*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green-deep:#0d2b1a;--green-mid:#1a4a2c;--green-fair:#2d6e45;--green-light:#4a9e68;--gold:#c8a84b;--gold-light:#e8cb7a;--cream:#f5f0e8;--cream-dark:#ede6d8;--green:#2d6e45;--green-dark:#1a4a2c;--bg:#f5f0e8;--surface:#fff;--border:#0d2b1a1f;--text:#0d2b1a;--text-muted:#0d2b1a80;--radius:12px;--shadow:0 2px 12px #00000012}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:DM Sans,system-ui,sans-serif}.app-nav{background:var(--green-deep);z-index:100;border-bottom:1px solid #c8a84b26;justify-content:space-between;align-items:center;height:56px;padding:0 2rem;display:flex;position:sticky;top:0}.nav-logo{color:var(--cream);font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700;text-decoration:none}.nav-logo span{color:var(--gold)}.nav-links{align-items:center;gap:1.25rem;display:flex}.nav-links a{color:#f5f0e8bf;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .15s}.nav-links a:hover{color:var(--cream)}.nav-signout{color:#f5f0e899;cursor:pointer;background:0 0;border:1.5px solid #f5f0e833;border-radius:999px;padding:.3rem .9rem;font-size:.85rem;transition:border-color .15s,color .15s}.nav-signout:hover{border-color:var(--gold);color:var(--gold)}.auth-page{background:radial-gradient(ellipse at 60% 0%, #c8a84b14 0%, transparent 70%), var(--green-deep);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{background:var(--surface);border-radius:20px;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 8px 40px #00000040}.auth-logo{text-align:center;color:var(--green-deep);margin-bottom:.25rem;font-family:Playfair Display,serif;font-size:2rem;font-weight:700}.auth-logo span{color:var(--gold)}.auth-tagline{text-align:center;color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.auth-tabs{background:var(--bg);border-radius:999px;gap:.5rem;margin-bottom:1.25rem;padding:.25rem;display:flex}.auth-tabs button{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:999px;flex:1;padding:.5rem;font-size:.95rem;font-weight:500;transition:all .15s}.auth-tabs button.active{background:var(--green-deep);color:var(--cream)}.auth-field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.75rem;margin-bottom:.3rem;font-size:.82rem;font-weight:600;display:block}.auth-card input[type=text],.auth-card input[type=email],.auth-card input[type=password],.auth-card input[type=date]{border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);outline:none;padding:.75rem 1rem;font-size:1rem;transition:border-color .15s}.auth-card input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c8a84b1f}.auth-card button[type=submit]{background:var(--gold);width:100%;color:var(--green-deep);border-radius:var(--radius);cursor:pointer;border:none;margin-top:1.25rem;padding:.85rem;font-size:1rem;font-weight:700;transition:background .15s}.auth-card button[type=submit]:hover{background:var(--gold-light)}.auth-card button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.auth-terms-label{color:var(--text-muted);cursor:pointer;align-items:flex-start;gap:.5rem;margin-top:.75rem;font-size:.85rem;display:flex}.auth-terms-label a{color:var(--green-fair)}.auth-field-hint{color:var(--text-muted);margin-top:.3rem;font-size:.8rem}.auth-error{color:#dc2626;border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin:.75rem 0;padding:.75rem 1rem;font-size:.9rem}.auth-success{color:#16a34a;border-radius:var(--radius);background:#f0fdf4;border:1px solid #86efac;margin:.75rem 0;padding:.75rem 1rem;font-size:.9rem}.auth-divider{text-align:center;color:var(--text-muted);margin:1rem 0;font-size:.85rem;position:relative}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);width:40%;height:1px;position:absolute;top:50%}.auth-divider:before{left:0}.auth-divider:after{right:0}.google-btn{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;width:100%;color:var(--text);background:#fff;padding:.75rem;font-size:.95rem;font-weight:500;transition:border-color .15s}.google-btn:hover{border-color:var(--gold)}.auth-footer-note{text-align:center;color:var(--text-muted);margin-top:1rem;font-size:.82rem}.auth-footer-note a{color:var(--green-fair)}.parent-info-box{background:var(--bg);border-radius:var(--radius);margin:1rem 0;padding:1rem}.parent-info-box div{border-bottom:1px solid var(--border);justify-content:space-between;padding:.4rem 0;display:flex}.parent-info-box div:last-child{border-bottom:none}.parent-info-box span{color:var(--text-muted);font-size:.85rem}.btn-secondary{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);background:0 0;padding:.65rem 1.25rem;font-size:.95rem;font-weight:500;transition:border-color .15s,background .15s}.btn-secondary:hover{border-color:var(--gold);background:var(--cream-dark)}.btn-sm{padding:.35rem .85rem;font-size:.85rem}.btn-text{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.4rem 0;font-size:.9rem}.btn-text:hover{color:var(--text)}.btn-full{width:100%}.page-container{max-width:1000px;margin:0 auto;padding:2rem 1.5rem}.dashboard-welcome{margin-bottom:2rem}.dashboard-welcome h1{margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.text-muted{color:var(--text-muted)}.dashboard-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.dash-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);color:var(--text);border:2px solid #0000;padding:1.5rem;text-decoration:none;transition:border-color .15s,transform .15s;display:block}.dash-card:hover{border-color:var(--gold);transform:translateY(-2px)}.dash-card-icon{margin-bottom:.75rem;font-size:2rem}.dash-card h3{margin-bottom:.25rem;font-size:1.1rem;font-weight:600}.dash-card p{color:var(--text-muted);font-size:.85rem}.btn-primary{background:var(--green-deep);color:var(--cream);border-radius:var(--radius);cursor:pointer;border:none;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--green-mid)}.tee-time-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.tee-time-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1.5px solid var(--border);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.ttc-header{justify-content:space-between;align-items:flex-start;display:flex}.ttc-course{font-size:1rem;font-weight:600}.ttc-date{color:var(--text-muted);font-size:.82rem}.ttc-body{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.9rem;display:flex}.ttc-host{color:var(--text);font-weight:500}.ttc-notes{font-style:italic}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.82rem;font-weight:600;display:block}.field-optional{text-transform:none;letter-spacing:0;font-weight:400}input[type=text],input[type=number],input[type=date],input[type=time],input[type=email],textarea,select{border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);outline:none;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c8a84b1f}textarea{resize:vertical}.seg-group{flex-wrap:wrap;gap:.4rem;display:flex}.seg-btn{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:999px;padding:.45rem 1rem;font-size:.9rem;font-weight:500;transition:all .15s}.seg-btn:hover{border-color:var(--gold);color:var(--text)}.seg-btn.active{background:var(--green-deep);color:var(--cream);border-color:var(--green-deep)}.round-type-badge{color:var(--text-muted);background:#0d2b1a14;border-radius:999px;padding:.2rem .6rem;font-size:.78rem;font-weight:600;display:inline-block}.jr-fee-badge{border-radius:999px;padding:.2rem .75rem;font-size:.82rem;font-weight:600;display:inline-block}.jr-fee-price{color:#8a6a1a;background:#c8a84b26}.jr-fee-strokes{color:#2563eb;background:#5b9cf61f}.jr-strokes-info{border-radius:var(--radius);background:#5b9cf60f;border:1px solid #5b9cf640;flex-wrap:wrap;align-items:flex-start;gap:1.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.jr-request-card{background:var(--bg);border-radius:var(--radius);border:1.5px solid var(--border);padding:1rem}.jr-banner{background:var(--bg);border-radius:var(--radius);border:1.5px solid var(--border);padding:.9rem 1rem;font-size:.95rem}.jr-banner.approved{color:#15803d;background:#f0fdf4;border-color:#86efac}.jr-banner.rejected{color:#dc2626;background:#fef2f2;border-color:#fecaca}.status-chip{color:var(--text-muted);background:#0d2b1a14;border-radius:999px;padding:.2rem .65rem;font-size:.78rem;font-weight:600;display:inline-block}.status-chip.approved{color:#15803d;background:#dcfce7}.status-chip.rejected{color:#dc2626;background:#fee2e2}.btn-approve{color:#15803d;cursor:pointer;background:#dcfce7;border:none;border-radius:999px;padding:.35rem .9rem;font-size:.85rem;font-weight:600}.btn-approve:hover{background:#bbf7d0}.btn-reject{color:#dc2626;cursor:pointer;background:#fee2e2;border:none;border-radius:999px;padding:.35rem .9rem;font-size:.85rem;font-weight:600}.btn-reject:hover{background:#fecaca}.btn-danger{border-radius:var(--radius);color:#dc2626;cursor:pointer;background:0 0;border:1.5px solid #fecaca;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600}.btn-danger:hover{background:#fee2e2}.modal-overlay{z-index:200;background:#0d2b1a80;justify-content:center;align-items:flex-end;padding:1rem;display:flex;position:fixed;inset:0}@media (width>=600px){.modal-overlay{align-items:center}}.modal{background:var(--cream);border-radius:16px 16px 0 0;width:100%;max-width:480px;max-height:85vh;padding:1.5rem;overflow-y:auto}@media (width>=600px){.modal{border-radius:16px}}.modal-header{margin-bottom:1.25rem;position:relative}.modal-header h2{margin-bottom:.15rem}.modal-sub{color:var(--text-muted);font-size:.85rem}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0;font-size:1.4rem;line-height:1;position:absolute;top:0;right:0}.invite-search-wrap{margin-bottom:.75rem;position:relative}.invite-search-wrap input{box-sizing:border-box;width:100%}.invite-results{border:1px solid var(--border);z-index:100;background:#fff;border-radius:10px;margin:0;padding:.25rem 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 8px 24px #0000001a}.invite-results li{cursor:pointer;align-items:center;gap:.6rem;padding:.55rem 1rem;font-size:.9rem;display:flex}.invite-results li:hover{background:var(--cream-dark)}.invite-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:30px;height:30px}.invite-avatar-initial{background:var(--green-deep);color:var(--gold);justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex}.invite-chips{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.invite-chip{background:var(--cream-dark);border-radius:20px;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.85rem;display:flex}.invite-chip button{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0;font-size:1rem;line-height:1}.invite-footer{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.invite-sent{text-align:center;color:var(--green-fair);padding:2rem 0;font-size:1.1rem;font-weight:600}.rating-group-section{border:1px solid var(--border);background:#2d6e450d;border-radius:10px;margin-bottom:1.25rem;padding:.9rem 1rem}.rating-group-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:.65rem;font-size:.72rem;font-weight:700}.rating-players{flex-direction:column;gap:1rem;margin-bottom:1.25rem;display:flex}.rating-player-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.rating-player-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.rating-player-controls{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.rating-player-name{align-items:center;gap:.6rem;font-weight:600;display:flex}.rating-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.rating-avatar-initial{background:var(--green-deep);color:var(--gold);justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.rating-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.rating-label{color:var(--text-muted);font-size:.82rem}.rating-toggle{gap:.35rem;display:flex}.rating-toggle button{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:6px;padding:.3rem .7rem;font-family:inherit;font-size:.8rem}.rating-toggle-sm button{padding:.25rem .55rem;font-size:.75rem}.rating-toggle button.active{background:var(--green-deep);color:var(--gold);border-color:var(--green-deep)}.rating-toggle button.active-no{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.rating-override-btn{border:1px solid var(--border);color:var(--green-fair);cursor:pointer;background:#fff;border-radius:6px;padding:.25rem .65rem;font-size:.75rem;font-weight:600;transition:background .12s}.rating-override-btn:hover{background:var(--cream-dark)}.rating-override-btn.open{background:var(--green-fair);color:#fff;border-color:var(--green-fair)}.rating-override-panel{border-left:2px solid var(--green-fair);margin:.4rem 0 .4rem .5rem;padding-left:.75rem}.rating-comment-wrap{margin-top:.6rem}.rating-comment{border:1px solid var(--border);resize:vertical;box-sizing:border-box;border-radius:8px;width:100%;padding:.6rem .75rem;font-family:inherit;font-size:.9rem}.rating-comment:focus{border-color:var(--gold);outline:none}.rating-comment-count{color:var(--text-muted);text-align:right;margin-top:.2rem;font-size:.75rem}.star-row{gap:2px;display:flex}.star-row .star{cursor:pointer;color:var(--cream-dark);background:0 0;border:none;padding:0;font-size:1.3rem;line-height:1}.star-row .star.filled{color:var(--gold)}@keyframes promoFadeIn{0%{opacity:0}to{opacity:1}}@keyframes promoSlideUp{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:none}}.promo-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b8;justify-content:center;align-items:center;padding:1.25rem;animation:.2s promoFadeIn;display:flex;position:fixed;inset:0}.promo-modal{color:#fff;background:#111;border:1px solid #ffffff1a;border-radius:18px;width:100%;max-width:400px;padding:2.25rem 2rem 1.75rem;animation:.28s cubic-bezier(.22,1,.36,1) promoSlideUp;position:relative;box-shadow:0 32px 80px #0009}.promo-close{cursor:pointer;color:#ffffff80;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;transition:background .15s;display:flex;position:absolute;top:1rem;right:1rem}.promo-close:hover{color:#fff;background:#ffffff26}.promo-eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--gold);margin:0 0 .6rem;font-size:.73rem;font-weight:700}.promo-title{color:#fff;margin:0 0 .75rem;font-size:1.5rem;font-weight:800;line-height:1.2}.promo-body{color:#ffffffa6;margin:0 0 1.5rem;font-size:.92rem;line-height:1.6}.promo-referral-block{margin-bottom:1.5rem}.promo-ref-row{gap:.5rem;display:flex}.promo-ref-input{color:#fff;background:#ffffff12;border:1px solid #ffffff26;border-radius:8px;flex:1;min-width:0;padding:.55rem .75rem;font-size:.78rem}.promo-copy-btn{background:var(--gold);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:.35rem;padding:.55rem 1rem;font-size:.83rem;font-weight:700;transition:opacity .15s;display:flex}.promo-copy-btn:hover{opacity:.88}.promo-cta-btn{background:var(--gold);color:#fff;border-radius:10px;justify-content:center;align-items:center;margin-bottom:1.5rem;padding:.85rem 1.5rem;font-size:.95rem;font-weight:700;text-decoration:none;transition:opacity .15s;display:flex}.promo-cta-btn:hover{opacity:.88}.promo-later{color:#ffffff59;cursor:pointer;letter-spacing:.02em;background:0 0;border:none;width:100%;padding:0;font-size:.82rem;transition:color .15s}.promo-later:hover{color:#ffffffa6}.nav-messages-link{align-items:center;font-size:1.1rem;display:flex;position:relative}.nav-messages-badge{color:#fff;background:#dc2626;border-radius:10px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.62rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-6px;right:-8px}.nav-credits{white-space:nowrap;background:#c8a84b2e;border-radius:999px;padding:.25rem .65rem;font-size:.8rem;font-weight:700;color:var(--gold-light)!important}.course-search-wrap{position:relative}.course-dropdown{border:1.5px solid var(--border);border-radius:var(--radius);z-index:200;background:#fff;margin:0;padding:.25rem 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 8px 24px #0000001a}.course-result{cursor:pointer;padding:.6rem 1rem;transition:background .1s}.course-result:hover{background:var(--cream-dark)}.course-result-name{font-size:.92rem;font-weight:600}.course-result-loc{color:var(--text-muted);margin-top:.15rem;font-size:.8rem}.course-geocoding{color:var(--text-muted);padding:.6rem 1rem;font-size:.85rem;font-style:italic}.loading{text-align:center;color:var(--text-muted);padding:3rem 0;font-size:1rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 0}.empty-state p{margin-bottom:1rem;font-size:1rem}.back-link{color:var(--text-muted);align-items:center;gap:.35rem;margin-bottom:1.25rem;font-size:.9rem;text-decoration:none;transition:color .15s;display:inline-flex}.back-link:hover{color:var(--text)}.jr-strokes-badge{color:#8a6a1a;background:#c8a84b26;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .85rem;font-size:.85rem;font-weight:700;display:inline-flex}.faq-list{flex-direction:column;gap:.5rem;margin-top:1.5rem;display:flex}.faq-item{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);overflow:hidden}.faq-question{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;font-size:.97rem;font-weight:600;transition:background .12s;display:flex}.faq-question:hover{background:var(--cream-dark)}.faq-chevron{color:var(--text-muted);flex-shrink:0;font-size:.8rem;transition:transform .2s}.faq-chevron.open{transform:rotate(180deg)}.faq-answer{color:var(--text-muted);border-top:1px solid var(--border);padding:.75rem 1.25rem 1rem;font-size:.9rem;line-height:1.6}.help-contact{background:var(--green-deep);color:var(--cream);border-radius:var(--radius);flex-direction:column;gap:.5rem;margin-top:2rem;padding:1.5rem;display:flex}.help-contact h3{color:var(--gold);margin-bottom:.25rem}.help-contact a{color:var(--gold-light)}.app-footer{background:var(--green-deep);border-top:1px solid #c8a84b26;margin-top:4rem;padding:2.5rem 2rem 1.5rem}.footer-inner{grid-template-columns:1fr;gap:2rem;max-width:1000px;margin:0 auto;display:grid}@media (width>=640px){.footer-inner{grid-template-columns:1.4fr 1fr 1fr 1fr}}.footer-brand{flex-direction:column;gap:.5rem;display:flex}.footer-logo{color:var(--cream);font-family:Playfair Display,serif;font-size:1.3rem;font-weight:700}.footer-logo span{color:var(--gold)}.footer-tagline{color:#f5f0e880;font-size:.82rem;line-height:1.5}.footer-links{display:contents}.footer-col{flex-direction:column;gap:.5rem;display:flex}.footer-col-title{text-transform:uppercase;letter-spacing:.08em;color:#f5f0e873;margin-bottom:.25rem;font-size:.78rem;font-weight:700}.footer-col a{color:#f5f0e8a6;font-size:.88rem;text-decoration:none;transition:color .15s}.footer-col a:hover{color:var(--gold)}.footer-bottom{text-align:center;color:#f5f0e84d;border-top:1px solid #f5f0e814;max-width:1000px;margin:1.5rem auto 0;padding-top:1.25rem;font-size:.78rem}.lessons-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.lesson-category-card{background:var(--surface);border-radius:var(--radius);border:2px solid var(--border);color:var(--text);cursor:pointer;box-shadow:var(--shadow);flex-direction:column;gap:.75rem;padding:1.5rem;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}.lesson-category-card:hover{border-color:var(--gold);box-shadow:0 4px 20px #c8a84b26}.lesson-cat-icon{font-size:2.5rem;line-height:1}.lesson-cat-body{flex:1}.lesson-cat-title{margin-bottom:.2rem;font-size:1.05rem;font-weight:700}.lesson-cat-desc{color:var(--text-muted);font-size:.85rem}.lesson-cat-progress{margin-top:.5rem}.lesson-progress-bar{background:var(--border);border-radius:999px;height:5px;overflow:hidden}.lesson-progress-fill{background:var(--gold);border-radius:999px;height:100%;transition:width .4s}.lesson-progress-label{color:var(--text-muted);margin-top:.3rem;font-size:.75rem}.lesson-cat-empty{color:var(--text-muted);font-size:.82rem;font-style:italic}.lesson-module-badge{color:#8a6a1a;background:#c8a84b1f;border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.lessons-search-wrap{margin-bottom:1.5rem;position:relative}.lessons-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.lessons-search-input{padding-left:2.5rem!important}.search-lesson-card{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);color:var(--text);align-items:center;gap:1rem;margin-bottom:.5rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .15s;display:flex}.search-lesson-card:hover{border-color:var(--gold)}.lesson-list{flex-direction:column;gap:.6rem;margin-top:1.5rem;display:flex}.lesson-row{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);color:var(--text);cursor:pointer;align-items:center;gap:1rem;padding:.85rem 1rem;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}.lesson-row:hover{border-color:var(--gold);box-shadow:0 2px 12px #c8a84b1a}.lesson-row-num{background:var(--border);width:24px;height:24px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.lesson-row-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:72px;height:48px}.lesson-row-body{flex:1;min-width:0}.lesson-row-title{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.lesson-row-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:.15rem;font-size:.8rem;overflow:hidden}.lesson-row-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.lesson-thumb-placeholder{background:var(--border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:48px;font-size:1.5rem;display:flex}.lesson-lock-overlay{background:#fff9;border-radius:8px;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;inset:0}.lesson-unlocked-badge{color:#15803d;font-size:.75rem;font-weight:600}.lesson-stroke-cost{color:#2563eb;font-size:.8rem;font-weight:700}.lesson-video-wrap{border-radius:var(--radius);aspect-ratio:16/9;background:#000;margin:1.25rem 0;position:relative;overflow:hidden}.lesson-video{object-fit:contain;width:100%;height:100%;display:block}.lesson-locked-wrap{border-radius:var(--radius);aspect-ratio:16/9;background:var(--green-deep);margin:1.25rem 0;position:relative;overflow:hidden}.lesson-locked-overlay{z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex;position:absolute;inset:0}.lesson-locked-icon{font-size:2.5rem}.lesson-locked-label{color:var(--cream);font-size:1.05rem;font-weight:700}.lesson-locked-note{color:#f5f0e88c;text-align:center;font-size:.82rem}.lesson-locked-thumb{object-fit:cover;opacity:.25;width:100%;height:100%}.lesson-locked-placeholder{background:var(--green-mid);position:absolute;inset:0}.lesson-cat-header{align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.lesson-cat-header-icon{flex-shrink:0;font-size:2.5rem}.lesson-cat-header-desc{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.module-unlock-banner{background:var(--surface);border:2px solid var(--gold);border-radius:var(--radius);flex-direction:column;gap:.35rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem;display:flex}.module-unlock-title{font-size:1rem;font-weight:700}.module-unlock-sub{color:var(--text-muted);font-size:.85rem}.module-unlocked-banner{border-radius:var(--radius);color:#15803d;background:#f0fdf4;border:1.5px solid #86efac;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem;font-weight:600}.lesson-detail-title{margin-bottom:.4rem;font-size:1.25rem;font-weight:700}.lesson-detail-desc{color:var(--text-muted);margin-bottom:1.25rem;font-size:.93rem;line-height:1.6}.lesson-nav-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.25rem;display:flex}.lesson-cat-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.85rem}.fp-filters{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;display:flex}.fp-filter-group{flex-direction:column;gap:.35rem;display:flex}.fp-filter-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.78rem;font-weight:700}.fp-filter-group input{width:90px}.fp-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:.5rem;display:grid}.fp-card{background:var(--surface);border-radius:var(--radius);border:2px solid var(--border);box-shadow:var(--shadow);flex-direction:column;gap:.85rem;padding:1.25rem;transition:border-color .15s;display:flex}.fp-card:hover{border-color:#c8a84b66}.fp-card-header{align-items:center;gap:.85rem;display:flex}.fp-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:52px;height:52px}.fp-avatar-initial{background:var(--green-deep);color:var(--gold);justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex}.fp-name{font-size:1rem;font-weight:700}.fp-sub{color:var(--text-muted);margin-top:.1rem;font-size:.82rem}.fp-tags{flex-wrap:wrap;gap:.35rem;display:flex}.fp-tag{background:var(--bg);color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:.2rem .65rem;font-size:.77rem}.fp-bio{color:var(--text-muted);font-size:.85rem;line-height:1.5}.fp-actions{gap:.5rem;margin-top:auto;display:flex}.fp-connect-btn{background:var(--green-deep);color:var(--cream);border-radius:var(--radius);cursor:pointer;border:none;flex:1;padding:.6rem;font-size:.9rem;font-weight:600;transition:background .15s}.fp-connect-btn:hover{background:var(--green-mid)}.fp-connect-btn:disabled{opacity:.5;cursor:not-allowed}.fp-skip-btn{border-radius:var(--radius);border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;padding:.6rem .9rem;font-size:.9rem;transition:border-color .15s}.fp-skip-btn:hover{border-color:var(--text-muted)}.fp-profile-link{color:var(--green-fair);text-align:center;font-size:.82rem;text-decoration:none}.fp-profile-link:hover{text-decoration:underline}.sa-upload-area{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface);padding:2.5rem 1.5rem;transition:border-color .15s,background .15s}.sa-upload-area:hover,.sa-upload-area.drag-over{border-color:var(--gold);background:#c8a84b0a}.sa-upload-icon{margin-bottom:.75rem;font-size:2.5rem}.sa-upload-title{margin-bottom:.35rem;font-size:1rem;font-weight:600}.sa-upload-sub{color:var(--text-muted);font-size:.85rem}.sa-preview-wrap{border-radius:var(--radius);background:#000;margin-bottom:1rem;position:relative;overflow:hidden}.sa-preview{object-fit:contain;width:100%;max-height:320px;display:block}.sa-preview-remove{cursor:pointer;color:#fff;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.1rem;display:flex;position:absolute;top:.5rem;right:.5rem}.sa-extracting{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;display:flex}.sa-frames{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.sa-frame{object-fit:cover;border:1.5px solid var(--border);border-radius:6px;width:60px;height:42px}.sa-feedback-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.sa-feedback-title{align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;font-weight:700;display:flex}.sa-section{margin-bottom:1.25rem}.sa-section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:.4rem;font-size:.75rem;font-weight:700}.sa-section p{color:var(--text);font-size:.9rem;line-height:1.6}.sa-drill{background:var(--bg);border-radius:8px;align-items:flex-start;gap:.5rem;margin-bottom:.4rem;padding:.65rem .85rem;font-size:.88rem;display:flex}.sa-drill-icon{flex-shrink:0;margin-top:.05rem}.sa-score-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.sa-score-label{color:var(--text-muted);font-size:.87rem}.sa-score-val{font-size:.87rem;font-weight:700}.sa-score-bar{background:var(--border);border-radius:999px;flex:1;height:6px;margin:0 .75rem;overflow:hidden}.sa-score-fill{background:var(--gold);border-radius:999px;height:100%}.sa-history-row{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);cursor:pointer;align-items:center;gap:1rem;margin-bottom:.5rem;padding:.85rem 1rem;transition:border-color .15s;display:flex}.sa-history-row:hover{border-color:var(--gold)}.sa-history-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:64px;height:44px}.sa-history-thumb-placeholder{background:var(--border);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.sa-history-body{flex:1;min-width:0}.sa-history-date{color:var(--text-muted);font-size:.82rem}.sa-history-summary{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.sa-tabs{gap:.4rem;margin-bottom:1.5rem;display:flex}.sa-tab{border:1.5px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:999px;padding:.45rem 1rem;font-size:.9rem;font-weight:500;transition:all .15s}.sa-tab.active{background:var(--green-deep);color:var(--cream);border-color:var(--green-deep)}
