:root{--color-bg:#1a1009;--color-bg-2:#241508;--color-bg-3:#2e1a0a;--color-surface:#3a2010;--color-surface-2:#4a2c14;--color-border:#5a3a1a;--color-primary:#e8721c;--color-primary-dim:#c45e14;--color-primary-glow:#e8721c40;--color-text:#f5e6d0;--color-text-2:#c8a882;--color-text-3:#8a6a4a;--color-text-inv:#1a1009;--color-success:#4caf50;--color-warning:#ffc107;--color-error:#f44336;--color-info:#2196f3;--color-primary-role:#4caf50;--color-secondary-role:#2196f3;--font-family:"Segoe UI", system-ui, -apple-system, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 24px #0009;--shadow-orange:0 4px 16px #e8721c4d;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--bottom-nav-height:64px;--top-bar-height:56px;--max-width:100%;--content-max-width:1200px;--tablet-width:768px;--desktop-width:1024px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;overflow:hidden}#app{height:100dvh;max-width:var(--max-width);flex-direction:column;margin:0 auto;display:flex;position:relative;overflow:hidden}.view-container{width:100%;max-width:var(--content-max-width);flex-direction:column;flex:1;margin:0 auto;display:flex;overflow:hidden}.view-content{padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--space-4));scroll-behavior:smooth;flex:1;overflow:hidden auto}@media (width>=768px){.view-content{padding:var(--space-6);padding-bottom:calc(var(--bottom-nav-height) + var(--space-6))}}.view-content::-webkit-scrollbar{width:4px}.view-content::-webkit-scrollbar-track{background:0 0}.view-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.top-bar{height:var(--top-bar-height);background:var(--color-bg-2);border-bottom:1px solid var(--color-border);padding:0 var(--space-4);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.top-bar__title{font-size:var(--font-size-lg);color:var(--color-text);font-weight:700}.top-bar__actions{gap:var(--space-2);align-items:center;display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:none;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary{background:var(--color-primary);color:var(--color-text-inv);box-shadow:var(--shadow-orange)}.btn--primary:hover:not(:disabled){background:var(--color-primary-dim)}.btn--secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-surface-2)}.btn--ghost{color:var(--color-primary);border:1px solid var(--color-primary);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--color-primary-glow)}.btn--danger{background:var(--color-error);color:#fff}.btn--icon{padding:var(--space-2);border-radius:var(--radius-sm);color:var(--color-text-2);font-size:var(--font-size-lg);background:0 0;min-width:36px;min-height:36px}.btn--icon:hover{background:var(--color-surface);color:var(--color-text)}.btn--full{width:100%}.btn--sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.input-group{gap:var(--space-1);margin-bottom:var(--space-4);flex-direction:column;display:flex}.input-label{font-size:var(--font-size-sm);color:var(--color-text-2);font-weight:500}.input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-family);font-size:var(--font-size-md);padding:var(--space-3) var(--space-4);width:100%;transition:border-color var(--transition-fast);accent-color:var(--color-primary);outline:none}input[type=date]::-webkit-calendar-picker-indicator{background-color:var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;filter:invert();padding:4px}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.input::placeholder{color:var(--color-text-3)}.input--error{border-color:var(--color-error)}.input-error-msg{font-size:var(--font-size-xs);color:var(--color-error)}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238A6A4A' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-8)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3);transition:border-color var(--transition-fast)}.card:hover{border-color:var(--color-primary)}.card--clickable{cursor:pointer}.card--clickable:active{transform:scale(.99)}.section-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border);display:flex}.section-title{font-size:var(--font-size-md);color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;flex:1;font-weight:700}.stats-row{gap:var(--space-3);margin-bottom:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{background:var(--color-bg-3);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);text-align:center}.stat-card__value{font-size:var(--font-size-xl);color:var(--color-primary);font-weight:700}.stat-card__label{font-size:var(--font-size-xs);color:var(--color-text-3);margin-top:var(--space-1)}.fab{bottom:calc(var(--bottom-nav-height) + var(--space-4));right:var(--space-4);border-radius:var(--radius-full);background:var(--color-primary);width:56px;height:56px;color:var(--color-text-inv);cursor:pointer;box-shadow:var(--shadow-orange);transition:all var(--transition-fast);z-index:20;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;font-size:1.5rem;display:flex;position:fixed}.fab:active{transform:scale(.93)}.fab:hover{background:var(--color-primary-dim)}.grid{gap:var(--space-4);grid-template-columns:1fr;display:grid}@media (width>=640px){.grid--cols-2-sm{grid-template-columns:repeat(2,1fr)}}@media (width>=768px){.grid--cols-2-md{grid-template-columns:repeat(2,1fr)}.grid--cols-3-md{grid-template-columns:repeat(3,1fr)}}@media (width>=1024px){.grid--cols-3-lg{grid-template-columns:repeat(3,1fr)}.grid--cols-4-lg{grid-template-columns:repeat(4,1fr)}}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;display:inline-flex}.badge--success{color:var(--color-success);background:#4caf5033}.badge--info{color:var(--color-info);background:#2196f333}.badge--warning{color:var(--color-warning);background:#ffc10733}.badge--error{color:var(--color-error);background:#f4433633}.divider{background:var(--color-border);height:1px;margin:var(--space-4) 0}.empty-state{padding:var(--space-12) var(--space-4);text-align:center;justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.empty-state__icon{opacity:.5;font-size:3rem}.empty-state__title{font-size:var(--font-size-lg);color:var(--color-text-2);font-weight:600}.empty-state__desc{font-size:var(--font-size-sm);color:var(--color-text-3)}.chip{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);background:var(--color-surface-2);color:var(--color-text-2);border:1px solid var(--color-border);align-items:center;font-weight:600;display:inline-flex}.chip--active{background:var(--color-primary-glow);color:var(--color-primary);border-color:var(--color-primary)}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.overlay{z-index:100;animation:fadeIn var(--transition-normal);background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.overlay--center{align-items:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sheet{background:var(--color-bg-2);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--color-border);padding:var(--space-6) var(--space-4) var(--space-8);width:100%;max-width:var(--max-width);max-height:90dvh;animation:slideUp var(--transition-normal);overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet__handle{background:var(--color-border);border-radius:var(--radius-full);width:40px;height:4px;margin:0 auto var(--space-5)}.sheet__title{font-size:var(--font-size-xl);margin-bottom:var(--space-5);color:var(--color-text);font-weight:700}.modal{background:var(--color-bg-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);width:calc(100% - var(--space-8));max-width:400px;animation:scaleIn var(--transition-normal)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal__title{font-size:var(--font-size-xl);margin-bottom:var(--space-4);font-weight:700}.modal__actions{gap:var(--space-3);margin-top:var(--space-5);display:flex}.toast-container{top:var(--space-4);z-index:200;gap:var(--space-2);pointer-events:none;width:calc(100% - var(--space-8));flex-direction:column;max-width:400px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);align-items:center;gap:var(--space-2);box-shadow:var(--shadow-lg);animation:toastIn var(--transition-normal);pointer-events:all;font-weight:500;display:flex}.toast--success{border-left:3px solid var(--color-success)}.toast--error{border-left:3px solid var(--color-error)}.toast--warning{border-left:3px solid var(--color-warning)}.toast--info{border-left:3px solid var(--color-info)}@keyframes toastIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.search-bar{align-items:center;gap:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);margin-bottom:var(--space-4);display:flex}.search-bar__icon{color:var(--color-text-3);font-size:var(--font-size-md)}.search-bar__input{color:var(--color-text);font-family:var(--font-family);font-size:var(--font-size-md);background:0 0;border:none;outline:none;flex:1}.search-bar__input::placeholder{color:var(--color-text-3)}.period-tabs{gap:var(--space-2);margin-bottom:var(--space-4);background:var(--color-bg-3);border-radius:var(--radius-md);padding:var(--space-1);display:flex}.period-tab{padding:var(--space-2);border-radius:var(--radius-sm);color:var(--color-text-3);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1;font-weight:600}.period-tab--active{background:var(--color-primary);color:var(--color-text-inv)}.att-btn{border-radius:var(--radius-sm);width:36px;height:36px;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);border:2px solid #0000;justify-content:center;align-items:center;font-weight:700;display:flex}.att-btn[data-status=A]{color:var(--color-success);background:#4caf5026}.att-btn[data-status=F]{color:var(--color-error);background:#f4433626}.att-btn[data-status=R]{color:var(--color-warning);background:#ffc10726}.att-btn[data-status=L]{color:var(--color-info);background:#2196f326}.att-btn--active[data-status=A]{background:var(--color-success);color:#fff;border-color:var(--color-success)}.att-btn--active[data-status=F]{background:var(--color-error);color:#fff;border-color:var(--color-error)}.att-btn--active[data-status=R]{background:var(--color-warning);color:#1a1009;border-color:var(--color-warning)}.att-btn--active[data-status=L]{background:var(--color-info);color:#fff;border-color:var(--color-info)}.eval-grid{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.eval-grid th{background:var(--color-bg-3);color:var(--color-text-2);padding:var(--space-2) var(--space-3);text-align:left;border-bottom:1px solid var(--color-border);font-weight:600;position:sticky;top:0}.eval-grid td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);color:var(--color-text)}.eval-grid tr:hover td{background:var(--color-surface)}.eval-grid .score-input{background:var(--color-bg-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:60px;color:var(--color-text);font-size:var(--font-size-sm);padding:var(--space-1) var(--space-2);text-align:center}.score--pass{color:var(--color-success);font-weight:700}.score--fail{color:var(--color-error);font-weight:700}.qr-container{align-items:center;gap:var(--space-4);padding:var(--space-6);flex-direction:column;display:flex}.qr-box{border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-orange);background:#fff}.qr-timer{font-size:var(--font-size-lg);color:var(--color-warning);font-weight:700}.lock-screen{height:100dvh;padding:var(--space-8);text-align:center;justify-content:center;align-items:center;gap:var(--space-5);background:var(--color-bg);flex-direction:column;display:flex}.lock-screen__icon{font-size:4rem}.lock-screen__title{font-size:var(--font-size-2xl);font-weight:700}.lock-screen__desc{font-size:var(--font-size-md);color:var(--color-text-2);line-height:1.6}.setup-screen{min-height:100dvh;padding:var(--space-8) var(--space-6);justify-content:center;align-items:center;gap:var(--space-5);flex-direction:column;display:flex}.setup-screen__logo{margin-bottom:var(--space-2);font-size:3rem}.setup-screen__title{font-size:var(--font-size-2xl);color:var(--color-primary);text-align:center;font-weight:700}.setup-screen__subtitle{font-size:var(--font-size-sm);color:var(--color-text-2);text-align:center;margin-bottom:var(--space-4)}.setup-form{gap:var(--space-1);flex-direction:column;width:100%;max-width:400px;display:flex}.setup-form .input-row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.otp-container{gap:var(--space-2);margin:var(--space-4) 0;justify-content:center;display:flex}.otp-input{text-align:center;width:48px;height:56px;font-size:var(--font-size-xl);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition-fast);outline:none;font-weight:700}.otp-input:focus{border-color:var(--color-primary)}.days-selector{gap:var(--space-2);margin-top:var(--space-1);flex-wrap:wrap;display:flex}.day-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);width:40px;height:40px;color:var(--color-text-2);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-weight:600;display:flex}.day-btn:hover{border-color:var(--color-primary)}.day-btn--active{background:var(--color-primary);color:var(--color-text-inv);border-color:var(--color-primary);box-shadow:var(--shadow-orange-sm)}.view-enter{animation:viewEnter var(--transition-normal) ease forwards}.view-exit{animation:viewExit var(--transition-fast) ease forwards}@keyframes viewEnter{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes viewExit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}.pulse{animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.bounce-in{animation:.4s cubic-bezier(.175,.885,.32,1.275) bounceIn}@keyframes bounceIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.shake{animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:radial-gradient(circle,#ffffff26 0%,#0000 70%);position:absolute;inset:0}.ripple:active:after{opacity:1}.skeleton{background:linear-gradient(90deg, var(--color-surface) 25%, var(--color-surface-2) 50%, var(--color-surface) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.sync-spin{animation:1s linear infinite spin;display:inline-block}.dot-indicator{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-indicator--online{background:var(--color-success);animation:2s infinite pulse}.dot-indicator--offline{background:var(--color-error)}.dot-indicator--syncing{background:var(--color-warning);animation:1s infinite pulse}
