:root{--bp-mobile: 480px;--bp-tablet: 768px}:root{--font-display: "Fraunces", Georgia, serif;--font-body: "Plus Jakarta Sans", system-ui, sans-serif;--color-bg: #faf7f2;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text: #1a1814;--color-text-secondary: #6b645a;--color-text-muted: #736b62;--color-border: #e8e3db;--color-border-light: #f0ece5;--color-accent: #ad4b1e;--color-accent-hover: #8e3c15;--color-accent-dark: #7a3415;--color-accent-subtle: rgba(173, 75, 30, .08);--color-success: #2d6a4f;--color-success-subtle: rgba(45, 106, 79, .08);--color-error: #b83232;--color-error-subtle: rgba(184, 50, 50, .07);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 2px rgba(26, 24, 20, .04);--shadow-md: 0 4px 16px rgba(26, 24, 20, .06), 0 1px 4px rgba(26, 24, 20, .04);--shadow-lg: 0 12px 40px rgba(26, 24, 20, .08), 0 2px 8px rgba(26, 24, 20, .04);--shadow-focus: 0 0 0 3px rgba(173, 75, 30, .2);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--callout-note-border: #2d6a4f;--callout-note-bg: rgba(45, 106, 79, .06);--callout-note-icon: #2d6a4f;--callout-warning-border: #c87c00;--callout-warning-bg: rgba(200, 124, 0, .06);--callout-warning-icon: #c87c00;--callout-tip-border: var(--color-accent);--callout-tip-bg: var(--color-accent-subtle);--callout-tip-icon: var(--color-accent);--callout-important-border: var(--color-error);--callout-important-bg: var(--color-error-subtle);--callout-important-icon: var(--color-error);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 2rem;--text-3xl: 2.5rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;font-size:15px;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.3;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-100%;left:16px;z-index:10000;padding:12px 24px;background:var(--color-text);color:var(--color-surface);font-family:var(--font-body);font-size:14px;font-weight:600;border-radius:var(--radius-md);text-decoration:none;transition:top .2s ease}.skip-link:focus{top:16px}h1{font-family:var(--font-display);font-size:32px;font-weight:600;font-optical-sizing:auto;letter-spacing:-.02em;line-height:1.2;margin-bottom:8px;color:var(--color-text)}h2{font-family:var(--font-display);font-size:24px;font-weight:500;font-optical-sizing:auto;letter-spacing:-.01em;line-height:1.3;margin-bottom:12px;color:var(--color-text)}p{margin-bottom:16px;color:var(--color-text-secondary);line-height:1.65}.tagline{font-size:15px;color:var(--color-text-muted);margin-bottom:36px;font-weight:400;letter-spacing:.01em}.brand-mark{font-family:var(--font-display);font-weight:700;font-size:36px;letter-spacing:-.03em;color:var(--color-text);line-height:1;margin-bottom:4px}.brand-mark .brand-dot{color:var(--color-accent)}.toggle-group{display:flex;gap:0;margin-bottom:24px;background:var(--color-bg);border-radius:var(--radius-md);padding:4px;border:1px solid var(--color-border-light)}.toggle-option{flex:1;padding:10px 20px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s var(--ease-out);text-align:center;position:relative}.toggle-option:hover:not(.active):not(:disabled){color:var(--color-text)}.toggle-option.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm);font-weight:600}.toggle-option:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.badge{display:inline-flex;align-items:center;padding:5px 14px;border-radius:100px;font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;background:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.badge.primary{background:var(--color-accent-subtle);color:var(--color-accent);border-color:#ad4b1e26}.error-message{padding:14px 18px;background:var(--color-error-subtle);border:1px solid rgba(184,50,50,.15);border-radius:var(--radius-md);color:var(--color-error);font-size:14px;font-weight:500;margin-bottom:24px;animation:messageEnter .3s var(--ease-out) both}.success-message{padding:14px 18px;background:var(--color-success-subtle);border:1px solid rgba(45,106,79,.15);border-radius:var(--radius-md);color:var(--color-success);font-size:14px;font-weight:500;margin-bottom:24px;animation:messageEnter .3s var(--ease-out) both}@keyframes messageEnter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.link{color:var(--color-accent);text-decoration:underline;text-decoration-color:transparent;text-underline-offset:3px;font-size:14px;font-weight:500;transition:color .15s ease,text-decoration-color .15s ease}.link:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent-hover)}.link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.divider{height:1px;background:var(--color-border-light);margin:24px 0;border:none}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:focus{outline:none}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.input:focus-visible{outline:none}.email-highlight{font-weight:600;color:var(--color-text)}.email-expiry{font-size:13px;color:var(--color-text-muted);margin-bottom:0}.email-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--color-accent-subtle);margin:0 auto 24px;font-size:28px;animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1);box-shadow:0 0 #ad4b1e1a}50%{transform:scale(1.03);box-shadow:0 0 0 12px #ad4b1e00}}.verify-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--color-bg)}.verify-container{max-width:600px;width:100%;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:48px;box-shadow:var(--shadow-lg);text-align:center;animation:cardEnter .6s var(--ease-out) both}.verify-branding{margin-bottom:40px}.verify-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;margin:0 auto 24px;font-size:42px;font-weight:700}.verify-icon.valid{background:var(--color-success-subtle);color:var(--color-success);border:2px solid rgba(45,106,79,.2)}.verify-icon.expired,.verify-icon.error{background:var(--color-error-subtle);color:var(--color-error);border:2px solid rgba(184,50,50,.2)}.verify-status h1{font-size:28px;margin-bottom:32px}.verify-status.valid h1{color:var(--color-success)}.verify-status.expired h1{color:var(--color-error)}.verify-details{display:flex;flex-direction:column;gap:24px;margin-top:32px;padding-top:32px;border-top:1px solid var(--color-border-light);text-align:left}.verify-holder,.verify-training,.verify-date{display:flex;flex-direction:column;gap:6px}.verify-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.verify-value{font-size:16px;font-weight:600;color:var(--color-text);font-family:var(--font-display)}.verify-footer{margin-top:40px;padding-top:24px;border-top:1px solid var(--color-border-light)}.verify-footer p{font-size:13px;color:var(--color-text-muted);margin:0}.verify-loading,.verify-error,.verify-not-found{text-align:center;padding:48px 24px}.verify-loading{color:var(--color-text-secondary);font-size:15px}.verify-error h1,.verify-not-found h1{font-size:24px;margin-bottom:12px}.verify-error p,.verify-not-found p{color:var(--color-text-secondary);font-size:15px;margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 28px;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s var(--ease-out);text-decoration:none;text-align:center;position:relative;overflow:hidden;letter-spacing:.01em}.btn-primary{background:var(--color-accent);color:#fff;width:100%;box-shadow:0 2px 8px #ad4b1e33}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:0 4px 16px #ad4b1e40;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #ad4b1e33}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:focus-visible{outline:2px solid var(--color-text);outline-offset:2px}.btn-secondary{background:transparent;color:var(--color-accent);border:1.5px solid var(--color-border)}.btn-secondary:hover:not(:disabled){border-color:var(--color-accent);background:var(--color-accent-subtle)}.form-group{margin-bottom:24px;animation:fieldEnter .5s var(--ease-out) both}.form-group:nth-child(1){animation-delay:.1s}.form-group:nth-child(2){animation-delay:.15s}.form-group:nth-child(3){animation-delay:.2s}@keyframes fieldEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--color-text);letter-spacing:.02em;text-transform:uppercase}.input{width:100%;padding:14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:15px;color:var(--color-text);background:var(--color-surface);transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.input:hover{border-color:#d0c9bf}.input:focus{outline:none;border-color:var(--color-accent);box-shadow:var(--shadow-focus);background:#fffdfb}.input::placeholder{color:var(--color-text-muted);font-weight:400}.input:disabled{opacity:.6;cursor:not-allowed;background:var(--color-bg)}.input[aria-invalid=true]{border-color:var(--color-error);box-shadow:0 0 0 3px #b832321a}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:40px;width:100%;max-width:440px;position:relative;animation:cardEnter .6s var(--ease-out) both}.card-wide{max-width:600px}@keyframes cardEnter{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.container{max-width:1120px;margin:0 auto;padding:0 24px}.page-center{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;position:relative}.page-center:before{content:"";position:fixed;top:-20%;right:-10%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(173,75,30,.04) 0%,transparent 70%);pointer-events:none}.page-center:after{content:"";position:fixed;bottom:-15%;left:-5%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(45,106,79,.03) 0%,transparent 70%);pointer-events:none}.header{background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);padding:0;position:sticky;top:0;z-index:100;animation:headerSlide .5s var(--ease-out) both}@keyframes headerSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.header-content{display:flex;justify-content:space-between;align-items:center;height:64px}.header-brand{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.header-brand .brand-dot{color:var(--color-accent)}.header-actions{display:flex;align-items:center;gap:20px}.header-user{font-size:13px;color:var(--color-text-muted);font-weight:500}.btn-logout{padding:8px 18px;font-family:var(--font-body);font-size:13px;font-weight:500;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.btn-logout:hover{color:var(--color-text);border-color:var(--color-text-muted);background:var(--color-bg)}.build-footer{text-align:center;padding:12px;font-size:.7rem;color:var(--color-text-muted, #bbb);font-family:var(--font-mono, monospace)}#main-content:has(.training-player)~.build-footer{display:none}.btn-logout:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.login-footer{text-align:center;margin-top:24px;font-size:13px;color:var(--color-text-muted)}.login-legal-text a{color:var(--color-text-secondary);text-decoration:underline}.login-legal-text a:hover{color:var(--color-accent)}.login-legal-text a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.login-copyright{margin-top:8px;font-size:12px}main{padding:48px 0 64px;animation:contentEnter .6s var(--ease-out) .2s both}@keyframes contentEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.header-nav{display:flex;align-items:center;gap:4px}.header-nav-link{padding:6px 12px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:color .15s ease,background-color .15s ease;white-space:nowrap}.header-nav-link:hover{color:var(--color-text);background:var(--color-bg)}.header-nav-link.active{color:var(--color-accent);font-weight:600}.header-nav-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.header-hamburger{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:0;border-radius:var(--radius-sm);transition:background-color .15s ease}.header-hamburger:hover{background:var(--color-bg)}.header-hamburger:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.hamburger-line{display:block;width:22px;height:2px;background:var(--color-text);border-radius:1px;transition:background-color .15s ease}.header-desktop-nav,.header-actions{display:none}.header-content{height:56px}@media(min-width:481px){.card{padding:28px 24px;border-radius:var(--radius-lg)}}@media(min-width:769px){.header-hamburger{display:none}.header-desktop-nav,.header-actions{display:flex}.header-content{height:64px}}.mobile-drawer-backdrop{position:fixed;inset:0;background:#1a181480;z-index:900;animation:drawerBackdropEnter .2s ease both}.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(320px,85vw);background:var(--color-cream, #faf7f2);z-index:910;display:flex;flex-direction:column;box-shadow:-4px 0 24px #1a18141f;animation:drawerSlideIn .25s var(--ease-out) both}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media(prefers-reduced-motion:reduce){.mobile-drawer{animation:drawerFadeIn .15s ease both}.mobile-drawer-backdrop{animation:none;opacity:1}@keyframes drawerFadeIn{0%{opacity:0}to{opacity:1}}}.mobile-drawer-header{display:flex;justify-content:flex-end;padding:16px 20px 8px}.mobile-drawer-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:color .15s ease,background-color .15s ease}.mobile-drawer-close:hover{color:var(--color-text);background:var(--color-bg)}.mobile-drawer-close:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.mobile-drawer-nav{flex:1;display:flex;flex-direction:column;padding:8px 16px;gap:2px;overflow-y:auto}.mobile-drawer-link{display:flex;align-items:center;min-height:44px;padding:10px 16px;font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:color .15s ease,background-color .15s ease}.mobile-drawer-link:hover{color:var(--color-text);background:var(--color-bg)}.mobile-drawer-link.active{color:var(--color-accent);font-weight:600;background:var(--color-accent-subtle);border-left:3px solid var(--color-accent)}.mobile-drawer-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.mobile-drawer-footer{display:flex;flex-direction:column;gap:12px;padding:16px 20px 24px;border-top:1px solid var(--color-border-light)}.mobile-drawer-email{font-size:13px;color:var(--color-text-muted);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-drawer-signout{display:flex;align-items:center;justify-content:center;min-height:44px;padding:10px 18px;font-family:var(--font-body);font-size:14px;font-weight:500;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.mobile-drawer-signout:hover{color:var(--color-text);border-color:var(--color-text-muted);background:var(--color-bg)}.mobile-drawer-signout:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(min-width:769px){.mobile-drawer-backdrop,.mobile-drawer{display:none}}.shame-banner{background:var(--color-error-subtle);border-bottom:1px solid rgba(184,50,50,.2);position:sticky;top:56px;z-index:90;animation:messageEnter .3s var(--ease-out) both}.shame-banner-content{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:12px 16px;min-height:52px}.shame-icon{font-size:18px;flex-shrink:0;color:var(--color-error);line-height:1}.shame-text{flex:1;font-size:14px;font-weight:500;color:var(--color-error);line-height:1.4}.shame-action-btn{background:var(--color-error);color:#fff;border:none;padding:8px 18px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s var(--ease-out);box-shadow:0 2px 6px #b8323233;width:100%;text-align:center}.shame-action-btn:hover:not(:disabled){background:#9a2929;box-shadow:0 3px 10px #b832324d;transform:translateY(-1px)}.shame-action-btn:focus-visible{outline:2px solid var(--color-text);outline-offset:2px}.shame-banner~* .progress-bar-container{top:108px}@media(min-width:769px){.shame-banner{top:64px}.shame-banner-content{flex-direction:row;align-items:center;gap:12px;padding:12px 24px;flex-wrap:wrap}.shame-action-btn{width:auto;text-align:left}.shame-banner~* .progress-bar-container{top:116px}}.onboarding-shell-brand{margin-top:48px;margin-bottom:16px;text-align:center}.step-dots{display:flex;justify-content:center;gap:8px;margin-bottom:16px}.step-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--color-border);background:transparent;transition:all .2s ease}.step-dot.active,.step-dot.completed{background:var(--color-accent);border-color:var(--color-accent)}.login-confirm-state{animation:loginFadeIn .3s ease both}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.text-muted{color:var(--color-text-muted);font-size:13px}.btn-full-width{width:100%}.form-footer-action{margin-top:16px;text-align:center;margin-bottom:0}.form-footer-link{margin-top:16px;font-size:13px;color:var(--color-text-secondary);text-align:center}.onboarding-choice-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:24px 20px;margin-bottom:32px;box-shadow:var(--shadow-sm);animation:cardEnter .4s var(--ease-out) both}@keyframes cardEnter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.onboarding-choice-card.celebrating{text-align:center;animation:celebrationPulse .5s var(--ease-out) both}@keyframes celebrationPulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1);opacity:.95}}.onboarding-card-celebration{padding:20px 0}.celebration-check{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--color-success-subtle);color:var(--color-success);font-size:24px;margin-bottom:12px}.onboarding-card-celebration h3{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--color-text);margin-bottom:4px}.onboarding-card-celebration p{color:var(--color-text-secondary);font-size:15px}.onboarding-card-header h3{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--color-text);margin-bottom:20px}.onboarding-actions{display:grid;grid-template-columns:1fr;gap:16px}.onboarding-actions.single{grid-template-columns:1fr;max-width:none}.onboarding-action{display:flex;align-items:center;gap:14px;padding:18px 20px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:var(--color-text);transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out),background .2s var(--ease-out),opacity .3s var(--ease-out);position:relative;cursor:pointer}.onboarding-action:hover{border-color:var(--color-accent);box-shadow:0 2px 8px #ad4b1e14;background:var(--color-surface)}.onboarding-action:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.onboarding-action.action-completed{opacity:.55;background:var(--color-success-subtle);border-color:#2d6a4f26;pointer-events:none}.onboarding-action.action-prominent{border-color:var(--color-accent);box-shadow:0 2px 12px #ad4b1e1a;background:var(--color-surface)}.action-checkmark{position:absolute;top:10px;right:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-success-subtle);color:var(--color-success);font-size:13px;font-weight:700}.onboarding-action-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:var(--color-accent-subtle);color:var(--color-accent);font-size:18px;flex-shrink:0}.action-completed .onboarding-action-icon{background:var(--color-success-subtle);color:var(--color-success)}.onboarding-action-content h4{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--color-text);margin-bottom:2px}.onboarding-action-content p{font-size:13px;color:var(--color-text-muted);line-height:1.4}.onboarding-action-arrow{margin-left:auto;color:var(--color-accent);font-size:18px;flex-shrink:0;transition:transform .2s var(--ease-out)}.onboarding-action:hover .onboarding-action-arrow{transform:translate(3px)}@media(min-width:481px){.onboarding-choice-card{padding:32px 36px}.onboarding-actions{grid-template-columns:1fr 1fr}.onboarding-actions.single{grid-template-columns:1fr;max-width:480px}}@media(prefers-reduced-motion:reduce){.onboarding-choice-card,.onboarding-choice-card.celebrating{animation:none}.onboarding-action-arrow{transition:none}}.welcome-section{margin-bottom:40px}.welcome-section h1{margin-bottom:4px}.welcome-meta{font-size:.875rem;color:var(--color-text-secondary, #666);margin-bottom:12px}.account-info{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.placeholder-card{padding:64px 40px;text-align:center;background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);transition:border-color .2s ease}.placeholder-card:hover{border-color:var(--color-text-muted)}.placeholder-card h2{color:var(--color-text);margin-bottom:8px}.placeholder-card p{color:var(--color-text-muted);margin-bottom:0;font-size:14px}.modules-section{margin-top:24px}.modules-section h2{margin-bottom:24px;font-size:20px}.module-list{display:flex;flex-direction:column;gap:16px}.module-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s var(--ease-out),border-color .2s var(--ease-out)}.module-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.module-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:16px}.module-title-area{flex:1}.module-card h3{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-text);margin-bottom:4px;letter-spacing:-.01em}.module-duration{font-size:13px;color:var(--color-text-muted);margin-bottom:0}.module-freshness{font-size:13px;color:color-mix(in srgb,var(--color-accent) 60%,var(--color-text-muted));margin-bottom:0}.module-description{color:var(--color-text-secondary);font-size:14px;line-height:1.6;margin-bottom:16px}.module-footer{display:flex;justify-content:flex-end}.status-badge{display:inline-flex;align-items:center;padding:5px 12px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.status-badge.not-started{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.status-badge.in-progress{background:#ffa00014;color:#c87c00;border:1px solid rgba(255,160,0,.15)}.status-badge.completed{background:var(--color-success-subtle);color:var(--color-success);border:1px solid rgba(45,106,79,.15)}.btn-module{display:inline-flex;align-items:center;padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:14px;font-weight:600;background:var(--color-accent);color:#fff;border:none;text-decoration:none;cursor:pointer;transition:all .2s var(--ease-out);box-shadow:0 2px 8px #ad4b1e26}.btn-module:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:0 4px 12px #ad4b1e33;transform:translateY(-1px)}.btn-module:disabled{opacity:.4;cursor:not-allowed;background:var(--color-text-muted)}.btn-module.completed-btn{background:transparent;color:var(--color-accent);border:1.5px solid var(--color-border);box-shadow:none}.btn-module.completed-btn:hover{border-color:var(--color-accent);background:var(--color-accent-subtle)}.module-skeleton{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:24px;animation:pulse 1.5s ease-in-out infinite}.skeleton-line{height:20px;background:var(--color-bg);border-radius:4px;margin-bottom:12px}.skeleton-line.short{width:60%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.dashboard-skeleton{padding:0}.skeleton-welcome{margin-bottom:40px}.continue-hero{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:24px;text-decoration:none;margin-bottom:32px;transition:box-shadow .2s ease,border-color .2s ease}.continue-hero:hover{border-color:var(--color-accent);box-shadow:0 2px 8px #0000000f}.continue-hero-content{display:flex;flex-direction:column;gap:4px}.continue-hero-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent)}.continue-hero-title{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:1.25rem}.continue-hero-progress{color:var(--color-text-secondary);font-size:14px}.continue-hero-arrow{font-size:24px;color:var(--color-accent);transition:transform .2s ease;flex-shrink:0;margin-left:16px}.continue-hero:hover .continue-hero-arrow{transform:translate(4px)}.training-blocked-wrapper{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.training-blocked{opacity:.4!important;cursor:not-allowed!important}.training-blocked-msg{font-size:12px;color:var(--color-error);font-weight:500}.training-blocked-portal-link{display:inline-block;margin-top:var(--space-sm);padding:var(--space-xs) var(--space-md);font-size:var(--text-sm);font-family:inherit;color:var(--color-accent, #ad4b1e);background:none;border:1px solid var(--color-accent, #ad4b1e);border-radius:var(--radius-md, 8px);cursor:pointer;transition:background-color .2s,color .2s}.training-blocked-portal-link:hover{background:var(--color-accent, #ad4b1e);color:#fff}.training-blocked-portal-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.training-blocked-help{display:block;margin-top:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-secondary, #666)}.module-card{padding:16px}.module-header{flex-direction:column;align-items:flex-start}.cert-card{padding:16px}.cert-card-header{flex-direction:column;align-items:flex-start;gap:8px}.welcome-section{margin-bottom:24px}.training-blocked-wrapper{align-items:flex-start}.continue-hero{padding:16px}.skeleton-welcome{margin-bottom:24px}.module-skeleton{padding:16px}.placeholder-card{padding:40px 20px}@media(min-width:481px){.module-card{padding:24px}.module-header{flex-direction:row;align-items:flex-start;justify-content:space-between}.cert-card{padding:20px 24px}.cert-card-header{flex-direction:row;align-items:center}.welcome-section{margin-bottom:40px}.training-blocked-wrapper{align-items:flex-end}.continue-hero{padding:24px}.skeleton-welcome{margin-bottom:40px}.module-skeleton{padding:24px}.placeholder-card{padding:64px 40px}}.training-player{height:calc(100vh - 56px);height:calc(100dvh - 56px);display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg)}.progress-bar-container{position:sticky;top:56px;z-index:50;background:var(--color-surface);border-bottom:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.progress-bar-wrapper{max-width:1120px;margin:0 auto;padding:8px 12px}@media(min-width:481px){.progress-bar-wrapper{padding:16px 24px}}.progress-bar-track{position:relative;width:100%;height:8px;background:var(--color-bg);border-radius:100px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:var(--color-accent);border-radius:100px;transition:width .3s var(--ease-out)}.progress-bar-text{display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;gap:4px;font-size:11px;color:var(--color-text-secondary);font-weight:500}.progress-bar-text>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}@media(min-width:481px){.progress-bar-text{font-size:13px;flex-wrap:wrap}.progress-bar-text>span:first-child{overflow:visible;text-overflow:unset;white-space:normal;min-width:auto}}.progress-bar-right{display:flex;align-items:center;gap:8px}.progress-completion-badge{font-weight:600;font-size:13px;color:var(--color-text-secondary)}.progress-completion-badge--complete{color:var(--color-success)}.slide-container{flex:1;min-height:0;overflow-y:auto;max-width:800px;margin:0 auto;padding:16px 12px;width:100%}.module-name-row{display:none;flex-direction:column;align-items:flex-start;gap:4px;padding-bottom:0;border-bottom:none;margin-bottom:0}.module-name{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--color-text);margin:0;line-height:1.3;display:none}.module-name-time{display:none;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}@media(min-width:481px){.module-name-row{display:flex;flex-direction:row;align-items:baseline;justify-content:space-between;gap:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border-light);margin-bottom:8px}.module-name{display:block}.module-name-time{display:flex}}.progress-bar-row{display:flex;align-items:center;flex-wrap:nowrap;gap:8px}@media(min-width:481px){.progress-bar-row{flex-wrap:wrap;gap:12px}}.progress-bar-row>.progress-bar-container{flex:1;min-width:0}.module-time-estimate{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}.mode-toggle{display:inline-flex;margin:0;padding:0;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;font-family:var(--font-body);font-size:12px;font-weight:600;flex-shrink:0}@media(min-width:481px){.mode-toggle{font-size:13px}.mode-toggle__option{padding:6px 14px}}.mode-toggle__option{padding:5px 10px;cursor:pointer;background:var(--color-surface);color:var(--color-text-secondary);border:none;transition:all .2s var(--ease-out)}.mode-toggle__option--active{background:var(--color-accent);color:#fff}.mode-toggle__option:not(.mode-toggle__option--active):hover{background:var(--color-accent-subtle);color:var(--color-accent)}.auto-highlight-toggle{display:none;align-items:center;gap:5px;padding:5px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s var(--ease-out);flex-shrink:0;white-space:nowrap}@media(min-width:481px){.auto-highlight-toggle{display:inline-flex}}.auto-highlight-toggle--active{border-color:var(--color-accent);color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 6%,var(--color-surface))}.auto-highlight-toggle:not(.auto-highlight-toggle--active):hover{border-color:var(--color-text-muted);color:var(--color-text)}.auto-highlight-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes term-auto-glow{0%{box-shadow:0 0 8px color-mix(in srgb,var(--hl-color) 50%,transparent)}to{box-shadow:none}}.transcript-block{margin-top:24px;padding:20px 24px;background:var(--color-accent-subtle);border-left:3px solid var(--color-accent);border-radius:0 var(--radius-md) var(--radius-md) 0}.transcript-block__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);margin-bottom:8px}.transcript-block__text{font-size:15px;line-height:1.7;color:var(--color-text)}.transcript-panel{position:sticky;bottom:0;flex-shrink:0;background:var(--color-surface);border-top:1px solid var(--color-border-light);padding:16px 24px;box-shadow:0 -4px 16px #1a18140a;z-index:50}.transcript-panel__inner{max-width:800px;margin:0 auto}.transcript-timer{display:flex;flex-direction:column;gap:6px}.transcript-timer__header{display:flex;justify-content:space-between;align-items:center}.transcript-timer__label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted)}.transcript-timer__bar{width:100%;height:6px;background:var(--color-bg);border-radius:100px;overflow:hidden}.transcript-timer__fill{height:100%;background:var(--color-accent);border-radius:100px;transition:width 1s linear}@media(prefers-reduced-motion:reduce){.transcript-timer__fill{transition:none}}.transcript-timer__text{font-size:13px;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.training-player-layout{display:flex;flex:1;min-height:0;height:100%;overflow:hidden}.training-player-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.section-transition{max-width:800px;margin:0 auto;padding:48px 24px;text-align:center;animation:sectionTransitionEnter .5s var(--ease-out) both;width:100%;box-sizing:border-box}.section-transition__card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:40px 32px;box-shadow:var(--shadow-sm)}.section-transition__check{font-size:32px;margin-bottom:12px;color:var(--color-accent)}.section-transition__title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--color-text);margin-bottom:8px}.section-transition__subtitle{font-family:var(--font-body);font-size:14px;color:var(--color-text-secondary);margin-bottom:24px}.section-transition__cta{display:inline-block;padding:10px 24px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:600;transition:all .2s}.section-transition__cta:hover{background:var(--color-accent-hover);transform:translateY(-1px)}@keyframes sectionTransitionEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.section-transition__card,.section-sidebar,.section-sidebar__item{transition:none}@keyframes sectionTransitionEnter{0%{opacity:1;transform:none}}}.nav-controls{max-width:800px;margin:0 auto;padding:8px 12px;flex-shrink:0;display:flex;justify-content:space-between;gap:8px;width:100%;box-sizing:border-box}.nav-button{padding:10px 16px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:13px;font-weight:600;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all .2s var(--ease-out)}.nav-button:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.nav-button:disabled{opacity:.3;cursor:not-allowed}.nav-button.primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 2px 8px #ad4b1e26}.nav-button.primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);box-shadow:0 4px 12px #ad4b1e33;transform:translateY(-1px)}.nav-hint{text-align:center;font-size:12px;color:var(--color-text-muted);padding:0 24px 8px;max-width:800px;margin:-8px auto 0}.nav-button[aria-disabled=true]{opacity:.3;cursor:not-allowed}.nav-button.primary[aria-disabled=true]:hover{background:var(--color-accent);border-color:var(--color-accent);box-shadow:0 2px 8px #ad4b1e26;transform:none}@keyframes nav-button-shake{0%,to{transform:translate(0)}15%{transform:translate(-4px)}30%{transform:translate(4px)}45%{transform:translate(-3px)}60%{transform:translate(3px)}75%{transform:translate(-1px)}90%{transform:translate(1px)}}.nav-button-shake{animation:nav-button-shake .5s ease;will-change:transform}@media(prefers-reduced-motion:reduce){.nav-button-shake{animation:none}}.progress-saved-hint{font-size:11px;color:var(--color-text-muted);text-align:center;margin:4px 0 0;display:none}@media(min-width:481px){.progress-saved-hint{display:block}}@media(min-width:481px){.slide-container{padding:48px 24px}.nav-controls{padding:16px 24px;gap:16px}.nav-button{padding:12px 24px;font-size:14px}}@media(max-height:500px)and (orientation:landscape){.progress-bar-wrapper{padding:8px 16px}.progress-bar-container{position:static}.slide-container{padding:16px}.nav-controls{padding:8px 16px}}@media(min-width:769px){.training-player{height:calc(100vh - 64px);height:calc(100dvh - 64px)}.progress-bar-container{top:64px}}.slide{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:20px 16px;box-shadow:var(--shadow-md);animation:slideEnter .4s var(--ease-out) both}@keyframes slideEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.slide-container>.slide{animation:none}}.slide h2{margin-bottom:20px}.slide p{margin-bottom:16px}.slide-intro{text-align:center;background:linear-gradient(135deg,var(--color-surface) 0%,#fffdfb 100%);border:2px solid var(--color-accent);padding:24px 16px}.slide-intro h2{font-size:24px;margin-bottom:16px}.slide-content ul{list-style:none;padding-left:0;margin-bottom:20px}.slide-content li{position:relative;padding-left:28px;margin-bottom:12px;color:var(--color-text-secondary);line-height:1.6}.slide-content li:before{content:"•";position:absolute;left:12px;color:var(--color-accent);font-weight:700}.slide-scenario{background:#fffdfb;border-left:4px solid var(--color-accent)}.slide-scenario:before{content:"Scenario";display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);margin-bottom:12px}.slide-key-takeaway{border:2px solid var(--color-accent);background:var(--color-accent-subtle)}.slide-key-takeaway:before{content:"Key Takeaway";display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);margin-bottom:12px}.slide-key-takeaway ul{list-style:none;padding-left:0}.slide-key-takeaway li{position:relative;padding-left:28px;margin-bottom:12px;color:var(--color-text);font-weight:500;line-height:1.6}.slide-key-takeaway li:before{content:"✓";position:absolute;left:8px;color:var(--color-accent);font-weight:700}.callout{background:var(--color-bg);padding:16px 20px;border-radius:var(--radius-md);border:1px solid var(--color-border);margin-top:20px;font-style:italic;color:var(--color-text-secondary)}.speaker-notes{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border-light)}.speaker-notes summary{font-size:13px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;cursor:pointer;user-select:none}.speaker-notes summary:hover{color:var(--color-text-secondary)}.speaker-notes p{margin-top:12px;font-size:14px;color:var(--color-text-secondary);line-height:1.6}@media(max-height:500px)and (orientation:landscape){.slide{padding:20px 16px}.slide-intro{padding:24px 16px}}@media(min-width:481px){.slide{padding:32px 24px}.slide-intro{padding:48px 24px}.slide-intro h2{font-size:28px}}@media(min-width:769px){.slide{padding:48px}.slide-intro{padding:64px 48px}}.callout-box{display:flex;gap:14px;padding:16px 20px;border-radius:var(--radius-md);border-left:4px solid;margin-top:20px;animation:richBlockEnter .35s var(--ease-out) both}.callout-box--note{border-color:var(--callout-note-border);background:var(--callout-note-bg)}.callout-box--warning{border-color:var(--callout-warning-border);background:var(--callout-warning-bg)}.callout-box--tip{border-color:var(--callout-tip-border);background:var(--callout-tip-bg)}.callout-box--important{border-color:var(--callout-important-border);background:var(--callout-important-bg)}.callout-box__icon{font-size:16px;line-height:1.5;flex-shrink:0}.callout-box--note .callout-box__icon{color:var(--callout-note-icon)}.callout-box--warning .callout-box__icon{color:var(--callout-warning-icon)}.callout-box--tip .callout-box__icon{color:var(--callout-tip-icon)}.callout-box--important .callout-box__icon{color:var(--callout-important-icon)}.callout-box__body p{margin:0;font-size:14px;color:var(--color-text);line-height:1.6}.callout-box__heading{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.callout-box--note .callout-box__heading{color:var(--callout-note-icon)}.callout-box--warning .callout-box__heading{color:var(--callout-warning-icon)}.callout-box--tip .callout-box__heading{color:var(--callout-tip-icon)}.callout-box--important .callout-box__heading{color:var(--callout-important-icon)}.key-terms{margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border-light)}.key-terms__heading{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:12px;font-family:var(--font-body)}.key-terms__list{display:flex;flex-wrap:wrap;gap:8px}.term-wrapper{position:relative;display:inline;--hl-color: var(--hl-yellow)}:root{--hl-yellow: #ffe066;--hl-pink: #ffb3c6;--hl-green: #a8e6a3;--hl-blue: #a0d2f7;--hl-orange: #ffcc80;--hl-purple: #d4b8f0;--hl-teal: #80d8d0;--hl-coral: #f7a89c}.term-wrapper[data-hl="0"]{--hl-color: var(--hl-yellow)}.term-wrapper[data-hl="1"]{--hl-color: var(--hl-pink)}.term-wrapper[data-hl="2"]{--hl-color: var(--hl-green)}.term-wrapper[data-hl="3"]{--hl-color: var(--hl-blue)}.term-wrapper[data-hl="4"]{--hl-color: var(--hl-orange)}.term-wrapper[data-hl="5"]{--hl-color: var(--hl-purple)}.term-wrapper[data-hl="6"]{--hl-color: var(--hl-teal)}.term-wrapper[data-hl="7"]{--hl-color: var(--hl-coral)}.term-trigger{background:none;border:none;padding:1px 2px;margin:0 -2px;font-family:inherit;font-size:inherit;color:var(--color-text);font-weight:600;cursor:help;border-bottom:2px solid color-mix(in srgb,var(--hl-color) 70%,transparent);border-radius:2px;text-decoration:none;transition:background-color .2s ease}.term-trigger:hover{background-color:color-mix(in srgb,var(--hl-color) 35%,transparent)}.term-trigger--highlighted{background-color:color-mix(in srgb,var(--hl-color) 45%,transparent);border-bottom:2px solid var(--hl-color);cursor:help;transition:background-color .3s ease,border-color .3s ease;animation:term-auto-glow .5s ease-out}.term-trigger:focus-visible{outline:2px solid color-mix(in srgb,var(--hl-color) 80%,var(--color-text));outline-offset:2px;border-radius:2px}.term-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:min(280px,calc(100vw - 32px));background:var(--color-text);color:var(--color-surface);font-size:13px;line-height:1.5;padding:12px 14px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;pointer-events:none;animation:tooltipEnter .15s var(--ease-out) both}.term-tooltip p{margin:0;color:var(--color-surface)}.term-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--color-text)}.scenario-meta{display:flex;gap:12px;align-items:center;margin-bottom:8px;flex-wrap:wrap}.scenario-meta__role{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-accent);background:var(--color-accent-subtle);padding:4px 10px;border-radius:var(--radius-sm)}.scenario-meta__setting{font-size:12px;color:var(--color-text-secondary);font-style:italic}.slide-scenario--enriched:before{display:none}@keyframes richBlockEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes tooltipEnter{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.audio-controls{position:sticky;bottom:0;flex-shrink:0;background:var(--color-surface);border-top:1px solid var(--color-border-light);padding:10px 12px;box-shadow:0 -4px 16px #1a18140a;z-index:50}.audio-player-wrapper{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.audio-player-controls{display:flex;align-items:center;gap:16px}.audio-play-container{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.audio-play-button{width:48px;height:48px;border-radius:50%;background:var(--color-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease-out);box-shadow:0 2px 8px #ad4b1e33;position:relative;z-index:1}.audio-play-button svg{transition:transform .15s var(--ease-spring)}.audio-play-button:active svg{transform:scale(.85)}.audio-play-button.audio-playing{background:var(--color-accent-hover);box-shadow:0 2px 12px #ad4b1e59}.audio-play-button:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:0 4px 12px #ad4b1e4d;transform:scale(1.05)}.audio-play-button:disabled{opacity:.5;cursor:not-allowed}.audio-pulse-ring{position:absolute;width:48px;height:48px;border-radius:50%;border:2px solid var(--color-accent);opacity:0;pointer-events:none}.audio-playing~.audio-pulse-ring{animation:audioPulse 2s var(--ease-out) infinite}@keyframes audioPulse{0%{transform:scale(1);opacity:.4}to{transform:scale(1.6);opacity:0}}.audio-progress-bar{flex:1;display:flex;flex-direction:column;gap:8px}.audio-track-touch-area{min-height:44px;display:flex;align-items:center;cursor:pointer}.audio-track{position:relative;width:100%;height:6px;background:var(--color-bg);border-radius:100px;overflow:hidden;cursor:pointer}.audio-track-fill{position:absolute;top:0;left:0;height:100%;background:var(--color-accent);border-radius:100px;transition:width .1s linear}.audio-time{display:flex;justify-content:space-between;font-size:12px;color:var(--color-text-muted);font-weight:500}.audio-completed-badge{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;font-weight:600;color:var(--color-success);padding:8px 16px;background:var(--color-success-subtle);border-radius:var(--radius-md);border:1px solid rgba(45,106,79,.15)}.audio-replay-button{display:flex;align-items:center;gap:4px;background:transparent;border:none;cursor:pointer;padding:4px 8px;color:var(--color-text-secondary);font-size:12px;font-weight:500;font-family:inherit;border-radius:var(--radius-sm);transition:color .15s ease,background .15s ease}.audio-replay-button:hover{color:var(--color-text);background:#0000000d}.audio-replay-button svg{width:14px;height:14px}@media(prefers-reduced-motion:reduce){.audio-replay-button{transition:none}}@media(max-height:500px)and (orientation:landscape){.audio-controls{padding:8px 16px}.audio-player-wrapper{gap:8px}}@media(min-width:481px){.audio-controls{padding:20px 24px}}.section-sidebar-backdrop{position:fixed;inset:0;background:#1a181480;z-index:99;animation:drawerBackdropEnter .2s ease both}@keyframes drawerBackdropEnter{0%{opacity:0}to{opacity:1}}.section-sidebar{position:fixed;left:0;top:56px;bottom:0;z-index:100;width:260px;flex-shrink:0;background:var(--color-surface);border-right:1px solid var(--color-border-light);padding:16px;display:flex;flex-direction:column;gap:4px;transition:transform .3s var(--ease-out);overflow:hidden;min-height:0;box-shadow:var(--shadow-lg);transform:translate(0)}.section-sidebar--collapsed{transform:translate(-100%);pointer-events:none}@media(min-width:769px){.section-sidebar-backdrop{display:none}.section-sidebar{position:static;top:auto;bottom:auto;z-index:auto;box-shadow:none;transition:width .3s var(--ease-out),padding .3s var(--ease-out);transform:none}.section-sidebar--collapsed{width:48px;padding:12px 8px;transform:none;pointer-events:auto}}.sidebar-toggle-mobile{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;flex-shrink:0;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s;padding:0}.sidebar-toggle-mobile:hover{background:var(--color-accent-subtle);color:var(--color-accent);border-color:var(--color-accent)}.sidebar-toggle-mobile:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.sidebar-toggle-inline{width:36px;height:36px;min-width:36px;min-height:36px;position:relative}.sidebar-toggle-inline:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:44px;min-height:44px}@media(min-width:481px){.sidebar-toggle-inline{display:none}}@media(min-width:769px){.sidebar-toggle-mobile{display:none}}@media(prefers-reduced-motion:reduce){.section-sidebar{transition:opacity .2s ease;transform:none}.section-sidebar--collapsed{opacity:0;transform:none}.section-sidebar-backdrop{animation:none}}.section-sidebar__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--color-border-light);flex-shrink:0}.section-sidebar__title{font-family:var(--font-body);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);opacity:1;visibility:visible;transition:opacity .2s,visibility .2s;white-space:nowrap}.section-sidebar--collapsed .section-sidebar__title{opacity:0;visibility:hidden;overflow:hidden;width:0}.section-sidebar__toggle{width:32px;height:32px;min-width:32px;min-height:32px;flex-shrink:0;border-radius:var(--radius-sm);border:1px solid var(--color-border-light);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--color-text-secondary);transition:all .2s;position:relative}.section-sidebar__toggle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:44px;min-height:44px}.section-sidebar__toggle:hover{background:var(--color-accent-subtle);color:var(--color-accent)}.section-sidebar__list{display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow-y:auto}.section-sidebar--collapsed .section-sidebar__list{opacity:0;visibility:hidden;overflow:hidden}.section-sidebar__item{padding:10px 12px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-secondary);border:none;background:transparent;text-align:left;width:100%;display:flex;align-items:center;gap:8px;transition:all .2s var(--ease-out);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section-sidebar__item--completed{color:var(--color-text-secondary);cursor:pointer}.section-sidebar__item--completed:hover{background:var(--color-accent-subtle);color:var(--color-accent)}.section-sidebar__item--current{background:var(--color-accent-subtle);color:var(--color-text);font-weight:600;cursor:pointer}.section-sidebar__item--upcoming{color:var(--color-text-muted);cursor:default;opacity:.7}.section-sidebar__icon{width:20px;flex-shrink:0;text-align:center;font-size:14px}.section-sidebar__icon--check{color:var(--color-accent)}.section-sidebar__icon--current{width:8px;height:8px;border-radius:50%;background:var(--color-accent);display:inline-block}.section-sidebar__name{flex:1;overflow:hidden;text-overflow:ellipsis}.section-sidebar__count{margin-left:auto;font-size:12px;color:var(--color-text-muted);font-weight:500;font-variant-numeric:tabular-nums;flex-shrink:0}.study-notes{position:fixed;inset:56px 0 0;z-index:80;background:var(--color-bg);padding:16px;overflow-y:auto;box-sizing:border-box;animation:sectionTransitionEnter .4s var(--ease-out) both}.study-notes__header{position:sticky;top:0;background:var(--color-bg);z-index:1;padding-bottom:12px;display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.study-notes__back{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 14px;cursor:pointer;font-family:var(--font-body);font-size:13px;color:var(--color-text-secondary);transition:all .2s}.study-notes__back:hover{border-color:var(--color-text-muted);color:var(--color-text)}.study-notes__title{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--color-text);margin:0;flex:1}.study-notes__count{font-family:var(--font-body);font-size:13px;color:var(--color-text-muted)}.study-notes__sections{display:flex;flex-direction:column;gap:20px}.study-notes__section{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm)}.study-notes__section-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--color-text);margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--color-border-light)}.study-notes__term-list{display:flex;flex-direction:column;gap:12px}.study-notes__term{padding:0}.study-notes__term-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.study-notes__term-name{font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--color-accent)}.study-notes__category{display:inline-block;font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--color-text-muted);background:var(--color-accent-subtle);border-radius:999px;padding:2px 8px;text-transform:uppercase;letter-spacing:.02em}.study-notes__term-definition{font-family:var(--font-body);font-size:14px;color:var(--color-text-secondary);line-height:1.5;margin:0}.study-notes__empty{text-align:center;padding:48px 24px;color:var(--color-text-secondary);font-family:var(--font-body);font-size:14px;line-height:1.6}.study-notes__empty p{margin:0 0 8px}.study-notes__footer{position:sticky;bottom:0;background:var(--color-bg);padding-top:12px;margin-top:28px;text-align:center}@media(min-width:769px){.study-notes{position:static;inset:auto;z-index:auto;max-width:800px;margin:0 auto;padding:24px;width:100%;flex:1;min-height:0}.study-notes__header{position:static;z-index:auto;padding-bottom:0}.study-notes__footer{position:static;padding-top:0}}@media(prefers-reduced-motion:reduce){.study-notes{animation:none}}.quiz-page{height:calc(100vh - 56px);height:calc(100dvh - 56px);display:flex;flex-direction:column;overflow:hidden;padding:24px 0 0}.quiz-container{flex:1;min-height:0;overflow-y:auto;max-width:700px;margin:0 auto;width:100%;box-sizing:border-box;padding:0 16px}.question-number{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-text)}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.quiz-back-link{font-size:13px;color:var(--color-text-muted);text-decoration:none;margin-bottom:8px;display:inline-flex;align-items:center;gap:4px;padding:0 16px}.quiz-back-link:hover{color:var(--color-accent)}.option--checking{position:relative;pointer-events:none}.option--checking:after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--color-accent-subtle);animation:optionPulse 1s ease-in-out infinite}@keyframes optionPulse{0%,to{opacity:.3}50%{opacity:.6}}.question-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:24px 16px;box-shadow:var(--shadow-md);margin-bottom:16px;animation:slideEnter .4s var(--ease-out) both}.question-text{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-text);margin-bottom:16px;line-height:1.4;letter-spacing:-.01em}.options-list{display:flex;flex-direction:column;gap:12px}.option-button{display:flex;align-items:center;gap:16px;padding:12px 16px;min-height:44px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:15px;font-weight:500;color:var(--color-text);text-align:left;cursor:pointer;transition:all .2s var(--ease-out);width:100%}.option-button:hover:not(:disabled){border-color:var(--color-accent);background:var(--color-accent-subtle);transform:translate(4px)}.option-button:disabled{cursor:not-allowed}.option-button.option--selected{background:var(--color-accent-subtle);border-color:var(--color-accent);font-weight:600;box-shadow:0 0 0 3px #ad4b1e1a}.option-button.option--correct{border-color:var(--color-success)!important;background:var(--color-success-subtle)!important;cursor:default}.option-button.option--wrong{border-color:var(--color-error)!important;background:var(--color-error-subtle)!important;cursor:default}.option-button.option--dimmed{opacity:.45;cursor:default}.option-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--color-surface);border:1.5px solid var(--color-border);font-weight:700;font-size:14px;color:var(--color-text-secondary);flex-shrink:0;transition:all .2s var(--ease-out)}.option-button:hover:not(:disabled) .option-letter{border-color:var(--color-accent);color:var(--color-accent)}.option-button.option--selected .option-letter{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.option-button.option--correct .option-letter,.option-letter--correct{background:var(--color-success)!important;border-color:var(--color-success)!important;color:#fff!important}.option-button.option--wrong .option-letter,.option-letter--wrong{background:var(--color-error)!important;border-color:var(--color-error)!important;color:#fff!important}.option-text{flex:1;line-height:1.6}.quiz-nav{display:flex;justify-content:center;gap:16px;max-width:700px;margin:0 auto;flex-shrink:0;padding:16px 16px 24px;width:100%;box-sizing:border-box}.quiz-feedback{margin-top:16px;padding:16px 20px;border-radius:var(--radius-md);animation:richBlockEnter .3s var(--ease-out) both}.quiz-feedback--correct{background:var(--color-success-subtle);border:1px solid rgba(45,106,79,.15)}.quiz-feedback--wrong{background:var(--color-error-subtle);border:1px solid rgba(184,50,50,.15)}.quiz-feedback__result{display:block;font-size:16px;font-weight:700;margin-bottom:8px}.quiz-feedback--correct .quiz-feedback__result{color:var(--color-success)}.quiz-feedback--wrong .quiz-feedback__result{color:var(--color-error)}.quiz-feedback__explanation{font-size:14px;color:var(--color-text-secondary);line-height:1.6;margin:0}@media(prefers-reduced-motion:reduce){.quiz-feedback{animation:none}.option--checking:after{animation:none}}.result-container{max-width:600px;margin:0 auto;text-align:center;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:40px 24px;box-shadow:var(--shadow-lg);animation:cardEnter .6s var(--ease-out) both;word-break:break-word}.result-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;margin:0 auto 24px;font-size:42px;font-weight:700}.result-pass .result-icon{background:var(--color-success-subtle);color:var(--color-success);border:2px solid rgba(45,106,79,.2);animation:result-celebration .6s var(--ease-out) .3s both}.result-fail .result-icon{background:var(--color-accent-subtle);color:var(--color-accent);border:2px solid rgba(173,75,30,.2)}@keyframes result-celebration{0%{transform:scale(1);box-shadow:0 0 #2d6a4f4d}50%{transform:scale(1.12);box-shadow:0 0 0 20px #2d6a4f00}to{transform:scale(1);box-shadow:0 0 #2d6a4f00}}@media(prefers-reduced-motion:reduce){.result-pass .result-icon{animation:none}}.result-container h1{font-size:32px;margin-bottom:16px}.result-score{font-size:18px;color:var(--color-text-secondary);margin-bottom:16px}.result-score strong{font-size:28px;font-family:var(--font-display);color:var(--color-text);font-weight:700}.result-message{font-size:15px;color:var(--color-text-secondary);margin-bottom:0;line-height:1.6}.subjects-review{margin-top:32px;padding-top:32px;border-top:1px solid var(--color-border-light)}.subjects-review h3{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-text);margin-bottom:16px}.subject-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;list-style:none;padding:0;margin:0}.subject-tag{display:inline-flex;align-items:center;padding:8px 18px;background:var(--color-accent-subtle);color:var(--color-accent);border:1px solid rgba(173,75,30,.2);border-radius:100px;font-size:13px;font-weight:600;letter-spacing:.02em}.result-actions{display:flex;flex-direction:column;gap:16px;margin-top:32px}.result-actions .btn,.quiz-nav .nav-button.primary{width:100%}@media(min-width:481px){.quiz-container,.quiz-back-link{padding:0 24px}.question-card{padding:32px}.question-text{font-size:24px}.quiz-nav{padding:16px 24px 24px}.quiz-nav .nav-button.primary{width:auto}.quiz-feedback{padding:14px 18px}.result-container{padding:64px 48px}.result-actions{flex-direction:row}.result-actions .btn{width:auto}}@media(min-width:769px){.quiz-page{height:calc(100vh - 64px);height:calc(100dvh - 64px)}}.pre-quiz-screen{max-width:800px;margin:0 auto;padding:48px 24px;text-align:center;animation:sectionTransitionEnter .5s var(--ease-out) both;width:100%;box-sizing:border-box}.pre-quiz-screen__card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:48px 32px;box-shadow:var(--shadow-sm)}.pre-quiz-screen__icon{font-size:36px;margin-bottom:16px;color:var(--color-success)}.pre-quiz-screen__title{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--color-text);margin-bottom:12px}.pre-quiz-screen__subtitle{font-family:var(--font-body);font-size:15px;color:var(--color-text-secondary);margin-bottom:28px;max-width:420px;margin-left:auto;margin-right:auto;line-height:1.5}.pre-quiz-screen__actions{display:flex;flex-direction:column;gap:12px;align-items:stretch}@media(min-width:481px){.pre-quiz-screen__actions{flex-direction:row;justify-content:center;flex-wrap:wrap;align-items:center}}@media(prefers-reduced-motion:reduce){.pre-quiz-screen{animation:none}}.certificates-section{margin-top:48px}.certificates-section h2{margin-bottom:24px;font-size:20px}.certificate-list{display:flex;flex-direction:column;gap:12px}a.cert-card{text-decoration:none;color:inherit;display:block}.cert-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:20px 24px;cursor:pointer;transition:all .2s var(--ease-out)}.cert-card:hover{border-color:var(--color-accent);box-shadow:0 4px 16px #ad4b1e1f;transform:translateY(-1px)}@media(prefers-reduced-motion:reduce){.cert-card:hover{transform:none}}.cert-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.cert-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cert-card-header h3{font-size:16px;font-weight:600;margin:0}.cert-status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.cert-status.valid{background:var(--color-success-subtle);color:var(--color-success)}.cert-status.expiring{background:#fef3cd;color:#856404}.cert-status.expired{background:#f8d7da;color:#721c24}.cert-card-details{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--color-text-secondary, #666)}@media(min-width:481px){.cert-card-details{flex-direction:row;gap:24px}}.certificate-card{max-width:800px;margin:0 auto;background:var(--color-surface);border:3px solid var(--color-accent);border-radius:var(--radius-xl);padding:24px 16px;box-shadow:var(--shadow-lg);text-align:center;animation:cardEnter .6s var(--ease-out) both;position:relative}.certificate-card:before{content:"";position:absolute;inset:8px;border:1px solid var(--color-border-light);border-radius:calc(var(--radius-xl) - 4px);pointer-events:none}.certificate-header h1{font-family:var(--font-display);font-weight:600;color:var(--color-text-secondary);margin-bottom:32px;text-transform:uppercase;letter-spacing:.05em;font-size:14px}.certificate-recipient{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--color-accent);margin-bottom:12px;letter-spacing:-.02em;line-height:1.2;word-break:break-word}.certificate-org{font-size:16px;color:var(--color-text-secondary);margin-bottom:24px;font-weight:500}.certificate-details{display:grid;grid-template-columns:1fr;gap:16px;margin:40px 0;padding:24px 0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light)}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.detail-value{font-size:15px;font-weight:600;color:var(--color-text)}.certificate-id{font-family:Courier New,monospace;font-size:13px;color:var(--color-text-secondary);word-break:break-all}.validity-badge-container{margin-bottom:32px}.validity-badge{display:inline-flex;align-items:center;padding:8px 24px;border-radius:100px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.validity-badge.valid{background:var(--color-success-subtle);color:var(--color-success);border:1px solid rgba(45,106,79,.2)}.validity-badge.expiring{background:#ffa00014;color:#c87c00;border:1px solid rgba(255,160,0,.2)}.validity-badge.expired{background:var(--color-error-subtle);color:var(--color-error);border:1px solid rgba(184,50,50,.2)}.certificate-actions{display:flex;flex-direction:column;gap:12px;justify-content:center}.certificate-actions .btn{width:100%}.btn-linkedin svg{width:16px;height:16px;vertical-align:middle;margin-right:6px;fill:currentColor}@media(min-width:481px){.certificate-card{padding:64px 48px}.certificate-card:before{inset:12px}.certificate-header h1{font-size:16px}.certificate-recipient{font-size:42px}.certificate-org{font-size:18px;margin-bottom:32px}.certificate-details{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;padding:32px 0}.certificate-actions{flex-direction:row;flex-wrap:wrap}.certificate-actions .btn{width:auto}}.cert-card-renewal{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--color-border-light);gap:12px}.days-remaining{font-size:13px;font-weight:600}.days-remaining.valid{color:var(--color-success)}.days-remaining.expiring{color:#c87c00}.days-remaining.expired{color:var(--color-error)}.cert-renew-link{font-size:13px;font-weight:600;color:var(--color-accent);text-decoration:underline;text-decoration-color:transparent;text-underline-offset:3px;transition:color .15s ease,text-decoration-color .15s ease;white-space:nowrap;cursor:pointer;border:none;background:none;font-family:inherit;padding:0}.cert-renew-link:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent-hover)}.cert-renew-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.cert-empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-2xl) var(--space-lg);color:var(--color-text-secondary, #666);text-align:center}.cert-empty-state .cert-empty-icon{color:var(--color-accent, #ad4b1e);opacity:.6}.cert-group{display:flex;flex-direction:column}.cert-history-toggle{font-size:13px;font-weight:500;color:var(--color-accent);background:none;border:none;padding:8px 0;cursor:pointer;text-align:left;font-family:inherit}.cert-history-toggle:hover{text-decoration:underline;text-underline-offset:3px}.cert-history-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.cert-history-list{display:flex;flex-direction:column;gap:4px;padding-left:16px;border-left:2px solid var(--color-border-light);margin-bottom:8px}.cert-history-item{display:flex;justify-content:space-between;padding:8px 12px;font-size:13px;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:background .15s ease}.cert-history-item:hover{background:var(--color-accent-subtle);color:var(--color-text)}.team-page{padding-top:32px;padding-bottom:48px;animation:contentEnter .6s var(--ease-out) .2s both}.back-link{display:inline-block;font-family:var(--font-body);font-size:14px;color:var(--color-text-secondary);text-decoration:none;margin-bottom:8px}.back-link:hover{color:var(--color-text)}.team-page .page-header{margin-bottom:24px}.team-page .page-header h1{margin-bottom:8px}.billing-admin-note{font-size:13px;color:var(--color-text-muted);font-style:italic;margin-bottom:0}.compliance-summary{display:flex;flex-direction:column;align-items:flex-start;gap:24px;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:24px}.compliance-skeleton{margin-bottom:32px;height:160px}.progress-ring-wrapper{flex-shrink:0;display:flex;align-items:center;justify-content:center}.summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.stat-item{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.stat-count{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1;letter-spacing:-.02em}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);white-space:nowrap}.invite-section{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:32px}.invite-section h2{font-size:18px;margin-bottom:8px}.seat-info{font-size:14px;color:var(--color-text-secondary);margin-bottom:16px}.invite-row{display:flex;flex-direction:column;gap:12px;align-items:stretch;margin-bottom:12px}.invite-input{flex:1;min-width:0;max-width:none}.invite-input-wrapper{display:flex;align-items:center;flex:1;min-width:0;max-width:none;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);overflow:hidden}.invite-input-wrapper .invite-input{border:none;border-radius:0;flex:1;min-width:0;max-width:none}.invite-input-wrapper .invite-input:focus{outline:none;box-shadow:none}.invite-input-wrapper:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 2px #ad4b1e26}.invite-domain-suffix{padding:0 12px;color:var(--color-text-muted);font-size:14px;white-space:nowrap;user-select:none;flex-shrink:0}.invite-btn{width:100%;white-space:nowrap;padding:14px 24px}.invite-toggle{font-size:13px;margin-top:4px;display:block}.bulk-textarea{min-height:120px;resize:vertical;font-family:var(--font-body);line-height:1.6}.field-hint{font-size:12px;color:var(--color-text-muted);margin-top:6px;margin-bottom:0}.members-table-wrapper{overflow-x:auto;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch;position:relative}.members-table-wrapper:after{content:"";position:absolute;top:0;right:0;bottom:0;width:24px;background:linear-gradient(to right,transparent,var(--color-surface));pointer-events:none;border-radius:0 var(--radius-lg) var(--radius-lg) 0}.members-table{width:100%;border-collapse:collapse;font-size:14px;min-width:480px}.members-table thead th{padding:12px 16px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border-light);white-space:nowrap}.members-table thead th:first-child{border-radius:var(--radius-lg) 0 0 0}.members-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}.members-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .15s ease}.members-table tbody tr:last-child{border-bottom:none}.members-table tbody tr:hover{background-color:#1a181405}.members-table tbody tr.row-loading{opacity:.5}.members-table tbody td{padding:12px 16px;vertical-align:middle;color:var(--color-text-secondary)}.member-name{min-width:140px}.name-text{display:block;font-weight:600;color:var(--color-text);font-size:14px;margin-bottom:2px}.role-label{display:block;font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-weight:500}.member-email-inline{display:block;font-size:11px;color:var(--color-text-muted);margin-top:1px}.cert-expiry,.last-activity{white-space:nowrap;font-size:13px}.status-badge.member-complete{background:var(--color-success-subtle);color:var(--color-success);border:1px solid rgba(45,106,79,.15)}.status-badge.member-expiring{background:#b8860b14;color:#b8860b;border:1px solid rgba(184,134,11,.2)}.status-badge.member-in-progress{background:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.status-badge.member-not-started{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.status-badge.member-expired{background:#dc262614;color:#dc2626;border:1px solid rgba(220,38,38,.2)}.status-badge.member-grace-period{background:#6b645a14;color:var(--color-text-secondary);border:1px solid var(--color-border)}.email-warning-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#c2410c;background:#fb923c1f;border:1px solid rgba(251,146,60,.3);border-radius:var(--radius-sm);padding:2px 8px;margin-left:6px;white-space:nowrap;vertical-align:middle}.email-failure-banner{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-md);margin-bottom:20px;animation:messageEnter .3s var(--ease-out) both}.email-failure-banner-content{display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:14px;color:#92400e}.email-failure-banner-content svg{flex-shrink:0;color:#d97706}.email-failure-link{color:#92400e;font-weight:600;text-decoration:underline;text-underline-offset:2px}.email-failure-link:hover{color:#78350f}.email-failure-dismiss{margin-left:auto;background:none;border:none;font-size:18px;color:#92400e;cursor:pointer;padding:0 4px;line-height:1;opacity:.7;transition:opacity .15s ease}.email-failure-dismiss:hover{opacity:1}.actions-menu{position:relative;display:inline-block}.actions-trigger{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);font-size:18px;font-weight:700;cursor:pointer;letter-spacing:.05em;transition:all .15s ease;padding:0;line-height:1;position:relative}.actions-trigger:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:44px;min-height:44px}.actions-trigger:hover:not(:disabled){border-color:var(--color-text-muted);color:var(--color-text);background:var(--color-bg)}.actions-trigger:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.actions-trigger:disabled{opacity:.4;cursor:not-allowed}.actions-dropdown{position:absolute;right:0;top:calc(100% + 4px);z-index:200;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;animation:dropdownEnter .15s var(--ease-out) both}.dropdown-portal{position:fixed;z-index:9999;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;animation:dropdownEnter .15s var(--ease-out) both}@keyframes dropdownEnter{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.action-item{display:flex;align-items:center;width:100%;padding:9px 12px;background:transparent;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text);text-align:left;cursor:pointer;transition:background-color .12s ease}.action-item:hover{background:var(--color-bg)}.action-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.action-item.destructive{color:var(--color-error)}.action-item.destructive:hover{background:var(--color-error-subtle)}.action-item-submenu{display:flex;flex-direction:column;cursor:default;padding:9px 12px 6px}.action-item-submenu:hover{background:transparent}.action-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:6px}.role-options{display:flex;flex-direction:column;gap:2px}.role-option{padding:7px 10px;background:transparent;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-secondary);text-align:left;cursor:pointer;transition:all .12s ease}.role-option:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.role-option:disabled{opacity:.4;cursor:not-allowed}.empty-state{background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:48px 24px;text-align:center}.empty-state p{color:var(--color-text-muted);font-size:15px;margin:0;font-style:italic}.confirm-modal-overlay{position:fixed;inset:0;background:#1a181480;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:overlayEnter .2s ease both}@keyframes overlayEnter{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:28px 24px;max-width:480px;width:100%;box-shadow:var(--shadow-lg);animation:cardEnter .3s var(--ease-out) both}.confirm-modal h3{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--color-text);margin-bottom:16px;letter-spacing:-.01em}.confirm-modal p{font-size:15px;color:var(--color-text-secondary);line-height:1.65;margin-bottom:28px}.confirm-modal-actions{display:flex;flex-direction:column;gap:12px}.confirm-modal-actions .btn{width:100%}.confirm-remove-btn{background:var(--color-error)!important;box-shadow:0 2px 8px #b8323233!important}.confirm-remove-btn:hover:not(:disabled){background:#9a2929!important;box-shadow:0 4px 16px #b8323240!important}@media(min-width:481px){.team-page .page-header{margin-bottom:32px}.compliance-summary{padding:24px;margin-bottom:32px}.invite-row{flex-direction:row;align-items:center}.invite-input,.invite-input-wrapper{min-width:240px;max-width:400px}.invite-btn{width:auto}.summary-stats{display:flex;gap:24px;flex-wrap:wrap;width:100%}}@media(min-width:769px){.team-page{padding-top:48px;padding-bottom:64px}.members-table-wrapper:after{display:none}.compliance-summary{flex-direction:row;align-items:center;gap:48px;padding:32px 40px}.stat-count{font-size:36px}.summary-stats{gap:40px}.invite-section{padding:28px 32px}.confirm-modal{padding:40px}.confirm-modal-actions{flex-direction:row;flex-wrap:wrap}.confirm-modal-actions .btn{flex:1;width:auto;min-width:120px}}.settings-page{padding-top:32px;padding-bottom:48px;max-width:720px;animation:contentEnter .6s var(--ease-out) .2s both}.settings-page .page-header{margin-bottom:28px}.settings-page .page-header h1{margin-bottom:8px}.page-subtitle{font-size:15px;color:var(--color-text-secondary);margin-bottom:0}.settings-section{padding:24px 0}.settings-section h2{margin-bottom:8px}.section-description{font-size:14px;color:var(--color-text-secondary);margin-bottom:24px;line-height:1.6}.label-optional{font-size:11px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--color-text-muted);margin-left:4px}.renewal-toggle{margin-bottom:16px}.renewal-description{margin-bottom:20px}.renewal-policy-note{font-size:14px;color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:0;line-height:1.6}.renewal-date-input{max-width:100%}.policy-option-cards{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.policy-option-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;user-select:none}.policy-option-card:hover:not(.disabled):not(.selected){border-color:var(--color-border);box-shadow:0 1px 4px #0000000f}.policy-option-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.policy-option-card.selected{border-color:var(--color-accent);background:var(--color-accent-subtle)}.policy-option-card.disabled{cursor:default;opacity:.65}.policy-option-indicator{flex-shrink:0;margin-top:2px;width:18px;height:18px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-surface);transition:border-color .15s ease;position:relative}.policy-option-card.selected .policy-option-indicator{border-color:var(--color-accent)}.policy-option-card.selected .policy-option-indicator:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--color-accent)}.policy-option-text{display:flex;flex-direction:column;gap:4px}.policy-option-title{font-size:14px;font-weight:600;color:var(--color-text);line-height:1.4}.policy-option-description{font-size:13px;color:var(--color-text-secondary);line-height:1.6}.policy-date-hint{font-size:13px;color:var(--color-text-muted);margin-top:8px;line-height:1.5}.settings-save-btn{width:100%;margin-top:8px}.leaderboard-toggle{flex-wrap:wrap}.plan-info{display:grid;grid-template-columns:1fr;gap:16px;background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:16px;margin-bottom:24px}.plan-detail{display:flex;flex-direction:column;gap:4px}.plan-detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.plan-detail-value{font-size:15px;font-weight:600;color:var(--color-text)}.subscription-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.subscription-status.active{background:var(--color-success-subtle);color:var(--color-success);border:1px solid rgba(45,106,79,.15)}.subscription-status.past-due{background:#ffa00014;color:#c87c00;border:1px solid rgba(255,160,0,.15)}.subscription-status.canceled{background:var(--color-error-subtle);color:var(--color-error);border:1px solid rgba(184,50,50,.15)}.settings-loading{padding:32px 0}@media(min-width:481px){.settings-page{padding-top:48px;padding-bottom:64px}.settings-page .page-header{margin-bottom:40px}.settings-section{padding:32px 0}.plan-info{grid-template-columns:1fr 1fr;gap:20px;padding:24px}.policy-option-card{gap:14px;padding:18px 20px}.renewal-date-input{max-width:240px}.leaderboard-toggle{flex-wrap:nowrap}.settings-save-btn{width:auto}}.subscribe-card{overflow:hidden;padding:0;max-width:520px;animation:cardEnter .6s var(--ease-out) both}.subscribe-header{background:var(--color-accent-dark);color:#fff;padding:var(--space-xl) var(--space-2xl);text-align:center}.subscribe-plan-name{font-family:var(--font-body);font-size:var(--text-base);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-xs)}.subscribe-price{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;line-height:1.1;margin-bottom:var(--space-xs)}.subscribe-price-period{font-size:var(--text-xl);font-weight:400}.subscribe-price-sub{font-size:var(--text-lg);font-weight:600}.subscribe-body{padding:var(--space-xl) var(--space-2xl) var(--space-2xl)}.subscribe-features{list-style:none;padding:0;margin:0 0 var(--space-lg);display:flex;flex-direction:column;gap:10px}.subscribe-feature-item{display:flex;align-items:flex-start;gap:var(--space-sm);font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.5;animation:fieldEnter .5s var(--ease-out) both}.subscribe-check-icon{color:var(--color-success);flex-shrink:0;margin-top:3px}.subscribe-trust{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg);animation:fieldEnter .5s var(--ease-out) both;animation-delay:.35s}.subscribe-trust-item{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);font-weight:600;color:var(--color-success)}.subscribe-cta{width:100%;animation:fieldEnter .5s var(--ease-out) both;animation-delay:.4s}.subscribe-secure{display:flex;align-items:center;justify-content:center;gap:6px;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-sm);margin-bottom:var(--space-lg)}.subscribe-compare{font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;padding:var(--space-md);background:var(--color-accent-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-md);line-height:1.5}.subscribe-proof{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-lg)}.subscribe-badge{display:inline-block;padding:2px 10px;background:var(--color-success-subtle);color:var(--color-success);border-radius:100px;font-size:var(--text-xs);font-weight:600}.subscribe-faq{border-top:1px solid var(--color-border-light);padding-top:var(--space-lg);margin-bottom:var(--space-lg)}.subscribe-faq-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-md);color:var(--color-text)}.faq-item{border-bottom:1px solid var(--color-border-light)}.faq-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-md) 0;background:none;border:none;font-family:var(--font-body);font-size:var(--text-base);font-weight:500;color:var(--color-text);cursor:pointer;text-align:left;gap:var(--space-sm)}.faq-trigger:hover{color:var(--color-accent)}.faq-trigger:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.faq-chevron{flex-shrink:0;color:var(--color-text-muted);transition:transform .2s var(--ease-out)}.faq-chevron--open{transform:rotate(180deg)}.faq-panel{max-height:0;overflow:hidden;transition:max-height .3s var(--ease-out),padding .3s var(--ease-out);padding:0}.faq-panel--open{max-height:200px;padding:0 0 var(--space-md)}.faq-panel p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.6}@media(prefers-reduced-motion:reduce){.subscribe-card,.subscribe-feature-item,.subscribe-trust,.subscribe-cta{animation:none}.faq-panel,.faq-chevron{transition:none}}.info-message{padding:14px 18px;background:var(--callout-warning-bg);border:1px solid var(--callout-warning-border);border-radius:var(--radius-md);color:#7a5c00;font-size:14px;font-weight:500;margin-bottom:24px;animation:messageEnter .3s var(--ease-out) both}.subscribe-back-link{text-align:center;margin-top:20px;margin-bottom:0;font-size:13px;color:var(--color-text-muted)}.link-btn{background:none;border:none;padding:0;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-accent);cursor:pointer;text-decoration:underline;text-decoration-color:transparent;text-underline-offset:3px;transition:color .15s ease,text-decoration-color .15s ease}.link-btn:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent-hover)}.link-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}button,[role=button],a:not(.inline-link):not(.cert-history-item):not(.login-legal-text a):not(.slide-content a):not(.quiz-back-link),input[type=checkbox],input[type=radio],select,summary{min-height:44px;min-width:44px}button,[role=button],a,input,select,textarea,summary{touch-action:manipulation}.touch-target-extend{position:relative}.touch-target-extend:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:44px;min-height:44px}.header{padding-top:env(safe-area-inset-top)}.build-footer{padding-bottom:max(12px,env(safe-area-inset-bottom))}body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.audio-controls{padding-bottom:max(20px,env(safe-area-inset-bottom))}.transcript-panel{padding-bottom:max(16px,env(safe-area-inset-bottom))}.quiz-nav{padding-bottom:max(24px,env(safe-area-inset-bottom))}.nav-controls{padding-bottom:max(16px,env(safe-area-inset-bottom))}.page-center,.verify-page{padding-top:max(24px,env(safe-area-inset-top));padding-bottom:max(24px,env(safe-area-inset-bottom));padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right))}.compliance-snapshot{padding:var(--space-sm) var(--space-md);border-radius:12px;background:var(--color-surface);border:1px solid var(--color-border-light);margin-bottom:var(--space-lg)}.snapshot-compliant{background:var(--color-success-subtle);border-color:#2d6a4f26}.snapshot-blocked{background:#ffa0000f;border-color:#c87c0040}.snapshot-personal-row{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-sm)}.snapshot-progress{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);font-weight:600;color:var(--color-text);white-space:nowrap}.snapshot-cert{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);flex-wrap:wrap}.snapshot-cert-dot{display:inline-flex;align-items:center}.snapshot-cert-green{color:var(--color-success)}.snapshot-cert-amber{color:#c87c00}.snapshot-cert-red{color:#b83232}.snapshot-cert-none{color:var(--color-text-secondary)}.snapshot-cert-label{font-weight:500;color:var(--color-text)}.snapshot-cert-days{display:inline-flex;align-items:center;gap:3px;font-size:var(--text-xs);color:var(--color-text-secondary);margin-left:var(--space-xs)}.snapshot-cta-area{flex-shrink:0;width:100%}.snapshot-cta{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);background:var(--color-accent);color:#fff;padding:var(--space-xs) var(--space-md);border-radius:8px;font-weight:600;font-size:var(--text-sm);font-family:var(--font-body);text-decoration:none;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;line-height:1.4;width:100%}.snapshot-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.snapshot-cta:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.snapshot-cta:disabled,.snapshot-cta[aria-disabled=true]{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.snapshot-microcopy{color:var(--color-text-secondary);font-size:var(--text-sm);margin:var(--space-xs) 0 0;line-height:1.4}.snapshot-payment-blocked{margin-top:var(--space-sm)}.snapshot-payment-msg{font-size:var(--text-sm);color:var(--color-text-secondary)}.snapshot-payment-btn{background:none;border:none;color:var(--color-accent);font-weight:600;font-size:var(--text-sm);font-family:var(--font-body);cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.snapshot-payment-btn:hover{color:var(--color-accent-hover)}.snapshot-payment-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.snapshot-team-row{display:flex;flex-direction:column;gap:var(--space-xs);padding-top:var(--space-sm);border-top:1px solid var(--color-border-light);margin-top:var(--space-sm);font-size:var(--text-sm)}.snapshot-team-stat{color:var(--color-text-secondary)}.snapshot-team-stat.stat-amber{color:#c87c00;font-weight:600}.snapshot-team-stat.stat-red{color:#b83232;font-weight:600}.snapshot-gamification{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-secondary);padding-top:var(--space-xs);flex-wrap:wrap}.snapshot-stats-link{color:var(--color-accent);font-weight:500;text-decoration:none;margin-left:0;width:100%;margin-top:var(--space-xs)}.snapshot-stats-link:hover{text-decoration:underline}.snapshot-stats-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(min-width:481px){.compliance-snapshot{padding:var(--space-md) var(--space-lg)}.snapshot-personal-row{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.snapshot-cta-area{width:auto}.snapshot-cta{width:auto;justify-content:flex-start}.snapshot-team-row{flex-direction:row;gap:var(--space-lg)}.snapshot-stats-link{margin-left:auto;width:auto;margin-top:0}}@media(prefers-reduced-motion:reduce){.snapshot-cta{transition:none}.snapshot-cta:hover{transform:none}}.badge-unlock{position:fixed;bottom:24px;right:24px;z-index:1000;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:20px 24px;box-shadow:var(--shadow-lg);max-width:360px;animation:badgeUnlockEnter .4s var(--ease-out) both;display:flex;align-items:flex-start;gap:12px}.badge-unlock__content{flex:1;min-width:0}.badge-unlock__label{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--color-accent);margin:0 0 8px;text-transform:uppercase;letter-spacing:.02em}.badge-unlock__badge{display:flex;align-items:center;gap:12px;margin-bottom:4px}.badge-unlock__icon{width:40px;height:40px;border-radius:50%;background:var(--color-accent-subtle);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px;color:var(--color-accent)}.badge-unlock__icon--star:before{content:"★"}.badge-unlock__icon--shield:before{content:"⬡"}.badge-unlock__icon--lightning:before{content:"↯"}.badge-unlock__icon--refresh:before{content:"⟳"}.badge-unlock__icon--cosmetic{font-size:20px;line-height:1}.badge-unlock__label--cosmetic{color:var(--color-text-secondary);font-size:12px;margin-top:12px;margin-bottom:6px}.badge-unlock__text{flex:1;min-width:0}.badge-unlock__name{display:block;font-weight:600;font-size:14px;color:var(--color-text)}.badge-unlock__desc{display:block;font-size:13px;color:var(--color-text-secondary);line-height:1.4}.badge-unlock__dismiss{background:none;border:none;font-size:20px;color:var(--color-text-muted);cursor:pointer;padding:4px;line-height:1;flex-shrink:0;border-radius:var(--radius-sm);transition:color .2s var(--ease-out),background .2s var(--ease-out)}.badge-unlock__dismiss:hover{color:var(--color-text);background:var(--color-accent-subtle)}.badge-unlock__dismiss:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes badgeUnlockEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.badge-unlock{bottom:16px;right:16px;left:16px;max-width:none}}.micro-quiz{margin-top:16px;padding:24px;border-top:1px solid var(--color-border-light);animation:richBlockEnter .3s var(--ease-out) both}.micro-quiz__prompt{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 24px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);gap:8px}.micro-quiz__prompt-icon{font-size:28px;line-height:1;margin-bottom:4px}.micro-quiz__prompt-heading{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-text);letter-spacing:-.01em;margin:0}.micro-quiz__prompt-description{font-size:14px;color:var(--color-text-secondary);margin:0 0 8px}.micro-quiz__reveal-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border:1.5px solid var(--color-accent);border-radius:var(--radius-md);background:transparent;color:var(--color-accent);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s var(--ease-out);letter-spacing:.01em;margin-top:4px}.micro-quiz__reveal-btn:hover{background:var(--color-accent-subtle);border-color:var(--color-accent-hover);color:var(--color-accent-hover)}.micro-quiz__reveal-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.micro-quiz__active{display:flex;flex-direction:column;gap:0}.micro-quiz__question{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--color-text);line-height:1.4;margin:0 0 16px;letter-spacing:-.01em}.micro-quiz__choices{display:flex;flex-direction:column;gap:8px;margin-bottom:0}.micro-quiz__choice{display:block;width:100%;padding:12px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);font-size:14px;font-weight:400;text-align:left;cursor:pointer;transition:border-color .18s var(--ease-out),background .18s var(--ease-out),box-shadow .18s var(--ease-out);line-height:1.5}.micro-quiz__choice:hover:not(:disabled):not(.micro-quiz__choice--wrong):not(.micro-quiz__choice--correct){border-color:var(--color-accent);background:var(--color-accent-subtle)}.micro-quiz__choice:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.micro-quiz__choice:disabled{cursor:not-allowed;opacity:.6}.micro-quiz__choice--wrong{border-color:var(--color-error)!important;background:var(--color-error-subtle)!important;cursor:not-allowed;opacity:.7}.micro-quiz__choice--correct{border-color:var(--color-success)!important;background:var(--color-success-subtle)!important;font-weight:600;cursor:default}.micro-quiz__feedback{margin-top:16px;padding:14px 16px;border-radius:var(--radius-md);animation:richBlockEnter .25s var(--ease-out) both}.micro-quiz__feedback--correct{background:var(--color-success-subtle);border:1px solid rgba(45,106,79,.15)}.micro-quiz__feedback--wrong{background:#c87c000d;border:1px solid rgba(200,124,0,.15)}.micro-quiz__feedback--detail{background:var(--color-bg);border:1px solid var(--color-border-light)}.micro-quiz__feedback-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.micro-quiz__feedback-result{font-size:14px;font-weight:600;color:var(--color-text);display:block;margin-bottom:4px}.micro-quiz__feedback--correct .micro-quiz__feedback-result{color:var(--color-success)}.micro-quiz__points{display:inline-flex;align-items:center;padding:2px 10px;border-radius:100px;background:var(--color-success-subtle);color:var(--color-success);font-size:13px;font-weight:700;border:1px solid rgba(45,106,79,.15);white-space:nowrap;flex-shrink:0}.micro-quiz__explanation{font-size:14px;color:var(--color-text-secondary);line-height:1.6;margin:0}.micro-quiz__retry-prompt{display:flex;align-items:center;gap:8px;margin-top:8px;padding:12px 16px;background:var(--cream, #faf7f2);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;color:var(--color-text-secondary);animation:richBlockEnter .25s var(--ease-out) both}.micro-quiz__retry-icon{font-size:1rem;color:var(--color-accent);flex-shrink:0}.micro-quiz__skip{display:block;background:none;border:none;color:var(--color-text-muted);font-family:var(--font-body);font-size:13px;font-weight:400;text-decoration:underline;text-decoration-color:transparent;text-underline-offset:2px;cursor:pointer;padding:8px 0;margin-top:8px;transition:color .15s ease,text-decoration-color .15s ease}.micro-quiz__skip:hover{color:var(--color-text-secondary);text-decoration-color:var(--color-text-secondary)}.micro-quiz__skip:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.micro-quiz__banner{padding:12px 16px;border-left:3px solid var(--color-success);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease;border-top:1px solid var(--color-border-light);border-right:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);user-select:none}.micro-quiz__banner:hover{background:var(--color-bg)}.micro-quiz__banner:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-radius:var(--radius-md)}.micro-quiz__banner-header{display:flex;align-items:center;gap:10px}.micro-quiz__banner-icon{font-size:16px;font-weight:700;flex-shrink:0;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%}.micro-quiz__banner-icon--correct{background:var(--color-success-subtle);color:var(--color-success);border:1.5px solid rgba(45,106,79,.2)}.micro-quiz__banner-icon--wrong{background:var(--color-error-subtle);color:var(--color-error);border:1.5px solid rgba(184,50,50,.2)}.micro-quiz__banner-title{flex:1;font-size:14px;font-weight:500;color:var(--color-text)}.micro-quiz__banner-toggle{font-size:11px;color:var(--color-text-muted);flex-shrink:0}.micro-quiz__banner-details{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border-light);cursor:default}.micro-quiz__banner-details .micro-quiz__question{font-size:16px;margin-bottom:12px}.micro-quiz__banner-details .micro-quiz__choices{margin-bottom:12px}.micro-quiz__banner-details .micro-quiz__choice{cursor:default}@media(max-width:480px){.micro-quiz{padding:20px 0}.micro-quiz__prompt{padding:24px 16px}.micro-quiz__question{font-size:16px}.micro-quiz__choice{padding:10px 14px}}.streak-counter{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:600;color:var(--color-accent);padding:4px 12px;background:var(--color-accent-subtle);border-radius:var(--radius-md);animation:streakPulse .4s var(--ease-out)}@keyframes streakPulse{0%{transform:scale(1)}30%{transform:scale(1.15)}to{transform:scale(1)}}@media(prefers-reduced-motion:reduce){.streak-counter{animation:none}}.streak-counter__fire{font-size:16px}.streak-counter__number{font-variant-numeric:tabular-nums}.streak-counter__label{font-size:12px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.02em}
