:root{--bg-top:#ece8df;--bg-bottom:#d7ebef;--ink:#16212f;--muted:#506173;--panel:rgba(255, 255, 255, 0.72);--track:#bed2db;--arc:#1b6b88;--start:#135f7b;--end:#f05c4f;--sleep:#1b6b88;--bath:#dd7f2e;--focus:#ffb000}*{box-sizing:border-box}[hidden]{display:none!important}body{margin:0;min-height:100vh;min-height:100dvh;overflow-x:hidden;font-family:"Avenir Next","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;color:var(--ink);background:radial-gradient(circle at 18% 8%,rgba(255,255,255,.8),transparent 26%),radial-gradient(circle at 85% 92%,rgba(196,231,238,.55),transparent 34%),linear-gradient(165deg,var(--bg-top),var(--bg-bottom))}.app{max-width:760px;margin:0 auto;padding:1rem 1rem 2rem}.hero{margin-bottom:.6rem}.eyebrow{margin:0;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);font-weight:700;font-size:.82rem}h1{margin:0;font-size:clamp(1.05rem, 3.8vw, 1.35rem);line-height:1.2}.sub{margin:0;color:var(--muted);font-size:.86rem}.dial-panel{background:var(--panel);border-radius:28px;backdrop-filter:blur(7px);padding:1.2rem 1rem 1.4rem;box-shadow:0 20px 40px rgba(37,68,80,.16)}.dial-panel h2{margin:0 0 .8rem;font-size:1.08rem}.dial-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.dial-title-heading{margin:0;min-width:0}.set-trigger{border:0;background:0 0;color:var(--ink);padding:0;display:inline-flex;align-items:baseline;gap:.45rem;font-size:1.08rem;font-weight:700;border-radius:6px;cursor:pointer}.set-trigger:hover{color:#0f4f6d;background:0 0}.set-trigger-caret{font-size:.72rem;color:var(--muted);font-weight:600;letter-spacing:.04em}.save-set-btn{white-space:nowrap}.save-status{margin:0 0 .55rem;min-height:1.1em;color:#1f5ab0;font-size:.82rem}.dial-wrap{width:min(100%,380px);margin:0 auto;position:relative}.dial{width:100%;height:auto;touch-action:none;overflow:hidden}.dial-track{fill:none;stroke:var(--track);stroke-width:18;pointer-events:none}.task-layer{isolation:isolate}.dial-tick{stroke:rgba(28,48,66,0.45);stroke-linecap:round}.dial-tick.major{stroke-width:2.4;stroke:rgba(22,44,61,0.62)}.dial-tick.minor{stroke-width:1.5}.dial-label{fill:rgba(22,44,61,0.78);font-size:10px;font-weight:600;text-anchor:middle;dominant-baseline:middle;letter-spacing:.03em;user-select:none}.day-start-marker{stroke:#e15a44;stroke-width:3;stroke-linecap:round}.day-start-marker-dot{fill:#e15a44}.day-start-label{fill:#bf3c26;font-size:9px;font-weight:700;text-anchor:middle;dominant-baseline:middle;letter-spacing:.02em;user-select:none}.current-time-marker{stroke:#1f6fd1;stroke-width:3;stroke-linecap:round}.current-time-marker-dot{fill:#1f6fd1}.current-time-label{fill:#1f5ab0;font-size:9px;font-weight:700;text-anchor:middle;dominant-baseline:middle;letter-spacing:.02em;user-select:none}.dial-labels,.dial-ticks{pointer-events:none}.global-drag-ring{fill:none;stroke:transparent;stroke-width:34;pointer-events:stroke;cursor:grab}.global-drag-ring:active{cursor:grabbing}.dial-arc{fill:none;stroke-width:18;stroke-linecap:round;cursor:grab}.dial.is-view-mode .task-arc{stroke-width:26;stroke-linecap:butt}.task-arc{opacity:.92}.task-arc-label{font-size:10px;font-weight:700;text-anchor:middle;dominant-baseline:middle;letter-spacing:.04em;user-select:none;pointer-events:auto;cursor:grab}.task-arc.sleep{stroke:var(--sleep)}.task-arc.bath{stroke:var(--bath)}.task-arc.is-selected{filter:drop-shadow(0 0 4px rgba(17, 34, 48, .32))}.dial-arc:active{cursor:grabbing}.dial-handle{stroke:#fff;stroke-width:3;cursor:grab}.dial.is-view-mode .dial-handle{display:none}.dial-handle:active{cursor:grabbing}.dial-handle.start{fill:var(--start)}.dial-handle.end{fill:var(--end)}.task-handle.sleep.start{fill:#135f7b}.task-handle.sleep.end{fill:#2188ab}.task-handle.bath.start{fill:#bd6220}.task-handle.bath.end{fill:#f0983f}.dial-handle:focus-visible{outline:0;stroke:var(--focus);stroke-width:5}.dial-center{position:absolute;inset:0;display:grid;place-content:center;text-align:center;pointer-events:none}.sleep-label{margin:0;color:var(--muted);font-size:.88rem}.sleep-value{margin:.2rem 0;font-size:clamp(1.35rem, 5vw, 1.9rem);font-weight:700}.range-value{margin:0;color:var(--muted);font-size:.95rem}.slide-mode{margin:1rem 0 0;padding:.6rem .7rem;border:1px solid rgba(40,63,84,.2);border-radius:12px;display:flex;flex-wrap:wrap;gap:.8rem}.slide-mode legend{padding:0 .25rem;font-size:.8rem;color:var(--muted)}.slide-mode label{display:inline-flex;align-items:center;gap:.35rem;font-size:.88rem;color:var(--ink)}.card-display-mode{margin-top:.95rem;display:grid;gap:0}.card-display-mode-label{margin:0;font-size:.8rem;color:var(--muted)}.card-display-mode-segment{display:inline-flex;align-items:center;justify-content:flex-end;justify-self:end;gap:.6rem;border:1px solid rgba(40,63,84,.2);border-radius:11px;background:rgba(255,255,255,.66);padding:.38rem .55rem}.card-display-mode-text{font-size:.82rem;color:var(--ink);user-select:none}.card-display-mode-switch{position:relative;display:inline-flex;align-items:center;width:42px;height:24px}.card-display-mode-switch input{position:absolute;opacity:0;inset:0;margin:0;cursor:pointer}.card-display-mode-slider{width:100%;height:100%;border-radius:999px;background:rgba(105,123,139,.35);border:1px solid rgba(56,76,95,.22);position:relative;transition:background-color 160ms}.card-display-mode-slider::before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(20,39,56,.28);transition:transform 160ms}.card-display-mode-switch input:checked+.card-display-mode-slider{background:rgba(31,90,176,.65)}.card-display-mode-switch input:checked+.card-display-mode-slider::before{transform:translateX(18px)}.card-display-mode-switch input:focus-visible+.card-display-mode-slider{outline:rgba(31,90,176,.75) solid 2px;outline-offset:2px}.task-controls{margin-top:1.2rem;display:grid;grid-template-columns:1fr;gap:.8rem;overflow:hidden}.task-control{background:rgba(255,255,255,.72);border:1px solid rgba(40,63,84,.14);border-radius:14px;padding:.75rem;display:grid;gap:.55rem}.task-control.empty p{margin:0}.task-card-head{display:grid;grid-template-columns:minmax(180px,1fr) auto;gap:.8rem}.card-field{display:grid;gap:.3rem;font-size:.8rem;color:var(--muted)}.color-preset-grid{display:grid;grid-template-columns:repeat(10,20px);justify-content:start;gap:.35rem}.color-preset{display:block;width:20px;height:20px;border-radius:999px;border:2px solid rgba(255,255,255,.95);box-shadow:0 0 0 1px rgba(30,50,70,.25);padding:0}.color-preset:hover{transform:translateY(-1px)}.color-preset.is-active{box-shadow:0 0 0 1px rgba(30,50,70,.25),0 0 0 3px rgba(255,176,0,.55)}.task-time-readonly{display:grid;grid-template-columns:repeat(2,minmax(110px,1fr));gap:.6rem}.task-time-readonly p{margin:0;color:var(--muted);font-size:.86rem}.task-time-readonly strong{color:var(--ink);font-size:1rem}.task-actions{display:flex;gap:.5rem;flex-wrap:wrap}button{border:1px solid rgba(40,63,84,.22);background:rgba(255,255,255,.9);color:var(--ink);border-radius:10px;padding:.45rem .7rem;font-size:.85rem;cursor:pointer}button:hover{background:#fff}button.danger{border-color:rgba(175,65,65,.36);color:#8a2a2a}.task-control.is-selected{border-color:rgba(27,107,136,.42);box-shadow:0 6px 14px rgba(32,70,83,.11)}.task-control-view{padding:.5rem .8rem}.timeline-task-block{display:grid;gap:.22rem;padding:.32rem 0}.timeline-time{margin:0;color:#5a7082;font-size:.9rem;font-weight:600;letter-spacing:.03em;font-variant-numeric:tabular-nums}.timeline-title{margin:0;color:var(--ink);font-size:1.14rem;font-weight:800;line-height:1.2;text-align:center}.timeline-middle-row{display:grid;grid-template-columns:minmax(76px,auto) 1fr;align-items:center;column-gap:.45rem}.timeline-duration-rail{display:inline-flex;align-items:center;gap:.28rem;color:#5f7687;font-size:.82rem;white-space:nowrap}.timeline-duration-marker{color:#7890a1;font-size:.95rem;font-weight:700;line-height:1}.timeline-duration{font-variant-numeric:tabular-nums}.timeline-gap-row{display:inline-flex;align-items:center;gap:.38rem;margin:.02rem .2rem .18rem .3rem;color:#4d6475;font-size:.9rem}.timeline-gap-bar{color:#7890a1;font-size:1rem;font-weight:700;line-height:1}.timeline-gap-text{font-variant-numeric:tabular-nums}.set-panel-overlay{position:fixed;inset:0;background:rgba(16,33,47,.26);backdrop-filter:blur(1.5px);z-index:1600;opacity:0;transition:opacity 220ms}.set-panel{position:fixed;inset:0 auto 0 0;width:min(92vw,420px);background:rgba(249,251,253,.98);border-right:1px solid rgba(40,63,84,.16);box-shadow:18px 0 34px rgba(14,29,41,.2);z-index:1700;transform:translateX(-102%);transition:transform 260ms cubic-bezier(.2, 0, 0, 1);display:grid;grid-template-rows:auto auto 1fr;padding:calc(1rem + env(safe-area-inset-top)) calc(.95rem + env(safe-area-inset-right)) calc(.95rem + env(safe-area-inset-bottom)) calc(.95rem + env(safe-area-inset-left))}body.set-panel-open .set-panel-overlay{opacity:1}body.set-panel-open .set-panel{transform:translateX(0)}.set-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.7rem;margin-bottom:.7rem}.set-panel-header h2{margin:0;font-size:1rem}.set-panel-tools{margin-bottom:.7rem}.set-list{overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;display:grid;gap:.55rem;align-content:start;padding-right:.2rem}.set-row{border:1px solid rgba(40,63,84,.16);border-radius:12px;background:#fff;padding:.6rem;display:grid;gap:.5rem}.set-row[draggable=true]{user-select:none}.set-row.is-active{border-color:rgba(27,107,136,.5);box-shadow:0 4px 12px rgba(32,70,83,.1)}.set-row.is-reordering-source{opacity:.55}.set-row.is-drop-before{box-shadow:inset 0 3px 0 #1f5ab0}.set-row.is-drop-after{box-shadow:inset 0 -3px 0 #1f5ab0}.set-row-head{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.5rem}.set-drag-handle{width:1.9rem;height:1.9rem;border-radius:10px;padding:0;font-size:.94rem;line-height:1;color:#3f5366;cursor:grab}.set-drag-handle:active{cursor:grabbing}.set-drag-handle:disabled{cursor:not-allowed;opacity:.45}.set-title-button{border:0;background:0 0;text-align:left;padding:0;margin:0;font-size:.97rem;font-weight:700;color:var(--ink);cursor:pointer}.set-title-button:hover{color:#0f4f6d;background:0 0}.set-title-editor{width:100%}.set-row-actions{display:flex;gap:.45rem;flex-wrap:wrap}.set-row-actions button{font-size:.78rem;padding:.34rem .55rem}.set-empty{margin:0;color:var(--muted);font-size:.9rem}.options-toggle-btn{position:fixed;top:calc(1.2rem + env(safe-area-inset-top));right:calc(1.2rem + env(safe-area-inset-right));z-index:1200}.options-panel{position:fixed;top:calc(60px + env(safe-area-inset-top));right:calc(40px + env(safe-area-inset-right));z-index:1400;background:rgba(255,255,255,.97);box-shadow:0 8px 20px rgba(0,0,0,.18);padding:1rem 1rem 1.1rem;border-radius:12px;min-width:300px;max-width:min(92vw,360px);display:grid;gap:.75rem}.options-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.options-panel-title{margin:0;font-size:1rem}.options-group{display:grid;gap:.35rem}.options-inline-toggle{display:inline-flex;align-items:center;gap:.5rem}.options-transfer{border-top:1px solid rgba(40,63,84,.16);margin-top:.2rem;padding-top:.8rem;display:grid;gap:.45rem}.options-transfer h3{margin:0;font-size:.93rem}.options-help{margin:0;color:var(--muted);font-size:.8rem;line-height:1.4}.options-actions{display:flex;flex-wrap:wrap;gap:.45rem}.options-howto-btn{justify-self:start}.import-dialog-overlay{position:fixed;inset:0;background:rgba(16,33,47,.38);backdrop-filter:blur(2px);z-index:2000;opacity:0;transition:opacity 180ms}.import-dialog{position:fixed;inset:auto calc(1rem + env(safe-area-inset-right)) calc(1rem + env(safe-area-inset-bottom)) auto;width:min(92vw,420px);background:rgba(248,251,254,.98);border:1px solid rgba(40,63,84,.2);border-radius:14px;box-shadow:0 16px 34px rgba(15,30,42,.3);z-index:2100;padding:.9rem;display:grid;gap:.7rem;transform:translateY(14px);opacity:0;pointer-events:none;transition:transform 220ms cubic-bezier(.2, 0, 0, 1),opacity 220ms}.import-dialog-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.import-dialog-header h2{margin:0;font-size:1rem}.import-dialog-text{margin:0;color:var(--ink);line-height:1.45;font-size:.9rem}.import-dialog-actions{display:flex;justify-content:flex-end;gap:.45rem;flex-wrap:wrap}.switch-set-dialog-overlay{position:fixed;inset:0;background:rgba(16,33,47,.38);backdrop-filter:blur(2px);z-index:2200;opacity:0;transition:opacity 180ms}.switch-set-dialog{position:fixed;inset:auto calc(1rem + env(safe-area-inset-right)) calc(1rem + env(safe-area-inset-bottom)) auto;width:min(92vw,420px);background:rgba(248,251,254,.98);border:1px solid rgba(40,63,84,.2);border-radius:14px;box-shadow:0 16px 34px rgba(15,30,42,.3);z-index:2300;padding:.9rem;display:grid;gap:.7rem;transform:translateY(14px);opacity:0;pointer-events:none;transition:transform 220ms cubic-bezier(.2, 0, 0, 1),opacity 220ms}.switch-set-dialog-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.switch-set-dialog-header h2{margin:0;font-size:1rem}.switch-set-dialog-text{margin:0;color:var(--ink);line-height:1.45;font-size:.9rem}.switch-set-dialog-actions{display:flex;justify-content:flex-end;gap:.45rem;flex-wrap:wrap}button.primary{border-color:rgba(22,90,176,.5);background:#1f5ab0;color:#fff}button.primary:hover{background:#1a4d98}body.import-dialog-open{overflow:hidden}body.import-dialog-open .import-dialog-overlay{opacity:1}body.import-dialog-open .import-dialog{transform:translateY(0);opacity:1;pointer-events:auto}body.switch-set-dialog-open{overflow:hidden}body.switch-set-dialog-open .switch-set-dialog-overlay{opacity:1}body.switch-set-dialog-open .switch-set-dialog{transform:translateY(0);opacity:1;pointer-events:auto}.howto-dialog-overlay{position:fixed;inset:0;background:rgba(16,33,47,.38);backdrop-filter:blur(2px);z-index:2400;opacity:0;transition:opacity 180ms}.howto-dialog{position:fixed;inset:auto calc(1rem + env(safe-area-inset-right)) calc(1rem + env(safe-area-inset-bottom)) auto;width:min(92vw,560px);max-height:min(84dvh,760px);overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:rgba(248,251,254,.98);border:1px solid rgba(40,63,84,.2);border-radius:14px;box-shadow:0 16px 34px rgba(15,30,42,.3);z-index:2500;padding:.9rem;display:grid;gap:.7rem;transform:translateY(14px);opacity:0;pointer-events:none;transition:transform 220ms cubic-bezier(.2, 0, 0, 1),opacity 220ms}.howto-dialog-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.howto-dialog-header h2{margin:0;font-size:1rem}.howto-dialog-content{display:grid;gap:.7rem}.howto-section{border:1px solid rgba(40,63,84,.16);border-radius:12px;background:rgba(255,255,255,.84);padding:.75rem;display:grid;gap:.45rem}.howto-section h3{margin:0;font-size:.95rem}.howto-section li,.howto-section p{margin:0;line-height:1.5;font-size:.9rem}.howto-section ol,.howto-section ul{margin:0;padding-left:1.25rem;display:grid;gap:.32rem}body.howto-dialog-open{overflow:hidden}body.howto-dialog-open .howto-dialog-overlay{opacity:1}body.howto-dialog-open .howto-dialog{transform:translateY(0);opacity:1;pointer-events:auto}.task-title{margin:0;font-size:.9rem;font-weight:700;color:var(--ink)}.task-time-row{display:grid;gap:.45rem;grid-template-columns:repeat(2,minmax(90px,1fr))}label{display:grid;gap:.35rem;font-size:.85rem;color:var(--muted)}input[type=time]{padding:.52rem .6rem;border-radius:10px;border:1px solid rgba(40,63,84,.25);font-size:1rem;color:var(--ink);background:rgba(255,255,255,.9)}input[type=text]{padding:.48rem .55rem;border-radius:10px;border:1px solid rgba(40,63,84,.25);font-size:1rem;color:var(--ink);background:rgba(255,255,255,.9)}input[type=color]{width:52px;height:36px;border:1px solid rgba(40,63,84,.25);border-radius:10px;padding:2px;background:rgba(255,255,255,.9)}@media (max-width:520px){.app{padding:1.3rem .85rem 2rem}.dial-label{font-size:9px}.current-time-label,.day-start-label{display:none}.dial-panel{border-radius:20px}.task-card-head,.task-controls,.task-time-readonly{grid-template-columns:1fr}.card-display-mode-segment{justify-content:flex-end;justify-self:end;gap:.65rem}.card-display-mode-text{font-size:.8rem}.timeline-title{font-size:1.04rem}.timeline-time{font-size:.84rem}.timeline-middle-row{grid-template-columns:minmax(68px,auto) 1fr;column-gap:.36rem}.timeline-duration-rail{font-size:.76rem}.dial-title-row{flex-direction:column;align-items:stretch}.save-set-btn{width:100%}.set-panel{width:100vw;border-right:0;padding-left:calc(.8rem + env(safe-area-inset-left));padding-right:calc(.8rem + env(safe-area-inset-right))}.color-preset-grid{grid-template-columns:repeat(8,20px)}.options-panel{top:calc(56px + env(safe-area-inset-top));right:.65rem;left:.65rem;min-width:auto;max-width:none}.options-toggle-btn{right:calc(.85rem + env(safe-area-inset-right));top:calc(.85rem + env(safe-area-inset-top))}.import-dialog,.switch-set-dialog{inset:auto calc(0.65rem + env(safe-area-inset-right)) calc(0.65rem + env(safe-area-inset-bottom)) calc(0.65rem + env(safe-area-inset-left));width:auto}.howto-dialog{inset:auto calc(0.65rem + env(safe-area-inset-right)) calc(0.65rem + env(safe-area-inset-bottom)) calc(0.65rem + env(safe-area-inset-left));width:auto;max-height:min(86dvh,760px)}}