*{box-sizing:border-box;margin:0;padding:0}body{font-family:Times New Roman,Times,serif;font-size:16px;line-height:1.6}@keyframes slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.animate-slide-in{animation:slide-in .3s ease-out}.animate-fade-in{animation:fade-in .3s ease-out}.animate-slide-up{animation:slide-up .3s ease-out}.login-page{align-items:center;background:linear-gradient(135deg,#1e3a8a,#1e40af);display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:1rem}.login-card{background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-width:32rem;overflow:hidden;width:100%}.login-header{background:linear-gradient(90deg,#1e3a8a,#1e40af);color:#fff;padding:1.5rem;text-align:center}.login-header img{border:3px solid #fff;border-radius:50%;box-shadow:0 4px 12px #0000001a;height:70px;margin-bottom:.75rem;width:70px}.login-header h1{font-size:1.5rem;font-weight:800;line-height:1.3;margin-bottom:.5rem}.login-header p{font-size:.875rem;line-height:1.4;margin-bottom:.25rem}.login-form{padding:1.5rem}.login-page .form-group label{color:#fff!important}.form-group{margin-bottom:1rem}.form-group label{color:#050608;font-size:.875rem;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a;outline:none}.password-group{position:relative}.password-toggle{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.25rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.captcha-group{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.captcha-code{background:linear-gradient(90deg,#e5e7eb,#d1d5db);border:2px solid #9ca3af;border-radius:.5rem;color:#0f172a;flex:1 1;font-family:Courier New,monospace;font-size:1.3rem;letter-spacing:.25em;overflow:hidden;padding:.75rem 1rem;text-align:center;text-overflow:ellipsis;-webkit-user-select:none;user-select:none}.captcha-refresh{align-items:center;background:#f3f4f6;border:2px solid #d1d5db;border-radius:.5rem;cursor:pointer;display:flex;justify-content:center;padding:.75rem;transition:all .2s}.captcha-refresh:hover{background:#e5e7eb}.form-row{flex-wrap:wrap;font-size:.875rem;justify-content:space-between;margin-bottom:1.5rem}.checkbox-label,.form-row{align-items:center;display:flex;gap:.5rem}.checkbox-label{cursor:pointer;flex-shrink:0}.forgot-link{background:none;border:none;color:#1e40af;cursor:pointer;font-size:.875rem;white-space:nowrap}.forgot-link:hover{text-decoration:underline}.btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.btn-full{width:100%}.btn-primary{background:linear-gradient(90deg,#1e40af,#1e3a8a);color:#fff}.btn-primary:hover{background:linear-gradient(90deg,#1e3a8a,#1e1b4b);box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.btn-secondary{background:#f3f4f6;border:2px solid #d1d5db;color:#374151}.btn-secondary:hover{background:#e5e7eb;transform:translateY(-2px)}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669;transform:translateY(-2px)}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706;transform:translateY(-2px)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-2px)}.btn-sm{font-size:.875rem;padding:.5rem 1rem}.demo-info{background:#f9fafb;border-left:4px solid #1e40af;border-radius:.5rem;font-size:.875rem;margin-top:1.5rem;padding:1rem}.demo-info strong{color:#1e40af}.footer{background:#f9fafb;border-top:1px solid #e5e7eb;color:#6b7280;font-size:.875rem;padding:1rem;text-align:center}.footer p{margin-bottom:.5rem}.app{background:#f8fafc;display:flex;height:100vh;overflow:hidden}.sidebar{background:linear-gradient(180deg,#111827,#1f2937);box-shadow:2px 0 10px #0000001a;color:#fff;display:flex;flex-direction:column;position:relative;transition:width .3s ease;width:16rem;z-index:50}.sidebar.collapsed{width:5rem}.sidebar-header{border-bottom:1px solid #374151;gap:.75rem;padding:1rem}.sidebar-avatar,.sidebar-header{align-items:center;display:flex;flex-shrink:0}.sidebar-avatar{background:linear-gradient(135deg,#1e40af,#1e3a8a);border-radius:9999px;color:#fff;font-size:1.25rem;font-weight:700;height:3rem;justify-content:center;min-width:3rem;width:3rem}.sidebar-user-info{flex:1 1;min-width:0;overflow:hidden}.sidebar-user-info p{font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-info p:last-child{font-size:.75rem;opacity:.6}.sidebar-nav{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:1rem}.nav-item{align-items:center;background:none;border:none;border-radius:.5rem;color:#d1d5db;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem;text-align:left;transition:all .2s;white-space:nowrap;width:100%}.nav-item:hover{background:#374151}.nav-item.active{background:linear-gradient(90deg,#1e40af,#1e3a8a);box-shadow:0 2px 8px #1e40af4d;color:#fff}.nav-item svg{flex-shrink:0}.sidebar-status{border-top:1px solid #374151;color:#9ca3af;flex-shrink:0;font-size:.75rem;padding:1rem}.status-item{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.status-dot{background:#10b981;border-radius:9999px;flex-shrink:0;height:.5rem;width:.5rem}.header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;flex:none;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem}.header,.header-left{align-items:center;display:flex}.header-left{flex:1 1;gap:.75rem;min-width:0}.header-toggle{align-items:center;background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.5rem;transition:color .2s}.header-toggle:hover{background:#f3f4f6;color:#111827}.header-brand{align-items:center;display:flex;gap:.75rem;min-width:0}.header-brand img{flex-shrink:0;height:40px;width:40px}.header-brand>div{min-width:0}.header-brand h2{color:#111827;font-size:1rem;font-weight:800}.header-brand h2,.header-brand h3{line-height:1.3;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-brand h3{color:#6b7280;font-size:.75rem;font-weight:600}.header-brand p{color:#6b7280;font-size:.7rem;line-height:1.3;margin:0}.header-right{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.role-badge{background:linear-gradient(90deg,#1e40af,#1e3a8a);border-radius:9999px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.user-avatar{background:linear-gradient(135deg,#1e40af,#1e3a8a);border-radius:9999px;flex-shrink:0;font-size:1.125rem;font-weight:700;height:2.5rem;justify-content:center;min-width:2.5rem;width:2.5rem}.logout-btn,.user-avatar{align-items:center;color:#fff;cursor:pointer;display:flex}.logout-btn{background:#ef4444;border:none;border-radius:.5rem;font-size:.875rem;gap:.5rem;padding:.5rem .75rem;transition:background .2s;white-space:nowrap}.logout-btn:hover{background:#dc2626}.main-content{-webkit-overflow-scrolling:touch;background:#f8fafc;flex:1 1;overflow-y:auto;padding:1.5rem}.page-header{margin-bottom:1.5rem}.page-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#1e40af,#1e3a8a);-webkit-background-clip:text;background-clip:text;color:#111827;font-size:1.75rem;font-weight:800;line-height:1.2;margin-bottom:.5rem}.page-header p{color:#6b7280;font-size:1rem;line-height:1.5}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:1.5rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:1.25rem;transition:all .3s}.stat-card:hover{box-shadow:0 10px 25px #0000001a;transform:translateY(-2px)}.stat-content{align-items:center;display:flex;justify-content:space-between}.stat-number{color:#111827;font-size:1.75rem;font-weight:800;line-height:1;margin-bottom:.25rem}.stat-label{color:#6b7280;font-size:.875rem;line-height:1.4}.stat-icon{align-items:center;border-radius:.75rem;display:flex;flex-shrink:0;height:2.5rem;justify-content:center;width:2.5rem}.quick-actions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1.5rem}.action-card{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;height:100%;padding:1.25rem;text-align:left;transition:all .2s}.action-card:hover{background:#eef2ff;border-color:#1e40af;box-shadow:0 4px 12px #1e40af1a;transform:translateY(-2px)}.action-icon{color:#1e40af;height:2rem;margin-bottom:.75rem;width:2rem}.action-title{color:#111827;font-size:1.125rem;font-weight:800;line-height:1.3;margin-bottom:.25rem}.action-desc{color:#6b7280;font-size:.875rem;line-height:1.5}.card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.25rem;overflow:hidden;padding:1.25rem}.card-title{border-bottom:2px solid #e5e7eb;color:#111827;font-size:1.25rem;font-weight:700;line-height:1.3;margin-bottom:1rem;padding-bottom:.5rem}.upload-area{background:#f9fafb;border:2px dashed #d1d5db;border-radius:.5rem;cursor:pointer;padding:1.5rem;text-align:center;transition:border-color .2s}.upload-area:hover{background:#eef2ff;border-color:#1e40af}.upload-icon{color:#9ca3af;height:3rem;margin:0 auto 1rem;width:3rem}.form-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.btn-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.btn-group .btn{flex:1 1;min-width:120px}.table-container{-webkit-overflow-scrolling:touch;border:1px solid #e5e7eb;border-radius:.5rem;margin:1rem 0;overflow-x:auto}table{border-collapse:collapse;min-width:600px;width:100%}th{background:#f9fafb;border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;text-align:left;white-space:nowrap}td,th{font-size:.875rem;padding:.75rem 1rem}td{border-bottom:1px solid #e5e7eb}tr:hover{background:#f9fafb}.status-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.status-active{background:#d1fae5;color:#065f46}.status-inactive{background:#f3f4f6;color:#374151}.status-completed{background:#dbeafe;color:#1e40af}.status-rejected{background:#fee2e2;color:#991b1b}.status-waiting{background:#fef3c7;color:#92400e}.action-buttons{gap:.5rem}.action-btn{align-items:center;border:none;border-radius:.25rem;cursor:pointer;display:flex;flex-shrink:0;height:2rem;justify-content:center;padding:.5rem;transition:all .2s;width:2rem}.edit-btn{color:#3b82f6}.edit-btn:hover{background:#dbeafe}.delete-btn{color:#ef4444}.delete-btn:hover{background:#fee2e2}.view-btn{color:#10b981}.view-btn:hover{background:#d1fae5}.profile-card{background:linear-gradient(135deg,#1e40af,#1e3a8a);border-radius:.75rem;box-shadow:0 20px 60px #0000001a;color:#fff;margin-bottom:1.5rem;padding:1.5rem}.profile-avatar{align-items:center;background:#fff;border:4px solid #ffffff4d;border-radius:9999px;box-shadow:0 10px 30px #0003;color:#1e40af;display:flex;font-size:1.75rem;font-weight:800;height:5rem;justify-content:center;margin:0 auto 1.5rem;width:5rem}.profile-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1.5rem}.info-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;height:100%;padding:1.25rem;transition:transform .2s}.info-card:hover{transform:translateY(-2px)}.info-card h3{align-items:center;border-bottom:2px solid #e5e7eb;color:#1e40af;display:flex;font-size:1.125rem;gap:.5rem;line-height:1.3;margin-bottom:1rem;padding-bottom:.5rem}.info-item{border-bottom:1px solid #f3f4f6;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;padding:.75rem 0}.info-item:last-child{border-bottom:none}.info-label{color:#6b7280;flex-shrink:0;font-size:.875rem;font-weight:600}.info-value{color:#111827;flex:1 1;font-size:.875rem;font-weight:500;min-width:0;overflow-wrap:break-word;text-align:right}.notification{align-items:center;border-radius:.5rem;box-shadow:0 10px 25px #0000001a;color:#fff;display:flex;gap:.75rem;left:1rem;margin:0 auto;max-width:400px;padding:1rem 1.25rem;position:fixed;right:1rem;top:1rem;z-index:1000}.notification.success{background:#10b981}.notification.error{background:#ef4444}.notification.info{background:#3b82f6}.notification.warning{background:#f59e0b}.modal{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;overflow-y:auto;padding:1rem;position:fixed;top:0;width:100%;z-index:1001}.modal-header{flex-shrink:0}.modal-footer{flex-wrap:wrap}.modal-close{font-size:1.5rem}.hidden{display:none!important}.subject-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:1.5rem}.subject-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;cursor:pointer;height:100%;padding:1.25rem;transition:all .2s}.subject-card:hover{border-color:#1e40af;box-shadow:0 4px 12px #1e40af1a}.subject-card.selected{background:#f0fdf4;border-color:#10b981}.subject-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:.75rem}.subject-code{background:#1e40af;border-radius:9999px;color:#fff;flex-shrink:0;font-size:.75rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.subject-name{color:#111827;flex:1 1;font-size:1.125rem;font-weight:700;line-height:1.3;margin-bottom:.5rem;min-width:0}.subject-details{color:#6b7280;display:flex;flex-wrap:wrap;font-size:.875rem;gap:1rem;margin-bottom:1rem}.subject-credits,.subject-semester{align-items:center;display:flex;gap:.25rem;white-space:nowrap}.exam-form-header{background:linear-gradient(135deg,#1e3a8a,#1e40af);border-radius:.75rem;box-shadow:0 10px 30px #1e40af33;color:#fff;margin-bottom:1.5rem;padding:1.5rem;text-align:center}.exam-form-title{font-size:1.5rem;font-weight:800;line-height:1.3;margin-bottom:.5rem}.exam-form-subtitle{font-size:1.125rem;line-height:1.4;margin-bottom:1rem;opacity:.9}.form-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.25rem}.form-section-title{align-items:center;border-bottom:2px solid #e5e7eb;color:#1e40af;display:flex;font-size:1.125rem;gap:.5rem;line-height:1.3;margin-bottom:1rem;padding-bottom:.5rem}.subject-table{border:1px solid #e5e7eb;min-width:400px;width:100%}.subject-table th{background:#1e40af;color:#fff;text-align:center}.subject-table td{text-align:center}.signature-area{border-top:2px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin-top:2rem;padding-top:1.5rem}.signature-box{flex:1 1;min-width:150px;text-align:center}.signature-line{background:#374151;height:1px;margin:1.5rem 0 .5rem;width:100%}.search-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.search-input{flex:1 1;min-width:200px;padding:.75rem 1rem}.guide-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.guide-card{background:#fff;border-radius:.75rem;height:100%;padding:1.25rem;transition:all .2s}.guide-card:hover{border-color:#1e40af;box-shadow:0 4px 12px #1e40af1a}.guide-name{color:#111827;font-size:1.125rem;font-weight:700;line-height:1.3;margin-bottom:.5rem}.guide-department{color:#6b7280;font-size:.875rem;line-height:1.4;margin-bottom:.5rem}.student-subject-request{background:#f0f9ff;border:1px solid #dbeafe;border-radius:.75rem;margin-bottom:1rem;padding:1.25rem}.subject-request-status{border-radius:9999px;display:inline-block;font-size:.875rem;font-weight:600;margin-bottom:1rem;padding:.25rem .75rem;white-space:nowrap}.password-strength{background:#e5e7eb;border-radius:2px;height:4px;margin-top:.5rem;overflow:hidden}.password-strength-fill{height:100%;transition:width .3s}.password-strength.weak .password-strength-fill{background:#ef4444;width:33%}.password-strength.medium .password-strength-fill{background:#f59e0b;width:66%}.password-strength.strong .password-strength-fill{background:#10b981;width:100%}.semester-selector{margin-bottom:1.5rem}.semester-tabs{-webkit-overflow-scrolling:touch;display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.5rem}.semester-tab{background:#fff;border:2px solid #d1d5db;border-radius:.5rem;cursor:pointer;flex-shrink:0;font-weight:600;padding:.75rem 1.25rem;transition:all .2s;white-space:nowrap}.semester-tab.active{background:#1e40af;border-color:#1e40af;color:#fff}.selected-subjects-list{background:#f0fdf4;border:2px solid #10b981;border-radius:.75rem;margin-bottom:1.5rem;padding:1.25rem}.selected-subjects-list h4{align-items:center;color:#065f46;display:flex;font-size:1.125rem;gap:.5rem;line-height:1.3;margin-bottom:1rem}.tabs{-webkit-overflow-scrolling:touch;border-bottom:2px solid #e5e7eb;display:flex;margin-bottom:1.25rem;overflow-x:auto}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;flex-shrink:0;font-weight:600;margin-bottom:-2px;padding:.75rem 1.25rem;transition:all .2s;white-space:nowrap}.tab.active{border-bottom:2px solid #1e40af;color:#1e40af}.tab-content{display:none}.tab-content.active{display:block}.form-control{border:2px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem 1rem;width:100%}.form-control:focus{border-color:#1e40af;outline:none}.login-type{display:flex;gap:.75rem;margin-bottom:1rem}.login-type-btn{background:#fff;border:2px solid #d1d5db;border-radius:.5rem;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.75rem;text-align:center;transition:all .2s;white-space:nowrap}.login-type-btn.active{background:#1e40af;border-color:#1e40af;color:#fff}.modal-backdrop{background:#00000080;height:100%;left:0;position:fixed;top:0;width:100%;z-index:1000}@media (min-width:1200px){.sidebar{width:18rem}.sidebar.collapsed{width:5rem}.main-content{padding:2rem}.stats-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:768px) and (max-width:1199px){.quick-actions-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}.profile-grid{grid-template-columns:1fr}.guide-list,.subject-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:767px){.login-page{padding:.5rem}.login-card{border-radius:.75rem}.login-header{padding:1.25rem}.login-header h1{font-size:1.25rem}.login-header p{font-size:.75rem}.login-form{padding:1.25rem}.app{flex-direction:column;height:100vh;overflow:hidden}.sidebar{height:calc(100vh - 4rem);left:0;position:absolute;top:4rem;transform:translateX(-100%);transition:transform .3s ease;width:100%;z-index:100}.sidebar.open{transform:translateX(0)}.sidebar.collapsed{width:100%}.header{padding:.75rem 1rem;position:relative;z-index:101}.header-left{flex:1 1}.header-brand h2{font-size:.875rem}.header-brand h3{font-size:.7rem}.header-brand p{font-size:.65rem}.header-right{flex-wrap:wrap;justify-content:flex-end}.role-badge{font-size:.7rem;padding:.2rem .5rem}.logout-btn{font-size:.75rem;padding:.4rem .6rem}.logout-btn span{display:none}.main-content{-webkit-overflow-scrolling:touch;overflow-y:auto;padding:1rem}.page-header h1{font-size:1.5rem}.page-header p{font-size:.875rem}.stats-grid{gap:.75rem;grid-template-columns:1fr}.stat-card{padding:1rem}.stat-number{font-size:1.5rem}.quick-actions-grid{gap:.75rem;grid-template-columns:1fr}.action-card,.card{padding:1rem}.card{margin-bottom:1rem}.card-title{font-size:1.125rem}.upload-area{padding:1rem}.form-grid{gap:1rem;grid-template-columns:1fr}.btn-group{flex-direction:column}.btn-group .btn{width:100%}.profile-card{padding:1.25rem}.profile-avatar{font-size:1.5rem;height:4rem;width:4rem}.profile-grid{gap:1rem;grid-template-columns:1fr}.info-card{padding:1rem}.subject-grid{gap:.75rem;grid-template-columns:1fr}.subject-card{padding:1rem}.subject-name{font-size:1rem}.exam-form-header{padding:1.25rem}.exam-form-title{font-size:1.25rem}.exam-form-subtitle{font-size:1rem}.form-section{padding:1rem}.signature-area{flex-direction:column;gap:1.5rem}.signature-box{width:100%}.search-bar{flex-direction:column}.search-input{width:100%}.guide-list{gap:.75rem;grid-template-columns:1fr}.guide-card,.student-subject-request{padding:1rem}.semester-tabs{gap:.25rem}.semester-tab{font-size:.875rem;padding:.5rem .75rem}.selected-subjects-list{padding:1rem}.tabs{gap:.25rem}.tab{font-size:.875rem;padding:.5rem .75rem}.login-type{flex-direction:column}.login-type-btn{width:100%}.sidebar.collapsed .nav-item span,.sidebar.collapsed .sidebar-user-info,.sidebar.collapsed .sidebar-user-info span{display:none}.sidebar.collapsed .sidebar-header{justify-content:center}.notification{left:.5rem;max-width:none;right:.5rem}.modal{padding:.5rem}.modal-content{max-height:95vh;max-width:100%}.modal-body,.modal-footer,.modal-header{padding:1rem}}@media (max-width:480px){.login-header h1{font-size:1.125rem}.login-header p{font-size:.7rem}.header-brand img{height:32px;width:32px}.user-avatar{font-size:1rem;height:2rem;width:2rem}.page-header h1{font-size:1.25rem}.card-title,.form-section-title{font-size:1rem}.subject-name{font-size:.875rem}.exam-form-title{font-size:1.125rem}.btn,.exam-form-subtitle{font-size:.875rem}.btn{padding:.625rem 1rem}.table-container{border-left:none;border-radius:0;border-right:none;margin-left:-.5rem;margin-right:-.5rem}table{font-size:.75rem}td,th{padding:.5rem}}@media (max-height:600px) and (orientation:landscape){.login-page{align-items:flex-start;overflow-y:auto;padding-top:1rem}.login-card{max-height:90vh;overflow-y:auto}.app{height:100vh}.main-content{padding:1rem}}@media print{.action-buttons,.btn,.header,.modal,.role-badge,.search-bar,.sidebar,.tabs{display:none!important}.app{background:#fff;display:block;height:auto}.main-content{background:#fff;padding:0}.card,.form-section{border:1px solid #e5e7eb;box-shadow:none;page-break-inside:avoid}.exam-form-header{box-shadow:none}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.login-card{box-shadow:0 20px 60px -12px #0000004d}.action-card,.card,.stat-card{box-shadow:0 2px 6px #0000001a}.notification{box-shadow:0 15px 35px #00000026}}@media (prefers-color-scheme:dark){.login-page{background:linear-gradient(135deg,#0f172a,#1e293b)}.login-card{background:#1f2937;color:#e5e7eb}.login-header{background:linear-gradient(90deg,#0f172a,#1e293b)}.form-group label{color:#0c0d0f}.form-group input,.form-group select,.form-group textarea{background:#fff;border-color:#4b5563;color:#060708}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.captcha-refresh{background:#4b5563;border-color:#6b7280;color:#d1d5db}.demo-info{background:#374151;border-left-color:#3b82f6}.footer{background:#1f2937;border-top-color:#374151;color:#9ca3af}}.search-input-wrapper{flex:1 1;position:relative}.search-icon{color:#9ca3af;left:12px;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.search-input{border:2px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem 1rem .75rem 2.5rem;width:100%}.search-input:focus{border-color:#1e40af;outline:none}.clear-search{background:#ef4444;color:#fff;right:12px;z-index:2}.clear-search:hover{background:#dc2626}.no-results{background:#f9fafb;border:2px dashed #d1d5db;border-radius:.5rem;color:#6b7280;font-size:1.125rem;grid-column:1/-1;padding:3rem;text-align:center}.password-input-group{position:relative}.password-toggle-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:.25rem;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.edit-modal,.password-toggle-btn{align-items:center;display:flex;justify-content:center}.edit-modal{background:#00000080;height:100%;left:0;padding:1rem;position:fixed;top:0;width:100%;z-index:1000}.edit-modal-content{background:#fff;border-radius:1rem;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.edit-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem}.edit-modal-body{padding:1.25rem}.edit-modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;padding:1.25rem}.confirmation-dialog{background:#fff;border-radius:.75rem;max-width:400px;padding:1.5rem;text-align:center;width:100%}.confirmation-dialog h3{color:#111827;margin-bottom:1rem}.confirmation-dialog p{color:#6b7280;margin-bottom:1.5rem}.confirmation-buttons{display:flex;gap:1rem;justify-content:center}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dialog-overlay{align-items:center;animation:fade-in .2s ease-out;background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.dialog-content{animation:slide-up .3s ease-out;background:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-width:400px;overflow:hidden;width:100%}.dialog-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.dialog-title{color:#111827;font-size:1.25rem;font-weight:700;margin:0}.dialog-close{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;padding:.25rem}.dialog-body{padding:1.5rem}.dialog-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;padding:1.5rem}.dialog-message{color:#6b7280;line-height:1.5;margin-bottom:1.5rem}.dialog-icon{margin-bottom:1rem;text-align:center}.dialog-icon-danger{color:#ef4444}.dialog-icon-warning{color:#f59e0b}.dialog-icon-success{color:#10b981}.dialog-icon-info{color:#3b82f6}.dialog-btn{border:none;border-radius:.5rem;cursor:pointer;flex:1 1;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.dialog-btn-cancel{background:#f3f4f6;color:#374151}.dialog-btn-cancel:hover{background:#e5e7eb}.dialog-btn-confirm{background:#ef4444;color:#fff}.dialog-btn-confirm:hover{background:#dc2626}.dialog-btn-warning{background:#f59e0b;color:#fff}.dialog-btn-warning:hover{background:#d97706}.dialog-btn-success{background:#10b981;color:#fff}.dialog-btn-success:hover{background:#059669}.dialog-btn-info{background:#3b82f6;color:#fff}.dialog-btn-info:hover{background:#2563eb}.modal-overlay{align-items:center;animation:fade-in .2s ease-out;background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.modal-content{animation:slide-up .3s ease-out;background:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-width:500px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem}.modal-header h3{color:#111827;font-size:1.25rem;font-weight:700;margin:0}.modal-close{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.25rem}.modal-close:hover{color:#111827}.modal-body,.modal-footer{padding:1.25rem}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end}.assign-btn{color:#3b82f6!important}.assign-btn:hover{background:#dbeafe!important}.w-full{width:100%}.px-2{padding-left:.5rem;padding-right:.5rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.border{border:1px solid #d1d5db}.rounded{border-radius:.25rem}.flex{display:flex}.items-center{align-items:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.text-yellow-500{color:#f59e0b}.text-blue-600{color:#2563eb}.form-control-sm{border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;line-height:1.5;padding:.25rem .5rem;width:100%}.clear-search{background:#f3f4f6;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;position:absolute;right:40px;top:50%;transform:translateY(-50%);z-index:1}.clear-search:hover{background:#e5e7eb}.subject-card.selected{background:#eff6ff;border-color:#3b82f6}.subject-card.has-request{background:#f0fdf4;border-color:#10b981}.subject-card.selected .subject-name{color:#1e40af}.subject-card.has-request .subject-name{color:#065f46}.btn:disabled{cursor:not-allowed;opacity:.5}.status-indicator{border-radius:.25rem;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.status-selected{background:#dbeafe;color:#1e40af}.status-pending{background:#fef3c7;color:#92400e}.status-approved{background:#d1fae5;color:#065f46}.subject-selection-grid{grid-gap:.75rem;border:1px solid #d1d5db;border-radius:.5rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));max-height:400px;overflow-y:auto;padding:.5rem}.subject-selection-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;padding:1rem;transition:all .2s}.subject-selection-card:hover{background:#f9fafb;border-color:#d1d5db}.subject-selection-card.selected{background:#e0f2fe;border-color:#38bdf8;box-shadow:0 0 0 1px #38bdf8}.subject-selection-card .subject-code{background:#1e40af;border-radius:9999px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.subject-selection-card input[type=checkbox]{appearance:none;-webkit-appearance:none;background:#fff;border:2px solid #d1d5db;border-radius:.25rem;cursor:pointer;height:20px;position:relative;width:20px}.subject-selection-card input[type=checkbox]:checked{background:#3b82f6;border-color:#3b82f6}.subject-selection-card input[type=checkbox]:checked:after{color:#fff;content:"✓";font-size:14px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.modal-content{max-height:85vh;max-width:90%}.modal-body{max-height:60vh;overflow-y:auto}.session-badge{border-radius:9999px;font-size:.75rem;padding:.25rem .75rem}.session-both{background:#f0f9ff;color:#1e40af}.log-row:hover{background:#f9fafb}.log-details-modal{max-width:800px}.spinner{animation:spin 1s linear infinite}.modal-content{max-height:90vh;overflow-y:auto}.hall-ticket-table th{background:#1e40af;border:1px solid #d1d5db;color:#fff;padding:8px;text-align:center}.hall-ticket-table td{border:1px solid #d1d5db;padding:8px;vertical-align:middle}.session-badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:4px 8px;text-transform:uppercase}.session-morning{background:#fef3c7;color:#92400e}.session-afternoon{background:#dbeafe;color:#1e40af}.session-evening{background:#f3e8ff;color:#7c3aed}.hall-ticket-watermark{color:#1e40af1a;font-size:60px;font-weight:700;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%) rotate(-45deg);white-space:nowrap;z-index:0}@media print{.hall-ticket-container{border:2px solid #1e40af!important;margin:0!important;padding:20px!important}.hall-ticket-header{border-bottom:2px solid #1e40af;margin-bottom:20px;text-align:center}.no-print{display:none!important}}.rc-committee-container{display:flex;flex-direction:column;height:100%;padding:1.5rem}.rc-content{display:flex;flex:1 1;flex-direction:column}.student-avatar-small{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;color:#fff;display:flex;font-size:.875rem;font-weight:700;height:32px;justify-content:center;width:32px}.discussion-card{display:flex;flex:1 1;flex-direction:column;height:calc(100vh - 250px)}.discussion-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem}.student-header-info{margin-top:1rem}.student-header-main{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:.5rem}.student-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tag{border-radius:.375rem;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.tag.prn{background:#dbeafe;color:#1e40af}.tag.department{background:#f0f9ff;color:#0c4a6e}.tag.course{background:#f0fdf4;color:#065f46}.tag.you-guide{background:#fef3c7;color:#92400e;font-weight:600}.tag.you-co-guide{background:#f3e8ff;color:#7c3aed;font-weight:600}.guide-info{display:flex;flex-wrap:wrap;gap:1rem}.guide-card{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;gap:.5rem;min-width:200px;padding:.5rem .75rem}.guide-card.co{background:#fefce8;border-color:#fef3c7}.messages-container{background:#f9fafb;flex:1 1;overflow-y:auto;padding:1.5rem}.empty-messages{align-items:center;color:#9ca3af;display:flex;flex-direction:column;height:300px;justify-content:center}.empty-messages svg{margin-bottom:1rem}.empty-hint{color:#6b7280;font-size:.875rem;margin-top:.5rem;text-align:center}.message{background:#fff;border:1px solid #e5e7eb;border-left:4px solid #1e40af;border-radius:.75rem;margin-bottom:1.5rem;padding:1.5rem}.message.own{border-left:4px solid #10b981}.message-header{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.message-sender{align-items:center;display:flex;gap:.75rem}.main-guide-avatar{align-items:center;background:linear-gradient(135deg,#1e40af,#1d4ed8);border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:700;height:40px;justify-content:center;width:40px}.sender-name{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.sender-role.main-guide-role{background:#fef3c7;border-radius:.25rem;color:#92400e;font-size:.75rem;font-weight:600;padding:.125rem .375rem}.message-content{background:#f9fafb;border-left:3px solid #d1d5db;border-radius:.5rem;color:#374151;font-size:1rem;line-height:1.6;margin-bottom:1.5rem;padding:1rem}.responses-section{background:#f8fafc;border:1px solid #e5e7eb;border-radius:.5rem;margin-top:1rem;padding:1rem}.responses-header{color:#6b7280;font-size:.875rem;font-weight:500;margin-bottom:.75rem}.responses-list-text{display:flex;flex-direction:column;gap:.75rem}.response-item-text{background:#fff;border-radius:.5rem;padding:.75rem}.response-text{display:flex;flex-direction:column;gap:.25rem}.response-header{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.response-label{font-size:.875rem;font-weight:500}.response-sender-info{color:#6b7280;font-size:.75rem}.response-time{color:#9ca3af;font-size:.7rem;text-align:right}.response-options{background:#f0f9ff;border:1px solid #dbeafe;border-radius:.5rem;margin-top:1rem;padding:1rem}.response-options-header{color:#1e40af;font-size:.875rem;font-weight:500;margin-bottom:.75rem}.response-list-text{display:flex;flex-direction:column;gap:.5rem}.response-btn-text{background:#fff;border:1px solid;border-radius:.375rem;cursor:pointer;display:block;font-size:.875rem;padding:.75rem 1rem;text-align:left;transition:all .2s;width:100%}.response-btn-text:hover{box-shadow:0 2px 4px #0000001a;transform:translateX(5px)}.response-btn-content{align-items:center;display:flex;gap:.75rem}.current-response-box{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;margin-top:1rem;padding:1rem}.current-response-header{color:#065f46;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.current-response-text{background:#fff;border-radius:.375rem;padding:.75rem}.main-guide-input{background:#f0f9ff;border-top:2px solid #1e40af;padding:1.5rem}.input-header{margin-bottom:1rem}.input-label{color:#1e40af;font-size:1rem;font-weight:600;margin-right:.5rem}.input-wrapper{display:flex;flex-direction:column;gap:1rem}.message-input-textarea{border:1px solid #d1d5db;border-radius:.5rem;font-family:inherit;font-size:.875rem;max-height:200px;min-height:80px;padding:1rem;resize:vertical;width:100%}.message-input-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.send-btn{align-items:center;align-self:flex-end;display:flex;gap:.5rem;padding:.75rem 1.5rem}.info-panel{background:#fefce8;border-top:1px solid #fef3c7;padding:1rem 1.5rem}.info-content{align-items:center;color:#92400e;display:flex;gap:.75rem}.info-content strong{font-size:.875rem}.info-content small{display:block;font-size:.75rem;margin-top:.25rem}.card-header{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.card-header,.empty-state{align-items:center;display:flex}.empty-state{color:#9ca3af;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.empty-icon{color:#d1d5db;margin-bottom:1rem}@media (max-width:768px){.student-header-main{align-items:flex-start}.guide-info,.student-header-main{flex-direction:column}.guide-card{min-width:auto;width:100%}.response-header{align-items:flex-start;flex-direction:column;gap:.25rem}.response-sender-info{margin-left:0}.card-header{align-items:stretch;flex-direction:column}.search-bar{width:100%!important}}@media print{.hall-ticket-print{border:2px solid #1e40af!important;margin:0!important;padding:15px!important}.hall-ticket-print,.hall-ticket-print table,.hall-ticket-print td,.hall-ticket-print th,.hall-ticket-print tr{break-inside:avoid!important;page-break-inside:avoid!important}.hall-ticket-print .modal-footer,.hall-ticket-print .no-print{display:none!important}}.editing-row td{padding:8px;vertical-align:middle}.edit-input,.edit-select{background-color:#fff;border:2px solid #3b82f6;border-radius:6px;box-shadow:0 2px 4px #3b82f61a;font-size:14px;padding:8px 10px;transition:all .2s;width:100%}.edit-input:focus,.edit-select:focus{border-color:#1e40af;box-shadow:0 0 0 3px #1e40af33;outline:none}.edit-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%233b82f6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;cursor:pointer;padding-right:35px}.editing-row .action-buttons{display:flex;gap:5px;justify-content:center}.editing-row .action-btn{align-items:center;border-radius:6px;display:flex;height:32px;justify-content:center;padding:0;width:32px}.editing-row .save-btn{background-color:#10b981;color:#fff}.editing-row .save-btn:hover{background-color:#059669}.editing-row .cancel-btn{background-color:#6b7280;color:#fff}.editing-row .cancel-btn:hover{background-color:#4b5563}.payment-response-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.response-content{background:#fff;border-radius:20px;max-width:400px;padding:32px;text-align:center;width:90%}.response-content.success .response-icon{color:#10b981;margin-bottom:16px}.response-content.failure .response-icon{color:#ef4444;margin-bottom:16px}.response-content h2{font-size:24px;margin:0 0 8px}.response-content p{color:#6b7280;margin:0 0 20px}.receipt-info{background:#f3f4f6;border-radius:8px;font-size:14px;margin-bottom:24px;padding:12px}.response-actions{display:flex;gap:12px;justify-content:center}.response-actions .btn-primary,.response-actions .btn-secondary{font-size:14px;padding:10px 20px}@media (max-width:640px){.payment-modal-content{max-width:95%}.form-row{gap:0;grid-template-columns:1fr}.payment-steps{padding:20px 16px 0}.payment-step span{display:none}.step-number{height:32px;width:32px}.payment-actions.dual{flex-direction:column}.payment-actions.dual .btn-primary,.payment-actions.dual .btn-secondary{width:100%}}.payment-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.payment-modal-content{animation:slide-up .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.payment-modal-header{align-items:center;background:linear-gradient(135deg,#1e40af,#1e3a8a);border-bottom:1px solid #e5e7eb;border-radius:20px 20px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.payment-header-left{gap:12px}.payment-header-left,.uni-logo{align-items:center;display:flex}.uni-logo{background:#fff;border-radius:50%;color:#1e40af;font-size:24px;font-weight:700;height:48px;justify-content:center;width:48px}.payment-modal-header h3{font-size:18px;margin:0}.payment-modal-header p{font-size:12px;margin:0;opacity:.8}.payment-steps{gap:0;padding:24px 24px 0}.payment-step,.payment-steps{align-items:center;display:flex}.payment-step{color:#9ca3af;font-size:12px;font-weight:500;gap:8px}.payment-step.active{color:#1e40af}.payment-step.completed{color:#10b981}.step-number{align-items:center;border:2px solid;border-radius:50%;display:flex;font-size:12px;font-weight:600;height:28px;justify-content:center;width:28px}.payment-step.completed .step-number{background:#10b981;border-color:#10b981;color:#fff}.payment-step.completed .step-number:after{content:"✓";font-size:12px}.payment-step.active .step-number{background:#1e40af;border-color:#1e40af;color:#fff}.step-line{background:#e5e7eb;flex:1 1;height:2px;margin:0 12px}.payment-step-content{padding:24px}.fee-summary-card{border:1px solid #e5e7eb;border-radius:12px;margin-bottom:20px;overflow:hidden}.fee-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px 20px}.fee-header h4{font-size:16px;font-weight:600;margin:0}.fee-badge{background:#dbeafe;border-radius:20px;color:#1e40af;font-size:12px;font-weight:600;padding:4px 12px}.fee-items{padding:0 20px}.fee-item{border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:12px 0}.fee-amount{color:#111827;font-weight:600}.fee-total{background:#f0f9ff;border-top:2px solid #e5e7eb;display:flex;font-size:16px;justify-content:space-between;padding:16px 20px}.total-amount{color:#1e40af;font-size:18px}.student-info-form{margin-bottom:24px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group{margin-bottom:16px}.form-group label{color:#374151;display:block;font-size:12px;font-weight:600;margin-bottom:6px}.required{color:#ef4444}.form-group input{border:1.5px solid #e5e7eb;border-radius:8px;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#1e40af;outline:none}.form-group input.error{border-color:#ef4444}.form-group input.readonly{background:#f9fafb;color:#6b7280;cursor:not-allowed}.error-text{color:#ef4444;display:block;font-size:11px;margin-top:4px}.payment-notice{align-items:center;background:#fffbeb;border:1px solid #fde047;border-radius:8px;color:#92400e;display:flex;font-size:12px;gap:12px;margin-bottom:20px;padding:12px 16px}.payment-actions{display:flex;gap:12px;margin-top:20px}.payment-actions.dual{justify-content:space-between}.payment-actions .btn-primary,.payment-actions .btn-secondary{flex:1 1;font-size:14px;padding:12px 20px}.payment-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2100}.overlay-content{background:#fff;border-radius:16px;max-width:320px;padding:32px;text-align:center}.overlay-spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#1e40af;height:48px;margin:0 auto 20px;width:48px}.overlay-content h4{color:#111827;font-size:18px;margin:0 0 8px}.overlay-content p{color:#6b7280;font-size:12px;margin:0}@keyframes spin{to{transform:rotate(1turn)}}.payment-response-container{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e6f0fa);display:flex;justify-content:center;min-height:100vh;padding:20px}.response-card{animation:slide-up .3s ease-out;background:#fff;border-radius:24px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:40px;text-align:center;width:100%}.response-card.processing{border-top:4px solid #3b82f6}.response-card.success{border-top:4px solid #10b981}.response-card.failure{border-top:4px solid #ef4444}.response-card.error{border-top:4px solid #f59e0b}.success-icon{color:#10b981;margin-bottom:20px}.failure-icon{color:#ef4444;margin-bottom:20px}.error-icon{color:#f59e0b;margin-bottom:20px}.response-card h2{color:#111827;font-size:24px;margin-bottom:12px}.response-card p{color:#6b7280;margin-bottom:24px}.receipt-summary{background:#f9fafb;border-radius:12px;margin:20px 0;padding:20px;text-align:left}.summary-row{border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:8px 0}.summary-row:last-child{border-bottom:none}.summary-row .amount{color:#1e40af;font-size:18px}.spinner-large{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:48px;margin:0 auto 20px;width:48px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:20px}.action-buttons .btn-primary,.action-buttons .btn-secondary{font-size:14px;padding:12px 24px}@media (max-width:480px){.response-card{padding:24px}.action-buttons{flex-direction:column}.action-buttons .btn-primary,.action-buttons .btn-secondary{width:100%}}
/*# sourceMappingURL=main.f329d565.css.map*/