:root{--bg: #0f1115;--surface: #181b22;--surface-2: #21252e;--border: #2c313c;--text: #e7e9ee;--muted: #98a0b0;--primary: #1f6f54;--primary-2: #2a8e6c;--danger: #c0413b;--warn: #b8862b;--radius: 12px;--shadow: 0 6px 24px rgba(0, 0, 0, .35)}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--primary-2);text-decoration:none}h1,h2,h3{margin:0 0 .5rem}h1{font-size:1.5rem}h2{font-size:1.2rem}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.topbar .brand{font-weight:700;display:flex;gap:.5rem;align-items:center}.topbar .who{color:var(--muted);font-size:.9rem}.tabs{display:flex;gap:.25rem;padding:.5rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto}.tabs a{padding:.5rem .9rem;border-radius:999px;color:var(--muted);white-space:nowrap;font-weight:600;font-size:.95rem}.tabs a.active{background:var(--primary);color:#fff}.subtabs{display:flex;gap:.25rem;overflow-x:auto;border-bottom:1px solid var(--border);margin-bottom:.5rem}.subtabs a{padding:.45rem .75rem;color:var(--muted);white-space:nowrap;font-weight:700;font-size:.9rem;border-bottom:2px solid transparent}.subtabs a.active{color:var(--text);border-bottom-color:var(--primary-2)}.content{padding:1rem;max-width:1100px;width:100%;margin:0 auto;flex:1}.pull-refresh{position:fixed;top:calc(env(safe-area-inset-top) + .5rem);left:50%;z-index:120;display:inline-flex;align-items:center;gap:.5rem;min-height:2.25rem;padding:.45rem .8rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease;font-size:.85rem;font-weight:700}.pull-refresh.active{opacity:1}.pull-refresh.ready{color:var(--text);border-color:var(--primary-2)}.pull-refresh-spinner{width:1rem;height:1rem;border:2px solid var(--border);border-top-color:var(--primary-2);border-radius:50%}.pull-refresh.ready .pull-refresh-spinner{animation:spin .8s linear infinite}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem}.card-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.row{display:flex;gap:.75rem;align-items:center}.row.between{justify-content:space-between}.row.wrap{flex-wrap:wrap}.stack{display:flex;flex-direction:column;gap:.5rem}.muted{color:var(--muted)}.small{font-size:.85rem}.spacer{flex:1}.pwa-install,.pwa-next{align-self:flex-start}.pwa-steps h3{margin:.25rem 0 0}.pwa-howto{display:grid;gap:.75rem}.pwa-step-card{display:grid;grid-template-columns:minmax(170px,.75fr) minmax(180px,1fr);gap:.75rem;align-items:start;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:.75rem}.pwa-step-copy{display:flex;gap:.65rem;align-items:flex-start}.pwa-step-copy p{margin:.2rem 0 0}.pwa-step-num{display:inline-grid;place-items:center;flex:0 0 auto;width:1.7rem;height:1.7rem;border-radius:999px;background:var(--primary);color:#fff;font-weight:800;font-size:.9rem}.pwa-safari-bar{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;min-height:56px;padding:.55rem;background:#1b1f27;border:1px solid var(--border);border-radius:14px;color:var(--text);font-weight:700}.pwa-safari-url{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-weight:600;font-size:.82rem}.pwa-safari-dots{position:relative;z-index:1;letter-spacing:.12rem;padding:.25rem .35rem;border-radius:999px}.pwa-safari-dots:after{content:"";position:absolute;top:-.35rem;right:-.3rem;bottom:-.35rem;left:-.3rem;border:3px solid #f0c04a;border-radius:999px;pointer-events:none}.pwa-shot{position:relative;margin:0;min-width:0;justify-self:center;width:100%;max-width:330px;overflow:hidden;border-radius:10px}.pwa-shot img{display:block;width:100%;max-height:380px;object-fit:contain;background:var(--bg);border:1px solid var(--border);border-radius:10px}.pwa-mark{position:absolute;border:3px solid #f0c04a;border-radius:999px;box-shadow:0 0 0 9999px #0000001f;pointer-events:none}.pwa-mark:after{content:"";position:absolute;right:-.5rem;bottom:-.45rem;width:.8rem;height:.8rem;border-right:3px solid #f0c04a;border-bottom:3px solid #f0c04a;transform:rotate(-15deg)}.pwa-mark-share{left:5%;top:1.5%;width:43%;height:11%}.pwa-mark-home{left:4%;top:75%;width:88%;height:7.5%}.notification-card:focus,.notification-card:target{outline:2px solid var(--primary-2);outline-offset:2px}button,.btn{font:inherit;cursor:pointer;border:1px solid var(--border);background:var(--surface-2);color:var(--text);padding:.55rem .9rem;border-radius:10px;font-weight:600}button:hover{border-color:var(--muted)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-2)}.btn-danger{background:transparent;border-color:var(--danger);color:#e88}.btn-sm{padding:.35rem .6rem;font-size:.85rem;border-radius:8px}.icon-btn{background:none;border:none;color:var(--muted);font-size:1.1rem;padding:.2rem .4rem}button:disabled{opacity:.5;cursor:not-allowed}label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.25rem}input,select,textarea{width:100%;font:inherit;padding:.55rem .7rem;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--text)}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-2);border-color:transparent}input[type=date],input[type=datetime-local],input[type=time]{color-scheme:dark}input::-webkit-calendar-picker-indicator{cursor:pointer;font-size:1.2rem;opacity:.8;padding-left:.3rem}input::-webkit-calendar-picker-indicator:hover{opacity:1}.field{margin-bottom:.75rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--border);font-size:.95rem}th{color:var(--muted);font-weight:600}.badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.78rem;font-weight:700;background:var(--surface-2);color:var(--muted)}.badge.ok{background:#2a8e6c33;color:#6fd6ad}.badge.warn{background:#b8862b33;color:#e6bd6b}.badge.danger{background:#c0413b33;color:#e89}.dot{width:9px;height:9px;border-radius:50%;display:inline-block;background:var(--muted)}.dot.on{background:#2a8e6c}.alert{padding:.7rem .9rem;border-radius:10px;margin-bottom:.75rem;font-size:.92rem}.alert.error{background:#c0413b26;border:1px solid var(--danger);color:#f0a6a3}.alert.info{background:var(--surface-2);border:1px solid var(--border);color:var(--muted)}.alert.success{background:#2a8e6c26;border:1px solid var(--primary);color:#8fe0c2}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary-2);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:460px;padding:1.2rem;box-shadow:var(--shadow);max-height:90vh;overflow:auto}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;padding:calc(.75rem + env(safe-area-inset-top)) .75rem calc(.75rem + env(safe-area-inset-bottom));display:grid;place-items:center;background:#000000b8;overflow:hidden}.onboarding-panel{width:min(720px,100%);max-height:min(820px,calc(100dvh - 1.5rem - env(safe-area-inset-top) - env(safe-area-inset-bottom)));overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}.onboarding-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.onboarding-head p{margin:0 0 .2rem}.onboarding-progress{display:flex;gap:.45rem;margin-bottom:.9rem}.onboarding-dot{width:2rem;height:.45rem;padding:0;border-radius:999px;background:var(--surface-2);border:1px solid var(--border)}.onboarding-dot.active{background:var(--primary-2);border-color:var(--primary-2)}.onboarding-dot.done{background:var(--primary);border-color:var(--primary)}.onboarding-body{min-height:180px;padding:.35rem 0 .75rem}.onboarding-body p{margin:0 0 .75rem;color:var(--muted)}.onboarding-feature-list{display:flex;flex-wrap:wrap;gap:.5rem}.onboarding-feature-list span{display:inline-flex;align-items:center;min-height:2rem;padding:.35rem .65rem;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;font-size:.9rem;font-weight:700}.onboarding-ios-grid{display:grid;gap:.75rem;grid-template-columns:1fr}.onboarding-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:.75rem}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:1rem}.login-card{width:100%;max-width:360px}.kiosk{min-height:100vh;background:var(--bg)}.kiosk-head{text-align:center;padding:1.5rem 1rem .5rem}.kiosk-clock{font-size:2.6rem;font-weight:800;letter-spacing:1px}.kiosk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;padding:1rem;max-width:900px;margin:0 auto}.kiosk-person{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem .8rem;text-align:center;font-weight:700;font-size:1.05rem;display:flex;flex-direction:column;gap:.5rem;align-items:center;min-height:96px;justify-content:center}.kiosk-person.in{border-color:var(--primary-2);box-shadow:inset 0 0 0 1px var(--primary-2)}.pin-display{font-size:2rem;letter-spacing:.5rem;text-align:center;min-height:2.5rem}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-top:.5rem}.pin-pad button{padding:1rem;font-size:1.3rem}.cal{border:1px solid var(--border);border-radius:10px;padding:.5rem;background:var(--bg)}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.cal-head .icon-btn{font-size:1.4rem;line-height:1;padding:0 .6rem}.cal-title{font-weight:700;text-transform:capitalize}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.cal-dow{text-align:center;font-size:.72rem;color:var(--muted);padding:.25rem 0;font-weight:600}.cal-day{aspect-ratio:1;border:1px solid transparent;background:var(--surface-2);border-radius:8px;font-weight:600;padding:0;font-size:.95rem}.cal-day:hover{border-color:var(--muted)}.cal-day.today{box-shadow:inset 0 0 0 1px var(--muted)}.cal-day.sel{background:var(--primary);border-color:var(--primary);color:#fff}@media(max-width:600px){.grid-2{grid-template-columns:1fr}.kiosk-clock{font-size:2rem}.pwa-step-card{grid-template-columns:1fr}.pwa-shot{max-width:min(280px,100%)}.pwa-shot img{max-height:min(300px,42dvh)}.onboarding-overlay{align-items:start}.onboarding-panel{padding:.85rem}.onboarding-body{min-height:150px}.onboarding-actions .spacer{display:none}.onboarding-actions button{flex:1 1 auto}}.day-group{margin-top:.75rem}.day-head{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;padding:.35rem .25rem;margin-bottom:.4rem;border-bottom:1px solid var(--border)}.day-head strong{text-transform:capitalize}.warn-text{color:#e6bd6b}.shift-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.5rem .7rem;margin-bottom:.35rem}.shift-main{display:flex;align-items:center;gap:.5rem;flex:1 1 240px;min-width:0}.shift-people{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.shift-actions{display:flex;gap:.4rem;margin-left:auto}.chip{display:inline-flex;align-items:center;gap:.35rem;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.15rem .5rem;font-size:.85rem}.chip-x{background:none;border:none;color:var(--muted);cursor:pointer;padding:0;font-size:.8rem;line-height:1}.chip-x:hover{color:#e89}.chip-ok{color:#6fd6ad;font-weight:700}.assign-select{padding:.3rem .5rem;font-size:.85rem;border-radius:8px;max-width:170px}@media(max-width:640px){.shift-actions{margin-left:0}.shift-main{flex-basis:100%}}.event-head{margin:.5rem 0 .3rem;font-size:.82rem;font-weight:600;letter-spacing:.03em;color:#e6bd6b}@media(max-width:720px){.content{padding:.75rem}h1{font-size:1.3rem}.topbar{flex-wrap:wrap;row-gap:.5rem}.topbar .who,.stamp-time{display:none}.card{overflow-x:auto;-webkit-overflow-scrolling:touch}table{white-space:nowrap}th,td{padding:.55rem .5rem}.stack>.row.wrap>.card{flex-basis:calc(50% - .5rem)}}.mock-shell{min-height:100vh;background:#f7f3eb;color:#17211e;padding:1.25rem}.mock-shell button,.mock-shell input{color:inherit}.mock-topline{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;max-width:1180px;margin:0 auto 1rem}.mock-topline h1{font-size:1.75rem;margin:0}.mock-topline a{color:#12352f;font-weight:800}.mock-kicker{margin:0 0 .25rem;color:#6f6255;font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.mock-switcher{display:flex;gap:.35rem;max-width:1180px;margin:0 auto 1rem;overflow-x:auto}.mock-switcher button,.mock-public-head button,.mock-actions button,.mock-login-panel button,.mock-sidebar button,.mock-toolbar button{border:1px solid #d9d0c2;background:#fffaf2;color:#17211e;border-radius:8px;min-height:2.4rem;padding:.55rem .8rem;font-weight:800}.mock-switcher button.active,.mock-sidebar button.active{background:#12352f;border-color:#12352f;color:#fffaf2}.mock-primary{background:#12352f!important;border-color:#12352f!important;color:#fffaf2!important}.mock-stage{max-width:1180px;min-height:660px;margin:0 auto;background:#fffaf2;border:1px solid #ded4c4;border-radius:12px;overflow:hidden;box-shadow:0 18px 55px #33281821}.mock-logo{display:inline-flex;align-items:center;gap:.7rem;min-width:0}.mock-logo img{width:42px;height:42px;border-radius:8px}.mock-logo strong,.mock-logo small{display:block;line-height:1.1}.mock-logo small{color:#6f6255;font-size:.78rem;font-weight:800}.mock-public{min-height:660px;background:linear-gradient(90deg,#12352ff2,#12352fb8),url(/harryda-bbq-logo-v3-512.png) right 8% center / min(42vw,440px) no-repeat,#12352f;color:#fffaf2}.mock-public-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,250,242,.2)}.mock-public-head nav,.mock-actions{display:flex;gap:.5rem;flex-wrap:wrap}.mock-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,390px);gap:2rem;align-items:center;min-height:570px;padding:2rem clamp(1.25rem,5vw,4rem)}.mock-hero-copy{max-width:620px}.mock-hero h1{font-size:clamp(2.4rem,8vw,5.4rem);line-height:.92;margin:0 0 1rem}.mock-hero p{max-width:520px;color:#f0dfc8;font-size:1.05rem;line-height:1.55}.mock-device{background:#f7f3eb;color:#17211e;border:8px solid #261b16;border-radius:28px;padding:1rem;box-shadow:0 24px 70px #00000059}.mock-device-top,.mock-status-row,.mock-panel-head,.mock-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem}.mock-status-row{margin:1.2rem 0 .7rem}.mock-pill{display:inline-flex;align-items:center;border-radius:999px;background:#f2b84b;color:#1d1607;min-height:1.7rem;padding:.25rem .65rem;font-size:.78rem;font-weight:900}.mock-shift-card{display:grid;gap:.35rem;background:#fffaf2;border:1px solid #ded4c4;border-radius:10px;padding:1rem}.mock-shift-card strong{font-size:1.8rem}.mock-shift-card small,.mock-device-top span,.mock-panel p,.mock-login-panel p{color:#6f6255}.mock-clock-btn{width:100%;min-height:3.4rem;margin-top:1rem;background:#d95f43!important;border-color:#d95f43!important;color:#fffaf2!important}.mock-centered{min-height:660px;display:grid;place-items:center;padding:1rem;background:#efe6d7}.mock-login-panel{display:grid;gap:.85rem;width:min(380px,100%);background:#fffaf2;border:1px solid #ded4c4;border-radius:12px;padding:1.25rem;box-shadow:0 18px 50px #3328181f}.mock-login-panel input{margin-top:.3rem;background:#f7f3eb;border:1px solid #d9d0c2;border-radius:8px}.mock-app{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:660px;background:#efe6d7}.mock-sidebar{display:flex;flex-direction:column;gap:.45rem;background:#12352f;color:#fffaf2;padding:1rem}.mock-sidebar .mock-logo{margin-bottom:1rem}.mock-sidebar .mock-logo small{color:#d9c9b3}.mock-sidebar button{width:100%;text-align:left;background:#fffaf214;color:#fffaf2;border-color:#fffaf22e}.mock-workspace{padding:1.25rem}.mock-toolbar{margin-bottom:1rem}.mock-toolbar h2{font-size:1.65rem}.mock-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.mock-panel{background:#fffaf2;border:1px solid #ded4c4;border-radius:10px;padding:1rem}.mock-span-2{grid-column:span 2}.mock-list-row{display:grid;grid-template-columns:1.2fr 1fr 1fr auto;align-items:center;gap:.75rem;padding:.7rem 0;border-top:1px solid #eadfce}.mock-list-row em{color:#12352f;font-style:normal;font-weight:900}.mock-meter{height:.8rem;overflow:hidden;background:#eadfce;border-radius:999px}.mock-meter span{display:block;height:100%;background:#12352f}.mock-stat{display:block;margin:.4rem 0;font-size:3rem;line-height:1}.mock-stat.warn{color:#d95f43}.mock-guidelines{display:grid;gap:1.4rem;min-height:660px;padding:clamp(1rem,4vw,2rem);background:#fffaf2}.mock-rule-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem}.mock-rule-grid article{border:1px solid #ded4c4;border-radius:10px;padding:1rem;background:#f7f3eb}.mock-rule-grid p{color:#6f6255}.mock-swatches{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:.6rem}.mock-swatches span{display:flex;align-items:end;min-height:90px;border-radius:10px;padding:.75rem;color:#fff;font-weight:900}@media(max-width:760px){.mock-shell{padding:.75rem}.mock-topline{align-items:flex-start;flex-direction:column}.mock-stage,.mock-public,.mock-centered,.mock-app,.mock-guidelines{min-height:600px}.mock-public-head{align-items:flex-start;flex-direction:column}.mock-hero{grid-template-columns:1fr;padding:1.25rem}.mock-device{max-width:360px}.mock-app{grid-template-columns:1fr}.mock-sidebar{position:static}.mock-grid,.mock-rule-grid,.mock-swatches{grid-template-columns:1fr}.mock-span-2{grid-column:auto}.mock-list-row{grid-template-columns:1fr;gap:.25rem}.mock-toolbar{align-items:flex-start;flex-direction:column}}
