:root{--bg:#f4f5f7;--panel:#ffffff;--panel-soft:#f8f9fb;--line:#e3e6eb;--line-strong:#d3d7de;--fg:#18202b;--muted:#667085;--faint:#98a2b3;--primary:#263b57;--primary-hover:#1c2d44;--primary-soft:#edf1f5;--green:#177a55;--green-soft:#eaf6f0;--red:#c33f46;--red-soft:#fff0f0;--ui:var(--font-ui),-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",sans-serif;--shadow:0 1px 2px rgba(16,24,40,.04),0 8px 24px rgba(16,24,40,.04)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--fg);font-family:var(--ui);line-height:1.6;font-feature-settings:"palt" 1;-webkit-font-smoothing:antialiased}button,input{font:inherit}.tnum{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.header{position:-webkit-sticky;position:sticky;top:0;z-index:30;height:68px;justify-content:space-between;padding:0 32px;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.brand,.header{display:flex;align-items:center}.brand{gap:11px}.brand-mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:#fff;background:var(--primary);font:700 16px/1 var(--ui)}.brand h1{margin:0;font-size:17px;letter-spacing:-.02em}.brand-divider{width:1px;height:18px;background:var(--line-strong);margin:0 3px}.brand-section{color:var(--muted);font-size:13px}.header-right{gap:12px}.conn,.header-right{display:flex;align-items:center}.conn{gap:7px;padding:6px 10px;border:1px solid var(--line);border-radius:20px;font-size:12px;color:var(--muted);font-weight:600}.dot{width:7px;height:7px;border-radius:50%}.dot.on{background:var(--green)}.dot.off{background:var(--faint)}.container{max-width:1180px;margin:0 auto;padding:46px 30px 100px}.page-title{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:28px}.page-title h2{margin:1px 0 4px;font-size:28px;line-height:1.3;letter-spacing:-.035em}.page-title p{margin:0;color:var(--muted);font-size:14px}.page-title .eyebrow{color:var(--faint);font-size:10px;font-weight:700;letter-spacing:.16em}.dashboard-grid{grid-template-columns:minmax(0,1fr) minmax(360px,.82fr);align-items:start}.dashboard-grid,.main-column,.side-column{display:grid;grid-gap:18px;gap:18px}.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:0 22px 22px;box-shadow:var(--shadow)}.card-head{min-height:59px;display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--line)}.card-head h2{margin:0;font-size:15px;font-weight:700;letter-spacing:-.01em}.card-head .spacer{flex:1 1}.status-card{border-top:3px solid var(--primary)}.setting{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:17px 0}.setting+.setting{border-top:1px solid var(--line)}.label{font-size:14px;font-weight:600}.desc,.setting .desc{margin-top:2px;color:var(--muted);font-size:12.5px}.btn{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 13px;border:1px solid var(--line-strong);border-radius:8px;color:#344054;background:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:.15s ease;white-space:nowrap}.btn:hover{border-color:#b6bdc8;background:var(--panel-soft)}.btn:active{transform:translateY(1px)}.btn:focus-visible,.input:focus,.tp-trigger:focus-visible{outline:3px solid rgba(38,59,87,.14);border-color:var(--primary)}.btn:disabled{opacity:.45;cursor:default;transform:none}.btn-primary{color:#fff;background:var(--primary);border-color:var(--primary)}.btn-primary:hover{color:#fff;background:var(--primary-hover);border-color:var(--primary-hover)}.btn-ok{color:var(--green);background:var(--green-soft);border-color:#b9dfcd}.btn-sm{min-height:32px;padding:5px 10px;font-size:12px}.btns{display:flex;gap:8px;flex-wrap:wrap}.iconbtn{width:36px;height:36px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;color:var(--muted);background:#fff;cursor:pointer;transition:.15s}.iconbtn:hover{color:var(--fg);background:var(--panel-soft)}.iconbtn.danger:hover{color:var(--red);border-color:#f2c0c3;background:var(--red-soft)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;border:1px solid transparent;font-size:11.5px;font-weight:700}.badge.on{color:var(--green);background:var(--green-soft);border-color:#c7e8d8}.badge.neutral{color:var(--muted);background:var(--panel-soft);border-color:var(--line)}.switch{position:relative;width:42px;height:24px;flex:0 0 auto;cursor:pointer}.switch input{position:absolute;opacity:0}.slider{inset:0;border-radius:20px;background:#d0d5dd}.slider,.slider:before{position:absolute;transition:.18s}.slider:before{content:"";width:18px;height:18px;left:3px;top:3px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(16,24,40,.2)}.switch input:checked+.slider{background:var(--primary)}.switch input:checked+.slider:before{transform:translateX(18px)}.input{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:8px;color:var(--fg);background:#fff;font-size:14px;transition:.15s}.input::placeholder{color:var(--faint)}.input:focus{outline:3px solid rgba(38,59,87,.1);border-color:var(--primary)}.inline{display:flex;align-items:center;gap:9px}.grow{flex:1 1;min-width:0}input[type=number].input{width:78px}.range-wrap{display:flex;align-items:center;gap:18px;margin:22px 0 18px}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:5px;border-radius:3px;outline:none;cursor:pointer;background:linear-gradient(90deg,var(--primary) var(--fill,25%),#e4e7ec var(--fill,25%))}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--primary);border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(16,24,40,.18)}.range-val{min-width:40px;text-align:right;color:var(--fg);font-size:19px;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.empty{padding:24px 0;text-align:center;color:var(--muted);font-size:13px}.member-block{padding:16px 0}.member-block+.member-block{border-top:1px solid var(--line)}.member-top{display:flex;align-items:center;gap:11px;margin-bottom:12px}.avatar{width:34px;height:34px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;color:var(--primary);background:var(--primary-soft);font-size:14px;font-weight:700}.member .name,.member-top .name{font-size:14px;font-weight:600}.time-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:9px;gap:9px}.tf{min-width:0;display:flex;flex-direction:column;gap:6px}.tf-label{color:var(--muted);font-size:11px;font-weight:600}.add-block{display:grid;grid-gap:11px;gap:11px;margin-top:16px;padding-top:18px;border-top:1px solid var(--line)}.member-times{display:grid;grid-template-columns:repeat(3,1fr);overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft)}.member-times>div{min-width:0;display:grid;padding:9px 11px}.member-times>div+div{border-left:1px solid var(--line)}.member-times span{color:var(--muted);font-size:10px;font-weight:600}.member-times strong{font-size:14px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.member-times small{color:var(--faint);font-size:9px}.member-edit{display:grid;grid-gap:12px;gap:12px;padding:14px;border:1px solid var(--line);border-radius:9px;background:var(--panel-soft)}.member-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:2px}.tp{position:relative}.tp-trigger{width:100%;min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid var(--line-strong);border-radius:8px;color:var(--fg);background:#fff;cursor:pointer}.tp-trigger.open{border-color:var(--primary)}.tp-trigger .val{font-size:14px;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tp-trigger .val.empty{padding:0;color:var(--faint);font-size:12px;font-weight:400}.tp-trigger .chev{color:var(--muted)}.tp-pop{position:absolute;z-index:40;top:calc(100% + 6px);left:0;right:0;min-width:210px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;box-shadow:0 16px 36px rgba(16,24,40,.16)}.tp-cols{display:flex;gap:8px}.tp-col{flex:1 1}.tp-col-h{margin-bottom:5px;color:var(--faint);text-align:center;font-size:10px}.tp-list{height:168px;display:grid;grid-gap:2px;gap:2px;overflow-y:auto}.tp-cell{padding:6px 0;border-radius:6px;color:var(--muted);text-align:center;font-size:13px;cursor:pointer}.tp-cell:hover{color:var(--fg);background:var(--panel-soft)}.tp-cell.sel{color:#fff;background:var(--primary);font-weight:700}.tp-foot{display:flex;justify-content:space-between;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--line)}.center{min-height:100dvh;display:grid;place-items:center;padding:24px;background:#eef0f3}.login{width:100%;max-width:390px;padding:34px}.login .brand-mark{margin-bottom:28px}.login h1{margin:0 0 5px;font-size:22px;letter-spacing:-.03em}.login .sub{margin:0 0 26px;color:var(--muted);font-size:13px}.field>label{display:block;margin-bottom:7px;color:#475467;font-size:12px;font-weight:600}.err{margin-top:12px;color:var(--red)}.err,.toast{font-size:13px}.toast{position:fixed;z-index:60;bottom:22px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;padding:11px 16px;border:1px solid var(--line);border-radius:9px;color:var(--fg);background:#fff;box-shadow:0 12px 32px rgba(16,24,40,.16);font-weight:600}.toast.success{color:var(--green)}.toast.error{color:var(--red);border-color:#f2c0c3}.spinner{width:20px;height:20px;border:2px solid #d0d5dd;border-top:2px solid var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:70px 0;color:var(--muted)}@media (max-width:860px){.dashboard-grid{grid-template-columns:1fr}.side-column{grid-row:auto}}@media (max-width:600px){.header{height:62px;padding:0 16px}.brand-divider,.brand-section{display:none}.container{padding:28px 14px 70px}.page-title{align-items:flex-start;flex-direction:column;margin-bottom:20px}.page-title h2{font-size:24px}.page-title .btn{width:100%}.card{padding:0 16px 18px}.setting{align-items:flex-start}.member-times,.time-grid{grid-template-columns:1fr}.member-times>div+div{border-left:0;border-top:1px solid var(--line)}.member-actions .btn{flex:1 1}.inline[style]{flex-wrap:wrap}.inline[style] .btn{width:100%}.conn{padding:5px 8px}.login{padding:28px 22px}}