.auth-container{padding:24px;max-width:400px;margin:80px auto;background-color:var(--panel);border-radius:8px;box-shadow:0 4px 12px #0000001a}.auth-container h1{font-size:28px;font-weight:700;margin-bottom:16px;color:var(--txt);text-align:center}.auth-container input{padding:14px;margin-bottom:12px;width:100%;border-radius:8px;border:1px solid var(--muted);background-color:var(--panel);color:var(--txt);font-size:16px}.auth-container input:focus{border-color:var(--brand);outline:none}.auth-container button{width:100%;padding:14px;border-radius:8px;background-color:var(--brand);color:#fff;border:none;cursor:pointer;font-size:16px;transition:background-color .3s ease}.auth-container button:hover{background-color:var(--brand-hover)}.auth-error{color:var(--err);margin-top:12px;font-size:14px;text-align:center}.container{max-width:1100px;margin:0 auto;padding:24px;background-color:#f5f7fa;min-height:100vh;font-family:Inter,sans-serif}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard-header h1{font-size:24px;font-weight:700;margin:0;color:#1e293b}.muted{color:#64748b;margin-top:4px;font-size:14px}.nav{display:flex;gap:12px;align-items:center}.nav a{color:#334155;text-decoration:none;font-weight:500}.nav a:hover{color:#007bff}.card{background-color:#2e3b45;padding:20px;border-radius:10px;color:#fff;box-shadow:0 4px 10px #0000001a;margin-bottom:20px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{font-size:18px;margin:0}.btn{background-color:#007bff;color:#fff;border:none;border-radius:6px;padding:8px 14px;font-size:14px;cursor:pointer;transition:background-color .25s ease}.btn:hover{background-color:#0056b3}.btn.primary{background-color:#4caf50}.btn.primary:hover{background-color:#3d8b40}.badge{display:inline-block;background-color:#1e40af;color:#fff;padding:4px 10px;border-radius:12px;font-size:12px}input,select{padding:8px 10px;border-radius:6px;border:1px solid #cbd5e1;outline:none;font-size:14px}input:focus,select:focus{border-color:#007bff}.course-form{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.course-form input{flex:1 1 250px}.course-list{display:flex;flex-direction:column;gap:12px}.course-item{background-color:#1f2937;padding:16px;border-radius:8px}.course-info{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px}.actions{display:flex;gap:8px;flex-wrap:wrap}.project-form{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.project-form input,.project-form select{flex:1 1 220px}.project-list{display:flex;flex-direction:column;gap:12px}.project-item{background-color:#1f2937;padding:16px;border-radius:8px}.project-info{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}.badges{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}a{color:#60a5fa;text-decoration:none}a:hover{text-decoration:underline}.error-card{border-left:5px solid #dc2626;background-color:#fef2f2;color:#991b1b;padding:16px}.error-badge{background:#b91c1c;color:#fff;margin-right:8px}@media (max-width: 768px){.course-form,.project-form{flex-direction:column}.actions{justify-content:flex-start}.nav{flex-direction:column;align-items:flex-end;gap:8px}.dashboard-header{flex-direction:column;align-items:flex-start;gap:8px}}.orgs-container{max-width:1000px;margin:0 auto;padding:24px;background-color:#f8fafc;min-height:100vh;font-family:Inter,sans-serif}.orgs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.orgs-header h1{font-size:24px;font-weight:700;color:#1e293b}.nav{display:flex;align-items:center;gap:12px}.nav a{color:#1e40af;text-decoration:none;font-weight:500}.nav a:hover{color:#2563eb}.card{background-color:#1f2937;color:#fff;padding:16px;border-radius:10px;box-shadow:0 4px 10px #0000001a}.error-card{border-left:5px solid #dc2626;background-color:#fee2e2;color:#7f1d1d;padding:12px 16px}.error-badge{background-color:#b91c1c;color:#fff;border-radius:8px;padding:4px 10px;font-size:12px;margin-right:8px}.org-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:16px}.org-card{display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;transition:transform .2s,background .2s}.org-card:hover{background-color:#334155;transform:translateY(-3px)}.org-top{display:flex;align-items:center;gap:12px}.org-avatar{width:48px;height:48px;border-radius:50%}.org-info h3{margin:0;font-size:16px;color:#fff}.muted{color:#cbd5e1;font-size:14px;margin-top:4px}.org-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:12px;border-top:1px solid #475569;padding-top:8px}.badge{background-color:#3b82f6;color:#fff;padding:4px 10px;border-radius:12px;font-size:12px}@media (max-width: 768px){.orgs-header{flex-direction:column;align-items:flex-start;gap:10px}.nav{flex-wrap:wrap}.org-grid{grid-template-columns:1fr}}.join-container{max-width:900px;margin:0 auto;padding:24px;background-color:#f5f7fa;min-height:100vh;font-family:Inter,sans-serif}.card{background-color:#1f2937;color:#fff;padding:20px;border-radius:10px;margin-bottom:20px;box-shadow:0 4px 8px #00000026}h2,h3{margin:0 0 12px;font-weight:600}.muted{color:#cbd5e1}.connected{margin-top:10px;color:#cbd5e1}.join-step{display:flex;flex-direction:column;gap:12px}input{padding:10px 12px;border-radius:6px;border:1px solid #cbd5e1;font-size:14px;outline:none;width:100%}input:focus{border-color:#3b82f6}.btn{padding:8px 14px;border-radius:6px;background-color:#3b82f6;border:none;color:#fff;cursor:pointer;transition:background .25s}.btn:hover{background-color:#2563eb}.btn.primary{background-color:#22c55e}.btn.primary:hover{background-color:#16a34a}.add-member-btn{margin-top:10px;background-color:#64748b}.add-member-btn:hover{background-color:#475569}.member-grid{display:flex;flex-direction:column;gap:8px}.member-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.member-row input{flex:1 1 240px}.badge{background-color:#0ea5e9;color:#fff;padding:4px 10px;border-radius:12px;font-size:12px;margin-left:8px}.error-card{border-left:5px solid #b91c1c;background-color:#fee2e2;color:#7f1d1d}.error-text{color:#fca5a5;margin-top:8px;font-size:14px}@media (max-width: 768px){.member-row{flex-direction:column;align-items:stretch}.btn{width:100%}}:root{--bg: #f4f7fa;--panel: #ffffff;--muted: #8a93a5;--txt: #2e3b45;--brand: #6ea8fe;--brand-hover: #4f89d1;--ok: #22c55e;--err: #ef4444}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:Roboto,sans-serif;background-color:var(--bg);color:var(--txt)}.container{padding:24px;max-width:1200px;margin:0 auto}button{padding:12px 20px;border-radius:8px;border:none;cursor:pointer;background-color:var(--brand);color:#fff;transition:background-color .3s ease}button:hover{background-color:var(--brand-hover)}.card{background-color:var(--panel);padding:16px;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px}.row{display:flex;gap:16px;align-items:center}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.ap-container{max-width:1100px;margin:32px auto;padding:0 20px}.ap-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.ap-header h1{font-size:32px;letter-spacing:.2px;color:#0f172a;margin:0}.ap-link{color:#2563eb;text-decoration:none;font-weight:500}.ap-link:hover{text-decoration:underline}.ap-section{display:flex;flex-direction:column;gap:12px;margin:28px 0}.ap-section-title{align-self:center;font-size:15px;text-transform:lowercase;letter-spacing:.8px;color:#64748b;margin:0}.ap-grid{display:grid;grid-template-columns:repeat(2,minmax(340px,1fr));gap:20px;justify-content:center}@media (max-width:900px){.ap-grid{grid-template-columns:minmax(320px,1fr)}}.ap-card{background:linear-gradient(180deg,#fff,#fbfbff);border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 8px 20px #0206170f,0 1px #0206170a;padding:14px 16px;display:flex;flex-direction:column;gap:12px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.ap-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #02061714;border-color:#dbe0f6}.ap-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ap-title{font-weight:700;color:#0f172a}.ap-muted{color:#6b7280;font-size:13px;margin-top:3px}.ap-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.ap-badge{--bg:#f3f4f6;--tx:#374151;background:var(--bg);color:var(--tx);border-radius:999px;padding:4px 10px;font-size:12px;border:1px solid rgba(0,0,0,.04)}.ap-badge.private{--bg:#eef2ff;--tx:#3730a3;border-color:#c7d2fe}.ap-badge.public{--bg:#ecfdf5;--tx:#065f46;border-color:#bbf7d0}.ap-badge-strong{background:#e0f2fe;border:1px solid #bae6fd;color:#075985;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.ap-groups{display:flex;flex-direction:column;gap:10px}.ap-group{border:1px dashed #e5e7eb;border-radius:12px;padding:10px 12px;background:#ffffff90}.ap-group-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.ap-group-title{font-weight:600;color:#0f172a;font-size:14px;margin:0}.ap-people{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}.ap-people li{display:flex;align-items:center;gap:6px}.ap-dot{width:7px;height:7px;background:#6366f1;border-radius:999px;flex:0 0 7px}.ap-person{color:#111827;font-weight:500}.ap-handle{color:#6b7280;font-size:12px}.ap-empty{color:#9ca3af;font-size:13px}.ap-chip{font-size:12px;font-weight:700;padding:3px 8px;border-radius:999px;border:1px solid transparent}.ap-chip.ok{background:#ecfeff;border-color:#a5f3fc;color:#0369a1}.ap-chip.full{background:#fff7ed;border-color:#fed7aa;color:#b45309}.ap-chip.empty{background:#f1f5f9;border-color:#e2e8f0;color:#64748b}.ap-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}.ap-meta{color:#475569;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ap-sep{color:#94a3b8}.ap-key{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;border-radius:10px;padding:6px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;cursor:pointer}.ap-key:hover{background:#f1f5f9}.ap-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:12px;border-radius:12px;margin-bottom:16px}.ap-loading{padding:24px;color:#334155}.cp-container{max-width:740px;margin:32px auto;padding:0 20px}.cp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.cp-link{color:#2563eb;text-decoration:none}.cp-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:14px}.cp-row{display:flex;flex-direction:column;gap:6px}.cp-row label{font-weight:600;color:#111827}.cp-row input{border:1px solid #d1d5db;border-radius:10px;padding:10px}.cp-inline{display:flex;gap:8px}.cp-status{font-size:13px;margin-top:4px}.cp-status.ok{color:#065f46}.cp-status.ko{color:#b91c1c}.cp-actions{display:flex;justify-content:flex-end}.btn{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:8px 12px;cursor:pointer}.btn.primary{background:#2563eb;border-color:#1d4ed8;color:#fff}.cp-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:12px;border-radius:12px;margin-bottom:12px}
