:root{--primary: #1e4a47;--primary-hover: #2a625e;--on-primary: #eef4f3;--accent: #c2703d;--accent-hover: #a85c2f;--accent-tint: #f6e7db;--on-accent: #2a1a0e;--bg: #f7f6f3;--surface: #ffffff;--panel: #eeece6;--hairline: #e3e0d8;--muted: #5c5f5b;--ink: #1c211f;--ink-soft: #2a2f2d;--green: #2e7d52;--green-tint: #e5f3ea;--amber: #c0871c;--amber-tint: #f5ecd7;--red: #c23b34;--red-tint: #f8e3e1;--info: #2b6cb0;--info-tint: #e6effb;--neutral: #5c5f5b;--neutral-tint: #e6e4dc;--on-solid: #ffffff;--overlay: rgba(28, 33, 31, .45);--font-head: "Spectral", Georgia, "Times New Roman", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-mono: "SF Mono", "Menlo", "Consolas", monospace;--fz-xs: 11px;--fz-sm: 12px;--fz-md: 13px;--fz-base: 14px;--fz-lg: 16px;--fz-xl: 19px;--fz-2xl: 23px;--fz-3xl: 30px;--fz-4xl: 40px;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-black: 700;--lh-tight: 1.2;--lh-snug: 1.4;--lh-base: 1.6;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--space-9: 56px;--space-10: 72px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 16px;--radius-pill: 999px;--border-thin: 1px;--border-med: 2px;--border-thick: 3px;--border-accent: 4px;--shadow-sm: 0 1px 2px rgba(28, 33, 31, .05);--shadow-md: 0 2px 8px rgba(28, 33, 31, .08);--shadow-lg: 0 10px 30px rgba(28, 33, 31, .18);--sidebar-w: 244px;--topbar-h: 60px;--bottombar-h: 64px;--content-max: 1320px;--touch: 48px;--tap-lg: 56px;--icon-sm: 16px;--icon-md: 18px;--icon-lg: 22px;--stroke: 1.75;--ls-1: .3px;--ls-2: .4px;--ls-3: .5px;--col-tile: 260px;--modal-w: 660px;--login-w: 420px;--ease: cubic-bezier(.2, .7, .3, 1);--dur-fast: .12s;--dur: .2s;--z-sticky: 50;--z-overlay: 200;--z-modal: 300;--z-toast: 400;--sidebar-display: flex;--bottombar-display: none;--content-pad-x: var(--space-8);--content-pad-bottom: var(--space-8);--tile-min: 260px}@media (max-width: 640px){:root{--sidebar-display: none;--bottombar-display: flex;--content-pad-x: var(--space-4);--content-pad-bottom: calc(var(--bottombar-h) + var(--space-6));--tile-min: 160px}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-body);font-size:var(--fz-base);line-height:var(--lh-base);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-head);line-height:var(--lh-tight)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.tnum{font-variant-numeric:tabular-nums}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100%}@media (max-width: 640px){.shell{grid-template-columns:1fr}}.sidebar{display:var(--sidebar-display);flex-direction:column;background:var(--primary);color:var(--on-primary);position:sticky;top:0;height:100vh}.brand{font-family:var(--font-head);font-weight:var(--fw-black);font-size:var(--fz-xl);letter-spacing:var(--ls-1);padding:var(--space-5) var(--space-5) var(--space-4);display:flex;flex-direction:column;gap:var(--space-1);border-bottom:var(--border-thin) solid var(--primary-hover)}.brand small{font-family:var(--font-body);font-weight:var(--fw-regular);font-size:var(--fz-sm);color:var(--accent);letter-spacing:0}.nav{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:2px}.nav a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--on-primary);font-size:var(--fz-md);font-weight:var(--fw-medium);min-height:var(--touch);opacity:.86;transition:background var(--dur-fast) var(--ease)}.nav a:hover{background:var(--primary-hover);opacity:1}.nav a.active{background:var(--accent);color:var(--on-accent);opacity:1;font-weight:var(--fw-semibold)}.nav a .ic{display:inline-flex;width:var(--icon-md);height:var(--icon-md)}.nav a .badge-dot{margin-left:auto;background:var(--red);color:var(--on-solid);font-size:var(--fz-xs);font-weight:var(--fw-bold);min-width:18px;height:18px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;justify-content:center;padding:0 var(--space-1)}.nav a.active .badge-dot{background:var(--primary);color:var(--on-primary)}.userbox{padding:var(--space-4);border-top:var(--border-thin) solid var(--primary-hover)}.userbox .name{font-weight:var(--fw-semibold);font-size:var(--fz-md)}.userbox .role{font-size:var(--fz-xs);color:var(--accent);text-transform:uppercase;letter-spacing:var(--ls-2)}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:var(--space-3);padding:0 var(--content-pad-x);border-bottom:var(--border-thin) solid var(--hairline);background:var(--surface);position:sticky;top:0;z-index:var(--z-sticky)}.topbar h1{font-size:var(--fz-2xl);font-weight:var(--fw-bold);letter-spacing:var(--ls-1)}.content{padding:var(--space-6) var(--content-pad-x) var(--content-pad-bottom);max-width:var(--content-max);width:100%}.spacer{flex:1}.toolbar{display:flex;align-items:center;gap:var(--space-3)}.bottombar{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottombar-h);background:var(--primary);z-index:var(--z-sticky);border-top:var(--border-thin) solid var(--primary-hover)}@media (max-width: 880px){.bottombar{display:var(--bottombar-display)}}.bottombar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--on-primary);font-size:var(--fz-xs);opacity:.8}.bottombar a.active{color:var(--accent);opacity:1}.card{background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm);margin-bottom:var(--space-4)}.card h3{font-size:var(--fz-lg);font-weight:var(--fw-bold);margin-bottom:var(--space-1)}.grid{display:grid;gap:var(--space-4)}.grid.cols{grid-template-columns:repeat(auto-fill,minmax(var(--tile-min),1fr))}.grid.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.two-col{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-4)}@media (max-width: 880px){.two-col{grid-template-columns:1fr}}.kpi{background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5)}.kpi .label{font-size:var(--fz-xs);text-transform:uppercase;letter-spacing:var(--ls-2);color:var(--muted);font-weight:var(--fw-semibold)}.kpi .value{font-family:var(--font-head);font-size:var(--fz-3xl);font-weight:var(--fw-black);margin-top:var(--space-1);font-variant-numeric:tabular-nums}.kpi .sub{font-size:var(--fz-sm);color:var(--muted);margin-top:var(--space-1)}.kpi.accent{border-left:var(--border-accent) solid var(--accent)}table{width:100%;border-collapse:collapse;font-size:var(--fz-md)}th{text-align:left;font-size:var(--fz-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--ls-3);color:var(--muted);padding:var(--space-2) var(--space-3);border-bottom:var(--border-med) solid var(--hairline);background:var(--panel);white-space:nowrap}td{padding:var(--space-2) var(--space-3);border-bottom:var(--border-thin) solid var(--hairline);vertical-align:middle}tbody tr:hover{background:var(--panel)}.num{text-align:right;font-variant-numeric:tabular-nums}.clickable{cursor:pointer}.badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--fz-xs);font-weight:var(--fw-bold);padding:2px var(--space-2);border-radius:var(--radius-sm);text-transform:capitalize;letter-spacing:var(--ls-1);white-space:nowrap}.badge.green{background:var(--green-tint);color:var(--green)}.badge.amber{background:var(--amber-tint);color:var(--amber)}.badge.red{background:var(--red-tint);color:var(--red)}.badge.info{background:var(--info-tint);color:var(--info)}.badge.neutral{background:var(--neutral-tint);color:var(--neutral)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:var(--touch);padding:0 var(--space-4);border-radius:var(--radius-md);border:var(--border-thin) solid var(--hairline);background:var(--surface);color:var(--ink);font-size:var(--fz-base);font-weight:var(--fw-semibold);transition:background var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}.btn:hover{background:var(--panel)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--on-primary)}.btn.dark{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}.btn.dark:hover{background:var(--primary-hover)}.btn.danger{background:var(--red);color:var(--on-solid);border-color:var(--red)}.btn.danger:hover{background:var(--red);opacity:.9}.btn.ghost{background:transparent}.btn.sm{min-height:var(--space-8);padding:0 var(--space-3);font-size:var(--fz-md)}.btn.block{width:100%}.btn:disabled{opacity:.55;cursor:default}.btn .ic{width:var(--icon-sm);height:var(--icon-sm)}.field{margin-bottom:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.field label{font-size:var(--fz-sm);font-weight:var(--fw-semibold);color:var(--ink-soft)}.field input,.field select,.field textarea{font-family:inherit;font-size:var(--fz-base);padding:var(--space-2) var(--space-3);min-height:var(--touch);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-md);background:var(--surface);color:var(--ink);width:100%}.field textarea{min-height:var(--space-10);resize:vertical;line-height:var(--lh-snug)}.field input:focus,.field select:focus,.field textarea:focus{outline:var(--border-med) solid var(--accent-tint);border-color:var(--accent)}.row2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-3)}@media (max-width: 880px){.row3{grid-template-columns:1fr}}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-3) var(--space-5)}.kv .k{font-size:var(--fz-xs);text-transform:uppercase;letter-spacing:var(--ls-2);color:var(--muted);font-weight:var(--fw-semibold)}.kv .v{font-size:var(--fz-base);font-weight:var(--fw-medium);margin-top:2px}.empty{padding:var(--space-7);text-align:center;color:var(--muted);font-size:var(--fz-md);border:var(--border-thin) dashed var(--hairline);border-radius:var(--radius-lg)}.muted{color:var(--muted)}.figure{font-family:var(--font-head);font-weight:var(--fw-bold);font-variant-numeric:tabular-nums}.ref{font-family:var(--font-mono);font-size:var(--fz-sm);color:var(--ink-soft)}.ic{display:inline-flex;align-items:center;justify-content:center}.right{text-align:right}.center{text-align:center}.price{font-family:var(--font-head);font-weight:var(--fw-bold);color:var(--accent-hover);font-variant-numeric:tabular-nums}.sync{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--fz-xs);font-weight:var(--fw-semibold);text-transform:capitalize;color:var(--muted)}.sync .dot{width:var(--space-2);height:var(--space-2);border-radius:var(--radius-pill);background:var(--green)}.sync.offline .dot{background:var(--red)}.sync.syncing .dot{background:var(--amber)}.spinner{width:var(--icon-lg);height:var(--icon-lg);border:var(--border-med) solid var(--hairline);border-top-color:var(--accent);border-radius:var(--radius-pill);display:inline-block;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);display:flex;align-items:flex-start;justify-content:center;padding:var(--space-8) var(--space-4);z-index:var(--z-modal);overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:var(--modal-w);padding:var(--space-6);box-shadow:var(--shadow-lg)}.modal h2{font-size:var(--fz-xl);font-weight:var(--fw-bold)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:var(--primary)}.login-card{width:100%;max-width:var(--login-w);background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-lg)}.login-card .brandmark{font-family:var(--font-head);font-weight:var(--fw-black);font-size:var(--fz-3xl);letter-spacing:var(--ls-1)}.login-card .brandmark span{color:var(--accent)}.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-top:var(--space-3)}.pin-grid button{min-height:var(--tap-lg);font-size:var(--fz-xl);font-weight:var(--fw-bold);border-radius:var(--radius-md);border:var(--border-thin) solid var(--hairline);background:var(--surface)}.pin-grid button:hover{background:var(--panel)}.staff-pick{display:flex;flex-direction:column;gap:var(--space-2)}.staff-pick button{display:flex;align-items:center;justify-content:space-between;min-height:var(--touch);padding:0 var(--space-4);border-radius:var(--radius-md);border:var(--border-thin) solid var(--hairline);background:var(--surface);font-weight:var(--fw-semibold)}.staff-pick button:hover{border-color:var(--accent)}.pin-display{letter-spacing:var(--ls-3);font-size:var(--fz-2xl);text-align:center;font-family:var(--font-head);min-height:var(--space-8)}.alert-list{display:flex;flex-direction:column;gap:var(--space-2)}.alert-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--panel);font-size:var(--fz-md)}.alert-row .ic{color:var(--amber)}.alert-row.red .ic{color:var(--red)}.tag-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}pre.payload{background:var(--primary);color:var(--on-primary);border-radius:var(--radius-md);padding:var(--space-4);overflow-x:auto;font-family:var(--font-mono);font-size:var(--fz-sm);line-height:var(--lh-snug)}.menu-course{margin-bottom:var(--space-4)}.menu-course h4{font-family:var(--font-head);font-size:var(--fz-lg);color:var(--primary);border-bottom:var(--border-thin) solid var(--hairline);padding-bottom:var(--space-1);margin-bottom:var(--space-2);text-transform:capitalize}.menu-dish{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) 0}.menu-dish .dish-name{font-family:var(--font-head);font-weight:var(--fw-semibold)}.menu-dish .dish-meta{font-size:var(--fz-sm);color:var(--muted)}.ppds{border:var(--border-med) solid var(--ink);border-radius:var(--radius-sm);padding:var(--space-4);max-width:360px;background:var(--surface)}.ppds .ppds-name{font-family:var(--font-head);font-weight:var(--fw-bold);font-size:var(--fz-lg)}.ppds .ppds-ingredients{font-size:var(--fz-sm);margin-top:var(--space-2);line-height:var(--lh-snug)}.ppds .ppds-allergen{font-weight:var(--fw-bold);text-transform:uppercase}.ppds .ppds-foot{font-size:var(--fz-xs);color:var(--muted);margin-top:var(--space-2)}.board{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(180px,1fr);gap:var(--space-3);overflow-x:auto;padding-bottom:var(--space-2)}.board .col{background:var(--panel);border-radius:var(--radius-md);padding:var(--space-3);min-height:120px}.board .col h4{font-family:var(--font-body);font-size:var(--fz-xs);text-transform:uppercase;letter-spacing:var(--ls-2);color:var(--muted);margin-bottom:var(--space-2)}.board .pcard{background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2);font-size:var(--fz-md)}.board .pcard .pcard-sub{font-size:var(--fz-sm);color:var(--muted)}.sidebar{height:100vh;height:100dvh}.login-wrap{min-height:100vh;min-height:100dvh}html{-webkit-text-size-adjust:100%}a,button,.btn,.clickable,.nav a,.bottombar a,.bottombar button,input,select,textarea{-webkit-tap-highlight-color:transparent}.btn,.nav a,.bottombar a,.bottombar button,.clickable{touch-action:manipulation}.board{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}img,video,canvas,svg.media{max-width:100%;height:auto}@media (max-width: 1024px){table tbody tr:hover td,table tbody tr.clickable:hover td,.tbl tbody tr:hover td,.tbl tbody tr.clickable:hover td,tr.clickable:hover td,.tbl tr:hover td{background:transparent}table tbody tr:hover,table tbody tr.clickable:hover,.tbl tbody tr:hover,.tbl tbody tr.clickable:hover{background:var(--surface)}.nav a:hover{background:transparent;opacity:.82}.btn:hover{background:var(--panel)}.btn.primary:hover{background:var(--accent)}.btn.dark:hover{background:var(--primary)}.btn.ghost:hover{background:transparent}.btn.danger:hover{filter:none}.btn.ghost.danger:hover{background:transparent;filter:none}.clickable:hover,.card:hover,.tile:hover{background:var(--surface)}}@media (max-width: 1024px){.field input,.field select,.field textarea,input,select,textarea{font-size:16px}.btn,button,.nav a,.clickable,.staff-btn{min-height:var(--touch)}.btn.sm,button.sm,.iconbtn,.icon-btn,.btn-icon,.btn.icon{min-height:44px;min-width:44px}}@media (max-width: 1024px){table{display:block;width:100%}table thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}table tbody{display:grid;gap:var(--space-2);grid-template-columns:1fr;min-width:0}table tr{display:block;background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);min-width:0;overflow-wrap:break-word}table td{display:inline;padding:0;border:0;white-space:normal;vertical-align:baseline;min-width:0}table td:first-child{display:block;font-weight:var(--fw-bold);font-size:var(--fz-base);color:var(--ink);margin-bottom:2px}table td:first-child:before{content:""}table td:not(:first-child){font-size:var(--fz-sm);color:var(--muted)}table td:not(:first-child):before{content:"·";color:var(--hairline);margin:0 var(--space-1)}table td:nth-child(2):before{content:"";margin:0}table td.row-actions,table td:has(>button),table td:has(>a.btn){display:block;margin-top:var(--space-2);font-size:var(--fz-md)}table td:not(:first-child).row-actions:before,table td:not(:first-child):has(>button):before,table td:not(:first-child):has(>a.btn):before{content:"";margin:0}table td:empty{display:none}}@media (min-width: 641px) and (max-width: 1024px){table tbody{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}@media (max-width: 640px){.shell{grid-template-columns:1fr}table tbody{grid-template-columns:1fr;gap:0;background:var(--surface);border:var(--border-thin) solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}table tr{border:0;border-bottom:var(--border-thin) solid var(--hairline);border-radius:0;padding:6px var(--space-3)}table tr:last-child{border-bottom:0}table tr{display:flow-root}table td:first-child{margin-bottom:0;line-height:var(--lh-tight)}table td:not(:first-child){line-height:var(--lh-tight)}table td.row-actions,table td:has(>button),table td:has(>a.btn){float:none;clear:both;display:flex;gap:var(--space-2);width:100%;margin:var(--space-2) 0 0}table td.row-actions>.btn,table td.row-actions>button,table td:has(>button)>button,table td:has(>button)>.btn,table td:has(>a.btn)>a.btn{flex:1 1 0;min-width:0;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.tile-grid,.grid.cols,.tiles{grid-template-columns:1fr}.grid.kpis,.kpis,.kpi-row,.stat-grid{grid-template-columns:1fr 1fr;gap:var(--space-2)}.kpi{padding:var(--space-3);min-width:0}.kpi>*:not(:first-child),.kpi .num,.kpi .value,.kpi .figure,.kpi strong,.kpi b{font-size:var(--fz-xl);line-height:var(--lh-tight);white-space:nowrap;overflow-wrap:normal}.content,.topbar{padding-left:max(var(--space-3),env(safe-area-inset-left));padding-right:max(var(--space-3),env(safe-area-inset-right))}.content>.card,.card{padding:var(--space-3)}.bottombar{height:calc(var(--bottombar-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.modal .toolbar:not(:first-child),.modal .actions,.modal .form-actions{display:flex;gap:var(--space-2);width:100%;margin-top:var(--space-4)}.modal .toolbar:not(:first-child)>.btn,.modal .toolbar:not(:first-child)>button,.modal .actions>.btn,.modal .actions>button{flex:1 1 0;min-height:48px}.modal .toolbar:not(:first-child)>.spacer{display:none}.modal form>.btn,.modal>.btn{display:block;width:100%;margin-top:var(--space-2);min-height:48px}.overlay{padding:0;align-items:stretch}.modal{width:100%;max-width:100%;height:100dvh;max-height:none;border-radius:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 var(--space-4) calc(var(--space-7) + env(safe-area-inset-bottom))}.modal>.toolbar:first-child,.modal h2:first-child{position:sticky;top:0;z-index:2;background:var(--surface);margin:0 calc(-1 * var(--space-4)) var(--space-3);padding:max(var(--space-4),env(safe-area-inset-top)) var(--space-4) var(--space-3);border-bottom:var(--border-thin) solid var(--hairline)}.staff-grid{grid-template-columns:1fr}.staff-btn{min-height:var(--touch);text-align:left}.pin{display:flex;justify-content:center;margin:var(--space-4) 0}.pin input{width:100%;max-width:280px;min-height:56px;font-size:1.5rem;text-align:center;letter-spacing:.4em}}.bottombar button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--on-primary);font-size:var(--fz-xs);opacity:.8;background:none;border:0;min-height:var(--touch)}.bottombar button.active{color:var(--accent);opacity:1}.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#141b2180;display:flex;flex-direction:column;justify-content:flex-end}.mobile-menu .sheet{background:var(--surface);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);max-height:85dvh;overflow-y:auto;padding:var(--space-3) var(--space-4) calc(var(--space-6) + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg)}.mobile-menu .sheet-handle{width:40px;height:4px;border-radius:var(--radius-pill);background:var(--hairline);margin:0 auto var(--space-3)}.mobile-menu .sheet-head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.mobile-menu .sheet-head .name{font-weight:var(--fw-semibold);font-size:var(--fz-md)}.mobile-menu .sheet-head .role{font-size:var(--fz-xs);color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-2)}.mobile-menu .sheet-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.mobile-menu .sheet-grid a{display:flex;align-items:center;gap:var(--space-3);min-height:var(--touch);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:var(--border-thin) solid var(--hairline);color:var(--ink);font-weight:var(--fw-semibold);font-size:var(--fz-md)}.mobile-menu .sheet-grid a.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.mobile-menu .sheet-grid a .ic{width:18px;height:18px}
