html{scroll-behavior:smooth}*{box-sizing:border-box}body{margin:0%;padding:0%;overflow-x:hidden}.layout{height:100vh;display:flex;flex-direction:column;overflow:hidden;background-color:#f8f9fb}.body{flex:1;display:flex;overflow:hidden}.navbar{height:64px;background:#fff;border-bottom:1px solid #E1E9E5;display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:1000}.navbar-left{display:flex;align-items:center;gap:20px}.menu-btn{background:transparent;border:none;cursor:pointer;color:#334155;display:none;align-items:center;justify-content:center;transition:color .2s ease}.menu-btn:hover{color:#0f172a}.brand{display:flex;align-items:center;gap:12px;cursor:pointer}.brand-icon{width:36px;height:36px;background:linear-gradient(135deg,#c62828,#e53935);color:#fff;display:flex;align-items:center;justify-content:center;border-radius:12px;box-shadow:0 6px 18px #c628284d}.brand-name{font-size:16px;font-weight:700;color:#0f172a;letter-spacing:.3px}.navbar-right{display:flex;align-items:center;gap:24px}.user-info{display:flex;align-items:center;gap:12px}.user-text{text-align:right}.user-name{margin:0;font-size:14px;font-weight:600;color:#0f172a}.user-role{font-size:12px;color:#64748b}.avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;border:2px solid #f1f5f9}.avatar img{width:100%;height:100%;object-fit:cover}.logout-btn{background:#f8fafc;border:1px solid #f1f5f9;width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#475569;transition:all .2s ease}.logout-btn:hover{background:#c62828;color:#fff;border-color:#c62828}.body{display:flex}.sidebar{width:260px;position:fixed;top:60px;bottom:0;left:-270px;background:linear-gradient(180deg,#fff,#f9fafc);border-right:1px solid rgba(0,0,0,.05);padding:24px 16px;transition:left .35s cubic-bezier(.4,0,.2,1);z-index:999;box-shadow:4px 0 25px #0000000a;overflow-y:auto;overflow-x:hidden}.sidebar.open{left:0}.sidebar nav{display:flex;flex-direction:column;gap:6px}.nav-item{background:transparent;border:none;padding:12px 14px;text-align:left;border-radius:12px;cursor:pointer;font-size:14px;font-weight:500;color:#444;display:flex;align-items:center;gap:12px;transition:all .25s ease;position:relative}.nav-item:hover{background:#c628280f;color:#c62828;transform:translate(4px)}.nav-item.active{background:linear-gradient(90deg,#c6282826,#c628280d);color:#c62828;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-16px;top:8px;bottom:8px;width:4px;background:#c62828;border-radius:0 6px 6px 0}.sidebar-footer{margin-top:150%;border-top:1px solid rgba(0,0,0,.06);font-size:13px;color:#777}.sidebar-footer-item button{width:100%}.overlay{position:fixed;inset:60px 0 0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:500;transition:opacity .3s ease}.content{flex:1;height:100%;overflow-y:auto;overflow-x:hidden;background:#f8fafc;padding-bottom:20px;scrollbar-width:none;-ms-overflow-style:none}.content::-webkit-scrollbar{display:none}.faculty-sidebar-footer,.student-sidebar-footer{margin-top:200%}@media(min-width:992px){.sidebar{position:static;left:0;box-shadow:none}.overlay{display:none}}@media(max-width:991px){.menu-btn{display:flex}}@media(max-width:768px){.sidebar-footer{margin-top:140%}.faculty-sidebar-footer,.student-sidebar-footer{margin-top:180%}}:root{--primary: #e11d48;--bg: #f8fafc;--text-dark: #0f172a;--text-light: #64748b;--slide: 0%}body{margin:0;font-family:Inter,sans-serif}.auth-container{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:32px;position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(225,29,72,.12),transparent 70%);top:-150px;right:-150px}.auth-card{width:100%;max-width:440px;background:#fff;padding:36px;border-radius:20px;box-shadow:0 4px 12px #0000000a,0 20px 40px #0000000f;position:relative;z-index:1;transition:.3s ease}.auth-card:hover{transform:translateY(-4px)}.auth-header{text-align:center;margin-bottom:28px}.logo-box{height:60px;width:60px;background:linear-gradient(135deg,#e11d48,#be123c);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 18px;box-shadow:0 12px 24px #e11d4840}.auth-header h2{font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:6px}.auth-header p{font-size:14px;color:var(--text-light)}.role-selector{position:relative;display:flex;background:#f1f5f9;padding:6px;border-radius:14px;margin-bottom:28px}.role-selector:before{content:"";position:absolute;top:6px;left:6px;width:calc(33.33% - 4px);height:calc(100% - 12px);background:#fff;border-radius:10px;box-shadow:0 6px 14px #0000000d;transform:translate(var(--slide));transition:.35s ease}.role-btn{flex:1;padding:10px;border:none;background:transparent;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;position:relative;z-index:2}.role-btn.active{color:var(--primary)}.form-field{margin-bottom:26px}.outlined-input{position:relative}.outlined-input input{width:100%;height:50px;padding:18px 16px;font-size:15px;font-weight:500;border:1.8px solid #e2e8f0;border-radius:14px;background:#f8fafc;outline:none;transition:all .25s ease;box-sizing:border-box}.outlined-input input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #e11d481f}.outlined-input label{position:absolute;left:14px;top:50%;transform:translateY(-50%);background:var(--bg);padding:0 8px;font-size:15px;font-weight:500;color:var(--text-light);pointer-events:none;transition:all .2s ease}.outlined-input input:focus+label,.outlined-input input:not(:placeholder-shown)+label{top:0;transform:translateY(-50%);font-size:12px;font-weight:600;color:var(--primary)}.eye-btn{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:13px;font-weight:600;cursor:pointer;color:#64748b}.error-text{font-size:12px;font-weight:500;color:var(--primary);margin-top:8px;display:block}.form-options{display:flex;justify-content:space-between;font-size:13px;margin-bottom:26px}.form-options a{color:var(--primary);text-decoration:none}.submit-btn{width:100%;background:var(--primary);color:#fff;border:none;padding:14px;border-radius:14px;font-weight:600;cursor:pointer;transition:.25s ease}.submit-btn:hover{background:#be123c;transform:translateY(-2px);box-shadow:0 10px 20px #e11d484d}.submit-btn.success{background:#16a34a}.footer-text{margin-top:24px;text-align:center;font-size:12px;color:#94a3b8}.admin-das-dashboard{padding:18px;width:100%;background:#f8fafc;box-sizing:border-box;min-height:100vh}.dashboard-top{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to right,#c62828,#e11d48);padding:18px 24px;border-radius:20px;color:#fff;margin-bottom:40px}.Atten-das{font-size:28px;font-weight:700}.admin-das-header{margin-bottom:28px}.admin-das-top{display:flex;justify-content:space-between;align-items:center}.admin-das-top h3{font-size:22px;font-weight:700;color:#0f172a;margin:0}.admin-das-date-badge{font-size:13px;padding:6px 14px;background:#fff;border-radius:30px;box-shadow:0 4px 12px #0000000f;font-weight:500;color:#475569}.admin-das-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;margin-bottom:34px}.admin-das-chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:26px}.admin-das-chart-card{background:#fff;padding:26px;border-radius:18px;border:1px solid #eef2f7;box-shadow:0 10px 30px #0000000d;transition:all .3s ease}.admin-das-chart-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #00000014}.admin-das-chart-title{margin:0 0 20px;font-size:17px;font-weight:600;color:#0f172a}.admin-das-chart-wrapper{width:100%;height:320px;position:relative}.admin-das-pie-card{background:#fff;padding:26px;border-radius:18px;box-shadow:0 10px 30px #0000000d;display:flex;flex-direction:column;transition:all .3s ease}.admin-das-pie-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #00000014}.admin-das-pie-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.admin-das-status{font-size:12px;padding:4px 12px;border-radius:20px;background:#ef44441a;color:#ef4444;font-weight:600}.admin-das-center-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.admin-das-center-text h2{margin:0;font-size:30px;font-weight:700;color:#0f172a}.admin-das-center-text p{margin:4px 0 0;font-size:13px;color:#64748b}.admin-das-legend{display:flex;justify-content:center;gap:24px;margin-top:auto;padding-top:24px}.admin-das-legend-item{font-size:14px;display:flex;align-items:center;gap:8px;color:#475569;font-weight:500}.admin-das-present-dot,.admin-das-absent-dot{width:12px;height:12px;border-radius:50%}.admin-das-present-dot{background:#ef4444}.admin-das-absent-dot{background:#e5e7eb}@media(max-width:992px){.admin-das-chart-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-das-dashboard{padding:18px}.admin-das-center-text h2{font-size:24px}}.card{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.dashboard-card{background:#fff;padding:24px;border-radius:20px;border:1px solid #f1f5f9;box-shadow:0 4px 12px #0f172a0a;transition:all .25s ease;display:flex;flex-direction:column;justify-content:space-between}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0f172a14}.card-top{display:flex;align-items:center;justify-content:space-between}.card-icon{padding:10px;border-radius:12px;color:#0f172a;display:flex;align-items:center;justify-content:center}.card-bottom{margin-top:20px}.card-bottom h3{margin:0;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.8px;color:#64748b}.card-value{margin:6px 0 0;font-size:26px;font-weight:700;color:#0f172a}.card-change{font-size:12px;font-weight:600}.card-change.positive{color:#16a34a}.card-change.negative{color:#dc2626}@media(max-width:768px){.dashboard-card{padding:20px}.card-value{font-size:22px}}.header1{width:100%}.header1-top{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to right,#c62828,#e11d48);padding:28px 32px;border-radius:20px;color:#fff;margin-bottom:40px}.header1-das{display:flex;flex-direction:column;justify-content:center}.header1-das h1{font-size:28px;font-weight:700;margin:0;line-height:1.2}.header1-das p{margin:6px 0 0;font-size:14px;opacity:.9}.header1-right{display:flex;align-items:center}.header1-date-badge{background:#fff3;padding:10px 16px;border-radius:12px;font-size:14px;font-weight:500;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-card{width:100%;max-width:500px;background:#fff;border-radius:16px;box-shadow:0 20px 50px #00000026;overflow:hidden;animation:modalEnter .25s ease;padding:24px}@keyframes modalEnter{0%{opacity:0;transform:translateY(-20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #eee}.modal-header h2{font-size:18px;font-weight:600}.close-btn{border:none;background:#f3f4f6;width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:18px}.close-btn:hover{background:#e11d48;color:#fff}.modal-body{display:grid}.form-field,.outlined-input{position:relative}.outlined-input input{width:100%;height:50px;border-radius:12px;border:1.8px solid #e5e7eb;background:#f8fafc;font-size:14px;outline:none;transition:.2s}.outlined-input input:focus{border-color:#e11d48;background:#fff;box-shadow:0 0 0 3px #e11d481f}.outlined-input label{position:absolute;left:12px;top:50%;transform:translateY(-50%);background:#f8fafc;padding:0 6px;font-size:14px;color:#64748b;pointer-events:none;transition:.2s}.outlined-input input:focus+label,.outlined-input input:not(:placeholder-shown)+label{top:0;transform:translateY(-50%);font-size:12px;color:#e11d48;background:#fff}.modal-footer{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #eee}.secondary-btn{background:#f3f4f6;border:none;height:50px;margin-top:10px;padding:0 18px;border-radius:10px;cursor:pointer}.secondary-btn:hover{background:#e5e7eb}.primary-btn{background:#e11d48;color:#fff;border:none;padding:10px 20px;border-radius:10px;font-weight:600;cursor:pointer}.page-header{background:linear-gradient(to right,#c62828,#e11d48);padding:24px;margin:18px 18px 36px;border-radius:20px;box-shadow:0 12px 35px #0f172a1f,inset 0 1px #ffffff26;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;position:relative;overflow:hidden}.page-header:after{content:"";position:absolute;top:-40%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.15),transparent 70%);pointer-events:none}.page-header-left h1{margin:0;font-size:28px;font-weight:700;color:#fff;letter-spacing:.4px}.page-header-left p{margin:8px 0 0;font-size:14px;color:#ffffffbf;font-weight:400}.primary-header-btn{display:inline-flex;align-items:center;gap:10px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.25);padding:12px 22px;border-radius:14px;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease}.primary-header-btn:hover{background:#fff;color:#7f1d1d;transform:translateY(-2px);box-shadow:0 12px 28px #0000002e}@media(max-width:768px){.page-header{padding:22px;flex-direction:column;align-items:flex-start}.primary-btn{width:100%;justify-content:center}}.table-container{width:100%}.table-card{background:#fff;border-radius:14px;box-shadow:0 10px 25px #00000014;overflow:hidden}.table-wrapper{width:100%;overflow-x:auto}.modern-table{width:100%;border-collapse:collapse;font-family:Inter,sans-serif;min-width:700px}.modern-table thead{background:#f8fafc}.modern-table th{text-align:left;padding:16px 18px;font-size:14px;font-weight:600;color:#334155;border-bottom:1px solid #e5e7eb}.modern-table td{padding:14px 18px;font-size:14px;color:#475569;border-bottom:1px solid #f1f5f9}.modern-table tbody tr{transition:all .2s ease}.modern-table tbody tr:hover{background:#f9fafb}.action-buttons{display:flex;gap:8px}.edit-btn,.delete-btn{border:none;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.edit-btn{background:#ecfdf5;color:#16a34a}.edit-btn:hover{background:#16a34a;color:#fff}.delete-btn{background:#fef2f2;color:#dc2626}.delete-btn:hover{background:#dc2626;color:#fff}.approve-btn{background:linear-gradient(145deg,#28a745,#218838);color:#fff;border:none;padding:8px 10px;font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #0000001a}.approve-btn:hover{background:linear-gradient(145deg,#218838,#28a745);transform:translateY(-2px);box-shadow:0 6px 8px #00000026}.approve-btn:active{background:#1e7e34;transform:translateY(2px);box-shadow:none}.approve-btn:focus{outline:none;box-shadow:0 0 0 3px #489b4899}@media(max-width:768px){.modern-table th,.modern-table td{padding:12px;font-size:13px}}.del-overlay{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000}.del-modal{width:380px;background:#fff;border-radius:14px;padding:24px;box-shadow:0 20px 40px #00000026}.del-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}.del-icon{width:36px;height:36px;border-radius:8px;background:#fee2e2;color:#dc2626;display:flex;align-items:center;justify-content:center}.del-title h3{margin:0;font-size:17px;font-weight:600;color:#111}.del-title p{margin:4px 0 0;font-size:13px;color:#6b7280}.del-body{font-size:14px;color:#4b5563;margin-bottom:22px;line-height:1.5}.del-actions{display:flex;justify-content:flex-end;gap:10px}.btn-cancel{padding:9px 16px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:14px}.btn-cancel:hover{background:#f9fafb}.btn-delete{padding:9px 16px;border-radius:8px;border:none;background:#dc2626;color:#fff;font-size:14px;cursor:pointer}.btn-delete:hover{background:#b91c1c}.btn-delete:disabled{opacity:.7;cursor:not-allowed}.table-card{background:#fff;border-radius:20px;padding:28px;margin:18px;border:1px solid #eef2f7;box-shadow:0 10px 35px #0f172a0f,0 2px 8px #0f172a0a;overflow:hidden}.table-wrapper{border-radius:14px;overflow:hidden}.mod-table{width:100%;border-collapse:collapse;font-size:14px;background:#fff}.mod-table thead{background:linear-gradient(to right,#f8fafc,#f1f5f9)}.mod-table th{text-align:left;padding:16px 18px;font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.6px;color:#475569;border-bottom:1px solid #e2e8f0}.mod-table td{padding:16px 18px;border-bottom:1px solid #f1f5f9;color:#0f172a;font-weight:500}.mod-table tbody tr{transition:all .25s ease}.mod-table tbody tr:hover{background:#f9fafb;transform:scale(1.002)}.badge{padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;letter-spacing:.3px}.badge.active{background:#16a34a1f;color:#15803d}.badge.inactive{background:#dc26261f;color:#b91c1c}.action-btn{background:#f1f5f9;border:1px solid #e2e8f0;padding:7px 14px;border-radius:10px;font-size:12px;font-weight:600;margin-right:8px;cursor:pointer;color:#334155;transition:all .2s ease}.action-btn:hover{background:#e2e8f0;transform:translateY(-1px)}.action-btn.danger{background:#dc262614;color:#b91c1c;border:1px solid rgba(220,38,38,.15)}.action-btn.danger:hover{background:#b91c1c;color:#fff;border-color:#b91c1c}.modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;padding:26px;border-radius:16px;width:340px;text-align:center;box-shadow:0 20px 60px #0f172a40;animation:fadeIn .25s ease}.modal-actions{margin-top:20px;display:flex;justify-content:center;gap:14px}.yes-btn{padding:8px 18px;background:#16a34a;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.yes-btn:hover{background:#15803d;transform:translateY(-2px)}.cancel-btn{padding:8px 18px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.cancel-btn:hover{background:#e2e8f0}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pagination{display:flex;justify-content:flex-end;gap:8px;margin-top:22px;flex-wrap:wrap}.page-btn{padding:8px 14px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;font-size:13px;font-weight:600;cursor:pointer;color:#334155;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#e2e8f0;transform:translateY(-1px)}.page-btn.active{background:#b91c1c;color:#fff;border-color:#7f1d1d}.page-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.mod-table th,.mod-table td{padding:12px}.table-card{padding:20px}}.faculty-dashboard{padding:18px;width:100%;background:#f8fafc;min-height:100vh}.faculty-dashboard-top{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to right,#c62828,#e11d48);padding:18px 24px;border-radius:20px;color:#fff;margin-bottom:40px}.dashboard-date-badge{background:#fff3;padding:8px 14px;border-radius:12px}.Atten-das{font-size:28px;font-weight:700;color:#fff}.faculty-das-header{margin-bottom:28px}.faculty-das-top{display:flex;justify-content:space-between;align-items:center}.faculty-das-top h3{font-size:22px;font-weight:700;color:#0f172a;margin:0}.faculty-das-date-badge{font-size:13px;padding:6px 14px;background:#fff;border-radius:30px;box-shadow:0 4px 12px #0000000f;font-weight:500;color:#475569}.faculty-das-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;margin-bottom:34px}.faculty-das-chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:26px}@media(max-width:992px){.faculty-das-chart-grid{grid-template-columns:1fr}}@media(max-width:768px){.faculty-das-dashboard{padding:18px}.faculty-das-center-text h2{font-size:24px}}.fac-attendance{margin:20px}.fac-filter-card{background:#fff;padding:24px 28px;border-radius:18px;border:1px solid #f1f5f9;box-shadow:0 8px 24px #0f172a0d;margin-bottom:24px}.fac-filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:end}.fac-form-group{display:flex;flex-direction:column;gap:8px}.fac-form-group label{font-size:13px;font-weight:600;color:#475569}.fac-form-group input,.fac-form-group select{padding:12px 14px;border-radius:12px;border:1px solid #e2e8f0;font-size:14px;background:#fff;transition:all .2s ease;outline:none;height:42px}.fac-form-group input:focus,.fac-form-group select:focus{border-color:#c62828;box-shadow:0 0 0 3px #c628281a}@media(max-width:768px){.fac-filter-grid{grid-template-columns:1fr}}.faculty-qr-dashboard{max-width:1400px;margin:0 auto;height:100vh}.faculty-qr-dashboard header{margin-bottom:30px}.faculty-qr-dashboard header h1{font-size:26px;font-weight:700;color:#0f172a;margin-bottom:6px}.faculty-qr-dashboard header p{color:#64748b}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}.control-panel{display:flex;flex-direction:column;gap:24px}.card,.metrics-card,.qr-panel{background:#fff;border-radius:24px;padding:28px;box-shadow:0 10px 25px #0000000a}.card-title{display:flex;align-items:center;gap:10px;font-weight:700;margin-bottom:24px}.vertical-card{display:flex;flex-direction:column;gap:18px}.form-group,.form-group select{width:100%}.full-btn{width:100%;height:50px}.form-group{margin-bottom:18px}.form-group label{font-size:14px;font-weight:600;display:block;margin-bottom:8px;color:#334155}select{width:100%;padding:12px;border-radius:10px;border:1px solid #e2e8f0;background:#f1f5f9;font-size:14px;transition:.2s ease}select:focus{outline:none;border-color:#e11d48;background:#fff}.primary-btn{width:100%;padding:14px;margin-top:8px;background:#dc2626;color:#fff;border-radius:14px;font-weight:700;border:none;cursor:pointer;transition:.2s ease}.primary-btn:hover{background:#be123c}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.metrics-card{background:#0f172a;color:#fff;position:relative;overflow:hidden;margin:10px}.metrics-card h3{margin-bottom:20px}.metrics-bg-icon{position:absolute;right:20px;top:20px;opacity:.5}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.metric-box{background:#1e293b;padding:18px;border-radius:16px}.metric-box span{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.metric-box h2{font-size:30px;margin-top:6px}.highlight{color:#e11d48}.progress-section{margin-top:22px}.progress-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.progress-bar{background:#1e293b;height:8px;border-radius:8px;overflow:hidden}.progress-fill{background:#e11d48;height:100%;transition:width .4s ease}.qr-panel{display:flex;align-items:center;justify-content:center;min-height:540px;text-align:center;padding:40px}.active-session{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%}.timer{display:inline-flex;align-items:center;gap:8px;background:#ffe4e6;color:#be123c;padding:10px 18px;border-radius:50px;font-weight:700;font-size:14px}.gen-qr-box{width:320px;height:320px;border:4px solid #C62828;margin:auto;display:flex;align-items:center;justify-content:center;padding:20px;border-radius:28px;background:#fff}.action-buttons{display:flex;gap:14px;width:100%;max-width:320px}.dark-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;background:#0f172a;color:#fff;padding:12px;border-radius:14px;border:none;cursor:pointer;transition:.2s ease}.dark-btn:hover{background:#1e293b}.outline-btn{display:flex;align-items:center;justify-content:center;border:1px solid #cbd5e1;background:#fff;padding:12px;border-radius:14px;cursor:pointer;transition:.2s ease}.outline-btn:hover{background:#f8fafc}.warning-box{margin-top:10px;background:#fef3c7;padding:14px;border-radius:14px;font-size:12px;display:flex;gap:10px;align-items:flex-start;max-width:380px;text-align:left}.review-section{margin-top:30px;background:#fff;padding:28px;border-radius:24px;box-shadow:0 12px 30px #0000000d}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.review-header h3{font-size:20px;font-weight:700}.review-header span{background:#f1f5f9;padding:6px 14px;border-radius:50px;font-size:13px;font-weight:600}.table-wrapper{overflow-x:auto;border-radius:16px}.attendance-table{width:100%;border-collapse:separate;border-spacing:0 12px}.attendance-table thead th{text-align:left;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:#64748b;padding:10px 16px}.attendance-table tbody tr{background:#f8fafc;border-radius:16px;transition:.2s ease}.attendance-table tbody tr:hover{background:#eef2ff;transform:translateY(-2px)}.attendance-table tbody td{padding:16px;font-size:14px}.attendance-table th,.attendance-table td{border:none}.attendance-table tbody tr td:first-child{border-radius:16px 0 0 16px}.attendance-table tbody tr td:last-child{border-radius:0 16px 16px 0}.toggle{position:relative;display:inline-block;width:46px;height:24px}.toggle input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;background-color:#cbd5e1;border-radius:50px;inset:0;transition:.3s}.slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.3s}.toggle input:checked+.slider{background-color:#22c55e}.toggle input:checked+.slider:before{transform:translate(22px)}.submit-btn-modern{margin-top:26px;padding:14px 26px;background:#0f172a;color:#fff;border:none;border-radius:14px;font-weight:600;cursor:pointer;transition:.2s ease}.submit-btn-modern:hover{background:#1e293b}@media(max-width:1024px){.faculty-qr-dashboard{display:flex;justify-content:center}.dashboard-grid{grid-template-columns:1fr}.qr-panel{min-height:auto}}.dashboard{padding:18px;width:100%;box-sizing:border-box;min-height:100vh;font-family:Inter,sans-serif}.student-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:28px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e2e8f0;background-color:#ff2626;padding:20px;border-radius:25px}.header-left{display:flex;align-items:center;gap:18px}.student-avatar{width:52px;height:52px;background:linear-gradient(145deg,#f1f5f9,#e2e8f0);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#64748b;box-shadow:0 4px 12px #0000000a}.student-info{display:flex;flex-direction:column;margin-top:10px}.student-info h1{font-size:26px;font-weight:700;color:#0f172a;letter-spacing:-.3px;margin:0}.student-info p{font-size:14px;font-weight:500;color:#64748b;margin-top:6px}.header-status{display:block}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#166534;font-size:12px;font-weight:600;border-radius:9999px;border:1px solid #bbf7d0;box-shadow:0 3px 10px #22c55e26;transition:.2s ease}.status-badge:hover{transform:translateY(-1px)}.status-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 1.6s infinite ease-in-out}.stu-history{margin-top:24px;padding:28px;border-radius:28px;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid #eef2f7;box-shadow:0 10px 40px #0f172a0f;position:relative;overflow:hidden}.stu-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.stu-history-title{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.3px}.stu-history-title svg{color:#e11d48}.stu-view-btn{font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;border:1px solid #f1f5f9;background:#fff;color:#e11d48;cursor:pointer;transition:all .25s ease}.stu-view-btn:hover{background:#e11d48;color:#fff;box-shadow:0 8px 20px #e11d4840;transform:translateY(-2px)}.stu-history-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.stu-history-card{background:#fff;padding:22px;border-radius:22px;border:1px solid #f1f5f9;position:relative;overflow:hidden;transition:all .35s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.stu-history-card:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(225,29,72,.04),transparent);opacity:0;transition:.4s ease}.stu-history-card:hover{transform:translateY(-6px) scale(1.02);border-color:#ffe4e6;box-shadow:0 18px 40px #0f172a14}.stu-history-card:hover:after{opacity:1}.stu-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.stu-card-icon{padding:12px;border-radius:14px;background:#f8fafc;color:#64748b;transition:all .3s ease}.stu-history-card:hover .stu-card-icon{background:#e11d48;color:#fff;box-shadow:0 8px 20px #e11d484d;transform:rotate(-1deg) scale(1.1)}.stu-badge{padding:6px 12px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:.3s ease}.stu-present{background:#22c55e1f;color:#15803d;border:1px solid rgba(34,197,94,.25)}.stu-absent{background:#f59e0b1f;color:#b45309;border:1px solid rgba(245,158,11,.25)}.stu-history-card:hover .stu-badge{transform:scale(1.08)}.stu-subject{font-weight:700;font-size:16px;color:#0f172a;margin-bottom:6px;letter-spacing:-.2px}.stu-faculty{font-size:13px;color:#64748b;margin-bottom:16px}.stu-card-footer{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:#94a3b8;padding-top:10px;border-top:1px dashed #f1f5f9}.stu-card-footer svg{opacity:.7}.stu-banner{margin-top:20px;background:linear-gradient(135deg,#ffe4e6,#fecdd3);border:1px solid #fecdd3;padding:26px 32px;border-radius:28px;display:flex;justify-content:space-between;align-items:center}.stu-banner-left{display:flex;align-items:center;gap:18px}.stu-banner-icon{background:#e11d48;color:#fff;padding:14px;border-radius:20px;box-shadow:0 6px 16px #e11d484d}.stu-banner-title{font-weight:700;font-size:16px;color:#881337}.stu-banner-sub{font-size:14px;color:#9f1239;margin-top:4px}.stu-banner-btn{padding:10px 22px;background:#fff;color:#e11d48;font-weight:700;border-radius:14px;border:1px solid #fecdd3;cursor:pointer;transition:.2s ease}.stu-banner-btn:hover{background:#ffe4e6}@media(max-width:768px){.stu-banner{flex-direction:column;align-items:flex-start;gap:20px}.stu-banner-action,.stu-banner-btn{width:100%}}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.dashboard{padding:24px}.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.header-status{display:none}}.attendance{margin:0 20px}.filter-card{background:#fff;margin-bottom:15px;padding:24px 28px;border-radius:18px;border:1px solid #f1f5f9;box-shadow:0 8px 24px #0f172a0d}.filter-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#475569}.form-group input,.form-group select{padding:10px 14px;border-radius:12px;border:1px solid #e2e8f0;font-size:14px;background:#fff;transition:all .2s ease;outline:none}.form-group input:focus,.form-group select:focus{border-color:#c62828;box-shadow:0 0 0 3px #c628281a}@media(max-width:768px){.filter-grid{grid-template-columns:1fr}}.scanner-page{position:fixed;inset:0;display:none;overflow:hidden}.camera-container{position:absolute;inset:0}#qr-reader{width:100%;height:100%}#qr-reader video{width:100%;height:100%;object-fit:cover}#qr-reader__dashboard,#qr-reader__scan_region img{display:none!important}.overlay{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;pointer-events:none}.scan-area{position:relative;width:min(70vw,340px);height:min(70vw,340px);border:1px solid rgba(255,255,255,.3)}.scan-line{position:absolute;top:50%;left:50%;width:300px;height:2px;background:#ff3b3b;box-shadow:0 0 10px #ff3b3b;transform:translate(-50%,-50%);animation:blink 1s infinite;z-index:5}@keyframes blink{0%{opacity:1}50%{opacity:.2}to{opacity:1}}.controls{position:absolute;bottom:30px;left:0;right:0;display:flex;justify-content:center;z-index:5}.center-screen{height:100vh;display:flex;align-items:center;justify-content:center}.start-btn{padding:14px 32px;background:#16a34a;color:#fff;border:none;border-radius:999px;font-weight:600;font-size:16px;cursor:pointer;box-shadow:0 6px 18px #16a34a59;transition:all .2s ease}.stop-btn{padding:14px 32px;background:#dc2626;color:#fff;border:none;border-radius:999px;font-weight:600;font-size:16px;cursor:pointer;box-shadow:0 6px 18px #16a34a59;transition:all .2s ease}@media(max-width:480px){.scanner-page{display:block}}.desktop-warning{display:flex;align-items:center;justify-content:center;margin-top:50px}.desktop-warning:hover{transform:translateY(-4px)}.warning-box{background:#fff;padding:50px 40px;border-radius:18px;width:92%;max-width:420px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 20px 60px #00000027,0 2px 10px #00000016;border-top:4px solid #ff2d2d;animation:fadeUp .5s ease}.warning-icon{display:flex;align-items:center;justify-content:center;color:#ff2d2d}.warning-box h2{font-size:24px;font-weight:700;color:#111;margin:0 0 14px;letter-spacing:.3px;text-align:center}.warning-box p{font-size:15px;line-height:1.6;color:#555;margin:0;max-width:300px;text-align:center}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:500px){.warning-box{display:none}}.landing-navbar{position:fixed;top:0;left:0;width:100%;z-index:999;background:#ffffffd9;background:#fffffff2;border-bottom:1px solid rgba(200,200,200,.4)}.landing-nav-container{max-width:1380px;margin:0 auto;padding:0 40px}.landing-nav-inner{height:80px;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:12px;cursor:pointer}.landing-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#c62828,#e11d48);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px #c6282840}.landing-logo-icon span{color:#fff;font-weight:700;font-size:18px}.landing-logo-text{font-weight:700;font-size:18px;color:#222}.landing-nav-links{display:flex;align-items:center;gap:28px}.landing-nav-links a{text-decoration:none;font-size:15px;color:#555;transition:.3s ease}.landing-nav-links a:hover{color:#c62828}.landing-nav-cta{display:flex;align-items:center;gap:16px}.landing-signin-btn{background:none;border:none;cursor:pointer;color:#d30202;font-size:14px;padding:8px 14px;transition:.3s ease}.landing-signin-btn:hover{color:#c62828}.landing-primary-btn{align-self:center;background:#c62828;color:#fff;border:none;padding:10px 18px;border-radius:10px;cursor:pointer;font-weight:500;font-size:14px;transition:.3s ease;box-shadow:0 8px 18px #c6282840}.landing-primary-btn:hover{background:#b71c1c;transform:translateY(-2px)}.landing-menu-btn{display:none;background:none;border:none;cursor:pointer;color:#555}.landing-mobile-menu{width:100%;border-top:1px solid rgba(0,0,0,.06);display:flex;justify-content:center;margin:4px;flex-direction:column;gap:18px;max-height:0;opacity:0;overflow:hidden;transition:max-height .4s ease,opacity .25s ease,padding .3s ease}.landing-mobile-menu.active{max-height:500px;opacity:1;padding:5px}.landing-mobile-menu a{font-size:16px;font-weight:500;color:#333;text-decoration:none;position:relative;transition:.25s ease}.landing-mobile-menu a:after{content:"";position:absolute;left:0;bottom:-4px;width:0%;height:2px;background:#c62828;transition:width .3s ease}.landing-mobile-menu a:hover{color:#c62828}.landing-mobile-menu a:hover:after{width:100%}.landing-mobile-cta{display:flex;flex-direction:column;gap:14px;padding-top:20px;border-top:1px solid rgba(0,0,0,.06)}@media(min-width:1025px){.landing-mobile-menu{display:none}}@media(max-width:1024px){.landing-logo-icon .landing-primary-btn{box-shadow:0 4px 12px #c6282826}.landing-mobile-menu{will-change:transform,opacity;transform:translateY(-10px);opacity:0;pointer-events:none;transition:transform .3s ease,opacity .25s ease}.landing-mobile-menu.active{transform:translateY(0);opacity:1;pointer-events:auto}.landing-nav-container{padding:0 24px}.landing-nav-links,.landing-nav-cta{display:none}.landing-menu-btn{display:block}}@media(max-width:640px){.landing-nav-container{padding:0 8px}.landing-logo-text{font-size:16px}.landing-nav-inner{height:70px}}.hero{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:transparent}.background-wrapper{position:absolute;inset:0;overflow:hidden}.background-image{width:100%;height:100%;object-fit:cover;opacity:.4;display:block}.hero-bg{position:absolute;inset:0;overflow:hidden}.bg-shape{position:absolute;border-radius:50%;filter:blur(120px)}.shape-1{width:260px;height:260px;background:#f43f5e33;top:80px;left:40px}.shape-2{width:380px;height:380px;background:#e11d4833;bottom:80px;right:40px}.hero-container{width:100%;max-width:1280px;margin:0 auto;padding:50px 2px;position:relative}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.hero-left{text-align:left}.badge{display:inline-block;padding:8px 16px;background:#ffe4e6cc;border-radius:999px;font-weight:500;margin-bottom:24px;color:#c62828}.hero-title{font-size:64px;font-weight:700;margin-bottom:24px;line-height:1.1}.highlight{color:#c62828}.hero-subtitle{font-size:22px;color:#555;margin-bottom:40px;max-width:500px}.hero-buttons{display:flex;gap:16px}.btn-primary{padding:16px 32px;background:#c62828;color:#fff;border:none;border-radius:20px;font-weight:500;cursor:pointer}.btn-secondary{padding:16px 32px;background:#fff;border:2px solid #ddd;border-radius:20px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px}.hero-right{display:flex;justify-content:flex-end;align-items:center;position:relative;min-height:600px;padding-right:80px}.phone-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.pulse-ring-wrapper{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}.pulse-ring{width:260px;height:260px;border:2px solid #f30d0d;border-radius:50%}.phone{width:280px;height:560px;background:linear-gradient(to bottom right,#111,#333);border-radius:48px;padding:12px;position:relative;box-shadow:0 30px 60px #0000004d;z-index:2}.phone-screen{background:#fff;height:100%;border-radius:40px;overflow:hidden}.status-bar{height:32px;background:linear-gradient(to right,#c62828,#e11d48);color:#fff;font-size:12px;display:flex;justify-content:space-between;align-items:center;padding:0 24px}.screen-content{margin-top:64px;padding:40px 24px;text-align:center}.qr-box{width:180px;height:180px;border:4px solid #C62828;border-radius:24px;margin:auto;display:flex;align-items:center;justify-content:center;padding:10px}.qr-grid{width:140px;height:140px;display:grid;background:linear-gradient(to bottom right,#111827,#374151,#111827);padding:18px;border-radius:10px;grid-template-columns:repeat(3,1fr);gap:6px}.qr-cell{background:#fff;border-radius:4px}.scan-title{margin-top:24px;font-weight:600;font-size:18px}.scan-sub{font-size:14px;color:#777}.notch{position:absolute;top:12px;left:50%;transform:translate(-50%);width:110px;height:20px;background:#111;border-radius:20px}.floating-qr{position:absolute;top:120px;right:-120px;transform:translate(40%);background-color:#0ff;z-index:20}.floating-box{width:120px;height:120px;background:#fff;border-radius:20px;padding:12px;box-shadow:0 0 30px #c6282866}.floating-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;height:100%}.floating-cell{background:#111;border-radius:2px}.scroll-indicator{display:flex;flex-direction:column;justify-content:center;align-items:center;position:absolute;bottom:40px;transform:translate(-50%);color:#888;text-align:center;font-size:14px}.scroll-indicator:hover{color:#c62828;scale:1.05}@media(max-width:1024px){.hero-grid{grid-template-columns:1fr;gap:60px}.hero-left{display:flex;flex-direction:column;align-items:center;text-align:center;padding-right:0}.hero-buttons{justify-content:center}.hero-right{justify-content:center;padding-right:0;min-height:auto}.floating-qr{display:none}.pulse-ring{width:200px;height:200px}}@media(max-width:768px){.bg-shape{display:none}.phone{box-shadow:0 12px 30px #0000002e}.scroll-indicator{display:none}.phone,.pulse-ring-wrapper,.hero-right{will-change:transform}}.features-section{padding:120px 0;background:linear-gradient(to bottom,#fff,#fff1f2);position:relative}.features-container{max-width:1200px;margin:0 auto;padding:0 40px}.features-header{text-align:center;margin-bottom:80px}.feature-badge{display:inline-block;padding:8px 18px;background:#fde8e8;color:#c62828;border-radius:50px;font-weight:500;margin-bottom:20px}.features-header h2{font-size:42px;font-weight:700;margin-bottom:20px;color:#222}.features-header p{font-size:18px;color:#666;max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px}.feature-card-wrapper{position:relative}.feature-card{padding:40px;border-radius:24px;background:#ffffffe6;border:1px solid #eee;box-shadow:0 10px 30px #0000000d;transition:all .3s ease}.feature-card:hover{box-shadow:0 20px 50px #0000001a}.icon-box{width:70px;height:70px;border-radius:18px;background:linear-gradient(to bottom right,#c62828,#e11d48);display:flex;align-items:center;justify-content:center;margin-bottom:24px;box-shadow:0 10px 25px #c628284d}.feature-card h3{font-size:22px;font-weight:600;margin-bottom:14px;color:#222}.feature-card p{font-size:16px;color:#666;line-height:1.6}.feature-card{padding:40px;border-radius:24px;background:#ffffffe6;border:1px solid #eee;box-shadow:0 10px 30px #0000000d;transition:all .35s ease;position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#c628281f,#e11d481f);opacity:0;transition:opacity .35s ease}.feature-card:hover:before{opacity:1}.feature-card:hover{transform:translateY(-6px);box-shadow:0 25px 60px #0000001f}.feature-card>*{position:relative;z-index:1}@media(max-width:900px){.features-grid{grid-template-columns:1fr}.features-section{padding:80px 0}}.how-section{padding-top:120px;padding-bottom:50px;background:#fff;position:relative}.how-container{max-width:1200px;margin:0 auto;padding:0 40px}.how-header{text-align:center;margin-bottom:100px}.how-badge{display:inline-block;padding:8px 18px;background:#fde8e8;color:#c62828;border-radius:50px;font-weight:500;margin-bottom:20px}.how-header h2{font-size:42px;font-weight:700;margin-bottom:20px}.how-header p{font-size:18px;color:#666}.timeline{position:relative}.progress-line{position:absolute;top:64px;left:0;right:0;height:4px;background:#eee;display:none}.progress-fill{height:100%;background:linear-gradient(to right,#c62828,#e11d48);width:0%}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;position:relative}.step-card{text-align:center;position:relative}.icon-wrapper{position:relative;margin-bottom:40px}.icon-circle{width:130px;height:130px;border-radius:50%;background:linear-gradient(to bottom right,#c62828,#e11d48);display:flex;align-items:center;justify-content:center;margin:0 auto;position:relative;box-shadow:0 20px 40px #c6282866}.step-number{position:absolute;top:-10px;right:-10px;width:38px;height:38px;background:#fff;border-radius:50%;font-weight:700;color:#c62828;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 15px #0000001a}.step-card h3{font-size:22px;font-weight:600;margin-bottom:16px}.step-card p{color:#666;font-size:16px;max-width:280px;margin:0 auto}.bottom-cta{margin-top:100px;display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center}.bottom-cta p{margin-bottom:24px;color:#666}.how-primary-btn{padding:16px 32px;width:200px;background:linear-gradient(to right,#c62828,#e11d48);color:#fff;border:none;border-radius:18px;font-weight:500;cursor:pointer;box-shadow:0 15px 35px #c628284d;transition:transform .3s ease}.primary-btn:hover{transform:scale(1.05)}@media(min-width:1024px){.progress-line{display:block}}@media(max-width:900px){.steps-grid{grid-template-columns:1fr;gap:60px}.how-section{padding:80px 0}}.landing-dashboard-section{padding:105px 0;background-color:#fff}.landing-dashboard-container{margin:0 auto;padding:0 40px}.landing-dashboard-header{text-align:center;margin-bottom:80px;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;justify-content:center;align-items:center}.dasboard-badge{width:200px;padding:12px 28px;margin-right:8px;background:#fde8e8;font-size:15px;color:#c62828;border-radius:50px;margin-bottom:20px}.landing-dashboard-header h2{font-size:42px;margin-bottom:20px;line-height:1.2}.landing-dashboard-header p{color:#666;font-size:18px;line-height:1.6;max-width:600px;margin:0 auto}.landing-dashboard-wrapper{display:flex;justify-content:center;perspective:1000px}.landing-dashboard-card{width:100%;max-width:1000px;background:#fff;border-radius:30px;padding:40px;box-shadow:0 40px 80px #0000001a;transition:transform .3s ease}.landing-dashboard-top{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to right,#c62828,#e11d48);padding:24px;border-radius:20px;color:#fff;margin-bottom:40px}.landing-date-badge{background:#fff3;padding:8px 14px;border-radius:12px}.landing-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:40px}.landing-stat-card{background:#fafafa;padding:20px;border-radius:18px;transition:all .3s ease}.landing-stat-card:hover{box-shadow:0 15px 35px #00000014}.landing-stat-icon{width:40px;height:40px;border-radius:10px;margin-bottom:12px;display:flex;align-items:center;justify-content:center}.landing-stat-card.blue .landing-stat-icon{background:#3b82f6}.landing-stat-card.green .landing-stat-icon{background:#16a34a}.landing-stat-card.purple .landing-stat-icon{background:#9333ea}.landing-stat-card.orange .landing-stat-icon{background:#ea580c}.landing-stat-label{font-size:14px;color:#666}.landing-stat-value{font-size:24px;font-weight:700;margin-top:6px}.landing-chart-section h4{margin-bottom:20px}.landing-chart-bars{display:flex;align-items:flex-end;gap:12px;height:180px}.landing-bar-wrapper{flex:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center}.landing-bar{width:100%;background:linear-gradient(to top,#c62828,#f43f5e);border-radius:8px 8px 0 0}.landing-bar-wrapper span{font-size:12px;margin-top:6px;color:#666}.landing-dashboard-features{display:grid;grid-template-columns:repeat(3,1fr);margin-top:60px;text-align:center;gap:40px}.landing-dashboard-features strong{display:block;margin-bottom:6px}.landing-dashboard-features span{color:#666}.landing-charts-row{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:center;margin-top:20px}.landing-landing-bar-chart{width:100%}.landing-pie-chart{display:flex;flex-direction:column;align-items:center;justify-content:center}.landing-pie{width:180px;height:180px;border-radius:50%;background:conic-gradient(#e11d48 0% 88%,#e0e0e0 88% 100%);margin-bottom:20px;box-shadow:0 20px 40px #00000014}.landing-pie-labels{font-size:14px;color:#555}.landing-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.landing-dot.present{background:#e11d48}.landing-dot.absent{background:#cdcdcd}@media(max-width:900px){.landing-charts-row{grid-template-columns:1fr;gap:30px}.landing-pie{width:150px;height:150px}}@media(max-width:1024px){.landing-dashboard-container{padding:0 24px}.landing-dashboard-header h2{font-size:34px}.landing-dashboard-header p{font-size:16px}.landing-dashboard-card{padding:30px}.landing-stats-grid{grid-template-columns:repeat(2,1fr)}.landing-dashboard-features{grid-template-columns:1fr 1fr;gap:30px}}@media(max-width:768px){.landing-dashboard-section{padding:60px 0}.landing-dashboard-container{padding:0 18px}.landing-dashboard-header{margin-bottom:50px;align-items:center}.landing-dashboard-header h2{font-size:28px;line-height:1.3}.landing-dashboard-header p{font-size:15px}.how-badge{font-size:13px;width:200px}.landing-dashboard-card{padding:20px;border-radius:20px}.landing-dashboard-top{flex-direction:column;gap:12px;text-align:center}.landing-stats-grid{grid-template-columns:1fr;gap:16px}.landing-stat-value{font-size:20px}.landing-chart-bars{height:140px;gap:8px}.landing-bar-wrapper span{font-size:11px}.landing-dashboard-features{grid-template-columns:1fr;gap:24px;margin-top:40px}}@media(max-width:480px){.landing-dashboard-header h2{font-size:22px}.landing-dashboard-header p{font-size:14px}.landing-dashboard-card,.landing-dashboard-top,.landing-stat-card{padding:16px}.landing-chart-bars{height:120px}}.footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:0 0 40px}.footer-container{max-width:1200px;margin:0 auto;padding:0 40px}.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:60px;margin-bottom:60px}.footer-column h4{font-weight:700;margin-bottom:20px;color:#111827}.footer-column ul{list-style:none;padding:0}.footer-column li{margin-bottom:12px}.footer-column a{text-decoration:none;color:#6b7280;transition:color .3s ease}.footer-column a:hover{color:#c62828}.footer-bottom{border-top:1px solid #e5e7eb;padding-top:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.footer-brand{display:flex;justify-content:center;align-items:center;gap:12px}.logo-box{width:40px;height:40px;background:linear-gradient(to bottom right,#c62828,#e11d48);border-radius:12px;color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;margin-top:14px}.brand-name{font-weight:700;color:#111827}.copyright{font-size:14px;color:#6b7280}.social-links{display:flex;gap:12px}.social-icon{width:40px;height:40px;border-radius:50%;background:#f3f4f6;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .3s ease;text-decoration:none}.social-icon:hover{background:#c62828;color:#fff}@media(max-width:900px){.footer-grid{grid-template-columns:repeat(2,1fr);gap:40px}.footer-bottom{flex-direction:column;text-align:center}}@media(max-width:600px){.footer-grid{grid-template-columns:1fr}}:root{--primary: #e11d48;--bg: #f8fafc;--text-dark: #0f172a;--text-light: #64748b}body{margin:0;font-family:Inter,sans-serif;background:var(--bg)}.register-auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px}.register-auth-card{width:100%;max-width:920px;background:#fff;padding:30px 28px;border-radius:24px;box-shadow:0 30px 60px #00000014}.register-auth-header{text-align:center;margin-bottom:32px}.register-logo-box{height:60px;width:60px;border-radius:18px;background:linear-gradient(135deg,#e11d48,#be123c);display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 18px}.register-role-selector{position:relative;display:flex;background:#f1f5f9;padding:6px;border-radius:14px;margin-bottom:32px}.register-role-selector:before{content:"";position:absolute;top:6px;left:6px;width:calc(50% - 6px);height:calc(100% - 12px);background:#fff;border-radius:10px;transition:.3s ease}.register-role-selector.register-faculty:before{transform:translate(100%)}.register-role-btn{flex:1;border:none;background:transparent;font-weight:600;padding:10px;cursor:pointer;z-index:1;display:flex;gap:6px;justify-content:center;align-items:center}.register-active{color:var(--primary)}.register-form-grid-layout{display:grid;grid-template-columns:1fr 1fr;gap:22px 28px}.register-form-column{display:flex;flex-direction:column;gap:18px}.register-full-width{grid-column:span 2}.register-outlined-input{position:relative}.register-outlined-input input{width:100%;height:50px;padding:18px 16px;font-size:medium;border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc;outline:none;transition:.2s ease}.register-outlined-input input:focus{border-color:var(--primary);background:#fff}.register-outlined-input label{position:absolute;left:14px;top:50%;transform:translateY(-50%);background:var(--bg);padding:0 8px;font-size:14px;color:var(--text-light);transition:.2s ease}.register-outlined-input input:focus+label,.register-outlined-input input:not(:placeholder-shown)+label{top:0;font-size:12px;color:var(--primary)}.register-eye-btn{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:12px;color:var(--primary)}.register-error-text{font-size:12px;color:var(--primary);margin-top:6px}.register-submit-btn{background:var(--primary);color:#fff;border:none;padding:14px;border-radius:14px;cursor:pointer;font-weight:600;transition:.2s ease}.register-submit-btn:hover:not(:disabled){opacity:.9}.register-submit-btn:disabled{opacity:.6;cursor:not-allowed}.register-logo-box p{color:#fff;font-weight:700;font-size:28px}.register-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top:2px solid white;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.register-pw-strength{display:flex;gap:4px;margin-top:6px}.register-bar{flex:1;height:4px;background:#e5e7eb;border-radius:4px}.register-outlined-input label{pointer-events:none}.register-pw-strength.register-s1 .register-bar:nth-child(1),.register-pw-strength.register-s2 .register-bar:nth-child(-n+2),.register-pw-strength.register-s3 .register-bar:nth-child(-n+3),.register-pw-strength.register-s4 .register-bar{background:var(--primary)}.register-footer-text{text-align:center;font-size:12px;color:#94a3b8;margin-top:24px}.register-image-wrapper{grid-column:span 2;display:flex;justify-content:center;margin-bottom:10px}.register-image-upload{display:flex;justify-content:center;margin-bottom:10px}.register-image-label{height:110px;width:110px;border-radius:50%;background:#f1f5f9;border:2px dashed #e2e8f0;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:.2s ease}.register-image-label:hover{border-color:var(--primary)}.register-image-label img{width:100%;height:100%;object-fit:cover}.register-image-label span{font-size:12px;color:var(--text-light);text-align:center;padding:10px}@media(max-width:900px){.register-form-grid-layout{grid-template-columns:1fr}.register-full-width{grid-column:span 1}.register-auth-card{padding:28px}}
