:root{
  /* "Aubergine & champagne" palette — deep plum, coral, champagne, gold */
  --bg:#f7f1e3; --card:#ffffff; --ink:#382b36; --ink2:#6e6168; --line:#e4dac5;
  --accent:#d95b40; --accent2:#b6492f; --dark:#432940; --cream:#f7f0e2; --gold:#cda350;
  --green:#3e7a4e; --greenbg:#e9f2ea; --amber:#a87416; --amberbg:#f7eed9;
  --red:#a8402f; --redbg:#f6e6e2; --blue:#3d6b8e; --bluebg:#e7eff5;
  --radius:14px; --shadow:0 1px 3px rgba(34,49,42,.07),0 8px 24px rgba(34,49,42,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
.serif{font-family:"Fraunces",Georgia,"Times New Roman",serif}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:8px 10px;background:#fff;width:100%}
input:focus,select:focus,textarea:focus{outline:2px solid #dca493;border-color:#dca493}
/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;padding:10px 18px;background:rgba(247,243,236,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:16px}
@media(max-width:680px){.brandSlogan{display:none}}
/* ---------- notification bell + panel ---------- */
.notifBell{position:relative;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--dark);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.notifBell:hover{background:#f3ece1}
.notifDot{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#e5392c;color:#fff;font-size:11px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
.notifPanel{position:fixed;top:60px;right:14px;width:384px;max-width:calc(100vw - 24px);max-height:74vh;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 60px rgba(31,19,27,.26);z-index:120;display:flex;flex-direction:column;overflow:hidden}
.npHead{display:flex;align-items:center;justify-content:space-between;padding:15px 16px 9px;gap:10px}
.npTitle{font-weight:700;font-size:17px;color:var(--dark)}
.npCount{color:var(--ink2);font-weight:500;font-size:13px;margin-left:4px}
.npActs{display:flex;align-items:center;gap:8px;flex-shrink:0}
.npLink{background:none;border:none;color:var(--accent);font-weight:600;font-size:13px;cursor:pointer;padding:0}
.npX{background:none;border:none;font-size:22px;line-height:1;color:var(--ink2);cursor:pointer;padding:0 2px}
.npTabs{display:flex;gap:4px;padding:0 12px 10px;border-bottom:1px solid var(--line)}
.npTab{flex:1;background:none;border:none;padding:7px 4px;border-radius:8px;font-weight:600;font-size:13px;color:var(--ink2);cursor:pointer}
.npTab.on{background:#f3ece1;color:var(--dark)}
.npList{overflow-y:auto;-webkit-overflow-scrolling:touch}
.npItem{display:flex;gap:11px;padding:12px 15px 12px 16px;border-bottom:1px solid #f2ede4;cursor:pointer;position:relative;align-items:flex-start}
.npItem:hover{background:#faf6ee}
.npItem.unread{background:#fbf4ec}
.npItem.unread::after{content:"";position:absolute;left:6px;top:18px;width:7px;height:7px;border-radius:50%;background:#e5392c}
.npIc{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px}
.npIc.new,.npIc.confirmed{background:#e6f3e8;color:#2f7a3e}
.npIc.updated{background:#e6eef5;color:#2f6b8e}
.npIc.cancelled,.npIc.noshow{background:#fbe9e5;color:#b6492f}
.npBody{flex:1;min-width:0}
.npB1{font-weight:700;font-size:14px;color:var(--dark)}
.npB2{font-size:13.5px;color:var(--ink2);margin-top:1px}
.npB3{font-size:12.5px;color:var(--ink2);opacity:.85;margin-top:3px}
.npAgo{font-size:12px;color:var(--ink2);white-space:nowrap;flex-shrink:0;margin-top:2px}
.npEmpty{text-align:center;color:var(--ink2);padding:42px 24px;font-size:14px;line-height:1.7}
@media(max-width:480px){.notifPanel{top:54px;right:8px;left:8px;width:auto}}
/* ---------- account chip + menu ---------- */
.acctWrap{position:relative}
.acctBtn{display:inline-flex;align-items:center;gap:5px;height:38px;padding:0 7px 0 4px;border-radius:19px;border:1px solid var(--line);background:#fff;cursor:pointer;color:var(--dark)}
.acctBtn:hover{background:#f3ece1}
.acctInitials{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:.3px}
.acctChev{color:var(--ink2);transition:transform .15s}
.acctBtn[aria-expanded="true"] .acctChev{transform:rotate(180deg)}
.acctMenu{position:absolute;top:46px;right:0;min-width:214px;max-width:calc(100vw - 24px);background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 44px rgba(31,19,27,.22);z-index:130;padding:6px}
.acctEmail{font-size:12.5px;color:var(--ink2);padding:8px 10px;word-break:break-all;border-bottom:1px solid var(--line);margin-bottom:4px}
.acctItem{display:block;width:100%;text-align:left;background:none;border:none;padding:10px;border-radius:8px;font-size:14px;font-weight:600;color:var(--dark);cursor:pointer}
.acctItem:hover{background:#f3ece1}
.statusPill{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:999px;font-size:13px;font-weight:700;border:1px solid transparent;cursor:pointer;white-space:nowrap;line-height:1}
.statusPill .spDot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}
.statusPill.live{background:#e7f3ea;color:#2f6b3a;border-color:#bfe0c8}
.statusPill.paused{background:#fbf0dd;color:#8a5a12;border-color:#ecd3a3}
.statusPill.susp{background:#fbe6e3;color:#b6492f;border-color:#e6b5ab}
.pauseOpts{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.pauseOpt{display:block;width:100%;text-align:left;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer}
.pauseOpt:hover{border-color:#c9b89d;background:var(--cream)}
@media(max-width:560px){
  .statusPill .spLabel{display:none}.statusPill{padding:8px;gap:0}.statusPill .spDot{width:11px;height:11px}
  .ownerApp .topbar{gap:8px;padding:8px 12px}
  .ownerApp .topbar .brand img:first-child{width:42px!important;height:42px!important}
  .ownerApp .topbar .brand span img{height:22px!important}
}
.brandMark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#d95b40,#b6492f);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}
.demoPill{font-size:11px;font-weight:600;color:var(--ink2);border:1px solid var(--line);border-radius:99px;padding:2px 9px;background:#fff}
.viewToggle{display:flex;background:#ece5d8;border-radius:99px;padding:3px;margin-left:auto}
.viewToggle button{padding:7px 16px;border-radius:99px;font-weight:600;font-size:13.5px;color:var(--ink2)}
.viewToggle button.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.12)}
.resetBtn{font-size:13px;color:var(--ink2);padding:7px 12px;border-radius:9px;border:1px solid var(--line);background:#fff}
.resetBtn:hover{color:var(--red);border-color:#dcc7c0}
/* ---------- guest view ---------- */
.hero{background:var(--dark);color:var(--cream);padding:46px 20px 56px;text-align:center}
.hero .kicker{letter-spacing:.22em;text-transform:uppercase;font-size:11px;color:#c9b89d;margin-bottom:10px}
.gCuisine{letter-spacing:.18em;text-transform:uppercase;font-size:12.5px;font-weight:700;color:var(--gold);margin-top:8px}
.hero h1{font-size:44px;font-weight:400;letter-spacing:.01em}
.hero p.tag{color:#bdb2a0;margin-top:8px;font-size:15px}
.hoursPill{display:inline-flex;gap:8px;align-items:center;margin-top:18px;border:1px solid #5c4156;border-radius:99px;padding:7px 16px;font-size:13px;color:#dfd0db}
.dotOpen{width:8px;height:8px;border-radius:50%;background:#7fbf8e;display:inline-block}
.guestGrid{max-width:1060px;margin:-30px auto 18px;padding:0 18px;display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch}
@media(max-width:860px){.guestGrid{grid-template-columns:1fr}}
/* opened via a change/cancel link → lead with the AI chat (the tool for managing a booking) */
.guestGrid.manageMode .chatCard{order:-1}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
/* chat */
.chatCard{display:flex;flex-direction:column;min-height:480px}
.chatHead{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line)}
.aiAvatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#d95b40,#b6492f);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}
.chatHead .t{font-weight:700;font-size:14.5px}
.chatHead .s{font-size:12px;color:var(--green);display:flex;align-items:center;gap:5px}
.chatLog{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;max-height:360px}
.msg{max-width:82%;padding:10px 14px;border-radius:16px;font-size:14.5px;white-space:pre-line}
.msg.ai{background:#f3ede2;border-bottom-left-radius:5px;align-self:flex-start}
.msg.me{background:var(--dark);color:var(--cream);border-bottom-right-radius:5px;align-self:flex-end}
.msg .conf{display:block;margin-top:8px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:10px;font-size:13.5px}
.msg .conf b{font-size:15px}
.codeTag{display:inline-block;background:var(--dark);color:var(--cream);border-radius:6px;padding:1px 8px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;letter-spacing:.06em}
.chipRow{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 12px}
.chip{border:1.5px solid #e0a795;color:var(--accent2);border-radius:99px;padding:6px 14px;font-size:13.5px;font-weight:600;background:#fff}
.chip:hover{background:#fbeee8}
.chatForm{display:flex;gap:9px;padding:12px 14px;border-top:1px solid var(--line)}
.chatForm input{flex:1}
.sendBtn{background:var(--accent);color:#fff;border-radius:9px;padding:0 18px;font-weight:700}
.sendBtn:hover{background:var(--accent2)}
.typing{display:inline-flex;gap:4px;padding:12px 16px}
.typing span{width:7px;height:7px;border-radius:50%;background:#b9a98e;animation:blink 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}
/* form card */
.formCard{padding:22px 24px;display:flex;flex-direction:column}
.formCard h3{font-family:"Fraunces",Georgia,"Times New Roman",serif;font-size:19px;font-weight:600;margin-bottom:4px}
.formCard .sub{font-size:13px;color:var(--ink2);margin-bottom:14px}
.formCard form{display:flex;flex-direction:column;flex:1}
.formCard .bookBtn{margin-top:auto}
.fRow{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.fRow.one{grid-template-columns:1fr}
.fLbl{font-size:12px;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}
.bookBtn{width:100%;background:var(--dark);color:var(--cream);border-radius:10px;padding:12px;font-weight:700;margin-top:6px}
.bookBtn:hover{background:#1f1320}
.formMsg{margin-top:12px;font-size:13.5px;border-radius:10px;padding:10px 12px;display:none}
.formMsg.ok{display:block;background:var(--greenbg);color:var(--green)}
.formMsg.err{display:block;background:var(--redbg);color:var(--red)}
/* ---------- guests (CRM) ---------- */
.guestRow{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.guestRow:last-child{border-bottom:none}
.guestRow:hover{background:#faf6ee}
.gAvatar{width:36px;height:36px;border-radius:50%;background:var(--dark);color:var(--cream);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.gMain{flex:1;min-width:0}
.gName{font-weight:700;font-size:14.5px}
.gSub{font-size:12.5px;color:var(--ink2);margin-top:1px}
.gUp{font-size:12.5px;color:var(--green);font-weight:700;white-space:nowrap;flex-shrink:0}
.gTag{display:inline-block;font-size:11px;padding:1px 7px;border-radius:6px;font-weight:700;white-space:nowrap}
.gReg{background:var(--greenbg);color:var(--green)}
.gRisk{background:var(--redbg);color:var(--red)}
.gNew{background:var(--bluebg);color:var(--blue)}
.gStatRow{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.gStatCard{background:var(--bg);border-radius:10px;padding:10px 12px;text-align:center}
.gStatCard .v{font-size:22px;font-weight:800}
.gStatCard .l{font-size:12px;color:var(--ink2);margin-top:2px}
.gActs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.gActs .aBtn{text-decoration:none}
.gSecH{font-weight:700;font-size:13px;margin:14px 0 6px}
.gReq{font-size:13px;padding:5px 0;border-bottom:1px dashed var(--line)}
.gReq span{color:var(--ink2);font-size:12px}
.gVisit{display:flex;justify-content:space-between;gap:10px;font-size:13px;padding:5px 0;border-bottom:1px dashed var(--line)}
.gVisit .gNo{color:var(--red)}
.gLink{cursor:pointer;border-bottom:1px dotted transparent}
.gLink:hover{border-bottom-color:currentColor}
.tlBlock.tlb-vip{box-shadow:inset 0 0 0 2px var(--gold)}
.abRec{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:9px 11px;margin:2px 0 10px}
.abRecInfo{flex:1;min-width:0;font-size:13.5px;color:var(--dark)}
.abReq{font-size:12.5px;color:var(--accent2);margin-top:2px}
.gDetail{background:var(--bg);border-radius:9px;padding:8px 11px;font-size:13.5px;color:var(--dark);margin:0 0 10px}
.gDetailReq{font-size:13px;color:var(--accent2);margin-top:3px}
.gEdit{background:var(--bg);border-radius:10px;padding:12px;margin:4px 0}
.gVipRow{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;cursor:pointer}
/* ---------- fast stepped reservation form ---------- */
.resvCard{padding:26px 26px 28px;display:flex;flex-direction:column;justify-content:center}
.rIc{width:17px;height:17px;flex-shrink:0}
.resvTitle{font-size:27px;font-weight:600;text-align:center;letter-spacing:.01em;color:var(--dark)}
.resvRest{display:flex;align-items:center;justify-content:center;gap:9px;margin:9px 0 24px;font-size:26px;font-weight:700;color:var(--dark);line-height:1.15}
.resvRest .rIc{width:21px;height:21px;color:var(--accent)}
.resvFields{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.resvField{position:relative}
.resvField.one{margin-bottom:11px}
.resvField .fLbl{display:flex;align-items:center;gap:5px}
.resvCard select,.resvCard .dateField,.resvCard input{height:46px;border-radius:11px}
.dateField{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;border:1px solid var(--line);background:#fff;color:var(--ink);font:inherit;padding:0 12px;text-align:left}
.dateField:hover{border-color:#dca493}
.dateField .rIc{color:var(--ink2)}
.calPop{position:absolute;z-index:60;top:calc(100% + 7px);left:0;width:300px;max-width:84vw;background:#fff;border:1px solid var(--line);border-radius:15px;box-shadow:0 20px 50px rgba(31,19,27,.24);padding:13px}
.calHead{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.calMon{font-weight:700;font-size:15px;color:var(--dark)}
.calNav{width:32px;height:32px;border-radius:9px;border:1px solid var(--line);background:#fff;font-size:19px;line-height:1;color:var(--dark);display:flex;align-items:center;justify-content:center}
.calNav:hover:not(:disabled){background:#f3ece1}
.calNav:disabled{opacity:.3;cursor:default}
.calGrid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.calWd{text-align:center;font-size:10.5px;font-weight:700;letter-spacing:.03em;color:var(--ink2);padding:2px 0 5px}
.calDay{aspect-ratio:1;min-height:34px;border:none;background:none;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--ink);display:flex;align-items:center;justify-content:center}
.calDay:hover:not(:disabled){background:#f3ece1}
.calDay:disabled{color:#cdc4cb;cursor:default;font-weight:400}
.calDay.today:not(.sel){box-shadow:inset 0 0 0 1.6px var(--gold)}
.calDay.sel{background:var(--dark);color:var(--cream)}
.quickDays{display:flex;justify-content:center;gap:26px;margin:15px 0 3px}
.quickDay{font-size:14px;font-weight:600;color:var(--ink2);padding:2px 1px 3px;border-bottom:2px solid transparent}
.quickDay:hover:not(:disabled):not(.on){color:var(--dark)}
.quickDay.on{color:var(--dark);border-bottom-color:var(--dark)}
.quickDay:disabled{color:#cdc4cb;cursor:default;text-decoration:line-through}
.resvCard .bookBtn{margin-top:18px;height:50px;font-size:15.5px;border-radius:12px}
.resvBack{font-size:13.5px;font-weight:600;color:var(--ink2);margin-bottom:13px;display:inline-block}
.resvBack:hover{color:var(--dark)}
.resvBack.center{display:block;margin:18px auto 2px;text-align:center}
.resvSummary{background:#f3ece1;border-radius:11px;padding:11px 13px;font-size:14px;color:var(--dark);margin-bottom:8px}
.resvHint{font-size:12.5px;color:var(--ink2);margin:8px 0 12px}
.slotGroup{margin-bottom:15px}
.slotLbl{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink2);margin-bottom:9px}
.slotChips{display:flex;flex-wrap:wrap;gap:9px}
.slotChip{border:1.5px solid var(--line);border-radius:11px;padding:10px 15px;font-weight:700;font-size:14.5px;background:#fff;color:var(--dark)}
.slotChip:hover{border-color:var(--dark);background:#f3ece1}
.slotsEmpty{color:var(--ink2);font-size:14px;line-height:1.6;padding:6px 2px 14px}
#rDetForm{display:flex;flex-direction:column}
.rConfHead{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.rConfTick{width:42px;height:42px;border-radius:50%;background:var(--greenbg);color:var(--green);font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rConfH{font-family:"Fraunces",Georgia,serif;font-size:21px;font-weight:600;color:var(--dark)}
.rConf .conf{display:block;padding:13px 15px;background:#faf6ee;border:1px solid var(--line);border-radius:12px;font-size:14px;line-height:1.65}
.rConf .conf b{font-size:15.5px}
.rConfNote{font-size:13px;color:var(--ink2);margin-top:11px;line-height:1.55}
.poweredBy{text-align:center;font-size:12px;color:var(--ink2);padding-bottom:30px}
/* ---------- owner view ---------- */
.ownerLayout{display:flex;min-height:calc(100vh - 53px)}
.sideNav{width:198px;flex-shrink:0;border-right:1px solid var(--line);padding:16px 10px;display:flex;flex-direction:column;gap:3px;background:#f2ecdf}
.sideNav button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:10px 12px;border-radius:10px;font-weight:600;font-size:14px;color:var(--ink2)}
.sideNav button.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.sideNav button:hover:not(.on){background:#ece4d4}
.sideNav .nIc{width:20px;text-align:center}
.tabPane{flex:1;padding:24px 28px;max-width:1080px}
.paneTitle{font-size:22px;font-weight:800;margin-bottom:3px}
.paneSub{color:var(--ink2);font-size:14px;margin-bottom:20px}
@media(max-width:760px){.ownerLayout{flex-direction:column}}
/* stats */
.statRow{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.stat .v{font-size:26px;font-weight:800}
.stat .l{font-size:12.5px;color:var(--ink2);margin-top:2px}
.stat .d{font-size:12px;margin-top:4px;font-weight:600}
/* booking list */
.resList{display:flex;flex-direction:column;gap:8px}
.timeGroup{font-size:12.5px;font-weight:800;color:var(--ink2);letter-spacing:.06em;margin:14px 0 4px}
.resItem{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 14px;flex-wrap:wrap}
.resTime{font-weight:800;font-size:15px;min-width:62px}
.resWho{flex:1;min-width:150px}
.resWho .n{font-weight:700}
.resWho .m{font-size:12.5px;color:var(--ink2)}
.badge{font-size:11.5px;font-weight:700;border-radius:99px;padding:3px 10px;white-space:nowrap}
.b-confirmed{background:var(--bluebg);color:var(--blue)}
.b-seated{background:var(--greenbg);color:var(--green)}
.b-completed{background:#eee9df;color:var(--ink2)}
.b-cancelled{background:#eee9df;color:var(--ink2);text-decoration:line-through}
.b-noshow{background:var(--redbg);color:var(--red)}
.risk{font-size:11.5px;font-weight:700;border-radius:99px;padding:3px 10px;cursor:help}
.r-low{background:var(--greenbg);color:var(--green)}
.r-med{background:var(--amberbg);color:var(--amber)}
.r-high{background:var(--redbg);color:var(--red)}
.resActs{display:flex;gap:6px;flex-wrap:wrap}
.aBtn{font-size:12.5px;font-weight:600;border:1px solid var(--line);border-radius:10px;padding:5px 10px;background:#fff;color:var(--ink2)}
.aBtn:hover{border-color:#c9b89d;color:var(--ink)}
.aBtn.warn:hover{color:var(--red);border-color:#dcc7c0}
.aBtn.go{background:var(--dark);color:var(--cream);border-color:var(--dark)}
.empty{padding:30px;text-align:center;color:var(--ink2);background:var(--card);border:1px dashed var(--line);border-radius:12px}
/* floor */
.floorCtl{display:flex;gap:10px;align-items:end;margin-bottom:16px;flex-wrap:wrap}
.floorCtl>div{width:170px}
.floorGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.tableCard{border-radius:12px;padding:13px 14px;border:1.5px solid var(--line);background:var(--card);cursor:pointer;transition:transform .08s}
.tableCard:hover{transform:translateY(-2px)}
.tableCard .tn{font-weight:800;display:flex;justify-content:space-between;align-items:center}
.tableCard .seats{font-size:12.5px;color:var(--ink2)}
.tableCard .occ{margin-top:8px;font-size:13px;font-weight:600}
.t-free{border-color:#bcd6c2;background:var(--greenbg)}
.t-reserved{border-color:#c4d4e2;background:var(--bluebg)}
.t-seated{border-color:#e0b9a0;background:#f8e9dd}
.legend{display:flex;gap:16px;margin-top:16px;font-size:13px;color:var(--ink2)}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block;margin-right:5px}
/* calendar */
.weekStrip{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:18px}
.dayCell{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px;text-align:center;cursor:pointer}
.dayCell.sel{border-color:var(--accent);outline:2px solid #ecc9ae}
.dayCell .dn{font-size:12px;font-weight:700;color:var(--ink2)}
.dayCell .dd{font-size:18px;font-weight:800;margin:2px 0}
.dayCell .bar{height:6px;border-radius:3px;background:#ece5d8;margin-top:6px;overflow:hidden}
.dayCell .bar i{display:block;height:100%;background:var(--accent)}
.dayCell .cv{font-size:11.5px;color:var(--ink2);margin-top:4px}
@media(max-width:760px){.weekStrip{grid-template-columns:repeat(4,1fr)}}
/* insights */
.aiCard{background:linear-gradient(135deg,#2f1c2d,#4a2d46);color:#eaf0e6;border-radius:var(--radius);padding:18px 20px;margin-bottom:18px}
.aiCard .h{display:flex;gap:9px;align-items:center;font-weight:700;margin-bottom:8px;color:#e9d3a4}
.aiCard p{font-size:14.5px;line-height:1.65}
.heatWrap{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:18px;overflow-x:auto}
.heatTitle{font-weight:700;margin-bottom:12px;font-size:14.5px}
.heat{display:grid;gap:3px;min-width:560px}
.heat .hCell{height:26px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--ink2)}
.recList{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.rec{display:flex;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:11px 14px;font-size:14px}
.rec .ic{flex-shrink:0}
/* owner chat */
.ownerChat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.ownerChat .chatLog{max-height:260px;min-height:120px}
/* settings */
.setCard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:16px}
.setCard h4{font-size:15px;margin-bottom:12px}
.hourRow{display:grid;grid-template-columns:90px 1fr 1fr 80px;gap:10px;align-items:center;margin-bottom:8px;font-size:14px}
.tblRow{display:grid;grid-template-columns:1fr 90px 110px 84px 40px;gap:10px;align-items:center;margin-bottom:8px}
.comboRow{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.comboRow b{min-width:110px}
.comboRow .cHint{font-size:12px;color:var(--ink2)}
.comboRow label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink2)}
.comboRow input{width:74px}
.tlTable.tlOff{opacity:.45}
.tlCell.cellOff{cursor:not-allowed;background:repeating-linear-gradient(45deg,transparent,transparent 6px,#f3eee4 6px,#f3eee4 8px)}
.tlCell.cellOff:hover{background:repeating-linear-gradient(45deg,transparent,transparent 6px,#f3eee4 6px,#f3eee4 8px);box-shadow:none}
.delX{color:var(--ink2);font-size:17px;text-align:center;border-radius:8px;padding:5px}
.delX:hover{color:var(--red);background:var(--redbg)}
.addRow{font-size:13.5px;font-weight:700;color:var(--accent2);padding:6px 0}
.saveBar{display:flex;gap:10px;align-items:center}
.primaryBtn{background:var(--accent);color:#fff;border-radius:10px;padding:11px 22px;font-weight:700}
.primaryBtn:hover{background:var(--accent2)}
.dangerBtn{border:1px solid #dcc7c0;color:var(--red);border-radius:10px;padding:10px 18px;font-weight:600;background:#fff}
/* modal & toast */
.modalBack{position:fixed;inset:0;background:rgba(36,31,25,.45);display:none;align-items:center;justify-content:center;z-index:100;padding:18px}
.modalBack.show{display:flex}
.modal{background:#fff;border-radius:16px;max-width:480px;width:100%;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:85vh;overflow-y:auto}
.modal h3{margin-bottom:10px;font-size:18px}
.modal .body{font-size:14.5px;color:#46403a;line-height:1.6}
.modal .body ul{margin:10px 0 10px 18px}
.modal .body li{margin-bottom:6px}
.msgPreview{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:12px;font-size:13.5px;margin:12px 0;white-space:pre-line}
.modalActs{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--dark);color:var(--cream);border-radius:99px;padding:11px 22px;font-size:14px;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,.3);transition:transform .25s;z-index:200}
.toast.show{transform:translateX(-50%) translateY(0)}
.hidden{display:none!important}
/* ---------- cloud additions ---------- */
.previewBanner{background:#432940;color:#f0e4ec;text-align:center;font-size:13px;padding:8px 14px}
.previewBanner b{color:#fff}
.authWrap{min-height:calc(100vh - 86px);display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}
.authCard{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:28px;width:100%;max-width:400px}
.authCard h2{font-size:20px;margin-bottom:4px}
.authCard .sub{color:var(--ink2);font-size:14px;margin-bottom:18px}
.authCard label{display:block;margin-bottom:10px}
.authErr{background:var(--redbg);color:var(--red);border-radius:9px;padding:9px 12px;font-size:13.5px;margin-top:10px;display:none}
.authErr.show{display:block}
.authOk{background:var(--greenbg);color:var(--green);border-radius:9px;padding:9px 12px;font-size:13.5px;margin-top:10px;display:none}
.authOk.show{display:block}
.switchAuth{text-align:center;font-size:13.5px;color:var(--ink2);margin-top:14px}
.switchAuth button{color:var(--accent2);font-weight:700;text-decoration:underline}
.codeBox{display:flex;gap:8px;align-items:center;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px;margin:8px 0;overflow-x:auto;white-space:pre}
.codeBox code{flex:1}
.copyBtn{flex-shrink:0;font-size:12px;font-weight:700;border:1px solid var(--line);border-radius:7px;padding:5px 10px;background:#fff;color:var(--ink2)}
.copyBtn:hover{color:var(--accent2);border-color:#dca493}
.linkCard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:14px}
.linkCard h4{font-size:14.5px;margin-bottom:6px}
.linkCard .hint{font-size:12.5px;color:var(--ink2);margin-top:4px}
.setCard .hint{font-size:12.5px;color:var(--ink2);margin:2px 0 12px}
.adminTable{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.adminTable th{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink2);text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);background:#faf6ee}
.adminTable td{padding:10px 12px;border-bottom:1px solid #f0eade;font-size:13.5px;vertical-align:middle}
.adminTable tr:last-child td{border-bottom:none}
.tag{font-size:11px;font-weight:700;border-radius:99px;padding:2px 9px}
.tagOk{background:var(--greenbg);color:var(--green)}
.tagWait{background:var(--amberbg);color:var(--amber)}
.tagBad{background:var(--redbg);color:var(--red)}
.tagDemo{background:var(--bluebg);color:var(--blue)}
.tagPaused{background:var(--redbg);color:var(--red)}
.codeMask{cursor:pointer;font-size:12px;letter-spacing:.08em}
.codeMask:hover{color:var(--accent2)}
.ownerMail{cursor:pointer;font-size:12.5px}
.ownerMail:hover{color:var(--accent2);text-decoration:underline}
.adminActs{display:flex;gap:6px;flex-wrap:wrap}
.drawerTabs{display:flex;gap:8px;margin-bottom:10px}
/* ---------- floor + today glanceability ---------- */
.emergencyBtn{margin-left:auto;display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--red);color:var(--red);background:#fff;border-radius:99px;padding:8px 16px;font-weight:700;font-size:13px;min-height:40px}
.emergencyBtn svg{width:15px;height:15px;flex-shrink:0}
.emergencyBtn:hover{background:var(--redbg)}
.emergencyBtn.isClosed{background:var(--red);color:#fff;border-color:var(--red)}
.emergencyBtn.isClosed:hover{background:#8d3526}
#tab-floor .addBtn{margin-left:auto}
.primaryBtn.danger{background:var(--red)}
.primaryBtn.danger:hover{background:#8d3526}
.modalActs{flex-wrap:wrap}
.modalActs .aBtn.warn{color:var(--red);border-color:#e6c4bc}
.liveGroup{font-size:13px;font-weight:800;letter-spacing:.08em;margin:18px 0 6px;display:flex;align-items:center;gap:8px;color:var(--ink2)}
.liveGroup.gArrive{color:var(--accent2)}
.liveGroup.gSeated{color:var(--green)}
.liveGroup.gNoshow{color:var(--red)}
.liveQuiet{font-size:13px;color:var(--ink2);padding:8px 2px}
.tblPill{font-weight:800;font-size:13px;background:var(--dark);color:var(--cream);border-radius:8px;padding:4px 10px;min-width:42px;text-align:center;flex-shrink:0}
.resItem.hot{border-left:4px solid var(--accent)}
.resItem.hot .resTime{font-size:18px;font-variant-numeric:tabular-nums}
.resItem.lateRow{border-left:4px solid var(--amber)}
.b-late{background:var(--amber);color:#fff}
@media(max-width:760px){
  .emergencyBtn{order:5;flex:1 1 100%;justify-content:center;min-height:46px;font-size:14px}
  .modalActs{gap:8px}
  .modalActs .aBtn{flex:1 1 calc(50% - 4px);min-height:44px}
  .modalActs .primaryBtn{flex:1 1 100%;order:9;min-height:48px}
  .tlWrap{max-height:calc(100dvh - 290px)}
  .tlCell{min-height:48px}
  .tlBlock{margin:3px 2px;font-size:12px}
}
.landingHero{background:var(--dark);color:var(--cream);text-align:center;padding:80px 20px}
.landingHero h1{font-size:46px;font-weight:400}
.landingHero p{color:#bdb2a0;margin-top:12px;font-size:17px;max-width:560px;margin-left:auto;margin-right:auto}
.landingCta{display:inline-block;margin-top:26px;background:var(--accent);color:#fff;border-radius:99px;padding:13px 28px;font-weight:700;text-decoration:none}
.landingCta:hover{background:var(--accent2)}
.featGrid{max-width:980px;margin:40px auto;padding:0 18px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.feat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.feat .ic{font-size:26px;margin-bottom:10px}
.feat h3{font-size:16px;margin-bottom:6px}
.feat p{font-size:14px;color:var(--ink2)}
.footerBar{text-align:center;color:var(--ink2);font-size:13px;padding:30px}
.spin{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--ink2);font-size:14px}
/* ---------- day timeline (floor v2) ---------- */
.dayStrip{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.dayBtn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:7px 12px;font-weight:600;font-size:12px;color:var(--ink2);cursor:pointer;text-align:center;min-width:72px}
.dayBtn .dd{font-size:16px;font-weight:800;display:block;color:inherit}
.dayBtn.on{background:var(--dark);color:var(--cream);border-color:var(--dark)}
.dayBtn.closedDay{opacity:.45}
.tlWrap{overflow:auto;max-height:min(620px,calc(100dvh - 240px));overscroll-behavior-x:contain;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 10px 10px;position:relative}
.tl{display:grid;position:relative;min-width:760px}
.tlCorner{position:sticky;left:0;top:0;background:#fff;z-index:8}
.tlHead{position:sticky;top:0;height:26px;padding:0;border-left:1px dashed var(--line);background:#fff;z-index:6;overflow:visible;white-space:nowrap}
.tlHead.hour{border-left:2px solid #cdbd9f}
/* label sits just RIGHT of its (solid, heavy) hour line, fully inside the
   hour's first cell — on a clickable grid, the cell under the text must be
   the time the text names */
.tlHr{position:absolute;left:3px;top:4px;font-size:12.5px;font-weight:800;color:var(--ink);background:inherit;padding:0 3px;line-height:1;font-variant-numeric:tabular-nums}
.tlHead.band,.tlCell.band{background:#faf6ee}
.tlTable{position:sticky;left:0;background:#fff;font-weight:800;font-size:12.5px;padding:8px 8px 0 2px;border-top:1px solid #f0e8d8;z-index:5;line-height:1.25}
.tlTable small{display:block;color:var(--ink2);font-weight:600;font-size:10.5px}
.tlCell{border-left:1px dashed #f0e9db;border-top:1px solid #f0e8d8;min-height:48px;cursor:pointer}
.tlCell.hh{border-left:1px dashed var(--line)}
.tlCell.hr{border-left:2px solid #cdbd9f}
.tlCell:hover{background:#faf3e3;box-shadow:inset 0 0 0 1.5px #e0c9a8}
.tlCell.band:hover{background:#faf3e3}
.tlBlock{border-radius:7px;margin:3px 2px;padding:4px 8px;font-size:13px;font-weight:700;overflow:hidden;cursor:pointer;z-index:2;line-height:1.25;align-self:stretch}
.tlBlock b{display:block;font-weight:800;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tlBlock small{display:block;font-weight:600;font-size:11px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tlb-confirmed{background:var(--bluebg);color:#2d5170;border:1px solid #9db8cc;border-left:4px solid var(--blue)}
.tlb-seated{background:var(--green);color:#fff;border:1px solid #2f5e3c;border-left:4px solid #2f5e3c}
.tlb-seated small{opacity:.95}
.tlb-completed{background:#f1ece2;color:#9a917f;border:1px dashed #ddd5c4;opacity:.75}
.tlb-noshow{background:var(--redbg);color:var(--red);border:1px solid #e6c4bc;border-left:4px solid var(--red);text-decoration:line-through}
.tlNow{position:absolute;top:0;bottom:0;width:3px;background:var(--red);opacity:.9;z-index:4;pointer-events:none;border-radius:2px}
.tlNow::before{content:"NOW";position:absolute;top:28px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:9.5px;font-weight:800;letter-spacing:.06em;padding:2px 7px;border-radius:99px;line-height:1.4}
.tlLegend{display:flex;gap:14px;margin-top:10px;font-size:12.5px;color:var(--ink2);flex-wrap:wrap}
.tlLegend i{width:11px;height:11px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:-1px}
.paneHead{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:4px}
.paneHead .paneTitle{margin-bottom:0}
.addBtn{margin-left:auto;background:var(--accent);color:#fff;border-radius:99px;padding:9px 18px;font-weight:700;font-size:13.5px}
.addBtn:hover{background:var(--accent2)}
.modalForm label{display:block;margin-bottom:10px}
.modalForm .fRow2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.forgot{font-size:13px;color:var(--ink2);text-align:center;margin-top:10px}
.forgot button{color:var(--accent2);font-weight:600;text-decoration:underline}
/* ---------- wave 1: professional polish ---------- */
.brand .word{font-family:"Fraunces",Georgia,serif;font-size:24px;font-weight:600;color:var(--dark)}
.brand .word i{font-style:normal;color:var(--accent)}
.paneTitle,.modal h3,.authCard h2{font-family:"Fraunces",Georgia,serif;font-weight:600;letter-spacing:.01em}
.paneTitle{font-size:24px}
.nIc{display:inline-flex;align-items:center;justify-content:center}
.nIc svg{width:18px;height:18px}
button,.dayCell,.tableCard{transition:background .15s,color .15s,border-color .15s,box-shadow .15s,transform .08s}
button:active{transform:scale(.97)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.resItem{transition:border-color .15s,box-shadow .15s}
.resItem:hover{border-color:#d9cbb4;box-shadow:0 2px 10px rgba(43,38,32,.06)}
.stat .v{font-variant-numeric:tabular-nums}
.stat .l{letter-spacing:.01em}
.aBtn.go{background:var(--accent);border-color:var(--accent);color:#fff}
.aBtn.go:hover{background:var(--accent2);border-color:var(--accent2);color:#fff}
.b-late{background:var(--amberbg);color:var(--amber)}
.toast.err{background:var(--red);color:#fff}
.toastUndo{margin-left:10px;background:rgba(255,255,255,.18);border-radius:99px;padding:3px 12px;font-weight:700;color:inherit}
.toastUndo:hover{background:rgba(255,255,255,.32)}
.modal{position:relative}
.modalBack.show .modal{animation:ttPop .16s ease}
@keyframes ttPop{from{transform:scale(.96);opacity:.5}to{transform:scale(1);opacity:1}}
.modalX{position:absolute;top:10px;right:12px;font-size:22px;line-height:1;color:var(--ink2);padding:6px 9px;border-radius:8px}
.modalX:hover{color:var(--ink);background:var(--bg)}
.alertBanner{background:var(--redbg);border:1px solid #e6c4bc;border-left:4px solid var(--red);color:var(--red);border-radius:12px;padding:13px 16px;margin-bottom:16px;font-size:14px}
.emptyState{padding:36px 24px;text-align:center;background:var(--card);border:1px dashed var(--line);border-radius:14px}
.esT{font-family:"Fraunces",Georgia,serif;font-size:19px;font-weight:600;margin-bottom:6px}
.esS{color:var(--ink2);font-size:14px;max-width:430px;margin:0 auto 16px}
.esActs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.cxGroup{margin-top:16px}
.cxGroup summary{cursor:pointer;font-size:13px;font-weight:700;color:var(--ink2);padding:6px 0}
.cxGroup .resItem{opacity:.72;margin-top:8px}
.spinner{width:24px;height:24px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:ttSpin .8s linear infinite;margin-right:10px;flex-shrink:0}
@keyframes ttSpin{to{transform:rotate(360deg)}}
.heatLegend{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--ink2);margin-top:10px}
.heatLegend i{flex:0 0 90px;height:8px;border-radius:4px;background:linear-gradient(90deg,#f7f2e9,#d95b40)}
.rec .ic svg{width:18px;height:18px;color:var(--accent2);vertical-align:-3px}
/* room view + designer */
.roomWrap{margin-top:6px}
.roomCanvas{position:relative;height:440px;background:#faf6ee;background-image:radial-gradient(#e6dccb 1px,transparent 1px);background-size:26px 26px;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.roomCanvas.designer{height:360px;background-color:#fff}
.rmTbl{position:absolute;aspect-ratio:1;min-width:52px;background:#fff;border:2px solid #cbbfae;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-size:11.5px;cursor:pointer;user-select:none;box-shadow:0 2px 8px rgba(34,49,42,.1);transition:box-shadow .15s}
.rmTbl:hover{box-shadow:0 4px 14px rgba(34,49,42,.18);z-index:5}
.rmTbl b{font-size:13px;line-height:1.2}
.rmTbl small{color:var(--ink2);font-size:10px}
.rmTbl.round{border-radius:50%}
.rmTbl.rmOff{background:repeating-linear-gradient(45deg,#f2ecdf,#f2ecdf 6px,#e7dfcf 6px,#e7dfcf 12px);border-style:dashed;color:var(--ink2)}
.rmTbl.rm-free{border-color:#9fc3a8}
.rmTbl.rm-soon{background:#f7eed9;border-color:#d9b96a}
.rmTbl.rm-seated{background:#3e7a4e;border-color:#2e5c3a;color:#fff}
.rmTbl.rm-seated small,.rmTbl.rm-seated .rmLbl{color:#d8e8da}
.rmLbl{font-size:9.5px;font-weight:700;line-height:1.25;max-width:95%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rm-soon .rmLbl{color:var(--amber)}
.rm-later .rmLbl{color:var(--ink2);font-weight:600}
.roomLegend{display:flex;gap:14px;font-size:12px;color:var(--ink2);margin-top:9px;flex-wrap:wrap;align-items:center}
.roomLegend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:-1px}
@media(max-width:760px){.roomCanvas{height:340px}.roomLegend span:last-child{margin-left:0}}
/* week navigation chevrons */
.stripNav{display:flex;align-items:stretch;gap:8px;margin-bottom:6px}
.navChev{width:36px;border-radius:10px;border:1px solid var(--line);background:#fff;font-size:20px;color:var(--ink2);flex-shrink:0;cursor:pointer}
.navChev:hover{color:var(--ink);border-color:#cbbfae}
.stripNav .resetBtn{flex-shrink:0;align-self:center}
.dayCell.isToday .dn{color:var(--accent2)}
/* printable run sheet */
#runSheet{display:none}
@media print{
  body *{visibility:hidden}
  #runSheet,#runSheet *{visibility:visible}
  #runSheet{display:block;position:absolute;left:0;top:0;width:100%;padding:10mm;font-family:Georgia,serif;color:#000}
  #runSheet h1{font-size:20pt;margin:0 0 4pt}
  #runSheet .rsDate{font-size:12pt;margin-bottom:10pt}
  #runSheet table{width:100%;border-collapse:collapse;font-size:10.5pt}
  #runSheet th,#runSheet td{border-bottom:1px solid #999;text-align:left;padding:5pt 7pt;vertical-align:top}
  #runSheet th{font-size:9pt;text-transform:uppercase;letter-spacing:.05em}
  #runSheet .rsFoot{margin-top:10pt;font-size:9pt;color:#555}
}
/* ---------- find us (guest page) ---------- */
.findUs{max-width:1060px;margin:0 auto 44px;padding:0 18px}
.fuGrid{display:grid;grid-template-columns:1.45fr 1fr;gap:18px;align-items:stretch}
.fuGrid.noMap{grid-template-columns:1fr}
.fuInfo{padding:22px 24px 24px}
.fuInfo h3{font-size:19px;margin-bottom:14px}
.fuRow{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;margin-bottom:10px}
.fuRow svg{width:17px;height:17px;color:var(--accent2);flex-shrink:0;margin-top:2px}
.fuRow a{color:var(--ink)}
.fuDir{font-size:13px;font-weight:600;color:var(--accent2)!important;white-space:nowrap}
.fuHours{margin-top:18px}
.fuHours h4{font-size:12px;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.fuHourRow{display:flex;justify-content:space-between;gap:14px;font-size:13.5px;padding:4px 0;border-bottom:1px dashed var(--line)}
.fuHourRow:last-child{border-bottom:none}
.fuHourRow.today{font-weight:700}
.fuHourRow .closed{color:var(--ink2)}
.todayPill{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent2);background:var(--redbg);border-radius:99px;padding:1px 7px;vertical-align:1px;margin-left:6px}
.fuMapCard{overflow:hidden;min-height:380px;background:#ece5d8;position:relative}
.fuMapCard iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
@media(max-width:860px){.fuGrid{grid-template-columns:1fr}.fuMapCard{min-height:280px}}
@media(max-width:760px){
  .sideNav{position:fixed;bottom:0;left:0;right:0;z-index:60;width:100%;flex-direction:row;justify-content:space-around;gap:0;border-right:none;border-bottom:none;border-top:1px solid var(--line);background:#fff;padding:6px 4px calc(6px + env(safe-area-inset-bottom))}
  .sideNav button{flex-direction:column;gap:3px;font-size:10.5px;padding:7px 4px;flex:1;text-align:center;align-items:center;justify-content:center}
  .sideNav button.on{box-shadow:none;background:var(--cream);color:var(--accent2)}
  .nIc svg{width:20px;height:20px}
  .tabPane{padding:18px 14px 96px}
  .aBtn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;font-size:13px}
  .resActs{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
  .risk{min-height:30px}
  .dayBtn{min-height:48px}
}

/* ---------- admin console: mobile (scoped so the dashboard/landing are untouched) ---------- */
@media(max-width:560px){
  /* header fits on one screen: wrap, shrink the logo, truncate the email */
  .adminPage .topbar{flex-wrap:wrap;gap:8px 10px;padding:8px 12px}
  .adminPage .topbar .brand{gap:8px}
  .adminPage .topbar .brand img:first-child{width:44px!important;height:44px!important}
  .adminPage #whoami{max-width:48vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}
  .adminPage .tabPane{padding:16px 12px 40px}
  .adminPage .setCard{padding:14px}
  .adminPage .fRow{grid-template-columns:1fr}
  .adminPage .modal{padding:18px}
  .adminPage .authCard{padding:22px}
  /* the wide "All restaurants" table -> one tidy card per restaurant */
  .adminPage table.adminTable.stack thead{display:none}
  .adminPage table.adminTable.stack,
  .adminPage table.adminTable.stack tbody,
  .adminPage table.adminTable.stack tr,
  .adminPage table.adminTable.stack td{display:block;width:100%}
  .adminPage table.adminTable.stack{border:none;background:none}
  .adminPage table.adminTable.stack tr{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:6px 14px 10px;background:#fff}
  .adminPage table.adminTable.stack td{border:none;padding:7px 0}
  .adminPage table.adminTable.stack td+td{border-top:1px dashed #f0eade}
  .adminPage table.adminTable.stack td:empty{display:none}
  .adminPage table.adminTable.stack td::before{content:attr(data-label);display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink2);font-weight:700;margin-bottom:3px}
  .adminPage table.adminTable.stack .adminActs{width:100%}
  .adminPage table.adminTable.stack .adminActs .aBtn{flex:1 1 calc(50% - 4px);min-height:40px;justify-content:center}
}


