*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#534ab7;--brand-light:#eeedfe;--brand-mid:#7f77dd;--accent:#534ab7;--accent-light:#eeedfe;--bg:#fdfcff;--surface:#fff;--border:#eceaf8;--text:#26215c;--text-2:#6b6b8a;--text-3:#afa9ec;--success:#0f6e56;--success-bg:#e1f5ee;--danger:#a32d2d;--danger-bg:#fcebeb;--warning:#854f0b;--warning-bg:#faeeda;--info:#185fa5;--info-bg:#e6f1fb;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 4px #534ab70f;--shadow:0 2px 12px #534ab714}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.6}.app-layout{min-height:100vh;display:flex}.sidebar{z-index:100;background:#1c1b2e;flex-direction:column;flex-shrink:0;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.main-content{flex:1;min-height:100vh;margin-left:240px;padding:32px}.sidebar-logo{border-bottom:1px solid #ffffff12;padding:24px 22px 18px}.sidebar-logo .logo-teacher{color:#afa9ec;letter-spacing:.12em;text-transform:uppercase;margin-bottom:3px;font-size:10px;font-weight:600;display:block}.sidebar-logo .logo-name{color:#fff;letter-spacing:.01em;font-size:17px;font-weight:700;display:block}.sidebar-profile{border-bottom:1px solid #ffffff12;align-items:center;gap:10px;padding:14px 22px 16px;display:flex}.sidebar-profile .profile-avatar{background:var(--brand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.sidebar-profile .profile-name{color:#fff;font-size:13px;font-weight:600;line-height:1.3}.sidebar-profile .profile-role{color:#ffffff73;margin-top:1px;font-size:11px;font-weight:400}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:99px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#fff3}.nav-section-label{color:#ffffff40;text-transform:uppercase;letter-spacing:.1em;padding:12px 10px 5px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--radius);color:#fff9;cursor:pointer;letter-spacing:.01em;align-items:center;gap:11px;margin-bottom:1px;padding:10px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{color:#ffffffe6;background:#ffffff12}.nav-item.active{color:#fff;background:#7f77dd33;border-left:3px solid #7f77dd;padding-left:9px;font-weight:600}.nav-item .nav-icon{flex-shrink:0;font-size:17px}.sidebar-footer{border-top:1px solid #ffffff12;padding:10px 12px 16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.card-sm{padding:14px 16px}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:28px;display:grid}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px 20px;position:relative;overflow:hidden}.metric-card:before{content:"";background:linear-gradient(90deg, var(--brand), #afa9ec);border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.metric-num{color:var(--text);margin-top:4px;font-size:28px;font-weight:700;line-height:1}.metric-label{color:var(--text-2);margin-top:5px;font-size:12px;font-weight:500}.page-header{margin-bottom:28px}.page-title{color:var(--text);font-size:22px;font-weight:700}.page-sub{color:var(--text-2);margin-top:3px;font-size:13px}.badge{letter-spacing:.02em;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-brand{background:var(--brand-light);color:var(--brand)}.badge-neutral{color:var(--text-2);background:#f1f3f7}.btn{border-radius:var(--radius);cursor:pointer;letter-spacing:.01em;border:1px solid #0000;align-items:center;gap:7px;padding:9px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-primary:hover{background:var(--brand-mid)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg)}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#f7c1c1}.btn-sm{padding:5px 12px;font-size:12px}.btn-block{justify-content:center;width:100%}.form-group{margin-bottom:16px}.form-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--surface);outline:none;padding:10px 13px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #50006e1a}.form-textarea{resize:vertical;min-height:80px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;color:var(--text-2);text-transform:uppercase;letter-spacing:.07em;border-bottom:2px solid var(--border);background:#f8f7ff;padding:11px 16px;font-size:11px;font-weight:700}tbody td{border-bottom:1px solid var(--border);color:var(--text);padding:13px 16px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f8f7ff}.alert{border-radius:var(--radius);align-items:flex-start;gap:10px;margin-bottom:12px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.alert-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #f7c1c1}.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #fac775}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid #9fe1cb}.alert-info{background:var(--info-bg);color:var(--info);border:1px solid #b5d4f4}.avatar{background:var(--brand-light);width:36px;height:36px;color:var(--brand);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.divider{background:var(--border);height:1px;margin:20px 0}.kanban{grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:12px;display:grid}.kanban-col{border-radius:var(--radius-lg);border:1px solid var(--border);background:#f8f9fc;padding:14px}.kanban-title{color:var(--text-2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px;font-size:11px;font-weight:700}.kanban-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);margin-bottom:8px;padding:11px 13px;transition:box-shadow .15s}.kanban-card:hover{box-shadow:var(--shadow);border-color:var(--brand)}.presenca-btns{gap:6px;display:flex}.p-btn{border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .15s;display:flex}.p-btn.presente{background:var(--success-bg);border-color:var(--success);color:var(--success)}.p-btn.falta{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.empty{text-align:center;color:var(--text-3);padding:48px 20px}.empty-icon{opacity:.4;margin-bottom:12px;font-size:36px}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:480px;padding:28px;box-shadow:0 12px 40px #534ab726}.modal-title{color:var(--text);margin-bottom:18px;font-size:17px;font-weight:700}@media (width<=768px){.sidebar{flex-direction:row;align-items:center;width:100%;height:56px;padding:0 16px;position:fixed;bottom:auto}.sidebar-logo .logo-teacher,.sidebar-profile,.sidebar-nav,.nav-section-label{display:none}.main-content{margin-top:56px;margin-left:0;padding:16px}.metrics-grid{grid-template-columns:repeat(2,1fr)}.sidebar{flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:60px;padding:0 16px;position:fixed;top:0;bottom:auto}.sidebar-logo{border:none;padding:0}.sidebar-logo .logo-teacher{display:none}.sidebar-logo .logo-name{font-size:15px}.sidebar-profile,.sidebar-nav,.sidebar-footer{display:none}.mobile-nav{z-index:100;background:#1c1b2e;border-bottom:1px solid #ffffff1a;align-items:center;height:50px;padding:0 8px;display:flex;position:fixed;top:60px;left:0;right:0}.mobile-nav-item{color:#ffffff80;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 4px;text-decoration:none;transition:color .15s;display:flex}.mobile-nav-item.active{color:#afa9ec}.mobile-nav-item i{font-size:20px}.mobile-nav-item span{font-size:10px;font-weight:500}.main-content{margin-top:110px;margin-bottom:20px;margin-left:0;padding:16px}.metrics-grid{grid-template-columns:repeat(2,1fr);gap:10px}.metric-num{font-size:22px}.card{padding:14px}.modal{margin:0 8px;padding:20px}.modal-overlay{align-items:flex-end;padding:8px}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh}table{font-size:12px}thead th{padding:8px 10px}tbody td{padding:10px}.btn{padding:10px 14px;font-size:13px}.btn-sm{padding:7px 12px;font-size:12px}.page-title{font-size:18px}.page-header{margin-bottom:16px}.p-btn{width:40px;height:40px;font-size:16px}.form-input,.form-select,.form-textarea{padding:11px 12px;font-size:16px}.form-label{margin-bottom:7px;font-size:13px}.hide-mobile{display:none}[style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}}@media (width>=769px){.mobile-nav{display:none}}
