:root{--bg: #f7f9fc;--bg-alt: #eef2f7;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e8edf3;--surface-4: #dde4ed;--border: rgba(15,23,42,.08);--border-strong: rgba(15,23,42,.14);--primary: #0f172a;--primary-dim: #334155;--muted: #64748b;--faint: #94a3b8;--accent: #059669;--accent-dim: #047857;--accent-bg: #ecfdf5;--accent-border: rgba(5,150,105,.22);--jade: #4a7c59;--jade-dim: #2d5a3e;--jade-bg: rgba(74,124,89,.08);--gold: #b45309;--gold-dim: #92400e;--gold-bg: #fffbeb;--danger: #dc2626;--danger-bg: rgba(220,38,38,.08);--radius: 14px;--radius-sm: 9px;--radius-lg: 20px;--radius-pill: 999px;--nav-height: 64px;--sidebar-width: 230px;--nav-bg: rgba(255,255,255,.92);--input-bg: #ffffff;--input-border: rgba(15,23,42,.16);--shadow-card: 0 2px 12px rgba(15,23,42,.07), 0 0 0 1px rgba(15,23,42,.06);--shadow-card-hover: 0 8px 32px rgba(15,23,42,.12), 0 0 0 1px rgba(5,150,105,.2);--shadow-modal: 0 12px 48px rgba(15,23,42,.18)}[data-theme=dark]{--bg: #060c15;--bg-alt: #0a1422;--surface: #0d1a2e;--surface-2: #112238;--surface-3: #172b44;--surface-4: #1e3352;--border: rgba(148,163,184,.09);--border-strong: rgba(148,163,184,.16);--primary: #e2e8f0;--primary-dim: #94a3b8;--muted: #64748b;--faint: #2d3f55;--accent: #10b981;--accent-dim: #059669;--accent-bg: rgba(16,185,129,.1);--accent-border: rgba(16,185,129,.24);--jade: #6ee7b7;--jade-dim: #34d399;--jade-bg: rgba(110,231,183,.08);--gold: #f59e0b;--gold-dim: #d97706;--gold-bg: rgba(245,158,11,.1);--danger: #ef4444;--danger-bg: rgba(239,68,68,.1);--nav-bg: rgba(6,12,21,.9);--input-bg: var(--surface-2);--input-border: rgba(148,163,184,.18);--shadow-card: 0 4px 24px rgba(0,0,0,.4);--shadow-card-hover: 0 12px 40px rgba(0,0,0,.5), 0 0 0 1px rgba(16,185,129,.18);--shadow-modal: 0 24px 80px rgba(0,0,0,.6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Manrope,Noto Sans TC,-apple-system,sans-serif;background-color:var(--bg);background-image:radial-gradient(rgba(15,23,42,.05) 1px,transparent 1px);background-size:28px 28px;color:var(--primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .2s ease,color .2s ease}[data-theme=dark] body,[data-theme=dark]{background-image:radial-gradient(rgba(148,163,184,.07) 1px,transparent 1px);background-size:28px 28px}a{color:inherit;text-decoration:none}.container{max-width:1160px;margin:0 auto;padding:0 32px}nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);display:flex;align-items:center;padding:0 28px;gap:4px;background:var(--nav-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}nav .brand{font-family:"Noto Serif",serif;font-size:1rem;font-weight:600;color:var(--primary);letter-spacing:-.01em;margin-right:auto;display:flex;align-items:center;gap:10px}nav .brand-mark{width:30px;height:30px;background:linear-gradient(135deg,var(--accent) 0%,var(--jade-dim) 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #10b98159}nav .brand span{color:var(--accent)}nav .nav-links{display:flex;align-items:center;gap:2px}nav .nav-links a,nav .nav-links button{font-family:Manrope,sans-serif;font-size:.8rem;white-space:nowrap;min-height:44px;display:inline-flex;align-items:center;font-weight:500;color:var(--muted);letter-spacing:.02em;padding:6px 12px;border-radius:var(--radius-sm);background:none;border:none;cursor:pointer;transition:color .15s,background .15s}nav .nav-links a:hover,nav .nav-links button:hover{color:var(--primary);background:var(--surface-3)}nav .user-pill{display:flex;align-items:center;gap:8px;padding:4px 14px 4px 5px;background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-pill);font-size:.77rem;color:var(--primary-dim);margin-left:8px}nav .user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--jade-dim));display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;color:#fff;text-transform:uppercase;flex-shrink:0}nav .nav-divider{width:1px;height:18px;background:var(--border-strong);margin:0 8px}main{padding-top:var(--nav-height)}.page{padding:56px 0 80px}.page-header{margin-bottom:40px}.page-header .eyebrow,.eyebrow{font-size:.67rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}.page-header .eyebrow:before,.eyebrow:before{content:"";display:inline-block;width:18px;height:2px;background:var(--accent);border-radius:1px;flex-shrink:0}.page-header h1{font-family:"Noto Serif",serif;font-size:2.6rem;font-weight:600;letter-spacing:-.025em;color:var(--primary);line-height:1.1}.page-header p{font-size:.9rem;color:var(--muted);margin-top:10px;line-height:1.6}.hero{position:relative;overflow:hidden;background:linear-gradient(140deg,var(--surface) 0%,var(--bg-alt) 100%);border:1px solid var(--border);border-radius:var(--radius-lg);padding:56px 52px;margin-bottom:40px}.hero:before{content:"";position:absolute;top:-120px;right:-100px;width:420px;height:420px;background:radial-gradient(circle,rgba(16,185,129,.12) 0%,transparent 65%);pointer-events:none}.hero:after{content:"";position:absolute;bottom:-80px;left:-60px;width:320px;height:320px;background:radial-gradient(circle,rgba(245,158,11,.06) 0%,transparent 65%);pointer-events:none}.hero .eyebrow{margin-bottom:14px;position:relative}.hero h1{font-family:"Noto Serif",serif;font-size:3.4rem;font-weight:600;letter-spacing:-.03em;color:var(--primary);line-height:1.1;margin-bottom:14px;position:relative}.hero p{font-size:.95rem;color:var(--muted);max-width:480px;line-height:1.75;position:relative}.hero-compact{padding:32px 44px;margin-bottom:28px;border-radius:var(--radius)}.hero-compact h1{font-size:2.2rem;margin-bottom:8px}.hero-compact .eyebrow{margin-bottom:10px}.org-card{min-height:190px;padding:32px 32px 28px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.org-card:after{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.03) 0%,transparent 70%);pointer-events:none}.label-tag{display:inline-flex;align-items:center;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface-3);border:1px solid var(--border);padding:3px 10px;border-radius:var(--radius-pill);white-space:nowrap}.label-tag.jade{color:var(--jade);background:var(--jade-bg);border-color:#6ee7b733}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;font-family:Manrope,sans-serif;font-size:.82rem;font-weight:600;letter-spacing:.02em;cursor:pointer;border:none;border-radius:var(--radius-sm);transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dim) 100%);color:#fff;box-shadow:0 2px 10px #10b98147}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--jade-dim) 0%,var(--accent) 100%);transform:translateY(-1px);box-shadow:0 4px 18px #10b98161}[data-theme=light] .btn-primary{box-shadow:0 2px 10px #05966938}.btn-secondary{background:var(--surface-3);color:var(--primary);border:1px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-4);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--primary-dim);border:1px solid var(--border-strong)}.btn-outline:hover:not(:disabled){background:var(--surface-3);color:var(--primary)}.btn-ghost{background:transparent;color:var(--muted);border:none}.btn-ghost:hover:not(:disabled){background:var(--surface-3);color:var(--primary)}.btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(239,68,68,.22)}.btn-danger:hover:not(:disabled){background:var(--danger-bg)}.btn-sm{padding:6px 12px;font-size:.75rem}.btn-lg{padding:14px 28px;font-size:.9rem}.btn-full{width:100%}.class-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.class-grid>*:nth-child(4n+1){grid-column:span 2}.class-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px 24px 0;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden}.class-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent) 0%,var(--jade-dim) 50%,transparent 100%);opacity:.5;transition:opacity .2s}.class-card:hover{border-color:var(--accent-border);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.class-card:hover:before{opacity:1}.class-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.class-card h3{font-family:"Noto Serif",serif;font-size:1.1rem;font-weight:600;color:var(--primary);letter-spacing:-.01em;line-height:1.35;flex:1}.class-card .tutor{font-size:.77rem;color:var(--muted);margin-top:2px}.class-card .meta-row{display:flex;flex-wrap:wrap;gap:10px}.class-card .meta-item{display:flex;align-items:center;gap:4px;font-size:.76rem;color:var(--primary-dim)}.class-card .meta-icon{font-size:.7rem;opacity:.65}.class-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;margin-left:-24px;margin-right:-24px;padding:12px 24px;background:var(--surface-2);border-top:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius)}.class-card .price{font-size:.95rem;font-weight:700;color:var(--primary)}.spots-bar-wrap{display:flex;flex-direction:column;gap:4px;flex:1;margin:0 14px}.spots-bar{height:5px;background:var(--surface-4);border-radius:3px;overflow:hidden}.spots-bar-fill{height:100%;min-width:16px;background:linear-gradient(90deg,var(--accent),var(--jade-dim));border-radius:3px;transition:width .5s ease}.spots-bar-fill.low{background:linear-gradient(90deg,var(--gold-dim),var(--gold))}.spots-bar-fill.full{background:linear-gradient(90deg,var(--danger),#f87171)}.spots-label{font-size:.67rem;color:var(--muted);letter-spacing:.04em}.form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:7px}.form-group label{font-size:.71rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.form-group input,.form-group textarea,.form-group select{font-family:Manrope,sans-serif;font-size:.875rem;color:var(--primary);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);padding:11px 14px;width:100%;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--faint)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #10b9811a}[data-theme=light] .form-group input:focus,[data-theme=light] .form-group textarea:focus,[data-theme=light] .form-group select:focus{box-shadow:0 0 0 3px #0596691a}.form-group select option{background:var(--surface-3)}.form-group textarea{resize:vertical;min-height:80px}.phone-input-wrap{display:flex;align-items:center;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .15s,box-shadow .15s}.phone-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #10b9811a}.phone-prefix{font-family:Manrope,sans-serif;font-size:.875rem;color:var(--primary-dim);padding:11px 14px;background:var(--surface-3);border-right:1px solid var(--input-border);white-space:nowrap;-webkit-user-select:none;user-select:none}.phone-input-wrap input{border:none!important;border-radius:0!important;background:transparent!important;box-shadow:none!important}.phone-input-wrap input:focus{border:none!important;box-shadow:none!important}.auth-page{min-height:calc(100vh - var(--nav-height));display:grid;grid-template-columns:1fr 1fr}.auth-aside{background:linear-gradient(155deg,var(--surface) 0%,var(--bg-alt) 100%);border-right:1px solid var(--border);padding:72px 60px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.auth-aside:before{content:"";position:absolute;top:-100px;right:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(16,185,129,.1) 0%,transparent 65%);pointer-events:none}.auth-aside:after{content:"";position:absolute;bottom:-80px;left:-60px;width:360px;height:360px;background:radial-gradient(circle,rgba(245,158,11,.06) 0%,transparent 65%);pointer-events:none}.auth-aside-badge{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:28px;position:relative}.auth-aside-badge:before{content:"";width:7px;height:7px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px #10b98180}.auth-aside h2{font-family:"Noto Serif",serif;font-size:3.2rem;font-weight:600;letter-spacing:-.03em;color:var(--primary);line-height:1.1;margin-bottom:20px;position:relative}.auth-aside p{font-size:.875rem;color:var(--muted);line-height:1.75;max-width:340px;position:relative}.auth-aside-features{margin-top:40px;display:flex;flex-direction:column;gap:14px;position:relative}.auth-aside-feature{display:flex;align-items:center;gap:12px;font-size:.82rem;color:var(--primary-dim)}.auth-aside-feature:before{content:"✓";width:20px;height:20px;min-width:20px;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:800;color:var(--accent)}.auth-box{display:flex;flex-direction:column;justify-content:center;padding:72px 60px;background:var(--bg)}.auth-box h3{font-family:"Noto Serif",serif;font-size:2rem;font-weight:600;letter-spacing:-.025em;color:var(--primary);margin-bottom:8px}.auth-box .auth-subtitle{font-size:.85rem;color:var(--muted);margin-bottom:36px;line-height:1.65}.auth-box .switch{font-size:.82rem;color:var(--muted);margin-top:24px;text-align:center}.auth-box .switch a{color:var(--accent);font-weight:600}.alert{padding:12px 16px;font-size:.82rem;line-height:1.5;border-radius:var(--radius-sm);margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.22)}.alert-success{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}.alert-info{background:var(--surface-2);color:var(--primary-dim);border:1px solid var(--border-strong)}.alert-warning{background:var(--gold-bg);color:var(--gold);border:1px solid rgba(245,158,11,.22)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;font-size:.67rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius-pill)}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.badge-green{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}.badge-yellow{background:var(--gold-bg);color:var(--gold);border:1px solid rgba(245,158,11,.22)}.badge-red{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.22)}.badge-gray{background:var(--surface-3);color:var(--muted);border:1px solid var(--border)}.badge-jade{background:var(--jade-bg);color:var(--jade);border:1px solid rgba(110,231,183,.2)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-padded{padding:28px 32px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px 22px 28px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(to bottom,var(--accent),var(--jade-dim))}.stat-card:nth-child(2):before{background:linear-gradient(to bottom,var(--gold),var(--gold-dim))}.stat-card:nth-child(3):before{background:linear-gradient(to bottom,var(--jade),var(--jade-dim))}.stat-card:nth-child(4):before{background:linear-gradient(to bottom,var(--jade-dim),var(--accent))}.stat-card .stat-label{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.stat-card .stat-value{font-family:"Noto Serif",serif;font-size:2.2rem;font-weight:600;color:var(--primary);letter-spacing:-.025em;line-height:1}.stat-card .stat-sub{font-size:.73rem;color:var(--muted);margin-top:5px}table{width:100%;border-collapse:collapse}thead{border-bottom:2px solid var(--border)}th{text-align:left;padding:12px 18px;font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}td{padding:14px 18px;font-size:.84rem;color:var(--primary-dim);border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tbody tr{transition:background .12s}tbody tr:hover td{background:var(--surface-2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:200}.modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-modal)}.modal-wide{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-header h3{font-family:"Noto Serif",serif;font-size:1.2rem;font-weight:600;color:var(--primary)}.modal-close{background:var(--surface-3);border:1px solid var(--border);color:var(--muted);font-size:.9rem;cursor:pointer;padding:6px 10px;border-radius:7px;transition:all .15s;line-height:1}.modal-close:hover{color:var(--primary);background:var(--surface-4)}.modal-body{padding:24px 28px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:20px 28px;border-top:1px solid var(--border);background:var(--surface);position:sticky;bottom:0}.form-section{padding:20px 0;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:16px}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.form-section-title{font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:8px}.form-section-title:before{content:"";width:14px;height:2px;background:var(--accent);border-radius:1px;flex-shrink:0}.form-section-desc{font-size:.78rem;color:var(--muted);line-height:1.5;margin-top:-4px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:10px;font-size:.84rem!important;font-weight:500!important;letter-spacing:0!important;text-transform:none!important;color:var(--primary-dim)!important;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;border:none;border-bottom:none!important;border-radius:4px;accent-color:var(--accent);cursor:pointer;flex-shrink:0;padding:0!important}.day-picker{display:flex;gap:6px;flex-wrap:wrap}.day-btn{padding:7px 14px;font-family:Manrope,sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.04em;background:var(--surface-2);color:var(--muted);border:1px solid var(--border-strong);border-radius:var(--radius-pill);cursor:pointer;transition:all .15s}.day-btn:hover{color:var(--primary);border-color:var(--accent-border)}.day-btn.selected{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.field-hint{font-size:.72rem;color:var(--accent);margin-top:4px}.detail-hero{background:linear-gradient(140deg,var(--surface) 0%,var(--bg-alt) 100%);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px;margin-bottom:20px;position:relative;overflow:hidden}.detail-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,var(--jade-dim) 40%,transparent 100%)}.detail-hero:after{content:"";position:absolute;top:-80px;right:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(16,185,129,.08) 0%,transparent 65%);pointer-events:none}.detail-hero h1{font-family:"Noto Serif",serif;font-size:2.4rem;font-weight:600;letter-spacing:-.025em;color:var(--primary);line-height:1.2;margin:16px 0 12px;position:relative}.detail-hero .description{font-size:.9rem;color:var(--muted);line-height:1.75;max-width:600px;position:relative}.detail-grid{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}.detail-meta-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.detail-meta-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:15px 22px;border-bottom:1px solid var(--border)}.detail-meta-row:last-child{border-bottom:none}.meta-label{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-shrink:0;padding-top:2px}.meta-value{font-size:.84rem;color:var(--primary);text-align:right}.enroll-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:16px;position:sticky;top:calc(var(--nav-height) + 20px)}.enroll-card h4{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.enroll-price{font-family:"Noto Serif",serif;font-size:2.2rem;font-weight:600;color:var(--primary);letter-spacing:-.025em}.enroll-price span{font-size:.9rem;color:var(--muted);font-family:Manrope,sans-serif;font-weight:400;letter-spacing:0}.enroll-divider{height:1px;background:var(--border)}.enroll-prompt-btns{display:flex;flex-direction:column;gap:8px}.admin-layout{display:flex;min-height:calc(100vh - var(--nav-height))}.admin-sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:2px;position:sticky;top:var(--nav-height);height:calc(100vh - var(--nav-height));overflow-y:auto}.sidebar-section-label{font-size:.59rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:14px 12px 6px;margin-top:4px}.sidebar-section-label:first-child{padding-top:4px;margin-top:0}.admin-sidebar a,.admin-sidebar .sidebar-btn{display:flex;align-items:center;gap:10px;padding:9px 12px;font-family:Manrope,sans-serif;font-size:.82rem;font-weight:500;color:var(--muted);border-radius:var(--radius-sm);background:none;border:none;cursor:pointer;transition:all .15s;width:100%;text-align:left;text-decoration:none}.admin-sidebar a:hover,.admin-sidebar .sidebar-btn:hover{color:var(--primary);background:var(--surface-3)}.admin-sidebar a.sidebar-active{color:var(--accent);background:var(--accent-bg);font-weight:600}.sidebar-icon{font-size:.92rem;flex-shrink:0;width:18px;text-align:center;opacity:.8}.sidebar-sep{height:1px;background:var(--border);margin:8px 4px}.admin-content{flex:1;min-width:0;padding:44px 40px 80px}.admin-content .page{padding:0}.admin-content .page>.container{max-width:none;padding:0}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:500;color:var(--muted);background:none;border:none;cursor:pointer;padding:6px 0;margin-bottom:28px;transition:color .15s}.back-link:hover{color:var(--primary)}.empty-state{text-align:center;padding:80px 40px;color:var(--muted);font-size:.875rem;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius)}.nav-mobile-toggle{display:none}@media (max-width: 860px){.class-grid{grid-template-columns:repeat(2,1fr)}.class-grid>*:nth-child(4n+1){grid-column:span 1}}@media (max-width: 768px){nav{padding:0 16px}.container{padding:0 16px}.class-grid,.detail-grid,.auth-page{grid-template-columns:1fr}.auth-aside{display:none}.stat-grid{grid-template-columns:1fr 1fr}.hero{padding:36px 28px;border-radius:var(--radius)}.hero h1{font-size:2.4rem}.hero-compact{padding:24px 28px}.hero-compact h1{font-size:1.8rem}.detail-hero{padding:28px;border-radius:var(--radius)}.detail-hero h1{font-size:1.8rem}.auth-box{padding:48px 28px}.page{padding:32px 0 60px}.nav-classes-link{display:none}.admin-layout{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:static;flex-direction:row;overflow-x:auto;padding:10px 12px;gap:4px;border-right:none;border-bottom:1px solid var(--border)}.sidebar-section-label,.sidebar-sep{display:none}.admin-content{padding:24px 16px 60px}}@media (max-width: 480px){.stat-grid,.form-row{grid-template-columns:1fr}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-16px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(18px,-18px) scale(1.05)}66%{transform:translate(-8px,10px) scale(.96)}}@keyframes gradientPan{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes pulseDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}@keyframes shimmerSweep{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes barGrow{0%{width:0!important}}.page{animation:fadeIn .28s ease both}.hero:before{animation:orbFloat 10s ease-in-out infinite}.hero:after{animation:orbFloat 13s ease-in-out infinite reverse}.detail-hero:after{animation:orbFloat 12s ease-in-out infinite}.auth-aside:before{animation:orbFloat 10s ease-in-out infinite}.auth-aside:after{animation:orbFloat 14s ease-in-out infinite reverse}.gradient-text{background:linear-gradient(135deg,var(--accent) 0%,var(--jade-dim) 50%,var(--gold) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientPan 5s linear infinite}.class-grid>*{animation:fadeInUp .36s ease both}.class-grid>*:nth-child(1){animation-delay:0ms}.class-grid>*:nth-child(2){animation-delay:55ms}.class-grid>*:nth-child(3){animation-delay:.11s}.class-grid>*:nth-child(4){animation-delay:165ms}.class-grid>*:nth-child(5){animation-delay:.22s}.class-grid>*:nth-child(6){animation-delay:275ms}.class-grid>*:nth-child(7){animation-delay:.33s}.class-grid>*:nth-child(8){animation-delay:385ms}.class-grid>*:nth-child(9){animation-delay:.44s}.class-grid>*:nth-child(10){animation-delay:495ms}.class-grid>*:nth-child(11){animation-delay:.55s}.class-grid>*:nth-child(12){animation-delay:605ms}.spots-bar-fill{animation:barGrow .8s cubic-bezier(.4,0,.2,1) both .3s}.stat-card{animation:slideInLeft .3s ease both}.stat-card:nth-child(2){animation-delay:60ms}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:nth-child(4){animation-delay:.18s}.auth-aside-badge:before{animation:pulseDot 2.4s ease-in-out infinite}.btn:active:not(:disabled){transform:scale(.97) translateY(0)!important}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmerSweep 1.4s linear infinite;border-radius:var(--radius-sm)}.label-tag.accent{color:var(--accent);background:var(--accent-bg);border-color:var(--accent-border)}.label-tag.gold{color:var(--gold);background:var(--gold-bg);border-color:#f59e0b38}.class-card{padding:0;gap:0}.class-card-visual{height:76px;position:relative;overflow:hidden;flex-shrink:0;display:flex;align-items:flex-end;padding:10px 20px;border-bottom:1px solid var(--border);transition:filter .2s}.class-card-visual:before{content:"";position:absolute;right:-28px;top:-28px;width:110px;height:110px;border-radius:50%;background:#ffffff0f;pointer-events:none}.class-card-visual:after{content:"";position:absolute;right:36px;top:8px;width:56px;height:56px;border-radius:50%;background:#ffffff0a;pointer-events:none}.class-card-labels{display:flex;gap:6px;flex-wrap:wrap;position:relative;z-index:1}.class-card-body{padding:18px 22px 14px;display:flex;flex-direction:column;gap:10px;flex:1}.class-card-footer{margin-left:0!important;margin-right:0!important;margin-bottom:0!important}.class-card:hover .class-card-visual{filter:brightness(1.08)}.org-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:"Noto Serif",serif;font-size:1.3rem;font-weight:700;margin-bottom:16px;flex-shrink:0;position:relative;z-index:1;transition:transform .2s}.class-card:hover .org-card-icon{transform:scale(1.06)}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:10px;background:none;border:none;cursor:pointer;margin-left:auto;border-radius:var(--radius-sm);transition:background .15s}.nav-hamburger:hover{background:var(--surface-3)}.nav-hamburger span{display:block;width:20px;height:2px;background:var(--primary-dim);border-radius:2px;transition:background .15s}.nav-hamburger:hover span{background:var(--primary)}.mobile-nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:150;animation:fadeIn .2s ease both}.mobile-nav-drawer{position:absolute;right:0;top:0;bottom:0;width:min(300px,85vw);background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;animation:slideInRight .26s cubic-bezier(.16,1,.3,1) both;overflow-y:auto;box-shadow:-8px 0 40px #0006}.mobile-nav-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-nav-header .brand{font-family:"Noto Serif",serif;font-size:.95rem;font-weight:600;display:flex;align-items:center;gap:8px}.mobile-nav-header .brand-mark{width:26px;height:26px;font-size:.65rem}.mobile-nav-close{background:var(--surface-3);border:1px solid var(--border);color:var(--muted);font-size:.9rem;cursor:pointer;padding:5px 9px;border-radius:7px;line-height:1;transition:all .15s}.mobile-nav-close:hover{color:var(--primary);background:var(--surface-4)}.mobile-nav-body{display:flex;flex-direction:column;padding:12px 10px;gap:2px;flex:1}.mobile-nav-section{font-size:.59rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:12px 12px 5px;margin-top:4px}.mobile-nav-body a,.mobile-nav-body button{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--primary-dim);background:none;border:none;cursor:pointer;text-decoration:none;transition:all .15s;width:100%;text-align:left}.mobile-nav-body a:hover,.mobile-nav-body button:hover{background:var(--surface-3);color:var(--primary)}.mobile-nav-footer{padding:16px 10px;border-top:1px solid var(--border);flex-shrink:0}.mobile-user-pill{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}.mobile-user-pill .user-avatar{width:32px;height:32px;font-size:.72rem}.mobile-user-pill-name{font-size:.85rem;font-weight:600;color:var(--primary)}.mobile-user-pill-role{font-size:.7rem;color:var(--muted);margin-top:1px}@media (max-width: 768px){nav .nav-links{display:none}.nav-hamburger{display:flex}}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;padding:20px 0 4px}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--radius-pill);font-size:.76rem;font-weight:600;letter-spacing:.02em;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .14s ease;white-space:nowrap;font-family:Manrope,sans-serif}.filter-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #0596694d}[data-theme=dark] .filter-chip{background:var(--surface-2)}[data-theme=dark] .filter-chip.active{background:var(--accent);color:#fff}.search-bar-wrap{position:relative;margin-bottom:16px}.search-bar-wrap .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.9rem;pointer-events:none}.search-input{width:100%;padding:10px 14px 10px 38px;border-radius:var(--radius-sm);border:1.5px solid var(--border-strong);background:var(--surface);color:var(--primary);font-size:.875rem;font-family:Manrope,sans-serif;transition:border-color .15s,box-shadow .15s;outline:none}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.search-input::placeholder{color:var(--muted)}.stats-strip{display:flex;gap:20px;flex-wrap:wrap;padding:12px 0 4px;color:var(--muted);font-size:.82rem}.stats-strip-item{display:flex;align-items:center;gap:6px}.stats-strip-item strong{color:var(--accent);font-weight:700}.appt-card{display:flex;align-items:stretch;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden;transition:box-shadow .2s ease,transform .2s ease;cursor:pointer;text-decoration:none;color:inherit;border-left:4px solid transparent}.appt-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px);border-left-color:var(--accent)}.appt-date-block{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:72px;padding:16px 10px;background:var(--surface-2);border-right:1px solid var(--border);gap:0;flex-shrink:0}.appt-date-month{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.appt-date-day{font-size:1.9rem;font-weight:800;line-height:1;color:var(--primary);font-family:Manrope,sans-serif;margin:2px 0}.appt-date-dow{font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.appt-body{flex:1;padding:14px 18px;display:flex;flex-direction:column;gap:6px;min-width:0}.appt-title{font-family:"Noto Serif",serif;font-size:1rem;font-weight:600;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appt-subtitle{font-size:.75rem;color:var(--muted);margin-top:-4px}.appt-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.75rem;color:var(--muted)}.appt-meta-item{display:flex;align-items:center;gap:4px}.appt-price-block{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;padding:14px 18px;min-width:100px;flex-shrink:0;gap:6px}.appt-price{font-size:1rem;font-weight:700;color:var(--primary);font-family:Manrope,sans-serif}.appt-spots{display:flex;flex-direction:column;align-items:flex-end;gap:3px;width:80px}.appt-spots-label{font-size:.65rem;color:var(--muted);white-space:nowrap}.appt-card .label-tag{font-size:.62rem;padding:2px 7px}.appt-list{display:flex;flex-direction:column;gap:10px;padding-top:8px}@media (max-width: 600px){.appt-price-block{display:none}.appt-body{padding:12px 14px}.appt-date-block{min-width:58px}.appt-date-day{font-size:1.5rem}}.booking-confirm-grid{display:flex;flex-direction:column;gap:12px;padding:4px 0}.booking-confirm-title{font-family:"Noto Serif",serif;font-size:1.2rem;font-weight:600;color:var(--primary)}.booking-confirm-meta{display:flex;flex-direction:column;gap:8px;background:var(--surface-2);border-radius:var(--radius-sm);padding:14px 16px}.booking-confirm-row{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;gap:16px}.booking-confirm-row .label{color:var(--muted)}.booking-confirm-row .value{font-weight:600;color:var(--primary);text-align:right}.booking-confirm-price{display:flex;justify-content:space-between;align-items:center;padding:12px 0 0;border-top:1px solid var(--border-strong);margin-top:4px}.booking-confirm-price .label{font-size:.82rem;color:var(--muted)}.booking-confirm-price .value{font-size:1.3rem;font-weight:800;color:var(--accent)}.ticket-list{display:flex;flex-direction:column;gap:10px}.ticket-card{display:flex;align-items:center;gap:0;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden;transition:box-shadow .18s}.ticket-card:hover{box-shadow:var(--shadow-card-hover)}.ticket-accent{width:4px;align-self:stretch;flex-shrink:0;background:var(--accent)}.ticket-accent.yellow{background:var(--gold)}.ticket-accent.gray{background:var(--muted)}.ticket-body{flex:1;padding:14px 18px;min-width:0}.ticket-title{font-family:"Noto Serif",serif;font-size:.98rem;font-weight:600;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ticket-meta{font-size:.76rem;color:var(--muted);margin-top:3px}.ticket-actions{display:flex;align-items:center;gap:8px;padding:0 16px 0 8px;flex-shrink:0}@media (max-width: 600px){.ticket-card{flex-wrap:wrap}.ticket-actions{padding:0 14px 14px;width:100%}}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:20px 0 8px;display:flex;align-items:center;gap:8px}.section-label:after{content:"";flex:1;height:1px;background:var(--border-strong)}.org-card-header{height:52px;margin:-24px -24px 16px;display:flex;align-items:flex-end;padding:0 20px 10px;border-bottom:1px solid var(--border)}.org-card.class-card{padding:24px}
