/* ============================================================
   ROYAL MAISON CHARTER — Stylesheet
   Design tokens: Midnight Navy + Champagne Gold, instrument-panel motif
   ============================================================ */

:root{
  /* --- Color tokens --- */
  --navy-950:#080C18;
  --navy-900:#0A1122;
  --navy-800:#101A33;
  --navy-700:#16223F;
  --navy-line: rgba(198,161,91,0.18);
  --gold:#C6A15B;
  --gold-bright:#E7C583;
  --gold-dim: rgba(198,161,91,0.35);
  --ivory:#F4EFE4;
  --mist:#93A0BC;
  --mist-dim:#5C6784;
  --cream:#F4EFE4;
  --ink:#10182C;
  --ink-soft:#3B4359;
  --line-on-cream: rgba(16,24,44,0.12);
  --danger:#B4553F;

  /* --- Type --- */
  --font-display:'Marcellus', 'Georgia', serif;
  --font-body:'Jost', 'Helvetica Neue', Arial, sans-serif;
  --font-mono:'IBM Plex Mono', 'Courier New', monospace;

  /* --- Layout --- */
  --container: 1180px;
  --radius-s: 2px;
  --radius-m: 4px;
  --ease: cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; }
}

body{
  margin:0;
  background:var(--navy-900);
  color:var(--mist);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
input,select,textarea{ font-family:inherit; font-size:1rem; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 28px; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ivory);
  font-weight:400;
  line-height:1.15;
  margin:0;
}
.on-cream h1,.on-cream h2,.on-cream h3,.on-cream h4{ color:var(--ink); }

p{ margin:0; }

.eyebrow{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px;
  background:var(--gold);
  display:inline-block;
}

.visually-hidden{
  position:absolute; width:1px; height:1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap;
}

/* Icons */
.icon{ width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }
.icon-sm{ width:16px; height:16px; }
.icon-lg{ width:30px; height:30px; }

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 28px;
  font-family:var(--font-body);
  font-size:0.82rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  border-radius:var(--radius-s);
  border:1px solid transparent;
  transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn-gold{ background:var(--gold); color:var(--navy-950); border-color:var(--gold); }
.btn-gold:hover{ background:var(--gold-bright); border-color:var(--gold-bright); transform:translateY(-1px); }
.btn-outline{ background:transparent; color:var(--ivory); border-color:var(--gold-dim); }
.btn-outline:hover{ border-color:var(--gold); color:var(--gold-bright); }
.btn-outline-ink{ background:transparent; color:var(--ink); border-color:rgba(16,24,44,0.35); }
.btn-outline-ink:hover{ border-color:var(--ink); }
.btn-block{ width:100%; }
.btn[disabled]{ opacity:0.5; cursor:not-allowed; }

/* ============ HEADER / NAV ============ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(8,12,24,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--navy-line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:86px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{ color:var(--gold); }
.brand-text{
  font-family:var(--font-display);
  font-size:1.28rem;
  letter-spacing:0.03em;
  color:var(--ivory);
}
.brand-text em{ color:var(--gold); font-style:normal; }

.site-nav{ display:flex; align-items:center; gap:38px; }
.site-nav a{
  font-size:0.82rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--mist);
  position:relative;
  padding:6px 0;
  transition:color .2s var(--ease);
}
.site-nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--gold); transition:width .25s var(--ease);
}
.site-nav a:hover, .site-nav a.active{ color:var(--ivory); }
.site-nav a:hover::after, .site-nav a.active::after{ width:100%; }

.header-actions{ display:flex; align-items:center; gap:22px; }
.nav-toggle{
  display:none; background:none; border:none; color:var(--ivory); padding:8px;
}

@media (max-width:900px){
  .site-nav{
    position:fixed; inset:86px 0 0 0;
    background:var(--navy-950);
    flex-direction:column; justify-content:flex-start;
    padding:40px 28px; gap:26px;
    transform:translateX(100%);
    transition:transform .35s var(--ease);
  }
  .site-nav.open{ transform:translateX(0); }
  .site-nav a{ font-size:1rem; }
  .nav-toggle{ display:block; }
  .nav-cta{ display:none; }
}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:92vh;
  display:flex; align-items:center;
  overflow:hidden;
  background:
    radial-gradient(ellipse 900px 500px at 78% 15%, rgba(198,161,91,0.14), transparent 60%),
    linear-gradient(180deg,#080C18 0%, #0A1122 60%, #0D1630 100%);
}
.hero-compass{
  position:absolute; top:50%; right:-180px; transform:translateY(-50%);
  width:640px; height:640px; opacity:0.55;
  animation:spin 140s linear infinite;
}
@keyframes spin{ to{ transform:translateY(-50%) rotate(360deg); } }
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(var(--navy-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--navy-line) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(180deg, transparent, rgba(0,0,0,0.5) 40%, transparent 90%);
  opacity:0.5;
}
.hero-inner{ position:relative; z-index:2; max-width:720px; padding:120px 0 90px; }
.hero h1{
  font-size:clamp(2.6rem, 5.2vw, 4.4rem);
  margin-bottom:26px;
}
.hero h1 span{ color:var(--gold); }
.hero-lede{
  font-size:1.08rem; color:var(--mist); max-width:520px; margin-bottom:40px;
}
.hero-actions{ display:flex; gap:18px; flex-wrap:wrap; margin-bottom:64px; }
.hero-meta{
  display:flex; gap:40px; flex-wrap:wrap;
  border-top:1px solid var(--navy-line); padding-top:26px;
}
.hero-meta div{ display:flex; flex-direction:column; gap:4px; }
.hero-meta strong{ font-family:var(--font-mono); color:var(--gold-bright); font-size:1.5rem; }
.hero-meta span{ font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--mist-dim); }

/* ============ SECTIONS ============ */
section{ padding:110px 0; }
.section-tight{ padding:80px 0; }
.on-cream{ background:var(--cream); color:var(--ink-soft); }
.section-head{
  display:flex; justify-content:space-between; align-items:flex-end; gap:40px;
  margin-bottom:60px; flex-wrap:wrap;
}
.section-head h2{ font-size:clamp(1.9rem,3.2vw,2.7rem); max-width:600px; }
.section-head p{ max-width:380px; color:var(--mist); }
.on-cream .section-head p{ color:var(--ink-soft); }

.divider-instrument{
  display:flex; align-items:center; gap:16px;
  margin:0 auto 60px; max-width:var(--container); padding:0 28px;
  color:var(--gold);
}
.divider-instrument .line{ flex:1; height:1px; background:var(--navy-line); }
.divider-instrument span{
  font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.3em; text-transform:uppercase;
}

/* ============ FEATURE GRID ============ */
.feature-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--navy-line); border:1px solid var(--navy-line); }
.feature-card{ background:var(--navy-900); padding:38px 30px; }
.feature-card .icon{ color:var(--gold); margin-bottom:22px; }
.feature-card h3{ font-size:1.15rem; margin-bottom:12px; }
.feature-card p{ font-size:0.92rem; color:var(--mist); }
@media (max-width:960px){ .feature-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .feature-grid{ grid-template-columns:1fr; } }

/* ============ FLEET CARDS ============ */
.fleet-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:980px){ .fleet-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .fleet-grid{ grid-template-columns:1fr; } }

.fleet-card{
  background:linear-gradient(180deg,var(--navy-800), var(--navy-900));
  border:1px solid var(--navy-line);
  border-radius:var(--radius-m);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition:border-color .25s var(--ease), transform .25s var(--ease);
}
.fleet-card:hover{ border-color:var(--gold-dim); transform:translateY(-4px); }
.heli-art{ width:100%; height:auto; }
.fleet-art{
  position:relative;
  padding:34px 26px 10px;
  background:radial-gradient(ellipse at 30% 20%, rgba(198,161,91,0.12), transparent 60%);
  color:var(--gold);
}
.fleet-tag{
  position:absolute; top:20px; right:20px;
  font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold-dim); padding:4px 10px; border-radius:20px;
}
.fleet-body{ padding:8px 26px 30px; display:flex; flex-direction:column; flex:1; }
.fleet-body h3{ font-size:1.35rem; margin-bottom:4px; }
.fleet-model{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.08em; color:var(--mist-dim); margin-bottom:16px; }
.fleet-desc{ font-size:0.92rem; color:var(--mist); margin-bottom:24px; }
.spec-row{
  display:grid; grid-template-columns:repeat(4,1fr); gap:10px;
  border-top:1px solid var(--navy-line); padding-top:18px; margin-top:auto; margin-bottom:22px;
}
.spec{ display:flex; flex-direction:column; gap:6px; }
.spec .icon{ color:var(--gold); width:16px; height:16px; }
.spec strong{ font-family:var(--font-mono); font-size:0.95rem; color:var(--ivory); }
.spec span{ font-size:0.66rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--mist-dim); }
.fleet-features{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.fleet-features li{
  font-size:0.72rem; letter-spacing:0.03em; color:var(--mist);
  border:1px solid var(--navy-line); padding:6px 12px; border-radius:20px;
}

/* ============ STATS STRIP ============ */
.stats-strip{
  border-top:1px solid var(--navy-line); border-bottom:1px solid var(--navy-line);
  background:var(--navy-950);
}
.stats-strip .container{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:44px 20px; text-align:center; border-left:1px solid var(--navy-line); }
.stat:first-child{ border-left:none; }
.stat strong{ display:block; font-family:var(--font-mono); font-size:2rem; color:var(--gold-bright); margin-bottom:6px; }
.stat span{ font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--mist-dim); }
@media (max-width:760px){ .stats-strip .container{ grid-template-columns:repeat(2,1fr); } .stat:nth-child(3){ border-left:none; } }

/* ============ SERVICES / EXPERIENCE ============ */
.experience-grid{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:70px; align-items:center; }
@media (max-width:900px){ .experience-grid{ grid-template-columns:1fr; gap:40px; } }
.experience-list{ display:flex; flex-direction:column; }
.experience-item{
  display:flex; gap:22px; padding:26px 0; border-top:1px solid var(--navy-line);
}
.experience-item:last-child{ border-bottom:1px solid var(--navy-line); }
.experience-item .icon{ color:var(--gold); margin-top:4px; }
.experience-item h3{ font-size:1.1rem; margin-bottom:8px; }
.experience-item p{ font-size:0.9rem; color:var(--mist); }
.instrument-panel{
  border:1px solid var(--navy-line); border-radius:var(--radius-m);
  background:var(--navy-800); padding:36px;
  position:relative;
}
.instrument-panel::before{
  content:""; position:absolute; inset:10px; border:1px solid var(--gold-dim); border-radius:var(--radius-s); pointer-events:none;
}

/* ============ TESTIMONIAL ============ */
.testimonial{ text-align:center; max-width:760px; margin:0 auto; }
.testimonial .icon{ color:var(--gold); margin:0 auto 30px; }
.testimonial blockquote{
  font-family:var(--font-display); font-size:clamp(1.4rem,2.6vw,2rem); color:var(--ivory);
  line-height:1.5; margin-bottom:28px;
}
.testimonial cite{ font-style:normal; font-size:0.82rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--mist-dim); }

/* ============ CTA BANNER ============ */
.cta-banner{
  background:linear-gradient(120deg, var(--navy-800), var(--navy-950));
  border-top:1px solid var(--navy-line); border-bottom:1px solid var(--navy-line);
  padding:90px 0;
}
.cta-inner{ display:flex; justify-content:space-between; align-items:center; gap:40px; flex-wrap:wrap; }
.cta-inner h2{ max-width:520px; font-size:clamp(1.7rem,3vw,2.4rem); }

/* ============ FOOTER ============ */
.site-footer{ background:var(--navy-950); border-top:1px solid var(--navy-line); padding-top:80px; }
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:50px;
  padding-bottom:60px; border-bottom:1px solid var(--navy-line);
}
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-brand p{ font-size:0.88rem; color:var(--mist); margin:18px 0 26px; max-width:280px; }
.footer-social{ display:flex; gap:14px; }
.footer-social a{
  width:36px; height:36px; border:1px solid var(--navy-line); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:var(--mist);
  transition:all .2s var(--ease);
}
.footer-social a:hover{ color:var(--gold); border-color:var(--gold-dim); }
.footer-col h4{ font-size:0.78rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.footer-col ul{ display:flex; flex-direction:column; gap:12px; }
.footer-col a{ font-size:0.88rem; color:var(--mist); transition:color .2s var(--ease); }
.footer-col a:hover{ color:var(--ivory); }
.footer-contact li{ display:flex; gap:12px; font-size:0.88rem; color:var(--mist); align-items:flex-start; }
.footer-contact .icon{ color:var(--gold); margin-top:3px; }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
  padding:26px 0; font-size:0.76rem; color:var(--mist-dim); letter-spacing:0.02em;
}
.footer-bottom span{ font-family:var(--font-mono); }

/* ============ PAGE HEADER (interior pages) ============ */
.page-header{
  position:relative; padding:150px 0 80px; overflow:hidden;
  background:linear-gradient(180deg,#080C18 0%, #0A1122 100%);
  border-bottom:1px solid var(--navy-line);
}
.page-header .hero-grid{ opacity:0.35; }
.page-header-inner{ position:relative; z-index:2; max-width:640px; }
.page-header h1{ font-size:clamp(2.2rem,4vw,3.2rem); margin-bottom:18px; }
.page-header p{ color:var(--mist); font-size:1.02rem; }
.breadcrumb{
  display:flex; align-items:center; gap:8px; margin-bottom:22px;
  font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--mist-dim);
}
.breadcrumb a{ color:var(--mist-dim); }
.breadcrumb a:hover{ color:var(--gold); }

/* ============ BOOKING FORM ============ */
.booking-layout{ display:grid; grid-template-columns:1.4fr 1fr; gap:50px; align-items:flex-start; }
@media (max-width:960px){ .booking-layout{ grid-template-columns:1fr; } }

.form-card{
  background:var(--navy-800); border:1px solid var(--navy-line); border-radius:var(--radius-m);
  padding:44px;
}
.form-section-title{
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold);
  margin-bottom:26px;
}
.form-section-title:not(:first-child){ margin-top:40px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
@media (max-width:600px){ .form-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column:1/-1; }
.field label{ font-size:0.76rem; letter-spacing:0.06em; text-transform:uppercase; color:var(--mist-dim); }
.field input, .field select, .field textarea{
  background:var(--navy-900); border:1px solid var(--navy-line); border-radius:var(--radius-s);
  padding:13px 14px; color:var(--ivory); outline:none; transition:border-color .2s var(--ease);
}
.field input::placeholder, .field textarea::placeholder{ color:var(--mist-dim); }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--gold); }
.field textarea{ resize:vertical; min-height:100px; }
.radio-group{ display:flex; gap:10px; flex-wrap:wrap; }
.radio-chip{
  border:1px solid var(--navy-line); border-radius:20px; padding:10px 18px; font-size:0.82rem;
  color:var(--mist); cursor:pointer; transition:all .2s var(--ease); position:relative;
}
.radio-chip input{ position:absolute; opacity:0; inset:0; cursor:pointer; margin:0; }
.radio-chip.active{ border-color:var(--gold); color:var(--gold-bright); background:rgba(198,161,91,0.08); }
.form-note{ font-size:0.78rem; color:var(--mist-dim); margin-top:18px; }
.form-error{ color:var(--danger); font-size:0.8rem; margin-top:6px; display:none; }
.field.has-error input, .field.has-error select{ border-color:var(--danger); }
.field.has-error .form-error{ display:block; }

.brief-panel{
  position:sticky; top:110px;
  background:var(--navy-800); border:1px solid var(--gold-dim); border-radius:var(--radius-m);
  padding:34px;
}
.brief-panel h3{ font-size:1.1rem; margin-bottom:6px; }
.brief-sub{ font-size:0.8rem; color:var(--mist-dim); margin-bottom:26px; }
.brief-row{
  display:flex; justify-content:space-between; gap:12px;
  padding:14px 0; border-top:1px solid var(--navy-line);
  font-size:0.86rem;
}
.brief-row span:first-child{ color:var(--mist-dim); }
.brief-row span:last-child{ color:var(--ivory); font-family:var(--font-mono); text-align:right; }
.brief-panel .btn{ margin-top:26px; }
.brief-dial{ display:flex; justify-content:center; margin-bottom:24px; color:var(--gold); }

.confirm-panel{
  display:none; text-align:center; padding:50px 34px;
  background:var(--navy-800); border:1px solid var(--gold-dim); border-radius:var(--radius-m);
}
.confirm-panel.show{ display:block; }
.confirm-panel .icon-lg{ color:var(--gold); margin:0 auto 20px; }
.confirm-panel h3{ margin-bottom:12px; }
.confirm-panel p{ color:var(--mist); font-size:0.92rem; margin-bottom:24px; }
.confirm-ref{ font-family:var(--font-mono); color:var(--gold-bright); letter-spacing:0.08em; }

/* ============ ABOUT PAGE ============ */
.value-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:860px){ .value-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .value-grid{ grid-template-columns:1fr; } }
.value-card{ border:1px solid var(--navy-line); border-radius:var(--radius-m); padding:32px; }
.value-card .icon{ color:var(--gold); margin-bottom:20px; }
.value-card h3{ font-size:1.08rem; margin-bottom:10px; }
.value-card p{ font-size:0.9rem; color:var(--mist); }

.timeline{ position:relative; padding-left:40px; }
.timeline::before{ content:""; position:absolute; left:5px; top:6px; bottom:6px; width:1px; background:var(--navy-line); }
.timeline-item{ position:relative; padding-bottom:44px; }
.timeline-item:last-child{ padding-bottom:0; }
.timeline-item::before{
  content:""; position:absolute; left:-40px; top:4px; width:11px; height:11px; border-radius:50%;
  background:var(--navy-900); border:2px solid var(--gold);
}
.timeline-year{ font-family:var(--font-mono); color:var(--gold); font-size:0.85rem; letter-spacing:0.08em; margin-bottom:8px; display:block; }
.timeline-item h3{ font-size:1.15rem; margin-bottom:8px; }
.timeline-item p{ font-size:0.9rem; color:var(--mist); max-width:520px; }

.leader-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:860px){ .leader-grid{ grid-template-columns:1fr; } }
.leader-card{ text-align:center; }
.leader-avatar{
  width:100px; height:100px; border-radius:50%; margin:0 auto 18px;
  background:var(--navy-800); border:1px solid var(--gold-dim);
  display:flex; align-items:center; justify-content:center; color:var(--gold);
}
.leader-card h3{ font-size:1.05rem; margin-bottom:4px; }
.leader-card span{ font-size:0.76rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--mist-dim); }

/* ============ CONTACT PAGE ============ */
.contact-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-detail{ display:flex; gap:18px; padding:24px 0; border-top:1px solid var(--navy-line); }
.contact-detail:last-child{ border-bottom:1px solid var(--navy-line); }
.contact-detail .icon{ color:var(--gold); margin-top:2px; }
.contact-detail h3{ font-size:1rem; margin-bottom:6px; }
.contact-detail p{ font-size:0.9rem; color:var(--mist); }

.location-card{
  border:1px solid var(--navy-line); border-radius:var(--radius-m); padding:26px; display:flex; flex-direction:column; gap:6px;
}
.location-card strong{ color:var(--ivory); font-size:1rem; }
.location-card span{ font-family:var(--font-mono); font-size:0.76rem; color:var(--gold); }
.location-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:20px; }
@media (max-width:760px){ .location-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .location-grid{ grid-template-columns:1fr; } }

.compass-widget{
  aspect-ratio:1; border-radius:50%; border:1px solid var(--navy-line);
  display:flex; align-items:center; justify-content:center; color:var(--gold);
  background:radial-gradient(circle, rgba(198,161,91,0.08), transparent 70%);
}

.faq-item{ border-top:1px solid var(--navy-line); }
.faq-item:last-child{ border-bottom:1px solid var(--navy-line); }
.faq-q{
  width:100%; background:none; border:none; text-align:left; color:var(--ivory);
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:24px 0; font-size:1rem; font-family:var(--font-body);
}
.faq-q .icon{ color:var(--gold); transition:transform .25s var(--ease); flex-shrink:0; }
.faq-item.open .faq-q .icon{ transform:rotate(180deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s var(--ease); }
.faq-a p{ padding:0 0 24px; color:var(--mist); font-size:0.92rem; max-width:640px; }

/* ============ MISC UTILITIES ============ */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
@media (max-width:860px){ .grid-2{ grid-template-columns:1fr; gap:36px; } }
.tag-list{ display:flex; flex-wrap:wrap; gap:10px; }
.tag{ font-size:0.72rem; letter-spacing:0.06em; border:1px solid var(--navy-line); padding:6px 14px; border-radius:20px; color:var(--mist); }

.badge-strip{ display:flex; gap:40px; flex-wrap:wrap; align-items:center; opacity:0.85; }
.badge-strip div{ display:flex; align-items:center; gap:10px; font-size:0.8rem; color:var(--mist); }
.badge-strip .icon{ color:var(--gold); }

.toast{
  position:fixed; bottom:28px; right:28px; z-index:200;
  background:var(--navy-800); border:1px solid var(--gold-dim); border-radius:var(--radius-m);
  padding:16px 22px; display:flex; align-items:center; gap:12px; color:var(--ivory); font-size:0.88rem;
  transform:translateY(20px); opacity:0; pointer-events:none; transition:all .3s var(--ease);
}
.toast.show{ transform:translateY(0); opacity:1; }
.toast .icon{ color:var(--gold); }
