.layout{display:flex;min-height:100vh}.layout__main{flex:1;min-width:0;display:flex;flex-direction:column}.layout__mobile-bar,.layout__backdrop{display:none}.sidebar{width:240px;background:#111827;color:#f9fafb;display:flex;flex-direction:column;padding:1.5rem 1rem;flex-shrink:0}.sidebar__top{position:relative}.sidebar__brand{font-weight:700;margin-bottom:2rem}.sidebar__close{display:none}.sidebar nav{display:flex;flex-direction:column;gap:.5rem;flex:1}.sidebar nav a{color:#d1d5db;text-decoration:none;padding:.5rem .75rem;border-radius:6px;min-height:var(--touch-min, 44px);display:flex;align-items:center}.sidebar nav a.active,.sidebar nav a:hover{background:#374151;color:#fff}.sidebar__footer{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem;margin-top:1rem}.sidebar__role{color:#9ca3af}.sidebar__footer button{background:transparent;border:1px solid #4b5563;color:#f9fafb;padding:.5rem;border-radius:6px;min-height:var(--touch-min, 44px)}.content{flex:1;padding:var(--space-4, 1rem);padding-bottom:calc(var(--space-4, 1rem) + var(--safe-bottom, 0px));min-width:0}@media (min-width: 768px){.content{padding:2rem}}@media (max-width: 767px){.layout__mobile-bar{display:flex;align-items:center;gap:var(--space-3, .75rem);padding:var(--space-3, .75rem) var(--space-4, 1rem);background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:30}.layout__menu-btn{min-width:var(--touch-min, 44px);min-height:var(--touch-min, 44px);border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:1.25rem}.layout__mobile-title{font-weight:600;font-size:.875rem}.layout__backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;border:none;background:#11182773;cursor:pointer}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:50;width:min(280px,88vw);transform:translate(-110%);transition:transform .2s ease;box-shadow:0 -4px 24px #0003}.layout--nav-open .sidebar{transform:translate(0)}.sidebar__close{display:inline-flex;position:absolute;top:0;right:0;min-width:36px;min-height:36px;align-items:center;justify-content:center;border:none;border-radius:6px;background:#ffffff1f;color:#f9fafb}.sidebar__brand{margin-bottom:1.5rem;padding-right:2.5rem}}.audit table{width:100%;border-collapse:collapse;background:#fff;font-size:.9rem}.audit__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.audit__header h1{margin:0;font-size:clamp(1.25rem,4vw,1.75rem)}.audit__filter{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;width:100%}@media (min-width: 480px){.audit__filter{flex-direction:row;align-items:center;width:auto}}.audit__filter select{min-height:var(--touch-min, 44px);padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px}@media (min-width: 480px){.audit__filter select{margin-left:.5rem}}.audit__pager{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:1rem}.audit__pager button{min-height:var(--touch-min, 44px);padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff}.audit th,.audit td{padding:.6rem .75rem;border-bottom:1px solid #e5e7eb;vertical-align:top}.audit th{white-space:nowrap}.dashboard__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.dashboard__header h1{margin:0;font-size:clamp(1.25rem,4vw,1.75rem)}.dashboard__header button{min-height:var(--touch-min, 44px)}.dashboard__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1rem}.metric-card{background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:8px;padding:1rem 1.25rem}.metric-card__label{display:block;font-size:.85rem;color:var(--muted, #6b7280);margin-bottom:.35rem}.metric-card__value{font-size:clamp(1.25rem,4vw,1.75rem);line-height:1.2}.metric-card--ok{border-color:#86efac}.metric-card--off{border-color:#fca5a5}.metric-card--warn{border-color:#fcd34d}.dashboard__total{color:var(--muted, #6b7280)}.dashboard__links a{color:var(--link, #2563eb)}.dashboard__section{margin:1.5rem 0;padding:1rem;border:1px solid var(--border, #e5e7eb);border-radius:8px;background:var(--surface, #fff)}.dashboard__section--warn{border-color:#fcd34d;background:#fffbeb}.dashboard__section h2{margin:0 0 .75rem;font-size:1rem}.dashboard__urgent-list,.dashboard__audit-list{margin:0 0 .75rem;padding-left:1.25rem}.dashboard__audit-list li{margin-bottom:.35rem;display:flex;flex-wrap:wrap;gap:.5rem}.dashboard__audit-reason{color:var(--muted, #6b7280);font-size:.875rem}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4, 1rem)}.login__card{background:#fff;padding:2rem;border-radius:12px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000014;display:flex;flex-direction:column;gap:1rem}.login__card label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.login__card input{padding:.6rem;border:1px solid #d1d5db;border-radius:6px}.login__hint{color:#6b7280;margin:0;font-size:.9rem}.login__error{color:#b91c1c;margin:0}.login__card button[type=submit]{background:#2563eb;color:#fff;border:none;padding:.75rem;border-radius:6px;font-weight:600}.detail h1{margin:0 0 1rem;font-size:clamp(1.25rem,4vw,1.75rem)}.detail section{background:#fff;padding:1.25rem;border-radius:8px;margin-bottom:1rem}.detail__meta{color:#6b7280;word-break:break-word}.detail__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem}.detail__actions button,.detail__actions a{min-height:var(--touch-min, 44px);padding:.5rem 1rem;border-radius:6px;border:1px solid #d1d5db;background:#fff}.detail__actions button.danger{background:#b91c1c;color:#fff;border-color:#b91c1c}.detail textarea,.detail select,.detail input[type=email],.detail input[type=password],.detail input[type=text]{display:block;width:100%;margin:.5rem 0;padding:.5rem .75rem;min-height:var(--touch-min, 44px);border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box}.detail__hint{font-size:.85rem;color:#6b7280}.detail__msg{color:#065f46;background:#d1fae5;padding:.5rem .75rem;border-radius:6px}.detail__form-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.detail__form-row>*{flex:1 1 12rem;min-width:0}@media (max-width: 767px){.detail section{padding:1rem}}.restaurants header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.restaurants header h1{margin:0;font-size:clamp(1.25rem,4vw,1.75rem)}.restaurants__search{display:flex;flex-wrap:wrap;gap:.5rem;width:100%}@media (min-width: 768px){.restaurants__search{width:auto;flex-wrap:nowrap}}.restaurants__search input{flex:1 1 12rem;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;min-height:var(--touch-min, 44px);min-width:0}.restaurants__search select{flex:1 1 8rem;min-height:var(--touch-min, 44px);padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px}.restaurants__search button{flex:1 1 auto;min-height:var(--touch-min, 44px);padding:.5rem 1rem;border:none;border-radius:6px;background:#2563eb;color:#fff;font-weight:600}@media (min-width: 480px){.restaurants__search button{flex:0 0 auto}}.restaurants__hint{margin:.25rem 0 0;color:#6b7280;font-size:.9rem;width:100%}.restaurants__summary{margin:0 0 1rem;padding:.75rem 1rem;border-radius:8px;background:#fef3c7;color:#92400e}.restaurants header>button{min-height:var(--touch-min, 44px);padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff}table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}th{white-space:nowrap}.badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.badge--ok{background:#d1fae5;color:#065f46}.badge--off{background:#fee2e2;color:#991b1b}:root{color-scheme:light;--safe-bottom: env(safe-area-inset-bottom, 0px);--color-bg: #f5f3ef;--color-surface: #ffffff;--color-text: #1c1c1a;--color-text-muted: #6b6b66;--color-border: #e4e0d8;--color-primary: #1a5c38;--color-primary-hover: #144a2d;--color-status-bg: #eef6f1;--color-accent: #c8a96e;--color-error: #b42318;--color-error-bg: #fef3f2;--color-success: #067647;--color-warning: #b54708;--color-warning-bg: #fffbeb;--color-warning-text: #92400e;--color-accent-bg: #f8f3eb;--font-sans: "Segoe UI", system-ui, -apple-system, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.45;--line-height-relaxed: 1.5;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--shadow-bar: 0 -4px 24px rgba(28, 28, 26, .08);--shadow-card: 0 1px 3px rgba(28, 28, 26, .06);--touch-min: 44px}:root{--bp-xs: 320px;--bp-sm: 480px;--bp-md: 768px;--bp-lg: 1024px;--bp-xl: 1280px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-4, 1rem));padding:0 var(--space-4, 1rem)}@media (min-width: 768px){.table-scroll{margin:0;padding:0}}.table-scroll table{min-width:640px}.app-shell{width:100%;margin-inline:auto}@media (min-width: 768px){.app-shell--narrow{max-width:480px}.app-shell--medium{max-width:768px}.app-shell--wide{max-width:1200px}}.field__input,.field__select,.field textarea,.form-field input,.form-field select,.form-field textarea{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.form-field input[type=time],.form-field input[type=date],.field__input[type=time],.field__input[type=date]{display:block}@media (max-width: 479px){.form__actions,.form-actions{flex-direction:column;align-items:stretch}.form__actions .btn,.form-actions .btn{width:100%}.field__input,.field__select{font-size:16px}}@media (min-width: 480px) and (max-width: 767px){.form__row--tablet-1{grid-template-columns:1fr}}.detail label,.detail .detail__field{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;margin-bottom:.75rem}.detail input,.detail select,.detail textarea{display:block;width:100%;max-width:100%;margin:0;padding:.5rem .75rem;min-height:var(--touch-min, 44px);border:1px solid #d1d5db;border-radius:6px;font:inherit;box-sizing:border-box}.detail textarea{min-height:5rem;resize:vertical}@media (max-width: 479px){.detail input,.detail select,.detail textarea{font-size:16px}.detail__actions{flex-direction:column}.detail__actions button,.detail__actions a{width:100%;text-align:center}}.login__card input{width:100%;min-height:var(--touch-min, 44px);box-sizing:border-box}@media (max-width: 479px){.login__card input{font-size:16px}}.audit__filter select{width:100%}@media (min-width: 480px){.audit__filter select{width:auto;min-width:12rem}}.restaurants__search input{width:100%}@media (min-width: 768px){.restaurants__search input{width:auto}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,sans-serif;background:var(--sn-color-bg, #f4f5f7);color:var(--sn-color-text, #1a1a1a)}a{color:var(--sn-color-primary, #2563eb)}.error{color:#b91c1c}button{cursor:pointer}
