:root{--color-bg-primary:#fff;--color-bg-secondary:#f7f9fc;--color-bg-tertiary:#f1f3f5;--color-text-primary:#2c3e50;--color-text-secondary:#495057;--color-text-tertiary:#6c757d;--color-text-inverse:#fff;--color-border:#dee2e6;--color-border-light:#e9ecef;--color-border-dark:#ced4da;--color-accent-primary:#dc2626;--color-accent-hover:#b91c1c;--color-accent-light:#fecaca;--color-primary:#007bff;--color-primary-hover:#0056b3;--color-primary-light:#e3f2fd;--color-success:#28a745;--color-success-light:#d4edda;--color-warning:#ffc107;--color-warning-light:#fff3cd;--color-danger:#dc3545;--color-danger-light:#f8d7da;--color-info:#17a2b8;--color-info-light:#d1ecf1;--color-shadow:#0000001a;--color-shadow-medium:#00000026;--color-shadow-strong:#0003;--color-overlay:#00000080;--transition-speed:0.3s}body[data-theme=dark]{--color-bg-primary:#0f172a;--color-bg-secondary:#1e293b;--color-bg-tertiary:#334155;--color-text-primary:#f8fafc;--color-text-secondary:#e2e8f0;--color-text-tertiary:#cbd5e1;--color-text-inverse:#0f172a;--color-border:#334155;--color-border-light:#475569;--color-border-dark:#1e293b;--color-accent-primary:#dc2626;--color-accent-hover:#ef4444;--color-accent-light:#7f1d1d;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-light:#1e3a8a;--color-success:#22c55e;--color-success-light:#14532d;--color-warning:#eab308;--color-warning-light:#422006;--color-danger:#ef4444;--color-danger-light:#7f1d1d;--color-info:#06b6d4;--color-info-light:#164e63;--color-shadow:#0000004d;--color-shadow-medium:#0006;--color-shadow-strong:#00000080;--color-overlay:#000000b3}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f7f9fc;background-color:var(--color-bg-secondary);color:#2c3e50;color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:16px;line-height:1.6;margin:0;transition:background-color .3s ease,color .3s ease;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease}html{font-size:14px}@media (min-width:768px){html{font-size:16px}}.container{margin:0 auto;max-width:1200px;padding:0 1rem;width:100%}@media (min-width:768px){.container{padding:0 2rem}}.mobile-only{display:block}.desktop-only{display:none}@media (min-width:768px){.mobile-only{display:none}.desktop-only{display:block}}.clickable,button{min-height:44px;min-width:44px}input[type=email],input[type=number],input[type=password],input[type=tel],input[type=text],input[type=url],select,textarea{font-size:16px}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media print{:root,body,body[data-theme=dark]{--color-bg-primary:#fff!important;--color-bg-secondary:#f7f9fc!important;--color-bg-tertiary:#f1f3f5!important;--color-text-primary:#2c3e50!important;--color-text-secondary:#495057!important;--color-text-tertiary:#6c757d!important;--color-border:#dee2e6!important;--color-border-light:#e9ecef!important;--color-border-dark:#ced4da!important;--color-primary:#007bff!important;--color-primary-light:#cfe2ff!important;--color-primary-dark:#0056b3!important;--color-accent:#dc2626!important;--color-accent-light:#fee2e2!important;--color-accent-hover:#b91c1c!important;--color-success:#28a745!important;--color-success-light:#d4edda!important;--color-success-dark:#155724!important;--color-warning:#ffc107!important;--color-warning-light:#fff3cd!important;--color-warning-dark:#856404!important;--color-danger:#dc3545!important;--color-danger-light:#f8d7da!important;--color-danger-dark:#721c24!important;--color-info:#17a2b8!important;--color-info-light:#d1ecf1!important;--color-info-dark:#0c5460!important;--color-overlay:#00000080!important}.app-shell,.card,.main-content,.modal,.panel,.table,:root,body,body[data-theme=dark],td,th,tr{background-color:#fff!important;color:#2c3e50!important}.grade-item,.info-item strong,.student-info,div,h1,h2,h3,h4,h5,h6,label,p,span{color:#2c3e50!important}.table,.table td,.table th{border-color:#dee2e6!important}.app-nav,.delete-btn,.edit-btn,.header-actions,.modal-close,.no-print,.side-nav,.theme-toggle,button:not(.print-only){display:none!important}*{color-adjust:exact!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}body.generating-pdf,body.generating-pdf[data-theme=dark]{--color-bg-primary:#fff!important;--color-bg-secondary:#f7f9fc!important;--color-bg-tertiary:#f1f3f5!important;--color-text-primary:#2c3e50!important;--color-text-secondary:#495057!important;--color-text-tertiary:#6c757d!important;--color-border:#dee2e6!important;--color-border-light:#e9ecef!important;--color-border-dark:#ced4da!important;--color-primary:#007bff!important;--color-primary-light:#cfe2ff!important;--color-primary-dark:#0056b3!important;--color-accent:#dc2626!important;--color-accent-light:#fee2e2!important;--color-accent-hover:#b91c1c!important;--color-success:#28a745!important;--color-success-light:#d4edda!important;--color-success-dark:#155724!important;--color-warning:#ffc107!important;--color-warning-light:#fff3cd!important;--color-warning-dark:#856404!important;--color-danger:#dc3545!important;--color-danger-light:#f8d7da!important;--color-danger-dark:#721c24!important;--color-info:#17a2b8!important;--color-info-light:#d1ecf1!important;--color-info-dark:#0c5460!important;--color-overlay:#00000080!important;background-color:#fff!important;color:#2c3e50!important}body.generating-pdf .app-shell,body.generating-pdf .card,body.generating-pdf .grade-item,body.generating-pdf .info-grid,body.generating-pdf .main-content,body.generating-pdf .modal,body.generating-pdf .panel,body.generating-pdf .student-detail-card{background-color:#fff!important;color:#2c3e50!important}body.generating-pdf .grade-item,body.generating-pdf .info-item strong,body.generating-pdf .student-info,body.generating-pdf div,body.generating-pdf h1,body.generating-pdf h2,body.generating-pdf h3,body.generating-pdf h4,body.generating-pdf h5,body.generating-pdf h6,body.generating-pdf label,body.generating-pdf p,body.generating-pdf span,body.generating-pdf td,body.generating-pdf th{color:#2c3e50!important}body.generating-pdf .students-table,body.generating-pdf .students-table td,body.generating-pdf .students-table th,body.generating-pdf .table,body.generating-pdf .table td,body.generating-pdf .table th{border-color:#dee2e6!important}.session-modal-backdrop{align-items:center;background-color:var(--color-overlay);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.session-modal{background:var(--color-bg-primary);border-radius:8px;box-shadow:0 4px 6px var(--color-shadow);max-height:90vh;max-width:400px;overflow-y:auto;width:90%}.session-modal-header{border-bottom:1px solid #e2e8f0;padding:1.5rem 1.5rem 1rem}.session-modal-header h3{color:#dc3545;font-size:1.25rem;font-weight:600;margin:0}.session-modal-body{padding:1rem 1.5rem}.session-modal-body p{color:#4a5568;line-height:1.5;margin:0 0 1rem}.session-modal-body p:last-child{margin-bottom:0}.session-modal-footer{border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;padding:1rem 1.5rem 1.5rem}.session-modal-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.session-modal-button:hover{background-color:#c82333}.session-modal-button:focus{box-shadow:0 0 0 2px #dc354580;outline:none}@media (max-width:480px){.session-modal{margin:1rem;width:95%}.session-modal-body,.session-modal-footer,.session-modal-header{padding:1rem}}.esb-loading-screen{align-items:center;background:#f8fafc;background:var(--color-bg-primary,#f8fafc);bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.esb-loading-spinner{animation:esb-spin 1s linear infinite;border:4px solid #e2e8f0;border-top-color:#3b82f6;border:4px solid var(--color-border,#e2e8f0);border-radius:50%;border-top-color:var(--color-primary,#3b82f6);height:50px;width:50px}@keyframes esb-spin{to{transform:rotate(1turn)}}.esb-loading-screen p{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:1rem;margin-top:1rem}.esb-blocked-content{filter:blur(5px);pointer-events:none;-webkit-user-select:none;user-select:none}.esb-modal-overlay{align-items:center;background:#0f172ad9;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:1rem;position:fixed;right:0;top:0;z-index:10001}.esb-modal-container{animation:esb-slideIn .3s ease-out;background:#fff;background:var(--color-bg-primary,#fff);border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:900px;overflow-y:auto;width:100%}@keyframes esb-slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.esb-modal-header{align-items:flex-start;background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:3px solid #f59e0b;border-radius:16px 16px 0 0;display:flex;gap:1rem;padding:1.5rem 2rem}.esb-modal-icon{flex-shrink:0;font-size:2.5rem}.esb-modal-header h2{color:#92400e;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.esb-modal-header p{color:#a16207;font-size:.95rem;line-height:1.5;margin:0}.esb-modal-body{padding:2rem}.esb-user-count-info{background:#f1f5f9;background:var(--color-bg-secondary,#f1f5f9);border-radius:8px;margin-bottom:1.5rem;padding:1rem;text-align:center}.esb-user-count-info p{color:#1e293b;color:var(--color-text-primary,#1e293b);margin:0}.esb-user-count-info .esb-help-text{color:#64748b;color:var(--color-text-tertiary,#64748b);font-size:.85rem;margin-top:.25rem}.esb-plans-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.esb-plan-card{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:12px;display:flex;flex-direction:column;padding:1.5rem;position:relative;transition:all .3s ease}.esb-plan-card:hover{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 10px 25px -5px #3b82f626;transform:translateY(-2px)}.esb-plan-card.esb-popular{background:linear-gradient(180deg,#fffbeb,#fff 20%);border-color:#f59e0b}.esb-popular-badge{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;left:50%;padding:.35rem 1rem;position:absolute;top:-12px;transform:translateX(-50%);white-space:nowrap}.esb-plan-header{margin-bottom:1rem;text-align:center}.esb-plan-header h3{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.esb-plan-description{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.9rem;line-height:1.4;margin:0}.esb-plan-pricing{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);margin-bottom:1rem;padding:1rem 0;text-align:center}.esb-main-price{color:#3b82f6;color:var(--color-primary,#3b82f6);font-size:2rem;font-weight:800}.esb-price-period{color:#64748b;color:var(--color-text-tertiary,#64748b);font-size:1rem;font-weight:400}.esb-price-details{margin-top:.5rem}.esb-price-details p{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.9rem;margin:0}.esb-savings-badge{background:#dcfce7;border-radius:20px;color:#166534;display:inline-block;font-size:.75rem;font-weight:600;margin-left:.5rem;padding:.2rem .6rem}.esb-billing-info{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.85rem;margin-top:1rem}.esb-billing-info p{margin:.25rem 0}.esb-minimum-notice{color:#d97706!important;font-weight:500}.esb-no-minimum-notice{color:#16a34a!important;font-weight:500}.esb-plan-features{flex:1 1;margin-bottom:1rem}.esb-plan-features h4{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:.95rem;font-weight:600;margin:0 0 .75rem}.esb-plan-features ul{list-style:none;margin:0;padding:0}.esb-plan-features li{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.85rem;line-height:1.4;padding:.4rem 0}.esb-btn-select{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.85rem 1.5rem;transition:all .2s ease;width:100%}.esb-btn-select:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.esb-popular .esb-btn-select{background:linear-gradient(135deg,#f59e0b,#d97706)}.esb-popular .esb-btn-select:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #d977064d}.esb-checkout-container{margin:0 auto;max-width:500px}.esb-checkout-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.esb-checkout-header h3{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1.25rem;margin:0}.esb-checkout-back{background:none;border:none;color:#3b82f6;color:var(--color-primary,#3b82f6);cursor:pointer;font-size:.9rem;font-weight:500}.esb-checkout-back:hover{text-decoration:underline}.esb-checkout-summary{background:#f1f5f9;background:var(--color-bg-secondary,#f1f5f9);border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem}.esb-checkout-summary h4{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1rem;margin:0 0 1rem}.esb-summary-item{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;font-size:.95rem;justify-content:space-between;padding:.5rem 0}.esb-summary-item:last-child{border-bottom:none}.esb-summary-item.esb-total{border-bottom:none;border-top:2px solid #e2e8f0;border-top:2px solid var(--color-border,#e2e8f0);color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1.1rem;margin-top:.5rem;padding-top:.75rem}.esb-payment-section{margin-bottom:1.5rem}.esb-payment-section h4{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1rem;margin:0 0 1rem}.esb-card-element-container{background:#fff;border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;padding:1rem;transition:border-color .2s ease}.esb-card-element-container:focus-within{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6)}.esb-payment-hint{color:#64748b;color:var(--color-text-tertiary,#64748b);font-size:.85rem;margin:.75rem 0 0;text-align:center}.esb-error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.esb-checkout-actions{display:flex;gap:1rem}.esb-btn-secondary{background:#f1f5f9;background:var(--color-bg-secondary,#f1f5f9);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;color:#1e293b;color:var(--color-text-primary,#1e293b);cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:.85rem 1.5rem;transition:all .2s ease}.esb-btn-secondary:hover{background:#e2e8f0;background:var(--color-bg-tertiary,#e2e8f0)}.esb-btn-primary{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:2 1;font-size:1rem;font-weight:600;padding:.85rem 1.5rem;transition:all .2s ease}.esb-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 12px #16a34a4d;transform:translateY(-1px)}.esb-btn-primary:disabled{cursor:not-allowed;opacity:.7}.esb-modal-footer{align-items:center;background:#f1f5f9;background:var(--color-bg-secondary,#f1f5f9);border-radius:0 0 16px 16px;border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);display:flex;flex-direction:column;gap:.75rem;padding:1.25rem 2rem}.esb-btn-logout{background:#0000;border:2px solid #dc2626;border-radius:8px;color:#dc2626;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 2rem;transition:all .2s ease}.esb-btn-logout:hover{background:#dc2626;color:#fff}.esb-footer-note{color:#64748b;color:var(--color-text-tertiary,#64748b);font-size:.85rem;margin:0}body[data-theme=dark] .esb-loading-screen{background:var(--color-bg-primary)}body[data-theme=dark] .esb-modal-container{background:var(--color-bg-secondary)}body[data-theme=dark] .esb-modal-header{background:linear-gradient(135deg,#422006,#78350f);border-bottom-color:#f59e0b}body[data-theme=dark] .esb-modal-header h2{color:#fef3c7}body[data-theme=dark] .esb-modal-header p{color:#fde68a}body[data-theme=dark] .esb-user-count-info{background:var(--color-bg-tertiary)}body[data-theme=dark] .esb-plan-card{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .esb-plan-card:hover{border-color:var(--color-primary)}body[data-theme=dark] .esb-plan-card.esb-popular{background:linear-gradient(180deg,#f59e0b1a 0,var(--color-bg-tertiary) 20%)}body[data-theme=dark] .esb-plan-features h4,body[data-theme=dark] .esb-plan-header h3{color:var(--color-text-primary)}body[data-theme=dark] .esb-billing-info,body[data-theme=dark] .esb-plan-description,body[data-theme=dark] .esb-plan-features li{color:var(--color-text-secondary)}body[data-theme=dark] .esb-plan-pricing{border-color:var(--color-border)}body[data-theme=dark] .esb-savings-badge{background:#16a34a33;color:#4ade80}body[data-theme=dark] .esb-checkout-summary{background:var(--color-bg-tertiary)}body[data-theme=dark] .esb-checkout-header h3,body[data-theme=dark] .esb-checkout-summary h4,body[data-theme=dark] .esb-payment-section h4{color:var(--color-text-primary)}body[data-theme=dark] .esb-summary-item{border-bottom-color:var(--color-border);color:var(--color-text-secondary)}body[data-theme=dark] .esb-summary-item.esb-total{border-top-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .esb-card-element-container{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .esb-error-message{background:#b91c1c1a;border-color:#dc2626;color:#f87171}body[data-theme=dark] .esb-btn-secondary{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .esb-btn-secondary:hover{background:var(--color-bg-primary)}body[data-theme=dark] .esb-modal-footer{background:var(--color-bg-tertiary);border-top-color:var(--color-border)}@media (max-width:768px){.esb-modal-container{border-radius:12px;max-height:95vh}.esb-modal-header{border-radius:12px 12px 0 0;flex-direction:column;padding:1.25rem 1.5rem;text-align:center}.esb-modal-icon{font-size:2rem}.esb-modal-header h2{font-size:1.25rem}.esb-modal-body{padding:1.25rem}.esb-plans-grid{grid-template-columns:1fr}.esb-checkout-actions{flex-direction:column}.esb-btn-primary,.esb-btn-secondary{flex:none;width:100%}.esb-modal-footer{border-radius:0 0 12px 12px;padding:1rem 1.5rem}}@media (max-width:480px){.esb-modal-overlay{padding:.5rem}.esb-modal-container{max-height:98vh}.esb-main-price{font-size:1.75rem}.esb-plan-card{padding:1.25rem}}@media print{.esb-modal-overlay{display:none!important}.esb-blocked-content{filter:none;pointer-events:auto;-webkit-user-select:auto;user-select:auto}}.session-expired-backdrop{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.session-expired-modal{animation:sessionExpiredFadeIn .3s ease-out;background:var(--color-bg-primary);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:2rem;text-align:center;width:100%}@keyframes sessionExpiredFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.session-expired-icon{animation:sessionExpiredPulse 2s infinite;color:#ffc107;font-size:4rem;margin-bottom:1rem}@keyframes sessionExpiredPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.session-expired-title{color:#dc3545;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.session-expired-message{color:var(--color-text-secondary);font-size:1rem;line-height:1.6;margin:0 0 2rem}.session-expired-actions{display:flex;justify-content:center}.session-expired-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;min-width:120px;padding:.75rem 2rem;transition:all .2s ease}.session-expired-btn:hover{background:#c82333;box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.session-expired-btn:active{transform:translateY(0)}.session-expired-btn:focus{box-shadow:0 0 0 3px #dc35454d;outline:none}@media (max-width:480px){.session-expired-modal{margin:1rem;padding:1.5rem}.session-expired-icon{font-size:3rem}.session-expired-title{font-size:1.3rem}.session-expired-message{font-size:.9rem}.session-expired-btn{font-size:.9rem;padding:.875rem 1.5rem}}@media (prefers-contrast:high){.session-expired-modal{border:3px solid #000}.session-expired-btn{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.session-expired-icon,.session-expired-modal{animation:none}.session-expired-btn{transition:none}.session-expired-btn:hover{transform:none}}body.session-expired-modal-open{overflow:hidden}.session-expired-modal:focus{outline:none}.session-expired-backdrop[aria-hidden=false]{pointer-events:auto}.session-expired-backdrop[aria-hidden=true]{pointer-events:none}.trial-expired-info,.trial-expired-message,.trial-expired-title{color:var(--color-text-primary)}.director-contact-info{color:#212529}.login-container{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b 50%,#0f172a);display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;justify-content:center;min-height:100vh;padding:1rem;position:relative}.login-container:before{background:url(/static/media/login.dbd9887f0d62cbbbf17d.png) 50%/contain no-repeat;bottom:0;content:"";left:0;opacity:.15;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.login-logo{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172acc;border:1px solid #dc26264d;border-radius:8px;height:60px;left:1rem;padding:.5rem;position:absolute;top:1rem;transition:transform .3s;z-index:10}.login-logo:hover{transform:scale(1.05)}.login-title{color:#fff;font-size:1.5rem;left:50%;margin:0;position:absolute;text-align:center;top:1rem;transform:translateX(-50%);z-index:10}.login-promo{display:none}.login-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0000004d;color:#fff;margin-top:2rem;max-width:400px;padding:2rem;position:relative;width:100%;z-index:10}.login-form h2{color:#fff;font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.login-form label{color:#ffffffe6;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.login-form input{background:#ffffff0d;border:1px solid #fff3;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;margin-bottom:1rem;outline:none;padding:.75rem;transition:all .3s;width:100%}.login-form input::placeholder{color:#fff6}.login-form input:focus{background:#ffffff14;border-color:#dc2626}.login-form button{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-height:44px;padding:.75rem;transition:all .3s;width:100%}.login-form button:hover{background:#b91c1c;box-shadow:0 8px 20px #dc262666;transform:translateY(-2px)}.login-form button:active{transform:translateY(1px)}.register-button{background:#0000;border:2px solid #dc2626;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;min-height:44px;padding:.75rem;transition:all .3s;width:100%}.register-button:hover{background:#dc26261a}.forgot-text{color:#dc2626;cursor:pointer;font-size:.9rem;margin-top:1rem;text-align:center;text-decoration:underline;transition:color .3s ease}.forgot-text:hover{color:#b91c1c}.error-message{background:#dc26261a;border:1px solid #dc2626;border-radius:8px;color:#fca5a5;font-size:.9rem;margin-top:1rem;text-align:center}.forgot-form-container{align-items:center;background:#000000e6;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.forgot-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0000004d;color:#fff;max-width:400px;padding:2rem;width:100%}.forgot-form h3{color:#fff;margin-bottom:1.5rem;text-align:center}.forgot-form label{color:#ffffffe6;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.forgot-form input{background:#ffffff0d;border:1px solid #fff3;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;margin-bottom:1rem;padding:.75rem;transition:all .3s;width:100%}.forgot-form input::placeholder{color:#fff6}.forgot-form input:focus{background:#ffffff14;border-color:#dc2626;outline:none}.forgot-form button{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-height:44px;padding:.75rem;transition:all .3s;width:100%}.forgot-form button:hover{background:#b91c1c;box-shadow:0 8px 20px #dc262666;transform:translateY(-2px)}.forgot-message{color:#22c55e;font-size:.9rem;margin-top:1rem;text-align:center}@media (min-width:768px){.login-container{padding:2rem}.login-logo{height:80px;left:1.5rem;top:1.5rem}.login-title{font-size:2rem;top:1.5rem}.login-promo{display:block;left:50%;max-width:50%;opacity:.7;pointer-events:none;transform:translate(-50%,-50%);z-index:1}.login-form,.login-promo{position:absolute;top:50%}.login-form{left:3rem;margin-top:0;max-width:none;transform:translateY(-50%);width:380px;z-index:10}.login-form h2{font-size:1.8rem}}@media (min-width:1024px){.login-logo{height:100px;left:2rem;top:2rem}.login-title{font-size:2.5rem;top:2rem}.login-promo{max-width:60%;opacity:.8}.login-form{left:4rem;padding:2.5rem;width:420px}}.login-form button:disabled{cursor:not-allowed;opacity:.6}.login-form button:focus,.login-form input:focus,.register-button:focus{outline:2px solid #dc2626;outline-offset:2px}.login-form{animation:fadeInUp .6s ease-out}@media (prefers-contrast:high){.login-form{background:#fff}.login-form,.login-form input{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.login-form{animation:none}.login-form button:active{transform:none}}.captcha-container{margin-bottom:1rem}.captcha-question{align-items:center;background:#ffffff0d;border:1px solid #fff3;border-radius:8px;display:flex;font-family:Courier New,monospace;font-size:1.1rem;font-weight:700;justify-content:space-between;margin-bottom:.5rem;padding:.75rem}.captcha-text{color:#fff;letter-spacing:2px;-webkit-user-select:none;user-select:none}.captcha-refresh{align-items:center;background:#6c757d;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:30px;justify-content:center;transition:background .3s ease,transform .2s ease;width:30px}.captcha-refresh:hover{background:#5a6268;transform:rotate(180deg)}.captcha-refresh:active{transform:rotate(180deg) scale(.95)}.captcha-error-message{animation:shake .5s ease-in-out;background:#dc26261a;border:1px solid #dc2626;border-radius:8px;box-shadow:0 2px 4px #dc262633;color:#fca5a5;font-size:.9rem;font-weight:500;margin-top:.5rem;padding:.75rem;text-align:center}.captcha-input-error{animation:shake .5s ease-in-out;background:#dc26260d!important;border-color:#dc2626!important;box-shadow:0 0 0 .2rem #dc262640!important}@keyframes pulse-error{0%{opacity:0;transform:scale(.95)}50%{opacity:1;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.captcha-error-message{animation:pulse-error .3s ease-out,shake .5s ease-in-out}.captcha-container input{font-size:1.1rem;font-weight:700;text-align:center}.captcha-container input:focus{border-color:#dc2626;box-shadow:0 0 0 .2rem #dc262640}@keyframes captcha-refresh{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.captcha-refresh.rotating{animation:captcha-refresh .5s ease-in-out}@media (prefers-color-scheme:dark){.captcha-question{background:#2d3748;border-color:#4a5568}.captcha-text{color:#e2e8f0}.captcha-error-message{background-color:#2d3748;border-color:#e53e3e;color:#fed7d7}.captcha-input-error{background-color:#2d1b1b!important}}.captcha-refresh:focus{outline:2px solid #dc2626;outline-offset:2px}@media (max-width:480px){.captcha-question{font-size:1rem;padding:.5rem}.captcha-refresh{font-size:1rem;height:25px;width:25px}}.forgot-form-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.forgot-close-button{align-items:center;background:none;border:none;border-radius:50%;color:#fff9;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:.25rem;transition:all .3s ease;width:30px}.forgot-close-button:hover{background:#ffffff1a;color:#fff;transform:scale(1.1)}.forgot-form button.submitting{background:#6c757d;cursor:not-allowed;position:relative}.forgot-form button.submitting:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:16px;margin:auto;position:absolute;width:16px}.forgot-confirmation{padding:1rem 0;text-align:center}.forgot-success-icon{animation:bounceIn .6s ease-out;font-size:3rem;margin-bottom:1rem}.forgot-confirmation h3{color:#22c55e;font-size:1.5rem;margin-bottom:1rem}.forgot-message.success{background:#22c55e1a;border:1px solid #22c55e;border-radius:8px;color:#86efac;font-weight:500;line-height:1.4;margin-bottom:1.5rem;padding:1rem}.countdown-container{align-items:center;display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.countdown-circle{align-items:center;animation:pulse 2s infinite;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:50%;box-shadow:0 4px 15px #dc26264d;display:flex;height:80px;justify-content:center;position:relative;width:80px}.countdown-circle:before{animation:countdown-rotation 15s linear;background:conic-gradient(from 0deg,#dc2626 0deg,#b91c1c 1turn);border-radius:50%;content:"";height:100%;opacity:.3;position:absolute;width:100%}.countdown-number{color:#fff;font-size:1.8rem;font-weight:700;position:relative;z-index:1}.countdown-text{color:#fff9;font-size:.9rem;line-height:1.3;margin:0;max-width:250px;text-align:center}.forgot-close-manual{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:1rem;padding:.5rem 1.5rem;transition:all .3s ease}.forgot-close-manual:hover{background:#5a6268;transform:translateY(-1px)}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:.8;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes countdown-rotation{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.forgot-confirmation,.forgot-form form{animation:fadeInUp .4s ease-out}@media (max-width:480px){.countdown-circle{height:60px;width:60px}.countdown-number{font-size:1.4rem}.forgot-success-icon{font-size:2.5rem}.forgot-confirmation h3{font-size:1.3rem}.countdown-text{font-size:.8rem;max-width:200px}}@media (prefers-color-scheme:dark){.forgot-message.success{background-color:#1e4620;border-color:#2d5a2f;color:#a3d9a5}.forgot-close-button:hover{background-color:#3d4043;color:#e9ecef}}@media (prefers-reduced-motion:reduce){.countdown-circle,.countdown-circle:before,.forgot-confirmation,.forgot-form form,.forgot-success-icon{animation:none}}.forgot-close-button:focus,.forgot-close-manual:focus{outline:2px solid #dc2626;outline-offset:2px}.tem-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172af2!important}.trial-expired-modal.tem-expanded{max-height:90vh;max-width:850px;overflow-y:auto;padding:0;width:95%}.tem-plans-container{padding:1.5rem}.tem-plans-header{margin-bottom:1.5rem;text-align:center}.tem-plans-header h2{color:#f8fafc;color:var(--color-text-primary,#f8fafc);font-size:1.5rem;margin:0 0 .5rem}.tem-plans-header p{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:.95rem;margin:0}.tem-region-badge{background:#3b82f626;border:1px solid #3b82f64d;border-radius:20px;color:#60a5fa;display:inline-block;font-size:.8rem;margin-top:.75rem;padding:.35rem .75rem}.tem-loading{align-items:center;display:flex;flex-direction:column;padding:3rem}.tem-spinner{animation:tem-spin 1s linear infinite;border:3px solid #fff3;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes tem-spin{to{transform:rotate(1turn)}}.tem-user-info{background:#3b82f61a;border:1px solid #3b82f64d;border-radius:8px;margin-bottom:1.5rem;padding:1rem;text-align:center}.tem-user-info p{color:#f8fafc;color:var(--color-text-primary,#f8fafc);margin:0}.tem-user-info span{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:.85rem}.tem-plans-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}@media (max-width:700px){.tem-plans-grid{grid-template-columns:1fr}}.tem-plan-card{background:#1e293bcc;border:2px solid #ffffff1a;border-radius:12px;display:flex;flex-direction:column;padding:1.5rem;position:relative;transition:all .3s ease}.tem-plan-card:hover{border-color:#3b82f6;transform:translateY(-2px)}.tem-plan-card.tem-popular{background:linear-gradient(180deg,#f59e0b26,#1e293bcc 30%);border-color:#f59e0b}.tem-popular-badge{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;left:50%;padding:.35rem 1rem;position:absolute;top:-12px;transform:translateX(-50%);white-space:nowrap}.tem-plan-card h3{color:#f8fafc;color:var(--color-text-primary,#f8fafc);font-size:1.25rem;margin:.5rem 0;text-align:center}.tem-plan-desc{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:.9rem;margin:0 0 1rem;text-align:center}.tem-plan-price{border-bottom:1px solid #ffffff1a;border-top:1px solid #ffffff1a;margin-bottom:1rem;padding:1rem 0;text-align:center}.tem-price{color:#3b82f6;font-size:2rem;font-weight:700;transition:all .3s ease}.tem-period{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:1rem}.tem-plan-details{margin-bottom:.5rem;text-align:center}.tem-plan-details p{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:.9rem;margin:0}.tem-savings{background:#22c55e33;border-radius:20px;color:#4ade80;display:inline-block;font-size:.75rem;font-weight:600;margin-left:.5rem;padding:.2rem .6rem}.tem-billing-info{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);flex:1 1;font-size:.85rem;margin:1rem 0}.tem-billing-info p{margin:.25rem 0}.tem-minimum{color:#fbbf24!important;font-weight:500}.tem-no-minimum{color:#4ade80!important;font-weight:500}.tem-select-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.85rem;transition:all .2s ease;width:100%}.tem-select-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.tem-popular .tem-select-btn{background:linear-gradient(135deg,#f59e0b,#d97706)}.tem-popular .tem-select-btn:hover{background:linear-gradient(135deg,#d97706,#b45309)}.tem-slider-section{background:#1e293b99;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.tem-slider-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.tem-slider-label{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:.95rem}.tem-slider-value{background:#3b82f626;border-radius:20px;color:#3b82f6;font-size:1.1rem;font-weight:700;padding:.25rem .75rem}.tem-slider{-webkit-appearance:none;appearance:none;border-radius:4px;cursor:pointer;height:8px;margin-bottom:.5rem;outline:none;width:100%}.tem-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#3b82f6,#2563eb);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #3b82f680;cursor:pointer;height:24px;-webkit-transition:transform .2s ease,box-shadow .2s ease;transition:transform .2s ease,box-shadow .2s ease;width:24px}.tem-slider::-webkit-slider-thumb:hover{box-shadow:0 4px 12px #3b82f6b3;transform:scale(1.1)}.tem-slider::-moz-range-thumb{background:linear-gradient(135deg,#3b82f6,#2563eb);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #3b82f680;cursor:pointer;height:24px;width:24px}.tem-slider-marks{display:flex;justify-content:space-between;margin-bottom:1rem;padding:0 2px}.tem-slider-marks span{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.7rem}.tem-discount-badge{animation:tem-pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#22c55e33,#22c55e1a);border:1px solid #22c55e80;border-radius:8px;color:#4ade80;font-size:.9rem;padding:.6rem 1rem;text-align:center}@keyframes tem-pulse{0%,to{opacity:1}50%{opacity:.8}}.tem-reset-btn{background:#0000;border:1px dashed #ffffff4d;border-radius:6px;color:#94a3b8;color:var(--color-text-secondary,#94a3b8);cursor:pointer;display:block;font-size:.85rem;margin-top:.75rem;padding:.5rem;transition:all .2s ease;width:100%}.tem-reset-btn:hover{background:#3b82f61a;border-color:#3b82f6;color:#3b82f6}.tem-plans-footer{border-top:1px solid #ffffff1a;padding-top:1rem;text-align:center}.tem-checkout-container{padding:1.5rem}.tem-checkout-back{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.9rem;margin-bottom:1rem;padding:0}.tem-checkout-back:hover{text-decoration:underline}.tem-checkout-title{color:#f8fafc;color:var(--color-text-primary,#f8fafc);font-size:1.25rem;margin:0 0 1.5rem;text-align:center}.tem-checkout-summary{background:#1e293bcc;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem}.tem-summary-row{border-bottom:1px solid #ffffff1a;color:#94a3b8;color:var(--color-text-secondary,#94a3b8);display:flex;font-size:.95rem;justify-content:space-between;padding:.5rem 0}.tem-summary-row:last-child{border-bottom:none}.tem-summary-row.tem-total{border-bottom:none;border-top:2px solid #fff3;font-size:1.1rem;margin-top:.5rem;padding-top:.75rem}.tem-summary-row strong,.tem-summary-row.tem-total{color:#f8fafc;color:var(--color-text-primary,#f8fafc)}.tem-discount-applied{color:#4ade80!important}.tem-card-section{margin-bottom:1.5rem}.tem-card-section label{color:#f8fafc;color:var(--color-text-primary,#f8fafc);display:block;font-size:.95rem;margin-bottom:.5rem}.tem-card-element{background:#fffffff2;border:2px solid #fff3;border-radius:8px;padding:1rem;transition:border-color .2s ease}.tem-card-element:focus-within{border-color:#3b82f6}.tem-secure-note{color:#94a3b8;color:var(--color-text-secondary,#94a3b8);font-size:.85rem;margin:.75rem 0 0;text-align:center}.tem-error{margin-bottom:1rem}.tem-error,.tem-global-error{background:#ef444426;border:1px solid #ef444480;border-radius:8px;color:#f87171;font-size:.9rem;padding:.75rem 1rem}.tem-global-error{margin:1rem 1.5rem}.tem-checkout-actions{display:flex;gap:1rem}.tem-checkout-actions .btn-secondary{flex:1 1}.tem-checkout-actions .btn-primary{flex:2 1}@media (max-width:768px){.trial-expired-modal.tem-expanded{border-radius:12px;max-height:95vh}.tem-checkout-container,.tem-plans-container{padding:1rem}.tem-checkout-actions{flex-direction:column}.tem-checkout-actions .btn-primary,.tem-checkout-actions .btn-secondary{flex:none;width:100%}.tem-slider-header{flex-direction:column;gap:.5rem;text-align:center}}.side-nav{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;display:flex;flex-direction:column;height:100vh;padding:1rem;position:-webkit-sticky;position:sticky;top:0;width:250px}.logo-container{flex-shrink:0;margin-bottom:1.5rem;padding:.5rem;position:relative;text-align:center}.logo{background:#ffffff1a;border-radius:8px;height:100px;max-width:100%;object-fit:contain;padding:.5rem;transition:all .3s ease;width:100px}.logo:hover{background:#ffffff26;transform:scale(1.05)}.school-name{word-wrap:break-word;color:#fff;font-size:.8rem;font-weight:500;line-height:1.2;margin:.5rem 0 0;max-width:100%;opacity:.9;text-align:center;text-shadow:0 1px 2px #00000080}.logo-loading{align-items:center;display:flex;flex-direction:column;gap:.5rem}.logo-skeleton{animation:loading 1.5s infinite;background:linear-gradient(90deg,#ffffff1a 25%,#fff3 50%,#ffffff1a 75%);background-size:200% 100%;border-radius:8px;height:100px;width:100px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-text{color:#ffffffb3;font-size:.75rem;font-weight:500}.nav-container{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.nav-list{-webkit-overflow-scrolling:touch;flex:1 1;list-style:none;margin:0;overflow-x:hidden;overflow-y:auto;padding:0;scroll-behavior:smooth;scrollbar-color:#ffffff4d #0000;scrollbar-width:thin}.nav-list::-webkit-scrollbar{width:6px}.nav-list::-webkit-scrollbar-track{background:#0000}.nav-list::-webkit-scrollbar-thumb{background-color:#fff3;border-radius:3px;-webkit-transition:background-color .2s ease;transition:background-color .2s ease}.nav-list::-webkit-scrollbar-thumb:hover{background-color:#fff6}.nav-item{align-items:center;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;margin-bottom:.5rem;min-height:44px;padding:.75rem;position:relative;text-decoration:none;transition:all .3s ease}.nav-item:hover{background:#fff3;transform:translateX(2px)}.nav-item:active{transform:translateX(0)}.nav-icon{font-size:1.25rem;margin-right:.75rem;min-width:1.5rem;text-align:center}.nav-text{font-size:.95rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-footer{border-top:1px solid #ffffff1a;display:flex;flex-direction:column;flex-shrink:0;gap:.5rem;margin-top:.5rem;padding-top:1rem}.theme-toggle{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.5rem;justify-content:center;min-height:44px;padding:.75rem 1rem;transition:all .3s ease;width:100%}.theme-toggle:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.theme-toggle:active{transform:translateY(0)}.theme-icon{font-size:1.2rem;line-height:1}.theme-text{font-size:.9rem}.logout-button{align-items:center;background:#ff4e50;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;justify-content:center;min-height:44px;padding:.75rem 1rem;transition:all .3s ease;width:100%}.logout-button:hover{background:#ff1e1e;transform:translateY(-1px)}.logout-button:active{transform:translateY(0)}.nav-close{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:32px;z-index:10}.nav-close:hover{background:#fff3}@media (max-width:767px){.side-nav{height:100vh;padding:1.5rem 1rem;position:fixed;width:280px}.logo-container{margin-bottom:2rem;padding-top:1rem}.logo,.logo-skeleton{height:120px;width:120px}.school-name{font-size:.9rem}.nav-item{font-size:1rem;padding:1rem .75rem}.nav-icon{font-size:1.5rem;margin-right:1rem}.nav-text{font-size:1rem}.logout-button{font-size:1rem;padding:1rem}.nav-list{padding-right:.5rem}}@media (min-width:768px) and (max-width:1023px){.side-nav{height:100vh;padding:1.25rem .75rem;position:-webkit-sticky;position:sticky;top:0;width:220px}.logo,.logo-skeleton{height:90px;width:90px}.school-name{font-size:.75rem}.nav-item{padding:.6rem}.nav-icon{font-size:1.1rem}.nav-text{font-size:.9rem}}@media (min-width:1024px){.side-nav{height:100vh;padding:1.5rem 1.25rem;position:-webkit-sticky;position:sticky;top:0;width:280px}.logo,.logo-skeleton{height:140px;width:140px}.school-name{font-size:.9rem}.nav-item{padding:.875rem 1rem}.nav-icon{font-size:1.4rem}.nav-text{font-size:1rem}}.nav-list:before{background:linear-gradient(180deg,#0000004d,#0000);content:"";display:block;height:10px;margin:0 -1rem -10px;opacity:0;pointer-events:none;position:-webkit-sticky;position:sticky;top:0;transition:opacity .3s ease;z-index:1}.nav-list:not(:first-child):before{opacity:1}.nav-list:after{background:linear-gradient(0deg,#0000004d,#0000);bottom:0;content:"";display:block;height:10px;margin:-10px -1rem 0;opacity:0;pointer-events:none;position:-webkit-sticky;position:sticky;transition:opacity .3s ease;z-index:1}.logout-button:focus,.nav-item:focus{outline:2px solid #fff;outline-offset:2px}.nav-item.loading{opacity:.6;pointer-events:none}.nav-item.active{background:#ffffff40;color:#fff}.nav-item.active:before{background:#0af;border-radius:0 3px 3px 0;content:"";height:100%;left:0;position:absolute;top:0;width:3px}.logo-container:focus-within{border-radius:8px;outline:2px solid #ffffff80;outline-offset:2px}.school-name{animation:fadeIn .5s ease-out}.logo-error{color:#fff9;font-size:.75rem;margin-top:.25rem}.nav-container:hover .nav-list::-webkit-scrollbar-thumb{background-color:#ffffff4d}.nav-list{scroll-padding-bottom:1rem;scroll-padding-top:1rem}@media (prefers-reduced-motion:reduce){.logo,.logout-button,.nav-item{transition:none}.logo:hover,.logout-button:hover,.nav-item:hover{transform:none}.logo-skeleton,.school-name{animation:none}.nav-list{scroll-behavior:auto}}.help-center-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.help-center-modal{animation:slideUp .3s ease-out;background:var(--color-bg-primary);border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:800px;width:90%}.help-center-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid var(--color-border-light);border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.help-center-header h2{font-size:24px;font-weight:600;margin:0}.help-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;transition:all .2s;width:36px}.help-close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.help-tabs{background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border-light);display:flex;padding:0}.help-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:var(--color-text-tertiary);cursor:pointer;flex:1 1;font-size:16px;font-weight:500;padding:16px 24px;transition:all .2s}.help-tab:hover{background:#667eea0d;color:#667eea}.help-tab.active{background:var(--color-bg-primary);border-bottom-color:#667eea;color:#667eea}.help-content{flex:1 1;overflow-y:auto;padding:24px}.help-search-section{display:flex;flex-direction:column;gap:20px}.search-box{position:relative}.search-box input{border:2px solid var(--color-border-light);border-radius:8px;font-size:16px;padding:16px 50px 16px 20px;transition:all .2s;width:100%}.search-box input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.search-spinner{animation:spin 1s linear infinite;font-size:20px;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.search-hint{color:var(--color-text-tertiary);font-size:14px;padding:40px 20px;text-align:center}.search-results h3{color:var(--color-text-primary);font-size:18px;margin:0 0 16px}.search-result-item{background:var(--color-bg-primary);border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;margin-bottom:12px;padding:16px;transition:all .2s}.search-result-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.search-result-item h4{color:var(--color-text-primary);font-size:16px;margin:0 0 8px}.search-result-item p{color:var(--color-text-tertiary);font-size:14px;line-height:1.5;margin:0 0 12px}.search-result-item mark{background:var(--color-warning-light);border-radius:3px;font-weight:600;padding:2px 4px}.result-meta{display:flex;font-size:12px;gap:16px}.result-category{background:#e3f2fd;border-radius:4px;color:#1976d2;font-weight:500;padding:4px 8px}.no-results,.result-views{color:var(--color-text-tertiary)}.no-results{padding:60px 20px;text-align:center}.no-results p{margin:10px 0}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-family:inherit;font-size:inherit;padding:0;text-decoration:underline}.link-button:hover{color:#764ba2}.article-view{animation:fadeIn .3s}.back-button{background:var(--color-bg-tertiary);border:1px solid #e0e0e0;border-radius:6px;color:var(--color-text-tertiary);cursor:pointer;font-size:14px;margin-bottom:20px;padding:8px 16px;transition:all .2s}.back-button:hover{background:#e0e0e0}.article-header{margin-bottom:24px}.article-header h2{color:var(--color-text-primary);font-size:28px;margin:0 0 12px}.article-category{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;color:#fff;display:inline-block;font-size:14px;font-weight:500;padding:6px 12px}.article-content{color:var(--color-text-primary);line-height:1.8;margin-bottom:32px}.article-content p{margin-bottom:16px}.article-footer{border-top:1px solid #e0e0e0;padding-top:24px;text-align:center}.help-suggestion{color:var(--color-text-tertiary);font-size:14px}.help-ticket-section{animation:fadeIn .3s}.ticket-intro{background:var(--color-bg-tertiary);border-radius:8px;margin-bottom:24px;padding:16px 20px;text-align:center}.ticket-intro p{color:var(--color-text-primary);font-size:15px;margin:0}.submit-message{animation:slideDown .3s;border-radius:8px;font-weight:500;margin-bottom:24px;padding:16px 20px}.submit-message.success{background:var(--color-success-light);border:1px solid #c3e6cb;color:#155724}.submit-message.error{background:var(--color-danger-light);border:1px solid #f5c6cb;color:#721c24}.ticket-number-display{font-size:16px;margin:12px 0 0}.ticket-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.form-group label{font-size:14px}.form-group input,.form-group select,.form-group textarea{border:2px solid var(--color-border-light);border-radius:6px;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{min-height:120px}.char-count,.form-group small{color:var(--color-text-tertiary);font-size:12px}.char-count{margin-top:-4px;text-align:right}.file-preview{background:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:14px;margin-top:8px;padding:10px 12px}.form-info{background:var(--color-bg-tertiary)!important;border-left:4px solid #667eea;border-radius:6px;padding:16px}.form-info p{color:var(--color-text-primary);font-size:14px;margin:0 0 8px}.form-info ul{margin:8px 0;padding-left:20px}.form-info li{color:var(--color-text-tertiary);font-size:14px;margin:4px 0}.privacy-note{color:#667eea!important;font-weight:500;margin-top:12px}.submit-ticket-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:all .2s}.submit-ticket-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.submit-ticket-btn:active:not(:disabled){transform:translateY(0)}.submit-ticket-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.help-center-modal{max-height:90vh;width:95%}.help-center-header{padding:16px 20px}.help-center-header h2{font-size:20px}.help-content{padding:20px}.help-tab{font-size:14px;padding:12px 16px}.search-box input{font-size:15px;padding:14px 45px 14px 16px}.article-header h2{font-size:24px}}.help-content::-webkit-scrollbar{width:8px}.help-content::-webkit-scrollbar-track{background:#f1f1f1}.help-content::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.help-content::-webkit-scrollbar-thumb:hover{background:#764ba2}.form-group select option{background:var(--color-bg-primary)!important;color:var(--color-text-primary)!important}.app-shell{display:flex;min-height:100vh;position:relative}.impersonation-banner{animation:impersonationPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#9333ea,#7c3aed,#6d28d9);border-bottom:3px solid #581c87;box-shadow:0 4px 12px #9333ea66;box-sizing:border-box;color:#fff;font-family:Arial,sans-serif;font-size:.9rem;font-weight:600;height:52px;left:0;padding:10px 16px;position:fixed;right:0;text-align:center;top:0;z-index:10000}.impersonation-banner-content{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:0 auto;max-width:1400px}.impersonation-banner-icon{animation:impersonationBounce 1.5s infinite;font-size:1.3rem}.impersonation-banner-text{letter-spacing:.3px;text-shadow:1px 1px 2px #0000004d}.impersonation-banner-text strong{color:#fbbf24;font-weight:700}.impersonation-user-name{background:#fff3;border-radius:6px;font-weight:700;padding:2px 8px}.impersonation-banner-admin{background:#0003;border-radius:12px;font-size:.75rem;opacity:.85;padding:3px 10px}.impersonation-stop-btn{align-items:center;background:linear-gradient(135deg,#dc2626,#b91c1c);border:2px solid #7f1d1d;border-radius:8px;box-shadow:0 2px 6px #dc262666;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:700;gap:6px;padding:6px 16px;transition:all .2s ease}.impersonation-stop-btn:hover:not(:disabled){background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 10px #dc262680;transform:translateY(-1px)}.impersonation-stop-btn:active:not(:disabled){transform:translateY(0)}.impersonation-stop-btn:disabled{cursor:not-allowed;opacity:.7}@keyframes impersonationPulse{0%,to{box-shadow:0 4px 12px #9333ea66}50%{box-shadow:0 4px 20px #9333ea99}}@keyframes impersonationBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.dev-banner{animation:devBannerPulse 3s ease-in-out infinite;background:linear-gradient(135deg,#ff6b6b,#ee5a24);border-bottom:2px solid #c44601;box-shadow:0 2px 8px #00000026;box-sizing:border-box;color:#fff;font-family:Arial,sans-serif;font-size:.85rem;font-weight:600;height:44px;left:0;padding:8px 16px;position:fixed;right:0;text-align:center;top:0;z-index:9999}.app-shell.has-impersonation-banner .dev-banner{top:52px}.dev-banner-content{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 auto;max-width:1200px}.dev-banner-icon{animation:bounce 2s infinite;font-size:1.1rem}.dev-banner-text{font-weight:700;letter-spacing:.5px;text-shadow:1px 1px 2px #0000004d}.dev-banner-details{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border-radius:12px;font-size:.75rem;opacity:.9;padding:2px 8px}@keyframes devBannerPulse{0%,to{opacity:1}50%{opacity:.9}}.trial-banner{background:linear-gradient(135deg,#3c94e7,#2b5fbf);border-bottom:2px solid #a93226;box-shadow:0 2px 8px #0003;box-sizing:border-box;color:#fff;font-family:Arial,sans-serif;font-size:.85rem;font-weight:500;height:48px;left:0;padding:10px 16px;position:fixed;right:0;text-align:center;top:0;z-index:9998}.app-shell.has-impersonation-banner .trial-banner{top:52px}.app-shell.has-dev-banner:not(.has-impersonation-banner) .trial-banner{top:44px}.app-shell.has-impersonation-banner.has-dev-banner .trial-banner{top:96px}.trial-banner-content{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto;max-width:1200px;position:relative}.trial-banner-icon{font-size:1rem}.trial-banner-text{font-weight:600;letter-spacing:.3px}.trial-banner-details{background:#ffffff26;border-radius:12px;font-size:.75rem;opacity:.9;padding:3px 10px}.trial-banner-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.75rem;height:24px;justify-content:center;position:absolute;right:0;top:50%;transform:translateY(-50%);transition:background .2s ease;width:24px}.trial-banner-close:hover{background:#ffffff4d}.version-indicator{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000000d;border:1px solid #0000001a;border-radius:6px;color:#666;font-family:Arial,sans-serif;font-size:.75rem;font-weight:500;padding:6px 12px;pointer-events:none;position:fixed;right:1rem;top:1rem;-webkit-user-select:none;user-select:none;z-index:1001}.app-shell.has-impersonation-banner .version-indicator{top:calc(1rem + 52px)}.version-text{letter-spacing:.3px;opacity:.7}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner){padding-top:52px}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .hamburger-btn{top:calc(1rem + 52px)}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .side-nav{height:calc(100vh - 52px);top:52px}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .app-shell-main{padding-top:calc(4rem + 52px)}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner){padding-top:44px}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .hamburger-btn{top:calc(1rem + 44px)}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .side-nav{height:calc(100vh - 44px);top:44px}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .app-shell-main{padding-top:calc(4rem + 44px)}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner){padding-top:48px}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .hamburger-btn{top:calc(1rem + 48px)}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .side-nav{height:calc(100vh - 48px);top:48px}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .app-shell-main{padding-top:calc(4rem + 48px)}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner){padding-top:96px}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .hamburger-btn{top:calc(1rem + 96px)}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .side-nav{height:calc(100vh - 96px);top:96px}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .app-shell-main{padding-top:calc(4rem + 96px)}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner){padding-top:100px}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .hamburger-btn{top:calc(1rem + 100px)}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .side-nav{height:calc(100vh - 100px);top:100px}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .app-shell-main{padding-top:calc(4rem + 100px)}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner){padding-top:92px}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .hamburger-btn{top:calc(1rem + 92px)}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .side-nav{height:calc(100vh - 92px);top:92px}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .app-shell-main{padding-top:calc(4rem + 92px)}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner{padding-top:144px}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .hamburger-btn{top:calc(1rem + 144px)}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .side-nav{height:calc(100vh - 144px);top:144px}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .app-shell-main{padding-top:calc(4rem + 144px)}.app-shell .side-nav{box-shadow:2px 0 10px #0000001a;height:100vh;left:-100%;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:1000}.app-shell.nav-open .side-nav{left:0}.nav-overlay{background:#00000080;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:999}.app-shell.nav-open .nav-overlay{display:block}.hamburger-btn{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;border:none;border-radius:8px;box-shadow:0 2px 8px #0000004d;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;left:1rem;position:fixed;top:1rem;transition:all .3s ease;width:48px;z-index:1001}.hamburger-btn:hover{background:#000000e6;transform:scale(1.05)}.hamburger-btn:active{transform:scale(.95)}.hamburger-btn span{font-size:1.5rem;font-weight:700}.app-shell-main{background:var(--color-bg-secondary);flex:1 1;min-height:100vh;overflow-y:auto;padding:4rem 1rem 1rem;width:100%}@media (min-width:768px){.hamburger-btn{display:none!important}.app-shell .side-nav{box-shadow:none;left:0;position:relative;width:250px}.app-shell.has-dev-banner .side-nav,.app-shell.has-dev-banner.has-trial-banner .side-nav,.app-shell.has-impersonation-banner .side-nav,.app-shell.has-impersonation-banner.has-dev-banner .side-nav,.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .side-nav,.app-shell.has-impersonation-banner.has-trial-banner .side-nav,.app-shell.has-trial-banner .side-nav{height:100vh;top:0}.nav-overlay{display:none!important}.app-shell-main{padding:2rem}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .app-shell-main{padding-top:calc(2rem + 52px)}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .app-shell-main{padding-top:calc(2rem + 44px)}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .app-shell-main{padding-top:calc(2rem + 48px)}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .app-shell-main{padding-top:calc(2rem + 96px)}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .app-shell-main{padding-top:calc(2rem + 100px)}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .app-shell-main{padding-top:calc(2rem + 92px)}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .app-shell-main{padding-top:calc(2rem + 144px)}}@media (min-width:1024px){.app-shell .side-nav{width:280px}.app-shell-main{padding:2rem 3rem}}@media (max-width:767px){.impersonation-banner{font-size:.8rem;height:46px;padding:8px 10px}.impersonation-banner-content{flex-wrap:nowrap;gap:6px}.impersonation-banner-icon{font-size:1rem}.impersonation-banner-text{font-size:.75rem}.impersonation-banner-text strong{display:none}.impersonation-user-name{font-size:.75rem;padding:1px 5px}.impersonation-banner-admin{display:none}.impersonation-stop-btn{font-size:.75rem;padding:4px 10px}.app-shell.has-impersonation-banner .dev-banner,.app-shell.has-impersonation-banner .trial-banner{top:46px}.app-shell.has-impersonation-banner.has-dev-banner .trial-banner{top:84px}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner){padding-top:46px}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .hamburger-btn{top:calc(1rem + 46px)}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .side-nav{height:calc(100vh - 46px);top:46px}.app-shell.has-impersonation-banner:not(.has-dev-banner):not(.has-trial-banner) .app-shell-main{padding-top:calc(4rem + 46px)}.dev-banner{font-size:.8rem;height:38px;padding:6px 12px}.dev-banner-content{gap:6px}.dev-banner-details{font-size:.7rem;padding:1px 6px}.trial-banner{font-size:.8rem;height:42px;padding:8px 12px}.trial-banner-content{gap:6px}.trial-banner-details{font-size:.7rem;padding:2px 6px}.trial-banner-close{font-size:.65rem;height:20px;width:20px}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner){padding-top:38px}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .hamburger-btn{top:calc(1rem + 38px)}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .side-nav{height:calc(100vh - 38px);top:38px}.app-shell.has-dev-banner:not(.has-impersonation-banner):not(.has-trial-banner) .app-shell-main{padding-top:calc(4rem + 38px)}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner){padding-top:42px}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .hamburger-btn{top:calc(1rem + 42px)}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .side-nav{height:calc(100vh - 42px);top:42px}.app-shell.has-trial-banner:not(.has-impersonation-banner):not(.has-dev-banner) .app-shell-main{padding-top:calc(4rem + 42px)}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner){padding-top:84px}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .hamburger-btn{top:calc(1rem + 84px)}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .side-nav{height:calc(100vh - 84px);top:84px}.app-shell.has-impersonation-banner.has-dev-banner:not(.has-trial-banner) .app-shell-main{padding-top:calc(4rem + 84px)}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner){padding-top:88px}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .hamburger-btn{top:calc(1rem + 88px)}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .side-nav{height:calc(100vh - 88px);top:88px}.app-shell.has-impersonation-banner.has-trial-banner:not(.has-dev-banner) .app-shell-main{padding-top:calc(4rem + 88px)}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner){padding-top:80px}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .hamburger-btn{top:calc(1rem + 80px)}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .side-nav{height:calc(100vh - 80px);top:80px}.app-shell.has-dev-banner.has-trial-banner:not(.has-impersonation-banner) .app-shell-main{padding-top:calc(4rem + 80px)}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner{padding-top:126px}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .hamburger-btn{top:calc(1rem + 126px)}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .side-nav{height:calc(100vh - 126px);top:126px}.app-shell.has-impersonation-banner.has-dev-banner.has-trial-banner .app-shell-main{padding-top:calc(4rem + 126px)}.hamburger-btn{display:flex!important}.version-indicator{font-size:.7rem;padding:4px 8px;right:.5rem;top:.5rem}.app-shell.has-impersonation-banner .version-indicator{top:calc(.5rem + 46px)}}.responsive-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto;white-space:nowrap}@media (max-width:767px){.responsive-table table{min-width:600px}}.responsive-form{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;max-width:100%}@media (min-width:768px){.responsive-form{gap:1.5rem;grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.responsive-form{gap:2rem;grid-template-columns:repeat(3,1fr)}}.responsive-form .full-width{grid-column:1/-1}.card-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}@media (min-width:576px){.card-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.card-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.card-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:767px){.hamburger-btn{display:flex!important}}.dashboard-container{background:var(--color-bg-secondary);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem}@media (min-width:768px){.dashboard-container{padding:2rem}}.dashboard-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}@media (min-width:768px){.dashboard-header{align-items:center;flex-direction:row;justify-content:space-between}}.dashboard-header h1{color:var(--color-text-primary);font-size:1.5rem;margin:0}@media (min-width:768px){.dashboard-header h1{font-size:2rem}}.dashboard-sections{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:768px){.dashboard-sections{grid-template-columns:repeat(2,1fr)}}.dashboard-section{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 6px var(--color-shadow);padding:1.5rem;transition:box-shadow .2s ease}.dashboard-section:hover{box-shadow:0 4px 12px #00000026}.section-header{align-items:center;border-bottom:1px solid #f8f9fa;display:flex;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem}.section-icon{border-radius:8px;color:#fff;font-size:1.5rem;height:48px;justify-content:center;width:48px}.section-icon.aforo{background:linear-gradient(135deg,#667eea,#764ba2)}.section-icon.progreso{background:linear-gradient(135deg,#f093fb,#f5576c)}.section-icon.volumetria{background:linear-gradient(135deg,#4facfe,#00f2fe)}.section-icon.finanzas{background:linear-gradient(135deg,#43e97b,#38f9d7)}.section-title{flex:1 1}.section-title h2{color:var(--color-text-primary);font-size:1.3rem;font-weight:600;margin:0 0 .25rem}@media (min-width:768px){.section-title h2{font-size:1.5rem}}.section-subtitle{color:var(--color-text-tertiary);font-size:.85rem;margin:0}.section-content{display:flex;flex-direction:column;gap:1.5rem}.metrics-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}@media (min-width:768px){.metrics-grid{gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.metric-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:6px;padding:1rem;text-align:center;transition:all .2s ease}.metric-card:hover{background:var(--color-border-light);border-color:var(--color-border);transform:translateY(-1px)}.metric-card h3{color:var(--color-text-tertiary);font-size:.8rem;font-weight:500;letter-spacing:.3px;line-height:1.2;margin:0 0 .5rem;text-transform:uppercase}.metric-value{color:var(--color-text-primary);font-size:1.75rem;font-weight:700;line-height:1;margin:0}@media (min-width:768px){.metric-value{font-size:2rem}}.metric-change{font-size:.75rem;font-weight:500;margin-top:.25rem}.metric-change.positive{color:#28a745}.metric-change.negative{color:#dc3545}.metric-change.neutral{color:var(--color-text-tertiary)}.chart-container{background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:6px;margin-top:.5rem;padding:1rem}.chart-container h4{color:var(--color-text-secondary);font-size:.9rem;font-weight:600;margin:0 0 1rem;text-align:center}.recharts-wrapper{margin:0 auto}.recharts-legend-wrapper{padding-top:1rem!important}.recharts-default-legend{display:flex!important;flex-wrap:wrap!important;gap:.75rem!important;justify-content:center!important}.recharts-legend-item{font-size:.8rem!important;margin-right:0!important}.recharts-legend-item-text{font-weight:500!important}.recharts-legend-item span,.recharts-legend-item text,.recharts-legend-item tspan,.recharts-legend-item-text{fill:var(--color-text-primary)!important;color:var(--color-text-primary)!important}.recharts-pie-label-text{fill:var(--color-text-primary)!important;font-size:.85rem;font-weight:600}.recharts-pie-label-line{stroke:var(--color-text-tertiary)!important;stroke-width:1}.recharts-tooltip-item,.recharts-tooltip-label{color:var(--color-text-primary)!important}.recharts-legend-icon rect[fill="#ffffff"],.recharts-surface rect[fill="#ffffff"]{stroke:var(--color-border)!important;stroke-width:1!important}.empty-state{padding:2rem 1rem}.empty-state-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.1rem}.empty-state p{font-size:.9rem;margin:0}.upcoming-list{background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:6px;list-style:none;margin:0;padding:0}.upcoming-item{align-items:center;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;padding:.75rem 1rem}.upcoming-item:last-child{border-bottom:none}.upcoming-date{color:var(--color-text-secondary);font-size:.9rem;font-weight:600}.upcoming-count{background:var(--color-primary);border-radius:12px;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .6rem}@media (max-width:768px){.dashboard-sections{gap:1.5rem;grid-template-columns:1fr}.dashboard-section{padding:1.25rem}.section-header{flex-direction:column;gap:.5rem;text-align:center}.section-icon{font-size:1.2rem;height:40px;width:40px}.metrics-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.metric-card{padding:.75rem}.metric-value{font-size:1.5rem}.chart-container{padding:.75rem}.chart-container svg{height:auto;max-width:100%}}@media (max-width:480px){.dashboard-container{padding:.75rem}.dashboard-section{padding:1rem}.section-icon{height:36px;width:36px}.section-icon,.section-title h2{font-size:1.1rem}.metrics-grid{grid-template-columns:1fr}.metric-card{padding:1rem}.metric-value{font-size:1.75rem}}.dashboard-section{animation:fadeInUp .4s ease-out}@media (prefers-reduced-motion:reduce){.dashboard-section{animation:none}.metric-card:hover{transform:none}}.dashboard-section:focus-within{outline:2px solid #007bff;outline-offset:2px}@media print{.dashboard-container{background:var(--color-bg-primary);padding:1rem}.dashboard-section{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.section-icon{background:#ddd!important;color:#000!important}}.metric-card:hover{box-shadow:0 2px 4px #007bff1a}.dashboard-section:hover{box-shadow:0 6px 16px #00000026}.section-loading{align-items:center;color:var(--color-text-tertiary);display:flex;justify-content:center;padding:2rem}.section-loading .spinner{border-width:3px;height:32px;margin-bottom:.5rem;width:32px}@media (prefers-contrast:high){.dashboard-section{border:2px solid #000}.metric-card{border:2px solid #666}.section-icon{background:#000!important;border:2px solid #000}}.reg-container{align-items:center;background:linear-gradient(135deg,#1b2735,#090a0f);display:flex;font-family:Roboto,sans-serif;justify-content:center;min-height:100vh;padding:20px 0}.reg-form{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border-radius:10px;box-shadow:0 4px 15px #0000004d;color:#fff;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.reg-title{font-size:1.8rem;margin-bottom:20px;text-align:center}.reg-field,.reg-label{margin-bottom:5px}.reg-label{display:block;font-size:.9rem}.reg-input,.reg-select{background:var(--color-bg-primary);border:none;border-radius:4px;box-sizing:border-box;color:var(--color-text-primary);font-size:1rem;margin-bottom:15px;padding:10px;transition:border .3s ease;width:100%}.reg-select option{background:#1a1a2e;color:#fff;padding:10px}.reg-input-error{border:2px solid #ff6b6b;margin-bottom:5px}.reg-submit-btn{background:#0af;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:12px;transition:background .3s ease;width:100%}.reg-submit-btn:hover:not(:disabled){background:#08c}.reg-submit-btn:disabled{background:#666;cursor:not-allowed}.reg-error-message{color:#ff6b6b}.reg-error-message,.reg-success-message{font-size:.9rem;margin-top:10px;text-align:center}.reg-success-message{background:#4ade8033;border:1px solid #4ade80;border-radius:4px;color:#fff;padding:12px}.reg-field-error{color:#ff6b6b;font-size:.8rem;margin-bottom:10px;margin-top:-10px;padding-left:2px}.reg-pwd-strength-bar{background:#fff3;border-radius:3px;height:6px;margin:4px 0;width:100%}.reg-pwd-strength-fill{background:#ff4d4d;border-radius:3px;height:100%;transition:width .3s ease,background-color .3s ease}.reg-pwd-strength-fill.reg-complete{background:#4ade80}.reg-pwd-requirements{font-size:.85rem;list-style:none;margin:4px 0 12px;padding-left:0}.reg-pwd-requirement{color:#ff4d4d}.reg-pwd-requirement.reg-met{color:#a8e6a3}.reg-validation-bar{background:#ffffff1a;border-radius:3px;height:6px;margin-bottom:10px;margin-top:4px;overflow:hidden}.reg-validation-fill{border-radius:3px;height:100%;transition:all .3s}.reg-validation-fill.reg-checking{animation:reg-pulse 1.5s ease-in-out infinite;background:#f59e0b;width:50%}.reg-validation-fill.reg-unavailable{background:#dc2626}.reg-validation-fill.reg-available{background:#22c55e}.reg-validation-fill.reg-full-width{width:100%}@keyframes reg-pulse{0%,to{opacity:1}50%{opacity:.5}}.reg-legal-section{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;margin:20px 0;padding:15px}.reg-legal-title{color:#fff;font-size:1.2rem;margin:0 0 15px;text-align:center}.reg-loading{color:#aaa;font-style:italic;padding:10px;text-align:center}.reg-legal-documents{margin:15px 0}.reg-legal-document{background:#ffffff14;border:1px solid #ffffff1a;border-radius:6px;margin-bottom:15px;padding:15px}.reg-document-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.reg-document-title{color:#fff;font-size:1rem;margin:0}.reg-required-badge{background:#ff6b6b;border-radius:12px;color:#fff;font-size:.75rem;font-weight:700;padding:2px 8px}.reg-document-description{background:#ffffff0d;border-left:3px solid #0af;border-radius:4px;margin:10px 0;padding:8px 12px}.reg-document-description p{color:#e0e0e0;font-size:.85rem;line-height:1.4;margin:0}.reg-document-file-info{align-items:center;background:#ffffff14;border:1px solid #ffffff1a;border-radius:4px;display:flex;justify-content:space-between;margin:10px 0;padding:10px 12px}.reg-file-details{display:flex;flex-direction:column;gap:2px}.reg-file-name{color:#fff;font-size:.9rem;font-weight:500}.reg-file-size{color:#aaa;font-size:.75rem}.reg-download-link{border:1px solid #0af;border-radius:4px;color:#0af;font-size:.85rem;font-weight:500;padding:6px 12px;text-decoration:none;transition:all .2s ease;white-space:nowrap}.reg-download-link:hover{background:#0af;color:#fff;text-decoration:none}.reg-document-acceptance{margin-top:10px}.reg-acceptance-checkbox{align-items:flex-start;cursor:pointer;display:flex;font-size:.9rem;gap:8px}.reg-acceptance-checkbox input[type=checkbox]{flex-shrink:0;margin:2px 0 0;width:auto}.reg-acceptance-text{color:#fff;line-height:1.3}.reg-gdpr-notice{background:#00aaff1a;border:1px solid #00aaff4d;border-radius:6px;margin-top:15px;padding:12px}.reg-gdpr-notice small{color:#cce7ff;display:block;font-size:.8rem;line-height:1.4}.reg-gdpr-notice strong{color:#0af}@media (max-width:600px){.reg-container{padding:10px}.reg-form{max-height:95vh;padding:20px;width:95%}.reg-document-header{align-items:flex-start;flex-direction:column;gap:5px}.reg-required-badge{align-self:flex-end}.reg-acceptance-checkbox{font-size:.85rem}.reg-document-file-info{align-items:stretch;flex-direction:column;gap:10px}.reg-file-details{align-items:center;text-align:center}.reg-download-link{box-sizing:border-box;text-align:center;width:100%}.reg-document-description p{font-size:.8rem}}body,html{overflow-x:hidden}.page-container,body,html{margin:0;padding:0;width:100%}.page-container{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#0f172a);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh}.header{background:#0f172acc;position:-webkit-sticky;position:sticky}.header-logo{height:50px;transition:transform .3s}.header-logo:hover{transform:scale(1.05)}.login-btn{border:2px solid #dc2626;font-weight:600}.login-btn:hover{transform:translateY(-2px)}.hero{margin:0 auto;max-width:900px;padding:4rem 2rem;text-align:center}.hero-content{display:flex;flex-direction:column}.hero-badge{align-items:center;background:#dc26261a;border:1px solid #dc26264d;border-radius:50px;color:#dc2626;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;margin-bottom:2rem;padding:.5rem 1rem}.hero-title{color:#fff}.text-highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#dc2626,#991b1b);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#ffffffb3;font-size:1.3rem}.alert{border-radius:8px;margin:2rem auto;max-width:1000px;padding:1rem 2rem}.alert-error{background:#dc26261a;border:1px solid #dc2626;color:#fca5a5}.alert-success{background:#22c55e1a;border:1px solid #22c55e;color:#86efac}.form-wrapper{margin:0 auto 4rem;max-width:1000px;padding:0 2rem}.section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;margin-bottom:2rem;padding:2rem}.section-title{color:#fff;font-size:1.5rem;gap:.75rem;margin-bottom:1.5rem}.section-icon,.section-title{align-items:center;display:flex}.section-icon{color:#dc2626}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.form-field{min-width:0}.form-field.full-width{grid-column:1/-1}label{color:#ffffffe6;font-size:.95rem;font-weight:500}label.required:after{color:#dc2626;content:" *"}input,select,textarea{background:#ffffff0d;border:1px solid #fff3;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:.75rem 1rem;transition:all .3s;width:100%}input::placeholder,textarea::placeholder{color:#fff6}input:focus,select:focus,textarea:focus{background:#ffffff14;border-color:#dc2626;outline:none}input.error,select.error,textarea.error{border-color:#dc2626}.field-error{color:#fca5a5;font-size:.85rem}.password-strength{margin-top:.75rem}.strength-bar{background:#ffffff1a;border-radius:3px;height:6px;margin-bottom:.75rem}.strength-fill{border-radius:3px;height:100%;transition:all .3s}.strength-fill.weak{background:#dc2626;width:40%}.strength-fill.medium{background:#f59e0b;width:70%}.strength-fill.strong{background:#22c55e;width:100%}.requirements-list{display:flex;flex-direction:column;gap:.5rem}.requirement{align-items:center;color:#ffffff80;display:flex;font-size:.85rem;gap:.5rem;transition:color .3s}.requirement.met{color:#22c55e}.requirement svg{flex-shrink:0}.validation-bar{background:#ffffff1a;border-radius:3px;height:6px;margin-top:.5rem;overflow:hidden}.validation-fill{border-radius:3px;height:100%;transition:all .3s}.validation-fill.checking{animation:pulse 1.5s ease-in-out infinite;background:#f59e0b;width:50%}.validation-fill.unavailable{background:#dc2626}.validation-fill.available{background:#22c55e}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.gdpr-consent{background:#dc262614;border:1px solid #dc262640;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.checkbox-label{align-items:flex-start;color:#ffffffe6;cursor:pointer;display:flex;gap:.75rem}.checkbox{accent-color:#dc2626;cursor:pointer;flex-shrink:0;height:20px;margin-top:.25rem;min-height:20px;min-width:20px;width:20px}.checkbox-label a{color:#dc2626;text-decoration:none}.checkbox-label a:hover{text-decoration:underline}.submit-section{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem}.submit-btn{border-radius:8px;font-size:1.1rem;font-weight:700;padding:1rem 2rem;transition:all .3s}.submit-btn.primary{background:#dc2626;color:#fff}.submit-btn.primary:hover:not(:disabled){background:#b91c1c;box-shadow:0 8px 20px #dc262666;transform:translateY(-2px)}.submit-btn.secondary{background:#0000;border:2px solid #dc2626;color:#fff}.submit-btn.secondary:hover:not(:disabled){background:#dc26261a}.submit-btn:disabled{opacity:.5;transform:none}.footer{color:#fff9;padding:2rem;text-align:center}.footer-links{justify-content:center;margin-top:1rem}.footer-links a{color:#fff9;text-decoration:none;transition:color .3s}.footer-links a:hover{color:#dc2626}.modal-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293bf2;border:1px solid #dc262680;border-radius:16px;color:#fff}.success-header{background:linear-gradient(135deg,#dc262666,#991b1b66);border-bottom:1px solid #dc26264d;border-top-left-radius:16px;border-top-right-radius:16px;color:#fff;padding:2rem;text-align:center}.success-icon{color:#22c55e;font-size:4rem;margin-bottom:.5rem}.success-header h2{color:#fff;font-size:1.8rem;font-weight:700;margin-bottom:.5rem;margin-top:0}.success-header p{color:#ffffffe6;font-size:1rem;margin:0}.success-body{padding:2rem}.success-notice{align-items:flex-start;border-radius:12px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.success-notice,.success-notice.email{background:#dc262626;border:1px solid #dc262666}.notice-icon{flex-shrink:0;font-size:2rem}.success-notice strong{color:#fff;display:block;font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.success-notice p{color:#fffffff2;font-size:.95rem;line-height:1.5;margin:0 0 .5rem}.success-notice small{color:#fffc;font-size:.85rem}@media (max-width:768px){.hero-title{font-size:2.5rem}.form-grid{grid-template-columns:1fr}.submit-section{flex-direction:column}}@media (max-width:480px){.hero-title{font-size:2rem}.header-content,.section{padding:1rem}}.reset-container{align-items:center;background:url(/static/media/login.dbd9887f0d62cbbbf17d.png) 50%/cover no-repeat;background-color:#f0f0f0;display:flex;font-family:Roboto,sans-serif;justify-content:center;min-height:100vh;padding:1rem;position:relative}.reset-logo{height:60px;left:1rem}.reset-logo,.reset-title{position:absolute;top:1rem;z-index:10}.reset-title{color:#fff;font-size:1.5rem;left:50%;margin:0;text-align:center;transform:translateX(-50%)}.reset-modal{max-width:500px;width:100%;z-index:100}.reset-modal-content{animation:fadeInUp .6s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:12px;box-shadow:0 8px 32px #0000004d;overflow:hidden}.reset-modal-header{background:linear-gradient(135deg,#007bff,#0056b3);border-bottom:1px solid #ffffff1a;padding:1.5rem}.reset-modal-header h2{color:#fff;font-size:1.5rem;font-weight:600;margin:0;text-align:center}.reset-modal-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group>div{position:relative;width:100%}.form-group input{background:var(--color-bg-primary);border:1px solid var(--color-border-dark);border-radius:6px;box-sizing:border-box;font-size:1rem;min-height:50px;padding:1rem 3.5rem 1rem 1rem;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 .2rem #007bff40;outline:none}.form-group input:disabled{background-color:var(--color-border-light);cursor:not-allowed;opacity:1}.password-toggle{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:1.2rem;height:auto;min-height:auto;padding:0;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .2s ease;width:auto}.password-toggle:hover{color:var(--color-text-secondary)}.strength-bar{background:var(--color-border-light);border-radius:2px;height:4px;margin-top:.5rem;overflow:hidden}.strength-bar-fill{height:100%;transition:width .3s ease,background-color .3s ease}.requirements-list{font-size:.8rem;list-style:none;margin-bottom:0;margin-top:.75rem;padding-left:0}.requirements-list li{align-items:center;display:flex;gap:.5rem;padding:4px 0;transition:color .2s ease}.requirements-list li.passed{color:#28a745}.requirements-list li.failed{color:#dc3545}.password-match{align-items:center;display:flex;font-size:.8rem;font-weight:500;gap:.25rem;margin-top:.5rem;transition:color .2s ease}.password-match.match{color:#28a745}.password-match.no-match{color:#dc3545}.error-msg{animation:shake .5s ease-in-out}.error-msg,.success-msg{border-radius:6px;margin-bottom:1rem}.success-msg{animation:fadeIn .4s ease-out;text-align:center}.modal-actions{justify-content:center}.submit-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;min-height:44px;padding:.75rem 2rem;transition:all .3s ease;width:100%}.submit-btn:hover:not(:disabled){box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@media (min-width:768px){.reset-logo{height:80px;left:1.5rem;top:1.5rem}.reset-title{font-size:2rem;top:1.5rem}.reset-modal{max-width:550px}.reset-modal-header h2{font-size:1.8rem}}@media (min-width:1024px){.reset-logo{height:100px;left:2rem;top:2rem}.reset-title{font-size:2.5rem;top:2rem}}.submit-btn:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";display:inline-block;height:14px;margin-left:8px;width:14px}.form-group input:focus,.password-toggle:focus,.submit-btn:focus{outline:2px solid #007bff;outline-offset:2px}@media (prefers-contrast:high){.reset-modal-content{background:#fff}.form-group input,.reset-modal-content{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.error-msg,.reset-modal-content,.success-msg{animation:none}.submit-btn:hover:not(:disabled){transform:none}.password-match,.requirements-list li,.strength-bar-fill{transition:none}}@media print{.reset-container{background:none;padding:0}.reset-logo,.reset-title{position:static}.reset-modal-content{box-shadow:none}.modal-actions,.password-toggle{display:none}}.column-drag-drop-manager{background-color:var(--color-bg-secondary);display:flex;flex-direction:column;font-family:Roboto,sans-serif;gap:1rem}.available-columns-zone{background:var(--color-bg-primary);border:2px dashed var(--color-border);border-radius:12px;box-shadow:0 2px 8px #0000000d;min-height:120px;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.available-columns-zone:before{background:linear-gradient(45deg,#0000 48%,#007bff0d 50%,#0000 52%);background-size:20px 20px;bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease}.available-columns-zone.drop-active{background:var(--color-info-light);border-color:var(--color-primary);box-shadow:0 0 20px #007bff33;transform:scale(1.02)}.available-columns-zone.drop-active:before{opacity:1}.available-columns-zone.empty{background:var(--color-bg-secondary);border-color:var(--color-success);border-style:solid}.available-columns-header{display:flex;flex-direction:column;gap:0;margin-bottom:1rem;text-align:center}.zone-title-row{flex-wrap:nowrap;justify-content:space-between}.zone-title-row,.zone-title-section{align-items:center;display:flex;gap:1rem}.zone-title-section{flex:1 1;text-align:left}.zone-title{align-items:center;color:var(--color-text-primary);display:flex;flex-shrink:0;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0}.zone-subtitle{color:var(--color-text-secondary);flex:1 1;font-size:.85rem;font-style:italic;line-height:1.3;margin:0;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.reset-columns-btn{align-self:center;background:var(--color-text-tertiary);border:none;border-radius:15px;box-shadow:0 1px 3px #0000001a;color:#fff;cursor:pointer;flex-shrink:0;font-size:.8rem;font-weight:500;padding:.4rem .8rem;transition:all .2s ease;white-space:nowrap}.reset-columns-btn:hover{background:var(--color-text-secondary);box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.reset-columns-btn:active{box-shadow:0 1px 3px #0000001a;transform:translateY(0)}.available-columns-zone.drop-active .zone-title{color:var(--color-primary)}.available-columns-zone.drop-active .zone-subtitle{color:var(--color-primary-hover);font-weight:500}.available-columns-list{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;min-height:50px}.no-available-columns{align-items:center;display:flex;flex-direction:column;gap:.5rem;padding:1rem;text-align:center;width:100%}.empty-message{color:var(--color-success);font-size:1rem;font-weight:600}.empty-hint{color:var(--color-text-secondary);font-size:.85rem;font-style:italic;line-height:1.3;max-width:300px}.available-column-chip{align-items:center;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:20px;box-shadow:0 1px 3px #0000001a;color:var(--color-text-primary);display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;overflow:hidden;padding:.6rem 1rem;position:relative;-webkit-user-select:none;user-select:none}.available-column-chip:before{background:linear-gradient(90deg,#0000,#fffc,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.available-column-chip:hover{background:var(--color-bg-primary);border-color:var(--color-primary);box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.available-column-chip:hover:before{left:100%}.available-column-chip.dragging,.available-column-chip:active{box-shadow:0 4px 12px #0003;cursor:grabbing;opacity:.9;transform:scale(.98);z-index:1000}.column-icon{font-size:1rem}.column-name{font-weight:600}.drag-hint{font-size:.8rem;opacity:.7;transition:opacity .2s ease}.available-column-chip:hover .drag-hint{opacity:1}.drop-indicator{align-items:center;animation:pulse-drop 1s ease-in-out infinite;background:#dc35451a;border:2px dashed var(--color-danger);border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.drop-indicator-content{background:#dc3545e6;border:2px solid var(--color-text-inverse);border-radius:20px;box-shadow:0 4px 12px #0000004d;color:#fff;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;text-align:center}.drop-indicator-content,.table-drop-indicator{animation:glow-pulse 1.5s ease-in-out infinite alternate}.table-drop-indicator{background:linear-gradient(180deg,var(--color-primary) 0,var(--color-primary-hover) 50%,var(--color-primary) 100%);border-radius:2px;bottom:0;box-shadow:0 0 8px #007bff99;pointer-events:none;position:absolute;top:0;width:4px;z-index:100}.table-drop-indicator.left{left:-2px}.table-drop-indicator.right{right:-2px}.table-drop-indicator.end{background:linear-gradient(180deg,var(--color-primary) 0,var(--color-primary-hover) 50%,var(--color-primary) 100%);border-radius:2px;box-shadow:0 0 8px #007bff99;position:relative;width:4px}.draggable-header.dragging{border:2px dashed var(--color-warning)!important}.draggable-header.drop-target{border-left:3px solid var(--color-primary)!important}.table-container.dragging-active{-webkit-user-select:none;user-select:none}.table-container.dragging-active .draggable-header:not(.dragging){opacity:.7;transition:opacity .2s ease}.table-container.dragging-active .inline-filter-select{pointer-events:none}@keyframes pulse-drop{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}@media (max-width:768px){.available-columns-zone{min-height:100px;padding:1rem}.available-columns-header{margin-bottom:.75rem}.zone-title-row{align-items:stretch;flex-direction:column;gap:.75rem}.zone-title-section{flex-direction:column;gap:.25rem;text-align:center}.zone-title{font-size:1rem;justify-content:center}.zone-subtitle{font-size:.8rem;text-align:center;white-space:normal}.reset-columns-btn{align-self:center;font-size:.75rem;padding:.3rem .6rem}.available-column-chip{font-size:.85rem;padding:.5rem .75rem}.available-columns-list{gap:.5rem}}@media (max-width:576px){.column-drag-drop-manager{gap:.75rem}.available-columns-zone{min-height:80px;padding:.75rem}.zone-title-row{gap:.5rem}.zone-title-section{gap:.15rem}.zone-subtitle{font-size:.75rem}.available-column-chip{font-size:.8rem;padding:.4rem .6rem}.drag-hint{display:none}}@media (min-width:1200px){.zone-title-section{gap:1.5rem}}.available-column-chip:focus,.reset-columns-btn:focus{outline:2px solid #007bff;outline-offset:2px}@media (prefers-reduced-motion:reduce){.available-column-chip,.available-columns-zone,.draggable-header,.table-drop-indicator{animation:none;transition:none}.available-column-chip:hover{transform:none}.available-column-chip.dragging,.available-column-chip:active{transform:scale(.95)}}@media (prefers-contrast:high){.available-columns-zone{border-color:var(--color-text-primary);border-width:3px}.available-column-chip{background:var(--color-bg-primary);border:2px solid var(--color-text-primary)}.drop-indicator-content{border:2px solid var(--color-text-inverse)}.table-drop-indicator{background:var(--color-text-primary);box-shadow:0 0 8px #000c}.reset-columns-btn{border:2px solid var(--color-text-primary)}}.column-resizer{align-items:center;background:#0000;cursor:col-resize;display:flex;height:100%;justify-content:center;min-height:80px;opacity:0;position:absolute;right:-4px;top:0;transition:opacity .2s ease;width:8px;z-index:20}.resizable-table{position:relative;table-layout:fixed}.resizable-table th{height:auto;min-height:50px;position:relative}.resizable-table td,.resizable-table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.resizable-table td{height:80px;min-height:80px;vertical-align:middle}.resizable-table td .student-photo{align-items:center;display:flex;height:80px;justify-content:center}body.column-resizing{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}body.column-resizing *{cursor:col-resize!important;pointer-events:none!important}body.column-resizing .column-resizer{opacity:1!important;pointer-events:auto!important}body.column-resizing .resizable-table th .column-resizer.resizing{background:#007bff80!important;right:-6px!important;width:12px!important}.resizing-indicator{background:var(--color-primary);bottom:0;box-shadow:0 0 10px #007bff80;display:none;pointer-events:none;position:fixed;top:0;width:2px;z-index:9999}body.column-resizing .resizing-indicator{display:block}@media (min-width:1200px){.column-resizer{right:-5px;width:10px}}@media (max-width:1200px) and (min-width:768px){.column-resizer{right:-4px;width:8px}.resizable-table td{height:100px;min-height:100px}}@media (max-width:767px){.column-resizer{display:none!important}.resizable-table td{height:auto;min-height:auto}}@media (max-width:1024px) and (min-width:768px){.column-resizer{right:-6px;width:12px}.column-resizer.resizing,.column-resizer:hover{background:#007bff66}}.column-resizer:focus{opacity:1;outline:2px solid #007bff;outline-offset:2px}.column-resizer:focus .resizer-handle{opacity:1}@media (prefers-reduced-motion:reduce){.column-resizer,.resizer-handle{transition:none}}@media (prefers-contrast:high){.resizer-handle{background:#000;border:1px solid #fff}.column-resizer.resizing,.column-resizer:hover{background:#0000004d}.column-resizer.resizing .resizer-handle,.column-resizer:hover .resizer-handle{background:#000;border:2px solid #fff}}.students-table.resizable-table tbody tr{height:80px!important}.students-table.resizable-table tbody td{height:80px!important;padding:.2rem .5rem;vertical-align:middle!important}.students-table.resizable-table tbody td:first-child{padding:.3rem}.students-table.resizable-table .no-photo,.students-table.resizable-table .thumb{margin:0 auto}.resizable-table td .venues-list,.resizable-table td.venues-list{max-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.create-user-modal-backdrop{align-items:center!important;backdrop-filter:blur(5px)!important;-webkit-backdrop-filter:blur(5px)!important;background:#000c!important;bottom:0!important;display:flex!important;justify-content:center!important;left:0!important;padding:1rem!important;position:fixed!important;right:0!important;top:0!important;z-index:9999!important}.create-user-modal{background:var(--color-bg-primary)!important;background-color:var(--color-bg-primary)!important;border:2px solid var(--color-border)!important;border-radius:12px!important;box-shadow:0 20px 40px #00000080!important;box-sizing:border-box!important;display:block!important;margin:0!important;max-height:92vh!important;max-width:1200px!important;min-width:900px!important;overflow-y:auto!important;padding:2.5rem!important;position:relative!important;width:100%!important}.create-user-modal.create-user-large-modal{max-height:95vh!important;max-width:1300px!important;min-width:950px!important;overflow-y:auto!important;padding:3rem!important;width:95vw!important}.create-user-modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.create-user-modal-header h3{color:var(--color-text-primary);font-size:1.8rem;margin:0}.create-user-step-indicator{background:var(--color-primary-light);border-radius:25px;color:var(--color-primary);font-size:1rem;font-weight:500;padding:.75rem 1.5rem}.create-user-form-step{margin-bottom:2rem}.create-user-form-grid{grid-gap:2rem!important;align-items:baseline!important;display:grid!important;gap:2rem!important;grid-template-columns:1fr 1fr!important;margin-bottom:3rem!important;width:100%!important}.create-user-form-group{align-items:flex-start;display:flex;flex-direction:column;justify-content:flex-start;min-height:95px!important;width:100%!important}.create-user-form-group label{color:var(--color-text-secondary);display:block;font-size:1rem;font-weight:600;line-height:1.2;margin-bottom:.75rem;margin-top:0;padding-top:0;width:100%}.create-user-form-group input,.create-user-form-group select{background:var(--color-bg-primary)!important;border:1px solid var(--color-border-dark)!important;border-radius:8px!important;box-sizing:border-box!important;color:var(--color-text-primary)!important;font-size:1.1rem!important;height:55px!important;padding:1rem!important;transition:border-color .2s ease,box-shadow .2s ease!important;width:100%!important}.create-user-form-group input:focus,.create-user-form-group select:focus{border-color:#007bff!important;box-shadow:0 0 0 4px #007bff1a!important;outline:none!important}.create-user-form-group input:disabled,.create-user-form-group select:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.create-user-checkbox-group{align-items:center;flex-direction:row;margin-top:.5rem;min-height:60px!important}.create-user-checkbox-label{align-items:center;cursor:pointer;display:flex!important;font-size:1rem!important;font-weight:500!important;gap:.75rem;margin:0!important}.create-user-checkbox-label input[type=checkbox]{cursor:pointer;height:auto!important;margin:0;transform:scale(1.5)!important;width:auto!important}.create-user-password-section{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;margin-bottom:2rem;padding:2.5rem!important}.create-user-password-section h4{align-items:center;color:var(--color-text-secondary);display:flex;font-size:1.3rem;gap:.75rem;margin:0 0 1.5rem}.create-user-password-section h4:before{content:"🔑";font-size:1.5rem}.create-user-pwd-wrapper{position:relative;width:100%}.create-user-pwd-wrapper input{background:var(--color-bg-primary)!important;border:1px solid var(--color-border-dark)!important;border-radius:8px!important;box-sizing:border-box!important;color:var(--color-text-primary)!important;font-size:1.1rem!important;height:55px!important;padding:1rem 4rem 1rem 1rem!important;width:100%!important}.create-user-eye{align-items:center;background:#ffffffe6;border-radius:4px;cursor:pointer;display:flex;font-size:1.5rem!important;height:30px!important;justify-content:center;padding:6px!important;position:absolute;right:15px!important;top:50%;transform:translateY(-50%);transition:all .2s ease;-webkit-user-select:none;user-select:none;width:30px!important;z-index:10}.create-user-eye:hover{background:#fff;box-shadow:0 2px 4px var(--color-shadow);transform:translateY(-50%) scale(1.15)}.create-user-pwd-strength-bar{background-color:var(--color-border-light);border-radius:3px!important;height:6px!important;margin-top:.75rem;overflow:hidden;width:100%}.create-user-pwd-strength-fill{border-radius:3px;height:100%;transition:width .3s ease,background-color .3s ease}.create-user-pwd-requirements{font-size:.95rem;list-style:none;margin:1rem 0 0;padding:0}.create-user-pwd-requirements li{color:#dc3545;padding:.4rem 0;transition:color .2s ease}.create-user-pwd-requirements li.met{color:#28a745}.create-user-pwd-error{color:#dc3545;font-size:.95rem;font-weight:500;margin-top:.75rem}.create-user-error-msg{background-color:var(--color-danger-light);border:1px solid #f5c6cb;border-radius:6px;color:#dc3545;font-size:1rem;margin-bottom:1.5rem;padding:1rem}.create-user-step-description{color:var(--color-text-tertiary);font-size:1.1rem;line-height:1.5;margin-bottom:2rem}.create-user-photo-upload-section{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;margin-bottom:2rem;padding:2.5rem!important}.create-user-photo-upload-section h4{align-items:center;color:var(--color-text-secondary);display:flex;font-size:1.3rem;gap:.75rem;margin:0 0 1.5rem}.create-user-photo-upload-section h4:before{content:"📷";font-size:1.5rem}.create-user-photo-upload-area{align-items:center;display:flex;justify-content:center;min-height:280px!important}.create-user-upload-placeholder{align-items:center;background:var(--color-bg-primary);border:3px dashed #007bff!important;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:1.5rem;min-width:350px!important;padding:3rem!important;text-align:center;transition:all .2s ease}.create-user-upload-placeholder:hover{background:var(--color-bg-tertiary);border-color:#0056b3;transform:translateY(-3px)}.create-user-upload-icon{color:var(--color-primary);font-size:4rem!important}.create-user-upload-placeholder p{color:var(--color-text-secondary);font-size:1.1rem!important;font-weight:500;margin:0}.create-user-photo-file-input{background:var(--color-bg-primary);border:3px dashed #007bff!important;border-radius:8px;cursor:pointer;font-size:1rem!important;padding:1rem!important;transition:all .2s ease;width:100%}.create-user-photo-file-input:hover{background:var(--color-bg-tertiary);border-color:#0056b3}.create-user-photo-file-input:disabled{background:var(--color-bg-tertiary);border-color:var(--color-border-dark);cursor:not-allowed;opacity:.7}.create-user-photo-preview-section{align-items:center;display:flex;flex-direction:column;gap:1.5rem}.create-user-photo-preview-container{display:inline-block;position:relative}.create-user-photo-preview-img{border:4px solid #dee2e6!important;border-radius:16px!important;box-shadow:0 6px 12px #00000026!important;height:280px!important;object-fit:cover;width:280px!important}.create-user-remove-photo-btn{align-items:center;background:#dc3545;border:none;border-radius:50%;box-shadow:0 4px 8px #dc354566!important;color:#fff;cursor:pointer;display:flex;font-size:1.2rem!important;height:38px!important;justify-content:center;position:absolute;right:-10px!important;top:-10px!important;transition:all .2s ease;width:38px!important}.create-user-remove-photo-btn:hover:not(:disabled){background:#c82333;box-shadow:0 6px 12px #dc354580;transform:scale(1.15)}.create-user-remove-photo-btn:disabled{background:#6c757d;box-shadow:0 2px 4px #6c757d4d;cursor:not-allowed;transform:none}.create-user-photo-info{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;min-width:300px!important;padding:1.5rem!important;text-align:center}.create-user-photo-info p{color:var(--color-text-secondary);font-size:1rem!important;margin:.4rem 0}.create-user-photo-info p:first-child{color:var(--color-text-primary);font-weight:600}.create-user-photo-actions{max-width:350px!important;width:100%}.create-user-enrollment-section{background:var(--color-bg-primary);border:1px solid var(--color-border);border-left:6px solid #28a745!important;border-radius:12px;margin-bottom:2rem;padding:2.5rem!important}.create-user-enrollment-section h5{color:var(--color-text-secondary);font-size:1.2rem!important;font-weight:600;margin:0 0 1.5rem}.create-user-iban-section{background:var(--color-bg-primary);border:1px solid var(--color-border);border-left:6px solid #17a2b8!important;border-radius:12px;margin-bottom:2rem;padding:2.5rem!important}.create-user-iban-section h5{color:var(--color-text-secondary);font-size:1.2rem!important;font-weight:600;margin:0 0 1.5rem}.create-user-iban-section input{font-family:Courier New,Consolas,Lucida Console,monospace!important;font-size:1.1rem!important;letter-spacing:1.5px!important;text-transform:uppercase!important}.create-user-iban-section input::placeholder{color:var(--color-text-tertiary);font-weight:400}.create-user-instructor-section{background:var(--color-bg-primary);border:1px solid var(--color-border);border-left:6px solid #ffc107!important;border-radius:12px;margin-bottom:2rem;padding:2.5rem!important}.create-user-instructor-section h5,.create-user-primary-venue-selection h5,.create-user-venues-selection h5{color:var(--color-text-secondary);font-size:1.2rem!important;font-weight:600;margin:0 0 1.5rem}.create-user-venues-checkboxes{grid-gap:1.25rem!important;display:grid;gap:1.25rem!important;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))!important;margin-bottom:2.5rem!important}.create-user-venue-checkbox{align-items:center;background-color:var(--color-bg-primary);border:2px solid #dee2e6!important;border-radius:12px!important;cursor:pointer;display:flex!important;gap:1rem;margin:0!important;padding:1.5rem!important;transition:all .3s ease!important}.create-user-venue-checkbox:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-primary);box-shadow:0 4px 8px #007bff26!important;transform:translateY(-2px)!important}.create-user-venue-checkbox input[type=checkbox]{cursor:pointer;height:auto!important;margin:0!important;transform:scale(1.5)!important;width:auto!important}.create-user-venue-checkbox input[type=checkbox]:checked+span{color:var(--color-primary);font-weight:600}.create-user-venue-checkbox span{flex:1 1;font-size:1rem!important;line-height:1.5}.create-user-venue-checkbox small{color:var(--color-text-tertiary);display:block;font-size:.9rem!important;margin-top:.4rem}.create-user-primary-venue-selection{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:12px;margin-bottom:2rem;padding:2rem!important}.create-user-primary-venue-selection select{background-color:var(--color-bg-primary);border:1px solid var(--color-border-dark);border-radius:8px;box-sizing:border-box;font-size:1.1rem!important;height:55px!important;max-width:400px!important;padding:1rem!important;width:100%}.create-user-no-venues-message{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;color:var(--color-text-tertiary);font-size:1.1rem!important;font-style:italic;padding:3rem!important;text-align:center}.create-user-modal-actions{align-items:center;border-top:2px solid #dee2e6!important;display:flex;flex-wrap:wrap;gap:2rem!important;justify-content:flex-end;margin-top:1.5rem;padding-top:2.5rem!important}.create-user-modal-actions button{border:none;border-radius:8px!important;cursor:pointer;font-size:1.1rem!important;font-weight:600!important;height:55px!important;min-width:180px!important;padding:1.25rem 2.5rem!important;transition:all .3s ease!important}.create-user-modal-actions .create-user-primary-btn{background:var(--color-primary);color:#fff}.create-user-modal-actions .create-user-primary-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 6px 12px #007bff66!important;transform:translateY(-2px)!important}.create-user-modal-actions .create-user-primary-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.create-user-modal-actions button:not(.create-user-primary-btn){background:#6c757d;color:#fff}.create-user-modal-actions button:not(.create-user-primary-btn):hover:not(:disabled){background:#5a6268;box-shadow:0 4px 8px #0003!important;transform:translateY(-2px)}.create-user-modal-actions button:disabled{cursor:not-allowed;opacity:.7;transform:none}@media (max-width:1400px){.create-user-modal.create-user-large-modal{max-width:95vw;min-width:800px;padding:2.5rem}.create-user-modal{max-width:90vw;min-width:750px;padding:2rem}}@media (max-width:1200px){.create-user-modal.create-user-large-modal{max-width:98vw;min-width:700px;padding:2rem}.create-user-modal{max-width:95vw;min-width:650px;padding:1.5rem}.create-user-form-grid{gap:1.5rem;margin-bottom:2.5rem}.create-user-venues-checkboxes{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (max-width:992px){.create-user-modal.create-user-large-modal{max-width:98vw;min-width:600px;padding:1.5rem}.create-user-modal{max-width:95vw;min-width:550px;padding:1.25rem}.create-user-form-grid{gap:1.25rem;margin-bottom:2rem}.create-user-venues-checkboxes{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width:768px){.create-user-modal.create-user-large-modal{margin:.5rem;max-height:98vh;max-width:98vw;min-width:auto;padding:1.5rem;width:98vw}.create-user-modal{max-height:95vh;max-width:95vw;min-width:auto;padding:1.25rem}.create-user-form-grid{gap:1rem;grid-template-columns:1fr}.create-user-modal-header{flex-direction:column;gap:1rem;text-align:center}.create-user-step-indicator{text-align:center;width:100%}.create-user-venues-checkboxes{grid-template-columns:1fr}.create-user-modal-actions{flex-direction:column;gap:.75rem}.create-user-modal-actions button{min-width:auto;width:100%}.create-user-enrollment-section,.create-user-iban-section,.create-user-instructor-section,.create-user-password-section,.create-user-photo-upload-section{padding:1.5rem}.create-user-photo-preview-img{height:200px;width:200px}.create-user-upload-placeholder{min-width:250px;padding:2rem}.create-user-upload-icon{font-size:3rem}}@media (max-width:576px){.create-user-modal.create-user-large-modal{margin:.25rem;max-height:99vh;overflow-y:auto;padding:1rem}.create-user-modal{max-height:96vh;padding:1rem}.create-user-form-group input,.create-user-form-group select{font-size:1rem;height:50px}.create-user-eye{font-size:1.4rem;height:26px;right:12px;width:26px}.create-user-photo-preview-img{height:180px;width:180px}.create-user-upload-placeholder{min-width:220px;padding:1.5rem}.create-user-upload-icon{font-size:2.5rem}.create-user-modal-actions button{font-size:1rem;height:50px;min-width:130px;padding:1rem 1.5rem}}.create-user-venue-checkbox:focus-within{outline:3px solid #007bff!important;outline-offset:3px!important}.create-user-primary-venue-selection select:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #007bff26!important;outline:none}.create-user-photo-file-input:focus{outline:3px solid #007bff!important;outline-offset:3px!important}.create-user-iban-section input:focus{border-color:#17a2b8;box-shadow:0 0 0 4px #17a2b826!important;outline:none}@media (prefers-contrast:high){.create-user-enrollment-section,.create-user-form-group input,.create-user-form-group select,.create-user-iban-section,.create-user-instructor-section,.create-user-password-section,.create-user-photo-file-input,.create-user-photo-upload-section,.create-user-upload-placeholder,.create-user-venue-checkbox{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.create-user-eye,.create-user-modal-actions button,.create-user-remove-photo-btn,.create-user-upload-placeholder,.create-user-venue-checkbox{transition:none}.create-user-modal-actions .create-user-primary-btn:hover,.create-user-modal-actions button:hover,.create-user-remove-photo-btn:hover,.create-user-upload-placeholder:hover,.create-user-venue-checkbox:hover{transform:none}}.license-confirmation-overlay{align-items:center;animation:fadeIn .3s ease;background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10000}.license-confirmation-modal{animation:slideUp .3s ease;background:var(--color-bg-primary);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.license-confirmation-header{background:linear-gradient(135deg,#ff9800,#ff5722);border-radius:12px 12px 0 0;color:#fff;padding:1.5rem}.license-confirmation-header h3{font-size:1.3rem;font-weight:600;margin:0}.license-confirmation-body{padding:2rem}.license-warning-box{background:var(--color-warning-light);border-left:4px solid #ff9800;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.license-warning-box p{color:#856404;font-size:.95rem;margin:.5rem 0}.license-warning-box p:first-child{font-size:1rem;font-weight:600}.license-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1.5rem}.license-info-item{background:var(--color-bg-tertiary);border:2px solid #e9ecef;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.license-label{color:var(--color-text-tertiary);font-size:.85rem;font-weight:500}.license-value{color:#212529;font-size:1.5rem;font-weight:700}.license-value.highlight{color:#ff9800}.license-value.warning{color:#dc3545}.license-details-box{background:#e7f3ff;border-left:4px solid #2196f3;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.license-details-box p{color:#0d47a1;font-size:.95rem;margin:.5rem 0}.license-note{font-size:.9rem!important;font-style:italic;margin-top:1rem!important}.license-question{background:var(--color-bg-tertiary);border-radius:8px;margin-bottom:1rem;padding:1rem;text-align:center}.license-question p{color:#212529;font-size:1.05rem;font-weight:600;margin:0}.license-confirmation-actions{background:var(--color-bg-tertiary);border-radius:0 0 12px 12px;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.license-confirmation-actions button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.license-confirmation-actions .btn-secondary{background:#6c757d;color:#fff}.license-confirmation-actions .btn-secondary:hover{background:#5a6268;box-shadow:0 4px 12px #6c757d4d;transform:translateY(-2px)}.license-confirmation-actions .btn-primary{background:linear-gradient(135deg,#ff9800,#ff5722);color:#fff}.license-confirmation-actions .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#e64a19);box-shadow:0 4px 12px #ff980066;transform:translateY(-2px)}.license-confirmation-actions .btn-primary:disabled{cursor:not-allowed;opacity:.6}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.create-user-form-group input::placeholder,.create-user-form-group select::placeholder,.create-user-password-wrapper input::placeholder{color:var(--color-text-tertiary)!important;opacity:.7}.create-user-form-group select option{background:var(--color-bg-primary)!important;color:var(--color-text-primary)!important}.students-page-container{background:var(--color-bg-secondary);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem}@media (min-width:768px){.students-page-container{padding:1.5rem}}@media (max-width:480px){.students-page-container{padding:.5rem}}.students-page-header{background-color:var(--color-bg-secondary);display:flex;flex-direction:column;gap:1rem}.students-page-header h1{background-color:var(--color-bg-secondary);color:var(--color-text-primary);flex-shrink:0;font-size:1.5rem;margin:0}.students-header-actions{align-items:center;display:flex;flex:1 1;gap:1rem;justify-content:flex-end}.students-header-buttons-group{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.students-page-search{background:var(--color-bg-primary);border:1px solid var(--color-border-dark);border-radius:6px;box-shadow:0 2px 4px #0000001a;flex:1 1;font-size:1rem;max-width:400px;min-width:200px;padding:.75rem;width:100%}@media (min-width:768px){.students-page-header{align-items:center;flex-direction:row;justify-content:space-between}.students-page-header h1{font-size:2rem}}@media (max-width:768px){.students-header-actions{flex-direction:column;gap:.75rem;width:100%}.students-page-search{max-width:none;order:1;width:100%}.students-header-buttons-group{gap:.5rem;justify-content:stretch;order:2;width:100%}.students-header-buttons-group>button{flex:1 1;justify-content:center}}@media (max-width:576px){.students-page-search{font-size:1rem}.students-header-buttons-group{flex-direction:column}.students-header-buttons-group>button{width:100%}.students-page-header{gap:.75rem}}.students-config-btn,.students-pdf-btn{align-items:center;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;min-height:44px;padding:.75rem 1rem;transition:all .2s;white-space:nowrap}.students-config-btn{background:#6c757d}.students-config-btn:hover{background:#5a6268;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.students-config-btn[style*="background: #28a745"]{background:#28a745!important}.students-config-btn[style*="background: #28a745"]:hover{background:#218838!important;box-shadow:0 2px 4px #28a7454d;transform:translateY(-1px)}.students-pdf-btn{background:#dc3545}.students-pdf-btn:hover:not(:disabled){background:#c82333;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.students-pdf-btn:disabled{animation:students-pulse 1.5s ease-in-out infinite;background:#6c757d;cursor:not-allowed;opacity:.7;transform:none}.students-config-btn:focus,.students-pdf-btn:focus{outline:2px solid #007bff;outline-offset:2px}@media (max-width:576px){.students-pdf-btn{font-size:.85rem;padding:.6rem .8rem}}.students-table-wrapper{background:var(--color-bg-primary);border-radius:6px;box-shadow:0 2px 6px var(--color-shadow);overflow:hidden}.students-page-table{border-collapse:collapse;display:table;table-layout:fixed;width:100%}.students-page-table td,.students-page-table th{border-bottom:1px solid #eee;font-size:.9rem;min-width:60px;padding:.4rem;text-align:left;vertical-align:middle}.students-page-table th{background:var(--color-bg-primary);color:var(--color-text-secondary);cursor:pointer;font-weight:600;position:relative;transition:background-color .2s;-webkit-user-select:none;user-select:none}.students-page-table th:hover{background:var(--color-bg-tertiary)}.students-page-table tr:hover{background-color:var(--color-bg-tertiary)}.students-resizable-table{position:relative}.students-resizable-table td,.students-resizable-table th{border-right:1px solid #eee;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.students-resizable-table td:last-child,.students-resizable-table th:last-child{border-right:none}.students-resizable-table th:hover{background:var(--color-bg-tertiary)}.students-resizable-table td[title]{cursor:help}.students-resizing{-webkit-user-select:none;user-select:none}body.students-column-resizing{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}body.students-column-resizing *{cursor:col-resize!important}@media (min-width:1024px){.students-page-table td,.students-page-table th{font-size:1rem;padding:1rem}}@media (max-width:1200px){.students-page-table td,.students-page-table th{font-size:.85rem;padding:.6rem .4rem}}@media (max-width:992px){.students-page-table{font-size:.8rem}.students-page-table td,.students-page-table th{padding:.4rem .25rem}}.students-page-cards{display:none}@media (max-width:767px){.students-page-table{display:none}.students-page-cards{display:block}}.students-page-card{align-items:center;border-bottom:1px solid #eee;display:flex;padding:1rem;transition:background-color .2s}@media (max-width:480px){.students-page-card{padding:.75rem}.students-photo{margin-right:.75rem}}.students-thumb{border:none!important;border-radius:10%!important;box-shadow:none!important;display:block!important;flex-shrink:0!important;height:48px!important;max-height:48px!important;max-width:48px!important;min-height:48px!important;min-width:48px!important;object-fit:cover!important;outline:none!important;width:48px!important}.students-no-photo{background:var(--color-border)!important;border-radius:10%!important;color:var(--color-text-secondary)!important;font-size:.7rem!important;font-weight:500!important}.students-no-photo,.students-photo{align-items:center!important;border:none!important;box-shadow:none!important;display:flex!important;flex-shrink:0!important;height:48px!important;justify-content:center!important;max-height:48px!important;max-width:48px!important;min-height:48px!important;min-width:48px!important;outline:none!important;width:48px!important}.students-photo{overflow:hidden!important}@media (max-width:480px){.students-no-photo,.students-photo,.students-thumb{height:40px!important;max-height:40px!important;max-width:40px!important;min-height:40px!important;min-width:40px!important;width:40px!important}}.students-status-indicator{align-items:center;display:inline-flex;font-size:1.2rem;font-weight:700;height:20px;justify-content:center;margin-left:.5rem;width:20px}.students-status-active{color:#28a745}.students-status-inactive{color:#dc3545}.students-name .students-status-indicator{font-size:1rem;height:16px;margin-left:.5rem;width:16px}.students-page-table td:last-child,.students-page-table th:last-child{min-width:80px;text-align:center}.students-sort-arrow{font-size:.8rem;margin-left:.5rem;opacity:.6}.students-sort-arrow.active{color:var(--color-primary);opacity:1}.students-venues-list{word-wrap:break-word;color:var(--color-text-tertiary);font-style:italic;line-height:1.3;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (min-width:1400px){.students-venues-list{max-width:250px;white-space:normal}}.students-venue-primary{color:var(--color-text-secondary);font-weight:600}.students-info-banner{align-items:center;background-color:var(--color-info-light);border:1px solid #bbdefb;border-radius:6px;color:var(--color-text-primary);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.students-info-icon{font-size:1.1rem}.students-error-msg{background-color:var(--color-danger-light);border:1px solid #f5c6cb;border-radius:4px;color:#dc3545;margin-bottom:1rem;padding:.75rem}.students-loading{align-items:center;color:var(--color-text-tertiary);display:flex;justify-content:center;padding:2rem}.students-empty-state{color:var(--color-text-tertiary);padding:3rem 1rem;text-align:center}.students-empty-state h3{color:var(--color-text-secondary);margin-bottom:.5rem}.students-no-columns-warning{align-items:center;background-color:var(--color-warning-light);border:1px solid #ffeaa7;border-radius:6px;color:#856404;display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.students-no-columns-warning button{background:none;border:none;color:#856404;cursor:pointer;font-weight:500;text-decoration:underline}.students-no-columns-warning button:hover{color:#533f03}.students-page-table .filter-row{background:var(--color-bg-secondary)!important;border-bottom:2px solid var(--color-border);box-shadow:none}.students-page-table .filter-row:hover{background:var(--color-bg-tertiary)!important}.students-page-table .filter-header{background:var(--color-bg-secondary)!important;border-bottom:2px solid var(--color-border)!important;height:45px;padding:.25rem .5rem!important;vertical-align:middle}.students-page-table .filter-header.has-active-filter{background:var(--color-primary-light)!important;border-bottom-color:var(--color-primary)!important}.students-page-table thead tr:first-child th{background:var(--color-bg-primary);border-bottom:1px solid var(--color-border)}.inline-filter-select{-webkit-appearance:none;appearance:none;background:var(--color-bg-primary);background-image:url("data:image/svg+xml;charset=US-ASCII,<svg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 4 5%27><path fill=%27%23666%27 d=%27M2 0L0 2h4zm0 5L0 3h4z%27/></svg>");background-position:right .5rem center;background-repeat:no-repeat;background-size:8px 10px;border:1px solid var(--color-border-dark);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;font-size:.85rem;max-width:100%;min-height:28px;padding:.25rem 1.5rem .25rem .5rem;transition:all .2s;width:100%}.inline-filter-select:hover{box-shadow:0 0 0 .1rem #007bff26}.inline-filter-select:focus,.inline-filter-select:hover{background-color:var(--color-bg-primary);border-color:var(--color-primary)}.inline-filter-select:focus{box-shadow:0 0 0 .2rem #007bff26;outline:none}.inline-filter-select[data-filtered=true]{background-color:var(--color-info-light);border-color:var(--color-primary);color:var(--color-text-primary);font-weight:500}.inline-filter-select:disabled{background-color:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-tertiary);cursor:not-allowed;opacity:.6}.students-page-table .has-active-filter .inline-filter-select{background-color:var(--color-info-light);border-color:#1976d2;color:var(--color-text-primary);font-weight:600}.inline-filter-select option{background:var(--color-bg-primary);color:var(--color-text-secondary);font-size:.9rem;padding:.5rem}.inline-filter-select option:first-child{background:var(--color-bg-tertiary);color:var(--color-text-tertiary);font-style:italic}.inline-filter-select option:checked,.inline-filter-select option:hover{background-color:var(--color-primary);color:#fff}.inline-filter-placeholder{background:var(--color-bg-tertiary);border-radius:4px;color:var(--color-text-tertiary);font-size:.8rem;font-style:italic;padding:.25rem;text-align:center}@media (max-width:1200px){.inline-filter-select{background-size:7px 8px;font-size:.8rem;min-height:26px;padding:.2rem 1.2rem .2rem .4rem}.students-page-table .filter-header{height:40px}}@media (max-width:992px){.inline-filter-select{background-size:6px 7px;font-size:.75rem;min-height:24px;padding:.15rem 1rem .15rem .3rem}.students-page-table .filter-header{height:35px;padding:.15rem .3rem!important}}@media (max-width:767px){.students-page-table .filter-row{display:none}}.draggable-header{position:relative;transition:all .2s ease}.draggable-header:not(.dragging):hover{background:#007bff0d!important;cursor:grab}.draggable-header.dragging{background:#ffc10733!important;border:2px dashed #ffc107!important;cursor:grabbing;opacity:.7;transform:scale(.98);z-index:1000}.draggable-header.drop-target{background:#007bff1a!important;border-left:3px solid #007bff!important;transition:all .2s ease}.students-page-table.dragging-active{-webkit-user-select:none;user-select:none}.students-page-table.dragging-active .draggable-header:not(.dragging){opacity:.7;transition:opacity .2s ease}.students-page-table.dragging-active .inline-filter-select{pointer-events:none}body.dragging-column{-webkit-user-select:none!important;user-select:none!important}body.dragging-column *{cursor:grabbing!important}.column-drop-indicator{animation:glow-pulse 1.5s ease-in-out infinite alternate;background:linear-gradient(180deg,#007bff,#0056b3 50%,#007bff);border-radius:2px;bottom:0;box-shadow:0 0 8px #007bff99;pointer-events:none;position:absolute;top:0;width:4px;z-index:100}.column-drop-indicator.left{left:-2px}.column-drop-indicator.right{right:-2px}.available-column-chip{cursor:grab;transition:all .2s ease}.available-column-chip:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.available-column-chip.dragging{box-shadow:0 8px 16px #0003;cursor:grabbing;opacity:.8;transform:scale(.95) rotate(5deg);z-index:1000}.draggable-header .column-resizer{pointer-events:auto;z-index:200}.draggable-header:hover .column-resizer{opacity:1}.draggable-header .inline-filter-select{pointer-events:auto;z-index:150}.drop-zone-active{background:#007bff1a!important;border:2px dashed #007bff!important}@media (max-width:768px){.column-drop-indicator{width:3px}.draggable-header{cursor:default!important}.available-column-chip{cursor:default}.available-column-chip[draggable],.draggable-header[draggable]{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none}}.students-pdf-date{color:var(--color-text-tertiary);display:none;font-size:.85rem;font-style:italic;margin-top:.5rem;text-align:center}body.generating-students-pdf .students-pdf-date{display:block!important}.students-page-container>[class*=Modal]:last-child,.students-page-container>[class*=modal]:last-child,.students-page-container>div:last-child[class*=Modal],.students-page-container>div:last-child[class*=modal]{align-items:center!important;backdrop-filter:blur(5px)!important;-webkit-backdrop-filter:blur(5px)!important;background:#000c!important;bottom:0!important;display:flex!important;justify-content:center!important;left:0!important;padding:1rem!important;position:fixed!important;right:0!important;top:0!important;z-index:9999!important}@keyframes students-pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}@keyframes students-slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes students-slideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}@keyframes column-added{0%{background:#28a7454d;transform:scale(1.05)}to{background:#0000;transform:scale(1)}}@keyframes glow-pulse{0%{box-shadow:0 0 6px #007bff80}to{box-shadow:0 0 12px #007bffcc,0 0 24px #007bff66}}.students-success-notification{align-items:center;display:flex;font-family:Roboto,sans-serif;font-weight:500;gap:.5rem}.students-success-notification:before{content:"âœ…";font-size:1.1rem}.column-added-animation{animation:column-added .3s ease-out}.students-page-table td,.students-page-table th{transition:width .1s ease}.students-page-card:focus,.students-page-table th:focus{outline:2px solid #007bff;outline-offset:2px}.students-column-config-overlay{z-index:9999}.inline-filter-select:focus-visible{outline:2px solid #007bff;outline-offset:2px}@media (prefers-reduced-motion:reduce){.available-column-chip,.draggable-header,.inline-filter-select,.students-page-table .filter-row{animation:none;transition:none}.available-column-chip:hover,.draggable-header:hover{transform:none}}@media (prefers-contrast:high){.students-config-btn,.students-pdf-btn{border:2px solid #000}.students-config-btn:hover:not(:disabled),.students-pdf-btn:hover:not(:disabled){border-color:#fff}.inline-filter-select{background-color:var(--color-bg-primary);border:2px solid #000}.inline-filter-select:focus{border-color:var(--color-text-primary);box-shadow:0 0 0 3px #00000080}.students-page-table .filter-header{border-bottom:3px solid #000!important}.column-config-modal,.column-item{border:2px solid #000}}@media print{.inline-filter-select,.students-column-resizer,.students-config-btn,.students-header-actions,.students-info-banner,.students-page-header button,.students-page-search,.students-page-table .filter-row,.students-pdf-btn{display:none!important}.students-page-table{display:table!important}.students-page-cards{display:none!important}.students-page-card{break-inside:avoid;page-break-inside:avoid}.students-pdf-date{display:block!important}.students-status-indicator{-webkit-print-color-adjust:exact;print-color-adjust:exact}.students-venues-list{max-width:none;white-space:normal}.students-resizable-table td,.students-resizable-table th{border-right:none!important}}body.generating-students-pdf .students-page-table .filter-row{display:none!important}@media (min-width:769px) and (max-width:1200px){.students-header-actions{flex-wrap:wrap}.students-page-search{flex:1 1 300px;min-width:250px}.students-header-buttons-group{flex:0 0 auto}}@media (min-width:1201px){.students-header-actions{gap:1.5rem}.students-header-buttons-group{gap:1rem}}@media (max-width:576px){.students-success-notification{left:10px!important;right:10px!important;text-align:center;width:auto!important}}.iban-full{background-color:var(--color-bg-secondary)}.iban-full,.iban-masked{border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:monospace;font-size:.9em;padding:2px 6px}.iban-masked{background-color:var(--color-bg-tertiary)}.iban-missing{color:var(--color-text-secondary);font-style:italic}.status-active{color:var(--color-success);font-size:1.2em}.status-inactive{color:var(--color-danger);font-size:1.2em}.modal-content,.modal-header{background:var(--color-bg-primary)!important}.modal-header h2{color:var(--color-text-primary)!important}.form-group input,.form-group select,.form-group textarea,.password-input-wrapper input[type=password],.password-input-wrapper input[type=text]{background:var(--color-bg-primary)!important;color:var(--color-text-primary)!important}.password-input-wrapper input[type=password],.password-input-wrapper input[type=text]{border:1px solid var(--color-border-dark)!important}.error-msg,.success-msg{border:1px solid var(--color-border);color:var(--color-text-primary)}.user-info-box{border-left:4px solid var(--color-primary)!important;border-radius:4px;margin-bottom:1rem;padding:.75rem}.user-info-text{font-size:.9rem;margin:0}.user-info-text,.user-info-text strong{color:var(--color-text-primary)!important}.user-info-text strong{font-weight:600}.password-input-wrapper{position:relative}.password-toggle-btn{background:none!important;border:none!important;color:var(--color-text-tertiary)!important;cursor:pointer;font-size:1.1rem;height:auto;min-height:auto;padding:0;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .2s;width:auto}.password-toggle-btn:hover:not(:disabled){color:var(--color-text-primary)!important}.password-toggle-btn:disabled{cursor:not-allowed;opacity:.5}.password-strength-bar{background:var(--color-border-light);border-radius:2px;height:4px;margin-top:.5rem;overflow:hidden}.password-strength-fill{height:100%;transition:width .3s ease,background-color .3s ease}.password-strength-fill.strength-weak{background-color:var(--color-danger)}.password-strength-fill.strength-medium{background-color:var(--color-warning)}.password-strength-fill.strength-strong{background-color:var(--color-success)}.password-requirements{font-size:.8rem;list-style:none;margin-bottom:0;margin-top:.75rem;padding-left:0}.requirement-item{align-items:center;color:var(--color-text-primary);display:flex;gap:.5rem;padding:2px 0}.requirement-item.valid{color:var(--color-success)!important}.requirement-item.invalid{color:var(--color-danger)!important}.requirement-icon{font-weight:700;text-align:center;width:16px}.password-match-indicator{font-size:.8rem;font-weight:500;margin-top:.5rem}.password-match-indicator.match{color:var(--color-success)!important}.password-match-indicator.no-match{color:var(--color-danger)!important}.modal-actions button{align-items:center;display:flex;gap:.5rem;justify-content:center;min-height:44px}.modal-actions .cancel-btn{background:var(--color-text-tertiary)!important;color:#fff!important}.modal-actions .cancel-btn:hover:not(:disabled){background:var(--color-text-secondary)!important}.modal-actions .submit-btn{background:var(--color-primary)!important;color:#fff!important}.modal-actions .submit-btn:hover:not(:disabled){background:var(--color-primary-hover)!important}.modal-actions .submit-btn:disabled{background:var(--color-bg-primary)!important;cursor:not-allowed;opacity:.6}.modal-actions .cancel-btn:disabled{cursor:not-allowed;opacity:.6}.form-group input:-webkit-autofill,.form-group input:-webkit-autofill:focus,.form-group input:-webkit-autofill:hover,.password-input-wrapper input:-webkit-autofill,.password-input-wrapper input:-webkit-autofill:focus,.password-input-wrapper input:-webkit-autofill:hover{-webkit-text-fill-color:var(--color-text-primary)!important;border:1px solid var(--color-border-dark)!important;box-shadow:0 0 0 1000px var(--color-bg-primary) inset!important;-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s}.password-input-wrapper input{background:var(--color-bg-primary)!important;color:var(--color-text-primary)!important}.delete-modal-overlay{align-items:center;animation:fadeIn .3s ease-out;background:var(--color-overlay);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.delete-modal{animation:slideInScale .3s ease-out;background:var(--color-bg-primary)!important;border:2px solid var(--color-danger);border-radius:12px;box-shadow:0 20px 40px #dc35454d;max-height:90vh;max-width:600px;overflow:hidden;width:90%}.delete-modal-header{align-items:center;background:var(--color-danger-light)!important;border-bottom:2px solid var(--color-danger);display:flex;justify-content:space-between;padding:1.5rem 2rem 1rem}.delete-modal-header h3{color:var(--color-danger)!important;font-size:1.4rem;font-weight:700;margin:0}.delete-modal-close{background:#0000;border:none;border-radius:4px;color:var(--color-danger)!important;cursor:pointer;font-size:1.5rem;padding:.25rem .5rem;transition:all .2s ease}.delete-modal-close:hover{background:#dc354533;transform:scale(1.1)}.delete-modal-body{background:var(--color-bg-primary)!important;max-height:60vh;overflow-y:auto;padding:2rem}.delete-warning{margin-bottom:2rem}.delete-warning>p:first-child{color:var(--color-text-primary)!important;font-size:1.1rem;margin-bottom:1.5rem}.user-info-box{background:var(--color-bg-tertiary)!important;border:1px solid var(--color-border);border-radius:8px;margin:1rem 0;padding:1.5rem}.user-info-box p{color:var(--color-text-primary)!important;font-size:.95rem;margin:.5rem 0}.user-info-box p:first-child{margin-top:0}.user-info-box p:last-child{margin-bottom:0}.danger-text,.user-info-box strong{color:var(--color-text-primary)!important}.danger-text{background:var(--color-danger-light)!important;border:1px solid var(--color-danger);border-radius:6px;font-weight:600;margin:1rem 0;padding:1rem}.danger-text strong{color:var(--color-danger)!important}.alternative-suggestion{background:var(--color-info-light)!important;border:1px solid var(--color-info);border-radius:6px;color:var(--color-text-primary)!important;font-weight:500;margin:1rem 0;padding:1rem}.alternative-suggestion strong{color:var(--color-info)!important}.confirmation-input{margin-bottom:1.5rem}.confirmation-input label{color:var(--color-text-primary)!important;display:block;font-size:.95rem;font-weight:600;margin-bottom:.75rem}.confirmation-input label strong{color:var(--color-danger)!important}.confirmation-text-input{background:var(--color-bg-primary)!important;border:2px solid var(--color-danger);border-radius:6px;color:var(--color-text-primary)!important;font-family:monospace;font-size:1rem;padding:.875rem;transition:all .2s ease;width:100%}.confirmation-text-input:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #dc354533;outline:none}.confirmation-text-input:disabled{background:var(--color-bg-tertiary)!important;cursor:not-allowed;opacity:.7}.confirmation-text-input::placeholder{color:var(--color-text-tertiary)!important;opacity:.7}.delete-error{background:var(--color-danger-light)!important;border:1px solid var(--color-danger);border-radius:6px;color:var(--color-text-primary)!important;margin-bottom:1rem;padding:1rem}.delete-error p{font-weight:500;margin:0}.delete-modal-footer{background:var(--color-bg-secondary)!important;border-top:1px solid var(--color-border);display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.cancel-delete-btn{background:#6c757d!important;border:none;border-radius:6px;color:#fff!important;cursor:pointer;font-size:.95rem;font-weight:500;min-width:120px;padding:.875rem 1.5rem;transition:all .2s ease}.cancel-delete-btn:hover:not(:disabled){background:#5a6268!important;box-shadow:0 4px 8px #6c757d4d;transform:translateY(-1px)}.cancel-delete-btn:disabled{background:#495057!important;cursor:not-allowed;opacity:.8;transform:none}.confirm-delete-btn{align-items:center;background:#dc3545!important;border:none;border-radius:6px;color:#fff!important;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;min-width:160px;padding:.875rem 1.5rem;transition:all .2s ease}.confirm-delete-btn:hover:not(:disabled){background:#c82333!important;box-shadow:0 4px 12px #dc354566;transform:translateY(-1px)}.confirm-delete-btn:disabled{background:#495057!important;box-shadow:none;color:#cbd5e1!important;cursor:not-allowed;opacity:.9;transform:none}@keyframes slideInScale{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width:768px){.delete-modal{margin:1rem;width:95%}.delete-modal-header{padding:1rem 1.5rem .75rem}.delete-modal-header h3{font-size:1.2rem}.delete-modal-body{padding:1.5rem}.delete-modal-footer{flex-direction:column-reverse;padding:1rem 1.5rem}.cancel-delete-btn,.confirm-delete-btn{justify-content:center;width:100%}}@media (max-width:480px){.delete-modal{border-radius:0;height:100%;max-height:none;width:100%}.delete-modal-header{padding:1rem}.delete-modal-body{height:calc(100vh - 200px);max-height:none;padding:1rem}.delete-modal-footer,.user-info-box{padding:1rem}}.delete-modal:focus-within{outline:none}.cancel-delete-btn:focus,.confirm-delete-btn:focus,.confirmation-text-input:focus,.delete-modal-close:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-contrast:high){.delete-modal{border:3px solid var(--color-border)}.delete-modal-header{border-bottom-color:var(--color-danger)}.confirmation-text-input{border-color:var(--color-danger)}.confirm-delete-btn{border:2px solid var(--color-danger)}.cancel-delete-btn{border:2px solid var(--color-border)}}.sdp-loading{color:var(--color-text-secondary)}.sdp-loading-spinner{border-top-color:#007bff}.sdp-action-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}@media (max-width:576px){.sdp-action-buttons{flex-direction:column;gap:.5rem}}.sdp-back-btn{display:flex;transition:background-color .2s}.sdp-back-btn:hover{background:#5a6268}.sdp-retry-btn{align-items:center;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s}.sdp-retry-btn:hover{background:#218838}.sdp-pdf-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .2s;white-space:nowrap}.sdp-pdf-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.sdp-pdf-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.sdp-reset-password-btn{align-items:center;background:#ffc107;border:none;border-radius:6px;color:#000;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .2s}.sdp-reset-password-btn:hover{background:#e0a800;transform:translateY(-1px)}.sdp-delete-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .2s}.sdp-delete-btn:hover{background:#c82333;transform:translateY(-1px)}@media (max-width:576px){.sdp-delete-btn,.sdp-pdf-btn,.sdp-reset-password-btn{justify-content:center;width:100%}}.sdp-info-banner{background:#e7f3ff;border:1px solid #bee5eb;border-radius:4px;color:#0c5460;padding:.75rem}.sdp-error-msg{color:#721c24}body[data-theme=dark] .sdp-error-msg{background-color:#5c2a2a;border-color:#8b3a3a;color:#ffb3b3}.sdp-error-msg p{margin:0}.sdp-success-msg{animation:sdp-fadeIn .3s ease-in;border-radius:4px;padding:.75rem}body[data-theme=dark] .sdp-success-msg{background-color:#1e4a2b;border-color:#2d6b3f;color:#a3e4b5}.sdp-success-msg p{margin:0}.sdp-panel{background:var(--color-bg-secondary)}.sdp-panel h2{color:var(--color-text-primary);margin-bottom:1.5rem;margin-top:0}@media (max-width:576px){.sdp-panel{padding:1rem}.sdp-panel h2{font-size:1.25rem}}.sdp-pdf-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.sdp-pdf-header h2{color:var(--color-text-primary);margin:0}.sdp-pdf-date{color:#6c757d;display:none;font-size:.9rem;font-style:italic}body.generating-pdf .sdp-pdf-date{display:block!important}@media (max-width:576px){.sdp-pdf-header{flex-direction:column;text-align:center}}.sdp-detail-card{align-items:flex-start;display:flex;gap:1.5rem}@media (max-width:768px){.sdp-detail-card{align-items:center;flex-direction:column;text-align:center}}.sdp-photo-section{flex-shrink:0;position:relative}.sdp-photo-container{display:inline-block;position:relative}.sdp-photo-container img{border:3px solid var(--color-border);border-radius:12px;height:120px;object-fit:cover;width:120px}.sdp-no-photo{align-items:center;background:var(--color-bg-tertiary);border-radius:12px;color:var(--color-text-secondary);display:flex;font-weight:500;height:120px;justify-content:center;width:120px}.sdp-no-photo--hidden{display:none}.sdp-edit-photo-btn{align-items:center;background:#007bff;border:none;border-radius:50%;bottom:-8px;box-shadow:0 2px 4px #007bff4d;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:32px;justify-content:center;position:absolute;right:-8px;transition:all .2s ease;width:32px}.sdp-edit-photo-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 8px #007bff66;transform:scale(1.1)}.sdp-edit-photo-btn:disabled{background:#6c757d;box-shadow:0 2px 4px #6c757d4d;cursor:not-allowed;transform:none}@media (max-width:576px){.sdp-no-photo,.sdp-photo-container img{height:100px;width:100px}}.sdp-photo-edit-container{animation:sdp-fadeIn .3s ease-out;background:var(--color-bg-tertiary);border:2px solid var(--color-primary);border-radius:8px;box-shadow:0 4px 12px #007bff1a;margin:1rem 0;padding:1.5rem}.sdp-photo-edit-container h4{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.sdp-photo-edit-container h4:before{content:"📷";font-size:1.2rem}.sdp-photo-edit-form{display:flex;flex-direction:column;gap:1rem}.sdp-photo-file-input{background:var(--color-bg-primary);border:2px dashed var(--color-primary);border-radius:6px;color:var(--color-text-primary);cursor:pointer;font-size:.9rem;padding:.75rem;transition:all .2s ease}.sdp-photo-file-input:hover{background:var(--color-bg-tertiary);border-color:#0056b3}.sdp-photo-file-input:disabled{background:var(--color-bg-tertiary);border-color:var(--color-border);cursor:not-allowed;opacity:.7}.sdp-photo-preview{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);font-size:.9rem;padding:1rem}.sdp-photo-preview p{margin:.25rem 0}.sdp-photo-preview p:first-child{color:#2c3e50;font-weight:600}.sdp-photo-edit-actions{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem}.sdp-save-photo-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:140px;padding:.75rem 1.25rem;transition:all .2s ease}.sdp-save-photo-btn:hover:not(:disabled){background:#218838;box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.sdp-save-photo-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.sdp-cancel-photo-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:120px;padding:.75rem 1.25rem;transition:all .2s ease}.sdp-cancel-photo-btn:hover:not(:disabled){background:#c82333;box-shadow:0 4px 8px #dc35454d;transform:translateY(-1px)}.sdp-cancel-photo-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.sdp-info-section{flex:1 1}.sdp-info-grid{grid-template-columns:1fr}@media (min-width:576px){.sdp-info-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.sdp-info-grid{grid-template-columns:repeat(3,1fr)}}.sdp-info-item{display:flex;flex-direction:column;gap:.25rem}.sdp-info-item strong{color:var(--color-text-secondary);font-size:.9rem;font-weight:600}.sdp-info-item span{color:var(--color-text-secondary);font-size:1rem}.sdp-editable-field{border-radius:6px;margin:-.75rem;padding:.75rem;transition:background-color .2s ease}.sdp-editable-field:hover{background-color:#007bff05}.sdp-field-display{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.sdp-field-display span{word-wrap:break-word;color:var(--color-text-primary);flex:1 1;line-height:1.4}.sdp-field-iban{font-family:monospace;font-size:.9em}.sdp-edit-field-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:.9rem;height:24px;justify-content:center;min-width:24px;opacity:0;padding:.25rem;pointer-events:none;transition:all .2s ease}.sdp-editable-field:hover .sdp-edit-field-btn{opacity:.6;pointer-events:auto}.sdp-edit-field-btn:hover{background:#007bff1a;opacity:1;transform:scale(1.1)}.sdp-edit-field-btn:active{transform:scale(.95)}.sdp-inline-edit-container{align-items:center;animation:sdp-fadeIn .2s ease-in;display:flex;gap:.5rem;width:100%}.sdp-inline-edit-input{background:var(--color-bg-primary);border:2px solid var(--color-primary);border-radius:4px;color:var(--color-text-primary);flex:1 1;font-size:.95rem;outline:none;padding:.5rem;transition:all .2s ease}.sdp-inline-edit-input--iban{font-family:monospace;text-transform:uppercase}.sdp-inline-edit-select{background:var(--color-bg-primary);border:2px solid var(--color-primary);border-radius:4px;color:var(--color-text-primary);cursor:pointer;flex:1 1;font-size:.95rem;outline:none;padding:.5rem;transition:all .2s ease}.sdp-inline-edit-select option{background-color:var(--color-bg-primary);color:var(--color-text-primary);padding:.5rem}.sdp-inline-edit-input:focus,.sdp-inline-edit-select:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff1a}.sdp-inline-edit-input:disabled,.sdp-inline-edit-select:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.sdp-inline-edit-actions{display:flex;flex-shrink:0;gap:.25rem}.sdp-save-field-btn{align-items:center;background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;min-width:28px;padding:.375rem;transition:all .2s ease}.sdp-save-field-btn:hover:not(:disabled){background:#218838;box-shadow:0 2px 4px #28a7454d;transform:scale(1.05)}.sdp-save-field-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.sdp-cancel-field-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;min-width:28px;padding:.375rem;transition:all .2s ease}.sdp-cancel-field-btn:hover:not(:disabled){background:#c82333;box-shadow:0 2px 4px #dc35454d;transform:scale(1.05)}.sdp-cancel-field-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.sdp-venues-display{margin-bottom:1rem}.sdp-venues-list{display:flex;flex-direction:column;gap:.5rem}.sdp-venue-item{align-items:center;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;display:flex;padding:.75rem}.sdp-venue-name{color:var(--color-text-primary);font-weight:500}.sdp-primary-badge{background:#28a745;border-radius:3px;color:#fff;display:inline-block;font-size:.8rem;margin-left:.5rem;padding:.2rem .5rem}.sdp-venue-address{color:var(--color-text-secondary);font-size:.9rem;margin-left:.5rem}.sdp-venues-editing{animation:sdp-fadeIn .3s ease-in-out;background-color:var(--color-bg-tertiary);border:2px solid var(--color-primary);border-radius:8px;padding:1.5rem}.sdp-venues-selection h4{color:var(--color-text-primary);font-size:1.1rem;margin-bottom:1rem}.sdp-venues-checkboxes{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1rem}.sdp-venue-checkbox{align-items:center;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;display:flex!important;gap:.5rem;padding:.75rem;transition:all .2s ease}.sdp-venue-checkbox:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-primary)}.sdp-venue-checkbox input[type=checkbox]{margin:0;transform:scale(1.2)}.sdp-venue-checkbox input[type=checkbox]:checked+span{color:var(--color-primary);font-weight:600}.sdp-primary-venue-selection{margin-bottom:1.5rem}.sdp-primary-venue-selection select{border:1px solid var(--color-border);border-radius:4px;font-size:1rem;min-width:200px;padding:.5rem}.sdp-primary-venue-selection select,.sdp-primary-venue-selection select option{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.sdp-venues-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.sdp-save-btn{align-items:center;background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.25rem;padding:.5rem 1rem;transition:all .2s ease}.sdp-save-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.sdp-save-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.sdp-cancel-btn{align-items:center;background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.25rem;padding:.5rem 1rem;transition:all .2s ease}.sdp-cancel-btn:hover{background:#5a6268;transform:translateY(-1px)}.sdp-edit-btn{align-items:center;background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.25rem;padding:.5rem 1rem;transition:all .2s ease}.sdp-edit-btn:hover{background:#0056b3;transform:translateY(-1px)}@media (max-width:768px){.sdp-venues-checkboxes{grid-template-columns:1fr}.sdp-venues-actions{flex-direction:column}.sdp-cancel-btn,.sdp-edit-btn,.sdp-save-btn{justify-content:center;width:100%}.sdp-primary-venue-selection select{width:100%}}.sdp-exams-info{background-color:var(--color-bg-tertiary);border-left:4px solid #007bff;border-radius:6px;margin-bottom:1rem;padding:.75rem}.sdp-exams-info p{color:var(--color-text-primary);font-size:.9rem;margin:0}.sdp-seminaires-info{background-color:var(--color-bg-tertiary);border-left:4px solid #28a745;border-radius:6px;margin-bottom:1rem;padding:.75rem}.sdp-seminaires-info p{color:var(--color-text-primary);font-size:.9rem;margin:0}.sdp-tournaments-info{background-color:var(--color-bg-tertiary);border-left:4px solid var(--color-warning);border-radius:6px;margin-bottom:1rem;padding:.75rem}.sdp-tournaments-info p{color:var(--color-text-primary);font-size:.9rem;margin:0}.sdp-table-wrapper{margin:0 -.5rem;overflow-x:auto;padding:0 .5rem}.sdp-table{background-color:var(--color-bg-secondary);border-collapse:collapse;font-size:.9rem;table-layout:fixed;width:100%}.sdp-table td,.sdp-table th{border-bottom:1px solid var(--color-border);color:var(--color-text-primary);overflow:hidden;padding:.75rem;text-align:left;text-overflow:ellipsis}.sdp-table th{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);font-weight:600;position:relative;-webkit-user-select:none;user-select:none}.sdp-table td{background-color:var(--color-bg-secondary)}.sdp-table.sdp-table--striped tbody tr:nth-child(2n) td{background-color:var(--color-bg-tertiary)}.sdp-table tbody tr:hover td{background-color:#007bff1a}.sdp-table.sdp-table--resizable{cursor:default}.sdp-table.sdp-table--resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.sdp-table-empty-cell{color:var(--color-text-secondary);padding:2rem;text-align:center}.sdp-grades-cell,.sdp-participation-cell{word-wrap:break-word;font-family:monospace;font-size:.9em;line-height:1.4;padding:.75rem;vertical-align:top;white-space:pre-line;white-space:normal}.sdp-actions-cell{align-items:center;display:flex;gap:.5rem}.sdp-detail-btn{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:4px;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:.5rem;transition:all .2s}.sdp-detail-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-primary);transform:scale(1.05)}.sdp-detail-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.sdp-detail-btn:disabled:hover{background:#0000;border-color:var(--color-border);transform:none}.sdp-exam-pdf-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.25rem;padding:.4rem .6rem;transition:all .2s;white-space:nowrap}.sdp-exam-pdf-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.sdp-exam-pdf-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.7}.sdp-mobile-only{display:block}.sdp-desktop-only{display:none}@media (min-width:769px){.sdp-mobile-only{display:none}.sdp-desktop-only{display:block}}.sdp-exam-card,.sdp-seminaire-card,.sdp-tournament-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem;padding:1rem}.sdp-exam-card-header,.sdp-seminaire-card-header,.sdp-tournament-card-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem}.sdp-exam-card-title,.sdp-seminaire-card-title,.sdp-tournament-card-title{color:var(--color-text-primary);font-size:1.1rem;margin:0}.sdp-exam-card-body,.sdp-seminaire-card-body,.sdp-tournament-card-body{display:flex;flex-direction:column;gap:.5rem}.sdp-exam-detail,.sdp-seminaire-detail,.sdp-tournament-detail{color:var(--color-text-secondary);font-size:.95rem}.sdp-exam-detail strong,.sdp-seminaire-detail strong,.sdp-tournament-detail strong{color:var(--color-text-primary)}.sdp-grades-text{border-left:3px solid #007bff}.sdp-grades-text,.sdp-participation-text{background-color:var(--color-bg-tertiary);border-radius:4px;color:var(--color-text-primary);font-family:monospace;font-size:.9em;line-height:1.4;margin-top:.5rem;padding:.5rem;white-space:pre-line}.sdp-participation-text{border-left:3px solid #ffc107}.sdp-empty-state{color:var(--color-text-secondary);padding:2rem}.sdp-card-actions{display:flex;gap:.5rem}.sdp-error-buttons{display:flex;flex-wrap:wrap;gap:1rem}@keyframes sdp-fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.sdp-field-display{align-items:flex-start;flex-direction:column;gap:.25rem}.sdp-edit-field-btn{align-self:flex-end;opacity:1;pointer-events:auto}.sdp-inline-edit-container{flex-direction:column;gap:.75rem}.sdp-inline-edit-input,.sdp-inline-edit-select{width:100%}.sdp-inline-edit-actions{align-self:center;gap:.5rem}.sdp-cancel-field-btn,.sdp-save-field-btn{font-size:1rem;height:36px;min-width:36px}}@media (max-width:480px){.sdp-field-display{gap:.5rem}.sdp-edit-field-btn{font-size:1rem;height:32px;min-width:32px}.sdp-inline-edit-input,.sdp-inline-edit-select{font-size:1rem;padding:.75rem}.sdp-cancel-field-btn,.sdp-save-field-btn{font-size:1.1rem;height:44px;min-width:44px}.sdp-container{padding:.5rem}.sdp-back-btn{justify-content:center;width:100%}.sdp-panel{padding:.75rem}.sdp-detail-card{gap:1rem}}@media (hover:none) and (pointer:coarse){.sdp-field-display .sdp-edit-field-btn{opacity:.7;pointer-events:auto}.sdp-cancel-field-btn,.sdp-detail-btn,.sdp-save-field-btn{height:44px;min-width:44px}.sdp-detail-btn{padding:.75rem}.sdp-back-btn{min-height:44px;padding:1rem}}.sdp-cancel-field-btn:focus,.sdp-edit-field-btn:focus,.sdp-save-field-btn:focus{outline:2px solid #007bff;outline-offset:2px}.sdp-edit-field-btn:focus-visible{background:#007bff1a;opacity:1}.sdp-primary-venue-selection select:focus,.sdp-venue-checkbox:focus-within{outline:2px solid #007bff;outline-offset:2px}body.generating-pdf .sdp-detail-card{align-items:flex-start!important;flex-direction:row!important;gap:1.5rem!important}body.generating-pdf .sdp-photo-container img{border:2px solid #ddd!important;border-radius:8px!important;height:120px!important;object-fit:cover!important;width:120px!important}body.generating-pdf .sdp-info-grid{gap:1rem!important;grid-template-columns:repeat(2,1fr)!important}body.generating-pdf .sdp-table{border-collapse:collapse!important;font-size:.9rem!important}body.generating-pdf .sdp-table td,body.generating-pdf .sdp-table th{border:1px solid #ddd!important;padding:.5rem!important}body.generating-pdf .sdp-table th{background-color:#f8f9fa!important;color:#333!important;font-weight:600!important}body.generating-pdf .sdp-panel{margin-bottom:1.5rem!important;page-break-inside:avoid!important}body.generating-pdf .sdp-panel h2{color:#333!important;font-size:1.3rem!important;margin-bottom:1rem!important}body.generating-pdf .sdp-exams-info,body.generating-pdf .sdp-seminaires-info,body.generating-pdf .sdp-tournaments-info{background-color:#f9f9f9!important;border:1px solid #ddd!important}@media print{.sdp-action-buttons,.sdp-back-btn,.sdp-delete-btn,.sdp-detail-btn,.sdp-edit-field-btn,.sdp-info-banner,.sdp-inline-edit-container,.sdp-pdf-btn,.sdp-reset-password-btn{display:none!important}.sdp-panel{border:1px solid #ddd;box-shadow:none}.sdp-detail-card,.sdp-panel{break-inside:avoid;page-break-inside:avoid}.sdp-mobile-only{display:none!important}.sdp-desktop-only{display:block!important}}@media (prefers-contrast:high){.sdp-panel{border:2px solid #000}.sdp-photo-container img{border-color:#000}.sdp-detail-btn{border:2px solid #000}.sdp-edit-field-btn{background:#fff;border:1px solid #666}.sdp-save-field-btn{border:2px solid #28a745}.sdp-cancel-field-btn{border:2px solid #dc3545}.sdp-inline-edit-input,.sdp-inline-edit-select{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.sdp-loading-spinner{animation:none}.sdp-back-btn,.sdp-cancel-field-btn,.sdp-detail-btn,.sdp-edit-field-btn,.sdp-save-field-btn{transition:none}.sdp-cancel-field-btn:hover,.sdp-edit-field-btn:hover,.sdp-save-field-btn:hover{transform:none}.sdp-inline-edit-container,.sdp-success-msg{animation:none}}.sdp-protected-indicator{color:#dc3545;font-size:.9rem;font-weight:700;margin-left:.5rem}.sdp-edit-field-btn--disabled{color:#6c757d;cursor:not-allowed;opacity:.3}.sdp-no-venues-message{color:var(--color-text-secondary);font-style:italic;padding:1rem 0}.sdp-venue-info{flex:1 1}.sdp-venue-name-primary{color:#28a745;font-weight:600}.sdp-venue-name-secondary{color:var(--color-text-primary)}.sdp-venue-details{margin-top:.5rem}.sdp-detail-row{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.9rem;gap:.5rem;margin-top:.25rem}.sdp-detail-icon{font-size:.9rem}.sdp-detail-text{flex:1 1}.sdp-legal-docs-info{background:var(--color-bg-tertiary);border-left:4px solid #6c5ce7;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.sdp-legal-docs-info p{color:var(--color-text-primary);font-size:.95rem;margin:.25rem 0}.sdp-legal-docs-info p:first-child{margin-top:0}.sdp-legal-docs-info p:last-child{margin-bottom:0}.sdp-loading-docs{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.sdp-doc-description{color:var(--color-text-secondary);font-size:.9rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sdp-download-btn{align-items:center;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border-radius:6px;box-shadow:0 2px 4px #6c5ce733;display:inline-flex;justify-content:center;padding:.5rem .75rem;text-decoration:none;transition:all .2s ease}.sdp-download-btn:hover{box-shadow:0 4px 8px #6c5ce74d;transform:translateY(-2px)}.sdp-legal-doc-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem;padding:1rem;transition:all .2s ease}.sdp-legal-doc-card:hover{box-shadow:0 4px 12px #0000001a}.sdp-legal-doc-card:last-child{margin-bottom:0}.sdp-legal-doc-card-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:.75rem;margin-bottom:.75rem;padding-bottom:.75rem}.sdp-legal-doc-icon{flex-shrink:0;font-size:2rem}.sdp-legal-doc-card-title{color:var(--color-text-primary);flex:1 1;font-size:1.1rem;font-weight:600;line-height:1.3;margin:0}.sdp-legal-doc-card-body{display:flex;flex-direction:column;gap:.5rem}.sdp-legal-doc-detail{color:var(--color-text-secondary);font-size:.95rem;line-height:1.4}.sdp-legal-doc-detail strong{color:var(--color-text-primary);font-weight:600}@media (max-width:768px){.sdp-legal-docs-info{padding:.5rem .75rem}.sdp-legal-doc-card{padding:.75rem}.sdp-legal-doc-icon{font-size:1.75rem}.sdp-legal-doc-card-title{font-size:1rem}}@media print{.sdp-download-btn{display:none!important}.sdp-legal-doc-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}}@media (prefers-contrast:high){.sdp-download-btn,.sdp-legal-doc-card{border:2px solid #000}.sdp-download-btn{background:#6c5ce7}}.ldm-container{margin:2rem 0;padding:0}.ldm-header{align-items:center;border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--color-border,#e9ecef);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:0 0 1rem}.ldm-header h2{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;margin:0}.ldm-header h2,.ldm-school-info{align-items:center;display:flex;gap:.5rem}.ldm-school-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);color:#fff;font-size:.875rem;font-weight:500;padding:.5rem 1rem}.ldm-info-msg{background:#d1ecf1;background:var(--color-info-light,#d1ecf1);border:1px solid #bee5eb;border:1px solid var(--color-info-border,#bee5eb);border-radius:8px;color:#0c5460;color:var(--color-info-dark,#0c5460);font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.ldm-success-msg{background:#d4edda;background:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);border-radius:8px;color:#155724;color:var(--color-success-dark,#155724)}.ldm-error-msg,.ldm-success-msg{animation:ldm-slideIn .3s ease-out;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.ldm-error-msg{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:8px;color:#dc3545;color:var(--color-danger,#dc3545)}@keyframes ldm-slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.ldm-info-banner{align-items:center;background-color:#fff3cd;background-color:var(--color-warning-light,#fff3cd);border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);border-radius:8px;color:#856404;color:var(--color-warning-dark,#856404);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.ldm-info-icon{font-size:1.1rem}.ldm-upload-section{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;margin-bottom:2rem;padding:1.5rem}.ldm-upload-section h3{align-items:center;color:#4a5568;color:var(--color-text-secondary,#4a5568);display:flex;font-size:1.2rem;gap:.5rem;margin:0 0 1rem}.ldm-upload-form{gap:1rem}.ldm-form-row,.ldm-form-row label,.ldm-upload-form{display:flex;flex-direction:column}.ldm-form-row label{color:#374151;color:var(--color-text-secondary,#374151);font-weight:500;gap:.25rem;margin-bottom:.5rem}.ldm-form-row label.ldm-required:after{color:#ef4444;color:var(--color-danger,#ef4444);content:" *"}.ldm-form-row input,.ldm-form-row textarea{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;color:#333;color:var(--color-text-primary,#333);font-size:.875rem;padding:.75rem;transition:all .2s ease}.ldm-form-row input:focus,.ldm-form-row textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.ldm-form-row input:disabled,.ldm-form-row textarea:disabled{background:#f1f5f9;background:var(--color-bg-disabled,#f1f5f9);cursor:not-allowed;opacity:.6}.ldm-file-help{color:#6b7280;color:var(--color-text-tertiary,#6b7280);font-size:.75rem;margin-top:.25rem}.ldm-checkbox-label{align-items:center;cursor:pointer;flex-direction:row!important;gap:.5rem}.ldm-checkbox-label input[type=checkbox]{margin:0;width:auto}.ldm-progress-bar{background:#e2e8f0;background:var(--color-border,#e2e8f0);border-radius:4px;height:8px;margin:1rem 0;overflow:hidden;width:100%}.ldm-progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .3s ease}.ldm-form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.ldm-btn-primary,.ldm-btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.ldm-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.ldm-btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.ldm-btn-primary:disabled{background:#9ca3af;background:var(--color-secondary,#9ca3af);box-shadow:none;cursor:not-allowed;transform:none}.ldm-btn-secondary{background:#f3f4f6;background:var(--color-bg-tertiary,#f3f4f6);border:1px solid #d1d5db;border:1px solid var(--color-border,#d1d5db);color:#374151;color:var(--color-text-secondary,#374151)}.ldm-btn-secondary:hover:not(:disabled){background:#e5e7eb;background:var(--color-bg-hover,#e5e7eb);border-color:#9ca3af;border-color:var(--color-border-dark,#9ca3af)}.ldm-documents-section{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;padding:1.5rem}.ldm-documents-section h3{align-items:center;color:#4a5568;color:var(--color-text-secondary,#4a5568);display:flex;font-size:1.2rem;gap:.5rem;margin:0 0 1.5rem}.ldm-empty-state{color:#6b7280;color:var(--color-text-tertiary,#6b7280);padding:3rem 1rem;text-align:center}.ldm-empty-icon{font-size:3rem;margin-bottom:1rem}.ldm-empty-state p{color:#4a5568;color:var(--color-text-secondary,#4a5568);font-size:1.1rem;margin-bottom:.5rem}.ldm-empty-state small{color:#9ca3af;color:var(--color-text-tertiary,#9ca3af);font-size:.875rem}.ldm-documents-table{display:flex;flex-direction:column;gap:.5rem}.ldm-table-header{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-radius:8px;color:#374151;color:var(--color-text-secondary,#374151);font-size:.875rem;font-weight:600;padding:1rem}.ldm-document-row,.ldm-table-header{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1fr 1.5fr 1fr}.ldm-document-row{align-items:start;background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;padding:1.5rem 1rem;transition:all .2s ease}.ldm-document-row:hover{border-color:#cbd5e1;border-color:var(--color-border-dark,#cbd5e1);box-shadow:0 2px 8px #0000000d;box-shadow:0 2px 8px var(--color-shadow,#0000000d)}.ldm-document-info{display:flex;flex-direction:column;gap:.5rem}.ldm-document-title{align-items:flex-start;display:flex;gap:.75rem}.ldm-file-icon{flex-shrink:0;font-size:1.5rem}.ldm-document-title strong{color:#1f2937;color:var(--color-text-primary,#1f2937);display:block;font-size:1rem;line-height:1.4;margin-bottom:.25rem}.ldm-document-description{color:#6b7280;color:var(--color-text-tertiary,#6b7280);font-size:.875rem;line-height:1.4;margin-top:.25rem}.ldm-document-status{align-items:flex-start;display:flex}.ldm-status-badge{border-radius:20px;font-size:.75rem;font-weight:500;padding:.375rem .75rem;text-align:center;white-space:nowrap}.ldm-status-badge.ldm-active{background:#dcfce7;background:var(--color-success-light,#dcfce7);border:1px solid #bbf7d0;border:1px solid var(--color-success-border,#bbf7d0);color:#166534;color:var(--color-success-dark,#166534)}.ldm-status-badge.ldm-inactive{background:#fef2f2;background:var(--color-danger-light,#fef2f2);border:1px solid #fecaca;border:1px solid var(--color-danger-border,#fecaca);color:#991b1b;color:var(--color-danger-dark,#991b1b)}.ldm-document-meta{display:flex;flex-direction:column;font-size:.875rem;gap:.25rem}.ldm-meta-item{color:#6b7280;color:var(--color-text-tertiary,#6b7280);line-height:1.4}.ldm-meta-item strong{color:#374151;color:var(--color-text-secondary,#374151);font-weight:500}.ldm-document-actions{align-items:flex-start;display:flex;gap:.5rem}.ldm-action-btn{align-items:center;background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:6px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;padding:.5rem;transition:all .2s ease;width:36px}.ldm-action-btn:hover:not(:disabled){box-shadow:0 2px 8px #00000026;box-shadow:0 2px 8px var(--color-shadow,#00000026);transform:translateY(-1px)}.ldm-action-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.ldm-action-btn.ldm-view{border-color:#3b82f6;color:#3b82f6}.ldm-action-btn.ldm-view:hover:not(:disabled){background:#eff6ff;border-color:#2563eb}.ldm-action-btn.ldm-toggle.ldm-active{border-color:#10b981;border-color:var(--color-success,#10b981);color:#10b981;color:var(--color-success,#10b981)}.ldm-action-btn.ldm-toggle.ldm-active:hover:not(:disabled){background:#ecfdf5;background:var(--color-success-light,#ecfdf5);border-color:#059669}.ldm-action-btn.ldm-toggle.ldm-inactive{border-color:#f59e0b;border-color:var(--color-warning,#f59e0b);color:#f59e0b;color:var(--color-warning,#f59e0b)}.ldm-action-btn.ldm-toggle.ldm-inactive:hover:not(:disabled){background:#fffbeb;background:var(--color-warning-light,#fffbeb);border-color:#d97706}.ldm-action-btn.ldm-delete{border-color:#ef4444;border-color:var(--color-danger,#ef4444);color:#ef4444;color:var(--color-danger,#ef4444)}.ldm-action-btn.ldm-delete:hover:not(:disabled){background:#fef2f2;background:var(--color-danger-light,#fef2f2);border-color:#dc2626}@media (max-width:1024px){.ldm-document-row,.ldm-table-header{gap:1rem;grid-template-columns:1fr}.ldm-table-header{display:none}.ldm-document-row{background:#f9fafb;background:var(--color-bg-tertiary,#f9fafb);border-radius:12px;padding:1.5rem}.ldm-document-actions,.ldm-document-info,.ldm-document-meta,.ldm-document-status{grid-column:1}.ldm-document-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);justify-content:flex-start;margin-top:1rem;padding-top:1rem}}@media (max-width:640px){.ldm-header{align-items:flex-start;gap:1rem}.ldm-form-actions,.ldm-header{flex-direction:column}.ldm-btn-primary,.ldm-btn-secondary{justify-content:center;width:100%}.ldm-document-title{flex-direction:column;gap:.5rem}.ldm-file-icon{align-self:flex-start}}@media (hover:none) and (pointer:coarse){.ldm-action-btn{height:44px;width:44px}.ldm-btn-primary,.ldm-btn-secondary{min-height:44px;padding:.875rem 1.5rem}.ldm-form-row input,.ldm-form-row textarea{font-size:16px;padding:.875rem}}@media print{.ldm-container{margin:0}.ldm-document-actions,.ldm-form-actions,.ldm-info-banner,.ldm-upload-section{display:none!important}.ldm-documents-section{border:1px solid #ddd;box-shadow:none}.ldm-document-row{break-inside:avoid;page-break-inside:avoid}}@media (prefers-contrast:high){.ldm-document-row,.ldm-documents-section,.ldm-form-row input,.ldm-form-row textarea,.ldm-upload-section{border:2px solid #000}.ldm-action-btn,.ldm-btn-primary,.ldm-btn-secondary{border:2px solid}}@media (prefers-reduced-motion:reduce){.ldm-error-msg,.ldm-success-msg{animation:none}.ldm-action-btn:hover:not(:disabled),.ldm-btn-primary:hover:not(:disabled),.ldm-btn-secondary:hover:not(:disabled),.ldm-document-row:hover{transform:none}.ldm-progress-fill{transition:none}}body[data-theme=dark] .ldm-container{color:var(--color-text-primary)}body[data-theme=dark] .ldm-header{border-bottom-color:var(--color-border)}body[data-theme=dark] .ldm-documents-section h3,body[data-theme=dark] .ldm-header h2,body[data-theme=dark] .ldm-upload-section h3{color:var(--color-text-primary)}body[data-theme=dark] .ldm-documents-section,body[data-theme=dark] .ldm-upload-section{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .ldm-form-row label{color:var(--color-text-secondary)}body[data-theme=dark] .ldm-form-row input,body[data-theme=dark] .ldm-form-row textarea{background:var(--color-bg-primary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .ldm-form-row input:focus,body[data-theme=dark] .ldm-form-row textarea:focus{border-color:#667eea}body[data-theme=dark] .ldm-form-row input:disabled,body[data-theme=dark] .ldm-form-row textarea:disabled{background:var(--color-bg-tertiary)}body[data-theme=dark] .ldm-file-help{color:var(--color-text-tertiary)}body[data-theme=dark] .ldm-btn-secondary{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .ldm-btn-secondary:hover:not(:disabled){background:var(--color-bg-primary)}body[data-theme=dark] .ldm-table-header{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}body[data-theme=dark] .ldm-document-row{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .ldm-document-row:hover{border-color:var(--color-border);box-shadow:0 2px 8px #0000004d}body[data-theme=dark] .ldm-document-title strong{color:var(--color-text-primary)}body[data-theme=dark] .ldm-document-description,body[data-theme=dark] .ldm-meta-item{color:var(--color-text-tertiary)}body[data-theme=dark] .ldm-meta-item strong{color:var(--color-text-secondary)}body[data-theme=dark] .ldm-action-btn{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .ldm-action-btn.ldm-view{border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .ldm-action-btn.ldm-view:hover:not(:disabled){background:#60a5fa33}body[data-theme=dark] .ldm-action-btn.ldm-toggle.ldm-active:hover:not(:disabled){background:#10b98133}body[data-theme=dark] .ldm-action-btn.ldm-toggle.ldm-inactive:hover:not(:disabled){background:#f59e0b33}body[data-theme=dark] .ldm-action-btn.ldm-delete:hover:not(:disabled){background:#ef444433}body[data-theme=dark] .ldm-empty-state{color:var(--color-text-tertiary)}body[data-theme=dark] .ldm-empty-state p{color:var(--color-text-secondary)}body[data-theme=dark] .ldm-empty-state small{color:var(--color-text-tertiary)}body[data-theme=dark] .ldm-progress-bar{background:var(--color-bg-tertiary)}body[data-theme=dark] .ldm-info-banner{background-color:#fbbf2433;border-color:var(--color-warning);color:var(--color-warning)}body[data-theme=dark] .ldm-info-msg{background-color:#3b82f633;border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .ldm-success-msg{background-color:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .ldm-error-msg{background-color:#ef444433;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .ldm-status-badge.ldm-active{background:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .ldm-status-badge.ldm-inactive{background:#ef444433;border-color:var(--color-danger);color:var(--color-danger)}.ldm-action-btn:focus,.ldm-btn-primary:focus,.ldm-btn-secondary:focus,.ldm-documents-section:focus-within,.ldm-form-row input:focus,.ldm-form-row textarea:focus,.ldm-upload-section:focus-within{outline:2px solid #667eea;outline-offset:2px}.certificate-templates-manager{padding:1rem}.templates-header{margin-bottom:1.5rem}.templates-header h3{color:var(--color-text-primary);margin:0 0 .5rem}.school-info{color:var(--color-text-tertiary);font-size:.9rem;margin:0}.error-msg,.info-msg,.success-msg{border-radius:6px;margin-bottom:1rem;padding:1rem}.info-msg{background:var(--color-info-light);border:1px solid #bee5eb;color:#0c5460}.info-banner{background:var(--color-warning-light);border:1px solid #ffeaa7;border-radius:6px;color:#856404;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.info-icon{font-size:1.2rem}.template-type-selector{background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:8px;margin-bottom:2rem;padding:1rem}.template-type-selector h4{color:var(--color-text-primary);font-size:1.1rem;margin:0 0 1rem}.template-type-tabs{display:flex;flex-wrap:wrap;gap:.5rem}.tab-button{background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:6px;color:var(--color-text-tertiary);cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.tab-button:hover{background:var(--color-bg-tertiary);border-color:#adb5bd}.tab-button.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.upload-section{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.upload-section h4{align-items:center;color:var(--color-text-primary);display:flex;gap:.5rem;margin:0 0 1rem}.upload-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;flex-wrap:wrap;gap:1rem}.form-group{flex:1 1;min-width:250px}.form-group label{color:var(--color-text-secondary)}.form-group input[type=file],.form-group select{border:1px solid var(--color-border-dark);border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}.form-group input[type=file]:focus,.form-group select:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.form-help{color:var(--color-text-tertiary);display:block;font-size:.8rem;font-style:italic;margin-top:.25rem}.file-info{background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;margin:1rem 0;padding:1rem}.file-info p{color:#1565c0;font-size:.9rem;margin:0 0 .25rem}.file-info p:last-child{margin-bottom:0}.upload-btn{align-self:flex-start;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.upload-btn:hover:not(:disabled){background:#218838}.upload-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.templates-list{margin-top:2rem}.templates-list h4{color:var(--color-text-primary);margin:0 0 1rem}.empty-state{background:var(--color-bg-tertiary);border:2px dashed #dee2e6;border-radius:8px;font-style:italic}.templates-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.template-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:box-shadow .2s ease}.template-card:hover{box-shadow:0 4px 12px #0000001a}.template-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.template-header h5{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.1rem;gap:.5rem;margin:0}.template-badge{background:#17a2b8;border-radius:12px;color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.template-badge.badge-tournament{background:#ffc107;color:#212529}.template-details{color:var(--color-text-tertiary);font-size:.85rem;margin:0 0 .5rem}.template-details:last-of-type{margin-bottom:1rem}.template-details strong{color:var(--color-text-secondary)}.template-actions{display:flex;gap:.5rem;justify-content:flex-end}.action-btn{border:1px solid #0000;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.preview-btn{background:#17a2b8;border-color:#17a2b8;color:#fff}.preview-btn:hover:not(:disabled){background:#138496;border-color:#117a8b}.delete-btn{background:#dc3545;border-color:#dc3545;color:#fff}.delete-btn:hover:not(:disabled){background:#c82333;border-color:#bd2130}.action-btn:disabled{cursor:not-allowed;opacity:.6}.template-preview-modal{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1050}.preview-content{background:var(--color-bg-primary);border-radius:8px;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.preview-header{align-items:center;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:1rem 1.5rem}.preview-header h4{color:var(--color-text-primary);margin:0}.close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--color-text-tertiary);cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;padding:0;transition:background-color .2s ease;width:2rem}.close-btn:hover{background:var(--color-border-light);color:var(--color-text-secondary)}.preview-image-container{align-items:center;background:var(--color-bg-tertiary);display:flex;justify-content:center;overflow:auto;padding:1.5rem}.preview-image{border-radius:4px;box-shadow:0 4px 12px #00000026;max-height:70vh;max-width:100%;object-fit:contain}@media (max-width:768px){.templates-grid{grid-template-columns:1fr}.form-row{flex-direction:column}.form-group{min-width:100%}.template-type-tabs{flex-direction:column}.tab-button{width:100%}.template-header{align-items:flex-start;flex-direction:column;gap:.5rem}.template-actions{justify-content:stretch;width:100%}.action-btn{flex:1 1}}.pmm-container{margin:0 auto;max-width:1400px;padding:2rem}.pmm-header{margin-bottom:2rem}.pmm-header h2{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin:0 0 .5rem}.pmm-description{color:#6c757d;color:var(--color-text-tertiary,#6c757d);line-height:1.6;margin:0}.pmm-profile-selector{background:#fff;background:var(--color-bg-primary,#fff);border-radius:12px;box-shadow:0 2px 8px #0000001a;color:#212529;color:var(--color-text-primary,#212529);margin-bottom:2rem;padding:1.5rem}.pmm-school-selector-wrapper{margin-bottom:1.5rem}.pmm-school-selector-label{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.pmm-school-select{background:linear-gradient(135deg,#f0f9ff,#e0e7ff);border:2px solid #a78bfa;border-radius:8px;box-shadow:0 2px 4px #8b5cf61a;color:#212529;color:var(--color-text-primary,#212529);cursor:pointer;font-size:.95rem;font-weight:500;min-width:300px;padding:.6rem 1rem;transition:all .2s ease;width:100%}.pmm-school-select:hover{border-color:#8b5cf6}.pmm-school-select:focus{border-color:#7c3aed;outline:none}.pmm-school-info-badge{background:linear-gradient(135deg,#dbeafe,#e0e7ff);border:1px solid #93c5fd;border-radius:6px;color:#1e40af;display:inline-block;font-size:.85rem;margin-top:.5rem;padding:.5rem 1rem}.pmm-selector-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.pmm-profile-label{align-items:center;display:flex;gap:.5rem}.pmm-profile-select{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:6px;color:#212529;color:var(--color-text-primary,#212529);min-width:200px;padding:.5rem;width:100%}.pmm-profile-select:focus{border-color:#4299e1;outline:none}.pmm-btn-delete-profile,.pmm-btn-new-profile{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.pmm-btn-new-profile{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.pmm-btn-new-profile:hover:not(:disabled){box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.pmm-btn-delete-profile{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.pmm-btn-delete-profile:hover:not(:disabled){box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.pmm-btn-delete-profile:disabled,.pmm-btn-new-profile:disabled{cursor:not-allowed;opacity:.5}.pmm-info-banner{align-items:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-left:4px solid #2196f3;border-radius:8px;display:flex;gap:.75rem;margin-top:1rem;padding:1rem}.pmm-info-icon{flex-shrink:0;font-size:1.5rem}.pmm-info-banner span:not(.pmm-info-icon){color:#1976d2;font-weight:500}.pmm-protected-banner{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left:4px solid #ff9800;border-radius:8px;margin-top:1rem;padding:1rem 1.25rem}.pmm-protected-banner-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.pmm-protected-banner-header span:first-child{font-size:1.5rem}.pmm-protected-banner-header strong{color:#e65100;font-size:1.1rem}.pmm-protected-banner p{color:#e65100;line-height:1.4;margin:0}.pmm-changes-badge{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border-radius:20px;color:#856404;color:var(--color-warning-dark,#856404);display:inline-block;font-size:.85rem;font-weight:500;margin-top:1rem;padding:.25rem .75rem}.pmm-sections{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-bottom:2rem}.pmm-section{background:#fff;background:var(--color-bg-primary,#fff);border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s}.pmm-section:hover{box-shadow:0 4px 16px #00000026}.pmm-section-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:.75rem;padding:1rem 1.25rem}.pmm-section-icon{font-size:1.5rem}.pmm-section-title{align-items:center;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0}.pmm-permission-grid{padding:1rem}.pmm-permission-item{align-items:center;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem;transition:background .2s}.pmm-permission-item:hover{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.pmm-permission-label{align-items:center;cursor:pointer;display:flex;justify-content:space-between;width:100%}.pmm-permission-text{color:#495057;color:var(--color-text-secondary,#495057);flex:1 1;font-size:.95rem}.pmm-toggle-container{display:inline-block;height:28px;position:relative;width:52px}.pmm-toggle-input{height:0;opacity:0;width:0}.pmm-toggle-slider{background:#cbd5e0;background:var(--color-border,#cbd5e0);border:2px solid #a0aec0;border-radius:34px;bottom:0;cursor:pointer;left:0;right:0;top:0}.pmm-toggle-slider,.pmm-toggle-slider:before{position:absolute;transition:all .3s cubic-bezier(.4,0,.2,1)}.pmm-toggle-slider:before{background:#fff;border-radius:50%;bottom:2px;box-shadow:0 2px 4px #0003;content:"";height:20px;left:2px;width:20px}.pmm-toggle-input:checked+.pmm-toggle-slider{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#5568d3;box-shadow:0 2px 8px #667eea66}.pmm-toggle-input:checked+.pmm-toggle-slider:before{transform:translateX(24px)}.pmm-toggle-input:disabled+.pmm-toggle-slider,.pmm-toggle-slider.pmm-disabled{cursor:not-allowed;opacity:.6}.pmm-toggle-slider.pmm-protected-enabled{background:linear-gradient(135deg,#28a745,#20c997)!important;border:2px solid #1e7e34!important;box-shadow:0 2px 8px #28a7454d!important;cursor:not-allowed!important}.pmm-toggle-slider.pmm-protected-enabled:before{background:#fff!important;box-shadow:0 2px 4px #0003!important}.pmm-toggle-input:disabled:checked+.pmm-toggle-slider.pmm-protected-enabled{background:linear-gradient(135deg,#28a745,#20c997)!important}.pmm-toggle-input:disabled:checked+.pmm-toggle-slider.pmm-protected-enabled:before{background:#fff!important;transform:translateX(24px)!important}.pmm-permission-item:has(.pmm-toggle-slider.pmm-protected-enabled) .pmm-permission-text:after{content:"🔒";font-size:.8em;margin-left:8px;opacity:.7}.pmm-actions{display:flex;gap:1rem;justify-content:center;padding:2rem 0}.pmm-btn-reset,.pmm-btn-save{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s}.pmm-btn-save{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d;color:#fff}.pmm-btn-save:hover:not(:disabled){box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.pmm-btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.pmm-btn-reset{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #dc3545;border:2px solid var(--color-danger,#dc3545);color:#dc3545;color:var(--color-danger,#dc3545)}.pmm-btn-reset:hover:not(:disabled){background:#dc3545;background:var(--color-danger,#dc3545);color:#fff;transform:translateY(-2px)}.pmm-btn-reset:disabled{cursor:not-allowed;opacity:.5;transform:none}.pmm-modal-overlay{align-items:center;animation:pmm-fadeIn .2s ease;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes pmm-fadeIn{0%{opacity:0}to{opacity:1}}.pmm-modal-content{animation:pmm-slideUp .3s ease;background-color:#fff;background-color:var(--color-bg-primary,#fff);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:90vw;min-width:400px;padding:2rem}@keyframes pmm-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pmm-modal-content h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin-top:0}.pmm-form-group{margin-bottom:1rem}.pmm-form-group label{color:#495057;color:var(--color-text-secondary,#495057);display:block;font-weight:500;margin-bottom:.5rem}.pmm-form-input,.pmm-form-select,.pmm-form-textarea{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;padding:.5rem;transition:border-color .2s ease;width:100%}.pmm-form-input:focus,.pmm-form-select:focus,.pmm-form-textarea:focus{border-color:#667eea;outline:none}.pmm-form-textarea{resize:vertical}.pmm-modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.pmm-btn-cancel,.pmm-btn-confirm{border:none;border-radius:6px;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.pmm-btn-cancel{background:#6c757d;background:var(--color-secondary,#6c757d);color:#fff}.pmm-btn-cancel:hover{background:#5a6268}.pmm-btn-confirm{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.pmm-btn-confirm:hover:not(:disabled){box-shadow:0 4px 12px #28a7454d;transform:translateY(-1px)}.pmm-btn-confirm:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.pmm-container{padding:1rem}.pmm-sections{grid-template-columns:1fr}.pmm-profile-label,.pmm-selector-row{align-items:stretch;flex-direction:column}.pmm-btn-delete-profile,.pmm-btn-new-profile,.pmm-profile-select{width:100%}.pmm-actions{flex-direction:column}.pmm-btn-reset,.pmm-btn-save{width:100%}.pmm-modal-content{margin:1rem;min-width:0;min-width:auto;width:90vw}}@media (hover:none) and (pointer:coarse){.pmm-btn-cancel,.pmm-btn-confirm,.pmm-btn-delete-profile,.pmm-btn-new-profile,.pmm-btn-reset,.pmm-btn-save{min-height:44px}.pmm-toggle-container{height:32px;width:58px}.pmm-toggle-slider:before{height:24px;width:24px}.pmm-toggle-input:checked+.pmm-toggle-slider:before{transform:translateX(26px)}.pmm-form-input,.pmm-form-select,.pmm-form-textarea,.pmm-profile-select,.pmm-school-select{font-size:16px}}@media print{.pmm-profile-selector{border:1px solid #000;box-shadow:none}.pmm-actions,.pmm-btn-delete-profile,.pmm-btn-new-profile,.pmm-modal-overlay{display:none!important}.pmm-section{box-shadow:none;break-inside:avoid;page-break-inside:avoid}.pmm-section,.pmm-toggle-slider{border:1px solid #000}}@media (prefers-contrast:high){.pmm-profile-selector,.pmm-section,.pmm-toggle-slider{border:2px solid #000}.pmm-btn-cancel,.pmm-btn-confirm,.pmm-btn-delete-profile,.pmm-btn-new-profile,.pmm-btn-reset,.pmm-btn-save{border:2px solid}}@media (prefers-reduced-motion:reduce){.pmm-modal-content,.pmm-modal-overlay{animation:none}.pmm-btn-delete-profile,.pmm-btn-new-profile,.pmm-btn-reset,.pmm-btn-save,.pmm-section,.pmm-toggle-slider,.pmm-toggle-slider:before{transition:none}}body[data-theme=dark] .pmm-container,body[data-theme=dark] .pmm-header h2{color:var(--color-text-primary)}body[data-theme=dark] .pmm-description{color:var(--color-text-tertiary)}body[data-theme=dark] .pmm-profile-selector{background:var(--color-bg-secondary);box-shadow:0 2px 8px #0000004d}body[data-theme=dark] .pmm-school-select{background:linear-gradient(135deg,#8b5cf633,#764ba233);border-color:#8b5cf6;color:var(--color-text-primary)}body[data-theme=dark] .pmm-school-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .pmm-school-info-badge{background:linear-gradient(135deg,#93c5fd33,#e0e7ff33);border-color:#60a5fa;color:#93c5fd}body[data-theme=dark] .pmm-profile-select{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .pmm-profile-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .pmm-info-banner{background:linear-gradient(135deg,#2196f333,#2196f31a);border-left-color:#60a5fa}body[data-theme=dark] .pmm-info-banner span:not(.pmm-info-icon){color:#93c5fd}body[data-theme=dark] .pmm-protected-banner{background:linear-gradient(135deg,#ff980033,#ff98001a);border-left-color:#ffa726}body[data-theme=dark] .pmm-protected-banner p,body[data-theme=dark] .pmm-protected-banner-header strong{color:#ffb74d}body[data-theme=dark] .pmm-changes-badge{background:#fbbf2433;color:var(--color-warning)}body[data-theme=dark] .pmm-section{background:var(--color-bg-secondary);box-shadow:0 2px 8px #0000004d}body[data-theme=dark] .pmm-permission-item:hover{background:var(--color-bg-tertiary)}body[data-theme=dark] .pmm-permission-text{color:var(--color-text-secondary)}body[data-theme=dark] .pmm-toggle-slider{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .pmm-btn-reset{background:var(--color-bg-secondary);border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .pmm-btn-reset:hover:not(:disabled){background:var(--color-danger);color:#fff}body[data-theme=dark] .pmm-modal-content{background-color:var(--color-bg-secondary)}body[data-theme=dark] .pmm-modal-content h3{color:var(--color-text-primary)}body[data-theme=dark] .pmm-form-group label{color:var(--color-text-secondary)}body[data-theme=dark] .pmm-form-input,body[data-theme=dark] .pmm-form-select,body[data-theme=dark] .pmm-form-textarea{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .pmm-form-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.pmm-btn-cancel:focus,.pmm-btn-confirm:focus,.pmm-btn-delete-profile:focus,.pmm-btn-new-profile:focus,.pmm-btn-reset:focus,.pmm-btn-save:focus,.pmm-form-input:focus,.pmm-form-select:focus,.pmm-form-textarea:focus,.pmm-profile-select:focus,.pmm-school-select:focus,.pmm-toggle-input:focus+.pmm-toggle-slider{outline:2px solid #667eea;outline:2px solid var(--color-primary,#667eea);outline-offset:2px}.spl-container{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem}@media (min-width:768px){.spl-container{padding:2rem}}.spl-info-banner{align-items:center;background:#e3f2fd;background:var(--color-info-light,#e3f2fd);border:1px solid #90caf9;border:1px solid var(--color-info-border,#90caf9);border-radius:6px;color:#0c5460;color:var(--color-info-dark,#0c5460);display:flex;font-size:.95rem;gap:.5rem;margin-bottom:1rem;padding:1rem}.spl-info-icon{font-size:1.2rem}.spl-header{margin-bottom:2rem}.spl-btn-back{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem;transition:background .2s ease}.spl-btn-back:hover{background:#5a6268}.spl-header h2{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.8rem;margin-bottom:1rem;text-align:center}@media (min-width:768px){.spl-header h2{font-size:2.2rem}}.spl-subtitle{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:1.1rem;margin-left:auto;margin-right:auto;max-width:600px}.spl-subtitle,.spl-user-count-info{margin-bottom:2rem;text-align:center}.spl-user-count-info{background:#e7f3ff;background:var(--color-info-light,#e7f3ff);border:1px solid #bee5eb;border:1px solid var(--color-info-border,#bee5eb);border-radius:8px;padding:1rem}.spl-user-count-info p{color:#0c5460;color:var(--color-info-dark,#0c5460);margin:0}.spl-user-count-info p:first-child{font-size:1.1rem;margin-bottom:.5rem}.spl-help-text{font-size:.9rem;opacity:.8}.spl-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;font-size:1.1rem;justify-content:center;padding:4rem}.spl-loading-spinner{animation:spl-spin 1s linear infinite;border:4px solid #dee2e6;border-top-color:#007bff;border:4px solid var(--color-border,#dee2e6);border-radius:50%;border-top-color:var(--color-primary,#007bff);height:40px;margin-bottom:1rem;width:40px}@keyframes spl-spin{to{transform:rotate(1turn)}}.spl-plans-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin:0 auto;max-width:900px}@media (max-width:768px){.spl-plans-grid{gap:1.5rem;grid-template-columns:1fr}}.spl-plan-card{animation:spl-fadeInUp .4s ease-out;background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:12px;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--color-shadow,#0000001a);cursor:pointer;padding:2rem;position:relative;transition:all .3s ease}.spl-plan-card:nth-child(2){animation-delay:.1s}@keyframes spl-fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.spl-plan-card:hover{box-shadow:0 8px 25px #00000026;box-shadow:0 8px 25px var(--color-shadow,#00000026);transform:translateY(-2px)}.spl-plan-card.spl-selected{background:linear-gradient(135deg,#fff,#f8f9ff);background:linear-gradient(135deg,var(--color-bg-primary,#fff),var(--color-bg-tertiary,#f8f9ff));border-color:#007bff;border-color:var(--color-primary,#007bff)}.spl-plan-card.spl-popular{border-color:#28a745;border-color:var(--color-success,#28a745);position:relative}.spl-plan-card.spl-popular:before{background:#28a745;background:var(--color-success,#28a745);border-radius:20px;color:#fff;content:"💎 MÁS POPULAR";font-size:.8rem;font-weight:600;left:50%;letter-spacing:.5px;padding:.3rem 1rem;position:absolute;top:-12px;transform:translateX(-50%)}.spl-plan-card.spl-disabled{cursor:default;opacity:.8}.spl-plan-card.spl-disabled:hover{transform:none}.spl-plan-header{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);margin-bottom:2rem;padding-bottom:1.5rem;text-align:center}.spl-plan-header h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.spl-plan-description{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:1rem;line-height:1.5;margin-bottom:1rem}.spl-billing-period{background:#007bff;background:var(--color-primary,#007bff);border-radius:15px;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.3px;padding:.3rem .8rem;text-transform:uppercase}.spl-billing-period.spl-annual{background:#28a745;background:var(--color-success,#28a745)}.spl-plan-pricing{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:8px;margin-bottom:2rem;padding:1.5rem;text-align:center}.spl-main-price{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.spl-price-period{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:1rem;margin-bottom:1rem}.spl-price-details{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;line-height:1.4}.spl-price-details p{margin:.5rem 0}.spl-minimum-notice{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border:1px solid #ffeaa7;border:1px solid var(--color-warning,#ffeaa7);border-radius:6px;color:#856404;color:var(--color-warning-dark,#856404);font-size:.85rem;margin-top:1rem;padding:.5rem .8rem}.spl-minimum-notice.spl-success{background:#d4edda;background:var(--color-success-light,#d4edda);border-color:#c3e6cb;border-color:var(--color-success-border,#c3e6cb);color:#155724;color:var(--color-success-dark,#155724)}.spl-savings-badge{background:#28a745;background:var(--color-success,#28a745);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;margin-left:.5rem;padding:.2rem .6rem}.spl-plan-features{margin-bottom:2rem}.spl-plan-features h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;font-weight:600;margin-bottom:1rem;text-align:center}.spl-features-grid{grid-gap:.8rem;display:grid;gap:.8rem}.spl-feature-item{align-items:flex-start;background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:6px;display:flex;gap:.75rem;padding:.75rem;transition:background .2s ease}.spl-feature-item:hover{background:#e9ecef;background:var(--color-bg-hover,#e9ecef)}.spl-feature-icon{font-size:1.1rem;margin-top:.1rem;min-width:20px}.spl-feature-content{flex:1 1}.spl-feature-content h5{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:.95rem;font-weight:600;margin:0 0 .3rem}.spl-feature-content p{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.85rem;line-height:1.3;margin:0}.spl-btn-select{background:#007bff;background:var(--color-primary,#007bff);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;letter-spacing:.5px;padding:1rem 1.5rem;text-transform:uppercase;transition:all .2s ease;width:100%}.spl-btn-select:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.spl-btn-select:disabled{background:#6c757d;background:var(--color-secondary,#6c757d);cursor:not-allowed;opacity:.6;transform:none}.spl-plan-card.spl-selected .spl-btn-select{background:#28a745;background:var(--color-success,#28a745)}.spl-plan-card.spl-selected .spl-btn-select:hover:not(:disabled){background:#1e7e34}@media (max-width:768px){.spl-container{padding:1rem .5rem}.spl-plan-card{padding:1.5rem}.spl-header h2{font-size:1.5rem}.spl-main-price{font-size:2rem}.spl-plans-grid{grid-template-columns:1fr}}@media (max-width:480px){.spl-plan-card{padding:1.25rem}.spl-main-price{font-size:1.8rem}.spl-feature-item{padding:.5rem}}@media (hover:none) and (pointer:coarse){.spl-btn-back,.spl-btn-select{min-height:44px}.spl-plan-card:hover{transform:none}.spl-feature-item{padding:.875rem}}@media print{.spl-container{background:#fff;padding:1rem}.spl-plan-card{animation:none;border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.spl-btn-back,.spl-btn-select,.spl-info-banner{display:none!important}}@media (prefers-contrast:high){.spl-plan-card{border:3px solid #000}.spl-btn-back,.spl-btn-select{border:2px solid}.spl-feature-item{border:1px solid #000}}@media (prefers-reduced-motion:reduce){.spl-plan-card{animation:none}.spl-btn-select:hover:not(:disabled),.spl-plan-card:hover{transform:none}.spl-loading-spinner{animation:none}}body[data-theme=dark] .spl-container{background:var(--color-bg-primary)}body[data-theme=dark] .spl-info-banner{background:#3b82f633;border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .spl-btn-back{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .spl-btn-back:hover{background:var(--color-bg-secondary)}body[data-theme=dark] .spl-header h2{color:var(--color-text-primary)}body[data-theme=dark] .spl-subtitle{color:var(--color-text-tertiary)}body[data-theme=dark] .spl-user-count-info{background:#3b82f633;border-color:#60a5fa}body[data-theme=dark] .spl-user-count-info p{color:#60a5fa}body[data-theme=dark] .spl-loading{color:var(--color-text-tertiary)}body[data-theme=dark] .spl-loading-spinner{border-color:var(--color-border);border-top-color:var(--color-primary)}body[data-theme=dark] .spl-plan-card{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .spl-plan-card:hover{box-shadow:0 8px 25px #0000004d}body[data-theme=dark] .spl-plan-card.spl-selected{background:linear-gradient(135deg,var(--color-bg-secondary),var(--color-bg-tertiary));border-color:var(--color-primary)}body[data-theme=dark] .spl-plan-card.spl-popular{border-color:var(--color-success)}body[data-theme=dark] .spl-plan-header{border-bottom-color:var(--color-border)}body[data-theme=dark] .spl-plan-header h3{color:var(--color-text-primary)}body[data-theme=dark] .spl-plan-description{color:var(--color-text-tertiary)}body[data-theme=dark] .spl-plan-pricing{background:var(--color-bg-tertiary)}body[data-theme=dark] .spl-main-price{color:var(--color-text-primary)}body[data-theme=dark] .spl-price-period{color:var(--color-text-tertiary)}body[data-theme=dark] .spl-price-details{color:var(--color-text-secondary)}body[data-theme=dark] .spl-minimum-notice{background:#fbbf2433;border-color:var(--color-warning);color:var(--color-warning)}body[data-theme=dark] .spl-minimum-notice.spl-success{background:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .spl-plan-features h4{color:var(--color-text-primary)}body[data-theme=dark] .spl-feature-item{background:var(--color-bg-tertiary)}body[data-theme=dark] .spl-feature-item:hover{background:var(--color-bg-primary)}body[data-theme=dark] .spl-feature-content h5{color:var(--color-text-primary)}body[data-theme=dark] .spl-feature-content p{color:var(--color-text-tertiary)}.spl-btn-back:focus,.spl-btn-select:focus,.spl-plan-card:focus-within{outline:2px solid #007bff;outline:2px solid var(--color-primary,#007bff);outline-offset:2px}.cas-section{border-top:2px solid #dee2e6;border-top:2px solid var(--color-border,#dee2e6);margin-top:3rem;padding-top:2rem}.cas-warning-box{background:linear-gradient(135deg,#fff5f5,#ffe5e5);border:2px solid #dc3545;border:2px solid var(--color-danger,#dc3545);border-radius:12px;padding:2rem;text-align:center}.cas-warning-box h3{color:#dc3545;color:var(--color-danger,#dc3545);font-size:1.3rem;margin-bottom:1rem;margin-top:0}.cas-warning-box p{color:#721c24;color:var(--color-danger-dark,#721c24);font-size:1rem;margin-bottom:1.5rem}.cas-btn-danger-outline{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #dc3545;border:2px solid var(--color-danger,#dc3545);border-radius:8px;color:#dc3545;color:var(--color-danger,#dc3545);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.cas-btn-danger-outline:hover{background:#dc3545;background:var(--color-danger,#dc3545);box-shadow:0 4px 12px #dc35454d;color:#fff;transform:translateY(-2px)}.cas-modal-overlay{align-items:center;animation:cas-fadeIn .3s ease;background:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10000}@keyframes cas-fadeIn{0%{opacity:0}to{opacity:1}}.cas-modal{animation:cas-slideUp .3s ease;background:#fff;background:var(--color-bg-primary,#fff);border-radius:12px;box-shadow:0 10px 40px #0006;max-height:90vh;max-width:700px;overflow-y:auto;width:90%}@keyframes cas-slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.cas-modal-header{border-radius:12px 12px 0 0;padding:1.5rem;position:relative}.cas-modal-header.cas-danger{background:linear-gradient(135deg,#dc3545,#c82333);background:linear-gradient(135deg,var(--color-danger,#dc3545),#c82333);color:#fff}.cas-modal-header h2{font-size:1.4rem;font-weight:600;margin:0}.cas-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;line-height:1;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:40px}.cas-modal-close:hover:not(:disabled){background:#ffffff4d;transform:rotate(90deg)}.cas-modal-close:disabled{cursor:not-allowed;opacity:.5}.cas-modal-body{padding:2rem}.cas-error{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border-left:4px solid #dc3545;border-left:4px solid var(--color-danger,#dc3545);border-radius:8px;color:#721c24;color:var(--color-danger-dark,#721c24);font-weight:500;margin-bottom:1.5rem;padding:1rem}.cas-warning-content{text-align:center}.cas-warning-icon{font-size:4rem;margin-bottom:1rem}.cas-warning-content h3{color:#dc3545;color:var(--color-danger,#dc3545);font-size:1.5rem;margin-bottom:1rem}.cas-warning-content>p{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:1rem;margin-bottom:2rem}.cas-consequences{margin-top:2rem;text-align:left}.cas-consequence-item{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-left:4px solid #dc3545;border-left:4px solid var(--color-danger,#dc3545);border-radius:8px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem}.cas-consequence-item.cas-recovery{background:#d4edda;background:var(--color-success-light,#d4edda);border-left-color:#28a745;border-left-color:var(--color-success,#28a745)}.cas-consequence-icon{flex-shrink:0;font-size:2rem}.cas-consequence-item strong{color:#212529;color:var(--color-text-primary,#212529);display:block;font-size:1rem;margin-bottom:.5rem}.cas-consequence-item p{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.9rem;margin:0}.cas-consequence-item.cas-recovery p,.cas-consequence-item.cas-recovery strong{color:#155724;color:var(--color-success-dark,#155724)}.cas-confirmation-content{text-align:center;text-transform:none}.cas-confirmation-instruction{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:1.05rem;margin-bottom:1.5rem}.cas-school-name-display{background:#e7f3ff;background:var(--color-info-light,#e7f3ff);border:2px solid #2196f3;border-radius:8px;color:#0d47a1;font-size:1.3rem;font-weight:700;margin-bottom:1.5rem;padding:1rem;text-transform:none!important;word-break:break-word}.cas-confirmation-input{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #ced4da;border:2px solid var(--color-border,#ced4da);border-radius:8px;color:#333;color:var(--color-text-primary,#333);font-size:1.1rem;font-weight:600;padding:1rem;transition:all .3s ease;width:100%}.cas-confirmation-input:focus{border-color:#dc3545;border-color:var(--color-danger,#dc3545);box-shadow:0 0 0 .2rem #dc354540;outline:none}.cas-confirmation-input:disabled{background:#f1f5f9;background:var(--color-bg-disabled,#f1f5f9);cursor:not-allowed}.cas-match-indicator{font-size:1rem;font-weight:600;margin-top:1rem;min-height:30px}.cas-match-success{color:#28a745;color:var(--color-success,#28a745)}.cas-match-error{color:#dc3545;color:var(--color-danger,#dc3545)}.cas-reason-content{text-align:left}.cas-feedback-offer{background:linear-gradient(135deg,#e7f3ff,#cfe9ff);border-left:4px solid #2196f3;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.cas-feedback-offer h3{color:#0d47a1;font-size:1.2rem;margin-bottom:1rem;margin-top:0}.cas-feedback-offer p{color:#1565c0;font-size:.95rem;margin-bottom:1rem}.cas-offer-highlight{background:#fff;background:var(--color-bg-primary,#fff);border:2px dashed #2196f3;border-radius:8px;padding:1rem}.cas-offer-highlight p{color:#0d47a1;font-size:1rem;font-weight:600;margin:0}.cas-reason-input-group{margin-bottom:2rem}.cas-reason-input-group label{color:#6c757d;color:var(--color-text-secondary,#6c757d);display:block;font-size:1rem;font-weight:600;margin-bottom:.75rem}.cas-reason-textarea{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #ced4da;border:2px solid var(--color-border,#ced4da);border-radius:8px;color:#333;color:var(--color-text-primary,#333);font-family:inherit;font-size:1rem;padding:1rem;resize:vertical;transition:all .3s ease;width:100%}.cas-reason-textarea:focus{border-color:#2196f3;box-shadow:0 0 0 .2rem #2196f340;outline:none}.cas-reason-textarea:disabled{background:#f1f5f9;background:var(--color-bg-disabled,#f1f5f9);cursor:not-allowed}.cas-final-warning{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border-left:4px solid #ff9800;border-left:4px solid var(--color-warning,#ff9800);border-radius:8px;padding:1rem}.cas-final-warning p{color:#856404;color:var(--color-warning-dark,#856404);font-size:.95rem;margin:0}.cas-modal-footer{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:0 0 12px 12px;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.cas-modal-footer button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.cas-btn-secondary{background:#6c757d;background:var(--color-secondary,#6c757d);color:#fff}.cas-btn-secondary:hover:not(:disabled){background:#5a6268;box-shadow:0 4px 12px #6c757d4d;transform:translateY(-2px)}.cas-btn-secondary:disabled{cursor:not-allowed;opacity:.6}.cas-btn-danger{background:#dc3545;background:var(--color-danger,#dc3545);color:#fff}.cas-btn-danger:hover:not(:disabled){background:#c82333;box-shadow:0 4px 12px #dc354566;transform:translateY(-2px)}.cas-btn-danger:disabled{cursor:not-allowed;opacity:.6}.cas-btn-danger-final{background:linear-gradient(135deg,#dc3545,#bd2130);background:linear-gradient(135deg,var(--color-danger,#dc3545),#bd2130);color:#fff;font-size:1.05rem;padding:1rem 2rem}.cas-btn-danger-final:hover:not(:disabled){background:linear-gradient(135deg,#c82333,#a71d2a);box-shadow:0 6px 16px #dc354580;transform:translateY(-2px)}.cas-btn-danger-final:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.cas-modal{max-height:95vh;width:95%}.cas-modal-body{padding:1.5rem}.cas-consequence-item{flex-direction:column;text-align:center}.cas-consequence-icon{font-size:2.5rem}.cas-modal-footer{flex-direction:column}.cas-modal-footer button{width:100%}}@media (hover:none) and (pointer:coarse){.cas-btn-danger,.cas-btn-danger-final,.cas-btn-danger-outline,.cas-btn-secondary{min-height:44px}.cas-modal-close{height:44px;width:44px}.cas-confirmation-input,.cas-reason-textarea{font-size:16px}}@media print{.cas-section{display:none!important}}@media (prefers-contrast:high){.cas-modal,.cas-warning-box{border:3px solid #000}.cas-btn-danger,.cas-btn-danger-final,.cas-btn-danger-outline,.cas-btn-secondary{border:2px solid}.cas-consequence-item{border:2px solid #000;border-left:4px solid #dc3545;border-left:4px solid var(--color-danger,#dc3545)}}@media (prefers-reduced-motion:reduce){.cas-modal,.cas-modal-overlay{animation:none}.cas-btn-danger-final:hover:not(:disabled),.cas-btn-danger-outline:hover,.cas-btn-danger:hover:not(:disabled),.cas-btn-secondary:hover:not(:disabled),.cas-modal-close:hover:not(:disabled){transform:none}}body[data-theme=dark] .cas-section{border-top-color:var(--color-border)}body[data-theme=dark] .cas-warning-box{background:linear-gradient(135deg,#dc354533,#dc35451a);border-color:var(--color-danger)}body[data-theme=dark] .cas-warning-box h3{color:var(--color-danger)}body[data-theme=dark] .cas-warning-box p{color:#f8d7da}body[data-theme=dark] .cas-btn-danger-outline{background:#0000;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .cas-btn-danger-outline:hover{background:var(--color-danger);color:#fff}body[data-theme=dark] .cas-modal{background:var(--color-bg-secondary)}body[data-theme=dark] .cas-error{background:#dc354533;border-left-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .cas-warning-content h3{color:var(--color-danger)}body[data-theme=dark] .cas-warning-content>p{color:var(--color-text-secondary)}body[data-theme=dark] .cas-consequence-item{background:var(--color-bg-tertiary)}body[data-theme=dark] .cas-consequence-item strong{color:var(--color-text-primary)}body[data-theme=dark] .cas-consequence-item p{color:var(--color-text-tertiary)}body[data-theme=dark] .cas-consequence-item.cas-recovery{background:#22c55e33}body[data-theme=dark] .cas-consequence-item.cas-recovery p,body[data-theme=dark] .cas-consequence-item.cas-recovery strong{color:var(--color-success)}body[data-theme=dark] .cas-confirmation-instruction{color:var(--color-text-secondary)}body[data-theme=dark] .cas-school-name-display{background:#2196f333;border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .cas-confirmation-input{background:var(--color-bg-primary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .cas-confirmation-input:focus{border-color:var(--color-danger)}body[data-theme=dark] .cas-feedback-offer{background:linear-gradient(135deg,#2196f333,#2196f31a);border-left-color:#60a5fa}body[data-theme=dark] .cas-feedback-offer h3{color:#60a5fa}body[data-theme=dark] .cas-feedback-offer p{color:#93c5fd}body[data-theme=dark] .cas-offer-highlight{background:var(--color-bg-tertiary);border-color:#60a5fa}body[data-theme=dark] .cas-offer-highlight p{color:#60a5fa}body[data-theme=dark] .cas-reason-input-group label{color:var(--color-text-secondary)}body[data-theme=dark] .cas-reason-textarea{background:var(--color-bg-primary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .cas-reason-textarea:focus{border-color:#60a5fa}body[data-theme=dark] .cas-final-warning{background:#fbbf2433;border-left-color:var(--color-warning)}body[data-theme=dark] .cas-final-warning p{color:var(--color-warning)}body[data-theme=dark] .cas-modal-footer{background:var(--color-bg-tertiary)}.cas-btn-danger-final:focus,.cas-btn-danger-outline:focus,.cas-btn-danger:focus,.cas-btn-secondary:focus,.cas-confirmation-input:focus,.cas-modal-close:focus,.cas-reason-textarea:focus{outline:2px solid #007bff;outline:2px solid var(--color-primary,#007bff);outline-offset:2px}.cas-modal:focus-within{outline:none}.sst-container{font-family:Roboto,sans-serif;padding:1rem}.sst-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:1.1rem;padding:3rem}.sst-loading,.sst-no-subscription{display:flex;justify-content:center}.sst-no-subscription{padding:2rem}.sst-no-subscription-content{background:#fff;background:var(--color-bg-primary,#fff);border-radius:12px;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--color-shadow,#0000001a);max-width:500px;padding:2rem;text-align:center}.sst-no-subscription-content h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;margin-bottom:1rem}.sst-no-subscription-content p{color:#6c757d;color:var(--color-text-secondary,#6c757d);line-height:1.6;margin-bottom:1.5rem}.sst-contact-admin{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.9rem;margin-top:1rem}.sst-info-banner{align-items:center;background:#e3f2fd;background:var(--color-info-light,#e3f2fd);border:1px solid #90caf9;border:1px solid var(--color-info-border,#90caf9);border-radius:6px;color:#0c5460;color:var(--color-info-dark,#0c5460);display:flex;font-size:.95rem;gap:.5rem;margin-bottom:1rem;padding:1rem}.sst-info-icon{font-size:1.2rem}.sst-status{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:12px;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--color-shadow,#0000001a);padding:1.5rem}.sst-status.sst-active{border-color:#28a745;border-color:var(--color-success,#28a745)}.sst-status.sst-inactive{border-color:#dc3545;border-color:var(--color-danger,#dc3545)}.sst-status h3{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border,#eee);color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.4rem;margin-bottom:1.5rem;padding-bottom:1rem}.sst-overview{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}@media (max-width:768px){.sst-overview{gap:1.5rem;grid-template-columns:1fr}}.sst-details{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:8px;padding:1rem}.sst-details h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.2rem;margin-bottom:1rem}.sst-details p{color:#495057;color:var(--color-text-secondary,#495057);font-size:.95rem;margin:.5rem 0}.sst-status-row{align-items:center;display:flex;gap:.5rem;margin:.75rem 0}.sst-status-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:capitalize}.sst-status-badge.sst-active{background:#d4edda;background:var(--color-success-light,#d4edda);color:#155724;color:var(--color-success-dark,#155724)}.sst-status-badge.sst-canceled,.sst-status-badge.sst-inactive{background:#f8d7da;background:var(--color-danger-light,#f8d7da);color:#721c24;color:var(--color-danger-dark,#721c24)}.sst-cancellation-notice,.sst-status-badge.sst-past_due{background:#fff3cd;background:var(--color-warning-light,#fff3cd);color:#856404;color:var(--color-warning-dark,#856404)}.sst-cancellation-notice{border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);border-radius:6px;font-size:.9rem;margin-top:1rem;padding:.75rem}.sst-billing-details{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:8px;padding:1rem}.sst-billing-details h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.2rem;margin-bottom:1rem}.sst-pricing-breakdown{margin-bottom:1.5rem}.sst-price-item{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);color:#495057;color:var(--color-text-secondary,#495057);display:flex;font-size:.95rem;justify-content:space-between;padding:.5rem 0}.sst-price-item.sst-total{border-bottom:none;border-top:2px solid #dee2e6;border-top:2px solid var(--color-border,#dee2e6);color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;margin-top:.5rem;padding-top:.75rem}.sst-user-count-section{border-top:1px solid #eee;border-top:1px solid var(--color-border-light,#eee);padding-top:1rem}.sst-user-count-section h5{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1rem;margin-bottom:.75rem}.sst-help-text{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.85rem;margin-top:.5rem}.sst-history{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.sst-history h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;margin-bottom:1rem}.sst-history-list{display:flex;flex-direction:column;gap:.5rem}.sst-history-item{grid-gap:1rem;background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #eee;border:1px solid var(--color-border-light,#eee);border-radius:6px;display:grid;font-size:.9rem;gap:1rem;grid-template-columns:1fr 2fr 1fr;padding:.75rem}@media (max-width:480px){.sst-history-item{gap:.25rem;grid-template-columns:1fr}}.sst-count{color:#007bff;color:var(--color-primary,#007bff);font-weight:600}.sst-reason{color:#6c757d;color:var(--color-text-secondary,#6c757d);text-transform:capitalize}.sst-date{color:#adb5bd;color:var(--color-text-tertiary,#adb5bd);text-align:right}@media (max-width:480px){.sst-date{text-align:left}}.sst-actions{border-top:1px solid #eee;border-top:1px solid var(--color-border,#eee);display:flex;flex-wrap:wrap;gap:1rem;padding-top:1rem}@media (max-width:480px){.sst-actions{flex-direction:column}.sst-actions button{width:100%}}.sst-btn-danger,.sst-btn-primary,.sst-btn-secondary{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.sst-btn-primary{background:#007bff;background:var(--color-primary,#007bff);color:#fff}.sst-btn-primary:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.sst-btn-secondary{background:#6c757d;background:var(--color-secondary,#6c757d);color:#fff}.sst-btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.sst-btn-danger{background:#dc3545;background:var(--color-danger,#dc3545);color:#fff}.sst-btn-danger:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.sst-btn-small{font-size:.85rem;padding:.5rem 1rem}.sst-btn-danger:disabled,.sst-btn-primary:disabled,.sst-btn-secondary:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.sst-container{padding:.5rem}.sst-status{padding:1rem}.sst-status h3{font-size:1.2rem}}@media (hover:none) and (pointer:coarse){.sst-btn-danger,.sst-btn-primary,.sst-btn-secondary{min-height:44px;padding:.875rem 1.5rem}.sst-btn-small{min-height:40px}}@media print{.sst-container{padding:0}.sst-status{border:1px solid #ddd;box-shadow:none}.sst-actions,.sst-info-banner{display:none!important}}@media (prefers-contrast:high){.sst-status{border:3px solid #000}.sst-btn-danger,.sst-btn-primary,.sst-btn-secondary{border:2px solid}.sst-history-item{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.sst-btn-danger:hover:not(:disabled),.sst-btn-primary:hover:not(:disabled),.sst-btn-secondary:hover:not(:disabled){transform:none}}body[data-theme=dark] .sst-container{color:var(--color-text-primary)}body[data-theme=dark] .sst-no-subscription-content{background:var(--color-bg-secondary)}body[data-theme=dark] .sst-no-subscription-content h3{color:var(--color-text-primary)}body[data-theme=dark] .sst-no-subscription-content p{color:var(--color-text-secondary)}body[data-theme=dark] .sst-info-banner{background:#3b82f633;border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .sst-status{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .sst-status.sst-active{border-color:var(--color-success)}body[data-theme=dark] .sst-status.sst-inactive{border-color:var(--color-danger)}body[data-theme=dark] .sst-status h3{border-bottom-color:var(--color-border);color:var(--color-text-inverse)}body[data-theme=dark] .sst-billing-details,body[data-theme=dark] .sst-details,body[data-theme=dark] .sst-history{background:var(--color-bg-tertiary)}body[data-theme=dark] .sst-billing-details h4,body[data-theme=dark] .sst-details h4,body[data-theme=dark] .sst-history h4,body[data-theme=dark] .sst-user-count-section h5{color:var(--color-text-primary)}body[data-theme=dark] .sst-details p,body[data-theme=dark] .sst-price-item{color:var(--color-text-secondary)}body[data-theme=dark] .sst-price-item{border-bottom-color:var(--color-border)}body[data-theme=dark] .sst-price-item.sst-total{border-top-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .sst-status-badge.sst-active{background:#22c55e33;color:var(--color-success)}body[data-theme=dark] .sst-status-badge.sst-canceled,body[data-theme=dark] .sst-status-badge.sst-inactive{background:#ef444433;color:var(--color-danger)}body[data-theme=dark] .sst-cancellation-notice,body[data-theme=dark] .sst-status-badge.sst-past_due{background:#fbbf2433;color:var(--color-warning)}body[data-theme=dark] .sst-cancellation-notice{border-color:var(--color-warning)}body[data-theme=dark] .sst-user-count-section{border-top-color:var(--color-border)}body[data-theme=dark] .sst-help-text{color:var(--color-text-tertiary)}body[data-theme=dark] .sst-history-item{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .sst-count{color:#60a5fa}body[data-theme=dark] .sst-reason{color:var(--color-text-secondary)}body[data-theme=dark] .sst-date{color:var(--color-text-tertiary)}body[data-theme=dark] .sst-actions{border-top-color:var(--color-border)}body[data-theme=dark] .sst-contact-admin{color:var(--color-text-tertiary)}.sst-btn-danger:focus,.sst-btn-primary:focus,.sst-btn-secondary:focus,.sst-status:focus-within{outline:2px solid #007bff;outline:2px solid var(--color-primary,#007bff);outline-offset:2px}.adc-container h1{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;margin-bottom:1rem}@media (min-width:768px){.adc-container h1{font-size:2rem;margin-bottom:1.5rem}}.adc-header-row{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}@media (min-width:768px){.adc-header-row{align-items:center;flex-direction:row;justify-content:space-between;margin-bottom:1.5rem}}.adc-header-row h1{margin-bottom:0}.adc-impersonation-btn{align-items:center;background:linear-gradient(135deg,#9333ea,#7c3aed);border:2px solid #9333ea4d;border-radius:8px;box-shadow:0 2px 8px #9333ea40;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.25rem;transition:all .3s ease;white-space:nowrap}.adc-impersonation-btn:hover{background:linear-gradient(135deg,#a855f7,#9333ea);box-shadow:0 4px 15px #9333ea59;transform:translateY(-2px)}.adc-impersonation-btn:active{transform:translateY(0)}.adc-impersonation-icon{animation:adc-icon-pulse 2s ease-in-out infinite;font-size:1.2rem}@keyframes adc-icon-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.adc-impersonation-text{font-size:.85rem;letter-spacing:.3px}@media (max-width:767px){.adc-impersonation-btn{padding:1rem;width:100%}}[data-theme=dark] .adc-impersonation-btn{background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#8b5cf666;box-shadow:0 2px 8px #8b5cf64d}[data-theme=dark] .adc-impersonation-btn:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 4px 15px #8b5cf666}.adc-panel{background:#fff;background:var(--color-bg-primary,#fff);border-radius:6px;box-shadow:0 2px 6px #00000014;margin:1rem 0;padding:1rem}@media (min-width:768px){.adc-panel{margin:1.5rem 0;padding:1.5rem}}.adc-panel.adc-full-width{max-width:none;width:100%}.adc-panel:last-child{margin-bottom:0}.adc-full-width-container{max-width:none;width:100%}.adc-navigation{background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;display:flex;flex-wrap:wrap;gap:.5rem;margin:2rem 0;padding:.5rem}.adc-nav-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#6b7280;color:var(--color-text-tertiary,#6b7280);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease;white-space:nowrap}.adc-nav-btn:hover{background:#e5e7eb;background:var(--color-bg-secondary,#e5e7eb);color:#374151;color:var(--color-text-primary,#374151)}.adc-nav-btn.adc-active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.adc-nav-btn.adc-active:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.adc-error-msg,.adc-info-msg,.adc-success-msg{border-radius:4px;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.adc-success-msg{background-color:#d4edda;background-color:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;color:#155724}.adc-error-msg{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;color:#721c24}.adc-info-msg{background-color:#d1ecf1;background-color:var(--color-info-light,#d1ecf1);border:1px solid #bee5eb;color:#0c5460}.adc-hint{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.85rem;font-style:italic;padding:.5rem 0}.adc-table{-webkit-overflow-scrolling:touch;margin-top:1rem;overflow-x:auto}.adc-table-head,.adc-table-row{grid-gap:.5rem;align-items:start;border-bottom:1px solid #f3f3f3;border-bottom:1px solid var(--color-border-light,#f3f3f3);display:grid;gap:.5rem;grid-template-columns:1fr;padding:.75rem}.adc-table-head{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-bottom:1px solid #ddd;border-bottom:1px solid var(--color-border,#ddd);display:none;font-weight:600}.adc-table-row{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border-light,#e2e8f0);border-radius:6px;margin-bottom:.5rem}.adc-table-row>span{display:flex;flex-direction:column;padding:.25rem 0}.adc-table-row>span:before{color:#6c757d;color:var(--color-text-tertiary,#6c757d);content:attr(data-label);font-size:.8rem;font-weight:600;margin-bottom:.25rem;text-transform:uppercase}@media (min-width:768px){.adc-table-head,.adc-table-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr 100px 200px}.adc-table-row{align-items:center;background:#0000;border:none;border-radius:0;margin-bottom:0}.adc-table-row>span{flex-direction:row;padding:.5rem 0}.adc-table-row>span:before{display:none}}.adc-btn-group{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.adc-btn-group .adc-icon-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;min-width:36px;padding:0;position:relative;transition:all .2s ease;width:36px}.adc-btn-group .adc-icon-btn.adc-edit{background:#007bff;background:var(--color-primary,#007bff);color:#fff}.adc-btn-group .adc-icon-btn.adc-edit:hover{background:#0056b3}.adc-btn-group .adc-icon-btn.adc-delete{background:#dc3545;background:var(--color-danger,#dc3545);color:#fff}.adc-btn-group .adc-icon-btn.adc-delete:hover{background:#c82333}.adc-btn-group .adc-icon-btn:after{background:#333;border-radius:4px;bottom:-35px;color:#fff;content:attr(data-tooltip);font-size:12px;left:50%;opacity:0;padding:4px 8px;position:absolute;transform:translateX(-50%);transition:all .2s ease;visibility:hidden;white-space:nowrap;z-index:1000}.adc-btn-group .adc-icon-btn:hover:after{opacity:1;visibility:visible}@media (min-width:768px){.adc-btn-group .adc-icon-btn{font-size:14px;height:32px;min-width:32px;width:32px}}.adc-btn-group button:not(.adc-icon-btn){flex:1 1;font-size:.85rem;min-width:120px;padding:.5rem .75rem;white-space:nowrap}@media (min-width:768px){.adc-btn-group button:not(.adc-icon-btn){flex:none;margin-right:.5rem;min-width:auto}}.adc-btn-group .adc-danger{background:#dc3545;background:var(--color-danger,#dc3545);color:#fff}.adc-btn-group .adc-danger:hover{background:#c82333}.adc-form{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-top:1rem;width:100%}.adc-form.adc-full-width{max-width:none;width:100%}@media (min-width:576px){.adc-form{gap:1rem 1.5rem;grid-template-columns:repeat(2,1fr)}.adc-form.adc-full-width{grid-template-columns:repeat(3,1fr)}}@media (min-width:768px){.adc-form{gap:1rem 1.5rem;grid-template-columns:repeat(3,1fr)}.adc-form.adc-full-width{grid-template-columns:repeat(4,1fr)}}@media (min-width:1024px){.adc-form{gap:1.5rem 2rem;grid-template-columns:repeat(4,1fr)}.adc-form.adc-full-width{gap:1.5rem 2rem;grid-template-columns:repeat(5,1fr)}}@media (min-width:1200px){.adc-form.adc-full-width{gap:1.5rem 2rem;grid-template-columns:repeat(6,1fr)}}.adc-form label{color:#2c3e50;color:var(--color-text-primary,#2c3e50);display:flex;flex-direction:column;font-size:.9rem}.adc-form label.adc-required:after{color:#dc3545;color:var(--color-danger,#dc3545);content:" *";font-weight:700}.adc-form input,.adc-form select{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;margin-top:.25rem;padding:.75rem;transition:border-color .25s,box-shadow .25s}.adc-form input:focus,.adc-form select:focus{border-color:#007bff;border-color:var(--color-primary,#007bff);box-shadow:0 0 0 .2rem #007bff40;outline:none}.adc-form input.adc-error,.adc-form select.adc-error{border-color:#dc3545;border-color:var(--color-danger,#dc3545);box-shadow:0 0 0 .2rem #dc354540}.adc-form .adc-full-row{grid-column:1/-1}.adc-form button{background:#007bff;background:var(--color-primary,#007bff);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;min-height:44px;padding:.75rem 1.5rem;transition:background .25s}.adc-form button:hover{background:#0056b3}.adc-form button:disabled{background-color:#6c757d!important;background-color:var(--color-secondary,#6c757d)!important;cursor:not-allowed;opacity:.65}.adc-search-box{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;margin-bottom:1rem;max-width:400px;padding:.75rem;width:100%}@media (min-width:768px){.adc-search-box{width:300px}}.adc-edit-form-container{background:#f8fafc;background:var(--color-bg-tertiary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;margin-top:2rem;max-width:none;padding:2rem;width:100%}.adc-edit-form-container h3{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.25rem;margin:0 0 1.5rem;padding-bottom:.75rem}.adc-form-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}@media (max-width:640px){.adc-form-actions{flex-direction:column}.adc-btn-cancel,.adc-btn-save{justify-content:center;width:100%}.adc-edit-form-container{margin-top:1rem;padding:1rem}}.adc-btn-cancel,.adc-btn-save{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.adc-btn-cancel{background:#f3f4f6;background:var(--color-bg-tertiary,#f3f4f6);border:1px solid #d1d5db;border:1px solid var(--color-border,#d1d5db);color:#374151;color:var(--color-text-primary,#374151)}.adc-btn-cancel:hover:not(:disabled){background:#e5e7eb;background:var(--color-bg-secondary,#e5e7eb);border-color:#9ca3af}.adc-btn-save{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.adc-btn-save:hover:not(:disabled){box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.adc-btn-cancel:disabled,.adc-btn-save:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.adc-btn-danger{background:#e74c3c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s}.adc-btn-danger:hover:not(:disabled){background:#c0392b;box-shadow:0 4px 12px #e74c3c4d;transform:translateY(-1px)}.adc-btn-danger:disabled{cursor:not-allowed;opacity:.6;transform:none}.adc-logo-preview{display:flex;flex-direction:column;gap:.5rem}.adc-logo-preview label{color:#374151;color:var(--color-text-secondary,#374151);font-weight:500;margin:0}.adc-logo-image-container{align-items:center;display:flex;justify-content:flex-start}.adc-logo-preview-image{border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;box-shadow:0 2px 4px #0000001a;max-height:100px;max-width:100px;object-fit:cover}.adc-director-school-info{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:12px;margin-bottom:2rem;overflow:hidden;padding:2rem;position:relative}.adc-director-school-info:before{background:linear-gradient(90deg,#007bff,#28a745,#ffc107);content:"";height:4px;left:0;position:absolute;right:0;top:0}.adc-director-school-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.adc-director-school-header h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;font-weight:600;margin:0}.adc-director-school-badge{background:linear-gradient(135deg,#007bff,#0056b3);border-radius:20px;color:#fff;font-size:.85rem;font-weight:500;letter-spacing:.5px;padding:.5rem 1rem}.adc-director-school-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1.5rem}.adc-school-detail-item{align-items:center;background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #f3f3f3;border:1px solid var(--color-border-light,#f3f3f3);border-radius:8px;display:flex;gap:.75rem;padding:.75rem}.adc-school-detail-icon{font-size:1.2rem;min-width:24px;text-align:center}.adc-school-detail-content{flex:1 1}.adc-school-detail-label{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.8rem;font-weight:500;letter-spacing:.5px;margin-bottom:.25rem;text-transform:uppercase}.adc-school-detail-value{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:.95rem;font-weight:500}.adc-director-school-actions{border-top:1px solid #dee2e6;border-top:1px solid var(--color-border,#dee2e6);display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.adc-btn-edit-school{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.adc-btn-edit-school:hover{box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.adc-legal-section-header{align-items:center;border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--color-border,#e9ecef);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.adc-legal-section-header h2{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;margin:0}.adc-school-selector{align-items:center;display:flex;gap:1rem}.adc-school-selector label{align-items:center;color:#374151;color:var(--color-text-secondary,#374151);display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.adc-school-selector select{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:6px;color:#374151;color:var(--color-text-primary,#374151);font-size:.875rem;min-width:200px;padding:.5rem .75rem;transition:all .2s ease}.adc-school-selector select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.adc-school-selector select:disabled{background:#f1f5f9;background:var(--color-bg-disabled,#f1f5f9);cursor:not-allowed;opacity:.6}.adc-school-info-display{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-radius:6px;font-size:.9rem;padding:.5rem 1rem}.adc-subscriptions-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:1rem;overflow:hidden;width:100%}.adc-subscriptions-table td,.adc-subscriptions-table th{border-bottom:1px solid #f3f3f3;border-bottom:1px solid var(--color-border-light,#f3f3f3);padding:1rem;text-align:left}.adc-subscriptions-table th{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.adc-subscriptions-table th,.adc-subscriptions-table tr:hover{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.adc-subscription-status{border-radius:20px;font-size:.8rem;font-weight:500;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.adc-subscription-status.adc-active{background:#d4edda;background:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;color:#155724}.adc-subscription-status.adc-expired{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;color:#721c24}.adc-subscription-status.adc-cancelled{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border:1px solid #ffeaa7;color:#856404}.adc-subscription-actions{display:flex;gap:.5rem}.adc-subscription-form{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1rem}.adc-subscription-form label{display:flex;flex-direction:column;gap:.5rem}.adc-subscription-form label.adc-required:after{color:#dc3545;color:var(--color-danger,#dc3545);content:" *"}.adc-director-field{background-color:#f8f9fa!important;background-color:var(--color-bg-tertiary,#f8f9fa)!important;border:1px solid #e9ecef!important;border:1px solid var(--color-border,#e9ecef)!important;cursor:not-allowed!important;font-style:italic}.adc-director-field:focus{border-color:#e9ecef!important;border-color:var(--color-border,#e9ecef)!important;box-shadow:none!important}.adc-director-field-container{display:flex;flex-direction:column;position:relative}.adc-director-help-text{color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:block;font-size:.8rem;margin-top:.25rem}.adc-director-help-text.adc-error{color:#dc3545;color:var(--color-danger,#dc3545)}.adc-director-help-text.adc-success{color:#28a745;color:var(--color-success,#28a745)}.adc-director-field.adc-loading{animation:adc-loading 1.5s infinite;background:linear-gradient(90deg,#f8f9fa 25%,#e9ecef 50%,#f8f9fa 75%);background-size:200% 100%}@keyframes adc-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.adc-modal-overlay{align-items:center;animation:adc-fadeIn .2s ease-in;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}@keyframes adc-fadeIn{0%{opacity:0}to{opacity:1}}.adc-modal-content{animation:adc-slideUp .3s ease-out;background:#fff;background:var(--color-bg-primary,#fff);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes adc-slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.adc-modal-header{align-items:center;background:#fee;border-bottom:2px solid #e74c3c;display:flex;justify-content:space-between;padding:20px 24px}.adc-modal-header h2{color:#c0392b;font-size:1.4rem;margin:0}.adc-modal-close{background:none;border:none;color:#c0392b;cursor:pointer;font-size:2rem;height:30px;line-height:1;padding:0;transition:transform .2s;width:30px}.adc-modal-close:hover{transform:scale(1.2)}.adc-modal-body{padding:24px}.adc-modal-footer{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-top:1px solid #dee2e6;border-top:1px solid var(--color-border,#dee2e6);display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.adc-warning-box{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border:2px solid #ffc107;border-radius:8px;margin-bottom:20px;padding:16px}.adc-warning-box p{margin:8px 0}.adc-info-box{background:#e8f4f8;border:2px solid #3498db;border-radius:8px;margin-bottom:20px;padding:16px}.adc-info-box ul{margin:12px 0;padding-left:20px}.adc-info-box li{line-height:1.6;margin:6px 0}.adc-backup-info{background:#d4edda;background:var(--color-success-light,#d4edda);border:2px solid #28a745;border-radius:8px;margin-bottom:20px;padding:16px}.adc-school-name-highlight{background:#ffe4e1;border:2px solid #e74c3c;border-radius:6px;color:#c0392b;font-size:1.2rem;margin:12px 0;padding:12px;text-align:center}.adc-confirmation-input{margin-top:24px}.adc-confirmation-input label{color:#2c3e50;color:var(--color-text-primary,#2c3e50);display:block;font-weight:600;margin-bottom:8px}.adc-expected-text{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:4px;color:#6c757d;color:var(--color-text-secondary,#6c757d);display:block;font-family:monospace;margin-top:8px;padding:8px 12px}.adc-confirmation-input input{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #ced4da;border:2px solid var(--color-border,#ced4da);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;margin-top:12px;padding:12px;transition:border-color .3s;width:100%}.adc-confirmation-input input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.adc-confirmation-input input.adc-valid{background:#f0fff4;border-color:#28a745}.adc-validation-error{color:#e74c3c}.adc-validation-error,.adc-validation-success{display:block;font-size:.9rem;font-weight:500;margin-top:8px}.adc-validation-success{color:#28a745}.adc-loading{opacity:.6;pointer-events:none}.adc-loading-spinner{animation:adc-spin 1s linear infinite;border:4px solid #e2e8f0;border-top-color:#667eea;border:4px solid var(--color-border,#e2e8f0);border-radius:50%;border-top-color:var(--color-primary,#667eea);height:40px;margin:2rem auto;width:40px}@keyframes adc-spin{to{transform:rotate(1turn)}}.adc-chk{align-items:center;display:flex;gap:.5rem;margin:.5rem 0}.adc-chk input[type=checkbox]{height:1.25rem;margin:0;width:1.25rem}.adc-form input[type=file]{border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}@media (max-width:768px){.adc-navigation{flex-direction:column;gap:.25rem}.adc-nav-btn{justify-content:center;padding:1rem;width:100%}.adc-legal-section-header{align-items:flex-start;flex-direction:column;gap:1rem}.adc-school-selector{gap:.5rem}.adc-school-selector,.adc-school-selector label{align-items:flex-start;flex-direction:column;width:100%}.adc-school-selector select{min-width:0;min-width:auto;width:100%}.adc-director-school-details{grid-template-columns:1fr}.adc-director-school-actions{flex-direction:column}.adc-subscriptions-table{font-size:.8rem}.adc-subscriptions-table td,.adc-subscriptions-table th{padding:.5rem}.adc-subscription-actions{flex-direction:column}.adc-modal-content{max-height:95vh;width:95%}.adc-modal-body,.adc-modal-footer,.adc-modal-header{padding:16px}.adc-modal-footer{flex-direction:column}.adc-btn-cancel,.adc-btn-danger{width:100%}}@media (max-width:640px){.adc-navigation{gap:.25rem;padding:.25rem}.adc-nav-btn{font-size:.75rem;padding:.75rem}.adc-director-school-info{padding:1rem}.adc-director-school-header h3{font-size:1.25rem}.adc-subscription-form{grid-template-columns:1fr}}@media (max-width:576px){.adc-container{padding:.5rem}.adc-panel{margin:.5rem 0;padding:.75rem}.adc-form{gap:.75rem}.adc-btn-group{flex-direction:row}.adc-btn-group button:not(.adc-icon-btn){margin-bottom:.5rem;width:100%}}@media (hover:none) and (pointer:coarse){.adc-btn-cancel,.adc-btn-danger,.adc-btn-edit-school,.adc-btn-save,.adc-nav-btn{min-height:44px}.adc-btn-group .adc-icon-btn{height:44px;min-width:44px;width:44px}.adc-form input,.adc-form select,.adc-school-selector select,.adc-search-box{font-size:16px}}@media print{.adc-btn-group,.adc-form-actions,.adc-modal-overlay,.adc-navigation{display:none!important}.adc-panel{border:1px solid #000;box-shadow:none}}@media (prefers-contrast:high){.adc-panel{border:2px solid #000}.adc-nav-btn{border:2px solid #0000}.adc-nav-btn.adc-active{border-color:#000}.adc-table-row{border:2px solid #000}.adc-modal-content{border:3px solid #000}}@media (prefers-reduced-motion:reduce){.adc-loading-spinner,.adc-modal-content,.adc-modal-overlay{animation:none}.adc-btn-cancel,.adc-btn-danger,.adc-btn-edit-school,.adc-btn-save,.adc-icon-btn,.adc-nav-btn{transition:none}}body[data-theme=dark] .adc-container h1{color:var(--color-text-primary)}body[data-theme=dark] .adc-panel{background:var(--color-bg-secondary);box-shadow:0 2px 6px #0000004d}body[data-theme=dark] .adc-navigation{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .adc-nav-btn{color:var(--color-text-tertiary)}body[data-theme=dark] .adc-nav-btn:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .adc-success-msg{background:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .adc-error-msg{background:#ef444433;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .adc-info-msg{background:#3b82f633;border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .adc-table-head{background:var(--color-bg-tertiary)}body[data-theme=dark] .adc-table-row{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .adc-table-row>span:before{color:var(--color-text-tertiary)}body[data-theme=dark] .adc-form label{color:var(--color-text-primary)}body[data-theme=dark] .adc-form input,body[data-theme=dark] .adc-form select,body[data-theme=dark] .adc-search-box{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .adc-form input option,body[data-theme=dark] .adc-form select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .adc-edit-form-container{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .adc-edit-form-container h3{border-bottom-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .adc-btn-cancel{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .adc-director-school-info{background:linear-gradient(135deg,var(--color-bg-secondary) 0,var(--color-bg-tertiary) 100%);border-color:var(--color-border)}body[data-theme=dark] .adc-director-school-header h3{color:var(--color-text-primary)}body[data-theme=dark] .adc-school-detail-item{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .adc-school-detail-label{color:var(--color-text-tertiary)}body[data-theme=dark] .adc-school-detail-value{color:var(--color-text-primary)}body[data-theme=dark] .adc-legal-section-header{border-bottom-color:var(--color-border)}body[data-theme=dark] .adc-legal-section-header h2{color:var(--color-text-primary)}body[data-theme=dark] .adc-school-selector label{color:var(--color-text-secondary)}body[data-theme=dark] .adc-school-selector select{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .adc-school-selector select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .adc-school-info-display{background:var(--color-bg-tertiary);color:var(--color-text-primary)}body[data-theme=dark] .adc-subscriptions-table{background:var(--color-bg-secondary)}body[data-theme=dark] .adc-subscriptions-table th{background:var(--color-bg-tertiary);color:var(--color-text-primary)}body[data-theme=dark] .adc-subscriptions-table td{border-bottom-color:var(--color-border)}body[data-theme=dark] .adc-subscriptions-table tr:hover{background:var(--color-bg-tertiary)}body[data-theme=dark] .adc-subscription-status.adc-active{background:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .adc-subscription-status.adc-expired{background:#ef444433;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .adc-subscription-status.adc-cancelled{background:#fbbf2433;border-color:var(--color-warning);color:var(--color-warning)}body[data-theme=dark] .adc-director-field{background-color:var(--color-bg-tertiary)!important;border-color:var(--color-border)!important}body[data-theme=dark] .adc-modal-content{background:var(--color-bg-secondary)}body[data-theme=dark] .adc-modal-header{background:#e74c3c33;border-bottom-color:#e74c3c}body[data-theme=dark] .adc-modal-close,body[data-theme=dark] .adc-modal-header h2{color:#f87171}body[data-theme=dark] .adc-modal-footer{background:var(--color-bg-tertiary);border-top-color:var(--color-border)}body[data-theme=dark] .adc-warning-box{background:#fbbf2433;border-color:var(--color-warning)}body[data-theme=dark] .adc-info-box{background:#3b82f633;border-color:#60a5fa}body[data-theme=dark] .adc-backup-info{background:#22c55e33;border-color:var(--color-success)}body[data-theme=dark] .adc-school-name-highlight{background:#e74c3c33;border-color:#e74c3c;color:#f87171}body[data-theme=dark] .adc-confirmation-input label{color:var(--color-text-primary)}body[data-theme=dark] .adc-expected-text{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-secondary)}body[data-theme=dark] .adc-confirmation-input input{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .adc-hint{color:var(--color-text-tertiary)}body[data-theme=dark] .adc-logo-preview label{color:var(--color-text-secondary)}body[data-theme=dark] .adc-logo-preview-image{border-color:var(--color-border)}.adc-btn-cancel:focus,.adc-btn-danger:focus,.adc-btn-edit-school:focus,.adc-btn-save:focus,.adc-form input:focus,.adc-form select:focus,.adc-icon-btn:focus,.adc-modal-close:focus,.adc-nav-btn:focus,.adc-school-selector select:focus,.adc-search-box:focus{outline:2px solid #667eea;outline:2px solid var(--color-primary,#667eea);outline-offset:2px}.lgv-container{max-width:100%;padding:20px}.lgv-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.lgv-header h2{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;margin:0}.lgv-btn-export{align-items:center;background:linear-gradient(135deg,#27ae60,#229954);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:.5rem;padding:10px 20px;transition:all .3s ease}.lgv-btn-export:hover:not(:disabled){background:linear-gradient(135deg,#229954,#1e8449);box-shadow:0 4px 12px #27ae604d;transform:translateY(-1px)}.lgv-btn-export:disabled{background:#95a5a6;background:var(--color-secondary,#95a5a6);box-shadow:none;cursor:not-allowed;transform:none}.lgv-filters-panel{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;margin-bottom:20px;padding:20px}.lgv-filters-panel h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:18px;margin-bottom:15px;margin-top:0}.lgv-filters-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:15px}.lgv-filter-item{display:flex;flex-direction:column}.lgv-filter-item.lgv-full-width{grid-column:1/-1}.lgv-filter-item label{color:#495057;color:var(--color-text-secondary,#495057);font-size:14px;font-weight:600;margin-bottom:5px}.lgv-filter-item input,.lgv-filter-item select{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:14px;padding:10px 12px;transition:border-color .3s,box-shadow .3s}.lgv-filter-item input:focus,.lgv-filter-item select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db26;outline:none}.lgv-filter-actions{display:flex;gap:10px;margin-top:15px}.lgv-btn-primary,.lgv-btn-secondary{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:.5rem;padding:10px 20px;transition:all .3s ease}.lgv-btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.lgv-btn-primary:hover{background:linear-gradient(135deg,#2980b9,#2472a4);box-shadow:0 4px 12px #3498db4d;transform:translateY(-1px)}.lgv-btn-secondary{background:#95a5a6;background:var(--color-secondary,#95a5a6);color:#fff}.lgv-btn-secondary:hover{background:#7f8c8d}.lgv-btn-details{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;min-width:32px;padding:6px 12px;transition:all .3s ease}.lgv-btn-details:hover{background:linear-gradient(135deg,#2980b9,#2472a4);transform:scale(1.05)}.lgv-results-info{background:linear-gradient(135deg,#e8f4f8,#d4edda);border-left:4px solid #3498db;border-radius:4px;margin-bottom:15px;padding:12px 16px}.lgv-results-info p{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:14px;font-weight:500;margin:0}.lgv-table-container{background:#fff;background:var(--color-bg-primary,#fff);border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.lgv-table{border-collapse:collapse;font-size:14px;width:100%}.lgv-table thead{background:linear-gradient(135deg,#34495e,#2c3e50);color:#fff}.lgv-table th{font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.lgv-table tbody tr{border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--color-border,#dee2e6);transition:background .2s ease}.lgv-table tbody tr:hover{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.lgv-table td{padding:12px;vertical-align:top}.lgv-cell-date{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-family:Courier New,Consolas,monospace;font-size:13px;white-space:nowrap}.lgv-cell-user .lgv-user-info{display:flex;flex-direction:column;gap:3px}.lgv-cell-user .lgv-username{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-weight:600}.lgv-cell-user .lgv-fullname{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:12px}.lgv-cell-user .lgv-school-name{color:#95a5a6;font-size:11px;font-style:italic}.lgv-cell-table{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-family:Courier New,Consolas,monospace;font-size:13px}.lgv-cell-description{max-width:300px;overflow:hidden;text-overflow:ellipsis}.lgv-cell-ip{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-family:Courier New,Consolas,monospace;font-size:12px}.lgv-cell-actions{text-align:center}.lgv-action-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.lgv-badge-create{background:#d4edda;background:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;color:#155724}.lgv-badge-update{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border:1px solid #ffeaa7;color:#856404}.lgv-badge-delete{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;color:#721c24}.lgv-badge-login{background:#cce5ff;border:1px solid #b8daff;color:#004085}.lgv-badge-error{background:#f5c6cb;border:1px solid #f1b0b7;color:#721c24}.lgv-badge-warning{background:#ffeaa7;border:1px solid #ffd93d;color:#856404}.lgv-badge-success{background:#c3e6cb;border:1px solid #a3d9a5;color:#155724}.lgv-badge-default{background:#e2e3e5;border:1px solid #d6d8db;color:#383d41}.lgv-details-row{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.lgv-details-row td{padding:0}.lgv-log-details{border-top:2px solid #dee2e6;border-top:2px solid var(--color-border,#dee2e6);padding:20px}.lgv-detail-section{margin-bottom:20px}.lgv-detail-section:last-child{margin-bottom:0}.lgv-detail-section h4{align-items:center;border-bottom:2px solid #3498db;color:#2c3e50;color:var(--color-text-primary,#2c3e50);display:flex;font-size:16px;gap:.5rem;margin-bottom:12px;margin-top:0;padding-bottom:8px}.lgv-detail-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.lgv-detail-item{background:#fff;background:var(--color-bg-primary,#fff);border-left:3px solid #3498db;border-radius:6px;box-shadow:0 1px 3px #0000000d;padding:10px 12px}.lgv-detail-item strong{color:#495057;color:var(--color-text-secondary,#495057);display:block;font-size:12px;letter-spacing:.3px;margin-bottom:5px;text-transform:uppercase}.lgv-detail-section pre{background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:6px;color:#ecf0f1;font-family:Courier New,Consolas,monospace;font-size:12px;line-height:1.6;margin:0;overflow-x:auto;padding:15px}.lgv-pagination{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:20px;padding:20px}.lgv-btn-pagination{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:6px;color:#333;color:var(--color-text-primary,#333);cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .3s ease}.lgv-btn-pagination:hover:not(:disabled){background:linear-gradient(135deg,#3498db,#2980b9);border-color:#3498db;color:#fff;transform:translateY(-1px)}.lgv-btn-pagination:disabled{color:#6c757d;color:var(--color-text-tertiary,#6c757d);cursor:not-allowed;opacity:.5}.lgv-btn-pagination:disabled,.lgv-page-info{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.lgv-page-info{border-radius:6px;color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-weight:600;padding:10px 16px}.lgv-empty-msg,.lgv-error-msg,.lgv-loading-msg,.lgv-success-msg{border-radius:6px;font-size:14px;font-weight:500;margin-bottom:20px;padding:15px 20px}.lgv-success-msg{background:#d4edda;background:var(--color-success-light,#d4edda);border-left:4px solid #28a745;color:#155724}.lgv-error-msg{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border-left:4px solid #dc3545;color:#721c24}.lgv-loading-msg{background:#cce5ff;border-left:4px solid #007bff;color:#004085;text-align:center}.lgv-empty-msg{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border-left:4px solid #ffc107;color:#856404;text-align:center}@media (max-width:768px){.lgv-header{align-items:flex-start;flex-direction:column;gap:15px}.lgv-btn-export{justify-content:center;width:100%}.lgv-filters-grid{grid-template-columns:1fr}.lgv-filter-actions{flex-direction:column}.lgv-btn-primary,.lgv-btn-secondary{justify-content:center;width:100%}.lgv-table{font-size:12px}.lgv-table td,.lgv-table th{padding:8px}.lgv-cell-description{max-width:150px}.lgv-pagination{flex-wrap:wrap;gap:8px}.lgv-btn-pagination{font-size:12px;padding:8px 12px}.lgv-detail-grid{grid-template-columns:1fr}}@media (max-width:576px){.lgv-container{padding:10px}.lgv-header h2{font-size:1.25rem}.lgv-filters-panel{padding:15px}.lgv-table th{font-size:10px}.lgv-action-badge{font-size:9px;padding:3px 6px}}@media (hover:none) and (pointer:coarse){.lgv-btn-details,.lgv-btn-export,.lgv-btn-pagination,.lgv-btn-primary,.lgv-btn-secondary{min-height:44px}.lgv-filter-item input,.lgv-filter-item select{font-size:16px;min-height:44px}}@media print{.lgv-btn-details,.lgv-btn-export,.lgv-filter-actions,.lgv-filters-panel,.lgv-pagination{display:none!important}.lgv-container{padding:0}.lgv-table-container{border:1px solid #000;box-shadow:none}.lgv-table thead{background:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lgv-table tbody tr{page-break-inside:avoid}}@media (prefers-contrast:high){.lgv-filters-panel,.lgv-table-container{border:2px solid #000}.lgv-table td,.lgv-table th{border:1px solid #000}.lgv-action-badge{border-width:2px}.lgv-btn-pagination{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.lgv-btn-details,.lgv-btn-export,.lgv-btn-pagination,.lgv-btn-primary,.lgv-btn-secondary,.lgv-filter-item input,.lgv-filter-item select,.lgv-table tbody tr{transition:none}}body[data-theme=dark] .lgv-container,body[data-theme=dark] .lgv-header h2{color:var(--color-text-primary)}body[data-theme=dark] .lgv-filters-panel{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .lgv-filters-panel h3{color:var(--color-text-primary)}body[data-theme=dark] .lgv-filter-item label{color:var(--color-text-secondary)}body[data-theme=dark] .lgv-filter-item input,body[data-theme=dark] .lgv-filter-item select{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .lgv-filter-item select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .lgv-results-info{background:linear-gradient(135deg,#3498db33,#27ae6033)}body[data-theme=dark] .lgv-results-info p{color:var(--color-text-primary)}body[data-theme=dark] .lgv-table-container{background:var(--color-bg-secondary);box-shadow:0 2px 8px #0000004d}body[data-theme=dark] .lgv-table thead{background:linear-gradient(135deg,#1e293b,#0f172a)}body[data-theme=dark] .lgv-table tbody tr{border-bottom-color:var(--color-border)}body[data-theme=dark] .lgv-table tbody tr:hover{background:var(--color-bg-tertiary)}body[data-theme=dark] .lgv-cell-date,body[data-theme=dark] .lgv-cell-ip,body[data-theme=dark] .lgv-cell-table{color:var(--color-text-tertiary)}body[data-theme=dark] .lgv-cell-user .lgv-username{color:var(--color-text-primary)}body[data-theme=dark] .lgv-cell-user .lgv-fullname,body[data-theme=dark] .lgv-cell-user .lgv-school-name{color:var(--color-text-tertiary)}body[data-theme=dark] .lgv-badge-create{background:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .lgv-badge-update{background:#fbbf2433;border-color:var(--color-warning);color:var(--color-warning)}body[data-theme=dark] .lgv-badge-delete{background:#ef444433;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .lgv-badge-login{background:#3b82f633;border-color:#60a5fa;color:#60a5fa}body[data-theme=dark] .lgv-badge-error{background:#ef444433;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .lgv-badge-warning{background:#fbbf2433;border-color:var(--color-warning);color:var(--color-warning)}body[data-theme=dark] .lgv-badge-success{background:#22c55e33;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .lgv-badge-default{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-secondary)}body[data-theme=dark] .lgv-details-row{background:var(--color-bg-tertiary)}body[data-theme=dark] .lgv-log-details{border-top-color:var(--color-border)}body[data-theme=dark] .lgv-detail-section h4{color:var(--color-text-primary)}body[data-theme=dark] .lgv-detail-item{background:var(--color-bg-secondary);box-shadow:0 1px 3px #0003}body[data-theme=dark] .lgv-detail-item strong{color:var(--color-text-tertiary)}body[data-theme=dark] .lgv-detail-section pre{background:linear-gradient(135deg,#0f172a,#1e293b)}body[data-theme=dark] .lgv-btn-pagination{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .lgv-btn-pagination:disabled{background:var(--color-bg-tertiary);color:var(--color-text-tertiary)}body[data-theme=dark] .lgv-page-info{background:var(--color-bg-tertiary);color:var(--color-text-primary)}body[data-theme=dark] .lgv-success-msg{background:#22c55e33;border-left-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .lgv-error-msg{background:#ef444433;border-left-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .lgv-loading-msg{background:#3b82f633;border-left-color:#3b82f6;color:#60a5fa}body[data-theme=dark] .lgv-empty-msg{background:#fbbf2433;border-left-color:var(--color-warning);color:var(--color-warning)}.lgv-btn-details:focus,.lgv-btn-export:focus,.lgv-btn-pagination:focus,.lgv-btn-primary:focus,.lgv-btn-secondary:focus,.lgv-filter-item input:focus,.lgv-filter-item select:focus{outline:2px solid #3498db;outline:2px solid var(--color-primary,#3498db);outline-offset:2px}.gcm-container{margin:0 auto;max-width:1400px;padding:20px}.gcm-container h3{border-bottom:2px solid #3498db;border-bottom:2px solid var(--color-primary,#3498db);color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:24px;margin:0 0 25px;padding-bottom:10px}.gcm-container h4{color:#34495e;color:var(--color-text-secondary,#34495e);font-size:18px;margin:0 0 15px}.gcm-loading{color:#7f8c8d;color:var(--color-text-tertiary,#7f8c8d);font-size:16px;padding:40px;text-align:center}.gcm-alert{align-items:center;border-radius:6px;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 16px}.gcm-alert-error{background-color:#fee;background-color:var(--color-danger-light,#fee);border:1px solid #fcc;border:1px solid var(--color-danger-border,#fcc);color:#c33;color:var(--color-danger,#c33)}.gcm-alert-success{background-color:#d4edda;background-color:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);color:#155724;color:var(--color-success-dark,#155724)}.gcm-alert-info{background-color:#d1ecf1;background-color:var(--color-info-light,#d1ecf1);border:1px solid #bee5eb;border:1px solid var(--color-info-border,#bee5eb);color:#0c5460;color:var(--color-info-dark,#0c5460)}.gcm-section{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #e0e0e0;border:1px solid var(--color-border,#e0e0e0);border-radius:8px;box-shadow:0 1px 3px #0000000d;box-shadow:0 1px 3px var(--color-shadow,#0000000d);margin-bottom:25px;padding:20px}.gcm-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.gcm-section-description{color:#7f8c8d;color:var(--color-text-tertiary,#7f8c8d);font-size:14px;line-height:1.5;margin-bottom:15px}.gcm-config-info{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-left:4px solid #3498db;border-left:4px solid var(--color-primary,#3498db);border-radius:6px;padding:15px}.gcm-config-info p{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:14px;margin:8px 0}.gcm-config-info p:first-child{margin-top:0}.gcm-config-info p:last-child{margin-bottom:0}.gcm-text-muted{color:#7f8c8d!important;color:var(--color-text-tertiary,#7f8c8d)!important;font-size:13px}.gcm-text-center{text-align:center}.gcm-text-small{font-size:12px}.gcm-templates-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:15px}.gcm-template-card{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e0e0e0;border:2px solid var(--color-border,#e0e0e0);border-radius:8px;padding:20px;position:relative;transition:all .3s ease}.gcm-template-card:hover{box-shadow:0 4px 12px #3498db26;box-shadow:0 4px 12px var(--color-primary-shadow,#3498db26);transform:translateY(-2px)}.gcm-template-card.gcm-active,.gcm-template-card:hover{border-color:#3498db;border-color:var(--color-primary,#3498db)}.gcm-template-card.gcm-active{background:#f0f8ff;background:var(--color-primary-light,#f0f8ff);box-shadow:0 0 0 3px #3498db1a;box-shadow:0 0 0 3px var(--color-primary-shadow,#3498db1a)}.gcm-template-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px}.gcm-template-header h5{color:#2c3e50;color:var(--color-text-primary,#2c3e50);flex:1 1;font-size:16px;font-weight:600;margin:0}.gcm-template-description{color:#7f8c8d;color:var(--color-text-tertiary,#7f8c8d);font-size:13px;line-height:1.5;margin:10px 0;min-height:40px}.gcm-template-info{align-items:center;display:flex;font-size:13px;gap:10px;margin:15px 0}.gcm-grading-count{color:#7f8c8d;color:var(--color-text-tertiary,#7f8c8d);font-weight:500}.gcm-template-card .gcm-btn{margin-top:10px;width:100%}.gcm-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.gcm-badge-primary{background:#3498db;background:var(--color-primary,#3498db);color:#fff}.gcm-badge-success{background:#27ae60;background:var(--color-success,#27ae60);color:#fff}.gcm-badge-info{background:#3498db;background:var(--color-info,#3498db);color:#fff}.gcm-badge-warning{background:#f39c12;background:var(--color-warning,#f39c12);color:#fff}.gcm-badge-secondary{background:#95a5a6;background:var(--color-secondary,#95a5a6);color:#fff}.gcm-add-form{animation:gcm-slideDown .3s ease-out;background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--color-border,#e0e0e0);border-radius:6px;margin-bottom:20px;padding:20px}@keyframes gcm-slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.gcm-form-row{grid-gap:15px;align-items:end;display:grid;gap:15px;grid-template-columns:2fr 2fr 1fr auto}.gcm-form-group{display:flex;flex-direction:column}.gcm-form-group label{color:#34495e;color:var(--color-text-secondary,#34495e);font-size:13px;font-weight:600;margin-bottom:6px}.gcm-form-group input{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #ddd;border:1px solid var(--color-border,#ddd);border-radius:4px;color:#333;color:var(--color-text-primary,#333);font-size:14px;padding:10px 12px;transition:border-color .2s}.gcm-form-group input:focus{border-color:#3498db;border-color:var(--color-primary,#3498db);box-shadow:0 0 0 3px #3498db1a;box-shadow:0 0 0 3px var(--color-primary-shadow,#3498db1a);outline:none}.gcm-form-group input:disabled{background:#f5f5f5;background:var(--color-bg-disabled,#f5f5f5);cursor:not-allowed}.gcm-form-actions{align-items:flex-end;display:flex}.gcm-table-responsive{margin-top:15px;overflow-x:auto}.gcm-table{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #e0e0e0;border:1px solid var(--color-border,#e0e0e0);border-collapse:initial;border-radius:8px;border-spacing:0;overflow:hidden;width:100%}.gcm-table thead{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa)}.gcm-table th{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--color-border,#e0e0e0);color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.gcm-table td{border-bottom:1px solid #f0f0f0;border-bottom:1px solid var(--color-border-light,#f0f0f0);color:#34495e;color:var(--color-text-secondary,#34495e);font-size:14px;padding:14px 16px}.gcm-table tbody tr:hover{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.gcm-table tbody tr:last-child td{border-bottom:none}.gcm-rank-order{color:#3498db;color:var(--color-primary,#3498db);font-weight:600;width:80px}.gcm-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:10px 18px;transition:all .2s ease;white-space:nowrap}.gcm-btn:hover:not(:disabled){box-shadow:0 4px 8px #00000026;box-shadow:0 4px 8px var(--color-shadow,#00000026);transform:translateY(-1px)}.gcm-btn:active:not(:disabled){transform:translateY(0)}.gcm-btn:disabled{cursor:not-allowed;opacity:.6}.gcm-btn-primary{background:#3498db;background:var(--color-primary,#3498db);color:#fff}.gcm-btn-primary:hover:not(:disabled){background:#2980b9}.gcm-btn-success{background:#27ae60;background:var(--color-success,#27ae60);color:#fff}.gcm-btn-success:hover:not(:disabled){background:#229954}.gcm-btn-danger{background:#e74c3c;background:var(--color-danger,#e74c3c);color:#fff}.gcm-btn-danger:hover:not(:disabled){background:#c0392b}.gcm-btn-sm{font-size:13px;padding:8px 14px}.gcm-btn-xs{font-size:12px;padding:6px 12px}@media (max-width:1200px){.gcm-templates-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.gcm-container{padding:15px}.gcm-form-row,.gcm-templates-grid{grid-template-columns:1fr}.gcm-form-actions{justify-content:stretch}.gcm-form-actions .gcm-btn{width:100%}.gcm-table{font-size:13px}.gcm-table td,.gcm-table th{padding:10px 12px}.gcm-section-header{align-items:stretch;flex-direction:column;gap:10px}.gcm-section-header .gcm-btn{width:100%}}@media (max-width:480px){.gcm-container h3{font-size:20px}.gcm-container h4{font-size:16px}.gcm-badge{font-size:10px;padding:3px 8px}}@media (hover:none) and (pointer:coarse){.gcm-btn{min-height:44px;padding:12px 18px}.gcm-btn-sm{min-height:40px;padding:10px 14px}.gcm-btn-xs{min-height:36px;padding:8px 12px}.gcm-form-group input{font-size:16px;padding:12px}.gcm-template-card:hover{transform:none}}@media print{.gcm-container{padding:10px}.gcm-section{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.gcm-add-form,.gcm-btn,.gcm-form-actions{display:none!important}.gcm-template-card{break-inside:avoid;page-break-inside:avoid}}@media (prefers-contrast:high){.gcm-form-group input,.gcm-section,.gcm-table{border:2px solid #000}.gcm-table td,.gcm-table th{border:1px solid #000}.gcm-btn{border:2px solid}}@media (prefers-reduced-motion:reduce){.gcm-add-form{animation:none}.gcm-btn:hover:not(:disabled),.gcm-template-card:hover{transform:none}.gcm-btn,.gcm-template-card{transition:none}}body[data-theme=dark] .gcm-container{color:var(--color-text-primary)}body[data-theme=dark] .gcm-container h3{border-bottom-color:var(--color-primary);color:var(--color-text-primary)}body[data-theme=dark] .gcm-container h4{color:var(--color-text-secondary)}body[data-theme=dark] .gcm-section{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .gcm-config-info{background:var(--color-bg-tertiary);border-left-color:var(--color-primary)}body[data-theme=dark] .gcm-config-info p{color:var(--color-text-primary)}body[data-theme=dark] .gcm-template-card{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .gcm-template-card:hover{border-color:var(--color-primary)}body[data-theme=dark] .gcm-template-card.gcm-active{background:var(--color-bg-tertiary);border-color:var(--color-primary)}body[data-theme=dark] .gcm-template-header h5{color:var(--color-text-primary)}body[data-theme=dark] .gcm-grading-count,body[data-theme=dark] .gcm-template-description{color:var(--color-text-tertiary)}body[data-theme=dark] .gcm-add-form{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .gcm-form-group label{color:var(--color-text-secondary)}body[data-theme=dark] .gcm-form-group input{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .gcm-form-group input:focus{border-color:var(--color-primary)}body[data-theme=dark] .gcm-form-group input:disabled{background:var(--color-bg-tertiary)}body[data-theme=dark] .gcm-table{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .gcm-table thead{background:var(--color-bg-secondary)}body[data-theme=dark] .gcm-table th{border-bottom-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .gcm-table td{border-bottom-color:var(--color-border);color:var(--color-text-secondary)}body[data-theme=dark] .gcm-table tbody tr:hover{background:var(--color-bg-tertiary)}body[data-theme=dark] .gcm-alert-error{background-color:#dc354533;border-color:var(--color-danger);color:var(--color-danger)}body[data-theme=dark] .gcm-alert-success{background-color:#28a74533;border-color:var(--color-success);color:var(--color-success)}body[data-theme=dark] .gcm-alert-info{background-color:#3498db33;border-color:#3498db;border-color:var(--color-info,#3498db);color:#3498db;color:var(--color-info,#3498db)}body[data-theme=dark] .gcm-text-muted{color:var(--color-text-tertiary)!important}body[data-theme=dark] .gcm-loading{color:var(--color-text-tertiary)}.gcm-btn:focus,.gcm-form-group input:focus,.gcm-section:focus-within,.gcm-template-card:focus-within{outline:2px solid #3498db;outline:2px solid var(--color-primary,#3498db);outline-offset:2px}.imp-modal-overlay{align-items:center;animation:imp-fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10001}@keyframes imp-fadeIn{0%{opacity:0}to{opacity:1}}.imp-modal-container{animation:imp-slideIn .3s ease-out;background:#fff;background:var(--color-bg-primary,#fff);border-radius:16px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-height:85vh;max-width:600px;overflow:hidden;width:100%}@keyframes imp-slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.imp-modal-header{align-items:center;background:linear-gradient(135deg,#9333ea,#7c3aed);color:#fff;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.imp-modal-title{align-items:center;display:flex;gap:.75rem}.imp-modal-icon{animation:imp-iconBounce 2s ease-in-out infinite;font-size:1.5rem}@keyframes imp-iconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.imp-modal-title h2{font-size:1.25rem;font-weight:600;margin:0}.imp-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.imp-modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.imp-modal-warning{align-items:flex-start;background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:1px solid #f59e0b;color:#92400e;display:flex;font-size:.85rem;gap:.75rem;line-height:1.5;padding:1rem 1.5rem}.imp-warning-icon{flex-shrink:0;font-size:1.25rem}.imp-modal-filters{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);display:flex;flex-direction:column;gap:.75rem;padding:1rem 1.5rem}.imp-filter-search{width:100%}.imp-search-input{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:.95rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.imp-search-input:focus{border-color:#9333ea;box-shadow:0 0 0 3px #9333ea26;outline:none}.imp-search-input::placeholder{color:#94a3b8;color:var(--color-text-tertiary,#94a3b8)}.imp-filter-selects{display:flex;flex-wrap:wrap;gap:.75rem}.imp-filter-select{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;color:#1e293b;color:var(--color-text-primary,#1e293b);cursor:pointer;flex:1 1;font-size:.9rem;min-width:150px;padding:.6rem .75rem;transition:all .2s ease}.imp-filter-select:focus{border-color:#9333ea;outline:none}.imp-modal-error{align-items:center;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-bottom:1px solid #fecaca;color:#b91c1c;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1.5rem}.imp-modal-content{flex:1 1;max-height:400px;min-height:200px;overflow-y:auto;padding:0}.imp-loading{align-items:center;color:#64748b;color:var(--color-text-tertiary,#64748b);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.imp-spinner{animation:imp-spin .8s linear infinite;border:3px solid #e2e8f0;border:3px solid var(--color-border,#e2e8f0);border-radius:50%;border-top:3px solid #9333ea;height:40px;width:40px}@keyframes imp-spin{to{transform:rotate(1turn)}}.imp-empty{align-items:center;color:#64748b;color:var(--color-text-tertiary,#64748b);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem;text-align:center}.imp-empty-icon{font-size:3rem;opacity:.5}.imp-users-list{padding:.5rem 0}.imp-users-count{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);color:#64748b;color:var(--color-text-tertiary,#64748b);font-size:.8rem;padding:.5rem 1.5rem}.imp-user-card,.imp-users-count{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0)}.imp-user-card{align-items:center;display:flex;gap:1rem;justify-content:space-between;padding:1rem 1.5rem;transition:background .2s ease}.imp-user-card:hover{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc)}.imp-user-card:last-child{border-bottom:none}.imp-user-info{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0}.imp-user-avatar{align-items:center;background:linear-gradient(135deg,#9333ea,#7c3aed);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:600;height:48px;justify-content:center;text-transform:uppercase;width:48px}.imp-user-details{flex:1 1;min-width:0}.imp-user-name{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:.95rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.imp-user-meta{color:#64748b;color:var(--color-text-tertiary,#64748b);display:flex;flex-wrap:wrap;font-size:.8rem;gap:.5rem;margin-top:.25rem}.imp-user-username{color:#9333ea;font-weight:500}.imp-user-email{overflow:hidden;text-overflow:ellipsis}.imp-user-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.imp-badge{border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.2rem .5rem;text-transform:uppercase}.imp-badge-director{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.imp-badge-instructor{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.imp-badge-student{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534}.imp-badge-parent{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#9d174d}.imp-badge-default{background:#e2e8f0;background:var(--color-bg-tertiary,#e2e8f0);color:#475569;color:var(--color-text-secondary,#475569)}.imp-badge-school{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7c3aed}.imp-user-btn{background:linear-gradient(135deg,#9333ea,#7c3aed);border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.85rem;font-weight:600;padding:.6rem 1rem;transition:all .2s ease;white-space:nowrap}.imp-user-btn:hover:not(:disabled){background:linear-gradient(135deg,#a855f7,#9333ea);box-shadow:0 4px 12px #9333ea4d;transform:translateY(-1px)}.imp-user-btn:disabled{cursor:not-allowed;opacity:.6}.imp-modal-footer{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);display:flex;justify-content:flex-end;padding:1rem 1.5rem}.imp-btn-cancel{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;color:#475569;color:var(--color-text-secondary,#475569);cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.imp-btn-cancel:hover{background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);border-color:#94a3b8;border-color:var(--color-text-tertiary,#94a3b8)}.imp-confirm-overlay{align-items:center;animation:imp-fadeIn .15s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10002}.imp-confirm-modal{animation:imp-confirmSlideIn .25s ease-out;background:#fff;background:var(--color-bg-primary,#fff);border-radius:16px;box-shadow:0 25px 50px -12px #00000059;max-width:420px;overflow:hidden;width:100%}@keyframes imp-confirmSlideIn{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.imp-confirm-header{align-items:center;background:linear-gradient(135deg,#9333ea,#7c3aed);color:#fff;display:flex;gap:.75rem;padding:1.25rem 1.5rem}.imp-confirm-icon{font-size:1.5rem}.imp-confirm-header h3{font-size:1.15rem;font-weight:600;margin:0}.imp-confirm-body{padding:1.5rem}.imp-confirm-user-card{align-items:center;background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-radius:12px;display:flex;gap:1rem;margin-bottom:1.25rem;padding:1rem}.imp-confirm-avatar{align-items:center;background:linear-gradient(135deg,#9333ea,#7c3aed);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:56px;justify-content:center;text-transform:uppercase;width:56px}.imp-confirm-user-info{flex:1 1;min-width:0}.imp-confirm-user-name{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.imp-confirm-user-meta{display:flex;flex-wrap:wrap;gap:.4rem}.imp-confirm-message{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:1rem;line-height:1.5;margin:0 0 1rem;text-align:center}.imp-confirm-note{align-items:flex-start;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:8px;color:#1e40af;display:flex;font-size:.85rem;gap:.5rem;line-height:1.4;padding:.75rem 1rem}.imp-note-icon{flex-shrink:0;font-size:1rem}.imp-confirm-footer{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);display:flex;gap:.75rem;padding:1rem 1.5rem}.imp-confirm-btn-cancel{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #e2e8f0;border:2px solid var(--color-border,#e2e8f0);border-radius:8px;color:#475569;color:var(--color-text-secondary,#475569);cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:.85rem 1rem;transition:all .2s ease}.imp-confirm-btn-cancel:hover:not(:disabled){background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);border-color:#94a3b8;border-color:var(--color-text-tertiary,#94a3b8)}.imp-confirm-btn-cancel:disabled{cursor:not-allowed;opacity:.6}.imp-confirm-btn-confirm{align-items:center;background:linear-gradient(135deg,#9333ea,#7c3aed);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1.5 1;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;padding:.85rem 1rem;transition:all .2s ease}.imp-confirm-btn-confirm:hover:not(:disabled){background:linear-gradient(135deg,#a855f7,#9333ea);box-shadow:0 4px 12px #9333ea4d;transform:translateY(-1px)}.imp-confirm-btn-confirm:disabled{cursor:not-allowed;opacity:.7;transform:none}.imp-btn-spinner{animation:imp-spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}[data-theme=dark] .imp-confirm-modal,[data-theme=dark] .imp-modal-container{background:#1e293b;background:var(--color-bg-primary,#1e293b)}[data-theme=dark] .imp-modal-warning{background:linear-gradient(135deg,#422006,#78350f);border-color:#92400e;color:#fde68a}[data-theme=dark] .imp-modal-filters{background:#0f172a;background:var(--color-bg-secondary,#0f172a);border-color:#334155;border-color:var(--color-border,#334155)}[data-theme=dark] .imp-filter-select,[data-theme=dark] .imp-search-input{background:#1e293b;background:var(--color-bg-tertiary,#1e293b);border-color:#334155;border-color:var(--color-border,#334155);color:#f1f5f9;color:var(--color-text-primary,#f1f5f9)}[data-theme=dark] .imp-filter-select:focus,[data-theme=dark] .imp-search-input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f733}[data-theme=dark] .imp-modal-error{background:linear-gradient(135deg,#450a0a,#7f1d1d);border-color:#b91c1c;color:#fecaca}[data-theme=dark] .imp-users-count{background:#0f172a;background:var(--color-bg-secondary,#0f172a)}[data-theme=dark] .imp-user-card,[data-theme=dark] .imp-users-count{border-color:#334155;border-color:var(--color-border,#334155)}[data-theme=dark] .imp-user-card:hover{background:#0f172a;background:var(--color-bg-secondary,#0f172a)}[data-theme=dark] .imp-confirm-footer,[data-theme=dark] .imp-modal-footer{background:#0f172a;background:var(--color-bg-secondary,#0f172a);border-color:#334155;border-color:var(--color-border,#334155)}[data-theme=dark] .imp-btn-cancel,[data-theme=dark] .imp-confirm-btn-cancel{background:#1e293b;background:var(--color-bg-tertiary,#1e293b);border-color:#334155;border-color:var(--color-border,#334155);color:#94a3b8;color:var(--color-text-secondary,#94a3b8)}[data-theme=dark] .imp-btn-cancel:hover,[data-theme=dark] .imp-confirm-btn-cancel:hover:not(:disabled){background:#0f172a;background:var(--color-bg-secondary,#0f172a);border-color:#64748b;border-color:var(--color-text-tertiary,#64748b)}[data-theme=dark] .imp-confirm-user-card{background:#0f172a;background:var(--color-bg-tertiary,#0f172a)}[data-theme=dark] .imp-confirm-note{background:linear-gradient(135deg,#1e3a5f,#1e40af);color:#93c5fd}[data-theme=dark] .imp-badge-director{background:linear-gradient(135deg,#78350f,#92400e);color:#fde68a}[data-theme=dark] .imp-badge-instructor{background:linear-gradient(135deg,#1e3a5f,#1e40af);color:#93c5fd}[data-theme=dark] .imp-badge-student{background:linear-gradient(135deg,#14532d,#166534);color:#86efac}[data-theme=dark] .imp-badge-parent{background:linear-gradient(135deg,#831843,#9d174d);color:#f9a8d4}[data-theme=dark] .imp-badge-default{background:#334155;background:var(--color-bg-tertiary,#334155);color:#94a3b8;color:var(--color-text-secondary,#94a3b8)}[data-theme=dark] .imp-badge-school{background:linear-gradient(135deg,#4c1d95,#5b21b6);color:#c4b5fd}@media (max-width:640px){.imp-modal-overlay{align-items:flex-end;padding:0}.imp-modal-container{animation:imp-slideUp .3s ease-out;border-radius:20px 20px 0 0;max-height:95vh;max-width:100%}@keyframes imp-slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.imp-modal-header{padding:1rem 1.25rem}.imp-modal-title h2{font-size:1.1rem}.imp-modal-warning{font-size:.8rem}.imp-modal-filters,.imp-modal-warning{padding:.75rem 1.25rem}.imp-filter-selects{flex-direction:column}.imp-filter-select{width:100%}.imp-user-card{align-items:stretch;flex-direction:column;gap:.75rem;padding:.75rem 1.25rem}.imp-user-btn{padding:.75rem;width:100%}.imp-modal-footer{padding:.75rem 1.25rem}.imp-confirm-overlay{align-items:flex-end}.imp-confirm-modal{animation:imp-slideUp .25s ease-out;border-radius:20px 20px 0 0;max-width:100%}.imp-confirm-body{padding:1.25rem}.imp-confirm-footer{flex-direction:column;padding:1rem 1.25rem}.imp-confirm-btn-cancel,.imp-confirm-btn-confirm{flex:none;width:100%}}@media (prefers-reduced-motion:reduce){.imp-btn-spinner,.imp-confirm-modal,.imp-confirm-overlay,.imp-modal-container,.imp-modal-icon,.imp-modal-overlay,.imp-spinner{animation:none}.imp-confirm-btn-confirm,.imp-user-btn{transition:none}.imp-confirm-btn-confirm:hover:not(:disabled),.imp-user-btn:hover:not(:disabled){transform:none}}.modal-backdrop{align-items:center!important;backdrop-filter:blur(5px)!important;-webkit-backdrop-filter:blur(5px)!important;background:var(--color-overlay)!important;bottom:0!important;display:flex!important;justify-content:center!important;left:0!important;padding:1rem!important;position:fixed!important;right:0!important;top:0!important;z-index:9999!important}.modal{background:var(--color-bg-primary)!important;background-color:var(--color-bg-primary)!important;border:2px solid var(--color-border)!important;border-radius:12px!important;box-shadow:0 20px 40px #00000080!important;box-sizing:border-box!important;display:block!important;margin:0!important;max-height:92vh!important;max-width:600px!important;overflow-y:auto!important;padding:2.5rem!important;position:relative!important;width:100%!important}.modal h3{border-bottom:2px solid var(--color-border)!important;color:var(--color-text-primary)!important;font-size:1.8rem!important;font-weight:600!important;margin:0 0 2rem!important;padding-bottom:1rem!important}.form-group{align-items:flex-start;display:flex;flex-direction:column;margin-bottom:1.5rem!important;width:100%!important}.form-group label{color:var(--color-text-primary)!important;font-size:1rem!important;font-weight:600;margin-bottom:.75rem!important;width:100%}.form-group input,.form-group textarea{background:var(--color-bg-primary)!important;border:1px solid var(--color-border)!important;border-radius:8px!important;box-sizing:border-box!important;color:var(--color-text-primary)!important;font-family:inherit;font-size:1.1rem!important;padding:1rem!important;transition:border-color .2s ease,box-shadow .2s ease!important;width:100%!important}.form-group input[type=date]{height:55px!important}.form-group textarea{font-family:inherit;line-height:1.5;min-height:100px!important}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary)!important;box-shadow:0 0 0 4px #007bff1a!important;outline:none!important}.form-group input:disabled,.form-group textarea:disabled{background-color:var(--color-bg-tertiary)!important;cursor:not-allowed!important;opacity:.7!important}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-tertiary)!important;opacity:.7}.error-msg{background-color:var(--color-danger-light)!important;border:1px solid var(--color-danger)!important;border-radius:6px!important;color:var(--color-text-primary)!important;font-size:1rem!important;font-weight:500!important;margin-bottom:1.5rem!important;padding:1rem!important}.modal-actions{align-items:center;border-top:2px solid var(--color-border)!important;gap:1rem!important;margin-top:1.5rem!important;padding-top:2rem!important}.modal-actions button{border:none;border-radius:8px!important;font-size:1.1rem!important;font-weight:600!important;height:55px!important;min-width:140px!important;padding:1rem 2rem!important;transition:all .3s ease!important}.modal-actions button:first-child{background:var(--color-primary)!important;color:#fff!important}.modal-actions button:first-child:hover:not(:disabled){background:var(--color-primary-dark)!important;box-shadow:0 6px 12px #007bff66!important;transform:translateY(-2px)!important}.modal-actions button:first-child:disabled{background:var(--color-text-tertiary)!important;box-shadow:none!important;cursor:not-allowed!important;opacity:.7!important;transform:none!important}.modal-actions button:last-child{background:var(--color-text-tertiary)!important;color:#fff!important}.modal-actions button:last-child:hover:not(:disabled){background:var(--color-text-secondary)!important;box-shadow:0 4px 8px #0003!important;transform:translateY(-2px)!important}.modal-actions button:disabled{cursor:not-allowed!important;opacity:.7!important;transform:none!important}@media (max-width:768px){.modal{max-width:95%!important;padding:1.5rem!important}.modal h3{font-size:1.5rem!important}.form-group input,.form-group textarea,.modal-actions button{font-size:1rem!important}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}@media (max-width:480px){.modal{border-radius:0!important;max-height:100vh!important;max-width:100%!important;padding:1rem!important}.modal-backdrop{padding:0!important}}.modal.loading{opacity:.8;pointer-events:none}.modal-actions button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.form-group input:focus-visible,.form-group textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.exp-container{padding:1rem 2rem}@media (max-width:768px){.exp-container{padding:1rem}}.exp-loading{align-items:center;color:var(--color-text-tertiary);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.exp-loading-spinner{animation:exp-spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid #007bff;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-primary,#007bff);height:40px;width:40px}@keyframes exp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.exp-access-denied{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa);border-radius:8px;margin:2rem;padding:2rem;text-align:center}.exp-access-denied-title{color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem}.exp-access-denied-message{color:#666;color:var(--color-text-secondary,#666);font-size:1.1rem}.exp-access-denied-hint{color:#999;color:var(--color-text-tertiary,#999);font-size:.9rem;margin-top:1rem}.exp-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.exp-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.75rem;margin:0}@media (max-width:576px){.exp-header{align-items:stretch;flex-direction:column}.exp-title{font-size:1.5rem;text-align:center}}.exp-btn-create{background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.exp-btn-create:hover:not(:disabled){background:#218838}.exp-btn-create:disabled{cursor:not-allowed;opacity:.6}.exp-btn-create-first{background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .2s ease}.exp-btn-create-first:hover{background:#218838}@media (max-width:576px){.exp-btn-create,.exp-btn-create-first{text-align:center;width:100%}}.exp-info{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa);border-left:4px solid #007bff;border-left:4px solid var(--color-primary,#007bff);border-radius:6px;margin-bottom:1rem;padding:.75rem}.exp-info p{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem;margin:0}.exp-info p+p{margin-top:.25rem}.exp-filter-container{margin-bottom:1.5rem}.exp-filter-input{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.exp-filter-input:focus{border-color:#007bff;border-color:var(--color-primary,#007bff);box-shadow:0 0 0 3px #007bff26;outline:none}.exp-filter-input::placeholder{color:#999;color:var(--color-text-tertiary,#999)}.exp-error{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:6px;color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem;padding:1rem}.exp-empty-state{color:#6c757d;color:var(--color-text-tertiary,#6c757d);padding:3rem;text-align:center}.exp-empty-icon{font-size:3rem;margin-bottom:1rem}.exp-empty-state h3{color:#495057;color:var(--color-text-secondary,#495057);margin:0 0 .5rem}.exp-empty-state p{font-size:.95rem;margin:0}.exp-mobile-only{display:block}.exp-desktop-only{display:none}@media (min-width:769px){.exp-mobile-only{display:none!important}.exp-desktop-only{display:block!important}}@media (max-width:768px){.exp-mobile-only{display:block!important}.exp-desktop-only{display:none!important}}.exp-mobile-view{display:flex;flex-direction:column;gap:1rem}.exp-card{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);padding:1rem}.exp-card-header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.75rem}.exp-card-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);flex:1 1;font-size:1.1rem;margin:0}.exp-card-school{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.8rem;font-weight:400;margin-top:.25rem}.exp-card-actions{display:flex;gap:.5rem}.exp-card-body{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem}.exp-card-detail{margin-bottom:.5rem}.exp-card-detail strong{color:#333;color:var(--color-text-primary,#333)}.exp-card-description{margin-top:.75rem}.exp-card-description strong{color:#333;color:var(--color-text-primary,#333)}.exp-action-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:inline-flex;font-size:1rem;justify-content:center;min-height:32px;min-width:32px;padding:.25rem;text-decoration:none;transition:background-color .2s ease}.exp-action-btn:hover:not(:disabled){background-color:#f0f0f0;background-color:var(--color-bg-tertiary,#f0f0f0)}.exp-action-btn:disabled{cursor:not-allowed;opacity:.5}.exp-action-view{color:#007bff;color:var(--color-primary,#007bff)}.exp-action-edit{color:#28a745;color:var(--color-success,#28a745)}.exp-action-delete{color:#dc3545;color:var(--color-danger,#dc3545)}.exp-table-actions{display:flex;gap:.5rem}.exp-table-wrapper{border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);overflow-x:auto}.exp-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;width:100%}.exp-table thead{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa)}.exp-table th{border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);color:#333;color:var(--color-text-primary,#333);font-weight:600;padding:1rem;text-align:left}.exp-table td{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);color:#555;color:var(--color-text-secondary,#555);padding:1rem}.exp-table tbody tr:hover{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa)}.exp-table tbody tr:last-child td{border-bottom:none}@media (hover:none) and (pointer:coarse){.exp-action-btn{font-size:1.2rem;min-height:44px;min-width:44px;padding:.5rem}.exp-btn-create,.exp-btn-create-first{min-height:44px;padding:1rem 1.5rem}.exp-filter-input{font-size:16px;padding:1rem}}@media print{.exp-mobile-only{display:none!important}.exp-desktop-only{display:block!important}.exp-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.exp-btn-create,.exp-btn-create-first,.exp-card-actions,.exp-filter-container,.exp-table-actions{display:none!important}.exp-table{box-shadow:none}}@media (prefers-contrast:high){.exp-card{border:2px solid #000}.exp-action-btn{border:2px solid}.exp-filter-input{border:2px solid #000}.exp-table td,.exp-table th{border:1px solid #000}}@media (prefers-reduced-motion:reduce){.exp-loading-spinner{animation:none}.exp-action-btn,.exp-btn-create,.exp-btn-create-first,.exp-filter-input{transition:none}}body[data-theme=dark] .exp-card{border-color:var(--color-border)}body[data-theme=dark] .exp-card,body[data-theme=dark] .exp-table{background:var(--color-bg-primary)}body[data-theme=dark] .exp-table thead{background:var(--color-bg-secondary)}body[data-theme=dark] .exp-access-denied,body[data-theme=dark] .exp-action-btn:hover:not(:disabled),body[data-theme=dark] .exp-filter-input,body[data-theme=dark] .exp-info{background-color:var(--color-bg-secondary)}body[data-theme=dark] .exp-filter-input{border-color:var(--color-border);color:var(--color-text-primary)}.edp-container{background:#f7f9fc;background:var(--color-bg-tertiary,#f7f9fc);font-family:Roboto,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}@media (min-width:768px){.edp-container{padding:2rem}}@media (max-width:480px){.edp-container{padding:.5rem}}.edp-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.edp-loading-spinner{animation:edp-spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid #007bff;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-primary,#007bff);height:40px;width:40px}@keyframes edp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.edp-mobile-only{display:block}.edp-desktop-only{display:none}@media (min-width:769px){.edp-mobile-only{display:none!important}.edp-desktop-only{display:block!important}}@media (max-width:768px){.edp-mobile-only{display:block!important}.edp-desktop-only{display:none!important}}.edp-error-msg{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:6px;color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem;padding:1rem}.edp-error-msg strong{display:block;margin-bottom:.5rem}.edp-success-msg{align-items:center;animation:edp-slideInDown .3s ease-out;background-color:#d4edda;background-color:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);border-radius:6px;color:#155724;color:var(--color-success-dark,#155724);display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.edp-success-msg:before{content:"✓";font-size:1.1rem}.edp-info-banner{align-items:center;background-color:#e3f2fd;background-color:var(--color-info-light,#e3f2fd);border:1px solid #bbdefb;border:1px solid var(--color-info-border,#bbdefb);border-radius:6px;color:#1565c0;color:var(--color-info-dark,#1565c0);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.edp-info-icon{font-size:1.1rem}.edp-empty-state{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-style:italic;padding:2rem 1rem}.edp-empty-cell,.edp-empty-state{text-align:center}@keyframes edp-slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.edp-error-actions{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.edp-back-container{margin-bottom:1rem}.edp-back-btn{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s ease}.edp-back-btn:hover:not(:disabled){background:#5a6268}.edp-back-btn:disabled{cursor:not-allowed;opacity:.6}.edp-back-btn-margin{margin-top:1rem}.edp-retry-btn{background:#28a745;background:var(--color-success,#28a745)}.edp-retry-btn:hover:not(:disabled){background:#218838}.edp-panel{background:#fff;background:var(--color-bg-secondary,#fff);border-radius:8px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--color-shadow,#0000001a);margin-bottom:1.5rem;padding:1.5rem}.edp-panel h2,.edp-panel h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin-bottom:1rem;margin-top:0}.edp-panel h2{font-size:1.5rem}.edp-panel h3{font-size:1.25rem}@media (max-width:576px){.edp-panel{padding:1rem}.edp-panel h2{font-size:1.25rem}.edp-panel h3{font-size:1.1rem}}.edp-section-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.edp-section-info{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa);border-left:3px solid #007bff;border-left:3px solid var(--color-primary,#007bff);border-radius:4px;margin-bottom:1rem;padding:.5rem}.edp-section-info p{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;margin:0}.edp-flex-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.edp-select{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;color:#333;color:var(--color-text-primary,#333);flex:1 1;font-size:.95rem;min-width:200px;padding:.5rem}.edp-select:focus{border-color:#007bff;border-color:var(--color-primary,#007bff);box-shadow:0 0 0 2px #007bff26;outline:none}.edp-btn-add{background:#007bff;background:var(--color-primary,#007bff);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:background-color .2s ease}.edp-btn-add:hover:not(:disabled){background:#0056b3}.edp-btn-add:disabled{cursor:not-allowed;opacity:.6}@media (max-width:576px){.edp-flex-row{flex-direction:column}.edp-btn-add,.edp-select{width:100%}}.edp-mobile-list-view{display:flex;flex-direction:column;gap:1rem}.edp-person-card{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000000d;box-shadow:0 2px 4px var(--color-shadow,#0000000d);padding:1rem;transition:box-shadow .2s ease}.edp-person-card:hover{box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--color-shadow,#0000001a)}.edp-person-card-header{align-items:flex-start;display:flex;gap:1rem}.edp-person-photo{flex-shrink:0}.edp-person-photo img{border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:8px;height:60px;object-fit:cover;width:60px}.edp-no-photo{align-items:center;background:#dee2e6;background:var(--color-bg-tertiary,#dee2e6);border-radius:8px;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;font-weight:500;height:60px;justify-content:center;width:60px}.edp-person-info{flex:1 1}.edp-person-info h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;margin:0 0 .5rem}.edp-person-info p{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;margin:.25rem 0}.edp-person-info strong{color:#2c3e50;color:var(--color-text-primary,#2c3e50)}.edp-person-actions{display:flex;flex-direction:column;flex-shrink:0;gap:.5rem}@media (max-width:576px){.edp-person-actions{flex-direction:row;flex-wrap:wrap;gap:.25rem}.edp-person-card-header{align-items:center;flex-direction:column;text-align:center}.edp-person-info{text-align:center}.edp-person-actions{justify-content:center}}.edp-action-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.edp-cert-btn,.edp-delete-btn,.edp-grade-btn,.edp-print-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;min-width:36px;padding:.5rem;transition:background-color .2s ease,transform .1s ease}.edp-delete-btn{background:#f8d7da;background:var(--color-danger-light,#f8d7da);color:#dc3545;color:var(--color-danger,#dc3545)}.edp-delete-btn:hover:not(:disabled){background:#dc3545;background:var(--color-danger,#dc3545);color:#fff}.edp-grade-btn{background:#fff3cd;background:var(--color-warning-light,#fff3cd);color:#856404;color:var(--color-warning-dark,#856404)}.edp-grade-btn:hover:not(:disabled){background:#ffc107;background:var(--color-warning,#ffc107);color:#212529}.edp-print-btn{background:#d1ecf1;background:var(--color-info-light,#d1ecf1);color:#0c5460;color:var(--color-info-dark,#0c5460)}.edp-print-btn:hover:not(:disabled){background:#17a2b8;background:var(--color-info,#17a2b8);color:#fff}.edp-cert-btn{background:#d4edda;background:var(--color-success-light,#d4edda);color:#28a745;color:var(--color-success,#28a745)}.edp-cert-btn:hover:not(:disabled){background:#28a745;background:var(--color-success,#28a745);color:#fff}.edp-cert-btn:disabled,.edp-delete-btn:disabled,.edp-grade-btn:disabled,.edp-print-btn:disabled{cursor:not-allowed;opacity:.5}.edp-certificate-actions{display:flex;gap:.5rem}.edp-certificate-btn{background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .2s ease;white-space:nowrap}.edp-certificate-btn:hover:not(:disabled){background:#218838}.edp-certificate-btn:disabled{cursor:not-allowed;opacity:.6}.edp-bulk-certificate-btn{background:#007bff;background:var(--color-primary,#007bff)}.edp-bulk-certificate-btn:hover:not(:disabled){background:#0056b3}.edp-bulk-progress-container{background:#fff;background:var(--color-bg-secondary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;margin-bottom:1rem;padding:1rem}.edp-bulk-progress-info{margin-bottom:.75rem}.edp-bulk-progress-info strong{color:#333;color:var(--color-text-primary,#333)}.edp-bulk-progress-info p{color:#666;color:var(--color-text-secondary,#666);font-size:.9rem;margin:.25rem 0}.edp-progress-bar{background:#e9ecef;background:var(--color-bg-tertiary,#e9ecef);border-radius:4px;height:8px;overflow:hidden;width:100%}.edp-progress-fill{background:#007bff;background:var(--color-primary,#007bff);border-radius:4px;height:100%;transition:width .3s ease}.edp-table-wrapper{border-radius:8px;overflow-x:auto}.edp-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;width:100%}.edp-table th{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);color:#333;color:var(--color-text-primary,#333);font-weight:600;padding:1rem;text-align:left}.edp-table td{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);color:#555;color:var(--color-text-secondary,#555);padding:1rem;vertical-align:middle}.edp-table tbody tr:hover{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa)}.edp-table tbody tr:last-child td{border-bottom:none}.edp-table-striped tbody tr:nth-child(2n){background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa)}.edp-table-striped tbody tr:nth-child(2n):hover{background-color:#e9ecef;background-color:var(--color-border-light,#e9ecef)}.edp-thumb{border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:6px;height:48px;object-fit:cover;width:48px}body.generating-pdf{overflow:hidden}body.generating-pdf .edp-action-buttons,body.generating-pdf .edp-back-btn,body.generating-pdf .edp-certificate-actions,body.generating-pdf .edp-flex-row,body.generating-pdf .edp-info-banner,body.generating-pdf .edp-mobile-only,body.generating-pdf .edp-person-actions{display:none!important}body.generating-pdf .edp-desktop-only{display:block!important}body.generating-pdf .edp-table td:last-child,body.generating-pdf .edp-table th:last-child{display:none!important}body.generating-pdf .edp-panel{border:1px solid #ddd!important;box-shadow:none!important;margin-bottom:1.5rem!important;page-break-inside:avoid!important}@media print{.edp-mobile-only{display:none!important}.edp-desktop-only{display:block!important}.edp-person-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.edp-back-btn,.edp-certificate-actions,.edp-flex-row,.edp-info-banner,.edp-person-actions{display:none!important}.edp-panel{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.edp-table td:last-child,.edp-table th:last-child{display:none!important}}@media (prefers-contrast:high){.edp-cert-btn,.edp-delete-btn,.edp-grade-btn,.edp-person-card,.edp-print-btn{border:2px solid #000}.edp-person-photo img,.edp-thumb{border-color:#000}.edp-table td,.edp-table th{border:1px solid #000}}@media (prefers-reduced-motion:reduce){.edp-loading-spinner{animation:none}.edp-back-btn,.edp-btn-add,.edp-cert-btn,.edp-certificate-btn,.edp-delete-btn,.edp-grade-btn,.edp-print-btn{transition:none}.edp-success-msg{animation:none}.edp-progress-fill{transition:none}}@media (hover:none) and (pointer:coarse){.edp-cert-btn,.edp-delete-btn,.edp-grade-btn,.edp-print-btn{font-size:1.2rem;height:44px;min-width:44px}.edp-back-btn,.edp-btn-add,.edp-certificate-btn{min-height:44px;padding:.75rem 1rem}.edp-select{font-size:16px;padding:.75rem}}.edp-back-btn:focus,.edp-btn-add:focus,.edp-cert-btn:focus,.edp-certificate-btn:focus,.edp-delete-btn:focus,.edp-grade-btn:focus,.edp-person-card:focus-within,.edp-print-btn:focus,.edp-select:focus{outline:2px solid #007bff;outline:2px solid var(--color-primary,#007bff);outline-offset:2px}body[data-theme=dark] .edp-container{background:var(--color-bg-tertiary)}body[data-theme=dark] .edp-panel{background:var(--color-bg-secondary)}body[data-theme=dark] .edp-person-card{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .edp-table{background:var(--color-bg-primary)}body[data-theme=dark] .edp-no-photo,body[data-theme=dark] .edp-table th{background:var(--color-bg-secondary)}body[data-theme=dark] .edp-section-info{background-color:var(--color-bg-secondary)}body[data-theme=dark] .edp-bulk-progress-container{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .edp-progress-bar{background:var(--color-bg-tertiary)}body[data-theme=dark] .edp-select{border-color:var(--color-border)}body[data-theme=dark] .edp-select,body[data-theme=dark] .edp-select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .edp-select option:checked,body[data-theme=dark] .edp-select option:hover{background-color:var(--color-primary);color:var(--color-text-inverse)}.modal-overlay{background:#0006;height:100%;width:100%;z-index:2000}.modal{background:var(--color-bg-primary);border-radius:8px;box-shadow:0 4px 16px #00000040;max-width:460px;padding:24px;width:90%}.modal h3{font-size:1.4em;margin-bottom:16px;margin-top:0}.modal label{display:block;font-weight:700;margin-bottom:4px}.modal input[type=number]{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:1em;margin-bottom:12px;padding:6px 8px;width:100%}.modal button{border:none;border-radius:4px;cursor:pointer;font-size:1em;padding:8px 14px}.modal button[type=submit]{background-color:#007acc;color:#fff}.modal button.secondary,.modal button[type=button]{background-color:#ccc;color:var(--color-text-primary)}.modal .error-msg,.modal .success-msg{border-radius:4px;font-size:.9em;margin-bottom:12px;padding:8px}.modal .error-msg{background:#ffe0e0;color:#a33}.modal .success-msg{background:#e0ffe0;color:#393}.action-buttons{align-items:center;display:flex;gap:.5rem;justify-content:center}@media (max-width:576px){.action-buttons{flex-direction:column;gap:.25rem}}.exam-pdf-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.8rem;height:32px;justify-content:center;min-width:32px;padding:.5rem;transition:all .2s}.exam-pdf-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.exam-pdf-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}@media (max-width:576px){.exam-pdf-btn{font-size:.9rem;height:36px;min-width:40px;width:100%}}body.generating-pdf .action-buttons .pdf-btn,body.generating-pdf .exam-pdf-btn{display:none!important}@media (max-width:768px){.students-table td:last-child,.students-table th:last-child{min-width:120px}}.pdf-btn[disabled]{cursor:not-allowed;opacity:.7}.pdf-btn[disabled]:hover{transform:none}@media (hover:none) and (pointer:coarse){.action-buttons button,.exam-pdf-btn{min-height:44px;min-width:44px}}.pdf-btn[disabled] .loading-icon{animation:spin 1s linear infinite}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.action-buttons button{border:.5px solid #0000}}body.generating-pdf .exam-card-header .action-buttons,body.generating-pdf .exam-card-header .detail-btn,body.generating-pdf .exam-card-header .pdf-btn{display:none!important}body.generating-pdf .exam-card-header,body.generating-pdf .seminaire-card-header,body.generating-pdf .tournament-card-header{justify-content:flex-start!important}body.generating-pdf .exam-card-title,body.generating-pdf .seminaire-card-title,body.generating-pdf .tournament-card-title{flex:1 1!important}@media (prefers-contrast:high){.action-buttons button{border:2px solid}.pdf-btn{border-color:#dc3545}.detail-btn{border-color:var(--color-primary)}}@media (prefers-reduced-motion:reduce){.action-buttons button{transition:none}.exam-pdf-btn:hover,.pdf-btn:hover{transform:none}}.authorities-container{background:var(--color-bg-secondary);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem}@media (min-width:768px){.authorities-container{padding:2rem}}.authorities-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}@media (min-width:768px){.authorities-header{align-items:center;flex-direction:row;justify-content:space-between}}.authorities-header h1{color:var(--color-text-primary);font-size:1.5rem;margin:0}@media (min-width:768px){.authorities-header h1{font-size:2rem}}.header-subtitle{color:var(--color-text-tertiary);font-size:1rem;margin:0}@media (min-width:768px){.header-subtitle{font-size:1.1rem}}.loading-spinner{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:50px;margin-bottom:1rem;width:50px}.error-message{background-color:var(--color-danger-light);border:1px solid #f5c6cb;border-radius:4px;color:#dc3545;margin-bottom:1rem;padding:.75rem}.error-message h2{color:#721c24;margin-bottom:1rem}.retry-button{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1rem;padding:.75rem 1.5rem;transition:background .2s}.retry-button:hover{background:#c82333}.authorities-section,.school-info-section,.venues-section{margin-bottom:2rem}.authorities-section h2,.school-info-section h2,.venues-section h2{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.3rem;font-weight:600;gap:.5rem;margin-bottom:1rem}@media (min-width:768px){.authorities-section h2,.school-info-section h2,.venues-section h2{font-size:1.5rem}}.section-icon{font-size:1.2rem}.authorities-count,.venues-count{background:#6c757d;border-radius:12px;color:#fff;font-size:.8rem;font-weight:500;margin-left:1rem;padding:.2rem .8rem}.add-authority-btn{align-items:center;background:#28a745;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:36px;justify-content:center;margin-left:.5rem;transition:all .2s ease;width:36px}.add-authority-btn:hover:not(:disabled){background:#218838;transform:scale(1.1)}.add-authority-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.add-venue-btn{align-items:center;background:var(--color-primary);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:36px;justify-content:center;margin-left:.5rem;transition:all .2s ease;width:36px}.add-venue-btn:hover:not(:disabled){background:#0056b3;transform:scale(1.1)}.add-venue-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.school-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 6px var(--color-shadow);padding:1.5rem;transition:box-shadow .2s ease}.school-card:hover{box-shadow:0 4px 12px #00000026}.school-header{align-items:center;border-bottom:1px solid #eee;display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}@media (max-width:768px){.school-header{flex-direction:column;text-align:center}}.school-logo{border:2px solid var(--color-border);border-radius:8px;height:64px;object-fit:cover;width:64px}.school-name-section h3{color:var(--color-text-primary);font-size:1.3rem;font-weight:600;margin:0 0 .5rem}@media (min-width:768px){.school-name-section h3{font-size:1.5rem}}.school-badge{background:#28a745;border-radius:12px;color:#fff;font-size:.8rem;font-weight:500;letter-spacing:.3px;padding:.25rem .75rem;text-transform:uppercase}.school-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.detail-item{align-items:flex-start;background:var(--color-bg-tertiary);border-radius:6px;display:flex;gap:.75rem;padding:.75rem;transition:background .2s ease}.detail-item:hover{background:var(--color-border-light)}.detail-icon{color:var(--color-text-tertiary);font-size:1.1rem;margin-top:.1rem}.detail-content{flex:1 1}.detail-content label{color:var(--color-text-secondary);display:block;font-size:.85rem;font-weight:600;letter-spacing:.3px;margin-bottom:.2rem;text-transform:uppercase}.detail-content p{color:var(--color-text-primary);font-size:.95rem;line-height:1.4;margin:0}.detail-content a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.detail-content a:hover{color:#0056b3;text-decoration:underline}.no-school-info{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-tertiary);padding:2rem;text-align:center}.authorities-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.authority-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 6px var(--color-shadow);padding:1.5rem;transition:box-shadow .2s ease}.authority-card:hover{box-shadow:0 4px 12px #00000026}.authority-header{align-items:center;border-bottom:1px solid #f8f9fa;display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem}.authority-photo{object-fit:cover}.authority-photo,.authority-photo-placeholder{border:2px solid var(--color-border);border-radius:50%;height:56px;width:56px}.authority-photo-placeholder{align-items:center;background:#6c757d;color:#fff;display:flex;font-size:1.3rem;justify-content:center}.authority-info h3{color:var(--color-text-primary);font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.authority-role{background:#6c757d;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.3px;padding:.2rem .6rem;text-transform:uppercase}.authority-role.role-presidente{background:#007bff!important;color:#fff!important}.authority-role.role-vice-presidente{background:#28a745!important;color:#fff!important}.authority-role.role-tesorera,.authority-role.role-tesorero{background:#ffc107!important;color:#212529!important}.authority-role.role-secretaria,.authority-role.role-secretario{background:#17a2b8!important;color:#fff!important}.authority-role.role-vocal{background:#6f42c1!important;color:#fff!important}.authority-role.role-default{background:#6c757d!important;color:#fff!important}.authority-role-container{align-items:center;display:flex;gap:.5rem}.role-edit-select{background:var(--color-bg-primary);border:2px solid #007bff;border-radius:4px;color:var(--color-text-primary);font-size:.75rem;min-width:140px;outline:none;padding:.25rem .5rem}.role-edit-select:focus{background:var(--color-bg-primary);border-color:#0056b3;box-shadow:0 0 0 2px #007bff1a}.role-edit-actions{display:flex;gap:.25rem}.save-role-btn{align-items:center;background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.7rem;height:22px;justify-content:center;padding:.25rem;transition:all .2s ease;width:22px}.save-role-btn:hover:not(:disabled){background:#218838}.save-role-btn:disabled{background:#6c757d;cursor:not-allowed}.cancel-role-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.7rem;height:22px;justify-content:center;padding:.25rem;transition:all .2s ease;width:22px}.cancel-role-btn:hover:not(:disabled){background:#c82333}.cancel-role-btn:disabled{background:#6c757d;cursor:not-allowed}.edit-role-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:.8rem;height:22px;justify-content:center;opacity:.6;padding:.25rem;transition:all .2s ease;width:22px}.edit-role-btn:hover{background:#007bff1a;opacity:1}.authority-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{align-items:center;display:flex;font-size:.9rem;gap:.5rem;padding:.25rem 0}.detail-row .detail-icon{color:var(--color-text-tertiary);font-size:.9rem;text-align:center;width:18px}.detail-text{color:var(--color-text-secondary);flex:1 1}.no-authorities{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-tertiary);padding:3rem 2rem;text-align:center}.no-authorities-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.new-authority-form{background:var(--color-bg-tertiary);border:2px solid #28a745;border-radius:8px;box-shadow:0 4px 12px #28a7451a;margin-bottom:2rem;padding:1.5rem}.new-authority-form h3{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.2rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.new-authority-form h3:before{content:"👥";font-size:1.3rem}.authority-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:1.5rem}@media (min-width:768px){.authority-form-grid{gap:1.5rem;grid-template-columns:2fr 1fr}}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{color:var(--color-text-secondary);font-size:.9rem;font-weight:600}.user-select{border:2px solid #28a745;border-radius:6px;color:var(--color-text-primary);font-size:.9rem;outline:none;padding:.75rem;transition:all .2s ease}.user-select,.user-select:focus{background:var(--color-bg-primary)}.user-select:focus{border-color:#218838;box-shadow:0 0 0 3px #28a7451a}.user-select:disabled{background:var(--color-bg-tertiary);border-color:var(--color-border-dark);cursor:not-allowed;opacity:.7}.role-select{border:2px solid #28a745;border-radius:6px;color:var(--color-text-primary);font-size:.9rem;outline:none;padding:.75rem;transition:all .2s ease}.role-select,.role-select:focus{background:var(--color-bg-primary)}.role-select:focus{border-color:#218838;box-shadow:0 0 0 3px #28a7451a}.role-select:disabled{background:var(--color-bg-tertiary);border-color:var(--color-border-dark);cursor:not-allowed;opacity:.7}.authority-form-actions{display:flex;gap:.75rem;justify-content:center}@media (max-width:768px){.authority-form-actions{flex-direction:column}}.create-authority-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:160px;padding:.75rem 1.5rem;transition:all .2s ease}.create-authority-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.create-authority-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.cancel-authority-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:120px;padding:.75rem 1.5rem;transition:all .2s ease}.cancel-authority-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.cancel-authority-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.user-preview{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;margin-top:.5rem;padding:1rem}.user-preview-content{align-items:center;display:flex;gap:1rem}.user-preview-photo{object-fit:cover}.user-preview-photo,.user-preview-photo-placeholder{border:2px solid var(--color-border);border-radius:50%;height:48px;width:48px}.user-preview-photo-placeholder{align-items:center;background:#6c757d;color:#fff;display:flex;font-size:1.2rem;justify-content:center}.user-preview-info h4{color:var(--color-text-primary);font-size:1rem;margin:0 0 .25rem}.user-preview-info p{color:var(--color-text-tertiary);font-size:.85rem;margin:0}.new-venue-form{background:var(--color-bg-tertiary);border:2px solid #007bff;border-radius:8px;box-shadow:0 4px 12px #007bff1a;margin-bottom:2rem;padding:1.5rem}.new-venue-form h3{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.2rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.new-venue-form h3:before{content:"🏢";font-size:1.3rem}.venue-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1.5rem}@media (min-width:768px){.venue-form-grid{gap:1.5rem;grid-template-columns:repeat(2,1fr)}}.venue-form-input{background:var(--color-bg-primary);border:2px solid #007bff;border-radius:6px;color:var(--color-text-primary);font-size:.9rem;outline:none;padding:.75rem;transition:all .2s ease}.venue-form-input:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff1a}.venue-form-input:disabled{background:var(--color-bg-tertiary);border-color:var(--color-border-dark);cursor:not-allowed;opacity:.7}.venue-form-actions{display:flex;gap:.75rem;justify-content:center}@media (max-width:768px){.venue-form-actions{flex-direction:column}}.save-venue-btn{align-items:center;background:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:160px;padding:.75rem 1.5rem;transition:all .2s ease}.save-venue-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.save-venue-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.cancel-venue-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:120px;padding:.75rem 1.5rem;transition:all .2s ease}.cancel-venue-btn:hover:not(:disabled){background:#c82333;box-shadow:0 4px 8px #dc35454d;transform:translateY(-1px)}.cancel-venue-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.create-first-venue-btn{background:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.create-first-venue-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.create-first-venue-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.create-first-authority-btn{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.create-first-authority-btn:hover:not(:disabled){background:#218838;box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.create-first-authority-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.venues-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.venue-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 6px var(--color-shadow);padding:1.5rem;position:relative;transition:box-shadow .2s ease}.venue-card:hover{box-shadow:0 4px 12px #00000026}.venue-header{align-items:flex-start;border-bottom:1px solid #f8f9fa;display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem}.venue-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;height:48px;justify-content:center;width:48px}.venue-info{flex:1 1;min-width:0}.venue-info h3{word-wrap:break-word;color:var(--color-text-primary);font-size:1.1rem;font-weight:600;line-height:1.3;margin:0 0 .5rem}.venue-status{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.3px;padding:.2rem .6rem;text-transform:uppercase}.venue-status.active{background:var(--color-success-light);border:1px solid #c3e6cb;color:var(--color-text-primary)}.venue-status.inactive{background:var(--color-danger-light);border:1px solid #f5c6cb;color:#721c24}.venue-details{display:flex;flex-direction:column;gap:.5rem}.venue-details .detail-row{align-items:flex-start;display:flex;font-size:.9rem;gap:.5rem;padding:.25rem 0}.venue-details .detail-row .detail-icon{color:var(--color-text-tertiary);flex-shrink:0;font-size:.9rem;margin-top:.1rem;text-align:center;width:18px}.venue-address{word-wrap:break-word;flex:1 1;line-height:1.4}.venue-contact-info{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:1fr;margin-top:.5rem}.venue-contact-info .detail-row{padding:.1rem 0}.no-venues{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-tertiary);padding:3rem 2rem;text-align:center}.no-venues-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.info-banner{align-items:center;background:#e7f3ff;border:1px solid #bee5eb;border-radius:4px;color:#0c5460;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem}.info-icon{font-size:1.1rem}@media (max-width:768px){.authorities-grid,.venues-grid{gap:1rem;grid-template-columns:1fr}.authority-card,.venue-card{padding:1.25rem}.school-details{grid-template-columns:1fr}.authorities-count,.venues-count{margin-left:0;margin-top:.5rem}.authorities-section h2,.venues-section h2{align-items:flex-start;flex-direction:column}.add-authority-btn{align-self:flex-start;font-size:1rem;height:32px;margin-left:0;margin-top:.5rem;width:32px}}@media (max-width:480px){.authorities-container{padding:.5rem}.authority-card,.school-card,.venue-card{padding:1rem}.authority-photo,.authority-photo-placeholder,.school-logo{height:48px;width:48px}.venue-icon{font-size:1.2rem;height:40px;width:40px}.authority-header,.venue-header{gap:.75rem}.authority-info h3,.venue-info h3{font-size:1rem}.add-authority-btn{font-size:1.1rem;height:36px;width:36px}.new-authority-form{padding:1rem}.authority-form-grid{grid-template-columns:1fr}.cancel-authority-btn,.create-authority-btn{font-size:1rem;min-width:auto;padding:1rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.authority-card,.new-authority-form,.school-card,.venue-card{animation:fadeInUp .4s ease-out}@media (prefers-reduced-motion:reduce){.authority-card,.new-authority-form,.school-card,.venue-card{animation:none}.add-authority-btn:hover,.authority-card:hover,.cancel-authority-btn:hover,.create-authority-btn:hover,.school-card:hover,.venue-card:hover{transform:none}}.authority-card:focus-within,.new-authority-form:focus-within,.school-card:focus-within,.venue-card:focus-within{outline:2px solid #007bff;outline-offset:2px}@media print{.authorities-container{background:var(--color-bg-primary);padding:1rem}.authority-card,.school-card,.venue-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.add-authority-btn,.new-authority-form,.retry-button{display:none}}.loading{align-items:center;color:var(--color-text-tertiary);display:flex;justify-content:center;padding:2rem}.loading p{font-size:1rem;margin-left:1rem}.empty-state{color:var(--color-text-tertiary);padding:3rem 1rem;text-align:center}.empty-state h3{color:var(--color-text-secondary);margin-bottom:.5rem}.editable-field .detail-content{position:relative}.field-display{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.field-display p{flex:1 1;margin:0}.edit-field-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:.9rem;height:24px;justify-content:center;min-width:24px;opacity:.6;padding:.25rem;transition:all .2s ease}.edit-field-btn:hover{background:#007bff1a;opacity:1;transform:scale(1.1)}.edit-field-btn:active{transform:scale(.95)}.inline-edit-container{align-items:center;display:flex;gap:.5rem;width:100%}.inline-edit-input{background:var(--color-bg-primary);border:2px solid #007bff;border-radius:4px;flex:1 1;font-size:.95rem;outline:none;padding:.5rem;transition:all .2s ease}.inline-edit-input:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff1a}.inline-edit-input:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.inline-edit-textarea{background:var(--color-bg-primary);border:2px solid #007bff;border-radius:4px;flex:1 1;font-family:inherit;font-size:.95rem;min-height:60px;outline:none;padding:.5rem;resize:vertical;transition:all .2s ease}.inline-edit-textarea:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff1a}.inline-edit-textarea:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.editable-venue-field{border-radius:4px;margin:-.5rem;padding:.5rem;transition:background-color .2s ease}.editable-venue-field:hover{background-color:#007bff05}.venue-field-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.venue-field-display{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.venue-field-display .detail-text{word-wrap:break-word;flex:1 1;line-height:1.4}.editable-venue-field .detail-row{align-items:flex-start;display:flex;font-size:.9rem;gap:.5rem;padding:.25rem 0}.editable-venue-field .detail-icon{color:var(--color-text-tertiary);flex-shrink:0;font-size:.9rem;margin-top:.1rem;text-align:center;width:18px}.inline-edit-actions{display:flex;flex-shrink:0;gap:.25rem}.save-field-btn{align-items:center;background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;min-width:28px;padding:.375rem;transition:all .2s ease}.save-field-btn:hover:not(:disabled){background:#218838;transform:scale(1.05)}.save-field-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.cancel-field-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;min-width:28px;padding:.375rem;transition:all .2s ease}.cancel-field-btn:hover:not(:disabled){background:#c82333;transform:scale(1.05)}.cancel-field-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.success-message{align-items:center;animation:slideInDown .3s ease-out;background-color:var(--color-success-light);border:1px solid #c3e6cb;border-radius:4px;color:#155724;display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem}.success-message:before{content:"✅";font-size:1.1rem}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.inline-edit-container{animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.field-display,.venue-field-display{align-items:flex-start;flex-direction:column;gap:.25rem}.edit-field-btn{align-self:flex-end;opacity:1}.inline-edit-container{flex-direction:column;gap:.75rem}.inline-edit-input,.inline-edit-textarea{width:100%}.inline-edit-actions{align-self:center;gap:.5rem}.cancel-field-btn,.save-field-btn{font-size:1rem;height:36px;min-width:36px}.venue-field-content{width:100%}.venue-field-display{align-items:flex-start;flex-direction:column;gap:.25rem}.venue-field-display .edit-field-btn{align-self:flex-end}.authority-role-container{align-items:flex-start;flex-direction:column;gap:.5rem}.role-edit-select{background:var(--color-bg-primary);min-width:auto;width:100%}.role-edit-actions{align-self:center}}@media (max-width:480px){.field-display,.venue-field-display{gap:.5rem}.edit-field-btn{font-size:1rem;height:32px;min-width:32px}.inline-edit-input,.inline-edit-textarea{font-size:1rem;padding:.75rem}.cancel-field-btn,.save-field-btn{font-size:1.1rem;height:44px;min-width:44px}.cancel-role-btn,.save-role-btn{font-size:1rem;height:36px;width:36px}.edit-role-btn{font-size:1rem;height:32px;width:32px}}.add-authority-btn:focus,.cancel-field-btn:focus,.cancel-role-btn:focus,.edit-field-btn:focus,.edit-role-btn:focus,.save-field-btn:focus,.save-role-btn:focus{outline:2px solid #007bff;outline-offset:2px}.edit-field-btn:focus-visible{background:#007bff1a;opacity:1}.save-field-btn:hover:not(:disabled){box-shadow:0 2px 4px #28a7454d}.cancel-field-btn:hover:not(:disabled){box-shadow:0 2px 4px #dc35454d}.add-authority-btn:hover:not(:disabled){box-shadow:0 2px 6px #28a7454d}.create-authority-btn:hover:not(:disabled){box-shadow:0 4px 8px #28a7454d}.cancel-authority-btn:hover:not(:disabled){box-shadow:0 4px 8px #dc35454d}.save-field-btn:disabled:after,.save-role-btn:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:12px;width:12px}.authority-role-container .edit-role-btn,.field-display .edit-field-btn,.venue-field-display .edit-field-btn{opacity:0;pointer-events:none}.authority-role-container:hover .edit-role-btn,.editable-field:hover .edit-field-btn,.editable-venue-field:hover .edit-field-btn{opacity:.6;pointer-events:auto}.authority-role-container:hover .edit-role-btn:hover,.editable-field:hover .edit-field-btn:hover,.editable-venue-field:hover .edit-field-btn:hover{opacity:1}@media (hover:none) and (pointer:coarse){.authority-role-container .edit-role-btn,.field-display .edit-field-btn,.venue-field-display .edit-field-btn{opacity:.7;pointer-events:auto}.cancel-field-btn,.save-field-btn{height:44px;min-width:44px}}@media (prefers-contrast:high){.edit-field-btn,.edit-role-btn{background:var(--color-bg-primary);border:1px solid #666}.save-field-btn,.save-role-btn{border:2px solid #28a745}.cancel-field-btn,.cancel-role-btn{border:2px solid #dc3545}.inline-edit-input{border:2px solid #000}.add-authority-btn{border:2px solid #28a745}}@media (prefers-reduced-motion:reduce){.add-authority-btn,.cancel-field-btn,.cancel-role-btn,.edit-field-btn,.edit-role-btn,.save-field-btn,.save-role-btn{transform:none;transition:none}.add-authority-btn:hover,.cancel-field-btn:hover,.cancel-role-btn:hover,.edit-field-btn:hover,.edit-role-btn:hover,.save-field-btn:hover,.save-role-btn:hover{transform:none}.inline-edit-container,.success-message{animation:none}}.editable-field{border-radius:6px;margin:-.75rem;padding:.75rem;transition:background-color .2s ease}.editable-field:hover{background-color:#007bff05}.field-display p{word-wrap:break-word;color:var(--color-text-primary);line-height:1.4}.field-display a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.field-display a:hover{color:#0056b3;text-decoration:underline}.school-logo-container{display:inline-block;position:relative}.edit-logo-btn{align-items:center;background:var(--color-primary);border:none;border-radius:50%;bottom:-8px;box-shadow:0 2px 4px #007bff4d;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:32px;justify-content:center;position:absolute;right:-8px;transition:all .2s ease;width:32px}.edit-logo-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 8px #007bff66;transform:scale(1.1)}.edit-logo-btn:disabled{background:#6c757d;box-shadow:0 2px 4px #6c757d4d;cursor:not-allowed;transform:none}.logo-edit-container{background:var(--color-bg-tertiary);border:2px solid #007bff;border-radius:8px;box-shadow:0 4px 12px #007bff1a;margin:1rem 0;padding:1.5rem}.logo-edit-container h4{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.logo-edit-container h4:before{content:"📷";font-size:1.2rem}.logo-edit-form{display:flex;flex-direction:column;gap:1rem}.logo-file-input{background:var(--color-bg-primary);border:2px dashed #007bff;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.75rem;transition:all .2s ease}.logo-file-input:hover{background:var(--color-bg-tertiary);border-color:#0056b3}.logo-file-input:disabled{background:var(--color-bg-tertiary);border-color:var(--color-border-dark);cursor:not-allowed;opacity:.7}.logo-preview{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);font-size:.9rem;padding:1rem}.logo-preview p{margin:.25rem 0}.logo-preview p:first-child{color:var(--color-text-primary);font-weight:600}.logo-edit-actions{gap:.75rem;margin-top:.5rem}.logo-edit-actions,.save-logo-btn{display:flex;justify-content:center}.save-logo-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;gap:.5rem;min-width:140px;padding:.75rem 1.25rem;transition:all .2s ease}.save-logo-btn:hover:not(:disabled){background:#218838;box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.save-logo-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.cancel-logo-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:120px;padding:.75rem 1.25rem;transition:all .2s ease}.cancel-logo-btn:hover:not(:disabled){background:#c82333;box-shadow:0 4px 8px #dc35454d;transform:translateY(-1px)}.cancel-logo-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}@media (max-width:768px){.edit-logo-btn{bottom:-6px;font-size:.8rem;height:28px;right:-6px;width:28px}.logo-edit-container{margin:.75rem 0;padding:1rem}.logo-edit-container h4{font-size:1rem}.logo-edit-actions{flex-direction:column;gap:.5rem}.cancel-logo-btn,.save-logo-btn{font-size:1rem;min-width:auto;padding:.875rem 1rem;width:100%}}@media (max-width:480px){.edit-logo-btn{bottom:-4px;font-size:.7rem;height:24px;right:-4px;width:24px}.logo-edit-container{padding:.875rem}.logo-file-input{font-size:1rem;padding:.875rem}.cancel-logo-btn,.save-logo-btn{font-size:1.1rem;padding:1rem}}.cancel-logo-btn:focus,.edit-logo-btn:focus,.save-logo-btn:focus{outline:2px solid #007bff;outline-offset:2px}.logo-file-input:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff1a;outline:none}@media (hover:none) and (pointer:coarse){.edit-logo-btn{font-size:1rem;height:36px;width:36px}.cancel-logo-btn,.save-logo-btn{font-size:1rem;min-height:48px}}@media (prefers-reduced-motion:reduce){.cancel-logo-btn,.edit-logo-btn,.save-logo-btn{transition:none}.cancel-logo-btn:hover,.edit-logo-btn:hover,.save-logo-btn:hover{transform:none}}@media (prefers-contrast:high){.edit-logo-btn{border:2px solid #007bff}.save-logo-btn{border:2px solid #28a745}.cancel-logo-btn{border:2px solid #dc3545}.logo-file-input{border:2px solid #007bff}.logo-edit-container{border:3px solid #007bff}}@keyframes logoEditSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.logo-edit-container{animation:logoEditSlideIn .3s ease-out}@media print{.edit-logo-btn,.logo-edit-container{display:none!important}}.pmp-container{background:#f7f9fc;background:var(--color-bg-secondary,#f7f9fc);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem}@media (min-width:768px){.pmp-container{padding:2rem}}.pmp-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}@media (min-width:768px){.pmp-header{align-items:center;flex-direction:row;justify-content:space-between}}.pmp-header h1{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;margin:0}@media (min-width:768px){.pmp-header h1{font-size:2rem}}.pmp-header-subtitle{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:1rem;margin:0}@media (min-width:768px){.pmp-header-subtitle{font-size:1.1rem}}.pmp-loading-spinner{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;justify-content:center;padding:4rem}.pmp-spinner{border:4px solid #f3f3f3;border-top:4px solid #28a745;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-success,#28a745);height:50px;margin-bottom:1rem;width:50px}.pmp-spinner,.pmp-spinner-small{animation:pmp-spin 1s linear infinite}.pmp-spinner-small{border:3px solid #f3f3f3;border-top:3px solid #28a745;border:3px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-success,#28a745);height:20px;width:20px}@keyframes pmp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.pmp-loading-indicator{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;font-size:.9rem;gap:.5rem;padding:1rem}.pmp-error-message{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:4px;color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem;padding:.75rem}.pmp-error-message h2{color:#721c24;color:var(--color-danger-dark,#721c24);margin-bottom:1rem}.pmp-success-message{align-items:center;animation:pmp-slideInDown .3s ease-out;background-color:#d4edda;background-color:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);border-radius:4px;color:#155724;color:var(--color-success-dark,#155724);display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem}.pmp-success-message:before{content:"✓";font-size:1.1rem}.pmp-info-banner{align-items:center;background-color:#fff3cd;background-color:var(--color-warning-light,#fff3cd);border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);border-radius:6px;color:#856404;color:var(--color-warning-dark,#856404);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.pmp-info-icon{font-size:1.1rem}@keyframes pmp-slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pmp-layout{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:1200px){.pmp-layout{grid-template-columns:1fr 350px}}.pmp-main{gap:2rem}.pmp-main,.pmp-sidebar{display:flex;flex-direction:column}.pmp-sidebar{gap:1.5rem}.pmp-section{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 6px #0000001a;box-shadow:0 2px 6px var(--color-shadow,#0000001a);padding:1.5rem;transition:box-shadow .2s ease}.pmp-section:hover{box-shadow:0 4px 12px #00000026;box-shadow:0 4px 12px var(--color-shadow,#00000026)}.pmp-section-header{align-items:center;border-bottom:1px solid #f8f9fa;border-bottom:1px solid var(--color-border-light,#f8f9fa);display:flex;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem}.pmp-section-icon{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);background:linear-gradient(135deg,var(--color-success,#28a745) 0,#20c997 100%);border-radius:8px;color:#fff;display:flex;font-size:1.5rem;height:48px;justify-content:center;width:48px}.pmp-section-title h2{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.3rem;font-weight:600;margin:0 0 .25rem}@media (min-width:768px){.pmp-section-title h2{font-size:1.5rem}}.pmp-section-subtitle{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.85rem;margin:0}.pmp-section-actions{display:flex;gap:.75rem;margin-left:auto}.pmp-add-btn{align-items:center;background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.pmp-add-btn:hover:not(:disabled){background:#218838;transform:scale(1.1)}.pmp-add-btn:disabled{cursor:not-allowed;transform:none}.pmp-add-btn:disabled,.pmp-print-btn{background:#6c757d;background:var(--color-secondary,#6c757d)}.pmp-print-btn{align-items:center;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;margin-right:.5rem;transition:all .2s ease;width:36px}.pmp-print-btn:hover:not(:disabled){background:#5a6268;transform:scale(1.1)}.pmp-print-btn:disabled{background:#adb5bd;cursor:not-allowed;opacity:.6;transform:none}.pmp-debt-report-btn{align-items:center;background:#dc3545;background:var(--color-danger,#dc3545);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;margin-right:.5rem;transition:all .2s ease;width:36px}.pmp-debt-report-btn:hover:not(:disabled){background:#c82333;transform:scale(1.1)}.pmp-debt-report-btn:disabled{background:#f5c6cb;background:var(--color-danger-light,#f5c6cb);cursor:not-allowed;opacity:.6;transform:none}.pmp-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}@media (min-width:768px){.pmp-controls{align-items:center;flex-direction:row;justify-content:space-between}}.pmp-controls-left{display:flex;flex-direction:column;gap:1rem}@media (min-width:768px){.pmp-controls-left{align-items:center;flex-direction:row;flex-wrap:wrap}}.pmp-controls-right{display:flex;gap:.75rem}.pmp-filter-group{align-items:center;display:flex;gap:.5rem}.pmp-filter-label{font-weight:500;min-width:-webkit-fit-content;min-width:fit-content}.pmp-filter-label,.pmp-filter-select{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem}.pmp-filter-select{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:4px;min-width:120px;outline:none;padding:.5rem .75rem;transition:border-color .2s ease}.pmp-filter-select:focus{border-color:#28a745;border-color:var(--color-success,#28a745)}.pmp-search-input{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:4px;color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;min-width:200px;outline:none;padding:.5rem .75rem;transition:border-color .2s ease}.pmp-search-input:focus{border-color:#28a745;border-color:var(--color-success,#28a745)}.pmp-table-container{border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;overflow-x:auto}.pmp-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;width:100%}.pmp-table td,.pmp-table th{border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--color-border,#dee2e6);padding:.75rem;text-align:left;vertical-align:middle}.pmp-table th{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa);color:#495057;color:var(--color-text-secondary,#495057);font-size:.85rem;font-weight:600;letter-spacing:.3px;position:-webkit-sticky;position:sticky;text-transform:uppercase;top:0;z-index:10}.pmp-table tr:hover{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa)}.pmp-table tr:last-child td{border-bottom:none}.pmp-student-cell{align-items:center;display:flex;gap:.75rem}.pmp-student-photo{object-fit:cover}.pmp-student-photo,.pmp-student-photo-placeholder{border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:50%;height:40px;width:40px}.pmp-student-photo-placeholder{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);color:#fff;display:flex;font-size:1rem;justify-content:center}.pmp-student-info h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:.9rem;font-weight:600;margin:0 0 .1rem}.pmp-student-info p{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.8rem;margin:0}.pmp-amount-cell{color:#28a745;color:var(--color-success,#28a745);font-family:Courier New,monospace;font-size:.95rem;font-weight:600;white-space:nowrap}.pmp-date-cell{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem}.pmp-month-cell{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:.9rem;font-weight:600}.pmp-payment-type-cell{white-space:nowrap}.pmp-payment-type-badge{background:#e9ecef;background:var(--color-bg-tertiary,#e9ecef);border-radius:12px;color:#333;color:var(--color-text-primary,#333);display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .6rem}.pmp-type-cuota{background:#d4edda;color:#155724}.pmp-type-licencia{background:#cce5ff;color:#004085}.pmp-type-matricula{background:#fff3cd;color:#856404}.pmp-type-examen{background:#f8d7da;color:#721c24}.pmp-type-equipacion{background:#d1ecf1;color:#0c5460}.pmp-type-dobok{background:#e2e3e5;color:#383d41}.pmp-type-curso{background:#d6d8db;color:#1b1e21}.pmp-type-torneo{background:#ffeeba;color:#856404}.pmp-type-otros{background:#f5f5f5;color:#6c757d}.pmp-row-actions{display:flex;gap:.25rem}.pmp-action-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:.85rem;height:28px;justify-content:center;padding:.25rem;transition:all .2s ease;width:28px}.pmp-action-btn:hover{background:#007bff1a;transform:scale(1.1)}.pmp-action-btn.pmp-delete{color:#dc3545;color:var(--color-danger,#dc3545)}.pmp-action-btn.pmp-delete:hover{background:#dc35451a;background:var(--color-danger-light,#dc35451a)}.pmp-new-payment-form{animation:pmp-fadeInUp .4s ease-out;background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:2px solid #28a745;border:2px solid var(--color-success,#28a745);border-radius:8px;box-shadow:0 4px 12px #28a7451a;box-shadow:0 4px 12px var(--color-success-shadow,#28a7451a);margin-bottom:2rem;padding:1.5rem}.pmp-new-payment-form h3{align-items:center;color:#2c3e50;color:var(--color-text-primary,#2c3e50);display:flex;font-size:1.2rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.pmp-new-payment-form h3:before{content:"💰";font-size:1.3rem}@keyframes pmp-fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pmp-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:1.5rem}@media (min-width:768px){.pmp-form-grid{gap:1.5rem;grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.pmp-form-grid{grid-template-columns:repeat(4,1fr)}}.pmp-form-field{display:flex;flex-direction:column;gap:.5rem}.pmp-form-field label{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;font-weight:600}.pmp-form-field.pmp-required label:after{color:#dc3545;color:var(--color-danger,#dc3545);content:" *"}.pmp-form-input,.pmp-form-select{background:#fff;background:var(--color-bg-primary,#fff);border:2px solid #28a745;border:2px solid var(--color-success,#28a745);border-radius:6px;color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:.9rem;outline:none;padding:.75rem;transition:all .2s ease}.pmp-form-input:focus,.pmp-form-select:focus{border-color:#218838;box-shadow:0 0 0 3px #28a7451a;box-shadow:0 0 0 3px var(--color-success-shadow,#28a7451a)}.pmp-form-input:disabled,.pmp-form-select:disabled{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-color:#ced4da;border-color:var(--color-border,#ced4da);cursor:not-allowed;opacity:.7}.pmp-form-error{color:#dc3545;color:var(--color-danger,#dc3545);font-size:.8rem;margin-top:.25rem}.pmp-form-field.pmp-error .pmp-form-input,.pmp-form-field.pmp-error .pmp-form-select{border-color:#dc3545;border-color:var(--color-danger,#dc3545)}.pmp-form-help{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.75rem;margin-top:.25rem}.pmp-form-actions{display:flex;gap:.75rem;justify-content:center}@media (max-width:768px){.pmp-form-actions{flex-direction:column}}.pmp-btn-primary{align-items:center;background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:160px;padding:.75rem 1.5rem;transition:all .2s ease}.pmp-btn-primary:hover:not(:disabled){background:#218838;box-shadow:0 4px 8px #28a7454d;box-shadow:0 4px 8px var(--color-success-shadow,#28a7454d);transform:translateY(-1px)}.pmp-btn-primary:disabled{box-shadow:none;cursor:not-allowed;transform:none}.pmp-btn-primary:disabled,.pmp-btn-secondary{background:#6c757d;background:var(--color-secondary,#6c757d)}.pmp-btn-secondary{align-items:center;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:120px;padding:.75rem 1.5rem;transition:all .2s ease}.pmp-btn-secondary:hover:not(:disabled){background:#5a6268;box-shadow:0 4px 8px #6c757d4d;transform:translateY(-1px)}.pmp-btn-secondary:disabled{background:#adb5bd;box-shadow:none;cursor:not-allowed;transform:none}.pmp-summary-panel{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 6px #0000001a;box-shadow:0 2px 6px var(--color-shadow,#0000001a);padding:1.5rem}.pmp-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}.pmp-summary-item{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #e9ecef;border:1px solid var(--color-border-light,#e9ecef);border-radius:6px;padding:1rem;text-align:center}.pmp-summary-item h4{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.8rem;font-weight:500;letter-spacing:.3px;margin:0 0 .5rem;text-transform:uppercase}.pmp-summary-value{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.5rem;font-weight:700;margin:0}.pmp-summary-value.pmp-money{color:#28a745;color:var(--color-success,#28a745);font-family:Courier New,monospace}.pmp-summary-change{font-size:.75rem;font-weight:500;margin-top:.25rem}.pmp-summary-change.pmp-positive{color:#28a745;color:var(--color-success,#28a745)}.pmp-summary-change.pmp-negative{color:#dc3545;color:var(--color-danger,#dc3545)}.pmp-summary-change.pmp-neutral{color:#6c757d;color:var(--color-text-tertiary,#6c757d)}.pmp-stats-timestamp{border-radius:4px;font-size:.75rem;margin-top:1rem;padding:.5rem}.pmp-empty-state,.pmp-stats-timestamp{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);color:#6c757d;color:var(--color-text-tertiary,#6c757d);text-align:center}.pmp-empty-state{border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;padding:3rem 2rem}.pmp-empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.pmp-empty-state h3{color:#495057;color:var(--color-text-secondary,#495057);font-size:1.1rem;margin-bottom:.5rem}.pmp-empty-state p{font-size:.9rem;margin:0}.pmp-create-first-btn{background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.pmp-create-first-btn:hover:not(:disabled){background:#218838;box-shadow:0 4px 8px #28a7454d;box-shadow:0 4px 8px var(--color-success-shadow,#28a7454d);transform:translateY(-1px)}.pmp-create-first-btn:disabled{background:#6c757d;background:var(--color-secondary,#6c757d);box-shadow:none;cursor:not-allowed;transform:none}.pmp-pagination{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:2rem;padding:1rem}.pmp-pagination-btn{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:4px;color:#333;color:var(--color-text-primary,#333);cursor:pointer;font-size:.9rem;padding:.5rem .75rem;transition:all .2s ease}.pmp-pagination-btn:hover:not(:disabled){background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border-color:#28a745;border-color:var(--color-success,#28a745)}.pmp-pagination-btn:disabled{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);cursor:not-allowed}.pmp-pagination-btn:disabled,.pmp-pagination-info{color:#6c757d;color:var(--color-text-tertiary,#6c757d)}.pmp-pagination-info{font-size:.9rem;margin:0 1rem;text-align:center}.pmp-pagination-details{display:block;font-size:.8rem}.pmp-pagination-quick{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;font-size:.9rem;gap:.5rem;justify-content:center;margin-top:1rem}.pmp-page-input{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:4px;color:#333;color:var(--color-text-primary,#333);font-size:.9rem;padding:.25rem .5rem;text-align:center;width:60px}@media (max-width:768px){.pmp-table-container{font-size:.85rem}.pmp-table td,.pmp-table th{padding:.5rem}.pmp-student-cell{align-items:flex-start;flex-direction:column;gap:.5rem}.pmp-student-photo,.pmp-student-photo-placeholder{font-size:.9rem;height:32px;width:32px}.pmp-row-actions{flex-direction:column;gap:.1rem}.pmp-action-btn{font-size:.75rem;height:24px;width:24px}}@media (max-width:480px){.pmp-container{padding:.75rem}.pmp-section{padding:1rem}.pmp-section-icon{font-size:1.2rem;height:40px;width:40px}.pmp-new-payment-form{padding:1rem}.pmp-form-grid{grid-template-columns:1fr}.pmp-form-actions{flex-direction:column}.pmp-btn-primary,.pmp-btn-secondary{min-width:auto;width:100%}}@media (hover:none) and (pointer:coarse){.pmp-add-btn,.pmp-debt-report-btn,.pmp-print-btn{height:44px;width:44px}.pmp-btn-primary,.pmp-btn-secondary,.pmp-create-first-btn{min-height:44px;padding:.875rem 1.5rem}.pmp-filter-select,.pmp-form-input,.pmp-form-select,.pmp-search-input{font-size:16px;padding:.75rem}}@media print{.pmp-container{background:#fff;padding:1rem}.pmp-section{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.pmp-add-btn,.pmp-controls,.pmp-debt-report-btn,.pmp-info-banner,.pmp-new-payment-form,.pmp-pagination,.pmp-pagination-quick,.pmp-print-btn,.pmp-row-actions,.pmp-sidebar{display:none!important}}@media (prefers-contrast:high){.pmp-form-input,.pmp-form-select,.pmp-section{border:2px solid #000}.pmp-btn-primary{border:2px solid #28a745;border:2px solid var(--color-success,#28a745)}.pmp-btn-secondary{border:2px solid #6c757d;border:2px solid var(--color-secondary,#6c757d)}.pmp-table td,.pmp-table th{border:1px solid #000}}@media (prefers-reduced-motion:reduce){.pmp-new-payment-form,.pmp-section{animation:none}.pmp-add-btn:hover,.pmp-btn-primary:hover,.pmp-btn-secondary:hover,.pmp-debt-report-btn:hover,.pmp-print-btn:hover{transform:none}.pmp-spinner,.pmp-spinner-small,.pmp-success-message{animation:none}}body[data-theme=dark] .pmp-container{background:var(--color-bg-tertiary)}body[data-theme=dark] .pmp-section,body[data-theme=dark] .pmp-summary-panel{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .pmp-table{background:var(--color-bg-primary)}body[data-theme=dark] .pmp-table th{background:var(--color-bg-secondary)}body[data-theme=dark] .pmp-new-payment-form{background:var(--color-bg-secondary);border-color:var(--color-success)}body[data-theme=dark] .pmp-filter-select,body[data-theme=dark] .pmp-form-input,body[data-theme=dark] .pmp-form-select,body[data-theme=dark] .pmp-search-input{background-color:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .pmp-filter-select option,body[data-theme=dark] .pmp-form-select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .pmp-empty-state,body[data-theme=dark] .pmp-stats-timestamp,body[data-theme=dark] .pmp-summary-item{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .pmp-pagination-btn{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .pmp-pagination-btn:hover:not(:disabled){background:var(--color-bg-tertiary)}body[data-theme=dark] .pmp-page-input{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .pmp-info-banner{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-text-primary)}body[data-theme=dark] .pmp-payment-type-badge{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.pmp-action-btn:focus,.pmp-add-btn:focus,.pmp-btn-primary:focus,.pmp-btn-secondary:focus,.pmp-debt-report-btn:focus,.pmp-filter-select:focus,.pmp-form-input:focus,.pmp-form-select:focus,.pmp-new-payment-form:focus-within,.pmp-page-input:focus,.pmp-pagination-btn:focus,.pmp-print-btn:focus,.pmp-search-input:focus,.pmp-section:focus-within{outline:2px solid #28a745;outline:2px solid var(--color-success,#28a745);outline-offset:2px}.under-construction{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:10px;box-shadow:0 4px 6px var(--color-shadow);display:flex;flex-direction:column;justify-content:center;margin:2rem;min-height:70vh;padding:2rem;text-align:center}.construction-icon{animation:bounce 2s infinite;font-size:4rem;margin-bottom:1rem}.under-construction h1{color:var(--color-text-primary);font-size:2.5rem;font-weight:300;margin-bottom:1rem}.construction-message{margin:0 auto;max-width:600px}.construction-message h2{color:#e74c3c;font-size:1.8rem;font-weight:500;margin-bottom:1rem}.construction-message p{color:#5a6c7d;font-size:1.1rem;line-height:1.6;margin-bottom:.8rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}@media (max-width:768px){.under-construction{margin:1rem;padding:1.5rem}.construction-icon{font-size:3rem}.under-construction h1{font-size:2rem}.construction-message h2{font-size:1.5rem}.construction-message p{font-size:1rem}}.smp-container{background:#f7f9fc;background:var(--color-bg-tertiary,#f7f9fc);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem 2rem}@media (max-width:768px){.smp-container{padding:1rem}}.smp-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.smp-loading-spinner{animation:smp-spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid #28a745;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-success,#28a745);height:40px;width:40px}@keyframes smp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.smp-error-msg{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:6px;color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem;padding:1rem}.smp-error-msg strong{display:block;margin-bottom:.5rem}.smp-error-actions{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.smp-back-btn{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s ease}.smp-back-btn:hover:not(:disabled){background:#5a6268}.smp-retry-btn{background:#28a745;background:var(--color-success,#28a745)}.smp-retry-btn:hover:not(:disabled){background:#218838}.smp-header{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.smp-header,.smp-header h1{align-items:center;display:flex}.smp-header h1{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.75rem;gap:.5rem;margin:0}.smp-header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.smp-admin-badge{font-size:1.2rem;margin-left:.5rem}@media (max-width:576px){.smp-header{align-items:stretch;flex-direction:column}.smp-header h1{font-size:1.5rem;justify-content:center}.smp-header-controls{flex-direction:column;width:100%}}.smp-search{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;min-width:250px;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease}.smp-search:focus{border-color:#28a745;border-color:var(--color-success,#28a745);box-shadow:0 0 0 3px #28a74526;outline:none}.smp-search::placeholder{color:#999;color:var(--color-text-tertiary,#999)}@media (max-width:576px){.smp-search{min-width:0;min-width:auto;width:100%}}.smp-btn-create{background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease;white-space:nowrap}.smp-btn-create:hover:not(:disabled){background:#218838}.smp-btn-create:disabled{cursor:not-allowed;opacity:.6}@media (max-width:576px){.smp-btn-create{text-align:center;width:100%}}.smp-info-banner{align-items:center;background-color:#e3f2fd;background-color:var(--color-info-light,#e3f2fd);border:1px solid #bbdefb;border:1px solid var(--color-info-border,#bbdefb);border-radius:6px;color:#1565c0;color:var(--color-info-dark,#1565c0);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.smp-info-banner-admin{background-color:#e8f4f8;border-color:#b8daff;color:#0c5460}.smp-info-icon{font-size:1.1rem}.smp-info{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa);border-left:4px solid #28a745;border-left:4px solid var(--color-success,#28a745);border-radius:6px;margin-bottom:1rem;padding:.75rem}.smp-info p{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem;margin:0}.smp-info p+p{margin-top:.25rem}.smp-empty-state{color:#6c757d;color:var(--color-text-tertiary,#6c757d);padding:3rem;text-align:center}.smp-empty-state h3{color:#495057;color:var(--color-text-secondary,#495057);margin:0 0 .5rem}.smp-empty-state p{font-size:.95rem;margin:0}.smp-mobile-only{display:block}.smp-desktop-only{display:none}@media (min-width:769px){.smp-mobile-only{display:none!important}.smp-desktop-only{display:block!important}}@media (max-width:768px){.smp-mobile-only{display:block!important}.smp-desktop-only{display:none!important}}.smp-mobile-view{display:flex;flex-direction:column;gap:1rem}.smp-card{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);padding:1rem;transition:box-shadow .2s ease,transform .2s ease}.smp-card:hover{box-shadow:0 4px 8px #00000026;box-shadow:0 4px 8px var(--color-shadow,#00000026);transform:translateY(-1px)}.smp-card-header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.75rem}.smp-card-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);flex:1 1;font-size:1.1rem;margin:0}.smp-school-badge{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.8rem;font-weight:400;margin-top:.25rem}.smp-card-actions{display:flex;gap:.5rem}.smp-card-body{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem}.smp-card-detail{margin-bottom:.5rem}.smp-card-detail strong{color:#333;color:var(--color-text-primary,#333)}.smp-action-buttons{display:flex;gap:.5rem}.smp-delete-btn,.smp-edit-btn,.smp-view-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;min-width:36px;padding:.5rem;transition:background-color .2s ease}.smp-view-btn{color:#007bff;color:var(--color-primary,#007bff)}.smp-view-btn:hover:not(:disabled){background-color:#e3f2fd;background-color:var(--color-primary-light,#e3f2fd)}.smp-edit-btn{color:#28a745;color:var(--color-success,#28a745)}.smp-edit-btn:hover:not(:disabled){background-color:#d4edda;background-color:var(--color-success-light,#d4edda)}.smp-delete-btn{color:#dc3545;color:var(--color-danger,#dc3545)}.smp-delete-btn:hover:not(:disabled){background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da)}.smp-delete-btn:disabled,.smp-edit-btn:disabled,.smp-view-btn:disabled{cursor:not-allowed;opacity:.5}.smp-table-wrapper{border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);overflow-x:auto}.smp-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;width:100%}.smp-table thead{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa)}.smp-table th{border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);color:#333;color:var(--color-text-primary,#333);font-weight:600;padding:1rem;text-align:left}.smp-table td{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);color:#555;color:var(--color-text-secondary,#555);padding:1rem}.smp-table tbody tr:hover{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa)}.smp-table tbody tr:last-child td{border-bottom:none}.smp-school-name{color:#666;color:var(--color-text-secondary,#666);font-size:.9rem}@media (hover:none) and (pointer:coarse){.smp-delete-btn,.smp-edit-btn,.smp-view-btn{font-size:1.2rem;height:44px;min-width:44px;padding:.75rem}.smp-back-btn,.smp-btn-create{min-height:44px;padding:1rem 1.5rem}.smp-search{font-size:16px;padding:1rem}}@media print{.smp-mobile-only{display:none!important}.smp-desktop-only{display:block!important}.smp-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.smp-action-buttons,.smp-back-btn,.smp-btn-create,.smp-card-actions,.smp-header-controls,.smp-search{display:none!important}.smp-table{box-shadow:none}}@media (prefers-contrast:high){.smp-card{border:2px solid #000}.smp-delete-btn,.smp-edit-btn,.smp-view-btn{border:2px solid}.smp-search{border:2px solid #000}.smp-table td,.smp-table th{border:1px solid #000}.smp-info{border-left-color:var(--color-text-primary)}}@media (prefers-reduced-motion:reduce){.smp-loading-spinner{animation:none}.smp-card{transition:none}.smp-card:hover{transform:none}.smp-back-btn,.smp-btn-create,.smp-delete-btn,.smp-edit-btn,.smp-search,.smp-view-btn{transition:none}}body[data-theme=dark] .smp-container{background:var(--color-bg-tertiary)}body[data-theme=dark] .smp-card{border-color:var(--color-border)}body[data-theme=dark] .smp-card,body[data-theme=dark] .smp-table{background:var(--color-bg-primary)}body[data-theme=dark] .smp-table thead{background:var(--color-bg-secondary)}body[data-theme=dark] .smp-info{background-color:var(--color-bg-secondary)}body[data-theme=dark] .smp-search{background-color:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .smp-info-banner{border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .smp-info-banner,body[data-theme=dark] .smp-info-banner-admin{background-color:var(--color-info-light)}body[data-theme=dark] .smp-view-btn:hover:not(:disabled){background-color:var(--color-primary-light)}body[data-theme=dark] .smp-edit-btn:hover:not(:disabled){background-color:var(--color-success-light)}body[data-theme=dark] .smp-delete-btn:hover:not(:disabled){background-color:var(--color-danger-light)}.smp-back-btn:focus,.smp-btn-create:focus,.smp-card:focus-within,.smp-delete-btn:focus,.smp-edit-btn:focus,.smp-search:focus,.smp-view-btn:focus{outline:2px solid #28a745;outline:2px solid var(--color-success,#28a745);outline-offset:2px}.sdp-container{background:#f7f9fc;background:var(--color-bg-tertiary,#f7f9fc);font-family:Roboto,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}@media (min-width:768px){.sdp-container{padding:2rem}}@media (max-width:480px){.sdp-container{padding:.5rem}}.sdp-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.sdp-loading-spinner{animation:sdp-spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid #28a745;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-success,#28a745);height:40px;width:40px}@keyframes sdp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sdp-error-msg{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:6px;color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem;padding:1rem}.sdp-error-msg strong{display:block;margin-bottom:.5rem}.sdp-success-msg{align-items:center;animation:sdp-slideInDown .3s ease-out;background-color:#d4edda;background-color:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);border-radius:6px;color:#155724;color:var(--color-success-dark,#155724);display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.sdp-success-msg:before{content:"✓";font-size:1.1rem}.sdp-info-banner{align-items:center;background-color:#e3f2fd;background-color:var(--color-info-light,#e3f2fd);border:1px solid #bbdefb;border:1px solid var(--color-info-border,#bbdefb);border-radius:6px;color:#1565c0;color:var(--color-info-dark,#1565c0);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.sdp-info-icon{font-size:1.1rem}@keyframes sdp-slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sdp-error-actions{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.sdp-back-container{margin-bottom:1rem}.sdp-back-btn{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s ease}.sdp-back-btn:hover:not(:disabled){background:#5a6268}.sdp-retry-btn{background:#28a745;background:var(--color-success,#28a745)}.sdp-retry-btn:hover:not(:disabled){background:#218838}.sdp-panel{background:#fff;background:var(--color-bg-secondary,#fff);border-radius:8px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--color-shadow,#0000001a);margin-bottom:1.5rem;padding:1.5rem}.sdp-panel h2,.sdp-panel h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin-bottom:1rem;margin-top:0}.sdp-panel h2{font-size:1.5rem}.sdp-panel h3{font-size:1.25rem}@media (max-width:576px){.sdp-panel{padding:1rem}.sdp-panel h2{font-size:1.25rem}.sdp-panel h3{font-size:1.1rem}}.sdp-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.sdp-info-grid p{color:#495057;color:var(--color-text-secondary,#495057);margin:.5rem 0}.sdp-info-grid strong{color:#2c3e50;color:var(--color-text-primary,#2c3e50)}.sdp-school-name{color:#495057;color:var(--color-text-secondary,#495057);font-weight:500;margin-left:.5rem}.sdp-temario-section{border-top:1px solid #dee2e6;border-top:1px solid var(--color-border,#dee2e6);margin-top:1.5rem;padding-top:1rem}.sdp-temario-section h4{align-items:center;color:#2c3e50;color:var(--color-text-primary,#2c3e50);display:flex;font-size:1.1rem;gap:.5rem;margin-bottom:.75rem}.sdp-temario-section h4:before{content:"📋";font-size:1.2rem}.sdp-temario-content{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #e9ecef;border:1px solid var(--color-border-light,#e9ecef);border-radius:8px;color:#495057;color:var(--color-text-secondary,#495057);font-size:.95rem;line-height:1.6;padding:1.5rem;white-space:pre-wrap}.sdp-temario-content:empty:before{color:#6c757d;color:var(--color-text-tertiary,#6c757d);content:"No se ha especificado temario para este seminario";font-style:italic}.sdp-attendees-section{margin-top:1rem}.sdp-attendees-section h3:before{content:"👥";font-size:1.2rem;margin-right:.5rem}.sdp-section-header{align-items:center;gap:1rem;justify-content:space-between}.sdp-attendees-controls,.sdp-section-header{display:flex;flex-wrap:wrap;margin-bottom:1rem}.sdp-attendees-controls{gap:.5rem}.sdp-select{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;color:#333;color:var(--color-text-primary,#333);flex:1 1;font-size:.95rem;min-width:200px;padding:.5rem;transition:border-color .2s ease,box-shadow .2s ease}.sdp-select:focus{border-color:#28a745;border-color:var(--color-success,#28a745);box-shadow:0 0 0 2px #28a74526;outline:none}.sdp-btn-add{background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:background-color .2s ease;white-space:nowrap}.sdp-btn-add:hover:not(:disabled){background:#218838}.sdp-btn-add:disabled{background:#6c757d;background:var(--color-secondary,#6c757d);cursor:not-allowed}@media (max-width:576px){.sdp-attendees-controls{flex-direction:column}.sdp-select{min-width:0;min-width:auto;width:100%}.sdp-btn-add{width:100%}}.sdp-empty-state{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:2px dashed #dee2e6;border:2px dashed var(--color-border,#dee2e6);border-radius:8px;color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-style:italic;padding:2rem 1rem;text-align:center}.sdp-attendees-list{display:flex;flex-direction:column;gap:1rem}.sdp-attendee-card{align-items:center;animation:sdp-fadeInUp .3s ease;background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000000d;box-shadow:0 2px 4px var(--color-shadow,#0000000d);display:flex;justify-content:space-between;padding:1rem;transition:all .2s ease}.sdp-attendee-card:hover{box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--color-shadow,#0000001a);transform:translateY(-1px)}@keyframes sdp-fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sdp-attendee-info{align-items:center;display:flex;flex:1 1;gap:1rem}.sdp-attendee-photo{flex-shrink:0}.sdp-photo-img{object-fit:cover}.sdp-photo-img,.sdp-photo-placeholder{border:2px solid #e9ecef;border:2px solid var(--color-border-light,#e9ecef);border-radius:50%;height:50px;width:50px}.sdp-photo-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:1.2rem;font-weight:700;justify-content:center}.sdp-attendee-details h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;margin:0 0 .25rem}.sdp-attendee-metadata{display:flex;flex-direction:column;gap:.15rem}.sdp-attendee-enrollment,.sdp-attendee-graduation{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-size:.85rem;margin:0}.sdp-attendee-enrollment strong,.sdp-attendee-graduation strong{color:#495057;color:var(--color-text-secondary,#495057)}.sdp-attendee-actions{align-items:center;display:flex;gap:.5rem}@media (max-width:768px){.sdp-attendee-card{align-items:flex-start;flex-direction:column;gap:1rem}.sdp-attendee-info{width:100%}.sdp-attendee-actions{justify-content:flex-end;width:100%}}@media (max-width:576px){.sdp-attendee-info{align-items:center;flex-direction:column;gap:.5rem;text-align:center}.sdp-attendee-actions{justify-content:center}}.sdp-certificate-actions,.sdp-certificate-btn{display:flex;gap:.5rem}.sdp-certificate-btn{align-items:center;background:#28a745;background:var(--color-success,#28a745);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.sdp-certificate-btn:hover:not(:disabled){background:#218838;transform:scale(1.02)}.sdp-certificate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.sdp-bulk-certificate-btn{background:#007bff;background:var(--color-primary,#007bff)}.sdp-bulk-certificate-btn:hover:not(:disabled){background:#0056b3}.sdp-individual-certificate-btn,.sdp-remove-btn{justify-content:center;min-width:40px;padding:.4rem .8rem}.sdp-remove-btn{align-items:center;background:#dc3545;background:var(--color-danger,#dc3545);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;transition:all .2s ease}.sdp-remove-btn:hover{background:#c82333;transform:scale(1.05)}@media (max-width:768px){.sdp-certificate-actions{flex-direction:column;gap:.5rem;width:100%}.sdp-bulk-certificate-btn{justify-content:center;width:100%}}.sdp-bulk-progress-container{background:#fff;background:var(--color-bg-secondary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;margin-bottom:1rem;padding:1rem}.sdp-bulk-progress-info{margin-bottom:.75rem}.sdp-bulk-progress-info strong{color:#333;color:var(--color-text-primary,#333)}.sdp-bulk-progress-info p{color:#666;color:var(--color-text-secondary,#666);font-size:.9rem;margin:.25rem 0}.sdp-progress-bar{background:#e9ecef;background:var(--color-bg-tertiary,#e9ecef);border-radius:6px;box-shadow:inset 0 1px 3px #0000001a;box-shadow:inset 0 1px 3px var(--color-shadow,#0000001a);height:12px;overflow:hidden;width:100%}.sdp-progress-fill{background:linear-gradient(90deg,#28a745,#20c997);background:linear-gradient(90deg,var(--color-success,#28a745),#20c997);border-radius:6px;height:100%;position:relative;transition:width .3s ease}.sdp-progress-fill:after{animation:sdp-progressAnimation 1s linear infinite;background-image:linear-gradient(-45deg,#fff3 25%,#0000 0,#0000 50%,#fff3 0,#fff3 75%,#0000 0,#0000);background-size:20px 20px;bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes sdp-progressAnimation{0%{background-position:0 0}to{background-position:20px 20px}}@media (hover:none) and (pointer:coarse){.sdp-certificate-btn,.sdp-remove-btn{font-size:1rem;min-height:44px;min-width:44px}.sdp-back-btn,.sdp-btn-add{min-height:44px;padding:.75rem 1rem}.sdp-select{font-size:16px;padding:.75rem}}@media print{.sdp-attendee-actions,.sdp-attendees-controls,.sdp-back-container,.sdp-certificate-actions,.sdp-info-banner{display:none!important}.sdp-attendee-card,.sdp-panel{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}}@media (prefers-contrast:high){.sdp-attendee-card,.sdp-back-btn,.sdp-btn-add,.sdp-certificate-btn,.sdp-panel,.sdp-remove-btn,.sdp-select{border:2px solid #000}.sdp-photo-img,.sdp-photo-placeholder{border-color:#000}}@media (prefers-reduced-motion:reduce){.sdp-loading-spinner{animation:none}.sdp-attendee-card{animation:none;transition:none}.sdp-attendee-card:hover{transform:none}.sdp-back-btn,.sdp-btn-add,.sdp-certificate-btn,.sdp-remove-btn{transition:none}.sdp-certificate-btn:hover:not(:disabled),.sdp-remove-btn:hover{transform:none}.sdp-success-msg{animation:none}.sdp-progress-fill{transition:none}.sdp-progress-fill:after{animation:none}}body[data-theme=dark] .sdp-container{background:var(--color-bg-tertiary)}body[data-theme=dark] .sdp-panel{background:var(--color-bg-secondary)}body[data-theme=dark] .sdp-attendee-card{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .sdp-temario-content{background:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .sdp-bulk-progress-container,body[data-theme=dark] .sdp-empty-state{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .sdp-progress-bar{background:var(--color-bg-tertiary)}body[data-theme=dark] .sdp-select{border-color:var(--color-border)}body[data-theme=dark] .sdp-select,body[data-theme=dark] .sdp-select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .sdp-info-banner{background-color:var(--color-info-light);border-color:var(--color-border);color:var(--color-text-primary)}.sdp-attendee-card:focus-within,.sdp-back-btn:focus,.sdp-btn-add:focus,.sdp-certificate-btn:focus,.sdp-remove-btn:focus,.sdp-select:focus{outline:2px solid #28a745;outline:2px solid var(--color-success,#28a745);outline-offset:2px}.modal-overlay{background:var(--color-overlay);bottom:0;left:0;right:0;top:0;z-index:1000}.modal-content{background:var(--color-bg-primary);border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:500px;overflow-y:auto}.modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.5rem 0}.modal-header h2{color:var(--color-text-primary);font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:none;border-radius:4px;color:var(--color-text-tertiary);font-size:1.5rem;height:2rem;padding:0;transition:background-color .2s,color .2s;width:2rem}.modal-close:hover{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.modal-close:disabled{cursor:not-allowed;opacity:.5}.modal-form{padding:0 1.5rem 1.5rem}.form-group{margin-bottom:1rem}.form-group label{color:var(--color-text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:var(--color-bg-primary);border:1px solid var(--color-border-dark);border-radius:4px;font-size:.9rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 .2rem #007bff40;outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--color-border-light);cursor:not-allowed;opacity:1}.form-group textarea{min-height:80px;resize:vertical}.required{color:#dc3545;font-weight:700}.readonly-field{background:var(--color-bg-tertiary);border:1px solid var(--color-border-dark);color:var(--color-text-tertiary);font-weight:500}.error-msg,.readonly-field{border-radius:4px;font-size:.9rem;padding:.75rem}.error-msg{background:var(--color-danger-light);border:1px solid #f5c6cb;color:#721c24}.success-msg{background:var(--color-success-light);border:1px solid #c3e6cb;border-radius:4px;color:#155724;font-size:.9rem;padding:.75rem}.modal-actions{border-top:1px solid var(--color-border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}.modal-actions button{border:1px solid #0000;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;min-width:100px;padding:.75rem 1.5rem;transition:all .2s}.cancel-btn{background:#6c757d;border-color:var(--color-text-tertiary);color:#fff}.cancel-btn:hover:not(:disabled){background:#5a6268;border-color:#545b62}.submit-btn{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.submit-btn:hover:not(:disabled){background:#0056b3;border-color:#004085}.cancel-btn:disabled,.submit-btn:disabled{cursor:not-allowed;opacity:.65}.form-group input.invalid,.form-group select.invalid,.form-group textarea.invalid{border-color:#dc3545}.form-group input.invalid:focus,.form-group select.invalid:focus,.form-group textarea.invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem #dc354540}.field-error{color:#dc3545;font-size:.8rem;margin-top:.25rem}.loading-spinner{border:2px solid #f3f3f3;display:inline-block;height:1rem;margin-right:.5rem;width:1rem}@media (max-width:768px){.modal-overlay{padding:.5rem}.modal-content{max-height:95vh}.modal-header{margin-bottom:1rem;padding:1rem 1rem 0}.modal-form{padding:0 1rem 1rem}.modal-actions{flex-direction:column-reverse;gap:.5rem}.modal-actions button{width:100%}}@media (max-width:576px){.modal-overlay{padding:.25rem}.modal-header{padding:.75rem .75rem 0}.modal-form{padding:0 .75rem .75rem}.form-group input,.form-group select,.form-group textarea{padding:.625rem}}@media print{.modal-overlay{background:none;padding:0;position:static}.modal-content{box-shadow:none;max-height:none;overflow:visible}.modal-header{border-bottom:2px solid #000}.modal-actions,.modal-close{display:none}}@media (prefers-contrast:high){.form-group input,.form-group select,.form-group textarea,.modal-content,.readonly-field{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.form-group input,.form-group select,.form-group textarea,.modal-actions button{transition:none}.loading-spinner{animation:none}}.tnp-container{background:#f7f9fc;background:var(--color-bg-tertiary,#f7f9fc);font-family:Roboto,sans-serif;min-height:100vh;padding:1rem 2rem}@media (max-width:768px){.tnp-container{padding:1rem}}.tnp-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.tnp-loading-spinner{animation:tnp-spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid #ffc107;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-warning,#ffc107);height:40px;width:40px}@keyframes tnp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.tnp-error-msg{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:6px;color:#dc3545;color:var(--color-danger,#dc3545);margin-bottom:1rem;padding:1rem}.tnp-error-msg strong{display:block;margin-bottom:.5rem}.tnp-error-actions{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.tnp-back-btn{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s ease}.tnp-back-btn:hover:not(:disabled){background:#5a6268}.tnp-retry-btn{background:#ffc107;background:var(--color-warning,#ffc107);color:#212529}.tnp-retry-btn:hover:not(:disabled){background:#e0a800}.tnp-header{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.tnp-header,.tnp-header h1{align-items:center;display:flex}.tnp-header h1{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.75rem;gap:.5rem;margin:0}.tnp-header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.tnp-admin-badge{font-size:1.2rem;margin-left:.5rem}@media (max-width:576px){.tnp-header{align-items:stretch;flex-direction:column}.tnp-header h1{font-size:1.5rem;justify-content:center}.tnp-header-controls{flex-direction:column;width:100%}}.tnp-search{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:1rem;min-width:250px;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease}.tnp-search:focus{border-color:#ffc107;border-color:var(--color-warning,#ffc107);box-shadow:0 0 0 3px #ffc10726;outline:none}.tnp-search::placeholder{color:#999;color:var(--color-text-tertiary,#999)}@media (max-width:576px){.tnp-search{min-width:0;min-width:auto;width:100%}}.tnp-btn-create{background:#ffc107;background:var(--color-warning,#ffc107);border:none;border-radius:6px;color:#212529;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease;white-space:nowrap}.tnp-btn-create:hover:not(:disabled){background:#e0a800}.tnp-btn-create:disabled{cursor:not-allowed;opacity:.6}@media (max-width:576px){.tnp-btn-create{text-align:center;width:100%}}.tnp-info-banner{align-items:center;background-color:#fff3cd;background-color:var(--color-warning-light,#fff3cd);border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);border-radius:6px;color:#856404;color:var(--color-text-primary,#856404);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.tnp-info-banner-admin{background-color:#e8f4f8;background-color:var(--color-info-light,#e8f4f8);border-color:#17a2b8;border-color:var(--color-info,#17a2b8);color:#0c5460;color:var(--color-info-dark,#0c5460)}.tnp-info-icon{flex-shrink:0;font-size:1.1rem}.tnp-info{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa);border-left:4px solid #ffc107;border-left:4px solid var(--color-warning,#ffc107);border-radius:6px;margin-bottom:1rem;padding:.75rem}.tnp-info p{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem;margin:0}.tnp-info p+p{margin-top:.25rem}.tnp-empty-state{color:#6c757d;color:var(--color-text-tertiary,#6c757d);padding:3rem;text-align:center}.tnp-empty-state h3{color:#495057;color:var(--color-text-secondary,#495057);margin:0 0 .5rem}.tnp-empty-state p{font-size:.95rem;margin:0}.tnp-mobile-only{display:block}.tnp-desktop-only{display:none}@media (min-width:769px){.tnp-mobile-only{display:none!important}.tnp-desktop-only{display:block!important}}@media (max-width:768px){.tnp-mobile-only{display:block!important}.tnp-desktop-only{display:none!important}}.tnp-mobile-view{display:flex;flex-direction:column;gap:1rem}.tnp-card{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);padding:1rem;transition:box-shadow .2s ease,transform .2s ease}.tnp-card:hover{box-shadow:0 4px 8px #00000026;box-shadow:0 4px 8px var(--color-shadow,#00000026);transform:translateY(-1px)}.tnp-card-header{gap:.5rem;justify-content:space-between;margin-bottom:.75rem}.tnp-card-header,.tnp-card-title{align-items:flex-start;display:flex}.tnp-card-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);flex:1 1;flex-direction:column;font-size:1.1rem;gap:.25rem;margin:0}.tnp-school-badge{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:12px;color:#333;color:var(--color-text-primary,#333);display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.tnp-card-actions{display:flex;gap:.5rem}.tnp-card-body{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem}.tnp-card-detail{margin-bottom:.5rem}.tnp-card-detail strong{color:#333;color:var(--color-text-primary,#333)}@media (max-width:768px){.tnp-card-title{align-items:center;text-align:center}}.tnp-registration-status{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:500;margin-left:.25rem;padding:.25rem .5rem;white-space:nowrap}.tnp-status-open{background:#d4edda;background:var(--color-success-light,#d4edda);border:1px solid #28a745;border:1px solid var(--color-success,#28a745);color:#155724;color:var(--color-success-dark,#155724)}.tnp-status-closed{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border:1px solid #dc3545;border:1px solid var(--color-danger,#dc3545);color:#721c24;color:var(--color-danger-dark,#721c24)}.tnp-status-not-started{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);color:#856404;color:var(--color-warning-dark,#856404)}.tnp-status-no-dates{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);color:#6c757d;color:var(--color-text-tertiary,#6c757d)}.tnp-card .tnp-registration-status{display:inline-block;margin-left:0;margin-top:.25rem}.tnp-action-buttons{display:flex;gap:.5rem}.tnp-delete-btn,.tnp-edit-btn,.tnp-view-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;min-width:36px;padding:.5rem;transition:background-color .2s ease}.tnp-view-btn{color:#ffc107;color:var(--color-warning,#ffc107)}.tnp-view-btn:hover:not(:disabled){background-color:#fff3cd;background-color:var(--color-warning-light,#fff3cd)}.tnp-edit-btn{color:#007bff;color:var(--color-primary,#007bff)}.tnp-edit-btn:hover:not(:disabled){background-color:#e3f2fd;background-color:var(--color-primary-light,#e3f2fd)}.tnp-delete-btn{color:#dc3545;color:var(--color-danger,#dc3545)}.tnp-delete-btn:hover:not(:disabled){background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da)}.tnp-delete-btn:disabled,.tnp-edit-btn:disabled,.tnp-view-btn:disabled{cursor:not-allowed;opacity:.5}.tnp-table-wrapper{border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);overflow-x:auto}.tnp-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;width:100%}.tnp-table thead{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa)}.tnp-table th{border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);color:#333;color:var(--color-text-primary,#333);font-weight:600;padding:1rem;text-align:left}.tnp-table td{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);color:#555;color:var(--color-text-secondary,#555);padding:1rem}.tnp-table tbody tr:hover{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa)}.tnp-table tbody tr:last-child td{border-bottom:none}.tnp-school-name{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:6px;color:#333;color:var(--color-text-primary,#333);font-size:.85rem;font-weight:500;padding:.25rem .5rem;white-space:nowrap}.tnp-table td:nth-child(5),.tnp-table th:nth-child(5){min-width:120px}@media (hover:none) and (pointer:coarse){.tnp-delete-btn,.tnp-edit-btn,.tnp-view-btn{font-size:1.2rem;height:44px;min-width:44px;padding:.75rem}.tnp-back-btn,.tnp-btn-create{min-height:44px;padding:1rem 1.5rem}.tnp-search{font-size:16px;padding:1rem}}@media print{:root,body,body[data-theme=dark]{--color-bg-primary:#fff!important;--color-bg-secondary:#f7f9fc!important;--color-bg-tertiary:#f1f3f5!important;--color-text-primary:#2c3e50!important;--color-text-secondary:#495057!important;--color-text-tertiary:#6c757d!important;--color-border:#dee2e6!important}.tnp-mobile-only{display:none!important}.tnp-desktop-only{display:block!important}.tnp-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.tnp-action-buttons,.tnp-back-btn,.tnp-btn-create,.tnp-card-actions,.tnp-header-controls,.tnp-info-banner,.tnp-search{display:none!important}.tnp-table{box-shadow:none}.tnp-admin-badge,.tnp-school-badge{background:#f8f9fa!important;border:1px solid #000!important;color:#000!important}*{background-color:#fff!important;color:#2c3e50!important}}@media (prefers-contrast:high){.tnp-card{border:2px solid #000}.tnp-delete-btn,.tnp-edit-btn,.tnp-view-btn{border:2px solid}.tnp-search{border:2px solid #000}.tnp-table td,.tnp-table th{border:1px solid #000}.tnp-info{border-left-color:var(--color-text-primary)}.tnp-admin-badge,.tnp-school-badge,.tnp-school-name{border:2px solid var(--color-text-primary)}.tnp-registration-status{border-width:2px}}@media (prefers-reduced-motion:reduce){.tnp-loading-spinner{animation:none}.tnp-card{transition:none}.tnp-card:hover{transform:none}.tnp-back-btn,.tnp-btn-create,.tnp-delete-btn,.tnp-edit-btn,.tnp-search,.tnp-view-btn{transition:none}}body[data-theme=dark] .tnp-container{background:var(--color-bg-tertiary)}body[data-theme=dark] .tnp-card{border-color:var(--color-border)}body[data-theme=dark] .tnp-card,body[data-theme=dark] .tnp-table{background:var(--color-bg-primary)}body[data-theme=dark] .tnp-table thead{background:var(--color-bg-secondary)}body[data-theme=dark] .tnp-info,body[data-theme=dark] .tnp-search{background-color:var(--color-bg-secondary)}body[data-theme=dark] .tnp-search{border-color:var(--color-border);color:var(--color-text-primary)}body[data-theme=dark] .tnp-info-banner{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-text-primary)}body[data-theme=dark] .tnp-info-banner-admin{background-color:var(--color-info-light);border-color:var(--color-info)}body[data-theme=dark] .tnp-school-badge,body[data-theme=dark] .tnp-school-name{background-color:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .tnp-view-btn:hover:not(:disabled){background-color:var(--color-warning-light)}body[data-theme=dark] .tnp-edit-btn:hover:not(:disabled){background-color:var(--color-primary-light)}body[data-theme=dark] .tnp-delete-btn:hover:not(:disabled){background-color:var(--color-danger-light)}body[data-theme=dark] .tnp-status-open{background-color:var(--color-success-light);color:var(--color-text-primary)}body[data-theme=dark] .tnp-status-closed{background-color:var(--color-danger-light);color:var(--color-text-primary)}body[data-theme=dark] .tnp-status-not-started{background-color:var(--color-warning-light);color:var(--color-text-primary)}body[data-theme=dark] .tnp-status-no-dates{background-color:var(--color-bg-secondary);color:var(--color-text-tertiary)}.tnp-admin-badge:focus,.tnp-back-btn:focus,.tnp-btn-create:focus,.tnp-card:focus-within,.tnp-delete-btn:focus,.tnp-edit-btn:focus,.tnp-school-badge:focus,.tnp-school-name:focus,.tnp-search:focus,.tnp-view-btn:focus{outline:2px solid #ffc107;outline:2px solid var(--color-warning,#ffc107);outline-offset:2px}.tdp-container{background:#f7f9fc;background:var(--color-bg-tertiary,#f7f9fc);font-family:Roboto,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}@media (min-width:768px){.tdp-container{padding:2rem}}@media (max-width:480px){.tdp-container{padding:.5rem}}.tdp-loading{align-items:center;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.tdp-loading-spinner{animation:tdp-spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid #ffc107;border:4px solid var(--color-border-light,#f3f3f3);border-radius:50%;border-top-color:var(--color-warning,#ffc107);height:40px;width:40px}@keyframes tdp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.tdp-error-msg{background-color:#f8d7da;background-color:var(--color-danger-light,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-danger-border,#f5c6cb);border-radius:6px;margin-bottom:1rem;padding:1rem}.tdp-error-msg strong{display:block;margin-bottom:.5rem}.tdp-success-msg{align-items:center;animation:tdp-slideInDown .3s ease-out;background-color:#d4edda;background-color:var(--color-success-light,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);border-radius:6px;display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.tdp-success-msg:before{content:"✓";font-size:1.1rem}.tdp-info-banner{align-items:center;background-color:#fff3cd;background-color:var(--color-warning-light,#fff3cd);border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);border-radius:6px;color:#856404;color:var(--color-warning-dark,#856404);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.tdp-info-icon{font-size:1.1rem}@keyframes tdp-slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tdp-error-actions{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.tdp-back-container{margin-bottom:1rem}.tdp-back-btn{align-items:center;background:#6c757d;background:var(--color-secondary,#6c757d);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s ease}.tdp-back-btn:hover:not(:disabled){background:#5a6268}.tdp-retry-btn{background:#ffc107;background:var(--color-warning,#ffc107);color:#212529}.tdp-retry-btn:hover:not(:disabled){background:#e0a800}.tdp-tabs{border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem}.tdp-tab{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:6px 6px 0 0;color:#495057;color:var(--color-text-secondary,#495057);cursor:pointer;font-size:.9rem;padding:.75rem 1rem;transition:all .2s ease}.tdp-tab:hover:not(.tdp-tab-active){background:#e9ecef;background:var(--color-bg-tertiary,#e9ecef)}.tdp-tab-active{background:#ffc107;background:var(--color-warning,#ffc107);border-color:#ffc107;border-color:var(--color-warning,#ffc107);color:#212529;font-weight:600}@media (max-width:576px){.tdp-tabs{flex-direction:column}.tdp-tab{border-radius:6px;text-align:center}}.tdp-panel{background:#fff;background:var(--color-bg-secondary,#fff);border-radius:8px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--color-shadow,#0000001a);margin-bottom:1.5rem;padding:1.5rem}.tdp-panel h2,.tdp-panel h3{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin-bottom:1rem;margin-top:0}.tdp-panel h2{font-size:1.5rem}.tdp-panel h3{font-size:1.25rem}@media (max-width:576px){.tdp-panel{padding:1rem}.tdp-panel h2{font-size:1.25rem}.tdp-panel h3{font-size:1.1rem}}.tdp-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.tdp-info-grid p{color:#495057;color:var(--color-text-secondary,#495057);margin:.5rem 0}.tdp-info-grid strong{color:#2c3e50;color:var(--color-text-primary,#2c3e50)}.tdp-registration-status{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;margin-left:.5rem;padding:.25rem .5rem;white-space:nowrap}.tdp-status-open{background:#d4edda;background:var(--color-success-light,#d4edda);border:1px solid #28a745;border:1px solid var(--color-success,#28a745);color:#155724;color:var(--color-success-dark,#155724)}.tdp-status-closed{background:#f8d7da;background:var(--color-danger-light,#f8d7da);border:1px solid #dc3545;border:1px solid var(--color-danger,#dc3545);color:#721c24;color:var(--color-danger-dark,#721c24)}.tdp-status-not-started{background:#fff3cd;background:var(--color-warning-light,#fff3cd);border:1px solid #ffc107;border:1px solid var(--color-warning,#ffc107);color:#856404;color:var(--color-warning-dark,#856404)}.tdp-status-no-dates{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);color:#6c757d;color:var(--color-text-tertiary,#6c757d)}.tdp-description-section{margin-top:1rem}.tdp-description-section h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin:0 0 .5rem}.tdp-description-content{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #e9ecef;border:1px solid var(--color-border-light,#e9ecef);border-radius:6px;color:#495057;color:var(--color-text-secondary,#495057);padding:1rem;white-space:pre-wrap}.tdp-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1.5rem}.tdp-summary-card{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;padding:1rem}.tdp-summary-card h4{border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--color-border,#dee2e6);color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1rem;margin:0 0 .75rem;padding-bottom:.5rem}.tdp-summary-card p{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;margin:.25rem 0}.tdp-section-info{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa);border-left:3px solid #ffc107;border-left:3px solid var(--color-warning,#ffc107);border-radius:4px;margin-bottom:1rem;padding:.5rem}.tdp-section-info p{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;margin:0}.tdp-controls{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tdp-select{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;color:#333;color:var(--color-text-primary,#333);flex:1 1;font-size:.95rem;min-width:200px;padding:.5rem;transition:border-color .2s ease}.tdp-select:focus{border-color:#ffc107;border-color:var(--color-warning,#ffc107);box-shadow:0 0 0 2px #ffc10726;outline:none}.tdp-btn-add{background:#ffc107;background:var(--color-warning,#ffc107);border:none;border-radius:4px;color:#212529;cursor:pointer;font-size:.95rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s ease;white-space:nowrap}.tdp-btn-add:hover:not(:disabled){background:#e0a800}.tdp-btn-add:disabled{background:#6c757d;background:var(--color-secondary,#6c757d);color:#fff;cursor:not-allowed}@media (max-width:576px){.tdp-controls{flex-direction:column}.tdp-select{min-width:0;min-width:auto;width:100%}.tdp-btn-add{width:100%}}.tdp-pos-select{background-color:#fff;background-color:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:4px;color:#333;color:var(--color-text-primary,#333);font-size:.85rem;margin-left:.5rem;padding:.35rem .5rem}.tdp-pos-select:focus{border-color:#ffc107;border-color:var(--color-warning,#ffc107);outline:none}.tdp-mobile-only{display:block}.tdp-desktop-only{display:none}@media (min-width:769px){.tdp-mobile-only{display:none!important}.tdp-desktop-only{display:block!important}}@media (max-width:768px){.tdp-mobile-only{display:block!important}.tdp-desktop-only{display:none!important}}.tdp-mobile-list{display:flex;flex-direction:column;gap:1rem}.tdp-person-card{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000000d;box-shadow:0 2px 4px var(--color-shadow,#0000000d);padding:1rem;transition:box-shadow .2s ease}.tdp-person-card:hover{box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--color-shadow,#0000001a)}.tdp-person-card-header{align-items:flex-start;display:flex;gap:1rem}.tdp-person-photo{flex-shrink:0}.tdp-person-photo img{border:2px solid #dee2e6;border:2px solid var(--color-border,#dee2e6);border-radius:8px;height:60px;object-fit:cover;width:60px}.tdp-no-photo{align-items:center;background:#dee2e6;background:var(--color-bg-tertiary,#dee2e6);border-radius:8px;color:#6c757d;color:var(--color-text-tertiary,#6c757d);display:flex;font-weight:500;height:60px;justify-content:center;width:60px}.tdp-person-info{flex:1 1}.tdp-person-info h4{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;margin:0 0 .5rem}.tdp-person-info p{color:#495057;color:var(--color-text-secondary,#495057);font-size:.9rem;margin:.25rem 0}.tdp-person-info strong{color:#2c3e50;color:var(--color-text-primary,#2c3e50)}.tdp-delete-btn{align-items:center;background:#dc3545;background:var(--color-danger,#dc3545);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:40px;justify-content:center;min-width:40px;padding:.5rem;transition:all .2s ease}.tdp-delete-btn:hover:not(:disabled){background:#c82333;transform:scale(1.05)}.tdp-delete-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.tdp-table-wrapper{border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);overflow-x:auto}.tdp-table{background:#fff;background:var(--color-bg-primary,#fff);border-collapse:collapse;width:100%}.tdp-table thead{background:#f8f9fa;background:var(--color-bg-secondary,#f8f9fa)}.tdp-table th{border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);color:#333;color:var(--color-text-primary,#333);font-weight:600;padding:1rem;text-align:left}.tdp-table td{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);color:#555;color:var(--color-text-secondary,#555);padding:1rem}.tdp-table tbody tr:hover{background-color:#f8f9fa;background-color:var(--color-bg-tertiary,#f8f9fa)}.tdp-table tbody tr:last-child td{border-bottom:none}.tdp-table tbody tr:nth-child(2n){background-color:#00000005}.tdp-thumb{border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:6px;height:40px;object-fit:cover;width:40px}.tdp-empty-cell,.tdp-empty-state{color:#6c757d;color:var(--color-text-tertiary,#6c757d);font-style:italic;text-align:center}.tdp-empty-state{background:#f8f9fa;background:var(--color-bg-tertiary,#f8f9fa);border:2px dashed #dee2e6;border:2px dashed var(--color-border,#dee2e6);border-radius:8px;padding:2rem 1rem}.tdp-category-section{margin-bottom:2rem}.tdp-category-title{border-bottom:2px solid #dee2e6;border-bottom:2px solid var(--color-border,#dee2e6);color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin-bottom:1rem;padding-bottom:.5rem}@media (hover:none) and (pointer:coarse){.tdp-delete-btn{font-size:1.2rem;height:44px;min-width:44px}.tdp-back-btn,.tdp-btn-add,.tdp-tab{min-height:44px;padding:.75rem 1rem}.tdp-pos-select,.tdp-select{font-size:16px;padding:.75rem}}@media print{.tdp-back-container,.tdp-controls,.tdp-delete-btn,.tdp-info-banner,.tdp-mobile-only,.tdp-tabs{display:none!important}.tdp-desktop-only{display:block!important}.tdp-panel{border:1px solid #ddd;break-inside:avoid;page-break-inside:avoid}.tdp-panel,.tdp-table{box-shadow:none}}@media (prefers-contrast:high){.tdp-back-btn,.tdp-btn-add,.tdp-delete-btn,.tdp-panel,.tdp-person-card,.tdp-pos-select,.tdp-select,.tdp-tab{border:2px solid #000}.tdp-table td,.tdp-table th{border:1px solid #000}.tdp-registration-status{border-width:2px}}@media (prefers-reduced-motion:reduce){.tdp-loading-spinner{animation:none}.tdp-back-btn,.tdp-btn-add,.tdp-delete-btn,.tdp-person-card,.tdp-tab{transition:none}.tdp-delete-btn:hover:not(:disabled){transform:none}.tdp-success-msg{animation:none}}body[data-theme=dark] .tdp-container{background:var(--color-bg-tertiary)}body[data-theme=dark] .tdp-panel{background:var(--color-bg-secondary)}body[data-theme=dark] .tdp-person-card{background:var(--color-bg-primary);border-color:var(--color-border)}body[data-theme=dark] .tdp-table{background:var(--color-bg-primary)}body[data-theme=dark] .tdp-table thead{background:var(--color-bg-secondary)}body[data-theme=dark] .tdp-description-content,body[data-theme=dark] .tdp-section-info,body[data-theme=dark] .tdp-summary-card{background-color:var(--color-bg-tertiary);border-color:var(--color-border)}body[data-theme=dark] .tdp-empty-state,body[data-theme=dark] .tdp-tab{background:var(--color-bg-secondary);border-color:var(--color-border)}body[data-theme=dark] .tdp-tab{color:var(--color-text-primary)}body[data-theme=dark] .tdp-tab:hover:not(.tdp-tab-active){background:var(--color-bg-tertiary)}body[data-theme=dark] .tdp-tab-active{background:var(--color-warning);color:#212529}body[data-theme=dark] .tdp-pos-select,body[data-theme=dark] .tdp-select{border-color:var(--color-border)}body[data-theme=dark] .tdp-pos-select,body[data-theme=dark] .tdp-pos-select option,body[data-theme=dark] .tdp-select,body[data-theme=dark] .tdp-select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}body[data-theme=dark] .tdp-info-banner{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-text-primary)}body[data-theme=dark] .tdp-no-photo{background:var(--color-bg-secondary)}body[data-theme=dark] .tdp-status-open{background-color:var(--color-success-light);color:var(--color-text-primary)}body[data-theme=dark] .tdp-status-closed{background-color:var(--color-danger-light);color:var(--color-text-primary)}body[data-theme=dark] .tdp-status-not-started{background-color:var(--color-warning-light);color:var(--color-text-primary)}body[data-theme=dark] .tdp-status-no-dates{background-color:var(--color-bg-secondary);color:var(--color-text-tertiary)}.tdp-back-btn:focus,.tdp-btn-add:focus,.tdp-delete-btn:focus,.tdp-person-card:focus-within,.tdp-pos-select:focus,.tdp-select:focus,.tdp-tab:focus{outline:2px solid #ffc107;outline:2px solid var(--color-warning,#ffc107);outline-offset:2px}.school-billing-container{font-family:Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:1rem}@media (min-width:768px){.school-billing-container{padding:2rem}}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:2rem}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#007bff;height:40px;margin-bottom:1rem;width:40px}.loading-state p{color:var(--color-text-tertiary);font-size:1.1rem;margin:0}.auth-required{align-items:center;display:flex;flex-direction:column;justify-content:center;margin:0 auto;max-width:500px;min-height:60vh;padding:2rem;text-align:center}.auth-required h2{color:var(--color-text-primary);font-size:1.8rem;margin-bottom:1rem}.auth-required p{color:var(--color-text-tertiary);font-size:1.1rem;line-height:1.5;margin-bottom:2rem}.auth-actions{gap:1rem}.access-denied,.auth-actions{display:flex;justify-content:center}.access-denied{align-items:center;flex-direction:column;margin:0 auto;max-width:600px;min-height:60vh;padding:2rem;text-align:center}.access-denied h2{color:#dc3545;font-size:1.8rem;margin-bottom:1rem}.access-denied p{color:var(--color-text-tertiary);font-size:1.1rem;line-height:1.5;margin-bottom:1rem}.user-info{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;margin-bottom:2rem;padding:1rem}.access-denied-actions{display:flex;gap:1rem;justify-content:center}.error-banner{align-items:center;animation:slideDown .3s ease-out;background:var(--color-danger-light);border:1px solid #f5c6cb;border-radius:6px;color:#721c24;display:flex;justify-content:space-between;margin:1rem;padding:1rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-close{align-items:center;background:none;border:none;border-radius:50%;color:#721c24;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;margin-left:1rem;padding:0;transition:background .2s ease;width:30px}.error-close:hover{background:#721c241a}.btn-primary{background:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .2s ease}.btn-primary:hover{background:#0056b3;transform:translateY(-1px)}.btn-secondary{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .2s ease}.btn-secondary:hover{background:#5a6268;transform:translateY(-1px)}.btn-danger{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .2s ease}.btn-danger:hover{background:#c82333;transform:translateY(-1px)}@media (max-width:768px){.school-billing-container{padding:.5rem}.access-denied,.auth-required{min-height:50vh;padding:1rem}.access-denied h2,.auth-required h2{font-size:1.5rem}.access-denied-actions,.auth-actions{align-items:center;flex-direction:column}.btn-danger,.btn-primary,.btn-secondary{max-width:250px;width:100%}.error-banner{flex-direction:column;gap:.5rem;margin:.5rem;padding:.75rem;text-align:center}.error-close{align-self:flex-end;margin:0}}@media (prefers-reduced-motion:reduce){.error-banner,.loading-spinner{animation:none}.btn-danger:hover,.btn-primary:hover,.btn-secondary:hover{transform:none}}.btn-danger:focus,.btn-primary:focus,.btn-secondary:focus,.error-close:focus{outline:2px solid #007bff;outline-offset:2px}@media (prefers-contrast:high){.access-denied,.auth-required{border:2px solid #000}.error-banner{border:2px solid #721c24}}.clp-container{padding:1rem 2rem}.clp-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.clp-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.75rem;margin:0}.clp-loading-container{color:#666;color:var(--color-text-secondary,#666);padding:2rem;text-align:center}.clp-loading-text{margin-bottom:1rem}.clp-loading-icon{font-size:1.5rem}.clp-btn-primary{background:#007bff;background:var(--color-primary,#007bff);border:none;border-radius:6px;color:#fff;color:var(--color-text-on-primary,#fff);cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.clp-btn-primary:hover{background:#0069d9;background:var(--color-primary-hover,#0069d9)}.clp-btn-mt{margin-top:1rem}.clp-filter-container{margin-bottom:1.5rem}.clp-filter-input{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #ced4da;border:1px solid var(--color-border,#ced4da);border-radius:6px;color:#212529;color:var(--color-text-primary,#212529);font-size:1rem;padding:.75rem;width:100%}.clp-filter-input::placeholder{color:#6c757d;color:var(--color-text-muted,#6c757d)}.clp-filter-input:focus{border-color:#007bff;border-color:var(--color-primary,#007bff);box-shadow:0 0 0 2px #007bff40;box-shadow:0 0 0 2px var(--color-primary-alpha,#007bff40);outline:none}.clp-error-msg{background:#f8d7da;background:var(--color-error-bg,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-error-border,#f5c6cb);border-radius:6px;color:#dc3545;color:var(--color-error-text,#dc3545);margin-bottom:1rem;padding:1rem}.clp-empty-state{color:#6c757d;color:var(--color-text-secondary,#6c757d);padding:3rem;text-align:center}.clp-empty-icon{font-size:3rem;margin-bottom:1rem}.clp-empty-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);margin:0 0 .5rem}.clp-empty-text{margin:0}.clp-mobile-only{display:block}.clp-desktop-only{display:none}@media (min-width:769px){.clp-mobile-only{display:none!important}.clp-desktop-only{display:block!important}}@media (max-width:768px){.clp-mobile-only{display:block!important}.clp-desktop-only{display:none!important}}.clp-mobile-list{display:flex;flex-direction:column;gap:1rem}.clp-card{background:#fff;background:var(--color-bg-primary,#fff);border:1px solid #dee2e6;border:1px solid var(--color-border,#dee2e6);border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--color-shadow,#0000001a);padding:1rem}.clp-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.clp-card-title{color:#2c3e50;color:var(--color-text-primary,#2c3e50);font-size:1.1rem;margin:0}.clp-card-actions{display:flex;gap:.5rem}.clp-card-info{color:#6c757d;color:var(--color-text-secondary,#6c757d);font-size:.9rem}.clp-card-row{margin-bottom:.5rem}.clp-card-row strong{color:#495057;color:var(--color-text-primary,#495057)}.clp-card-description{margin-top:.75rem}.clp-card-description strong{color:#495057;color:var(--color-text-primary,#495057)}.clp-action-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:inline-flex;font-size:1rem;justify-content:center;padding:.25rem;text-decoration:none;transition:background-color .2s ease}.clp-action-btn:hover{background:#0000000d;background:var(--color-bg-hover,#0000000d)}.clp-table-actions{display:flex;gap:.5rem}.clp-schedule-item{color:var(--color-text-primary);display:block;font-size:.85rem;line-height:1.4;padding:.125rem 0}.clp-schedule-item:not(:last-child){border-bottom:1px dotted #dee2e6;border-bottom:1px dotted var(--color-border-light,#dee2e6);margin-bottom:.25rem;padding-bottom:.25rem}.clp-capacity-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.85rem;font-weight:500;padding:.25rem .5rem}.clp-capacity-available{background:#d4edda;background:var(--color-success-bg,#d4edda);border:1px solid #c3e6cb;border:1px solid var(--color-success-border,#c3e6cb);color:#155724;color:var(--color-success-text,#155724)}.clp-capacity-full{background:#f8d7da;background:var(--color-error-bg,#f8d7da);border:1px solid #f5c6cb;border:1px solid var(--color-error-border,#f5c6cb);color:#721c24;color:var(--color-error-text,#721c24)}.clp-capacity-warning{background:#fff3cd;background:var(--color-warning-bg,#fff3cd);border:1px solid #ffeaa7;border:1px solid var(--color-warning-border,#ffeaa7);color:#856404;color:var(--color-warning-text,#856404)}.clp-instructor-count{align-items:center;background:#e3f2fd;background:var(--color-info-bg,#e3f2fd);border:1px solid #bbdefb;border:1px solid var(--color-info-border,#bbdefb);border-radius:12px;color:#1565c0;color:var(--color-info-text,#1565c0);display:inline-flex;font-size:.85rem;font-weight:500;padding:.25rem .5rem}.clp-school-name{color:#495057;color:var(--color-text-secondary,#495057);font-weight:500}.clp-table-wrapper{-webkit-overflow-scrolling:touch;background:#fff;background:var(--color-bg-primary,#fff);border-radius:6px;box-shadow:0 2px 6px #0000001a;box-shadow:0 2px 6px var(--color-shadow,#0000001a);overflow:hidden;overflow-x:auto}.clp-table{border-collapse:collapse;table-layout:fixed;width:100%}.clp-table td,.clp-table th{border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border-light,#eee);font-size:.9rem;min-width:60px;padding:.75rem;text-align:left;vertical-align:middle}.clp-table th{background:var(--color-bg-secondary);font-weight:600;position:relative;-webkit-user-select:none;user-select:none}.clp-table td,.clp-table th{color:var(--color-text-primary)}.clp-table tbody tr:hover{background-color:#f1f3f5;background-color:var(--color-bg-tertiary,#f1f3f5)}.clp-table tbody tr:hover .clp-schedule-item,.clp-table tbody tr:hover .clp-school-name,.clp-table tbody tr:hover td,.clp-table tbody tr:hover td *{color:var(--color-text-primary)}.clp-table tbody tr:hover .clp-capacity-available{color:#155724!important;color:var(--color-success-text,#155724)!important}.clp-table tbody tr:hover .clp-capacity-full{color:#721c24!important;color:var(--color-error-text,#721c24)!important}.clp-table tbody tr:hover .clp-capacity-warning{color:#856404!important;color:var(--color-warning-text,#856404)!important}.clp-table tbody tr:hover .clp-instructor-count{color:#1565c0!important;color:var(--color-info-text,#1565c0)!important}.clp-table td:nth-child(2),.clp-table th:nth-child(2){text-align:center}.clp-table td .clp-schedule-item{white-space:nowrap}@media (max-width:768px){.clp-container{padding:1rem}.clp-header{align-items:stretch;flex-direction:column;gap:1rem}.clp-title{font-size:1.5rem;text-align:center}.clp-btn-primary{text-align:center;width:100%}}@media (max-width:576px){.clp-card,.clp-container{padding:.75rem}.clp-card-title{font-size:1rem}.clp-card-info{font-size:.85rem}.clp-empty-state{padding:2rem 1rem}.clp-empty-icon{font-size:2.5rem}}@media (min-width:1024px){.clp-table td,.clp-table th{font-size:1rem;padding:1rem}}@media (max-width:1200px){.clp-table td,.clp-table th{font-size:.85rem;padding:.6rem .4rem}}@media (max-width:992px){.clp-table{font-size:.8rem}.clp-table td,.clp-table th{padding:.4rem .25rem}}@media (hover:none) and (pointer:coarse){.clp-action-btn{min-height:44px;min-width:44px;padding:.5rem}.clp-btn-primary{min-height:44px;padding:1rem}}@media print{.clp-action-btn,.clp-card-actions,.clp-filter-container,.clp-header button,.clp-mobile-only,.clp-table-actions{display:none!important}.clp-desktop-only{display:block!important}.clp-card{break-inside:avoid;page-break-inside:avoid}.clp-card,.clp-table-wrapper{border:1px solid #ddd;box-shadow:none}}@media (prefers-contrast:high){.clp-btn-primary,.clp-card,.clp-filter-input,.clp-table-wrapper{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.clp-action-btn,.clp-btn-primary,.clp-filter-input{transition:none}}@keyframes clp-pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}@keyframes clp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cdp-container{background:var(--color-bg-secondary);font-family:Roboto,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}@media (min-width:768px){.cdp-container{padding:2rem}}@media (max-width:480px){.cdp-container{padding:.5rem}}.cdp-loading{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.cdp-loading-spinner{animation:cdp-spin 1s linear infinite;border-top:4px solid var(--color-border-light);border:4px solid var(--color-border-light);border-radius:50%;border-top-color:var(--color-primary);height:40px;width:40px}@keyframes cdp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cdp-mobile-only{display:block}.cdp-desktop-only{display:none}@media (min-width:769px){.cdp-mobile-only{display:none!important}.cdp-desktop-only{display:block!important}}@media (max-width:768px){.cdp-mobile-only{display:block!important}.cdp-desktop-only{display:none!important}}.cdp-error-msg{background-color:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:6px;color:var(--color-danger);margin-bottom:1rem;padding:1rem}.cdp-success-msg{background-color:var(--color-success-light);border:1px solid var(--color-success);border-radius:6px;color:var(--color-success);margin-bottom:1rem;padding:1rem}.cdp-info-banner{align-items:center;background-color:var(--color-info-light);border:1px solid var(--color-info);border-radius:6px;color:var(--color-info);display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.cdp-info-banner-warning{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning)}.cdp-info-icon{font-size:1.1rem}.cdp-empty-state{color:var(--color-text-secondary);font-style:italic;padding:2rem 1rem;text-align:center}.cdp-warning-text{color:var(--color-danger);font-weight:700}.cdp-error-actions{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.cdp-nav-back{margin-bottom:1rem}.cdp-back-btn{align-items:center;background:var(--color-bg-tertiary);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s}.cdp-back-btn:hover{background:var(--color-text-secondary)}.cdp-back-btn-success{background:var(--color-success)}.cdp-back-btn-success:hover{background:var(--color-primary-hover)}.cdp-mt-1{margin-top:1rem}.cdp-tabs{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;display:flex;gap:.25rem;margin-bottom:1.5rem;padding:.25rem}.cdp-tab{background:#0000;border:none;border-radius:6px;color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:.75rem 1rem;text-align:center;transition:all .2s ease}.cdp-tab:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.cdp-tab-active{background:var(--color-info);box-shadow:0 2px 4px #17a2b84d;color:#fff}@media (max-width:768px){.cdp-tabs{flex-direction:column}.cdp-tab{text-align:left}}.cdp-panel{background:var(--color-bg-primary);border-radius:8px;box-shadow:0 2px 8px var(--color-shadow);margin-bottom:1.5rem;padding:1.5rem}.cdp-panel-title{font-size:1.5rem}.cdp-panel-subtitle,.cdp-panel-title{color:var(--color-text-primary);margin-bottom:1rem;margin-top:0}.cdp-panel-subtitle{font-size:1.25rem}@media (max-width:576px){.cdp-panel{padding:1rem}.cdp-panel-title{font-size:1.25rem}.cdp-panel-subtitle{font-size:1.1rem}}.cdp-section-info{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;margin-bottom:1rem;padding:.75rem}.cdp-section-info p{color:var(--color-text-primary);font-size:.9rem;margin:.25rem 0}.cdp-section-info p:first-child{margin-top:0}.cdp-section-info p:last-child{margin-bottom:0}.cdp-section-info strong{color:var(--color-text-primary);font-weight:600}.cdp-schedules-section{margin-bottom:1.5rem}.cdp-section-heading{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.1rem;gap:.5rem;margin-bottom:.75rem}.cdp-schedules-grid{grid-gap:.5rem;display:grid;gap:.5rem}.cdp-schedule-card{align-items:center;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.cdp-schedule-info{flex:1 1}.cdp-schedule-day{color:var(--color-text-primary);font-weight:600}.cdp-schedule-time{color:var(--color-text-primary);font-size:.9rem}.cdp-schedule-badge{background:var(--color-info);border-radius:12px;color:#fff;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.cdp-empty-schedules{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);padding:1rem;text-align:center}.cdp-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.cdp-info-grid p{margin:.5rem 0}.cdp-info-grid p,.cdp-info-grid strong{color:var(--color-text-primary)}@media (max-width:768px){.cdp-info-grid{grid-template-columns:1fr}}.cdp-description-section{margin-top:1rem}.cdp-description-section h4{color:var(--color-text-primary);margin-bottom:.5rem}.cdp-description-content{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);padding:1rem;white-space:pre-wrap}.cdp-venue-contact{margin-top:1rem}.cdp-venue-contact h4{color:var(--color-text-primary);margin-bottom:.5rem}.cdp-venue-contact-box{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;padding:1rem}.cdp-venue-contact-box p{color:var(--color-text-primary);font-size:.95rem;margin:.5rem 0}.cdp-venue-contact-box p:first-child{margin-top:0}.cdp-venue-contact-box p:last-child{margin-bottom:0}.cdp-venue-contact-box strong{color:var(--color-text-primary);font-weight:600}.cdp-school-name{color:var(--color-text-primary);font-weight:500;margin-left:.5rem}.cdp-flex-row{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.cdp-select{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);flex:1 1;font-size:.9rem;min-width:200px;padding:.5rem}.cdp-select:focus{border-color:var(--color-info);box-shadow:0 0 0 2px #17a2b833;outline:none}.cdp-select option{background:var(--color-bg-primary);color:var(--color-text-primary);padding:.5rem}.cdp-btn-action{background:var(--color-info);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s;white-space:nowrap}.cdp-btn-action:hover:not(:disabled){background:var(--color-primary-hover)}.cdp-btn-action:disabled{background:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}@media (max-width:576px){.cdp-flex-row{align-items:stretch;flex-direction:column}.cdp-select{min-width:auto}.cdp-btn-action{width:100%}}.cdp-mobile-list{display:flex;flex-direction:column;gap:1rem}.cdp-person-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 4px var(--color-shadow);padding:1rem;transition:box-shadow .2s ease}.cdp-person-card:hover{box-shadow:0 4px 8px var(--color-shadow)}.cdp-person-card-header{align-items:center;display:flex;gap:1rem}.cdp-person-photo{flex-shrink:0}.cdp-person-photo img{border:2px solid var(--color-border);border-radius:50%;height:50px;object-fit:cover;width:50px}.cdp-no-photo{align-items:center;background:var(--color-bg-tertiary);border-radius:50%;color:var(--color-text-secondary);display:flex;font-size:1.2rem;font-weight:500;height:50px;justify-content:center;width:50px}.cdp-person-info{flex:1 1}.cdp-person-info h4{color:var(--color-text-primary);font-size:1rem;margin:0 0 .25rem}.cdp-person-info p{color:var(--color-text-primary);font-size:.85rem;margin:.125rem 0}@media (max-width:576px){.cdp-no-photo,.cdp-person-photo img{height:40px;width:40px}.cdp-person-info h4{font-size:.95rem}.cdp-person-info p{font-size:.8rem}.cdp-person-card-header{align-items:center;flex-direction:column;text-align:center}.cdp-person-info{text-align:center}}.cdp-delete-btn{align-items:center;background:var(--color-danger);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;min-width:36px;padding:.5rem;transition:background-color .2s}.cdp-delete-btn:hover:not(:disabled){background:var(--color-accent-hover)}.cdp-delete-btn:disabled{background:var(--color-text-tertiary);cursor:not-allowed}@media (hover:none) and (pointer:coarse){.cdp-delete-btn{height:44px;min-width:44px;padding:.75rem}}.cdp-table-wrapper{-webkit-overflow-scrolling:touch;background:var(--color-bg-primary);border-radius:6px;box-shadow:0 2px 6px var(--color-shadow);overflow:hidden;overflow-x:auto}.cdp-table{border-collapse:collapse;margin-top:1rem;width:100%}.cdp-table thead{background:var(--color-bg-secondary);border-bottom:2px solid var(--color-border)}.cdp-table th{border-bottom:2px solid var(--color-border);font-size:.9rem;font-weight:600;text-align:left}.cdp-table td,.cdp-table th{color:var(--color-text-primary);padding:.75rem}.cdp-table td{border-bottom:1px solid var(--color-border-light)}.cdp-table tbody tr{background:var(--color-bg-primary);transition:background-color .2s}.cdp-table tbody tr:hover{background:var(--color-bg-tertiary)}.cdp-table-striped tbody tr:nth-child(2n){background:var(--color-bg-secondary)}.cdp-table-striped tbody tr:nth-child(2n):hover{background:var(--color-bg-tertiary)}.cdp-table-empty{color:var(--color-text-secondary);font-style:italic}.cdp-table-empty,.cdp-text-center{text-align:center}.cdp-thumb{border:2px solid var(--color-border);border-radius:50%;height:48px;object-fit:cover;width:48px}.cdp-no-photo-sm{align-items:center;background:var(--color-bg-tertiary);border-radius:50%;color:var(--color-text-secondary);display:flex;font-size:.7rem;font-weight:500;height:48px;justify-content:center;width:48px}.cdp-badge-instructor{background:var(--color-info-light);border:1px solid var(--color-info);border-radius:12px;color:var(--color-info)}.cdp-badge-instructor,.cdp-badge-student{align-items:center;display:inline-flex;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.cdp-badge-student{background:var(--color-accent-light);border:1px solid var(--color-accent-primary);border-radius:12px}.cdp-badge-instructor-sm{background:var(--color-info-light);border:1px solid var(--color-info);border-radius:4px;color:var(--color-info);font-size:.7rem;font-weight:400;margin-left:.5rem;padding:.2rem .4rem}@media print{.cdp-btn-action,.cdp-delete-btn,.cdp-flex-row,.cdp-mobile-only,.cdp-nav-back,.cdp-tabs{display:none!important}.cdp-desktop-only{display:block!important}.cdp-panel,.cdp-person-card{break-inside:avoid;page-break-inside:avoid}.cdp-panel,.cdp-person-card,.cdp-table-wrapper{border:1px solid #ddd;box-shadow:none}}@media (prefers-contrast:high){.cdp-person-card{border:2px solid #000}.cdp-person-photo img{border-color:#000}.cdp-delete-btn,.cdp-panel,.cdp-tab-active,.cdp-table-wrapper{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.cdp-back-btn,.cdp-btn-action,.cdp-delete-btn,.cdp-person-card,.cdp-tab,.cdp-table tbody tr{transition:none}.cdp-person-card:hover{transform:none}.cdp-loading-spinner{animation:none}}*{box-sizing:border-box;margin:0;padding:0}.landing-container{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#0f172a);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172af2;border-bottom:1px solid #dc26264d;left:0;position:fixed;right:0;top:0;z-index:1000}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 2rem}.header-content,.logo-link{align-items:center;display:flex}.logo-link{transition:opacity .3s}.logo-link:hover{opacity:.8}.header-logo{height:48px;width:auto}.desktop-nav{align-items:center;display:flex;gap:2rem}.nav-link{color:#fff;text-decoration:none;transition:color .3s}.nav-link:hover{color:#dc2626}.login-btn{background:#0000;border:1px solid #dc2626;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;padding:.5rem 1.5rem;transition:all .3s}.login-btn:hover{background:#dc2626}.mobile-menu-btn{background:none;border:none;color:#fff;cursor:pointer;display:none;padding:.5rem}.mobile-nav{background:#1e293b;border-top:1px solid #dc26264d;display:none;padding:1rem 2rem}.mobile-nav-link{color:#fff;display:block;padding:.75rem 0;text-decoration:none;transition:color .3s}.mobile-nav-link:hover{color:#dc2626}.mobile-login-btn{background:#0000;border:1px solid #dc2626;border-radius:8px;color:#fff;cursor:pointer;display:block;margin-top:.5rem;padding:.75rem 1.5rem;text-align:center;transition:all .3s;width:100%}.mobile-login-btn:hover{background:#dc2626}.hero-section{align-items:center;display:flex;min-height:100vh;padding:8rem 2rem 4rem}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.hero-text{text-align:left}.badge{align-items:center;background:#dc262633;border:1px solid #dc262680;border-radius:50px;display:inline-flex;font-size:.875rem;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem}.badge-icon{align-items:center;color:#dc2626;display:flex}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.text-highlight{color:#dc2626}.hero-subtitle{color:#fffc;font-size:1.25rem;line-height:1.6;margin-bottom:2rem}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.cta-primary{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.125rem;font-weight:700;padding:1rem 2rem;transition:all .3s}.cta-primary:hover{background:#b91c1c;box-shadow:0 10px 25px #dc262666;transform:translateY(-2px)}.cta-secondary{align-items:center;background:#0000;border:2px solid #dc2626;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.125rem;font-weight:700;gap:.5rem;padding:1rem 2rem;transition:all .3s}.cta-secondary:hover{background:#dc26261a;transform:translateY(-2px)}.trust-indicators{color:#fff9;display:flex;font-size:.875rem;gap:2rem}.trust-item-inline{align-items:center;color:#dc2626;display:flex;gap:.5rem}.trust-item-inline span{color:#fff9}.hero-mockup{position:relative}.mockup-card{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #dc26264d;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;padding:2rem}.mockup-bar{background:#dc26264d;border-radius:6px;height:12px;margin-bottom:1rem}.mockup-bar.short{background:#334155;width:75%}.mockup-bar.medium{background:#334155;width:85%}.mockup-icons{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-top:1.5rem}.mockup-icon{align-items:center;background:#334155;border-radius:8px;color:#dc2626;display:flex;height:80px;justify-content:center}.trust-banner{border-bottom:1px solid #dc26264d;border-top:1px solid #dc26264d;padding:3rem 2rem}.trust-banner-content{margin:0 auto;max-width:1200px;text-align:center}.trust-banner-text{font-size:1.875rem;font-weight:600;margin-bottom:1rem}.trust-banner-subtext{color:#fff9;font-size:1.125rem}.features-section{margin:0 auto;max-width:1200px;padding:5rem 2rem}.landing-container .section-header{background:#0000!important;border:none!important;color:inherit!important;margin-bottom:4rem;padding:0!important;text-align:center}.landing-container .section-title{color:#fff!important;font-size:3rem;font-weight:800;margin-bottom:1rem}.landing-container .section-subtitle{color:#ffffffb3!important;font-size:1.25rem;margin:0 auto;max-width:800px}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-card{background:#1e293b80;border:1px solid #dc26264d;border-radius:12px;padding:2rem;transition:all .3s}.feature-card:hover{border-color:#dc262680;box-shadow:0 10px 30px #0000004d;transform:translateY(-5px)}.feature-icon{align-items:center;background:#dc262633;border-radius:12px;color:#dc2626;display:flex;height:64px;justify-content:center;margin-bottom:1.5rem;width:64px}.feature-title{font-size:1.25rem;font-weight:700;margin-bottom:1rem}.feature-description{color:#ffffffb3;line-height:1.6}.benefits-section{background:#0003;padding:5rem 2rem}.benefits-grid{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.benefits-text h2{font-size:3rem;font-weight:800;margin-bottom:1.5rem}.benefits-intro{color:#ffffffb3;font-size:1.25rem;margin-bottom:2rem}.benefits-list{display:flex;flex-direction:column;gap:1rem}.benefit-item{align-items:flex-start;display:flex;gap:1rem}.benefit-icon{color:#dc2626;flex-shrink:0;margin-top:2px}.benefit-text{color:#fffc;font-size:1.125rem}.why-card{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #dc26264d;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;padding:2rem}.why-title{font-size:1.5rem;font-weight:700;margin-bottom:2rem;text-align:center}.why-items{display:flex;flex-direction:column;gap:1.5rem}.why-item{align-items:flex-start;display:flex;gap:1rem}.why-icon{align-items:center;background:#dc262633;border-radius:8px;color:#dc2626;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.why-item-title{font-weight:700;margin-bottom:.5rem}.why-item-text{color:#fff9;font-size:.875rem;line-height:1.5}.demo-section{margin:0 auto;max-width:1000px;padding:5rem 2rem;text-align:center}.demo-content h2{font-size:3rem;font-weight:800;margin-bottom:1rem}.demo-content p{color:#ffffffb3;font-size:1.25rem;margin-bottom:3rem}.video-container{aspect-ratio:16/9;background:#1e293b;border:1px solid #dc26264d;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;overflow:hidden;position:relative;width:100%}.video-container iframe{border:none;height:100%;left:0;position:absolute;top:0;width:100%}.video-placeholder{aspect-ratio:16/9;background:#1e293b;border:1px solid #dc26264d;border-radius:16px;cursor:pointer;overflow:hidden;position:relative}.video-overlay{align-items:center;background:#0f172a80;display:flex;inset:0;justify-content:center;position:absolute;transition:background .3s}.video-placeholder:hover .video-overlay{background:#0f172a4d}.play-button{align-items:center;background:#dc2626;border-radius:50%;color:#fff;display:flex;height:80px;justify-content:center;transition:transform .3s;width:80px}.video-placeholder:hover .play-button{transform:scale(1.1)}.calendly-section{background:#0003;padding:5rem 2rem}.calendly-content{margin:0 auto;max-width:1000px}.calendly-header{margin-bottom:3rem;text-align:center}.calendly-icon{color:#dc2626;display:flex;justify-content:center;margin-bottom:1.5rem}.calendly-header h2{font-size:3rem;font-weight:800;margin-bottom:1rem}.calendly-header p{color:#ffffffb3;font-size:1.25rem;margin:0 auto;max-width:700px}.calendly-wrapper{background:#0f172a;border:1px solid #dc26264d;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;margin-bottom:2rem;overflow:hidden}.calendly-inline-widget{width:100%}.calendly-benefits{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:2rem}.calendly-benefit{align-items:center;color:#fffc;display:flex;font-size:.95rem;gap:.5rem}.calendly-benefit svg{color:#dc2626;flex-shrink:0}.cta-section{background:linear-gradient(90deg,#dc262633,#0f172a);padding:5rem 2rem}.cta-content{margin:0 auto;max-width:800px;text-align:center}.cta-icon{color:#dc2626;display:flex;justify-content:center;margin-bottom:1.5rem}.cta-content h2{font-size:3rem;font-weight:800;margin-bottom:1rem}.cta-content p{color:#ffffffb3;font-size:1.25rem;margin-bottom:2.5rem}.cta-button-large{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.25rem;font-weight:700;padding:1.25rem 3rem;transition:all .3s}.cta-button-large:hover{background:#b91c1c;transform:scale(1.05)}.cta-login-text{color:#fff9;margin-top:1.5rem}.cta-login-link{color:#dc2626;font-weight:600;text-decoration:none;transition:color .3s}.cta-login-link:hover{color:#b91c1c}.footer{border-top:1px solid #dc26264d;padding:3rem 2rem}.footer-content{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin:0 auto;max-width:1200px}.footer-logo-link{transition:opacity .3s}.footer-logo-link:hover{opacity:.8}.footer-logo{height:48px;width:auto}.footer-links{display:flex;gap:2rem}.footer-link{color:#fff9;font-size:.875rem;text-decoration:none;transition:color .3s}.footer-link:hover{color:#dc2626}.footer-copyright{color:#fff9;font-size:.875rem}.modal-overlay{align-items:center;background:#000000e6;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:9999}.modal-content{max-width:1000px;position:relative;width:100%}.video-modal-content{max-width:900px}.modal-video-container{aspect-ratio:16/9;background:#0f172a;border-radius:12px;overflow:hidden;position:relative;width:100%}.modal-video-container iframe{border:none;height:100%;left:0;position:absolute;top:0;width:100%}.modal-close{align-items:center;background:#dc2626;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:0;top:-50px;transition:background .3s;width:40px}.modal-close:hover{background:#b91c1c}.modal-video-placeholder{align-items:center;aspect-ratio:16/9;background:#0f172a;border-radius:8px;color:#fff9;display:flex;flex-direction:column;justify-content:center}.modal-video-icon{color:#dc2626;margin-bottom:1rem}.modal-video-hint{font-size:.875rem;margin-top:.5rem}.animate-in{animation:slideInUp .8s ease-out forwards;opacity:0;transform:translateY(30px)}.delay-1{animation-delay:.2s}.delay-2{animation-delay:.4s}.delay-3{animation-delay:.6s}.delay-4{animation-delay:.8s}@keyframes slideInUp{to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.desktop-nav{display:none}.mobile-menu-btn,.mobile-nav{display:block}.hero-content{grid-template-columns:1fr}.hero-title{font-size:2.5rem}.benefits-grid,.features-grid{grid-template-columns:1fr}.footer-content{flex-direction:column;text-align:center}.footer-links{flex-direction:column;gap:1rem}.calendly-wrapper{border-radius:8px}.calendly-inline-widget{height:600px!important}.calendly-benefits{align-items:center;flex-direction:column;gap:1rem}}.pricing-section{background:#0003;padding:6rem 2rem}.pricing-loading{color:#fffc;padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff1a;border-radius:50%;border-top-color:#dc2626;height:50px;margin:0 auto 1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.pricing-plans-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr;margin:0 auto 3rem;max-width:1200px}@media (min-width:768px){.pricing-plans-grid{grid-template-columns:1fr 1fr}}.pricing-plan-card{background:#1e293b80;border:2px solid #dc26264d;border-radius:16px;box-shadow:0 4px 20px #0000004d;color:#fff;cursor:pointer;padding:2rem;position:relative;transition:all .3s ease}.pricing-plan-card:hover{border-color:#dc262680;box-shadow:0 10px 30px #0006;transform:translateY(-4px)}.pricing-plan-card.selected{border-color:#dc2626;box-shadow:0 8px 30px #dc262666;transform:translateY(-4px)}.popular-badge{background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:12px;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:4px 12px;position:absolute;right:20px;top:-12px}.free-trial-btn{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:10px;box-shadow:0 4px 15px #22c55e4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;margin-bottom:1.25rem;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.free-trial-btn:hover{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 6px 20px #22c55e66;transform:translateY(-2px)}.free-trial-btn:active{transform:translateY(0)}.plan-header h3{color:#fff;font-size:1.8rem;margin:0 0 .5rem}.plan-description{color:#ffffffb3;font-size:1rem;margin:0 0 1rem}.billing-badge{background:#e2e8f033;border:1px solid #fff3;border-radius:12px;color:#ffffffe6;display:inline-block;font-size:.85rem;font-weight:600;padding:6px 14px}.billing-badge.yearly{background:#dc262633;border-color:#dc262680;color:#fca5a5}.plan-pricing{background:#0000004d;border:1px solid #dc26264d;border-radius:12px;margin:2rem 0;padding:1.5rem}.price-display{align-items:baseline;display:flex;gap:.25rem;justify-content:center}.price-display .currency{color:#dc2626;font-size:1.5rem;font-weight:700}.price-display .amount{color:#fff;font-size:3rem;font-weight:800}.price-display .period{color:#fff9;font-size:1rem}.price-detail{color:#ffffffb3;font-size:.9rem;margin-top:.5rem;text-align:center}.minimum-notice{background:#fbbf2426;border:1px solid #fbbf2480;border-radius:8px;color:#fbbf24}.minimum-notice,.no-minimum-notice{font-size:.9rem;margin:1rem 0;padding:10px;text-align:center}.no-minimum-notice{background:#22c55e26;border:1px solid #22c55e80;border-radius:8px;color:#4ade80;font-weight:600}.plan-features{border-top:2px solid #ffffff1a;list-style:none;margin:1.5rem 0 0;padding:1.5rem 0 0}.plan-features li{align-items:center;border-bottom:1px solid #ffffff1a;color:#ffffffe6;display:flex;gap:.75rem;padding:.75rem 0}.plan-features li:last-child{border-bottom:none}.plan-features li svg{color:#4ade80;flex-shrink:0}.plan-features li.highlight{color:#fca5a5;font-weight:600}.plan-features li.highlight svg{color:#dc2626}.pricing-calculator{background:#1e293b80;border:2px solid #dc26264d;border-radius:16px;box-shadow:0 4px 20px #0000004d;color:#fff;margin:0 auto;max-width:900px;padding:2.5rem}.calculator-header{margin-bottom:2rem;text-align:center}.calculator-header h3{color:#fff;font-size:1.8rem;margin:0 0 .5rem}.calculator-header p{color:#ffffffb3;font-size:1rem}.user-selector{margin-bottom:2.5rem}.user-selector label{color:#fff;display:block;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.slider-container{position:relative}.user-slider{-webkit-appearance:none;background:linear-gradient(90deg,#dc2626 0,#b91c1c);border-radius:4px;cursor:pointer;height:8px;outline:none;width:100%}.user-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;border:3px solid #dc2626;border-radius:50%;box-shadow:0 2px 8px #0003;cursor:pointer;height:24px;width:24px}.user-slider::-moz-range-thumb{background:#fff;border:3px solid #dc2626;border-radius:50%;box-shadow:0 2px 8px #0003;cursor:pointer;height:24px;width:24px}.slider-value{color:#dc2626;font-size:1.5rem;font-weight:700;margin-top:1rem;text-align:center}.volume-tiers{background:#0000004d;border:1px solid #dc26264d;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.volume-tiers h4{color:#fff;font-size:1.1rem;margin:0 0 1rem}.volume-tiers ul{list-style:none;margin:0;padding:0}.volume-tiers li{align-items:center;background:#1e293b66;border:2px solid #ffffff1a;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .3s ease}.volume-tiers li.active{background:#dc262633;border-color:#dc2626}.tier-range{color:#ffffffe6;font-weight:600}.tier-discount{color:#fca5a5;font-weight:700}.volume-tiers li.active .tier-discount{color:#dc2626}.pricing-summary{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:12px;color:#fff;padding:2rem}.summary-row{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:1rem 0}.summary-row:last-child{border-bottom:none}.summary-row.total{border-top:2px solid #fff3;font-size:1.2rem;padding-top:1.5rem}.summary-row span{color:#fffc}.summary-row strong{color:#fff;font-size:1.1rem}.total-price{color:#dc2626!important;font-size:2rem!important}.total-period{color:#fff9;font-size:1rem;font-weight:400}@media (max-width:480px){.hero-title,.landing-container .section-title{font-size:2rem}.cta-primary,.cta-secondary{justify-content:center;width:100%}.pricing-section{padding:3rem 1rem}.pricing-calculator{padding:1.5rem}.plan-pricing{padding:1rem}.price-display .amount{font-size:2rem}.pricing-plan-card{padding:1.5rem}}