:root{--bg: #f5f6fa;--panel: #fff;--ink: #1a1a2e;--muted: #6b7280;--line: #e7e8ef;--shadow: 0 1px 3px rgba(20, 18, 40, .08), 0 6px 24px rgba(20, 18, 40, .06);--brand: #6d5efc;--brand-2: #8b7bff;--brand-ink: #fff;--brand-soft: #efecff;--sidebar: #16142a;--sidebar-ink: #c7c5da;--sidebar-active: #2a2745;--sidebar-hover: #211e3a;--sidebar-border: #2a2745}[data-role=SUPER_ADMIN]{--brand: #4f46e5;--brand-2: #7c3aed;--brand-ink: #fff;--brand-soft: #eceafe;--sidebar: #1b1733;--sidebar-ink: #c4bdf0;--sidebar-active: #2e2752;--sidebar-hover: #261f47;--sidebar-border: #2e2752}[data-role=ADMIN]{--brand: #0ea5e9;--brand-2: #6366f1;--brand-ink: #06283d;--brand-soft: #e6f6fe;--sidebar: #0f1b2d;--sidebar-ink: #aebdd0;--sidebar-active: #1c3047;--sidebar-hover: #16263a;--sidebar-border: #1c3047}[data-role=LEAD]{--brand: #f59e0b;--brand-2: #ef4444;--brand-ink: #4a3000;--brand-soft: #fef3c7;--sidebar: #251c08;--sidebar-ink: #d8c9a8;--sidebar-active: #3a2c10;--sidebar-hover: #2f2410;--sidebar-border: #3a2c10}[data-role=STUDENT]{--brand: #6d5efc;--brand-2: #8b7bff;--brand-ink: #fff;--brand-soft: #efecff;--sidebar: #16142a;--sidebar-ink: #c7c5da;--sidebar-active: #2a2745;--sidebar-hover: #211e3a;--sidebar-border: #2a2745}[data-role=RECRUITER]{--brand: #10b981;--brand-2: #059669;--brand-ink: #03281c;--brand-soft: #e6faf2;--sidebar: #0c241b;--sidebar-ink: #a7d3c2;--sidebar-active: #103a2c;--sidebar-hover: #0f3324;--sidebar-border: #103a2c}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45}a{color:var(--brand)}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);color:var(--sidebar-ink);padding:18px 14px;display:flex;flex-direction:column;gap:6px}.logo{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:16px;padding:6px 8px 4px}.logo .mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:grid;place-items:center;font-size:16px}.rolechip{font-size:10px;letter-spacing:.1em;text-transform:uppercase;background:var(--brand);color:var(--brand-ink);font-weight:800;border-radius:5px;padding:3px 8px;margin:6px 8px 12px;display:inline-block;width:fit-content}.navgroup{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#7a7a90;margin:12px 8px 4px}.nav{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;color:var(--sidebar-ink);font-weight:500;text-decoration:none}.nav:hover{background:var(--sidebar-hover)}.nav.active{background:var(--sidebar-active);color:#fff}.nav .ic{width:18px;text-align:center}.nav .badge{margin-left:auto;background:var(--brand);color:var(--brand-ink);border-radius:20px;font-size:11px;padding:1px 7px;font-weight:700}.spacer{flex:1}.me{display:flex;align-items:center;gap:10px;padding:8px;border-top:1px solid var(--sidebar-border);margin-top:8px}.me .logout{margin-left:auto;background:transparent;border:1px solid var(--sidebar-border);color:var(--sidebar-ink);border-radius:7px;padding:4px 8px;font-size:11px;cursor:pointer}.me .logout:hover{background:var(--sidebar-hover)}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:60px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 24px}.topbar h1{font-size:16px;margin:0}.crumb{color:var(--muted);font-size:12px}.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--brand-soft);color:var(--brand)}.top-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.content{padding:24px;overflow:auto}.avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700;flex:none;background:var(--brand)}h2.section{font-size:18px;margin:0 0 4px}.sub{color:var(--muted);margin:0 0 18px}.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}.pad{padding:18px}.btn{border:0;background:var(--brand);color:var(--brand-ink);font-weight:700;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line);font-weight:600}.btn.sm{padding:5px 10px;font-size:12px}.btn.danger{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}.chip{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px;display:inline-block}.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.stat-card .n{font-size:26px;font-weight:800}.stat-card .l{color:var(--muted);font-size:12px}.grid2{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}.field,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px;font:inherit;resize:vertical}.kv{margin-bottom:14px}.kv .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:5px}.note{font-size:12px;color:var(--muted);background:var(--brand-soft);border:1px solid var(--line);border-radius:8px;padding:8px 12px;margin-bottom:16px}.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:7px;background:#eef0f6}.quote{background:#f8fafc;border-left:3px solid var(--brand);padding:10px 12px;border-radius:0 8px 8px 0;margin:8px 0}.row{display:flex;gap:12px;flex-wrap:wrap}.chip.green{background:#dcfce7;color:#15803d}.chip.amber{background:#fef9c3;color:#854d0e}.chip.blue{background:#dbeafe;color:#1d4ed8}.chip.red{background:#fef2f2;color:#b91c1c}.chip.gray{background:#f3f4f9;color:#6b7280}.chip.violet{background:#efeaff;color:#6d28d9}.req{border-left:3px solid var(--brand);background:var(--brand-soft);padding:12px 14px;border-radius:0 10px 10px 0;margin-bottom:12px}.req .ref{font-weight:800;color:var(--brand);margin-right:6px}.tasklet{display:flex;align-items:center;gap:8px;font-size:13px;padding:5px 0;border-top:1px dashed var(--line)}.tasklet .id{color:var(--muted);font-weight:700;font-size:11px}.pts{margin-left:auto;background:#eef0f6;border-radius:6px;font-size:11px;font-weight:700;padding:1px 7px;color:#475569}.board{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}.board.wide{grid-template-columns:repeat(6,1fr)}.col{background:#eef0f6;border-radius:12px;padding:10px;min-height:120px}.col h3{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#5b6170;margin:2px 4px 10px}.tcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:9px}.tcard.clickable{cursor:pointer}.tcard.clickable:hover{border-color:var(--brand)}.tcard .ttl{font-weight:600;margin:5px 0;font-size:13px}.tcard .meta{display:flex;align-items:center;gap:8px}.tcard .id{color:var(--muted);font-size:11px;font-weight:700}.tcard select{margin-top:8px;font-size:12px;padding:5px 6px}.review{border-radius:10px;padding:12px;margin-top:8px}.review.changes{background:#fef2f2;border:1px solid #fecaca}.review.approved{background:#f0fdf4;border:1px solid #bbf7d0}.rate{display:inline-flex;gap:3px;cursor:pointer}.star{color:var(--brand);font-size:16px}.star.off{color:#d4d4d8}.hero{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;border-radius:16px;padding:22px 26px;margin-bottom:18px}.hero h2{margin:0;font-size:22px}.hero p{margin:4px 0 0;opacity:.9}.hublinks{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}.hubcard{display:block;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:var(--shadow);cursor:pointer;text-decoration:none;color:inherit;transition:.12s}.hubcard:hover{border-color:var(--brand);transform:translateY(-2px)}.hubcard .ic{font-size:30px}.hubcard h3{margin:10px 0 4px;font-size:16px}.hubcard p{margin:0;color:var(--muted);font-size:12.5px}.hubcard .ext{font-size:11px;color:var(--brand);font-weight:700;margin-top:8px;display:inline-block}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:14px 0 18px}.tab{background:transparent;border:0;border-bottom:2px solid transparent;padding:8px 14px;font:inherit;font-weight:600;color:var(--muted);cursor:pointer;margin-bottom:-1px}.tab:hover{color:var(--ink)}.tab.on{color:var(--brand);border-bottom-color:var(--brand)}.wiki-folder{margin-bottom:14px}.wiki-folder-head{display:flex;align-items:center;justify-content:space-between;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;padding:4px 6px 6px}.wiki{display:grid;grid-template-columns:230px 1fr;gap:18px;align-items:start}.tree{font-size:13px}.tree .pg{padding:6px 10px;border-radius:7px;cursor:pointer;color:#374151}.tree .pg:hover{background:#f3f4f9}.tree .pg.on{background:var(--brand-soft);color:var(--brand);font-weight:700}.tree .sub-pg{padding-left:22px}.prose h3{margin-top:0}.prose p{color:#374151;white-space:pre-wrap}.ver{font-size:12px;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:14px}.inbox-item{display:flex;gap:12px;padding:14px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;align-items:flex-start}.inbox-item.unseen{border-left:4px solid var(--brand);background:var(--brand-soft)}.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#16142a,#2a2745);padding:24px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:32px;width:100%;max-width:400px}.login-card .logo{color:var(--ink);padding:0 0 8px}.login-card h1{font-size:20px;margin:8px 0 2px}.login-hint{font-size:12px;color:var(--muted);background:#f5f6fa;border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-top:16px}.login-hint code{color:#6d28d9}.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:8px 12px;font-size:13px;margin:8px 0}.empty{color:var(--muted);padding:20px;text-align:center;font-size:13px}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.skill{display:inline-block;font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;background:var(--brand-soft);color:var(--brand);margin:2px 4px 2px 0}.rte{border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden;transition:box-shadow .12s,border-color .12s}.rte.focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.rte-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px;background:#f7f8fc;border-bottom:1px solid var(--line)}.rte-btn{border:1px solid transparent;background:transparent;border-radius:6px;min-width:30px;height:30px;padding:0 8px;font-size:13px;color:#374151;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1}.rte-btn:hover{background:#fff;border-color:var(--line);color:var(--ink)}.rte-btn:active{background:var(--brand-soft);border-color:var(--brand)}.rte-body{position:relative}.rte-placeholder{position:absolute;top:12px;left:14px;color:#9aa0ad;pointer-events:none;font-size:14px}.rte-editable{padding:12px 14px;outline:none;font-size:14px;line-height:1.6;color:var(--ink)}.rte-editable:focus{outline:none}.rte-view{font-size:14px;line-height:1.65;color:#374151;word-wrap:break-word}.rte-view.rte-empty{color:#9aa0ad;font-style:italic}.rte-view h1{font-size:24px;margin:18px 0 8px;line-height:1.25;color:var(--ink)}.rte-view h2{font-size:19px;margin:16px 0 6px;line-height:1.3;color:var(--ink)}.rte-view h3{font-size:16px;margin:14px 0 6px;color:var(--ink)}.rte-view h1:first-child,.rte-view h2:first-child,.rte-view h3:first-child,.rte-view p:first-child{margin-top:0}.rte-view p{margin:8px 0}.rte-view ul,.rte-view ol{margin:8px 0;padding-left:26px}.rte-view li{margin:3px 0}.rte-view a{color:var(--brand);text-decoration:underline}.rte-view blockquote{margin:12px 0;padding:8px 14px;border-left:3px solid var(--brand);background:#f8fafc;border-radius:0 8px 8px 0;color:#475569}.rte-view pre{background:#16142a;color:#e8e6ff;padding:12px 14px;border-radius:8px;overflow:auto;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;margin:12px 0}.rte-view code{background:#eef0f6;color:#6d28d9;padding:1px 5px;border-radius:5px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12.5px}.rte-view pre code{background:transparent;color:inherit;padding:0}.rte-editable h1{font-size:24px;margin:14px 0 6px}.rte-editable h2{font-size:19px;margin:12px 0 6px}.rte-editable h3{font-size:16px;margin:10px 0 6px}.rte-editable ul,.rte-editable ol{padding-left:26px;margin:6px 0}.rte-editable blockquote{margin:8px 0;padding:6px 12px;border-left:3px solid var(--brand);background:#f8fafc;color:#475569}.rte-editable pre{background:#16142a;color:#e8e6ff;padding:10px 12px;border-radius:8px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12.5px;white-space:pre-wrap}.rte-editable a{color:var(--brand)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#14122873;display:grid;place-items:start center;padding:40px 20px;z-index:50;overflow:auto}.modal{background:var(--panel);border-radius:16px;box-shadow:0 24px 70px #00000059;width:100%;max-width:640px;padding:20px 22px}.modal.ticket{max-width:920px}.ticket-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.ticket-crumb{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--muted)}.ticket-crumb .sep{color:#c7c9d4}.ticket-crumb .key{font-weight:800;color:var(--brand);letter-spacing:.02em}.ticket-crumb .trace{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-grid{display:grid;grid-template-columns:1fr 250px;gap:22px;align-items:start}.ticket-main{min-width:0}.ticket-title{font-size:22px;margin:0 0 16px;line-height:1.25}.ticket-section-label{display:flex;align-items:center;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;margin-bottom:8px}.ticket-side{background:#f7f8fc;border:1px solid var(--line);border-radius:12px;padding:14px}.meta-block{margin-bottom:14px}.meta-block:last-child{margin-bottom:0}.meta-k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;margin-bottom:5px}.meta-val{font-size:14px;font-weight:600}.meta-muted{color:var(--muted);font-size:13px}.meta-person{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}.comments{margin-top:4px}.comments-empty{color:var(--muted);font-size:13px;padding:8px 0 14px}.comment{display:flex;gap:10px;padding:10px 0;border-top:1px solid var(--line)}.comment-body{flex:1;min-width:0}.comment-head{display:flex;align-items:baseline;gap:8px;font-size:13px}.comment-when{font-size:11px;color:var(--muted)}.comment-text{font-size:13.5px;color:#374151;white-space:pre-wrap;margin-top:2px}.comment-add{display:flex;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.wiki-doc-crumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);margin-bottom:8px}.wiki-doc-crumb .sep{color:#c7c9d4}.wiki-doc-title{font-size:28px;margin:0 0 6px;line-height:1.2}@media (max-width: 720px){.ticket-grid{grid-template-columns:1fr}.modal.ticket{max-width:100%}}.searchbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;max-width:420px}.searchbar .field{flex:1}.nav.locked{opacity:.5;cursor:not-allowed}.nav.locked:hover{background:transparent}.nav.locked .badge{background:transparent;color:var(--sidebar-ink);font-size:12px;padding:0}.path-now{background:#ffffff29;border-radius:12px;padding:10px 14px;text-align:right}.path-now .k{font-size:11px;text-transform:uppercase;letter-spacing:.04em;opacity:.85}.path-now-stage{font-size:17px;font-weight:700;margin-top:2px}.path-prog{margin-top:16px}.path-prog-bar{height:8px;border-radius:99px;background:#ffffff40;overflow:hidden}.path-prog-bar>span{display:block;height:100%;border-radius:99px;background:#fff;transition:width .4s ease}.path{position:relative}.pstep{display:flex;gap:14px;align-items:stretch}.pstep-rail{position:relative;width:40px;display:flex;justify-content:center}.pstep-rail:before{content:"";position:absolute;top:0;bottom:0;width:2px;background:var(--line)}.pstep:first-child .pstep-rail:before{top:18px}.pstep:last-child .pstep-rail:before{bottom:calc(100% - 18px)}.pstep-dot{position:relative;z-index:1;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:16px;background:#fff;border:2px solid var(--line);margin-top:2px}.pstep.done .pstep-dot{background:#dcfce7;border-color:#86efac;color:#15803d}.pstep.current .pstep-dot{background:var(--brand);border-color:var(--brand);color:var(--brand-ink);box-shadow:0 0 0 4px var(--brand-soft)}.pstep-body{flex:1;padding:0 0 18px;min-width:0}.pstep-head{display:flex;align-items:center;gap:10px}.pstep-head h3{margin:0;font-size:16px}.pstep-body .sub{margin:2px 0 8px}.pstep.locked{opacity:.6}.labgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.labcard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column}.labcard.locked{opacity:.65}.labcard.current{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft),var(--shadow)}.labcard h3{margin:10px 0 4px;font-size:16px}.labcard .sub{margin:0 0 10px;flex:1}.labcard-top{display:flex;align-items:center;justify-content:space-between}.labnum{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;background:var(--brand-soft);color:var(--brand)}.labcard.done .labnum{background:#dcfce7;color:#15803d}.labcard.locked .labnum{background:#f3f4f9;color:#9ca3af}.labmeta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.labcard-foot{margin-top:auto}.locked-panel{text-align:center;max-width:480px;margin:40px auto;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:36px 28px;box-shadow:var(--shadow)}.locked-ic{font-size:40px}.locked-panel h2{margin:10px 0 6px}.locked-panel .sub{margin:0 0 18px}.minipath{display:inline-flex;gap:6px;align-items:center}.minidot{width:11px;height:11px;border-radius:50%;background:var(--line)}.minidot.done{background:#86efac}.minidot.current{background:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.fork{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px}.forkcard{display:block;text-decoration:none;color:inherit;border:1px solid var(--line);border-radius:14px;padding:18px;background:var(--bg);transition:border-color .15s,transform .15s,box-shadow .15s}.forkcard:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}.forkcard .forkic{font-size:28px}.forkcard h4{margin:8px 0 4px;font-size:16px}.forkcard .ext{display:inline-block;margin-top:8px;color:var(--brand);font-weight:700;font-size:13px}.journey{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.jstep{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow)}.jnum{position:absolute;top:12px;right:12px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;background:var(--brand-soft);color:var(--brand)}.jic{font-size:24px}.jstep h4{margin:8px 0 4px;font-size:15px}@media (max-width: 900px){.fork{grid-template-columns:1fr}.journey{grid-template-columns:1fr 1fr}}@media (max-width: 560px){.journey{grid-template-columns:1fr}}.pstep-link{flex:1;text-decoration:none;color:inherit;border-radius:12px;transition:background .15s}.pstep-link:hover{background:var(--brand-soft)}.pstep .ext{display:inline-block;margin-top:6px;color:var(--brand);font-weight:700;font-size:13px}.lvlprog{display:flex;align-items:center;gap:10px;margin:2px 0 4px;max-width:360px}.lvlprog-bar{flex:1;height:7px;border-radius:99px;background:var(--line);overflow:hidden}.lvlprog-bar>span{display:block;height:100%;border-radius:99px;background:var(--brand);transition:width .4s ease}.modulecard,.checkpoint{margin-bottom:14px}.checkpoint{border:1px dashed var(--line);background:var(--brand-soft)}.module-head{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}.module-head h3{margin:0;font-size:16px}.module-num{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand);background:var(--brand-soft);border-radius:6px;padding:2px 8px}.module-num.optional{color:#854d0e;background:#fef9c3}.itemlist{display:flex;flex-direction:column;gap:8px}.item{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--bg)}.item.done{background:#f0fdf4;border-color:#bbf7d0}.item-ic{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:#fff;border:1px solid var(--line);flex-shrink:0}.item.done .item-ic{background:#dcfce7;border-color:#86efac;color:#15803d}.item-body{flex:1;min-width:0}.item-title{font-weight:600;display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}.item-meta{font-size:12px;font-weight:500;color:var(--muted)}.item-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.item.locked{opacity:.72;background:#fafafe}.notes{margin-top:6px}.notes>summary{cursor:pointer;font-size:12px;font-weight:700;color:var(--brand);list-style:none}.notes>summary::-webkit-details-marker{display:none}.notes>summary:before{content:"📝 "}.notes-body{margin-top:6px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:8px;font-size:13px;color:var(--ink);white-space:pre-wrap}.lvlcard{flex:1;min-width:200px;text-decoration:none;color:inherit;transition:border-color .15s,transform .15s,box-shadow .15s}.lvlcard:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}.lvlcard-ic{font-size:28px}.itemform{border:1px solid var(--brand);border-radius:10px;padding:14px;background:var(--brand-soft);display:flex;flex-direction:column;gap:10px}.formrow{display:flex;flex-direction:column;gap:4px}.formrow2{display:grid;grid-template-columns:140px 1fr;gap:10px}.itemform label{font-size:12px;font-weight:700;color:var(--muted)}.itemform textarea.field{resize:vertical;font-family:inherit}@media (max-width: 560px){.formrow2{grid-template-columns:1fr}}
