*{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#2c5aa0;--color-primary-dark:#1f4178;--color-primary-light:#3d6bb5;--color-accent:#b29f9d;--color-accent-light:#c9b5b0;--color-accent-dark:#9a8580;--color-accent-bg:hsla(6,12%,66%,.1);--color-accent-hover:#9a8580;--color-background-start:#f5f7fa;--color-background-end:#c3cfe2;--color-white:#fff;--color-gray-light:#f8f9fa;--color-gray-border:#e9ecef;--color-gray:#6c757d;--color-text:#333;--color-text-secondary:#666;--color-success:#28a745;--color-danger:#dc3545;--color-warning:#ffc107;--color-info:#17a2b8;--font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-size-base:clamp(14px,2vw,16px);--font-size-small:clamp(12px,1.75vw,14px);--font-size-large:clamp(16px,2.25vw,18px);--font-size-h1:clamp(24px,4vw,36px);--font-size-h2:clamp(20px,3vw,28px);--font-size-h3:clamp(18px,2.5vw,22px);--spacing-xs:clamp(4px,0.5vw,6px);--spacing-sm:clamp(8px,1vw,12px);--spacing-md:clamp(12px,1.5vw,16px);--spacing-lg:clamp(16px,2vw,24px);--spacing-xl:clamp(24px,3vw,36px);--spacing-2xl:clamp(32px,4vw,48px);--spacing-3xl:clamp(48px,5vw,64px);--border-radius:10px;--border-radius-lg:15px;--border-radius-sm:5px;--border-radius-pill:20px;--shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 2px 15px rgba(0,0,0,.08);--shadow-lg:0 5px 20px rgba(44,90,160,.3);--transition-fast:0.2s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease}body{background:linear-gradient(135deg,var(--color-background-start) 0,var(--color-background-end) 100%);color:var(--color-text);font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;min-height:100vh;padding:0}body.no-nav{padding:var(--spacing-lg)}h1,h2,h3,h4,h5,h6{color:var(--color-primary);font-weight:600;margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-h1)}h2{font-size:var(--font-size-h2)}h3{font-size:var(--font-size-h3)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-dark)}a.link-accent{color:var(--color-accent)}a.link-accent:hover{color:var(--color-accent-dark)}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}a:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.container{margin:0 auto;max-width:1400px;padding:var(--spacing-lg)}.no-nav .container{padding:0}.card{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.card,.card-header{margin-bottom:var(--spacing-lg)}.card-header{border-bottom:1px solid var(--color-gray-border);padding-bottom:var(--spacing-md)}.card-body{padding:var(--spacing-md) 0}.card-primary{border-left:4px solid var(--color-primary)}.card-accent{border-left:4px solid var(--color-accent)}.card-success{border-left:4px solid var(--color-success)}.card-warning{border-left:4px solid var(--color-warning)}.card-danger{border-left:4px solid var(--color-danger)}.card-hover-accent{transition:border-color var(--transition-normal)}.card-hover-accent:hover{border-left:4px solid var(--color-accent)}.card-shadow-sm{box-shadow:var(--shadow-sm)}.card-shadow-md{box-shadow:var(--shadow-md)}.card-shadow-lg{box-shadow:var(--shadow-lg)}.card-footer{background:var(--color-gray-light);border-radius:0 0 var(--border-radius-lg) var(--border-radius-lg);border-top:1px solid var(--color-gray-border);padding:var(--spacing-md)}header{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl);text-align:center}.logo{color:var(--color-primary);font-size:var(--font-size-h1);font-weight:700;margin-bottom:var(--spacing-sm)}.subtitle{color:var(--color-text-secondary);font-size:var(--font-size-large)}.welcome-banner{background:var(--color-primary);border-radius:var(--border-radius);color:var(--color-white);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);text-align:center}.welcome-banner h2{color:var(--color-white);margin-bottom:var(--spacing-sm)}.alert{border-radius:var(--border-radius);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-danger{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.alert-info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.alert-accent{background-color:var(--color-accent-bg);border:1px solid var(--color-accent-light);color:var(--color-accent-dark)}.alert-content{align-items:flex-start;display:flex;flex:1;gap:var(--spacing-sm)}.alert-icon{flex-shrink:0;font-size:20px;margin-top:2px}.alert-body{flex:1}.alert-title{display:block;font-size:var(--font-size-base);margin-bottom:var(--spacing-xs)}.alert-message{font-size:var(--font-size-small)}.alert-close{background:none;border:none;cursor:pointer;font-size:24px;line-height:1;margin-left:var(--spacing-sm);opacity:.7;padding:0;transition:opacity var(--transition-fast)}.alert-close:hover{opacity:1}.alert-close:focus-visible{outline:2px solid currentColor;outline-offset:2px}.alert[data-controller=alert].alert-dismissing{animation:alertDismiss .3s ease-out forwards}@keyframes alertDismiss{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.portal-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:var(--spacing-xl)}.app-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.portal-section{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.section-title{align-items:center;border-bottom:2px solid var(--color-accent-light);color:var(--color-primary);display:flex;font-size:var(--font-size-h3);font-weight:600;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.section-icon{color:var(--color-accent);font-size:24px;margin-right:var(--spacing-sm)}.app-tile{align-items:center;background:var(--color-gray-light);border:2px solid var(--color-gray-border);border-radius:var(--border-radius);color:var(--color-text);cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:120px;padding:var(--spacing-lg) var(--spacing-sm);text-align:center;text-decoration:none;transition:all var(--transition-normal)}.app-tile:hover{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-accent) 100%);border-color:var(--color-accent);box-shadow:var(--shadow-lg);color:var(--color-white);transform:translateY(-5px)}.app-tile:focus-visible{box-shadow:var(--shadow-lg);outline:3px solid var(--color-primary);outline-offset:2px;transform:translateY(-5px)}.app-icon{font-size:40px;margin-bottom:var(--spacing-sm)}.app-name{font-size:var(--font-size-small);font-weight:500}.mobile-app-indicator{display:block;font-size:12px;margin-top:4px;opacity:.7}.app-icon-image{align-items:center;display:flex;justify-content:center;padding:8px}.app-icon-image img{border-radius:var(--border-radius-sm);height:48px;-o-object-fit:contain;object-fit:contain;width:48px}.btn{border:none;border-radius:var(--border-radius-sm);cursor:pointer;display:inline-block;font-size:var(--font-size-base);font-weight:500;padding:12px 24px;text-align:center;text-decoration:none;transition:all var(--transition-fast)}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn:focus-visible{outline:3px solid var(--color-primary-dark);outline-offset:2px}.btn-secondary{background:var(--color-gray);color:var(--color-white)}.btn-secondary:hover{background:#5a6268}.btn-success{background:var(--color-success);color:var(--color-white)}.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-block{display:block;width:100%}.btn-sm{font-size:var(--font-size-small);padding:8px 16px}.btn-lg{font-size:var(--font-size-large);padding:16px 32px}.btn-accent{background:var(--color-accent);color:var(--color-text)}.btn-accent:hover{background:var(--color-accent-dark);color:var(--color-white)}.btn-outline-accent{background:transparent;border:2px solid var(--color-accent);color:var(--color-accent)}.btn-outline-accent:hover{background:var(--color-accent);color:var(--color-text)}.btn-info{background:var(--color-info);color:var(--color-white)}.btn-info:hover{background:#138496}.btn-warning{background:var(--color-warning);color:#333}.btn-warning:hover{background:#e0a800}.btn-icon{align-items:center;display:inline-flex;margin:0 4px}.btn-icon-left{margin-left:0;margin-right:8px}.btn-icon-right{margin-left:8px;margin-right:0}.btn-label{display:inline-block}.btn:disabled,.btn[aria-disabled=true]{cursor:not-allowed;opacity:.6;pointer-events:none}.btn:active:not(:disabled){box-shadow:inset 0 2px 4px rgba(0,0,0,.1);transform:translateY(0)}.btn-md{font-size:var(--font-size-base);padding:12px 24px}.form-group{margin-bottom:var(--spacing-lg)}.form-label{color:var(--color-text);display:block;font-weight:500;margin-bottom:var(--spacing-xs)}.form-control{border:1px solid var(--color-gray-border);border-radius:var(--border-radius-sm);font-family:var(--font-family);font-size:var(--font-size-base);padding:12px 16px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(44,90,160,.1);outline:none}.form-control.form-control-accent:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.form-control::-moz-placeholder{color:var(--color-gray)}.form-control::placeholder{color:var(--color-gray)}.form-control.is-invalid{border-color:var(--color-danger)}.form-control.is-valid{border-color:var(--color-success)}.invalid-feedback{color:var(--color-danger);display:block;font-size:var(--font-size-small);margin-top:var(--spacing-xs)}.form-check{align-items:center;display:flex;margin-bottom:var(--spacing-md)}.form-check-input{cursor:pointer;margin-right:var(--spacing-sm)}.form-check-label{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.form-required{font-weight:700;margin-left:4px}.form-group.has-error .form-label,.form-required{color:var(--color-danger)}.form-group.has-error .form-control{border-color:var(--color-danger)}.form-text{display:block;font-size:var(--font-size-small);margin-top:var(--spacing-xs)}.form-text,.text-muted{color:var(--color-text-secondary)}.quick-links{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.link-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.quick-link{background:var(--color-accent-bg);border:1px solid var(--color-accent-light);border-radius:var(--border-radius-pill);color:var(--color-accent-dark);font-size:var(--font-size-small);padding:8px 16px;text-decoration:none;transition:all var(--transition-normal)}.quick-link:hover{background:var(--color-accent);border-color:var(--color-accent);box-shadow:var(--shadow-sm);color:var(--color-text);transform:translateY(-2px)}.footer{color:var(--color-text-secondary);font-size:var(--font-size-small);padding:var(--spacing-lg);text-align:center}.help-button{align-items:center;background:linear-gradient(135deg,var(--color-accent) 0,var(--color-primary) 100%);border-radius:50%;bottom:30px;box-shadow:0 4px 15px hsla(6,12%,66%,.4);color:var(--color-white);cursor:pointer;display:flex;font-size:24px;height:60px;justify-content:center;position:fixed;right:30px;text-decoration:none;transition:all var(--transition-normal);width:60px}.help-button:hover{box-shadow:0 6px 20px hsla(6,12%,66%,.6);transform:scale(1.1)}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-lg)}.login-card{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);max-width:450px;padding:var(--spacing-2xl);width:100%}.login-header{margin-bottom:var(--spacing-xl);text-align:center}.login-logo{color:var(--color-primary);font-size:36px;font-weight:700;margin-bottom:var(--spacing-sm)}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-base)}.login-footer{margin-top:var(--spacing-lg);text-align:center}@media (max-width:768px){body{padding:var(--spacing-sm)}.app-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.portal-grid{grid-template-columns:1fr}header{padding:var(--spacing-lg)}.logo{font-size:24px}.login-card{padding:var(--spacing-lg)}.help-button{bottom:20px;font-size:20px;height:50px;right:20px;width:50px}}@media (max-width:767px){.card{margin-bottom:var(--spacing-md)}.card,.card-header{padding:var(--spacing-md)}.card-header{font-size:16px}.card-body,.card-footer{padding:var(--spacing-md)}.card-footer{flex-direction:column;gap:var(--spacing-sm)}.card-footer .btn{width:100%}.modal-dialog{margin:0;max-height:100vh}.modal-lg,.modal-md,.modal-sm,.modal-xl{max-width:100%;min-height:100vh;width:100%}.modal-content{border-radius:0;display:flex;flex-direction:column;min-height:100vh}.modal-header{padding:var(--spacing-md) var(--spacing-lg)}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.modal-footer{flex-direction:column-reverse;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg)}.modal-footer .btn{margin:0;width:100%}.alert{font-size:14px;padding:var(--spacing-md)}.alert-icon{margin-bottom:var(--spacing-xs)}.alert-content{align-items:flex-start;flex-direction:column}.alert-close{position:absolute;right:var(--spacing-sm);top:var(--spacing-sm)}.btn-responsive{display:block;text-align:center;width:100%}.btn-group{flex-direction:column;width:100%}.btn-group .btn{border-radius:var(--border-radius-md)!important;margin-bottom:var(--spacing-xs);width:100%}.btn-group .btn:last-child{margin-bottom:0}.form-group{margin-bottom:var(--spacing-md)}.form-row{display:block}.form-row .form-group{margin-bottom:var(--spacing-md)}.form-control{font-size:16px;padding:12px 14px;width:100%}.form-label{font-size:14px;margin-bottom:var(--spacing-xs)}.form-actions{flex-direction:column-reverse;gap:var(--spacing-sm)}.form-actions .btn{width:100%}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}table{font-size:13px;min-width:600px}td,th{padding:10px 12px}.breadcrumb{font-size:12px;overflow-x:auto;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap}.stats-grid{gap:var(--spacing-md)}.sidebar-layout,.sidebar-layout-wide,.stats-grid,.three-column-layout{grid-template-columns:1fr}}@media (max-width:575px){.alert,.card,.card-body,.card-footer,.card-header{padding:var(--spacing-sm)}.alert{font-size:13px}.btn{font-size:14px;padding:11px 18px}.btn-sm{font-size:13px;padding:8px 14px}.btn-lg{font-size:16px;padding:14px 22px}.form-control{padding:10px 12px}.modal-footer,.modal-header{padding:var(--spacing-sm) var(--spacing-md)}.modal-body{padding:var(--spacing-md)}}.badge{border-radius:var(--border-radius-pill);display:inline-block;font-size:var(--font-size-small);font-weight:500;line-height:1.5;padding:4px 12px}.badge-primary{background:var(--color-primary);color:var(--color-white)}.badge-accent{background:var(--color-accent);color:var(--color-text)}.badge-success{background:var(--color-success);color:var(--color-white)}.badge-warning{background:var(--color-warning);color:var(--color-text)}.badge-danger{background:var(--color-danger);color:var(--color-white)}.badge-info{background:var(--color-info);color:var(--color-white)}.badge-outline-accent{background:transparent;border:2px solid var(--color-accent);color:var(--color-accent)}.status-pill{align-items:center;border-radius:var(--border-radius-pill);display:inline-flex;font-size:var(--font-size-small);font-weight:500;gap:var(--spacing-xs);padding:6px 14px}.status-pill-pending{background:var(--color-accent-bg);border:1px solid var(--color-accent-light);color:var(--color-accent-dark)}.status-pill-active{background:rgba(40,167,69,.1);border:1px solid var(--color-success);color:var(--color-success)}.status-pill-completed{background:rgba(23,162,184,.1);border:1px solid var(--color-info);color:var(--color-info)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.flex-column{flex-direction:column}.justify-center{justify-content:center}.align-center{align-items:center}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}.gap-3{gap:var(--spacing-lg)}.text-accent{color:var(--color-accent)}.text-accent-dark{color:var(--color-accent-dark)}.bg-accent{background-color:var(--color-accent)}.bg-accent-light{background-color:var(--color-accent-bg)}.border-accent{border-color:var(--color-accent)}.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border-width:0;white-space:nowrap}.sr-only-focusable:focus{height:auto;margin:inherit;overflow:visible;padding:inherit;position:static;width:auto;clip:auto;white-space:normal}.admin-quick-access{background:var(--color-white);border:2px solid var(--color-accent-light);border-radius:var(--border-radius-lg);border-top:4px solid var(--color-accent);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.admin-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:var(--spacing-md)}.admin-card{align-items:center;background:linear-gradient(135deg,#f8f9fa 0,var(--color-accent-bg) 100%);border:2px solid var(--color-accent-light);border-radius:var(--border-radius);cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:140px;padding:var(--spacing-lg);text-align:center;text-decoration:none;transition:all var(--transition-normal)}.admin-card:hover{background:linear-gradient(135deg,var(--color-accent) 0,var(--color-primary) 100%);border-color:var(--color-accent);box-shadow:var(--shadow-lg);transform:translateY(-5px)}.admin-card:hover .admin-desc,.admin-card:hover .admin-icon,.admin-card:hover .admin-title{color:var(--color-white)}.admin-icon{font-size:48px;margin-bottom:var(--spacing-sm)}.admin-icon,.admin-title{transition:color var(--transition-normal)}.admin-title{color:var(--color-primary);font-size:var(--font-size-large);font-weight:600;margin-bottom:var(--spacing-xs)}.admin-desc{color:var(--color-text-secondary);font-size:var(--font-size-small);transition:color var(--transition-normal)}@media (max-width:768px){.admin-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}.documents-section{margin-bottom:var(--spacing-xl)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg)}.view-all-link{color:var(--color-primary);font-size:var(--font-size-small);font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.view-all-link:hover{color:var(--color-primary-dark)}.documents-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.document-item{align-items:center;background:var(--color-gray-light);border-left:3px solid transparent;border-radius:var(--border-radius);display:flex;gap:var(--spacing-md);padding:var(--spacing-md);transition:all var(--transition-fast)}.document-item:hover{background:var(--color-accent-bg);border-left-color:var(--color-accent);transform:translateX(5px)}.doc-icon{align-items:center;background:var(--color-white);border-radius:var(--border-radius-sm);display:flex;flex-shrink:0;font-size:32px;height:48px;justify-content:center;width:48px}.doc-content{flex:1}.doc-title{color:var(--color-primary);font-size:var(--font-size-base);font-weight:600;margin:0 0 4px}.doc-meta{color:var(--color-text-secondary);font-size:var(--font-size-small);margin:0}.doc-download{cursor:pointer;font-size:24px;text-decoration:none;transition:transform var(--transition-fast)}.doc-download:hover{transform:scale(1.2)}@media (max-width:768px){.documents-grid{grid-template-columns:1fr}.section-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}}.modal{align-items:center;bottom:0;display:none;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.modal.modal-open{display:flex}.modal-backdrop{animation:fadeIn .3s ease;background:rgba(0,0,0,.5);bottom:0;left:0;position:absolute;right:0;top:0}.modal-dialog{animation:modalSlideIn .3s ease;background:#fff;border-radius:var(--border-radius-lg);box-shadow:0 10px 40px rgba(0,0,0,.3);max-height:90vh;overflow-y:auto;position:relative;z-index:10000}.modal-sm{max-width:400px;width:90%}.modal-md{max-width:600px;width:90%}.modal-lg{max-width:800px;width:90%}.modal-xl{max-width:1200px;width:90%}.modal-content{display:flex;flex-direction:column}.modal-header{align-items:center;border-bottom:1px solid var(--color-gray-border);display:flex;justify-content:space-between;padding:var(--spacing-lg)}.modal-title{color:var(--color-primary);font-size:var(--font-size-h2);margin:0}.modal-close{background:none;border:none;cursor:pointer;font-size:32px;line-height:1;opacity:.7;padding:0;transition:opacity var(--transition-fast)}.modal-close:hover{opacity:1}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.modal-footer{border-top:1px solid var(--color-gray-border);display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.toast-container{flex-direction:column;max-width:350px;position:fixed;right:20px;top:20px;z-index:10000}.toast,.toast-container{display:flex;gap:var(--spacing-sm)}.toast{align-items:center;background:#fff;border-radius:var(--border-radius);box-shadow:0 4px 12px rgba(0,0,0,.15);opacity:0;padding:var(--spacing-md);transform:translateX(400px);transition:all .3s ease}.toast.toast-show{opacity:1;transform:translateX(0)}.toast.toast-dismiss{opacity:0;transform:translateX(400px)}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-danger)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-icon{flex-shrink:0;font-size:20px}.toast-message{flex:1;font-size:var(--font-size-small)}.toast-close{background:none;border:none;cursor:pointer;font-size:20px;line-height:1;opacity:.5;padding:0;transition:opacity var(--transition-fast)}.toast-close:hover{opacity:1}@media (max-width:768px){.toast-container{left:10px;max-width:none;right:10px}}@media (min-width:576px){.container{padding:var(--spacing-xl)}.portal-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.app-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.btn-responsive{padding:14px 28px}}@media (min-width:768px) and (max-width:1023px){.container{max-width:960px;padding:var(--spacing-2xl) var(--spacing-xl)}.portal-grid{gap:var(--spacing-xl);grid-template-columns:repeat(2,1fr)}.app-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.admin-grid,.documents-grid{gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}.card{padding:var(--spacing-xl)}.card-header{padding:var(--spacing-lg) var(--spacing-xl)}.card-body{padding:var(--spacing-xl)}.card-footer{padding:var(--spacing-lg) var(--spacing-xl)}.btn{font-size:15px;padding:13px 26px}.btn-sm{font-size:13px;padding:9px 18px}.btn-lg{font-size:17px;padding:17px 34px}.form-group{margin-bottom:var(--spacing-lg)}.form-row{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}.form-control{font-size:15px;padding:12px 16px}.modal{padding:var(--spacing-lg)}.modal-content{max-width:90vw;width:auto}.modal-md{max-width:600px}.modal-lg{max-width:800px}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}table{font-size:14px}td,th{padding:12px 16px}.login-card{max-width:500px;padding:var(--spacing-2xl)}.portal-section{margin-bottom:var(--spacing-xl);padding:var(--spacing-xl)}.portal-section-header{margin-bottom:var(--spacing-lg)}.app-tile{min-height:140px;padding:var(--spacing-lg)}.app-tile-icon{font-size:42px}.app-tile-title{font-size:15px}.announcement-card,.document-card{padding:var(--spacing-lg)}.alert{margin-bottom:var(--spacing-lg);padding:14px 18px}.breadcrumb{font-size:14px;padding:var(--spacing-md) var(--spacing-lg)}h1{margin-bottom:var(--spacing-lg)}h2{margin-bottom:var(--spacing-md)}.stats-grid{gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}.two-column-tablet{display:grid;gap:var(--spacing-xl);grid-template-columns:1fr 1fr}.sidebar-layout{display:grid;gap:var(--spacing-xl);grid-template-columns:250px 1fr}}@media (min-width:1024px){.container{max-width:1400px}.portal-grid{gap:var(--spacing-2xl);grid-template-columns:repeat(3,1fr)}.app-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.admin-grid,.documents-grid{grid-template-columns:repeat(3,1fr)}.app-tile{transition:all .3s ease}.app-tile:hover{transform:translateY(-8px)}}@media (min-width:1280px){.container{max-width:1400px}.portal-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.app-grid{gap:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (min-width:1440px){.container{max-width:1600px;padding:var(--spacing-2xl) var(--spacing-3xl)}.admin-grid,.documents-grid,.portal-grid{gap:var(--spacing-2xl);grid-template-columns:repeat(4,1fr)}.app-grid{gap:var(--spacing-2xl);grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.card{padding:var(--spacing-2xl)}.card-header{padding:var(--spacing-xl) var(--spacing-2xl)}.card-body{padding:var(--spacing-2xl)}.card-footer{padding:var(--spacing-xl) var(--spacing-2xl)}.welcome-banner{padding:var(--spacing-3xl) var(--spacing-2xl)}h1{font-size:clamp(32px,3vw,40px);margin-bottom:var(--spacing-xl)}h2{font-size:clamp(24px,2.5vw,32px);margin-bottom:var(--spacing-lg)}h3{font-size:clamp(20px,2vw,24px)}.form-row{display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(3,1fr)}.form-group{margin-bottom:var(--spacing-xl)}.form-control{font-size:16px;padding:14px 18px}.modal-content{max-width:70vw}.modal-sm{max-width:400px}.modal-md{max-width:700px}.modal-lg{max-width:1000px}.modal-xl{max-width:1400px}.btn{font-size:16px;padding:14px 32px}.btn-sm{font-size:14px;padding:10px 20px}.btn-lg{font-size:18px;padding:18px 40px}table{font-size:15px}td,th{padding:14px 20px}.app-tile{min-height:160px;padding:var(--spacing-2xl)}.app-tile-icon{font-size:56px;margin-bottom:var(--spacing-md)}.app-tile-title{font-size:16px}.portal-section{margin-bottom:var(--spacing-2xl);padding:var(--spacing-2xl)}.portal-section-header{margin-bottom:var(--spacing-xl)}.sidebar-layout{display:grid;gap:var(--spacing-2xl);grid-template-columns:300px 1fr}.sidebar-layout-wide{grid-template-columns:350px 1fr}.three-column-layout{display:grid;gap:var(--spacing-2xl);grid-template-columns:repeat(3,1fr)}.stats-grid{gap:var(--spacing-xl);grid-template-columns:repeat(4,1fr)}.login-card{max-width:550px;padding:var(--spacing-3xl)}.announcement-card,.document-card{padding:var(--spacing-xl)}.alert{font-size:15px;padding:16px 24px}.breadcrumb{font-size:15px;padding:var(--spacing-md) var(--spacing-xl)}.content-narrow{margin:0 auto;max-width:800px}.content-medium{margin:0 auto;max-width:1000px}.content-wide{margin:0 auto;max-width:1400px}}@media (min-width:1920px){.container{max-width:1800px}.portal-grid{grid-template-columns:repeat(5,1fr)}}@media (hover:none) and (pointer:coarse){.alert-close,.breadcrumb-item,.btn,.dropdown-item,.form-check,.modal-close,.nav-link,.user-menu-item,a.card{min-height:44px;min-width:44px}.app-tile{min-height:140px;padding:var(--spacing-lg)}.app-tile:hover,.btn:hover,.card:hover{box-shadow:none;transform:none}.dropdown-item:hover,.nav-link:hover,.user-menu-item:hover{background:transparent}.app-tile:active,.btn:active,.card:active,.dropdown-item:active,.nav-link:active{opacity:.7;transform:scale(.98);transition:all .1s ease}.alert-close{margin:calc(var(--spacing-sm)*-1);padding:var(--spacing-sm)}.modal-close{margin:calc(var(--spacing-md)*-1);padding:var(--spacing-md)}.form-control,.form-select,textarea{min-height:44px;padding:12px 16px}textarea{min-height:100px}.form-check-input{min-height:24px;min-width:24px}.form-check{padding:var(--spacing-sm) 0}a{align-items:center;min-height:44px;padding:var(--spacing-xs) 0}a,a.btn{display:inline-flex}.btn-group .btn,.nav-menu .nav-link{margin-bottom:var(--spacing-xs)}.card-footer .btn{margin-top:var(--spacing-xs)}.dropdown-item{padding:14px 16px}.alert-close,.app-tile,.btn,.modal-close,.nav-link{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.app-tile,.btn,.card{-webkit-touch-callout:none}.modal-body,.table-responsive,body{-webkit-overflow-scrolling:touch}.modal-body,.table-responsive{overscroll-behavior-y:contain}a:active{opacity:.7}.nav-tabs .nav-link{min-height:48px;padding:var(--spacing-md) var(--spacing-lg)}.pagination .page-link{min-height:44px;min-width:44px;padding:var(--spacing-sm) var(--spacing-md)}.breadcrumb-item{padding:var(--spacing-xs) 0}.toast{min-height:60px;touch-action:pan-y}}@media print{body{background:#fff}.help-button,.main-nav,.user-dropdown{display:none}.container{max-width:100%;padding:0}.card,.portal-section{border:1px solid #ddd;box-shadow:none;page-break-inside:avoid}}@media (orientation:landscape) and (max-height:600px){.welcome-banner{padding:var(--spacing-md)}.card{margin-bottom:var(--spacing-md)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){:root{--color-primary:#1f4178;--color-gray-border:#666;--shadow-md:0 2px 8px rgba(0,0,0,.3)}.btn,.card,.form-control{border:2px solid}}.skip-link{background:var(--color-primary);border-radius:0 0 8px 0;color:#fff;font-weight:500;left:0;padding:8px 16px;position:absolute;text-decoration:none;top:-40px;z-index:10000}.skip-link:focus{top:0}.main-nav{background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.1);position:sticky;top:0;z-index:1000}.nav-container{height:60px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 20px}.nav-brand a,.nav-container{align-items:center;display:flex}.nav-brand a{text-decoration:none}.brand-logo{height:40px;-o-object-fit:contain;object-fit:contain;width:auto}.nav-menu{flex:1;gap:10px;margin-left:40px}.nav-link,.nav-menu{align-items:center;display:flex}.nav-link{background:none;border:none;border-radius:8px;color:#333;cursor:pointer;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#f8f9fa;color:#2c5aa0}.nav-dropdown{position:relative}.dropdown-toggle:after{content:" ▼";font-size:10px}.dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);left:0;margin-top:8px;min-width:200px;opacity:0;position:absolute;top:100%;transform:translateY(-10px);transition:all .3s ease;visibility:hidden}.dropdown-menu.dropdown-open,.nav-dropdown:hover .dropdown-menu{opacity:1;transform:translateY(0);visibility:visible}.dropdown-item{align-items:center;color:#333;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-decoration:none;transition:background .2s ease}.dropdown-item:hover{background:#f8f9fa;color:#2c5aa0}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}.nav-user{position:relative}.user-toggle{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:6px 12px;transition:background .3s ease}.user-toggle:hover{background:#f8f9fa}.user-avatar{align-items:center;background:#2c5aa0;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.user-name{color:#333;font-weight:500}.user-dropdown:hover .user-menu,.user-menu.dropdown-open{opacity:1;transform:translateY(0);visibility:visible}.user-menu{background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);margin-top:8px;min-width:250px;opacity:0;position:absolute;right:0;top:100%;transform:translateY(-10px);transition:all .3s ease;visibility:hidden}.user-info{border-bottom:1px solid #e9ecef;padding:16px}.user-info strong{color:#333;display:block;margin-bottom:4px}.user-info small{color:#666;font-size:12px}.user-menu-item{align-items:center;color:#333;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-decoration:none;transition:background .2s ease}.user-menu-item:hover{background:#f8f9fa;color:#2c5aa0}.user-menu-divider{background:#e9ecef;height:1px;margin:8px 0}@media (max-width:768px){.nav-container{padding:0 15px}.nav-menu{gap:5px;margin-left:20px}.dropdown-item,.nav-link{font-size:13px;padding:8px 12px}.brand-logo{height:35px}.user-name{display:none}}