@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Elms+Sans:wght@400;500;600;700;800&display=swap);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);@font-face{font-display:swap;font-family:Elms Sans;font-style:normal;font-weight:400;src:url(/static/media/elms-sans-vietnamese-400-normal.4d897d37c9bb01416c64.woff2) format("woff2"),url(/static/media/elms-sans-vietnamese-400-normal.63474e3d78a83f2abcb9.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:Elms Sans;font-style:normal;font-weight:400;src:url(/static/media/elms-sans-latin-ext-400-normal.da5979e210211119dda0.woff2) format("woff2"),url(/static/media/elms-sans-latin-ext-400-normal.232470e49f4a9bf4e87e.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:Elms Sans;font-style:normal;font-weight:400;src:url(/static/media/elms-sans-latin-400-normal.41431116bde622660cd7.woff2) format("woff2"),url(/static/media/elms-sans-latin-400-normal.46a2f63715383f21b0eb.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-display:swap;font-family:Stack Sans Notch;font-style:normal;font-weight:400;src:url(/static/media/stack-sans-notch-latin-ext-400-normal.0f6d480f46e5ede632c3.woff2) format("woff2"),url(/static/media/stack-sans-notch-latin-ext-400-normal.d637c9d2e9de5e274e10.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:Stack Sans Notch;font-style:normal;font-weight:400;src:url(/static/media/stack-sans-notch-latin-400-normal.103a81ac69011649635f.woff2) format("woff2"),url(/static/media/stack-sans-notch-latin-400-normal.6bdb47b05efb52825ee8.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}body{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--warning-border:#f59e0b;--warning-text:#92400e}.stm-overlay{align-items:center;animation:overlayFadeIn .2s ease-out;background:#0009;bottom:0;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:9999}.stm-modal{animation:modalSlideIn .3s ease-out;background:#fff;border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-width:440px;overflow:hidden;width:370px}.stm-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:24px 24px 16px;text-align:center}.stm-title{color:#1f2937;color:var(--text-dark);font-size:20px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.stm-subtitle,.stm-title{font-family:Elms Sans,sans-serif}.stm-subtitle{color:#6b7280;color:var(--text-medium);font-size:14px;font-weight:400;line-height:1.5;margin:0 auto;max-width:320px}.stm-timer-section{background:#fff;padding:32px 32px 24px;position:relative;text-align:center}.stm-timer-container{animation:timerPulse 2s ease-in-out infinite;height:140px;margin:0 auto;position:relative;width:140px}@keyframes timerPulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.stm-timer-svg{height:100%;transform:rotate(-90deg);width:100%}.stm-timer-circle-bg{fill:none;stroke:#f3f4f6;stroke-width:8}.stm-timer-circle-fg{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke .3s ease}.stm-timer-text{font-family:SF Mono,Monaco,Inconsolata,Fira Mono,Courier New,monospace;font-size:32px;font-weight:700;left:50%;letter-spacing:-1px;position:absolute;top:50%;transform:translate(-50%,-50%);transition:color .3s ease}.stm-warning-section{background:#fff;padding:0 32px 16px}.stm-warning-box{align-items:flex-start;background:#fef3c7;background:var(--warning-bg);border:1px solid #f59e0b;border:1px solid var(--warning-border);border-radius:8px;display:flex;gap:12px;padding:16px;text-align:left}.stm-warning-icon{color:#d97706;flex-shrink:0;margin-top:2px}.stm-warning-text{color:#92400e;color:var(--warning-text);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;line-height:1.5;margin:0}.stm-action-section{background:#fff;display:flex;flex-direction:column;gap:12px;padding:24px 32px 32px}.stm-btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:10px;justify-content:center;letter-spacing:-.01em;padding:14px 20px;transition:all .2s ease;width:100%}.stm-btn:disabled{cursor:not-allowed;opacity:.5}.stm-btn-continue{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.stm-btn-continue:hover:not(:disabled){background:#1565c0;border-color:#1565c0;box-shadow:0 6px 16px #1976d24d;transform:translateY(-1px)}.stm-btn-continue:active:not(:disabled){box-shadow:0 2px 8px #1976d233;transform:translateY(0)}.stm-btn-logout{background:#fff;border-color:#e5e7eb;border-color:var(--border-color);color:#6b7280;color:var(--text-medium)}.stm-btn-logout:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#1f2937;color:var(--text-dark);transform:translateY(-1px)}.stm-btn-logout:active:not(:disabled){transform:translateY(0)}.stm-btn-icon{flex-shrink:0}@media (max-width:768px){.stm-modal{max-width:400px}.stm-header{padding:28px 28px 16px}.stm-timer-section{padding:28px 28px 20px}.stm-warning-section{padding:0 28px 16px}.stm-action-section{padding:20px 28px 28px}}@media (max-width:480px){.stm-modal{margin:0 16px;max-width:none}.stm-header{padding:24px 24px 16px}.stm-title{font-size:20px}.stm-subtitle{font-size:13px}.stm-timer-section{padding:24px 24px 20px}.stm-timer-container{height:120px;width:120px}.stm-timer-text{font-size:28px}.stm-warning-section{padding:0 24px 12px}.stm-warning-box{padding:14px}.stm-warning-text{font-size:12px}.stm-action-section{padding:20px 24px 24px}.stm-btn{font-size:13px;padding:13px 16px}}@media (max-width:375px){.stm-overlay{padding:12px}.stm-modal{margin:0 8px}.stm-header{padding:20px 20px 16px}.stm-title{font-size:18px}.stm-timer-section{padding:20px 20px 16px}.stm-timer-container{height:110px;width:110px}.stm-timer-text{font-size:26px}.stm-warning-section{padding:0 20px 12px}.stm-action-section{padding:16px 20px 20px}}@media (prefers-reduced-motion:reduce){.stm-btn,.stm-modal,.stm-overlay,.stm-timer-circle-fg,.stm-timer-container{animation:none;transition:none}.stm-btn:hover:not(:disabled){transform:none}}.stm-btn:focus-visible{outline:3px solid #1976d280;outline-offset:2px}@media (prefers-contrast:high){.stm-modal{border:2px solid #1f2937;border:2px solid var(--text-dark)}.stm-btn,.stm-warning-box{border-width:2px}}:root{--bg-light:#f9fafb}.osce-navbar{background:#fff;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);font-family:Elms Sans,sans-serif;position:-webkit-sticky;position:sticky;top:0;z-index:100}.osce-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:16px 40px}.osce-navbar-left{align-items:center;display:flex;gap:16px}.osce-navbar-logo{background:#0000!important;border:none;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:24px;font-weight:800;letter-spacing:-.5px;padding:0;text-decoration:none;transition:opacity .2s ease}.osce-navbar-logo:hover{opacity:.8}.osce-logo-primary{color:#1976d2;color:var(--primary-blue)}.osce-logo-secondary{color:#7c3aed;color:var(--primary-purple)}.osce-navbar-custom-actions,.osce-navbar-right{align-items:center;display:flex;gap:10px}.osce-navbar-custom-actions{margin-right:8px}.osce-back-button{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.osce-back-button:hover{background:#f9fafb;background:var(--bg-light);border-color:#d1d5db;transform:translateY(-1px)}.osce-nav-back-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;flex-shrink:0;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;height:40px;justify-content:center;padding:8px 12px;transition:all .2s ease;width:40px}.osce-nav-back-btn:hover{background:#f9fafb;background:var(--bg-light);border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.osce-nav-back-btn svg{height:20px;width:20px}.osce-nav-icon-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;height:38px;justify-content:center;padding:8px;position:relative;transition:all .2s ease;width:38px}.osce-nav-icon-btn:hover{background:#f9fafb;background:var(--bg-light);border-color:#d1d5db;transform:translateY(-1px)}.osce-nav-icon-btn.active{background:#1976d21a;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.osce-nav-icon-btn.active:hover{background:#1976d226}.osce-nav-icon-btn svg{flex-shrink:0}.osce-notification-badge{background:#ef4444;border-radius:10px;box-shadow:0 2px 4px #0000001a;color:#fff;font-size:10px;font-weight:600;height:16px;min-width:16px;padding:2px 6px;position:absolute;right:4px;top:4px}.osce-notification-badge,.osce-profile-btn{align-items:center;display:flex;justify-content:center}.osce-profile-btn{background:#0000;border:1px solid #0000;border-radius:8px;cursor:pointer;flex-shrink:0;font-family:Elms Sans,sans-serif;height:44px;padding:4px;position:relative;transition:all .2s ease;width:44px}.osce-profile-btn:hover{background:#f9fafb;background:var(--bg-light);border-color:#e5e7eb;border-color:var(--border-color);transform:scale(1.05)}.osce-profile-btn.active{background:#1976d21a;border-color:#1976d2;border-color:var(--primary-blue)}.osce-profile-btn.active:hover{background:#1976d226}.osce-profile-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:14px;font-weight:600;justify-content:center;overflow:hidden}.osce-profile-avatar,.osce-profile-avatar-img{border:2px solid #e5e7eb;border-radius:50%;flex-shrink:0;height:36px;max-height:36px;max-width:36px;min-height:36px;min-width:36px;width:36px}.osce-profile-avatar-img{display:block;object-fit:cover}.osce-profile-name{display:none}.osce-logout-btn{align-items:center;background:#0000;border:1px solid #ef4444;border-radius:8px;color:#ef4444;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.osce-logout-btn:hover{background:#fee2e2;transform:translateY(-1px)}.osce-logout-btn svg{flex-shrink:0}.osce-nav-links{gap:10px;margin-right:12px}.osce-nav-link,.osce-nav-links{align-items:center;display:flex}.osce-nav-link{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;text-decoration:none;transition:all .2s ease}.osce-nav-link:hover{background:#f9fafb;background:var(--bg-light);border-color:#d1d5db;transform:translateY(-1px)}.osce-nav-link.active{background:#1976d21a;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue);font-weight:600}@media (max-width:1024px){.osce-navbar-container{padding:14px 24px}.osce-navbar-logo{font-size:22px}.osce-nav-link span:last-child{display:none}.osce-nav-link{font-size:16px;padding:8px}.osce-profile-btn{height:40px;padding:3px;width:40px}.osce-profile-avatar{font-size:13px}.osce-profile-avatar,.osce-profile-avatar-img{height:34px;max-height:34px;max-width:34px;min-height:34px;min-width:34px;width:34px}}@media (max-width:768px){.osce-navbar-container{padding:12px 20px}.osce-navbar-logo{font-size:20px}.osce-logout-btn span,.osce-nav-links{display:none}.osce-logout-btn{justify-content:center;min-width:38px;padding:8px}.osce-navbar-right{gap:7px}.osce-back-button{font-size:12px;padding:7px 12px}.osce-profile-btn{height:38px;padding:3px;width:38px}.osce-profile-avatar{font-size:12px}.osce-profile-avatar,.osce-profile-avatar-img{height:32px;max-height:32px;max-width:32px;min-height:32px;min-width:32px;width:32px}.osce-nav-icon-btn{height:36px;padding:7px;width:36px}.osce-nav-icon-btn svg{height:18px;width:18px}}@media (max-width:480px){.osce-navbar-container{padding:10px 16px}.osce-navbar-logo{font-size:18px}.osce-navbar-right{gap:6px}.osce-back-button{font-size:11px;gap:4px;padding:6px 10px}.osce-nav-icon-btn{height:34px;padding:6px;width:34px}.osce-nav-icon-btn svg{height:16px;width:16px}.osce-profile-btn{height:36px;padding:3px;width:36px}.osce-profile-avatar{font-size:11px}.osce-profile-avatar,.osce-profile-avatar-img{height:30px;max-height:30px;max-width:30px;min-height:30px;min-width:30px;width:30px}.osce-logout-btn{min-width:34px;padding:7px}.osce-logout-btn svg{height:16px;width:16px}}@media (hover:none) and (pointer:coarse){.osce-back-button:hover,.osce-logout-btn:hover,.osce-nav-icon-btn:hover,.osce-nav-link:hover,.osce-profile-btn:hover{transform:none}.osce-logout-btn,.osce-nav-icon-btn,.osce-profile-btn{min-height:44px;min-width:44px}}.osce-back-button:focus-visible,.osce-logout-btn:focus-visible,.osce-nav-icon-btn:focus-visible,.osce-nav-link:focus-visible,.osce-profile-btn:focus-visible{outline:2px solid #1976d2;outline:2px solid var(--primary-blue);outline-offset:2px}.osce-profile-btn.loading .osce-profile-avatar,.osce-profile-btn.loading .osce-profile-avatar-img{animation:pulse 1.5s ease-in-out infinite;opacity:.5}@media print{.osce-navbar{display:none}}.osce-navbar-logo-img{background:#0000!important;display:block;height:40px;object-fit:contain;transition:transform .2s ease;width:auto}.osce-navbar-logo:hover .osce-navbar-logo-img{transform:scale(1.05)}@media (max-width:768px){.osce-navbar-logo-img{height:32px}}:root{--osce-blue:#2563eb;--osce-purple:#7c3aed;--osce-blue-light:#dbeafe;--osce-purple-light:#e9d5ff;--gray-50:#fafafa;--gray-100:#f4f4f5;--gray-200:#e4e4e7;--gray-300:#d4d4d8;--gray-400:#a1a1aa;--gray-500:#71717a;--gray-600:#52525b;--gray-700:#3f3f46;--gray-800:#27272a;--gray-900:#18181b;--font-main:"Elms Sans",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif}.oscepal-vapi-container{background:#f8f9fa;color:#18181b;color:var(--gray-900);display:flex;flex-direction:column;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);height:100vh;overflow:hidden}.oscepal-vapi-top-bar{background:#fff;border-bottom:1px solid #e4e4e7;border-bottom:1px solid var(--gray-200);flex-shrink:0;padding:12px 0;z-index:50}.oscepal-vapi-top-bar-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 24px}.oscepal-vapi-logo-header{cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:24px;font-weight:700;-webkit-user-select:none;user-select:none}.oscepal-vapi-logo-osce{color:#2563eb;color:var(--osce-blue)}.oscepal-vapi-logo-pal{color:#7c3aed;color:var(--osce-purple)}.oscepal-vapi-exit-btn{background:none;border:none;border-radius:6px;color:#52525b;color:var(--gray-600);cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.oscepal-vapi-exit-btn:hover{background:#fee2e2;color:#ef4444;color:var(--error)}.oscepal-vapi-info-bar{background:#fff;border-bottom:1px solid #e4e4e7;border-bottom:1px solid var(--gray-200);flex-shrink:0;padding:16px 0}.oscepal-vapi-info-bar-content{grid-gap:24px;align-items:center;display:grid;gap:24px;grid-template-columns:2fr 1.2fr .8fr;margin:0 auto;max-width:1400px;padding:0 24px}.oscepal-vapi-case-info-left{display:flex;flex-direction:column;gap:6px}.oscepal-vapi-case-badge-new{background:#dbeafe;background:var(--osce-blue-light);border-radius:4px;color:#2563eb;color:var(--osce-blue);display:inline-block;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;width:-webkit-fit-content;width:fit-content}.oscepal-vapi-case-badge-new,.oscepal-vapi-case-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main)}.oscepal-vapi-case-title{color:#18181b;color:var(--gray-900);font-size:20px;font-weight:600;line-height:1.2;margin:0}.oscepal-vapi-case-details{align-items:center;color:#52525b;color:var(--gray-600);display:flex;flex-wrap:wrap;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:14px;gap:8px}.oscepal-vapi-separator{color:#a1a1aa;color:var(--gray-400)}.oscepal-vapi-vitals-section{background:#fafafa;background:var(--gray-50);border:1px solid #e4e4e7;border:1px solid var(--gray-200);border-radius:8px;padding:12px 16px}.oscepal-vapi-vitals-label{color:#71717a;color:var(--gray-500);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px}.oscepal-vapi-vitals-label,.oscepal-vapi-vitals-values{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main)}.oscepal-vapi-vitals-values{align-items:center;color:#3f3f46;color:var(--gray-700);display:flex;flex-wrap:wrap;font-size:12px;gap:8px;margin-bottom:4px}.oscepal-vapi-vitals-values:last-child{margin-bottom:0}.oscepal-vapi-timer-section{text-align:right}.oscepal-vapi-timer-value{color:#27272a;color:var(--gray-800);font-family:Courier New,monospace;font-size:28px;font-weight:700;line-height:1;margin-bottom:4px}.oscepal-vapi-timer-text{color:#71717a;color:var(--gray-500);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:12px}.oscepal-vapi-module-content{background:#fff;border-bottom:1px solid #e4e4e7;border-bottom:1px solid var(--gray-200);flex-shrink:0;max-height:300px;overflow-y:auto;padding:16px 24px}.oscepal-vapi-module-content-inner{margin:0 auto;max-width:1400px}.oscepal-vapi-content-title{color:#2563eb;color:var(--osce-blue);font-size:16px;font-weight:600;margin:0 0 12px;text-align:center}.oscepal-vapi-content-title,.oscepal-vapi-prescription-content{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main)}.oscepal-vapi-prescription-content{color:#333;font-size:12px;line-height:1.4}.oscepal-vapi-ecg-container{text-align:center}.oscepal-vapi-ecg-thumbnail{border:2px solid #e4e4e7;border:2px solid var(--gray-200);border-radius:8px;cursor:pointer;height:auto;max-width:300px;transition:all .2s;width:100%}.oscepal-vapi-ecg-thumbnail:hover{border-color:#2563eb;border-color:var(--osce-blue);transform:scale(1.02)}.oscepal-vapi-ecg-hint{color:#71717a;color:var(--gray-500);font-size:12px;margin:8px 0 0}.oscepal-vapi-ecg-hint,.oscepal-vapi-status-message{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-style:italic}.oscepal-vapi-status-message{background:#f8f9fa;border-bottom:1px solid #e4e4e7;border-bottom:1px solid var(--gray-200);color:#52525b;color:var(--gray-600);font-size:13px;padding:12px 24px;text-align:center}.oscepal-vapi-chat-area{background:#f8f9fa;flex:1 1;overflow-y:auto;padding:24px;scroll-behavior:smooth}.oscepal-vapi-messages-wrapper{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:900px;padding-bottom:120px}.oscepal-vapi-msg{align-items:flex-start;animation:slideIn .3s ease-out;display:flex;gap:12px}.oscepal-vapi-msg-user{align-self:flex-end;flex-direction:row-reverse;max-width:75%}.oscepal-vapi-msg-ai{align-self:flex-start;flex-direction:row;max-width:75%}.oscepal-vapi-msg-avatar{flex-shrink:0}.oscepal-vapi-avatar-circle{align-items:center;border-radius:50%;display:flex;font-size:20px;height:40px;justify-content:center;overflow:hidden;width:40px}.oscepal-vapi-avatar-doctor{background:#2563eb;background:var(--osce-blue);color:#fff}.oscepal-vapi-avatar-patient{background:#7c3aed;background:var(--osce-purple);color:#fff}.oscepal-vapi-avatar-circle img{height:100%;object-fit:cover;width:100%}.oscepal-vapi-msg-bubble{word-wrap:break-word;border-radius:16px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:15px;line-height:1.5;padding:12px 16px}.oscepal-vapi-msg-user .oscepal-vapi-msg-bubble{background:#2563eb;background:var(--osce-blue);border-bottom-right-radius:4px;color:#fff}.oscepal-vapi-msg-ai .oscepal-vapi-msg-bubble{background:#fff;border:1px solid #e4e4e7;border:1px solid var(--gray-200);border-bottom-left-radius:4px;color:#27272a;color:var(--gray-800)}.oscepal-vapi-bottom-bar{background:#fff;border-top:1px solid #e4e4e7;border-top:1px solid var(--gray-200);bottom:0;box-shadow:0 -2px 10px #0000000d;left:0;padding:20px 0;position:fixed;right:0;z-index:100}.oscepal-vapi-bottom-bar-content{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto;max-width:900px;padding:0 24px}.oscepal-vapi-control-btn{align-items:center;background:#fff;border:1px solid #d4d4d8;border:1px solid var(--gray-300);border-radius:8px;color:#3f3f46;color:var(--gray-700);cursor:pointer;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .2s;white-space:nowrap}.oscepal-vapi-control-btn:hover{background:#fafafa;background:var(--gray-50);border-color:#a1a1aa;border-color:var(--gray-400)}.oscepal-vapi-control-btn:disabled{cursor:not-allowed;opacity:.5}.oscepal-vapi-btn-icon{font-size:16px}.oscepal-vapi-btn-end{border-color:#ef4444;border-color:var(--error);color:#ef4444;color:var(--error)}.oscepal-vapi-btn-end:hover{background:#fee2e2}.oscepal-vapi-mic-wrapper{align-items:center;display:flex;flex-direction:column;gap:8px}.oscepal-vapi-mic-btn{align-items:center;background:#2563eb;background:var(--osce-blue);border:none;border-radius:50%;box-shadow:0 4px 12px #2563eb4d;color:#fff;cursor:pointer;display:flex;font-size:32px;height:70px;justify-content:center;outline:none;position:relative;transition:all .2s;width:70px}.oscepal-vapi-mic-btn:hover{box-shadow:0 6px 16px #2563eb66;transform:scale(1.05)}.oscepal-vapi-mic-btn:disabled{cursor:not-allowed;opacity:.6}.oscepal-vapi-mic-active{animation:pulse 1.5s infinite;background:#ef4444;background:var(--error)}.oscepal-vapi-mic-connecting{animation:pulse 1s infinite}.oscepal-vapi-mic-icon{font-size:32px}.oscepal-vapi-mic-label{color:#71717a;color:var(--gray-500);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:12px;text-align:center}.oscepal-vapi-ecg-modal{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;touch-action:none;z-index:1000}.oscepal-vapi-ecg-modal-content{background:#fff;border-radius:12px;height:90vh;overflow:hidden;position:relative;width:90vw}.oscepal-vapi-ecg-controls{display:flex;flex-direction:column;gap:8px;left:10px;position:absolute;top:10px;z-index:1001}.oscepal-vapi-ecg-btn{align-items:center;background:#000000b3;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:18px;font-weight:600;height:40px;justify-content:center;transition:background .2s;width:40px}.oscepal-vapi-ecg-btn:hover{background:#000000d9}.oscepal-vapi-ecg-btn-reset{font-size:12px}.oscepal-vapi-ecg-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:300;height:40px;justify-content:center;position:absolute;right:10px;top:10px;width:40px;z-index:1001}.oscepal-vapi-ecg-close:hover{background:#000000d9}.oscepal-vapi-ecg-zoom-indicator{font-size:12px;font-weight:500;left:10px}.oscepal-vapi-ecg-instructions,.oscepal-vapi-ecg-zoom-indicator{background:#000000b3;border-radius:6px;bottom:10px;color:#fff;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);padding:6px 10px;position:absolute;z-index:1001}.oscepal-vapi-ecg-instructions{font-size:11px;max-width:140px;right:10px;text-align:center}.oscepal-vapi-ecg-image{height:100%;object-fit:contain;width:100%}.oscepal-vapi-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2000}.oscepal-vapi-modal-box{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:90vw;min-width:360px;padding:32px 28px 24px;text-align:center}.oscepal-vapi-modal-title{color:#18181b;color:var(--gray-900);font-size:20px;font-weight:700;margin:0 0 12px}.oscepal-vapi-modal-text,.oscepal-vapi-modal-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main)}.oscepal-vapi-modal-text{color:#52525b;color:var(--gray-600);font-size:15px;line-height:1.5;margin:0 0 24px}.oscepal-vapi-modal-actions{display:flex;gap:12px;justify-content:center}.oscepal-vapi-modal-btn{border:none;border-radius:8px;cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.oscepal-vapi-modal-btn-confirm{background:#ef4444;background:var(--error);box-shadow:0 2px 8px #ef444433;color:#fff}.oscepal-vapi-modal-btn-confirm:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d}.oscepal-vapi-modal-btn-cancel{background:#e4e4e7;background:var(--gray-200);color:#3f3f46;color:var(--gray-700)}.oscepal-vapi-modal-btn-cancel:hover{background:#d4d4d8;background:var(--gray-300)}@media (max-width:1024px){.oscepal-vapi-info-bar-content{gap:16px;grid-template-columns:1fr}.oscepal-vapi-timer-section{text-align:left}}@media (max-width:768px){.oscepal-vapi-bottom-bar-content,.oscepal-vapi-info-bar-content,.oscepal-vapi-top-bar-content{padding:0 16px}.oscepal-vapi-chat-area{padding:16px}.oscepal-vapi-messages-wrapper{gap:16px}.oscepal-vapi-msg-ai,.oscepal-vapi-msg-user{max-width:85%}.oscepal-vapi-bottom-bar-content{gap:16px}.oscepal-vapi-control-btn{font-size:0;padding:10px 12px}.oscepal-vapi-btn-icon{font-size:18px}.oscepal-vapi-mic-btn{font-size:28px;height:60px;width:60px}.oscepal-vapi-vitals-section{display:none}.oscepal-vapi-case-title{font-size:18px}.oscepal-vapi-case-details{font-size:13px}}.oscepal-vapi-case-badge-new,.oscepal-vapi-case-details,.oscepal-vapi-case-title,.oscepal-vapi-content-title,.oscepal-vapi-control-btn,.oscepal-vapi-ecg-btn,.oscepal-vapi-ecg-hint,.oscepal-vapi-ecg-instructions,.oscepal-vapi-ecg-zoom-indicator,.oscepal-vapi-exit-btn,.oscepal-vapi-logo-header,.oscepal-vapi-mic-label,.oscepal-vapi-modal-btn,.oscepal-vapi-modal-text,.oscepal-vapi-modal-title,.oscepal-vapi-msg-bubble,.oscepal-vapi-prescription-content,.oscepal-vapi-status-message,.oscepal-vapi-timer-text,.oscepal-vapi-vitals-label,.oscepal-vapi-vitals-values{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main)}.feedback-screen-body{background:#f9fafb;background:var(--gray-50);color:#111827;color:var(--gray-900);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);margin:0;padding:0}.feedback-navbar{background:#fff;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);position:-webkit-sticky;position:sticky;top:0;z-index:100}.feedback-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:16px 24px}.feedback-navbar-logo{color:#111827;color:var(--gray-900);cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:24px;font-weight:700;text-decoration:none}.feedback-logo-osce{color:#2563eb;color:var(--primary)}.feedback-logo-pal{color:#7c3aed;color:var(--secondary)}.feedback-logout-btn{background:#ef4444;border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.feedback-logout-btn:hover{background:#dc2626;transform:translateY(-1px)}.feedback-main-container{margin:0 auto;max-width:1280px;padding:24px}.feedback-page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.feedback-breadcrumb{align-items:center;display:flex;font-size:14px;gap:8px;margin-bottom:8px}.feedback-breadcrumb,.feedback-breadcrumb-link{color:#6b7280;color:var(--gray-500);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.feedback-breadcrumb-link{cursor:pointer;text-decoration:none;transition:color .2s}.feedback-breadcrumb-link:hover{color:#2563eb;color:var(--primary)}.feedback-page-title{color:#111827;color:var(--gray-900);font-size:28px;font-weight:700;margin:0}.feedback-btn,.feedback-page-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.feedback-btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.feedback-btn-primary{background:#2563eb;background:var(--primary);border:none;color:#fff}.feedback-btn-primary:hover{background:#1d4ed8;background:var(--primary-hover);transform:translateY(-1px)}.feedback-btn-secondary{background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);color:#374151;color:var(--gray-700)}.feedback-btn-secondary:hover{background:#f9fafb;background:var(--gray-50);border-color:#9ca3af;border-color:var(--gray-400);transform:translateY(-1px)}.feedback-modal-container{background:#fff;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);margin:0 auto;max-width:900px;overflow:hidden}.feedback-modal-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;gap:16px;padding:24px}.feedback-patient-avatar{border-radius:50%;height:64px;object-fit:cover;width:64px}.feedback-patient-info{flex:1 1}.feedback-patient-name{color:#111827;color:var(--gray-900);font-size:20px;font-weight:700;margin:0 0 4px}.feedback-patient-condition,.feedback-patient-name{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.feedback-patient-condition{color:#4b5563;color:var(--gray-600);font-size:14px;margin:0}.feedback-condition-label{color:#6b7280;color:var(--gray-500);display:block;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:12px;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.feedback-modal-body{background:#fafbfc;max-height:calc(100vh - 250px);overflow-y:auto;padding:32px}.feedback-section{margin-bottom:32px}.feedback-section:last-of-type{margin-bottom:0}.feedback-section-title{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--gray-200);color:#111827;color:var(--gray-900);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;font-weight:700;margin:0 0 20px;padding-bottom:12px}.feedback-loading-container{align-items:center;background:#f9fafb;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:12px;padding:20px}.feedback-loading-text{color:#4b5563;color:var(--gray-600);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px}.feedback-spinner{animation:feedback-spin 1s linear infinite;border:3px solid #d1d5db;border-top:3px solid #2563eb;border:3px solid var(--gray-300);border-radius:50%;border-top-color:var(--primary);height:24px;width:24px}@keyframes feedback-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.feedback-error-message{background:#fee2e2;background:var(--error-bg);border-left:4px solid #ef4444;border-left:4px solid var(--error);border-radius:8px;border-radius:var(--radius-md);color:#ef4444;color:var(--error);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);padding:16px}.feedback-success-eval-box{background:#fff;border:1px solid #d1fae5;border-left:4px solid #10b981;border-left:4px solid var(--success);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.feedback-success-eval-title{color:#065f46;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:15px;font-weight:700;margin:0 0 12px}.feedback-success-eval-content{color:#1f2937;color:var(--gray-800);font-size:15px;line-height:1.7}.feedback-success-eval-content,.feedback-success-eval-content *{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.feedback-success-eval-content h1,.feedback-success-eval-content h2,.feedback-success-eval-content h3,.feedback-success-eval-content h4{color:#111827;color:var(--gray-900);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:600;margin-bottom:8px;margin-top:16px}.feedback-success-eval-content h1{font-size:20px}.feedback-success-eval-content h2{font-size:18px}.feedback-success-eval-content h3{font-size:16px}.feedback-success-eval-content h4{font-size:15px}.feedback-success-eval-content p{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 0 14px}.feedback-success-eval-content p:last-child{margin-bottom:0}.feedback-success-eval-content ol,.feedback-success-eval-content ul{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:12px 0;padding-left:24px}.feedback-success-eval-content li{line-height:1.6;margin:6px 0}.feedback-success-eval-content li,.feedback-success-eval-content strong{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.feedback-success-eval-content strong{color:#111827;color:var(--gray-900);font-weight:600}.feedback-success-eval-content em{font-style:italic}.feedback-content,.feedback-success-eval-content em{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.feedback-content{color:#1f2937;color:var(--gray-800);font-size:15px;line-height:1.7}.feedback-content *{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.feedback-content h1,.feedback-content h2,.feedback-content h3,.feedback-content h4{color:#111827;color:var(--gray-900);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:600;margin-bottom:10px;margin-top:20px}.feedback-content h1{font-size:22px}.feedback-content h2{font-size:20px}.feedback-content h3{font-size:18px}.feedback-content h4{font-size:16px}.feedback-content p{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 0 14px}.feedback-content p:last-child{margin-bottom:0}.feedback-content ol,.feedback-content ul{margin:12px 0;padding-left:24px}.feedback-content li,.feedback-content ol,.feedback-content ul{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.feedback-content li{line-height:1.6;margin:6px 0}.feedback-content strong{color:#111827;color:var(--gray-900);font-weight:600}.feedback-content em,.feedback-content strong{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.feedback-content em{font-style:italic}.feedback-content code{border-radius:4px;font-size:14px;padding:2px 6px}.feedback-content code,.feedback-content pre{background:#f3f4f6;background:var(--gray-100);font-family:Elms Sans,Courier New,monospace}.feedback-content pre{border-radius:8px;border-radius:var(--radius-md);margin:12px 0;overflow-x:auto;padding:12px}.feedback-content blockquote{border-left:4px solid #2563eb;border-left:4px solid var(--primary);color:#4b5563;color:var(--gray-600);font-style:italic;margin:12px 0;padding-left:16px}.feedback-rating-section{background:#f9fafb;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);margin-bottom:24px;padding:24px;text-align:center}.feedback-rating-title{color:#111827;color:var(--gray-900);font-size:16px;font-weight:600;margin:0 0 16px}.feedback-rating-saved,.feedback-rating-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.feedback-rating-saved{color:#10b981;color:var(--success);font-size:14px;font-weight:500;margin-top:12px}.feedback-text-feedback-section{background:#f9fafb;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);margin-bottom:24px;padding:24px}.feedback-text-feedback-title{color:#111827;color:var(--gray-900);font-size:16px;font-weight:600;margin:0 0 12px;text-align:center}.feedback-text-feedback-title,.feedback-textarea{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.feedback-textarea{border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);box-sizing:border-box;font-size:14px;min-height:80px;padding:12px;resize:vertical;transition:border-color .2s;width:100%}.feedback-textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 2px #dbeafe;box-shadow:0 0 0 2px var(--primary-light);outline:none}.feedback-textarea:disabled{background:#f3f4f6;background:var(--gray-100);color:#6b7280;color:var(--gray-500);cursor:not-allowed}.feedback-meta{align-items:center;color:#6b7280;color:var(--gray-500);display:flex;font-size:12px;justify-content:space-between;margin-top:8px}.feedback-meta-text{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.feedback-saved{color:#10b981;color:var(--success);font-weight:500}.feedback-modal-footer{background:#fff;border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;gap:12px;justify-content:center;padding:20px 24px}@media (max-width:768px){.feedback-main-container{padding:16px}.feedback-page-header{flex-direction:column;gap:16px}.feedback-modal-header{align-items:flex-start;flex-direction:column}.feedback-patient-avatar{height:48px;width:48px}.feedback-modal-footer{flex-direction:column}.feedback-btn{justify-content:center;width:100%}}@media (max-width:480px){.feedback-navbar-container{padding:12px 16px}.feedback-logout-btn{font-size:12px;padding:6px 12px}.feedback-modal-body,.feedback-modal-header{padding:16px}.feedback-page-title{font-size:24px}.feedback-patient-name{font-size:18px}}.floating-navbar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#ffffff4d;display:flex;gap:24px;justify-content:space-between;left:50%;margin:0 auto;max-width:1800px;padding:12px 40px;position:fixed;transform:translateX(-50%);transition:background-color .3s ease,border-radius .3s ease,box-shadow .3s ease;width:calc(100% - 80px);z-index:1000}.navbar-fixed-top{animation:slideUp .4s cubic-bezier(.4,0,.2,1) forwards;border-radius:0;box-shadow:none;left:0;margin:0;max-width:100%;right:0;top:0;transform:none}.navbar-floating{animation:popOutVertical .5s cubic-bezier(.34,1.56,.64,1) forwards;border-radius:16px;box-shadow:0 2px 15px #00000014,0 1px 4px rgba(0,0,0,.046);top:20px}@keyframes popOutVertical{0%{opacity:0;transform:translateX(-50%) translateY(-30px) scale(.9)}60%{transform:translateX(-50%) translateY(8px) scale(1.03)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.navbar-brand-container{align-items:flex-start;display:flex;flex-direction:column;flex-shrink:0}.navbar-brand{align-items:flex-start;cursor:pointer;display:flex;gap:12px;line-height:1.2;transition:all .3s cubic-bezier(.4,0,.2,1)}.navbar-brand-text-container{align-items:flex-start;display:flex;flex-direction:column}.navbar-logo-img{flex-shrink:0;height:40px;object-fit:contain;width:auto}.navbar-brand-text,.navbar-logo-img{transition:all .3s cubic-bezier(.4,0,.2,1)}.navbar-brand-text{color:#1976d2;font-family:Elms Sans,sans-serif;font-size:25px;font-weight:700;letter-spacing:-.5px}.navbar-brand:hover .navbar-logo-img{opacity:.9;transform:scale(1.05)}.navbar-brand:hover .navbar-brand-text{color:#1565c0}.navbar-powered-by{color:#1d1d1d;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:400;letter-spacing:.3px;line-height:1;margin-top:-3px;text-transform:lowercase}.navbar-mobile-toggle{background:none;border:none;color:#333;cursor:pointer;display:none;padding:8px;transition:color .3s ease;z-index:1001}.navbar-mobile-toggle:hover{color:#1976d2}.navbar-links{align-items:center;display:flex;flex:1 1;gap:32px;justify-content:center}.new-badge{color:#1976d2;font-size:9px;font-weight:700;letter-spacing:.3px;margin-left:3px;text-transform:uppercase;top:-4px;vertical-align:super}.nav-link,.new-badge{display:inline-block;font-family:Elms Sans,sans-serif;position:relative}.nav-link{background:none;border:none;border-radius:20px;color:#333;cursor:pointer;font-size:16px;font-weight:500;padding:8px 16px;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.nav-link:after{background:#1976d2;border-radius:2px;bottom:6px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%) scaleX(0);transition:transform .3s cubic-bezier(.4,0,.2,1);width:calc(100% - 32px)}.nav-link:hover{background-color:#1976d214;color:#1976d2;transform:translateY(-1px)}.nav-link:hover:after{transform:translateX(-50%) scaleX(1)}.nav-link:active{transform:translateY(0)}.navbar-mobile-get-started{display:none}.navbar-get-started{background:#0000;border:2px solid #1976d2;border-radius:6px;color:#1976d2;cursor:pointer;flex-shrink:0;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;overflow:hidden;padding:10px 24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.navbar-get-started:before{background:linear-gradient(90deg,#0000,#1976d21a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.navbar-get-started:hover{background:#1976d214;border-color:#1565c0;box-shadow:0 6px 16px #1976d240;color:#1565c0;transform:translateY(-2px)}.navbar-get-started:hover:before{left:100%}.navbar-get-started:active{box-shadow:0 2px 8px #1976d233;transform:translateY(0)}@media (max-width:1024px){.floating-navbar{gap:16px;padding:10px 24px;width:calc(100% - 48px)}.navbar-brand{font-size:clamp(16px,2vw,20px)}.nav-link{padding:6px 12px}.nav-link,.navbar-get-started{font-size:clamp(13px,1.5vw,16px)}.navbar-get-started{padding:8px 18px}}@media (max-width:768px){.floating-navbar.navbar-floating{width:calc(100% - 40px)}.floating-navbar.navbar-fixed-top{left:0;transform:none;width:100%}.floating-navbar{gap:12px;padding:10px 16px}.navbar-brand{font-size:clamp(16px,2.5vw,18px);gap:10px}.navbar-logo-img{height:32px}.navbar-brand-text{font-size:clamp(18px,2.2vw,22px)}.navbar-powered-by{font-size:clamp(9px,1.1vw,10px)}.navbar-links{gap:8px}.nav-link{font-size:clamp(12px,1.8vw,14px);padding:6px 10px}.new-badge{font-size:7px}.navbar-get-started{font-size:clamp(12px,1.8vw,14px);padding:8px 14px}}@media (max-width:600px){.floating-navbar.navbar-floating{padding:8px 12px;width:calc(100% - 32px)}.floating-navbar.navbar-fixed-top{left:0;padding:8px 12px;transform:none;width:100%}.navbar-brand{gap:8px}.navbar-logo-img{height:30px}.navbar-brand-text{font-size:17px}.navbar-powered-by{font-size:9px}.navbar-links{gap:4px}.nav-link{font-size:12px;padding:6px 8px}.navbar-get-started{font-size:12px;padding:6px 12px}}@media (max-width:480px){.navbar-mobile-toggle{display:block;position:relative;z-index:1003!important}.floating-navbar.navbar-floating{animation:none;border-radius:0;box-shadow:none;left:0;margin:0;right:0;top:0;transform:none;width:100%}.floating-navbar.navbar-menu-open{z-index:1001}.navbar-mobile-backdrop{background:#fff;z-index:1000}.navbar-links,.navbar-mobile-backdrop{bottom:0;height:100vh;left:0;position:fixed;right:0;top:0;width:100vw}.navbar-links{align-items:center;-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000!important;flex-direction:column;gap:24px;justify-content:flex-start;margin:0;max-width:100%;opacity:1!important;padding-left:0;padding-right:0;padding-top:80px;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1001!important}.navbar-links .nav-link{position:relative;z-index:1002}.navbar-links-open{transform:translateX(0)}.nav-link{font-size:18px;padding:12px 24px;width:auto}.floating-navbar{gap:8px;justify-content:space-between;left:0;transform:none;width:100%}.navbar-brand{font-size:18px;gap:8px}.navbar-logo-img{height:28px}.navbar-brand-text{font-size:16px}.navbar-powered-by{font-size:9px;margin-top:-2px}.navbar-get-started{display:none}.navbar-mobile-get-started{align-items:center!important;background:#0000!important;border:2px solid #1976d2!important;border-radius:12px!important;box-shadow:none;color:#1976d2!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;margin-top:24px;max-width:280px;min-width:auto;padding:14px 24px!important;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)!important;white-space:nowrap;width:calc(100% - 48px);z-index:1002}.navbar-mobile-get-started:hover{background:#1976d20d!important;border-color:#1565c0!important;box-shadow:0 4px 12px #1976d226!important;color:#1565c0!important;transform:translateY(-2px)}.navbar-mobile-get-started:after{display:none}.navbar-mobile-get-started:active{box-shadow:none!important;transform:translateY(0)}.navbar-mobile-arrow{flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1)}.navbar-mobile-get-started:hover .navbar-mobile-arrow{transform:translateX(4px)}}body.home-page{background:#fff;height:100vh;overflow-x:hidden;overflow-y:auto;width:100vw}.wrapper{background:#fff;min-height:100vh}.hero-section,.wrapper{position:relative;width:100%}.hero-section{align-items:center;display:flex;height:100vh;justify-content:center;overflow:hidden;padding:0}.hero-section:after{background:linear-gradient(180deg,#fff0 0,#ffffff80 50%,#fff);content:"";height:200px;pointer-events:none;z-index:3}.blurer,.hero-section:after{bottom:0;left:0;position:absolute;width:100%}.blurer{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#ffffff1a;border-radius:0;display:flex;flex-direction:column;font-family:Elms Sans,sans-serif;height:100%;justify-content:center;overflow:visible;padding:40px 20px;right:0;top:0;z-index:1}.floating-tooltips-above{height:50px;left:0;position:absolute;top:-70px}.floating-tooltips-above,.floating-tooltips-below{overflow:visible;pointer-events:none;width:100%;z-index:10}.floating-tooltips-below{align-items:center;display:flex;gap:40px;justify-content:center;margin-top:40px;position:relative}.hero-start-trial-button{align-self:center;animation:shadowPulse 2s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000;border:2px solid #1976d2;border-radius:8px;color:#1976d2;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:clamp(1rem,1.5vw,1.1rem);font-weight:600;margin-top:48px;overflow:visible;padding:14px 32px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10}.hero-start-trial-button:hover{animation:none;background:#1976d2;border-color:#1976d2;box-shadow:0 6px 20px #1976d266;color:#fff;transform:translateY(-2px)}.hero-start-trial-button:active{box-shadow:0 2px 8px #1976d24d;transform:translateY(0)}@keyframes shadowPulse{0%{box-shadow:0 0 0 0 #1976d266}50%{box-shadow:0 0 0 8px #1976d21a}to{box-shadow:0 0 0 0 #1976d200}}.floating-tooltip{animation:fadeInStay 2s forwards,subtleBounce 2s cubic-bezier(.4,0,.2,1) infinite;animation-delay:0s,2s;animation-delay:var(--delay,0s),calc(var(--delay, 0s) + 2s);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 4px 12px #00000026;color:#333;font-family:Elms Sans,sans-serif;font-size:clamp(.7rem,1.5vw,.8rem);opacity:0;padding:8px 14px;position:absolute;top:10px;white-space:nowrap;will-change:transform}.floating-tooltips-above .floating-tooltip:first-child{animation-delay:0s,2s;left:25%}.floating-tooltips-above .floating-tooltip:nth-child(2){animation-delay:.3s,2.3s;animation-name:fadeInStayRight,subtleBounceRight;left:75%}.floating-tooltips-below .floating-tooltip{animation-name:fadeInStay,subtleBounce;left:auto;position:relative;top:auto}.floating-tooltips-below .floating-tooltip:first-child{animation-delay:0s,2s}.floating-tooltips-below .floating-tooltip:nth-child(2){animation-delay:.3s,2.3s}@keyframes fadeInStay{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes subtleBounce{0%,to{transform:translateY(0)}25%{transform:translateY(-2px)}50%{transform:translateY(-4px)}75%{transform:translateY(-2px)}}@keyframes subtleBounceRight{0%,to{transform:translateX(-100%) translateY(0)}25%{transform:translateX(-100%) translateY(-2px)}50%{transform:translateX(-100%) translateY(-4px)}75%{transform:translateX(-100%) translateY(-2px)}}@keyframes subtleBounceCenter{0%,to{transform:translateX(-50%) translateY(0)}25%{transform:translateX(-50%) translateY(-2px)}50%{transform:translateX(-50%) translateY(-4px)}75%{transform:translateX(-50%) translateY(-2px)}}@keyframes fadeInStayRight{0%{opacity:0;transform:translateX(-100%) translateY(10px) scale(.95)}to{opacity:1;transform:translateX(-100%) translateY(0) scale(1)}}@keyframes fadeInStayCenter{0%{opacity:0;transform:translateX(-50%) translateY(10px) scale(.95)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.home-content{align-items:flex-start;display:flex;flex-direction:column;gap:24px;margin:0 auto;max-width:1000px;padding:0 20px;position:relative;text-align:left;width:100%;z-index:2}.hero-logo-container{align-items:center;display:flex;justify-content:center;margin-bottom:24px;width:100%}.hero-logo-img{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));height:60px;object-fit:contain;transition:all .3s cubic-bezier(.4,0,.2,1);width:auto}.hero-logo-container:hover .hero-logo-img{opacity:.9;transform:scale(1.05)}.home-description-section{display:flex;flex-direction:column;gap:16px;margin-left:auto;margin-right:auto;margin-top:-45px;max-width:800px;width:100%}.now-live-badge{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#b0e0e6e6;border:1px solid #b0e0e680;border-radius:50px;box-shadow:0 2px 8px #0000001a;color:#0d47a1;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:clamp(.85rem,1.2vw,1rem);font-weight:600;gap:8px;margin:0 auto 24px;padding:8px 20px}.badge-dot{background:#1976d2;border-radius:50%;display:inline-block;height:8px;width:8px}.home-heading{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#000,#b0b0b0);-webkit-background-clip:text;background-clip:text;font-family:Elms Sans,sans-serif;font-size:clamp(3.5rem,6vw,4.5rem);font-weight:600;letter-spacing:-.5px;line-height:1.2;margin:0 auto;max-width:1000px;text-align:center;text-shadow:0 2px 4px #0d47a11a;width:100%}.heading-italic{-webkit-text-fill-color:#d32f2f;background:none;color:#d32f2f;font-style:italic}.heading-italic-underline{text-decoration:underline;-webkit-text-decoration-color:#0d47a1;text-decoration-color:#0d47a1;text-decoration-thickness:3px;text-underline-offset:4px}.heading-highlight{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#2563eb,#14b8a6);-webkit-background-clip:text;background-clip:text}.home-description{color:#333;font-family:Elms Sans,sans-serif;font-size:clamp(1.2rem,2.5vw,1.5rem);line-height:1.7;margin:50px 0 0;max-width:800px;text-align:left;width:100%}.home-get-started{background:#1976d2;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:1.1rem;font-weight:600;margin-top:8px;padding:14px 32px;transition:all .3s cubic-bezier(.4,0,.2,1)}.home-get-started:hover{background:#1565c0;box-shadow:0 6px 16px #1976d24d;transform:translateY(-2px)}.home-get-started:active{transform:translateY(0)}h1,h2,h3,h4,h5,h6{font-family:Stack Sans Notch,sans-serif}h2{color:#222;font-size:2.5em;text-align:justify}.used-by-section{background:#fff;padding:60px 20px;text-align:center}.used-by-heading{color:#000;font-family:Elms Sans,sans-serif;font-size:clamp(1.2rem,2.4vw,2rem);font-weight:700;letter-spacing:-.5px;margin:0 0 16px;text-transform:none}.used-by-description{color:#666;font-family:Elms Sans,sans-serif;font-size:clamp(1rem,1.8vw,1.2rem);font-weight:400;line-height:1.6;margin:-15px 0 40px}.used-by-logos{align-items:center;display:flex;flex-wrap:wrap;gap:0;justify-content:center;margin:0 auto;max-width:1200px;pointer-events:auto}.logo-item{color:#504f4f;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:20px;font-weight:500;padding:0 24px;pointer-events:auto;position:relative;transition:color .3s ease;white-space:nowrap;z-index:1}.logo-item:hover{color:#3e3d3d;transform:scale(1.05)}.logo-divider{background:#e0e0e0;height:20px;margin:0 8px;width:1px}@media (max-width:768px){.used-by-section{padding:50px 20px}.used-by-heading{font-size:clamp(1.3rem,4vw,1.75rem);margin-bottom:12px}.used-by-description{font-size:clamp(.95rem,3vw,1.1rem);line-height:1.6;margin:-10px 0 40px;padding:0 10px}.used-by-logos{flex-wrap:wrap;gap:12px;margin:0 auto;max-width:600px}.logo-item,.used-by-logos{align-items:center;display:flex;justify-content:center}.logo-item{background:#0000;border:1.5px solid #e0e0e0;border-radius:24px;color:#504f4f;font-size:clamp(.85rem,2.5vw,.95rem);font-weight:500;min-height:40px;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.logo-item:hover{background:#2563eb0d;border-color:#2563eb;color:#2563eb;transform:translateY(-2px)}.logo-divider{display:none}}@media (max-width:480px){.used-by-section{padding:40px 16px}.used-by-heading{font-size:1.4rem;margin-bottom:10px}.used-by-description{font-size:.9rem;line-height:1.5;margin:-8px 0 32px;padding:0 4px}.used-by-logos{gap:10px;max-width:100%}.logo-item{border-radius:20px;border-width:1px;font-size:.8rem;min-height:38px;padding:8px 16px}}.features-section{background:#fff;padding:80px 20px;position:relative;text-align:center}.features-tooltip{animation:tooltipFadeIn .15s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;border-radius:24px;box-shadow:0 4px 16px #0000004d;color:#fff;font-family:Elms Sans,sans-serif;font-size:.8rem;font-weight:500;margin-top:-8px;padding:8px 16px;pointer-events:none;position:fixed;transform:translate(-50%,-100%);white-space:nowrap;z-index:10000}.features-tooltip:after{border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid #000000e6;bottom:-6px;content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.team-tooltip{animation:tooltipFadeIn .15s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;border-radius:24px;box-shadow:0 4px 16px #0000004d;color:#fff;font-family:Elms Sans,sans-serif;font-size:.8rem;font-weight:500;margin-top:-10px;padding:8px 16px;pointer-events:none;position:fixed;transform:translate(-50%,-100%);white-space:nowrap;z-index:10000}.team-tooltip:after{border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid #000000e6;bottom:-6px;content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.hero-tooltip{animation:tooltipFadeInRight .15s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;border-radius:24px;box-shadow:0 4px 16px #0000004d;color:#fff;font-family:Elms Sans,sans-serif;font-size:.8rem;font-weight:500;padding:8px 16px;pointer-events:none;position:fixed;transform:translate(10px,-50%);white-space:nowrap;z-index:10000}.hero-tooltip:after{border-bottom:6px solid #0000;border-right:6px solid #000000e6;border-top:6px solid #0000;content:"";height:0;left:-6px;position:absolute;top:50%;transform:translateY(-50%);width:0}@keyframes tooltipFadeInRight{0%{opacity:0;transform:translate(5px,-50%) scale(.9)}to{opacity:1;transform:translate(10px,-50%) scale(1)}}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-100%) scale(.9)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.features-heading{color:#000;cursor:help;display:inline-block;font-family:Elms Sans,sans-serif;font-size:clamp(1.2rem,2.4vw,2rem);font-weight:700;letter-spacing:-.5px;margin:0 0 60px;position:relative;text-transform:none}.features-grid{grid-gap:0;background:#fff;display:grid;gap:0;grid-auto-rows:1fr;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.feature-card{background:#fff;border-bottom:1px solid #e0e0e0;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100%;padding:48px 32px;text-align:center;transition:background .2s ease}.feature-card:nth-child(3n){border-right:none}.feature-card:nth-child(4),.feature-card:nth-child(5),.feature-card:nth-child(6){border-bottom:none}.feature-card:hover{background:#fafafa}.feature-icon{align-items:center;color:#000;display:flex;justify-content:center;margin-bottom:24px;opacity:.9}.feature-title{color:#000;font-family:Elms Sans,sans-serif;font-size:clamp(1.1rem,1.6vw,1.3rem);font-weight:700;letter-spacing:-.3px;line-height:1.3;margin:0 0 8px}.feature-description{color:#666;flex-grow:1;font-family:Elms Sans,sans-serif;font-size:clamp(.85rem,1.2vw,.95rem);font-weight:400;line-height:1.5;margin:0}@media (max-width:768px){.features-grid{grid-template-columns:1fr}.feature-card{border-bottom:1px solid #e0e0e0;border-right:none}.feature-card:last-child{border-bottom:none}}.stats-section{padding:80px 20px}.stats-grid,.stats-section{background:#fff;position:relative}.stats-grid{grid-gap:0;border:1px solid #e0e0e0;display:grid;gap:0;grid-template-columns:repeat(4,1fr);margin:0 auto;max-width:1200px;z-index:1}.stat-item{align-items:center;aspect-ratio:1;background:#fff;border:none;border-radius:0;border-right:1px solid #e0e0e0;box-shadow:none;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.stat-item:last-child{border-right:none}.stat-item:hover{background:#fafafa}.stat-icon{margin:0 auto 20px;transition:transform .3s ease}.stat-item:hover .stat-icon{transform:scale(1.1)}.stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#1e40af);-webkit-background-clip:text;background-clip:text;font-size:40px;font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:12px}.stat-label,.stat-number{font-family:Elms Sans,sans-serif}.stat-label{color:#333;font-size:clamp(.9rem,1.2vw,1.1rem);letter-spacing:.5px}@media (max-width:768px){.stats-section{padding:60px 20px}.stats-grid{border:1px solid #e0e0e0;border-radius:12px;gap:0;grid-template-columns:repeat(2,1fr);overflow:hidden}.stat-item{aspect-ratio:1;border-bottom:1px solid #e0e0e0;border-right:1px solid #e0e0e0;padding:32px 16px}.stat-item:nth-child(2n){border-right:none}.stat-item:nth-child(3),.stat-item:nth-child(4){border-bottom:none}.stat-icon{margin-bottom:16px}.stat-icon svg{height:36px;width:36px}.stat-number{font-size:clamp(28px,5vw,36px);margin-bottom:10px}.stat-label{font-size:clamp(.75rem,2vw,.9rem);letter-spacing:.3px}}@media (max-width:480px){.stats-section{padding:40px 16px}.stats-grid{border:1px solid #e0e0e0;border-radius:12px;gap:0;grid-template-columns:1fr;overflow:hidden}.stat-item{aspect-ratio:auto;border-bottom:1px solid #e0e0e0;border-right:none;min-height:140px;padding:28px 20px}.stat-item:last-child{border-bottom:none}.stat-icon{margin-bottom:14px}.stat-icon svg{height:32px;width:32px}.stat-number{font-size:clamp(26px,6vw,32px);margin-bottom:8px}.stat-label{font-size:clamp(.7rem,2.5vw,.85rem);letter-spacing:.3px;line-height:1.3}}.pricing-section{background:linear-gradient(135deg,#ffd4c4,#b8e0f5);border-radius:32px;box-shadow:0 20px 60px #0000001f;margin:0 auto;max-width:1400px;min-height:100vh;overflow:hidden;padding:clamp(80px,10vh,120px) clamp(20px,5vw,40px) clamp(40px,6vh,60px);position:relative;width:calc(100% - 80px);z-index:1}.pricing-section:before{background:radial-gradient(circle at 20% 20%,#ffb47866 0,#0000 50%),radial-gradient(circle at 80% 80%,#78b4ff66 0,#0000 50%);z-index:1}.pricing-section:after,.pricing-section:before{content:"";height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.pricing-section:after{animation:grain 8s steps(10) infinite;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");background-size:200px 200px;mix-blend-mode:overlay;opacity:.15;z-index:2}@keyframes grain{0%,to{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}.pricing-header{margin:0 auto 60px;max-width:1200px;position:relative;text-align:center;z-index:3}.pricing-subtitle{color:#666;font-family:Elms Sans,sans-serif;font-size:clamp(.85rem,1.2vw,1rem);font-weight:500;letter-spacing:2px;margin:0 0 16px;text-transform:uppercase}.pricing-heading{color:#000;font-family:Elms Sans,sans-serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:0 0 32px;text-align:center}.pricing-toggle-container{align-items:center;display:flex;gap:16px;justify-content:center;margin-top:24px}.pricing-toggle-label{color:#666;font-family:Elms Sans,sans-serif;font-size:clamp(.9rem,1.2vw,1rem);font-weight:500;position:relative;transition:color .3s ease}.pricing-toggle-label.active{color:#000;font-weight:600}.pricing-savings-badge{background:#10b981;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;margin-left:8px;padding:2px 8px}.pricing-toggle-switch{background:#e5e7eb;border:none;border-radius:16px;cursor:pointer;height:32px;outline:none;padding:0;position:relative;transition:background .3s ease;width:56px}.pricing-toggle-switch:hover{background:#d1d5db}.pricing-toggle-switch.yearly{background:#2563eb}.pricing-toggle-switch.yearly:hover{background:#1d4ed8}.pricing-toggle-slider{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;height:24px;left:4px;position:absolute;top:4px;transition:transform .3s cubic-bezier(.4,0,.2,1);width:24px}.pricing-toggle-switch.yearly .pricing-toggle-slider{transform:translateX(24px)}.pricing-card-original-price{color:#999;font-family:Elms Sans,sans-serif;font-size:clamp(.85rem,1.1vw,.95rem);font-weight:400;margin-top:4px;text-decoration:line-through}.pricing-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1200px;position:relative;z-index:3}.pricing-card{background:#fff;border-radius:16px;display:flex;flex-direction:column;padding:40px 32px;position:relative;transition:transform .2s ease}.pricing-card:hover{transform:translateY(-4px)}.pricing-card-featured{border:2px solid #e0e0e0;position:relative}.pricing-card-badge{background:#2563eb;border-radius:20px;color:#fff;font-family:Elms Sans,sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:6px 16px;position:absolute;right:20px;text-transform:uppercase;top:20px}.pricing-card-title{color:#000;font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.pricing-card-tagline,.pricing-card-title{font-family:Elms Sans,sans-serif;text-align:left}.pricing-card-tagline{color:#999;font-size:clamp(.9rem,1.2vw,1rem);font-weight:400;margin:0 0 32px}.pricing-card-price{color:#000;font-family:Elms Sans,sans-serif;font-size:clamp(2.5rem,4vw,3.5rem);font-weight:700;letter-spacing:-1px;line-height:1;margin:0 0 32px;text-align:left}.pricing-card-period{color:#666;font-size:clamp(.9rem,1.2vw,1rem);font-weight:400;margin-left:4px}.pricing-card-features{display:flex;flex-direction:column;flex-grow:1;gap:20px;margin-bottom:24px}.pricing-feature-item{align-items:center;color:#333;display:flex;font-family:Elms Sans,sans-serif;font-size:clamp(.95rem,1.3vw,1.05rem);gap:12px}.pricing-feature-icon{align-items:center;color:#000;display:flex;flex-shrink:0;justify-content:center;opacity:.8}.pricing-checkmark{color:#2563eb;flex-shrink:0}.pricing-card-button{border:none;border-radius:12px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:clamp(1rem,1.3vw,1.1rem);font-weight:600;letter-spacing:.3px;margin-top:32px;overflow:hidden;padding:16px 32px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.pricing-card-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.pricing-card-button:hover:before{left:100%}.pricing-card-button-primary{background:linear-gradient(135deg,#fff,#99d5ff);box-shadow:0 4px 14px #99d5ff4d;color:#000}.pricing-card-button-primary:hover{background:linear-gradient(135deg,#e6f5ff,#7cc5ff);box-shadow:0 6px 20px #99d5ff66;transform:translateY(-2px)}.pricing-card-button-primary:active{box-shadow:0 2px 8px #99d5ff40;transform:translateY(0)}.pricing-card-button-secondary{background:#fff;border:2px solid #e5e7eb;box-shadow:0 2px 8px #0000000d;color:#000}.pricing-card-button-secondary:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.pricing-card-button-secondary:active{box-shadow:0 1px 4px #0000000d;transform:translateY(0)}.pricing-usage-badge{background:#f5f5f5;border-radius:20px;color:#999;font-family:Elms Sans,sans-serif;font-size:clamp(.75rem,1vw,.85rem);font-weight:500;letter-spacing:.3px;margin-top:auto;padding:8px 16px;text-align:center}@media (max-width:968px){.pricing-toggle-container{gap:12px}.pricing-toggle-switch{height:28px;width:50px}.pricing-toggle-switch.yearly .pricing-toggle-slider{transform:translateX(22px)}.pricing-toggle-slider{height:20px;width:20px}.pricing-header{gap:24px}.pricing-cards,.pricing-header{grid-template-columns:1fr}}.team-section{background-color:#fff;padding:clamp(60px,8vh,80px) clamp(20px,5vw,40px);position:relative;width:100%;z-index:1}.team-container{grid-gap:40px;align-items:start;display:grid;gap:40px;grid-template-columns:1fr 1.5fr;margin:0 auto;max-width:1200px}.team-quote-section{display:flex;flex-direction:column;gap:24px}.team-quote-icon{color:#000;height:80px;opacity:.6;width:80px}.team-quote-text{color:#000;font-size:clamp(2rem,4vw,3.5rem);line-height:1;margin:0}.team-quote-description,.team-quote-text{font-family:Elms Sans,sans-serif;font-weight:400;max-width:500px}.team-quote-description{color:#666;font-size:clamp(1rem,1.5vw,1.2rem);line-height:1.6;margin:16px 0 0}.team-expert-dialog{background:linear-gradient(135deg,#e0f2fe,#b8e0f5);border-radius:20px;box-shadow:0 4px 16px #b8e0f54d;margin-top:24px;max-width:500px;padding:24px 28px}.team-expert-title{color:#000;font-family:Elms Sans,sans-serif;font-size:clamp(1.3rem,2vw,1.6rem);font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:0 0 12px}.team-expert-text{color:#333;font-family:Elms Sans,sans-serif;font-size:clamp(.95rem,1.3vw,1.1rem);font-weight:400;line-height:1.6;margin:0}.team-testimonials-section{position:relative}.team-testimonials-background{display:none}.team-testimonials-grid{grid-gap:0;background:#fff;display:grid;gap:0;grid-auto-rows:1fr;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1200px;position:relative;z-index:1}.testimonial-card{background:#fff;border-bottom:1px solid #e0e0e0;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100%;padding:32px 24px;text-align:center;transition:background .2s ease}.testimonial-card:nth-child(2n){border-right:none}.testimonial-card:last-child,.testimonial-card:nth-child(3),.testimonial-card:nth-child(4){border-bottom:none}.testimonial-card:hover{background:#fafafa}.testimonial-card-content{align-items:center;display:flex;flex-direction:column;gap:0}.testimonial-avatar{align-items:center;background:#f0f0f0;border-radius:50%;display:flex;height:64px;justify-content:center;margin-bottom:16px;overflow:hidden;width:64px}.testimonial-avatar img{height:100%;object-fit:cover;width:100%}.testimonial-name{color:#000;font-family:Elms Sans,sans-serif;font-size:clamp(1.1rem,1.6vw,1.3rem);font-weight:700;letter-spacing:-.3px;line-height:1.3;margin:0 0 8px}.testimonial-title{color:#2563eb;font-family:Elms Sans,sans-serif;font-size:clamp(.9rem,1.2vw,1rem);font-weight:600;margin:0 0 12px}.testimonial-text{color:#666;flex-grow:1;font-family:Elms Sans,sans-serif;font-size:clamp(.85rem,1.2vw,.95rem);font-weight:400;line-height:1.5;margin:0}.team-qualifications{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.qualification-pill{background:#f5f5f5;border-radius:20px;color:#666;font-family:Elms Sans,sans-serif;font-size:clamp(.75rem,1vw,.85rem);font-weight:500;padding:6px 12px}@media (max-width:1024px){.team-container{gap:40px;grid-template-columns:1fr}.team-quote-section{align-items:center;text-align:center}.team-quote-text{max-width:100%}}@media (max-width:768px){.team-testimonials-grid{grid-template-columns:1fr}.testimonial-card{border-bottom:1px solid #e0e0e0;border-right:none}.testimonial-card:last-child{border-bottom:none}}@media (max-width:1024px){.hero-section{height:auto;min-height:100vh}.home-content{gap:32px;max-width:100%}.home-description-section{margin-left:0;margin-right:0;max-width:100%;text-align:center}.home-description{text-align:center}.floating-tooltips-above,.floating-tooltips-below,.hero-tooltip{display:none}.features-grid{gap:0}.feature-card{padding:44px 30px}.pricing-section{width:calc(100% - 60px)}.pricing-cards{gap:20px}}@media (max-width:768px){.hero-section{height:auto;min-height:100vh;padding:20px 0}.hero-logo-container{justify-content:center;margin-bottom:20px}.hero-logo-img{height:50px}.blurer{min-height:auto;padding:20px 16px}.home-content{gap:24px;padding:0 10px}.home-heading{font-size:clamp(2.5rem,7vw,3.5rem)}.home-description{font-size:clamp(1.1rem,3vw,1.3rem);text-align:center}.home-description-section{gap:12px;margin-top:-30px;text-align:center}.now-live-badge{font-size:.85rem;padding:7px 18px}.floating-tooltips-below{flex-wrap:wrap;gap:20px;margin-top:32px}.hero-start-trial-button{font-size:1rem;max-width:300px;padding:13px 28px;width:auto}.features-section{padding:60px 20px}.features-heading{font-size:1.75rem;margin-bottom:40px}.features-grid{grid-template-columns:1fr}.feature-card{border-bottom:1px solid #e0e0e0;border-right:none;padding:40px 28px}.feature-card:last-child{border-bottom:none}.pricing-section{border-radius:28px;padding:60px 16px 40px;width:calc(100% - 40px)}.pricing-header{margin-bottom:40px}.pricing-heading{font-size:2.25rem}.pricing-cards{gap:20px;grid-template-columns:1fr}.pricing-card{padding:32px 24px}.pricing-card-featured{transform:scale(1)}.pricing-card-featured:hover{transform:translateY(-8px)}.pricing-card-title{font-size:1.75rem}.pricing-card-price{font-size:2.75rem}.pricing-card-features{gap:18px}.pricing-feature-item{font-size:.95rem}.team-section{padding:60px 16px 40px}.team-container{gap:40px;grid-template-columns:1fr}.team-quote-section{align-items:center;text-align:center}.team-quote-text{max-width:100%}.team-quote-description,.team-quote-text{text-align:center}.team-expert-dialog{max-width:100%}.team-testimonials-grid{grid-template-columns:1fr}.testimonial-card{border-bottom:1px solid #e0e0e0;border-right:none;padding:28px 24px}.testimonial-card:last-child{border-bottom:none}}@media (max-width:480px){.hero-section{height:auto;min-height:100vh;padding:20px 0}.blurer{min-height:auto;padding:16px 12px}.home-content{gap:20px;padding:0 8px}.home-heading{font-size:clamp(2rem,8vw,2.5rem);line-height:1.3;margin-bottom:16px}.home-description{font-size:clamp(1rem,4vw,1.2rem);margin:20px 0 0;text-align:center}.home-description-section{margin-top:-20px;text-align:center}.now-live-badge{font-size:.75rem;margin-bottom:16px;padding:6px 16px}.floating-tooltips-below{flex-direction:column;gap:12px;margin-top:24px}.floating-tooltip{font-size:.7rem;left:auto;padding:6px 12px;position:relative;top:auto}.hero-start-trial-button{font-size:.95rem;margin-top:32px;max-width:280px;padding:12px 24px;width:100%}.features-section{padding:40px 16px}.features-heading{font-size:1.5rem;margin-bottom:32px}.feature-card{padding:32px 20px}.feature-icon{margin-bottom:16px}.feature-icon svg{height:32px;width:32px}.feature-title{font-size:1.1rem;margin-bottom:8px}.feature-description{font-size:.85rem}.pricing-section{border-radius:24px;min-height:auto;padding:40px 16px;width:calc(100% - 32px)}.pricing-header{margin-bottom:32px}.pricing-subtitle{font-size:.75rem;margin-bottom:12px}.pricing-heading{font-size:1.75rem}.pricing-cards{gap:16px}.pricing-card{padding:24px 20px}.pricing-card-badge{font-size:.65rem;padding:4px 12px;right:12px;top:12px}.pricing-card-title{font-size:1.5rem}.pricing-card-price{font-size:2rem}.pricing-card-features{gap:16px;margin-bottom:20px}.pricing-feature-item{font-size:.9rem;gap:10px}.pricing-checkmark{height:18px;width:18px}.pricing-card-button{font-size:.95rem;margin-top:24px;padding:14px 24px}.team-section{padding:40px 16px}.team-container{gap:32px}.team-quote-icon{height:60px;width:60px}.team-quote-text{font-size:1.75rem;text-align:center}.team-quote-description{font-size:.95rem;text-align:center}.team-expert-dialog{margin-top:20px;padding:20px}.team-expert-title{font-size:1.2rem}.team-expert-text{font-size:.9rem}.team-testimonials-grid{grid-template-columns:1fr}.testimonial-card{padding:24px 20px}.testimonial-avatar{height:56px;margin-bottom:12px;width:56px}.testimonial-name{font-size:1.1rem}.testimonial-title{font-size:.85rem}.testimonial-text{font-size:.8rem}.qualification-pill{font-size:.7rem;padding:4px 10px}}@media (max-width:375px){.home-heading{font-size:clamp(1.75rem,9vw,2.25rem);line-height:1.2}.home-description{font-size:clamp(.95rem,4.5vw,1.15rem)}.hero-start-trial-button{font-size:.9rem;max-width:100%;padding:11px 20px}.used-by-heading{font-size:1.3rem}.used-by-description{font-size:.85rem}.logo-item{font-size:14px}.stat-number{font-size:28px}.stat-label{font-size:.8rem}.features-heading{font-size:1.3rem}.feature-title{font-size:1rem}.feature-description{font-size:.8rem}.pricing-heading{font-size:1.5rem}.pricing-card{padding:20px 16px}.pricing-card-title{font-size:1.3rem}.pricing-card-price{font-size:1.75rem}.pricing-feature-item{font-size:.85rem}.team-quote-text{font-size:1.5rem}.team-quote-description{font-size:.9rem}}@media (max-width:768px){.hero-start-trial-button,.pricing-card-button{min-height:44px;touch-action:manipulation}.logo-item{align-items:center;display:flex;justify-content:center;min-height:44px}.feature-card,.stat-item,.testimonial-card{cursor:default}}@media (min-width:1400px){.home-content{max-width:1200px}.pricing-section .pricing-cards,.pricing-section .pricing-heading{max-width:1400px}}.auth-page{align-items:center;background:#f4f6f8;background:var(--bg-page);background-image:linear-gradient(#00000008 1px,#0000 0),linear-gradient(90deg,#00000008 1px,#0000 0);background-size:40px 40px;display:flex;font-family:Elms Sans,Inter,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;padding:40px 20px;position:relative}.floating-icons-container{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:0}.floating-icon{align-items:center;animation:floatUp linear infinite;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:50%;bottom:-80px;display:flex;height:48px;justify-content:center;opacity:1;position:absolute;transition:all .3s ease;width:48px;will-change:transform}.floating-icon:hover{opacity:.9;transform:scale(1.05)}.floating-icon svg{color:#fff;display:block;height:24px;width:24px}@keyframes floatUp{0%{opacity:0;transform:translateY(0) translateX(0) rotate(0deg)}3%{opacity:1}97%{opacity:1}to{opacity:0;transform:translateY(calc(-100vh - 80px)) translateX(30px) rotate(8deg)}}.auth-container{max-width:480px;position:relative;width:100%;z-index:1}.auth-card{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:20px;box-shadow:0 10px 25px #00000014;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.auth-card:hover{box-shadow:0 15px 35px #0000001f;transform:translateY(-2px)}.gradient-border{display:none}.auth-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);padding:40px 40px 24px;text-align:center}.auth-logo-container{align-items:center;display:flex;justify-content:center;margin-bottom:12px}.auth-logo-img{height:50px;object-fit:contain;width:auto}.auth-tagline{color:#6b7280;color:var(--text-grey);font-family:Inter,sans-serif;font-size:14px;font-weight:400;margin:0}.auth-content{padding:40px 40px 48px}.auth-content form>*{animation:slideIn .3s ease-out}.auth-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px;text-align:center}.auth-subtitle{color:#6b7280;color:var(--text-grey);font-family:Inter,sans-serif;font-size:14px;line-height:1.5;margin:0 0 32px;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600}.form-group input,.form-group label{color:#111827;color:var(--text-dark);font-family:Inter,sans-serif}.form-group input{background:#fff;background:var(--bg-white);border:1.5px solid #e5e7eb;border:1.5px solid var(--border-light);border-radius:10px;box-sizing:border-box;font-size:15px;height:48px;padding:0 18px;transition:all .2s ease;width:100%}.form-group input::placeholder{color:#9ca3af;color:var(--text-light)}.form-group input:hover{border-color:#d1d5db}.form-group input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 4px #1976d21a;outline:none;transform:translateY(-1px)}.form-group input:invalid:not(:placeholder-shown):not(:focus){border-color:#ef4444}.form-group input.input-error{border-color:#ef4444}.field-error{color:#ef4444}.field-error,.field-success{align-items:center;display:flex;font-size:12px;gap:4px;margin-top:6px}.field-success{color:#10b981}.input-with-button{align-items:center;display:flex;position:relative}.input-with-button input{padding-right:70px}.show-button{background:none;border:none;border-radius:4px;color:#6b7280;color:var(--text-grey);cursor:pointer;font-family:Inter,sans-serif;font-size:13px;font-weight:600;padding:6px 10px;position:absolute;right:8px;transition:color .2s ease}.show-button:hover{background:#1976d20d;color:#1976d2;color:var(--primary-blue)}.form-checkbox{align-items:flex-start;display:flex;flex-direction:row;gap:12px;margin:24px 0 24px 18px;padding:0}.form-checkbox input[type=checkbox]{accent-color:#1976d2;accent-color:var(--primary-blue);border-radius:4px;cursor:pointer;flex-shrink:0;height:18px;margin-left:0;margin-top:2px;width:18px}.form-checkbox label{color:#6b7280;color:var(--text-grey);cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:14px;line-height:1.5;margin:0}.form-checkbox label a{color:#1976d2;color:var(--primary-blue);font-weight:600;text-decoration:none}.form-checkbox label a:hover{text-decoration:underline}.btn-primary{border-radius:10px;box-shadow:0 4px 12px #1976d240;color:var(--bg-white);font-family:Inter,sans-serif;font-size:15px;height:50px;justify-content:center;margin-top:8px;overflow:hidden;position:relative;transition:all .2s ease;width:100%}.btn-primary.loading:after{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fffc;content:"";height:16px;position:absolute;width:16px}.btn-primary:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 16px #1976d259;transform:translateY(-2px)}.alert{align-items:center;animation:slideDown .3s ease-out;border:1px solid;border-radius:10px;display:flex;font-family:Inter,sans-serif;gap:10px;margin-bottom:24px;padding:14px 16px}.alert:before{border-radius:50%;content:"";flex-shrink:0;height:20px;width:20px}.alert-error:before{background:#ef4444;content:"✕"}.alert-error:before,.alert-success:before{align-items:center;color:#fff;display:flex;font-size:12px;font-weight:700;justify-content:center}.alert-success:before{background:#10b981;content:"✓"}.alert-error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.auth-links{margin-top:24px;text-align:center}.link-button{background:none;border:none;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Inter,sans-serif;font-size:13px;font-weight:600;padding:0;transition:color .2s ease}.link-button:hover{color:#1565c0;text-decoration:underline}.divider{align-items:center;color:#9ca3af;color:var(--text-light);display:flex;font-family:Inter,sans-serif;font-size:12px;font-weight:500;gap:12px;margin:24px 0}.divider:after,.divider:before{background:#e5e7eb;background:var(--border-light);content:"";flex:1 1;height:1px}.signup-steps{align-items:center;display:flex;justify-content:space-between;margin-bottom:40px;padding:0 20px;position:relative}.signup-steps:before{background:#e5e7eb;background:var(--border-light);content:"";height:2px;left:20px;position:absolute;right:20px;top:20px;z-index:0}.step-indicator{flex:1 1;flex-direction:column;gap:8px;position:relative;z-index:1}.step-indicator,.step-number{align-items:center;display:flex}.step-number{background:#fff;background:var(--bg-white);border:2px solid #e5e7eb;border:2px solid var(--border-light);border-radius:50%;color:#6b7280;color:var(--text-grey);font-size:14px;font-weight:600;height:40px;justify-content:center;transition:all .3s ease;width:40px}.step-indicator.active .step-number{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.step-indicator.completed .step-number{background:#10b981;border-color:#10b981;color:#fff}.step-label{color:#6b7280;color:var(--text-grey);font-size:12px;font-weight:500;text-align:center}.step-indicator.active .step-label{color:#1976d2;color:var(--primary-blue);font-weight:600}.step-indicator.completed .step-label{color:#10b981}.signup-steps .step-indicator,.signup-steps .step-number{transition:all .3s ease}.btn-secondary{align-items:center;background:#fff;background:var(--bg-white);border:1.5px solid #e5e7eb;border:1.5px solid var(--border-light);border-radius:10px;box-shadow:0 1px 3px #0000001a;color:#111827;color:var(--text-dark);display:flex;font-family:Inter,sans-serif;font-size:15px;height:50px;justify-content:center;margin-top:8px;transition:all .2s ease;width:100%}.btn-secondary:hover{background:#f4f6f8;background:var(--bg-page);border-color:#6b7280;border-color:var(--text-grey);box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0)}.form-actions{display:flex;gap:12px;margin-top:8px}.form-actions .btn-primary,.form-actions .btn-secondary{flex:1 1;margin-top:0}.password-requirements{background:#f8fafc;border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;margin-top:12px;padding:12px}.requirement{align-items:center;color:#6b7280;color:var(--text-grey);display:flex;font-size:13px;gap:8px;margin-bottom:6px;transition:color .2s ease}.requirement:last-child{margin-bottom:0}.requirement-icon{align-items:center;color:#6b7280;color:var(--text-grey);display:flex;font-size:12px;font-weight:600;height:18px;justify-content:center;transition:all .2s ease;width:18px}.requirement.met{color:#10b981}.requirement.met .requirement-icon{color:#10b981;font-size:14px}@media (max-width:640px){.auth-page{padding:20px}.auth-container{max-width:100%}.auth-header{padding:32px 24px 20px}.auth-content{padding:32px 24px 40px}.auth-title{font-size:22px}.auth-subtitle{font-size:13px}.auth-logo-img{height:44px}.auth-tagline{font-size:13px}.btn-primary,.form-group input{font-size:14px;height:42px}}@media (max-width:480px){.auth-page{padding:16px}.auth-header{padding:28px 20px 18px}.auth-content{padding:28px 20px 36px}.auth-title{font-size:20px}.auth-subtitle{font-size:12px;margin-bottom:24px}.auth-logo-img{height:40px}.form-group{margin-bottom:18px}.form-group label{font-size:13px}.form-checkbox{gap:10px;margin:24px 0}.form-checkbox input[type=checkbox]{height:16px;margin-top:2px;width:16px}.form-checkbox label{font-size:13px}.link-button{font-size:12px}.divider{margin:20px 0}}@media (max-width:375px){.auth-content{padding:24px 16px 32px}.auth-title{font-size:18px}.form-group input{font-size:13px;height:40px;padding:0 12px}.btn-primary{height:40px}}@media (max-width:768px){.btn-primary,.link-button{min-height:44px;touch-action:manipulation}.btn-primary,.form-group input{-webkit-tap-highlight-color:transparent}}.reset-password-container{background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin:4rem auto;max-width:400px;padding:2rem}.reset-password-title{margin-bottom:24px}.reset-password-description{color:#666;font-size:14px;margin-bottom:24px}.reset-password-form-group{margin-bottom:16px}.reset-password-label{display:block;margin-bottom:4px}.reset-password-input{border:1px solid #ddd;border-radius:4px;font-size:14px;margin-top:4px;padding:8px;width:100%}.reset-password-input:focus{border-color:#1976d2;outline:none}.reset-password-submit-btn{background:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:10px;transition:background-color .2s ease;width:100%}.reset-password-submit-btn:hover:not(:disabled){background:#1565c0}.reset-password-submit-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.7}.reset-password-validation-message{color:#666;font-size:12px;margin-top:8px;text-align:center}.reset-password-back-btn{background:none;border:none;color:#1976d2;cursor:pointer;font-size:14px;margin-top:16px;padding:0}.reset-password-back-btn:hover{text-decoration:underline}.reset-password-back-container{margin-top:16px;text-align:center}.reset-password-error{background:#ffebee;border:1px solid #ffcdd2;border-radius:4px;color:#d32f2f;font-size:14px;margin-top:16px;padding:12px}.reset-password-message{background:#e8f5e8;border:1px solid #c8e6c9;border-radius:4px;color:#2e7d32;font-size:14px;margin-top:16px;padding:12px}.reset-password-requirements{color:#888;font-size:12px;line-height:1.4;margin-top:16px}.reset-password-requirements ul{margin:8px 0;padding-left:20px}.reset-password-requirements li{margin-bottom:4px}body.modules-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.mp-loading,body.modules-page-body{background:#fff;background:var(--bg-page)}.mp-loading{align-items:center;display:flex;height:100vh;justify-content:center}.mp-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.mp-navbar{background:#fff;background:var(--bg-page);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:none;position:-webkit-sticky;position:sticky;top:0;z-index:100}.mp-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:20px 40px}.mp-logo{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:26px;font-weight:800;letter-spacing:-.5px;text-decoration:none}.mp-logo-osce{color:#1976d2;color:var(--primary-blue)}.mp-logo-pal{color:#7c3aed;color:var(--primary-purple)}.mp-navbar-actions{align-items:center;display:flex;gap:12px}.mp-profile-btn{align-items:center;background:none;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:6px 12px;transition:all .2s ease}.mp-profile-btn:hover{background:#f9fafb;border-color:#e5e7eb;border-color:var(--border-color)}.mp-profile-name{color:#1f2937;color:var(--text-dark);display:none;font-size:14px;font-weight:600}.mp-admin-btn,.mp-logout-btn{border:1px solid #000;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.mp-admin-btn{background:#1976d2;background:var(--primary-blue);color:#fff}.mp-admin-btn:hover{background:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}.mp-logout-btn{background:#0000;border:1px solid #3e80a3;color:#6b7280;color:var(--text-medium)}.mp-logout-btn:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.mp-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.mp-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;margin-bottom:48px;padding:32px 40px}.mp-header-content{align-items:center;display:flex;gap:24px;justify-content:space-evenly}@media (max-width:768px){.mp-header-content{align-items:flex-start;flex-direction:column}}.mp-welcome-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;letter-spacing:-1px;margin-bottom:8px;white-space:wrap}.mp-welcome-title strong{font-weight:700}.mp-welcome-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;margin:0}.mp-dashboard-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-left:200px;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.mp-dashboard-button:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.mp-dashboard-button:active{box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.mp-modules-section{margin-bottom:60px}.mp-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:24px}.mp-modules-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.mp-module-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;padding:28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.mp-module-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.mp-module-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.mp-module-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}.mp-module-description{color:#6b7280;color:var(--text-medium);flex-grow:1;font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:20px;min-height:60px}.mp-module-stats{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:16px;margin-bottom:16px;padding:16px 0}.mp-module-stat{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;gap:6px}.mp-start-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s ease;width:100%}.mp-start-button:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.mp-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;padding-top:40px;text-align:center}.mp-footer-role,.mp-footer-text{margin:4px 0}@media (min-width:640px){.mp-profile-name{display:inline}}@media (max-width:1024px){.mp-navbar-container{padding:16px 24px}.mp-main{padding:48px 24px 60px}.mp-modules-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.mp-navbar-container{padding:12px 20px}.mp-dashboard-button{margin-left:0}.mp-logo{font-size:22px}.mp-main{padding:40px 20px 60px}.mp-header{margin-bottom:36px;padding:24px 20px}.mp-welcome-title{display:flex;flex-direction:column;font-size:28px}.mp-welcome-text{font-size:16px}.mp-module-card{padding:24px}.mp-modules-grid{grid-template-columns:1fr}}.oscepal-page{background:#fff;font-family:Elms Sans,sans-serif;min-height:100vh;position:relative;width:100%}.oscepal-navbar-logo{transition:opacity .2s ease}.oscepal-navbar-logo:hover{opacity:.8}.oscepal-nav-link{align-items:center;background:#0000;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.oscepal-nav-link:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.oscepal-main-container{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.oscepal-page-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:48px;padding:32px 40px}.oscepal-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:700;letter-spacing:-1px;line-height:1.2;margin:0 0 8px}.oscepal-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;line-height:1.6;margin:0}.oscepal-search-results-wrapper{grid-gap:20px;align-items:center;display:grid;gap:20px;grid-template-columns:1fr auto;margin-bottom:48px}.oscepal-search-bar{position:relative;width:100%}.oscepal-search-icon{color:#9ca3af;left:16px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.oscepal-search-input{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:400;padding:14px 16px 14px 48px;transition:all .2s ease;width:100%}.oscepal-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.oscepal-search-input::placeholder{color:#9ca3af}.oscepal-results-count{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:12px;padding:14px 24px;white-space:nowrap}.oscepal-stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);-webkit-background-clip:text;background-clip:text;font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;line-height:1}.oscepal-stat-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.oscepal-cases-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:60px}.oscepal-case-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;height:100%;padding:28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.oscepal-case-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.oscepal-case-icon-box-simple{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:48px;justify-content:center;margin-bottom:16px;width:48px}.oscepal-card-title-simple{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;line-height:1.3;margin:0 0 12px}.oscepal-card-description-simple{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#6b7280;color:var(--text-medium);display:-webkit-box;flex-grow:1;font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:24px;min-height:60px;overflow:hidden}.oscepal-card-stats-simple{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:12px;margin-bottom:16px;padding:16px 0}.oscepal-stat-detail{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;flex-shrink:0;gap:6px}.oscepal-highlight-mark{background-color:#fef9c3;border-radius:4px;color:inherit;color:#1f2937;color:var(--text-dark);font-weight:600;padding:2px 4px}.oscepal-btn{padding:12px 20px;text-decoration:none}.oscepal-btn-primary{box-shadow:0 4px 12px #1976d233;width:100%}.oscepal-btn-primary:hover{background:#1565c0;box-shadow:0 6px 16px #1976d24d;transform:translateY(-1px)}.oscepal-btn-link{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);box-shadow:none;color:#6b7280;color:var(--text-medium);min-width:200px}.oscepal-btn-link:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.oscepal-empty-state{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);grid-column:1/-1;padding:60px 40px;text-align:center}.oscepal-empty-icon{font-size:64px;margin-bottom:24px;opacity:.5}.oscepal-empty-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0 0 8px}.oscepal-empty-description{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:400;line-height:1.6;margin:0}.oscepal-back-button-container{margin-top:48px;text-align:center}@media (max-width:1024px){.oscepal-navbar-container{padding:16px 24px}.oscepal-main-container{padding:48px 24px 60px}.oscepal-cases-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:968px){.oscepal-search-results-wrapper{gap:16px;grid-template-columns:1fr}.oscepal-results-count{justify-content:center}}@media (max-width:768px){.oscepal-navbar-container{padding:12px 20px}.oscepal-navbar-logo{font-size:22px}.oscepal-main-container{padding:40px 20px 60px}.oscepal-page-header{margin-bottom:36px;padding:24px 20px}.oscepal-page-title{font-size:28px}.oscepal-page-subtitle{font-size:16px}.oscepal-search-results-wrapper{margin-bottom:36px}.oscepal-cases-grid{gap:20px;grid-template-columns:1fr}.oscepal-case-card{padding:24px}.oscepal-card-stats-simple{gap:10px}}@media (max-width:480px){.oscepal-navbar-container{padding:10px 16px}.oscepal-navbar-logo{font-size:20px}.oscepal-nav-link{font-size:13px;gap:6px;padding:8px 14px}.oscepal-main-container{padding:32px 16px 48px}.oscepal-page-header{padding:20px 16px}.oscepal-page-title{font-size:24px}.oscepal-page-subtitle{font-size:14px}.oscepal-search-input{font-size:14px;padding:12px 16px 12px 44px}.oscepal-results-count{padding:12px 20px}.oscepal-stat-value{font-size:20px}.oscepal-stat-label{font-size:12px}.oscepal-cases-grid{gap:16px;margin-bottom:48px}.oscepal-btn{font-size:13px;padding:10px 18px}.oscepal-empty-state{padding:48px 24px}.oscepal-empty-icon{font-size:48px}.oscepal-empty-title{font-size:18px}.oscepal-empty-description{font-size:13px}.oscepal-back-button-container{margin-top:36px}}@media (max-width:375px){.oscepal-page-title{font-size:22px}.oscepal-card-stats-simple{align-items:flex-start;flex-direction:column;gap:8px}}.oscepal-case-card{animation:fadeIn .3s ease-out}.oscepal-case-card:first-child{animation-delay:0s}.oscepal-case-card:nth-child(2){animation-delay:.05s}.oscepal-case-card:nth-child(3){animation-delay:.1s}.oscepal-case-card:nth-child(4){animation-delay:.15s}.oscepal-case-card:nth-child(5){animation-delay:.2s}.oscepal-case-card:nth-child(6){animation-delay:.25s}@media (hover:none) and (pointer:coarse){.oscepal-btn:hover,.oscepal-case-card:hover,.oscepal-nav-link:hover{transform:none}}:root{--border-card:#e0e4e8;--shadow-sm:0 1px 3px 0 #0000000d;--shadow-md:0 4px 8px -2px #0000001a,0 2px 4px -2px #0000000f}.up-container{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;min-height:100vh;padding:0}.up-container,.up-header{background:#fff;background:var(--bg-white)}.up-header{align-items:center;border-bottom:1px solid #e0e4e8;border-bottom:1px solid var(--border-card);display:flex;justify-content:space-between;padding:16px 280px}.up-logo{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:700;letter-spacing:-.5px}.up-back-button{align-items:center;background:#f5f5f5;border:none;border-radius:8px;color:#111827;color:var(--text-dark);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:6px;padding:10px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.up-back-button:hover{background:#e0e0e0;color:#111827;color:var(--text-dark);transform:translateY(-1px)}.up-back-button:active{transform:translateY(0)}.up-main-content{margin:0 auto;max-width:800px;padding:48px 24px}.up-page-title-section{margin-bottom:32px}.up-page-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(24px,4vw,32px);font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.up-page-subtitle{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:14px;margin:0}.up-profile-card{background:#fff;background:var(--bg-white);border:1px solid #e0e4e8;border:1px solid var(--border-card);border-radius:16px;box-shadow:0 4px 8px -2px #0000001a,0 2px 4px -2px #0000000f;box-shadow:var(--shadow-md);padding:32px}.up-photo-section{align-items:center;border-bottom:1px solid #e0e4e8;border-bottom:1px solid var(--border-card);display:flex;gap:24px;margin-bottom:32px;padding-bottom:32px}.up-avatar-wrapper{min-width:80px;position:relative}.up-avatar{background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);box-shadow:0 4px 12px #1976d24d;color:#fff;font-family:Elms Sans,sans-serif;font-size:28px;font-weight:700;height:80px;width:80px}.up-avatar,.up-camera-badge{align-items:center;border-radius:50%;display:flex;justify-content:center}.up-camera-badge{background:#1976d2;background:var(--primary-blue);border:3px solid #fff;bottom:0;box-shadow:0 2px 8px #1976d24d;cursor:pointer;height:28px;position:absolute;right:0;transition:all .3s cubic-bezier(.4,0,.2,1);width:28px}.up-camera-badge:hover{background:#1565c0;transform:scale(1.05)}.up-camera-badge:active{transform:scale(.95)}.up-photo-info{flex:1 1}.up-photo-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;margin-bottom:4px}.up-photo-description{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:12px;margin-bottom:12px}.up-upload-button{background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;letter-spacing:.3px;padding:8px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.up-upload-button:hover{background:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}.up-upload-button:active{transform:translateY(0)}.up-form-grid{grid-gap:20px;display:grid;gap:20px}.up-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.up-label{color:#111827;color:var(--text-dark);display:block;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;margin-bottom:8px}.up-required{color:#ef4444}.up-input,.up-select,.up-textarea{border:1px solid #e0e4e8;border:1px solid var(--border-card);border-radius:8px;box-sizing:border-box;color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 12px;transition:all .2s ease;width:100%}.up-input:focus,.up-select:focus,.up-textarea:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.up-select{-webkit-appearance:none;appearance:none;background:#fff;background:var(--bg-white);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='m9.293 12.95.707.707L15.657 8l-1.414-1.414L10 10.828 5.757 6.586 4.343 8z' fill='%236b7280'/%3E%3C/svg%3E");background-position:right .7rem center;background-repeat:no-repeat;background-size:1em 1em;cursor:pointer;width:100%}.up-textarea{font-family:Elms Sans,sans-serif;line-height:1.5;resize:vertical}.up-input-disabled{background:#f4f6f8;background:var(--bg-page);border:1px solid #e0e4e8;border:1px solid var(--border-card);color:#6b7280;color:var(--text-grey)}.up-input-disabled:focus{border-color:#e0e4e8;border-color:var(--border-card);box-shadow:none}.up-input-help{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:11px;margin-top:4px}.up-bio-counter{text-align:right}.up-student-type-box{align-items:center;background:#1976d214;border:1px solid #1976d233;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:12px;transition:background .2s ease}.up-student-type-box:hover{background:#1976d21f}.up-student-type-box span{color:#1565c0;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500}.up-student-type-box input[type=checkbox]{border-radius:4px;cursor:pointer;height:16px;width:16px}.up-message{border:1px solid;border-radius:8px;font-family:Elms Sans,sans-serif;font-size:14px;margin-top:24px;padding:12px 16px}.up-message-success{background:#d1fae5;border-color:#6ee7b7;color:#065f46}.up-message-error{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.up-buttons-container{border-top:1px solid #e0e4e8;border-top:1px solid var(--border-card);display:flex;flex-direction:column;gap:12px;margin-top:32px;padding-top:24px}.up-button{border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:.3px;padding:10px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.up-button:disabled{cursor:not-allowed;opacity:.6}.up-button-save{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;color:#fff;display:flex;gap:8px;justify-content:center;order:1}.up-button-save:not(:disabled):hover{background:#1565c0;box-shadow:0 6px 20px #1976d24d;transform:translateY(-2px)}.up-button-save:not(:disabled):active{box-shadow:0 2px 8px #1976d240;transform:translateY(0)}.up-button-cancel{background:#fff;background:var(--bg-white);border:1px solid #e0e4e8;border:1px solid var(--border-card);color:#111827;color:var(--text-dark);order:2}.up-button-cancel:not(:disabled):hover{background:#fafafa;border-color:#d1d5db}.up-button-cancel:not(:disabled):active{background:#f5f5f5}.up-loading-container{align-items:center;background:#fff;background:var(--bg-white);display:flex;height:100vh;justify-content:center}.up-loading-text{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:18px}@media (min-width:640px){.up-buttons-container{flex-direction:row;justify-content:flex-end}.up-button-save{flex:0 1 auto;min-width:150px;order:2}.up-button-cancel{flex:0 1 auto;min-width:120px;order:1}}@media (max-width:768px){.up-header{padding-left:20px;padding-right:20px}.up-main-content{padding:32px 16px}.up-profile-card{padding:24px 20px}.up-photo-section{align-items:flex-start;flex-direction:column;gap:16px}.up-avatar-wrapper{align-self:center}.up-photo-info{text-align:center;width:100%}.up-upload-button{width:100%}.up-form-row{grid-template-columns:1fr}.up-select{width:100%}}@media (max-width:480px){.up-header{padding:12px 16px}.up-logo{font-size:18px}.up-back-button{font-size:13px;padding:8px 12px}.up-page-title{font-size:22px}.up-page-subtitle{font-size:13px}.up-profile-card{border-radius:12px;padding:20px 16px}.up-avatar{font-size:24px;height:64px;width:64px}.up-camera-badge{height:24px;width:24px}.up-photo-title{font-size:13px}.up-photo-description{font-size:11px}.up-upload-button{font-size:12px;padding:7px 14px}.up-label{font-size:12px}.up-input,.up-select,.up-textarea{font-size:13px;padding:9px 11px}.up-button{font-size:13px;padding:9px 20px}}@media (max-width:375px){.up-main-content{padding:24px 12px}.up-page-title{font-size:20px}.up-profile-card{padding:16px 12px}.up-buttons-container{gap:10px}}@media (max-width:768px){.up-button,.up-upload-button{min-height:44px;touch-action:manipulation}.up-input,.up-select,.up-textarea{min-height:44px}}.rls-debug-container{background:#f5f5f5;min-height:100vh;padding:2rem 1rem}.rls-debug-content{margin:0 auto;max-width:800px}.rls-debug-title{color:#333;font-size:2rem;margin-bottom:1rem}.rls-debug-description{color:#666;margin-bottom:2rem}.rls-debug-button{background:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;margin-bottom:2rem;padding:.75rem 1.5rem;transition:background .2s}.rls-debug-button:hover:not(:disabled){background:#1565c0}.rls-debug-button:disabled{background:#ccc;cursor:not-allowed}.rls-debug-results{display:flex;flex-direction:column;gap:1rem}.rls-debug-result-card{background:#fff;border:2px solid #4caf50;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.rls-debug-result-card.error{border-color:#f44336}.rls-debug-result-header{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.rls-debug-status-icon{align-items:center;background:#4caf50;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;width:20px}.rls-debug-status-icon.error{background:#f44336}.rls-debug-result-title{color:#333;font-size:1.2rem;font-weight:600;margin:0}.rls-debug-error-box{background:#ffeaea;color:#d32f2f;font-size:.9rem;margin-bottom:1rem}.rls-debug-data-box,.rls-debug-error-box{border-radius:4px;font-family:monospace;padding:.75rem}.rls-debug-data-box{background:#f8f9fa;font-size:.8rem;max-height:200px;overflow:auto}.rls-debug-data-pre{margin:.5rem 0 0;white-space:pre-wrap}.rls-debug-info-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:2rem;padding:1.5rem}.rls-debug-info-title{color:#333;font-size:1.2rem;margin-bottom:1rem}.rls-debug-info-content{color:#666;font-size:.9rem;line-height:1.6}.rls-debug-info-content p{margin:.5rem 0}.rls-debug-info-content code{background:#f5f5f5;border-radius:3px;font-family:monospace;font-size:.85rem;padding:.2rem .4rem}.dashboard-container{background:#f5f7fa;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh}.dashboard-loading-spinner{animation:dashboard-spin .8s linear infinite;border:3px solid #1976d21a;border-radius:50%;border-top-color:#1976d266;height:32px;margin:0 auto;width:32px}@keyframes dashboard-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dashboard-loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:40px}.mobile-menu-toggle{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#4b5563;cursor:pointer;display:none;left:1rem;padding:.75rem;position:fixed;top:1rem;transition:all .2s ease;z-index:1100}.mobile-menu-toggle:hover{background:#f3f4f6;border-color:#2563eb;color:#2563eb}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-overlay{background:#00000080;bottom:0;display:none;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity .3s ease;z-index:999}.mobile-overlay.active{opacity:1}.dashboard-sidebar{background:#fff;border-right:1px solid #e5e7eb;box-shadow:2px 0 8px #0000000a;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:width .3s ease,transform .3s ease;width:280px;z-index:1000}.dashboard-sidebar.collapsed{width:80px}.sidebar-logo{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:flex-start;padding:1rem}.sidebar-brand{align-items:flex-start;cursor:pointer;display:flex;gap:12px;line-height:1.2;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.dashboard-sidebar.collapsed .sidebar-brand,.sidebar-brand{justify-content:center}.sidebar-brand-text-container{align-items:flex-start;display:flex;flex-direction:column}.sidebar-logo-icon{align-items:center;background-color:initial;border-radius:6px;display:flex;flex-shrink:0;height:60px;justify-content:center;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);width:180px}.dashboard-sidebar.collapsed .sidebar-logo-icon{height:60px;width:60px}.sidebar-logo-img{display:block;height:100%;object-fit:contain;width:100%}.sidebar-brand:hover .sidebar-logo-icon{transform:scale(1.05)}.dashboard-sidebar.collapsed .sidebar-logo-img{height:32px}.sidebar-toggle{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.sidebar-toggle:hover{background:#f3f4f6;color:#2563eb}.dashboard-sidebar.collapsed .sidebar-toggle{margin:0 auto}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1rem 0}.nav-section{margin-bottom:2rem}.nav-section-title{color:#9ca3af;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1.5rem;text-transform:uppercase}.dashboard-sidebar.collapsed .nav-section-title{display:none}.nav-item{align-items:center;color:#4b5563;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;padding:.75rem 1.5rem;position:relative;transition:all .2s ease}.nav-item:hover{background:#f3f4f6;color:#2563eb}.nav-item.active{background:#eff6ff;border-left:3px solid #2563eb;color:#2563eb}.nav-item.active:before{background:#2563eb;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.nav-item svg{color:inherit;flex-shrink:0}.nav-item span:not(.nav-arrow){flex:1 1}.nav-arrow{color:#9ca3af;font-size:.75rem}.dashboard-sidebar.collapsed .nav-item{justify-content:center;padding:.75rem}.dashboard-sidebar.collapsed .nav-item span{display:none}.toggle-switch{display:inline-block;height:24px;margin-left:auto;position:relative;width:44px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#d1d5db;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}.toggle-switch input:checked+.toggle-slider{background-color:#2563eb}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(20px)}.dashboard-sidebar.collapsed .toggle-switch{display:none}.sidebar-footer{border-top:1px solid #e5e7eb;display:flex;flex-direction:column;margin-top:auto;padding:0}.sidebar-footer .sidebar-toggle{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:center;margin:0;padding:1rem 1.5rem;width:100%}.dashboard-sidebar.collapsed .sidebar-footer .sidebar-toggle{padding:1rem;width:100%}.user-profile{gap:.75rem;padding:1rem 1.5rem}.user-avatar,.user-profile{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:50%;color:#fff;flex-shrink:0;font-size:.9rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-info{min-width:0}.user-name{color:#111827;font-size:.9rem;font-weight:600}.user-name,.user-role{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#6b7280;font-size:.75rem}.sign-out-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.sign-out-btn:hover{background:#f3f4f6;border-color:#d1d5db;color:#2563eb}.dashboard-sidebar.collapsed .sign-out-btn,.dashboard-sidebar.collapsed .user-info{display:none}.dashboard-sidebar.collapsed .user-profile{justify-content:center}.dashboard-container .dashboard-main{flex:1 1;margin-left:280px;max-width:none;min-height:100vh;transition:margin-left .3s ease;width:calc(100% - 280px)}.dashboard-container .dashboard-main.sidebar-collapsed{margin-left:80px;width:calc(100% - 80px)}.dashboard-content{box-sizing:border-box;margin:0;max-width:none;padding:2rem;width:100%}.dashboard-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.dashboard-title{color:#111827;font-family:Elms Sans,sans-serif;font-size:2rem;font-weight:700;margin:0}.dashboard-controls{align-items:center;display:flex;gap:1rem}.time-period-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.time-period-select:hover{border-color:#2563eb}.time-period-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.add-data-btn{align-items:center;background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.add-data-btn:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.add-data-btn span{font-size:1.2rem;font-weight:300;line-height:1}.kpi-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.kpi-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;transition:all .2s ease}.kpi-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.kpi-title{color:#6b7280;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.kpi-value{color:#111827;font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:.75rem}.kpi-change{align-items:center;display:flex;font-size:.875rem;font-weight:600;gap:.25rem}.kpi-change.positive{color:#10b981}.kpi-change.negative{color:#ef4444}.charts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.chart-card{box-shadow:0 1px 3px #0000001a;padding:1.5rem}.chart-title{color:#111827;font-size:1.125rem;margin:0 0 1.5rem}.chart-placeholder{align-items:center;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:8px;color:#6b7280;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:2rem;text-align:center}.chart-placeholder p{margin:.5rem 0}.chart-note{color:#9ca3af;font-size:.875rem;font-style:italic}.chart-header{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.toggle-details-btn{background:#2563eb;border:none;border-radius:6px;color:#fff;font-size:.9rem;font-weight:500;padding:.5rem 1rem}.toggle-details-btn:hover{background:#1d4ed8}.toggle-details-btn.active{background:#6b7280}.call-stats-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem}.call-stat-item{background:#f8f9fa;padding:1rem;text-align:center}.call-stat-item h4{font-size:.875rem;font-weight:500;margin:0 0 .5rem}.stat-value{font-family:Elms Sans,sans-serif;font-size:1.5rem;font-weight:700;margin:0}.calls-by-module{margin-bottom:1.5rem}.calls-by-module h4{color:#333;font-size:1rem;margin:0 0 1rem}.module-stats{gap:.5rem}.module-stat-item{background:#f8f9fa;border-radius:6px;padding:.75rem}.module-name{color:#111827;text-transform:capitalize}.module-cost{color:#2563eb;font-weight:600}.call-details{margin-top:1.5rem}.call-details h4{color:#333;font-size:1rem;margin:0 0 1rem}.calls-table-container{max-height:400px;overflow-y:auto}.calls-table{font-size:.9rem}.calls-table thead{background:#f5f5f5;position:-webkit-sticky;position:sticky;top:0;z-index:10}.calls-table th{border-bottom:1px solid #e0e0e0;color:#666;font-size:.875rem;padding:.75rem}.calls-table td{border-bottom:1px solid #f0f0f0;padding:.75rem}.calls-table tbody tr:hover{background:#f9fafb}.module-badge{border-radius:4px;font-size:.8rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.module-badge.practipal{background:#e3f2fd;color:#1976d2}.module-badge.ezrx{background:#e8f5e8;color:#4caf50}.module-badge.ezecg{background:#fff3e0;color:#f57c00}.no-data{color:#666;padding:2rem}.kpi-subtitle{color:#9ca3af;font-size:.75rem;margin-bottom:.5rem}.nav-back-btn{background:#fff;border:1px solid #2563eb;border-radius:6px;color:#2563eb;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.nav-back-btn:hover{background:#eff6ff}.quick-stats-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:2rem}.quick-stat-card{align-items:flex-start;background:#fff;border-left:4px solid #0000;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.quick-stat-card:hover{border-left-color:#2563eb;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.quick-stat-card:first-child{border-left-color:#3b82f6}.quick-stat-card:first-child .quick-stat-icon{background:#eff6ff;color:#3b82f6}.quick-stat-card:first-child:hover{background:#f8fafc;border-left-color:#2563eb}.quick-stat-card:nth-child(2){border-left-color:#06b6d4}.quick-stat-card:nth-child(2) .quick-stat-icon{background:#ecfeff;color:#06b6d4}.quick-stat-card:nth-child(2):hover{background:#f0fdfa;border-left-color:#0891b2}.quick-stat-card:nth-child(3){border-left-color:#10b981}.quick-stat-card:nth-child(3) .quick-stat-icon{background:#ecfdf5;color:#10b981}.quick-stat-card:nth-child(3):hover{background:#f0fdf4;border-left-color:#059669}.quick-stat-card:nth-child(4){border-left-color:#f59e0b}.quick-stat-card:nth-child(4) .quick-stat-icon{background:#fffbeb;color:#f59e0b}.quick-stat-card:nth-child(4):hover{background:#fefce8;border-left-color:#d97706}.quick-stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:56px;justify-content:center;transition:all .2s ease;width:56px}.quick-stat-card:hover .quick-stat-icon{transform:scale(1.05)}.quick-stat-content{flex:1 1;min-width:0}.quick-stat-value{color:#111827;font-family:Elms Sans,sans-serif;font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:.25rem}.quick-stat-label{color:#4b5563;font-family:Elms Sans,sans-serif;font-size:.875rem;font-weight:600;letter-spacing:.025em;margin-bottom:.125rem;text-transform:uppercase}.quick-stat-sublabel{color:#6b7280;font-family:Elms Sans,sans-serif;font-size:.8125rem;font-weight:500;margin-top:.25rem}.quick-stat-arrow{color:#9ca3af;flex-shrink:0;font-size:1.25rem;margin-top:.25rem;transition:all .2s ease}.quick-stat-card:hover .quick-stat-arrow{color:#2563eb;transform:translateX(4px)}.summary-section{margin-bottom:2rem}.summary-title{color:#111827;font-family:Elms Sans,sans-serif;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.summary-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.summary-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.summary-card h4{color:#111827;font-family:Elms Sans,sans-serif;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.summary-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;min-height:200px}.summary-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem;transition:all .2s ease}.summary-item:hover{background:#f3f4f6}.summary-item-main{color:#111827;font-family:Elms Sans,sans-serif;font-size:.9rem;font-weight:500}.summary-item-sub{color:#6b7280;font-family:Elms Sans,sans-serif;font-size:.8rem}.summary-item-sub.active{color:#2e7d2e;font-weight:500}.summary-item-sub.inactive{color:#d32f2f;font-weight:500}.view-all-btn{background:#0000;border:1px solid #e5e7eb;border-radius:8px;color:#2563eb;font-size:.9rem;font-weight:500;padding:.75rem;transition:all .2s ease;width:100%}.view-all-btn:hover{background:#eff6ff;border-color:#2563eb}.section-header{gap:1rem;margin-bottom:1.5rem}.section-title{color:#111827;font-size:1.5rem;margin:0}.section-actions{display:flex;flex-wrap:wrap;gap:1rem}.btn{font-size:1rem;padding:.75rem 1.5rem}.btn-primary{background:#1976d2}.btn-primary:hover{background:#1565c0}.btn-success{background:#4caf50}.btn-success:hover{background:#45a049}.btn-warning{background:#ff9800;color:#fff}.btn-warning:hover{background:#f57c00}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover{background:#d32f2f}.btn-info{background:#2196f3;color:#fff}.btn-info:hover{background:#1976d2}.btn-sm{font-size:.8rem;padding:.5rem 1rem}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{font-size:.9rem}.data-table thead{background:#f5f5f5}.data-table th{border-bottom:1px solid #ddd;color:#333;padding:1rem}.data-table td{border-bottom:1px solid #eee;color:#666;padding:1rem}.no-data-cell{color:#666;font-style:italic;padding:2rem;text-align:center}.status-badge{font-size:.8rem;font-weight:600;padding:.25rem .75rem}.status-badge.active{background:#e8f5e8;color:#2e7d2e}.status-badge.inactive{background:#ffeaea;color:#d32f2f}.module-access-cell{flex-direction:column}.module-access-btn,.module-access-cell{align-items:center;display:flex;gap:.25rem}.module-access-btn{border:none;border-radius:12px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:.75rem;font-weight:500;justify-content:center;min-width:80px;padding:.25rem .5rem;transition:all .2s ease}.module-access-btn:hover{opacity:.8;transform:translateY(-1px)}.module-access-display{align-items:center;display:flex;flex-direction:column;gap:.25rem}.module-badge-small{align-items:center;border:1px solid;border-radius:12px;display:inline-flex;font-size:.7rem;font-weight:500;gap:.25rem;padding:.2rem .5rem}.module-badge-small.enabled{background:#2563eb1a;border-color:#2563eb4d;color:#1976d2}.module-badge-small.disabled{background:#f5f5f5;border-color:#ddd;color:#999}.action-buttons{flex-wrap:wrap;justify-content:center}.message{border:1px solid;border-radius:8px;padding:1rem}.message.success{background:#e8f5e8;border-color:#4caf50;color:#2e7d2e}.message.error{background:#ffeaea;border-color:#f44336;color:#d32f2f}.credit-transactions h4{color:#333;font-family:Elms Sans,sans-serif;font-size:1rem;margin:0 0 1rem}.positive-value{color:#4caf50}.modal-overlay{z-index:2000}.modal-content{box-shadow:0 10px 30px #0003;max-height:80vh;padding:2rem}.modal-header{margin-bottom:1.5rem}.modal-title{font-size:1.5rem}.form-group{margin-bottom:1rem}.form-input{box-sizing:border-box;font-size:1rem;padding:.75rem}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{border:1px solid #ddd;border-radius:6px;font-family:Elms Sans,sans-serif;font-size:1rem;min-height:80px;padding:.75rem;width:100%}.form-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.modal-actions{gap:1rem;margin-top:1.5rem}.checkbox-group{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:1rem}.checkbox-item{align-items:center;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem}.checkbox-item input[type=checkbox]{cursor:pointer;height:16px;width:16px}.checkbox-label{font-weight:500}.checkbox-description{color:#666;font-size:.85rem}@media (max-width:1024px){.dashboard-sidebar{width:240px}.dashboard-container .dashboard-main{margin-left:240px;width:calc(100% - 240px)}.dashboard-container .dashboard-main.sidebar-collapsed{margin-left:80px;width:calc(100% - 80px)}.charts-grid{grid-template-columns:1fr}}@media (max-width:768px){.mobile-menu-toggle{display:flex}.mobile-overlay{display:block}.dashboard-sidebar{transform:translateX(-100%);width:280px}.dashboard-sidebar.mobile-open{transform:translateX(0)}.dashboard-sidebar.collapsed{transform:translateX(-100%);width:280px}.dashboard-container .dashboard-main,.dashboard-container .dashboard-main.sidebar-collapsed{margin-left:0;width:100%}.dashboard-content{padding:4rem 1rem 1rem}.dashboard-header{align-items:flex-start;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.dashboard-title{font-size:1.5rem}.dashboard-controls{flex-direction:column;gap:.75rem;width:100%}.add-data-btn,.time-period-select{justify-content:center;min-height:44px;width:100%}.kpi-grid{gap:1rem;grid-template-columns:1fr}.kpi-card{padding:1.25rem}.kpi-value{font-size:1.75rem}.charts-grid{gap:1rem;grid-template-columns:1fr}.chart-card{padding:1.25rem}.chart-placeholder{min-height:250px;padding:1.5rem}.chart-title{font-size:1rem}.table-container{-webkit-overflow-scrolling:touch;margin:0 -1rem;overflow-x:auto;padding:0 1rem}.calls-table,.data-table{min-width:600px}.calls-table td,.calls-table th,.data-table td,.data-table th{font-size:.85rem;padding:.5rem}.summary-grid{gap:1rem;grid-template-columns:1fr}.summary-card{padding:1.25rem}.summary-list{min-height:auto}.section-header{align-items:flex-start;flex-direction:column}.section-title{font-size:1.25rem}.section-actions{flex-direction:column;gap:.75rem;width:100%}.section-actions .btn{min-height:44px;width:100%}.action-buttons{flex-direction:column;gap:.5rem;width:100%}.action-buttons .btn{min-height:44px;width:100%}.modal-overlay{padding:.5rem}.modal-content{max-height:90vh;padding:1.5rem}.modal-title{font-size:1.25rem}.modal-actions{flex-direction:column;gap:.75rem}.modal-actions .btn{min-height:44px;width:100%}.call-stats-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.call-stat-item{padding:.75rem}.stat-value{font-size:1.25rem}.module-access-cell{flex-direction:row;flex-wrap:wrap;gap:.5rem}.module-access-btn,.module-badge-small{font-size:.7rem;min-width:70px;padding:.2rem .4rem}.quick-stats-grid{gap:1rem;grid-template-columns:1fr}.quick-stat-card{padding:1.25rem}.quick-stat-icon{height:48px;width:48px}.quick-stat-value{font-size:1.875rem}.quick-stat-label{font-size:.8rem}.btn,.nav-item,.sign-out-btn,.toggle-switch,.view-all-btn{min-height:44px}.chart-header{align-items:flex-start;flex-direction:column}.toggle-details-btn{min-height:44px;width:100%}}@media (max-width:480px){.dashboard-content{padding:3.5rem .75rem .75rem}.dashboard-title{font-size:1.25rem}.kpi-value,.quick-stat-value{font-size:1.5rem}.chart-title{font-size:.95rem}.call-stats-grid{grid-template-columns:1fr}.modal-content{padding:1rem}.form-input,.form-textarea{font-size:16px}.mobile-menu-toggle{left:.75rem;padding:.625rem;top:.75rem}.section-title{font-size:1.125rem}.summary-card h4{font-size:1rem}.btn{font-size:.9rem;padding:.625rem 1.25rem}}@media (max-width:360px){.dashboard-content{padding:3rem .5rem .5rem}.chart-card,.kpi-card,.summary-card{padding:1rem}.quick-stat-card{gap:.75rem;padding:1rem}.quick-stat-icon{height:40px;width:40px}.quick-stat-value{font-size:1.375rem}}:root{--info-bg:#1976d21a}.dm-loading-overlay{align-items:center;background:#0009;bottom:0;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.dm-loading-card{background:#fff;border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);min-width:300px;padding:40px;text-align:center}.dm-loading-spinner{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top:4px solid var(--primary-blue);height:48px;margin:0 auto 16px;width:48px}.dm-loading-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.dm-overlay{align-items:center;animation:overlayFadeIn .2s ease-out;background:#0009;bottom:0;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:9999}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.dm-modal{animation:modalSlideIn .3s ease-out;background:#fff;border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:900px;overflow-y:auto;width:100%}.dm-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);gap:16px;justify-content:space-between;padding:32px 40px 24px}.dm-header,.dm-header-content{align-items:center;display:flex}.dm-header-content{flex:1 1;gap:12px}.dm-header-icon{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.dm-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.5px;margin:0}.dm-close-btn{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:8px;transition:all .2s ease}.dm-close-btn:hover{background:#0000000d;color:#1f2937;color:var(--text-dark)}.dm-info-card{background:#1976d21a;background:var(--info-bg);border:1px solid #1976d24d;border-radius:8px;margin:24px 40px;padding:20px}.dm-info-header{align-items:center;display:flex;gap:8px;margin-bottom:12px}.dm-info-icon{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.dm-info-title{color:#1f2937;color:var(--text-dark);font-size:14px;font-weight:600}.dm-info-list,.dm-info-title{font-family:Elms Sans,sans-serif;margin:0}.dm-info-list{color:#6b7280;color:var(--text-medium);font-size:13px;line-height:1.6;padding-left:20px}.dm-info-list li{margin-bottom:6px}.dm-info-list code{background:#1976d226;border-radius:4px;color:#1976d2;color:var(--primary-blue);font-family:SF Mono,Monaco,Inconsolata,Courier New,monospace;font-size:12px;font-weight:500;padding:2px 6px}.dm-message{align-items:center;animation:messageSlideIn .3s ease-out;border:1px solid;border-radius:8px;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;gap:12px;margin:0 40px 24px;padding:16px 20px}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dm-message-success{background:#d1fae5;background:var(--success-bg);border-color:#10b981;border-color:var(--success);color:#10b981;color:var(--success)}.dm-message-error{background:#fee2e2;background:var(--error-bg);border-color:#ef4444;border-color:var(--error);color:#ef4444;color:var(--error)}.dm-message-info{background:#1976d21a;background:var(--info-bg);border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.dm-section{padding:0 40px 24px}.dm-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0 0 16px}.dm-empty-state{background:#f9fafb;border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:8px;padding:48px 24px;text-align:center}.dm-empty-icon{color:#9ca3af;color:var(--text-light);margin-bottom:16px;opacity:.5}.dm-empty-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;margin:0 0 4px}.dm-empty-subtext{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;margin:0}.dm-domains-list{background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;max-height:300px;overflow-y:auto;padding:8px}.dm-domain-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:12px;margin-bottom:8px;padding:12px 16px;transition:all .2s ease}.dm-domain-item:last-child{margin-bottom:0}.dm-domain-item:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 2px 8px #1976d21a}.dm-domain-icon{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.dm-domain-text{color:#1f2937;color:var(--text-dark);flex:1 1;font-family:SF Mono,Monaco,Inconsolata,Courier New,monospace;font-weight:500}.dm-domain-wildcard{color:#f59e0b;color:var(--warning);font-weight:700}.dm-remove-btn{align-items:center;background:#fee2e2;background:var(--error-bg);border:none;border-radius:6px;color:#ef4444;color:var(--error);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:6px 8px;transition:all .2s ease}.dm-remove-btn:hover{background:#ef4444;background:var(--error);color:#fff;transform:scale(1.05)}.dm-form-group{padding:0 40px 24px}.dm-form-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;letter-spacing:-.3px;margin:0 0 12px}.dm-input-group{align-items:stretch;display:flex;gap:12px}.dm-input-group input{flex:1 1}.dm-input{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.dm-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.dm-input::placeholder{color:#9ca3af;color:var(--text-light)}.dm-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.dm-btn:disabled{cursor:not-allowed;opacity:.5}.dm-btn-primary{background:#10b981;background:var(--success);border:1px solid #10b981;border:1px solid var(--success);color:#fff}.dm-btn-primary:hover:not(:disabled){background:#059669;border-color:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.dm-btn-secondary{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.dm-btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#1f2937;color:var(--text-dark)}.dm-btn-info{background:#1976d2;background:var(--primary-blue);border:1px solid #1976d2;border:1px solid var(--primary-blue);color:#fff}.dm-btn-info:hover:not(:disabled){background:#1565c0;border-color:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}.dm-btn-cancel{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium);padding:12px 24px}.dm-btn-cancel:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.dm-btn-save{background:#1976d2;background:var(--primary-blue);border:1px solid #1976d2;border:1px solid var(--primary-blue);color:#fff;padding:12px 24px}.dm-btn-save:hover:not(:disabled){background:#1565c0;border-color:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}.dm-toggle-section{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.dm-toggle-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.dm-toggle-btn:hover{background:#f9fafb;border-color:#d1d5db;color:#1f2937;color:var(--text-dark)}.dm-bulk-container{animation:slideDown .3s ease-out}.dm-textarea{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:SF Mono,Monaco,Inconsolata,Courier New,monospace;font-size:13px;height:120px;padding:12px 16px;resize:vertical;transition:all .2s ease;width:100%}.dm-textarea:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.dm-textarea::placeholder{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif}.dm-bulk-actions{display:flex;gap:12px;margin-top:12px}.dm-actions{background:#f9fafb;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;padding:24px 40px 32px}@media (max-width:768px){.dm-modal{margin:0 16px;max-height:95vh;max-width:none}.dm-header{align-items:flex-start;flex-direction:column;padding:24px 28px 20px}.dm-header-content{width:100%}.dm-close-btn{position:absolute;right:28px;top:24px}.dm-title{font-size:20px}.dm-actions,.dm-form-group,.dm-info-card,.dm-message,.dm-section{padding-left:28px;padding-right:28px}.dm-input-group{flex-direction:column}.dm-btn{width:100%}.dm-bulk-actions{flex-direction:column}.dm-actions{flex-direction:column-reverse}}@media (max-width:480px){.dm-modal{margin:0 8px}.dm-header{padding:20px 24px 16px}.dm-close-btn{right:24px;top:20px}.dm-title{font-size:18px}.dm-actions,.dm-form-group,.dm-info-card,.dm-message,.dm-section{padding-left:24px;padding-right:24px}.dm-domain-item{font-size:13px;padding:10px 12px}.dm-domains-list{max-height:250px}}@media (prefers-reduced-motion:reduce){.dm-btn,.dm-bulk-container,.dm-message,.dm-modal,.dm-overlay{animation:none;transition:none}.dm-btn:hover:not(:disabled){transform:none}}.dm-btn:focus-visible{outline:3px solid #1976d280;outline-offset:2px}.dm-domains-list::-webkit-scrollbar,.dm-modal::-webkit-scrollbar{width:8px}.dm-domains-list::-webkit-scrollbar-track,.dm-modal::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.dm-domains-list::-webkit-scrollbar-thumb,.dm-modal::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.dm-domains-list::-webkit-scrollbar-thumb:hover,.dm-modal::-webkit-scrollbar-thumb:hover{background:#9ca3af}.student-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.student-modal-container{background:#fff;background:var(--bg-page);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-height:90vh;max-width:700px;overflow-y:auto;position:relative;width:100%}.student-modal-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;gap:16px;justify-content:space-between;padding:32px 32px 24px}.student-modal-header-content{align-items:flex-start;display:flex;flex:1 1;gap:16px}.student-modal-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.student-modal-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0 0 4px}.student-modal-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;margin:0}.student-modal-close{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s ease;width:36px}.student-modal-close:hover{background:#fee2e2;background:var(--error-bg);border-color:#ef4444;border-color:var(--error);color:#ef4444;color:var(--error)}.student-modal-form{padding:32px}.student-form-section{margin-bottom:32px}.student-form-section:last-child{margin-bottom:0}.student-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.3px;margin:0 0 8px}.student-section-desc{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;margin:0 0 20px}.student-form-group{margin-bottom:20px}.student-form-group:last-child{margin-bottom:0}.student-label{color:#1f2937;color:var(--text-dark);display:block;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px;margin-bottom:8px}.student-required{color:#ef4444;color:var(--error);margin-left:2px}.student-optional{color:#9ca3af;color:var(--text-light);font-size:13px;font-weight:500}.student-input{background:#fff;background:var(--bg-page);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.student-input::placeholder{color:#9ca3af;color:var(--text-light)}.student-input:hover:not(:disabled){border-color:#6b7280;border-color:var(--text-medium)}.student-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.student-input:disabled{background:#f9fafb;background:var(--bg-secondary);cursor:not-allowed;opacity:.6}.student-modules-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.student-checkbox-hidden{opacity:0;pointer-events:none;position:absolute}.student-module-card{align-items:center;background:#fff;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;gap:16px;padding:16px;position:relative;transition:all .2s ease}.student-module-card:hover{background:#1976d205;border-color:#1976d2;border-color:var(--primary-blue);transform:translateX(4px)}.student-module-card.active{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 1px #1976d2;box-shadow:0 0 0 1px var(--primary-blue)}.student-module-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.student-module-icon.practipal{background:#1976d21a;color:#1976d2;color:var(--primary-blue)}.student-module-icon.ezrx{background:#7c3aed1a;color:#7c3aed;color:var(--primary-purple)}.student-module-icon.ezecg{background:#10b9811a;color:#10b981;color:var(--success)}.student-module-content{flex:1 1}.student-module-name{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:700;letter-spacing:-.2px;margin-bottom:2px}.student-module-desc{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px}.student-module-check{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.student-info-box{align-items:flex-start;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:8px;display:flex;gap:12px;padding:14px 16px}.student-info-icon{color:#f59e0b;color:var(--warning);flex-shrink:0;margin-top:2px}.student-info-text{color:#92400e;font-family:Elms Sans,sans-serif;font-size:13px;line-height:1.5}.student-message{align-items:flex-start;display:flex;gap:12px;margin-bottom:24px;padding:16px}.student-message.success{background:var(--success-bg);border-color:var(--success)}.student-message.error{background:var(--error-bg);border-color:var(--error)}.student-message-icon{flex-shrink:0;margin-top:2px}.student-message.success .student-message-icon{color:#10b981;color:var(--success)}.student-message.error .student-message-icon{color:#ef4444;color:var(--error)}.student-message-content{flex:1 1;font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;white-space:pre-line}.student-modal-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.student-btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.student-btn-secondary{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.student-btn-secondary:hover:not(:disabled){background:#f9fafb;background:var(--bg-secondary);border-color:#6b7280;border-color:var(--text-medium)}.student-btn-primary{background:#1976d2;background:var(--primary-blue);color:#fff}.student-btn-primary:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.student-btn:disabled{cursor:not-allowed;opacity:.5}.student-modal-container::-webkit-scrollbar{width:8px}.student-modal-container::-webkit-scrollbar-track{background:#f9fafb;background:var(--bg-secondary);border-radius:4px}.student-modal-container::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}.student-modal-container::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-light)}@media (max-width:768px){.student-modal-container{max-height:95vh;max-width:95%}.student-modal-header{padding:24px 20px 20px}.student-modal-header-content{align-items:flex-start;flex-direction:column}.student-modal-title{font-size:20px}.student-modal-subtitle{font-size:13px}.student-modal-form{padding:24px 20px}.student-modal-footer{flex-direction:column-reverse}.student-btn{width:100%}}@media (max-width:480px){.student-modal-header{padding:20px 16px 16px}.student-modal-icon{height:40px;width:40px}.student-modal-title{font-size:18px}.student-modal-form{padding:20px 16px}.student-module-card{padding:12px}.student-module-icon{height:36px;width:36px}}.student-modal-container{animation:slideIn .3s ease}.bulk-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.bulk-modal-container{background:#f9fafb;background:var(--bg-secondary);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-height:90vh;max-width:1200px;overflow-y:auto;padding:40px;position:relative;width:100%}.bulk-back-btn{align-items:center;background:#0000;border:none;color:#6b7280;color:var(--text-medium);cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;gap:8px;margin-bottom:24px;padding:8px 0;transition:all .2s ease}.bulk-back-btn:hover{color:#1976d2;color:var(--primary-blue)}.bulk-header{margin-bottom:32px}.bulk-title{color:#1f2937;color:var(--text-dark);font-size:clamp(28px,3vw,36px);font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.bulk-subtitle,.bulk-title{font-family:Elms Sans,sans-serif}.bulk-subtitle{color:#6b7280;color:var(--text-medium);font-size:16px;font-weight:400;margin:0}.bulk-steps{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;justify-content:center;margin-bottom:48px;padding:32px 0}.bulk-step,.bulk-steps{align-items:center;display:flex}.bulk-step{flex-direction:column;gap:8px}.bulk-step-number{align-items:center;background:#fff;border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:50%;color:#9ca3af;color:var(--text-light);display:flex;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;height:40px;justify-content:center;transition:all .3s ease;width:40px}.bulk-step.active .bulk-step-number{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.bulk-step-label{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;transition:all .3s ease}.bulk-step.active .bulk-step-label{color:#1976d2;color:var(--primary-blue)}.bulk-step-line{background:#e5e7eb;background:var(--border-color);height:2px;margin:0 16px;transition:all .3s ease;width:120px}.bulk-step-line.active{background:#1976d2;background:var(--primary-blue)}.bulk-content{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;margin-bottom:24px;padding:32px}.bulk-section{margin-bottom:32px}.bulk-label{display:block;font-size:14px;font-weight:700;letter-spacing:-.2px;margin-bottom:8px}.bulk-label,.bulk-select{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif}.bulk-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.bulk-select:hover{border-color:#6b7280;border-color:var(--text-medium)}.bulk-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.bulk-helper-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;margin:8px 0 0}.bulk-template-card{align-items:center;background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:16px;margin-bottom:32px;padding:20px;transition:all .2s ease}.bulk-template-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.bulk-template-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.bulk-template-content{flex:1 1}.bulk-template-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:700;letter-spacing:-.2px;margin:0 0 4px}.bulk-template-desc{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;margin:0}.bulk-template-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease;white-space:nowrap}.bulk-template-btn:hover{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);transform:translateY(-1px)}.bulk-upload-area{background:#f9fafb;background:var(--bg-secondary);border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:12px;cursor:pointer;margin-bottom:32px;padding:60px 40px;text-align:center;transition:all .3s ease}.bulk-upload-area:hover{background:#1976d205;border-color:#1976d2;border-color:var(--primary-blue)}.bulk-upload-area.drag-active{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);transform:scale(1.01)}.bulk-upload-area.has-file{background:#d1fae5;background:var(--success-bg);border-color:#10b981;border-color:var(--success);border-style:solid}.bulk-upload-icon{color:#9ca3af;color:var(--text-light);margin-bottom:16px}.bulk-upload-area.drag-active .bulk-upload-icon{animation:bounce .5s ease infinite;color:#1976d2;color:var(--primary-blue)}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bulk-upload-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;margin:0 0 8px}.bulk-upload-hint{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;margin:0}.bulk-file-icon{color:#10b981;color:var(--success);margin-bottom:16px}.bulk-file-name{color:#1f2937;color:var(--text-dark);font-size:16px;font-weight:600;margin:0 0 4px}.bulk-file-name,.bulk-file-size{font-family:Elms Sans,sans-serif}.bulk-file-size{color:#6b7280;color:var(--text-medium);font-size:14px;margin:0 0 16px}.bulk-file-remove{background:#0000;border:1px solid #ef4444;border:1px solid var(--error);border-radius:6px;color:#ef4444;color:var(--error);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.bulk-file-remove:hover{background:#fee2e2;background:var(--error-bg)}.bulk-progress-card{background:#1976d20d;border:1px solid #1976d233;border-radius:8px;margin-bottom:32px;padding:20px}.bulk-progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.bulk-progress-text{font-weight:600}.bulk-progress-percent,.bulk-progress-text{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:14px}.bulk-progress-percent{font-weight:700}.bulk-progress-current{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;margin-bottom:12px}.bulk-progress-bar-bg{background:#fff;border-radius:4px;height:8px;overflow:hidden;width:100%}.bulk-progress-bar-fill{background:#1976d2;background:var(--primary-blue);border-radius:4px;height:100%;transition:width .3s ease}.bulk-results{display:flex;flex-direction:column;gap:20px;max-height:400px;overflow-y:auto}.bulk-result-card{border:1px solid;border-radius:8px;padding:20px}.bulk-result-card.success{background:#d1fae5;background:var(--success-bg);border-color:#10b981;border-color:var(--success)}.bulk-result-card.error{background:#fee2e2;background:var(--error-bg);border-color:#ef4444;border-color:var(--error)}.bulk-result-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.bulk-result-card.success .bulk-result-header{color:#10b981;color:var(--success)}.bulk-result-card.error .bulk-result-header{color:#ef4444;color:var(--error)}.bulk-result-title{font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.2px;margin:0}.bulk-result-list{display:flex;flex-direction:column;gap:8px}.bulk-result-item{align-items:center;background:#fff;border-radius:6px;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;justify-content:space-between;padding:12px 16px}.bulk-result-name{color:#1f2937;color:var(--text-dark);font-weight:600}.bulk-result-email{color:#6b7280;color:var(--text-medium);font-size:13px}.bulk-result-item.error{align-items:flex-start;flex-direction:column;gap:4px}.bulk-result-error-main{color:#1f2937;color:var(--text-dark);font-size:14px}.bulk-result-error-reason{color:#6b7280;color:var(--text-medium);font-size:12px}.bulk-result-more{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-style:italic;margin-top:8px}.bulk-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.bulk-btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.bulk-btn-secondary{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.bulk-btn-secondary:hover:not(:disabled){background:#f9fafb;background:var(--bg-secondary);border-color:#6b7280;border-color:var(--text-medium)}.bulk-btn-primary{background:#1976d2;background:var(--primary-blue);color:#fff}.bulk-btn-primary:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.bulk-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.bulk-modal-container{max-height:95vh;padding:24px}.bulk-title{font-size:24px}.bulk-subtitle{font-size:14px}.bulk-steps{padding:24px 16px}.bulk-step-line{margin:0 8px;width:60px}.bulk-content{padding:24px 20px}.bulk-upload-area{padding:40px 20px}.bulk-template-card{flex-direction:column;text-align:center}.bulk-template-btn{width:100%}.bulk-footer{flex-direction:column-reverse}.bulk-btn{width:100%}}@media (max-width:480px){.bulk-steps{flex-direction:column;gap:16px}.bulk-step-line{height:40px;margin:0;width:2px}.bulk-result-item{align-items:flex-start;flex-direction:column;gap:4px}}.chart-card{margin-bottom:24px;padding:28px;transition:all .2s ease}.chart-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.chart-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);justify-content:space-between;margin-bottom:24px;padding-bottom:20px}.chart-header,.chart-title{align-items:center;display:flex}.chart-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;font-weight:600;gap:8px;letter-spacing:-.3px;margin:0}.toggle-details-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.toggle-details-btn:hover{background:#1976d20d;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1976d2;color:var(--primary-blue);transform:translateY(-1px)}.toggle-details-btn.active,.toggle-details-btn:hover{border-color:#1976d2;border-color:var(--primary-blue)}.toggle-details-btn.active{background:#1976d2;background:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.toggle-details-btn.active:hover{background:#1565c0;box-shadow:0 4px 8px #1976d24d}.call-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:28px}.call-stat-item{background:#1976d208;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;padding:20px;transition:all .2s ease}.call-stat-item:hover{background:#1976d20d;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.call-stat-item h4{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.call-stat-item .stat-value{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:800;line-height:1;margin:0}.calls-by-module{background:#1976d205;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;margin-bottom:28px;padding:20px}.calls-by-module h4{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;letter-spacing:-.3px;margin:0 0 16px}.module-stats{flex-direction:column;gap:12px}.module-stat-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:14px 16px;transition:all .2s ease}.module-stat-item:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateX(4px)}.module-name{color:#1f2937;color:var(--text-dark);flex:2 1;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600}.module-count{color:#6b7280;color:var(--text-medium);font-size:13px;font-weight:500;text-align:center}.module-cost,.module-count{flex:1 1;font-family:Elms Sans,sans-serif}.module-cost{color:#1976d2;color:var(--primary-blue);font-size:14px;font-weight:700;text-align:right}.call-details{border-top:2px solid #e5e7eb;border-top:2px solid var(--border-color);margin-top:28px;padding-top:28px}.call-details h4{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0 0 20px}.calls-table-container{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.no-data{background:#1976d205;border-radius:8px;color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;padding:60px 20px;text-align:center}.calls-table{background:#fff;border-collapse:collapse;font-size:14px;width:100%}.calls-table thead{background:#1976d208}.calls-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.calls-table tbody tr{transition:background-color .2s ease}.calls-table tbody tr:hover{background:#1976d205}.calls-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:16px 20px;vertical-align:middle}.calls-table tbody tr:last-child td{border-bottom:none}.module-badge{border-radius:12px;display:inline-block;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.module-badge.practipal{background:#1976d21a;border:1px solid #bae6fd;color:#1e40af}.module-badge.ezrx{background:#7c3aed1a;border:1px solid #ddd6fe;color:#6d28d9}.module-badge.ezecg{background:#10b9811a;border:1px solid #a7f3d0;color:#065f46}.module-badge.viva{background:#f59e0b1a;border:1px solid #fde68a;color:#92400e}.module-badge.mcq{background:#ef44441a;border:1px solid #fecaca;color:#991b1b}@media (max-width:1024px){.call-stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.calls-table{font-size:13px}.calls-table td,.calls-table th{padding:12px 16px}}@media (max-width:768px){.chart-card{padding:24px}.chart-header{align-items:flex-start;flex-direction:column;gap:16px}.toggle-details-btn{justify-content:center;width:100%}.call-stats-grid{grid-template-columns:1fr}.module-stat-item{align-items:flex-start;flex-direction:column;gap:8px}.module-cost,.module-count,.module-name{text-align:left}.calls-table-container{overflow-x:scroll}.calls-table{min-width:800px}}@media (max-width:480px){.chart-card{padding:20px}.chart-title{font-size:18px}.call-stat-item .stat-value{font-size:24px}.call-details,.calls-by-module{padding:16px}}.call-details{animation:fadeIn .3s ease-out}@media print{.toggle-details-btn{display:none}.chart-card{box-shadow:none;break-inside:avoid;page-break-inside:avoid}.calls-table{font-size:12px}.calls-table td,.calls-table th{padding:10px}}.student-management-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem}.student-management-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.student-management-title{color:#111827;font-family:Elms Sans,sans-serif;font-size:1.8rem;font-weight:700;margin:0}.student-management-actions{display:flex;flex-wrap:wrap;gap:1rem}.student-action-btn{align-items:center;background:#fff;border:1.5px solid #2563eb;border-radius:8px;color:#2563eb;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.student-action-btn:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8;transform:translateY(-1px)}.student-action-btn svg{color:inherit;flex-shrink:0}.student-action-btn-primary,.student-action-btn-success,.student-action-btn-warning{background:#fff;border:1.5px solid #2563eb;color:#2563eb}.student-action-btn-primary:hover,.student-action-btn-success:hover,.student-action-btn-warning:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.student-filters{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:1rem;min-width:0}.student-search{flex:1 1;min-width:250px;position:relative}.student-search-input{border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem;padding:.75rem 1rem .75rem 2.5rem;transition:all .2s ease;width:100%}.student-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.student-search-icon{color:#9ca3af;left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.student-filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:.95rem;min-width:150px;padding:.75rem 1rem}.student-filter-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.students-table-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto}.students-table{border-collapse:collapse;font-size:.9rem;min-width:1000px;width:100%}.students-table thead{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:10}.students-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:.85rem;font-weight:600;letter-spacing:.05em;padding:1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.students-table th:first-child{padding-left:1.5rem}.students-table th:last-child{padding-right:1.5rem}.students-table tbody tr{border-bottom:1px solid #f3f4f6;transition:all .2s ease}.students-table tbody tr:hover{background:#f9fafb}.students-table tbody tr:last-child{border-bottom:none}.students-table td{color:#374151;padding:1rem;vertical-align:middle}.students-table td:first-child{padding-left:1.5rem}.students-table td:last-child{padding-right:1.5rem}.student-name{color:#111827;font-size:.95rem;font-weight:600}.student-email{color:#6b7280;font-size:.9rem}.student-id{color:#6b7280;font-family:Courier New,monospace;font-size:.85rem}.student-status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.375rem .75rem;white-space:nowrap}.student-status-badge.active{background:#d1fae5;color:#065f46}.student-status-badge.inactive{background:#fee2e2;color:#991b1b}.student-module-access{align-items:center;display:flex;flex-direction:column;gap:.5rem}.student-module-btn{align-items:center;background:#fff;border:1.5px solid #2563eb;border-radius:8px;color:#2563eb;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:.75rem;font-weight:500;gap:.375rem;justify-content:center;min-width:90px;padding:.375rem .625rem;transition:all .2s ease}.student-module-btn svg{color:inherit;flex-shrink:0}.student-module-btn:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8;transform:translateY(-1px)}.student-module-btn.active{background:#eff6ff;border-color:#2563eb;color:#2563eb}.student-module-btn.inactive{background:#fff;border-color:#d1d5db;color:#9ca3af}.student-module-btn.inactive:hover{background:#f9fafb;border-color:#2563eb;color:#2563eb}.student-module-btn.ezecg.active,.student-module-btn.ezrx.active,.student-module-btn.practipal.active{background:#eff6ff;border-color:#2563eb;color:#2563eb}.student-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.student-action-btn-sm{align-items:center;background:#fff;border:1.5px solid #2563eb;border-radius:6px;color:#2563eb;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:.8rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.student-action-btn-sm svg{color:inherit;flex-shrink:0}.student-action-btn-sm:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8;transform:translateY(-1px)}.student-action-btn-sm.activate,.student-action-btn-sm.deactivate,.student-action-btn-sm.delete{background:#fff;border:1.5px solid #2563eb;color:#2563eb}.student-action-btn-sm.activate:hover,.student-action-btn-sm.deactivate:hover,.student-action-btn-sm.delete:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.students-empty-state{color:#6b7280;padding:4rem 2rem;text-align:center}.students-empty-icon{color:#9ca3af;display:flex;justify-content:center;margin-bottom:1rem;opacity:.5}.students-empty-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.students-empty-description{font-size:.95rem;margin-bottom:1.5rem}.student-message{border:1px solid;border-radius:8px;font-size:.9rem;line-height:1.5;margin-bottom:1.5rem;padding:1rem 1.5rem}.student-message.success{background:#d1fae5;border-color:#10b981;color:#065f46}.student-message.error{background:#fee2e2;border-color:#ef4444;color:#991b1b}.student-message pre{word-wrap:break-word;font-family:Courier New,monospace;margin:0;white-space:pre-wrap}@media (max-width:1024px){.student-management-container{padding:1.5rem}.student-management-header{align-items:flex-start;flex-direction:column}.student-filters,.student-management-actions{width:100%}.student-action-btn{flex:1 1;justify-content:center}.students-table{font-size:.85rem}.students-table td,.students-table th{padding:.75rem}}@media (max-width:768px){.student-management-container{padding:1rem}.student-filters{flex-direction:column}.student-search{min-width:auto;width:100%}.student-filter-select{width:100%}.students-table{font-size:.8rem;min-width:800px}.students-table td,.students-table th{padding:.5rem}.student-actions{flex-direction:column;width:100%}.student-action-btn-sm{width:100%}}.analytics-section{margin:0 auto;max-width:1200px;padding:24px}.analytics-error,.analytics-loading{align-items:center;color:#666;display:flex;flex-direction:column;height:400px;justify-content:center}.spinning{animation:spin 1s linear infinite}.analytics-header{align-items:center;border-bottom:1px solid #e1e5e9;display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:16px}.analytics-title{align-items:center;display:flex;gap:12px}.analytics-title h2{color:#1a202c;font-size:24px;font-weight:600;margin:0}.analytics-controls{align-items:center;display:flex;gap:16px}.date-range{align-items:center;display:flex;gap:8px}.date-range input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.date-range span{color:#6b7280;font-size:14px}.analytics-overview{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.overview-card{align-items:center;background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:24px}.card-icon{background:#f3f4f6;border-radius:8px;color:#6366f1;padding:12px}.card-content h3{color:#1a202c;font-size:28px;font-weight:700;margin:0 0 4px}.card-content p{color:#6b7280;font-size:14px;margin:0 0 4px}.card-subtitle{color:#9ca3af;font-size:12px}.analytics-details{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.analytics-chart{background:#fff;border:1px solid #e1e5e9;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.analytics-chart h3{color:#1a202c;font-size:18px;font-weight:600;margin:0 0 20px}.module-usage{display:flex;flex-direction:column;gap:16px}.usage-item{align-items:center;display:flex;gap:12px}.module-name{color:#374151;font-weight:500;min-width:120px}.usage-value{color:#1a202c;font-weight:600;min-width:80px;text-align:right}.usage-bar{background:#f3f4f6;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.usage-fill{background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;height:100%;transition:width .3s ease}.institution-table,.transactions-list,.users-list{display:flex;flex-direction:column;gap:8px}.table-header,.table-row{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr 1fr;padding:12px 0}.table-header{border-bottom:1px solid #e1e5e9;color:#6b7280;font-size:14px;font-weight:600}.table-row{border-bottom:1px solid #f3f4f6;font-size:14px}.table-row:last-child{border-bottom:none}.users-list .user-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;gap:16px;padding:12px 0}.users-list .user-item:last-child{border-bottom:none}.rank{color:#6366f1;font-weight:600;min-width:32px}.user-info{display:flex;flex:1 1;flex-direction:column}.user-name{color:#1a202c;font-weight:500}.user-institution{color:#6b7280;font-size:12px}.user-usage{color:#1a202c;font-weight:600}.transactions-list .transaction-item{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:16px 0}.transactions-list .transaction-item:last-child{border-bottom:none}.transaction-info{display:flex;flex-direction:column;gap:4px}.transaction-amount{color:#059669;font-size:16px;font-weight:600}.transaction-institution{color:#374151;font-size:14px}.transaction-added-by{color:#6b7280;font-size:12px}.transaction-meta{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.transaction-date{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:4px}.transaction-notes{color:#9ca3af;font-size:12px;font-style:italic;max-width:200px;text-align:right}.btn{border:none;display:flex;gap:8px}.btnPrimary{background:#6366f1}.btnPrimary:hover{background:#5855eb}.btnSecondary{background:#fff;border:1px solid #d1d5db;color:#374151}.btnSecondary:hover{background:#f9fafb}@media (max-width:768px){.analytics-section{padding:16px}.analytics-header{align-items:flex-start;flex-direction:column;gap:16px}.analytics-controls{justify-content:space-between;width:100%}.date-range{flex-wrap:wrap}.analytics-details,.analytics-overview,.table-header,.table-row{grid-template-columns:1fr}.table-header,.table-row{gap:8px}.table-row span:first-child{font-weight:500}.table-row span:not(:first-child):before{color:#6b7280;content:attr(data-label) ": ";font-weight:600}.transactions-list .transaction-item{align-items:flex-start;flex-direction:column;gap:8px}.transaction-meta{align-items:flex-start}}:root{--border-accent:#8ec5ef66;--shadow-lg:0 20px 25px -5px #1976d21a}.chart-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:32px;transition:all .3s cubic-bezier(.4,0,.2,1)}.chart-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.section-header{border-radius:12px;flex-wrap:wrap;gap:16px;padding:24px}.section-header,.section-title{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;margin-bottom:32px}.section-title{border-radius:12px;font-weight:700;padding:24px 28px}.section-header>div{flex:1 1}.section-title{font-size:20px;letter-spacing:-.3px;margin:0 0 4px}.section-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:400;line-height:1.5;margin:0}.mp-primary-btn{justify-content:center}.mp-primary-btn:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.mp-primary-btn:active{box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.mp-primary-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.mp-secondary-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);display:flex;gap:8px;justify-content:center;transition:all .2s ease;white-space:nowrap}.mp-secondary-btn:hover:not(:disabled){background:#f9fafb;border-color:#1976d2;border-color:var(--primary-blue)}.mp-secondary-btn:disabled{cursor:not-allowed;opacity:.6}.credit-transactions{margin-top:24px}.table-heading{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;letter-spacing:-.3px;margin:0 0 16px}.table-container{border:1px solid #8ec5ef99}.data-table thead{background:#f9fafb}.data-table th{font-size:11px;font-weight:600;letter-spacing:.5px}.data-table td,.data-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);font-family:Elms Sans,sans-serif;padding:16px}.data-table td{color:#1f2937;color:var(--text-dark)}.data-table tbody tr{transition:background .2s ease}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr:last-child td{border-bottom:none}.positive-value{background:#10b9811a;color:#10b981;font-weight:600}.positive-value,.user-badge{display:inline-block;font-size:13px}.user-badge{background:#1976d21a;border-radius:6px;color:#1976d2;color:var(--primary-blue);font-weight:500;padding:4px 10px}.notes-cell{align-items:center;display:flex;gap:8px}.notes-icon{flex-shrink:0}.empty-notes,.notes-icon{color:#9ca3af;color:var(--text-light)}.empty-notes{font-style:italic}.no-data{justify-content:center;padding:48px 24px}.empty-state,.no-data{align-items:center;display:flex}.empty-state{color:#9ca3af;color:var(--text-light);flex-direction:column;gap:16px;text-align:center}.empty-state-icon{opacity:.5}.empty-state-text{font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin:0}.modal-overlay{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#f8fafcd9}.modal-content{border:1px solid #8ec5ef99;box-shadow:0 25px 50px #1976d226,0 0 0 1px #8ec5ef4d;max-width:520px}.modal-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border-bottom:1px solid #d4e9f0;padding:28px 32px}.modal-header h2{font-size:22px}.btn{border-radius:6px;font-family:Elms Sans,sans-serif;font-weight:500;padding:8px 16px}.btn-success{background:#10b981;background:var(--success);border:none;color:#fff}.btn-success:hover{background:#059669}.mp-primary-btn{box-shadow:0 2px 4px #1976d233;font-family:Elms Sans,sans-serif;font-size:14px;transition:all .2s ease}.mp-primary-btn:hover{background:#1565c0;background:var(--primary-hover);box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.mp-secondary-btn{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.mp-secondary-btn:hover{background:#e2e8f0;color:#1f2937;color:var(--text-dark)}.table-heading{color:#374151;font-size:16px;font-weight:600;margin-bottom:16px}.table-container{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{background:#f9fafb;color:#9ca3af;color:var(--text-light);font-size:12px;font-weight:700;letter-spacing:.05em;padding:14px 20px;text-align:left;text-transform:uppercase}.data-table td,.data-table th{border-bottom:1px solid #f3f4f6}.data-table td{color:#4b5563;font-size:14px;padding:16px 20px}.positive-value{background:#ecfdf5;border-radius:6px;color:#059669;font-weight:700;padding:4px 10px}.modal-overlay{animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f0f9ffcc;inset:0}.modal-content{animation:slideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid #d4e9f0;border-radius:16px;overflow:hidden}.modal-header{background:linear-gradient(135deg,#f0f9ff,#f5f3ff);border-bottom:1px solid #e0f2fe}.modal-header h2{color:#1f2937;color:var(--text-dark);font-size:20px;font-weight:700;letter-spacing:-.5px}.modal-close-btn{background:none;border:none;transition:color .2s}.form-label{color:#64748b;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.form-input{background:#f8fafc;border:1px solid #cbd5e1;font-size:15px;transition:all .2s}.form-input:focus{background:#fff}.input-suffix{color:#9ca3af;color:var(--text-light);font-size:13px}.modal-footer{background:#f8fafc;border-top:1px solid #f1f5f9}.data-table tbody tr:hover{background:#7c3aed0d}.modal-close-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.modal-close-btn:hover{background:#f9fafb;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.form-group:last-child{margin-bottom:0}.form-label{font-family:Elms Sans,sans-serif;font-size:13px}.input-wrapper{align-items:center;display:flex;position:relative}.form-input{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;padding:12px 16px;transition:all .2s ease}.form-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a}.form-input::placeholder{color:#9ca3af;color:var(--text-light)}.text-area{line-height:1.6;min-height:100px;resize:vertical}.input-suffix{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;pointer-events:none;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.modal-footer{background:#f9fafb;border-top:1px solid var(--border-color)}@media (max-width:768px){.chart-card{padding:24px}.section-header{align-items:flex-start;flex-direction:column;gap:16px;padding:20px}.mp-primary-btn,.mp-secondary-btn{justify-content:center;width:100%}.table-container{overflow-x:auto}.data-table{min-width:600px}.modal-overlay{padding:16px}.modal-content{max-width:100%}.modal-header{padding:24px}.modal-header h2{font-size:20px}.modal-body{padding:24px}.modal-footer{flex-direction:column-reverse;padding:16px 24px}.modal-footer .mp-primary-btn,.modal-footer .mp-secondary-btn{width:100%}}@media (max-width:480px){.chart-card{padding:20px}.section-header{padding:16px}.section-title{font-size:18px}.section-subtitle{font-size:13px}.table-heading{font-size:15px}.data-table th{font-size:10px;padding:12px}.data-table td{font-size:13px;padding:12px}.modal-header{padding:20px}.modal-header h2{font-size:18px}.modal-body{padding:20px}.form-group{margin-bottom:20px}}body.um-page-body{color:#111827;color:var(--text-dark);font-family:Elms Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.um-loading,body.um-page-body{background:#f4f6f8;background:var(--bg-page)}.um-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.um-loading-text{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,Inter,sans-serif;font-size:16px;font-weight:500;margin-top:16px}.um-navbar{background:#fff;background:var(--bg-white);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.um-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:16px 40px}.um-logo-section{align-items:center;display:flex;gap:12px}.um-logo{color:#111827;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:20px;font-weight:800;letter-spacing:-.5px}.um-logo-osce{color:#1976d2;color:var(--primary-blue)}.um-logo-pal{color:#7c3aed;color:var(--primary-purple)}.um-badge-admin{background:#111827;background:var(--text-dark);border-radius:4px;color:#fff;font-family:Elms Sans,Inter,sans-serif;font-size:10px;font-weight:700;letter-spacing:.5px;padding:4px 10px}.um-nav-links{align-items:center;display:flex;gap:8px}.um-nav-link{background:none;border:none;border-radius:6px;color:#6b7280;color:var(--text-grey);cursor:pointer;font-family:Elms Sans,Inter,sans-serif;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.um-nav-link:hover{background:#1976d20d}.um-nav-active,.um-nav-link:hover{color:#1976d2;color:var(--primary-blue)}.um-nav-active{font-weight:600}.um-profile-btn{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;margin-left:8px;padding:4px;transition:all .2s ease}.um-profile-btn:hover{background:#00000005}.um-profile-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);border-radius:50%;color:#fff;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.um-main{margin:0 auto;max-width:1400px;padding:0 32px 40px}.um-page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:32px}.um-header-content{flex:1 1}.um-page-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.um-page-subtitle{color:#6b7280;color:var(--text-grey);font-size:15px;margin:0}.um-btn-add,.um-page-subtitle{font-family:Elms Sans,Inter,sans-serif}.um-btn-add{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 4px 6px -1px #1976d233;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.um-btn-add:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.um-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.um-stat-card{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:20px}.um-stat-label{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,Inter,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.um-stat-value{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:700;line-height:1;margin-bottom:8px}.um-value-error{color:#ef4444;color:var(--error)}.um-stat-change{align-items:center;display:flex;font-family:Elms Sans,Inter,sans-serif;font-size:13px;font-weight:500;gap:4px}.um-change-positive{color:#10b981;color:var(--success)}.um-stat-meta{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,Inter,sans-serif;font-size:13px}.um-filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.um-search-wrapper{flex:1 1;min-width:300px;position:relative}.um-search-icon{color:#9ca3af;color:var(--text-light);left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.um-search-input{border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;color:#111827;color:var(--text-dark);font-family:Elms Sans,Inter,sans-serif;font-size:14px;padding:10px 14px 10px 44px;transition:all .2s ease;width:100%}.um-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.um-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.um-filter-selects{display:flex;gap:12px}.um-select-wrapper{position:relative}.um-select{-webkit-appearance:none;appearance:none;background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;color:#111827;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,Inter,sans-serif;font-size:14px;min-width:160px;padding:10px 36px 10px 14px;transition:all .2s ease}.um-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.um-select-icon{color:#9ca3af;color:var(--text-light);pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.um-table-container{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.um-table{border-collapse:collapse;font-family:Elms Sans,Inter,sans-serif;width:100%}.um-table thead{background:#00000005}.um-table th{color:#6b7280;color:var(--text-grey);font-size:11px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.um-table td,.um-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light)}.um-table td{color:#111827;color:var(--text-dark);font-size:14px;padding:16px}.um-table tbody tr:hover{background:#00000003}.um-table tbody tr:last-child td{border-bottom:none}.um-user-cell{gap:12px}.um-user-avatar,.um-user-cell{align-items:center;display:flex}.um-user-avatar{background:#6b72801a;border-radius:50%;color:#6b7280;color:var(--text-grey);flex-shrink:0;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;height:40px;justify-content:center;width:40px}.um-user-info{display:flex;flex-direction:column;gap:2px}.um-user-name{color:#111827;color:var(--text-dark);font-size:14px;font-weight:600}.um-user-email,.um-user-name{font-family:Elms Sans,sans-serif}.um-user-email{color:#6b7280;color:var(--text-grey);font-size:13px}.um-badge{border-radius:4px;display:inline-block;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:700;letter-spacing:.3px;padding:4px 10px;text-align:center;text-transform:uppercase;width:100%}.um-badge-purple{background:#7c3aed1a;color:#7c3aed;color:var(--primary-purple)}.um-badge-blue{background:#1976d21a;color:#1976d2;color:var(--primary-blue)}.um-badge-purple-dark{background:#7c3aed1a;color:#7c3aed;color:var(--primary-purple)}.um-badge-gray{background:#6b72801a;color:#6b7280;color:var(--text-grey)}.um-institution{color:#111827;color:var(--text-dark);font-weight:500}.um-institution,.um-status{font-family:Elms Sans,sans-serif}.um-status{align-items:center;display:flex;gap:8px}.um-status-dot{border-radius:50%;height:8px;width:8px}.um-status-active{background:#10b981;background:var(--success)}.um-status-suspended{background:#ef4444;background:var(--error)}.um-last-login{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:13px}.um-actions{display:flex;gap:8px}.um-action-btn{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;color:var(--text-grey);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.um-action-btn:hover{background:#0000000d;color:#111827;color:var(--text-dark)}.um-action-delete:hover{background:#ef44441a;color:#ef4444;color:var(--error)}.um-no-results{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-style:italic;padding:60px 20px;text-align:center}@media (max-width:1200px){.um-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:1024px){.um-navbar-container{padding:12px 24px}.um-main{padding:24px}.um-nav-links{gap:4px}.um-nav-link{font-size:13px;padding:6px 12px}}@media (max-width:768px){.um-navbar-container{padding:10px 20px}.um-logo{font-size:18px}.um-badge-admin{font-size:9px;padding:3px 8px}.um-main{padding:20px 16px}.um-page-header{align-items:stretch;flex-direction:column}.um-btn-add{justify-content:center;width:100%}.um-stats-grid{grid-template-columns:1fr}.um-filters{flex-direction:column}.um-search-wrapper{min-width:0;width:100%}.um-filter-selects{flex-direction:column}.um-select{width:100%}.um-table-container{overflow-x:auto}.um-table{min-width:800px}.um-nav-link span{display:none}}@media (max-width:480px){.um-page-title{font-size:24px}.um-stat-value{font-size:28px}.um-user-avatar{font-size:13px;height:36px;width:36px}.um-actions{flex-direction:column}}.um-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:9999}.um-modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;font-family:Elms Sans,Inter,sans-serif;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.um-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px 32px}.um-modal-header h2{color:#111827;font-family:Elms Sans,sans-serif;font-size:24px;font-weight:600;margin:0}.um-modal-close{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:background-color .2s}.um-modal-close:hover{background-color:#f3f4f6;color:#111827}.um-modal-form{font-family:Elms Sans,Inter,sans-serif;padding:32px}.um-form-section{margin-bottom:32px}.um-form-section:last-of-type{margin-bottom:0}.um-form-section h3{border-bottom:2px solid #f3f4f6;color:#111827;font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.um-form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}@media (max-width:640px){.um-form-row{grid-template-columns:1fr}}.um-form-group{display:flex;flex-direction:column}.um-form-group label{color:#374151;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin-bottom:8px}.um-required{color:#ef4444;margin-left:2px}.um-form-group input,.um-form-group select,.um-form-group textarea{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;font-family:Elms Sans,Inter,sans-serif;font-size:14px;padding:10px 14px;transition:all .2s}.um-form-group input:focus,.um-form-group select:focus,.um-form-group textarea:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.um-form-group input:disabled,.um-form-group select:disabled,.um-form-group textarea:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.um-form-group textarea{min-height:80px;resize:vertical}.um-form-group small{color:#6b7280;font-family:Elms Sans,sans-serif;font-size:12px;margin-top:6px}.um-checkbox-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}@media (max-width:640px){.um-checkbox-grid{grid-template-columns:1fr}}.um-checkbox-label{align-items:center;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;gap:10px;padding:12px 16px;transition:all .2s;-webkit-user-select:none;user-select:none}.um-checkbox-label:hover{background-color:#f9fafb;border-color:#d1d5db}.um-checkbox-label input[type=checkbox]{accent-color:#8b5cf6;cursor:pointer;height:18px;width:18px}.um-checkbox-label span{color:#374151;font-size:14px;font-weight:500}.um-modal-footer{align-items:center;background-color:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding:20px 32px}.um-btn-primary{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 24px;transition:all .2s}.um-btn-primary:hover:not(:disabled){background-color:#7c3aed;box-shadow:0 4px 12px #8b5cf64d;transform:translateY(-1px)}.um-btn-primary:active:not(:disabled){transform:translateY(0)}.um-btn-primary:disabled{background-color:#d1d5db;cursor:not-allowed;opacity:.6}.um-btn-secondary{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s}.um-btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.um-btn-secondary:disabled{cursor:not-allowed;opacity:.5}.um-modal-content::-webkit-scrollbar{width:8px}.um-modal-content::-webkit-scrollbar-track{background:#f3f4f6;border-radius:0 12px 12px 0}.um-modal-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.um-modal-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width:768px){.um-modal-content{margin:20px;max-width:95%}.um-modal-header{padding:20px 24px}.um-modal-header h2{font-size:20px}.um-modal-form{padding:24px}.um-modal-footer{flex-direction:column-reverse;padding:16px 24px}.um-modal-footer button{justify-content:center;width:100%}}.um-btn-primary:disabled,.um-btn-secondary:disabled{position:relative}.um-btn-primary:focus-visible,.um-btn-secondary:focus-visible,.um-checkbox-label:focus-within,.um-modal-close:focus-visible{outline:2px solid #8b5cf6;outline-offset:2px}.im-main{background:var(--bg-page);color:var(--text-dark);font-family:Elms Sans,sans-serif;margin:0 auto;max-width:1200px;padding:0 40px 80px}.im-page-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:40px}.im-page-header,.im-page-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.im-page-title{font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}.im-page-subtitle{color:var(--text-medium);font-size:14px;line-height:1.6}.im-btn-add{align-items:center;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .2s ease}.im-btn-add:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.im-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(4,1fr);margin-bottom:40px}.im-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-sm);padding:24px}.im-stat-label{color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.6px;margin-bottom:6px}.im-stat-value{color:var(--text-dark);font-size:32px;font-weight:700}.im-stat-meta{color:var(--text-medium);font-size:13px;margin-top:6px}.im-warning{color:#f59e0b}.im-filters{align-items:center;display:flex;gap:16px;margin-bottom:24px}.im-search-wrapper{flex:1 1;position:relative}.im-search-icon{color:var(--text-light);left:14px;position:absolute;top:50%;transform:translateY(-50%)}.im-search-input{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 14px 10px 42px;width:100%}.im-search-input::placeholder{color:var(--text-light)}.im-filter-selects{display:flex;gap:12px}.im-select-wrapper{position:relative}.im-select{-webkit-appearance:none;appearance:none;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 36px 10px 14px}.im-select-icon{color:var(--text-light);pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.im-table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}.im-table{border-collapse:collapse;font-family:Elms Sans,sans-serif;width:100%}.im-table th{background:#f9fafb;color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.6px;text-align:left}.im-table td,.im-table th{border-bottom:1px solid var(--border-color);padding:16px}.im-table td{color:var(--text-dark);font-size:14px}.im-inst-cell{gap:12px}.im-avatar,.im-inst-cell{align-items:center;display:flex}.im-avatar{background:#1976d21a;border-radius:50%;color:var(--primary-blue);height:40px;justify-content:center;width:40px}.im-avatar,.im-inst-name{font-size:14px;font-weight:600}.im-inst-domain{color:var(--text-medium);font-size:13px}.im-admin-name{font-weight:500}.im-admin-email{color:var(--text-medium);font-size:13px}.im-plan{color:var(--primary-purple);font-size:13px;font-weight:600}.im-status{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 10px;text-transform:capitalize}.im-status-active{background:#10b98126;color:#059669}.im-status-pending{background:#f59e0b26;color:#b45309}.im-status-inactive{background:#6b728026;color:#374151}.im-actions{align-items:center;color:var(--text-medium);display:flex;gap:14px}.im-actions svg{cursor:pointer;transition:color .2s ease}.im-actions svg:hover{color:var(--primary-blue)}.im-review-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:6px 12px;transition:all .2s ease}.im-review-btn:hover{background:#f9fafb;border-color:var(--primary-blue);color:var(--primary-blue)}.im-modal-backdrop{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.im-modal{background:var(--bg-page);border-radius:12px;box-shadow:var(--shadow-md);max-width:90%;padding:24px;width:400px}.im-modal,.im-modal h2{font-family:Elms Sans,sans-serif}.im-modal h2{font-size:20px;font-weight:700;margin-bottom:16px}.im-modal label{display:flex;flex-direction:column;font-weight:500;margin-bottom:12px}.im-modal input,.im-modal label{color:var(--text-dark);font-size:14px}.im-modal input{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;font-family:Elms Sans,sans-serif;margin-top:6px;padding:10px 14px}.im-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.im-modal-actions button{border:none;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 18px;transition:all .2s ease}.im-modal-actions button:first-child{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-dark)}.im-modal-actions button:first-child:hover{background:#f9fafb;border-color:var(--primary-blue);color:var(--primary-blue)}.im-modal-actions button:last-child{background:var(--primary-blue);color:#fff}.im-modal-actions button:last-child:hover{background:#1565c0}@media (max-width:1024px){.im-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.im-main{padding:40px 20px 60px}.im-page-header{align-items:flex-start;flex-direction:column}.im-stats-grid{grid-template-columns:1fr}.im-filters{align-items:stretch;flex-direction:column}.im-filter-selects,.im-select{width:100%}}.cm-main-container{--primary-blue:#1976d2;--primary-purple:#7c3aed;--success-color:#10b981;--warning-color:#f59e0b;--error-color:#ef4444;--bg-page:#fff;--bg-card:#fff;--text-dark:#1f2937;--text-medium:#6b7280;--text-light:#9ca3af;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.coupon-page-body{background:var(--bg-page);color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.cm-main{margin:0 auto;max-width:1200px;padding:20px 40px 80px}.cm-error-state,.cm-loading-state{padding:100px 0;text-align:center}.cm-error-state{color:var(--error-color)}.cm-header{align-items:center;background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #8ec5ef99;border-radius:12px;display:flex;gap:24px;justify-content:space-between;margin-bottom:48px;padding:32px 40px}.cm-title{color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;letter-spacing:-1px;margin-bottom:8px}.cm-title strong{font-weight:700}.cm-subtitle{color:var(--text-medium);font-size:18px;margin:0}.cm-create-btn,.cm-subtitle{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.cm-create-btn{align-items:center;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.cm-create-btn:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.cm-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:48px}.cm-stat-card{background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:var(--shadow-sm);padding:28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.cm-stat-card:hover{border-color:var(--primary-blue);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.cm-stat-card.cm-warning{border-color:#f59e0b4d}.cm-stat-label{color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.cm-stat-label,.cm-stat-value{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.cm-stat-value{color:var(--text-dark);font-size:36px;font-weight:700;letter-spacing:-1px}.cm-filters{background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:32px;padding:24px}.cm-search-wrapper{align-items:center;display:flex;position:relative}.cm-search-wrapper svg{color:var(--text-medium);left:12px;position:absolute;top:12px}.cm-search{border:1px solid var(--border-color);border-radius:8px;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;padding:12px 16px 12px 48px;transition:all .2s ease;width:100%}.cm-search:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.cm-table-wrapper{align-items:center;display:flex;position:relative}.cm-table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-sm);flex:1 1;overflow-x:auto;overflow-y:visible}.cm-scroll-btn{align-items:center;background:var(--primary-blue);border:none;border-radius:50%;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:32px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s ease;width:32px;z-index:10}.cm-scroll-btn:hover{background:#1565c0;transform:translateY(-50%) scale(1.1)}.cm-scroll-left{left:-16px}.cm-scroll-right{right:-16px}.cm-table{border-collapse:collapse;min-width:1100px;width:100%}.cm-table-container::-webkit-scrollbar{height:8px}.cm-table-container::-webkit-scrollbar-track{background:#f3f4f6;border-radius:0 0 16px 16px}.cm-table-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.cm-table-container::-webkit-scrollbar-thumb:hover{background:#9ca3af}.cm-table thead{background:#f9fafb;border-bottom:1px solid var(--border-color)}.cm-table th{color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.5px;padding:16px 24px;text-align:left;text-transform:uppercase}.cm-table td{border-bottom:1px solid var(--border-color);font-size:14px;padding:20px 24px}.cm-table tbody tr:hover{background:#f9fafb}.cm-table-empty{color:var(--text-medium);padding:40px;text-align:center}.cm-code{background:#f3f4f6;border-radius:4px;color:var(--text-dark);font-family:Courier New,monospace;font-weight:700;padding:4px 8px}.cm-discount{color:var(--primary-blue);font-weight:600}.cm-discount,.cm-usage-text{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.cm-usage-text{color:var(--text-medium);font-size:12px;font-weight:500;margin-bottom:6px}.cm-progress{background:#f3f4f6;border-radius:10px;height:6px;max-width:120px;overflow:hidden;width:100%}.cm-progress-fill{border-radius:10px;height:100%;transition:width .3s ease,background-color .3s ease}.cm-status{align-items:center;border-radius:6px;display:inline-flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:11px;font-weight:700;letter-spacing:.3px;padding:6px 12px;text-transform:uppercase}.cm-actions{gap:8px}.cm-action-btn,.cm-actions{align-items:center;display:flex}.cm-action-btn{background:none;border:none;border-radius:6px;color:var(--text-medium);cursor:pointer;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.cm-action-btn:hover{background:#0000000d;color:var(--text-dark)}.cm-edit-btn:hover{background:#1976d21a;color:var(--primary-blue)}.cm-delete-btn:hover{background:#ef44441a;color:var(--error-color)}.cm-validation-test{background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:var(--shadow-sm);margin-top:40px;padding:32px}.cm-validation-test h3{color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin-bottom:12px}.cm-test-inputs{align-items:center;display:flex;gap:12px}.cm-test-inputs .cm-search{flex:1 1}.cm-test-inputs input[type=number]{width:140px}.cm-test-result{border-radius:8px;font-family:Elms Sans,sans-serif;font-size:14px;margin-top:12px;padding:12px}.cm-test-result.valid{background:#ecfdf5;color:#059669}.cm-test-result.invalid{background:#fee2e2;color:#dc2626}.modal-overlay{background-color:#0009;height:100%;overflow-y:auto;padding:50px;width:100%;z-index:9999}.modal-content{animation:modalSlideIn .3s ease-out;border-radius:12px;box-shadow:0 20px 60px #0000004d;font-family:Elms Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;max-height:95vh;max-width:1300px}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:24px 32px}.modal-header h2{color:#111827;font-family:Elms Sans,sans-serif;font-size:24px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:background-color .2s}.modal-close:hover{background-color:#f3f4f6;color:#111827}.modal-body{font-family:Elms Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:32px}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;font-weight:500;margin-bottom:20px;padding:12px 16px}.form-section{margin-bottom:32px}.form-section:last-of-type{margin-bottom:0}.form-section h3{border-bottom:2px solid #f3f4f6;color:#111827;font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.form-row{grid-gap:20px;gap:20px;margin-bottom:20px}.validity-row{grid-template-columns:1fr}.form-group{display:flex;flex-direction:column}.form-group label{color:#374151;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin-bottom:8px}.required{color:#ef4444;margin-left:2px}.form-group small{color:#6b7280;font-family:Elms Sans,sans-serif;font-size:12px;margin-top:6px}.form-input,.form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;font-family:Elms Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;padding:10px 14px;transition:all .2s;width:100%}.form-input:focus,.form-select:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.form-input:disabled{background-color:#f9fafb;color:#9ca3af}.checkbox-label{align-items:center;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;gap:10px;padding:12px 16px;transition:all .2s;-webkit-user-select:none;user-select:none}.checkbox-label:hover{background-color:#f9fafb;border-color:#d1d5db}.checkbox-label input[type=checkbox]{accent-color:#8b5cf6;cursor:pointer;height:18px;width:18px}.checkbox-label span{color:#374151;font-size:14px;font-weight:500}.modal-footer{background-color:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;gap:12px;justify-content:flex-end;padding:20px 32px}.btn-primary,.modal-footer{align-items:center;display:flex}.btn-primary{background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 24px;transition:all .2s}.btn-primary:hover:not(:disabled){background-color:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background-color:#d1d5db;cursor:not-allowed;opacity:.6}.btn-secondary{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s}.btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#f3f4f6;border-radius:0 12px 12px 0}.modal-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width:768px){.cm-main{padding:20px 24px 60px}.cm-header{flex-direction:column;padding:24px;text-align:center}.cm-stats-grid{grid-template-columns:repeat(2,1fr)}.cm-test-inputs,.form-row{flex-direction:column;gap:12px}.cm-test-inputs input[type=number],.form-group{width:100%}.modal-content{margin:20px;max-width:95%}.modal-header{padding:20px 24px}.modal-header h2{font-size:20px}.modal-body{padding:24px}.modal-footer{flex-direction:column-reverse;padding:16px 24px}.modal-footer button{justify-content:center;width:100%}}@media (max-width:640px){.cm-stats-grid,.form-row{grid-template-columns:1fr}.cm-table td,.cm-table th{padding:12px 16px}}@media (max-width:480px){.cm-main{padding:16px 20px 40px}.cm-header{padding:20px}.cm-title{font-size:28px}.cm-subtitle{font-size:16px}.modal-overlay{padding:16px}.modal-header{padding:16px 20px}.modal-header h2{font-size:18px}.modal-body{padding:20px}.form-input,.form-select{font-size:16px}}.btn-primary:focus-visible,.btn-secondary:focus-visible,.modal-close:focus-visible{outline:2px solid #8b5cf6;outline-offset:2px}:root{--success-light:#d1fae5;--warning-light:#fef3c7;--error-light:#fee2e2;--space-1:4px;--space-5:20px;--radius-sm:4px;--radius-xl:16px;--shadow-lg:0 10px 15px -3px #0000001a}.mp-container{background-color:#f9fafb;background-color:var(--gray-50);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1400px;min-height:100vh;padding:32px;padding:var(--space-8)}.mp-header{align-items:flex-start;display:flex;gap:20px;gap:var(--space-5);justify-content:space-between;margin-bottom:32px;margin-bottom:var(--space-8)}.mp-header-left{flex:1 1}.mp-title{color:#111827;color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-size:30px;font-weight:700;margin:0 0 8px;margin:0 0 var(--space-2) 0}.mp-subtitle{color:#4b5563;color:var(--gray-600);font-size:16px;line-height:1.5;margin:0}.mp-primary-btn{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 4px 12px #2563eb33;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;gap:var(--space-2);padding:12px 24px;padding:var(--space-3) var(--space-6);transition:all .2s;white-space:nowrap}.mp-primary-btn:hover{box-shadow:0 6px 20px #2563eb4d;transform:translateY(-2px)}.mp-stats-grid{grid-gap:20px;grid-gap:var(--space-5);display:grid;gap:20px;gap:var(--space-5);grid-template-columns:repeat(4,1fr);margin-bottom:32px;margin-bottom:var(--space-8)}.mp-stat-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;padding:24px;padding:var(--space-6);position:relative;transition:all .2s}.mp-stat-card:before{background:linear-gradient(90deg,#2563eb,#7c3aed);background:linear-gradient(90deg,var(--primary),var(--secondary));content:"";height:3px;left:0;position:absolute;right:0;top:0}.mp-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.mp-stat-label{color:#6b7280;color:var(--gray-500);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;margin-bottom:var(--space-3);text-transform:uppercase}.mp-stat-value{color:#111827;color:var(--gray-900);font-size:32px;font-weight:700;line-height:1;margin:0 0 8px;margin:0 0 var(--space-2) 0}.mp-stat-desc{color:#4b5563;color:var(--gray-600);font-size:14px;margin:0}.mp-stat-positive{font-size:14px;font-weight:500;margin:0}.mp-stat-normal,.mp-stat-ok,.mp-stat-positive{color:#10b981;color:var(--success)}.mp-stat-low{color:#2563eb;color:var(--primary)}.mp-stat-high{color:#f59e0b;color:var(--warning)}.mp-stat-critical{color:#ef4444;color:var(--error)}.mp-filters{display:flex;gap:16px;gap:var(--space-4);margin-bottom:24px;margin-bottom:var(--space-6)}.mp-search-box{align-items:center;background:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);display:flex;flex:1 1;gap:12px;gap:var(--space-3);padding:12px 16px;padding:var(--space-3) var(--space-4);position:relative;transition:all .2s}.mp-search-box:focus-within{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--primary-light)}.mp-search-box svg{color:#9ca3af;color:var(--gray-400);flex-shrink:0}.mp-search-box input{background:#0000;border:none;color:#111827;color:var(--gray-900);flex:1 1;font-family:inherit;font-size:15px;outline:none}.mp-search-box input::placeholder{color:#9ca3af;color:var(--gray-400)}.mp-select-wrapper{min-width:180px;position:relative}.mp-select{-webkit-appearance:none;appearance:none;background:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#111827;color:var(--gray-900);cursor:pointer;font-family:inherit;font-size:15px;padding:12px 40px 12px 16px;padding:var(--space-3) 40px var(--space-3) var(--space-4);transition:all .2s;width:100%}.mp-select:hover{border-color:#9ca3af;border-color:var(--gray-400)}.mp-select:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--primary-light);outline:none}.mp-select-icon{color:#6b7280;color:var(--gray-500);pointer-events:none;position:absolute;right:14px;top:50%;transform:translateY(-50%)}.mp-table-wrapper{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.mp-table{border-collapse:collapse;width:100%}.mp-table thead{background:#f9fafb;background:var(--gray-50);border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--gray-200)}.mp-table th{color:#6b7280;color:var(--gray-500);font-size:12px;font-weight:600;letter-spacing:.5px;padding:16px 20px;padding:var(--space-4) var(--space-5);text-align:left;text-transform:uppercase}.mp-table tbody tr{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);transition:background-color .2s}.mp-table tbody tr:hover{background-color:#f9fafb;background-color:var(--gray-50)}.mp-table tbody tr:last-child{border-bottom:none}.mp-table td{color:#374151;color:var(--gray-700);font-size:14px;padding:20px;padding:var(--space-5);vertical-align:middle}.mp-module-name h3{color:#111827;color:var(--gray-900);font-size:16px;font-weight:600;margin:0 0 4px;margin:0 0 var(--space-1) 0}.mp-module-name h3,.mp-module-name p{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif}.mp-module-name p{color:#4b5563;color:var(--gray-600);font-size:14px;line-height:1.4;margin:0}.mp-type-badge{background-color:#dbeafe;background-color:var(--primary-light);color:#2563eb;color:var(--primary);font-size:12px}.mp-credit-badge,.mp-type-badge{border-radius:4px;border-radius:var(--radius-sm);display:inline-block;font-weight:600;padding:4px 12px;padding:var(--space-1) var(--space-3)}.mp-credit-badge{background-color:#fef3c7;background-color:var(--warning-light);color:#92400e;font-size:13px}.mp-status{border-radius:4px;border-radius:var(--radius-sm);display:inline-block;font-size:12px;font-weight:600;letter-spacing:.3px;padding:4px 12px;padding:var(--space-1) var(--space-3);text-transform:uppercase}.mp-status.mp-active{background-color:#d1fae5;background-color:var(--success-light);color:#065f46}.mp-status.mp-inactive{background-color:#f3f4f6;background-color:var(--gray-100);color:#4b5563;color:var(--gray-600)}.mp-status.mp-maintenance{background-color:#fef3c7;background-color:var(--warning-light);color:#92400e}.mp-status.mp-beta{background-color:#dbeafe;background-color:var(--primary-light);color:#2563eb;color:var(--primary)}.mp-actions{gap:8px;gap:var(--space-2)}.mp-action-btn,.mp-actions{align-items:center;display:flex}.mp-action-btn{background:#f3f4f6;background:var(--gray-100);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#4b5563;color:var(--gray-600);cursor:pointer;justify-content:center;padding:8px;padding:var(--space-2);transition:all .2s}.mp-action-btn:hover{background:#e5e7eb;background:var(--gray-200);color:#111827;color:var(--gray-900);transform:translateY(-1px)}.mp-action-delete:hover{background:#fee2e2;background:var(--error-light);color:#ef4444;color:var(--error)}.mp-no-results{color:#9ca3af;color:var(--gray-400);font-size:15px;padding:60px 20px!important;text-align:center}.mp-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;padding:var(--space-5);position:fixed;right:0;top:0;z-index:9999}.mp-modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.mp-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:24px 32px;padding:var(--space-6) var(--space-8)}.mp-modal-header,.mp-modal-header h2{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif}.mp-modal-header h2{color:#111827;color:var(--gray-900);font-size:24px;font-weight:700;margin:0}.mp-modal-close{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-md);color:#6b7280;color:var(--gray-500);cursor:pointer;display:flex;justify-content:center;padding:8px;padding:var(--space-2);transition:all .2s}.mp-modal-close:hover{background-color:#f3f4f6;background-color:var(--gray-100);color:#111827;color:var(--gray-900)}.mp-modal-form{padding:32px;padding:var(--space-8)}.mp-form-section{margin-bottom:32px;margin-bottom:var(--space-8)}.mp-form-section,.mp-form-section:last-of-type{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif}.mp-form-section:last-of-type{margin-bottom:0}.mp-form-section h3{border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--gray-100);color:#111827;color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-size:18px;font-weight:600;margin:0 0 20px;margin:0 0 var(--space-5) 0;padding-bottom:12px;padding-bottom:var(--space-3)}.mp-form-row{grid-gap:20px;grid-gap:var(--space-5);display:grid;gap:20px;gap:var(--space-5);grid-template-columns:1fr 1fr}.mp-form-group,.mp-form-row{margin-bottom:20px;margin-bottom:var(--space-5)}.mp-form-group{display:flex;flex-direction:column}.mp-form-group:last-child{margin-bottom:0}.mp-form-group label{color:#374151;color:var(--gray-700);font-size:14px;font-weight:500;margin-bottom:8px;margin-bottom:var(--space-2)}.mp-required{color:#ef4444;color:var(--error);margin-left:2px}.mp-form-group input,.mp-form-group select,.mp-form-group textarea{background-color:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#111827;color:var(--gray-900);font-family:inherit;font-size:14px;padding:10px 14px;transition:all .2s}.mp-form-group input:focus,.mp-form-group select:focus,.mp-form-group textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--primary-light);outline:none}.mp-form-group input:disabled,.mp-form-group select:disabled,.mp-form-group textarea:disabled{background-color:#f9fafb;background-color:var(--gray-50);color:#6b7280;color:var(--gray-500);cursor:not-allowed}.mp-form-group textarea{line-height:1.5;min-height:80px;resize:vertical}.mp-checkbox-label{align-items:center;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:12px;gap:var(--space-3);padding:12px 16px;padding:var(--space-3) var(--space-4);transition:all .2s;-webkit-user-select:none;user-select:none}.mp-checkbox-label:hover{background-color:#f9fafb;background-color:var(--gray-50);border-color:#d1d5db;border-color:var(--gray-300)}.mp-checkbox-label input[type=checkbox]{accent-color:#2563eb;accent-color:var(--primary);cursor:pointer;height:18px;width:18px}.mp-checkbox-label span{color:#374151;color:var(--gray-700);font-size:14px;font-weight:500}.mp-stats-display{grid-gap:16px;grid-gap:var(--space-4);background-color:#f9fafb;background-color:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);display:grid;gap:16px;gap:var(--space-4);grid-template-columns:repeat(2,1fr);margin-bottom:16px;margin-bottom:var(--space-4);padding:20px;padding:var(--space-5)}.mp-stat-item{align-items:center;display:flex;justify-content:space-between}.mp-stat-item span{color:#4b5563;color:var(--gray-600);font-size:14px}.mp-stat-item strong{color:#111827;color:var(--gray-900);font-size:16px;font-weight:600}.mp-btn-refresh{align-items:center;background-color:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#374151;color:var(--gray-700);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;gap:var(--space-2);justify-content:center;padding:10px 20px;transition:all .2s;width:100%}.mp-btn-refresh:hover{border-color:#9ca3af;border-color:var(--gray-400)}.mp-btn-refresh:hover,.mp-modal-footer{background-color:#f9fafb;background-color:var(--gray-50)}.mp-modal-footer{align-items:center;border-radius:0 0 12px 12px;border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;gap:12px;gap:var(--space-3);justify-content:flex-end;padding:20px 32px;padding:var(--space-5) var(--space-8)}.mp-btn-primary{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 2px 8px #2563eb33;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;gap:var(--space-2);padding:10px 24px;transition:all .2s}.mp-btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.mp-btn-primary:disabled{background:#d1d5db;background:var(--gray-300);box-shadow:none;cursor:not-allowed;opacity:.6}.mp-btn-secondary{background-color:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#374151;color:var(--gray-700);cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s}.mp-btn-secondary:hover:not(:disabled){background-color:#f9fafb;background-color:var(--gray-50);border-color:#9ca3af;border-color:var(--gray-400)}.mp-btn-secondary:disabled{cursor:not-allowed;opacity:.5}.mp-modal-content::-webkit-scrollbar{width:8px}.mp-modal-content::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100);border-radius:0 12px 12px 0;border-radius:0 var(--radius-lg) var(--radius-lg) 0}.mp-modal-content::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--gray-300);border-radius:4px}.mp-modal-content::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--gray-400)}@media (max-width:1024px){.mp-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.mp-container{padding:20px;padding:var(--space-5)}.mp-header{flex-direction:column}.mp-stats-grid{grid-template-columns:1fr}.mp-filters{flex-direction:column}.mp-select-wrapper{width:100%}.mp-table-wrapper{overflow-x:auto}.mp-form-row,.mp-stats-display{grid-template-columns:1fr}.mp-modal-content{max-width:95%}.mp-modal-form,.mp-modal-header{padding:20px 24px;padding:var(--space-5) var(--space-6)}.mp-modal-footer{flex-direction:column-reverse;padding:16px 24px;padding:var(--space-4) var(--space-6)}.mp-modal-footer button{justify-content:center;width:100%}.mp-table thead{display:none}.mp-table tbody tr{border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);display:block;margin-bottom:16px;margin-bottom:var(--space-4)}.mp-table td{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:12px 16px;padding:var(--space-3) var(--space-4)}.mp-table td:last-child{border-bottom:none}.mp-table td:before{color:#6b7280;color:var(--gray-500);content:attr(data-label);font-size:12px;font-weight:600;text-transform:uppercase}.mp-table td:first-child:before{display:none}.mp-module-name{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;width:100%}}:root{--status-active:#3b82f6;--success-light:#10b9811a;--error-light:#ef44441a;--info-light:#2563eb1a;--purple-light:#7c3aed1a}body.reports-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;overflow-x:hidden;padding:0}.rp-loading,body.reports-page-body{background:#fff;background:var(--bg-page)}.rp-loading{align-items:center;display:flex;flex-direction:column;gap:16px;height:100vh;justify-content:center}.rp-loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#1976d2;border-top:3px solid var(--primary-blue);height:40px;width:40px}.rp-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.rp-main{margin:0 auto;max-width:1400px;overflow-x:hidden;padding:40px 40px 80px}.rp-header,.rp-main{box-sizing:border-box;width:100%}.rp-header{background:linear-gradient(135deg,#f8fafc,#f0f9ff);border:1px solid #e0f2fe;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-bottom:40px;overflow:hidden;padding:32px 40px;position:relative}.rp-header:before{background:linear-gradient(135deg,#1976d21a,#7c3aed0d);border-radius:0 0 0 100%;content:"";height:200px;position:absolute;right:0;top:0;width:200px;z-index:0}.rp-header-content{align-items:flex-start;display:flex;flex-wrap:wrap;gap:32px;justify-content:space-between;position:relative;width:100%;z-index:1}.rp-title-section{flex:1 1;min-width:300px}.rp-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:36px;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:0 0 8px}.rp-page-title:after{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(90deg,var(--primary-blue),var(--primary-purple));border-radius:2px;content:"";display:block;height:4px;margin-top:12px;width:60px}.rp-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:400;line-height:1.5;margin:0;max-width:600px}.rp-role-badge{align-items:center;background:linear-gradient(90deg,#1976d21a,#7c3aed1a);border:1px solid #1976d233;border-radius:20px;color:#1976d2;color:var(--primary-blue);display:inline-flex;font-size:12px;font-weight:600;letter-spacing:.5px;margin-left:12px;padding:4px 12px;text-transform:uppercase}.rp-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.rp-refresh-btn{align-items:center;background:#fff;border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:10px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-width:120px;padding:10px 20px;transition:all .2s ease}.rp-refresh-btn:hover:not(:disabled){background:#f8fafc;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1976d2;color:var(--primary-blue);transform:translateY(-1px)}.rp-refresh-btn:disabled{background:#f1f5f9;cursor:not-allowed;opacity:.6}.rp-time-range-container{min-width:180px;position:relative}.rp-time-range-btn{align-items:center;background:#fff;border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:10px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:space-between;padding:10px 20px;transition:all .2s ease;width:100%}.rp-time-range-btn:hover{background:#f8fafc;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1976d2;color:var(--primary-blue)}.rp-time-dropdown{animation:dropdownFade .2s ease;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);left:0;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rp-time-option{background:none;border:none;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;padding:12px 20px;text-align:left;transition:all .2s ease;width:100%}.rp-time-option:last-child{border-bottom:none}.rp-time-option:hover{background:#f8fafc;color:#1976d2;color:var(--primary-blue)}.rp-time-option.active{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(90deg,var(--primary-blue),var(--primary-purple));color:#fff;font-weight:600}.rp-export-container{display:flex;flex-shrink:0;gap:10px}.rp-export-btn{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:10px;box-shadow:0 4px 12px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-width:140px;padding:10px 20px;transition:all .3s ease}.rp-export-btn:hover:not(:disabled){background:#1565c0;box-shadow:0 8px 20px #1976d24d;transform:translateY(-2px)}.rp-export-btn:active:not(:disabled){transform:translateY(0)}.rp-export-btn:disabled{box-shadow:0 2px 4px #0000001a;cursor:not-allowed;opacity:.6;transform:none}.rp-export-pdf{background:linear-gradient(90deg,#7c3aed,#a855f7);background:linear-gradient(90deg,var(--primary-purple),#a855f7);box-shadow:0 4px 12px #7c3aed33}.rp-export-pdf:hover:not(:disabled){background:linear-gradient(90deg,#6d28d9,#9333ea);box-shadow:0 8px 20px #7c3aed4d}.rp-stats-section{margin-bottom:48px;width:100%}.rp-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));width:100%}.rp-stat-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:16px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);box-sizing:border-box;overflow:hidden;padding:24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.rp-stat-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.rp-stat-card:before{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(90deg,var(--primary-blue),var(--primary-purple));border-radius:16px 16px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.rp-stat-icon{color:#1976d2;color:var(--primary-blue);opacity:.2;position:absolute;right:24px;top:24px;transition:all .3s ease}.rp-stat-card:hover .rp-stat-icon{opacity:.8;transform:scale(1.1)}.rp-stat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.rp-stat-label{background:#f8fafc;border-radius:6px;color:#9ca3af;color:var(--text-light);display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.rp-stat-label,.rp-stat-value{font-family:Elms Sans,sans-serif}.rp-stat-value{color:#1f2937;color:var(--text-dark);font-size:32px;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:12px 0}.rp-stat-change{align-items:center;background:#f8fafc;border-radius:6px;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;width:-webkit-fit-content;width:fit-content}.rp-stat-change.positive{background:#10b9811a;background:var(--success-light);color:#10b981;color:var(--status-paid)}.rp-stat-change.negative{background:#ef44441a;background:var(--error-light);color:#ef4444;color:var(--status-failed)}.rp-stat-change svg{flex-shrink:0}.rp-charts-section{margin-bottom:48px;width:100%}.rp-charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr;width:100%}@media (max-width:1200px){.rp-charts-grid{grid-template-columns:1fr}}.rp-chart-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:16px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);box-sizing:border-box;padding:28px;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.rp-chart-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.rp-chart-large{grid-column:span 1}.rp-chart-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.rp-chart-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin:0}.rp-chart-stats{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.rp-chart-stat{background:#f9fafb;border-radius:6px;font-size:13px;padding:6px 12px}.rp-chart-stat,.rp-chart-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-weight:500}.rp-chart-subtitle{font-size:14px}.rp-chart-placeholder{justify-content:center;min-height:320px}.rp-chart-placeholder,.rp-no-data{align-items:center;display:flex;flex-direction:column;width:100%}.rp-no-data{color:#9ca3af;color:var(--text-light);gap:16px;padding:40px 20px;text-align:center}.rp-no-data p{font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin:0}.rp-bar-chart{align-items:flex-end;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;gap:8px;height:240px;justify-content:space-between;overflow-x:auto;padding-bottom:32px;width:100%}.rp-bar-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:8px;height:100%;min-width:60px;position:relative}.rp-bar{background:linear-gradient(0deg,#1976d2,#7c3aed);background:linear-gradient(to top,var(--primary-blue),var(--primary-purple));border-radius:6px 6px 0 0;cursor:pointer;position:relative;transition:all .3s ease;width:40px}.rp-bar:hover{opacity:.9;transform:scale(1.05)}.rp-bar:after{background:#000000e6;border-radius:6px;color:#fff;content:attr(title);font-family:Elms Sans,sans-serif;font-size:12px;left:50%;opacity:0;padding:8px 12px;pointer-events:none;position:absolute;top:-40px;transform:translateX(-50%);transition:opacity .2s ease;white-space:nowrap;z-index:10}.rp-bar:hover:after{opacity:1}.rp-bar-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:500;padding-top:8px;text-align:center;white-space:nowrap}.rp-chart-footer{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;margin-top:20px;padding-top:16px;width:100%}.rp-chart-note{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:12px}.rp-donut-chart{height:220px;margin:0 auto 32px;position:relative;width:220px}.rp-donut-svg{height:100%;transform:rotate(-90deg);width:100%}.rp-donut-center{align-items:center;display:flex;flex-direction:column;gap:4px;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.rp-donut-total{color:#1f2937;color:var(--text-dark);font-size:28px;font-weight:700;line-height:1}.rp-donut-label,.rp-donut-total{display:block;font-family:Elms Sans,sans-serif}.rp-donut-label{color:#6b7280;color:var(--text-medium);font-size:13px;font-weight:500}.rp-donut-legend{display:flex;flex-direction:column;gap:12px;width:100%}.rp-legend-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:10px;transition:background .2s ease}.rp-legend-item:hover{background:#f9fafb}.rp-legend-color{border-radius:50%;flex-shrink:0;height:14px;width:14px}.rp-legend-info{align-items:center;display:flex;flex:1 1;justify-content:space-between}.rp-legend-label{color:#1f2937;color:var(--text-dark);font-size:13px}.rp-legend-label,.rp-legend-stats{font-family:Elms Sans,sans-serif;font-weight:500}.rp-legend-stats{color:#6b7280;color:var(--text-medium);font-size:12px}.rp-table-section{margin-bottom:48px;width:100%}.rp-section-header{margin-bottom:24px;width:100%}.rp-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:22px;font-weight:600;margin:0 0 8px}.rp-section-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500}.rp-table-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:16px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);box-sizing:border-box;overflow:hidden;padding:28px;width:100%}.rp-table-wrapper{border-radius:8px;margin:0;max-width:100%;overflow-x:auto;padding:0;position:relative;width:100%}.rp-table{border-collapse:collapse;font-family:Elms Sans,sans-serif;margin:0;min-width:1100px;width:100%}.rp-table thead{z-index:10}.rp-table th,.rp-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color);position:-webkit-sticky;position:sticky;top:0}.rp-table th{color:#9ca3af;color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.5px;min-width:120px;padding:16px 20px;text-align:left;text-transform:uppercase;white-space:nowrap}.rp-table th:first-child{min-width:80px}.rp-table th:nth-child(2){min-width:220px}.rp-table th:nth-child(3){min-width:100px}.rp-table th:nth-child(4),.rp-table th:nth-child(5){min-width:120px}.rp-table th:nth-child(6),.rp-table th:nth-child(7){min-width:180px}.rp-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);font-size:14px;min-width:120px;padding:16px 20px;vertical-align:middle;white-space:nowrap}.rp-table tbody tr{transition:background .2s ease}.rp-table tbody tr:hover{background:#f9fafb}.rp-table tbody tr:last-child td{border-bottom:none}.rp-rank{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;min-width:80px;padding:16px 20px;text-align:center}.rp-institution-cell{align-items:center;display:flex;gap:12px;min-width:220px;padding:16px 20px}.rp-institution-cell svg{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.rp-institution-cell span{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rp-plan-badge{border-radius:20px;display:inline-block;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;min-width:100px;padding:6px 12px;text-align:center;text-transform:uppercase;white-space:nowrap}.rp-plan-basic{background:#9ca3af1a;border:1px solid #9ca3af33;color:#9ca3af;color:var(--text-light)}.rp-plan-pro{background:#2563eb1a;border:1px solid #2563eb33;color:#2563eb}.rp-plan-enterprise{background:#7c3aed1a;border:1px solid #7c3aed33;color:#7c3aed;color:var(--primary-purple)}.rp-session-count,.rp-student-count{font-family:Elms Sans,sans-serif;font-weight:500;min-width:120px;padding:16px 20px;text-align:center}.rp-score-container{align-items:center;display:flex;gap:12px;min-width:180px;padding:16px 20px}.rp-score-value{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;min-width:50px;text-align:center}.rp-score-bar{background:#f3f4f6;flex:1 1;height:10px;min-width:100px;overflow:hidden}.rp-score-bar,.rp-score-fill{border-radius:5px;position:relative}.rp-score-fill{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(to right,var(--primary-blue),var(--primary-purple));height:100%;transition:width .3s ease}.rp-score-percentage{color:#fff;font-family:Elms Sans,sans-serif;font-size:9px;font-weight:600;left:50%;pointer-events:none;position:absolute;text-shadow:0 1px 2px #0003;top:50%;transform:translate(-50%,-50%);z-index:2}.rp-revenue-cell{display:flex;flex-direction:column;gap:8px;min-width:180px;padding:16px 20px}.rp-revenue-amount{color:#1f2937;color:var(--text-dark);font-size:15px}.rp-payment-status,.rp-revenue-amount{font-family:Elms Sans,sans-serif;font-weight:600;white-space:nowrap}.rp-payment-status{border-radius:12px;display:inline-block;font-size:11px;letter-spacing:.5px;padding:4px 10px;text-align:center;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.rp-status-paid{background:#10b9811a;background:var(--success-light);border:1px solid #10b98133;color:#10b981;color:var(--status-paid)}.rp-status-pending{background:#f59e0b1a;background:var(--warning-light);border:1px solid #f59e0b33;color:#f59e0b;color:var(--status-pending)}.rp-status-failed{background:#ef44441a;background:var(--error-light);border:1px solid #ef444433;color:#ef4444;color:var(--status-failed)}.rp-table-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);gap:16px;justify-content:space-between;margin-top:20px;padding:20px 0;width:100%}.rp-table-footer,.rp-table-summary{align-items:center;display:flex;flex-wrap:wrap}.rp-table-summary{gap:12px}.rp-summary-label{font-size:13px}.rp-table-empty{align-items:center;color:#9ca3af;color:var(--text-light);display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:80px 24px;text-align:center;width:100%}.rp-table-empty p{font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin:20px 0 0}.rp-table-wrapper::-webkit-scrollbar{height:8px}.rp-table-wrapper::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px;margin:0 4px}.rp-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.rp-table-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.rp-scroll-indicator{align-items:center;background:#000000b3;border-radius:20px;bottom:10px;color:#fff;display:flex;font-size:11px;font-weight:600;gap:6px;opacity:0;padding:6px 12px;pointer-events:none;position:absolute;right:20px;transition:opacity .3s ease;z-index:5}.rp-table-wrapper:hover .rp-scroll-indicator{opacity:1}.rp-summary-section{margin-bottom:48px;width:100%}.rp-summary-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));width:100%}.rp-summary-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:16px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);box-sizing:border-box;padding:28px;width:100%}.rp-summary-title{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin:0 0 24px;padding-bottom:16px}.rp-summary-content{display:flex;flex-direction:column;gap:20px;width:100%}.rp-summary-stat{align-items:center;display:flex;justify-content:space-between;padding:8px 0;width:100%}.rp-summary-label{color:#6b7280;color:var(--text-medium);flex:1 1;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500}.rp-summary-value{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600;min-width:120px;text-align:right}.rp-summary-success{color:#10b981;color:var(--status-paid)}.rp-summary-failed{color:#ef4444;color:var(--status-failed)}.rp-summary-pending{color:#f59e0b;color:var(--status-pending)}.rp-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);margin-top:48px;padding-top:48px;text-align:center;width:100%}.rp-footer-text{color:#6b7280;color:var(--text-medium);font-size:14px;margin:0 0 8px}.rp-footer-note,.rp-footer-text{font-family:Elms Sans,sans-serif;font-weight:500}.rp-footer-note{color:#9ca3af;color:var(--text-light);font-size:12px;margin:0}@media (max-width:1200px){.rp-main{padding:32px 32px 64px}.rp-header{padding:28px 32px}.rp-stats-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.rp-table-wrapper{max-width:calc(100vw - 64px)}}@media (max-width:1024px){.rp-main{padding:28px 24px 56px}.rp-header-content{align-items:stretch;flex-direction:column;gap:24px}.rp-header-actions{justify-content:flex-start;width:100%}.rp-summary-grid{grid-template-columns:1fr}.rp-table-wrapper{max-width:calc(100vw - 48px)}}@media (max-width:768px){.rp-main{padding:24px 20px 48px}.rp-header{margin-bottom:32px;padding:24px}.rp-page-title{font-size:30px}.rp-page-subtitle{font-size:15px}.rp-stats-grid{gap:20px;grid-template-columns:1fr}.rp-stat-card{padding:20px}.rp-stat-value{font-size:28px}.rp-charts-grid{gap:20px}.rp-chart-card{padding:20px}.rp-chart-header{align-items:flex-start;flex-direction:column;gap:12px}.rp-chart-stats{align-items:flex-start;width:100%}.rp-bar-chart{height:200px}.rp-bar{width:32px}.rp-donut-chart{height:180px;width:180px}.rp-export-container{flex-direction:column;width:100%}.rp-export-btn{width:100%}.rp-table-wrapper{max-width:calc(100vw - 40px)}.rp-table-footer{align-items:flex-start;flex-direction:column;gap:12px}.rp-summary-grid{grid-template-columns:1fr}}@media (max-width:480px){.rp-main{padding:20px 16px 40px}.rp-header{margin-bottom:24px;padding:20px}.rp-page-title{font-size:26px}.rp-role-badge{display:inline-block;margin-left:0;margin-top:8px}.rp-header-actions{align-items:stretch;flex-direction:column;gap:12px}.rp-refresh-btn,.rp-time-range-container{width:100%}.rp-stat-value{font-size:24px}.rp-chart-placeholder{min-height:280px}.rp-table-wrapper{max-width:calc(100vw - 32px)}.rp-summary-card{padding:20px}}.rp-export-btn:focus-visible,.rp-refresh-btn:focus-visible,.rp-time-option:focus-visible,.rp-time-range-btn:focus-visible{outline:2px solid #1976d2;outline:2px solid var(--primary-blue);outline-offset:2px}.rp-refresh-btn .spinning{animation:spin 1s linear infinite}.rp-table thead th{box-shadow:0 2px 4px #0000000d}.rp-export-btn:disabled,.rp-refresh-btn:disabled{position:relative}.rp-export-btn:disabled:after,.rp-refresh-btn:disabled:after{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}:root{--status-paid:#10b981;--status-pending:#f59e0b;--status-failed:#ef4444}body.billing-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.bp-loading,body.billing-page-body{background:#fff;background:var(--bg-page)}.bp-loading{align-items:center;display:flex;height:100vh;justify-content:center}.bp-loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#1976d2;border-top:3px solid var(--primary-blue);height:40px;width:40px}.bp-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500;margin-left:16px}.bp-main{margin:0 auto;max-width:1200px;padding:0 40px 80px}.bp-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #8ec5ef99;border-radius:12px;margin-bottom:48px;padding:32px 40px}.bp-header-content{align-items:center;display:flex;gap:24px;justify-content:space-between}.bp-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;letter-spacing:-1px;margin-bottom:8px}.bp-page-title strong{font-weight:700}.bp-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;margin:0}.bp-header-actions{align-items:center;display:flex;gap:12px}.bp-refresh-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.bp-refresh-btn:hover{background:#f9fafb;border-color:#1976d2;border-color:var(--primary-blue);transform:translateY(-1px)}.bp-refresh-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.bp-refresh-btn .spinning{animation:spin 1s linear infinite}.bp-export-btn{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.bp-export-btn:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.bp-stats-section{margin-bottom:48px}.bp-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.bp-stat-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.bp-stat-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.bp-stat-card.warning{border-color:#f59e0b4d}.bp-stat-card.warning:hover{border-color:#f59e0b;border-color:var(--status-pending)}.bp-stat-header{margin-bottom:12px}.bp-stat-label{color:#9ca3af;color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.bp-stat-label,.bp-stat-value{font-family:Elms Sans,sans-serif}.bp-stat-value{color:#1f2937;color:var(--text-dark);font-size:36px;font-weight:700;letter-spacing:-1px;margin-bottom:8px}.bp-stat-change{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:6px}.bp-stat-change.positive{color:#10b981;color:var(--status-paid)}.bp-stat-change.negative{color:#ef4444;color:var(--status-failed)}.bp-stat-subtext{font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;margin-top:8px}.bp-stat-subtext.warning{color:#f59e0b;color:var(--status-pending)}.bp-stat-subtext.neutral{color:#6b7280;color:var(--text-medium)}.bp-filters-section{margin-bottom:32px}.bp-filters-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:24px}.bp-search-wrapper{align-items:center;display:flex;flex:1 1;position:relative}.bp-search-icon{color:#9ca3af;color:var(--text-light);left:16px;pointer-events:none;position:absolute}.bp-search-input{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:12px 16px 12px 48px;transition:all .2s ease;width:100%}.bp-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.bp-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.bp-date-input,.bp-filter-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;min-width:180px;padding:12px 16px;transition:all .2s ease}.bp-date-input:focus,.bp-date-input:hover,.bp-filter-select:focus,.bp-filter-select:hover{border-color:#1976d2;border-color:var(--primary-blue)}.bp-date-input:focus,.bp-filter-select:focus{box-shadow:0 0 0 3px #1976d21a;outline:none}.bp-date-input{min-width:200px}.bp-clear-filters-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.bp-clear-filters-btn:hover{background:#f9fafb;border-color:#ef4444;border-color:var(--status-failed);color:#ef4444;color:var(--status-failed)}.bp-table-section{margin-bottom:60px}.bp-table-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.bp-table-stats{background:#f9fafb;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;padding:20px 24px}.bp-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 40px;text-align:center}.bp-empty-icon{color:#9ca3af;color:var(--text-light);margin-bottom:20px;opacity:.5}.bp-empty-state p{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;margin-bottom:20px}.bp-table-container{overflow-x:auto}.bp-table{border-collapse:collapse;font-family:Elms Sans,sans-serif;width:100%}.bp-table thead{background:#f9fafb;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color)}.bp-table th{color:#9ca3af;color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.5px;padding:16px 24px;text-align:left;text-transform:uppercase;white-space:nowrap}.bp-table tbody tr{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);transition:background .2s ease}.bp-table tbody tr:hover{background:#f9fafb}.bp-table tbody tr:last-child{border-bottom:none}.bp-table td{color:#1f2937;color:var(--text-dark);font-size:14px;padding:20px 24px;vertical-align:middle;white-space:nowrap}.bp-invoice-id-cell{display:flex;flex-direction:column;gap:4px}.bp-invoice-id-main{color:#1f2937;color:var(--text-dark);font-family:Courier New,monospace;font-size:14px;font-weight:600}.bp-package-name{color:#6b7280;color:var(--text-medium);font-size:12px;font-weight:500}.bp-customer-cell{display:flex;flex-direction:column;gap:4px}.bp-customer-name{color:#1f2937;color:var(--text-dark);font-weight:600}.bp-customer-email{color:#6b7280;color:var(--text-medium);font-size:13px}.bp-customer-phone{color:#9ca3af;color:var(--text-light);font-size:12px}.bp-amount{color:#1f2937;color:var(--text-dark);font-weight:600}.bp-status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:11px;font-weight:700;gap:6px;letter-spacing:.3px;padding:6px 12px;text-transform:uppercase;white-space:nowrap}.bp-status-icon{flex-shrink:0}.bp-status-paid{background:#10b9811a;color:#10b981;color:var(--status-paid)}.bp-status-pending{background:#f59e0b1a;color:#f59e0b;color:var(--status-pending)}.bp-status-failed{background:#ef44441a;color:#ef4444;color:var(--status-failed)}.bp-credits-cell{min-width:120px}.bp-credits-info{display:flex;flex-direction:column;gap:2px}.bp-credits-count{color:#1f2937;color:var(--text-dark);font-weight:600}.bp-bonus-credits{color:#10b981;color:var(--status-paid);font-size:11px;font-weight:600}.bp-actions{gap:8px}.bp-action-btn,.bp-actions{align-items:center;display:flex}.bp-action-btn{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;height:36px;justify-content:center;transition:all .2s ease;width:36px}.bp-action-btn:hover{background:#f3f4f6;color:#1976d2;color:var(--primary-blue)}.bp-refund-btn:hover{background:#fef2f2;color:#ef4444;color:var(--status-failed)}.bp-pagination{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:16px;justify-content:center;padding:24px}.bp-page-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;min-width:80px;padding:8px 16px;transition:all .2s ease}.bp-page-btn:hover:not(:disabled){background:#f9fafb;border-color:#1976d2;border-color:var(--primary-blue)}.bp-page-btn:disabled{cursor:not-allowed;opacity:.5}.bp-page-numbers{display:flex;gap:4px}.bp-page-number{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#1f2937;color:var(--text-dark);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;height:36px;justify-content:center;transition:all .2s ease;width:36px}.bp-page-number:hover{background:#f9fafb}.bp-page-number.active,.bp-page-number:hover{border-color:#1976d2;border-color:var(--primary-blue)}.bp-page-number.active{background:#1976d2;background:var(--primary-blue);color:#fff}.bp-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;padding-top:40px;text-align:center}.bp-footer-text{margin:4px 0}@media (max-width:1024px){.bp-main{padding:48px 24px 60px}.bp-filters-card{flex-wrap:wrap}.bp-search-wrapper{flex-basis:100%}}@media (max-width:768px){.bp-main{padding:40px 20px 60px}.bp-header{margin-bottom:36px;padding:24px 20px}.bp-header-content{align-items:flex-start;flex-direction:column}.bp-header-actions{justify-content:space-between;width:100%}.bp-export-btn,.bp-refresh-btn{flex:1 1}.bp-page-title{font-size:28px}.bp-page-subtitle{font-size:16px}.bp-stats-grid{grid-template-columns:1fr}.bp-filters-card{flex-direction:column}.bp-date-input,.bp-filter-select{width:100%}.bp-table-card{border-radius:8px}.bp-table{min-width:900px}.bp-pagination{flex-direction:column;gap:12px}}@media (max-width:480px){.bp-main{padding:32px 16px 48px}.bp-header{padding:20px 16px}.bp-page-title{font-size:24px}.bp-page-subtitle{font-size:14px}.bp-header-actions{flex-direction:column;width:100%}.bp-export-btn,.bp-refresh-btn{width:100%}.bp-stat-card{padding:20px}.bp-stat-value{font-size:32px}.bp-filters-card{padding:20px}.bp-table td,.bp-table th,.bp-table-stats{padding:16px 20px}}body.register-institution-body{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.rip-loading{align-items:center;background:#fff;background:var(--bg-page);display:flex;height:100vh;justify-content:center}.rip-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.rip-main{background:#fff;background:var(--bg-page);min-height:100vh;padding:0 40px 80px}.rip-container{margin:0 auto;max-width:900px}.rip-back-btn{align-items:center;background:none;border:none;color:#6b7280;color:var(--text-medium);cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;gap:8px;margin-bottom:24px;padding:8px 0;transition:all .2s ease}.rip-back-btn:hover{color:#1976d2;color:var(--primary-blue)}.rip-header{margin-bottom:40px}.rip-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:36px;font-weight:700;letter-spacing:-1px;margin-bottom:8px}.rip-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:400;line-height:1.6;margin:0}.rip-form{display:flex;flex-direction:column;gap:32px}.rip-section{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:32px}.rip-section-header{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;gap:12px;margin-bottom:24px}.rip-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0}.rip-section-note{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:24px}.rip-form-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.rip-form-group{display:flex;flex-direction:column;gap:8px}.rip-form-group.rip-full-width{grid-column:1/-1}.rip-label{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600}.rip-required{color:#ef4444}.rip-input,.rip-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:12px 16px;transition:all .2s ease}.rip-input:focus,.rip-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.rip-input::placeholder{color:#9ca3af;color:var(--text-light)}.rip-helper-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;margin-top:4px}.rip-upload-area{position:relative}.rip-file-input{height:0;opacity:0;overflow:hidden;position:absolute;width:0}.rip-upload-label{align-items:center;background:#f9fafb;border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:40px;transition:all .2s ease}.rip-upload-label:hover{background:#1976d205;border-color:#1976d2;border-color:var(--primary-blue)}.rip-upload-icon{color:#9ca3af;color:var(--text-light)}.rip-upload-text{align-items:center;display:flex;flex-direction:column;gap:4px;text-align:center}.rip-upload-primary{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600}.rip-upload-secondary{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px}.rip-logo-preview{align-items:center;border-radius:8px;display:flex;height:120px;justify-content:center;overflow:hidden;width:120px}.rip-logo-preview img{max-height:100%;max-width:100%;object-fit:contain}.rip-plan-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.rip-plan-card{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;padding:20px;text-align:center;transition:all .2s ease}.rip-plan-card:hover{background:#1976d205}.rip-plan-card.selected,.rip-plan-card:hover{border-color:#1976d2;border-color:var(--primary-blue)}.rip-plan-card.selected{background:#1976d214;box-shadow:0 0 0 3px #1976d21a}.rip-plan-name{color:#1f2937;color:var(--text-dark);font-size:16px;font-weight:700;margin-bottom:6px}.rip-plan-desc,.rip-plan-name{font-family:Elms Sans,sans-serif}.rip-plan-desc{color:#6b7280;color:var(--text-medium);font-size:13px}.rip-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.rip-btn-cancel,.rip-btn-submit{border:none;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 32px;transition:all .2s ease}.rip-btn-cancel{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.rip-btn-cancel:hover{background:#f3f4f6;border-color:#6b7280;border-color:var(--text-medium)}.rip-btn-submit{background:#1976d2;background:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.rip-btn-submit:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.rip-btn-submit:active{box-shadow:0 2px 4px #1976d233;transform:translateY(0)}@media (max-width:768px){.rip-main{padding:40px 20px 60px}.rip-page-title{font-size:28px}.rip-page-subtitle{font-size:15px}.rip-section{padding:24px 20px}.rip-form-grid,.rip-plan-cards{grid-template-columns:1fr}.rip-actions{flex-direction:column-reverse}.rip-btn-cancel,.rip-btn-submit{width:100%}}:root{--status-active:#10b981;--status-inactive:#9ca3af;--status-suspended:#ef4444}body.edit-institution-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.eip-loading,body.edit-institution-body{background:#fff;background:var(--bg-page)}.eip-loading{align-items:center;display:flex;height:100vh;justify-content:center}.eip-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.eip-main{background:#fff;background:var(--bg-page);min-height:100vh;padding:0 40px 80px}.eip-container{margin:0 auto;max-width:900px}.eip-back-btn{align-items:center;background:none;border:none;color:#6b7280;color:var(--text-medium);cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;gap:8px;margin-bottom:24px;padding:8px 0;transition:all .2s ease}.eip-back-btn:hover{color:#1976d2;color:var(--primary-blue)}.eip-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:40px}.eip-header-left{flex:1 1}.eip-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:36px;font-weight:700;letter-spacing:-1px;margin-bottom:8px}.eip-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:400;margin:0}.eip-status-dropdown{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:10px;padding:8px 16px}.eip-status-indicator{border-radius:50%;height:10px;width:10px}.eip-status-indicator.active{background:#10b981;background:var(--status-active)}.eip-status-indicator.inactive{background:#9ca3af;background:var(--status-inactive)}.eip-status-indicator.suspended{background:#ef4444;background:var(--status-suspended)}.eip-status-select{background:none;border:none;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;outline:none}.eip-form{display:flex;flex-direction:column;gap:32px}.eip-section{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:32px}.eip-section-header{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;gap:12px;margin-bottom:24px}.eip-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0}.eip-current-plan{align-items:center;background:#1976d21a;border-radius:6px;display:inline-flex;gap:8px;margin-bottom:24px;padding:8px 16px}.eip-current-plan-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500}.eip-current-plan-value{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:700}.eip-form-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.eip-form-group{display:flex;flex-direction:column;gap:8px}.eip-label{font-weight:600}.eip-input,.eip-label,.eip-select{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px}.eip-input,.eip-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;transition:all .2s ease}.eip-input:focus,.eip-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.eip-input::placeholder{color:#9ca3af;color:var(--text-light)}.eip-helper-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;margin-top:4px}.eip-reset-password-btn{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;margin-top:16px;padding:10px 20px;transition:all .2s ease}.eip-reset-password-btn:hover{background:#f9fafb;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.eip-actions{align-items:center;justify-content:space-between;padding-top:24px}.eip-actions,.eip-actions-right{display:flex;gap:12px}.eip-btn-delete,.eip-btn-discard,.eip-btn-save{border:none;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 32px;transition:all .2s ease}.eip-btn-delete{background:#0000;border:1px solid #fecaca;color:#ef4444}.eip-btn-delete:hover{background:#fef2f2;border-color:#ef4444}.eip-btn-discard{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.eip-btn-discard:hover{background:#f3f4f6;border-color:#6b7280;border-color:var(--text-medium)}.eip-btn-save{background:#1976d2;background:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.eip-btn-save:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.eip-btn-save:active{box-shadow:0 2px 4px #1976d233;transform:translateY(0)}@media (max-width:768px){.eip-main{padding:40px 20px 60px}.eip-header{flex-direction:column}.eip-status-dropdown{align-self:flex-start}.eip-page-title{font-size:28px}.eip-page-subtitle{font-size:13px}.eip-section{padding:24px 20px}.eip-form-grid{grid-template-columns:1fr}.eip-actions{align-items:stretch}.eip-actions,.eip-actions-right{flex-direction:column}.eip-btn-delete,.eip-btn-discard,.eip-btn-save{width:100%}}.eip-error-banner,.eip-success-banner{align-items:center;animation:slideDown .3s ease-out;border-radius:8px;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;padding:14px 20px}.eip-success-banner{background-color:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.eip-error-banner{background-color:#fee2e2;border:1px solid #fca5a5;color:#dc2626}.eip-error-banner button,.eip-success-banner button{align-items:center;background:none;border:none;border-radius:4px;color:inherit;cursor:pointer;display:flex;margin-left:auto;padding:4px;transition:background-color .2s}.eip-error-banner button:hover,.eip-success-banner button:hover{background-color:#0000000d}.eip-institution-selector{align-items:center;display:flex;gap:12px;margin-top:12px}.eip-selector-label{color:#374151;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500}.eip-select-wrapper{flex:1 1;max-width:400px;position:relative}.eip-institution-select{-webkit-appearance:none;appearance:none;background-color:#fff;border:2px solid #d1d5db;border-radius:8px;color:#111827;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;padding:10px 36px 10px 12px;transition:all .2s;width:100%}.eip-institution-select:hover{border-color:#9ca3af}.eip-institution-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.eip-institution-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.eip-select-icon{color:#6b7280;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.eip-empty-state{background:#fff;border:2px dashed #d1d5db;border-radius:12px;margin-top:20px;padding:80px 20px;text-align:center}.eip-empty-state svg{color:#9ca3af;margin-bottom:16px}.eip-empty-state p{color:#6b7280;font-family:Elms Sans,sans-serif;font-size:16px;margin:0}.eip-loading-form{background:#fff;border-radius:12px;margin-top:20px;padding:60px 20px;text-align:center}.eip-loading-form p{color:#6b7280;font-family:Elms Sans,sans-serif;font-size:16px;margin:0}.eip-form-group-full{grid-column:1/-1}.eip-status-indicator.pending{background-color:#f59e0b}.eip-btn-delete:disabled,.eip-btn-discard:disabled,.eip-btn-save:disabled,.eip-reset-password-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.eip-institution-selector{align-items:flex-start;flex-direction:column}.eip-select-wrapper{max-width:none;width:100%}}.viva-management-section{width:100%}.viva-management-section .loading-state{align-items:center;color:#666;display:flex;font-size:16px;justify-content:center;padding:3rem}.viva-management-section .dashboard-loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.viva-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.viva-search-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:14px;min-width:200px;padding:.5rem 1rem;transition:border-color .2s}.viva-search-input:focus{border-color:#1976d2;outline:none}.viva-filter-select{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:.5rem 1rem;transition:border-color .2s}.viva-filter-select:focus{border-color:#1976d2;outline:none}.expand-btn{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:color .2s}.expand-btn:hover{color:#1976d2}.expand-btn:disabled{cursor:not-allowed;opacity:.5}.topic-count{background:#f5f5f5;border-radius:4px;color:#666;display:inline-block;font-size:13px;padding:4px 8px}.topics-container{background:#f9fafb;padding:0!important}.topics-section{border-top:2px solid #e5e7eb;padding:1.5rem}.topics-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 1rem}.topics-table{background:#fff;border-collapse:collapse;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.topics-table thead{background:#f5f7fa}.topics-table th{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;padding:.75rem 1rem;text-align:left;text-transform:uppercase}.topics-table td{border-top:1px solid #e5e7eb;font-size:14px;padding:.75rem 1rem}.topics-table tbody tr:hover{background:#f9fafb}.no-topics{background:#fff;border:1px dashed #ddd;border-radius:6px;color:#999;font-size:14px;padding:2rem;text-align:center}.inactive-row{background:#fafafa;opacity:.6}.inactive-row:hover{opacity:.8}.action-buttons{align-items:center;display:flex;gap:.5rem}.action-buttons .btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:inline-flex;font-size:13px;gap:.25rem;padding:.375rem .75rem;transition:all .2s}.action-buttons .btn:disabled{cursor:not-allowed;opacity:.5}.action-buttons .btn-sm{font-size:12px;padding:.25rem .5rem}.action-buttons .btn-info{background:#e3f2fd;color:#1976d2}.action-buttons .btn-info:hover:not(:disabled){background:#bbdefb}.action-buttons .btn-success{background:#e8f5e9;color:#2e7d32}.action-buttons .btn-success:hover:not(:disabled){background:#c8e6c9}.action-buttons .btn-warning{background:#fff3e0;color:#e65100}.action-buttons .btn-warning:hover:not(:disabled){background:#ffe0b2}.action-buttons .btn-danger{background:#ffebee;color:#c62828}.action-buttons .btn-danger:hover:not(:disabled){background:#ffcdd2}.action-buttons .btn-primary{background:#1976d2;color:#fff}.action-buttons .btn-primary:hover:not(:disabled){background:#1565c0}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.message{border-radius:6px;font-size:14px;margin-bottom:1rem;padding:.75rem 1rem}.message.success{background:#e8f5e9;border:1px solid #c8e6c9;color:#2e7d32}.message.error{background:#ffebee;border:1px solid #ffcdd2;color:#c62828}.modal-overlay{background:#00000080;padding:1rem}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #e5e7eb;padding:1.5rem}.modal-title{color:#333;font-size:20px;font-weight:600;margin:0}.form-group{margin-bottom:1.25rem;padding:0 1.5rem}.form-label{color:#333;font-weight:500;margin-bottom:.5rem}.form-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:.625rem .75rem;transition:border-color .2s;width:100%}.form-input:focus{border-color:#1976d2;outline:none}.form-input:disabled{background:#f5f5f5;cursor:not-allowed}.form-label input[type=checkbox]{cursor:pointer;margin-right:.5rem}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem}@media (max-width:768px){.viva-filters{flex-direction:column}.viva-filter-select,.viva-search-input{width:100%}.topics-section{padding:1rem}.topics-table{font-size:12px}.topics-table td,.topics-table th{padding:.5rem}.action-buttons{flex-wrap:wrap}.modal-content{margin:1rem;max-width:100%}}:root{--primary-blue-light:#e3f2fd;--primary-purple-light:#f3e8ff;--bg-gradient:linear-gradient(135deg,#e8f4f8,#f0e6f6);--bg-hover:#f9fafb;--border-light:#f3f4f6;--border-medium:#d1d5db;--success-green:#10b981;--success-green-light:#d1fae5;--warning-amber:#f59e0b;--warning-amber-light:#fef3c7;--error-red-light:#fee2e2;--info-blue:#0ea5e9;--info-blue-light:#e0f2fe;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.viva-gemini-container{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f4f6f8;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.viva-gemini-main{margin:0 auto;max-width:1400px;padding:40px 32px 80px;transition:padding-top .2s cubic-bezier(.4,0,.2,1);transition:padding-top var(--transition-base)}.viva-gemini-container:has(.viva-session-active-badge) .viva-gemini-main{padding-top:40px}.viva-session-active-badge{align-items:center;animation:slideInRight .3s ease-out forwards;background:linear-gradient(135deg,#ef4444,#dc2626);background:linear-gradient(135deg,var(--error-red) 0,#dc2626 100%);border-radius:9999px;box-shadow:0 4px 12px #ef44444d;color:#fff;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:8px;opacity:0;padding:8px 18px;position:fixed;right:32px;top:80px;z-index:99}@media (max-width:768px){.viva-gemini-main{padding:24px 16px 60px}.viva-gemini-container:has(.viva-session-active-badge) .viva-gemini-main{padding-top:24px}.viva-session-active-badge{font-size:12px;padding:8px 16px;right:16px;top:70px}}.viva-session-active-dot{animation:pulseWhite 2s cubic-bezier(.4,0,.6,1) infinite;background-color:#fff;border-radius:50%;box-shadow:0 0 0 0 #ffffffb3;height:8px;width:8px}@keyframes pulseWhite{0%,to{box-shadow:0 0 0 0 #ffffffb3;opacity:1}50%{box-shadow:0 0 0 8px #fff0;opacity:.8}}.viva-setup-container{display:flex;flex-direction:column;gap:32px;margin:0 auto;max-width:1200px;width:100%}.viva-setup-header-section{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;margin-bottom:0;padding:32px 40px}.viva-setup-header-content{align-items:center;display:flex;gap:24px;justify-content:space-between}.viva-setup-welcome-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;letter-spacing:-1px;margin-bottom:8px}.viva-setup-welcome-title strong{font-weight:700}.viva-setup-welcome-text{font-size:18px;font-weight:400;margin:0 0 12px}.viva-setup-welcome-subtitle,.viva-setup-welcome-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif}.viva-setup-welcome-subtitle{font-size:15px;font-weight:500;margin:0;opacity:.85}.viva-setup-form-section{width:100%}.viva-setup-form{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);padding:48px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-setup-form:hover{border-color:#d1d5db;border-color:var(--border-medium);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.viva-setup-form-header{align-items:flex-start;border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--border-light);display:flex;flex-direction:column;margin-bottom:40px;padding-bottom:32px}.viva-setup-icon{align-items:center;align-self:center;background:linear-gradient(135deg,#1976d21a,#7c3aed1a);border-radius:50%;box-shadow:0 4px 12px #1976d226;display:flex;height:80px;justify-content:center;margin-bottom:20px;padding:0;position:relative;width:80px}.viva-setup-icon svg{color:#1976d2;color:var(--primary-blue);display:block;flex-shrink:0;height:40px;left:50%;margin:0 auto;padding:0;position:absolute;top:50%;transform:translate(-50%,-50%);width:40px}.viva-setup-form-header>div{align-items:flex-start;display:flex;flex-direction:column;text-align:left}.viva-setup-form-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:600;letter-spacing:-.5px;margin:0 0 8px;text-align:left}.viva-setup-form-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:400;margin:0;text-align:left}.viva-form{display:flex;flex-direction:column;gap:32px}.viva-form-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr}@media (min-width:768px){.viva-form-grid{grid-template-columns:repeat(2,1fr)}}.viva-form-group{display:flex;flex-direction:column}.viva-form-label{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:6px;margin-bottom:10px}.viva-form-input,.viva-form-select,.viva-form-textarea{-webkit-appearance:none;appearance:none;background:#fff;background:var(--bg-card);border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;padding:14px 18px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-form-input:focus,.viva-form-select:focus,.viva-form-textarea:focus{background:#fff;background:var(--bg-card);border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d214;outline:none;transform:translateY(-1px)}.viva-form-input:hover,.viva-form-select:hover,.viva-form-textarea:hover{border-color:#d1d5db;border-color:var(--border-medium)}.viva-form-select:disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}.viva-form-sublabel{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:400;margin-bottom:16px;margin-top:-6px}.viva-difficulty-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}@media (min-width:768px){.viva-difficulty-grid{grid-template-columns:repeat(4,1fr)}}.viva-difficulty-card{align-items:center;background:#fff;background:var(--bg-card);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:12px;overflow:hidden;padding:20px;position:relative;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-difficulty-card:before{background:#1976d2;background:var(--difficulty-color,var(--primary-blue));content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .2s cubic-bezier(.4,0,.2,1);transition:transform var(--transition-base)}.viva-difficulty-card:hover{background:#1976d205;border-color:#1976d2;border-color:var(--difficulty-color,var(--primary-blue));box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.viva-difficulty-card:hover:before{transform:scaleX(1)}.viva-difficulty-card.active{background:linear-gradient(135deg,#1976d214,#1976d208);border-color:#1976d2;border-color:var(--difficulty-color,var(--primary-blue));box-shadow:0 0 0 3px #1976d21a;transform:translateY(-2px)}.viva-difficulty-card.active:before{transform:scaleX(1)}.viva-difficulty-icon{align-items:center;background:#1976d214;border-radius:12px;color:#1976d2;color:var(--difficulty-color,var(--primary-blue));display:flex;height:48px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:48px}.viva-difficulty-card.active .viva-difficulty-icon{background:#1976d2;background:var(--difficulty-color,var(--primary-blue));color:#fff;transform:scale(1.1)}.viva-difficulty-content{align-items:center;display:flex;gap:8px;justify-content:center;width:100%}.viva-difficulty-name{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600}.viva-difficulty-card.active .viva-difficulty-name{color:#1976d2;color:var(--difficulty-color,var(--primary-blue));font-weight:700}.viva-difficulty-check{color:#1976d2;color:var(--difficulty-color,var(--primary-blue));flex-shrink:0}.viva-voice-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr}@media (min-width:768px){.viva-voice-grid{grid-template-columns:repeat(2,1fr)}}.viva-voice-card-modern{background:#fff;background:var(--bg-card);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:16px;overflow:hidden;padding:24px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-voice-card-modern:before{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(90deg,var(--primary-blue),var(--primary-purple));content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .2s cubic-bezier(.4,0,.2,1);transition:transform var(--transition-base)}.viva-voice-card-modern:hover{background:#1976d205;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-3px)}.viva-voice-card-modern:hover:before{transform:scaleX(1)}.viva-voice-card-modern.selected{background:linear-gradient(135deg,#1976d20f,#7c3aed08);border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21f,0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:0 0 0 3px #1976d21f,var(--shadow-md);transform:translateY(-2px)}.viva-voice-card-modern.selected:before{transform:scaleX(1)}.viva-voice-card-header{align-items:flex-start;display:flex;justify-content:space-between}.viva-voice-icon-modern{align-items:center;border-radius:14px;display:flex;flex-shrink:0;height:56px;justify-content:center;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:56px}.viva-voice-card-modern:hover .viva-voice-icon-modern{transform:scale(1.05) rotate(2deg)}.viva-voice-card-modern.selected .viva-voice-icon-modern{box-shadow:0 4px 12px #1976d233;transform:scale(1.1)}.viva-voice-icon-modern.female{background:linear-gradient(135deg,#ec489926,#db27771a);border:2px solid #ec489933;color:#ec4899}.viva-voice-card-modern.selected .viva-voice-icon-modern.female{background:linear-gradient(135deg,#ec4899,#db2777);border-color:#ec4899;color:#fff}.viva-voice-icon-modern.male{background:linear-gradient(135deg,#1976d226,#1565c01a);border:2px solid #1976d233;color:#1976d2;color:var(--primary-blue)}.viva-voice-card-modern.selected .viva-voice-icon-modern.male{background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.viva-voice-icon-modern svg{height:28px;width:28px}.viva-voice-selected-badge{align-items:center;animation:scaleIn .2s ease-out;background:#1976d2;background:var(--primary-blue);border-radius:50%;box-shadow:0 2px 8px #1976d24d;color:#fff;display:flex;height:28px;justify-content:center;width:28px}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.viva-voice-info-modern{flex:1 1}.viva-voice-name{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;letter-spacing:-.2px;margin:0 0 8px}.viva-voice-card-modern.selected .viva-voice-name{color:#1976d2;color:var(--primary-blue)}.viva-voice-meta{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:13px;gap:8px}.viva-voice-gender{font-weight:600;text-transform:capitalize}.viva-voice-separator{color:#9ca3af;color:var(--text-light)}.viva-voice-accent{font-weight:500}.viva-submit-btn{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 12px #1976d240;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;margin:0 auto;max-width:320px;min-width:200px;overflow:hidden;padding:14px 28px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:auto}.viva-submit-btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.viva-submit-btn:hover:not(:disabled):before{height:300px;width:300px}.viva-submit-btn:hover:not(:disabled){box-shadow:0 8px 20px #1976d266;transform:translateY(-2px)}.viva-submit-btn:active:not(:disabled){transform:translateY(0)}.viva-submit-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.viva-sessions-sidebar{width:100%}@media (min-width:1024px){.viva-sessions-sidebar{position:-webkit-sticky;position:sticky;top:100px;width:400px}}.viva-sessions-panel{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:-webkit-fit-content;height:fit-content;max-height:calc(100vh - 140px);padding:28px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-sessions-panel:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg)}.viva-sessions-header{align-items:center;border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--border-light);color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;gap:10px;margin:0 0 20px;padding-bottom:16px}.viva-sessions-header svg{color:#1976d2;color:var(--primary-blue);height:22px;width:22px}.viva-sessions-list{display:flex;flex:1 1;flex-direction:column;gap:14px;overflow-y:auto;padding-right:8px}.viva-sessions-list::-webkit-scrollbar{width:6px}.viva-sessions-list::-webkit-scrollbar-track{background:#f4f6f8;background:var(--bg-page);border-radius:10px}.viva-sessions-list::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:10px}.viva-sessions-list::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-light)}.viva-session-card{background:#fff;background:var(--bg-card);border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);cursor:pointer;overflow:hidden;padding:20px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-session-card:before{background:#1976d2;background:var(--primary-blue);bottom:0;content:"";left:0;position:absolute;top:0;transform:scaleY(0);transition:transform .2s cubic-bezier(.4,0,.2,1);transition:transform var(--transition-base);width:4px}.viva-session-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateX(4px)}.viva-session-card:hover:before{transform:scaleY(1)}.viva-session-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.viva-session-subject{background:#e3f2fd;background:var(--primary-blue-light);border-radius:8px;border-radius:var(--radius-sm);color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:11px;font-weight:700;letter-spacing:.8px;padding:4px 10px;text-transform:uppercase}.viva-session-date{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:500}.viva-session-topic{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;line-height:1.4;margin-bottom:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viva-session-grade{align-items:center;display:flex;gap:8px}.viva-grade-badge{border-radius:9999px;border-radius:var(--radius-full);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:700;letter-spacing:.5px;padding:6px 14px}.viva-grade-badge.grade-a{background:#d1fae5;background:var(--success-green-light);border:1px solid #10b98133;color:#10b981;color:var(--success-green)}.viva-grade-badge.grade-other{background:#e3f2fd;background:var(--primary-blue-light);border:1px solid #1976d233;color:#1976d2;color:var(--primary-blue)}.viva-session-wrapper{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:1400px;padding:0;width:100%}.viva-session-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 380px;min-height:calc(100vh - 250px)}.viva-main-panel,.viva-session-container,.viva-side-panel{display:flex;flex-direction:column}.viva-session-container{gap:24px;margin:0 auto;max-width:1200px;padding:0;width:100%}.viva-session-header{align-items:flex-start;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:24px 32px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-session-header:hover{border-color:#d1d5db;border-color:var(--border-medium);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.viva-session-title{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;flex-wrap:wrap;font-family:Elms Sans,sans-serif;font-size:26px;font-weight:600;gap:12px;letter-spacing:-.5px;margin:0 0 8px}@media (max-width:768px){.viva-session-title{font-size:20px;gap:8px}}.viva-session-title-dot{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;background-color:#ef4444;background-color:var(--error-red);border-radius:50%;box-shadow:0 0 0 0 #ef4444b3;height:10px;width:10px}.viva-session-meta{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;flex-wrap:wrap;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;gap:8px}.viva-session-meta:before{color:#9ca3af;color:var(--text-light);content:"•"}@media (max-width:768px){.viva-session-meta{font-size:13px}}.viva-end-btn{background:#fee2e2;background:var(--error-red-light);border:2px solid #ef44444d;border-radius:12px;border-radius:var(--radius-md);color:#ef4444;color:var(--error-red);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-end-btn:hover{background:#ef4444;background:var(--error-red);border-color:#ef4444;border-color:var(--error-red);box-shadow:0 4px 12px #ef44444d;color:#fff;transform:translateY(-2px)}.viva-transcript-container{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 600px);min-height:350px;overflow-x:hidden;overflow-y:auto;padding:24px 28px;scroll-behavior:smooth;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-transcript-container:empty{align-items:center;display:flex;justify-content:center;min-height:200px}.viva-transcript-container:hover{border-color:#d1d5db;border-color:var(--border-medium)}.viva-transcript-container::-webkit-scrollbar{width:8px}.viva-transcript-container::-webkit-scrollbar-track{background:#f4f6f8;background:var(--bg-page);border-radius:10px}.viva-transcript-container::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:10px}.viva-transcript-container::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-light)}.viva-transcript-loading{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;flex-direction:column;font-family:Elms Sans,sans-serif;gap:20px;height:100%;justify-content:center}.viva-spinner{animation:spin 1s linear infinite;border:4px solid #1976d21a;border-radius:50%;border-top:4px solid var(--primary-blue);height:56px;width:56px}.viva-transcript-loading p{font-size:16px;font-weight:500;margin:0}.viva-transcript-item{animation:fadeInUp .3s ease-out;display:flex;margin-bottom:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.viva-transcript-item.professor{justify-content:flex-start}.viva-transcript-item.student{justify-content:flex-end}.viva-transcript-bubble{word-wrap:break-word;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);max-width:80%;overflow-wrap:break-word;padding:16px 20px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}@media (max-width:768px){.viva-transcript-bubble{max-width:90%;padding:14px 18px}}.viva-transcript-bubble:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.viva-transcript-bubble.professor{background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border-left:4px solid #1976d2;border:2px solid var(--border-color);border-left:4px solid var(--primary-blue);color:#1f2937;color:var(--text-dark)}.viva-transcript-bubble.student{background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);box-shadow:0 4px 12px #1976d240;color:#fff}.viva-transcript-role{font-family:Elms Sans,sans-serif;font-size:10px;font-weight:700;letter-spacing:1px;margin-bottom:8px;opacity:.7;text-transform:uppercase}.viva-transcript-text{font-family:Elms Sans,sans-serif;font-size:15px;font-weight:400;line-height:1.7;margin:0}.viva-audio-panel{display:flex;flex-direction:column;gap:16px;height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:20px}.viva-status-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:20px;padding:24px}.viva-status-card-title{border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--border-light);color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;margin:0;padding-bottom:12px;text-transform:uppercase}.viva-current-state{align-items:center;border-radius:12px;border-radius:var(--radius-md);display:flex;gap:16px;padding:16px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-current-state.examiner{background:linear-gradient(135deg,#1976d214,#7c3aed14);border:2px solid #1976d233}.viva-current-state.candidate{background:linear-gradient(135deg,#10b98114,#05966914);border:2px solid #10b98133}.viva-current-state.waiting{background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color)}.viva-state-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.viva-current-state.examiner .viva-state-icon{background:linear-gradient(135deg,#1976d2,#7c3aed);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-purple) 100%);box-shadow:0 4px 12px #1976d24d;color:#fff}.viva-current-state.candidate .viva-state-icon{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-green) 0,#059669 100%);box-shadow:0 4px 12px #10b9814d;color:#fff}.viva-current-state.waiting .viva-state-icon{background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.viva-state-text{flex:1 1}.viva-state-label{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;margin:0 0 4px}.viva-state-description{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;margin:0}.viva-mic-monitor{display:flex;flex-direction:column;gap:12px}.viva-mic-monitor-header{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;gap:8px;letter-spacing:.5px;text-transform:uppercase}.viva-mic-monitor-header svg{color:#9ca3af;color:var(--text-light);transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-mic-monitor-header svg.active{animation:blink 1.5s ease-in-out infinite;color:#10b981;color:var(--success-green)}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.viva-volume-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);margin-bottom:16px;padding:18px}.viva-volume-header{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;gap:10px;margin-bottom:16px}.viva-volume-header h4{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;margin:0}.viva-volume-control{align-items:center;display:flex;gap:12px}.viva-volume-slider{-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,#1976d2 0,#1976d2 50%,#f3f4f6 0,#f3f4f6);background:linear-gradient(to right,var(--primary-blue) 0,var(--primary-blue) var(--volume-percentage,50%),var(--border-light) var(--volume-percentage,50%),var(--border-light) 100%);border-radius:3px;cursor:pointer;flex:1 1;height:6px;outline:none;transition:all .2s ease}.viva-volume-slider:hover{opacity:.8}.viva-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#1976d2;background:var(--primary-blue);border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:16px;-webkit-transition:all .2s ease;transition:all .2s ease;width:16px}.viva-volume-slider::-webkit-slider-thumb:hover{background:#1565c0;background:var(--primary-blue-dark);transform:scale(1.1)}.viva-volume-slider::-moz-range-thumb{background:#1976d2;background:var(--primary-blue);border:none;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:16px;-moz-transition:all .2s ease;transition:all .2s ease;width:16px}.viva-volume-slider::-moz-range-thumb:hover{background:#1565c0;background:var(--primary-blue-dark);transform:scale(1.1)}.viva-volume-percentage{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;min-width:40px;text-align:right}.viva-quick-guide{background:#f4f6f8;background:var(--bg-page);border:1px solid #f3f4f6;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);padding:16px}.viva-quick-guide h4{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:700;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.viva-guide-item{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:10px;margin-bottom:8px}.viva-guide-item:last-child{margin-bottom:0}.viva-guide-indicator{border-radius:50%;flex-shrink:0;height:12px;width:12px}.viva-guide-indicator.examiner{background:linear-gradient(135deg,#1976d2,#7c3aed);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-purple) 100%);box-shadow:0 0 0 3px #1976d233}.viva-guide-indicator.candidate{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-green) 0,#059669 100%);box-shadow:0 0 0 3px #10b98133}.viva-audio-container{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:28px;overflow:hidden;padding:40px 32px;position:relative;width:100%}.viva-audio-container:before{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);background:var(--bg-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.viva-error-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fef2f2fa;border-radius:16px;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:20px;inset:0;justify-content:center;padding:32px;position:absolute;z-index:20}.viva-error-message{color:#ef4444;color:var(--error-red);font-size:18px;text-align:center}.viva-error-message,.viva-restart-btn{font-family:Elms Sans,sans-serif;font-weight:600}.viva-restart-btn{background:#ef4444;background:var(--error-red);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 12px #ef44444d;color:#fff;cursor:pointer;font-size:15px;padding:14px 28px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-restart-btn:hover{background:#dc2626;box-shadow:0 6px 16px #ef444466;transform:translateY(-2px)}.viva-audio-circle{align-items:center;border-radius:50%;display:flex;height:140px;justify-content:center;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-slow);width:140px}.viva-audio-circle.speaking{animation:pulseCircle 2s ease-in-out infinite;background:linear-gradient(135deg,#1976d226,#7c3aed26);transform:scale(1.08)}@keyframes pulseCircle{0%,to{box-shadow:0 0 0 0 #1976d266}50%{box-shadow:0 0 0 20px #1976d200}}.viva-audio-circle.idle{background:#f4f6f8;background:var(--bg-page);border:3px solid #e5e7eb;border:3px solid var(--border-color)}.viva-audio-inner{align-items:center;border-radius:50%;display:flex;height:112px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-slow);width:112px}.viva-audio-inner.speaking{background:linear-gradient(135deg,#1976d2,#7c3aed);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-purple) 100%);box-shadow:0 8px 24px #1976d24d}.viva-audio-inner.idle{background:linear-gradient(135deg,#9ca3af,#6b7280);background:linear-gradient(135deg,var(--text-light) 0,var(--text-medium) 100%)}.viva-audio-inner svg{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:56px;width:56px}.viva-audio-status{max-width:600px;text-align:center;width:100%}.viva-audio-status h3{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;justify-content:center;margin:0 0 16px;min-height:28px}.viva-audio-visualizer{background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);height:100px;opacity:.9;padding:8px;width:100%}.viva-feedback-container{animation:fadeInScale .4s ease-out;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin:0 auto;max-width:1100px;padding:40px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-feedback-container:hover{border-color:#d1d5db;border-color:var(--border-medium);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg)}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.viva-feedback-header{align-items:flex-start;border-bottom:3px solid #f3f4f6;border-bottom:3px solid var(--border-light);display:flex;gap:24px;justify-content:space-between;margin-bottom:40px;padding-bottom:32px}.viva-feedback-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:600;letter-spacing:-.8px;margin:0 0 8px}.viva-feedback-subtitle{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:500;gap:8px}.viva-feedback-grade-container{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.viva-feedback-grade{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1976d2,#7c3aed);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-purple) 100%);-webkit-background-clip:text;background-clip:text;font-family:Elms Sans,sans-serif;font-size:72px;font-weight:700;line-height:1;margin:0}.viva-feedback-grade.grade-a,.viva-feedback-grade.grade-b{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-green) 0,#059669 100%);-webkit-background-clip:text;background-clip:text}.viva-feedback-grade-label{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase}.viva-feedback-summary{background:linear-gradient(135deg,#1976d20d,#7c3aed0d);border:2px solid #f3f4f6;border:2px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);margin-bottom:32px;overflow:hidden;padding:32px;position:relative}.viva-feedback-summary:before{background:linear-gradient(180deg,#1976d2,#7c3aed);background:linear-gradient(180deg,var(--primary-blue) 0,var(--primary-purple) 100%);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.viva-feedback-summary-title{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:700;gap:10px;letter-spacing:1px;margin:0 0 16px;text-transform:uppercase}.viva-feedback-summary-title svg{color:#1976d2;color:var(--primary-blue);height:18px;width:18px}.viva-feedback-summary-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:17px;font-style:italic;font-weight:400;line-height:1.8;margin:0}.viva-feedback-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;margin-bottom:32px}@media (min-width:768px){.viva-feedback-grid{grid-template-columns:repeat(2,1fr)}}.viva-feedback-card{background:#fff;background:var(--bg-card);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);padding:28px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-feedback-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.viva-feedback-card.strengths{background:linear-gradient(135deg,#10b98108,#10b98103);border-color:#10b98166}.viva-feedback-card.strengths:before{background:#10b981;background:var(--success-green);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.viva-feedback-card.weaknesses{background:linear-gradient(135deg,#f59e0b08,#f59e0b03);border-color:#f59e0b66}.viva-feedback-card.weaknesses:before{background:#f59e0b;background:var(--warning-amber);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.viva-feedback-card-title{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:700;gap:10px;letter-spacing:1px;margin:0 0 20px;text-transform:uppercase}.viva-feedback-card-title.strengths{color:#10b981;color:var(--success-green)}.viva-feedback-card-title.weaknesses{color:#f59e0b;color:var(--warning-amber)}.viva-feedback-card-title svg{height:22px;width:22px}.viva-feedback-list{display:flex;flex-direction:column;gap:16px;list-style:none;margin:0;padding:0}.viva-feedback-list-item{align-items:flex-start;background:#f4f6f8;background:var(--bg-page);border-radius:8px;border-radius:var(--radius-sm);color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:400;gap:14px;line-height:1.6;padding:12px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.viva-feedback-list-item:hover{background:#fff;background:var(--bg-card);transform:translateX(4px)}.viva-feedback-list-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:8px;width:8px}.viva-feedback-list-dot.strengths{background-color:#10b981;background-color:var(--success-green);box-shadow:0 0 0 4px #10b9811a}.viva-feedback-list-dot.weaknesses{background-color:#f59e0b;background-color:var(--warning-amber);box-shadow:0 0 0 4px #f59e0b1a}.viva-feedback-recommendations{background:linear-gradient(135deg,#1f2937,#1f2937);background:linear-gradient(135deg,var(--text-dark) 0,#1f2937 100%);border-radius:16px;border-radius:var(--radius-lg);color:#fff;margin-bottom:32px;overflow:hidden;padding:32px;position:relative}.viva-feedback-recommendations:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#1976d21a 0,#0000 70%);content:"";height:200%;position:absolute;right:-50%;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.viva-feedback-recommendations-title{color:#ffffffb3;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:700;letter-spacing:1.2px;margin:0 0 20px;position:relative;text-transform:uppercase;z-index:1}.viva-feedback-tags{display:flex;flex-wrap:wrap;gap:10px;position:relative;z-index:1}.viva-feedback-tag{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1f;border:1px solid #fff3;border-radius:9999px;border-radius:var(--radius-full);color:#fffffff2;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:10px 18px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-feedback-tag:hover{background:#fff3;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.viva-feedback-loading{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin:0 auto;max-width:600px;padding:64px 48px;text-align:center}.viva-feedback-loading-spinner{animation:spin 1s linear infinite;border:5px solid #1976d21a;border-radius:50%;border-top:5px solid var(--primary-blue);height:72px;margin:0 auto 32px;width:72px}.viva-feedback-loading h2{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:600;margin:0 0 12px}.viva-feedback-loading p{color:#6b7280;color:var(--text-medium);margin:0}.viva-feedback-loading p,.viva-reset-btn{font-family:Elms Sans,sans-serif;font-size:16px}.viva-reset-btn{background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 12px #1976d24d;color:#fff;cursor:pointer;font-weight:600;overflow:hidden;padding:18px 32px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-reset-btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.viva-reset-btn:hover:before{height:300px;width:300px}.viva-reset-btn:hover{box-shadow:0 8px 20px #1976d266;transform:translateY(-2px)}.viva-reset-btn:active{transform:translateY(0)}.viva-admin-container{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin:0 auto;max-width:1200px;padding:40px}.viva-admin-header{align-items:center;border-bottom:3px solid #f3f4f6;border-bottom:3px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.viva-admin-header h2{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:600;letter-spacing:-.5px;margin:0}.viva-admin-close-btn{align-items:center;background:#f4f6f8;background:var(--bg-page);border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:10px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.viva-admin-close-btn:hover{background:#fee2e2;background:var(--error-red-light);transform:rotate(90deg)}.viva-admin-close-btn svg{color:#6b7280;color:var(--text-medium);height:24px;width:24px}.viva-admin-close-btn:hover svg{color:#ef4444;color:var(--error-red)}.viva-admin-actions{display:flex;gap:12px;margin-bottom:32px}.viva-admin-add-btn{background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-admin-add-btn:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.viva-admin-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr}@media (min-width:768px){.viva-admin-grid{grid-template-columns:280px 1fr}}.viva-admin-sidebar{border-right:2px solid #f3f4f6;border-right:2px solid var(--border-light);padding-right:32px}.viva-admin-sidebar-title{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:700;letter-spacing:1px;margin:0 0 20px;text-transform:uppercase}.viva-admin-subjects-list{display:flex;flex-direction:column;gap:6px}.viva-admin-subject-btn{background:#0000;border:none;border-radius:12px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:500;padding:12px 16px;position:relative;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-admin-subject-btn:before{background:#1976d2;background:var(--primary-blue);border-radius:0 3px 3px 0;content:"";height:0;left:0;position:absolute;top:50%;transform:translateY(-50%);transition:height .2s cubic-bezier(.4,0,.2,1);transition:height var(--transition-base);width:3px}.viva-admin-subject-btn:hover{background:#f4f6f8;background:var(--bg-page);padding-left:19px}.viva-admin-subject-btn:hover:before{height:60%}.viva-admin-subject-btn.active{background:#e3f2fd;background:var(--primary-blue-light);color:#1976d2;color:var(--primary-blue);font-weight:600;padding-left:19px}.viva-admin-subject-btn.active:before{height:100%}.viva-admin-content{padding-left:32px}.viva-admin-content-header{align-items:center;border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.viva-admin-content-header h3{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;margin:0}.viva-admin-add-topic-btn{background:#0000;border:none;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;text-decoration:underline;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.viva-admin-add-topic-btn:hover{color:#1565c0;color:var(--primary-blue-dark)}.viva-admin-topics-list{display:flex;flex-direction:column;gap:16px}.viva-admin-topic-card{align-items:center;background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:20px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-admin-topic-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);transform:translateX(4px)}.viva-admin-topic-info{flex:1 1}.viva-admin-topic-info h4{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;margin:0 0 6px}.viva-admin-topic-info p{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;margin:0;max-width:500px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viva-admin-topic-actions{display:flex;gap:8px}.viva-admin-topic-btn{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-light);cursor:pointer;display:flex;justify-content:center;padding:10px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.viva-admin-topic-btn:hover.edit{background:#e3f2fd;background:var(--primary-blue-light);color:#1976d2;color:var(--primary-blue)}.viva-admin-topic-btn:hover.delete{background:#fee2e2;background:var(--error-red-light);color:#ef4444;color:var(--error-red)}.viva-admin-topic-btn svg{height:20px;width:20px}.viva-admin-empty{background:#f4f6f8;background:var(--bg-page);border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:15px;font-style:italic;height:300px}.viva-admin-empty,.viva-admin-modal{align-items:center;display:flex;justify-content:center}.viva-admin-modal{animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#0009;inset:0;padding:24px;position:fixed;z-index:1000}.viva-admin-modal-content{animation:slideUp .3s ease-out;background-color:#fff;background-color:var(--bg-card);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:700px;overflow-y:auto;padding:40px;width:100%}.viva-admin-modal-content::-webkit-scrollbar{width:8px}.viva-admin-modal-content::-webkit-scrollbar-track{background:#f4f6f8;background:var(--bg-page);border-radius:10px}.viva-admin-modal-content::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:10px}.viva-admin-modal-header{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:600;letter-spacing:-.5px;margin:0 0 32px}.viva-admin-modal-form{display:flex;flex-direction:column;gap:24px}.viva-admin-modal-actions{display:flex;gap:12px;margin-top:32px}.viva-admin-modal-save{background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;flex:1 1;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600;padding:14px 28px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-admin-modal-save:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.viva-admin-modal-cancel{background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-dark);cursor:pointer;flex:1 1;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600;padding:14px 28px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-admin-modal-cancel:hover{background:#fff;background:var(--bg-card);border-color:#9ca3af;border-color:var(--text-light)}@media (max-width:1024px){.viva-setup-container{max-width:100%}.viva-setup-header-section{padding:24px 28px}.viva-setup-form{padding:36px 32px}}@media (max-width:768px){.viva-gemini-main{padding:24px 16px 40px}.viva-setup-container{flex-direction:column;gap:24px}.viva-setup-header-section{padding:24px 20px}.viva-setup-header-content{align-items:flex-start;flex-direction:column}.viva-setup-welcome-title{font-size:28px}.viva-setup-welcome-text{font-size:16px}.viva-setup-welcome-subtitle{font-size:14px}.viva-setup-form{padding:28px 24px}.viva-setup-form-header{margin-bottom:32px;padding-bottom:24px}.viva-setup-form-title{font-size:24px}.viva-sessions-sidebar{position:static;width:100%}.viva-admin-grid{grid-template-columns:1fr}.viva-admin-sidebar{border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--border-light);border-right:none;margin-bottom:24px;padding-bottom:24px;padding-right:0}.viva-admin-content{padding-left:0}.viva-feedback-container{padding:28px 20px}.viva-feedback-header{align-items:flex-start;flex-direction:column;gap:16px}.viva-feedback-grade-container{align-items:flex-start;width:100%}.viva-feedback-grade{font-size:56px}.viva-feedback-summary{padding:24px 20px}.viva-feedback-grid{grid-template-columns:1fr}.viva-feedback-card{padding:20px}.viva-feedback-recommendations{padding:24px 20px}.viva-session-container{gap:20px;padding:0}.viva-session-header{align-items:stretch;flex-direction:column;padding:20px 24px}.viva-session-title{font-size:22px}.viva-end-btn{margin-top:8px;width:100%}.viva-transcript-container{gap:12px;max-height:calc(100vh - 550px);min-height:300px;padding:20px 16px}.viva-audio-container{gap:24px;padding:32px 24px}.viva-audio-circle{height:120px;width:120px}.viva-audio-inner{height:96px;width:96px}.viva-audio-status h3{font-size:16px}}.glass-effect{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3}.viva-confirm-dialog-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.viva-confirm-dialog{animation:slideUp .3s ease-out;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-width:480px;padding:32px;width:100%}.viva-confirm-dialog-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:22px;font-weight:600;letter-spacing:-.3px;margin:0 0 12px}.viva-confirm-dialog-message{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:15px;line-height:1.6;margin:0 0 28px}.viva-confirm-dialog-actions{display:flex;gap:12px;justify-content:flex-end}.viva-confirm-dialog-cancel,.viva-confirm-dialog-confirm{border:none;border-radius:12px;border-radius:var(--radius-md);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-confirm-dialog-cancel{background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);color:#1f2937;color:var(--text-dark)}.viva-confirm-dialog-cancel:hover{background:#fff;background:var(--bg-card);border-color:#d1d5db;border-color:var(--border-medium)}.viva-confirm-dialog-confirm{background:#ef4444;background:var(--error-red);box-shadow:0 4px 12px #ef44444d;color:#fff}.viva-confirm-dialog-confirm:hover{background:#dc2626;box-shadow:0 6px 16px #ef444466;transform:translateY(-1px)}@media (max-width:768px){.viva-confirm-dialog{max-width:calc(100% - 40px);padding:24px 20px}.viva-confirm-dialog-title{font-size:20px}.viva-confirm-dialog-message{font-size:14px}.viva-confirm-dialog-actions{flex-direction:column-reverse}.viva-confirm-dialog-cancel,.viva-confirm-dialog-confirm{width:100%}}.viva-instructions-container{align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:900px;min-height:calc(100vh - 200px);padding:40px 32px;width:100%}.viva-instructions-card{animation:fadeInScale .4s ease-out;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:48px;width:100%}.viva-instructions-header{border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--border-light);margin-bottom:40px;padding-bottom:32px;text-align:center}.viva-instructions-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:600;letter-spacing:-.5px;margin:0 0 12px}.viva-instructions-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:400;margin:0}.viva-instructions-content{display:flex;flex-direction:column;gap:28px;margin-bottom:40px}.viva-instruction-item{align-items:flex-start;background:#f4f6f8;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);display:flex;gap:20px;padding:24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-instruction-item:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);transform:translateX(4px)}.viva-instruction-icon{align-items:center;background:linear-gradient(135deg,#1976d21a,#7c3aed1a);border-radius:12px;border-radius:var(--radius-md);color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:56px;justify-content:center;min-width:56px;width:56px}.viva-instruction-icon svg{height:28px;width:28px}.viva-instruction-text{flex:1 1}.viva-instruction-text h3{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin:0 0 8px}.viva-instruction-text p{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:15px;line-height:1.6;margin:0}.viva-instructions-start-btn{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-dark) 100%);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 12px #1976d24d;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;gap:10px;justify-content:center;padding:16px 32px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.viva-instructions-start-btn:hover{box-shadow:0 8px 20px #1976d266;transform:translateY(-2px)}.viva-instructions-start-btn:active{transform:translateY(0)}.viva-instructions-start-btn.counting,.viva-instructions-start-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.viva-instructions-start-btn.counting:hover,.viva-instructions-start-btn:disabled:hover{box-shadow:0 4px 12px #1976d24d;transform:none}.viva-countdown-container{background:linear-gradient(135deg,#1976d20d,#7c3aed0d);border:2px solid #f3f4f6;border:2px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);margin-bottom:32px;padding:24px}.viva-countdown-text{align-items:center;display:flex;font-family:Elms Sans,sans-serif;gap:12px;justify-content:center;margin-bottom:16px}.viva-countdown-number{animation:pulseCountdown 1s ease-in-out infinite;color:#1976d2;color:var(--primary-blue);font-size:48px;font-weight:700;line-height:1;min-width:60px;text-align:center}@keyframes pulseCountdown{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.viva-countdown-label{color:#1f2937;color:var(--text-dark);font-size:16px;font-weight:600}.viva-progress-bar-container{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:9999px;border-radius:var(--radius-full);height:8px;overflow:hidden;position:relative;width:100%}.viva-progress-bar-fill{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(90deg,var(--primary-blue) 0,var(--primary-purple) 100%);border-radius:9999px;border-radius:var(--radius-full);height:100%;overflow:hidden;position:relative;transition:width .1s linear}.viva-progress-bar-fill:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}@media (max-width:768px){.viva-countdown-number{font-size:36px;min-width:50px}.viva-countdown-label{font-size:14px}.viva-countdown-container{padding:20px}}.viva-status-indicator{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:12px;justify-content:center;margin-bottom:20px;padding:12px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.viva-status-indicator.ai-speaking{background:#ef44441a;border:2px solid #ef444433;color:#ef4444;color:var(--error-red)}.viva-status-indicator.user-can-speak{background:#10b9811a;border:2px solid #10b98133;color:#10b981;color:var(--success-green)}.viva-status-indicator.waiting{background:#6b72801a;border:2px solid #6b728033;color:#6b7280;color:var(--text-medium)}.viva-status-dot{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;border-radius:50%;height:10px;width:10px}.viva-status-indicator.ai-speaking .viva-status-dot{background-color:#ef4444;background-color:var(--error-red);box-shadow:0 0 0 0 #ef4444b3}.viva-status-indicator.user-can-speak .viva-status-dot{background-color:#10b981;background-color:var(--success-green);box-shadow:0 0 0 0 #10b981b3}.viva-status-indicator.waiting .viva-status-dot{background-color:#6b7280;background-color:var(--text-medium);box-shadow:0 0 0 0 #6b7280b3}.viva-status-text{font-weight:600}.viva-audio-circle.listening{animation:pulseListening 2s ease-in-out infinite;background:linear-gradient(135deg,#10b98126,#05966926);border:3px solid #10b9814d}@keyframes pulseListening{0%,to{box-shadow:0 0 0 0 #10b98166}50%{box-shadow:0 0 0 15px #10b98100}}.viva-audio-inner.listening{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-green) 0,#059669 100%);box-shadow:0 8px 24px #10b9814d}@media (max-width:1024px){.viva-session-content{gap:16px;grid-template-columns:1fr}.viva-side-panel{position:relative}.viva-audio-panel{position:relative;top:0}.viva-status-card{padding:20px}}@media (max-width:768px){.viva-instructions-container{padding:24px 16px}.viva-session-wrapper{gap:16px}.viva-session-header{padding:16px 20px}.viva-status-card{padding:16px}.viva-current-state{gap:12px;padding:12px}.viva-state-icon{height:48px;width:48px}.viva-state-label{font-size:14px}.viva-state-description{font-size:12px}.viva-instructions-card{padding:32px 24px}.viva-instructions-title{font-size:26px}.viva-instruction-item{flex-direction:column;padding:20px;text-align:center}.viva-instruction-icon{margin:0 auto}.viva-status-indicator{font-size:13px;padding:10px 20px}}.viva-empty-session{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 200px);padding:40px 20px}.viva-empty-session-content{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:500px;padding:60px 40px;text-align:center}.viva-empty-session-content h2{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:700;margin-bottom:16px}.viva-empty-session-content p{color:#6b7280;color:var(--text-medium);font-size:16px;line-height:1.6;margin-bottom:32px}.viva-empty-session-content .viva-primary-btn{font-size:15px;min-width:200px;padding:14px 28px}@media (max-width:768px){.viva-empty-session-content{padding:40px 24px}.viva-empty-session-content h2{font-size:24px}.viva-empty-session-content p{font-size:15px}}.mcqg-body{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;min-height:100vh;padding:0}.mcqg-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.mcqg-breadcrumb{gap:8px;margin-bottom:32px}.mcqg-breadcrumb,.mcqg-breadcrumb-link{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:14px}.mcqg-breadcrumb-link{background:none;border:none;cursor:pointer;gap:6px;padding:0;text-decoration:none;transition:color .2s ease}.mcqg-breadcrumb-link:hover{color:#1976d2;color:var(--primary-blue)}.mcqg-breadcrumb-separator{color:#9ca3af;color:var(--text-light)}.mcqg-breadcrumb-current{color:#1f2937;color:var(--text-dark);font-weight:500}.mcqg-header{margin-bottom:20px;margin-top:-20px}.mcqg-header-content{align-items:flex-start;display:flex;gap:16px}.mcqg-header-icon{align-items:center;background:#1976d21a;border-radius:12px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.mcqg-title{color:#1f2937;color:var(--text-dark);font-size:clamp(28px,3vw,36px);font-weight:700;letter-spacing:-.5px;margin:0 0 6px}.mcqg-subtitle,.mcqg-title{font-family:Elms Sans,sans-serif}.mcqg-subtitle{color:#6b7280;color:var(--text-medium);font-size:16px;font-weight:400;margin:0}.mcqg-content-grid{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 380px}.mcqg-config-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:28px;padding:32px}.mcqg-form-group{display:flex;flex-direction:column;gap:10px}.mcqg-form-group.disabled{opacity:.5;pointer-events:none}.mcqg-label{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px}.mcqg-label-hint{color:#6b7280;color:var(--text-medium);font-weight:500}.mcqg-source-options{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.mcqg-source-btn{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;gap:12px;padding:16px;transition:all .2s ease}.mcqg-source-btn:hover{transform:translateY(-1px)}.mcqg-source-btn.active,.mcqg-source-btn:hover{border-color:#1976d2;border-color:var(--primary-blue)}.mcqg-source-btn.active{background:#1976d20d;box-shadow:0 0 0 1px #1976d2;box-shadow:0 0 0 1px var(--primary-blue)}.mcqg-source-btn svg{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.mcqg-source-text{display:flex;flex-direction:column;gap:2px;text-align:left}.mcqg-source-name{color:#1f2937;color:var(--text-dark);font-size:14px;font-weight:600}.mcqg-source-desc{color:#6b7280;color:var(--text-medium);font-size:12px}.mcqg-select{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;padding:12px 14px;transition:all .2s ease;width:100%}.mcqg-select:hover{border-color:#6b7280;border-color:var(--text-medium)}.mcqg-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.mcqg-weakness-toggle{align-items:center;background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:8px;cursor:pointer;display:flex;gap:16px;justify-content:space-between;padding:16px 20px;transition:all .2s ease}.mcqg-weakness-toggle:hover{border-color:#f59e0b;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.mcqg-weakness-content{align-items:flex-start;display:flex;flex:1 1;gap:12px}.mcqg-weakness-icon{align-items:center;background:#f59e0b33;border-radius:6px;color:#f59e0b;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.mcqg-weakness-title{color:#78350f;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;margin-bottom:2px}.mcqg-weakness-desc{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px}.mcqg-switch{display:inline-block;flex-shrink:0;height:26px;position:relative;width:48px}.mcqg-switch-input{height:0;opacity:0;width:0}.mcqg-switch-slider{background-color:#d1d5db;border-radius:26px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.mcqg-switch-slider:before{background-color:#fff;border-radius:50%;bottom:3px;box-shadow:0 1px 2px #0000001a;content:"";height:20px;left:3px;position:absolute;transition:.3s;width:20px}.mcqg-switch-input:checked+.mcqg-switch-slider{background-color:#f59e0b}.mcqg-switch-input:checked+.mcqg-switch-slider:before{transform:translateX(22px)}.mcqg-topics-grid{background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;display:flex;flex-wrap:wrap;gap:8px;min-height:100px;padding:14px}.mcqg-topics-placeholder{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:14px;padding:8px}.mcqg-topic-chip{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:20px;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;padding:8px 14px;transition:all .2s ease}.mcqg-topic-chip:hover{background:#1976d20d}.mcqg-topic-chip.selected,.mcqg-topic-chip:hover{border-color:#1976d2;border-color:var(--primary-blue)}.mcqg-topic-chip.selected{background:#dbeafe;color:#1976d2;color:var(--primary-blue);font-weight:600}.mcqg-difficulty-grid{grid-gap:16px;background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);padding:18px}.mcqg-diff-item{display:flex;flex-direction:column;gap:8px;text-align:center}.mcqg-diff-label{font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.mcqg-diff-label.easy{color:#10b981}.mcqg-diff-label.medium{color:#f59e0b}.mcqg-diff-label.hard{color:#ef4444}.mcqg-diff-input{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;padding:10px;text-align:center;transition:all .2s ease;width:100%}.mcqg-diff-input:hover{border-color:#6b7280;border-color:var(--text-medium)}.mcqg-diff-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.mcqg-summary{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border-radius:12px;border-top:4px solid #1976d2;border:1px solid var(--border-color);border-top:4px solid var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:20px;padding:28px;position:-webkit-sticky;position:sticky;top:100px}.mcqg-summary-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0}.mcqg-summary-list{display:flex;flex-direction:column;gap:12px}.mcqg-summary-row{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;justify-content:space-between}.mcqg-summary-key{color:#6b7280;color:var(--text-medium);font-weight:500}.mcqg-summary-value{color:#1f2937;color:var(--text-dark);font-weight:600;text-align:right}.mcqg-cost-box{background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:center}.mcqg-cost-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.mcqg-cost-value{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:40px;font-weight:800;line-height:1;margin-bottom:6px}.mcqg-cost-balance{color:#10b981;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500}.mcqg-btn-primary{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .2s ease;width:100%}.mcqg-btn-primary:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.mcqg-btn-primary:disabled{cursor:not-allowed;opacity:.6}.mcqg-btn-secondary{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease;width:100%}.mcqg-btn-secondary:hover{background:#f9fafb;border-color:#6b7280;border-color:var(--text-medium)}.mcqg-error{align-items:center;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;gap:8px;padding:12px 14px}.mcqg-error svg{flex-shrink:0}@media (max-width:1024px){.mcqg-main{padding:48px 24px 60px}.mcqg-content-grid{gap:24px;grid-template-columns:1fr}.mcqg-summary{position:static}}@media (max-width:768px){.mcqg-main{padding:40px 20px 60px}.mcqg-header-content{align-items:flex-start;flex-direction:column}.mcqg-config-card,.mcqg-summary{padding:24px 20px}.mcqg-source-options{grid-template-columns:1fr}.mcqg-difficulty-grid{gap:12px;padding:14px}.mcqg-cost-value{font-size:36px}}.question-bank-body{background:#f9fafb;background:var(--bg-secondary);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;min-height:100vh;padding:0 0 120px}.question-bank-navbar{background:#fff;background:var(--bg-page);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:none;position:-webkit-sticky;position:sticky;top:0;z-index:100}.question-bank-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:16px 40px}.question-bank-navbar-logo{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:800;letter-spacing:-.5px;text-decoration:none;transition:opacity .2s ease}.question-bank-navbar-logo:hover{opacity:.8}.question-bank-logo-osce{color:#1976d2;color:var(--primary-blue)}.question-bank-logo-pal{color:#7c3aed;color:var(--primary-purple)}.question-bank-profile-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.question-bank-profile-btn:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#e5e7eb;border-color:var(--border-color)}.question-bank-profile-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);border-radius:50%;color:#fff;display:flex;font-size:13px;font-weight:600;height:32px;justify-content:center;width:32px}.question-bank-main-container{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:280px 1fr;margin:0 auto;max-width:1200px;padding:60px 40px 80px}.question-bank-header-col{align-items:flex-end;display:flex;grid-column:1/-1;justify-content:space-between;margin-bottom:24px;margin-top:-30px}.question-bank-breadcrumb{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:8px;margin-bottom:12px}.question-bank-breadcrumb-link{color:#6b7280;color:var(--text-medium);font-weight:500;text-decoration:none;transition:color .2s ease}.question-bank-breadcrumb-link:hover{color:#1976d2;color:var(--primary-blue)}.question-bank-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(28px,3vw,36px);font-weight:700;letter-spacing:-.5px;margin:0}.question-bank-stats{align-items:center;background:#1976d21a;border:1px solid #1976d233;border-radius:8px;color:#1976d2;color:var(--primary-blue);display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:16px;padding:10px 18px}.question-bank-filters-panel{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px;position:-webkit-sticky;position:sticky;top:90px}.question-bank-filter-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.question-bank-filter-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.3px}.question-bank-reset-btn{background:none;border:none;border-radius:4px;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:4px 8px;transition:all .2s ease}.question-bank-reset-btn:hover{background:#1976d21a;color:#1565c0}.question-bank-search-input{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;margin-bottom:24px;padding:10px 14px;transition:all .2s ease;width:100%}.question-bank-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.question-bank-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.question-bank-filter-section{margin-bottom:24px}.question-bank-filter-label{color:#1f2937;color:var(--text-dark);display:block;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:700;letter-spacing:-.2px;margin-bottom:12px}.question-bank-checkbox-item{align-items:center;border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:10px;margin-bottom:10px;padding:6px 8px;transition:all .2s ease}.question-bank-checkbox-item:hover{background:#f9fafb;background:var(--bg-secondary);color:#1f2937;color:var(--text-dark)}.question-bank-checkbox-item input[type=checkbox]{accent-color:#1976d2;accent-color:var(--primary-blue);cursor:pointer;height:16px;width:16px}.question-bank-cb-count{color:#9ca3af;color:var(--text-light);font-size:12px;font-weight:600;margin-left:auto}.question-bank-list-header{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:20px;padding:14px 20px}.question-bank-list-info{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600}.question-bank-auto-select-btn{align-items:center;background:#0000;border:1px solid #1976d2;border:1px solid var(--primary-blue);border-radius:8px;color:#1976d2;color:var(--primary-blue);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.question-bank-auto-select-btn:hover{background:#1976d2;background:var(--primary-blue);box-shadow:0 4px 12px #1976d24d;color:#fff;transform:translateY(-1px)}.question-bank-question-list{display:flex;flex-direction:column;gap:16px}.question-bank-question-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;gap:16px;padding:20px;position:relative;transition:all .2s ease}.question-bank-question-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.question-bank-question-card.selected{background:#1976d20a;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 1px #1976d2;box-shadow:0 0 0 1px var(--primary-blue)}.question-bank-select-check{align-items:center;background:#fff;background:var(--bg-page);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:6px;display:flex;flex-shrink:0;height:22px;justify-content:center;margin-top:2px;transition:all .2s ease;width:22px}.question-bank-select-check.selected{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.question-bank-checkmark{color:#fff;font-size:14px;font-weight:700}.question-bank-q-content{flex:1 1}.question-bank-q-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.question-bank-tag{border-radius:12px;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:700;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.question-bank-tag-subject{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#1f2937;color:var(--text-dark)}.question-bank-tag-diff-easy{background:#d1fae5;background:var(--success-bg);color:#065f46}.question-bank-tag-diff-med{background:#fef3c7;background:var(--warning-bg);color:#92400e}.question-bank-tag-diff-hard{background:#fee2e2;background:var(--error-bg);color:#991b1b}.question-bank-q-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:400;line-height:1.6;margin-bottom:12px}.question-bank-q-meta{font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:20px}.question-bank-preview-btn,.question-bank-q-meta{align-items:center;color:#6b7280;color:var(--text-medium);display:flex}.question-bank-preview-btn{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;flex-shrink:0;height:36px;justify-content:center;transition:all .2s ease;width:36px}.question-bank-preview-btn:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue);transform:scale(1.05)}.question-bank-selection-footer{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff;background:var(--bg-page);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);bottom:0;box-shadow:0 -4px 12px #0000000d;display:flex;justify-content:center;left:0;padding:18px 40px;position:fixed;right:0;z-index:90}.question-bank-footer-content{align-items:center;display:flex;justify-content:space-between;max-width:1200px;width:100%}.question-bank-count-summary{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;letter-spacing:-.2px}.question-bank-cost-summary{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin-left:12px}.question-bank-cost-val{color:#1976d2;color:var(--primary-blue);font-size:16px;font-weight:700}.question-bank-footer-actions{display:flex;gap:12px}.question-bank-btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.question-bank-btn-primary{background:#1976d2;background:var(--primary-blue);color:#fff}.question-bank-btn-primary:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.question-bank-btn-secondary{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.question-bank-btn-secondary:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#6b7280;border-color:var(--text-medium)}.question-bank-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:200}.question-bank-modal-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:600px;padding:28px;width:90%}.question-bank-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.question-bank-modal-header h3{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0}.question-bank-modal-close{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;transition:all .2s ease;width:32px}.question-bank-modal-close:hover{background:#fee2e2;background:var(--error-bg);border-color:#ef4444;border-color:var(--error);color:#ef4444;color:var(--error)}.question-bank-modal-content{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;line-height:1.7}.question-bank-modal-note{background:#f9fafb;background:var(--bg-secondary);border-left:3px solid #1976d2;border-left:3px solid var(--primary-blue);border-radius:4px;color:#6b7280;color:var(--text-medium);font-size:13px;font-style:italic;margin-top:20px;padding:12px}@media (max-width:1024px){.question-bank-navbar-container{padding:14px 24px}.question-bank-main-container{gap:24px;grid-template-columns:240px 1fr;padding:48px 24px 80px}.question-bank-filters-panel{padding:20px}}@media (max-width:768px){.question-bank-navbar-container{padding:12px 20px}.question-bank-navbar-logo{font-size:20px}.question-bank-main-container{gap:20px;grid-template-columns:1fr;padding:40px 20px 80px}.question-bank-header-col{align-items:flex-start;flex-direction:column;gap:16px}.question-bank-page-title{font-size:24px}.question-bank-stats{align-items:flex-start;flex-direction:column;gap:8px;width:100%}.question-bank-filters-panel{position:static}.question-bank-list-header{align-items:stretch;flex-direction:column;gap:12px}.question-bank-auto-select-btn{justify-content:center}.question-bank-question-card{padding:16px}.question-bank-selection-footer{padding:14px 20px}.question-bank-footer-content{flex-direction:column;gap:16px}.question-bank-footer-actions{width:100%}.question-bank-btn{flex:1 1}.question-bank-modal-card{padding:24px;width:95%}}@media (max-width:480px){.question-bank-page-title{font-size:22px}.question-bank-question-card{flex-direction:column;gap:12px}.question-bank-select-check{align-self:flex-start}.question-bank-preview-btn{align-self:flex-end}.question-bank-q-meta{align-items:flex-start;flex-direction:column;gap:8px}}:root{--bg-secondary:#f9fafb}.mcq-attempt-body{background:#f9fafb;background:var(--bg-secondary);color:#1f2937;color:var(--text-dark);display:flex;flex-direction:column;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;margin:0;overflow:hidden;padding:0}.mcq-attempt-test-header{align-items:center;background:#fff;background:var(--bg-page);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;min-height:64px;padding:16px 40px;z-index:50}.mcq-attempt-header-info{display:flex;flex-direction:column;gap:4px}.mcq-attempt-header-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0}.mcq-attempt-header-sub{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500}.mcq-attempt-header-actions{align-items:center;display:flex;gap:12px}.mcq-attempt-timer-badge{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #7d9dab;border-radius:8px;color:#000;font-family:SF Mono,Monaco,Menlo,monospace;font-size:18px;font-weight:700;letter-spacing:.5px;min-width:90px;padding:8px 16px;text-align:center}.mcq-attempt-timer-badge.warning{animation:pulse 1.5s infinite;background:#ef4444;background:var(--error)}.mcq-attempt-btn-exit{background:#0000;border:1px solid #ef4444;border:1px solid var(--error);border-radius:8px;color:#ef4444;color:var(--error);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.mcq-attempt-btn-exit:hover{background:#fee2e2;background:var(--error-bg);transform:translateY(-1px)}.mcq-attempt-test-container{display:flex;flex:1 1;overflow:hidden}.mcq-attempt-palette-sidebar{background:#fff;background:var(--bg-page);border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;width:280px}.mcq-attempt-palette-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:20px}.mcq-attempt-palette-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(5,1fr);padding:20px}.mcq-attempt-q-node{align-items:center;background:#fff;background:var(--bg-page);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;height:38px;justify-content:center;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:38px}.mcq-attempt-q-node:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#1976d2;color:var(--primary-blue);transform:translateY(-2px)}.mcq-attempt-q-node.current{background:#1976d20d;border:2px solid #1976d2;border:2px solid var(--primary-blue);color:#1976d2;color:var(--primary-blue);font-weight:700}.mcq-attempt-q-node.answered{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.mcq-attempt-q-node.review{background:#fef3c7;background:var(--warning-bg);border-color:#f59e0b;border-color:var(--warning);color:#92400e}.mcq-attempt-q-node.review-answered{background:#f59e0b;background:var(--warning);border-color:#f59e0b;border-color:var(--warning);color:#fff;position:relative}.mcq-attempt-q-node.review-answered:after{bottom:2px;color:#fff;content:"✓";font-size:10px;font-weight:700;position:absolute;right:3px}.mcq-attempt-palette-legend{grid-gap:10px;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#6b7280;color:var(--text-medium);display:grid;font-family:Elms Sans,sans-serif;font-size:12px;gap:10px;grid-template-columns:1fr 1fr;margin-top:auto;padding:20px}.mcq-attempt-legend-item{align-items:center;display:flex;gap:8px}.mcq-attempt-legend-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.mcq-attempt-legend-dot-answered{background:#1976d2;background:var(--primary-blue)}.mcq-attempt-legend-dot-review{background:#f59e0b;background:var(--warning)}.mcq-attempt-legend-dot-unseen{background:#fff;background:var(--bg-page);border:1px solid #e5e7eb;border:1px solid var(--border-color)}.mcq-attempt-legend-dot-current{background:#1976d21a;border:2px solid #1976d2;border:2px solid var(--primary-blue)}.mcq-attempt-question-area{flex:1 1;margin:0 auto;max-width:900px;overflow-y:auto;padding:40px;width:100%}.mcq-attempt-q-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:40px}.mcq-attempt-q-meta{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:28px;padding-bottom:20px}.mcq-attempt-q-number{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;letter-spacing:-.3px}.mcq-attempt-review-toggle{align-items:center;border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:8px;padding:6px 12px;transition:all .2s ease}.mcq-attempt-review-toggle:hover{background:#f9fafb;background:var(--bg-secondary)}.mcq-attempt-review-toggle.active{background:#fef3c7;background:var(--warning-bg);color:#92400e;font-weight:600}.mcq-attempt-review-checkbox{accent-color:#f59e0b;accent-color:var(--warning);cursor:pointer;height:16px;width:16px}.mcq-attempt-q-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:400;line-height:1.7;margin-bottom:32px}.mcq-attempt-options-list{display:flex;flex-direction:column;gap:12px}.mcq-attempt-option-label{align-items:flex-start;background:#fff;background:var(--bg-page);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;gap:14px;padding:16px 18px;transition:all .2s ease}.mcq-attempt-option-label:hover{background:#1976d205;border-color:#1976d2;border-color:var(--primary-blue);transform:translateX(4px)}.mcq-attempt-option-label.selected{background:#1976d20f;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 1px #1976d2;box-shadow:0 0 0 1px var(--primary-blue)}.mcq-attempt-option-radio{accent-color:#1976d2;accent-color:var(--primary-blue);cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.mcq-attempt-option-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;line-height:1.5}.mcq-attempt-controls-footer{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;margin-top:36px;padding-top:24px}.mcq-attempt-btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.mcq-attempt-btn-prev{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.mcq-attempt-btn-prev:hover:not(.disabled){background:#f9fafb;background:var(--bg-secondary);border-color:#6b7280;border-color:var(--text-medium)}.mcq-attempt-btn-next{background:#1976d2;background:var(--primary-blue);color:#fff}.mcq-attempt-btn-next:hover{background:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}.mcq-attempt-btn-submit{background:#10b981;background:var(--success);color:#fff}.mcq-attempt-btn-submit:hover{background:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.mcq-attempt-btn.disabled{cursor:not-allowed;opacity:.4}.mcq-attempt-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:100}.mcq-attempt-modal-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:36px;text-align:center;width:440px}.mcq-attempt-modal-icon{color:#1976d2;color:var(--primary-blue);font-size:48px;margin-bottom:16px}.mcq-attempt-modal-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.5px;margin-bottom:12px}.mcq-attempt-modal-stats{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;margin:20px 0;padding:20px;text-align:left}.mcq-attempt-modal-stat-row{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;justify-content:space-between;margin-bottom:12px}.mcq-attempt-modal-stat-row:last-child{margin-bottom:0}.mcq-attempt-modal-stat-row strong{color:#1f2937;color:var(--text-dark);font-weight:700}.mcq-attempt-modal-stat-review{color:#f59e0b!important;color:var(--warning)!important;font-weight:700}.mcq-attempt-modal-warning-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;line-height:1.5;margin-bottom:28px}.mcq-attempt-modal-actions{display:flex;gap:12px;justify-content:center}@media (max-width:1024px){.mcq-attempt-test-header{padding:14px 24px}.mcq-attempt-palette-sidebar{width:240px}.mcq-attempt-palette-grid{grid-template-columns:repeat(4,1fr)}.mcq-attempt-question-area{padding:32px 24px}.mcq-attempt-q-card{padding:32px 28px}}@media (max-width:768px){.mcq-attempt-test-header{flex-wrap:wrap;gap:12px;padding:12px 20px}.mcq-attempt-header-title{font-size:16px}.mcq-attempt-header-sub{font-size:12px}.mcq-attempt-timer-badge{font-size:16px;min-width:80px;padding:6px 12px}.mcq-attempt-palette-sidebar{width:200px}.mcq-attempt-palette-grid{gap:8px;grid-template-columns:repeat(4,1fr)}.mcq-attempt-q-node{font-size:12px;height:34px;width:34px}.mcq-attempt-question-area{padding:24px 20px}.mcq-attempt-q-card{padding:28px 24px}.mcq-attempt-modal-card{max-width:400px;padding:28px;width:90%}}@media (max-width:640px){.mcq-attempt-test-container{flex-direction:column}.mcq-attempt-palette-sidebar{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);border-right:none;max-height:200px;width:100%}.mcq-attempt-palette-grid{grid-template-columns:repeat(8,1fr)}.mcq-attempt-q-card{padding:24px 20px}.mcq-attempt-q-text{font-size:15px}.mcq-attempt-option-text{font-size:14px}.mcq-attempt-controls-footer{flex-direction:column;gap:12px}.mcq-attempt-btn{width:100%}}.mcq-results-container{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.mcq-results-navbar{background:#fff;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.mcq-results-navbar-inner{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:16px 40px}.mcq-results-logo{color:#1f2937;color:var(--text-dark);font-size:26px;font-weight:800;letter-spacing:-.5px;text-decoration:none}.mcq-results-logo-osce{color:#1976d2;color:var(--primary-blue)}.mcq-results-logo-pal{color:#7c3aed;color:var(--primary-purple)}.mcq-results-profile-btn{align-items:center;background:none;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:6px 12px;transition:all .2s ease}.mcq-results-profile-btn:hover{background:#f9fafb;border-color:#e5e7eb;border-color:var(--border-color)}.mcq-results-profile-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.mcq-results-main{margin:-25px auto 0;max-width:1200px;padding:60px 40px 80px}.mcq-results-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;margin-bottom:32px}.mcq-results-header-actions{display:flex;gap:12px}.mcq-results-breadcrumb{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:8px;margin-bottom:12px}.mcq-results-breadcrumb a{color:#6b7280;color:var(--text-medium);font-weight:500;text-decoration:none;transition:color .2s}.mcq-results-breadcrumb a:hover{color:#1976d2;color:var(--primary-blue)}.mcq-results-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:700;letter-spacing:-.5px}.mcq-results-btn{align-items:center;border:none;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;text-decoration:none;transition:all .2s ease}.mcq-results-btn-primary{background:#1976d2;background:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.mcq-results-btn-primary:hover{background:#1565c0;box-shadow:0 4px 8px #1976d24d;transform:translateY(-1px)}.mcq-results-btn-secondary{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.mcq-results-btn-secondary:hover{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.mcq-results-btn-sm{font-size:13px;padding:8px 16px}.mcq-results-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1.5fr 1fr;margin-bottom:32px}.mcq-results-card{background:#fff;border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:28px;transition:all .2s ease}.mcq-results-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.mcq-results-score-panel{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;gap:24px;justify-content:space-between;margin-bottom:24px;padding-bottom:24px}.mcq-results-score-circle{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:130px;justify-content:center;position:relative;width:130px}.mcq-results-score-circle:before{background:#fff;border-radius:50%;box-shadow:0 0 0 2px #e5e7eb;box-shadow:0 0 0 2px var(--border-color);content:"";height:106px;position:absolute;width:106px}.mcq-results-score-text{position:relative;text-align:center;z-index:1}.mcq-results-score-val{color:#1f2937;color:var(--text-dark);display:block;font-family:Elms Sans,sans-serif;font-size:36px;font-weight:800;line-height:1}.mcq-results-score-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;margin-top:4px;text-transform:uppercase}.mcq-results-score-details{flex:1 1}.mcq-results-grade-badge{background:#10b9811a;border:1px solid #a7f3d0;border-radius:8px;color:#065f46;display:inline-block;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:700;margin-bottom:12px;padding:6px 14px}.mcq-results-percentile-info{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:8px}.mcq-results-percentile-info strong{color:#1f2937;color:var(--text-dark);font-weight:600}.mcq-results-time-info{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:6px}.mcq-results-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.mcq-results-stat-box{background:#1976d208;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;padding:20px 16px;text-align:center;transition:all .2s ease}.mcq-results-stat-box:hover{background:#1976d20d}.mcq-results-stat-num{display:block;font-family:Elms Sans,sans-serif;font-size:28px;font-weight:700;line-height:1;margin-bottom:6px}.mcq-results-stat-name{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.mcq-results-text-success{color:#10b981;color:var(--success)}.mcq-results-text-error{color:#ef4444;color:var(--error)}.mcq-results-text-gray{color:#6b7280;color:var(--text-medium)}.mcq-results-breakdown-list{display:flex;flex-direction:column;gap:20px}.mcq-results-topic-item{display:flex;flex-direction:column;gap:8px}.mcq-results-topic-header{color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;justify-content:space-between}.mcq-results-progress-bg{background:#1976d20d;border-radius:5px;height:10px;overflow:hidden}.mcq-results-progress-fill{border-radius:5px;height:100%;transition:width 1s ease-out}.mcq-results-progress-high{background:#10b981;background:var(--success)}.mcq-results-progress-med{background:#f59e0b;background:var(--warning)}.mcq-results-progress-low{background:#ef4444;background:var(--error)}.mcq-results-analysis-section{margin-bottom:24px}.mcq-results-analysis-section:last-child{margin-bottom:0}.mcq-results-section-header{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.mcq-results-tag-cloud{display:flex;flex-wrap:wrap;gap:10px}.mcq-results-tag{border-radius:8px;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;padding:6px 12px}.mcq-results-tag-strong{background:#10b9811a;border:1px solid #a7f3d0;color:#065f46}.mcq-results-tag-weak{background:#ef44441a;border:1px solid #fecaca;color:#991b1b}.mcq-results-ai-recommendation{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #1976d233;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:32px;padding:24px}.mcq-results-ai-title{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600;gap:8px;margin-bottom:10px}.mcq-results-ai-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:16px}.mcq-results-ai-actions{display:flex;flex-wrap:wrap;gap:12px}.mcq-results-review-section{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.mcq-results-review-header{align-items:center;background:#1976d208;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:24px 28px}.mcq-results-review-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px}.mcq-results-filter-buttons{display:flex;gap:8px}.mcq-results-filter-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.mcq-results-filter-btn:hover{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.mcq-results-filter-btn.mcq-results-filter-active{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.mcq-results-questions-container{max-height:none}.mcq-results-question-item{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:28px;transition:background .2s ease}.mcq-results-question-item:hover{background:#1976d203}.mcq-results-question-item:last-child{border-bottom:none}.mcq-results-q-status-row{align-items:center;display:flex;gap:12px;margin-bottom:14px}.mcq-results-q-id{color:#6b7280;color:var(--text-medium);font-size:14px}.mcq-results-q-id,.mcq-results-status-badge{font-family:Elms Sans,sans-serif;font-weight:700}.mcq-results-status-badge{border-radius:8px;font-size:11px;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.mcq-results-status-correct{background:#10b9811a;border:1px solid #a7f3d0;color:#10b981;color:var(--success)}.mcq-results-status-incorrect{background:#ef44441a;border:1px solid #fecaca;color:#ef4444;color:var(--error)}.mcq-results-status-skipped{background:#6b72801a;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.mcq-results-q-stem{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:500;line-height:1.6;margin-bottom:18px}.mcq-results-answer-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:18px}.mcq-results-ans-box{border:1px solid;border-radius:8px;font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.5;padding:14px 16px}.mcq-results-ans-box strong{display:block;font-weight:600;margin-bottom:6px}.mcq-results-ans-user{background:#ef44440d;border-color:#ef44444d;color:#991b1b}.mcq-results-ans-correct{background:#10b9810d;border-color:#10b9814d;color:#065f46}.mcq-results-ans-skipped{background:#6b728008;border-color:#e5e7eb;border-color:var(--border-color);border-style:dashed;color:#6b7280;color:var(--text-medium)}.mcq-results-explanation-box{background:#1976d20d;border-left:4px solid #1976d2;border-left:4px solid var(--primary-blue);border-radius:8px;padding:18px}.mcq-results-exp-title{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.mcq-results-exp-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6}@media (max-width:1024px){.mcq-results-main{padding:48px 24px 60px}.mcq-results-grid{grid-template-columns:1fr}}@media (max-width:768px){.mcq-results-main{padding:40px 20px 60px}.mcq-results-navbar-inner{padding:12px 20px}.mcq-results-logo{font-size:22px}.mcq-results-page-title{font-size:24px}.mcq-results-header{align-items:flex-start;flex-direction:column}.mcq-results-header-actions{flex-direction:column;width:100%}.mcq-results-btn{justify-content:center;width:100%}.mcq-results-answer-grid{grid-template-columns:1fr}.mcq-results-score-panel{flex-direction:column;gap:20px;text-align:center}.mcq-results-stats-row{grid-template-columns:1fr}.mcq-results-card{padding:24px}.mcq-results-question-item{padding:24px 20px}.mcq-results-ai-actions{flex-direction:column}.mcq-results-ai-actions .mcq-results-btn{width:100%}.mcq-results-review-header{align-items:flex-start;flex-direction:column}.mcq-results-filter-buttons{justify-content:flex-start;width:100%}}@media (max-width:480px){.mcq-results-score-circle{height:110px;width:110px}.mcq-results-score-circle:before{height:90px;width:90px}.mcq-results-score-val{font-size:28px}}@media print{.mcq-results-btn,.mcq-results-filter-buttons,.mcq-results-navbar{display:none}.mcq-results-main{padding:20px}.mcq-results-card,.mcq-results-question-item{break-inside:avoid;page-break-inside:avoid}}.mcq-history-container{background:#f9fafb;background:var(--gray-50);color:#111827;color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);min-height:100vh}.mcq-history-navbar{background:#fff;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.mcq-history-navbar-inner{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:16px 24px;padding:var(--space-4) var(--space-6)}.mcq-history-logo{color:#111827;color:var(--gray-900);font-size:24px;font-weight:700;text-decoration:none}.mcq-history-logo-osce{color:#2563eb;color:var(--primary)}.mcq-history-logo-pal{color:#7c3aed;color:var(--secondary)}.mcq-history-profile-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:8px;gap:var(--space-2)}.mcq-history-profile-avatar{align-items:center;background:linear-gradient(135deg,#2563eb,#7c3aed);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.mcq-history-main{margin:0 auto;max-width:1280px;padding:24px;padding:var(--space-6)}.mcq-history-header{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:24px;margin-bottom:var(--space-6)}.mcq-history-header-actions{display:flex;gap:12px}.mcq-history-breadcrumb{align-items:center;color:#6b7280;color:var(--gray-500);display:flex;font-size:14px;gap:8px;margin-bottom:8px}.mcq-history-breadcrumb a{color:#6b7280;color:var(--gray-500);text-decoration:none;transition:color .2s}.mcq-history-breadcrumb a:hover{color:#2563eb;color:var(--primary)}.mcq-history-page-title{color:#111827;color:var(--gray-900);font-size:28px;font-weight:700}.mcq-history-btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.mcq-history-btn-primary{background:#2563eb;background:var(--primary);color:#fff}.mcq-history-btn-primary:hover{background:#1d4ed8;background:var(--primary-hover)}.mcq-history-btn-secondary{background:#fff;border-color:#d1d5db;border-color:var(--gray-300);color:#374151;color:var(--gray-700)}.mcq-history-btn-secondary:hover{background:#f9fafb;background:var(--gray-50);border-color:#9ca3af;border-color:var(--gray-400)}.mcq-history-btn-icon-danger{background:#0000;border:none;border-radius:8px;border-radius:var(--radius-md);color:#9ca3af;color:var(--gray-400);cursor:pointer;padding:6px;transition:all .2s}.mcq-history-btn-icon-danger:hover{background:#fee2e2;background:var(--error-bg);color:#ef4444;color:var(--error)}.mcq-history-btn-sm{font-size:12px;padding:6px 12px}.mcq-history-analytics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:3fr 2fr;margin-bottom:32px}.mcq-history-stat-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;padding:24px}.mcq-history-stat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.mcq-history-stat-label{color:#6b7280;color:var(--gray-500);font-size:13px;font-weight:600;text-transform:uppercase}.mcq-history-improvement-text{color:#10b981;color:var(--success);font-size:12px;font-weight:600}.mcq-history-chart-container{height:120px;position:relative;width:100%}.mcq-history-chart-svg{height:100%;width:100%}.mcq-history-chart-line{fill:none;stroke:#f59e0b;stroke:var(--warning);stroke-width:3;vector-effect:non-scaling-stroke}.mcq-history-chart-area{fill:#fef3c7;fill:var(--warning-bg);opacity:.5}.mcq-history-chart-dot{fill:#fff;stroke:#f59e0b;stroke:var(--warning);stroke-width:2}.mcq-history-subject-row{align-items:center;display:flex;gap:12px;margin-bottom:12px}.mcq-history-subj-name{color:#374151;color:var(--gray-700);font-size:13px;font-weight:500;width:100px}.mcq-history-progress-track{background:#f3f4f6;background:var(--gray-100);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.mcq-history-progress-bar{border-radius:4px;height:100%}.mcq-history-subj-score{color:#111827;color:var(--gray-900);font-size:13px;font-weight:600;text-align:right;width:40px}.mcq-history-bar-green{background:#10b981;background:var(--success)}.mcq-history-bar-orange{background:#f59e0b;background:var(--warning)}.mcq-history-bar-red{background:#ef4444;background:var(--error)}.mcq-history-toolbar{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:16px}.mcq-history-search-wrapper{flex:2 1;min-width:250px;position:relative}.mcq-history-search-icon{color:#9ca3af;color:var(--gray-400);left:12px;position:absolute;top:50%;transform:translateY(-50%)}.mcq-history-form-input,.mcq-history-form-select{background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);font-size:14px;padding:10px 12px;width:100%}.mcq-history-search-wrapper .mcq-history-form-input{padding-left:36px}.mcq-history-form-input:focus,.mcq-history-form-select:focus{border-color:#2563eb;border-color:var(--primary);outline:none}.mcq-history-filter-group{display:flex;flex:3 1;gap:12px}.mcq-history-sort-select{width:auto}.mcq-history-table-container{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.mcq-history-data-table{border-collapse:collapse;font-size:14px;text-align:left;width:100%}.mcq-history-data-table th{background:#f9fafb;background:var(--gray-50);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#6b7280;color:var(--gray-500);font-weight:600;padding:16px 24px}.mcq-history-data-table th.mcq-history-th-actions{text-align:right}.mcq-history-data-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#374151;color:var(--gray-700);padding:16px 24px;vertical-align:middle}.mcq-history-data-table td.mcq-history-td-actions{text-align:right}.mcq-history-data-table tbody tr:hover{background-color:#f9fafb;background-color:var(--gray-50)}.mcq-history-time-text{color:#6b7280;color:var(--gray-500);font-size:11px}.mcq-history-score-pill{align-items:center;border-radius:20px;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:4px 10px}.mcq-history-pill-high{background:#d1fae5;background:var(--success-bg);border:1px solid #a7f3d0;color:#065f46}.mcq-history-pill-med{background:#fef3c7;background:var(--warning-bg);border:1px solid #fde68a;color:#92400e}.mcq-history-pill-low{background:#fee2e2;background:var(--error-bg);border:1px solid #fecaca;color:#991b1b}.mcq-history-subject-tag{color:#6b7280;color:var(--gray-500);display:block;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.mcq-history-topic-title{color:#111827;color:var(--gray-900);font-weight:600}.mcq-history-pagination{align-items:center;background:#fff;display:flex;justify-content:space-between;padding:16px 24px}.mcq-history-page-info{color:#6b7280;color:var(--gray-500);font-size:13px}.mcq-history-page-controls{display:flex;gap:8px}.mcq-history-page-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:4px;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;width:32px}.mcq-history-page-btn.mcq-history-page-active{background:#2563eb;background:var(--primary);border-color:#2563eb;border-color:var(--primary);color:#fff}.mcq-history-page-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:900px){.mcq-history-analytics-grid{grid-template-columns:1fr}.mcq-history-toolbar{align-items:stretch}.mcq-history-filter-group,.mcq-history-toolbar{flex-direction:column}}:root{--primary-blue-dark:#1565c0;--primary-blue-light:#bbdefb;--border-medium:#cbd5e1;--shadow-xs:0 1px 2px 0 #00000008;--shadow-sm:0 1px 3px 0 #00000014,0 1px 2px 0 #00000005;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -2px #00000008;--shadow-xl:0 20px 25px -5px #00000014,0 10px 10px -5px #00000005;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1)}*,:after,:before{margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dashboard-wrapper{background:#f4f6f8;background:var(--bg-page);color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;min-height:100vh;position:relative;width:100%}.dashboard-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:80vh}.loading-spinner{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-top:4px solid #1976d2;border:4px solid var(--border-light);border-radius:50%;border-top-color:var(--primary-blue);height:48px;width:48px}.loading-text{color:#6b7280;color:var(--text-grey);font-size:1rem;font-weight:500}.dashboard-error{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:80vh}.error-icon{color:#ef4444;opacity:.9}.error-text{color:#dc2626;font-size:1.125rem;font-weight:600}.error-button{background:#fff;border:2px solid #ef4444;border-radius:12px;border-radius:var(--radius-md);color:#ef4444;cursor:pointer;font-size:.9375rem;font-weight:600;margin-top:8px;padding:10px 20px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.error-button:hover{background:#ef4444;color:#fff;transform:translateY(-1px)}.dashboard-credit-warning{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fbbf24;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -2px #00000008;box-shadow:var(--shadow-lg);color:#92400e;display:flex;font-size:.875rem;font-weight:500;gap:12px;left:50%;padding:12px 20px;position:fixed;top:90px;transform:translateX(-50%);z-index:50}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}.warning-icon{align-items:center;color:#f59e0b;display:flex}.warning-text strong{color:#78350f;font-weight:700}.warning-buy-btn{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 2px 4px #d9770633;color:#fff;cursor:pointer;font-size:.8125rem;font-weight:700;padding:6px 14px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.warning-buy-btn:hover{box-shadow:0 4px 8px #d977064d;transform:translateY(-1px)}.warning-close-btn{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#92400e;cursor:pointer;display:flex;padding:4px;transition:background .15s cubic-bezier(.4,0,.2,1);transition:background var(--transition-fast)}.dashboard-wrapper .dashboard-main{margin:0 auto;max-width:1200px;padding:48px 32px 100px}.section-heading{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:1.25rem;font-weight:700;margin-bottom:20px}.dashboard-hero{animation:fadeIn .5s ease-out;margin-bottom:48px}.hero-greeting{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin:0 0 8px}.hero-subtitle{color:#6b7280;color:var(--text-grey);font-size:1.1rem;font-weight:400}.dashboard-credits-section{margin-bottom:56px}.credits-card{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:20px;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #00000014,0 2px 4px -1px #0000000a;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;overflow:hidden;padding:40px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-slow)}.credits-card:before{background:radial-gradient(circle,#1976d214 0,#0000 70%);border-radius:50%;content:"";height:300px;pointer-events:none;position:absolute;right:-10%;top:-50%;width:300px}.credits-card:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -2px #00000008;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.credits-info{position:relative;z-index:1}.credits-info h2{color:#6b7280;color:var(--text-grey);font-size:.8125rem;font-weight:700;letter-spacing:.1em;margin:0 0 12px;text-transform:uppercase}.credits-amount{color:#1976d2;color:var(--primary-blue);font-size:3.5rem;font-weight:700;line-height:1;margin-bottom:12px}.credits-breakdown{color:#6b7280;color:var(--text-grey);display:flex;font-size:.95rem;gap:8px}.credits-breakdown strong{color:#111827;color:var(--text-dark);font-weight:600}.credits-divider{color:#cbd5e1;color:var(--border-medium);font-weight:300}.institutional-badge{background:#eff6ff;border-radius:99px;display:inline-flex;font-size:.85rem;gap:6px;margin-top:12px;padding:6px 12px}.credits-buy-btn,.institutional-badge{align-items:center;color:#1976d2;color:var(--primary-blue);font-weight:500}.credits-buy-btn{background:#1976d214;border:1px solid #1976d233;border-radius:12px;border-radius:var(--radius-md);box-shadow:none;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:.9rem;gap:8px;padding:10px 20px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);z-index:1}.credits-buy-btn:hover{background:#1976d21f;border-color:#1976d24d;box-shadow:0 2px 8px #1976d226;transform:translateY(-1px)}.credits-buy-btn:active{box-shadow:none;transform:translateY(0)}.dashboard-modules-section{margin-bottom:56px}.modules-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.module-card{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #00000014,0 1px 2px 0 #00000005;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-slow)}.module-card:before{background:#1976d2;background:var(--module-color,var(--primary-blue));content:"";height:3px;left:0;opacity:0;position:absolute;top:0;transition:opacity .2s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition-base);width:100%}.module-card:after{background:radial-gradient(circle,var(--module-color),#0000);content:"";height:200px;opacity:0;pointer-events:none;position:absolute;right:-50%;top:-50%;transition:opacity .3s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition-slow);width:200px}.module-card:hover{border-color:#cbd5e1;border-color:var(--border-medium);box-shadow:0 20px 25px -5px #00000014,0 10px 10px -5px #00000005;box-shadow:var(--shadow-xl);transform:translateY(-6px)}.module-card:hover:before{opacity:1}.module-card:hover:after{opacity:.03}.module-icon-wrapper{align-items:center;background:#00000008;border-radius:12px;color:var(--module-color);display:flex;font-size:2rem;height:56px;justify-content:center;margin-bottom:16px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:56px}.credits-expire{display:flex;flex-direction:column;gap:5px}.module-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:1.125rem;font-weight:700;margin:0 0 8px}.module-description{color:#6b7280;color:var(--text-grey);flex-grow:1;font-size:.875rem;line-height:1.5;margin:0 0 20px}.module-stats{border-top:1px solid #f3f4f6;display:flex;flex-direction:row;gap:24px;margin-top:auto;padding-top:16px}.module-stat{gap:8px;line-height:1}.module-stat,.stat-icon{align-items:center;display:flex}.stat-icon{color:#9ca3af;color:var(--text-light);flex-shrink:0;height:16px;justify-content:center;margin-bottom:1px;width:16px}.stat-icon svg{display:block;height:16px!important;width:16px!important}.stat-label{color:#6b7280;color:var(--text-grey);font-size:.8rem;font-weight:600;letter-spacing:.02em;line-height:1;padding-top:1px;text-transform:uppercase;white-space:nowrap}.dashboard-performance-section{margin-bottom:56px}.performance-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.performance-stat{align-items:flex-start;background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #00000014,0 1px 2px 0 #00000005;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.performance-stat:hover{border-color:#cbd5e1;border-color:var(--border-medium);box-shadow:0 4px 6px -1px #00000014,0 2px 4px -1px #0000000a;box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-icon-bg{align-items:center;border-radius:12px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:52px;justify-content:center;transition:transform .2s cubic-bezier(.4,0,.2,1);transition:transform var(--transition-base);width:52px}.performance-stat:hover .stat-icon-bg{transform:scale(1.05)}.stat-icon-bg.blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.stat-icon-bg.green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.stat-icon-bg.purple{background:linear-gradient(135deg,#e9d5ff,#d8b4fe);color:#7c3aed}.stat-icon-bg.orange{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#ea580c}.stat-content{display:flex;flex-direction:column;gap:4px}.stat-value{color:#111827;color:var(--text-dark);font-size:1.75rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}.performance-stat .stat-label{color:#6b7280;color:var(--text-grey);font-size:.875rem;font-weight:600}.dashboard-activity-section{margin-bottom:56px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.section-header .section-heading{font-family:Elms Sans,sans-serif;margin-bottom:0}.activity-footer{background:linear-gradient(180deg,#fff0,#f8fafc80);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-light);display:flex;justify-content:center;padding:16px 28px}.view-all-btn{align-items:center;background:#1976d214;border:1px solid #1976d233;border-radius:12px;border-radius:var(--radius-md);color:#1976d2;color:var(--primary-blue);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:6px;padding:10px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.view-all-btn:hover{background:#1976d21f;border-color:#1976d24d;box-shadow:0 2px 8px #1976d226;transform:translateY(-1px)}.activity-card{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:20px;border-radius:var(--radius-xl);box-shadow:0 1px 3px 0 #00000014,0 1px 2px 0 #00000005;box-shadow:var(--shadow-sm);overflow:hidden}.activity-list{display:flex;flex-direction:column}.activity-item{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;padding:20px 28px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.activity-item:before{background:#1976d2;background:var(--primary-blue);bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .2s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition-base);width:3px}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:linear-gradient(90deg,#1976d205,#0000)}.activity-item:hover:before{opacity:1}.activity-icon-box{align-items:center;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;border-radius:var(--radius-md);display:flex;flex-shrink:0;font-size:1.25rem;height:44px;justify-content:center;margin-right:16px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:44px}.activity-item:hover .activity-icon-box{box-shadow:0 1px 3px 0 #00000014,0 1px 2px 0 #00000005;box-shadow:var(--shadow-sm);transform:scale(1.08)}.activity-content{flex:1 1;min-width:0}.activity-title{color:#111827;color:var(--text-dark);font-size:1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}.activity-meta{color:#6b7280;color:var(--text-grey);font-size:.8125rem;font-weight:500}.activity-right{align-items:center;display:flex;flex-shrink:0;gap:16px}.activity-score{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:8px;border-radius:var(--radius-sm);color:#111827;color:var(--text-dark);font-size:1.0625rem;font-weight:700;min-width:60px;padding:6px 12px;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.activity-item:hover .activity-score{background:linear-gradient(135deg,#bbdefb,#90caf9);background:linear-gradient(135deg,var(--primary-blue-light) 0,#90caf9 100%);color:#1565c0;color:var(--primary-blue-dark)}.activity-arrow{color:#9ca3af;color:var(--text-light);transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.activity-item:hover .activity-arrow{color:#1976d2;color:var(--primary-blue);transform:translateX(4px)}.activity-empty{color:#6b7280;color:var(--text-grey);padding:64px 32px;text-align:center}.empty-icon{color:#9ca3af;color:var(--text-light);margin-bottom:16px;opacity:.5}.empty-text{color:#6b7280;color:var(--text-grey);font-size:1.125rem;font-weight:600;margin-bottom:8px}.empty-subtext{color:#9ca3af;color:var(--text-light);font-size:.9375rem}@media (max-width:1024px){.performance-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard-wrapper .dashboard-main{padding:24px 16px}.credits-card{align-items:flex-start;flex-direction:column;gap:28px;padding:32px 28px}.credits-amount{font-size:3rem}.credits-buy-btn{justify-content:center;width:100%}.activity-item{padding:18px 20px}.activity-title{font-size:.9375rem}.activity-right{gap:12px}.modules-grid{grid-template-columns:1fr}}@media (max-width:480px){.dashboard-main{padding:24px 16px 80px}.performance-grid{grid-template-columns:1fr}.credits-amount{font-size:2.5rem}.hero-greeting{font-size:1.75rem}.hero-subtitle{font-size:1rem}.credits-card{padding:24px 20px}.dashboard-credit-warning{font-size:.8125rem;left:16px;padding:10px 16px;right:16px;transform:none}}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#dbeafe;--secondary:#7c3aed;--secondary-hover:#6d28d9;--secondary-light:#ede9fe;--gray-50:#f9fafb;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI","Roboto",sans-serif;--space-3:12px;--shadow-md:0 4px 6px -1px #0000001a}*{box-sizing:border-box;margin:0;padding:0}.performance-report-container{background:#f9fafb;background:var(--gray-50);color:#111827;color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);min-height:100vh}.perf-navbar{background:#fff;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.perf-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:16px 24px;padding:var(--space-4) var(--space-6)}.perf-navbar-logo{color:#111827;color:var(--gray-900);font-size:24px;font-weight:700;text-decoration:none}.perf-logo-osce{color:#2563eb;color:var(--primary)}.perf-logo-pal{color:#7c3aed;color:var(--secondary)}.perf-profile-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:8px;gap:var(--space-2)}.perf-profile-avatar{align-items:center;background:linear-gradient(135deg,#2563eb,#7c3aed);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.perf-main-container{margin:0 auto;max-width:1000px;padding:24px;padding:var(--space-6)}.perf-report-controls{align-items:center;background:#fff;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:16px;gap:var(--space-4);justify-content:space-between;margin-bottom:24px;margin-bottom:var(--space-6);padding:16px;padding:var(--space-4)}.perf-date-filter{align-items:center;display:flex;gap:8px}.perf-select-input{background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:14px;padding:8px 12px}.perf-action-btns{display:flex;gap:12px}.perf-btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px;transition:all .2s}.perf-btn-primary{background:#2563eb;background:var(--primary);color:#fff}.perf-btn-primary:hover{background:#1d4ed8;background:var(--primary-hover)}.perf-btn-outline{background:#fff;border-color:#d1d5db;border-color:var(--gray-300);color:#374151;color:var(--gray-700)}.perf-btn-outline:hover{background:#f9fafb;background:var(--gray-50);border-color:#9ca3af;border-color:var(--gray-400)}.perf-report-paper{background:#fff;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:40px}.perf-report-header{align-items:flex-end;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--gray-200);display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.perf-report-title h1{color:#111827;color:var(--gray-900);font-size:28px;font-weight:800;margin-bottom:4px}.perf-report-meta{color:#6b7280;color:var(--gray-500);font-size:13px}.perf-student-info{text-align:right}.perf-student-name{color:#111827;color:var(--gray-900);font-size:16px;font-weight:700}.perf-student-id{color:#6b7280;color:var(--gray-500);font-size:13px}.perf-summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.perf-summary-box{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);padding:16px}.perf-summary-label{color:#6b7280;color:var(--gray-500);font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.perf-summary-val{color:#111827;color:var(--gray-900);font-size:24px;font-weight:700}.perf-swot-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:32px}.perf-swot-panel{border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);padding:20px}.perf-swot-header{align-items:center;display:flex;font-size:16px;font-weight:700;gap:8px;margin-bottom:16px}.perf-list-item{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.perf-list-item:last-child{border-bottom:none}.perf-score-pill{border-radius:12px;font-size:12px;font-weight:600;padding:2px 8px}.perf-pill-high{background:#d1fae5;background:var(--success-bg);color:#065f46}.perf-pill-low{background:#fee2e2;background:var(--error-bg);color:#991b1b}.perf-table-section{margin-bottom:32px}.perf-section-title{align-items:center;color:#111827;color:var(--gray-900);display:flex;font-size:18px;font-weight:700;gap:8px;margin-bottom:16px}.perf-data-table{border-collapse:collapse;font-size:14px;width:100%}.perf-data-table th{background:#f3f4f6;background:var(--gray-100);border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--gray-200);color:#4b5563;color:var(--gray-600);font-weight:600;padding:12px;text-align:left}.perf-data-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#374151;color:var(--gray-700);padding:12px}.perf-status-dot{border-radius:50%;display:inline-block;height:8px;margin-right:6px;width:8px}.perf-dot-green{background:#10b981;background:var(--success)}.perf-dot-yellow{background:#f59e0b;background:var(--warning)}.perf-dot-red{background:#ef4444;background:var(--error)}.perf-chart-placeholder{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);height:200px;margin-bottom:32px;position:relative;width:100%}.perf-chart-svg{height:100%;width:100%}.perf-chart-line{fill:none;stroke:#2563eb;stroke:var(--primary);stroke-width:2}.perf-chart-area{fill:#dbeafe;fill:var(--primary-light);opacity:.3}.perf-chart-dot{fill:#2563eb;fill:var(--primary)}.perf-action-plan{background:#eff6ff;border:1px solid #dbeafe;border:1px solid var(--primary-light);border-radius:8px;border-radius:var(--radius-md);padding:24px}.perf-action-list{list-style-type:none;padding:0}.perf-action-list li{color:#1f2937;color:var(--gray-800);font-size:14px;margin-bottom:8px;padding-left:24px;position:relative}.perf-action-list li:before{color:#2563eb;color:var(--primary);content:"→";font-weight:700;left:0;position:absolute}@media print{body{background:#fff;-webkit-print-color-adjust:exact}.perf-navbar,.perf-report-controls{display:none}.perf-main-container{margin:0;max-width:100%;padding:0}.perf-report-paper{border-radius:0;box-shadow:none;padding:0}.perf-swot-grid,.perf-table-section{page-break-inside:avoid}.perf-pill-high{background-color:#d1fae5!important}.perf-pill-low{background-color:#fee2e2!important}.perf-action-plan{background-color:#eff6ff!important}}@media (max-width:768px){.perf-summary-grid{grid-template-columns:1fr 1fr}.perf-swot-grid{grid-template-columns:1fr}.perf-report-controls{align-items:flex-start;flex-direction:column}.perf-action-btns{width:100%}.perf-btn{flex:1 1;justify-content:center}.perf-report-header{align-items:flex-start;flex-direction:column;gap:16px}.perf-student-info{text-align:left}}:root{--info:#3b82f6;--info-bg:#dbeafe}.pc-page{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;min-height:100vh;padding:0;position:relative;width:100%}.pc-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.pc-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:48px;padding:32px 40px;text-align:center}.pc-page-title{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;gap:12px;justify-content:center;letter-spacing:-1px;margin:0 0 8px}.pc-page-title strong{font-weight:700}.pc-title-icon{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.pc-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;line-height:1.6;margin:0 auto;max-width:600px}.pc-environment-badge{align-items:center;background:#fef3c7;background:var(--warning-bg);border-radius:20px;color:#f59e0b;color:var(--warning);display:inline-flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;margin-top:12px;padding:6px 12px}.pc-balance-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:48px;overflow:hidden;padding:32px 40px;position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.pc-balance-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.pc-balance-card:before{background:linear-gradient(90deg,#1976d2,#7c3aed);background:linear-gradient(90deg,var(--primary-blue),var(--primary-purple));content:"";height:4px;left:0;position:absolute;right:0;top:0}.pc-balance-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;letter-spacing:.3px;margin-bottom:8px}.pc-balance-amount{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:700;gap:8px;justify-content:center;margin-bottom:16px}.pc-balance-icon{flex-shrink:0}.pc-balance-credits-text{color:#1f2937;color:var(--text-dark);font-size:1.5rem;font-weight:400}.pc-balance-info{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-medium);display:inline-flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:8px;padding:12px 20px}.pc-packages-section{margin-bottom:60px}.pc-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:24px}.pc-packages-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.pc-package-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;padding:28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.pc-package-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.pc-package-card.popular{background:linear-gradient(180deg,#faf5ff 0,#fff 20%);background:linear-gradient(to bottom,#faf5ff 0,var(--bg-card) 20%);border-color:#7c3aed;border-color:var(--primary-purple)}.pc-package-card.selected{background:linear-gradient(180deg,#e8f4f8 0,#fff 20%);background:linear-gradient(to bottom,#e8f4f8 0,var(--bg-card) 20%);border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a}.pc-popular-badge{background:#7c3aed;background:var(--primary-purple);border-radius:20px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 12px;position:absolute;right:24px;top:-12px}.pc-package-header{margin-bottom:20px;position:relative;text-align:center}.pc-package-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;height:48px;justify-content:center;margin:0 auto 16px;width:48px}.pc-package-name{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}.pc-package-credits{color:#1976d2;color:var(--primary-blue);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:700;margin-bottom:4px}.pc-credits-label{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500}.pc-bonus-badge{background:#d1fae5;background:var(--success-bg);border-radius:6px;color:#10b981;color:var(--success);display:inline-block;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:600;margin:8px auto 0;padding:4px 8px;white-space:nowrap}.pc-package-price{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;margin:16px 0 20px;text-align:center}.pc-price-per-credit{color:#9ca3af;color:var(--text-light);display:block;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:400;margin-top:4px}.pc-package-features{flex-grow:1;list-style:none;margin-bottom:20px;padding:0}.pc-package-feature{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:8px;line-height:1.6;padding:8px 0}.pc-feature-icon{color:#10b981;color:var(--success);flex-shrink:0}.pc-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;padding:12px 20px;text-decoration:none;transition:all .2s ease;width:100%}.pc-btn-primary{background:#1976d2;background:var(--primary-blue);color:#fff}.pc-btn-primary:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.pc-btn-secondary{background:#7c3aed;background:var(--primary-purple);color:#fff}.pc-btn-secondary:hover{background:#6d28d9;box-shadow:0 6px 12px #7c3aed4d;transform:translateY(-1px)}.pc-btn-outline{background:#fff;border:2px solid #1976d2;border:2px solid var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.pc-btn-outline:hover{background:#1976d2;background:var(--primary-blue);color:#fff}.pc-btn-cancel{background:#e5e7eb;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#1f2937;color:var(--text-dark)}.pc-btn-cancel:hover{background:#d1d5db;transform:translateY(-1px)}.pc-btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.6;transform:none!important}.pc-payment-section{animation:slideIn .3s ease-out;background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:none;margin:0 auto 60px;max-width:800px;padding:32px 40px}.pc-payment-section.active{display:block}.pc-payment-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);margin-bottom:32px;padding-bottom:24px;text-align:center}.pc-payment-title{font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:16px}.pc-payment-title,.pc-selected-package-info{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif}.pc-selected-package-info{align-items:center;background:#1976d21a;border:1px solid #1976d233;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;padding:16px 20px}.pc-bonus-text{color:#10b981;color:var(--success);font-size:13px;margin-left:4px}.pc-selected-price{color:#1976d2;color:var(--primary-blue);font-size:24px;font-weight:700}.pc-coupon-section{background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;margin-bottom:24px;padding:20px 24px}.pc-coupon-toggle{align-items:center;background:none;border:none;color:#1976d2;color:var(--primary-blue);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:0;transition:all .2s ease}.pc-coupon-toggle:hover{color:#1565c0;transform:translateX(4px)}.pc-coupon-input-wrapper{display:none;gap:12px;margin-top:16px}.pc-coupon-input-wrapper.show{display:flex}.pc-coupon-input{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);flex:1 1;font-family:Elms Sans,sans-serif;font-size:14px;padding:12px 16px;transition:all .2s ease}.pc-coupon-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.pc-btn-apply-coupon{min-width:100px;padding:12px 20px;white-space:nowrap;width:auto}.pc-btn-remove-coupon{font-size:13px;padding:8px 16px;width:auto}.pc-coupon-applied{align-items:center;animation:fadeIn .3s ease;background:linear-gradient(135deg,#d1fae5,#d1fae5);background:linear-gradient(135deg,var(--success-bg) 0,#d1fae5 100%);border:2px solid #10b981;border:2px solid var(--success);border-radius:12px;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.pc-coupon-applied-info{align-items:center;display:flex;flex:1 1;gap:12px}.pc-coupon-applied-info svg{color:#10b981;color:var(--success);flex-shrink:0}.pc-coupon-applied-details{flex:1 1}.pc-coupon-code{color:#2e7d32;display:block;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;letter-spacing:.3px;margin-bottom:4px}.pc-coupon-description{color:#6b7280;color:var(--text-medium);margin-bottom:6px}.pc-coupon-description,.pc-coupon-discount{font-family:Elms Sans,sans-serif;font-size:14px}.pc-coupon-discount{background:#4caf501a;border-radius:6px;color:#10b981;color:var(--success);display:inline-block;font-weight:600;padding:4px 10px}.pc-coupon-message{animation:slideInLeft .3s ease;border:1px solid;border-radius:8px;display:none;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;margin-top:8px;padding:12px 16px}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.pc-coupon-message.success{background:#d1fae5;background:var(--success-bg);border-color:#10b981;border-color:var(--success);color:#10b981;color:var(--success);display:block}.pc-coupon-message.error{background:#fee2e2;background:var(--error-bg);border-color:#ef4444;border-color:var(--error);color:#ef4444;color:var(--error);display:block}.pc-coupon-message.info{background:#dbeafe;background:var(--info-bg);border-color:#3b82f6;border-color:var(--info);color:#3b82f6;color:var(--info);display:block}.pc-order-summary{background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;margin-bottom:24px;padding:28px}.pc-summary-title{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin-bottom:20px;padding-bottom:12px}.pc-summary-row{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;justify-content:space-between;padding:12px 0}.pc-summary-label{color:#6b7280;color:var(--text-medium);font-weight:500}.pc-summary-value{color:#1f2937;color:var(--text-dark);font-weight:600}.pc-summary-value.discount{color:#10b981;color:var(--success)}.pc-summary-divider{background:#e5e7eb;background:var(--border-color);height:1px;margin:16px 0}.pc-total-row{border-top:2px solid #e5e7eb;border-top:2px solid var(--border-color);margin-top:8px;padding-top:20px}.pc-summary-total{color:#1976d2;color:var(--primary-blue);font-size:24px;font-weight:700}.pc-summary-credits{color:#10b981;color:var(--success);font-size:18px;font-weight:700}.pc-coupon-savings{align-items:center;animation:slideIn .5s ease;background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:2px solid #f59e0b;border:2px solid var(--warning);border-radius:12px;display:flex;gap:12px;margin-top:24px;padding:16px 20px}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.pc-coupon-savings-icon{flex-shrink:0;font-size:24px}.pc-coupon-savings-text{flex:1 1;font-family:Elms Sans,sans-serif}.pc-coupon-savings-text strong{color:#e65100;display:block;font-size:16px;letter-spacing:.3px;margin-bottom:4px}.pc-coupon-savings-subtext{color:#6b7280;color:var(--text-medium);font-size:13px}.pc-terms-checkbox{align-items:flex-start;display:flex;gap:12px;margin-bottom:24px}.pc-terms-checkbox input[type=checkbox]{accent-color:#1976d2;accent-color:var(--primary-blue);cursor:pointer;flex-shrink:0;height:18px;margin-top:4px;width:18px}.pc-terms-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6}.pc-terms-link{color:#1976d2;color:var(--primary-blue);font-weight:600;text-decoration:none}.pc-terms-link:hover{text-decoration:underline}.pc-payment-actions{display:flex;gap:16px;margin-bottom:20px}.pc-btn-pay{flex:1 1;font-size:15px;padding:14px 20px}.pc-btn-pay svg{height:20px;width:20px}.pc-test-mode-notice{align-items:center;background:#fef3c7;background:var(--warning-bg);border:1px solid #f59e0b4d;border-radius:8px;color:#f59e0b;color:var(--warning);display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:8px;padding:12px 16px}.pc-test-mode-notice svg{flex-shrink:0}.pc-info-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:48px}.pc-info-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:28px;text-align:center;transition:all .3s ease}.pc-info-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.pc-info-card-icon{color:#1976d2;color:var(--primary-blue);margin-bottom:16px}.pc-info-card-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin-bottom:12px}.pc-info-card-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6}.pc-loading-overlay{align-items:center;background:#000000b3;bottom:0;display:none;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.pc-loading-overlay.show{display:flex}.pc-loading-content{background:#fff;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:40px;text-align:center}.pc-loading-spinner{animation:spin 1s linear infinite;border:4px solid #1976d24d;border-radius:50%;border-top:4px solid var(--primary-blue);height:60px;margin:0 auto 16px;width:60px}.pc-loading-text{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;margin-bottom:8px}.pc-loading-subtext{color:#6b7280;color:var(--text-medium)}.pc-alert,.pc-loading-subtext{font-family:Elms Sans,sans-serif;font-size:14px}.pc-alert{align-items:center;animation:slideInRight .3s ease-out;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:none;font-weight:500;gap:12px;letter-spacing:.3px;max-width:400px;padding:16px 20px;position:fixed;right:24px;top:100px;z-index:1000}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.pc-alert.show{display:flex}.pc-alert-success{background:#d1fae5;background:var(--success-bg);border:2px solid #10b981;border:2px solid var(--success);color:#10b981;color:var(--success)}.pc-alert-error{background:#fee2e2;background:var(--error-bg);border:2px solid #ef4444;border:2px solid var(--error);color:#ef4444;color:var(--error)}.pc-alert-info{background:#dbeafe;background:var(--info-bg);border:2px solid #3b82f6;border:2px solid var(--info);color:#3b82f6;color:var(--info)}.pc-alert-warning{background:#fef3c7;background:var(--warning-bg);border:2px solid #f59e0b;border:2px solid var(--warning);color:#f59e0b;color:var(--warning)}.pc-alert svg{flex-shrink:0}@media (max-width:1024px){.pc-main{padding:48px 24px 60px}.pc-packages-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.pc-info-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width:768px){.pc-main{padding:40px 20px 60px}.pc-header{margin-bottom:36px;padding:24px 20px}.pc-page-title{flex-direction:column;font-size:28px;gap:8px}.pc-page-subtitle{font-size:16px}.pc-balance-card{margin-bottom:36px;padding:24px 20px}.pc-balance-amount{flex-wrap:wrap;font-size:32px}.pc-packages-grid{grid-template-columns:1fr}.pc-payment-section{padding:24px 20px}.pc-selected-package-info{flex-direction:column;gap:12px;text-align:center}.pc-coupon-input-wrapper.show{flex-direction:column}.pc-btn-apply-coupon{width:100%}.pc-payment-actions{flex-direction:column}.pc-info-cards{grid-template-columns:1fr}.pc-info-card{padding:24px 20px}.pc-alert{left:16px;max-width:none;right:16px;top:80px}}@media (max-width:480px){.pc-main{padding:32px 16px 48px}.pc-header{padding:20px 16px}.pc-page-title{font-size:24px}.pc-page-subtitle{font-size:14px}.pc-balance-card{padding:20px 16px}.pc-balance-amount{font-size:28px}.pc-package-card{padding:24px 20px}.pc-payment-section{padding:20px 16px}.pc-order-summary{padding:20px}.pc-coupon-applied{gap:16px;text-align:center}.pc-coupon-applied,.pc-coupon-applied-info{flex-direction:column}.pc-btn-remove-coupon{width:100%}.pc-coupon-savings{flex-direction:column;gap:8px;text-align:center}}@media (hover:none) and (pointer:coarse){.pc-balance-card:hover,.pc-btn:hover,.pc-coupon-toggle:hover,.pc-info-card:hover,.pc-package-card:hover{transform:none}}.nc-page{background:#fff;background:var(--bg-page);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;position:relative;width:100%}.nc-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.nc-header{align-items:center;background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:24px;justify-content:space-between;margin-bottom:48px;padding:32px 40px}.nc-header-content{flex:1 1}.nc-page-title{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:700;gap:12px;letter-spacing:-1px;margin:0 0 8px}.nc-unread-badge{align-items:center;background:#1976d2;background:var(--primary-blue);border-radius:20px;color:#fff;display:inline-flex;font-size:14px;font-weight:600;justify-content:center;min-width:32px;padding:4px 12px}.nc-page-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;line-height:1.6;margin:0}.nc-header-actions{align-items:center;display:flex;gap:12px}.nc-btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease;white-space:nowrap}.nc-btn-secondary{background:#fff;border-color:#e5e7eb;border-color:var(--border-color);color:#1f2937;color:var(--text-dark)}.nc-btn-secondary:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.nc-btn-text{background:#0000;border:1px solid #0000;color:#1976d2;color:var(--primary-blue)}.nc-btn-text:hover{background:#1976d21a;border-color:#1976d233}.nc-tabs-container{background:#fff;border:1px solid #8ec5ef99;border-bottom:1px solid var(--border-color);border-radius:12px;border-bottom-left-radius:0;border-bottom-right-radius:0;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:0;padding:0 24px}.nc-tabs{display:flex;gap:24px}.nc-tab-btn{background:#0000;border:none;border-bottom:2px solid #0000;color:#9ca3af;color:var(--text-light);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;padding:16px 4px;transition:all .2s ease}.nc-tab-btn:hover{color:#1f2937;color:var(--text-dark)}.nc-tab-btn.active{border-bottom-color:#1976d2;border-bottom-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue);font-weight:600}.nc-notification-list{background:#fff;border:1px solid #8ec5ef99;border-radius:12px;border-top:none;border-top-left-radius:0;border-top-right-radius:0;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);min-height:400px;overflow:hidden}.nc-notification-item{border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;gap:16px;padding:24px 28px;position:relative;transition:all .2s ease}.nc-notification-item:last-child{border-bottom:none}.nc-notification-item:hover{background:#f9fafb}.nc-notification-item.unread{background:#f0f7ff}.nc-notification-item.unread:hover{background:#e0efff}.nc-unread-dot{background:#1976d2;background:var(--primary-blue);border-radius:50%;display:none;height:8px;left:12px;position:absolute;top:32px;width:8px}.nc-notification-item.unread .nc-unread-dot{display:block}.nc-notif-icon-wrapper{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.icon-system{background:#6b72801a;color:#6b7280;color:var(--text-medium)}.icon-credit{background:#fef3c7;background:var(--warning-bg);color:#b45309}.icon-success{background:#d1fae5;background:var(--success-bg);color:#10b981;color:var(--success)}.icon-module{background:#7c3aed1a;color:#7c3aed;color:var(--primary-purple)}.nc-notif-content{flex:1 1;min-width:0}.nc-notif-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:6px}.nc-notif-title{color:#1f2937;color:var(--text-dark);font-size:15px;font-weight:600;line-height:1.4}.nc-notif-time,.nc-notif-title{font-family:Elms Sans,sans-serif}.nc-notif-time{color:#9ca3af;color:var(--text-light);flex-shrink:0;font-size:13px;white-space:nowrap}.nc-notif-body{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:8px}.nc-notif-meta{display:flex;gap:12px;margin-top:8px}.nc-notif-link{color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;text-decoration:none;transition:opacity .2s ease}.nc-notif-link:hover{opacity:.8;text-decoration:underline}.nc-item-actions{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fffffff2;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:8px;opacity:0;padding:4px;position:absolute;right:24px;top:50%;transform:translateY(-50%);transition:opacity .2s ease}.nc-notification-item:hover .nc-item-actions{opacity:1}.nc-action-icon-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.nc-action-icon-btn:hover{background:#f9fafb;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.nc-btn-delete:hover{background:#fee2e2;background:var(--error-bg);border-color:#ef4444;border-color:var(--error);color:#ef4444;color:var(--error)}.nc-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 40px;text-align:center}.nc-empty-icon{color:#9ca3af;color:var(--text-light);margin-bottom:24px;opacity:.5}.nc-empty-title{color:#1f2937;color:var(--text-dark);font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0 0 8px}.nc-empty-text,.nc-empty-title{font-family:Elms Sans,sans-serif}.nc-empty-text{color:#6b7280;color:var(--text-medium);font-size:14px;font-weight:400;line-height:1.6;margin:0}@media (max-width:1024px){.nc-main{padding:48px 24px 60px}}@media (max-width:768px){.nc-main{padding:40px 20px 60px}.nc-header{align-items:flex-start;flex-direction:column;margin-bottom:36px;padding:24px 20px}.nc-page-title{font-size:28px}.nc-page-subtitle{font-size:16px}.nc-header-actions{flex-direction:column;width:100%}.nc-btn{justify-content:center;width:100%}.nc-tabs-container{padding:0 20px}.nc-tabs{gap:16px}.nc-tab-btn{font-size:13px}.nc-notification-item{padding:20px 24px}.nc-notif-icon-wrapper{height:40px;width:40px}.nc-item-actions{align-self:flex-end;-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;box-shadow:none;margin-top:12px;opacity:1;position:static;transform:none}}@media (max-width:480px){.nc-main{padding:32px 16px 48px}.nc-header{padding:20px 16px}.nc-page-title{align-items:flex-start;flex-direction:column;font-size:24px;gap:8px}.nc-page-subtitle{font-size:14px}.nc-tabs-container{padding:0 16px}.nc-tabs{-webkit-overflow-scrolling:touch;gap:12px;overflow-x:auto}.nc-tab-btn{font-size:13px;white-space:nowrap}.nc-notification-item{flex-direction:column;gap:12px;padding:16px 20px}.nc-notif-icon-wrapper{height:36px;width:36px}.nc-notif-header{flex-direction:column;gap:4px}.nc-notif-time{align-self:flex-start}.nc-btn,.nc-notif-body{font-size:13px}.nc-btn{padding:8px 16px}.nc-empty-state{padding:60px 24px}.nc-empty-icon{height:48px;width:48px}.nc-empty-title{font-size:18px}.nc-empty-text{font-size:13px}}@media (max-width:375px){.nc-page-title{font-size:22px}.nc-notification-item{padding:16px}}.nc-notification-item{animation:fadeIn .3s ease-out}.nc-notification-item:first-child{animation-delay:0s}.nc-notification-item:nth-child(2){animation-delay:.05s}.nc-notification-item:nth-child(3){animation-delay:.1s}.nc-notification-item:nth-child(4){animation-delay:.15s}.nc-notification-item:nth-child(5){animation-delay:.2s}@media (hover:none) and (pointer:coarse){.nc-notification-item:hover{background:#0000}.nc-notification-item.unread:hover{background:#f0f7ff}.nc-btn:hover{transform:none}}.nc-loading-spinner{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#1976d2;height:48px;margin:0 auto 16px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.nc-tab-count{align-items:center;background:#ef4444;border-radius:10px;color:#fff;display:inline-flex;font-size:11px;font-weight:600;justify-content:center;margin-left:6px;min-width:18px;padding:2px 6px}body.viva-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.vp-loading,body.viva-page-body{background:#fff;background:var(--bg-page)}.vp-loading{align-items:center;display:flex;height:100vh;justify-content:center}.vp-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.vp-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.vp-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;margin-bottom:32px;padding:32px 40px}.vp-header-content{align-items:center;display:flex;gap:24px;justify-content:space-between}.vp-welcome-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;letter-spacing:-1px;margin-bottom:8px}.vp-welcome-title strong{font-weight:700}.vp-welcome-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;margin:0}.vp-dashboard-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.vp-dashboard-button:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.vp-dashboard-button:active{box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.vp-stats-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.vp-stat-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:24px;transition:all .2s ease}.vp-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.vp-stat-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.vp-stat-content{flex:1 1}.vp-stat-value{color:#1f2937;color:var(--text-dark);font-size:28px;font-weight:700;line-height:1;margin-bottom:4px}.vp-stat-label,.vp-stat-value{font-family:Elms Sans,sans-serif}.vp-stat-label{color:#6b7280;color:var(--text-medium);font-size:13px;font-weight:500}.vp-actions-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:48px}.vp-action-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;gap:16px;padding:24px;text-align:left;transition:all .3s cubic-bezier(.4,0,.2,1)}.vp-action-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.vp-action-primary{background:linear-gradient(135deg,#7c3aed0d,#7c3aed05);border-color:#7c3aed4d}.vp-action-primary:hover{border-color:#7c3aed;border-color:var(--primary-purple)}.vp-action-secondary:hover{border-color:#1976d2;border-color:var(--primary-blue)}.vp-action-icon{align-items:center;background:#7c3aed1a;border-radius:10px;color:#7c3aed;color:var(--primary-purple);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.vp-action-secondary .vp-action-icon{background:#1976d21a;color:#1976d2;color:var(--primary-blue)}.vp-action-content{flex:1 1}.vp-action-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0 0 4px}.vp-action-description{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;margin:0}.vp-action-badge{background:#7c3aed;background:var(--primary-purple);border-radius:20px;color:#fff;flex-shrink:0;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;padding:6px 12px}.vp-action-arrow{color:#1976d2;color:var(--primary-blue);flex-shrink:0}.vp-subjects-section{margin-bottom:60px}.vp-section-header{align-items:center;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;margin-bottom:24px}.vp-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0}.vp-controls{display:flex;flex:1 1;gap:12px;justify-content:flex-end;max-width:600px}.vp-search-wrapper{flex:1 1;max-width:350px;position:relative}.vp-search-icon{color:#9ca3af;color:var(--text-light);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.vp-search-input{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 12px 10px 40px;transition:all .2s ease;width:100%}.vp-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.vp-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.vp-category-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;min-width:160px;padding:10px 14px;transition:all .2s ease}.vp-category-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.vp-subjects-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.vp-no-results{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:15px;grid-column:1/-1;padding:60px 20px;text-align:center}.vp-subject-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;padding:28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.vp-subject-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.vp-subject-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.vp-subject-name{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}.vp-subject-category{color:#6b7280;color:var(--text-medium);flex-grow:1;font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin-bottom:20px;min-height:20px}.vp-subject-stats{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:16px;margin-bottom:16px;padding:16px 0}.vp-subject-stat{align-items:center;color:#6b7280;color:var(--text-medium);display:flex;gap:6px}.vp-start-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s ease;width:100%}.vp-start-button:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.vp-subject-locked{background:#fafafa;cursor:not-allowed;opacity:.6}.vp-subject-locked:hover{border-color:#e5e7eb;border-color:var(--border-color);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:none}.vp-lock-badge{align-items:center;background:#dc26261a;border-radius:50%;color:#dc2626;display:flex;height:32px;justify-content:center;position:absolute;right:16px;top:16px;width:32px}.vp-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;padding-top:40px;text-align:center}.vp-footer-text{margin:4px 0}@media (max-width:1024px){.vp-main{padding:48px 24px 60px}.vp-subjects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.vp-main{padding:40px 20px 60px}.vp-header{margin-bottom:24px;padding:24px 20px}.vp-header-content{align-items:flex-start;flex-direction:column}.vp-dashboard-button{width:100%}.vp-welcome-title{font-size:28px}.vp-welcome-text{font-size:16px}.vp-actions-section,.vp-stats-section{grid-template-columns:1fr}.vp-section-header{align-items:stretch;flex-direction:column}.vp-controls{flex-direction:column}.vp-controls,.vp-search-wrapper{max-width:100%}.vp-category-select{width:100%}.vp-subject-card{padding:24px}.vp-subjects-grid{grid-template-columns:1fr}}body.vs-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0 0 80px}.vs-loading,body.vs-page-body{background:#fff;background:var(--bg-page)}.vs-loading{align-items:center;display:flex;height:100vh;justify-content:center}.vs-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.vs-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.vs-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;margin-bottom:32px;padding:32px 40px}.vs-header-content{align-items:center;display:flex;gap:24px;justify-content:space-between}.vs-subject-header{align-items:center;display:flex;gap:16px}.vs-subject-icon{align-items:center;background:#1976d21a;border-radius:12px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.vs-subject-emoji{font-size:28px}.vs-welcome-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(28px,4vw,36px);font-weight:300;letter-spacing:-1px;margin-bottom:4px}.vs-welcome-title strong{font-weight:700}.vs-welcome-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:400;margin:0}.vs-dashboard-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.vs-dashboard-button:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.vs-dashboard-button:active{box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.vs-stats-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.vs-stat-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:24px;transition:all .2s ease}.vs-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.vs-stat-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.vs-stat-icon-success{background:#10b9811a;color:#10b981;color:var(--success)}.vs-stat-content{flex:1 1}.vs-stat-value{color:#1f2937;color:var(--text-dark);font-size:28px;font-weight:700;line-height:1;margin-bottom:4px}.vs-stat-label,.vs-stat-value{font-family:Elms Sans,sans-serif}.vs-stat-label{color:#6b7280;color:var(--text-medium);font-size:13px;font-weight:500}.vs-mode-section{margin-bottom:32px}.vs-section-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:20px}.vs-mode-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.vs-mode-card{align-items:flex-start;background:#fff;background:var(--bg-card);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;gap:16px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.vs-mode-card:hover{border-color:#1976d24d;transform:translateY(-2px)}.vs-mode-card.vs-mode-active,.vs-mode-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.vs-mode-card.vs-mode-active{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue)}.vs-mode-radio{accent-color:#1976d2;accent-color:var(--primary-blue);cursor:pointer;flex-shrink:0;height:18px;margin-top:4px;width:18px}.vs-mode-content{flex:1 1}.vs-mode-title{color:#1f2937;color:var(--text-dark);font-size:18px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}.vs-mode-desc,.vs-mode-title{font-family:Elms Sans,sans-serif}.vs-mode-desc{color:#6b7280;color:var(--text-medium);font-size:14px;line-height:1.6;margin:0}.vs-recommendation-section{margin-bottom:32px}.vs-recommendation-card{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #1976d233;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px}.vs-rec-header{align-items:flex-start;display:flex;gap:16px;margin-bottom:16px}.vs-rec-icon{align-items:center;background:#1976d226;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.vs-rec-title{color:#1f2937;color:var(--text-dark);font-size:16px;font-weight:600;letter-spacing:-.3px;margin:0 0 8px}.vs-rec-desc,.vs-rec-title{font-family:Elms Sans,sans-serif}.vs-rec-desc{color:#6b7280;color:var(--text-medium);font-size:14px;line-height:1.6;margin:0}.vs-rec-chips{display:flex;flex-wrap:wrap;gap:10px}.vs-rec-chip{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.vs-rec-chip:hover{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.vs-topics-section{margin-bottom:40px}.vs-section-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;margin-bottom:24px}.vs-section-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;margin:4px 0 0}.vs-search-wrapper{flex:1 1;max-width:350px;position:relative}.vs-search-icon{color:#9ca3af;color:var(--text-light);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.vs-search-input{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 12px 10px 40px;transition:all .2s ease;width:100%}.vs-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.vs-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.vs-topic-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.vs-no-results{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:15px;grid-column:1/-1;padding:60px 20px;text-align:center}.vs-topic-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:all .2s ease}.vs-topic-card:hover{background:#1976d205;border-color:#1976d2;border-color:var(--primary-blue);transform:translateY(-1px)}.vs-topic-card.vs-topic-selected{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue)}.vs-topic-card.vs-topic-highlight{animation:highlightPulse .5s ease;background:#1976d21a;border-color:#1976d2;border-color:var(--primary-blue)}@keyframes highlightPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.vs-topic-checkbox{accent-color:#1976d2;accent-color:var(--primary-blue);cursor:pointer;flex-shrink:0;height:18px;width:18px}.vs-topic-name{color:#1f2937;color:var(--text-dark);flex:1 1;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500}.vs-topic-card.vs-topic-selected .vs-topic-name{color:#1976d2;color:var(--primary-blue);font-weight:600}.vs-start-section{margin-bottom:60px}.vs-start-button,.vs-start-section{display:flex;justify-content:center}.vs-start-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 4px 6px -1px #1976d233;color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;gap:12px;padding:16px 40px;transition:all .2s ease}.vs-start-button:hover{background:#1565c0;box-shadow:0 8px 16px #1976d24d;transform:translateY(-2px)}.vs-start-button:active{box-shadow:0 4px 6px -1px #1976d233;transform:translateY(0)}.vs-credit-badge{background:#fff3;border-radius:12px;font-size:13px;font-weight:600;padding:4px 10px}.vs-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;padding-top:40px;text-align:center}.vs-footer-text{margin:4px 0}.vs-mobile-bar{align-items:center;background:#fff;background:var(--bg-card);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);bottom:0;box-shadow:0 -4px 10px #0000001a;display:none;justify-content:space-between;left:0;padding:16px 24px;position:fixed;right:0;z-index:90}.vs-mobile-info{flex:1 1}.vs-mobile-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:600}.vs-mobile-cost{color:#6b7280;color:var(--text-medium);font-size:13px;margin-top:2px}.vs-mobile-btn,.vs-mobile-cost{font-family:Elms Sans,sans-serif}.vs-mobile-btn{background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.vs-mobile-btn:active{transform:scale(.98)}@media (max-width:1024px){.vs-main{padding:48px 24px 60px}.vs-topic-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (max-width:768px){body.vs-page-body{padding-bottom:100px}.vs-main{padding:40px 20px 60px}.vs-header{margin-bottom:24px;padding:24px 20px}.vs-header-content{align-items:flex-start;flex-direction:column}.vs-dashboard-button,.vs-subject-header{width:100%}.vs-welcome-title{font-size:24px}.vs-welcome-text{font-size:14px}.vs-mode-grid,.vs-stats-section{grid-template-columns:1fr}.vs-section-header{align-items:stretch;flex-direction:column}.vs-search-wrapper{max-width:100%}.vs-topic-grid{grid-template-columns:1fr}.vs-start-section{display:none}.vs-mobile-bar{display:flex}}@media (max-width:480px){.vs-header{padding:20px 16px}.vs-mode-card,.vs-recommendation-card,.vs-stat-card{padding:20px}}:root{--shadow-up:0 -4px 6px -1px #0000001a}body.vps-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;margin:0;overflow:hidden;padding:0}.vps-loading,body.vps-page-body{background:#fff;background:var(--bg-page);display:flex;flex-direction:column}.vps-loading{align-items:center;justify-content:center;min-height:100vh}.vps-vapi-container{display:flex;flex:1 1;flex-direction:column;margin:0;min-height:0;overflow:hidden;padding:0}.vps-vapi-container>*{flex:1 1;min-height:0}.vps-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500;margin-top:16px}.vps-session-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border-bottom:1px solid #d4e9f0;flex-shrink:0;padding:24px 40px}.vps-header-content{align-items:center;display:flex;flex-wrap:wrap;gap:32px;justify-content:space-between;margin:0 auto;max-width:900px}.vps-session-meta{flex:1 1;min-width:200px}.vps-subject-tag{color:#6b7280;color:var(--text-medium);display:block;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.vps-session-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0}.vps-status-box{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.vps-mode-badge{border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);font-family:Elms Sans,sans-serif;font-size:11px;font-weight:700;letter-spacing:.5px;padding:8px 16px;text-transform:uppercase}.vps-mode-exam{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.vps-mode-practice{background:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.vps-timer{color:#1f2937;color:var(--text-dark);font-family:Courier New,monospace;font-size:20px;font-weight:700}.vps-counter-box,.vps-timer{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:8px 16px}.vps-counter-box{text-align:right}.vps-counter-val{color:#1976d2;color:var(--primary-blue);display:block;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700}.vps-counter-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.vps-chat-container{background:#fff;background:var(--bg-page);flex:1 1;overflow-y:auto;padding:32px 24px;scroll-behavior:smooth}.vps-chat-wrapper{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:800px;padding-bottom:120px}.vps-system-message{align-self:center;background:#1976d20d;border-radius:20px;color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;margin:12px 0;padding:8px 16px;text-align:center}.vps-message{animation:fadeIn .3s ease-out;display:flex;gap:12px;max-width:85%}.vps-message-ai{align-self:flex-start}.vps-message-user{align-self:flex-end;flex-direction:row-reverse}.vps-avatar{align-items:center;border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:50%;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-shrink:0;font-family:Elms Sans,sans-serif;font-size:20px;height:44px;justify-content:center;width:44px}.vps-avatar-ai{background:#fff}.vps-avatar-ai,.vps-avatar-user{border-color:#1976d2;border-color:var(--primary-blue)}.vps-avatar-user{background:#1976d2;background:var(--primary-blue);color:#fff;font-size:16px;font-weight:700}.vps-bubble{border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);font-family:Elms Sans,sans-serif;font-size:15px;line-height:1.6;padding:16px 20px}.vps-message-ai .vps-bubble{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-top-left-radius:4px;color:#1f2937;color:var(--text-dark)}.vps-message-user .vps-bubble{background:#1976d2;background:var(--primary-blue);border:1px solid #1976d2;border:1px solid var(--primary-blue);border-top-right-radius:4px;color:#fff}.vps-typing-indicator{animation:fadeIn .3s ease-out;color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-style:italic;font-weight:500;margin-left:56px}.vps-control-bar{background:#fff;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);bottom:0;box-shadow:0 -4px 6px -1px #0000001a;box-shadow:var(--shadow-up);flex-shrink:0;left:0;padding:14px 20px;position:fixed;right:0;z-index:100}.vps-control-wrapper{align-items:center;display:flex;gap:20px;justify-content:space-between;margin:0 auto;max-width:800px}.vps-btn-control{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease}.vps-btn-control:hover{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1976d2;color:var(--primary-blue);transform:translateY(-1px)}.vps-btn-end{align-items:center;background:#fff;border:1px solid #fecaca;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#ef4444;color:var(--error);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease}.vps-btn-end:hover{background:#fee2e2;border-color:#ef4444;border-color:var(--error);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.vps-mic-section{text-align:center}.vps-mic-btn{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:50%;box-shadow:0 4px 15px #1976d266;color:#fff;cursor:pointer;display:flex;font-size:28px;height:64px;justify-content:center;transition:all .2s ease;width:64px}.vps-mic-btn:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 20px #1976d280;transform:scale(1.05)}.vps-mic-btn:disabled{cursor:not-allowed;opacity:.5}.vps-mic-btn.vps-mic-active{animation:pulse 1.5s infinite;background:#ef4444;background:var(--error);box-shadow:0 4px 15px #ef444466}.vps-mic-status{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600;margin-top:6px;text-align:center}.vps-mic-status-active{color:#ef4444;color:var(--error)}.vps-feedback-overlay{align-items:center;animation:fadeIn .3s 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:200}.vps-feedback-card{animation:slideUp .3s ease-out;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:550px;overflow:hidden;width:90%}.vps-grade-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);padding:40px 32px;text-align:center}.vps-grade-large{color:#10b981;color:var(--success);font-family:Elms Sans,sans-serif;font-size:56px;font-weight:800;line-height:1;margin-bottom:8px}.vps-grade-subtitle{color:#6b7280;color:var(--text-medium);font-size:13px;letter-spacing:1px;margin-bottom:12px;text-transform:uppercase}.vps-grade-pass,.vps-grade-subtitle{font-family:Elms Sans,sans-serif;font-weight:600}.vps-grade-pass{border-radius:20px;display:inline-block;font-size:15px;padding:6px 16px}.vps-grade-pass.vps-pass{background:#10b9811a;color:#10b981;color:var(--success)}.vps-grade-pass.vps-fail{background:#ef44441a;color:#ef4444;color:var(--error)}.vps-scores-grid{background:#fff;display:flex;flex-direction:column;gap:20px;padding:32px}.vps-score-row{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:16px;justify-content:space-between}.vps-score-label{color:#1f2937;color:var(--text-dark);flex-shrink:0;font-weight:600;width:100px}.vps-progress-bar{background:#e5e7eb;background:var(--border-color);border-radius:5px;flex:1 1;height:10px;overflow:hidden}.vps-progress-fill{background:#1976d2;background:var(--primary-blue);border-radius:5px;height:100%;transition:width .5s ease}.vps-progress-warning{background:#f59e0b;background:var(--warning)}.vps-score-val{color:#1f2937;color:var(--text-dark);flex-shrink:0;font-weight:700;text-align:right;width:45px}.vps-feedback-text{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;margin:12px 0 0;padding-top:20px}.vps-feedback-text strong{color:#1f2937;color:var(--text-dark);font-weight:600}.vps-feedback-actions{background:#1976d205;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:16px;justify-content:space-between;padding:20px 32px}.vps-btn-primary,.vps-btn-secondary{border:none;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 28px;transition:all .2s ease}.vps-btn-secondary{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-medium)}.vps-btn-secondary:hover{background:#0000000d;border-color:#6b7280;border-color:var(--text-medium);color:#1f2937;color:var(--text-dark)}.vps-btn-primary{background:#1976d2;background:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.vps-btn-primary:hover{background:#1565c0;box-shadow:0 4px 12px #1976d24d;transform:translateY(-1px)}@media (max-width:768px){.vps-session-header{padding:20px}.vps-header-content{align-items:flex-start;flex-direction:column;gap:16px}.vps-status-box{gap:12px;justify-content:space-between;width:100%}.vps-chat-container{padding:20px 16px}.vps-control-wrapper{gap:12px}.vps-btn-control span,.vps-btn-end span{display:none}.vps-btn-control,.vps-btn-end{padding:10px}.vps-mic-btn{font-size:24px;height:56px;width:56px}.vps-feedback-card{width:95%}.vps-grade-header{padding:32px 24px}.vps-scores-grid{padding:24px}.vps-feedback-actions{flex-direction:column;padding:16px 24px}.vps-btn-primary,.vps-btn-secondary{width:100%}}@media (max-width:480px){.vps-session-title{font-size:20px}.vps-timer{font-size:18px}.vps-counter-box,.vps-timer{padding:6px 12px}.vps-message{max-width:90%}.vps-grade-large{font-size:48px}}body.vh-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.vh-loading,body.vh-page-body{background:#fff;background:var(--bg-page)}.vh-loading{align-items:center;display:flex;height:100vh;justify-content:center}.vh-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.vh-main{margin:0 auto;max-width:1280px;padding:60px 40px 80px}.vh-header{margin-bottom:32px;margin-top:-40px}.vh-header-content{align-items:flex-end;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between}.vh-breadcrumb{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:8px;margin-bottom:12px}.vh-breadcrumb,.vh-breadcrumb-link{color:#6b7280;color:var(--text-medium)}.vh-breadcrumb-link{cursor:pointer;font-weight:500;transition:color .2s ease}.vh-breadcrumb-link:hover{color:#1976d2;color:var(--primary-blue)}.vh-breadcrumb-separator{color:#9ca3af;color:var(--text-light)}.vh-breadcrumb-current{color:#1f2937;color:var(--text-dark);font-weight:600}.vh-page-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0}.vh-export-button{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#6b7280;color:var(--text-medium);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.vh-export-button:hover{background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1976d2;color:var(--primary-blue);transform:translateY(-1px)}.vh-stats-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr 1fr;margin-bottom:32px}.vh-stat-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px;transition:all .2s ease}.vh-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.vh-stat-card-trend{display:flex;flex-direction:column}.vh-stat-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.vh-stat-content{flex:1 1}.vh-stat-value{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:32px;font-weight:800;line-height:1;margin-bottom:8px}.vh-stat-label{color:#6b7280;color:var(--text-medium);font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.vh-stat-label,.vh-stat-trend{font-family:Elms Sans,sans-serif;font-size:13px}.vh-stat-trend{color:#10b981;color:var(--success);font-weight:500}.vh-trend-chart{height:100px;margin-top:-30px;width:100%}.vh-chart-line{fill:none;stroke:#1976d2;stroke:var(--primary-blue);stroke-width:3;vector-effect:non-scaling-stroke}.vh-chart-area{fill:#1976d21a}.vh-controls-section{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.vh-search-wrapper{flex:2 1;min-width:280px;position:relative}.vh-search-icon{color:#9ca3af;color:var(--text-light);left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.vh-search-input{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 14px 10px 42px;transition:all .2s ease;width:100%}.vh-search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.vh-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.vh-filters-wrapper{display:flex;flex:3 1;flex-wrap:wrap;gap:12px}.vh-filter-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-dark);cursor:pointer;flex:1 1;font-family:Elms Sans,sans-serif;font-size:14px;min-width:140px;padding:10px 14px;transition:all .2s ease}.vh-filter-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.vh-table-section{margin-bottom:60px}.vh-table-container{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.vh-table{border-collapse:collapse;font-size:14px;width:100%}.vh-table thead{background:#1976d208}.vh-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.vh-th-actions{text-align:right}.vh-table-row{transition:background-color .2s ease}.vh-table-row:hover{background:#1976d205}.vh-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);padding:16px 20px;vertical-align:middle}.vh-date-cell{display:flex;flex-direction:column;gap:2px}.vh-date{color:#1f2937;color:var(--text-dark);font-weight:600}.vh-time{color:#6b7280;color:var(--text-medium);font-size:12px}.vh-topic-cell{display:flex;flex-direction:column;gap:4px}.vh-subject-tag{color:#6b7280;color:var(--text-medium);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.vh-topic-title{color:#1f2937;color:var(--text-dark);font-weight:600}.vh-mode-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.vh-mode-exam{background:#fee2e2;color:#991b1b}.vh-mode-practice{background:#dbeafe;color:#1e40af}.vh-grade-cell{align-items:center;display:flex;gap:10px}.vh-grade-badge{align-items:center;border:2px solid;border-radius:50%;display:inline-flex;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.vh-grade-a{background:#10b9811a;border-color:#a7f3d0;color:#065f46}.vh-grade-b{background:#1976d21a;border-color:#bae6fd;color:#1e40af}.vh-grade-c{background:#f59e0b1a;border-color:#fde68a;color:#92400e}.vh-grade-default{background:#6b72801a;border-color:#e5e7eb;border-color:var(--border-color)}.vh-grade-default,.vh-score-text{color:#6b7280;color:var(--text-medium)}.vh-score-text{font-size:13px;font-weight:500}.vh-actions-cell{display:flex;gap:8px;justify-content:flex-end;text-align:right}.vh-btn-sm{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.vh-btn-secondary{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#6b7280;color:var(--text-medium)}.vh-btn-secondary:hover{background:#00000005;border-color:#6b7280;border-color:var(--text-medium);color:#1f2937;color:var(--text-dark)}.vh-btn-primary{background:#1976d2;background:var(--primary-blue);box-shadow:0 2px 4px #1976d233;color:#fff}.vh-btn-primary:hover{background:#1565c0;box-shadow:0 4px 8px #1976d24d;transform:translateY(-1px)}.vh-pagination{align-items:center;background:#fff;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.vh-page-info{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px}.vh-page-controls{display:flex;gap:8px}.vh-page-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#1f2937;color:var(--text-dark);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;height:36px;justify-content:center;transition:all .2s ease;width:36px}.vh-page-btn:hover:not(:disabled){background:#1976d20d;border-color:#1976d2;border-color:var(--primary-blue);color:#1976d2;color:var(--primary-blue)}.vh-page-btn:disabled{cursor:not-allowed;opacity:.4}.vh-page-btn.vh-page-active{background:#1976d2;background:var(--primary-blue);border-color:#1976d2;border-color:var(--primary-blue);color:#fff}.vh-modal-overlay{align-items:center;animation:fadeIn .3s 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:200}.vh-modal-card{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:90vh;max-width:650px;overflow:hidden;width:90%}.vh-modal-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:24px}.vh-modal-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:700;margin-bottom:4px}.vh-modal-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px}.vh-modal-close{background:none;border:none;color:#9ca3af;color:var(--text-light);cursor:pointer;font-size:28px;line-height:1;transition:color .2s ease}.vh-modal-close:hover{color:#1f2937;color:var(--text-dark)}.vh-modal-body{flex:1 1;overflow-y:auto;padding:24px}.vh-feedback-section{margin-bottom:24px}.vh-feedback-section:last-child{margin-bottom:0}.vh-section-label{color:#6b7280;color:var(--text-medium);display:block;font-family:Elms Sans,sans-serif;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.vh-transcript-snippet{background:#1976d20d;border-left:4px solid #1976d2;border-left:4px solid var(--primary-blue);border-radius:8px;color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.6;padding:16px}.vh-metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.vh-metric-card{background:#1976d208;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:center}.vh-metric-value{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:24px;font-weight:700;margin-bottom:6px}.vh-metric-label{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:12px;font-weight:600}.vh-improvement-list{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:14px;line-height:1.8;list-style-type:disc;padding-left:20px}.vh-improvement-list li{margin-bottom:8px}.vh-modal-footer{background:#1976d205;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1024px){.vh-main{padding:48px 24px 60px}.vh-stats-section{grid-template-columns:1fr}.vh-controls-section{flex-direction:column}.vh-filters-wrapper,.vh-search-wrapper{width:100%}.vh-filters-wrapper{flex-direction:column}.vh-filter-select{width:100%}.vh-metrics-grid{grid-template-columns:1fr}}@media (max-width:768px){.vh-main{padding:40px 20px 60px}.vh-page-title{font-size:24px}.vh-table-container{overflow-x:auto}.vh-table{min-width:800px}.vh-modal-card{width:95%}.vh-actions-cell{align-items:flex-end;flex-direction:column}.vh-btn-sm{justify-content:center;width:100%}.vh-pagination{align-items:flex-start;flex-direction:column;gap:16px}}body.ba-page-body{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.ba-loading,body.ba-page-body{background:#fff;background:var(--bg-page)}.ba-loading{align-items:center;display:flex;height:100vh;justify-content:center}.ba-loading-text{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500}.ba-main{margin:0 auto;max-width:1280px;padding:60px 40px 80px}.ba-header{margin-bottom:32px;margin-top:-30px}.ba-header-content{align-items:flex-end;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between}.ba-breadcrumb{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;gap:8px;margin-bottom:12px}.ba-breadcrumb,.ba-breadcrumb-link{color:#6b7280;color:var(--text-medium)}.ba-breadcrumb-link{cursor:pointer;font-weight:500;transition:color .2s ease}.ba-breadcrumb-link:hover{color:#1976d2;color:var(--primary-blue)}.ba-breadcrumb-separator{color:#9ca3af;color:var(--text-light)}.ba-breadcrumb-current{color:#1f2937;color:var(--text-dark);font-weight:600}.ba-page-title{align-items:center;color:#1f2937;color:var(--text-dark);color:#1976d2;color:var(--primary-blue);display:flex;font-family:Elms Sans,sans-serif;font-size:32px;font-weight:700;gap:12px;letter-spacing:-.5px;margin:0}.ba-controls{display:flex;flex-wrap:wrap;gap:12px}.ba-filter-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;padding:10px 14px;transition:all .2s ease}.ba-filter-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.ba-report-button{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.ba-report-button:hover{background:#1565c0;box-shadow:0 4px 8px #1976d24d;transform:translateY(-1px)}.ba-stats-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.ba-stat-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:24px;transition:all .2s ease}.ba-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.ba-stat-card-warning{background:#ef444405;border-color:#ef444433}.ba-stat-icon{align-items:center;background:#1976d21a;border-radius:10px;color:#1976d2;color:var(--primary-blue);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.ba-stat-icon-warning{background:#ef44441a;color:#ef4444;color:var(--error)}.ba-stat-content{flex:1 1}.ba-stat-label{color:#6b7280;color:var(--text-medium);font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.ba-stat-label,.ba-stat-value{font-family:Elms Sans,sans-serif}.ba-stat-value{color:#1f2937;color:var(--text-dark);font-size:32px;font-weight:800;line-height:1;margin-bottom:6px}.ba-stat-trend{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:500;gap:4px}.ba-trend-up{color:#10b981;color:var(--success)}.ba-trend-down{color:#ef4444;color:var(--error)}.ba-trend-neutral{color:#6b7280;color:var(--text-medium)}.ba-dashboard-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr}.ba-left-column,.ba-right-column{display:flex;flex-direction:column;gap:24px}.ba-section-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px}.ba-ai-section{background:linear-gradient(180deg,#1976d208,#fff)}.ba-card-header{justify-content:space-between;margin-bottom:24px}.ba-card-header,.ba-card-title{align-items:center;display:flex}.ba-card-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;gap:8px;letter-spacing:-.3px}.ba-toggle-container{align-items:center;background:#1976d20d;border-radius:8px;display:flex;gap:2px;padding:2px}.ba-toggle-btn{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:6px 14px;transition:all .2s ease}.ba-toggle-btn.ba-toggle-active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#1976d2;color:var(--primary-blue)}.ba-chart-container{height:250px;margin-bottom:8px;position:relative;width:100%}.ba-chart-svg{height:100%;overflow:visible;width:100%}.ba-chart-grid{stroke:#e5e7eb;stroke:var(--border-color);stroke-width:1;stroke-dasharray:4}.ba-chart-area{fill:#1976d21a}.ba-chart-line{fill:none;stroke:#1976d2;stroke:var(--primary-blue);stroke-width:3;vector-effect:non-scaling-stroke}.ba-chart-point{fill:#fff;stroke:#1976d2;stroke:var(--primary-blue);stroke-width:2;cursor:pointer;transition:r .2s}.ba-chart-point:hover{r:6}.ba-chart-labels{color:#6b7280;color:var(--text-medium);display:flex;font-family:Elms Sans,sans-serif;font-size:12px;justify-content:space-between}.ba-subjects-list{gap:20px}.ba-subject-row,.ba-subjects-list{display:flex;flex-direction:column}.ba-subject-row{gap:8px}.ba-subject-info{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:14px;justify-content:space-between}.ba-subject-name{color:#1f2937;color:var(--text-dark);font-weight:600}.ba-subject-score{font-size:13px;font-weight:600}.ba-subject-strong{color:#10b981;color:var(--success)}.ba-subject-average{color:#f59e0b;color:var(--warning)}.ba-subject-weak{color:#ef4444;color:var(--error)}.ba-progress-track{background:#1976d20d;border-radius:5px;height:10px;overflow:hidden}.ba-progress-bar{border-radius:5px;height:100%;transition:width 1s ease-out}.ba-bar-success{background:#10b981;background:var(--success)}.ba-bar-warning{background:#f59e0b;background:var(--warning)}.ba-bar-error{background:#ef4444;background:var(--error)}.ba-weakness-list{display:flex;flex-direction:column;gap:12px}.ba-weakness-item{align-items:center;background:#ef44440d;border-left:4px solid #ef4444;border-left:4px solid var(--error);border-radius:8px;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.ba-weakness-item:hover{background:#ef444414;transform:translateX(2px)}.ba-weak-content{flex:1 1}.ba-weak-topic{color:#991b1b;font-size:14px;font-weight:600;margin-bottom:4px}.ba-weak-subject,.ba-weak-topic{font-family:Elms Sans,sans-serif}.ba-weak-subject{color:#b91c1c;font-size:12px;font-weight:500}.ba-weak-score{color:#ef4444;color:var(--error);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700}.ba-recommendations-list{display:flex;flex-direction:column;gap:16px}.ba-recommendation-card{background:#fff;border:1px solid #1976d233;border-radius:8px;padding:16px;transition:all .2s ease}.ba-recommendation-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.ba-rec-header{align-items:center;color:#1976d2;color:var(--primary-blue);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:10px}.ba-rec-header,.ba-rec-text{font-family:Elms Sans,sans-serif}.ba-rec-text{color:#6b7280;color:var(--text-medium);font-size:13px;line-height:1.5;margin-bottom:14px}.ba-rec-text strong{color:#1f2937;color:var(--text-dark);font-weight:600}.ba-rec-button{background:#fff;border:1px solid #1976d2;border:1px solid var(--primary-blue);border-radius:8px;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:10px 16px;transition:all .2s ease;width:100%}.ba-rec-button:hover{background:#1976d2;background:var(--primary-blue);box-shadow:0 4px 8px #1976d233;color:#fff;transform:translateY(-1px)}@media (max-width:1024px){.ba-main{padding:48px 24px 60px}.ba-dashboard-grid{grid-template-columns:1fr}.ba-stats-section{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}@media (max-width:768px){.ba-main{padding:40px 20px 60px}.ba-page-title{font-size:24px}.ba-header-content{align-items:flex-start;flex-direction:column}.ba-controls{flex-direction:column;width:100%}.ba-filter-select,.ba-report-button{width:100%}.ba-stats-section{grid-template-columns:1fr}.ba-chart-container{height:200px}}@media (max-width:480px){.ba-stat-value{font-size:28px}.ba-section-card{padding:20px}.ba-card-title{font-size:16px}}:root{--bg-white:#fff;--border-light:#e5e7eb;--success:#10b981;--success-bg:#d1fae5;--warning:#f59e0b;--warning-bg:#fef3c7;--error:#ef4444}*,:after,:before{box-sizing:border-box}body.pr-page-body{color:#111827;color:var(--text-dark);font-family:Elms Sans,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}.pr-loading,body.pr-page-body{background:#f4f6f8;background:var(--bg-page);min-height:100vh}.pr-loading{align-items:center;display:flex;flex-direction:column;justify-content:center}.pr-loading-text{color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:500;margin-top:16px}.pr-navbar{background:#fff;background:var(--bg-white);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.pr-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:20px 40px}.pr-logo{color:#111827;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:24px;font-weight:800;letter-spacing:-.5px}.pr-logo-osce{color:#1976d2;color:var(--primary-blue)}.pr-logo-pal{color:#7c3aed;color:var(--primary-purple)}.pr-profile-btn{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:6px;transition:all .2s ease}.pr-profile-btn:hover{background:#f9fafb}.pr-profile-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.pr-main{margin:0 auto;max-width:1000px;padding:24px}.pr-controls{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:16px}.pr-controls,.pr-date-filter{align-items:center;display:flex}.pr-date-filter{gap:12px}.pr-filter-label{font-family:Elms Sans,sans-serif;font-weight:600}.pr-filter-label,.pr-select{color:#111827;color:var(--text-dark);font-size:14px}.pr-select{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;cursor:pointer;font-family:Inter,sans-serif;padding:8px 12px;transition:all .2s ease}.pr-select:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.pr-action-btns{display:flex;gap:12px}.pr-btn-outline,.pr-btn-primary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:all .2s ease}.pr-btn-outline{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-light);color:#111827;color:var(--text-dark)}.pr-btn-outline:hover{background:#00000005;border-color:#6b7280;border-color:var(--text-grey)}.pr-btn-primary{background:#1976d2;background:var(--primary-blue);box-shadow:0 4px 6px -1px #1976d233;color:#fff}.pr-btn-primary:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.pr-paper{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);padding:40px}.pr-header{align-items:flex-end;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-light);display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.pr-title-section{flex:1 1}.pr-main-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px;margin:0 0 8px}.pr-meta{color:#6b7280;color:var(--text-grey);font-family:Inter,sans-serif;font-size:13px}.pr-meta-value{color:#111827;color:var(--text-dark);font-weight:600}.pr-student-info{text-align:right}.pr-student-name{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;margin-bottom:4px}.pr-student-detail{color:#6b7280;color:var(--text-grey);font-family:Inter,sans-serif;font-size:13px}.pr-summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.pr-summary-box{background:#7c3aed08;border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;padding:20px}.pr-summary-label{color:#6b7280;color:var(--text-grey);font-family:Inter,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.pr-summary-value{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:28px;font-weight:700}.pr-value-blue{color:#1976d2;color:var(--primary-blue)}.pr-value-purple{color:#7c3aed;color:var(--primary-purple)}.pr-swot-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:32px}.pr-swot-panel{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;padding:20px}.pr-swot-header{align-items:center;display:flex;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:700;gap:8px;margin-bottom:16px}.pr-header-green{color:#10b981;color:var(--success)}.pr-header-red{color:#ef4444;color:var(--error)}.pr-list-item{align-items:center;border-bottom:1px solid #0000000d;display:flex;font-family:Inter,sans-serif;font-size:14px;justify-content:space-between;padding:10px 0}.pr-list-item:last-child{border-bottom:none}.pr-pill{border-radius:12px;font-family:Inter,sans-serif;font-size:12px;font-weight:600;padding:4px 10px}.pr-pill-high{background:#d1fae5;background:var(--success-bg);color:#065f46}.pr-pill-low{background:#fee2e2;background:var(--error-bg);color:#991b1b}.pr-section{margin-bottom:32px}.pr-section-title{align-items:center;color:#111827;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:18px;font-weight:700;gap:8px;margin-bottom:16px}.pr-title-blue{color:#1976d2;color:var(--primary-blue)}.pr-chart-placeholder{background:#7c3aed05;border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;height:200px;margin-bottom:32px;position:relative;width:100%}.pr-chart-svg{height:100%;width:100%}.pr-chart-label{bottom:8px;color:#6b7280;color:var(--text-grey);font-family:Inter,sans-serif;font-size:11px;position:absolute}.pr-chart-label-left{left:16px}.pr-chart-label-right{right:16px}.pr-table{border-collapse:collapse;font-family:Inter,sans-serif;font-size:14px;width:100%}.pr-table th{background:#7c3aed0d;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-light);color:#6b7280;color:var(--text-grey);font-family:Elms Sans,sans-serif;font-size:13px;font-weight:600;padding:12px;text-align:left}.pr-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);color:#111827;color:var(--text-dark);padding:14px 12px}.pr-table tbody tr:hover{background:#7c3aed05}.pr-status-dot{border-radius:50%;display:inline-block;height:8px;margin-right:8px;width:8px}.pr-status-green{background:#10b981;background:var(--success)}.pr-status-yellow{background:#f59e0b;background:var(--warning)}.pr-status-red{background:#ef4444;background:var(--error)}.pr-action-plan{background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;padding:24px}.pr-action-list{list-style-type:none;margin:0;padding:0}.pr-action-list li{color:#111827;color:var(--text-dark);font-family:Inter,sans-serif;font-size:14px;line-height:1.6;margin-bottom:12px;padding-left:24px;position:relative}.pr-action-list li:last-child{margin-bottom:0}.pr-action-list li:before{color:#1976d2;color:var(--primary-blue);content:"→";font-size:16px;font-weight:700;left:0;position:absolute}.pr-action-list li strong{color:#111827;color:var(--text-dark);font-weight:600}@media print{body.pr-page-body{background:#fff;-webkit-print-color-adjust:exact;print-color-adjust:exact}.pr-controls,.pr-navbar{display:none}.pr-main{margin:0;max-width:100%;padding:0}.pr-paper{border:none;border-radius:0;box-shadow:none;padding:0}.pr-section,.pr-swot-grid{page-break-inside:avoid}.pr-pill-high{background-color:#d1fae5!important}.pr-pill-high,.pr-pill-low{-webkit-print-color-adjust:exact}.pr-pill-low{background-color:#fee2e2!important}.pr-action-plan{background-color:#eff6ff!important;-webkit-print-color-adjust:exact}}@media (max-width:1024px){.pr-navbar-container{padding:16px 24px}.pr-summary-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.pr-navbar-container{padding:12px 20px}.pr-logo{font-size:20px}.pr-main{padding:16px}.pr-paper{padding:24px 20px}.pr-controls{align-items:stretch;flex-direction:column}.pr-action-btns{flex-direction:column;width:100%}.pr-btn-outline,.pr-btn-primary{justify-content:center;width:100%}.pr-summary-grid,.pr-swot-grid{grid-template-columns:1fr}.pr-header{align-items:flex-start;flex-direction:column}.pr-student-info{text-align:left}.pr-table{font-size:12px}.pr-table td,.pr-table th{padding:8px}}@media (max-width:480px){.pr-main-title{font-size:22px}.pr-summary-value{font-size:24px}.pr-chart-placeholder{height:150px}}.help-center-body{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;min-height:100vh;padding:0}.help-hero{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border:1px solid #d4e9f0;border-radius:12px;margin-bottom:40px;padding:60px 40px;text-align:center}.help-hero-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,4vw,42px);font-weight:300;letter-spacing:-1px;margin-bottom:8px}.help-hero-title strong{font-weight:700}.help-hero-subtitle{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:400;margin:0 0 20px}.help-search-container{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:flex;margin:0 auto;max-width:600px}.help-search-icon{align-items:center;color:#9ca3af;color:var(--text-light);display:flex;padding:0 15px}.help-search-input{background:#0000;border:none;color:#1f2937;color:var(--text-dark);flex-grow:1;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:400;outline:none;padding:14px 0}.help-search-input::placeholder{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-weight:400}.help-main{margin:0 auto;max-width:1200px;padding:60px 40px 80px}.help-categories{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:60px}.help-category-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;padding:28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.help-category-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.help-category-icon{align-items:center;border-radius:10px;display:flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.help-category-icon.blue{background:#1976d21a;color:#1976d2;color:var(--primary-blue)}.help-category-icon.purple{background:#7c3aed1a;color:#7c3aed;color:var(--primary-purple)}.help-category-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:8px}.help-category-desc{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:14px;font-weight:400;line-height:1.6}.help-faq-section{margin-bottom:60px}.help-faq-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:10px}.help-faq-title{color:#1f2937;color:var(--text-dark);font-size:20px;margin:0}.help-expand-btn,.help-faq-title{font-family:Elms Sans,sans-serif;font-weight:600}.help-expand-btn{background:none;border:none;border-radius:6px;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-size:14px;padding:8px 12px}.help-expand-btn:hover{background:#eef5fb}.help-faq-list{display:flex;flex-direction:column;gap:12px}.help-faq-item{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;transition:all .3s ease}.help-faq-item.open{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.help-faq-question{align-items:center;color:#1f2937;color:var(--text-dark);cursor:pointer;display:flex;font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;justify-content:space-between;padding:18px 20px}.help-faq-question:hover{color:#1976d2;color:var(--primary-blue)}.help-faq-icon{color:#6b7280;color:var(--text-medium);transition:transform .3s ease}.help-faq-item.open .help-faq-icon{color:#1976d2;color:var(--primary-blue);transform:rotate(180deg)}.help-faq-answer{border-top:1px solid #f3f4f6;color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:15px;font-weight:400;line-height:1.7;padding:0 20px 20px}.help-no-results{color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;padding:60px 20px;text-align:center}.help-no-results p{font-size:16px;font-weight:400}.help-reset-btn{background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;margin-top:20px;padding:12px 24px;transition:all .2s ease}.help-reset-btn:hover{background:#1565c0}.help-bottom-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:2fr 1fr;margin-top:40px}.help-contact-card,.help-resource-card{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:28px}.help-resource-card{align-items:flex-start;background:#eef5fb;border-color:#d4e9f0;display:flex;gap:20px}.help-resource-icon{color:#1976d2;color:var(--primary-blue);min-width:32px}.help-resource-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;margin-bottom:5px}.help-resource-desc{color:#6b7280;color:var(--text-medium);font-weight:400}.help-resource-desc,.help-resource-link{font-family:Elms Sans,sans-serif;font-size:14px}.help-resource-link{background:none;border:none;color:#1976d2;color:var(--primary-blue);cursor:pointer;font-weight:600;padding:0}.help-resource-link:hover{color:#1565c0}.help-contact-card{background:#fff;background:var(--bg-card);text-align:center}.help-contact-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;margin-bottom:8px}.help-contact-desc{color:#6b7280;color:var(--text-medium);font-weight:400;margin-bottom:20px}.help-contact-btn,.help-contact-desc{font-family:Elms Sans,sans-serif;font-size:14px}.help-contact-btn{background:#7c3aed;background:var(--primary-purple);border:none;border-radius:8px;box-shadow:0 2px 4px #7c3aed33;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s ease}.help-contact-btn:hover{background:#6d28d9;box-shadow:0 6px 12px #7c3aed4d;transform:translateY(-1px)}.help-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:13px;padding-top:40px;text-align:center}@media (max-width:1024px){.help-main{padding:48px 24px 60px}.help-categories{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.help-bottom-grid{gap:24px;grid-template-columns:1fr}}@media (max-width:768px){.help-main{padding:40px 20px 60px}.help-hero{padding:30px 20px}.help-hero-title{font-size:28px}.help-hero-subtitle{font-size:16px}.help-category-card{padding:24px}}:root{--primary-hover:#1565c0;--primary-light:#e3f2fd;--secondary-light:#f3e5f5;--success-color:#10b981;--error-color:#ef4444;--bg-field-readonly:#f9fafb;--font-family:"Elms Sans",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--radius-lg:12px}.contact-form-body{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);display:flex;flex-direction:column;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);line-height:1.6;min-height:100vh}.contact-container{margin:0 auto;max-width:1000px;padding:0 40px}.page-header{background:#fff;background:var(--bg-card);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color)}.back-link{align-items:center;color:#6b7280;color:var(--text-medium);display:inline-flex;font-size:14px;font-weight:500;margin-bottom:16px;text-decoration:none;transition:color .2s}.back-link:hover{color:#1976d2;color:var(--primary-blue)}.header-title{font-size:30px;margin-bottom:8px}.header-subtitle,.header-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.header-subtitle{font-size:18px;font-weight:400}.content-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:2fr 1fr;margin-top:32px;padding-bottom:60px}.contact-card{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:32px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group,.form-row{margin-bottom:24px}.form-label{color:#1f2937;color:var(--text-dark);display:block;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px;font-weight:600;margin-bottom:8px}.required-star{color:#ef4444;color:var(--error-color)}.form-input,.form-select,.form-textarea{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-dark);font-family:inherit;font-size:16px;padding:12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #e3f2fd;box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-textarea{min-height:150px;resize:vertical}.read-only-field{background-color:#f9fafb;background-color:var(--bg-field-readonly);color:#6b7280;color:var(--text-medium);cursor:default}.file-upload-box{align-items:center;background:#f9fafb;background:var(--bg-field-readonly);border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;padding:24px;text-align:center;transition:all .2s}.file-upload-box:hover{background:#e3f2fd;background:var(--primary-light);border-color:#1976d2;border-color:var(--primary-blue)}.file-icon{color:#6b7280;color:var(--text-medium);transition:color .2s}.file-upload-box:hover .file-icon{color:#1976d2;color:var(--primary-blue)}.file-upload-text{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px;margin-top:8px}.file-upload-box .file-upload-text[style*="var(--primary-blue)"]{color:#1976d2!important;color:var(--primary-blue)!important;font-weight:600}.btn-submit{align-items:center;background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;display:flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s ease;width:100%}.btn-submit:hover:not(:disabled){background:#1565c0;background:var(--primary-hover);box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.btn-submit:active:not(:disabled){box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.btn-submit:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.sidebar-box{background:#f9fafb;background:var(--bg-field-readonly);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:24px;padding:24px}.sidebar-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:18px;font-weight:700;margin-bottom:16px}.info-list{list-style:none;padding:0}.info-item{align-items:flex-start;color:#6b7280;color:var(--text-medium);display:flex;font-size:14px;gap:12px;margin-bottom:16px}.info-icon{margin-top:2px;min-width:18px}.info-icon,.link-text{color:#1976d2;color:var(--primary-blue)}.link-text{display:inline-block;font-weight:500;text-decoration:none}.link-text:hover{text-decoration:underline}.info-small-text{color:#6b7280;color:var(--text-medium);font-size:12px}.faq-link-card{background:#fff;background:var(--bg-card);border:1px solid #e3f2fd;border:1px solid var(--primary-light);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px;text-align:center}.faq-icon{color:#7c3aed;color:var(--primary-purple);margin-bottom:8px}.faq-title{font-size:18px;font-weight:600;margin-bottom:8px}.faq-desc,.faq-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.faq-desc{color:#6b7280;color:var(--text-medium);font-size:13px;margin-bottom:16px}.btn-faq-link{background:#fff;border:1px solid #1976d2;border:1px solid var(--primary-blue);border-radius:8px;border-radius:var(--radius-md);color:#1976d2;color:var(--primary-blue);cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s;width:100%}.btn-faq-link:hover{background:#e3f2fd;background:var(--primary-light)}.overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.success-modal{animation:popIn .3s ease-out;background:#fff;background:var(--bg-card);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:400px;padding:40px;text-align:center;width:90%}.success-icon{align-items:center;background:#e6f7ef;border-radius:50%;color:#10b981;color:var(--success-color);display:flex;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.modal-title{font-weight:700;margin-bottom:8px}.modal-desc,.modal-title{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.modal-desc{color:#6b7280;color:var(--text-medium);margin-bottom:24px}.modal-btn{margin:0 auto;padding:10px 30px;width:auto}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.contact-footer{background:#fff;background:var(--bg-card);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:13px;margin-top:auto;padding:24px 0;text-align:center}.footer-link{color:#6b7280;color:var(--text-medium);transition:color .2s}.footer-link:hover{color:#1976d2;color:var(--primary-blue);text-decoration:underline}@media (max-width:1024px){.contact-container{padding:0 24px}}@media (max-width:768px){.content-grid{gap:24px}.content-grid,.form-row{grid-template-columns:1fr}.contact-container{padding:0 20px}.page-header{padding:40px 0 20px}.header-title{font-size:28px}.header-subtitle{font-size:16px}.contact-card,.faq-link-card,.sidebar-box{padding:24px}}:root{--primary-light:#1976d21a;--secondary-light:#7c3aed1a;--success-color:#16a34a;--success-light:#16a34a1a;--warning-color:#f59e0b;--warning-light:#f59e0b1a;--gray-100:#f3f4f6}.tutorial-page-body{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;min-height:100vh;padding:0}.container{margin:0 auto;max-width:1200px;padding:0 40px}.page-header{background:linear-gradient(135deg,#e8f4f8,#f0e6f6);border-bottom:1px solid #d4e9f0;margin-bottom:48px;padding:40px 0}.header-top{align-items:flex-start;display:flex;gap:32px;justify-content:space-between;margin-bottom:32px}.header-title{color:#1f2937;color:var(--text-dark);font-size:36px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.header-subtitle,.header-title{font-family:Elms Sans,sans-serif}.header-subtitle{color:#6b7280;color:var(--text-medium);font-size:16px;margin:0}.search-wrapper{min-width:320px;position:relative}.search-icon{color:#9ca3af;color:var(--text-light);left:16px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;font-family:Elms Sans,sans-serif;font-size:15px;padding:12px 16px 12px 48px;transition:all .2s ease;width:100%}.search-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.filter-bar{display:flex;flex-wrap:wrap;gap:12px}.filter-chip{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:20px;color:#6b7280;color:var(--text-medium);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.filter-chip:hover{background:#f9fafb}.filter-chip.active,.filter-chip:hover{border-color:#1976d2;border-color:var(--primary-blue)}.filter-chip.active{background:#1976d2;background:var(--primary-blue);color:#fff}.featured-section{margin-bottom:60px}.featured-card{grid-gap:0;background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:grid;gap:0;grid-template-columns:1fr 1fr;overflow:hidden;transition:all .3s ease}.featured-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.featured-video-wrapper{aspect-ratio:16/9;cursor:pointer;overflow:hidden;position:relative}.featured-thumbnail{background-position:50%;background-size:cover;height:100%;width:100%}.play-btn-lg{align-items:center;background:#fffffff2;border-radius:50%;color:#1976d2;color:var(--primary-blue);display:flex;height:80px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:80px}.featured-video-wrapper:hover .play-btn-lg{background:#fff;transform:translate(-50%,-50%) scale(1.1)}.featured-content{display:flex;flex-direction:column;justify-content:center;padding:40px}.featured-label{background:#1976d21a;background:var(--primary-light);border-radius:6px;color:#1976d2;color:var(--primary-blue);display:inline-block;font-size:13px;font-weight:600;margin-bottom:16px;padding:6px 12px;width:-webkit-fit-content;width:fit-content}.featured-title{color:#1f2937;color:var(--text-dark);font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 16px}.featured-desc,.featured-title{font-family:Elms Sans,sans-serif}.featured-desc{color:#6b7280;color:var(--text-medium);font-size:15px;line-height:1.6;margin:0 0 24px}.btn-watch-now{background:#1976d2;background:var(--primary-blue);border:none;border-radius:8px;box-shadow:0 2px 4px #1976d233;color:#fff;cursor:pointer;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.btn-watch-now:hover{background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.grid-section{margin-bottom:60px}.section-title{align-items:center;color:#1f2937;color:var(--text-dark);display:flex;font-family:Elms Sans,sans-serif;font-size:22px;font-weight:600;gap:12px;margin:0 0 24px}.video-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.video-card{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;overflow:hidden;transition:all .3s ease}.video-card:hover{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-thumbnail-wrapper{aspect-ratio:16/9;overflow:hidden;position:relative}.card-img{background-position:50%;background-size:cover;height:100%;transition:transform .3s ease;width:100%}.video-card:hover .card-img{transform:scale(1.05)}.play-overlay{align-items:center;background:#0000004d;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.video-card:hover .play-overlay{opacity:1}.play-icon-sm{align-items:center;background:#fff;border-radius:50%;color:#1976d2;color:var(--primary-blue);display:flex;height:48px;justify-content:center;width:48px}.duration-badge{background:#000c;border-radius:4px;bottom:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 8px;position:absolute;right:12px}.card-body{padding:20px}.card-meta{margin-bottom:8px}.category-badge{background:#f3f4f6;background:var(--gray-100);border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:4px 8px}.card-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0 0 8px}.card-desc{font-size:14px;line-height:1.5;margin:0}.card-desc,.no-results-message{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif}.no-results-message{font-size:16px;padding:60px 20px;text-align:center}.modal-overlay{align-items:center;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-container{background:#fff;background:var(--bg-card);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:1200px;overflow:hidden;position:relative;width:100%}.close-modal{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:48px;z-index:10}.close-modal:hover{background:#000c;transform:scale(1.1)}.video-iframe-container{padding-bottom:56.25%;position:relative;width:100%}.video-iframe-container iframe{border:none;height:100%;left:0;position:absolute;top:0;width:100%}.footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);font-family:Elms Sans,sans-serif;font-size:14px;padding:40px 20px;text-align:center}@media (max-width:1024px){.container{padding:0 24px}.featured-card{grid-template-columns:1fr}.featured-content{padding:32px}.video-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.container{padding:0 20px}.page-header{margin-bottom:32px;padding:30px 0}.header-top{flex-direction:column;gap:20px}.header-title{font-size:28px}.search-wrapper{min-width:0;min-width:auto;width:100%}.featured-title{font-size:22px}.featured-content{padding:24px}.video-grid{grid-template-columns:1fr}.section-title{font-size:20px}}:root{--error-red:#ef4444;--bg-page:#f9fbfc;--font-family-base:"Elms Sans",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--font-size-jumbo:120px;--font-size-3xl:30px;--font-size-lg:18px;--font-size-sm:14px;--space-2:8px;--space-4:16px;--space-6:24px;--space-8:32px;--space-12:48px;--radius-md:8px}body,html{height:100%;margin:0;padding:0}.errorPageBody{-webkit-overflow-scrolling:touch;color:#1f2937;color:var(--text-dark);display:flex;flex-direction:column;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base);height:100%;overflow-y:auto}.errorPageBody,.navbar{background:#f9fbfc;background:var(--bg-page)}.navbar{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:none;position:relative;z-index:100}.navbarContainer{align-items:center;display:flex;justify-content:flex-start;margin:0 auto;max-width:1200px;padding:20px 40px}.navbarLogo{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base);font-size:26px;font-weight:800;letter-spacing:-.5px;text-decoration:none}.logoOsce{color:#1976d2;color:var(--primary-blue)}.logoPal{color:#7c3aed;color:var(--primary-purple)}.mainContainer{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;margin:0 auto;max-width:600px;padding:32px;padding:var(--space-8);text-align:center;width:100%}.errorContent{animation:fadeIn .5s ease-out;margin-bottom:32px;margin-bottom:var(--space-8);width:100%}.errorIllustration{animation:pulse 3s infinite;color:#6b7280;color:var(--text-medium);display:inline-block;font-size:60px}.errorCode,.errorIllustration{margin-bottom:16px;margin-bottom:var(--space-4)}.errorCode{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4c7cff,#997eff);-webkit-background-clip:text;font-size:120px;font-size:var(--font-size-jumbo);font-weight:900;letter-spacing:-5px;line-height:1;opacity:.9}.errorCode.serverError{-webkit-text-fill-color:#ef4444;-webkit-text-fill-color:var(--error-red);background:none;color:#ef4444;color:var(--error-red);opacity:1}.ecgLine{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='300' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 20h30L40 5l10 30 10-15h240' stroke='%23e5e7eb' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:repeat-x;height:40px;margin-bottom:24px;margin-bottom:var(--space-6);opacity:.8;width:100%}.errorTitle{color:#1f2937;color:var(--text-dark);font-size:32px;font-weight:700;margin-bottom:8px;margin-bottom:var(--space-2);margin-top:0}.errorMessage,.errorTitle{font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base)}.errorMessage{color:#6b7280;color:var(--text-medium);font-size:18px;font-size:var(--font-size-lg);line-height:1.6;margin-bottom:32px;margin-bottom:var(--space-8);margin-left:auto;margin-right:auto;max-width:480px}.btnGroup{display:flex;flex-wrap:wrap;gap:16px;gap:var(--space-4);width:100%}.btn,.btnGroup{justify-content:center}.btn{align-items:center;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base);font-size:14px;font-size:var(--font-size-sm);font-weight:600;padding:12px 24px;text-decoration:none;transition:all .2s ease}.btnPrimary{background:#1976d2;background:var(--primary-blue);border:none;box-shadow:0 4px 10px #1976d233;color:#fff}.btnPrimary:hover{background:#1565c0;box-shadow:0 6px 15px #1976d24d;transform:translateY(-1px)}.btnOutline{background:#f9fbfc;background:var(--bg-page);border:1px solid #e5e7eb;border:1px solid var(--border-color)}.btnOutline,.btnOutline:hover{color:#1f2937;color:var(--text-dark)}.btnOutline:hover{background:#f0f0f0;border-color:#6b7280;border-color:var(--text-medium)}.supportInfo{border-top:1px solid #f0f0f0;color:#6b7280;color:var(--text-medium);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base);font-size:14px;font-size:var(--font-size-sm);margin-top:48px;margin-top:var(--space-12);padding-top:24px;padding-top:var(--space-6);width:100%}.requestId{background:#f3f4f6;border-radius:4px;color:#1f2937;color:var(--text-dark);font-family:monospace;padding:2px 6px}.demoToggle{margin-top:16px;margin-top:var(--space-4)}.demoToggle button{background:none;border:none;color:#9ca3af;color:var(--text-light);cursor:pointer;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family-base);font-size:12px;text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}@media (max-width:768px){.navbarContainer{padding:12px 20px}.mainContainer{padding:40px 20px 60px}.errorCode{font-size:80px;letter-spacing:-3px}.errorTitle{font-size:28px}.btnGroup{flex-direction:column;gap:8px;gap:var(--space-2)}.btn{width:100%}}:root{--bg-page:#fff;--bg-card:#fff;--text-dark:#1f2937;--text-medium:#6b7280}.oscepal-page-settings{background:#fff;background:var(--bg-page);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;min-height:100vh;padding:0;position:relative;width:100%}.oscepal-navbar,.oscepal-navbar-settings{background:#fff;background:var(--bg-page);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:none;position:-webkit-sticky;position:sticky;top:0;z-index:100}.oscepal-navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:20px 40px}.oscepal-navbar-logo{color:#1f2937;color:var(--text-dark);cursor:pointer;font-family:Elms Sans,sans-serif;font-size:26px;font-weight:800;letter-spacing:-.5px;text-decoration:none}.logo-osce{color:#1976d2;color:var(--primary-blue)}.logo-pal{color:#7c3aed;color:var(--primary-purple)}.oscepal-navbar-right{align-items:center;display:flex;gap:12px}.mp-profile-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);background:linear-gradient(135deg,var(--primary-blue) 0,#1565c0 100%);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.oscepal-settings-main-container{display:flex;gap:40px;margin:0 auto;max-width:1200px;padding:60px 40px 80px}.oscepal-settings-menu{flex-shrink:0;padding-top:0;width:250px}.oscepal-menu-title{font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.oscepal-menu-item,.oscepal-menu-title{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif}.oscepal-menu-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;margin-bottom:4px;padding:12px 16px;transition:all .2s ease}.oscepal-menu-item:hover{background:#f9fafb}.oscepal-menu-item.active{background:#1976d21a;color:#1976d2;color:var(--primary-blue);font-weight:600}.oscepal-settings-content{flex-grow:1;max-width:800px}.oscepal-settings-panel{background:#fff;background:var(--bg-card);border:1px solid #8ec5ef99;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:24px;padding:32px;transition:all .3s cubic-bezier(.4,0,.2,1)}.oscepal-panel-title{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:24px;padding-bottom:12px}.oscepal-form-group{margin-bottom:24px}.oscepal-form-label{display:block;font-size:14px;font-weight:600;margin-bottom:8px}.oscepal-form-input,.oscepal-form-label{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif}.oscepal-form-input{background:#fff;background:var(--bg-card);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.oscepal-form-input:focus{border-color:#1976d2;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1976d21a;outline:none}.oscepal-form-input:disabled{background:#f9fafb;color:#9ca3af;color:var(--text-light);cursor:not-allowed}.oscepal-form-hint{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;line-height:1.5;margin-top:6px}.oscepal-form-toggle{align-items:center;display:flex;justify-content:space-between;padding:16px 0}.oscepal-toggle-info{flex-grow:1}.oscepal-toggle-title{color:#1f2937;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:16px;font-weight:600;margin-bottom:4px}.oscepal-toggle-description{color:#6b7280;color:var(--text-medium);font-family:Elms Sans,sans-serif;font-size:13px;line-height:1.5}.oscepal-switch{display:inline-block;height:24px;margin-left:16px;position:relative;width:44px}.oscepal-switch input{height:0;opacity:0;width:0}.oscepal-switch-slider{background-color:#ccc;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.oscepal-switch-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}input:checked+.oscepal-switch-slider{background-color:#1976d2;background-color:var(--primary-blue)}input:checked+.oscepal-switch-slider:before{transform:translateX(20px)}.alert{border-radius:8px;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:500;line-height:1.5;margin-bottom:20px;padding:14px 18px}.alert-error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.oscepal-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s ease}.oscepal-btn:disabled{cursor:not-allowed;opacity:.5}.oscepal-btn-primary{background:#1976d2;background:var(--primary-blue);border:none;box-shadow:0 2px 4px #1976d233;color:#fff}.oscepal-btn-primary:hover:not(:disabled){background:#1565c0;box-shadow:0 6px 12px #1976d24d;transform:translateY(-1px)}.oscepal-btn-primary:active:not(:disabled){box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.oscepal-btn-secondary{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);box-shadow:none;color:#6b7280;color:var(--text-medium)}.oscepal-btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.oscepal-settings-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:16px;justify-content:flex-end;margin-top:32px;padding:24px 0 0}@media (max-width:1024px){.oscepal-navbar-container{padding:16px 24px}.oscepal-settings-main-container{padding:48px 24px 60px}}@media (max-width:768px){.oscepal-navbar-container{padding:12px 20px}.oscepal-navbar-logo{font-size:22px}.oscepal-settings-main-container{flex-direction:column;gap:20px;padding:40px 20px 60px}.oscepal-settings-menu{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;gap:8px;overflow-x:auto;padding-bottom:10px;padding-top:0;white-space:nowrap;width:100%}.oscepal-menu-title{display:none}.oscepal-menu-item{flex-shrink:0;margin-bottom:0;margin-right:0;padding:10px 14px}.oscepal-settings-panel{padding:24px 20px}.oscepal-panel-title{font-size:18px}.oscepal-settings-actions{flex-direction:column-reverse}.oscepal-btn{width:100%}}:root{--toast-bg:var(--bg-white);--toast-border:var(--border-card);--toast-text:var(--text-dark);--toast-subtext:var(--text-grey);--toast-primary:var(--primary-blue);--toast-success-bg:#d1fae5;--toast-success-border:#6ee7b7;--toast-success-text:#065f46;--toast-error-bg:#fee2e2;--toast-error-border:#fca5a5;--toast-error-text:#991b1b}.Toastify__toast-container{padding:16px;z-index:9999}.Toastify__toast{background:var(--bg-white);background:var(--toast-bg);border:1px solid var(--toast-border);border-radius:12px;box-shadow:var(--shadow-md);color:var(--text-dark);color:var(--toast-text);font-family:Elms Sans,Inter,sans-serif;min-height:auto;padding:14px 16px}.Toastify__toast-body{font-size:14px;font-weight:500;line-height:1.4;margin:0;padding:0}.Toastify__close-button{color:var(--text-grey);opacity:1}.Toastify__close-button:hover{color:var(--text-dark)}.Toastify__progress-bar{background:var(--primary-blue);background:var(--toast-primary);height:3px}.Toastify__toast--success{background:#d1fae5;background:var(--toast-success-bg);border-color:#6ee7b7;border-color:var(--toast-success-border);color:#065f46;color:var(--toast-success-text)}.Toastify__toast--success .Toastify__progress-bar{background:#10b981}.Toastify__toast--error{background:#fee2e2;background:var(--toast-error-bg);border-color:#fca5a5;border-color:var(--toast-error-border);color:#991b1b;color:var(--toast-error-text)}.Toastify__toast--error .Toastify__progress-bar{background:#ef4444}.Toastify__toast--warning{background:#fef3c7;border-color:#fcd34d;color:#92400e}.Toastify__toast--warning .Toastify__progress-bar{background:#f59e0b}.Toastify__toast--info{background:#1976d214;border-color:#1976d240;color:#1565c0}.Toastify__toast--info .Toastify__progress-bar{background:var(--primary-blue)}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px}@media (max-width:480px){.Toastify__toast{border-radius:10px;padding:12px 14px}.Toastify__toast-body{font-size:13px}}:root{--primary-blue:#1976d2;--primary-purple:#7c3aed;--bg-page:#f4f6f8;--bg-surface:#fff;--bg-light-accent:#e3f2fd;--error:#dc2626;--error-bg:#fee2e2;--text-dark:#111827;--text-grey:#6b7280;--text-light:#9ca3af;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.legal-page{background:#f4f6f8;background:var(--bg-page);color:#111827;color:var(--text-dark);display:flex;flex-direction:column;font-family:Elms Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;min-height:100vh}.legal-content{flex:1 1;padding:40px 20px 80px}.legal-container{background:#fff;background:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin:0 auto;max-width:900px;padding:56px 48px}.legal-header{background:linear-gradient(135deg,#e3f2fd,#f0e6f6);background:linear-gradient(135deg,var(--bg-light-accent) 0,#f0e6f6 100%);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:56px 20px 40px;text-align:center}.legal-header-container{margin:0 auto;max-width:1200px}.legal-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif;font-size:clamp(32px,5vw,48px);font-weight:800;letter-spacing:-.5px;margin-bottom:12px}.legal-subtitle{color:#6b7280;color:var(--text-grey);font-size:14px;font-weight:500;letter-spacing:.2px}.legal-section{margin-bottom:48px;scroll-margin-top:120px}.legal-section:last-child{margin-bottom:0}.legal-section-title{align-items:center;border-left:4px solid #1976d2;border-left:4px solid var(--primary-blue);display:flex;font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:24px;padding-left:16px}.legal-section-title,.legal-subsection-title{color:#111827;color:var(--text-dark);font-family:Elms Sans,sans-serif}.legal-subsection-title{font-size:18px;font-weight:700;letter-spacing:-.3px;margin:28px 0 16px}.legal-text{color:#6b7280;color:var(--text-grey);font-size:15px;line-height:1.7;margin-bottom:16px}.legal-list{margin:16px 0 20px;padding-left:24px}.legal-list li{color:#6b7280;color:var(--text-grey);font-size:15px;line-height:1.7;margin-bottom:12px}.legal-list strong{color:#111827;color:var(--text-dark);font-weight:700}.legal-note{background-color:#f9fafb;border-left:4px solid;border-radius:8px;font-size:14px;margin:24px 0;padding:20px}.legal-note strong{color:#111827;color:var(--text-dark);display:block;font-weight:700;margin-bottom:6px}.legal-note-info{background:#eff6ff;border-left-color:#0ea5e9;color:#1e40af}.legal-note-warning{background:#fffbeb;border-left-color:#f59e0b;color:#92400e}.legal-note-error{background:#fee2e2;border-left-color:#dc2626;border-left-color:var(--error);color:#7f1d1d}.legal-contact{background:linear-gradient(135deg,#f0fdf4,#f0f9ff);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;margin:24px 0;padding:24px}.legal-contact p{color:#6b7280;color:var(--text-grey);font-size:15px;margin-bottom:10px}.legal-contact strong{color:#111827;color:var(--text-dark);font-weight:700}.legal-link{border-bottom:1px solid #0000;color:#1976d2;color:var(--primary-blue);font-weight:600;letter-spacing:.1px;text-decoration:none;transition:all .2s ease}.legal-link:hover{border-bottom-color:#1976d2;border-bottom-color:var(--primary-blue)}.legal-acknowledgment{background:linear-gradient(135deg,#eff6ff,#f0e6f6);border:2px solid #1976d2;border:2px solid var(--primary-blue);border-radius:8px;margin-top:56px;padding:40px;text-align:center}.legal-acknowledgment .legal-section-title{border:none;color:#1976d2;color:var(--primary-blue);font-size:24px;justify-content:center;padding:0}.legal-acknowledgment .legal-text{color:#111827;color:var(--text-dark);font-size:15px;font-weight:600;letter-spacing:.2px;text-align:center}.legal-footer{background:#fff;background:var(--bg-surface);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);margin-top:auto;padding:40px 20px}.legal-footer-container{margin:0 auto;max-width:1200px}.legal-footer-links{display:flex;gap:24px;justify-content:center;margin-bottom:16px}.legal-footer-link{color:#6b7280;color:var(--text-grey);font-size:13px;font-weight:600;letter-spacing:.1px;text-decoration:none;transition:color .2s ease}.legal-footer-link:hover{color:#1976d2;color:var(--primary-blue)}.legal-footer-separator{color:#e5e7eb;color:var(--border-color);font-weight:300}.legal-footer-text{color:#9ca3af;color:var(--text-light);font-size:13px;letter-spacing:.1px;text-align:center}@media (max-width:1024px){.legal-container{padding:40px 32px}.legal-section-title{font-size:24px}}@media (max-width:768px){.legal-container{border-radius:8px;padding:32px 24px}.legal-header{padding:40px 16px 32px}.legal-title{font-size:32px}.legal-section-title{border-left-width:3px;font-size:22px;padding-left:12px}.legal-subsection-title{font-size:16px;margin:20px 0 12px}.legal-list li,.legal-text{font-size:14px}.legal-note{font-size:13px;padding:16px}.legal-acknowledgment{margin-top:40px;padding:32px 24px}.legal-footer-links{align-items:center;flex-direction:column;gap:12px}.legal-footer-separator{display:none}}@media (max-width:480px){.legal-content{padding:20px 12px 48px}.legal-container{border-radius:6px;padding:24px 16px}.legal-title{font-size:26px}.legal-section-title{font-size:18px}.legal-list li,.legal-text{font-size:13px}}.footer{background:linear-gradient(135deg,#ffe5d9,#e0f2fe);color:#000;margin-top:0;overflow:hidden;padding:80px 40px 40px;position:relative}.footer-background-text{bottom:0;color:#00000008;font-family:Stack Sans Notch,sans-serif;font-size:clamp(240px,40vw,600px);font-weight:700;left:50%;letter-spacing:-20px;margin-bottom:-300px;overflow:hidden;pointer-events:none;position:absolute;text-align:center;transform:translateX(-50%);white-space:nowrap;width:100vw;z-index:0}.footer-background-text:after{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(180deg,#0000,#ffe5d9cc);bottom:0;content:"";height:200px;left:0;pointer-events:none;position:absolute;right:0}.footer-container{margin:0 auto;max-width:1400px;position:relative;z-index:1}.footer-top{grid-gap:80px;border-bottom:1px solid #0000001a;display:grid;gap:80px;grid-template-columns:1fr 2fr;margin-bottom:60px;padding-bottom:60px}.footer-left{display:flex;flex-direction:column;gap:24px}.footer-brand-section{align-items:flex-start;display:flex;gap:16px}.footer-logo-img{flex-shrink:0;height:56px;object-fit:contain;transition:all .3s cubic-bezier(.4,0,.2,1);width:auto}.footer-brand-section:hover .footer-logo-img{opacity:.9;transform:scale(1.05)}.footer-brand-text-container{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.footer-brand-name{color:#1976d2;font-family:Elms Sans,sans-serif;font-size:25px;font-weight:700;letter-spacing:-.5px;line-height:1.2}.footer-powered-by{color:#1d1d1d;font-family:Elms Sans,sans-serif;font-size:11px;font-weight:400;letter-spacing:.3px;line-height:1;margin-top:-3px;text-transform:lowercase}.footer-headline{color:#000;font-family:Stack Sans Notch,sans-serif;font-size:32px;font-weight:700;letter-spacing:-1px;line-height:1.2;margin:0}.footer-social-row{align-items:center;display:flex;gap:16px;margin-top:8px}.footer-social-icon{align-items:center;background:#0000000d;border:1px solid #0000001a;border-radius:8px;color:#000;display:flex;height:40px;justify-content:center;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);width:40px}.footer-social-icon:hover{background:#0000001a;border-color:#0003;transform:translateY(-2px)}.footer-right{grid-gap:60px;display:grid;gap:60px;grid-template-columns:repeat(3,1fr)}.footer-column{display:flex;flex-direction:column;gap:16px}.footer-column-title{color:#000;font-weight:700;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.footer-column-title,.footer-link{font-family:Elms Sans,sans-serif;font-size:14px}.footer-link{color:#000000b3;cursor:pointer;font-weight:400;text-decoration:none;transition:color .3s cubic-bezier(.4,0,.2,1)}.footer-link:hover{color:#000}.footer-bottom{align-items:center;display:flex;justify-content:space-between;padding-top:20px}.footer-copyright{color:#0009;font-family:Elms Sans,sans-serif;font-size:14px;font-weight:400}.footer-copyright p{margin:0}.footer-chat-button{align-items:center;background:#0000001a;border:1px solid #0003;border-radius:50%;color:#000;cursor:pointer;display:flex;height:48px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:48px}.footer-chat-button:hover{background:#00000026;transform:scale(1.05)}@media (max-width:1024px){.footer-background-text{font-size:150px}.footer-top{gap:50px;grid-template-columns:1fr}.footer-right{gap:40px;grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.footer{margin-top:0;padding:60px 24px 30px}.footer-background-text{font-size:100px}.footer-top{gap:40px;margin-bottom:40px;padding-bottom:40px}.footer-right{gap:32px;grid-template-columns:1fr}.footer-headline{font-size:28px}.footer-bottom{align-items:flex-start;flex-direction:column;gap:20px}}@media (max-width:480px){.footer{padding:50px 20px 24px}.footer-background-text{font-size:80px}.footer-headline{font-size:24px}.footer-cta-button{justify-content:center;width:100%}.footer-social-row{flex-wrap:wrap}}