:root{--bg:#0f0f12;--surface:#1a1a1f;--border:#2d2d35;--text:#e8e8ec;--text-muted:#888;--primary:#6366f1;--primary-hover:#818cf8;--segment:#3b82f6;--overlap:#22c55e;--font-sans:"DM Sans", system-ui, sans-serif;--radius:12px;--shadow:0 4px 24px #0006}*{box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;margin:0;line-height:1.5}#app{max-width:1100px;margin:0 auto;padding:1.5rem}.header{text-align:center;margin-bottom:2rem}.header h1{letter-spacing:-.02em;margin:0 0 .25rem;font-size:1.75rem;font-weight:700}.tagline{color:var(--text-muted);margin:0;font-size:.95rem}.view-tz{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:.75rem;margin-top:1rem;display:flex}.view-tz-label{text-align:left;color:var(--text-muted);font-size:.85rem;display:block}.view-tz .tz-picker-input{min-width:260px}.view-tz-reset{padding:.5rem .8rem}.main{flex-direction:column;gap:2rem;display:flex}.main-panels{grid-template-columns:1fr 1fr;align-items:start;gap:1.5rem;display:grid}.main-panel-left,.main-panel-right{min-width:0}@media (width<=700px){.main-panels{grid-template-columns:1fr}}.center{justify-content:center;align-items:center;display:flex}.clock-figure{text-align:center;margin:0}.clock-caption{color:var(--text-muted);margin-top:.5rem;font-size:.8rem}.clock-wrap{background:var(--surface);border:1px solid var(--border);width:100%;max-width:360px;box-shadow:var(--shadow);border-radius:50%;margin:0 auto;position:relative;overflow:visible}.clock-wrap .clock-svg{aspect-ratio:1;width:100%;height:auto;display:block}.clock-tooltip{z-index:100;pointer-events:none;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--text);white-space:nowrap;border-radius:8px;flex-direction:column;gap:.2rem;padding:.5rem .75rem;font-size:.85rem;line-height:1.4;display:flex;position:fixed}.clock-tooltip[hidden]{display:none!important}.clock-tooltip-time{font-variant-numeric:tabular-nums;color:var(--text);font-weight:600}.clock-tooltip-who{color:var(--text-muted);font-size:.9em}.clock-tooltip-dur{color:var(--primary);font-weight:500}.clock-segment{cursor:pointer;outline:none}.clock-segment:focus{outline:none}.clock-svg .clock-face{fill:#0000;stroke:var(--border);stroke-width:2px}.clock-svg .clock-inner{fill:var(--bg);stroke:var(--border);stroke-width:1px}.clock-svg .clock-tick{stroke:var(--text-muted);stroke-width:1.5px;opacity:.8}.clock-svg .clock-label{fill:var(--text-muted);font-size:14px;font-family:var(--font-sans);font-weight:500}.clock-svg .clock-overlap-arc{stroke:var(--overlap)}.summary,.people-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem 1.5rem}.summary h2,.people-section h2{margin:0 0 .75rem;font-size:1rem;font-weight:600}.summary .muted,.people-section .empty-msg{color:var(--text-muted);margin:0;font-size:.9rem}.overlap-hours{color:var(--overlap);margin:0 0 .5rem;font-weight:600}.ranges{color:var(--text-muted);margin:0;padding-left:1.25rem;font-size:.9rem}.who-is-when{flex-direction:column;gap:.35rem;margin:.5rem 0 0;padding:0;list-style:none;display:flex}.who-seg{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:baseline;gap:.35rem .75rem;padding:.35rem 0;font-size:.9rem;display:flex}.who-seg:last-child{border-bottom:none}.who-time{font-variant-numeric:tabular-nums;color:var(--text);min-width:10rem;font-weight:500}.who-count{color:var(--text-muted);font-size:.85rem}.who-names{color:var(--text-muted)}.people-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.people-header h2{margin:0}.people-header-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.people-add-row{justify-content:center;align-items:center;padding:.5rem 0 1rem;display:flex}.people-add-row .btn{margin:0}.people-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.person-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:border-color .15s,box-shadow .15s;display:flex}.person-card:hover{border-color:#ffffff1a;box-shadow:0 2px 8px #0003}.person-card--editing{flex-direction:column;align-items:stretch;padding:1rem}.person-card--editing .person-form--inline{flex-direction:column;gap:.5rem;display:flex}.person-card--editing .person-form--inline label{margin-bottom:0}.person-card--new{border-style:dashed;border-color:var(--primary);opacity:.95}.person-info{flex:1;align-items:center;gap:.65rem;min-width:0;display:flex}.person-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.person-meta{flex-direction:column;gap:.15rem;min-width:0;display:flex}.person-name{font-size:.95rem;font-weight:600}.person-tz,.person-hours{color:var(--text-muted);font-size:.8rem}.person-actions{flex-shrink:0;align-items:center;gap:.25rem;display:flex}.btn-icon{width:36px;height:36px;color:var(--text-muted);background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:1rem;line-height:1;transition:color .15s,background .15s,border-color .15s;display:inline-flex}.btn-icon:hover{color:var(--text);background:var(--border)}.btn-icon.btn-danger:hover{color:#f87171;background:#f871711f;border-color:#f871714d}.btn{font:inherit;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:.5rem 1rem;transition:background .15s,border-color .15s}.btn:hover{background:var(--border)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-outline{border-color:var(--border);color:var(--text);background:0 0}.btn-outline:hover{background:var(--border)}.btn-ghost{color:var(--text-muted);background:0 0;border:none;padding:.25rem .5rem;font-size:1.25rem;line-height:1}.btn-ghost:hover{color:var(--text)}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow);padding:1.5rem}.modal h2{margin:0 0 1rem;font-size:1.1rem}.person-form label{margin-bottom:.75rem;font-size:.9rem;display:block}.person-form label input,.person-form label select,.person-form input,.person-form select{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font:inherit;border-radius:6px;margin-top:.25rem;padding:.5rem .6rem;display:block}.person-form .time-ctrl input{margin-top:0}.tz-picker{margin-top:.25rem;position:relative}.tz-picker-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font:inherit;border-radius:6px;padding:.5rem .6rem;display:block}.tz-picker-list{background:var(--surface);border:1px solid var(--border);max-height:220px;box-shadow:var(--shadow);z-index:50;border-radius:8px;margin:.25rem 0 0;padding:.25rem 0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.tz-picker-list[hidden]{display:none}.tz-picker-list li{cursor:pointer;color:var(--text);padding:.4rem .6rem;font-size:.9rem}.tz-picker-list li:hover{background:var(--border)}.tz-picker-list li[hidden]{display:none}.person-form .required{color:var(--text-muted);font-size:.9em;font-weight:400}.person-form .shifts{border:1px solid var(--border);border-radius:8px;margin:1rem 0;padding:1rem}.person-form .shifts legend{padding:0 .25rem;font-size:.9rem}.shift-templates{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:.75rem;padding-bottom:.75rem;display:flex}.template-label{color:var(--text-muted);margin-right:.25rem;font-size:.85rem}.btn-template{min-width:auto;padding:.35rem .6rem;font-size:.85rem}.shift-row{grid-template-columns:1fr 1fr auto;align-items:end;gap:.75rem 1rem;margin-bottom:.75rem;display:grid}.shift-row:last-of-type{margin-bottom:.5rem}.shift-cell label{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem;display:block}.shift-cell-remove{align-items:flex-end;padding-bottom:.25rem;display:flex}.shift-cell-remove .btn{padding:.35rem .5rem;font-size:.85rem}.time-ctrl{align-items:center;gap:.25rem;display:flex}.time-ctrl input{flex:1;min-width:0}.btn-sm{justify-content:center;align-items:center;width:32px;min-width:0;height:32px;padding:0;font-size:1.1rem;font-weight:600;line-height:1;display:inline-flex}.form-actions{justify-content:flex-end;gap:.5rem;margin-top:1.25rem;display:flex}.form-actions .btn{min-width:80px}
