/* Worth the Drive — worth-the-drive.com */
:root{
  --bg:#f6efe4; --bg-2:#efe6d6; --surface:#fffdf8; --ink:#2a1c12; --muted:#7a6a59;
  --muted-2:#a89684; --line:#e7dcc9; --rust:#b5442f; --rust-deep:#8f3221;
  --amber:#a9701a; --green:#3f6f4a; --shadow:0 1px 2px rgba(60,40,20,.05),0 8px 24px rgba(60,40,20,.06);
  --radius:18px; --maxw:1180px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--rust-deep);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(246,239,228,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:600;font-size:1.32rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(150deg,var(--rust),var(--rust-deep));display:grid;place-items:center;color:#fff;font-size:18px}
.brand small{display:block;font-family:var(--sans);font-weight:500;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-top:-2px}
.nav{display:flex;gap:6px}
.nav a{padding:8px 14px;border-radius:10px;color:var(--muted);font-weight:600;font-size:.92rem}
.nav a:hover{background:var(--bg-2);color:var(--ink);text-decoration:none}
.nav a.active{color:var(--ink)}

/* hero */
.hero{padding:46px 0 26px}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,5vw,3.4rem);line-height:1.04;letter-spacing:-.01em;margin:0 0 14px}
.hero p{font-size:1.1rem;color:var(--muted);max-width:60ch;margin:0}
.hero .kicker{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rust);font-weight:700;margin:0 0 14px}

/* filter bar */
.filters{position:sticky;top:64px;z-index:40;background:var(--bg);padding:14px 0;border-bottom:1px solid var(--line)}
.filters .row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.search{flex:1 1 260px;position:relative;min-width:220px}
.search input{width:100%;padding:11px 14px 11px 40px;border:1px solid var(--line);border-radius:12px;background:var(--surface);font:inherit;color:var(--ink)}
.search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted-2)}
select,.btn{font:inherit;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:10px 12px;border-radius:12px;cursor:pointer}
select:focus,.search input:focus{outline:2px solid var(--rust);outline-offset:1px;border-color:transparent}
.btn-clear{color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.chip{border:1px solid var(--line);background:var(--surface);color:var(--muted);padding:6px 13px;border-radius:999px;font-size:.86rem;font-weight:600;cursor:pointer;transition:.12s}
.chip:hover{border-color:var(--muted-2);color:var(--ink)}
.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}
.dietary .chip.on{background:var(--green);border-color:var(--green)}
.count{color:var(--muted);font-size:.9rem;margin:16px 0 4px}
.count b{color:var(--ink)}

/* grid + cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px;padding:8px 0 50px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;cursor:pointer;transition:transform .14s,box-shadow .14s}
.card:hover{transform:translateY(-3px);box-shadow:0 4px 10px rgba(60,40,20,.08),0 18px 40px rgba(60,40,20,.10)}
.card .ph{aspect-ratio:16/10;background:var(--bg-2);overflow:hidden;position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .ph.empty{display:grid;place-items:center;color:var(--muted-2);background:repeating-linear-gradient(135deg,var(--bg-2),var(--bg-2) 14px,#eadfca 14px,#eadfca 28px)}
.card .ph.empty span{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase}
/* Google Places photo attribution (TOS) — only rendered on Google-sourced photos */
.ph-attr{position:absolute;left:0;right:0;bottom:0;padding:14px 10px 5px;font-size:.62rem;line-height:1.25;color:rgba(255,255,255,.92);background:linear-gradient(to top,rgba(0,0,0,.6),rgba(0,0,0,0));pointer-events:none}
.ph-attr a{color:#fff;text-decoration:underline;pointer-events:auto}
.rank{position:absolute;top:10px;left:10px;background:rgba(42,28,18,.82);color:#fff;font-size:.78rem;font-weight:700;padding:4px 9px;border-radius:999px;backdrop-filter:blur(3px)}
.card .body{padding:15px 16px 16px;display:flex;flex-direction:column;gap:9px;flex:1}
.card h3{font-family:var(--serif);font-weight:600;font-size:1.16rem;margin:0;line-height:1.18}
.meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.86rem;color:var(--muted)}
.stars{color:var(--amber);font-weight:700}
.pill{display:inline-block;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--bg-2);color:var(--muted)}
.pill.cuisine{background:#f3e4d3;color:var(--rust-deep)}
.tagrow{display:flex;gap:6px;flex-wrap:wrap}
.tag{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:6px;background:#e8f0e8;color:var(--green)}
.order{font-size:.9rem;color:var(--ink)}
.order b{color:var(--muted);font-weight:600;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:1px}
.card .where{font-size:.85rem;color:var(--muted);margin-top:auto}
.empty-state{text-align:center;padding:70px 20px;color:var(--muted)}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(30,18,10,.55);backdrop-filter:blur(3px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-bg.open{display:flex}
.modal{position:relative;background:var(--surface);border-radius:20px;max-width:560px;width:100%;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.35);animation:pop .16s ease}
@keyframes pop{from{transform:translateY(8px);opacity:.6}to{transform:none;opacity:1}}
.modal .hero-img{aspect-ratio:16/9;background:var(--bg-2);position:relative}
.modal .hero-img .ph-attr{font-size:.68rem;padding:16px 14px 7px}
.modal .hero-img img{width:100%;height:100%;object-fit:cover}
.modal .mbody{padding:22px 24px 26px}
.modal h2{font-family:var(--serif);font-size:1.6rem;margin:0 0 6px}
.modal .quote{font-style:italic;color:var(--muted);border-left:3px solid var(--rust);padding-left:12px;margin:14px 0}
.modal dl{display:grid;grid-template-columns:90px 1fr;gap:8px 14px;margin:14px 0 0;font-size:.92rem}
.modal dt{color:var(--muted-2);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding-top:2px}
.modal dd{margin:0}
.modal .actions{display:flex;gap:10px;margin-top:20px}
.btn-primary{background:var(--rust);color:#fff;border:none;padding:11px 18px;border-radius:12px;font-weight:700;cursor:pointer}
.btn-primary:hover{background:var(--rust-deep);text-decoration:none}
.btn-ghost{border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:11px 18px;border-radius:12px;font-weight:700}
.close{position:absolute;top:14px;right:14px;z-index:3;display:grid;place-items:center;background:rgba(255,255,255,.94);border:none;width:36px;height:36px;border-radius:50%;font-size:20px;line-height:1;cursor:pointer;color:var(--ink);box-shadow:0 1px 5px rgba(0,0,0,.22)}
.close:hover{background:#fff}

/* footer */
.site-footer{border-top:1px solid var(--line);background:var(--bg-2);padding:34px 0;margin-top:20px;color:var(--muted);font-size:.9rem}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center}

/* blog */
.article{max-width:760px;margin:0 auto;padding:40px 20px 60px}
.article .eyebrow{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rust);font-weight:700}
.article h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,5vw,3rem);line-height:1.06;margin:12px 0}
.article .lede{font-size:1.2rem;color:var(--muted);margin:0 0 8px}
.article .byline{color:var(--muted-2);font-size:.9rem;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:6px}
.article h2{font-family:var(--serif);font-size:1.7rem;margin:42px 0 4px;display:flex;align-items:baseline;gap:10px}
.article h2 .n{color:var(--rust);font-size:1.1rem;font-weight:700}
.article h2 .ct{color:var(--muted-2);font-size:.8rem;font-weight:600}
.article p{font-size:1.06rem;line-height:1.7}
.callout{background:#f4ead7;border-left:4px solid var(--amber);border-radius:8px;padding:16px 18px;color:#6a5326;font-size:.97rem;margin:22px 0}
.entry{border:1px solid var(--line);background:var(--surface);border-radius:16px;overflow:hidden;margin:20px 0;box-shadow:var(--shadow)}
.entry img{width:100%;aspect-ratio:16/8;object-fit:cover;background:var(--bg-2)}
.entry .ec{padding:18px 20px 20px}
.entry .top{display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap}
.entry h3{font-family:var(--serif);font-size:1.32rem;margin:0}
.entry .rate{color:var(--amber);font-weight:700;white-space:nowrap}
.entry .desc{color:var(--ink);margin:8px 0}
.entry .q{font-style:italic;color:var(--muted);border-left:3px solid var(--rust);padding-left:11px;margin:10px 0}
.entry dl{display:grid;grid-template-columns:78px 1fr;gap:5px 12px;font-size:.9rem;margin:10px 0 0}
.entry dt{color:var(--muted-2);font-size:.68rem;letter-spacing:.07em;text-transform:uppercase;padding-top:2px}
.entry dd{margin:0}
.toc{columns:2;gap:24px;font-size:.95rem;margin:14px 0}
.toc a{display:block;padding:3px 0}
@media(max-width:560px){.toc{columns:1}.modal dl{grid-template-columns:74px 1fr}}

/* blog list */
.bloglist{max-width:820px;margin:0 auto;padding:30px 20px 60px}
.post-card{display:grid;grid-template-columns:200px 1fr;gap:20px;border:1px solid var(--line);background:var(--surface);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.post-card img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1}
.post-card .pc{padding:20px 22px}
.post-card h2{font-family:var(--serif);margin:.2em 0 .3em;font-size:1.4rem}
@media(max-width:560px){.post-card{grid-template-columns:1fr}.post-card img{aspect-ratio:16/9}}

/* ---------- mobile ---------- */
@media (max-width:760px){
  .wrap{padding:0 16px}
  .site-header .wrap{height:56px}
  .brand{font-size:1.12rem;gap:8px}
  .brand .mark{width:27px;height:27px;font-size:16px}
  .nav a{padding:7px 10px;font-size:.88rem}

  .hero{padding:26px 0 14px}
  .hero h1{font-size:clamp(1.9rem,8.5vw,2.6rem)}
  .hero p{font-size:1rem}
  .hero .kicker{margin-bottom:10px}

  /* filters: NOT sticky on mobile (they were covering the screen) */
  .filters{position:static;top:auto;padding:12px 0}
  .filters .row{gap:8px}
  .search{flex:1 1 100%;min-width:0}
  .filters select{flex:1 1 0;min-width:0;font-size:.9rem;padding:11px 8px}
  .btn-clear{flex:1 1 100%;min-height:42px}

  /* chip rows become swipeable single-line rails instead of tall stacks */
  .chips{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
         margin:10px -16px 0;padding:2px 16px 9px;scrollbar-width:none}
  .chips::-webkit-scrollbar{display:none}
  .chip{flex:0 0 auto;min-height:40px;display:inline-flex;align-items:center}

  /* one comfortable column; no more horizontal overflow from 290px min */
  .grid{grid-template-columns:1fr;gap:16px;padding-bottom:40px}
  .card .ph{aspect-ratio:16/9}
  .card:hover{transform:none}
  .count{margin:14px 0 2px}

  .modal-bg{padding:10px;align-items:flex-start}
  .modal{border-radius:16px}
  .modal .mbody{padding:18px 18px 22px}
  .modal h2{font-size:1.4rem}
  .modal .actions{flex-wrap:wrap}
  .modal .actions a{flex:1 1 auto;text-align:center}

  .article{padding:26px 16px 48px}
  .article h1{font-size:clamp(1.9rem,8vw,2.4rem)}
  .article p{font-size:1.02rem}
  .entry img{aspect-ratio:16/10}
}

/* ================= accounts · saved lists · tried · titles ================= */
.acct-area{display:inline-flex;align-items:center}
.acct-btn{font:inherit;cursor:pointer;border:1px solid var(--rust);background:var(--rust);color:#fff;font-weight:700;font-size:.86rem;padding:8px 14px;border-radius:999px;display:inline-flex;align-items:center;gap:7px;line-height:1}
.acct-btn:hover{background:var(--rust-deep);border-color:var(--rust-deep)}
.acct-btn .dot{width:7px;height:7px;border-radius:50%;background:#bff0c8;box-shadow:0 0 0 2px rgba(255,255,255,.35)}

/* card photo action buttons */
.cardacts{position:absolute;top:8px;right:8px;display:flex;gap:6px;z-index:3}
.iconbtn{width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;font-size:16px;line-height:1;display:grid;place-items:center;background:rgba(255,255,255,.92);color:var(--ink);box-shadow:0 1px 5px rgba(0,0,0,.25);transition:transform .1s}
.iconbtn:hover{transform:scale(1.08)}
.iconbtn.save.on{background:#fff;color:var(--rust)}
.iconbtn.tried.on{background:var(--green);color:#fff}
.triedflag{position:absolute;left:8px;bottom:8px;z-index:3;background:var(--green);color:#fff;font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:999px;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.pill.price{background:#eee7da;color:var(--muted);font-weight:700}

/* modal tried/save row */
.userrow{display:flex;gap:10px;margin-top:14px}
.ubtn{flex:1;font:inherit;font-weight:700;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:10px 12px;border-radius:12px}
.ubtn:hover{border-color:var(--muted-2)}
.ubtn.on[data-act="tried"]{background:var(--green);border-color:var(--green);color:#fff}
.ubtn.on[data-act="save"]{background:#fff;border-color:var(--rust);color:var(--rust)}

/* sheets (auth + profile) */
.sheet-bg{position:fixed;inset:0;background:rgba(30,18,10,.55);backdrop-filter:blur(3px);z-index:120;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.sheet-bg.open{display:flex}
.sheet{position:relative;background:var(--surface);border-radius:20px;max-width:460px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:pop .16s ease}
.sbody{padding:26px 24px 28px}
.sbody h2{font-family:var(--serif);font-size:1.55rem;margin:0 0 4px}
.sbody .sub{color:var(--muted);margin:0 0 16px;font-size:.95rem}
.authtabs{display:flex;gap:6px;background:var(--bg-2);padding:4px;border-radius:12px;margin-bottom:16px}
.authtabs button{flex:1;font:inherit;font-weight:700;border:none;background:transparent;color:var(--muted);padding:9px;border-radius:9px;cursor:pointer}
.authtabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
#authForm{display:flex;flex-direction:column;gap:10px}
#authForm input{font:inherit;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--ink)}
#authForm input:focus{outline:2px solid var(--rust);outline-offset:1px;border-color:transparent}
.btn-primary.wide{width:100%;text-align:center}
.err{color:var(--rust);font-size:.86rem;min-height:1em}

/* profile */
.profile .ptop{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.profile h2{font-family:var(--serif);font-size:1.7rem;margin:2px 0 0}
.muted{color:var(--muted)} .tiny{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--muted-2)}
.btn-ghost.sm{padding:7px 12px;font-size:.82rem;border-radius:10px}
.prog{margin:16px 0}
.prog .bar{height:9px;border-radius:999px;background:var(--bg-2);overflow:hidden;margin-bottom:6px}
.prog .bar span{display:block;height:100%;background:linear-gradient(90deg,var(--amber),var(--rust));border-radius:999px;transition:width .4s ease}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 18px}
.badge{background:#e8f0e8;color:var(--green);font-weight:700;font-size:.74rem;padding:4px 10px;border-radius:999px}
.ladder-wrap{margin-bottom:18px}
.ladder{list-style:none;margin:8px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:5px 14px}
.ladder li{font-size:.86rem;color:var(--muted-2);display:flex;align-items:center;gap:7px}
.ladder li.earned{color:var(--ink);font-weight:600}
.ladder .lat{display:inline-grid;place-items:center;min-width:22px;height:22px;border-radius:6px;background:var(--bg-2);font-size:.7rem;font-weight:700;color:var(--muted)}
.ladder li.earned .lat{background:var(--green);color:#fff}
.lists{border-top:1px solid var(--line);padding-top:16px}
.listblock{margin:10px 0}
.lhead{display:flex;justify-content:space-between;font-size:.95rem;margin-bottom:5px}
.litems{display:flex;flex-wrap:wrap;gap:6px}
.litem{display:inline-flex;align-items:center;gap:5px;background:var(--bg-2);border-radius:999px;padding:4px 6px 4px 11px;font-size:.82rem}
.litem button{border:none;background:rgba(0,0,0,.08);color:var(--ink);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:13px;line-height:1}
.newlist{display:flex;gap:8px;margin-top:12px}
.newlist input{flex:1;font:inherit;padding:9px 12px;border:1px solid var(--line);border-radius:10px;background:var(--bg)}

/* toast */
#toast{position:fixed;left:50%;bottom:24px;translate:-50% 8px;background:var(--ink);color:#fff;padding:12px 20px;border-radius:14px;font-weight:600;font-size:.92rem;box-shadow:0 10px 30px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:opacity .2s,translate .2s;z-index:200;max-width:90vw;text-align:center}
#toast.show{opacity:1;translate:-50% 0}
.chips.types .chip.on{background:var(--rust);border-color:var(--rust);color:#fff}

@media (max-width:760px){
  .nav{gap:2px}
  .acct-btn{padding:7px 11px;font-size:.8rem}
  .sheet-bg{padding:10px;align-items:flex-start}
  .sbody{padding:20px 18px 24px}
  .ladder{grid-template-columns:1fr}
  .cardacts .iconbtn{width:36px;height:36px}
}
