@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@600;700;800&family=DM+Sans:wght@400;500;700&family=Noto+Sans+Arabic:wght@400;500;600;700&display=swap');

:root {
  --primary:#0066FF;--primary-dark:#0052CC;--secondary:#00D4AA;--accent:#FF6B35;
  --white:#FFF;--bg:#F8F9FB;--border:#E5E7EB;--text:#1A1D29;--text-sec:#6B7280;
  --success:#10B981;--warning:#F59E0B;--danger:#EF4444;--info:#3B82F6;
  --radius:12px;--radius-lg:16px;--radius-xl:24px;
  --shadow:0 4px 16px rgba(0,0,0,0.06);--shadow-hover:0 8px 32px rgba(0,0,0,0.10);--shadow-lg:0 20px 40px rgba(0,0,0,0.12);
  --font-heading:'Bricolage Grotesque',sans-serif;
  --font-body:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
}

/* Arabic font override */
[dir="rtl"] { --font-body:'Noto Sans Arabic','DM Sans',sans-serif; --font-heading:'Noto Sans Arabic','Bricolage Grotesque',sans-serif; }

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body,#root{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--font-heading);line-height:1.2;letter-spacing:-0.01em}
a{color:var(--primary);cursor:pointer;text-decoration:none;font-weight:600}
a:hover{text-decoration:underline}
input,select,textarea{font-family:inherit}

/* Safe area for notched phones */
body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);overscroll-behavior:none;-webkit-tap-highlight-color:transparent}

/* ── Nav ── */
.nav{background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;height:64px}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#0066FF,#00D4AA);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-actions{display:flex;gap:8px;align-items:center}

/* ── Lang Switcher ── */
.lang-switch{display:flex;gap:0;border:1.5px solid var(--border);border-radius:100px;overflow:hidden}
.lang-btn{padding:5px 12px;font-size:.75rem;font-weight:600;border:none;background:none;cursor:pointer;color:var(--text-sec);transition:all .2s;font-family:inherit}
.lang-btn.active{background:var(--primary);color:#fff}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius);border:none;font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .25s ease;white-space:nowrap;line-height:1.4}
.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 6px 20px rgba(0,102,255,.25)}
.btn-secondary{background:var(--white);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}
.btn-success{background:var(--success);color:#fff}.btn-success:hover{box-shadow:0 6px 20px rgba(16,185,129,.25)}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{box-shadow:0 6px 20px rgba(239,68,68,.25)}
.btn-ghost{background:transparent;color:var(--text-sec)}.btn-ghost:hover{color:var(--primary);background:rgba(0,102,255,.04)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-noshow{background:rgba(239,68,68,.08);color:var(--danger);border:1.5px solid rgba(239,68,68,.15)}.btn-noshow:hover{background:var(--danger);color:#fff}
.btn-sm{padding:7px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}
.btn-icon{background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--text-sec);display:flex;align-items:center;transition:all .2s}
.btn-icon:hover{background:var(--bg);color:var(--text)}.btn-icon-danger:hover{background:rgba(239,68,68,.08);color:var(--danger)}

/* ── Cards ── */
.card{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border);transition:all .3s ease}
.card-hover:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.card-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}

/* ── Inputs ── */
.field{margin-bottom:16px}
.field label{display:block;font-size:.875rem;font-weight:500;color:var(--text-sec);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:var(--radius);font-size:.95rem;color:var(--text);background:var(--white);transition:all .25s;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(0,102,255,.08)}
.field textarea{resize:vertical;min-height:80px}.field select{cursor:pointer}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checkbox-row{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 0;font-size:.9rem}
.checkbox-row input[type="checkbox"]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}

/* ── Badge ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:100px;font-size:.75rem;font-weight:600;white-space:nowrap}
.badge-success{background:rgba(16,185,129,.1);color:#059669}.badge-warning{background:rgba(245,158,11,.1);color:#D97706}
.badge-danger{background:rgba(239,68,68,.1);color:#DC2626}.badge-info{background:rgba(59,130,246,.1);color:#2563EB}
.badge-primary{background:rgba(0,102,255,.08);color:var(--primary)}

/* ── Alert ── */
.alert{padding:14px 18px;border-radius:var(--radius);display:flex;align-items:center;gap:10px;font-size:.875rem;line-height:1.5}
.alert-info{background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.12);color:#1E40AF}
.alert-success{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.12);color:#065F46}
.alert-warning{background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.12);color:#92400E}
.alert-danger{background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.12);color:#991B1B}

/* ── Toast ── */
.toast{padding:12px 18px;border-radius:var(--radius);font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-lg);animation:toastSlide .35s ease;min-width:260px;max-width:400px}
.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--primary);color:#fff}
@keyframes toastSlide{from{opacity:0;transform:translateX(80px)}}
[dir="rtl"] .toast{animation-name:toastSlideRTL}
@keyframes toastSlideRTL{from{opacity:0;transform:translateX(-80px)}}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:var(--white);border-radius:var(--radius-xl);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalPop .3s ease}
.modal-wide{max-width:620px}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}
.modal-body{padding:20px 24px 24px}
@keyframes modalPop{from{opacity:0;transform:scale(.96) translateY(8px)}}

/* ── Tabs ── */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:24px;overflow-x:auto;gap:0}
.tab{padding:12px 20px;font-size:.875rem;font-weight:500;border:none;background:none;cursor:pointer;color:var(--text-sec);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:6px;font-family:inherit}
.tab:hover{color:var(--primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
.tab-count{background:var(--danger);color:#fff;font-size:.65rem;padding:2px 7px;border-radius:100px}

/* ── Layout ── */
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.text-sec{color:var(--text-sec)}.text-sm{font-size:.875rem}.text-center{text-align:center}
.mono{font-family:'Monaco','Courier New',monospace}
.gradient-text{background:linear-gradient(135deg,#0066FF,#00D4AA);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.stat-card{background:var(--white);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);text-align:center}
.stat-value{font-size:2rem;font-weight:700;font-family:var(--font-heading);line-height:1}
.stat-label{font-size:.8rem;color:var(--text-sec);margin-top:6px}

.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.branch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.branch-details{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;margin-top:8px;font-size:.875rem}

.empty-state{text-align:center;padding:48px 16px;color:var(--text-sec)}.empty-icon{font-size:3rem;margin-bottom:12px}

/* ── Dashboard Layout ── */
.dashboard-layout{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--white);border-inline-end:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;inset-inline-start:0;bottom:0;z-index:50}
.sidebar-header{padding:16px 20px;border-bottom:1px solid var(--border)}
.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}
.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--radius);border:none;background:none;cursor:pointer;font-size:.875rem;color:var(--text-sec);transition:all .2s;width:100%;text-align:start;font-family:inherit}
.sidebar-item:hover{background:var(--bg);color:var(--primary)}
.sidebar-item.active{background:rgba(0,102,255,.06);color:var(--primary);font-weight:600}
.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px}
.main-content{flex:1;margin-inline-start:240px;display:flex;flex-direction:column;min-height:100vh}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}
.topbar-title{font-size:1.1rem;margin:0}
.topbar-right{display:flex;align-items:center;gap:12px}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0066FF,#00D4AA);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}
.content-area{flex:1;padding:24px;max-width:1100px}
.mobile-only{display:none}

/* ── Queue ── */
.queue-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.queue-branch-select{display:flex;align-items:center;gap:8px;margin-top:8px}
.queue-branch-select select{padding:6px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:.875rem;background:var(--white);font-family:inherit}
.queue-actions-bar{display:flex;gap:8px;flex-wrap:wrap}
.serving-hero{background:linear-gradient(135deg,#0066FF,#00D4AA);border-radius:var(--radius-xl);padding:32px;text-align:center;color:#fff;margin-bottom:20px}
.serving-label{font-size:.875rem;text-transform:uppercase;letter-spacing:1.5px;opacity:.85}
.serving-number{font-size:3.5rem;font-weight:800;font-family:var(--font-heading);line-height:1.1;margin:8px 0 16px}
.serving-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.queue-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px}
.queue-stat{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center}
.queue-stat strong{display:block;font-size:1.25rem;font-family:var(--font-heading);color:var(--primary)}
.queue-stat span{font-size:.75rem;color:var(--text-sec)}
.queue-list{display:flex;flex-direction:column;gap:6px}
.queue-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s;animation:fadeUp .3s ease both}
.queue-item:hover{border-color:var(--primary)}
.qi-number{font-size:1.25rem;font-weight:700;color:var(--primary);font-family:var(--font-heading);min-width:52px}
.qi-info{flex:1}.qi-phone{font-family:'Monaco',monospace;font-size:.875rem}
.qi-meta{display:flex;gap:8px;align-items:center;margin-top:2px}.qi-time{font-size:.75rem;color:var(--text-sec)}

/* ── Ticket ── */
.ticket-hero{background:linear-gradient(135deg,#0066FF,#00D4AA);border-radius:var(--radius-xl);padding:36px 24px;text-align:center;color:#fff;max-width:440px;margin:0 auto}
.ticket-label{font-size:.875rem;opacity:.85;text-transform:uppercase;letter-spacing:1px}
.ticket-number{font-size:4.5rem;font-weight:800;font-family:var(--font-heading);line-height:1;margin:8px 0}
.ticket-position{font-size:1.2rem;font-weight:500}.ticket-wait{font-size:.875rem;opacity:.8;margin-top:6px}
.ticket-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:.875rem}
.ticket-info-row:last-child{border:none}

/* ── Status Display ── */
.status-page{background:linear-gradient(135deg,#0D1117,#1A2332);min-height:100vh;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;cursor:pointer;user-select:none}
.status-store{font-size:1.25rem;opacity:.5;margin-bottom:24px}
.status-label{font-size:1.25rem;text-transform:uppercase;letter-spacing:3px;opacity:.6}
.status-number{font-size:7rem;font-weight:800;font-family:var(--font-heading);line-height:1;margin:12px 0 40px;background:linear-gradient(135deg,#0066FF,#00D4AA);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:520px;width:100%}
.status-box{text-align:center}.status-box-label{font-size:.875rem;opacity:.5;text-transform:uppercase;letter-spacing:1px}
.status-box-value{font-size:2.5rem;font-weight:700;font-family:var(--font-heading);margin-top:4px}
.status-paused{margin-top:32px;padding:12px 32px;background:rgba(245,158,11,.15);border-radius:var(--radius);color:#FCD34D;font-weight:600}
.status-footer{position:fixed;bottom:16px;font-size:.75rem;opacity:.3}

/* ── Visitor / Auth ── */
.visitor-page{min-height:100vh;background:var(--bg)}.visitor-center{padding:24px 16px;max-width:520px;margin:0 auto}
.auth-page{min-height:100vh;background:var(--bg)}
.auth-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 64px);padding:24px}
.auth-card{background:var(--white);border-radius:var(--radius-xl);padding:36px;max-width:440px;width:100%;box-shadow:var(--shadow);border:1px solid var(--border)}
.auth-switch{text-align:center;margin-top:20px;font-size:.875rem;color:var(--text-sec)}
.auth-hint{margin-top:16px;padding:12px;background:var(--bg);border-radius:8px;font-size:.8rem;color:var(--text-sec);text-align:center}
.steps-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:20px}
.step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;background:var(--border);color:var(--text-sec);transition:all .3s}
.step-dot.active{background:var(--primary);color:#fff}.step-line{width:48px;height:2px;background:var(--border)}

/* ── Landing ── */
.landing{min-height:100vh;background:var(--white)}
.hero{padding:80px 24px 64px;text-align:center;background:var(--white);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;inset-inline-end:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(0,102,255,.04) 0%,transparent 70%);pointer-events:none}
.hero-inner{max-width:720px;margin:0 auto;position:relative}
.hero-badge{display:inline-flex;padding:8px 16px;border-radius:100px;background:rgba(0,102,255,.06);color:var(--primary);font-size:.8rem;font-weight:600;margin-bottom:24px}
.hero h1{font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:20px;color:var(--text)}
.hero-sub{font-size:1.15rem;color:var(--text-sec);max-width:560px;margin:0 auto 32px;line-height:1.7}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.section{padding:64px 24px}.section-alt{background:var(--bg)}
.section-title{text-align:center;font-size:2rem;margin-bottom:8px}
.section-sub{text-align:center;color:var(--text-sec);margin-bottom:40px}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;max-width:960px;margin:0 auto}
.feature-card{background:var(--white);border-radius:var(--radius-lg);padding:28px;border:1px solid var(--border);transition:all .3s;animation:fadeUp .5s ease both}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.feature-icon{font-size:2rem;margin-bottom:12px}.feature-card h4{margin-bottom:6px}.feature-card p{font-size:.875rem;color:var(--text-sec)}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;max-width:960px;margin:0 auto}
.pricing-card{background:var(--white);border-radius:var(--radius-xl);padding:32px;border:1.5px solid var(--border);position:relative;transition:all .3s}
.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.pricing-popular{border-color:var(--primary);box-shadow:0 4px 24px rgba(0,102,255,.1)}
.popular-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:4px 16px;border-radius:100px;font-size:.65rem;font-weight:700;letter-spacing:1px}
.pricing-tier{margin-bottom:8px}
.pricing-price{font-size:2.5rem;font-weight:800;font-family:var(--font-heading);color:var(--text)}
.pricing-sub{font-size:.875rem;color:var(--text-sec);margin-bottom:20px}
.pricing-features{list-style:none;margin-bottom:24px}
.pricing-features li{padding:6px 0;font-size:.875rem;color:var(--text-sec);display:flex;align-items:center;gap:8px}
.pricing-features li .pf-icon{font-size:.8rem}
.pricing-features li:not(.disabled) .pf-icon{color:var(--success)}.pricing-features li.disabled{opacity:.45}.pricing-features li.disabled .pf-icon{color:var(--danger)}
.footer{padding:32px 24px;text-align:center;border-top:1px solid var(--border);color:var(--text-sec);font-size:.8rem}

/* ── Admin ── */
.admin-layout{min-height:100vh;background:var(--bg)}
.request-card{border-inline-start:4px solid var(--primary)}
.request-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin-bottom:12px}
.request-reason{background:var(--bg);border-radius:8px;padding:10px 14px;margin-bottom:12px}

/* ── Tier Selector ── */
.tier-selector{display:flex;gap:12px}
.tier-option{flex:1;padding:16px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;transition:all .2s}
.tier-option:hover{border-color:rgba(0,102,255,.3)}.tier-option.selected{border-color:var(--primary);background:rgba(0,102,255,.03)}
.tier-option strong{display:block;margin-bottom:2px}

/* ── Email Settings ── */
.settings-section{border-top:1px solid var(--border);margin-top:24px;padding-top:24px}
.smtp-status{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:100px;font-size:.75rem;font-weight:600}
.smtp-ok{background:rgba(16,185,129,.1);color:#059669}
.smtp-no{background:rgba(239,68,68,.1);color:#DC2626}

/* ── Animations ── */
.fade-in{animation:fadeUp .4s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Splash ── */
#splash{position:fixed;inset:0;z-index:99999;background:#FAFBFC;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .4s ease}
#splash.hide{opacity:0;pointer-events:none}
#splash .splash-logo{font-family:var(--font-heading);font-size:2rem;font-weight:800;background:linear-gradient(135deg,#0066FF,#00D4AA);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
#splash .splash-spinner{width:32px;height:32px;margin-top:24px;border:3px solid #E5E7EB;border-top-color:#0066FF;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.icon svg{width:100%;height:100%}

/* ── Mobile ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);transition:transform .3s ease;position:fixed}
  [dir="rtl"] .sidebar{transform:translateX(100%)}
  .sidebar-open{transform:translateX(0)!important;box-shadow:var(--shadow-lg)}
  .main-content{margin-inline-start:0}.mobile-only{display:flex!important}
  .hero h1{font-size:2.2rem}.hero{padding:48px 16px}
  .ticket-number{font-size:3.5rem}.serving-number{font-size:2.5rem}.status-number{font-size:5rem}
  .stats-grid{grid-template-columns:repeat(2,1fr)}.queue-stats-row{grid-template-columns:repeat(2,1fr)}
  .branch-grid{grid-template-columns:1fr}.pricing-grid{grid-template-columns:1fr;max-width:380px}
  .features-grid{grid-template-columns:1fr;max-width:440px}.request-grid{grid-template-columns:1fr}
  .queue-header{flex-direction:column}.content-area{padding:16px}.container{padding:0 16px}
  .field-row{grid-template-columns:1fr}
}
@media(max-width:480px){.hero h1{font-size:1.8rem}.stat-value{font-size:1.5rem}.serving-hero{padding:24px 16px}.serving-number{font-size:2rem}.auth-card{padding:24px}}
