@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Syne:wght@700;800;900&display=swap');

/* ─── Design tokens ─────────────────────────────────────── */
:root{
  --bg:#fdfcfb;
  --card:#ffffff;
  --text:#0f1117;
  --muted:#6c7585;
  --primary:#e23744;
  --primary-2:#b71f36;
  --primary-light:rgba(226,55,68,.10);
  --gold:#c98f1a;
  --line:rgba(15,20,40,.09);
  --line-strong:rgba(15,20,40,.16);
  --shadow:0 20px 60px rgba(15,20,40,.08),0 4px 16px rgba(15,20,40,.04);
  --shadow-lift:0 28px 80px rgba(15,20,40,.13),0 6px 20px rgba(15,20,40,.06);
  --radius:22px;
  --radius-sm:14px;
  --radius-xs:10px;
  --font-display:'Syne',system-ui,sans-serif;
  --font-body:'Plus Jakarta Sans',system-ui,sans-serif;
  --transition:.2s cubic-bezier(.4,0,.2,1);
}

/* ─── Reset & base ──────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
  background-image:
    radial-gradient(ellipse 600px 400px at 100% -80px,rgba(226,55,68,.09),transparent),
    radial-gradient(ellipse 500px 500px at -10% 110%,rgba(139,92,246,.06),transparent);
}
body.is-loading{overflow:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* ─── Layout ────────────────────────────────────────────── */
.container{width:min(1200px,calc(100% - 36px));margin-inline:auto}

/* ─── Orbs ──────────────────────────────────────────────── */
.bg-orb{position:fixed;inset:auto;z-index:-1;border-radius:50%;filter:blur(72px);opacity:.18;pointer-events:none}
.bg-orb-1{width:480px;height:480px;background:radial-gradient(circle,#e23744,#ff6b6b);top:-140px;right:-140px}
.bg-orb-2{width:520px;height:520px;background:radial-gradient(circle,#7c3aed,#a78bfa);bottom:-180px;left:-160px}

/* ─── Site header ───────────────────────────────────────── */
.site-header{position:sticky;top:0;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:rgba(253,252,251,.84);border-bottom:1px solid var(--line);z-index:20}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:15px 0}
.brand{font-family:var(--font-display);font-weight:900;font-size:1.25rem;letter-spacing:-.04em;color:var(--text)}
.brand span{color:var(--primary)}
.top-nav{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.top-nav a,.footer-links a{color:var(--muted);font-size:.875rem;font-weight:600;padding:7px 11px;border-radius:var(--radius-xs);transition:color var(--transition),background var(--transition)}
.top-nav a:hover,.footer-links a:hover{color:var(--text);background:rgba(15,20,40,.05)}
.top-nav a.active{color:var(--primary)}
.side-nav a:hover{color:var(--text);background:rgba(15,20,40,.05)}

/* ─── Page shell ────────────────────────────────────────── */
.page-shell{padding:32px 0 56px}

/* ─── Card surfaces ─────────────────────────────────────── */
.hero-card,.panel,.stat,.menu-item,.order-card,.project-card,.ad-card,.login-card,.profile-card{background:rgba(255,255,255,.92);border:1px solid rgba(15,23,42,.09);border-left:4px solid color-mix(in srgb,var(--primary) 34%,transparent);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.panel h2,.panel h3,.login-card h2{font-family:var(--font-display);letter-spacing:-.03em}

/* ─── Hero ──────────────────────────────────────────────── */
.hero{display:grid;grid-template-columns:1.35fr .9fr;gap:28px;align-items:center;padding:24px 0 12px}
.hero-copy h1,.section-title{font-family:var(--font-display);font-size:clamp(2.1rem,5.2vw,4.2rem);line-height:1.0;letter-spacing:-.05em;margin-bottom:16px}
.hero-copy p{font-size:1.06rem;color:var(--muted);max-width:56ch;line-height:1.75}
.pill-row,.badges-row{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0}
.pill,.badge{padding:7px 13px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.83rem;font-weight:700;letter-spacing:.01em}
.cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.hero-side{padding:22px}

/* ─── Buttons ───────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--radius-sm);border:1px solid transparent;font-family:var(--font-body);font-weight:700;font-size:.9rem;letter-spacing:.01em;transition:transform var(--transition),box-shadow var(--transition),background var(--transition);cursor:pointer}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0);transition-duration:.08s}
.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-2) 100%);color:#fff;box-shadow:0 8px 24px rgba(226,55,68,.28)}
.btn-primary:hover{box-shadow:0 12px 32px rgba(226,55,68,.36)}
.btn-secondary{background:#fff;border-color:var(--line);color:var(--text);box-shadow:0 2px 8px rgba(15,20,40,.06)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--muted)}
.btn-ghost:hover{color:var(--text);background:rgba(15,20,40,.04)}

/* ─── Grids ─────────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.menu-grid,.orders-grid{display:grid;gap:16px}

/* ─── Stats ─────────────────────────────────────────────── */
.stat,.panel,.menu-item,.order-card,.project-card,.ad-card,.login-card,.profile-card{padding:20px}
.stat .label,.muted{color:var(--muted);font-size:.875rem}
.stat .value{font-family:var(--font-display);font-size:2.1rem;font-weight:900;letter-spacing:-.05em;line-height:1.1;margin-top:4px}

/* ─── Sections ──────────────────────────────────────────── */
.section{margin-top:32px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:16px}
.feature-list{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feature{padding:22px;border-radius:20px;background:rgba(255,255,255,.88);border:1px solid var(--line);transition:box-shadow var(--transition),transform var(--transition)}
.feature:hover{box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.feature h3{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:10px}
.small{font-size:.875rem}

/* ─── Admin shell ───────────────────────────────────────── */
.admin-shell{display:grid;grid-template-columns:268px 1fr;min-height:100vh}
.sidebar{border-right:1px solid var(--line);background:rgba(255,255,255,.82);padding:24px 18px;position:sticky;top:0;height:100vh;overflow-y:auto;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.brand-block{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.side-nav{display:grid;gap:4px}
.side-nav a{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;color:var(--muted);transition:color var(--transition),background var(--transition)}
.admin-main{padding:28px 28px 40px}
.admin-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.admin-top h1{font-family:var(--font-display);letter-spacing:-.04em;font-size:1.9rem}

/* ─── Alerts ────────────────────────────────────────────── */
.alert{padding:14px 18px;border-radius:var(--radius-sm);margin:14px 0;font-size:.9rem;font-weight:600;border-left:5px solid currentColor;box-shadow:0 12px 28px rgba(15,20,40,.08)}
.alert-solid{border:1px solid rgba(15,23,42,.10)}
.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}
.alert-error,.alert-danger{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}
.alert-warning{background:#fffbeb;border:1px solid #fde68a;color:#92400e}
.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}

/* ─── Forms ─────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:grid;gap:6px}
.field label{font-size:.875rem;font-weight:600;color:var(--text)}
.field input,.field select,.field textarea{width:100%;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--line);font-family:inherit;font-size:.95rem;background:#fff;color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:rgba(226,55,68,.4);box-shadow:0 0 0 3px rgba(226,55,68,.10)}
.field textarea{min-height:110px;resize:vertical}

.password-group{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:stretch}
.password-group input{min-width:0}
.password-toggle{min-width:92px;padding-inline:14px;border-radius:var(--radius-sm);border:1px solid var(--line);background:#fff;font-weight:700;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;gap:8px}
.password-toggle:hover{color:var(--text)}
.password-meter{font-size:.82rem;font-weight:700;color:var(--muted)}
.password-meter[data-score='1']{color:#b91c1c}
.password-meter[data-score='2']{color:#b45309}
.password-meter[data-score='3']{color:#15803d}
.password-meter[data-score='4']{color:#0f766e}

/* ─── Tables ────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-size:.9rem}
.table th{padding:10px 12px;border-bottom:2px solid var(--line);text-align:left;font-size:.78rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.table td{padding:13px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background:rgba(226,55,68,.02)}

/* ─── Badges ────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:5px 11px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid transparent}
.badge.green{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}
.badge.red{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.badge.gold{background:#fffbeb;color:#92400e;border-color:#fde68a}
.badge.blue{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}

/* ─── Menu toolbar & cats ───────────────────────────────── */
.menu-toolbar,.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}
.menu-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.menu-cats a{padding:9px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:.875rem;font-weight:600;color:var(--muted);transition:all var(--transition)}
.menu-cats a:hover{color:var(--text);border-color:var(--line-strong)}
.menu-cats a.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 6px 18px rgba(226,55,68,.28)}

/* ─── Menu grid items ───────────────────────────────────── */
.menu-grid{perspective:1400px}
.menu-item{transform-style:preserve-3d;transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .22s cubic-bezier(.4,0,.2,1);overflow:hidden}
.menu-item:hover{transform:translateY(-5px) rotateX(1.5deg) rotateY(-1.5deg);box-shadow:var(--shadow-lift)}
.menu-image-frame{padding:12px;border-radius:18px;background:linear-gradient(180deg,#fff,#f9fafb);border:1px solid var(--line);display:grid;place-items:center;margin-bottom:14px;position:relative;overflow:hidden}
.menu-card-thumb{width:100%;max-height:180px;object-fit:contain;border-radius:12px}
.menu-item h3{font-family:var(--font-display);margin:0 0 8px;letter-spacing:-.03em}
.menu-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:.82rem;color:var(--muted);margin:10px 0}
.price{font-size:1.2rem;font-weight:800;color:var(--primary);font-family:var(--font-display);letter-spacing:-.04em}

/* ─── Cart rows ─────────────────────────────────────────── */
.cart-row,.order-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}
.cart-summary{display:grid;gap:10px}

/* ─── Profile / restaurant ──────────────────────────────── */
.restaurant-hero,.profile-card{display:grid;gap:18px}
.profile-head{display:flex;gap:16px;align-items:center}
.brand-logo{width:66px;height:66px;object-fit:cover;border-radius:20px;border:1px solid var(--line);background:#fff;padding:6px;box-shadow:0 8px 24px rgba(15,20,40,.10)}
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.detail-grid > div{padding:16px;border-radius:18px;background:rgba(15,111,255,.04);border:1px solid var(--line)}

/* ─── QR ────────────────────────────────────────────────── */
.qr-hint-box{margin:16px 0;padding:16px;border-radius:18px;border:1px dashed var(--line);background:#f8fbff}
.prompt-box{width:100%;min-height:280px;padding:16px;border-radius:18px;border:1px solid var(--line);background:#f8fafc;font:inherit;line-height:1.55;white-space:pre-wrap;resize:vertical}
.qr-wrap{display:grid;gap:14px;justify-items:center;text-align:center}
.qr-frame-classic,.qr-frame-gold,.qr-frame-dark,.qr-frame-rose,.qr-frame-mint,.qr-frame-cafe,.qr-frame-bbq,.qr-frame-sunrise,.qr-frame-ocean,.qr-frame-lemon{padding:20px;border-radius:28px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.qr-frame-gold{background:linear-gradient(180deg,#fff8e7,#fff);color:#3f2b00}
.qr-frame-dark{background:linear-gradient(180deg,#111827,#0b1220);color:#fff}
.qr-frame-rose{background:linear-gradient(180deg,#7f1d1d,#fff1f2);color:#fff}
.qr-frame-mint{background:linear-gradient(180deg,#ecfdf5,#fff);color:#064e3b}
.qr-frame-cafe{background:linear-gradient(180deg,#f8efe8,#fff);color:#4b2e2b}
.qr-frame-bbq{background:linear-gradient(180deg,#2f1b18,#fff5f1);color:#fff}
.qr-frame-sunrise{background:linear-gradient(180deg,#fff1cc,#fff);color:#9a3412}
.qr-frame-ocean{background:linear-gradient(180deg,#e0f2fe,#fff);color:#0f172a}
.qr-frame-lemon{background:linear-gradient(180deg,#fef9c3,#fff);color:#3f3f46}
.qr-print-card{max-width:520px;margin-inline:auto;justify-items:center;text-align:center;position:relative;overflow:hidden}
.qr-print-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,color-mix(in srgb,var(--qr-accent,#e23744) 18%,transparent),transparent 40%),radial-gradient(circle at bottom right,color-mix(in srgb,var(--qr-fg,#111) 10%,transparent),transparent 35%);pointer-events:none}
.qr-print-card > *{position:relative;z-index:1}
.qr-print-head{width:100%;display:grid;gap:16px}
.qr-print-badge{display:inline-flex;align-self:flex-start;margin-bottom:8px;padding:7px 12px;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.04em;background:rgba(226,55,68,.08);color:var(--primary);border:1px solid rgba(226,55,68,.15)}
.qr-print-info{width:100%;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid var(--line)}
.qr-card-meta{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.qr-card-meta > div{padding:14px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.8)}
.qr-code-image{width:320px;height:320px;object-fit:contain;border-radius:28px;border:10px solid #fff;background:#fff;box-shadow:0 24px 60px rgba(15,20,40,.14)}
.qr-card-copy{width:100%;padding:14px 16px;border-radius:16px;border:1px dashed var(--line);background:#f8fafc}
.qr-actions{justify-content:center}
.qr-design-preview{margin-top:16px;padding:14px;border-radius:18px;border:1px dashed var(--line);background:#f8fafc}
.qr-design-gallery{grid-template-columns:repeat(3,1fr);margin-top:16px}
.qr-poster-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.qr-poster-pill{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;background:var(--qr-accent,var(--primary));color:#fff;font-size:.8rem;font-weight:800;letter-spacing:.04em;box-shadow:0 12px 24px rgba(0,0,0,.10)}
.qr-poster-copy{width:100%;padding:10px 14px 0;display:grid;gap:6px}
.qr-poster-copy h3{font-family:var(--font-display);margin:0;font-size:2rem;line-height:1.02;letter-spacing:-.06em}
.qr-poster-copy p{margin:0;color:var(--muted);font-size:.92rem}
.qr-poster-kicker{font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);font-size:.78rem}
.qr-code-wrap{width:100%;display:grid;justify-items:center;gap:10px;padding:10px 0 4px}
.qr-code-caption{display:grid;justify-items:center;gap:2px}

/* QR template gallery */
.template-gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.template-card{display:grid;gap:10px;cursor:pointer}
.template-card input{position:absolute;opacity:0;pointer-events:none}
.template-thumb{min-height:196px;border-radius:24px;border:1px solid var(--line);padding:16px;display:grid;gap:12px;align-content:space-between;box-shadow:inset 0 1px 0 rgba(255,255,255,.75);transition:transform var(--transition),box-shadow var(--transition)}
.template-thumb:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift)}
.template-card.selected .template-thumb{outline:3px solid var(--primary);outline-offset:3px}
.template-thumb-top{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;font-size:1rem}
.template-thumb-copy{font-size:.92rem;font-weight:700;line-height:1.2;max-width:12ch}
.template-thumb-qr{width:88px;height:88px;border-radius:18px;background:#fff;border:1px solid rgba(15,20,40,.10);display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px;align-self:center;justify-self:center}
.template-thumb-qr span{border-radius:4px;background:linear-gradient(135deg,#111,#888)}
.template-thumb-qr span:nth-child(2){transform:scale(.92)}
.template-thumb-qr span:nth-child(3){transform:scale(.84)}
.template-card-title{text-align:center;font-size:.875rem;color:var(--muted);font-weight:600}

/* ─── Bill ──────────────────────────────────────────────── */
.bill-card{max-width:900px;margin-inline:auto}
.bill-meta{margin-top:18px}
.bill-lines{display:grid;gap:10px;margin-top:20px;padding-top:10px;border-top:1px dashed var(--line)}
.bill-line{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.bill-totals{display:grid;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
.bill-totals > div{display:flex;justify-content:space-between;gap:12px}
.bill-grand{font-size:1.1rem;font-weight:800}
.hide-on-print{margin-top:20px}
.bill-card .detail-grid{grid-template-columns:repeat(3,1fr)}

/* ─── Image viewer ──────────────────────────────────────── */
.menu-image-trigger{all:unset;display:block;cursor:pointer;width:100%}
.menu-image-trigger:focus-visible,.image-viewer-actions .btn:focus-visible,.image-viewer-backdrop:focus-visible{outline:3px solid rgba(226,55,68,.38);outline-offset:3px}
.menu-image-badge{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 12px;border-radius:999px;background:rgba(15,22,42,.78);color:#fff;font-size:.78rem;font-weight:700;position:absolute;left:50%;bottom:12px;transform:translateX(-50%);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);pointer-events:none}
.image-viewer-modal{position:fixed;inset:0;z-index:200;background:rgba(9,14,28,.76);display:none;align-items:center;justify-content:center;padding:14px}
.image-viewer-modal.is-open{display:flex}
.image-viewer-backdrop{position:absolute;inset:0;border:0;background:transparent;cursor:pointer}
.image-viewer-dialog{position:relative;z-index:1;width:min(1140px,100%);max-height:calc(100vh - 28px);overflow:hidden;background:rgba(255,255,255,.97);border:1px solid rgba(255,255,255,.5);border-radius:32px;box-shadow:0 40px 100px rgba(0,0,0,.32);display:grid;gap:16px;padding:22px;backdrop-filter:blur(20px)}
.image-viewer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.image-viewer-header h2{font-family:var(--font-display);margin:0;font-size:1.5rem;letter-spacing:-.04em}
.image-viewer-stage{min-height:min(68vh,720px);max-height:calc(100vh - 240px);overflow:auto;display:grid;place-items:center;padding:20px;border-radius:24px;background:radial-gradient(circle at top,rgba(226,55,68,.07),transparent 42%),linear-gradient(180deg,#f8fbff,#ffffff);perspective:1400px;overscroll-behavior:contain}
.image-viewer-card{transform-style:preserve-3d;transform:rotateX(8deg) rotateY(0deg);transition:transform .25s ease;display:grid;place-items:center}
.image-viewer-card.is-spin{animation:viewer-spin 4.2s linear infinite}
.image-viewer-card.is-original{animation:none;transform:none;width:max-content;max-width:none}
.image-viewer-image{display:block;width:min(100%,760px);max-width:100%;max-height:100%;height:auto;object-fit:contain;border-radius:24px;box-shadow:0 28px 80px rgba(15,22,42,.20)}
.image-viewer-card.is-original .image-viewer-image{width:auto;max-width:none;max-height:none}
.image-viewer-footer{padding:0 4px 2px}
@keyframes viewer-spin{from{transform:rotateX(8deg) rotateY(0deg)}to{transform:rotateX(8deg) rotateY(360deg)}}

/* ─── Menu hero ─────────────────────────────────────────── */
.menu-hero-shell{display:grid;gap:20px}
.menu-hero-panel{display:grid;gap:20px}
.menu-hero-copy{display:grid;gap:10px}
.menu-title{font-family:var(--font-display);margin-bottom:0;letter-spacing:-.04em}
.menu-subtitle{max-width:68ch;line-height:1.75}
.menu-hero-actions{display:grid;gap:14px}
.menu-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.menu-metric{padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#fff,rgba(255,255,255,.72));box-shadow:0 4px 14px rgba(15,20,40,.05)}
.menu-metric span{display:block;font-size:.8rem;color:var(--muted);margin-bottom:6px;font-weight:600}
.menu-metric strong{font-family:var(--font-display);font-size:1.4rem;letter-spacing:-.04em}
.menu-hero-summary{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.9fr);gap:16px;align-items:stretch;margin-top:0}
.menu-hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.menu-search-card{padding:18px;border-radius:24px;background:linear-gradient(135deg,rgba(226,55,68,.06),rgba(255,255,255,.94));border:1px solid var(--line)}
.menu-search-form{display:grid;gap:14px}
.menu-search-field input{min-height:52px;font-size:.97rem;border-radius:16px}
.menu-toolbar-panel{position:sticky;top:74px;z-index:10;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.menu-cats-sticky{overflow:auto;scrollbar-width:thin;padding-bottom:2px}
.menu-cats-sticky a{white-space:nowrap}
.menu-list-panel{padding-top:22px}
.menu-sections{display:grid;gap:28px}
.menu-section{display:grid;gap:16px}
.menu-section-head h2{font-family:var(--font-display);margin:0;font-size:1.45rem;letter-spacing:-.04em}
.menu-grid-app{grid-template-columns:repeat(2,1fr)}
.menu-item-app{display:grid;gap:16px;padding:18px}
.menu-card-top{display:grid;grid-template-columns:128px minmax(0,1fr);gap:16px;align-items:start}
.menu-image-trigger{border:0;padding:0;background:transparent;cursor:pointer;text-align:left}
.menu-image-frame{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fafc);min-height:128px;display:grid;place-items:center}
.menu-card-thumb{width:100%;height:128px;object-fit:cover}
.menu-image-badge{position:absolute;left:10px;bottom:10px;padding:6px 9px;border-radius:999px;background:rgba(15,22,42,.82);color:#fff;font-size:.75rem;font-weight:700}
.menu-card-placeholder{height:128px;border-radius:18px;border:1px dashed var(--line);display:grid;place-items:center;background:linear-gradient(180deg,#fff,#f8fafc);font-family:var(--font-display);font-weight:900;letter-spacing:.1em;color:var(--primary);font-size:1.4rem}
.menu-item-body{display:grid;gap:10px}
.menu-item-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.menu-item-topline h3{font-family:var(--font-display);margin:0;font-size:1.1rem;line-height:1.22;letter-spacing:-.03em}
.menu-description{line-height:1.65;color:var(--muted)}
.menu-meta{display:flex;flex-wrap:wrap;gap:6px}
.menu-meta span{padding:6px 10px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);font-size:.8rem;color:var(--muted)}
.menu-status-row{margin:0}
.menu-stock{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0;font-size:.8rem;font-weight:700}
.stock-soldout{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.menu-card-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding-top:12px;border-top:1px solid var(--line)}
.menu-stepper{display:flex;align-items:center;gap:10px}
.stepper-btn{width:40px;height:40px;border-radius:13px;border:1px solid var(--line);background:#fff;font-size:1.3rem;font-weight:900;cursor:pointer;box-shadow:0 4px 12px rgba(15,20,40,.07);transition:background var(--transition),box-shadow var(--transition),transform var(--transition)}
.stepper-btn:hover{background:#f8fafc;box-shadow:0 8px 20px rgba(15,20,40,.11);transform:translateY(-1px)}
.stepper-btn:active{transform:translateY(0)}
.stepper-count{min-width:44px;text-align:center;font-family:var(--font-display);font-weight:800;font-size:1.1rem}
.menu-add-btn,.menu-remove-btn{min-width:136px}
.menu-sticky-cart{position:sticky;bottom:18px;z-index:12;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:20px;padding:16px 20px;border-radius:24px;border:1px solid rgba(226,55,68,.15);background:rgba(255,255,255,.96);box-shadow:0 24px 60px rgba(15,20,40,.14);backdrop-filter:blur(14px)}
.menu-empty{padding:32px;text-align:center;display:grid;justify-items:center;gap:14px}

/* ─── Cart page ─────────────────────────────────────────── */
.cart-layout,.cart-checkout-grid{display:grid;gap:20px}
.cart-hero-panel{display:grid;gap:18px}
.cart-items-panel{display:grid;gap:18px}
.cart-list{display:grid;gap:16px}
.cart-item{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:16px;align-items:center;padding:18px;border-radius:22px;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#fbfdff);transition:box-shadow var(--transition)}
.cart-item:hover{box-shadow:var(--shadow)}
.cart-item-main{display:flex;align-items:center;gap:16px}
.cart-thumb{width:86px;height:86px;border-radius:18px;object-fit:cover;border:1px solid var(--line);background:#f3f4f6;flex-shrink:0}
.cart-item-copy{display:grid;gap:5px}
.cart-item-copy h3{font-family:var(--font-display);margin:0;font-size:1.05rem;letter-spacing:-.03em}
.cart-price{font-family:var(--font-display);font-weight:800;color:var(--primary);font-size:1.05rem}
.cart-item-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.cart-item-total{text-align:right;display:grid;gap:5px;min-width:112px}
.mini-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.checkout-form{display:grid;gap:14px;margin-top:16px}
.checkout-form textarea{min-height:120px}

/* ─── Menu layout variants ──────────────────────────────── */
.menu-layout-luxury .menu-item-app{border-radius:28px;box-shadow:0 24px 60px rgba(15,20,40,.09);border:1px solid rgba(124,58,237,.13)}
.menu-layout-luxury .menu-item-topline h3{font-size:1.45rem}
.menu-layout-poster .menu-item-app{border-radius:30px;border:1px solid rgba(234,88,12,.15);background:linear-gradient(180deg,rgba(255,247,237,.95),#fff)}
.menu-layout-poster .menu-item-topline h3{font-size:1.55rem;letter-spacing:-.05em}
.menu-layout-compact .menu-item-app{padding:14px;border-radius:18px}
.menu-layout-compact .menu-item-body{gap:7px}
.menu-layout-compact .menu-card-thumb{border-radius:14px}
.menu-layout-compact .menu-item-topline h3{font-size:1.05rem}
.menu-layout-compact .muted{font-size:.88rem}
.menu-layout-compact .badges-row{gap:5px}
.menu-layout-grid .menu-item-app{background:#fff}
.menu-layout-cards .menu-item-app{background:linear-gradient(180deg,#fff,#fbfdff)}

/* ─── Footer ────────────────────────────────────────────── */
.site-footer{padding:26px 0 38px;border-top:1px solid var(--line);margin-top:28px;background:rgba(255,255,255,.42);font-size:.875rem}
.footer-links{display:flex;gap:6px;flex-wrap:wrap}

/* ─── Login ─────────────────────────────────────────────── */
.login-wrap{display:grid;place-items:center;min-height:calc(100vh - 140px)}
.login-card{width:min(520px,100%)}

/* ─── Ads ───────────────────────────────────────────────── */
.one-ad{display:grid;grid-template-columns:144px 1fr;gap:16px;align-items:center}
.one-ad img{width:100%;height:100%;object-fit:cover;border-radius:18px}
.ad-stack{display:grid;gap:14px}.ad-stack .panel{width:100%}
.ad-google-block{min-height:250px;overflow:hidden}
.ad-google-block ins.adsbygoogle{display:block;min-height:250px}
.ad-card{min-height:240px}
.ad-card strong{font-size:1.02rem}
.ad-stack .grid-2{grid-template-columns:1fr}

/* ─── Misc ──────────────────────────────────────────────── */
.waiting-timer{font-family:var(--font-display);font-size:2rem;font-weight:900;letter-spacing:-.06em}
.waiting-timer[data-minutes]{display:inline-block;padding:10px 14px;border-radius:14px;background:#fff;border:1px solid rgba(15,23,42,.08)}
.mobile-only{display:none}
.code-box,.prompt-box{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,'Liberation Mono',monospace}

/* ─── Toast ─────────────────────────────────────────────── */
.toast-stack{position:fixed;top:20px;right:20px;z-index:1000;display:grid;gap:10px;max-width:min(92vw,360px)}
.toast{display:grid;gap:5px;padding:15px 18px;border-radius:20px;box-shadow:0 20px 50px rgba(15,20,40,.20);border:1px solid rgba(15,20,40,.07);background:#fff;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1) both}
@keyframes toastIn{from{opacity:0;transform:translateX(24px) scale(.97)}to{opacity:1;transform:none}}
.toast strong{font-size:.9rem;font-weight:700}
.toast span{font-size:.92rem;color:var(--muted)}
.toast-success{border-color:rgba(16,185,129,.22)}
.toast-error{border-color:rgba(239,68,68,.22)}
.toast-warning{border-color:rgba(245,158,11,.26)}
.toast-info{border-color:rgba(59,130,246,.22)}
.toast.is-hidden{opacity:0;transform:translateY(-8px) scale(.97);transition:all .35s ease;pointer-events:none}

/* ─── Page loader ───────────────────────────────────────── */
.page-loader{position:fixed;inset:0;background:rgba(253,252,251,.94);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;pointer-events:none;transition:opacity .22s ease}
.page-loader-card{min-width:228px;display:grid;justify-items:center;gap:14px;padding:30px 34px;border-radius:28px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-lift);text-align:center}
.page-loader-card strong{font-family:var(--font-display);font-size:1rem;letter-spacing:-.02em}
.page-loader-spinner{width:52px;height:52px;border-radius:50%;border:4px solid var(--primary-light);border-top-color:var(--primary);animation:spin .85s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
body.is-loading .page-loader{opacity:1;pointer-events:auto}

/* ─── Top progress bar ──────────────────────────────────── */
.top-progress{position:fixed;top:0;left:0;height:2.5px;width:0%;z-index:10002;background:linear-gradient(90deg,var(--primary),#ff8c94,var(--gold));box-shadow:0 0 16px rgba(226,55,68,.5);transition:width .24s ease,opacity .3s ease;opacity:0;pointer-events:none}
.top-progress[data-state="loading"]{opacity:1}
.top-progress[data-state="done"]{opacity:1}

/* ─── Fade in & loading states ──────────────────────────── */
body.is-loading .site-header,body.is-loading .page-shell,body.is-loading .admin-main{filter:blur(.3px)}
body:not(.is-loading) .page-shell,body:not(.is-loading) .admin-main{animation:fadeIn .3s ease-out}
@keyframes fadeIn{from{opacity:.96;transform:translateY(3px)}to{opacity:1;transform:none}}

/* ─── Content visibility ────────────────────────────────── */
.panel,.menu-item-app,.cart-item,.order-row,.feature,.stat,.menu-metric,.ad-card,.toast{content-visibility:auto;contain-intrinsic-size:1px 420px}
.menu-card-thumb,.cart-thumb,.brand-logo,.ad-card img,.qr-code-image{background:#f3f4f6}

/* ─── Skeleton ──────────────────────────────────────────── */
.skeleton-line,.skeleton-block{position:relative;overflow:hidden;background:#eef2f7;border-radius:12px}
.skeleton-line::after,.skeleton-block::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);animation:shimmer 1.5s infinite}
.skeleton-line{height:14px}
.skeleton-block{min-height:120px}
@keyframes shimmer{100%{transform:translateX(100%)}}

/* ─── Responsive ────────────────────────────────────────── */
@media (max-width:980px){
  .hero,.feature-list,.grid-3,.grid-4,.admin-shell,.grid-2,.form-grid,.detail-grid,.qr-card-meta{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto;overflow:visible}
  .cart-row,.order-row,.one-ad{grid-template-columns:1fr}
  .mobile-only{display:block}
  .top-nav{display:none}
  .hero-copy h1,.section-title{font-size:2.4rem}
  .qr-code-image{width:280px;height:280px}
  .menu-hero-summary,.menu-grid.grid-1 .menu-item-app{grid-template-columns:1fr}
  .menu-metrics{grid-template-columns:1fr 1fr}
  .menu-grid-app{grid-template-columns:1fr}
  .menu-toolbar-panel{top:0}
  .admin-main{padding:18px}
}

@media (max-width:640px){
  .menu-metrics,.mini-summary{grid-template-columns:1fr 1fr}
  .menu-card-top,.cart-item{grid-template-columns:1fr}
  .cart-item-main{align-items:flex-start}
  .menu-sticky-cart{flex-direction:column;align-items:stretch}
  .menu-item-app{padding:14px}
  .menu-card-actions{flex-direction:column;align-items:stretch}
  .menu-add-btn,.menu-remove-btn{width:100%}
  .cart-item{padding:14px}
  .cart-item-controls{justify-content:flex-start}
  .toast-stack{left:12px;right:12px;top:12px;max-width:none}
  .template-gallery{grid-template-columns:repeat(2,1fr)}
  .qr-design-gallery{grid-template-columns:1fr}
}

@media (max-width:720px){
  .image-viewer-dialog{padding:14px;border-radius:22px}
  .image-viewer-stage{min-height:58vh;max-height:calc(100vh - 240px);padding:12px}
  .image-viewer-image{border-radius:18px}
}

/* ─── Print ─────────────────────────────────────────────── */
@media print{
  @page{size:100mm 150mm;margin:0}
  html,body{background:#fff !important}
  body *{visibility:hidden !important}
  .qr-print-card,.qr-print-card *{visibility:visible !important}
  .qr-print-card{position:fixed;left:0;top:0;width:100mm;min-height:150mm;margin:0 !important;padding:6mm !important;box-shadow:none !important;border:0 !important;page-break-inside:avoid;break-inside:avoid}
  .qr-print-card .qr-code-image{width:62mm;height:62mm;border-width:2mm;box-shadow:none}
  .hide-on-print{display:none !important}
  .bill-card{max-width:none;padding:0;border:0;box-shadow:none}
  .bill-line,.bill-totals > div{break-inside:avoid}
}

/* ─── Reduced motion ────────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .page-loader-spinner{animation:none}
}


/* === Light UI refresh (safe override) === */
:root{
  --bg:#f8fafc;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --primary:#2563eb;
  --primary-2:#1d4ed8;
  --primary-light:rgba(37,99,235,.09);
  --gold:#b45309;
  --line:rgba(15,23,42,.08);
  --line-strong:rgba(15,23,42,.12);
  --shadow:0 8px 24px rgba(15,23,42,.05);
  --shadow-lift:0 14px 36px rgba(15,23,42,.08);
  --radius:18px;
  --radius-sm:12px;
  --radius-xs:10px;
  --font-display:system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-body:system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
html{color-scheme:light}
body{
  background:#f8fafc !important;
  background-image:none !important;
  color:var(--text) !important;
  font-family:var(--font-body) !important;
}
body.is-loading{overflow:hidden}
.bg-orb{display:none !important}
.container{width:min(1140px,calc(100% - 24px))}
.site-header,.sidebar{
  background:rgba(255,255,255,.88) !important;
  border-color:rgba(15,23,42,.06) !important;
  box-shadow:0 1px 0 rgba(15,23,42,.02) !important;
}
.site-header{backdrop-filter:blur(14px) saturate(140%) !important}
.header-inner{padding:12px 0}
.brand{font-size:1.08rem;letter-spacing:-.03em}
.top-nav{gap:6px}
.top-nav a,.footer-links a,.side-nav a{border-radius:999px;transition:background .18s ease,color .18s ease,transform .18s ease}
.top-nav a:hover,.footer-links a:hover,.side-nav a:hover{background:rgba(37,99,235,.06) !important;color:var(--text) !important;transform:translateY(-1px)}
.top-nav a.active{color:var(--primary) !important;background:var(--primary-light) !important}
.page-shell{padding:20px 0 40px}
.hero,.admin-shell,.grid-2,.grid-3,.grid-4,.feature-list,.stat-grid,.form-grid{gap:14px}
.hero{padding:14px 0 8px}
.hero-copy h1,.section-title{letter-spacing:-.045em}
.hero-copy p,.muted{color:var(--muted) !important}
.hero-card,.panel,.stat,.menu-item,.order-card,.project-card,.ad-card,.login-card,.profile-card{
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(15,23,42,.06) !important;
  box-shadow:var(--shadow) !important;
  border-radius:18px !important;
}
.hero-side,.panel,.stat,.menu-item,.order-card,.project-card,.ad-card,.login-card,.profile-card{padding:16px}
.btn{
  border-radius:12px !important;
  padding:10px 14px !important;
  box-shadow:none !important;
}
.btn-primary{box-shadow:none !important}
.btn:hover{transform:translateY(-1px) !important}
.btn:active{transform:translateY(0) scale(.99) !important}
.badge,.pill{background:#fff !important;border:1px solid rgba(15,23,42,.08) !important}
.dashboard, .stat-grid, .grid-2, .grid-3, .grid-4, .menu-grid, .orders-grid{gap:14px}
.stat .value{font-size:1.65rem}
.table th,.table td{padding:10px 8px}
.field input,.field select,.field textarea{
  border-radius:12px !important;
  background:#fff !important;
  border-color:rgba(15,23,42,.10) !important;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-color:rgba(37,99,235,.55) !important;
  box-shadow:0 0 0 4px rgba(37,99,235,.09);
}
.alert{border-radius:14px}
.toast-stack{left:12px;right:12px;top:12px;max-width:420px;z-index:10000}
.toast{border-radius:14px;box-shadow:var(--shadow)}
.page-loader{
  position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;
  background:rgba(248,250,252,.92);backdrop-filter:blur(10px);
  transition:opacity .22s ease,visibility .22s ease;
}
.page-loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.page-loader-card{
  display:grid;gap:10px;place-items:center;
  min-width:220px;padding:22px 24px;border-radius:20px;
  background:#fff;border:1px solid rgba(15,23,42,.06);box-shadow:var(--shadow);
}
.page-loader-spinner{
  width:42px;height:42px;border-radius:50%;
  border:3px solid rgba(37,99,235,.14);border-top-color:var(--primary);
  animation:spin .8s linear infinite;
}
.top-progress{
  position:fixed;top:0;left:0;width:0;height:2px;z-index:10000;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  transition:width .25s ease,opacity .25s ease;
}
.top-progress.is-done{opacity:0}
.site-footer{border-top:1px solid rgba(15,23,42,.06);background:rgba(255,255,255,.86)}
.admin-shell{grid-template-columns:260px 1fr}
.sidebar{padding:18px;backdrop-filter:blur(12px)}
.side-nav{gap:8px}
.side-nav a{padding:10px 12px;background:#fff;border:1px solid rgba(15,23,42,.06)}
.admin-main{padding:20px}
.admin-top{margin-bottom:16px}
.menu-item{display:flex;gap:14px;align-items:center}
.menu-item img{border-radius:14px}
.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 37%,#f1f5f9 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:0 0}}
.content-visibility-auto{content-visibility:auto;contain-intrinsic-size:1px 620px}
html,body,button,input,select,textarea{font-family:var(--font-body) !important}
h1,h2,h3,.brand,.section-title,.hero-copy h1,.panel h2,.panel h3,.login-card h2{font-family:var(--font-display) !important}
@media (max-width: 1024px){
  .hero,.admin-shell,.grid-2,.grid-3,.grid-4,.feature-list,.form-grid,.stat-grid{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid rgba(15,23,42,.06)}
  .admin-main{padding:16px}
}
@media (max-width: 760px){
  .container{width:min(100% - 16px,1140px)}
  .header-inner{flex-direction:column;align-items:flex-start;gap:10px}
  .top-nav{width:100%;overflow:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .top-nav a{white-space:nowrap}
  .page-shell{padding:16px 0 34px}
  .btn{width:100%}
  .cta-row,.pill-row,.badges-row{gap:8px}
}

.password-toggle-icon{font-size:1rem;line-height:1}
.password-toggle-text{line-height:1}

/* ─── Architecture / audit / enterprise views ──────────── */
.architecture-board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.arch-column{display:grid;gap:12px;align-content:start}
.arch-node{padding:18px;border-radius:20px;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f9fafb);box-shadow:var(--shadow);display:grid;gap:6px}
.arch-node strong{font-family:var(--font-display);letter-spacing:-.03em;font-size:1.02rem}
.arch-node span{color:var(--muted);font-size:.92rem;line-height:1.55}
.arch-source{border-color:rgba(34,197,94,.20);background:linear-gradient(180deg,#f0fdf4,#fff)}
.arch-admin{border-color:rgba(59,130,246,.20);background:linear-gradient(180deg,#eff6ff,#fff)}
.arch-sync{border-color:rgba(168,85,247,.18);background:linear-gradient(180deg,#faf5ff,#fff)}
.arch-arrow{text-align:center;font-size:1.35rem;color:var(--primary);font-weight:900;line-height:1}
.arch-story{display:grid;gap:12px}
.arch-story-item{padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:rgba(248,250,252,.9);display:grid;gap:4px}
.arch-story-item strong{font-family:var(--font-display);letter-spacing:-.03em}
.arch-story-item span{color:var(--muted);font-size:.92rem;line-height:1.55}
.audit-grid{display:grid;gap:10px}
.audit-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:#fff}
.audit-ok{background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.16)}
.audit-warn{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.20)}
.mini-menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.mini-menu-card{display:grid;grid-template-columns:94px 1fr;gap:12px;align-items:center;padding:12px;border-radius:18px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.mini-menu-image{width:94px;height:94px;border-radius:16px;display:grid;place-items:center;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,#f8fafc,#fff)}
.mini-menu-image img{width:100%;height:100%;object-fit:cover}
.arch-empty{padding:18px;border-radius:18px;border:1px dashed var(--line);background:#f8fafc;color:var(--muted);text-align:center}

@media (max-width: 900px){
  .architecture-board,.mini-menu-grid{grid-template-columns:1fr}
}


.qr-poster-shell{position:relative;width:min(100%,var(--poster-width,720px));margin:0 auto;min-height:760px;border-radius:var(--card-radius,28px);overflow:hidden;border:1px solid rgba(15,20,40,.12);box-shadow:0 24px 60px rgba(15,20,40,.16);background:#fff;display:block}
.qr-poster-background,.qr-poster-overlay,.qr-poster-content{position:absolute;inset:0}
.qr-poster-background{background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(1.01)}
.qr-poster-overlay{pointer-events:none;mix-blend-mode:normal}
.qr-poster-content{padding:var(--card-padding,24px);display:grid;grid-template-rows:auto 1fr auto;gap:18px;color:var(--poster-fg,#111);z-index:1}
.qr-poster-top{display:grid;gap:8px;max-width:100%}
.qr-poster-top h3,.qr-poster-copy h3{margin:0;font-family:var(--font-display);font-size:1.6rem;line-height:1.04;letter-spacing:-.04em}
.qr-poster-top p,.qr-poster-copy p{margin:0;line-height:1.5;max-width:36ch}
.qr-poster-copy{display:grid;gap:10px;align-content:center;max-width:min(100%,42ch);justify-self:start}
.qr-poster-kicker{font-size:.82rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--poster-accent,#111)}
.qr-poster-pill{display:inline-flex;width:max-content;max-width:100%;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.75);border:1px solid rgba(15,20,40,.12);font-size:.85rem;font-weight:800}
.qr-poster-qr{position:absolute;display:grid;place-items:center;width:calc(var(--qr-size,320px) + 20px);height:calc(var(--qr-size,320px) + 20px);padding:10px;border-radius:28px;background:rgba(255,255,255,.92);border:1px solid rgba(15,20,40,.12);box-shadow:0 18px 40px rgba(15,20,40,.18);z-index:2}
.qr-poster-qr .qr-code-image{width:var(--qr-size,320px);height:var(--qr-size,320px);border-width:6px;box-shadow:none}
.qr-pos-top-left .qr-poster-qr{top:var(--card-padding,24px);left:var(--card-padding,24px)}
.qr-pos-top-center .qr-poster-qr{top:var(--card-padding,24px);left:50%;transform:translateX(-50%)}
.qr-pos-top-right .qr-poster-qr{top:var(--card-padding,24px);right:var(--card-padding,24px)}
.qr-pos-center-left .qr-poster-qr{top:50%;left:var(--card-padding,24px);transform:translateY(-50%)}
.qr-pos-center .qr-poster-qr{top:50%;left:50%;transform:translate(-50%,-50%)}
.qr-pos-center-right .qr-poster-qr{top:50%;right:var(--card-padding,24px);transform:translateY(-50%)}
.qr-pos-bottom-left .qr-poster-qr{bottom:var(--card-padding,24px);left:var(--card-padding,24px)}
.qr-pos-bottom-center .qr-poster-qr{bottom:var(--card-padding,24px);left:50%;transform:translateX(-50%)}
.qr-pos-bottom-right .qr-poster-qr{bottom:var(--card-padding,24px);right:var(--card-padding,24px)}
.qr-poster-footer{font-size:.9rem;opacity:.9;padding-top:8px}
.qr-mini-brand{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:18px;background:rgba(255,255,255,.76);border:1px solid rgba(15,20,40,.12);font-weight:900;letter-spacing:.08em}
.qr-poster-shell .brand-logo{width:72px;height:72px;border-radius:20px}
.qr-text-left .qr-poster-copy,.qr-text-left .qr-poster-top{text-align:left;justify-self:start}
.qr-text-center .qr-poster-copy,.qr-text-center .qr-poster-top{text-align:center;justify-self:center}
.qr-text-right .qr-poster-copy,.qr-text-right .qr-poster-top{text-align:right;justify-self:end}
.qr-poster-shell .badges-row{justify-content:flex-start}
.qr-poster-shell .badge{background:rgba(255,255,255,.75)}
.qr-design-preview{position:relative}


/* ─── Icon helpers ─────────────────────────────────────── */
.nav-icon{width:1.05rem;height:1.05rem;display:inline-flex;align-items:center;justify-content:center;flex:0 0 1.05rem;color:currentColor}
.nav-icon svg{width:1.05rem;height:1.05rem;display:block;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.site-header .top-nav a,.side-nav a{display:inline-flex;align-items:center;gap:8px}
.site-header .top-nav a span:last-child,.side-nav a span:last-child{line-height:1}
.brand{display:inline-flex;align-items:center;gap:0;font-family:var(--font-display);font-weight:900;letter-spacing:-.05em;text-decoration:none}
.brand-mark{display:block}
.brand-wordmark{font-size:1.06rem;line-height:1;color:var(--text);padding:.1rem 0;white-space:nowrap}
.brand:hover .brand-wordmark{color:var(--primary)}
