/* Eortes visual-direction mockups — uses the app's real tokens + fonts. */
:root{
  --bg:#F6F1E7; --surface:#FFFDF8; --sunk:#F1E9D8; --white:#fff;
  --ink:#211C15; --inkSoft:#6A5F4D; --inkFaint:#9A8E78;
  --ox:#7E2A24; --oxDeep:#561A16; --oxTint:#F3E4E1;
  --gold:#A9802C; --goldSoft:#C9A24B; --line:#E6DAC2;
  --fishfg:#2F5E80; --fishbg:#E1ECF2; --oilfg:#9A6B1E; --oilbg:#F4E9D2;
  --display:"GFS Didot", serif; --body:"Commissioner", system-ui, sans-serif;
}
*{box-sizing:border-box} html,body{margin:0}
body{
  background:#EFE7D6;
  color:var(--ink); font-family:var(--body);
  -webkit-font-smoothing:antialiased; padding-bottom:60px;
}
a{color:inherit}

/* ---- page chrome ---- */
.top{position:sticky;top:0;z-index:20;background:rgba(246,241,231,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:14px 18px}
.top h1{font-family:var(--display);font-size:22px;margin:0 0 2px}
.top p{margin:0;color:var(--inkSoft);font-size:13px}
.seg{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.seg button{font-family:var(--body);font-weight:600;font-size:13px;border:1px solid var(--line);background:var(--surface);color:var(--inkSoft);padding:8px 12px;border-radius:999px;cursor:pointer}
.seg button.on{background:var(--ox);border-color:var(--ox);color:#fff}
.dirnote{max-width:1100px;margin:16px auto 0;padding:0 18px;color:var(--inkSoft);font-size:14px;line-height:1.5}
.dirnote b{color:var(--ink)}
.stage{display:flex;gap:26px;flex-wrap:wrap;justify-content:center;align-items:flex-start;padding:22px 18px 60px;max-width:1500px;margin:0 auto}
.framewrap{display:flex;flex-direction:column;align-items:center;gap:8px}
.framewrap .cap{font-size:12px;color:var(--inkFaint);font-weight:600;letter-spacing:.4px;text-transform:uppercase}

/* ---- phone frame ---- */
.phone{width:330px;height:710px;background:#000;border-radius:40px;padding:9px;box-shadow:0 18px 50px rgba(40,28,18,.28)}
.screen{position:relative;width:100%;height:100%;background:var(--bg);border-radius:32px;overflow:hidden;display:flex;flex-direction:column}
.statusbar{height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;font-size:11px;color:var(--ink);flex:0 0 auto}
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{display:none}
.pad{padding:18px}
.tabbar{flex:0 0 auto;height:58px;border-top:1px solid var(--line);background:var(--surface);display:flex;align-items:center;justify-content:space-around;padding-bottom:6px}
.tabbar .tab{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:9px;color:var(--inkFaint)}
.tabbar .tab.on{color:var(--ox)}
.tabbar .dot{width:20px;height:20px;border-radius:6px;border:2px solid currentColor;opacity:.85}

/* paper grain overlay (subtle) */
.grain::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}

/* ---- type ---- */
.hero{font-family:var(--display);font-size:34px;line-height:1.08;margin:0}
.title{font-family:var(--display);font-size:25px;line-height:1.12;margin:0}
.kicker{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:var(--inkFaint);font-weight:600}
.kicker.gold{color:var(--gold)}
.soft{color:var(--inkSoft);font-size:14px;line-height:1.5}
.small{color:var(--inkSoft);font-size:12px}

/* ---- components ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:0 6px 16px rgba(60,40,20,.06)}
.chip{display:inline-block;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 12px;font-weight:500;font-size:14px;margin:0 6px 6px 0}
.btn{display:block;text-align:center;background:var(--ox);color:#fff;font-weight:600;padding:13px;border-radius:12px;box-shadow:0 8px 18px rgba(126,42,36,.28)}
.btn.ghost{background:transparent;color:var(--ox);border:1px solid var(--ox);box-shadow:none}
.fastbadge{display:inline-flex;align-items:center;gap:8px;background:var(--fishbg);color:var(--fishfg);border-radius:999px;padding:7px 12px;font-weight:600;font-size:13px}
.fastbadge .d{width:9px;height:9px;border-radius:50%;background:currentColor}
.row{display:flex;align-items:center;gap:12px}

/* day medallion (A baseline) */
.medallion{width:64px;height:64px;border-radius:50%;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;background:var(--surface);flex:0 0 auto}
.medallion span{font-family:var(--display);font-size:32px;color:var(--gold)}

/* deterministic avatar */
.avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;flex:0 0 auto;font-size:17px;box-shadow:inset 0 -8px 16px rgba(0,0,0,.12)}

/* gradient feast header (A/all) */
.feastband{border-radius:16px;padding:18px;color:#fff;background:linear-gradient(135deg,var(--ox),var(--oxDeep) 60%,#3c1410);position:relative;overflow:hidden}
.feastband .kicker{color:var(--goldSoft)}
.feastband .title{color:#fff}
.feastband .sheen{position:absolute;right:-30px;top:-30px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,75,.45),transparent 70%)}

/* meander divider */
.meander{height:16px;margin:14px 0;background-repeat:repeat-x;background-position:center;opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='16' viewBox='0 0 32 16'><path d='M1 15 V5 H11 V11 H6 V8' fill='none' stroke='%23A9802C' stroke-width='1.6'/><path d='M16 15 V5 H26 V11 H21 V8' fill='none' stroke='%23A9802C' stroke-width='1.6'/></svg>");}

/* hero image band */
.herobg{position:relative;border-radius:18px;overflow:hidden;height:150px;display:flex;align-items:flex-end}
.herobg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.herobg .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(33,28,21,0) 30%,rgba(33,28,21,.62))}
.herobg .on{position:relative;color:#fff;padding:14px}
.herobg .on .hero{color:#fff} .herobg .on .kicker{color:#fff;opacity:.85}

.illus{width:100%;border-radius:14px;display:block;border:1px solid var(--line)}
.iconframe{border:3px solid var(--gold);border-radius:10px;padding:4px;background:linear-gradient(135deg,#f6eccf,#e8cf8f);box-shadow:0 8px 20px rgba(120,90,20,.25)}
.iconframe img{display:block;width:100%;border-radius:6px}
.goldrule{height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:14px 0;opacity:.7}
.foodthumb{width:100%;height:120px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.tag{display:inline-block;font-size:11px;font-weight:600;color:var(--gold);border:1px solid var(--gold);border-radius:999px;padding:2px 8px}
