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