/* ============================================================================
   SARA JOURNEYS — brand system
   Dark warm ground · gold + cream accents · editorial serif + humanist grotesk
   CSS variables drive the Tweaks panel (palette / type / density).
   ============================================================================ */

:root{
  /* — palette (overridable by Tweaks) — */
  --gold:        #c9a86a;
  --gold-bright: #ddc189;
  --cream:       #e7d8bf;

  /* — ground (warm browns; softer than near-black) — */
  --bg:    #271d11;
  --bg-2:  #2f2316;
  --bg-3:  #38291a;
  --raise: #46341f;
  --text:  #ece3d3;
  --muted: #a3937a;
  --faint: #6f6451;
  --line:  rgba(201,168,106,.16);
  --line-2:rgba(201,168,106,.28);

  /* — type (display family overridable by Tweaks) — */
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;

  /* — density (overridable by Tweaks) — */
  --pad-section: 132px;
  --gap-card: 22px;
  --radius: 4px;

  --maxw: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--sans); font-weight:400; font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body[data-view="itinerary"]{ overflow:hidden; }
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }
a{ color:inherit; text-decoration:none; }

/* ── Type primitives ───────────────────────────────────────────── */
.display{ font-family:var(--serif); font-weight:400; line-height:1.02;
  letter-spacing:-.01em; }
.eyebrow{
  font-size:12px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold); font-weight:600; margin:0 0 22px;
}
.eyebrow--light{ color:var(--gold-bright); }

/* ── Buttons ───────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:.6em; justify-content:center;
  font-family:var(--sans); font-size:14.5px; font-weight:500; letter-spacing:.02em;
  padding:13px 26px; border-radius:var(--radius); border:1px solid transparent;
  background:none; color:var(--text); transition:all .4s var(--ease); white-space:nowrap;
}
.btn--solid{ background:var(--gold); color:#1a1206; border-color:var(--gold); font-weight:600; }
.btn--solid:hover{ background:var(--gold-bright); transform:translateY(-1px); }
.btn--line{ border-color:var(--line-2); color:var(--cream); }
.btn--line:hover{ border-color:var(--gold); background:rgba(201,168,106,.06); }
.btn--ghost{ border-color:var(--line-2); color:var(--cream); padding:10px 20px; }
.btn--ghost:hover{ border-color:var(--gold); }
.btn--lg{ padding:17px 34px; font-size:15.5px; }
.btn__arrow{ transition:transform .4s var(--ease); }
.btn--lg:hover .btn__arrow{ transform:translateX(5px); }
.btn:disabled{ opacity:.45; pointer-events:none; }

/* ── Brand ─────────────────────────────────────────────────────── */
.brand{ display:flex; align-items:center; gap:12px; }
.brand__mark{
  width:26px; height:26px; border:1px solid var(--gold);
  position:relative; transform:rotate(45deg); border-radius:2px;
}
.brand__mark::after{
  content:""; position:absolute; inset:6px; background:var(--gold); border-radius:1px;
}
.brand__word{
  font-family:var(--serif); font-size:23px; font-weight:500; letter-spacing:.02em;
  color:var(--cream); line-height:1; white-space:nowrap;
}
.brand__word em{ font-style:italic; color:var(--gold); font-weight:400; margin-left:.02em; }

/* ════════════════════════ NAV ════════════════════════ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .5s var(--ease), border-color .5s var(--ease), backdrop-filter .5s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(18,13,8,.82); backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--line);
}
.nav__inner{
  max-width:var(--maxw); margin:0 auto; padding:20px 40px;
  display:flex; align-items:center; gap:34px;
}
.nav__links{ margin-left:auto; display:flex; gap:34px; }
.nav__links a{
  font-size:13.5px; letter-spacing:.04em; color:var(--muted);
  transition:color .3s; position:relative;
}
.nav__links a:hover{ color:var(--cream); }
.nav__cta{ flex:none; }

/* ════════════════════════ HERO ════════════════════════ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding:0 40px 12vh; overflow:hidden; }
.hero .hero__media{ position:absolute; inset:0; }
.hero__veil{
  position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(22,15,9,.26) 0%, rgba(22,15,9,.04) 34%, rgba(22,15,9,.52) 80%, var(--bg) 100%),
    radial-gradient(120% 88% at 16% 92%, rgba(22,15,9,.72), transparent 56%);
}
.hero__content{ position:relative; max-width:var(--maxw); margin:0 auto; width:100%; }
.hero__title{ font-size:clamp(46px, 7.4vw, 110px); margin:0 0 28px; color:#fff;
  text-shadow:0 2px 40px rgba(0,0,0,.35); }
.hero__lede{ max-width:540px; font-size:clamp(17px,1.5vw,20px); color:var(--cream);
  margin:0 0 38px; line-height:1.62; text-wrap:pretty; }
.hero__actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero__scroll{
  position:absolute; left:50%; bottom:30px; transform:translateX(-50%);
  width:26px; height:42px; border:1px solid var(--line-2); border-radius:13px;
  background:none; display:grid; place-items:center;
}
.hero__scroll span{ width:3px; height:8px; border-radius:2px; background:var(--gold);
  animation:scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot{ 0%{opacity:0; transform:translateY(-5px);} 40%{opacity:1;} 100%{opacity:0; transform:translateY(8px);} }

/* ════════════════════════ SECTIONS ════════════════════════ */
.section{ padding:var(--pad-section) 40px; max-width:var(--maxw); margin:0 auto; }
.section__head{ max-width:680px; margin:0 auto var(--gap-card); text-align:center; }
.section__head--left{ margin-left:0; text-align:left; }
.section__title{ font-size:clamp(34px,4.4vw,60px); margin:0 0 22px; color:var(--cream); }
.section__sub{ color:var(--muted); font-size:18px; line-height:1.65; text-wrap:pretty; margin:0; }

/* ── Media block (real photo w/ duotone fallback placeholder) ── */
.media{ position:relative; overflow:hidden; background:var(--bg-3);
  --h1:32; --h2:46; }
.media[data-theme="dune"]{ --h1:34; --h2:48; }
.media[data-theme="sea"]{ --h1:188; --h2:205; }
.media[data-theme="neom"]{ --h1:248; --h2:280; }
.media[data-theme="night"]{ --h1:250; --h2:268; }
.media[data-theme="spa"]{ --h1:150; --h2:135; }
.media[data-theme="dining"]{ --h1:24; --h2:14; }
.media[data-theme="heritage"]{ --h1:36; --h2:28; }
.media__ph{ position:absolute; inset:0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 2px, transparent 2px 11px),
    linear-gradient(150deg,
      hsl(var(--h1) 38% 26%) 0%,
      hsl(var(--h2) 30% 14%) 100%);
}
.media__ph::after{
  content:attr(data-label); position:absolute; left:16px; bottom:14px; right:16px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:10.5px;
  letter-spacing:.08em; text-transform:uppercase; color:rgba(231,216,191,.6);
}
.media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity 1s var(--ease); }
.media img.loaded{ opacity:1; }

/* ── Destinations grid ── */
.dest-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap-card); }
.dest-card{ position:relative; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; background:var(--bg-2); transition:border-color .5s, transform .5s var(--ease); }
.dest-card:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.dest-card .media{ aspect-ratio:3/4; }
.dest-card__veil{ position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 36%,rgba(15,11,7,.18) 55%,rgba(15,11,7,.92) 100%); }
.dest-card__body{ position:absolute; inset:auto 0 0 0; padding:26px; }
.dest-card__idx{ font-family:ui-monospace,monospace; font-size:11px; letter-spacing:.2em;
  color:var(--gold); margin:0 0 10px; }
.dest-card__name{ font-family:var(--serif); font-size:33px; color:#fff; margin:0 0 6px; line-height:1; }
.dest-card__tag{ font-size:13.5px; color:var(--cream); margin:0; opacity:.85; }

/* ── Method ── */
.method__steps{ list-style:none; margin:48px 0 0; padding:0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:48px; }
.method__steps li{ border-top:1px solid var(--line-2); padding-top:26px; }
.method__num{ font-family:var(--serif); font-size:40px; color:var(--gold); display:block; margin-bottom:18px; }
.method__steps h3{ font-family:var(--sans); font-weight:600; font-size:18px; color:var(--cream); margin:0 0 10px; }
.method__steps p{ color:var(--muted); font-size:15.5px; margin:0; line-height:1.6; }

/* ════════════════════════ FORM ════════════════════════ */
.engine{ }
.engine__frame{
  background:linear-gradient(180deg,var(--bg-2),var(--bg-3));
  border:1px solid var(--line); border-radius:8px;
  padding:clamp(34px,5vw,72px);
}
.form{ display:flex; flex-direction:column; gap:30px; margin-top:8px; }
.field{ display:flex; flex-direction:column; gap:11px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.field__label{ font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); font-weight:600; }
.field__opt{ color:var(--faint); font-style:normal; letter-spacing:.06em; text-transform:none; font-weight:400; }
.field__hint{ font-size:13px; color:var(--faint); }
.field input, .field textarea{
  width:100%; background:rgba(0,0,0,.22); border:1px solid var(--line);
  border-radius:var(--radius); color:var(--text); font-family:var(--sans);
  font-size:16px; padding:14px 16px; transition:border-color .3s, background .3s;
}
.field input::placeholder, .field textarea::placeholder{ color:var(--faint); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold);
  background:rgba(0,0,0,.34); }
.field textarea{ resize:vertical; line-height:1.6; }
input[type="date"]{ color-scheme:dark; }

/* choice grid (destinations as radio cards) */
.choice-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.choice{ position:relative; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; text-align:left; background:var(--bg-3); transition:border-color .35s, transform .35s; }
.choice .media{ aspect-ratio:16/10; }
.choice__veil{ position:absolute; inset:0; background:linear-gradient(180deg,transparent 30%,rgba(12,9,5,.9)); }
.choice__name{ position:absolute; left:14px; bottom:11px; right:14px;
  font-family:var(--serif); font-size:22px; color:#fff; line-height:1.05; }
.choice__check{ position:absolute; top:11px; right:11px; width:22px; height:22px; border-radius:50%;
  border:1px solid var(--line-2); background:rgba(12,9,5,.5); display:grid; place-items:center;
  opacity:0; transform:scale(.7); transition:.3s var(--ease); }
.choice__check::after{ content:"✓"; font-size:12px; color:#1a1206; }
.choice:hover{ border-color:var(--line-2); }
.choice.is-active{ border-color:var(--gold); transform:translateY(-2px); }
.choice.is-active .choice__check{ opacity:1; transform:scale(1); background:var(--gold); }

/* segmented control */
.seg{ display:inline-flex; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; align-self:flex-start; }
.seg__opt{ background:none; color:var(--muted); padding:13px 22px; font-size:14.5px;
  border:none; border-right:1px solid var(--line); transition:.3s; }
.seg__opt:last-child{ border-right:none; }
.seg__opt:hover{ color:var(--cream); }
.seg__opt.is-active{ background:var(--gold); color:#1a1206; font-weight:600; }

/* chips */
.chips{ display:flex; flex-wrap:wrap; gap:12px; }
.chip{ background:none; border:1px solid var(--line); color:var(--muted);
  padding:11px 22px; border-radius:40px; font-size:14.5px; transition:.3s var(--ease); }
.chip:hover{ border-color:var(--line-2); color:var(--cream); }
.chip.is-active{ background:rgba(201,168,106,.12); border-color:var(--gold); color:var(--gold-bright); }

.form__foot{ display:flex; align-items:center; justify-content:space-between; gap:20px;
  border-top:1px solid var(--line); padding-top:28px; margin-top:4px; flex-wrap:wrap; }
.form__note{ font-size:13.5px; color:var(--gold); margin:0; min-height:1em; }
.form__note.is-error{ color:#d98a6a; }

/* ════════════════════════ FOOTER ════════════════════════ */
.foot{ border-top:1px solid var(--line); padding:34px 40px; max-width:var(--maxw);
  margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.brand__word--foot{ font-size:19px; }
.foot__fine{ font-size:12.5px; color:var(--faint); letter-spacing:.04em; }

/* ════════════════════════ ITINERARY VIEW ════════════════════════ */
.itinerary{ position:fixed; inset:0; z-index:40; background:var(--bg);
  display:none; flex-direction:column; opacity:0; transition:opacity .6s var(--ease); }
body[data-view="itinerary"] .itinerary{ display:flex; opacity:1; }
/* the landing nav is fixed at a higher z-index than the overlays, so hide it
   once we leave the landing view (prototype intent: nav is landing-only) */
body[data-view="itinerary"] .nav,
body[data-view="summary"] .nav{ display:none; }

.itin-top{ display:flex; align-items:center; gap:24px; padding:18px 32px;
  border-bottom:1px solid var(--line); background:var(--bg-2); flex:none; }
.itin-top__brief{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.itin-top__name{ font-family:var(--serif); font-size:25px; color:var(--cream); line-height:1; }
.itin-top__meta{ font-size:13px; color:var(--muted); letter-spacing:.02em; }
.itin-top__meta b{ color:var(--gold); font-weight:600; }
.itin-top__actions{ margin-left:auto; display:flex; gap:12px; flex:none; }

.itin-body{ flex:1; min-height:0; display:grid; grid-template-columns:1fr 372px; }
.itin-main{ overflow-y:auto; padding:36px 40px 80px; }
.itin-main__head{ display:flex; align-items:flex-end; justify-content:space-between;
  gap:20px; margin-bottom:30px; flex-wrap:wrap; }
.itin-main__title{ font-family:var(--serif); font-size:clamp(30px,3.4vw,46px);
  color:var(--cream); line-height:1; margin:0; }
.itin-main__sub{ color:var(--muted); font-size:14.5px; margin:8px 0 0; }

/* day rail */
.day-rail{ display:flex; gap:10px; flex-wrap:wrap; }
.day-pill{ border:1px solid var(--line); background:var(--bg-2); color:var(--muted);
  border-radius:var(--radius); padding:10px 16px; font-size:13px; letter-spacing:.05em;
  display:flex; flex-direction:column; gap:2px; align-items:flex-start; transition:.3s; min-width:84px; }
.day-pill b{ font-family:var(--serif); font-size:19px; color:var(--cream); font-weight:500; }
.day-pill span{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; }
.day-pill:hover{ border-color:var(--line-2); }
.day-pill.is-active{ border-color:var(--gold); background:rgba(201,168,106,.1); }
.day-pill.is-active b{ color:var(--gold-bright); }

/* timeline of activity cards */
.timeline{ margin-top:34px; display:flex; flex-direction:column; gap:var(--gap-card); }
.acard{ display:grid; grid-template-columns:236px 1fr; border:1px solid var(--line);
  border-radius:6px; overflow:hidden; background:var(--bg-2);
  transition:border-color .5s, transform .5s var(--ease), box-shadow .5s; }
.acard:hover{ border-color:var(--line-2); }
.acard .media{ min-height:194px; }
.acard__body{ padding:26px 28px; display:flex; flex-direction:column; }
.acard__slot{ display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.acard__time{ font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
  font-weight:600; }
.acard__dot{ width:4px; height:4px; border-radius:50%; background:var(--faint); }
.acard__clock{ font-size:12px; color:var(--faint); letter-spacing:.04em; }
.acard__title{ font-family:var(--serif); font-size:27px; color:var(--cream); line-height:1.05; margin:0 0 6px; }
.acard__place{ font-size:13px; color:var(--gold); letter-spacing:.04em; margin:0 0 12px; }
.acard__place::before{ content:"⌖  "; opacity:.7; }
.acard__desc{ color:var(--muted); font-size:15px; line-height:1.62; margin:0 0 16px; text-wrap:pretty; }
.acard__foot{ margin-top:auto; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.tag{ font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--cream);
  border:1px solid var(--line); border-radius:30px; padding:5px 12px; }
.tag--style{ color:var(--gold-bright); border-color:var(--line-2); }
@keyframes swapflash{ 0%{ box-shadow:0 0 0 0 rgba(201,168,106,.6); border-color:var(--gold);}
  100%{ box-shadow:0 0 0 22px rgba(201,168,106,0); } }
.acard.is-swapped{ animation:swapflash 1.1s var(--ease); border-color:var(--gold); }
/* "Open time" — a deliberate, restful gap in the day; Layla can fill it on request */
.acard--open{ grid-template-columns:1fr; background:transparent; border-style:dashed;
  border-color:var(--line-2); }
.acard--open:hover{ border-color:var(--gold); transform:none; }
.acard--open .acard__title{ color:var(--muted); font-style:italic; font-size:23px; }
.acard--open .acard__desc{ color:var(--faint); }
.acard--open .tag{ color:var(--gold); border-color:var(--line-2); }

/* ════════════════════════ AI BUTLER ════════════════════════ */
.butler{ border-left:1px solid var(--line); background:var(--bg-2);
  display:flex; flex-direction:column; min-height:0; }
.butler__head{ padding:22px 24px; border-bottom:1px solid var(--line); flex:none; }
.butler__title{ display:flex; align-items:center; gap:11px; }
.butler__title .brand__mark{ width:18px; height:18px; }
.butler__title h3{ font-family:var(--serif); font-size:21px; color:var(--cream); margin:0; font-weight:500; }
.butler__sub{ font-size:12.5px; color:var(--muted); margin:8px 0 0; line-height:1.5; }
.butler__log{ flex:1; overflow-y:auto; padding:22px 24px; display:flex; flex-direction:column; gap:16px; }
.msg{ max-width:90%; font-size:14.5px; line-height:1.55; }
.msg__role{ font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold);
  margin-bottom:6px; }
.msg--butler{ align-self:flex-start; }
.msg--butler .msg__bubble{ background:var(--bg-3); border:1px solid var(--line);
  border-radius:3px 13px 13px 13px; padding:13px 16px; color:var(--cream); }
.msg--guest{ align-self:flex-end; text-align:right; }
.msg--guest .msg__role{ color:var(--muted); }
.msg--guest .msg__bubble{ background:rgba(201,168,106,.12); border:1px solid var(--line-2);
  border-radius:13px 3px 13px 13px; padding:13px 16px; color:var(--cream); }
.msg__bubble em{ color:var(--gold-bright); font-style:normal; font-weight:600; }
.typing{ display:inline-flex; gap:5px; }
.typing span{ width:6px; height:6px; border-radius:50%; background:var(--gold); opacity:.5;
  animation:typing 1.1s infinite; }
.typing span:nth-child(2){ animation-delay:.15s; } .typing span:nth-child(3){ animation-delay:.3s; }
@keyframes typing{ 0%,60%,100%{ transform:translateY(0); opacity:.4;} 30%{ transform:translateY(-4px); opacity:1;} }

.butler__suggest{ padding:0 24px 12px; display:flex; gap:8px; flex-wrap:wrap; flex:none; }
.sugg{ font-size:12px; color:var(--muted); border:1px solid var(--line); border-radius:30px;
  padding:7px 13px; background:none; transition:.3s; }
.sugg:hover{ border-color:var(--gold); color:var(--gold-bright); }
.butler__compose{ padding:16px 24px 22px; border-top:1px solid var(--line); flex:none;
  display:flex; gap:10px; align-items:flex-end; }
.butler__compose textarea{ flex:1; resize:none; background:rgba(0,0,0,.25); border:1px solid var(--line);
  border-radius:var(--radius); color:var(--text); font-family:var(--sans); font-size:14.5px;
  padding:12px 14px; line-height:1.5; max-height:120px; }
.butler__compose textarea:focus{ outline:none; border-color:var(--gold); }
.butler__send{ flex:none; width:46px; height:46px; border-radius:var(--radius); border:none;
  background:var(--gold); color:#1a1206; font-size:18px; display:grid; place-items:center;
  transition:.3s; }
.butler__send:hover{ background:var(--gold-bright); }
.butler__send:disabled{ opacity:.4; pointer-events:none; }

/* butler mobile toggle */
.butler-fab{ display:none; }

/* ════════════════════════ SUMMARY / EMAIL ════════════════════════ */
.summary-overlay{ position:fixed; inset:0; z-index:80; background:rgba(8,6,4,.86);
  backdrop-filter:blur(6px); display:none; align-items:flex-start; justify-content:center;
  overflow-y:auto; padding:48px 24px; }
body[data-view="summary"] .summary-overlay{ display:flex; }
.summary{ width:100%; max-width:720px; background:#f7f0e4; color:#2a2114;
  border-radius:6px; overflow:hidden; box-shadow:0 40px 120px rgba(0,0,0,.6);
  animation:summaryin .6s var(--ease); }
@keyframes summaryin{ from{ opacity:0; transform:translateY(24px);} to{ opacity:1; transform:none;} }
.summary__bar{ display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px; background:#2a2114; color:var(--cream); }
.summary__bar .brand__word{ font-size:17px; color:var(--cream); }
.summary__close{ background:none; border:1px solid rgba(231,216,191,.3); color:var(--cream);
  border-radius:3px; width:32px; height:32px; font-size:16px; }
.summary__doc{ padding:54px 56px 46px; }
.summary__letter{ font-size:12px; letter-spacing:.3em; text-transform:uppercase;
  color:#9c7b3e; font-weight:600; margin:0 0 28px; }
.summary__hi{ font-family:var(--serif); font-size:18px; color:#5b4a2e; margin:0 0 6px; }
.summary__title{ font-family:var(--serif); font-size:42px; line-height:1.05; color:#2a2114; margin:0 0 26px; }
.summary__facts{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px 30px;
  border-top:1px solid #d8c8a8; border-bottom:1px solid #d8c8a8; padding:24px 0; margin-bottom:30px; }
.summary__fact span{ font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  color:#9c7b3e; font-weight:600; display:block; margin-bottom:5px; }
.summary__fact b{ font-family:var(--serif); font-size:20px; font-weight:500; color:#2a2114; }
.summary__days{ display:flex; flex-direction:column; gap:0; }
.sday{ border-bottom:1px solid #e3d6bb; padding:18px 0; }
.sday:last-child{ border-bottom:none; }
.sday__h{ display:flex; align-items:baseline; gap:12px; margin-bottom:12px; }
.sday__n{ font-family:var(--serif); font-size:23px; color:#9c7b3e; }
.sday__label{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#8a7752; }
.sline{ display:grid; grid-template-columns:96px 1fr; gap:14px; padding:6px 0; font-size:14.5px; }
.sline__t{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#9c7b3e;
  font-weight:600; padding-top:3px; }
.sline__c b{ display:block; font-family:var(--serif); font-size:17px; color:#2a2114; font-weight:500; }
.sline__c span{ color:#6f5c3b; font-size:13px; }
.summary__foot{ margin-top:34px; padding-top:22px; border-top:1px solid #d8c8a8;
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.summary__sig{ font-family:var(--serif); font-style:italic; font-size:17px; color:#5b4a2e; }
.summary__ref{ font-family:ui-monospace,monospace; font-size:11.5px; color:#9c7b3e; letter-spacing:.08em; }
.summary__actions{ display:flex; gap:12px; padding:0 56px 40px; }
.btn--dark{ background:#2a2114; color:var(--cream); border-color:#2a2114; }
.btn--dark:hover{ background:#3a2e1c; }
.btn--paper{ border-color:#caa05a; color:#6f5320; }
.btn--paper:hover{ background:rgba(156,123,62,.08); }

/* ════════════════════════ TOAST ════════════════════════ */
.toast{ position:fixed; bottom:30px; left:50%; transform:translate(-50%,20px);
  background:var(--bg-3); border:1px solid var(--gold); color:var(--cream);
  padding:13px 22px; border-radius:var(--radius); font-size:14px; z-index:120;
  opacity:0; pointer-events:none; transition:.4s var(--ease); }
.toast.is-on{ opacity:1; transform:translate(-50%,0); }

/* ════════════════════════ REVEAL ════════════════════════ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

/* ════════════════════════ TWEAKS PANEL ════════════════════════ */
.tweaks{ position:fixed; top:84px; right:22px; z-index:200; width:268px;
  background:rgba(24,18,11,.96); backdrop-filter:blur(16px); border:1px solid var(--line-2);
  border-radius:8px; box-shadow:0 30px 80px rgba(0,0,0,.5); display:none;
  font-family:var(--sans); color:var(--text); overflow:hidden; }
.tweaks.is-open{ display:block; }
.tweaks__bar{ display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid var(--line); cursor:grab; }
.tweaks__bar h4{ margin:0; font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); }
.tweaks__x{ background:none; border:none; color:var(--muted); font-size:17px; line-height:1; }
.tweaks__body{ padding:16px; display:flex; flex-direction:column; gap:20px; }
.tw-sec{ display:flex; flex-direction:column; gap:10px; }
.tw-sec__label{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.tw-swatches{ display:flex; gap:9px; }
.tw-sw{ flex:1; height:40px; border-radius:4px; border:1px solid var(--line); position:relative;
  overflow:hidden; display:flex; }
.tw-sw i{ flex:1; display:block; }
.tw-sw.is-active{ border-color:var(--cream); box-shadow:0 0 0 2px rgba(231,216,191,.3); }
.tw-radio{ display:flex; border:1px solid var(--line); border-radius:5px; overflow:hidden; }
.tw-radio button{ flex:1; background:none; border:none; border-right:1px solid var(--line);
  color:var(--muted); padding:9px 4px; font-size:12px; transition:.25s; }
.tw-radio button:last-child{ border-right:none; }
.tw-radio button.is-active{ background:var(--gold); color:#1a1206; font-weight:600; }

/* ════════════════════════ RESPONSIVE ════════════════════════ */
@media (max-width:980px){
  .nav__links{ display:none; }
  .dest-grid{ grid-template-columns:1fr; }
  .method__steps{ grid-template-columns:1fr; gap:30px; }
  .field-row{ grid-template-columns:1fr; }
  .choice-grid{ grid-template-columns:1fr; }
  .itin-body{ grid-template-columns:1fr; }
  .butler{ position:fixed; inset:auto 0 0 0; height:74vh; border-left:none;
    border-top:1px solid var(--line-2); border-radius:14px 14px 0 0; transform:translateY(110%);
    transition:transform .5s var(--ease); z-index:50; }
  .butler.is-open{ transform:none; }
  .butler-fab{ display:grid; place-items:center; position:fixed; right:18px; bottom:18px; z-index:55;
    width:58px; height:58px; border-radius:50%; background:var(--gold); color:#1a1206; border:none;
    box-shadow:0 12px 30px rgba(0,0,0,.4); font-size:22px; }
  .acard{ grid-template-columns:1fr; }
  .acard .media{ aspect-ratio:16/9; min-height:0; }
  .summary__doc{ padding:36px 26px; }
  .summary__actions{ padding:0 26px 30px; }
  .summary__facts{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .section{ padding:84px 22px; }
  .hero{ padding:0 22px 14vh; }
  .nav__inner{ padding:16px 22px; }
  .summary__facts{ grid-template-columns:1fr; }
  .sline{ grid-template-columns:74px 1fr; }
}

/* ════════════════════════ PRINT (summary → PDF) ════════════════════════ */
@media print{
  body{ background:#fff; }
  body * { visibility:hidden; }
  .summary, .summary *{ visibility:visible; }
  .summary{ position:absolute; inset:0; margin:0; max-width:none; box-shadow:none; border-radius:0; }
  .summary__bar, .summary__actions, .summary__close{ display:none !important; }
  .summary__doc{ padding:40px; }
}
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}
