:root{--text:#475569;--text-h:#0f172a;--bg:#f4f7fb;--border:#d8e2ee;--code-bg:#eaf3ff;--accent:#2563eb;--accent-bg:#2563eb14;--accent-border:#2563eb3d;--social-bg:#ffffffb3;--shadow:#0f172a17 0 12px 24px -8px, #0f172a0f 0 6px 12px -8px;--sans:Inter, "Segoe UI", Roboto, sans-serif;--heading:Inter, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, SFMono-Regular, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#2563eb1f,#0000 42%),linear-gradient(#f8fbff 0%,#f4f7fb 100%)}@media (width<=1024px){:root{font-size:16px}}body{background:inherit;min-height:100vh;margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff6;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:700}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--surface:#ffffffdb;--surface-strong:#fff;--surface-soft:#eff6ff;--text-strong:#0f172a;--text-soft:#475569;--line:#d8e2ee;--primary:#2563eb;--primary-hover:#1d4ed8;--primary-soft:#2563eb1a;--primary-ink:#dbeafe;--success:#10b981;--success-soft:#10b9811f;--danger:#ef4444;--bg-accent:#3b82f614;--shadow:0 24px 60px #0f172a17}body{color:var(--text-strong);background:radial-gradient(circle at top,#2563eb1f,#0000 32%),linear-gradient(#f8fbff 0%,#f4f7fb 100%);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.auth-wrap{background:0 0;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border:1px solid var(--line);width:100%;max-width:380px;box-shadow:var(--shadow);background:linear-gradient(#fffffff2,#ffffffe0);border-radius:14px;flex-direction:column;gap:12px;padding:36px 32px;display:flex}.auth-logo{text-align:center;font-size:36px}.auth-title{text-align:center;font-size:20px;font-weight:700}.auth-sub{color:var(--text-soft);text-align:center;margin-bottom:4px;font-size:13px}.auth-error{color:var(--danger);background:#fef2f2;border-radius:6px;padding:8px 10px;font-size:12px}.auth-toggle{color:var(--text-soft);text-align:center;font-size:12px}.auth-toggle span{color:var(--primary);cursor:pointer;font-weight:700;text-decoration:underline}.loading{height:300px;color:var(--text-soft);justify-content:center;align-items:center;font-size:14px;display:flex}.input{border:1px solid var(--line);width:100%;color:var(--text-strong);background:#ffffffe6;border-radius:8px;outline:none;padding:9px 12px;font-size:13px}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.btn-primary{background:linear-gradient(135deg, var(--primary), #3b82f6);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:8px 16px;font-size:13px;box-shadow:0 10px 24px #2563eb38}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-hover), var(--primary))}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary.full{width:100%;padding:10px;font-size:14px}.btn-ghost{border:1px solid var(--line);color:var(--text-soft);cursor:pointer;white-space:nowrap;background:#ffffffb3;border-radius:8px;padding:8px 14px;font-size:13px}.btn-ghost:hover{background:var(--surface-soft);color:var(--text-strong)}.app{max-width:1100px;margin:0 auto;padding:28px 20px 40px}.header{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;display:flex}.header-title{color:var(--text-strong);font-size:18px;font-weight:700}.user-email{color:var(--text-soft);font-size:12px}.add-row{gap:8px;margin-bottom:16px;display:flex}.empty{height:300px;color:var(--text-soft);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.empty span{font-size:40px}.board{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));align-items:start;gap:14px;display:grid}.card{box-shadow:var(--shadow);border-radius:12px;flex-direction:column;gap:10px;padding:14px 14px 12px;display:flex}.card-header{align-items:flex-start;gap:7px;display:flex}.dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-top:4px;display:inline-block}.card-title-wrap{flex:1;min-width:0}.card-title{word-break:break-word;cursor:text;font-size:13px;font-weight:700;line-height:1.4;display:block}.card-count{margin-top:2px;font-size:11px;display:block}.title-input{background:0 0;border:none;border-bottom:1px solid;outline:none;width:100%;padding:0 0 2px;font-size:13px;font-weight:700}.del-btn{cursor:pointer;color:#bbb;background:0 0;border:none;flex-shrink:0;margin-top:-2px;padding:0;font-size:18px;line-height:1}.del-btn:hover{color:var(--danger)}.progress-track{background:#0f172a14;border-radius:999px;height:3px;overflow:hidden}.progress-bar{border-radius:999px;height:100%;transition:width .3s}.task-list{flex-direction:column;gap:4px;display:flex}.task-item{border-radius:6px;align-items:center;gap:7px;padding:4px 2px;display:flex}.task-check{cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:15px;height:15px;display:flex}.check-mark{color:#fff;font-size:9px;line-height:1}.task-title{word-break:break-word;flex:1;font-size:12px;line-height:1.4}.task-del{cursor:pointer;color:#0f172a57;background:0 0;border:none;flex-shrink:0;padding:0;font-size:14px;line-height:1}.task-del:hover{color:var(--danger)}.add-task-row{gap:6px;margin-top:2px;display:flex}.task-input{color:var(--text-strong);background:#fffc;border-radius:8px;outline:none;flex:1;padding:5px 8px;font-size:12px}.add-task-btn{color:#fff;cursor:pointer;border:none;border-radius:8px;padding:5px 10px;font-size:16px;line-height:1}.add-task-btn:hover{filter:brightness(1.03)}.res-toggle{cursor:pointer;text-align:left;background:0 0;border:none;border-top:.5px solid;align-items:center;gap:6px;width:100%;padding:8px 2px 0;font-size:12px;font-weight:500;display:flex}.res-toggle:hover{opacity:.75}.res-count{color:var(--primary);background:#2563eb1a;border-radius:999px;padding:1px 6px;font-size:11px}.res-panel{flex-direction:column;gap:8px;margin-top:4px;display:flex}.res-list{flex-direction:column;gap:4px;display:flex}.res-item{align-items:center;gap:6px;padding:3px 0;font-size:12px;display:flex}.res-icon{flex-shrink:0;font-size:13px}.res-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.res-label a{color:#185fa5;text-decoration:none}.res-label a:hover{text-decoration:underline}.res-tabs{border-bottom:1px solid #e5e5e3;gap:0;display:flex}.res-tab{cursor:pointer;color:#888;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:5px 4px;font-size:11px}.res-tab.active{color:var(--primary);font-weight:700}.res-tab:hover{color:var(--text-strong)}.res-form{flex-direction:column;gap:4px;display:flex}.file-label{color:var(--text-soft);cursor:pointer;text-align:center;border:1px dashed;border-radius:8px;justify-content:center;align-items:center;padding:14px;font-size:12px;display:flex}.file-label:hover{background:#2563eb0f}
