:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-input: #0f172a;--text-primary: #f1f5f9;--text-secondary:#94a3b8;--text-muted: #64748b;--text-inverse: #0f172a;--brand-red: #ef4444;--brand-red-hover:#dc2626;--brand-red-glow: rgba(239, 68, 68, .15);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .12);--color-warning: #eab308;--color-warning-bg: rgba(234, 179, 8, .12);--color-danger: #ef4444;--color-danger-bg: rgba(239, 68, 68, .12);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .12);--border-color: #334155;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--shadow-glow: 0 0 20px rgba(239, 68, 68, .2);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--touch-min: 48px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}#app{min-height:100vh;display:flex;flex-direction:column}.top-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.top-nav__brand{display:flex;align-items:center;gap:var(--space-sm)}.top-nav__logo{font-size:var(--font-size-xl);font-weight:800;color:var(--brand-red);letter-spacing:-.5px}.top-nav__subtitle{font-size:var(--font-size-sm);color:var(--text-muted);display:none}@media(min-width:768px){.top-nav__subtitle{display:inline}}.top-nav__actions{display:flex;align-items:center;gap:var(--space-md)}.top-nav__user{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:var(--font-size-sm)}.top-nav__avatar{width:36px;height:36px;border-radius:50%;background:var(--brand-red);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm)}.alert-bell{position:relative;background:none;border:none;color:var(--text-secondary);font-size:1.4rem;cursor:pointer;padding:var(--space-sm);min-width:var(--touch-min);min-height:var(--touch-min);display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:all .2s}.alert-bell:hover{color:var(--text-primary);background:var(--bg-tertiary)}.alert-bell__badge{position:absolute;top:4px;right:4px;background:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.main-content{flex:1;padding:var(--space-lg);max-width:1400px;margin:0 auto;width:100%}.page-header{margin-bottom:var(--space-lg)}.page-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.page-header p{color:var(--text-secondary);font-size:var(--font-size-sm)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--space-lg);transition:all .2s ease}.card:hover{border-color:var(--text-muted)}.card--clickable{cursor:pointer}.card--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.card__title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.card__value{font-size:var(--font-size-3xl);font-weight:800;line-height:1.1}.card__subtitle{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:var(--space-xs)}.card--success{border-left:4px solid var(--color-success)}.card--warning{border-left:4px solid var(--color-warning)}.card--danger{border-left:4px solid var(--color-danger)}.card--info{border-left:4px solid var(--color-info)}.card--success .card__value{color:var(--color-success)}.card--warning .card__value{color:var(--color-warning)}.card--danger .card__value{color:var(--color-danger)}.card--info .card__value{color:var(--color-info)}.grid-2,.grid-3{display:grid;grid-template-columns:1fr;gap:var(--space-md)}.grid-4{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}@media(min-width:1200px){.grid-3{grid-template-columns:repeat(3,1fr)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:14px 24px;font-family:var(--font-family);font-size:var(--font-size-base);font-weight:600;border:none;border-radius:var(--border-radius-sm);cursor:pointer;transition:all .2s ease;min-height:var(--touch-min);text-decoration:none;white-space:nowrap}.btn--primary{background:var(--brand-red);color:#fff}.btn--primary:hover{background:var(--brand-red-hover);box-shadow:var(--shadow-glow)}.btn--secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn--secondary:hover{background:#475569}.btn--success{background:var(--color-success);color:var(--text-inverse)}.btn--success:hover{background:#16a34a}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.btn--ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn--large{padding:18px 32px;font-size:var(--font-size-lg);min-height:56px;border-radius:var(--border-radius)}.btn--block{width:100%}.btn--icon{width:var(--touch-min);height:var(--touch-min);padding:0;border-radius:var(--border-radius-sm)}.btn:disabled{opacity:.5;cursor:not-allowed}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(min-width:768px){.quick-actions{grid-template-columns:repeat(3,1fr)}}@media(min-width:1200px){.quick-actions{grid-template-columns:repeat(4,1fr)}}.quick-action{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--space-lg);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);cursor:pointer;transition:all .2s ease;text-align:center;min-height:120px;justify-content:center}.quick-action:hover{border-color:var(--brand-red);transform:translateY(-2px);box-shadow:var(--shadow-md)}.quick-action__icon{font-size:2rem;line-height:1}.quick-action__label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.quick-action__sub{font-size:var(--font-size-xs);color:var(--text-muted)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input{width:100%;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);min-height:var(--touch-min);transition:border-color .2s}.form-input:focus{outline:none;border-color:var(--brand-red);box-shadow:0 0 0 3px var(--brand-red-glow)}.form-input--error{border-color:var(--color-danger)}select.form-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}textarea.form-input{min-height:100px;resize:vertical}.pass-fail-group{display:flex;gap:var(--space-sm)}.pass-fail-btn{flex:1;min-height:var(--touch-min);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-input);color:var(--text-secondary);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all .2s}.pass-fail-btn:hover{border-color:var(--text-muted)}.pass-fail-btn--pass.active{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.pass-fail-btn--fail.active{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.pass-fail-btn--na.active{background:#64748b1f;border-color:var(--text-muted);color:var(--text-muted)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.3px}.badge--success{background:var(--color-success-bg);color:var(--color-success)}.badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge--info{background:var(--color-info-bg);color:var(--color-info)}.badge--muted{background:#64748b1f;color:var(--text-muted)}.task-list{display:flex;flex-direction:column;gap:var(--space-sm)}.task-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--space-md) var(--space-lg);display:flex;align-items:center;gap:var(--space-md);cursor:pointer;transition:all .15s ease}.task-card:hover{border-color:var(--text-muted);background:var(--bg-tertiary)}.task-card--overdue{border-left:4px solid var(--color-danger)}.task-card--due{border-left:4px solid var(--color-warning)}.task-card--done{border-left:4px solid var(--color-success);opacity:.7}.task-card__info{flex:1}.task-card__name{font-weight:600;font-size:var(--font-size-base)}.task-card__meta{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.task-card__action{min-width:var(--touch-min);text-align:right}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);margin-top:var(--space-xl)}.section-header:first-child{margin-top:0}.section-header h2{font-size:var(--font-size-lg);font-weight:700}.activity-feed{display:flex;flex-direction:column;gap:1px}.activity-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--border-radius-sm);transition:background .15s}.activity-item:hover{background:var(--bg-tertiary)}.activity-item__icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.activity-item__text{flex:1}.activity-item__title{font-size:var(--font-size-sm);font-weight:500}.activity-item__time{font-size:var(--font-size-xs);color:var(--text-muted)}.form-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);margin-bottom:var(--space-md);overflow:hidden}.form-section__header{padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:var(--bg-tertiary);transition:background .15s}.form-section__header:hover{background:#3b4a60}.form-section__title{font-weight:600;font-size:var(--font-size-base)}.form-section__body{padding:var(--space-lg)}.form-section__instructions{font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--space-md);font-style:italic}.bottom-bar{position:sticky;bottom:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--space-md) var(--space-lg);display:flex;gap:var(--space-md);justify-content:flex-end;z-index:50}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:1rem}.login-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:2rem;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:1.5rem}.login-logo{width:100px;height:100px;object-fit:contain;margin-bottom:.75rem}.login-header h1{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0}.login-subtitle{font-size:.82rem;color:var(--text-muted);margin-top:.25rem}.login-error{background:#dc262626;border:1px solid rgba(220,38,38,.3);border-radius:var(--border-radius-sm);color:var(--color-danger);padding:.6rem .8rem;margin-bottom:1rem;font-size:.82rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.login-input{width:100%;padding:.7rem .9rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:1.1rem;font-family:var(--font-family);transition:border-color .2s;box-sizing:border-box}.login-input:focus{outline:none;border-color:var(--brand-red);box-shadow:0 0 0 3px var(--brand-red-glow)}.login-input-code{text-align:center;letter-spacing:.5em;font-size:1.5rem;font-weight:700}.login-btn{width:100%;padding:.75rem;background:var(--brand-red);color:#fff;border:none;border-radius:var(--border-radius-sm);font-size:.9rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:opacity .2s;margin-top:.25rem}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-sent-msg{text-align:center;font-size:.82rem;color:var(--text-secondary);margin-bottom:.25rem}.login-back-btn{background:none;border:none;color:var(--text-muted);font-size:.82rem;font-family:var(--font-family);cursor:pointer;text-align:center;padding:.25rem 0;margin-top:.25rem;width:100%}.login-back-btn:hover{color:var(--text-primary)}.login-numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1.25rem}.numpad-key{padding:.7rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:1.2rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:background .15s}.numpad-key:hover{background:var(--bg-tertiary)}.numpad-key.action{font-size:.9rem;color:var(--text-muted)}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:1000;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--space-md) var(--space-lg);min-width:300px;max-width:450px;box-shadow:var(--shadow-lg);animation:slide-in .3s ease;display:flex;align-items:center;gap:var(--space-md)}.toast--success{border-left:4px solid var(--color-success)}.toast--warning{border-left:4px solid var(--color-warning)}.toast--error{border-left:4px solid var(--color-danger)}@keyframes slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--brand-red);border-radius:50%;animation:spin .8s linear infinite;margin:var(--space-2xl) auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-muted)}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.empty-state__icon{font-size:3rem;margin-bottom:var(--space-md)}.empty-state__text{font-size:var(--font-size-base)}.area-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--space-md);display:flex;align-items:center;gap:var(--space-md)}.area-card__status{width:12px;height:12px;border-radius:50%;flex-shrink:0}.area-card__status--good{background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.area-card__status--partial{background:var(--color-warning);box-shadow:0 0 8px var(--color-warning)}.area-card__status--bad{background:var(--color-danger);box-shadow:0 0 8px var(--color-danger)}.area-card__status--none{background:var(--text-muted)}.area-card__info{flex:1}.area-card__name{font-weight:600;font-size:var(--font-size-sm)}.area-card__detail{font-size:var(--font-size-xs);color:var(--text-muted)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.text-sm{font-size:var(--font-size-sm)}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.hidden{display:none!important}@media(max-width:767px){.main-content{padding:var(--space-md)}.top-nav{padding:var(--space-sm) var(--space-md)}.page-header h1{font-size:var(--font-size-xl)}.card{padding:var(--space-md)}.bottom-bar{flex-wrap:wrap}.bottom-bar .btn{flex:1}}.sig-pad{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm);background:var(--bg-primary);transition:border-color .2s}.sig-pad:hover,.sig-pad:focus-within{border-color:var(--color-primary)}.sig-pad__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.sig-pad__label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.sig-pad__canvas-wrap{position:relative;display:flex;justify-content:center;background:#0f172a80;border-radius:var(--radius-sm);overflow:hidden}.sig-pad__canvas{cursor:crosshair;touch-action:none;display:block}.sig-pad__placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-muted);font-size:var(--font-size-sm);pointer-events:none;white-space:nowrap}.sig-pad__footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-xs);padding-top:var(--space-xs);border-top:1px solid var(--border-color)}.sig-pad__name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.sig-pad__timestamp{font-size:.7rem;color:var(--text-muted)}.sig-pad[data-mode=initials]{max-width:240px}.sig-pad[data-mode=initials] .sig-pad__canvas{max-width:200px}.sig-pad--signed{border-color:var(--color-success);border-style:solid}.sig-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sig-modal__content{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-xl);width:90%;max-width:480px;box-shadow:0 20px 60px #00000080}.sig-modal__content h2{margin-bottom:var(--space-md)}.sig-modal__actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.sig-modal__actions .btn{flex:1}.temp-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}@media(min-width:600px){.temp-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.temp-grid{grid-template-columns:repeat(3,1fr)}}.temp-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--space-lg);transition:all .2s ease;position:relative;overflow:hidden}.temp-card--ok{border-left:4px solid var(--color-success)}.temp-card--warning{border-left:4px solid var(--color-warning);background:#eab3080a}.temp-card--critical{border-left:4px solid var(--color-danger);background:#ef44440f;animation:temp-pulse 2s infinite}.temp-card--no-data{border-left:4px solid var(--text-muted);opacity:.7}@keyframes temp-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 16px 4px #ef444433}}.temp-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.temp-card__name{font-weight:700;font-size:var(--font-size-base);color:var(--text-primary)}.temp-card__status{font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary)}.temp-card--critical .temp-card__status{color:var(--color-danger)}.temp-card--warning .temp-card__status{color:var(--color-warning)}.temp-card--ok .temp-card__status{color:var(--color-success)}.temp-card__area{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--space-md)}.temp-card__reading{display:flex;align-items:baseline;gap:var(--space-md);margin-bottom:var(--space-sm)}.temp-card__value{font-size:2.4rem;font-weight:800;line-height:1;color:var(--text-primary)}.temp-card--critical .temp-card__value{color:var(--color-danger)}.temp-card--warning .temp-card__value{color:var(--color-warning)}.temp-card--ok .temp-card__value{color:var(--color-success)}.temp-card__humidity{font-size:var(--font-size-sm);color:var(--color-info);font-weight:500}.temp-card__limits{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--space-xs)}.temp-card__time{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--space-sm)}.temp-card__chart{height:60px;margin:var(--space-sm) 0}.data-table{width:100%;border-collapse:collapse;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.data-table th{background:var(--bg-tertiary);text-align:left;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.data-table td{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);font-size:var(--font-size-sm);color:var(--text-primary)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#ffffff05}@media(max-width:767px){.data-table{font-size:var(--font-size-xs)}.data-table th,.data-table td{padding:var(--space-sm) var(--space-md)}}
