/* ============================================================
   Seven Days on the Coast — editorial design system v2
   Photo-forward, full-bleed, generous air, restrained motion.
   Palette stays: warm greige paper, forest green, navy, gold.
   ============================================================ */
:root{
  --paper:#F3EFE7;
  --paper-2:#ECE6DA;
  --card:#FBF9F4;
  --ink:#1E2521;
  --muted:#646b64;
  --green:#2C3D32;
  --green-deep:#22302820;
  --navy:#1E2F45;
  --gold:#A97C24;
  --gold-soft:#C2922F;
  --line:#DcD4C4;
  --maxw:760px;
  --wide:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
html,body{overflow-x:hidden;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Inter Tight",system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px 110px;}

/* full-bleed: break out of the centered column to the full viewport width */
.bleed{width:100vw;position:relative;left:50%;margin-left:-50vw;}

/* ---- Top nav ---- */
.nav{position:sticky;top:0;z-index:60;background:rgba(243,239,231,.82);backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid rgba(0,0,0,.06);}
.nav-inner{max-width:var(--wide);margin:0 auto;padding:13px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.brand{font-family:"Fraunces",serif;font-weight:600;font-size:16px;color:var(--green);text-decoration:none;letter-spacing:.01em;white-space:nowrap;}
.brand span{color:var(--gold);}
.menu-btn{appearance:none;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:9px;padding:7px 13px;font:inherit;font-size:14px;cursor:pointer;}
.menu{display:none;max-width:var(--wide);margin:0 auto;padding:2px 16px 14px;flex-wrap:wrap;gap:6px;}
.menu.open{display:flex;}
.menu a{text-decoration:none;color:var(--navy);font-size:14px;font-weight:500;padding:7px 13px;border-radius:999px;border:1px solid transparent;}
.menu a:hover{border-color:var(--line);background:var(--card);}
.menu a.here{background:var(--green);color:#F4EFE3;}
@media(min-width:820px){
  .menu-btn{display:none;}
  .menu{display:flex !important;padding:0;gap:2px;}
  .nav-inner{max-width:var(--wide);}
  .nav{display:flex;flex-direction:column;}
  .nav .menu{position:static;}
  .nav-inner{padding-bottom:13px;}
  .nav{padding-bottom:8px;}
}

/* ---- Type scale ---- */
.eyebrow{text-transform:uppercase;letter-spacing:.26em;font-size:12px;font-weight:600;color:var(--gold);margin:0 0 18px;}
.eyebrow.light{color:#E7C877;}
h1{font-family:"Fraunces",serif;font-weight:480;font-size:clamp(40px,9vw,76px);line-height:1.0;letter-spacing:-.02em;margin:0 0 18px;color:var(--green);}
h2{font-family:"Fraunces",serif;font-weight:480;font-size:clamp(25px,4.6vw,36px);line-height:1.08;color:var(--navy);margin:52px 0 16px;letter-spacing:-.015em;}
h3{font-family:"Fraunces",serif;font-weight:500;font-size:20px;color:var(--green);margin:0 0 8px;letter-spacing:-.01em;}
p{margin:0 0 16px;}
a{color:var(--gold);}
.lead{font-size:20px;line-height:1.55;color:var(--ink);}
.dateline{font-family:"Fraunces",serif;font-style:italic;font-size:clamp(18px,4.4vw,22px);margin:0;color:var(--ink);}
.dateline.light{color:#F1ECE0;}
.subline{font-size:15px;color:var(--muted);margin:8px 0 0;}
.hr{height:1px;background:var(--line);border:0;margin:40px 0;}
.page-head{padding:64px 0 6px;text-align:center;}
.page-head h1{font-size:clamp(34px,7.5vw,58px);}

/* ---- Immersive hero (full screen, photo with overlaid type) ---- */
.immersive{position:relative;min-height:92vh;display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff;}
.immersive::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,28,24,.36) 0%,rgba(20,28,24,0) 26%,rgba(20,28,24,.12) 55%,rgba(20,28,24,.72) 100%);}
.immersive-inner{position:relative;z-index:2;max-width:var(--wide);margin:0 auto;width:100%;padding:0 24px 7vh;text-align:center;}
.immersive h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.28);max-width:none;margin-left:auto;margin-right:auto;}
.immersive .dateline{color:#F1ECE0;}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.8);font-size:11px;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;animation:bob 2.4s var(--ease) infinite;}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(6px);}}

/* ---- Editorial full-bleed image band ---- */
.band{position:relative;height:clamp(360px,68vh,640px);background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff;}
.band::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,28,24,0) 38%,rgba(20,28,24,.66) 100%);}
.band-inner{position:relative;z-index:2;max-width:var(--wide);margin:0 auto;width:100%;padding:0 24px 44px;}
.band h2{color:#fff;margin:0 0 6px;text-shadow:0 2px 24px rgba(0,0,0,.3);}
.band p{color:rgba(255,255,255,.92);max-width:46ch;margin:0;}
.band .eyebrow{color:#E7C877;}

/* ---- Standard hero image (in-column, rounded) ---- */
.hero-img{width:100%;height:clamp(230px,46vw,420px);object-fit:cover;border-radius:18px;margin:10px 0 6px;display:block;background:#cfd9d2;}
.cap{font-size:13px;color:var(--muted);margin:10px 0 0;}

/* ---- Cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px 24px;margin:0 0 18px;}
.green-card{background:var(--green);color:#E8E3D6;border-radius:20px;padding:34px 30px;margin:0 0 18px;}
.green-card h2,.green-card h3{color:#F4EFE3;}
.green-card a{color:#E9C97A;}

/* ---- Quick links ---- */
.links{display:grid;gap:14px;grid-template-columns:1fr;margin-top:10px;}
@media(min-width:560px){.links{grid-template-columns:1fr 1fr;}}
.linkcard{display:block;text-decoration:none;background:var(--card);border:1px solid var(--line);border-radius:15px;padding:22px;color:var(--ink);transition:border-color .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease);}
.linkcard:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 12px 30px rgba(40,50,40,.08);}
.linkcard .t{font-family:"Fraunces",serif;font-size:21px;color:var(--green);margin:0 0 4px;letter-spacing:-.01em;}
.linkcard .d{font-size:14px;color:var(--muted);margin:0;}

/* ---- Day index + day blocks ---- */
.dayindex{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 30px;}
.dayindex a{text-decoration:none;font-size:13px;font-weight:600;color:var(--navy);background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 14px;transition:background .2s var(--ease),color .2s var(--ease);}
.dayindex a:hover{background:var(--green);color:#F4EFE3;border-color:var(--green);}
.day{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 26px;margin:0 0 20px;scroll-margin-top:96px;}
.day-top{display:flex;align-items:baseline;gap:14px;margin-bottom:2px;}
.daynum{font-family:"Fraunces",serif;font-size:34px;color:var(--gold-soft);line-height:1;min-width:38px;}
.day-date{text-transform:uppercase;letter-spacing:.14em;font-size:11.5px;font-weight:600;color:var(--muted);}
.day-theme{font-family:"Fraunces",serif;font-size:25px;color:var(--green);margin:3px 0 16px;letter-spacing:-.015em;}
.day .hero-img{height:clamp(200px,40vw,300px);border-radius:14px;}
.sched{list-style:none;margin:0;padding:0;}
.sched li{display:flex;gap:16px;padding:11px 0;border-bottom:1px solid var(--line);font-size:15px;align-items:baseline;}
.sched li:last-child{border-bottom:0;}
.sched .tm{font-variant-numeric:tabular-nums;color:var(--gold);font-weight:600;white-space:nowrap;min-width:80px;font-size:13.5px;letter-spacing:.02em;}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.tag{font-size:12px;color:var(--navy);background:var(--paper-2);border-radius:999px;padding:6px 12px;font-weight:500;}
.vote-flag{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--gold);border-radius:6px;padding:2px 8px;margin-left:2px;vertical-align:middle;}

/* ---- Drive table ---- */
.tbl{width:100%;border-collapse:collapse;margin:8px 0;}
.tbl td{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.14);font-size:15px;}
.tbl tr:last-child td{border-bottom:0;}
.tbl td:last-child{text-align:right;color:#E9C97A;font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:500;}
.green-card .tbl td:first-child{color:#DED8C9;}

/* ---- Eat & do cards ---- */
.eatcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:0;margin:0 0 14px;overflow:hidden;}
.eatcard>.card-photo{display:block;width:100%;height:168px;object-fit:cover;margin:0 0 16px;background:var(--line);}
.eatcard>.row,.eatcard>.desc,.eatcard>details,.eatcard>div{padding-left:22px;padding-right:22px;}
.eatcard>*:last-child{padding-bottom:22px;}
.eatcard .row{display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap;}
.eatcard .nm{font-family:"Fraunces",serif;font-size:21px;color:var(--green);margin:0;letter-spacing:-.01em;}
.eatcard .meta{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;}
.eatcard .desc{font-size:15px;margin:10px 0 12px;color:var(--ink);}
.eatcard .price{color:var(--gold);font-weight:700;}
.btn{display:inline-block;text-decoration:none;font-size:13.5px;font-weight:600;color:#F4EFE3;background:var(--green);border-radius:10px;padding:9px 15px;margin-right:6px;transition:transform .2s var(--ease),opacity .2s var(--ease);}
.btn:hover{transform:translateY(-1px);opacity:.94;}
.btn.gold{background:var(--gold);}
.btn.out{background:transparent;color:var(--green);border:1px solid var(--green);}

/* ---- Checklists ---- */
.checklist{list-style:none;margin:0 0 12px;padding:0;}
.checklist li{font-size:15px;padding:11px 0 11px 32px;border-bottom:1px solid var(--line);position:relative;}
.checklist li:last-child{border-bottom:0;}
.checklist li::before{content:"";position:absolute;left:2px;top:14px;width:16px;height:16px;border:1.5px solid var(--gold);border-radius:5px;}
.checklist li span{color:var(--muted);font-size:13px;}

/* ---- Vote ---- */
.poll{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;margin:0 0 16px;}
.poll h3{margin-bottom:4px;}
.poll .when{font-size:12px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin:0 0 14px;}
.opt{display:block;width:100%;text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:13px 15px;margin:0 0 9px;font:inherit;font-size:15px;cursor:pointer;position:relative;overflow:hidden;color:var(--ink);transition:border-color .2s var(--ease);}
.opt:hover{border-color:var(--gold);}
.opt.picked{border-color:var(--green);background:#EDF1EC;font-weight:600;}
.opt .bar{position:absolute;left:0;top:0;bottom:0;background:rgba(169,124,36,.16);width:0;transition:width .5s var(--ease);z-index:0;}
.opt .lbl{position:relative;z-index:1;display:flex;justify-content:space-between;gap:10px;align-items:center;}
.opt .pct{font-variant-numeric:tabular-nums;color:var(--gold);font-weight:700;font-size:13px;}
.namebar{display:flex;gap:8px;margin:0 0 18px;flex-wrap:wrap;}
.namebar input{flex:1;min-width:160px;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font:inherit;background:var(--card);}
.status{font-size:13px;border-radius:11px;padding:12px 15px;margin:0 0 18px;}
.status.live{background:#E7EFE8;color:var(--green);border:1px solid #c7dccb;}
.status.local{background:#F6EEDD;color:#7a5b16;border:1px solid #e6d3a8;}

/* ---- Money ---- */
.totrow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:15px;}
.totrow:last-child{border-bottom:0;font-weight:700;color:var(--green);}

/* ---- Countdown ---- */
.countdown{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;}
.cd-unit{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(8px);border-radius:15px;padding:16px 8px;min-width:80px;text-align:center;}
.cd-num{font-family:"Fraunces",serif;font-size:38px;line-height:1;color:#fff;font-variant-numeric:tabular-nums;}
.cd-lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.85);margin-top:7px;}
.cd-msg{font-family:"Fraunces",serif;font-style:italic;font-size:26px;color:#fff;text-align:center;width:100%;}
/* light-section countdown variant */
.countdown.on-paper .cd-unit{background:var(--card);border-color:var(--line);backdrop-filter:none;}
.countdown.on-paper .cd-num{color:var(--green);}
.countdown.on-paper .cd-lbl{color:var(--muted);}
.countdown.on-paper .cd-msg{color:var(--gold);}
@media(max-width:440px){.cd-unit{min-width:66px;padding:13px 5px;}.cd-num{font-size:30px;}}

/* ---- Footer ---- */
footer{text-align:center;margin-top:60px;color:var(--muted);font-size:13px;}
footer .vine{width:56px;margin:0 auto 16px;opacity:.85;color:var(--gold);}
.vine{display:block;color:var(--gold);}

/* ---- Scroll reveal ---- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---- Section spacing helper ---- */
.section{padding:60px 0 8px;}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .opt .bar{transition:none;}
  .scroll-cue{animation:none;}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}

/* ---- Print / PDF: defeat scroll-reveal, expand menus, tidy layout ---- */
@media print {
  .nav { display: none !important; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .immersive { min-height: 0 !important; }
  details.menu > summary { list-style: none; }
  details.menu summary::before { content: "" !important; }
  details.menu > *:not(summary) { display: block !important; }
  details.menu::details-content { content-visibility: visible !important; display: block !important; }
  .eatcard>.card-photo { height: 150px; break-after: avoid; }
  .eatcard .row { break-after: avoid; }
  .section-label { break-after: avoid; }
  .page-head { padding: 6px 0 4px; }
  a { color: inherit; text-decoration: none; }
  body { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

/* ---- Green card inner (home) ---- */
.green-card .gc-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:#E9C97A;font-weight:700;margin:0 0 10px;}
.green-card .gc-title{font-family:"Fraunces",serif;font-size:26px;line-height:1.15;color:#F4EFE3;margin:0 0 12px;letter-spacing:-.01em;}
.green-card .gc-body{font-size:15px;line-height:1.6;color:#E8E3D6;margin:0 0 18px;}
