@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=DM+Sans:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--navy: #0f1b35;--navy-light: #1a2d52;--navy-mid: #243b6e;--emerald: #10b981;--emerald-light: #34d399;--emerald-dark: #059669;--amber: #f59e0b;--sky: #0ea5e9;--coral: #f43f5e;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--font-head: "Sora", sans-serif;--font-body: "DM Sans", sans-serif;--radius: 12px;--radius-sm: 8px;--radius-lg: 18px;--shadow: 0 4px 24px rgba(15,27,53,.1);--shadow-lg: 0 8px 40px rgba(15,27,53,.16)}body{font-family:var(--font-body);background:var(--slate-100);color:var(--slate-800);min-height:100vh;-webkit-font-smoothing:antialiased}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}@media (max-width: 768px){.login-wrap{grid-template-columns:1fr}.login-hero{display:none}}.login-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 60%,#1a4a7a 100%);display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:4rem;position:relative;overflow:hidden}.hero-pattern{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.06;background-image:radial-gradient(circle at 25% 25%,white 1px,transparent 1px),radial-gradient(circle at 75% 75%,white 1px,transparent 1px);background-size:48px 48px}.hero-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.18}.orb1{width:320px;height:320px;background:var(--emerald);top:-60px;right:-60px}.orb2{width:200px;height:200px;background:var(--sky);bottom:80px;left:-40px}.logo-wrap{display:flex;align-items:center;gap:14px}.logo-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--emerald),var(--emerald-light));border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:22px;color:#fff;box-shadow:0 8px 24px #10b98166}.logo-icon.sm{width:36px;height:36px;font-size:14px;border-radius:8px;box-shadow:none}.logo-text span{display:block;font-family:var(--font-head);font-weight:700;color:#fff}.logo-text span.lg{font-size:22px;letter-spacing:-.5px}.logo-text span.sm{font-size:15px}.logo-text small{font-size:11px;font-weight:300;color:#ffffff8c;letter-spacing:1.5px;text-transform:uppercase}.hero-heading{font-family:var(--font-head);color:#fff;font-size:40px;font-weight:700;line-height:1.15;letter-spacing:-1px;margin:3rem 0 1.25rem;position:relative;z-index:1}.hero-heading em{color:var(--emerald-light);font-style:normal}.hero-sub{color:#ffffffa6;font-size:16px;line-height:1.7;max-width:380px;position:relative;z-index:1}.hero-badges{display:flex;gap:10px;margin-top:2.5rem;flex-wrap:wrap;position:relative;z-index:1}.hero-badge{background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:50px;padding:6px 14px;font-size:12px;color:#fffc}.login-form-side{background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem}.form-box{width:100%;max-width:400px}.form-title{font-family:var(--font-head);font-size:28px;font-weight:700;color:var(--navy);margin-bottom:6px}.form-subtitle{color:var(--slate-500);font-size:14px;margin-bottom:2rem}.field{margin-bottom:1rem}.field label{display:block;font-size:13px;font-weight:500;color:var(--slate-600);margin-bottom:6px}.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--slate-200);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;color:var(--slate-800);transition:border-color .2s,box-shadow .2s;outline:none;background:var(--slate-50)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--emerald);box-shadow:0 0 0 3px #10b9811f;background:#fff}.btn-primary{width:100%;padding:12px;background:linear-gradient(135deg,var(--emerald),var(--emerald-dark));color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:15px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 14px #10b98159;margin-top:.5rem}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #10b98173}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{width:100%;padding:11px;background:transparent;color:var(--slate-600);border:1.5px solid var(--slate-200);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-top:.5rem}.btn-ghost:hover{border-color:var(--emerald);color:var(--emerald-dark);background:#10b9810a}.divider{display:flex;align-items:center;gap:12px;margin:1rem 0;color:var(--slate-400);font-size:12px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--slate-200)}.form-link{background:none;border:none;color:var(--emerald-dark);font-size:13px;cursor:pointer;text-decoration:underline;padding:0;font-family:var(--font-body)}.form-links-row{display:flex;justify-content:space-between;margin-top:.75rem}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:1rem;border:1px solid}.alert-error{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.alert-warning{background:#fffbeb;border-color:#fcd34d;color:#92400e}.alert-success{background:#f0fdf4;border-color:#86efac;color:#15803d}.radio-group{display:flex;gap:12px}.radio-opt{flex:1;border:1.5px solid var(--slate-200);border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;transition:all .2s;-webkit-user-select:none;user-select:none}.radio-opt.active{border-color:var(--emerald);background:#10b9810f;color:var(--emerald-dark);font-weight:500}.radio-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--slate-300);flex-shrink:0;transition:all .2s}.radio-opt.active .radio-dot{border-color:var(--emerald);background:var(--emerald)}.dash-shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--navy);flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:1.5rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar-section{padding:.75rem 1rem}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#ffffff59;padding:0 .5rem;margin-bottom:.25rem}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;color:#ffffffa6;font-size:13.5px;font-weight:400;transition:all .15s;margin-bottom:2px}.sidebar-item:hover{background:#ffffff14;color:#fff}.sidebar-item.active{background:#10b9812e;color:var(--emerald-light);font-weight:500}.sidebar-item .icon{font-size:16px;width:20px;text-align:center}.sidebar-footer{margin-top:auto;padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.07)}.user-card{display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--emerald),var(--sky));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}.user-info .name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .role{font-size:11px;color:#ffffff73;text-transform:capitalize}.btn-logout{background:none;border:none;color:#fff6;cursor:pointer;font-size:16px;margin-left:auto;padding:4px 8px;border-radius:6px;transition:all .15s}.btn-logout:hover{color:var(--coral);background:#f43f5e1a}.dash-main{flex:1;padding:2rem;overflow-x:hidden;min-width:0}.page-header{margin-bottom:1.75rem}.page-title{font-family:var(--font-head);font-size:24px;font-weight:700;color:var(--navy);margin-bottom:4px}.page-sub{color:var(--slate-500);font-size:14px}.card{background:#fff;border-radius:var(--radius);border:1px solid var(--slate-200);padding:1.25rem;box-shadow:var(--shadow)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:var(--radius);border:1px solid var(--slate-200);padding:1.25rem;display:flex;flex-direction:column;gap:6px}.stat-label{font-size:12px;color:var(--slate-400);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-family:var(--font-head);font-size:32px;font-weight:700;color:var(--navy)}.stat-accent{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:6px}.accent-green{background:#10b9811a}.accent-amber{background:#f59e0b1a}.accent-sky{background:#0ea5e91a}.accent-coral{background:#f43f5e1a}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{text-align:left;padding:10px 12px;border-bottom:1.5px solid var(--slate-200);color:var(--slate-500);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}tbody td{padding:12px;border-bottom:1px solid var(--slate-100);color:var(--slate-700);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--slate-50)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:50px;font-size:11px;font-weight:600}.badge-pending{background:#fffbeb;color:#92400e;border:1px solid #fcd34d}.badge-active{background:#f0fdf4;color:#15803d;border:1px solid #86efac}.badge-admin{background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd}.badge-professor{background:#e0f2fe;color:#0369a1;border:1px solid #7dd3fc}.badge-aluno{background:#fff7ed;color:#c2410c;border:1px solid #fdba74}.btn-sm{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:1.5px solid;transition:all .15s;font-family:var(--font-body)}.btn-approve{background:var(--emerald);color:#fff;border-color:var(--emerald-dark)}.btn-approve:hover{background:var(--emerald-dark)}.btn-danger{background:#fff;color:var(--coral);border-color:#fca5a5}.btn-danger:hover{background:#fef2f2}.btn-edit{background:#fff;color:var(--sky);border-color:#93c5fd}.btn-edit:hover{background:#eff6ff}.btn-create{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--emerald);color:#fff;border:none;border-radius:8px;font-family:var(--font-body);font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 10px #10b9814d}.btn-create:hover{background:var(--emerald-dark);transform:translateY(-1px)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-title{font-family:var(--font-head);font-size:16px;font-weight:600;color:var(--navy)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.qa-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius);padding:1.25rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:8px}.qa-card:hover{border-color:var(--emerald);box-shadow:0 4px 20px #10b9811f;transform:translateY(-2px)}.qa-icon{font-size:26px}.qa-title{font-family:var(--font-head);font-size:14px;font-weight:600;color:var(--navy)}.qa-desc{font-size:12px;color:var(--slate-400)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1b358c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;width:100%;max-width:480px;box-shadow:var(--shadow-lg);position:relative}.modal-title{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--navy);margin-bottom:1.25rem}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--slate-100);border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:14px;color:var(--slate-500)}.modal-close:hover{background:var(--slate-200)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.welcome-banner{background:linear-gradient(135deg,var(--navy),var(--navy-mid));border-radius:var(--radius-lg);padding:1.75rem 2rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden}.wb-pattern{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.05;background-image:radial-gradient(circle,white 1px,transparent 1px);background-size:24px 24px}.wb-text{position:relative;z-index:1}.wb-text h2{font-family:var(--font-head);font-size:22px;font-weight:700;color:#fff;margin-bottom:4px}.wb-text p{font-size:13px;color:#fff9}.wb-emoji{font-size:48px;position:relative;z-index:1}.trail-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius);overflow:hidden}.trail-card:hover{box-shadow:var(--shadow)}.trail-header{padding:1rem 1.25rem;background:linear-gradient(135deg,var(--navy),var(--navy-mid));color:#fff}.trail-header h3{font-family:var(--font-head);font-size:15px;font-weight:600}.trail-header p{font-size:12px;opacity:.6;margin-top:2px}.trail-progress{padding:1rem 1.25rem}.progress-bar-wrap{height:6px;background:var(--slate-200);border-radius:99px;margin:8px 0}.progress-bar{height:6px;border-radius:99px;background:linear-gradient(90deg,var(--emerald),var(--emerald-light))}.challenge-list{padding:0 1.25rem 1.25rem;display:flex;flex-direction:column;gap:8px}.challenge-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--slate-100);border-radius:8px;cursor:pointer;transition:all .15s}.challenge-item:hover{border-color:var(--emerald);background:#10b98108}.c-status{width:24px;height:24px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px}.c-done{background:var(--emerald);color:#fff}.c-curr{background:var(--amber);color:#fff}.c-lock{background:var(--slate-200);color:var(--slate-400)}.c-name{font-size:13px;font-weight:500;color:var(--slate-800)}.c-type{font-size:11px;color:var(--slate-400)}.c-xp{font-size:11px;font-weight:600;color:var(--amber)}.chatbot-wrap{display:flex;flex-direction:column;height:calc(100vh - 8rem);background:#fff;border-radius:var(--radius);border:1px solid var(--slate-200);overflow:hidden;box-shadow:var(--shadow)}.chat-header{display:flex;align-items:center;gap:12px;padding:1rem 1.25rem;border-bottom:1px solid var(--slate-200);background:var(--navy)}.chat-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--emerald),var(--sky));display:flex;align-items:center;justify-content:center;font-size:18px}.chat-header-info .name{font-weight:600;color:#fff;font-size:14px}.chat-header-info .status{font-size:11px;color:#ffffff80}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--emerald);display:inline-block;margin-right:4px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.chat-messages{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:12px}.msg{display:flex;gap:10px;max-width:80%}.msg.user{flex-direction:row-reverse;align-self:flex-end}.msg-bubble{padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.6;white-space:pre-wrap}.msg.bot .msg-bubble{background:var(--slate-100);color:var(--slate-800);border-bottom-left-radius:4px}.msg.user .msg-bubble{background:var(--navy);color:#fff;border-bottom-right-radius:4px}.msg-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}.bot-avatar{background:linear-gradient(135deg,var(--emerald),var(--sky))}.user-msg-avatar{background:var(--navy-mid);font-size:12px;font-weight:700;color:#fff}.chat-input-row{padding:1rem;border-top:1px solid var(--slate-200);display:flex;gap:10px;align-items:center}.chat-input{flex:1;padding:10px 14px;border:1.5px solid var(--slate-200);border-radius:50px;font-family:var(--font-body);font-size:13.5px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:var(--emerald)}.btn-send{width:38px;height:38px;background:var(--emerald);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;flex-shrink:0}.btn-send:hover{background:var(--emerald-dark);transform:scale(1.05)}.typing{display:flex;align-items:center;gap:4px;padding:10px 14px;background:var(--slate-100);border-radius:14px 14px 14px 4px}.typing span{width:6px;height:6px;background:var(--slate-400);border-radius:50%;animation:bounce 1s infinite}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.notice-card{border-left:4px solid var(--emerald)}.notice-date{font-size:11px;color:var(--slate-400);margin-bottom:4px}.notice-title{font-weight:600;font-size:14px;color:var(--navy);margin-bottom:4px}.notice-body{font-size:13px;color:var(--slate-600);line-height:1.6}.material-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.material-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius);padding:1rem;transition:all .2s;cursor:pointer}.material-card:hover{border-color:var(--sky);box-shadow:0 4px 16px #0ea5e91f}.mat-icon{font-size:28px;margin-bottom:8px}.mat-title{font-size:13px;font-weight:600;color:var(--navy);margin-bottom:4px}.mat-type{font-size:11px;color:var(--slate-400)}.empty-state{text-align:center;padding:3rem;color:var(--slate-400);font-size:14px}.empty-icon{font-size:42px;margin-bottom:1rem}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;flex-direction:column;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--slate-200);border-top-color:var(--emerald);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-logo-mobile,.login-dev-mobile{display:none}@media (max-width: 768px){.login-logo-mobile{display:flex!important}.login-dev-mobile{display:block!important}}.aluno-hub{display:flex;flex-direction:column;gap:1.5rem;max-width:100%}.hub-hero{background:linear-gradient(135deg,var(--navy) 0%,#1e3a5f 60%,#0f2544 100%);border-radius:18px;padding:1.75rem;color:#fff;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:center;position:relative;overflow:hidden}.hub-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:#ffffff0a}.hub-hero:after{content:"";position:absolute;bottom:-40px;left:80px;width:140px;height:140px;border-radius:50%;background:#ffffff08}.hub-hero-content{position:relative;z-index:1}.hub-greeting{display:flex;align-items:center;gap:14px;margin-bottom:1.25rem}.hub-emoji{font-size:40px;flex-shrink:0}.hub-greeting h1{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:4px}.hub-greeting p{font-size:13px;opacity:.65}.hub-xp-bar{position:relative;z-index:1}.hub-xp-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.hub-nivel{font-size:13px;font-weight:700;padding:2px 10px;border-radius:50px;background:#ffffff1a}.hub-xp-num{font-size:12px;opacity:.7}.hub-xp-track{height:8px;background:#ffffff26;border-radius:99px;overflow:hidden}.hub-xp-fill{height:8px;border-radius:99px;transition:width .8s ease}.hub-xp-sub{font-size:10px;opacity:.5;margin-top:5px}.hub-mini-stats{display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}.hub-mini-stat{text-align:center;padding:10px 16px;background:#ffffff14;border-radius:10px;border:1px solid rgba(255,255,255,.12);min-width:72px}.hub-mini-val{display:block;font-family:var(--font-head);font-size:20px;font-weight:700}.hub-mini-lbl{display:block;font-size:10px;opacity:.6;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.hub-turma-tabs{display:flex;gap:6px;flex-wrap:wrap}.hub-turma-tab{padding:7px 16px;border-radius:8px;border:1.5px solid var(--slate-200);background:#fff;cursor:pointer;font-size:13px;font-weight:500;color:var(--slate-600);transition:all .15s}.hub-turma-tab.active{border-color:var(--emerald);background:#10b98114;color:var(--emerald-dark);font-weight:600}.hub-turma-card{background:#fff;border:1.5px solid var(--slate-200);border-radius:14px;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 2px 8px #0000000d}.hub-turma-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.hub-turma-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--navy-mid));display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}.hub-turma-nome{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--navy);margin-bottom:4px}.hub-turma-meta{display:flex;gap:12px;font-size:12px;color:var(--slate-400);flex-wrap:wrap}.hub-turma-right{flex-shrink:0}.hub-turma-badge{padding:4px 12px;border-radius:50px;background:#10b9811a;color:var(--emerald-dark);font-size:12px;font-weight:600;border:1px solid rgba(16,185,129,.3);white-space:nowrap}.hub-section-title{margin-top:.25rem}.hub-section-title h2{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--navy);margin-bottom:3px}.hub-section-title p{font-size:12px;color:var(--slate-400)}.hub-modulos-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.875rem}.hub-modulo-card{position:relative;background:var(--mod-bg, #f0fdf4);border:2px solid var(--mod-bd, #86efac);border-radius:16px;padding:1.25rem 1rem;cursor:pointer;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .18s;outline:none;min-height:130px;justify-content:center}.hub-modulo-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--mod-cor)}.hub-modulo-card:active{transform:translateY(-1px)}.hub-modulo-icon{font-size:32px;margin-bottom:2px}.hub-modulo-label{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--mod-cor, var(--navy))}.hub-modulo-desc{font-size:11px;color:var(--slate-500);line-height:1.4}.hub-modulo-arrow{position:absolute;top:10px;right:12px;font-size:18px;color:var(--mod-cor);opacity:.5}.hub-pendencias{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.hub-pend-col{background:#fff;border:1px solid var(--slate-200);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000d}.hub-pend-header{padding:.875rem 1rem;border-bottom:1px solid var(--slate-100);display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--navy);background:var(--slate-50)}.hub-pend-link{font-size:12px;color:var(--sky);background:none;border:none;cursor:pointer;font-weight:600;padding:0}.hub-pend-list{display:flex;flex-direction:column}.hub-pend-item{display:flex;align-items:center;gap:10px;padding:.75rem 1rem;border-bottom:1px solid var(--slate-50);cursor:pointer;transition:background .1s}.hub-pend-item:hover{background:var(--slate-50)}.hub-pend-item:last-child{border-bottom:none}.hub-pend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hub-pend-info{flex:1;min-width:0}.hub-pend-nome{font-size:13px;font-weight:500;color:var(--navy);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.hub-pend-meta{display:flex;gap:8px;font-size:11px;color:var(--slate-400);flex-wrap:wrap}.hub-pend-pts{font-size:12px;font-weight:600;color:var(--slate-500);flex-shrink:0}.hub-pend-badge{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;flex-shrink:0}.hub-extras{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.hub-extra-btn{background:#fff;border:1.5px solid var(--slate-200);border-radius:12px;padding:1rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;transition:all .15s}.hub-extra-btn:hover{border-color:var(--emerald);box-shadow:0 4px 12px #10b9811f;transform:translateY(-2px)}.hub-extra-icon{font-size:24px}.hub-extra-label{font-size:12px;font-weight:600;color:var(--navy)}.hub-extra-desc{font-size:10px;color:var(--slate-400)}.hub-no-turma{text-align:center;padding:4rem 2rem;background:#fff;border-radius:18px;border:2px dashed var(--slate-200)}.hub-no-turma h3{font-family:var(--font-head);font-size:18px;color:var(--navy);margin-bottom:8px}.hub-no-turma p{color:var(--slate-400);font-size:14px}@media (max-width: 900px){.hub-hero{grid-template-columns:1fr;gap:1rem}.hub-mini-stats{flex-direction:row;justify-content:flex-start;gap:8px}.hub-mini-stat{flex:1;min-width:0}.hub-modulos-grid{grid-template-columns:repeat(3,1fr)}.hub-pendencias{grid-template-columns:1fr}.hub-extras{grid-template-columns:repeat(4,1fr)}.dash-shell{position:relative}.sidebar{width:200px}.dash-main{padding:1.25rem}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.dash-shell{display:block;position:relative}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;z-index:200;transform:translate(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #0000004d}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199}.sidebar-overlay.open{display:block}.dash-main{padding:1rem;min-height:100vh}.mobile-topbar{display:flex;align-items:center;gap:12px;padding:.875rem 1rem;background:var(--navy);color:#fff;position:sticky;top:0;z-index:100;margin:-1rem -1rem 1rem;box-shadow:0 2px 8px #0003}.mobile-topbar .mobile-logo{font-family:var(--font-head);font-size:16px;font-weight:700;flex:1}.mobile-hamburger{background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:4px 6px}.hub-hero{padding:1.25rem;border-radius:14px}.hub-greeting h1{font-size:18px}.hub-emoji{font-size:32px}.hub-modulos-grid{grid-template-columns:repeat(2,1fr);gap:.625rem}.hub-modulo-card{min-height:110px;padding:1rem .75rem}.hub-modulo-icon{font-size:26px}.hub-pendencias{grid-template-columns:1fr}.hub-extras{grid-template-columns:repeat(2,1fr)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-value{font-size:24px}.quick-actions{grid-template-columns:repeat(2,1fr)}.page-title{font-size:20px}div[style*="position:fixed"]>div[style*=maxWidth]{margin:0!important;border-radius:0!important;min-height:100vh!important;max-width:100%!important}.card{padding:1rem}table{font-size:12px}th,td{padding:8px 6px!important}}@media (max-width: 380px){.hub-modulos-grid,.hub-extras{grid-template-columns:1fr 1fr}.hub-mini-stats{gap:4px}}.mobile-topbar{display:none}@media (max-width: 640px){.mobile-topbar{display:flex}}
