:root{--accent: #4B99D2;--accent-600: #3a82ba;--accent-700: #2f6c9d;--accent-50: #eef6fc;--accent-100: #dcebf8;--accent-100: #d8eaf8;--accent-200: #bcdcf1;--ink: #16242f;--ink-soft: #41515d;--muted: #8595a1;--muted-2: #aab6bf;--bg: #f4f8fb;--bg-grad-top: #f7fbfe;--card: #ffffff;--border: #e6edf2;--border-strong: #d4dee5;--due: #f2994a;--shadow-sm: 0 1px 2px rgba(22, 47, 67, .05), 0 1px 3px rgba(22, 47, 67, .04);--shadow-md: 0 6px 18px rgba(28, 71, 105, .1);--shadow-lg: 0 18px 50px rgba(28, 71, 105, .18);--radius: 16px;--radius-sm: 11px;--font: "Figtree", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body{margin:0;height:100%;font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{overflow:hidden}body.is-mobile{overflow:auto}#root{height:100%}button{font-family:inherit;cursor:pointer}::selection{background:var(--accent-200)}.app{height:100%;display:flex;flex-direction:column;background:radial-gradient(1200px 600px at 80% -10%,var(--accent-50),transparent 60%),linear-gradient(180deg,var(--bg-grad-top),var(--bg))}.topbar{flex:0 0 auto;display:flex;align-items:center;gap:20px;padding:16px 26px}.brand{display:flex;align-items:center;gap:13px;flex:0 0 auto}.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--accent),var(--accent-700));box-shadow:0 4px 12px #4b99d266;display:grid;place-items:center;color:#fff;flex:0 0 auto}.brand-text{line-height:1.05}.brand-title{font-size:19px;font-weight:700;letter-spacing:-.01em;white-space:nowrap}.brand-sub{font-size:12.5px;color:var(--muted);font-weight:500;margin-top:2px}.topbar-spacer{flex:1 1 auto}.progress{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:7px 8px 7px 18px;box-shadow:var(--shadow-sm)}.progress-meta{text-align:right;line-height:1.1}.progress-count{font-size:14px;font-weight:700;font-variant-numeric:tabular-nums}.progress-count b{color:var(--accent-700)}.progress-label{font-size:11px;color:var(--muted);font-weight:500}.ring{width:38px;height:38px;flex:0 0 auto}.iconbtn{width:40px;height:40px;display:grid;place-items:center;background:var(--card);border:1px solid var(--border);border-radius:11px;color:var(--ink-soft);box-shadow:var(--shadow-sm);transition:transform .12s ease,border-color .12s,color .12s,background .12s}.iconbtn:hover{color:var(--accent-700);border-color:var(--accent-200);transform:translateY(-1px)}.iconbtn.active{background:var(--accent-50);border-color:var(--accent-200);color:var(--accent-700)}.iconbtn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px #4b99d259}.iconbtn.primary:hover{background:var(--accent-600)}.segmented{display:flex;gap:2px;padding:3px;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm)}.segmented button{width:34px;height:32px;border:0;background:transparent;border-radius:9px;color:var(--muted-2);display:grid;place-items:center;transition:background .12s,color .12s}.segmented button:hover{color:var(--accent-700)}.segmented button.active{background:var(--accent-50);color:var(--accent-700)}.board-viewport{flex:1 1 auto;position:relative;min-height:0;overflow:hidden}.board-scaler{position:absolute;top:0;left:50%;transform-origin:top center;will-change:transform}.board{display:flex;flex-direction:column;gap:18px;padding:4px 26px 26px}.section-head{display:flex;align-items:center;gap:11px;margin:0 2px 11px}.section-dot{width:9px;height:9px;border-radius:3px;background:var(--accent);flex:0 0 auto}.section-name{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}.section-meta{font-size:12px;color:var(--muted);font-weight:500;white-space:nowrap}.section-line{flex:1 1 auto;height:1px;background:linear-gradient(90deg,var(--border),transparent)}.section-edit{opacity:0;transition:opacity .15s}.section:hover .section-edit{opacity:1}.grid{display:grid;grid-auto-flow:dense;gap:13px}.grid.masonry{grid-template-columns:repeat(var(--cols, 6),1fr);grid-auto-rows:92px}.grid.tiles{grid-template-columns:repeat(var(--cols, 7),1fr);grid-auto-rows:1fr}.columns-wrap{display:grid;grid-template-columns:repeat(var(--seccols, 2),1fr);gap:22px;align-items:start}.columns-wrap .grid.columns{grid-template-columns:1fr;grid-auto-rows:auto}.grid.masonry .card.small{grid-column:span 1;grid-row:span 1}.grid.masonry .card.medium{grid-column:span 2;grid-row:span 1}.grid.masonry .card.large{grid-column:span 2;grid-row:span 2}.grid.tiles .card{grid-column:span 1;grid-row:span 1;aspect-ratio:1 / 1}.grid.tiles .card.medium{grid-column:span 2}.grid.tiles .card.large{grid-column:span 2;grid-row:span 2}.card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:13px 14px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);cursor:pointer;overflow:hidden;transition:transform .14s ease,box-shadow .16s,border-color .16s,opacity .25s,background .2s;-webkit-tap-highlight-color:transparent}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.card:active{transform:translateY(0)}.card.dragging{opacity:.35}.card.drop-before:after,.card.drop-after:after{content:"";position:absolute;top:0;bottom:0;width:4px;background:var(--accent);z-index:6;box-shadow:0 0 8px #4b99d2b3}.card.drop-before:after{left:0;border-radius:4px 0 0 4px}.card.drop-after:after{right:0;border-radius:0 4px 4px 0}.card-name{font-size:14.5px;font-weight:600;letter-spacing:-.01em;color:var(--ink);line-height:1.22;text-wrap:pretty}.card.large .card-name{font-size:20px}.card.medium .card-name{font-size:16px}.card-foot{margin-top:auto;display:flex;align-items:center;gap:7px;padding-top:9px}.card-ago{font-size:11.5px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card.large .card-ago,.card.medium .card-ago{font-size:12.5px}.card-top{display:flex;align-items:flex-start;gap:8px}.card-top .card-name{flex:1 1 auto}.check{flex:0 0 auto;width:22px;height:22px;border-radius:7px;border:2px solid var(--border-strong);display:grid;place-items:center;color:#fff;background:transparent;transition:background .16s,border-color .16s,transform .16s}.card.large .check,.card.medium .check{width:25px;height:25px;border-radius:8px}.check svg{opacity:0;transform:scale(.4);transition:opacity .16s,transform .2s cubic-bezier(.2,1.4,.4,1)}.card.due{border-color:var(--accent-200)}.card.due:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--accent),var(--accent-700))}.card.due .check{border-color:var(--accent)}.card.due:hover .check{background:var(--accent-50)}.card.overdue .card-ago{color:var(--due);font-weight:600}.card.done{background:#fbfdfe;border-color:var(--border);opacity:.62;box-shadow:none}.card.done:hover{opacity:1}.card.done .card-name{color:var(--ink-soft);text-decoration:line-through;text-decoration-color:var(--muted-2)}.card.done .check{background:var(--accent);border-color:var(--accent)}.card.done .check svg{opacity:1;transform:scale(1)}.ripe{position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--accent-50)}.ripe i{display:block;height:100%;background:var(--accent-200);transition:width .3s}.card.due .ripe,.card.done .ripe{display:none}.badges{display:flex;gap:5px;align-items:center}.badge{font-size:10px;font-weight:700;letter-spacing:.03em;padding:2px 7px;border-radius:999px;text-transform:uppercase;white-space:nowrap}.badge.opt{background:#f1f5f8;color:var(--muted)}.badge.freq{background:var(--accent-50);color:var(--accent-700)}.card-edit{position:absolute;top:7px;right:7px;width:26px;height:26px;border-radius:8px;background:#ffffffe6;border:1px solid var(--border);color:var(--ink-soft);display:grid;place-items:center;opacity:0;transform:translateY(-3px);transition:opacity .14s,transform .14s,background .14s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3}.card:hover .card-edit{opacity:1;transform:none}.card-edit:hover{background:var(--accent-50);color:var(--accent-700);border-color:var(--accent-200)}.card.small{padding:11px 12px}.card.small .card-name{font-size:13.5px}.card.small .card-foot{padding-top:6px}.complete-dock{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:center;padding:0 0 26px;pointer-events:none;z-index:40}.complete-btn{pointer-events:auto;display:inline-flex;align-items:center;gap:13px;padding:16px 30px;font-size:18px;font-weight:700;letter-spacing:-.01em;color:#fff;border:0;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-700));box-shadow:0 14px 38px #2f6c9d73,inset 0 1px #ffffff40;animation:popUp .5s cubic-bezier(.2,1.3,.4,1) both,glow 2.4s ease-in-out infinite}.complete-btn:hover{transform:translateY(-2px) scale(1.015)}.complete-btn .spark{font-size:21px}@keyframes popUp{0%{opacity:0;transform:translateY(28px) scale(.9)}}@keyframes glow{0%,to{box-shadow:0 14px 38px #2f6c9d73,inset 0 1px #ffffff40}50%{box-shadow:0 14px 52px #4b99d2b3,inset 0 1px #ffffff40}}#fx{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:60}.cheer{position:fixed;left:50%;top:38%;transform:transl(-50%,-50%);z-index:61;pointer-events:none;text-align:center;transform:translate(-50%,-50%)}.cheer-emoji{font-size:64px;animation:cheerPop .6s cubic-bezier(.2,1.4,.3,1) both}.cheer-text{margin-top:6px;font-size:30px;font-weight:800;letter-spacing:-.02em;color:var(--accent-700);text-shadow:0 2px 14px rgba(255,255,255,.9);animation:cheerPop .6s .06s cubic-bezier(.2,1.4,.3,1) both}.cheer-sub{font-size:15px;color:var(--ink-soft);font-weight:600;margin-top:4px;animation:cheerPop .6s .12s both}@keyframes cheerPop{0%{opacity:0;transform:scale(.5)}}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#12283a57;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:24px;animation:fade .18s ease both}@keyframes fade{0%{opacity:0}}.modal{width:100%;max-width:460px;background:var(--card);border-radius:20px;box-shadow:var(--shadow-lg);overflow:hidden;animation:modalIn .24s cubic-bezier(.2,1,.3,1) both;max-height:90vh;display:flex;flex-direction:column}.modal.wide{max-width:540px}@keyframes modalIn{0%{opacity:0;transform:translateY(14px) scale(.98)}}.modal-head{display:flex;align-items:center;gap:12px;padding:20px 22px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:18px;font-weight:700;flex:1 1 auto;letter-spacing:-.01em}.modal-body{padding:20px 22px;overflow-y:auto}.modal-foot{display:flex;gap:10px;align-items:center;padding:16px 22px;border-top:1px solid var(--border)}.modal-foot .grow{flex:1 1 auto}.field{margin-bottom:16px}.field:last-child{margin-bottom:0}.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:7px}.input,.select{width:100%;padding:11px 13px;font-family:inherit;font-size:14.5px;color:var(--ink);background:#fff;border:1.5px solid var(--border-strong);border-radius:11px;transition:border-color .14s,box-shadow .14s}.input:focus,.select:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.row{display:flex;gap:10px}.row>*{flex:1 1 0}.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{flex:1 1 0;padding:10px 12px;border-radius:11px;border:1.5px solid var(--border-strong);background:#fff;font-size:13.5px;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;gap:7px;transition:all .14s}.chip:hover{border-color:var(--accent-200)}.chip.on{border-color:var(--accent);background:var(--accent-50);color:var(--accent-700)}.chip .sz{display:block;border-radius:4px;background:currentColor;opacity:.85}.btn{padding:11px 18px;font-size:14.5px;font-weight:600;border-radius:11px;border:1.5px solid var(--border-strong);background:#fff;color:var(--ink-soft);transition:all .14s}.btn:hover{border-color:var(--accent-200);color:var(--accent-700)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px #4b99d24d}.btn.primary:hover{background:var(--accent-600)}.btn.danger{color:#c0392b;border-color:transparent;background:transparent;padding-left:8px;padding-right:8px}.btn.danger:hover{background:#fdecea}.btn.ghost{border-color:transparent;background:transparent}.sec-row{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;margin-bottom:8px;background:#fff}.sec-row .grip{color:var(--muted-2);cursor:grab}.sec-row .input{flex:1 1 auto;padding:8px 11px}.toggle{position:relative;width:44px;height:26px;border-radius:999px;background:var(--border-strong);border:0;transition:background .16s;flex:0 0 auto}.toggle.on{background:var(--accent)}.toggle i{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .18s cubic-bezier(.3,1.4,.4,1);box-shadow:0 1px 3px #0003}.toggle.on i{transform:translate(18px)}.toggle-row{display:flex;align-items:center;gap:12px}.toggle-row .tr-text{flex:1 1 auto}.toggle-row .tr-text b{display:block;font-size:14px}.toggle-row .tr-text span{font-size:12.5px;color:var(--muted)}.help{font-size:12.5px;color:var(--muted);margin-top:6px;line-height:1.4}.empty-hint{text-align:center;color:var(--muted);font-size:14px;padding:40px}body.is-mobile .app{height:auto;min-height:100%}body.is-mobile .board-viewport{overflow:visible}body.is-mobile .board-scaler{position:static;transform:none!important;left:auto;width:100%}body.is-mobile .topbar{flex-wrap:wrap;padding:14px 16px;gap:12px;position:sticky;top:0;z-index:30;background:#f7fbfee6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}body.is-mobile .board{padding:4px 16px 120px;gap:22px}body.is-mobile .grid.masonry,body.is-mobile .grid.tiles{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto}body.is-mobile .grid.masonry .card.large,body.is-mobile .grid.masonry .card.medium,body.is-mobile .grid.tiles .card.large,body.is-mobile .grid.tiles .card.medium{grid-column:span 2;grid-row:span 1;aspect-ratio:auto}body.is-mobile .grid.tiles .card{aspect-ratio:auto}body.is-mobile .columns-wrap{grid-template-columns:1fr}body.is-mobile .card{min-height:78px}body.is-mobile .progress{order:3}body.is-mobile .modal{max-width:100%}
