@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&display=swap";:root{--bg-1:#0a1432;--bg-2:#0a1738;--bg-3:#102247;--panel:#1a2a45;--panel-2:#1f314e;--input:#13213f;--border:#6c89b43d;--text:#e8eefc;--muted:#9fb2d3;--primary:#6a6cf8;--primary-2:#5860ec;--green:#0f766e;--green-2:#0f8e84;--danger:#ff6f7a;--radius-lg:16px;--radius-md:12px;--shadow:0 14px 30px #040a1c73}*{box-sizing:border-box}html,body,#root{width:100%;overflow-x:hidden}body{min-height:100vh;color:var(--text);background:radial-gradient(circle at 0% 0%, #2b56a838, transparent 35%), radial-gradient(circle at 100% 20%, #2d559b2e, transparent 30%), linear-gradient(135deg, var(--bg-1) 0%, var(--bg-2) 52%, var(--bg-3) 100%);margin:0;font-family:Outfit,Segoe UI,sans-serif}.container{width:min(1040px,100%);max-width:1040px;margin:26px auto;padding:10px 12px 28px}.nav{z-index:40;border-radius:var(--radius-lg);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow);background:linear-gradient(135deg,#1b2b48c7,#101e39bd);justify-content:space-between;align-items:center;margin-bottom:12px;padding:12px 14px;display:flex;position:relative}.brand-title{letter-spacing:.2px;background:linear-gradient(90deg,#7f83ff 0%,#44f0b9 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(34px,4vw,40px);font-weight:800;line-height:1}.nav-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.links{z-index:10;border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#1b2b48b8,#101e39b3);border-radius:13px;flex-wrap:wrap;gap:14px;margin-bottom:16px;padding:8px;display:flex;position:relative}.api-banner{flex-wrap:wrap;align-items:center;gap:10px;margin:8px 0 14px;display:flex}.api-loading{color:#9bb8ff;font-weight:600}.api-error{color:#ff7d88;font-weight:600}.links a{color:var(--muted);border-radius:8px;padding:9px 18px;font-weight:600;text-decoration:none;transition:background .2s,color .2s}.links a:hover{color:#fff;background:#6a6cf82e}.links a.active{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;box-shadow:0 8px 16px #5a60ec5c}.card{border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#1d2f4ecc,#182b49b8);margin-bottom:16px;padding:18px;transition:transform .2s,box-shadow .2s}.card:hover{transform:translateY(-2px)scale(1.004);box-shadow:0 18px 30px #02081757}.admin-hero{background:linear-gradient(135deg,#1e304ed6,#1a2d4ab8)}input,textarea,select{box-sizing:border-box;width:100%;color:var(--text);background:#14213ddb;border:1px solid #6785b257;border-radius:10px;margin:8px 0;padding:10px;font-family:inherit;font-size:16px}input::placeholder,textarea::placeholder{color:#94a3b8}button{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 14px;font-family:inherit;font-weight:700;transition:transform .15s,filter .15s,box-shadow .15s}button:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 14px #5c64ec59}button:disabled{opacity:.55;cursor:not-allowed}button.secondary{background:#283a5ae6}button.btn-green{background:linear-gradient(135deg, var(--green), var(--green-2))}button.btn-green:hover:not(:disabled){box-shadow:0 8px 14px #108e845c}.row{align-items:center;gap:8px;display:flex}.card-head-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.error{color:#ff8b94;font-weight:600}.success{color:#4ae8b7;font-weight:600}.hint,.muted{color:var(--muted)}.grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.grid-4{flex-wrap:wrap;grid-template-columns:1fr 1fr 1fr 1fr;justify-content:flex-end;gap:10px;display:grid}.dashboard-grid{grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;display:grid}.dashboard-container{box-shadow:none;color:var(--text);background:0 0;border:0;border-radius:18px;padding:0}.dashboard-panel{border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:var(--shadow);background:linear-gradient(135deg,#1e304ed6,#1a2d4ab8);padding:20px}.dashboard-header h1{color:#f8fbff;margin:0 0 6px;font-size:52px;line-height:1.05}.dashboard-header p{color:var(--muted);margin:0 0 14px;font-size:22px}.dashboard-card{background:linear-gradient(140deg,#273858cc,#1e2f4cbd);border:1px solid #7892bb47;border-radius:14px;padding:14px;transition:transform .2s,box-shadow .2s;animation:.45s both dashboardFadeIn;box-shadow:0 10px 22px #02081740}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 14px 28px #02081759}.dashboard-card-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.dashboard-icon{font-size:26px}.dashboard-label{color:var(--muted);font-size:15px;font-weight:600}.dashboard-card h2{color:#f8fbff;margin:0;font-size:44px;line-height:1}.empty-state{background:#14213d8c;border:1px dashed #819dc959;border-radius:12px;justify-items:center;gap:8px;padding:18px 10px;display:grid}.empty-icon{font-size:24px;line-height:1}.skeleton{background:#94a3b82e;border-radius:8px;position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);animation:1.2s infinite skeletonShimmer;position:absolute;inset:0;transform:translate(-100%)}.skeleton-line{height:14px;margin:8px 0}.skeleton-line.short{width:42%}.skeleton-line.wide{width:70%;height:30px}.skeleton-circle{background:#94a3b840;border-radius:999px;width:18px;height:18px;position:relative;overflow:hidden}.skeleton-circle:after{content:"";background:linear-gradient(90deg,#0000,#ffffff40,#0000);animation:1.2s infinite skeletonShimmer;position:absolute;inset:0;transform:translate(-100%)}.metric-card{background:linear-gradient(140deg,#273858cc,#1e2f4cbd);border:1px solid #7892bb47;border-radius:12px;padding:14px}.metric-card h2{margin:6px 0 0}.tasks-list{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:grid}.task-item{background:linear-gradient(140deg,#233656bf,#1b2c49b3);border:1px solid #7892bb3d;border-radius:12px;padding:12px}.task-overdue{background:linear-gradient(140deg,#4a222db3,#2a18239e);border-color:#ff6f7a73}.task-item h3{margin-top:0}.member-line{justify-content:space-between;align-items:center;gap:8px;margin:6px 0;display:flex}.notif-wrap{z-index:60;position:relative}.notif-btn{position:relative}.notif-badge{color:#fff;background:#de3655;border-radius:999px;padding:3px 6px;font-size:11px;line-height:1;position:absolute;top:-6px;right:-6px}.notif-dropdown{border:1px solid var(--border);z-index:80;background:linear-gradient(140deg,#1e304ef5,#14233ef2);border-radius:10px;width:300px;max-height:360px;padding:10px;position:absolute;top:40px;right:0;overflow-y:auto;box-shadow:0 10px 24px #02081759}.notif-item{border:1px solid #94a3b833;border-radius:8px;flex-wrap:wrap;margin-bottom:8px;padding:8px}.notif-item p{margin:0 0 6px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #94a3b840;padding:8px}th{color:#d6e2fb;background:#21314dad;font-weight:700}.inline-input{align-items:center;gap:8px;display:flex}.inline-input input{margin:0}.form-field{flex-direction:column;gap:4px;display:flex}.form-field label{color:#cbd5e1;font-size:13px;font-weight:600}.action-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.action-row.right{justify-content:flex-end;margin-top:12px}.badge-row{flex-wrap:wrap;gap:6px;display:flex}.badge{border:1px solid #94a3b84d;border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.status-todo{color:#bfdbfe;background:#3b82f62e}.status-in_progress{color:#c7d2fe;background:#6366f133}.status-done{color:#a7f3d0;background:#10b9812e}.priority-high{color:#fecaca;background:#ef444433}.priority-medium{color:#fde68a;background:#f59e0b33}.priority-low{color:#bbf7d0;background:#22c55e33}.tag-list{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.tag-chip{color:#c7d2fe;background:#6366f12e;border:1px solid #818cf866;border-radius:999px;padding:4px 10px;font-size:12px}.modal-backdrop{z-index:120;background:#020817a6;place-items:center;padding:14px;display:grid;position:fixed;inset:0}.modal-card{background:linear-gradient(135deg,#1f314ff2,#152541ed);border:1px solid #7e98c14d;border-radius:14px;width:min(560px,100%);max-height:calc(100vh - 48px);padding:16px;overflow-y:auto;box-shadow:0 20px 36px #02081773}.icon-btn{border-radius:8px;place-items:center;width:32px;height:32px;padding:0;display:inline-grid}.profile-line{color:#e2e8f0;margin:8px 0}.user-chip{color:#e2eaff;background:#3d4d70b8;border:1px solid #818cf84d;border-radius:999px;padding:6px 12px;font-weight:600}.auth-shell{justify-content:center;align-items:center;min-height:calc(100vh - 48px);display:flex}.auth-card{width:100%;max-width:520px}h1,h2,h3,h4{letter-spacing:-.01em;margin-top:0}h1{font-size:42px}h2{font-size:30px}h3{font-size:24px}.card h1{font-size:56px;line-height:1.05}.card h2{font-size:44px;line-height:1.1}.card h3{font-size:34px}@keyframes dashboardFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes skeletonShimmer{to{transform:translate(100%)}}@media (width<=980px){.grid-2,.grid-4,.dashboard-grid{grid-template-columns:1fr}.row,.inline-input,.nav-actions,.member-line{flex-direction:column;align-items:stretch}.container{width:100%;margin:10px auto;padding:8px}.nav{padding:12px}.brand-title{margin-bottom:8px;font-size:28px}.user-chip{text-align:center;white-space:normal;width:100%;line-height:1.25}.links{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.links a{text-align:center;padding:10px 8px}.card{padding:14px}.card h1{word-break:break-word;font-size:26px;line-height:1.1}.card h2{font-size:24px}.card h3{font-size:20px}.card-head-row{flex-direction:column;align-items:stretch}.card-head-row>button{width:100%}.notif-wrap{position:static}.notif-dropdown{width:auto;max-height:50vh;position:fixed;top:86px;left:10px;right:10px}h1{font-size:38px}.dashboard-header h1{font-size:40px}.dashboard-header p{font-size:18px}}
