/* =========================================================
   백운산 1박 2일 — Design System
   Restrained nature palette · hairline structure · no decorative gradients
   ========================================================= */

:root{
  /* Surfaces */
  --paper:#F4F1EA;
  --paper-2:#EEEAE0;
  --surface:#FFFFFF;
  --surface-2:#FAF8F3;

  /* Ink */
  --ink:#1B1A16;
  --ink-2:#454339;
  --muted:#7C7A6F;
  --faint:#A7A498;

  /* Hairlines */
  --line:rgba(27,26,22,.10);
  --line-2:rgba(27,26,22,.16);

  /* Brand — solid, no gradients */
  --forest:#2C5E47;
  --forest-deep:#173A2C;
  --forest-soft:#E7EFE9;
  --clay:#B05E33;
  --clay-soft:#F3E7DB;
  --crimson:#A33627;
  --crimson-soft:#F5E3DF;
  --gold:#9C7413;
  --gold-soft:#F1E8CE;
  --kakao:#FEE500;

  /* Elevation — whisper-soft */
  --sh-xs:0 1px 2px rgba(27,26,22,.05);
  --sh-sm:0 2px 8px rgba(27,26,22,.05);
  --sh-md:0 8px 28px rgba(27,26,22,.07);

  /* Radius */
  --r-xs:8px; --r-sm:12px; --r:16px; --r-lg:20px; --r-xl:26px;

  /* Rhythm */
  --pad:clamp(20px,4vw,30px);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Pretendard Variable",Pretendard,-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Noto Sans KR",system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  font-size:15.5px;
  letter-spacing:-0.011em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
b,strong{font-weight:700}
::selection{background:var(--forest);color:#fff}

.wrap{width:min(1080px,calc(100% - 40px));margin:0 auto}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* =========================================================
   Sticky nav
   ========================================================= */
.nav{
  position:sticky;top:0;z-index:40;
  background:color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter:saturate(150%) blur(16px);
  -webkit-backdrop-filter:saturate(150%) blur(16px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;gap:14px;height:54px}
.brand{
  display:flex;align-items:center;gap:9px;flex-shrink:0;
  font-weight:800;font-size:15px;letter-spacing:-0.03em;color:var(--ink);
  white-space:nowrap;
}
.brand .leaf{
  width:26px;height:26px;border-radius:8px;flex-shrink:0;
  background:var(--forest);color:#fff;
  display:grid;place-items:center;
}
.brand .leaf svg{width:15px;height:15px}
.nav-links{
  display:flex;gap:2px;overflow-x:auto;margin-left:auto;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.nav-links::-webkit-scrollbar{display:none}
.nav-links a{
  position:relative;white-space:nowrap;
  padding:8px 12px;border-radius:9px;
  font-size:13.5px;font-weight:600;color:var(--muted);
  transition:color .16s ease, background .16s ease;
}
.nav-links a:hover{color:var(--ink);background:rgba(27,26,22,.045)}
.nav-links a.active{color:var(--forest);background:var(--forest-soft)}

/* =========================================================
   Hero
   ========================================================= */
.hero{padding:clamp(34px,6vw,68px) 0 clamp(20px,3vw,30px)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:700;letter-spacing:0.04em;
  color:var(--forest);text-transform:uppercase;
}
.eyebrow .dot{width:6px;height:6px;border-radius:999px;background:var(--clay)}
.hero h1{
  font-size:clamp(40px,9vw,82px);
  line-height:0.98;
  letter-spacing:-0.05em;
  font-weight:800;
  margin:18px 0 0;
  color:var(--ink);
}
.hero h1 .yr{
  display:block;font-size:clamp(13px,2.4vw,17px);font-weight:700;
  letter-spacing:0.02em;color:var(--muted);margin-bottom:18px;
}
.hero .lead{
  font-size:clamp(15.5px,2vw,18.5px);
  color:var(--ink-2);max-width:600px;margin:22px 0 0;line-height:1.6;
}

/* Countdown — D-day display */
.countdown{
  display:flex;align-items:center;gap:clamp(16px,3vw,26px);
  margin-top:clamp(28px,4vw,40px);flex-wrap:wrap;
}
.dday{
  display:inline-flex;align-items:baseline;gap:2px;
  background:var(--forest-deep);color:#fff;
  padding:14px 22px;border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);position:relative;
}
.dday .d{font-size:clamp(15px,2vw,19px);font-weight:700;opacity:.7;letter-spacing:0.02em;margin-right:2px}
.dday .n{font-size:clamp(40px,8vw,62px);font-weight:800;letter-spacing:-0.05em;line-height:0.85}
.dday-meta{display:flex;flex-direction:column;gap:5px}
.dday-when{font-size:13.5px;font-weight:700;color:var(--ink);letter-spacing:-0.01em}
.dday-left{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;color:var(--muted);
}
.dday-left .pulse{width:7px;height:7px;border-radius:999px;background:var(--crimson);animation:pulse 1.6s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

/* Facts bar */
.facts{
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-top:clamp(28px,4vw,40px);
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-xs);
}
.fact{padding:clamp(16px,2.4vw,22px) clamp(16px,2.4vw,24px);border-left:1px solid var(--line)}
.fact:first-child{border-left:0}
.fact .k{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:0.01em}
.fact .v{font-size:clamp(17px,2.4vw,21px);font-weight:800;letter-spacing:-0.025em;margin-top:5px;color:var(--ink);line-height:1.15}
.fact .v.accent{color:var(--clay)}

/* =========================================================
   Sections
   ========================================================= */
section{padding:clamp(34px,5vw,56px) 0;scroll-margin-top:70px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:clamp(20px,3vw,30px)}
.sec-head .kicker{
  font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--clay);margin:0 0 9px;
}
.sec-head h2{
  font-size:clamp(25px,4vw,38px);letter-spacing:-0.04em;margin:0;
  font-weight:800;line-height:1.08;color:var(--ink);
}
.sec-head p{margin:8px 0 0;color:var(--muted);font-size:14.5px;max-width:60ch}
.sec-num{
  font-size:clamp(13px,1.6vw,15px);font-weight:700;color:var(--faint);
  letter-spacing:0.04em;flex-shrink:0;padding-bottom:4px;
}

/* =========================================================
   Cards & grids
   ========================================================= */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:clamp(20px,2.6vw,26px);
  box-shadow:var(--sh-xs);
}
.card h3{
  margin:0 0 12px;font-size:17px;font-weight:800;
  letter-spacing:-0.025em;line-height:1.3;color:var(--ink);
  display:flex;align-items:center;gap:9px;
}
.card h3 .ic{
  width:30px;height:30px;border-radius:9px;flex-shrink:0;
  display:grid;place-items:center;background:var(--forest-soft);color:var(--forest);
}
.card h3 .ic svg{width:17px;height:17px}
.card .small{color:var(--ink-2);font-size:14px;line-height:1.62;margin:0}
.card .small.muted{color:var(--muted)}

/* card variants — flat fills, no gradients */
.card--feature{border-color:var(--forest);box-shadow:0 0 0 1px var(--forest), var(--sh-sm)}
.card--clay{border-color:var(--clay);box-shadow:0 0 0 1px var(--clay), var(--sh-sm)}
.card--clay h3 .ic{background:var(--clay-soft);color:var(--clay)}
.card--danger{background:var(--crimson-soft);border-color:transparent}
.card--danger h3{color:var(--crimson)}
.card--danger h3 .ic{background:#fff;color:var(--crimson)}
.card--warn{background:var(--gold-soft);border-color:transparent}
.card--warn h3 .ic{background:#fff;color:var(--gold)}
.card--green{background:var(--forest-soft);border-color:transparent}

.stack > * + *{margin-top:14px}

.bullet{margin:6px 0 0;padding:0;list-style:none}
.bullet li{
  position:relative;padding:7px 0 7px 20px;
  font-size:14px;color:var(--ink-2);line-height:1.55;
  border-bottom:1px solid var(--line);
}
.bullet li:last-child{border-bottom:0}
.bullet li::before{
  content:"";position:absolute;left:2px;top:14px;
  width:6px;height:6px;border-radius:999px;background:var(--forest);
}
.bullet.danger li::before{background:var(--crimson)}
.bullet.clay li::before{background:var(--clay)}
.bullet.plain li{padding-left:18px}
.bullet.plain li::before{width:5px;height:5px;background:var(--faint);top:15px}

/* =========================================================
   Pills & badges
   ========================================================= */
.pill{
  display:inline-flex;align-items:center;
  background:var(--clay-soft);color:var(--clay);
  border-radius:999px;padding:4px 11px;
  font-size:11.5px;font-weight:700;letter-spacing:-0.005em;
  vertical-align:middle;margin-left:8px;
}
.pill--green{background:var(--forest-soft);color:var(--forest)}
.pill--red{background:var(--crimson-soft);color:var(--crimson)}
.pill--star{background:var(--gold-soft);color:var(--gold)}

/* =========================================================
   Buttons
   ========================================================= */
.links{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.btn{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--surface);
  border:1px solid var(--line-2);
  border-radius:var(--r-sm);
  padding:10px 15px;
  font-size:13.5px;font-weight:700;letter-spacing:-0.01em;
  color:var(--ink);min-height:42px;
  transition:transform .14s ease, background .14s ease, border-color .14s ease, box-shadow .14s ease;
}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn:hover{background:var(--surface-2);border-color:var(--ink-2);transform:translateY(-1px);box-shadow:var(--sh-xs)}
.btn:active{transform:translateY(0)}
.btn.primary{background:var(--forest);border-color:var(--forest);color:#fff}
.btn.primary:hover{background:var(--forest-deep);border-color:var(--forest-deep)}
.btn.kakao{background:var(--kakao);border-color:var(--kakao);color:#191600}
.btn.kakao:hover{background:#f5dd00;border-color:#f5dd00}
.btn.clay{background:var(--clay);border-color:var(--clay);color:#fff}
.btn.clay:hover{background:#985026;border-color:#985026}
.btn.dark{background:var(--ink);border-color:var(--ink);color:#fff}
.btn.dark:hover{background:#000}
.btn.ghost-light{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28);color:#fff}
.btn.ghost-light:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45)}

/* =========================================================
   Reservation summary — solid forest panel (no gradient)
   ========================================================= */
.summary{
  background:var(--forest-deep);color:#fff;
  border-radius:var(--r-xl);padding:clamp(28px,4vw,44px);
  box-shadow:var(--sh-md);position:relative;overflow:hidden;
}
.summary::after{
  content:"";position:absolute;right:-60px;top:-60px;
  width:220px;height:220px;border-radius:999px;
  border:1px solid rgba(255,255,255,.07);pointer-events:none;
}
.summary::before{
  content:"";position:absolute;right:10px;top:10px;
  width:120px;height:120px;border-radius:999px;
  border:1px solid rgba(255,255,255,.07);pointer-events:none;
}
.summary .tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);color:#fff;
  padding:7px 14px;border-radius:999px;
  font-size:12.5px;font-weight:700;letter-spacing:0.01em;
}
.summary .tag svg{width:15px;height:15px}
.summary h2{
  margin:18px 0 0;font-size:clamp(23px,4vw,34px);
  letter-spacing:-0.04em;line-height:1.12;font-weight:800;
  position:relative;
}
.summary .meta{
  display:grid;grid-template-columns:repeat(4,auto);gap:clamp(18px,3vw,40px);
  margin:26px 0 0;position:relative;
}
.summary .meta .k{font-size:12px;color:rgba(255,255,255,.6);font-weight:600}
.summary .meta .v{font-size:clamp(16px,2.2vw,20px);font-weight:800;letter-spacing:-0.02em;margin-top:5px}
.summary .desc{
  margin:24px 0 0;color:rgba(255,255,255,.78);font-size:14.5px;line-height:1.65;
  max-width:74ch;position:relative;
}
.summary .desc b{color:#fff}
.summary .links{margin-top:24px;position:relative}

/* =========================================================
   Tables
   ========================================================= */
.tablecard{
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  background:var(--surface);box-shadow:var(--sh-xs);
}
.compare{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}
.compare th,.compare td{padding:13px 16px;text-align:left;vertical-align:top;line-height:1.5;border-bottom:1px solid var(--line)}
.compare thead th{
  background:var(--surface-2);color:var(--muted);
  font-weight:700;font-size:11.5px;letter-spacing:0.04em;text-transform:uppercase;
  position:sticky;top:0;
}
.compare tbody tr:last-child td{border-bottom:0}
.compare tbody tr td:first-child{font-weight:700;color:var(--ink);white-space:nowrap}
.compare tbody tr.is-now{background:var(--crimson-soft)}
.compare tbody tr.is-past td{color:var(--faint)}
.compare tbody tr.is-past td:first-child{color:var(--faint)}
.row-now-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--crimson);color:#fff;padding:3px 9px;border-radius:999px;
  font-size:11px;font-weight:700;
}

/* compact two-col action table */
.tablecard.compact .compare td,.tablecard.compact .compare th{padding:11px 14px;font-size:13.5px}
.tablecard.compact .compare tbody tr.is-now td:first-child{color:var(--crimson)}

/* =========================================================
   Timeline (itinerary centerpiece)
   ========================================================= */
.days{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.4vw,24px)}
.day{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:clamp(22px,2.8vw,30px);box-shadow:var(--sh-xs);
}
.day-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.day-head .d-date{font-size:19px;font-weight:800;letter-spacing:-0.03em}
.day-head .d-dow{font-size:13px;font-weight:700;color:var(--clay);letter-spacing:0.02em}
.tl{margin:18px 0 0;position:relative;padding-left:0}
.tl-item{
  position:relative;display:grid;grid-template-columns:62px 1fr;gap:16px;
  padding:0 0 20px 0;
}
.tl-item:last-child{padding-bottom:0}
.tl-time{
  font-size:13px;font-weight:800;color:var(--forest);
  letter-spacing:-0.01em;text-align:right;padding-top:1px;
  white-space:nowrap;
}
.tl-body{
  position:relative;padding:0 0 0 22px;
  border-left:2px solid var(--line);
  font-size:14px;color:var(--ink-2);line-height:1.58;
}
.tl-item:last-child .tl-body{border-left-color:transparent}
.tl-body::before{
  content:"";position:absolute;left:-7px;top:4px;
  width:12px;height:12px;border-radius:999px;
  background:var(--surface);border:2.5px solid var(--forest);
}
.tl-item.key .tl-body::before{background:var(--forest);box-shadow:0 0 0 4px var(--forest-soft)}
.tl-item.warn .tl-time{color:var(--crimson)}
.tl-item.warn .tl-body::before{border-color:var(--crimson)}
.tl-item.tbd .tl-time{color:var(--muted)}
.tl-item.tbd .tl-body::before{border-color:var(--muted);border-style:dashed}
.tl-body b{color:var(--ink)}

/* people / departure cards */
.people{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.person{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:16px;box-shadow:var(--sh-xs);
}
.person .nm{display:flex;align-items:center;gap:9px;font-weight:800;font-size:15.5px;letter-spacing:-0.02em}
.person .av{
  width:30px;height:30px;border-radius:999px;flex-shrink:0;
  display:grid;place-items:center;font-size:13px;font-weight:800;color:#fff;
}
.person .from{font-size:12px;color:var(--muted);font-weight:600;margin:10px 0 0}
.person .role{font-size:13px;color:var(--ink-2);line-height:1.5;margin:6px 0 0}

/* =========================================================
   Checklist (interactive)
   ========================================================= */
.progress-bar{
  display:flex;align-items:center;gap:12px;margin-bottom:18px;
  font-size:13px;font-weight:700;color:var(--muted);
}
.progress-track{flex:1;height:7px;border-radius:999px;background:var(--paper-2);overflow:hidden}
.progress-fill{height:100%;background:var(--forest);border-radius:999px;width:0;transition:width .35s cubic-bezier(.2,.7,.3,1)}
.progress-pct{color:var(--forest);min-width:42px;text-align:right;font-variant-numeric:tabular-nums}

.checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.check{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:18px 20px;box-shadow:var(--sh-xs);
}
.check .grp{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.check .grp b{font-size:14px;font-weight:800;letter-spacing:-0.015em;color:var(--ink)}
.check .grp .ct{margin-left:auto;font-size:11.5px;font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums}
.opt{
  display:flex;align-items:flex-start;gap:10px;
  padding:7px 0;cursor:pointer;
  font-size:13.5px;color:var(--ink-2);line-height:1.45;
  user-select:none;
}
.opt .box{
  width:19px;height:19px;border-radius:6px;flex-shrink:0;margin-top:1px;
  border:1.8px solid var(--line-2);background:var(--surface);
  display:grid;place-items:center;transition:all .14s ease;
}
.opt .box svg{width:12px;height:12px;opacity:0;transform:scale(.6);transition:all .14s ease;color:#fff}
.opt.done .box{background:var(--forest);border-color:var(--forest)}
.opt.done .box svg{opacity:1;transform:scale(1)}
.opt.done .label{color:var(--faint);text-decoration:line-through;text-decoration-color:var(--line-2)}

/* simple action checklist (single column, in danger card) */
.actions{margin:8px 0 0;padding:0;list-style:none}
.actions .opt{padding:9px 0;border-bottom:1px solid rgba(163,54,39,.14);font-size:14px;color:var(--ink-2)}
.actions .opt:last-child{border-bottom:0}
.actions .opt .box{border-color:rgba(163,54,39,.4)}
.actions .opt.done .box{background:var(--crimson);border-color:var(--crimson)}
.actions .opt.done .label{color:var(--faint)}

/* =========================================================
   Note line
   ========================================================= */
.note{
  display:flex;gap:12px;margin-top:16px;
  padding:15px 18px;border-radius:var(--r-sm);
  background:var(--surface);border:1px solid var(--line);
  font-size:13.5px;color:var(--ink-2);line-height:1.6;
}
.note .ic{flex-shrink:0;color:var(--clay);margin-top:1px}
.note .ic svg{width:18px;height:18px}
.note b{color:var(--ink)}
.note a{color:var(--forest);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line-2)}
.note.warn{background:var(--gold-soft);border-color:transparent}
.note.warn .ic{color:var(--gold)}

/* =========================================================
   Footer
   ========================================================= */
.foot{
  padding:clamp(36px,5vw,56px) 0 70px;color:var(--muted);
  font-size:13px;line-height:1.7;border-top:1px solid var(--line);margin-top:24px;
}
.foot .foot-brand{display:flex;align-items:center;gap:9px;font-weight:800;color:var(--ink);font-size:15px;letter-spacing:-0.02em;margin-bottom:14px}
.foot .foot-brand .leaf{width:26px;height:26px;border-radius:8px;background:var(--forest);color:#fff;display:grid;place-items:center}
.foot .foot-brand .leaf svg{width:15px;height:15px}
.foot a{color:var(--ink-2);text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:3px}
.foot p{max-width:80ch;margin:0}

/* Back to top */
.totop{
  position:fixed;right:20px;bottom:20px;z-index:50;
  width:46px;height:46px;border-radius:999px;
  background:var(--ink);color:#fff;border:0;cursor:pointer;
  display:grid;place-items:center;box-shadow:var(--sh-md);
  opacity:0;transform:translateY(12px) scale(.9);pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop svg{width:20px;height:20px}
.totop:hover{background:#000}

/* =========================================================
   Responsive
   ========================================================= */
@media(max-width:920px){
  .grid,.grid-2{grid-template-columns:1fr;gap:12px}
  .days{grid-template-columns:1fr}
  .people{grid-template-columns:repeat(2,1fr)}
  .summary .meta{grid-template-columns:repeat(2,1fr);gap:18px 28px}
}
@media(max-width:680px){
  body{font-size:15px}
  .wrap{width:calc(100% - 32px)}
  .brand span{display:none}
  .facts{grid-template-columns:repeat(2,1fr)}
  .fact{border-left:1px solid var(--line);border-top:1px solid var(--line)}
  .fact:first-child,.fact:nth-child(2){border-top:0}
  .fact:nth-child(odd){border-left:0}
  .sec-head{flex-direction:column;align-items:flex-start;gap:10px}
  .sec-num{order:-1}
  .checklist{grid-template-columns:1fr}
  .people{grid-template-columns:1fr 1fr}
  .countdown{gap:12px}
  .cd-tag{margin-left:0;width:100%;justify-content:center;order:5}

  /* tables → stacked cards */
  .tablecard{border:0;background:transparent;box-shadow:none;border-radius:0}
  .compare{display:block}
  .compare thead{display:none}
  .compare tbody{display:block}
  .compare tbody tr{
    display:block;background:var(--surface);
    border:1px solid var(--line);border-radius:var(--r-sm);
    padding:15px 17px;margin-bottom:10px;box-shadow:var(--sh-xs);
  }
  .compare tbody tr.is-now{box-shadow:0 0 0 1.5px var(--crimson)}
  .compare tbody tr.is-past{opacity:.6}
  .compare td{display:block;padding:0;border:0;line-height:1.55;font-size:13.5px;color:var(--ink-2)}
  .compare td:first-child{
    font-weight:800;color:var(--ink);font-size:15px;letter-spacing:-0.015em;
    padding-bottom:9px;margin-bottom:9px;border-bottom:1px solid var(--line);white-space:normal;
  }
  .compare td:not(:first-child){padding:3px 0}
  .compare td[data-label]::before{
    content:attr(data-label) "  ";
    font-size:11px;color:var(--muted);font-weight:700;
    text-transform:uppercase;letter-spacing:0.03em;margin-right:8px;
  }
  /* keep compact action table as real table on mobile */
  .tablecard.compact{display:block;border:1px solid var(--line);background:var(--surface);border-radius:var(--r)}
  .tablecard.compact .compare{display:table;width:100%}
  .tablecard.compact .compare thead{display:table-header-group}
  .tablecard.compact .compare tbody{display:table-row-group}
  .tablecard.compact .compare tr{display:table-row;background:transparent;border:0;border-radius:0;padding:0;margin:0;box-shadow:none}
  .tablecard.compact .compare td,.tablecard.compact .compare th{display:table-cell;padding:10px 12px;font-size:13px;border-bottom:1px solid var(--line)}
  .tablecard.compact .compare td::before{content:none}
  .tl-item{grid-template-columns:52px 1fr;gap:12px}
}
@media(max-width:380px){
  .people{grid-template-columns:1fr}
  .hero h1{font-size:38px}
}

/* =========================================================
   Print
   ========================================================= */
@media print{
  .nav,.totop,.links,.cd-tag{display:none !important}
  body{background:#fff}
  .card,.day,.summary,.tablecard{box-shadow:none}
  .summary{background:#fff;color:var(--ink);border:1.5px solid var(--forest)}
  .summary .desc,.summary .meta .k{color:var(--ink-2)}
  .summary .meta .v,.summary h2{color:var(--ink)}
  section{padding:16px 0;break-inside:avoid}
  .grid,.days,.checklist{break-inside:avoid}
}

/* Focus */
a:focus-visible,.btn:focus-visible,.opt:focus-visible,.totop:focus-visible{
  outline:2.5px solid var(--forest);outline-offset:3px;border-radius:8px;
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
