:root{
  --bg:#f6f2ea; --bg-2:#efe8db; --surface:#ffffff;
  --ink:#1a1f1c; --ink-soft:#4a504c; --muted:#8a8f8a; --line:#e6dfd1;
  --primary:#1f3a2e; --primary-2:#2a5141;
  --accent:#c1665a; --accent-2:#a8554a; --gold:#c8a866;
  --ok:#2f7a4d; --warn:#b9842b; --danger:#b14a3e;
  --tint-ok:#f0fdf4; --tint-warn:#fef3c7; --tint-danger:#fef0e9; --tint-info:#f0f9ff; --color-info:#0369a1;
  --scroll-thumb:#d4ccbe; --scroll-thumb-hover:#b5aca0;
  --shadow:0 1px 2px rgba(20,30,25,.04), 0 8px 28px rgba(20,30,25,.08);
  --shadow-lg:0 10px 40px rgba(20,30,25,.18);
  --radius:12px; --radius-lg:18px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.5;min-height:100vh}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-.01em;margin:0}
h1{font-size:42px;line-height:1.1} h2{font-size:28px;line-height:1.15} h3{font-size:20px;line-height:1.2}
p{margin:0} a{color:inherit;text-decoration:none}
button{font-family:inherit;font-size:14px;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:14px;color:var(--ink)}
::selection{background:var(--primary);color:#fff}

.loader-screen{min-height:100vh;display:grid;place-items:center;font-family:var(--sans);color:var(--ink-soft)}
.loader-screen > div{text-align:center}
.loader-brand{font-family:var(--serif);font-size:32px;color:var(--primary);margin-bottom:8px}
.noscript-msg{margin-top:12px;color:var(--danger)}

.app{display:flex;min-height:100vh}
.sidebar{width:240px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .2s ease;overflow:hidden}
.brand{padding:22px 22px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);transition:padding .2s}
.brand-mark{width:30px;height:30px;border-radius:8px;background:var(--primary);display:grid;place-items:center;color:#fff;font-family:var(--serif);font-weight:700;font-size:18px;flex-shrink:0}
.brand-name{font-family:var(--serif);font-size:20px;font-weight:600;letter-spacing:-.01em}
.brand-sub{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-top:1px}
.nav{padding:14px 10px;flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}
.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);padding:14px 12px 6px;white-space:nowrap}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--ink-soft);font-weight:500;font-size:14px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}
.nav-item:hover{background:var(--bg-2);color:var(--ink)}
.nav-item.active{background:var(--primary);color:#fff}
.nav-item .count{margin-left:auto;font-size:11px;font-weight:700;background:var(--accent);color:#fff;padding:2px 7px;border-radius:999px;flex-shrink:0}
.nav-item.active .count{background:rgba(255,255,255,.25)}
.nav-item .nav-lbl{overflow:hidden;text-overflow:ellipsis}
.ic{width:18px;height:18px;flex-shrink:0;opacity:.8}
.sidebar-foot{padding:14px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px;overflow:hidden}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;color:var(--ink-soft);font-weight:600;font-size:13px;flex-shrink:0}
.avatar.primary{background:var(--primary);color:#fff}
.user-meta{font-size:12px;line-height:1.2;flex:1;min-width:0}
.user-meta b{display:block;font-weight:600;color:var(--ink);font-size:13px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.user-meta span{color:var(--muted);text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:block}
/* Sidebar collapse toggle */
.sidebar-toggle{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--muted);font-size:14px;cursor:pointer;transition:background .15s,color .15s;border:0;background:none;font-family:inherit;width:100%;white-space:nowrap;margin-top:auto}
.sidebar-toggle:hover{background:var(--bg-2);color:var(--ink)}
.sidebar-toggle .nav-lbl{font-weight:500}
/* Collapsed state */
.sidebar.collapsed{width:60px}
.sidebar.collapsed .brand{padding:16px 0;justify-content:center}
.sidebar.collapsed .brand-info,.sidebar.collapsed .nav-section,.sidebar.collapsed .nav-lbl,.sidebar.collapsed .user-meta{display:none}
.sidebar.collapsed .nav-item{justify-content:center;padding:9px 0;position:relative}
.sidebar.collapsed .nav-item .count{position:absolute;top:5px;right:5px;margin-left:0;padding:1px 4px;font-size:9px;min-width:14px;text-align:center;line-height:14px}
.sidebar.collapsed .sidebar-toggle{justify-content:center;padding:9px 0}
.sidebar.collapsed .sidebar-foot{justify-content:center;flex-direction:column;padding:10px 0;gap:8px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:62px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50}
.topbar-l{display:flex;align-items:center;gap:14px;min-width:0}
.topbar-l h2{font-size:18px;font-weight:600;font-family:var(--sans);letter-spacing:0}
.crumb{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}
.crumb .sep{color:var(--line)}
.crumb a{color:var(--ink-soft);cursor:pointer}
.crumb a:hover{color:var(--primary)}
.topbar-r{display:flex;align-items:center;gap:10px}
.content{padding:28px;max-width:1400px;width:100%;margin:0 auto;flex:1}
.content.narrow{max-width:900px}

.btn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 16px;border-radius:9px;font-weight:500;font-size:14px;cursor:pointer;transition:transform .05s,background .15s,border-color .15s,color .15s;border:1px solid transparent;background:var(--surface);color:var(--ink);white-space:nowrap}
.btn:hover{background:var(--bg-2)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-2);border-color:var(--primary-2)}
.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.accent:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn.ghost{background:transparent;border-color:var(--line)}
.btn.ghost:hover{background:var(--bg-2)}
.btn.danger{color:var(--danger);border-color:var(--danger);background:transparent}
.btn.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn.sm{height:32px;padding:0 12px;font-size:13px}
.btn.lg{height:46px;padding:0 22px;font-size:15px}
.btn .ic{width:16px;height:16px;opacity:.95}
.icon-btn{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;background:transparent;border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;transition:background .15s,color .15s}
.icon-btn:hover{background:var(--bg-2);color:var(--ink)}

/* Language picker */
.lang-picker{position:relative;display:inline-block}
.lang-btn{height:36px;padding:0 10px;border-radius:9px;border:1px solid var(--line);background:transparent;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-size:18px;line-height:1}
.lang-btn:hover{background:var(--bg-2)}
.lang-btn .chev{font-size:10px;color:var(--muted);margin-left:2px}
.lang-menu{position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);min-width:160px;z-index:600;overflow:hidden}
.lang-menu-item{padding:10px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink)}
.lang-menu-item:hover{background:var(--bg-2)}
.lang-menu-item.active{background:var(--bg);font-weight:600}
.lang-flag{font-size:18px;line-height:1}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.card.pad-lg{padding:28px}
.stack{display:flex;flex-direction:column;gap:16px}
.row{display:flex;gap:14px;align-items:center}
.row.between{justify-content:space-between}
.grid{display:grid;gap:18px}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.stat .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.stat .val{font-family:var(--serif);font-size:30px;font-weight:600;margin-top:6px;letter-spacing:-.02em}
.stat .delta{font-size:12px;color:var(--ok);margin-top:4px;font-weight:500}

.resto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.resto-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;flex-direction:column}
.resto-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#d8cfba}
.resto-cover{height:140px;background:var(--bg-2);position:relative;background-size:cover;background-position:center}
.resto-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.45))}
.resto-cover .badge{position:absolute;top:12px;left:12px;z-index:2;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;color:var(--ink)}
.resto-cover .badge.live{background:#15331e;color:#a7e6b6}
.resto-meta{padding:16px}
.resto-meta h3{font-size:18px;margin-bottom:2px}
.resto-meta .sub{font-size:13px;color:var(--muted)}
.resto-foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px;color:var(--ink-soft)}
.resto-foot b{color:var(--ink);font-weight:600}

.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:34px}
.page-head .lead{color:var(--ink-soft);margin-top:4px;max-width:560px}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:13px;font-weight:600;color:var(--ink)}
.field .hint{font-size:12px;color:var(--muted);font-weight:400}
.label-with-action{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--ink)}
.at-preview{font-size:12px;color:var(--primary);min-height:0;line-height:1.5;word-break:break-word}
.btn-translate{background:none;border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-size:11px;font-weight:500;color:var(--muted);cursor:pointer;white-space:nowrap;line-height:18px;transition:color .15s,border-color .15s,background .15s}
.btn-translate:hover{color:var(--primary);border-color:var(--primary);background:var(--tint)}
.input,.textarea,.select{width:100%;padding:10px 12px;border-radius:9px;background:#fff;border:1px solid var(--line);transition:border-color .15s,box-shadow .15s;outline:none}
.input:focus,.textarea:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(31,58,46,.12)}
select.input,select.select{appearance:none;-webkit-appearance:none;padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;cursor:pointer}
.textarea{min-height:90px;resize:vertical;line-height:1.5}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.modal-bg{position:fixed;inset:0;background:rgba(20,30,25,.5);display:none;align-items:center;justify-content:center;z-index:400;backdrop-filter:blur(2px)}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:var(--radius-lg);width:min(560px,calc(100% - 32px));box-shadow:var(--shadow-lg);overflow:hidden;max-height:90vh;display:flex;flex-direction:column}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-head h3{font-family:var(--serif);font-size:20px}
.modal-body{padding:22px;overflow-y:auto}
.modal-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px;background:var(--bg)}

.tabs-wrap{position:relative}
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}
.tab{padding:10px 16px;border-radius:8px 8px 0 0;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink-soft);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;flex-shrink:0}
.tabs-arrow{position:absolute;top:0;bottom:1px;width:32px;display:flex;align-items:center;justify-content:center;border:none;padding:0;cursor:pointer;z-index:2;font-size:16px;color:var(--ink-soft);background:none}
.tabs-arrow.left{left:0;background:linear-gradient(to right,var(--bg-2) 55%,transparent)}
.tabs-arrow.right{right:0;background:linear-gradient(to left,var(--bg-2) 55%,transparent)}
.tabs-arrow[hidden]{display:none}
.tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.tab:hover:not(.active){color:var(--ink);background:var(--bg-2)}

.editor{display:grid;grid-template-columns:340px 1fr;gap:0;height:calc(100vh - 62px)}
.editor-side{background:var(--surface);border-right:1px solid var(--line);overflow-y:auto;padding:18px}
.editor-canvas{overflow-y:auto}
.editor-preview{width:100%;pointer-events:none;user-select:none}
.editor-preview .pub-nav,.editor-preview .pub-nav *{pointer-events:auto;user-select:auto}
.editor-preview.mobile{max-width:390px;margin:0 auto;box-shadow:var(--shadow-lg)}
.panel{margin-bottom:18px}
.panel-h{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700;margin-bottom:10px}

.url-box{display:flex;align-items:stretch;gap:0;background:var(--bg);border:1px solid var(--line);border-radius:9px;overflow:hidden;font-family:'SF Mono',ui-monospace,Monaco,monospace;font-size:13px}
.url-box .pre{padding:10px 4px 10px 12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.url-box .slug{padding:10px 6px;color:var(--ink);font-weight:600;flex:1;background:transparent;border:0;outline:none;font-family:inherit;font-size:inherit;min-width:0}
.url-box .copy-btn{background:transparent;border:0;border-left:1px solid var(--line);padding:0 12px;display:grid;place-items:center;cursor:pointer;color:var(--ink-soft)}
.url-box .copy-btn:hover{background:var(--bg-2);color:var(--ink)}

.role-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;background:var(--bg-2);font-size:10px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}
.role-badge.admin{background:#15331e;color:#a7e6b6}
.role-badge.owner{background:#fbeae8;color:#a8554a}

.pub{font-family:var(--sans);color:var(--ink);background:#fff}
.pub .hero{position:relative;min-height:520px;display:grid;place-items:center;color:#fff;background-size:cover;background-position:center;text-align:center;padding:80px 24px}
.pub .hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.55))}
.pub .hero > *{position:relative;z-index:1}
.pub .hero .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;opacity:.85;margin-bottom:16px}
.pub .hero h1{font-family:var(--serif);font-size:64px;font-weight:600;line-height:1.05;margin-bottom:18px;letter-spacing:-.02em}
.pub .hero .tag{font-size:18px;max-width:560px;margin:0 auto 28px;opacity:.95}
.pub .pub-nav{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:18px 32px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.pub .pub-nav .name{font-family:var(--serif);font-size:22px;font-weight:600;letter-spacing:-.01em}
.pub .pub-nav .links{display:flex;gap:24px;font-size:14px;font-weight:500}
.pub .pub-nav .links a{cursor:pointer;color:var(--ink-soft)}
.pub .pub-nav .links a:hover{color:var(--ink)}
.pub .section{padding:80px 32px;max-width:1100px;margin:0 auto}
.gallery-section{padding-left:0;padding-right:0;overflow:hidden}
.gallery-wrap{position:relative}
.gallery-carousel{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:24px 10% 32px;-webkit-overflow-scrolling:touch}
.gallery-carousel::-webkit-scrollbar{display:none}
.gallery-slide{flex:0 0 80%;scroll-snap-align:center;border-radius:16px;overflow:hidden;aspect-ratio:16/9;position:relative;transition:transform .35s ease,opacity .35s ease,box-shadow .35s ease;opacity:.45;transform:scale(.88) translateY(10px);z-index:1;margin-right:-12%}
.gallery-slide:last-child{margin-right:0}
.gallery-slide.active{opacity:1;transform:scale(1) translateY(0);z-index:2;box-shadow:0 20px 56px rgba(0,0,0,.28)}
.gallery-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);color:#fff;border-radius:50%;width:44px;height:44px;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.3);transition:opacity .2s,background .2s;padding:0}
.gallery-btn:hover{background:rgba(0,0,0,.65)}
.gallery-btn-prev{left:calc(10% - 22px)}
.gallery-btn-next{right:calc(10% - 22px)}
.pub .section h2{font-family:var(--serif);font-size:38px;text-align:center;margin-bottom:8px}
.pub .section .lead{text-align:center;color:var(--ink-soft);max-width:560px;margin:0 auto 40px;font-size:16px}
.pub .menu-cats{display:flex;justify-content:center;gap:22px;margin-bottom:36px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:0}
.pub .menu-cat{padding:10px 4px;cursor:pointer;font-weight:600;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;border-bottom:2px solid transparent}
.pub .menu-cat.active{color:var(--ink);border-bottom-color:currentColor}
.pub .menu-section{margin-bottom:32px}
.pub .menu-section:last-child{margin-bottom:0}
.pub .menu-section h3.menu-section-title{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--p-primary);margin:0 0 12px}
.pub .menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.pub .menu-item{display:flex;justify-content:space-between;gap:14px;padding:18px;border:1px solid var(--line);border-radius:12px;background:#fff;transition:border-color .15s,box-shadow .15s}
.pub .menu-item:hover{border-color:#d8cfba;box-shadow:var(--shadow)}
.pub .menu-item .info{flex:1;min-width:0;display:flex;flex-direction:column}
.pub .menu-item h4{font-family:var(--serif);font-size:18px;font-weight:600;margin-bottom:4px;letter-spacing:-.01em}
.pub .menu-item .desc{font-size:13px;color:var(--ink-soft);line-height:1.5;flex:1}
.pub .menu-item .price{font-family:var(--serif);font-size:18px;font-weight:600;white-space:nowrap}
.pub .menu-item .add{margin-top:10px}
.pub .menu-item .end-col{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0;justify-content:space-between}
.pub .menu-item .item-img{width:88px;height:88px;border-radius:10px;background-size:cover;background-position:center;background-color:var(--bg-2);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.editor-preview.mobile .pub .menu-item .item-img{width:64px;height:64px}
.item-img-edit{width:56px;height:56px;border-radius:8px;background-size:cover;background-position:center;background-color:var(--bg-2);flex-shrink:0;border:1px solid var(--line);cursor:pointer;display:grid;place-items:center;color:var(--muted);font-size:10px;text-align:center;font-weight:600;transition:border-color .15s;line-height:1.2;padding:4px}
.item-img-edit:hover{border-color:var(--primary);color:var(--primary)}
.pub .info-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.pub .info-card{padding:24px;border-radius:12px;background:var(--bg)}
.pub .info-card h4{font-family:var(--serif);font-size:20px;margin-bottom:6px}
.pub .info-card p{font-size:14px;color:var(--ink-soft);margin-bottom:6px}
.pub footer{padding:40px 32px;text-align:center;background:var(--ink);color:rgba(255,255,255,.7);font-size:13px}
.pub footer .name{font-family:var(--serif);font-size:22px;color:#fff;margin-bottom:8px}
.pub footer .footer-custom{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6;margin:0 auto 12px;max-width:560px}

.drawer-bg{position:fixed;inset:0;background:rgba(20,30,25,.4);z-index:300;display:none}
.drawer-bg.show{display:block}
.drawer{position:fixed;right:0;top:0;height:100vh;width:min(420px,100%);background:#fff;z-index:301;transform:translateX(100%);transition:transform .25s ease;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.drawer.open{transform:translateX(0)}
.drawer-h{padding:20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer-b{flex:1;overflow-y:auto;padding:8px 20px}
.drawer-f{padding:20px;border-top:1px solid var(--line);background:var(--bg)}
.cart-row{display:flex;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.cart-row:last-child{border-bottom:0}
.qty{display:flex;align-items:center;gap:8px}
.cart-row .qty{margin-top:6px}
.qty button{width:24px;height:24px;border-radius:6px;border:1px solid var(--line);background:#fff;display:grid;place-items:center}
.summary-row{display:flex;justify-content:space-between;font-size:14px;margin:6px 0}
.summary-row.tot{font-family:var(--serif);font-size:20px;font-weight:600;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}

.orders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.order-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px}
.order-h{display:flex;justify-content:space-between;align-items:flex-start}
.order-id{font-family:var(--serif);font-size:18px;font-weight:600}
.order-time{font-size:12px;color:var(--muted)}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.pill.new{background:#e9f5ee;color:var(--ok)}
.pill.preparing{background:#fef4e1;color:var(--warn)}
.pill.ready{background:#dde8e3;color:var(--primary)}
.pill.delivered{background:#e8e6e2;color:var(--ink-soft)}
.pill.cancelled{background:#fbeae8;color:var(--danger)}
.order-items{font-size:13px;color:var(--ink-soft);line-height:1.6}
.order-foot{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px dashed var(--line)}
.order-total{font-family:var(--serif);font-size:18px;font-weight:600}

.toasts{position:fixed;top:24px;right:24px;z-index:500;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:var(--ink);color:#fff;padding:12px 16px;border-radius:10px;font-size:14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:slideIn .25s ease;pointer-events:auto}
.toast.ok{background:#15331e}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

.empty{text-align:center;padding:80px 24px;color:var(--muted);border:1px dashed var(--line);border-radius:var(--radius);background:rgba(255,255,255,.5)}
.empty h3{color:var(--ink);margin-bottom:8px}
.empty p{margin-bottom:18px}

.editor-preview.mobile .pub .hero h1{font-size:38px}
.editor-preview.mobile .pub .pub-nav{padding:14px 16px}
.editor-preview.mobile .pub .pub-nav .links{display:none}
.editor-preview.mobile .pub .section{padding:50px 18px}
.editor-preview.mobile .pub .menu-grid{grid-template-columns:1fr}
.editor-preview.mobile .pub .info-grid{grid-template-columns:1fr}

.theme-classic{--p-primary:#1f3a2e;--p-accent:#c1665a;--p-bg:#f6f2ea}
.theme-noir{--p-primary:#0e0e0e;--p-accent:#c8a866;--p-bg:#f4f4f2}
.theme-coastal{--p-primary:#1f486b;--p-accent:#e0a458;--p-bg:#f5f8fa}
.theme-rose{--p-primary:#52232a;--p-accent:#d97a76;--p-bg:#faf3ee}
.theme-forest{--p-primary:#2e4a2c;--p-accent:#b6a06e;--p-bg:#f4f1e7}
.theme-sun{--p-primary:#8b3a14;--p-accent:#e9b04e;--p-bg:#fdf6ea}
.pub .pub-nav .name,.pub .menu-item h4,.pub .info-card h4,.pub .section h2{color:var(--p-primary)}
.pub .btn-acc{background:var(--p-accent);color:#fff;border-color:var(--p-accent)}
.pub .btn-acc:hover{filter:brightness(.95)}
.pub .btn-pri{background:var(--p-primary);color:#fff;border-color:var(--p-primary)}
.pub .btn-pri:hover{filter:brightness(1.1)}
.pub footer{background:var(--p-primary)}

.auth-page{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr;background:var(--bg)}
.auth-side{background:var(--primary);color:#fff;padding:48px 56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-side::before{content:"";position:absolute;inset:0;background-image:url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?auto=format&fit=crop&w=1600&q=80');background-size:cover;background-position:center;opacity:.22}
.auth-side.branded::before{display:none}
.auth-side .branded-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.22;z-index:0}
.auth-side > *{position:relative;z-index:1}
.auth-brand{display:flex;align-items:center;gap:12px}
.auth-brand .mark{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.15);display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:22px;border:1px solid rgba(255,255,255,.2)}
.auth-quote{font-family:var(--serif);font-size:34px;line-height:1.25;font-weight:500;letter-spacing:-.01em;max-width:520px}
.auth-quote .cite{display:block;font-family:var(--sans);font-size:13px;font-weight:500;margin-top:18px;opacity:.7;letter-spacing:.04em;text-transform:uppercase;font-style:normal}
.auth-form{display:flex;align-items:center;justify-content:center;padding:40px 24px}
.auth-card{width:100%;max-width:420px}
.auth-card h1{font-size:38px;margin-bottom:8px}
.auth-card .lead{color:var(--ink-soft);margin-bottom:28px;font-size:15px}
.auth-foot-note{font-size:12px;color:var(--muted);margin-top:18px;text-align:center}

.customer-bar{position:fixed;top:14px;left:14px;z-index:402;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);padding:6px 8px 6px 14px;border-radius:999px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;border:1px solid var(--line)}

.credentials-box{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px;margin:12px 0;font-family:'SF Mono',ui-monospace,monospace;font-size:13px;word-break:break-all}
.credentials-box .row{justify-content:space-between;padding:6px 0}

@media (max-width:900px){
  .sidebar{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}
  .editor{grid-template-columns:1fr}
  .editor-side{height:auto;border-right:0;border-bottom:1px solid var(--line)}
  .auth-page{grid-template-columns:1fr}
  .auth-side{display:none}
}

/* Scrollbars — thin, themed, light + dark */
.nice-scroll,.modal-body{scrollbar-width:thin;scrollbar-color:var(--scroll-thumb) transparent}
.nice-scroll::-webkit-scrollbar,.modal-body::-webkit-scrollbar{width:6px;height:6px}
.nice-scroll::-webkit-scrollbar-track,.modal-body::-webkit-scrollbar-track{background:transparent}
.nice-scroll::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:99px}
.nice-scroll::-webkit-scrollbar-thumb:hover,.modal-body::-webkit-scrollbar-thumb:hover{background:var(--scroll-thumb-hover)}

/* ===== Dark mode ===== */
[data-theme="dark"]{
  --bg:#111111;--bg-2:#191919;--surface:#202020;
  --ink:#e8e8e8;--ink-soft:#999999;--muted:#606060;--line:#2c2c2c;
  --ok:#4caf72;--warn:#d4a030;--danger:#d96060;
  --tint-ok:#162a1c; --tint-warn:#2a2010; --tint-danger:#2e1715; --tint-info:#0d1f2d; --color-info:#38bdf8;
  --scroll-thumb:#333333; --scroll-thumb-hover:#4a4a4a;
  --shadow:0 1px 2px rgba(0,0,0,.35),0 8px 28px rgba(0,0,0,.45);
  --shadow-lg:0 10px 40px rgba(0,0,0,.65);
}
/* Form controls */
[data-theme="dark"] .input,[data-theme="dark"] .textarea,[data-theme="dark"] .select{background:var(--bg-2);color:var(--ink)}
[data-theme="dark"] .input:focus,[data-theme="dark"] .textarea:focus,[data-theme="dark"] .select:focus{box-shadow:0 0 0 3px rgba(120,120,120,.2)}
[data-theme="dark"] select.input,[data-theme="dark"] select.select{background-color:var(--bg-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px}
/* Language / dropdowns */
[data-theme="dark"] .lang-menu{background:var(--surface);border-color:var(--line)}
/* Modal */
[data-theme="dark"] .modal{background:var(--surface)}
[data-theme="dark"] .modal-foot{background:var(--bg-2)}
/* Drawer / cart */
[data-theme="dark"] .drawer{background:var(--surface)}
[data-theme="dark"] .drawer-f{background:var(--bg-2)}
[data-theme="dark"] .qty button{background:var(--bg-2)}
/* Checkboxes */
[data-theme="dark"] input[type="checkbox"]{accent-color:var(--ok);color-scheme:dark}
/* Buttons */
[data-theme="dark"] .btn{background:var(--surface);color:var(--ink)}
[data-theme="dark"] .btn:hover{background:var(--bg-2)}
[data-theme="dark"] .btn.ghost{background:transparent}
[data-theme="dark"] .btn.ghost:hover{background:var(--bg-2)}
[data-theme="dark"] .btn.danger{color:var(--danger);border-color:var(--danger);background:transparent}
[data-theme="dark"] .btn.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
/* Icon buttons */
[data-theme="dark"] .icon-btn{border-color:var(--line);color:var(--ink-soft)}
[data-theme="dark"] .icon-btn:hover{background:var(--bg-2);color:var(--ink)}
/* Empty state */
[data-theme="dark"] .empty{background:transparent}
/* Customer-preview bar */
[data-theme="dark"] .customer-bar{background:rgba(17,17,17,.95);border-color:var(--line)}
/* Editor */
[data-theme="dark"] .editor-preview{background:var(--surface)}
[data-theme="dark"] .editor-canvas{background:var(--bg)}
/* Credentials box */
[data-theme="dark"] .credentials-box{background:var(--bg-2)}
/* Role badges */
[data-theme="dark"] .role-badge{background:var(--bg-2);color:var(--ink-soft)}
[data-theme="dark"] .role-badge.owner{background:#3d1914;color:#d97a76}
/* Pills (order status) */
[data-theme="dark"] .pill.new{background:#1a2e1e;color:#4caf72}
[data-theme="dark"] .pill.preparing{background:#2a2010;color:#d4a030}
[data-theme="dark"] .pill.ready{background:#1e2222;color:#999999}
[data-theme="dark"] .pill.delivered{background:#222222;color:#606060}
[data-theme="dark"] .pill.cancelled{background:#2a1818;color:#d96060}
/* Toasts */
[data-theme="dark"] .toast{background:#252525}
[data-theme="dark"] .toast.ok{background:#1a2e1e}
/* URL box */
[data-theme="dark"] .url-box{background:var(--bg-2)}
/* ---- Public / customer page ---- */
[data-theme="dark"] .pub{background:var(--bg)}
[data-theme="dark"] .pub .pub-nav{background:rgba(17,17,17,.95);border-color:var(--line)}
[data-theme="dark"] .pub .menu-item{background:var(--surface);border-color:var(--line)}
[data-theme="dark"] .pub .menu-item:hover{border-color:var(--muted);box-shadow:var(--shadow)}
[data-theme="dark"] .pub .info-card{background:var(--bg-2)}
[data-theme="dark"] .pub .section{color:var(--ink)}
[data-theme="dark"] .pub .menu-section-title{color:var(--p-primary) !important}
/* Dark mode toggle */
.dark-toggle{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;border:1px solid var(--line);background:transparent;cursor:pointer;color:var(--ink-soft);transition:background .15s,color .15s;flex-shrink:0}
.dark-toggle:hover{background:var(--bg-2);color:var(--ink)}
