:root{--bg: #201c18;--surface: #2b2620;--surface-light: #363028;--cream: #e8ddd0;--cream-muted: #b5a893;--terracotta: #c4855a;--gold: #b8965a;--danger: #da6f5f;--success: #7a9b6d;--warning: #d4a24e;--radius-sm: 5px;--radius-md: 8px;--radius-lg: 10px;--touch: 48px;--font-ui: "Source Sans 3", system-ui, -apple-system, sans-serif;--font-title: "Lexend", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--cream);font-family:var(--font-ui);font-size:16px;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}h1,h2,h3{margin:0 0 .5em;text-wrap:balance}.page-title{display:flex;align-items:center;gap:12px}.page-logo{display:none;width:36px;height:36px;flex-shrink:0;mix-blend-mode:screen;filter:invert(1) brightness(.8) sepia(.3)}@media (max-width: 759px) and (orientation: portrait){.page-logo{display:block}}h1{font-family:var(--font-title);font-weight:700;font-size:2.3rem;letter-spacing:-.025em;line-height:1.1;color:var(--cream)}h2{font-family:var(--font-ui);font-size:1.35rem;font-weight:700;letter-spacing:-.01em;color:var(--terracotta)}h3{font-family:var(--font-ui);font-size:1.05rem;font-weight:700;color:var(--cream)}a{color:var(--gold)}button,input,select,textarea{font-family:inherit;font-size:1rem}.btn{min-height:calc(var(--touch) + 6px);border:none;border-radius:var(--radius-md);background:var(--terracotta);color:var(--bg);font-weight:700;font-size:1.05rem;padding:0 22px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:filter .12s ease-out,opacity .12s}.btn:hover:not(:disabled){filter:brightness(1.1)}.btn:active:not(:disabled){filter:brightness(.88);opacity:.92}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--secondary{background:var(--surface-light);color:var(--cream)}.btn--danger{background:var(--danger);color:var(--bg)}.btn--ghost{background:transparent;border:1px solid var(--gold);color:var(--gold)}.btn--block{width:100%}.btn--sm,.settings-page .btn{min-height:36px;font-size:.88rem;padding:0 14px}.card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;margin:8px 0}.card--alert{border:1px solid var(--danger)}.card--warn{border:1px solid var(--warning)}.field{display:block;margin-bottom:16px}.field label{display:block;font-size:.85rem;color:var(--cream-muted);margin-bottom:6px;font-weight:500}input:not([type=checkbox]):not([type=radio]),select,textarea{min-height:var(--touch);background:var(--surface);border:1px solid var(--surface-light);border-radius:var(--radius-sm);color:var(--cream);padding:10px 12px}.field input,.field select,.field textarea{width:100%}:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}input:not([type=checkbox]):not([type=radio]):focus-visible,select:focus-visible,textarea:focus-visible{border-color:var(--gold);outline-offset:0;border-radius:var(--radius-sm)}.muted{color:var(--cream-muted)}.error{color:var(--danger);font-weight:500;margin:8px 0}.chip{min-height:var(--touch);padding:0 16px;border-radius:8px;border:1px solid var(--gold);background:transparent;color:var(--cream);cursor:pointer;display:inline-flex;align-items:center;font-weight:500;transition:background .12s,color .12s,border-color .12s}.chip--active{background:var(--gold);color:var(--bg)}.chip--terracotta{border-color:var(--terracotta)}.chip--terracotta.chip--active{background:var(--terracotta);color:var(--bg)}.chip--danger{border-color:var(--danger)}.chip--danger.chip--active{background:var(--danger);color:var(--bg)}.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stack{display:flex;flex-direction:column;gap:8px}.spacer{flex:1}.grid-2{display:grid;grid-template-columns:1fr;gap:20px}@media (min-width: 760px){.grid-2{grid-template-columns:1fr 1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.app-shell{display:flex;min-height:100%}.content{flex:1;padding:24px 24px 96px;max-width:1100px;margin:0 auto;width:100%}.sidebar{width:230px;background:var(--surface);border-right:1px solid var(--surface-light);display:flex;flex-direction:column;padding:20px 12px;position:sticky;top:0;height:100vh}.brand{background:var(--surface);border-radius:var(--radius-md);padding:14px 12px 10px;margin-bottom:8px;text-align:center}.brand-logo{width:100%;max-width:140px;height:auto;display:block;margin:0 auto 6px;filter:invert(1) hue-rotate(155deg) saturate(.8) brightness(1.55);mix-blend-mode:screen}.brand-sub{color:var(--terracotta);font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;display:block}.nav-links{display:flex;flex-direction:column;gap:4px;flex:1}.nav-link{display:flex;align-items:center;gap:12px;min-height:var(--touch);padding:0 14px;border-radius:var(--radius-md);color:var(--cream-muted);text-decoration:none;font-weight:500}.nav-link.active{background:var(--surface-light);color:var(--cream)}.nav-icon{font-size:1.25rem;width:24px;text-align:center}.sidebar-foot{display:flex;flex-direction:column;gap:10px;padding:12px;border-top:1px solid var(--surface-light)}@media (max-width: 759px){.app-shell{flex-direction:column}.sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;height:auto;flex-direction:row;border-right:none;border-top:1px solid var(--surface-light);padding:4px;padding-bottom:max(4px,env(safe-area-inset-bottom));z-index:50;overflow-x:auto}.brand,.sidebar-foot{display:none}.nav-links{flex-direction:row;justify-content:space-between;width:100%;gap:0}.nav-link{flex-direction:column;gap:2px;flex:1;min-width:56px;padding:6px 2px;font-size:.7rem;text-align:center}.nav-label{font-size:.72rem}.content{padding:16px;padding-bottom:calc(90px + env(safe-area-inset-bottom))}}@keyframes login-enter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes dot-pop{0%{transform:scale(.5)}55%{transform:scale(1.25)}to{transform:scale(1)}}@keyframes pin-shake{0%,to{transform:translate(0)}18%{transform:translate(-8px)}36%{transform:translate(8px)}54%{transform:translate(-5px)}72%{transform:translate(5px)}90%{transform:translate(-2px)}}.login-wrap{display:grid;place-items:center;min-height:100vh;padding:24px}.login-card{width:100%;max-width:420px;animation:login-enter .42s cubic-bezier(.16,1,.3,1) both}.login-card>h1{margin-bottom:2px}.login-hello{margin-bottom:0}.login-card>p.muted{margin:4px 0 28px}.login-card>button.link-btn{display:block}.login-card>button.link-btn:first-child{margin-bottom:24px}.login-card>button.link-btn:last-child{margin-top:16px}.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin:0}.user-tile{display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--surface-light);border-radius:var(--radius-lg);padding:22px 10px;cursor:pointer;color:var(--cream);transition:border-color .15s,transform .05s;opacity:0;animation:login-enter .36s cubic-bezier(.16,1,.3,1) calc(80ms + var(--i, 0) * 45ms) both}.user-tile:hover{border-color:var(--gold)}.user-tile:active{transform:scale(.96)}.user-avatar{width:64px;height:64px;border-radius:50%;background:var(--terracotta);color:var(--bg);display:grid;place-items:center;font-family:var(--font-title);font-size:1.5rem;font-weight:700}.user-name{font-weight:600;text-align:center;font-size:.95rem}.pin-dots{display:flex;justify-content:center;gap:18px;margin:0 0 32px}.pin-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--gold);transition:background .12s,border-color .12s}.pin-dot--filled{background:var(--gold);animation:dot-pop .22s cubic-bezier(.16,1,.3,1) both}.pin-dots--shake{animation:pin-shake .34s cubic-bezier(.36,.07,.19,.97) both}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:300px;margin:0 auto}.pin-key{min-height:70px;font-size:1.7rem;font-weight:600;background:var(--surface);border:1px solid var(--surface-light);border-radius:var(--radius-md);color:var(--cream);cursor:pointer;transition:background .1s}.pin-key:active{background:var(--surface-light)}.pin-key:disabled{opacity:.45}.pin-key--del{font-size:1.4rem}.link-btn{background:none;border:none;color:var(--gold);cursor:pointer;padding:8px 0;font-size:.95rem;text-decoration:underline}.link-email{background:transparent;border:1px solid var(--surface-light);border-radius:20px;cursor:pointer;display:block;margin-top:16px;padding:8px 18px;font-family:var(--font-ui);font-size:.88rem;font-weight:500;color:var(--gold);transition:border-color .15s,background .15s}.link-email:hover{border-color:var(--gold);background:var(--surface-light)}.home-header{margin-bottom:28px}.home-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.home-greeting{margin-bottom:2px}.home-date{margin:0;font-size:.9rem}.home-signout{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--surface-light);background:var(--surface);color:var(--muted);font-size:1.2rem;cursor:pointer;flex-shrink:0;transition:border-color .15s,color .15s}.home-signout:hover{border-color:var(--gold);color:var(--cream)}.home-section{margin-bottom:28px}.home-section h2{margin-bottom:14px}.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.action-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px 16px;background:var(--surface);border-radius:var(--radius-lg);text-decoration:none;color:var(--cream);border:1px solid var(--surface-light);transition:opacity .15s,border-color .15s;text-align:center;min-height:110px}.action-tile:hover{border-color:var(--gold)}.action-tile:active{opacity:.8}.action-tile--wide{grid-column:1 / -1;flex-direction:row;justify-content:center;gap:12px;min-height:70px;padding:16px 24px}.action-tile--primary{background:var(--terracotta);border-color:transparent;color:var(--bg)}.action-tile--primary:hover{border-color:transparent;opacity:.9}.action-tile--green{background:var(--success);border-color:transparent;color:var(--bg)}.action-tile--green:hover{border-color:transparent;opacity:.9}.action-tile--cream{background:var(--cream);border-color:transparent;color:var(--bg)}.action-tile--cream:hover{border-color:transparent;opacity:.9}.action-tile-icon{font-size:2rem;line-height:1}.action-tile-label{font-weight:600;font-size:.9rem;line-height:1.3}.home-status{display:grid;grid-template-columns:1fr 1fr;gap:12px}.status-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:12px}.status-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.status-card-title{font-weight:700;font-size:.95rem;color:var(--cream)}.status-badge{font-size:.72rem;padding:2px 9px;border-radius:12px;font-weight:700;white-space:nowrap}.status-badge--ok{background:var(--success);color:var(--bg)}.status-card-link{font-size:.82rem;color:var(--gold);text-decoration:none;font-weight:600;margin-top:auto;padding-block:8px}.status-card-link:hover{text-decoration:underline}.cleaning-progress{display:flex;flex-direction:column;gap:6px}.cleaning-bar{height:8px;background:var(--surface-light);border-radius:4px;overflow:hidden}.cleaning-bar-fill{height:100%;width:100%;background:var(--gold);transform-origin:left center;transition:transform .5s ease-out}.cleaning-bar-fill--done{background:var(--success)}.cleaning-label{font-size:.85rem;font-weight:600;color:var(--cream)}.cleaning-sub{margin:0;font-size:.82rem}.oil-list{display:flex;flex-direction:column;gap:8px}.oil-item{display:flex;align-items:center;gap:10px}.oil-info{display:flex;flex-direction:column;gap:1px;min-width:0}.oil-fryer{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.oil-state{font-size:.78rem}@media (max-width: 480px){.home-actions,.home-status{grid-template-columns:1fr}.home-signout{display:flex}}.trace-page{display:flex;flex-direction:column;min-height:calc(100vh - 120px)}.capture-card{margin-top:auto}@media (max-width: 759px){.trace-page{min-height:calc(100vh - 106px - env(safe-area-inset-bottom))}.capture-card{margin-left:-16px;margin-right:-16px;margin-bottom:16px;border-radius:16px 16px 0 0;box-shadow:0 -4px 24px #0000004d}}.printer-badge{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;padding:5px 11px;border-radius:20px;margin-bottom:14px;border:1px solid}.printer-badge--ok{border-color:var(--success);color:var(--success);background:color-mix(in srgb,var(--success) 10%,transparent)}.printer-badge--off{border-color:var(--surface-light);color:var(--cream-muted)}.printer-badge-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:currentColor}.printer-badge--ok .printer-badge-dot{animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.35}}@media (prefers-reduced-motion: reduce){.printer-badge-dot{animation:none}}.label-group{margin-bottom:18px}.label-group-name{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--cream-muted);margin-bottom:8px}.label-chips{display:flex;flex-wrap:wrap;gap:8px}.product-chip{display:inline-flex;align-items:center;gap:6px;min-height:var(--touch);padding:0 6px 0 14px;border-radius:var(--radius-md);border:1px solid var(--terracotta);background:transparent;color:var(--cream);cursor:pointer;transition:background .12s,border-color .12s,color .12s;-webkit-user-select:none;user-select:none}.product-chip:hover{border-color:var(--gold);background:color-mix(in srgb,var(--terracotta) 12%,transparent)}.product-chip--active{background:var(--terracotta);border-color:var(--terracotta);color:var(--bg)}.product-chip--active .product-chip-fav{color:var(--bg);opacity:.6}.product-chip--active .product-chip-fav--on{opacity:1}.product-chip-name{font-weight:600;font-size:.95rem}.product-chip-days{font-size:.78rem;opacity:.7;white-space:nowrap}.product-chip-fav{background:none;border:none;cursor:pointer;padding:4px 6px;font-size:1rem;color:var(--cream-muted);line-height:1;border-radius:4px;transition:color .1s,transform .1s;flex-shrink:0}.product-chip-fav:hover{color:var(--gold);transform:scale(1.2)}.product-chip-fav--on{color:var(--gold)}
