.app-footer{text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;display:flex}.app-footer-tagline{color:var(--muted);font-size:.88rem}.app-footer-github{width:40px;height:32px;color:var(--text);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff29;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0;text-decoration:none;transition:all .2s;display:inline-flex}.app-footer-github:hover{background:#3b82f638;border-color:#3b82f652;transform:translateY(-1px)}.app-footer-github-icon{display:block}.app-footer-github:focus-visible{outline:2px solid var(--primary);outline-offset:2px}html.light .app-footer-github{color:#0f172a;background:#ffffffb8;border:1px solid #0f172a1a}html.light .app-footer-github:hover{background:#fffffff2;border-color:#2563eb47}.app-footer--landing{flex-shrink:0;width:100%;max-width:1120px;margin:0 auto;padding:20px 20px 28px}.app-footer--courses{border-top:1px solid var(--border);margin-top:28px;padding-top:22px}.app-footer--auth{width:100%;padding:28px 20px 12px}.auth-page *{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.auth-page{background:var(--bg);min-height:100vh;color:var(--text);flex-direction:column;justify-content:flex-start;align-items:center;padding:24px 20px 20px;display:flex}.auth-page .container{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-sizing:border-box;border-radius:22px;width:100%;max-width:428px;padding:36px 32px 40px;overflow:visible}.auth-page h2{text-align:center;color:var(--text);letter-spacing:.2px;margin-bottom:26px;font-weight:950}.auth-page .form-group{margin-bottom:16px}.auth-page label{color:#e5e7ebbf;margin-bottom:6px;font-size:.9rem;font-weight:700;display:block}.auth-page input,.auth-page select{width:100%;color:var(--text);background:#ffffff0f;border:1px solid #ffffff29;border-radius:14px;outline:none;padding:12px;font-size:1rem;transition:all .2s}.auth-page input::placeholder{color:#e5e7eb73}.auth-page input:focus,.auth-page select:focus{border-color:#3b82f68c;box-shadow:0 0 0 4px #3b82f629}.auth-page button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:6px;padding:12px;font-size:1rem;font-weight:900;transition:all .2s;display:inline-flex}.auth-page button svg{flex-shrink:0}.auth-page button:hover{background:var(--primary-hover);transform:translateY(-1px)}.auth-page .toggle-text{text-align:center;color:#e5e7ebb3;margin-top:18px;font-size:.9rem}.auth-page .toggle-text span{color:#93c5fd;cursor:pointer;font-weight:900;text-decoration:underline}.auth-page .message{text-align:center;word-wrap:break-word;opacity:0;border-radius:14px;margin-bottom:14px;padding:10px;font-size:.9rem;transition:opacity .45s,transform .45s;transform:translateY(-6px)}.auth-page .message.show{opacity:1;transform:translateY(0)}.auth-page .error{color:#fecaca;background:#ef44442e;border:1px solid #ef444447}.auth-page .success{color:#bbf7d0;background:#22c55e29;border:1px solid #22c55e42}.auth-page .brand{grid-template-columns:1fr auto 1fr;align-items:center;column-gap:10px;width:100%;margin-bottom:24px;display:grid}.auth-page .brand-slot-start{grid-column:1;justify-self:start}.auth-page .brand-core{grid-column:2;align-items:center;gap:14px;min-width:0;display:flex}.auth-page .brand-slot-end{grid-column:3;min-width:0}.auth-page .logo{letter-spacing:.4px;color:#fff;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:14px;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.1rem;font-weight:900;display:flex;box-shadow:0 12px 28px #3b82f659}.auth-page .brand-title{letter-spacing:.3px;color:var(--text);white-space:nowrap;font-size:1.6rem;font-weight:900;line-height:1.1}.auth-page .google-login-wrap{flex-direction:column;align-items:stretch;gap:14px;width:100%;margin-top:18px;display:flex;overflow:visible}.auth-page .google-login-btn-host{box-sizing:border-box;background:0 0;justify-content:center;align-items:center;width:100%;max-width:100%;padding-left:10px;padding-right:10px;display:flex;overflow:visible}.auth-page .google-login-btn-host *{margin:revert;padding:revert;box-sizing:border-box}.auth-page .google-login-btn-host iframe{max-width:100%;display:block}.auth-page .divider{text-align:center;color:#e5e7eba6;align-items:center;gap:10px;width:100%;font-size:.9rem;display:flex}.auth-page .divider:before,.auth-page .divider:after{content:"";background:#ffffff24;flex:1;height:1px}.auth-page .divider span{white-space:nowrap}html.light .auth-page{color:#0f172a}html.light .auth-page .container{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe0;border:1px solid #0f172a14;box-shadow:0 18px 40px #0f172a1a}html.light .auth-page .brand-title,html.light .auth-page h2,html.light .auth-page label{color:#0f172a}html.light .auth-page .toggle-text{color:#64748b}html.light .auth-page .toggle-text span{color:#3b82f6}html.light .auth-page input,html.light .auth-page select{color:#0f172a;background:#f8fafcf2;border:1px solid #0f172a1f}html.light .auth-page input::placeholder{color:#94a3b8}html.light .auth-page input:focus,html.light .auth-page select:focus{border-color:#2563eb59;box-shadow:0 0 0 4px #2563eb1a}html.light .auth-page .divider{color:#64748b}html.light .auth-page .divider:before,html.light .auth-page .divider:after{background:#0f172a1a}html.light .auth-page .message{color:#0f172a;background:#ffffffd1;border:1px solid #0f172a1a}html.light .auth-page .error{color:#b91c1c;background:#ef44441a;border-color:#ef444438}html.light .auth-page .success{color:#15803d;background:#22c55e1a;border-color:#22c55e38}.auth-page-body{flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;display:flex}.auth-home-btn{width:40px;height:40px;color:var(--text);background:#ffffff1a;border:1px solid #ffffff2e;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;padding:0;text-decoration:none;transition:all .2s;display:inline-flex;box-shadow:0 4px 16px #0000001a}.auth-home-btn--compact{border-radius:11px;width:38px;height:38px}.auth-home-btn:hover{background:#3b82f638;border-color:#3b82f673;transform:translateY(-1px)}.auth-home-btn svg{opacity:.92;flex-shrink:0}html.light .auth-home-btn{color:#0f172a;background:#ffffffe0;border:1px solid #0f172a1a;box-shadow:0 4px 14px #0f172a0f}html.light .auth-home-btn:hover{background:#fff;border-color:#2563eb59}.theme-toggle-btn{cursor:pointer;height:46px;color:var(--text);background:#ffffff1a;border:1px solid #ffffff2e;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:auto;padding:10px 14px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.92rem;font-weight:900;transition:all .2s;display:inline-flex}.theme-toggle-btn svg{flex-shrink:0}.theme-toggle-btn:hover{background:#ffffff29;transform:translateY(-1px)}html.light .theme-toggle-btn{color:#0f172a;background:#ffffffb8;border:1px solid #0f172a1a}html.light .theme-toggle-btn:hover{background:#fffffff2}@keyframes land-enter-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes land-enter-down{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}.land-page{background:var(--bg);min-height:100vh;color:var(--text);box-sizing:border-box;flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;display:flex}@media (prefers-reduced-motion:no-preference){.land-brand{animation:.55s cubic-bezier(.22,1,.36,1) both land-enter-down}.land-nav-actions{animation:.55s cubic-bezier(.22,1,.36,1) 80ms both land-enter-down}.land-hero>h1{animation:.65s cubic-bezier(.22,1,.36,1) .1s both land-enter-up}.land-hero>.land-hero-lead{animation:.65s cubic-bezier(.22,1,.36,1) .2s both land-enter-up}.land-hero>.land-hero-actions{animation:.65s cubic-bezier(.22,1,.36,1) .3s both land-enter-up}.land-features .land-feature:first-child{animation:.6s cubic-bezier(.22,1,.36,1) .38s both land-enter-up}.land-features .land-feature:nth-child(2){animation:.6s cubic-bezier(.22,1,.36,1) .48s both land-enter-up}.land-features .land-feature:nth-child(3){animation:.6s cubic-bezier(.22,1,.36,1) .58s both land-enter-up}.app-footer--landing{animation:.55s cubic-bezier(.22,1,.36,1) .65s both land-enter-up}}@media (prefers-reduced-motion:reduce){.land-brand,.land-nav-actions,.land-hero>h1,.land-hero>.land-hero-lead,.land-hero>.land-hero-actions,.land-features .land-feature,.app-footer--landing{animation:none}}.land-page *,.land-page :before,.land-page :after{box-sizing:border-box}.land-nav{flex-shrink:0;justify-content:center;width:100%;padding:20px 20px 0;display:flex}.land-nav-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;width:100%;max-width:1120px;margin:0 auto;display:flex}.land-brand{color:inherit;align-items:center;gap:12px;text-decoration:none;display:flex}.land-brand:hover{opacity:.92}.land-logo{color:#fff;background:linear-gradient(135deg, var(--primary), #60a5fa);letter-spacing:.2px;border-radius:14px;justify-content:center;align-items:center;width:46px;height:46px;font-weight:900;display:flex;box-shadow:0 12px 28px #3b82f659}.land-brand-text{flex-direction:column;gap:2px;display:flex}.land-brand-title{letter-spacing:.2px;color:var(--text);font-size:1.25rem;font-weight:950}.land-brand-tag{color:var(--muted);font-size:.85rem;font-weight:700}.land-nav-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.land-btn{cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;height:46px;padding:0 18px;font-family:inherit;font-size:.95rem;font-weight:900;text-decoration:none;transition:all .2s;display:inline-flex}.land-btn svg{flex-shrink:0}.land-btn-primary{background:var(--primary);color:#fff;border:1px solid #0000}.land-btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.land-btn-ghost{color:var(--text);background:#ffffff14;border:1px solid #ffffff29}.land-btn-ghost:hover{background:#ffffff24;transform:translateY(-1px)}.land-body{flex-direction:column;flex:1;justify-content:center;width:100%;min-height:0;display:flex}.land-main{box-sizing:border-box;width:100%;max-width:1120px;margin:0 auto;padding:40px 20px 48px}.land-hero{text-align:center;max-width:720px;margin:0 auto 48px;padding:0 8px}.land-hero h1{letter-spacing:-.02em;color:var(--text);margin:0 0 16px;font-size:clamp(2rem,4.5vw,2.75rem);font-weight:950;line-height:1.15}.land-hero-lead{color:var(--muted);margin:0 0 28px;font-size:1.1rem;line-height:1.55}.land-hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.land-features{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:16px;width:100%;max-width:1120px;margin:0 auto;display:grid}.land-feature{background:var(--card-strong);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);text-align:center;border-radius:22px;flex-direction:column;align-items:center;padding:24px 20px;display:flex}.land-feature-icon{color:#dbeafe;background:#3b82f62e;border:1px solid #3b82f647;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;margin:0 auto 14px;display:flex}.land-feature h2{color:var(--text);width:100%;margin:0 0 8px;font-size:1.05rem;font-weight:950}.land-feature p{color:var(--muted);max-width:280px;margin:0 auto;font-size:.95rem;line-height:1.45}html.light .land-btn-ghost{color:#0f172a;background:#ffffffb8;border:1px solid #0f172a1a}html.light .land-btn-ghost:hover{background:#fffffff2}html.light .land-feature{background:#ffffffb8;border:1px solid #0f172a14;box-shadow:0 12px 30px #0f172a14}html.light .land-feature-icon{color:#1d4ed8;background:#2563eb1a;border:1px solid #2563eb2e}@media (width<=900px){.land-features{grid-template-columns:1fr}.land-feature p{max-width:36rem}}@media (width<=640px){.land-nav-inner{flex-direction:column;justify-content:center;align-items:center}.land-brand{justify-content:center}.land-nav-actions{justify-content:center;width:100%}}html,body,#root{min-height:100%}body{margin:0}html.light{--primary:#2563eb;--primary-hover:#1d4ed8;--bg:radial-gradient(1200px 700px at 20% 0%, #2563eb14, transparent 55%), radial-gradient(900px 600px at 80% 10%, #38bdf80f, transparent 60%), #eef3f9;--card:#ffffffd1;--card-strong:#ffffffeb;--border:#0f172a1a;--text:#0f172a;--muted:#475569;--shadow:0 14px 35px #0f172a14}:root{--primary:#3b82f6;--primary-hover:#2563eb;--bg:radial-gradient(1200px 700px at 20% 0%, #3b82f624, transparent 55%), radial-gradient(900px 600px at 80% 10%, #0ea5e91a, transparent 60%), #0b1220;--card:#ffffff14;--card-strong:#ffffff1f;--border:#ffffff24;--text:#e5e7eb;--muted:#b6c2d1;--shadow:0 22px 55px #00000059}*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background:var(--bg);min-height:100vh;color:var(--text)}.shell{max-width:1200px;margin:26px auto;padding:0 16px 40px}.header{background:var(--card);border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:22px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:16px;display:flex;box-shadow:0 14px 35px #00000038}.header-top{flex:0 auto;justify-content:space-between;align-items:center;gap:10px;min-width:0;max-width:100%;display:flex}.header-quick{flex-shrink:0;align-items:center;gap:8px;display:flex}.brand{align-items:center;gap:12px;display:flex}button.brand{height:auto;min-height:0;font:inherit;color:inherit;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:16px;margin:0;padding:0;transition:opacity .2s}button.brand:hover{opacity:.88;background:0 0;transform:none}button.brand:focus-visible{outline-offset:3px;outline:2px solid #3b82f68c}.logo{color:#fff;background:linear-gradient(135deg, var(--primary), #60a5fa);border-radius:14px;justify-content:center;align-items:center;width:46px;height:46px;font-weight:900;display:flex;box-shadow:0 16px 34px #3b82f633}.brand-title{letter-spacing:.2px;color:#fff;font-weight:950}.brand-sub{color:#e5e7ebb8;margin-top:2px;font-size:.9rem}.header-actions{flex-wrap:wrap;flex:auto;justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}button{cursor:pointer;height:46px;color:var(--text);background:#ffffff1a;border:1px solid #ffffff2e;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:10px 14px;font-weight:900;transition:all .2s;display:flex}button svg{flex-shrink:0}button:hover{background:#ffffff29;transform:translateY(-1px)}.ghost{background:#ffffff14;border:1px solid #ffffff29}.ghost:hover{background:#ffffff24}.danger{background:#ef44442e;border:1px solid #ef444447}.danger:hover{background:#ef44443d}.icon-btn{background:#ffffff14;border:1px solid #ffffff29;justify-content:flex-start;align-items:center;gap:10px;display:flex}.icon-btn:hover{background:#ffffff24}.plus{color:#fff;background:#3b82f62e;border:1px solid #3b82f647;border-radius:10px;justify-content:center;align-items:center;width:26px;height:26px;font-size:18px;line-height:1;display:flex}.btn-text{font-weight:950}.profile-pill{height:46px;color:var(--text);-webkit-user-select:none;user-select:none;background:#ffffff14;border:1px solid #ffffff29;border-radius:14px;align-items:center;gap:10px;padding:10px 14px;transition:all .2s;display:flex}.profile-pill:hover{background:#ffffff24;transform:translateY(-1px)}.profile-ava{color:#fff;background:#3b82f62e;border:1px solid #3b82f647;border-radius:10px;justify-content:center;align-items:center;width:26px;height:26px;font-weight:950;display:flex}.profile-email{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:240px;font-size:.92rem;font-weight:900;overflow:hidden}.view-toggle{box-sizing:border-box;background:#ffffff14;border:1px solid #ffffff29;border-radius:12px;align-items:center;gap:4px;height:40px;padding:4px;display:flex}.view-btn{width:40px;min-width:40px;height:32px;color:var(--text);cursor:pointer;box-sizing:border-box;background:#ffffff0f;border:1px solid #ffffff29;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;gap:0;padding:0;font-weight:950;transition:all .2s;display:flex}.view-btn:hover{background:#ffffff1f;transform:translateY(-1px)}.view-btn.active{background:#3b82f638;border-color:#3b82f652}.header-quick .theme-toggle-btn.theme-toggle-btn--compact{justify-content:center;gap:0;width:40px;min-width:40px;height:40px;padding:0}.header-quick .theme-toggle-btn.theme-toggle-btn--compact .theme-toggle-btn-label{display:none}.header-quick .theme-toggle-btn.theme-toggle-btn--compact:hover{transform:translateY(-1px)}.header-quick button.danger.header-logout-btn{justify-content:center;gap:0;width:40px;min-width:40px;height:40px;padding:0}.header-quick button.danger.header-logout-btn:hover{transform:translateY(-1px)}.message{text-align:center;opacity:0;background:#0000002e;border:1px solid #ffffff24;border-radius:14px;margin:0 0 12px;padding:10px 12px;font-size:.95rem;transition:opacity .45s,transform .45s;transform:translateY(-6px)}.message.show{opacity:1;transform:translateY(0)}.error{color:#fecaca;background:#ef44442e;border-color:#ef444447}.success{color:#bbf7d0;background:#22c55e29;border-color:#22c55e42}.board.view-kanban{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.board.view-list,.board.view-grid{display:block}.column,.list-wrap,.grid-wrap{background:var(--card-strong);box-shadow:var(--shadow);border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:22px;padding:14px}.column{flex-direction:column;min-height:70vh;display:flex}.col-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.col-title{letter-spacing:.2px;color:var(--text);font-weight:950}.col-badge{color:#dbeafe;background:#3b82f629;border:1px solid #3b82f642;border-radius:999px;padding:6px 10px;font-size:.85rem;font-weight:950}.col-drop{flex-direction:column;flex:1;gap:10px;padding-bottom:6px;display:flex}.drop-hover{outline-offset:6px;border-radius:18px;outline:3px dashed #3b82f659}.card-item{cursor:grab;color:var(--text);background:#ffffff1a;border:1px solid #ffffff29;border-radius:18px;padding:12px;transition:all .2s}.card-item:active{cursor:grabbing}.card-item:hover{border-color:#3b82f659;transform:translateY(-1px);box-shadow:0 16px 40px #00000040}.card-title{color:var(--text);margin-bottom:6px;font-weight:950}.card-desc{color:var(--muted);white-space:pre-wrap;font-size:.92rem;line-height:1.35}.card-meta{justify-content:space-between;align-items:center;gap:10px;margin-top:10px;display:flex}.pill{color:var(--text);background:#ffffff14;border:1px solid #ffffff1f;border-radius:999px;padding:6px 10px;font-size:.82rem;font-weight:950}.list-wrap{padding:14px}.list-row{cursor:pointer;background:#ffffff1a;border:1px solid #ffffff29;border-radius:18px;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;padding:12px;transition:all .2s;display:flex}.list-row:hover{border-color:#3b82f659;transform:translateY(-1px);box-shadow:0 16px 40px #00000040}.list-left{flex:1}.list-title{color:var(--text);margin-bottom:6px;font-weight:950}.list-desc{color:var(--muted);white-space:pre-wrap;font-size:.92rem;line-height:1.35}.list-right{flex-direction:column;align-items:flex-end;gap:8px;min-width:160px;display:flex}.grid-wrap{padding:14px}.grid-cards{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.grid-card{cursor:pointer}.modal-backdrop{background:#00000073;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.modal{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);width:520px;max-width:100%;color:var(--text);background:#0f172aeb;border:1px solid #ffffff24;border-radius:22px;overflow:hidden;box-shadow:0 18px 55px #0000008c}.modal-head{border-bottom:1px solid #ffffff1f;justify-content:space-between;align-items:center;padding:14px;display:flex}.modal-title{color:var(--text);font-weight:950}.x-btn{width:40px;height:40px;color:var(--text);cursor:pointer;background:#ffffff14;border:1px solid #ffffff1f;border-radius:14px;justify-content:center;align-items:center;display:flex}.x-btn:hover{background:#ffffff1f;transform:translateY(-1px)}.modal-body{padding:14px 14px 16px}.form-group{margin-bottom:12px}label{color:#e5e7ebbf;margin-bottom:6px;font-size:.9rem;display:block}input,textarea{width:100%;color:var(--text);background:#ffffff0f;border:1px solid #ffffff24;border-radius:14px;outline:none;padding:12px;font-size:1rem;transition:all .2s}textarea{resize:vertical;min-height:120px}input:focus,textarea:focus{border-color:#3b82f68c;box-shadow:0 0 0 4px #3b82f629}.modal-actions{justify-content:flex-end;gap:10px;margin-top:10px;display:flex}html.light body{color:var(--text)}html.light .header,html.light .column,html.light .list-wrap,html.light .grid-wrap{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffb8;border:1px solid #0f172a14;box-shadow:0 12px 30px #0f172a14}html.light .brand-title,html.light .col-title,html.light .list-title,html.light .card-title,html.light .modal-title,html.light .profile-email{color:#0f172a}html.light .brand-sub,html.light .list-desc,html.light .card-desc,html.light label{color:#475569}html.light .profile-pill,html.light .view-toggle,html.light .ghost,html.light .icon-btn,html.light .view-btn{color:#0f172a;background:#ffffffb8;border:1px solid #0f172a1a}html.light .profile-pill:hover,html.light .ghost:hover,html.light .icon-btn:hover,html.light .view-btn:hover{background:#fffffff2}html.light .view-btn.active{color:#1d4ed8;background:#2563eb1f;border-color:#2563eb47}html.light .col-badge,html.light .pill,html.light .profile-ava,html.light .plus{color:#1d4ed8;background:#2563eb1a;border:1px solid #2563eb2e}html.light .card-item,html.light .list-row{color:#0f172a;background:#ffffffc7;border:1px solid #0f172a14}html.light .card-item:hover,html.light .list-row:hover{border-color:#2563eb33;box-shadow:0 12px 28px #0f172a14}html.light .message{color:#0f172a;background:#ffffffd1;border:1px solid #0f172a1a}html.light .error{color:#b91c1c;background:#ef44441a;border-color:#ef444438}html.light .success{color:#15803d;background:#22c55e1a;border-color:#22c55e38}html.light .danger{color:#991b1b;background:#ef444414;border:1px solid #ef444438}html.light .danger:hover{background:#ef444424}html.light .modal-backdrop{background:#0f172a2e}html.light .modal{color:#0f172a;background:#fffffff5;border:1px solid #0f172a14;box-shadow:0 20px 50px #0f172a29}html.light .modal-head{border-bottom:1px solid #0f172a14}html.light .x-btn{color:#0f172a;background:#ffffffd1;border:1px solid #0f172a1a}html.light .x-btn:hover{background:#fff}html.light input,html.light textarea,html.light select{color:#0f172a;background:#f8fafcf2;border:1px solid #0f172a1f}html.light input::placeholder,html.light textarea::placeholder{color:#94a3b8}html.light input:focus,html.light textarea:focus,html.light select:focus{border-color:#2563eb59;box-shadow:0 0 0 4px #2563eb1a}html.light .card-item b,html.light .list-row b{color:#1e3a8a}@media (width<=720px){.shell{margin:12px auto;padding:0 12px 28px}.header{flex-direction:column;align-items:stretch;gap:12px;padding:12px}.header-top{align-items:center;width:100%}button.brand{flex:0 auto;min-width:0;max-width:calc(100% - 96px)}.brand-text{min-width:0}.brand-title,.brand-sub{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.logo{border-radius:12px;width:42px;height:42px}.header-actions{grid-template-columns:1fr 1fr;align-items:stretch;gap:8px;width:100%;display:grid}.profile-pill{grid-area:1/1/auto/-1;min-width:0;max-width:100%;height:auto;min-height:46px;padding:8px 12px}.profile-email{min-width:0;max-width:100%}.view-toggle{flex-wrap:nowrap;grid-area:2/1/auto/-1;align-items:center;gap:4px;width:100%;height:auto;min-height:40px;padding:4px}.view-toggle .view-btn{flex:1 1 0;min-width:40px;height:auto;min-height:36px;max-height:36px}.icon-btn{grid-area:3/1/auto/-1;justify-content:center;width:100%}.modal-backdrop{align-items:flex-end;padding:12px}.modal{max-height:min(92vh,100%);overflow-y:auto}.list-right{min-width:0}}@media (width<=380px){.icon-btn .btn-text{display:none}.icon-btn{justify-content:center}}@media (width<=980px){.board.view-kanban,.grid-cards{grid-template-columns:1fr}.column{min-height:auto}}@media (width<=480px){.list-row{flex-direction:column;align-items:stretch}.list-right{flex-flow:wrap;align-items:flex-start}}
