@import"https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--brand: #1b4ed8;--brand-600: #1740b8;--brand-700: #122f8a;--brand-soft: #eaf0ff;--brand-soft-2: #d6e1ff;--n-0: #ffffff;--n-50: #f7f7f8;--n-100: #eeeef1;--n-150: #e4e4e9;--n-200: #d8d8de;--n-300: #c2c2cc;--n-400: #9a9aa6;--n-500: #74747e;--n-600: #54545c;--n-700: #3a3a42;--n-800: #1f1f25;--n-900: #0e0e13;--success: #0e8a5b;--success-soft: #e2f4ec;--warning: #b87100;--warning-soft: #fff3db;--danger: #c8243e;--danger-soft: #fae3e7;--info: #2563d9;--info-soft: #e4eeff;--bg: #f3f3f5;--surface: var(--n-0);--surface-sunk: var(--n-100);--fg1: var(--n-900);--fg2: var(--n-700);--fg3: var(--n-500);--fg4: var(--n-400);--border: var(--n-150);--border-strong: var(--n-200);--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-2xl: 28px;--r-full: 999px;--sh-xs: 0 1px 1px rgba(14,14,19,.04);--sh-sm: 0 1px 3px rgba(14,14,19,.06), 0 1px 2px rgba(14,14,19,.04);--sh-md: 0 6px 16px rgba(14,14,19,.08), 0 2px 6px rgba(14,14,19,.05);--sh-lg: 0 16px 40px rgba(14,14,19,.12), 0 6px 14px rgba(14,14,19,.06);--sh-brand: 0 12px 28px rgba(27,78,216,.32), 0 4px 10px rgba(27,78,216,.18);--sh-danger: 0 12px 28px rgba(200,36,62,.32), 0 4px 10px rgba(200,36,62,.18);--font: "Inter Tight", ui-sans-serif, system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--ease: cubic-bezier(.2, .8, .2, 1)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;font-family:var(--font);color:var(--fg1);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,.h1{font-family:var(--font);font-size:24px;line-height:1.2;letter-spacing:-.015em;font-weight:600;color:var(--fg1);margin:0}h2,.h2{font-family:var(--font);font-size:18px;line-height:1.3;letter-spacing:-.01em;font-weight:600;color:var(--fg1);margin:0}h3,.h3{font-size:15px;line-height:1.35;letter-spacing:-.005em;font-weight:600;color:var(--fg1);margin:0}p{font-size:14px;line-height:1.5;color:var(--fg2);margin:0}small,.small{font-size:12.5px;line-height:1.45;color:var(--fg3)}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.label-micro{font-family:var(--font);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.tawa-app{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;flex-direction:column;font-family:var(--font);color:var(--fg1);overflow:hidden}.tawa-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.tawa-content::-webkit-scrollbar{width:0;display:none}.app-header{padding:14px 20px;background:var(--bg);position:sticky;top:0;z-index:5}.app-header .row{display:flex;align-items:center;gap:12px}.app-header .ident{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.app-header .ident h1{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header .ident .sub{font-size:12px;color:var(--fg3);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar{width:38px;height:38px;border-radius:50%;background:var(--n-200);color:var(--fg1);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.app-header .status-dot{width:7px;height:7px;border-radius:50%;background:var(--success)}.app-header .status-dot.off{background:var(--fg4)}.net-chip{margin-left:auto;display:inline-flex;align-items:center;gap:6px;padding:6px 10px 6px 8px;border-radius:var(--r-full);font-size:12px;font-weight:500;background:var(--surface);border:1px solid var(--border);color:var(--fg2);white-space:nowrap}.net-chip .pulse{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 #0e8a5b80;animation:pulse 2s ease-out infinite}.net-chip.off .pulse{background:var(--warning);animation:none}.net-chip .count{background:var(--warning);color:#fff;font-family:var(--mono);font-weight:600;font-size:10px;padding:1px 6px;border-radius:var(--r-full);margin-left:2px}@keyframes pulse{0%{box-shadow:0 0 #0e8a5b80}70%{box-shadow:0 0 0 6px #0e8a5b00}to{box-shadow:0 0 #0e8a5b00}}.badge-stage{padding:0 20px 12px;display:flex;flex-direction:column;align-items:center}.badge-btn{width:100%;height:156px;border:none;border-radius:24px;color:#fff;font-family:var(--font);font-weight:600;font-size:22px;letter-spacing:-.01em;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;position:relative;cursor:pointer;transition:transform .1s var(--ease),box-shadow .1s var(--ease);overflow:hidden}.badge-btn:active{transform:scale(.985)}.badge-btn.in{background:linear-gradient(180deg,#16a06b,#0e8a5b);box-shadow:0 12px 28px #0e8a5b57,0 4px 10px #0e8a5b2e}.badge-btn.out{background:linear-gradient(180deg,#d63450,#b91d36);box-shadow:0 12px 28px #c8243e57,0 4px 10px #c8243e2e}.badge-btn .label{font-size:22px;font-weight:600}.badge-btn .hint{font-size:12.5px;opacity:.85;font-weight:500;letter-spacing:.02em}.badge-btn .icon-wrap{width:52px;height:52px;border-radius:50%;background:#ffffff2e;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #fff3}.badge-btn .ripple{position:absolute;border-radius:50%;background:#ffffff59;transform:translate(-50%,-50%);pointer-events:none;animation:ripple .6s var(--ease) forwards}@keyframes ripple{0%{width:0;height:0;opacity:.55}to{width:480px;height:480px;opacity:0}}.actions-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 20px}.sec-btn{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-lg);padding:14px 12px;display:flex;align-items:center;gap:10px;font-family:var(--font);font-weight:500;font-size:14px;color:var(--fg1);cursor:pointer;transition:background .12s var(--ease),border-color .12s var(--ease);text-align:left}.sec-btn:active{background:var(--n-100)}.sec-btn[disabled]{opacity:.5;pointer-events:none}.sec-btn .ic{width:32px;height:32px;border-radius:var(--r-sm);background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sec-btn.active{border-color:var(--brand);background:var(--brand-soft)}.sec-btn.active .ic{background:var(--brand);color:#fff}.sec-btn.active.warn{border-color:var(--warning);background:var(--warning-soft)}.sec-btn.active.warn .ic{background:var(--warning);color:#fff}.sec-btn .text{display:flex;flex-direction:column;gap:1px;min-width:0}.sec-btn .text .lbl{font-size:14px;font-weight:600;color:var(--fg1)}.sec-btn .text .sub{font-size:11.5px;color:var(--fg3)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin:12px 20px;overflow:hidden}.card-h{padding:14px 16px 8px;display:flex;align-items:center;justify-content:space-between}.card-h .ttl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--fg3)}.card-body{padding:0 16px 16px}.session-card{padding:16px}.session-card .top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4px}.session-card .top .timer{font-family:var(--mono);font-weight:600;font-size:34px;letter-spacing:-.02em;color:var(--fg1)}.session-card .top .label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--brand);display:flex;align-items:center;gap:5px}.session-card .top .label .live-dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:blink 1.2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.35}}.session-card .meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.session-card .meta .item{display:flex;flex-direction:column;gap:2px}.session-card .meta .k{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.session-card .meta .v{font-family:var(--mono);font-size:13px;color:var(--fg1)}.session-card .meta .v.text{font-family:var(--font);font-weight:500}.session-card .activity-line{margin-top:12px;padding:10px 12px;background:var(--brand-soft);border-radius:var(--r-md);font-size:13px;color:var(--brand-700);display:flex;align-items:center;gap:8px}.session-card .activity-line .dot{width:8px;height:8px;border-radius:50%;background:var(--brand)}.session-card .activity-line.break{background:var(--warning-soft);color:#8a5800}.session-card .activity-line.break .dot{background:var(--warning)}.toast{position:fixed;left:16px;right:16px;bottom:100px;padding:12px 14px;background:var(--n-900);color:#fff;border-radius:var(--r-md);font-size:13px;display:flex;align-items:center;gap:10px;box-shadow:var(--sh-lg);z-index:30;animation:toast-in .22s var(--ease)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast .ic{width:22px;height:22px;border-radius:50%;background:var(--warning);display:flex;align-items:center;justify-content:center;flex-shrink:0}.tabbar{position:relative;z-index:10;background:#ffffffeb;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--border);padding:8px 8px 20px;display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.tab{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px 6px;background:none;border:none;cursor:pointer;color:var(--fg3);border-radius:10px;transition:color .12s var(--ease),background .12s var(--ease);font-family:var(--font);text-decoration:none}.tab:active{background:var(--n-100)}.tab .lbl{font-size:10.5px;font-weight:500;letter-spacing:.01em}.tab.active{color:var(--brand)}.tab.active .lbl{font-weight:600}.tab .badge{position:absolute;margin-left:18px;margin-top:-2px;background:var(--warning);color:#fff;font-size:9.5px;font-weight:700;padding:1px 4px;border-radius:var(--r-full);min-width:14px;text-align:center;font-family:var(--mono)}.day-header{padding:14px 20px 6px;display:flex;align-items:baseline;justify-content:space-between}.day-header .date{font-size:22px;font-weight:700;letter-spacing:-.015em}.day-header .meta{font-size:12.5px;color:var(--fg3);font-family:var(--mono)}.active-banner{margin:6px 20px 12px;background:var(--brand);color:#fff;border-radius:var(--r-lg);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-brand)}.active-banner .left{flex:1;min-width:0}.active-banner .lbl{font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.85;margin-bottom:4px}.active-banner .ttl{font-size:15px;font-weight:600}.active-banner .sub{font-size:12px;opacity:.8;margin-top:2px}.active-banner .timer-big{font-family:var(--mono);font-size:22px;font-weight:600;letter-spacing:-.01em}.active-banner .stop{width:38px;height:38px;border-radius:50%;background:#ffffff2e;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.timeline{position:relative;padding:0 20px 110px}.timeline:before{content:"";position:absolute;left:39px;top:12px;bottom:32px;width:1.5px;background:linear-gradient(180deg,var(--border) 0%,var(--border) 80%,transparent 100%)}.tl-row{display:flex;align-items:flex-start;gap:14px;padding:10px 0;position:relative}.tl-row .time{font-family:var(--mono);font-size:12px;color:var(--fg3);width:42px;flex-shrink:0;padding-top:8px;text-align:right}.tl-row .node{width:28px;height:28px;border-radius:50%;background:var(--surface);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;z-index:2;margin-top:4px;flex-shrink:0;color:var(--fg2)}.tl-row.in .node{background:var(--success-soft);border-color:var(--success);color:var(--success)}.tl-row.out .node{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}.tl-row.act .node{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.tl-row.act-end .node{background:var(--brand-soft);border-color:var(--brand);color:var(--brand);opacity:.7}.tl-row.break .node{background:var(--warning-soft);border-color:var(--warning);color:var(--warning)}.tl-row .body{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;cursor:pointer}.tl-row .body .ttl{font-size:14px;font-weight:600;letter-spacing:-.005em}.tl-row .body .ttl .ctx{color:var(--fg3);font-weight:500}.tl-row .body .meta-row{display:flex;align-items:center;gap:8px;margin-top:5px;font-size:11.5px;color:var(--fg3)}.tl-row .body .meta-row .sep{width:3px;height:3px;border-radius:50%;background:var(--n-300)}.confidence{display:inline-flex;align-items:center;gap:4px;padding:2px 7px 2px 5px;border-radius:var(--r-full);font-size:10.5px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.confidence.verified{background:var(--success-soft);color:var(--success)}.confidence.declared{background:var(--n-100);color:var(--fg2)}.confidence.inferred{background:var(--warning-soft);color:var(--warning)}.confidence .dot{width:5px;height:5px;border-radius:50%;background:currentColor}.fab{position:fixed;bottom:102px;right:18px;height:52px;padding:0 18px 0 14px;border-radius:var(--r-full);background:var(--brand);color:#fff;border:none;font-family:var(--font);font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;cursor:pointer;box-shadow:var(--sh-brand);z-index:8;transition:transform .12s var(--ease)}.fab:active{transform:scale(.96)}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e0e136b;z-index:40;animation:fade-in .2s var(--ease)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.sheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-radius:24px 24px 0 0;z-index:41;padding:10px 0 36px;max-height:80%;display:flex;flex-direction:column;box-shadow:0 -16px 40px #0e0e132e;animation:sheet-in .28s var(--ease)}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet .handle{width:36px;height:4.5px;background:var(--n-300);border-radius:var(--r-full);margin:0 auto 8px}.sheet .head{padding:8px 20px 12px;display:flex;align-items:center;justify-content:space-between}.sheet .head h2{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0}.sheet .head .close{width:32px;height:32px;border-radius:50%;background:var(--n-100);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--fg2)}.sheet .body{padding:0 20px;overflow-y:auto}.search-input{width:100%;background:var(--n-100);border:none;border-radius:var(--r-md);padding:12px 14px 12px 40px;font-family:var(--font);font-size:15px;color:var(--fg1);outline:none;position:relative}.search-input::placeholder{color:var(--fg4)}.search-wrap{position:relative}.search-wrap .ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--fg4);pointer-events:none}.opt-list{display:flex;flex-direction:column;gap:2px;margin-top:12px}.opt{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:background .12s var(--ease),border-color .12s var(--ease)}.opt:hover{background:var(--n-50)}.opt.selected{border-color:var(--brand);background:var(--brand-soft)}.opt .code{font-family:var(--mono);font-size:11px;background:var(--n-100);color:var(--fg2);padding:3px 7px;border-radius:var(--r-xs);font-weight:600}.opt.selected .code{background:var(--brand);color:#fff}.opt .text{flex:1;min-width:0}.opt .text .lbl{font-size:14px;font-weight:500}.opt .text .sub{font-size:12px;color:var(--fg3);margin-top:1px}.context-fields{display:flex;flex-direction:column;gap:10px;margin-top:16px}.ctx-field{display:flex;flex-direction:column;gap:5px}.ctx-field label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.ctx-field .picker{background:var(--n-100);border:none;border-radius:var(--r-md);padding:12px 14px;font-size:14px;color:var(--fg1);display:flex;align-items:center;justify-content:space-between;cursor:pointer}.ctx-field .picker .val{color:var(--fg1);font-weight:500}.ctx-field .picker .val.placeholder{color:var(--fg4);font-weight:400}.sheet-cta{margin:16px 20px 0;display:flex;gap:8px}.sheet-cta .primary{flex:1;background:var(--brand);color:#fff;border:none;border-radius:var(--r-md);padding:14px;font-family:var(--font);font-weight:600;font-size:15px;cursor:pointer;box-shadow:var(--sh-brand)}.sheet-cta .primary:active{background:var(--brand-600)}.sheet-cta .primary[disabled]{background:var(--n-300);box-shadow:none;pointer-events:none}.period-nav{margin:14px 20px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 12px;display:flex;align-items:center;justify-content:space-between}.period-nav .arrow{width:32px;height:32px;border-radius:var(--r-sm);background:var(--n-100);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--fg2)}.period-nav .arrow:active{background:var(--n-150)}.period-nav .label{text-align:center}.period-nav .label .wk{font-size:13px;font-weight:600}.period-nav .label .rng{font-family:var(--mono);font-size:11px;color:var(--fg3);margin-top:1px}.summary{margin:12px 20px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.summary .item{display:flex;flex-direction:column;gap:3px}.summary .k{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.summary .v{font-family:var(--mono);font-size:22px;font-weight:600;letter-spacing:-.01em}.summary .item+.item{border-left:1px solid var(--border);padding-left:12px}.anom-banner{margin:12px 20px 0;background:linear-gradient(180deg,#fff3db,#ffe6b8);border:1px solid #f3c869;border-radius:var(--r-lg);padding:14px;display:flex;gap:12px;align-items:flex-start}.anom-banner .ic{width:32px;height:32px;border-radius:8px;background:var(--warning);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.anom-banner .text{flex:1;min-width:0}.anom-banner .ttl{font-size:13.5px;font-weight:600;color:#6b3f00}.anom-banner .sub{font-size:12.5px;color:#8a5800;margin-top:2px}.anom-banner .cta{margin-top:8px;background:#6b3f00;color:#fff;border:none;border-radius:var(--r-sm);padding:8px 12px;font-family:var(--font);font-weight:600;font-size:12.5px;cursor:pointer}.day-list{margin:14px 20px 110px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.day-row{display:flex;align-items:center;gap:12px;padding:14px 16px;position:relative}.day-row+.day-row{border-top:1px solid var(--border)}.day-row .date-block{width:38px;text-align:center;display:flex;flex-direction:column;gap:1px}.day-row .date-block .day-num{font-size:18px;font-weight:600;font-family:var(--mono);letter-spacing:-.02em}.day-row .date-block .day-name{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.day-row.today .date-block .day-num{color:var(--brand)}.day-row .info{flex:1;min-width:0}.day-row .info .ttl{font-family:var(--mono);font-size:14px;font-weight:600}.day-row .info .sub{font-size:11.5px;color:var(--fg3);margin-top:1px;display:flex;align-items:center;gap:6px}.day-row .status{font-size:11px;font-weight:600;padding:3px 8px;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em}.day-row .status.ok{background:var(--success-soft);color:var(--success)}.day-row .status.warn{background:var(--warning-soft);color:var(--warning)}.day-row .status.off{background:var(--n-100);color:var(--fg3)}.day-row .status.now{background:var(--brand-soft);color:var(--brand)}.submit-bar{margin:0 20px 110px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;display:flex;align-items:center;gap:12px}.submit-bar .text{flex:1;min-width:0}.submit-bar .text .ttl{font-size:13.5px;font-weight:600}.submit-bar .text .sub{font-size:12px;color:var(--fg3);margin-top:2px}.submit-bar .submit-btn{background:var(--brand);color:#fff;border:none;border-radius:var(--r-md);padding:10px 14px;font-family:var(--font);font-weight:600;font-size:13px;cursor:pointer}.submit-bar .submit-btn[disabled]{background:var(--n-300);pointer-events:none}.submit-bar .status-tag{background:var(--info-soft);color:var(--info);font-size:11px;font-weight:600;padding:3px 8px;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em}.profile-head{padding:14px 20px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.profile-head .big-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-700) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:26px;letter-spacing:-.02em}.profile-head .name{font-size:18px;font-weight:600;letter-spacing:-.01em}.profile-head .role{font-size:13px;color:var(--fg3);margin-top:-8px}.settings-list{margin:8px 20px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.set-row{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer}.set-row+.set-row{border-top:1px solid var(--border)}.set-row:active{background:var(--n-50)}.set-row .ic{width:32px;height:32px;border-radius:8px;background:var(--n-100);display:flex;align-items:center;justify-content:center;color:var(--fg2);flex-shrink:0}.set-row .ic.brand{background:var(--brand-soft);color:var(--brand)}.set-row .ic.warn{background:var(--warning-soft);color:var(--warning)}.set-row .ic.danger{background:var(--danger-soft);color:var(--danger)}.set-row .text{flex:1;min-width:0}.set-row .text .lbl{font-size:14.5px;font-weight:500}.set-row .text .sub{font-size:12px;color:var(--fg3);margin-top:1px}.set-row .val{font-size:13px;color:var(--fg3);font-family:var(--mono)}.set-row .chev{color:var(--n-300)}.sync-card{margin:8px 20px 0;border:1px solid var(--brand-soft-2);border-radius:var(--r-lg);background:linear-gradient(180deg,var(--brand-soft) 0%,#f4f7ff 100%);padding:14px 16px}.sync-card .top{display:flex;align-items:baseline;justify-content:space-between}.sync-card .lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-700)}.sync-card .num{font-family:var(--mono);font-size:28px;font-weight:600;color:var(--brand-700);letter-spacing:-.02em}.sync-card .sub{font-size:12.5px;color:var(--brand-700);opacity:.75;margin-top:4px}.sync-card .btn{margin-top:10px;width:100%;background:var(--brand);color:#fff;border:none;border-radius:var(--r-md);padding:11px;font-family:var(--font);font-weight:600;font-size:13.5px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.sync-card .btn[disabled]{background:var(--n-300);pointer-events:none;opacity:.7}.sync-card .btn .spin{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.switch{width:50px;height:30px;border-radius:var(--r-full);background:var(--n-200);position:relative;transition:background .2s var(--ease);flex-shrink:0;cursor:pointer;border:none;padding:0}.switch.on{background:var(--brand)}.switch:after{content:"";position:absolute;top:2px;left:2px;width:26px;height:26px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #0000002e;transition:transform .2s var(--ease)}.switch.on:after{transform:translate(20px)}.section-label{padding:18px 20px 6px;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.act-ic{width:30px;height:30px;border-radius:8px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}.spacer{height:100px}.spacer-sm{height:8px}.desk-app{width:100%;height:100vh;height:100dvh;display:grid;grid-template-columns:260px 1fr;grid-template-rows:100%;background:var(--bg);font-family:var(--font);color:var(--fg1);overflow:hidden;position:relative}.sidebar{background:linear-gradient(180deg,#fff,#fbfbfd);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 12px;overflow-y:auto;overflow-x:hidden;min-height:0}.sidebar::-webkit-scrollbar{width:0;display:none}.brand-mark{display:flex;align-items:center;gap:10px;padding:6px 10px 18px;border-bottom:1px solid var(--border);margin-bottom:12px}.brand-mark .logo{width:30px;height:30px;border-radius:8px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;letter-spacing:.02em}.brand-mark .name{font-size:15px;font-weight:600;letter-spacing:-.005em}.brand-mark .sub{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--fg3);margin-top:1px;font-weight:500}.nav-list{display:flex;flex-direction:column;gap:2px}.nav-section{padding:16px 14px 6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg4)}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--r-md);cursor:pointer;color:var(--fg2);font-size:13.5px;font-weight:500;border:none;background:transparent;text-align:left;width:100%;position:relative;transition:background .1s var(--ease),color .1s var(--ease);text-decoration:none;font-family:var(--font)}.nav-item:hover{background:var(--n-100);color:var(--fg1)}.nav-item.active{background:var(--brand-soft);color:var(--brand);font-weight:600}.nav-item .badge{margin-left:auto;background:var(--warning);color:#fff;font-family:var(--mono);font-weight:600;font-size:10px;padding:1px 6px;border-radius:var(--r-full);min-width:16px;text-align:center}.nav-item.active .ic-wrap{color:var(--brand)}.sidebar-spacer{flex:1}.user-card{border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;display:flex;align-items:center;gap:10px;background:var(--surface)}.user-card .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-700) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}.user-card .info{flex:1;min-width:0}.user-card .nm{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card .rl{font-size:11px;color:var(--fg3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card .menu{width:24px;height:24px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--fg3);cursor:pointer;display:flex;align-items:center;justify-content:center}.user-card .menu:hover{background:var(--n-100);color:var(--fg1)}.main{display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:56px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.topbar .crumb{font-size:13px;color:var(--fg3);display:flex;align-items:center;gap:6px}.topbar .crumb .cur{color:var(--fg1);font-weight:600}.topbar .spacer-flex{flex:1}.topbar .now-time{font-family:var(--mono);font-size:13.5px;color:var(--fg2)}.topbar .net-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px 5px 8px;border-radius:var(--r-full);font-size:12px;font-weight:500;background:var(--n-100);color:var(--fg2);border:none}.topbar .net-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--success)}.topbar .net-chip.off .dot{background:var(--warning)}.topbar .net-chip.off{background:var(--warning-soft);color:#8a5800}.topbar .quick-badge{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 14px 0 12px;border:none;border-radius:var(--r-md);color:#fff;font-weight:600;font-size:13px;cursor:pointer;font-family:var(--font)}.topbar .quick-badge.in{background:var(--success)}.topbar .quick-badge.out{background:var(--danger)}.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px 28px 80px;min-width:0}.page-h{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px}.page-h .t{font-size:26px;font-weight:700;letter-spacing:-.015em;line-height:1.1;margin:0}.page-h .meta{font-size:13px;color:var(--fg3);margin-top:4px}.page-h .actions{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--fg1);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:background .1s var(--ease),border-color .1s var(--ease)}.btn:hover{background:var(--n-50)}.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:600}.btn.primary:hover{background:var(--brand-600)}.btn.success{background:var(--success);color:#fff;border-color:var(--success);font-weight:600}.btn.danger{background:var(--danger);color:#fff;border-color:var(--danger);font-weight:600}.btn[disabled]{opacity:.5;pointer-events:none}.cols-2{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:flex-start}.cols-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.dcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.dcard-h{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.dcard-h .ttl{font-size:14px;font-weight:600;letter-spacing:-.005em}.dcard-h .meta{font-size:12px;color:var(--fg3);font-family:var(--mono)}.dcard-body{padding:20px}.session-d{padding:28px}.session-d .row{display:flex;align-items:center;gap:24px}.session-d .clock{font-family:var(--mono);font-weight:600;font-size:56px;letter-spacing:-.025em;color:var(--fg1);line-height:1}.session-d .clock .seconds{color:var(--fg3)}.session-d .col-right{flex:1;display:flex;flex-direction:column;gap:4px}.session-d .status-lbl{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--brand);display:flex;align-items:center;gap:5px}.session-d .status-lbl .dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:blink 1.2s ease-in-out infinite}.session-d .range{font-family:var(--mono);font-size:13.5px;color:var(--fg2)}.session-d .meta-grid{margin-top:20px;padding-top:20px;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:20px}.session-d .meta-grid .k{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3);margin-bottom:4px}.session-d .meta-grid .v{font-size:13.5px;font-weight:500;color:var(--fg1);display:flex;align-items:center;gap:5px}.session-d .meta-grid .v.mono{font-family:var(--mono);font-weight:600}.session-d .actions-row-d{display:flex;gap:10px;margin-top:20px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}.stat .k{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.stat .v{font-family:var(--mono);font-size:28px;font-weight:600;letter-spacing:-.015em;margin-top:4px}.stat .delta{font-size:12px;color:var(--fg3);margin-top:2px}.stat .delta.up{color:var(--success)}.stat .delta.down{color:var(--danger)}.tl-d{position:relative;padding:16px 24px 20px}.tl-d:before{content:"";position:absolute;left:79px;top:28px;bottom:28px;width:1.5px;background:var(--border)}.tl-d .row{display:flex;align-items:flex-start;gap:16px;padding:8px 0}.tl-d .row .t{font-family:var(--mono);font-size:12px;color:var(--fg3);width:48px;flex-shrink:0;padding-top:8px;text-align:right}.tl-d .row .nd{width:28px;height:28px;border-radius:50%;background:var(--surface);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;z-index:2;margin-top:4px;flex-shrink:0}.tl-d .row.in .nd{background:var(--success-soft);border-color:var(--success);color:var(--success)}.tl-d .row.out .nd{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}.tl-d .row.act .nd{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.tl-d .row.act-end .nd{background:var(--brand-soft);border-color:var(--brand);color:var(--brand);opacity:.7}.tl-d .row.break .nd{background:var(--warning-soft);border-color:var(--warning);color:var(--warning)}.tl-d .row .b{flex:1;display:flex;align-items:center;padding:8px 12px;border-radius:var(--r-md);gap:12px;border:1px solid transparent;min-height:36px;cursor:pointer}.tl-d .row:hover .b{background:var(--n-50)}.tl-d .row .ttl{font-size:13.5px;font-weight:600;flex:1}.tl-d .row .ttl .ctx{color:var(--fg3);font-weight:500}.tl-d .row .meta{display:flex;gap:10px;font-size:11.5px;color:var(--fg3);align-items:center}.tl-d .row .meta .sep{width:3px;height:3px;border-radius:50%;background:var(--n-300)}.week-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:20px}.day-cell{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px;cursor:pointer;transition:border-color .1s var(--ease)}.day-cell:hover{border-color:var(--n-300)}.day-cell.today{border-color:var(--brand);background:linear-gradient(180deg,var(--brand-soft) 0%,var(--surface) 60%)}.day-cell .dn{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3)}.day-cell .dnum{font-family:var(--mono);font-weight:600;font-size:22px;letter-spacing:-.02em;margin-top:2px}.day-cell.today .dnum{color:var(--brand)}.day-cell .hrs{font-family:var(--mono);font-size:13px;margin-top:10px;font-weight:600}.day-cell .hrs.muted{color:var(--fg4);font-weight:400}.day-cell .status{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 7px;border-radius:var(--r-full);display:inline-block;margin-top:8px}.day-cell .status.ok{background:var(--success-soft);color:var(--success)}.day-cell .status.warn{background:var(--warning-soft);color:var(--warning)}.day-cell .status.now{background:var(--brand-soft);color:var(--brand)}.day-cell .status.off{background:var(--n-100);color:var(--fg3)}.anom-d{background:linear-gradient(90deg,#fff3db,#ffe6b8);border:1px solid #f3c869;border-radius:var(--r-lg);padding:14px 18px;display:flex;gap:14px;align-items:center;margin-bottom:20px}.anom-d .ic{width:36px;height:36px;border-radius:8px;background:var(--warning);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.anom-d .text{flex:1}.anom-d .ttl{font-size:14px;font-weight:600;color:#6b3f00}.anom-d .sub{font-size:12.5px;color:#8a5800;margin-top:2px}.day-table{width:100%;border-collapse:collapse}.day-table th{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3);text-align:left;padding:12px 18px;border-bottom:1px solid var(--border);background:var(--n-50)}.day-table td{padding:12px 18px;border-bottom:1px solid var(--border);font-size:13px}.day-table td.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.day-table tr:last-child td{border-bottom:none}.day-table tr.today td{background:var(--brand-soft)}.day-table tr:hover td{background:var(--n-50);cursor:pointer}.day-table tr.today:hover td{background:var(--brand-soft)}.act-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.act-card{border:1px solid var(--border);border-radius:var(--r-md);padding:12px;background:var(--surface);cursor:pointer;display:flex;align-items:center;gap:12px;transition:border-color .12s var(--ease),background .12s var(--ease);text-align:left;font-family:var(--font)}.act-card:hover{border-color:var(--brand);background:var(--brand-soft)}.act-card .ic{width:36px;height:36px;border-radius:8px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}.act-card .text{flex:1;min-width:0}.act-card .code{font-family:var(--mono);font-size:10.5px;font-weight:600;color:var(--fg3);letter-spacing:.02em}.act-card .lbl{font-size:13px;font-weight:600;letter-spacing:-.005em;margin-top:1px}.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.set-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.set-block .head{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3);margin-bottom:14px}.set-list{display:flex;flex-direction:column;gap:14px}.set-line{display:flex;align-items:center;gap:12px}.set-line .ic{width:32px;height:32px;border-radius:8px;background:var(--n-100);color:var(--fg2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.set-line .text{flex:1;min-width:0}.set-line .text .lbl{font-size:13.5px;font-weight:500}.set-line .text .sub{font-size:11.5px;color:var(--fg3);margin-top:1px}.set-line .switch{width:42px;height:24px;border-radius:var(--r-full);background:var(--n-200);position:relative;cursor:pointer;transition:background .2s var(--ease);flex-shrink:0;border:none;padding:0}.set-line .switch.on{background:var(--brand)}.set-line .switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #0000002e;transition:transform .2s var(--ease)}.set-line .switch.on:after{transform:translate(18px)}.quick-banner{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 22px;display:flex;align-items:center;gap:18px;margin-bottom:20px}.quick-banner.in{background:linear-gradient(90deg,var(--success-soft) 0%,#f0fbf6 100%);border-color:var(--success)}.quick-banner.out{background:linear-gradient(90deg,var(--danger-soft) 0%,#fcf2f4 100%);border-color:var(--danger)}.quick-banner .clock{font-family:var(--mono);font-weight:600;font-size:36px;letter-spacing:-.02em;line-height:1}.quick-banner .info{flex:1}.quick-banner .info .lbl{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--fg3)}.quick-banner .info .ttl{font-size:16px;font-weight:600;letter-spacing:-.01em;margin-top:2px}.sec-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--fg3);margin:0 0 10px}.toast-d{position:fixed;top:88px;right:32px;background:var(--n-900);color:#fff;border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-lg);z-index:100;animation:toast-in .22s var(--ease);font-size:13px;max-width:360px}.toast-d .ic{width:26px;height:26px;border-radius:50%;background:var(--success);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-d .ttl{font-weight:600}.toast-d .sub{font-size:11.5px;opacity:.75;margin-top:1px}.sync-side{margin:12px 0;padding:12px;border:1px solid var(--border);border-radius:var(--r-md);background:linear-gradient(180deg,var(--brand-soft) 0%,#f4f7ff 100%)}.sync-side .num{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--brand-700);letter-spacing:-.01em}.sync-side .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-700);font-weight:600}.sync-side .sub{font-size:11px;color:var(--brand-700);opacity:.75;margin-top:4px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-scroll .day-table{min-width:680px}.menu-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--fg2);cursor:pointer;flex-shrink:0;padding:0}.menu-toggle:hover{background:var(--n-50);color:var(--fg1)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e0e136b;z-index:55;animation:fade-in .2s var(--ease)}.topbar .crumb,.topbar .now-time{min-width:0}@media (max-width: 1180px){.content{padding:20px 22px 60px}.cols-2{grid-template-columns:1.3fr 1fr;gap:16px}.session-d .meta-grid{grid-template-columns:1fr 1fr;gap:14px}}@media (max-width: 1080px){.desk-app{grid-template-columns:64px 1fr}.sidebar{padding:12px 6px}.brand-mark>div:not(.logo){display:none}.brand-mark{justify-content:center;gap:0;padding:6px 0 14px}.nav-item{justify-content:center;padding:10px;gap:0;position:relative}.nav-item>span:not(.ic-wrap):not(.badge){display:none}.nav-item .badge{position:absolute;top:2px;right:2px;margin:0;font-size:9px;padding:0 4px;min-width:14px;line-height:14px}.nav-section{display:none}.sync-side{padding:8px 4px;text-align:center}.sync-side .lbl,.sync-side .sub{display:none}.sync-side .num{font-size:16px}.user-card .info,.user-card .menu{display:none}.user-card{justify-content:center;padding:8px}}@media (max-width: 940px){.cols-2,.set-grid{grid-template-columns:1fr}.page-h{flex-direction:column;align-items:flex-start;gap:12px}.page-h .actions{flex-wrap:wrap}.topbar .crumb{display:none}.week-strip{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.week-strip .day-cell{min-width:110px;flex-shrink:0}.anom-d{flex-wrap:wrap}}@media (max-width: 760px){.cols-3,.act-grid{grid-template-columns:1fr 1fr}.content{padding:18px 16px 60px}.topbar{padding:0 14px;gap:10px}.topbar .now-time{display:none}.quick-banner{flex-wrap:wrap;gap:12px}.quick-banner .clock{font-size:28px}.stat .v,.page-h .t{font-size:22px}}
