.auth-page .ct-control:focus{border-color:var(--role-color);box-shadow:0 0 0 3px var(--role-glow);background:var(--elevated)}.auth-role-screen{background:var(--bg);cursor:none;flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-role-screen:before{content:"";pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 500'%3E%3Cg stroke='%23C8FF00' stroke-width='0.5' fill='none' opacity='0.06'%3E%3Crect x='80' y='60' width='640' height='380'/%3E%3Crect x='180' y='60' width='440' height='380'/%3E%3Cline x1='400' y1='60' x2='400' y2='440'/%3E%3Crect x='180' y='155' width='440' height='190'/%3E%3Ccircle cx='400' cy='250' r='30'/%3E%3Cline x1='80' y1='250' x2='180' y2='250'/%3E%3Cline x1='620' y1='250' x2='720' y2='250'/%3E%3C/g%3E%3C/svg%3E");background-position:50%;background-size:cover;position:absolute;inset:0}.auth-role-header{z-index:2;align-items:center;gap:12px;padding:40px 56px 32px;display:flex;position:relative}.auth-role-hero{z-index:2;text-align:center;padding:0 0 20px;position:relative}.auth-role-hero h1{font-family:var(--f-display);letter-spacing:.04em;color:var(--text);font-size:clamp(48px,7vw,88px);line-height:.92}.auth-role-hero h1 em{color:var(--lime);font-style:normal}.auth-role-hero p{font-family:var(--f-heading);color:var(--text3);letter-spacing:.1em;text-transform:uppercase;margin-top:14px;font-size:15px;font-weight:500}.auth-role-lanes{z-index:2;flex:1;gap:2px;padding:0 2px 2px;display:flex;position:relative;overflow:hidden}.auth-role-lane{cursor:pointer;border-radius:12px 12px 0 0;flex-direction:column;flex:1;transition:flex .6s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.auth-role-lanes:hover .auth-role-lane{flex:.65}.auth-role-lane:hover{flex:2.4!important}.auth-lane-bg{background:var(--surface);transition:background .4s,box-shadow .4s;position:absolute;inset:0}.auth-role-lane:hover .auth-lane-bg{background:var(--elevated)}.auth-lane-accent{opacity:.4;border-radius:3px 3px 0 0;height:3px;transition:opacity .4s;position:absolute;top:0;left:0;right:0}.auth-role-lane:hover .auth-lane-accent{opacity:1}.auth-lane-player{--lane-color:var(--lime);--lane-glow:var(--lime-glow)}.auth-lane-coach{--lane-color:var(--blue);--lane-glow:var(--blue-glow)}.auth-lane-academy{--lane-color:var(--orange);--lane-glow:var(--orange-glow)}.auth-lane-admin{--lane-color:var(--purple);--lane-glow:var(--purple-glow)}.auth-role-lane .auth-lane-accent{background:var(--lane-color)}.auth-role-lane:hover .auth-lane-bg{box-shadow:inset 0 0 80px var(--lane-glow)}.auth-lane-inner{z-index:1;flex-direction:column;flex:1;gap:12px;padding:28px 24px 32px;display:flex;position:relative}.auth-lane-icon{border-radius:var(--radius-lg);width:44px;height:44px;transition:transform var(--dur-slow);opacity:.6;justify-content:center;align-items:center;font-size:22px;display:flex}.auth-role-lane:hover .auth-lane-icon{opacity:1;transform:scale(1.1)}.auth-role-lane .auth-lane-icon{background:var(--lane-glow)}.auth-lane-label{font-family:var(--f-display);letter-spacing:.06em;color:var(--text2);transition:color var(--dur-slow),font-size .4s;white-space:nowrap;font-size:28px;line-height:1}.auth-role-lane:hover .auth-lane-label{color:var(--lane-color);font-size:36px}.auth-lane-desc{color:var(--text2);opacity:.85;max-width:200px;font-size:15px;line-height:1.55;transition:opacity .35s .1s,color .35s .1s}.auth-role-lane:hover .auth-lane-desc{opacity:1}.auth-role-lane .auth-lane-desc{color:var(--lane-color)}.auth-lane-cta{opacity:0;transition:opacity var(--dur-slow)var(--dur-fast),transform var(--dur-slow)var(--dur-fast);flex-direction:column;gap:8px;margin-top:auto;display:flex;transform:translateY(10px)}.auth-role-lane:hover .auth-lane-cta{opacity:1;transform:translateY(0)}.auth-lane-btn{border-radius:var(--radius-md);height:42px;font-family:var(--f-heading);letter-spacing:.08em;text-transform:uppercase;transition:filter var(--dur-normal);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.auth-lane-btn:hover{filter:brightness(1.15)}.auth-lane-btn-primary{color:#000}.auth-role-lane .auth-lane-btn-primary{background:var(--lane-color)}.auth-lane-btn-ghost{background:var(--border);border:1px solid var(--border-strong);color:var(--text2);font-size:12px}.auth-lane-divider{background:var(--border);flex-shrink:0;width:1px}.auth-split{flex-direction:row;align-items:stretch;min-height:100vh;display:flex}.auth-brand-panel{background:var(--surface);flex-direction:column;flex-shrink:0;width:420px;padding:40px 48px;transition:background .5s;display:flex;position:relative;overflow:hidden}.auth-brand-panel:before{content:"";pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 420 700'%3E%3Cg stroke='%23c8ff00' stroke-width='1.2' fill='none' opacity='0.12' stroke-linecap='square'%3E%3Crect x='10' y='72' width='400' height='556'/%3E%3Cline x1='58' y1='72' x2='58' y2='628'/%3E%3Cline x1='362' y1='72' x2='362' y2='628'/%3E%3Cline x1='58' y1='242' x2='362' y2='242'/%3E%3Cline x1='58' y1='458' x2='362' y2='458'/%3E%3Cline x1='210' y1='242' x2='210' y2='458'/%3E%3Cline x1='0' y1='350' x2='420' y2='350' stroke-width='1.5' opacity='1'/%3E%3Cline x1='210' y1='72' x2='210' y2='88'/%3E%3Cline x1='210' y1='612' x2='210' y2='628'/%3E%3Ccircle cx='210' cy='48' r='4'/%3E%3Cline x1='210' y1='52' x2='210' y2='72'/%3E%3Ccircle cx='210' cy='652' r='4'/%3E%3Cline x1='210' y1='628' x2='210' y2='648'/%3E%3C/g%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:100% 100%;position:absolute;inset:0}[data-theme=light] .auth-brand-panel:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 420 700'%3E%3Cg stroke='%2351b33b' stroke-width='1.2' fill='none' opacity='0.14' stroke-linecap='square'%3E%3Crect x='10' y='72' width='400' height='556'/%3E%3Cline x1='58' y1='72' x2='58' y2='628'/%3E%3Cline x1='362' y1='72' x2='362' y2='628'/%3E%3Cline x1='58' y1='242' x2='362' y2='242'/%3E%3Cline x1='58' y1='458' x2='362' y2='458'/%3E%3Cline x1='210' y1='242' x2='210' y2='458'/%3E%3Cline x1='0' y1='350' x2='420' y2='350' stroke-width='1.5' opacity='1'/%3E%3Cline x1='210' y1='72' x2='210' y2='88'/%3E%3Cline x1='210' y1='612' x2='210' y2='628'/%3E%3Ccircle cx='210' cy='48' r='4'/%3E%3Cline x1='210' y1='52' x2='210' y2='72'/%3E%3Ccircle cx='210' cy='652' r='4'/%3E%3Cline x1='210' y1='628' x2='210' y2='648'/%3E%3C/g%3E%3C/svg%3E")}.auth-brand-panel:after{content:"";background:linear-gradient(to bottom,transparent,var(--role-color),transparent);opacity:.35;width:3px;height:120%;transition:background .5s;position:absolute;top:-10%;right:-1px}.auth-brand-logo{z-index:1;align-items:center;gap:10px;display:flex;position:relative}.auth-corner-logo{z-index:1;align-items:center;width:calc(100% + 28px);margin-left:-14px;display:flex;position:relative}.auth-corner-logo-img{object-fit:contain;width:100%;height:auto}.auth-corner-logo-img--light,[data-theme=light] .auth-corner-logo-img--dark{display:none}[data-theme=light] .auth-corner-logo-img--light{display:block}.auth-brand-headline{z-index:1;margin-top:auto;position:relative}.auth-brand-eyebrow{font-family:var(--f-heading);letter-spacing:.15em;text-transform:uppercase;color:var(--role-text);margin-bottom:16px;font-size:12px;font-weight:600;transition:color .5s}.auth-brand-headline h2{font-family:var(--f-display);letter-spacing:.03em;color:var(--text);font-size:80px;line-height:.88}.auth-brand-headline .accent{color:var(--role-text);transition:color .5s}.auth-brand-role-pill{z-index:1;border-radius:var(--radius-full);border:1px solid var(--role-border);background:var(--role-glow);font-family:var(--f-heading);letter-spacing:.1em;text-transform:uppercase;color:var(--role-text);cursor:pointer;align-items:center;gap:8px;margin-top:28px;padding:7px 14px;font-size:12px;font-weight:700;transition:border-color .5s,background .5s,color .5s;display:inline-flex;position:relative}.auth-brand-role-pill:hover{filter:brightness(1.2)}.auth-brand-role-pill .dot{background:var(--role-color);border-radius:50%;width:6px;height:6px;transition:background .5s}.auth-brand-footer{z-index:1;color:var(--text3);margin-top:32px;font-size:12px;line-height:1.6;position:relative}.auth-brand-footer a{color:var(--text2)}.auth-brand-footer a:hover{color:var(--role-color)}.auth-form-panel{background:var(--bg);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px;display:flex;overflow-y:auto}.auth-form-card{flex-direction:column;gap:28px;width:100%;max-width:420px;display:flex}.auth-form-header{flex-direction:column;gap:6px;display:flex}.auth-form-header h3{font-family:var(--f-display);letter-spacing:.04em;font-size:36px}.auth-form-header p{color:var(--text2);font-size:14px}.auth-role-pills{flex-wrap:wrap;gap:6px;display:flex}.auth-role-pill{border-radius:var(--radius-full);border:1px solid var(--border-strong);height:30px;font-family:var(--f-heading);letter-spacing:.08em;text-transform:uppercase;color:var(--text3);cursor:pointer;background:0 0;padding:0 12px;font-size:11px;font-weight:700;transition:all .25s}.auth-role-pill-player{border-color:var(--lime-border);background:var(--lime-glow);color:var(--lime)}.auth-role-pill-coach{border-color:var(--blue-border);background:var(--blue-glow);color:var(--blue)}.auth-role-pill-academy{border-color:var(--orange-border);background:var(--orange-glow);color:var(--orange)}.auth-role-pill-admin{border-color:var(--purple-border);background:var(--purple-glow);color:var(--purple)}.auth-field-group{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:7px;display:flex}.auth-field label{font-family:var(--f-heading);letter-spacing:.08em;text-transform:uppercase;color:var(--text2);font-size:12px;font-weight:700}.auth-field-help{color:var(--text3);font-size:12px}.auth-pw-strength{background:var(--border);border-radius:2px;height:3px;margin-top:6px;overflow:hidden}.auth-pw-bar{border-radius:2px;width:0;height:100%;transition:width .4s,background .4s}.auth-form-actions{flex-direction:column;gap:12px;display:flex}.auth-btn-primary{border-radius:var(--radius-lg);background:var(--role-color);color:#000;height:50px;font-family:var(--f-heading);letter-spacing:.1em;text-transform:uppercase;transition:filter var(--dur-normal),transform var(--dur-fast);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;font-size:14px;font-weight:800;display:flex}.auth-btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}.auth-btn-primary:active{transform:translateY(0)}.auth-btn-primary:disabled{opacity:.55;cursor:not-allowed;filter:none;transform:none}.auth-btn-ghost{border-radius:var(--radius-lg);border:1px solid var(--border-strong);height:44px;color:var(--text2);font-family:var(--f-heading);letter-spacing:.06em;transition:border-color var(--dur-normal),color var(--dur-normal),background var(--dur-normal);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;width:100%;font-size:13px;font-weight:600;display:flex}.auth-btn-ghost:hover{background:var(--elevated);color:var(--text)}.auth-form-divider{color:var(--text4);align-items:center;gap:12px;font-size:12px;display:flex}.auth-form-divider:before,.auth-form-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-form-link-row{text-align:center;color:var(--text3);font-size:13px}.auth-form-link{color:var(--role-text);cursor:pointer;transition:opacity var(--dur-normal);font-weight:500}.auth-form-link:hover{opacity:.8}.auth-terms-row{color:var(--text3);align-items:flex-start;gap:10px;font-size:13px;display:flex}.auth-terms-row input[type=checkbox]{accent-color:var(--role-text);margin-top:2px}.auth-terms-row a{color:var(--text2);text-decoration:underline}.auth-email-sent{background:var(--bg);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:48px;display:flex}.auth-email-sent-icon{border:2px solid var(--role-border);background:var(--role-glow);border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;margin:0 auto 32px;font-size:38px;animation:2s ease-in-out infinite auth-pulse-ring;display:flex}@keyframes auth-pulse-ring{0%,to{box-shadow:0 0 0 0 var(--role-glow)}50%{box-shadow:0 0 0 18px #0000}}.auth-email-sent-title{font-family:var(--f-display);letter-spacing:.04em;color:var(--text);margin-bottom:12px;font-size:56px;line-height:.92}.auth-email-sent-sub{color:var(--text2);max-width:360px;margin:0 auto 36px;font-size:15px;line-height:1.6}.auth-email-sent-sub strong{color:var(--text)}.auth-email-sent-actions{flex-direction:column;gap:10px;width:100%;max-width:340px;display:flex}.auth-resend-note{color:var(--text3);margin-top:20px;font-size:13px}
