/* accommodation-booking-system.php — DESIGN.md Pattern A */

.seo-page {
  background:
    radial-gradient(circle at top left, rgba(29, 158, 117, 0.12), transparent 32rem),
    var(--bg-canvas);
  color: var(--text-body);
}

.seo-nav {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
  padding: var(--space-3) var(--container-padding-sm);
  background: color-mix(in srgb, var(--bg-canvas) 84%, transparent);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
}

.seo-nav__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-2);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.seo-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-heading);
  min-width: 0;
}

.seo-brand__logo {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  flex: 0 0 40px;
}

.seo-brand__logo img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.seo-brand__name {
  font-size: 18px;
  line-height: 1;
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  white-space: nowrap;
}

.seo-brand__dot {
  color: var(--brand-500);
}

.seo-nav__links {
  display: none;
  align-items: center;
  gap: var(--space-2);
}

.seo-nav__link,
.seo-menu__button {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: 0 var(--space-3);
  border-radius: var(--radius-md);
  color: var(--text-sub);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  border: 1px solid transparent;
}

.seo-nav__link:hover,
.seo-menu__button:hover,
.seo-nav__link.is-active {
  color: var(--brand-700);
  background: var(--brand-50);
  border-color: color-mix(in srgb, var(--brand-200) 60%, transparent);
}

.seo-menu {
  position: relative;
}

.seo-menu__panel {
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 0;
  width: min(22rem, calc(100vw - 2rem));
  padding: var(--space-2);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  display: none;
}

.seo-menu:hover .seo-menu__panel,
.seo-menu:focus-within .seo-menu__panel {
  display: block;
}

.seo-menu__item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  color: var(--text-body);
}

.seo-menu__item:hover {
  background: var(--bg-muted);
  color: var(--text-body);
}

.seo-menu__icon {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  background: var(--brand-50);
  color: var(--brand-700);
}

.seo-menu__title {
  display: block;
  color: var(--text-heading);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
}

.seo-menu__desc {
  display: block;
  margin-top: 2px;
  color: var(--text-sub);
  font-size: var(--text-cap);
  line-height: var(--leading-snug);
}

.seo-nav__actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.seo-nav__actions .btn {
  display: none;
}

.seo-theme,
.seo-burger {
  width: 42px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  border-radius: var(--radius-md);
  color: var(--text-body);
  background: var(--bg-muted);
  border: 1px solid var(--border);
}

.seo-burger {
  display: inline-grid;
}

.seo-mobile {
  display: none;
  max-width: var(--container-max);
  margin: var(--space-2) auto 0;
  padding: var(--space-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
}

.seo-mobile.is-open {
  display: grid;
  gap: var(--space-2);
}

.seo-mobile a {
  min-height: 44px;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-3);
  border-radius: var(--radius-md);
  color: var(--text-body);
  background: var(--bg-subtle);
}

.seo-mobile a.is-active {
  color: var(--brand-700);
  background: var(--brand-50);
}

.seo-hero {
  padding: clamp(4rem, 9vw, 7rem) var(--container-padding-sm) var(--space-14);
}

.seo-hero__inner,
.seo-section__inner,
.seo-footer__inner {
  width: min(1180px, 100%);
  margin: 0 auto;
}

.seo-hero__grid {
  display: grid;
  gap: var(--space-8);
  align-items: center;
}

.seo-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 34px;
  padding: 0 var(--space-3);
  color: var(--brand-700);
  background: var(--brand-50);
  border: 1px solid color-mix(in srgb, var(--brand-200) 70%, transparent);
  border-radius: var(--radius-full);
  font-size: var(--text-cap);
  font-weight: var(--weight-medium);
}

.seo-hero h1 {
  margin-top: var(--space-5);
  font-size: clamp(2rem, 7vw, 4.2rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.seo-lead {
  margin-top: var(--space-5);
  max-width: 42rem;
  color: var(--text-sub);
  font-size: clamp(1rem, 2.6vw, 1.2rem);
  line-height: var(--leading-relaxed);
}

.seo-hero__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.seo-proof {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.seo-proof__item {
  padding: var(--space-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
}

.seo-proof__num {
  display: block;
  color: var(--text-heading);
  font-size: 24px;
  font-weight: var(--weight-medium);
  line-height: 1.1;
}

.seo-proof__label {
  display: block;
  margin-top: var(--space-1);
  color: var(--text-sub);
  font-size: var(--text-cap);
  line-height: var(--leading-snug);
}

.seo-flow-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-lg);
}

.seo-flow-card__bar {
  height: 36px;
  display: flex;
  align-items: center;
  gap: 7px;
  margin: calc(-1 * var(--space-5)) calc(-1 * var(--space-5)) var(--space-5);
  padding: 0 var(--space-4);
  background: var(--bg-muted);
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  border-bottom: 1px solid var(--border);
}

.seo-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  background: var(--border-strong);
}

.seo-dot:nth-child(1) { background: #ff5f57; }
.seo-dot:nth-child(2) { background: #ffbd2e; }
.seo-dot:nth-child(3) { background: #28c840; }

.seo-flow {
  display: grid;
  gap: var(--space-3);
}

.seo-flow__step {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--bg-subtle);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.seo-flow__icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  color: var(--brand-700);
  background: var(--brand-50);
}

.seo-flow__step h2,
.seo-flow__step h3 {
  font-size: 16px;
  margin-bottom: 4px;
}

.seo-flow__step p {
  color: var(--text-sub);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}

.seo-section {
  padding: var(--space-14) var(--container-padding-sm);
}

.seo-section--muted {
  background: var(--bg-subtle);
  border-block: 1px solid var(--border);
}

.seo-section__header {
  max-width: 48rem;
  margin-bottom: var(--space-8);
}

.seo-section__kicker {
  color: var(--brand-700);
  font-size: var(--text-mini);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: var(--weight-medium);
}

.seo-section h2 {
  margin-top: var(--space-2);
  font-size: clamp(1.5rem, 4vw, 2.4rem);
  line-height: var(--leading-tight);
}

.seo-section__intro {
  margin-top: var(--space-3);
  color: var(--text-sub);
  line-height: var(--leading-relaxed);
}

.seo-grid {
  display: grid;
  gap: var(--space-4);
}

.seo-card {
  padding: var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xs);
}

.seo-card__icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  margin-bottom: var(--space-4);
  color: var(--brand-700);
  background: var(--brand-50);
  border-radius: var(--radius-lg);
}

.seo-card h3 {
  margin-bottom: var(--space-2);
  font-size: 17px;
}

.seo-card p,
.seo-card li {
  color: var(--text-sub);
  line-height: var(--leading-relaxed);
}

.seo-list {
  display: grid;
  gap: var(--space-2);
}

.seo-list li {
  position: relative;
  padding-left: var(--space-6);
}

.seo-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--brand-500);
}

.seo-readiness {
  display: grid;
  gap: var(--space-4);
}

.seo-readiness__panel {
  padding: var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xs);
}

.seo-readiness__icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  margin-bottom: var(--space-4);
  color: var(--brand-700);
  background: var(--brand-50);
  border-radius: var(--radius-lg);
}

.seo-readiness__panel h3 {
  margin-bottom: var(--space-3);
  font-size: 17px;
}

.seo-readiness__note {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--space-3);
  margin-top: var(--space-4);
  padding: var(--space-5);
  color: var(--text-body);
  background: var(--bg-subtle);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
}

.seo-readiness__note > span {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  color: var(--brand-700);
  background: var(--brand-50);
  border-radius: var(--radius-lg);
}

.seo-readiness__note h3 {
  margin-bottom: var(--space-2);
  font-size: 17px;
}

.seo-readiness__note p {
  color: var(--text-sub);
  line-height: var(--leading-relaxed);
}

.seo-steps {
  counter-reset: step;
  display: grid;
  gap: var(--space-3);
}

.seo-step {
  counter-increment: step;
  position: relative;
  padding: var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
}

.seo-step::before {
  content: counter(step);
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  margin-bottom: var(--space-3);
  color: #fff;
  background: var(--brand-500);
  border-radius: var(--radius-full);
  font-weight: var(--weight-medium);
}

.seo-faq {
  display: grid;
  gap: var(--space-3);
}

.seo-faq details {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.seo-faq summary {
  cursor: pointer;
  color: var(--text-heading);
  font-weight: var(--weight-medium);
}

.seo-faq p {
  margin-top: var(--space-3);
  color: var(--text-sub);
  line-height: var(--leading-relaxed);
}

.seo-cta {
  padding: var(--space-14) var(--container-padding-sm);
}

.seo-cta__box {
  width: min(980px, 100%);
  margin: 0 auto;
  padding: clamp(var(--space-6), 6vw, var(--space-14));
  background: linear-gradient(135deg, var(--brand-900), var(--brand-700));
  color: #fff;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
}

.seo-cta__box h2 {
  color: #fff;
  font-size: clamp(1.5rem, 5vw, 2.6rem);
  line-height: var(--leading-tight);
}

.seo-cta__box p {
  margin-top: var(--space-3);
  color: color-mix(in srgb, #fff 82%, transparent);
}

.seo-cta__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.seo-footer {
  padding: var(--space-10) var(--container-padding-sm);
  border-top: 1px solid var(--border);
  background: var(--bg-canvas);
}

.seo-footer__inner {
  display: grid;
  gap: var(--space-4);
  color: var(--text-sub);
  font-size: var(--text-sm);
}

.seo-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.seo-footer__links a {
  color: var(--text-sub);
}

.seo-footer__links a:hover {
  color: var(--brand-700);
}

html.dark .seo-page {
  background:
    radial-gradient(circle at top left, rgba(46, 178, 134, 0.16), transparent 32rem),
    var(--bg-canvas);
}

html.dark .seo-nav {
  background: color-mix(in srgb, var(--bg-canvas) 86%, transparent);
}

html.dark .seo-cta__box {
  background: linear-gradient(135deg, #04342c, #0f6e56);
}

@media (min-width: 640px) {
  .seo-hero__actions,
  .seo-cta__actions {
    flex-direction: row;
  }

  .seo-proof {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

}

@media (min-width: 920px) {
  .seo-nav {
    padding-inline: var(--container-padding-lg);
  }

  .seo-nav__links {
    display: flex;
  }

  .seo-nav__actions .btn {
    display: inline-flex;
  }

  .seo-burger {
    display: none;
  }

  .seo-hero {
    padding-inline: var(--container-padding-lg);
  }

  .seo-hero__grid {
    grid-template-columns: 1.05fr 0.95fr;
  }

  .seo-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .seo-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .seo-readiness {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .seo-steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .seo-section {
    padding-inline: var(--container-padding-lg);
  }

  .seo-footer__inner {
    grid-template-columns: 1fr auto;
    align-items: center;
  }
}

@media (max-width: 380px) {
  .seo-brand__name {
    max-width: 8rem;
    overflow: hidden;
  }
}
