.hero{display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:32px;min-height:400px;padding:48px;color:#fff;border-radius:var(--radius-lg);overflow:hidden;background:radial-gradient(circle at 80% 15%,rgba(247,148,29,.3),transparent 35%),radial-gradient(circle at 20% 80%,rgba(0,160,176,.2),transparent 40%),linear-gradient(135deg,#2e3192f2,#0f172aeb);box-shadow:var(--shadow-lg);margin-bottom:20px}.hero .eyebrow{color:#ffffffb3}.hero h1{margin:10px 0 14px;font-size:clamp(2rem,4vw,3.2rem);line-height:1.08;letter-spacing:-.02em;font-weight:900}.hero p{color:#ffffffb8;font-size:1.02rem;line-height:1.65;max-width:560px}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.hero-actions .btn-primary{background:#fff;color:var(--blue);box-shadow:0 4px 20px #00000026}.hero-actions .btn-primary:hover{box-shadow:0 8px 32px #0003}.hero-actions .btn-ghost{color:#fff;background:#ffffff1f;border-color:#fff3}.hero-actions .btn-ghost:hover{background:#fff3}.hero-visual{display:flex;flex-direction:column;align-items:center;gap:14px}.hero-logo{width:160px;height:160px;object-fit:contain;padding:16px;background:#fff;border-radius:50%;box-shadow:0 20px 50px #00000040}.hero-badges{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.hero-badge{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-sm);font-weight:750;font-size:.85rem}.quick-stats{display:grid;grid-template-columns:repeat(3,1fr) 1.6fr;gap:14px;margin-bottom:20px}.quick-stat{display:flex;flex-direction:column;gap:6px;padding:18px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.quick-stat span{font-size:.72rem;font-weight:800;text-transform:uppercase;color:var(--muted);letter-spacing:.05em}.quick-stat strong{font-size:1.8rem;font-weight:900;color:var(--blue);line-height:1}.quick-stat p{font-size:.88rem;color:var(--muted)}.quick-stat.wide{grid-column:auto}.featured-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}.featured-strip button{display:flex;flex-direction:column;gap:4px;padding:12px;text-align:left;border-radius:var(--radius-sm);background:var(--surface-solid);border:1px solid var(--line);transition:all var(--transition)}.featured-strip button:hover{border-color:#2e319233;box-shadow:var(--shadow-sm)}.featured-strip button strong{font-size:.82rem;line-height:1.2;overflow-wrap:anywhere;color:var(--ink)}.featured-strip small{color:var(--orange);font-weight:800;font-size:.78rem}.discover-layout{display:grid;grid-template-columns:1fr 420px;gap:20px;align-items:start}.discover-main{padding:20px}.toolbar{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.searchbox{display:flex;align-items:center;gap:10px;padding:0 14px;min-height:48px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color var(--transition)}.searchbox:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px #2e31921a}.searchbox svg{color:var(--muted);flex-shrink:0}.searchbox input{flex:1;border:0;outline:none;background:transparent;font-size:.92rem}.filter-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.filter-strip::-webkit-scrollbar{display:none}.filter-strip button{flex-shrink:0;padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:700;color:var(--ink-secondary);background:var(--surface-solid);border:1px solid var(--line);transition:all var(--transition);white-space:nowrap}.filter-strip button:hover{border-color:#2e319233}.filter-strip button.active{color:#fff;background:var(--blue);border-color:var(--blue)}.club-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.club-card{background:var(--surface-solid);border:1px solid transparent;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition)}.club-card:hover{box-shadow:var(--shadow)}.club-card.selected{border-color:var(--orange);box-shadow:var(--shadow),0 0 0 2px #f7941d4d}.club-cover{display:flex;align-items:flex-start;justify-content:space-between;min-height:110px;padding:14px;background:var(--cover)}.club-cover img{width:48px;height:48px;object-fit:contain;padding:6px;background:#fff;border-radius:50%;box-shadow:0 4px 12px #00000026}.club-rank{color:#fff;font-weight:850;font-size:.82rem;opacity:.8}.club-body{display:flex;flex-direction:column;gap:10px;padding:16px}.club-body h3{font-size:1rem;line-height:1.25;font-weight:750;min-height:44px;overflow-wrap:anywhere}.club-body p{font-size:.86rem;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.club-meta{display:flex;flex-direction:column;gap:6px;font-size:.82rem;color:var(--ink-secondary)}.club-meta span{display:flex;align-items:center;gap:6px}.club-meta svg{color:var(--muted)}.detail-panel{position:sticky;top:80px;padding:18px;display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 100px);overflow-y:auto}.detail-panel::-webkit-scrollbar{width:4px}.detail-panel::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.detail-cover{display:flex;gap:14px;align-items:center;min-height:140px;padding:20px;color:#fff;background:var(--cover);border-radius:var(--radius-sm)}.detail-cover img{width:64px;height:64px;object-fit:contain;padding:8px;background:#fff;border-radius:50%;box-shadow:0 8px 24px #0003}.detail-cover span{color:#ffffffbf;font-size:.8rem;font-weight:600}.detail-cover h2{margin-top:4px;font-size:1.2rem;line-height:1.15;overflow-wrap:anywhere}.detail-body{display:flex;flex-direction:column;gap:14px}.detail-description{color:var(--muted);line-height:1.6;font-size:.92rem}.detail-metrics,.detail-people{display:grid;grid-template-columns:1fr 1fr;gap:10px}.detail-metrics>div,.detail-people>div{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm)}.detail-metrics span,.detail-people span{font-size:.72rem;font-weight:750;text-transform:uppercase;color:var(--muted)}.detail-metrics strong{color:var(--blue);font-size:1.1rem}.detail-people strong{font-size:.88rem;overflow-wrap:anywhere}.join-flow{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.join-flow>div{display:flex;align-items:center;justify-content:center;gap:5px;padding:8px;background:#2e31920f;border-radius:var(--radius-sm);font-size:.8rem;font-weight:750;color:var(--blue)}.detail-events{display:flex;flex-direction:column;gap:8px}.detail-events h3,.detail-board h3{font-size:.95rem;font-weight:800;margin-bottom:4px}.event-row{display:grid;grid-template-columns:52px 1fr;gap:10px;align-items:center;padding:10px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color var(--transition)}.event-row:hover{border-color:#2e31922e}.event-row time{display:grid;place-items:center;min-height:40px;color:#fff;font-size:.72rem;font-weight:850;text-align:center;background:linear-gradient(135deg,var(--blue),var(--teal));border-radius:var(--radius-sm)}.event-row div{display:flex;flex-direction:column;gap:2px;min-width:0}.event-row strong{font-size:.88rem;overflow-wrap:anywhere}.event-row span{font-size:.8rem;color:var(--muted)}.detail-board{display:flex;flex-direction:column;gap:6px}.board-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm)}.board-row svg{color:var(--blue);flex-shrink:0}.board-row div{display:flex;flex-direction:column;gap:2px;min-width:0}.board-row span{font-size:.76rem;color:var(--muted);font-weight:650}.board-row strong{font-size:.86rem;overflow-wrap:anywhere}.login-page{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;align-items:stretch;min-height:calc(100vh - 140px)}.login-visual{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:48px;color:#fff;border-radius:var(--radius-lg);background:radial-gradient(circle at 75% 15%,rgba(247,148,29,.35),transparent 35%),radial-gradient(circle at 20% 85%,rgba(0,160,176,.25),transparent 40%),linear-gradient(135deg,#2e3192f5,#0f172af0);box-shadow:var(--shadow-lg)}.login-visual img{width:110px;height:110px;object-fit:contain;padding:12px;background:#fff;border-radius:50%;box-shadow:0 16px 48px #0003}.login-visual .eyebrow{color:#ffffffa6}.login-visual h1{font-size:clamp(1.8rem,4vw,3rem);line-height:1.06;font-weight:900}.login-visual p{color:#ffffffb3;font-size:1rem;line-height:1.6;max-width:500px}.login-features{display:flex;flex-wrap:wrap;gap:8px}.login-features span{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-sm);font-weight:750;font-size:.82rem}.login-form{display:flex;flex-direction:column;justify-content:center;gap:16px;padding:36px}.login-form h2{font-size:1.8rem;font-weight:900}.login-form>div>p{color:var(--muted);line-height:1.5}.login-form label{display:flex;flex-direction:column;gap:6px}.login-form label span{font-size:.85rem;font-weight:750;color:var(--ink-secondary)}.login-form input{width:100%;min-height:48px;padding:0 14px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);outline:none;font-size:.92rem;transition:border-color var(--transition)}.login-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2e319214}.password-field{position:relative}.password-field input{padding-right:44px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);padding:6px;color:var(--muted);border-radius:4px}.password-toggle:hover{color:var(--ink)}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;color:var(--red);background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);font-weight:700;font-size:.88rem}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.create-club-page{display:grid;grid-template-columns:.9fr 1.1fr;gap:20px;align-items:start}.creation-gate{padding:28px;display:flex;flex-direction:column;gap:18px}.gate-header svg{color:var(--orange)}.gate-header h2{margin:8px 0 4px;font-size:1.4rem}.gate-header p{color:var(--muted);line-height:1.6}.gate-status{display:flex;align-items:center;gap:14px;padding:16px;border-radius:var(--radius-sm);background:#fef3c7;border:1px solid #fde68a;color:#92400e}.gate-status.open{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.gate-status-icon{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:#00000014}.gate-status.open .gate-status-icon{background:#0596691f}.gate-status strong{font-size:1.05rem;display:block}.gate-status span{font-size:.85rem}.creation-form{padding:24px;display:flex;flex-direction:column;gap:14px}.creation-form h2{font-size:1.4rem}.creation-form label{display:flex;flex-direction:column;gap:6px}.creation-form label span{font-size:.85rem;font-weight:700;color:var(--ink-secondary)}.creation-form input,.creation-form textarea{width:100%;padding:10px 14px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);outline:none;font-size:.92rem;transition:border-color var(--transition)}.creation-form input:focus,.creation-form textarea:focus{border-color:var(--blue)}.creation-form textarea{min-height:140px;resize:vertical}.creation-form input:disabled,.creation-form textarea:disabled{opacity:.5;cursor:not-allowed}.form-hint{font-size:.85rem;color:var(--muted);font-style:italic}.status-page{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.status-card{padding:24px;display:flex;flex-direction:column;gap:12px}.status-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue-light))}.status-card h3{font-size:1.1rem}.status-card p{color:var(--muted);line-height:1.55;font-size:.9rem}.status-progress{display:flex;align-items:center;gap:0;margin-top:8px}.progress-step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:0 0 auto}.step-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--line);background:#fff;transition:all var(--transition)}.progress-step.completed .step-dot{background:var(--green);border-color:var(--green)}.progress-step span{font-size:.72rem;font-weight:700;color:var(--muted)}.progress-line{flex:1;height:2px;background:var(--line);min-width:20px}.badges-section{grid-column:1 / -1}.badges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:8px}.badge-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;text-align:center;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-solid);transition:all var(--transition)}.badge-item.locked{opacity:.4;filter:grayscale(.8)}.badge-item.unlocked{border-color:#f7941d4d}.badge-item.unlocked:hover{box-shadow:0 4px 16px #f7941d26;transform:translateY(-2px)}.badge-icon{color:var(--orange)}.badge-item strong{font-size:.82rem}.badge-item span{font-size:.75rem;color:var(--muted)}.club-panel-page{display:flex;flex-direction:column;gap:20px}.my-club-hero{display:flex;align-items:center;gap:24px;padding:32px;color:#fff;border-radius:var(--radius-lg);overflow:hidden;background:radial-gradient(circle at 82% 16%,rgba(247,148,29,.3),transparent 36%),var(--cover, linear-gradient(135deg, var(--blue), var(--teal)));box-shadow:var(--shadow-lg)}.my-club-hero img{width:72px;height:72px;object-fit:contain;padding:9px;background:#fff;border-radius:50%;box-shadow:0 8px 28px #0003;flex-shrink:0}.my-club-hero .eyebrow{display:inline-block;padding:4px 12px;color:#ffffffd9;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:6px;margin-bottom:4px}.my-club-hero h2{margin:6px 0 2px;font-size:clamp(1.3rem,3vw,2rem);line-height:1.1}.my-club-hero p{color:#ffffffb3;font-size:.9rem}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat-card{display:flex;flex-direction:column;gap:8px;padding:18px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all var(--transition)}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue-light))}.stat-label{font-size:.78rem;font-weight:700;color:var(--muted);text-transform:uppercase}.stat-value{font-size:1.7rem;font-weight:900;line-height:1;color:var(--ink)}.panel-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.panel-two-col .glass-panel{padding:20px}.panel-heading{display:flex;align-items:center;gap:8px;margin-bottom:14px}.panel-heading svg{color:var(--blue)}.panel-heading h2{font-size:1.1rem;flex:1}.panel-heading .btn-approve{margin-left:4px}.badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 8px;background:#2e31921a;color:var(--blue);border-radius:12px;font-size:.78rem;font-weight:800}.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.board-member-card{display:flex;align-items:center;gap:10px;padding:12px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);transition:all var(--transition)}.board-member-card:hover{border-color:#2e319233;box-shadow:var(--shadow-sm)}.board-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--blue),var(--teal))}.board-member-card>div:last-child{display:flex;flex-direction:column;gap:1px;min-width:0}.board-member-card strong{font-size:.85rem;overflow-wrap:anywhere}.board-member-card span{font-size:.76rem;color:var(--muted);font-weight:650}.board-member-card small{font-size:.72rem;color:var(--teal);overflow-wrap:anywhere}.event-list{display:flex;flex-direction:column;gap:8px}.managed-club-switcher{padding:16px 20px}.managed-club-switcher>span{display:block;margin-bottom:8px;font-size:.82rem;font-weight:750;color:var(--ink-secondary)}.managed-club-tabs{display:flex;flex-wrap:wrap;gap:8px}.managed-club-tabs button{min-height:38px;padding:0 12px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink-secondary);font-size:.86rem;font-weight:750;transition:all var(--transition)}.managed-club-tabs button:hover,.managed-club-tabs button.active{color:var(--blue);border-color:#2e319247;background:#2e319214}.president-nomination-panel{padding:20px}.president-nomination-form{display:grid;grid-template-columns:minmax(180px,.7fr) minmax(260px,1fr) auto;gap:12px;align-items:end}.president-nomination-form.compact{grid-template-columns:minmax(260px,1fr) auto}.president-nomination-form label{display:flex;flex-direction:column;gap:6px}.president-nomination-form label span{font-size:.82rem;font-weight:750;color:var(--ink-secondary)}.president-nomination-form input,.president-nomination-form select{width:100%;min-height:44px;padding:0 12px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);outline:none}.president-nomination-form input:focus,.president-nomination-form select:focus{border-color:var(--blue)}.inline-lookup{display:flex;gap:8px}.inline-lookup input{min-width:0}.inline-lookup .btn-ghost{padding:0 14px;min-height:44px;white-space:nowrap}.candidate-preview,.pending-nomination-note{grid-column:1 / -1;padding:12px 14px;border-radius:var(--radius-sm);background:var(--surface-solid);border:1px solid var(--line)}.candidate-preview{display:flex;align-items:center;justify-content:space-between;gap:12px}.candidate-preview span,.pending-nomination-note{color:var(--muted);font-size:.88rem;font-weight:700}.president-info-card{padding:20px}.president-assigned-info{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#10b9810f,#05966908);border:1px solid rgba(16,185,129,.2)}.president-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#7c3aed,#4f46e5)}.president-assigned-info>div{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.president-assigned-info>div strong{font-size:.95rem;font-weight:800;color:var(--ink)}.president-assigned-info>div span{font-size:.82rem;color:var(--muted);font-weight:650}.president-check-icon{color:var(--green);flex-shrink:0}.board-role-label{display:block;font-size:.72rem;font-weight:750;color:var(--muted);text-transform:uppercase;letter-spacing:.02em;margin-bottom:4px}.board-member-card.president-slot{border-color:#7c3aed26;background:linear-gradient(135deg,#7c3aed08,#4f46e505)}.board-assigned{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.board-assigned strong{font-size:.85rem}.board-assigned small{font-size:.72rem;color:var(--teal);flex-basis:100%}.btn-remove-board{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;margin-left:auto;color:var(--muted);background:transparent;border:1px solid transparent;cursor:pointer;transition:all var(--transition)}.btn-remove-board:hover{color:var(--red);background:#ef444414;border-color:#ef444433}.board-pending-nomination{display:flex;flex-direction:column;gap:3px}.pending-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:800;text-transform:uppercase;color:var(--orange);letter-spacing:.03em}.board-pending-nomination strong{font-size:.85rem}.board-lookup-form{display:flex;flex-direction:column;gap:6px}.board-lookup-input{display:flex;gap:4px;align-items:center}.board-lookup-input input{flex:1;min-width:0;height:30px;padding:0 8px;background:var(--surface-solid);border:1px solid var(--line);border-radius:4px;outline:none;font-size:.8rem;transition:border-color var(--transition)}.board-lookup-input input:focus{border-color:var(--blue)}.btn-lookup{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:4px;flex-shrink:0;color:var(--blue);background:#2e31920f;border:1px solid rgba(46,49,146,.15);cursor:pointer;transition:all var(--transition)}.btn-lookup:hover:not(:disabled){background:#2e31921f;border-color:#2e319240}.btn-lookup:disabled{opacity:.4;cursor:not-allowed}.board-candidate-preview{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 8px;border-radius:4px;background:#10b9810f;border:1px solid rgba(16,185,129,.15)}.board-candidate-preview strong{font-size:.82rem;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-assign-board{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:4px;font-size:.72rem;font-weight:800;color:#fff;background:var(--green);border:none;cursor:pointer;white-space:nowrap;transition:all var(--transition)}.president-slot .btn-assign-board{background:linear-gradient(135deg,#7c3aed,#4f46e5)}.btn-assign-board:hover:not(:disabled){filter:brightness(1.1)}.btn-assign-board:disabled{opacity:.5;cursor:not-allowed}.board-empty-label{font-size:.82rem;color:var(--muted);font-style:italic}.event-add-form{display:flex;flex-direction:column;gap:8px;padding:12px 16px;margin:0 16px 12px;background:var(--surface-solid);border-radius:var(--radius-sm);border:1px dashed var(--line)}.event-form-row{display:flex;gap:8px}.event-form-row input{flex:1;min-width:0;height:34px;padding:0 10px;background:var(--surface);border:1px solid var(--line);border-radius:4px;outline:none;font-size:.82rem;color:var(--text);transition:border-color var(--transition)}.event-form-row input:focus{border-color:var(--blue)}.event-form-row input::placeholder{color:var(--muted)}.event-row{display:flex;align-items:center;gap:8px}.event-row .btn-remove-board{flex-shrink:0}.chart-section{padding:20px}.chart-tooltip{padding:12px 16px;background:#fffffff2;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:.85rem}.chart-tooltip strong{display:block;margin-bottom:4px}.approvals-page{display:flex;flex-direction:column;gap:20px}.page-header{display:flex;align-items:center;gap:14px;padding:20px 24px;border-radius:var(--radius);background:linear-gradient(135deg,#2e31920f,#00a0b00a);border:1px solid var(--line)}.page-header svg{color:var(--blue);flex-shrink:0}.page-header h1{font-size:1.4rem}.page-header p{font-size:.9rem;color:var(--muted)}.page-header .badge-count{margin-left:auto}.approvals-list{padding:16px;display:flex;flex-direction:column;gap:10px}.approval-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);transition:all var(--transition)}.approval-card:hover{box-shadow:var(--shadow-sm)}.approval-info{flex:1;min-width:0}.approval-step{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:750;color:var(--muted);text-transform:uppercase;margin-bottom:4px}.approval-card h3{font-size:1rem;margin-bottom:2px}.approval-club{font-size:.88rem;color:var(--blue);font-weight:700}.approval-motivation{font-size:.85rem;color:var(--muted);font-style:italic;margin-top:4px}.approval-time{font-size:.78rem;color:var(--muted)}.approval-actions{display:flex;gap:8px;flex-shrink:0}.sks-page{display:flex;flex-direction:column;gap:20px}.sks-layout{display:grid;grid-template-columns:.75fr 1.25fr;gap:16px;align-items:start}.sks-unlock{padding:24px;display:flex;flex-direction:column;gap:14px}.sks-unlock h2{font-size:1.3rem}.sks-unlock p{color:var(--muted);line-height:1.5}.unlock-form{display:flex;flex-direction:column;gap:12px}.unlock-form label{display:flex;flex-direction:column;gap:5px}.unlock-form label span{font-size:.82rem;font-weight:700;color:var(--ink-secondary)}.unlock-form input{width:100%;min-height:44px;padding:0 12px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition)}.unlock-form input:focus{border-color:var(--blue)}.sks-requests{padding:20px;display:flex;flex-direction:column;gap:12px}.creation-request-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;margin-top:8px}.request-info{flex:1;min-width:0}.request-unit{font-size:.75rem;font-weight:750;color:var(--muted);text-transform:uppercase}.request-info h3{font-size:1.05rem;margin:4px 0 2px}.request-info p{font-size:.88rem;color:var(--muted)}.request-purpose{font-style:italic;margin-top:4px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 24px;text-align:center}.empty-icon{color:var(--muted);opacity:.4}.empty-state h3{font-size:1.1rem;color:var(--ink-secondary)}.empty-state p{font-size:.9rem;color:var(--muted);max-width:320px}.countdown-badge{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#2e31920f,#f7941d0f);border:1px solid rgba(46,49,146,.12)}.countdown-badge>svg{color:var(--blue);flex-shrink:0}.countdown-label{font-size:.82rem;font-weight:700;color:var(--ink-secondary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.countdown-units{display:flex;gap:8px}.countdown-unit{display:flex;flex-direction:column;align-items:center;gap:1px}.countdown-unit strong{font-size:1rem;font-weight:900;color:var(--blue)}.countdown-unit span{font-size:.65rem;font-weight:700;color:var(--muted);text-transform:uppercase}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:400px;width:100%}.toast{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#ffffffeb;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.toast--success{border-left:3px solid var(--green)}.toast--error{border-left:3px solid var(--red)}.toast--warning{border-left:3px solid var(--orange)}.toast--info{border-left:3px solid var(--blue)}.toast-icon{flex-shrink:0}.toast--success .toast-icon{color:var(--green)}.toast--error .toast-icon{color:var(--red)}.toast--warning .toast-icon{color:var(--orange)}.toast--info .toast-icon{color:var(--blue)}.toast-message{flex:1;font-size:.88rem;font-weight:600;color:var(--ink)}.toast-close{padding:4px;color:var(--muted);border-radius:4px;flex-shrink:0}.toast-close:hover{color:var(--ink)}.skeleton-card{border-radius:var(--radius);overflow:hidden;background:var(--surface-solid);border:1px solid var(--line)}.skeleton-cover{height:110px}.skeleton-body{padding:16px;display:flex;flex-direction:column;gap:10px}.skeleton-line{height:14px;border-radius:6px;background:#e2e8f0}.skeleton-circle{width:40px;height:40px;border-radius:50%;background:#e2e8f0}.skeleton-stat{display:flex;flex-direction:column;gap:10px;padding:18px;background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius)}.skeleton-row{margin-bottom:8px}.w-full{width:100%}.w-80{width:80%}.w-60{width:60%}.w-40{width:40%}.shimmer{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.confetti-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:10000;pointer-events:none}@media(max-width:1120px){.hero{grid-template-columns:1fr;min-height:auto;padding:32px}.hero-visual{flex-direction:row;justify-content:flex-start}.hero-logo{width:100px;height:100px}.quick-stats{grid-template-columns:repeat(2,1fr)}.quick-stat.wide{grid-column:1 / -1}.discover-layout{grid-template-columns:1fr}.detail-panel{position:static;max-height:none}.login-page{grid-template-columns:1fr}.login-visual{min-height:auto;padding:32px}.create-club-page,.status-page{grid-template-columns:1fr}.badges-grid{grid-template-columns:repeat(2,1fr)}.badges-section{grid-column:auto}.panel-two-col,.president-nomination-form{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.sks-layout{grid-template-columns:1fr}.my-club-hero{flex-direction:column;text-align:center}.board-grid{grid-template-columns:1fr}}@media(max-width:768px){.header-inner{flex-wrap:wrap;padding:10px 16px}.main-nav{display:none}.mobile-toggle{display:block}.auth-area .user-identity{display:none}.main-content{padding:16px}.hero{padding:24px}.hero h1{font-size:1.6rem}.hero-logo{width:80px;height:80px}.quick-stats,.featured-strip,.stat-grid,.badges-grid,.join-flow{grid-template-columns:1fr}.approval-card{flex-direction:column;align-items:stretch}.approval-actions{width:100%}.approval-actions button{flex:1}.inline-lookup{flex-direction:column}.creation-request-card{flex-direction:column;align-items:stretch}.login-form{padding:24px}.toast-container{bottom:12px;right:12px;left:12px;max-width:none}}@media(min-width:769px){.mobile-toggle{display:none}.mobile-nav{display:none!important}}:root{--blue: #2e3192;--blue-light: #4f46e5;--orange: #f7941d;--orange-dark: #ea580c;--teal: #00a0b0;--green: #16805b;--red: #b42318;--purple: #7c3aed;--ink: #0f172a;--ink-secondary: #334155;--muted: #64748b;--line: rgba(46,49,146,.1);--surface: rgba(255,255,255,.72);--surface-solid: #ffffff;--bg: #f1f5f9;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);--shadow: 0 4px 24px rgba(15,23,42,.08);--shadow-lg: 0 20px 60px rgba(15,23,42,.12);--shadow-glow: 0 0 40px rgba(46,49,146,.15);--transition: .2s cubic-bezier(.25,.46,.45,.94)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;color:var(--ink);background:linear-gradient(135deg,#f0f4ff,#e8f0fe,#fdf4e8);background-attachment:fixed;-webkit-font-smoothing:antialiased}button,input,textarea,select{font:inherit}button{cursor:pointer;border:none;background:none}a{text-decoration:none;color:inherit}.app-root{min-height:100vh;display:flex;flex-direction:column}.site-header{position:sticky;top:0;z-index:100;background:#ffffffc7;border-bottom:1px solid var(--line);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}.header-inner{display:flex;align-items:center;gap:20px;max-width:1440px;margin:0 auto;padding:10px 28px}.brand-lockup{display:flex;align-items:center;gap:12px;cursor:pointer;flex-shrink:0}.brand-lockup img{width:44px;height:44px;object-fit:contain;padding:5px;background:#fff;border-radius:50%;box-shadow:var(--shadow-sm)}.brand-lockup strong{display:block;font-size:.95rem;font-weight:800;color:var(--ink)}.brand-lockup span{display:block;font-size:.78rem;color:var(--muted);font-weight:500}.main-nav{display:flex;gap:4px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none}.main-nav::-webkit-scrollbar{display:none}.nav-pill{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:650;color:var(--muted);white-space:nowrap;transition:all var(--transition)}.nav-pill:hover{color:var(--blue);background:#2e31920f}.nav-pill.active{color:var(--blue);background:#2e31921a;box-shadow:inset 0 0 0 1px #2e319226}.nav-pill svg{width:17px;height:17px;flex-shrink:0}.auth-area{display:flex;align-items:center;gap:10px;flex-shrink:0}.user-menu{display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--teal));display:grid;place-items:center;color:#fff}.user-identity{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.85rem;font-weight:700;color:var(--ink-secondary);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role-label{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.7rem;font-weight:700;color:var(--muted)}.auth-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;transition:all var(--transition)}.auth-btn.login{color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue-light));box-shadow:0 4px 16px #2e319240}.auth-btn.login:hover{box-shadow:0 6px 24px #2e319259;transform:translateY(-1px)}.auth-btn.logout{color:var(--muted);padding:8px;border-radius:50%}.auth-btn.logout:hover{color:var(--red);background:#b4231814}.mobile-toggle{display:none;padding:8px;color:var(--ink)}.mobile-nav{display:flex;flex-direction:column;gap:4px;padding:8px 16px 16px;border-top:1px solid var(--line)}.main-content{flex:1;width:min(1440px,100%);margin:0 auto;padding:24px 28px 60px}.student-president-notice{width:min(1440px,calc(100% - 56px));margin:16px auto 0;padding:12px 16px;border:1px solid rgba(247,148,29,.28);border-radius:var(--radius-sm);color:#7c3f00;background:#fff7ed;font-weight:750;line-height:1.45}.glass-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.eyebrow{display:inline-flex;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--blue)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:var(--radius-sm);font-weight:750;color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue-light));box-shadow:0 4px 16px #2e319238;transition:all var(--transition)}.btn-primary:hover{box-shadow:0 8px 28px #2e31924d;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:var(--radius-sm);font-weight:700;color:var(--ink-secondary);background:#fff9;border:1px solid var(--line);transition:all var(--transition)}.btn-ghost:hover{background:#fff;border-color:#2e319233}.btn-apply{width:100%;padding:14px 22px;border-radius:var(--radius-sm);font-weight:750;color:#fff;background:linear-gradient(135deg,var(--blue),var(--orange));box-shadow:0 6px 24px #2e319233;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all var(--transition)}.btn-apply:hover{box-shadow:0 10px 36px #2e31924d;transform:translateY(-1px)}.btn-apply-login{background:linear-gradient(135deg,var(--ink-secondary),var(--blue))}.btn-approve,.btn-reject{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);font-weight:700;font-size:.85rem;transition:all var(--transition)}.btn-approve{color:#fff;background:var(--green)}.btn-approve:hover{background:#12714f;transform:translateY(-1px)}.btn-reject{color:#fff;background:var(--red)}.btn-reject:hover{background:#9a1e14;transform:translateY(-1px)}
