*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#6dc533;--green-light:#8ad957;--green-dark:#58a327;--teal:#1aafaa;--teal-light:#32c7c2;--teal-dark:#138583;--dark:#0d5c5c;--dark-deep:#08403f;--dark-soft:#134f4e;--navy:var(--dark);--navy-light:var(--dark-soft);--navy-dark:var(--dark-deep);--gold:var(--green);--gold-light:var(--green-light);--gold-dark:var(--green-dark);--white:#fff;--gray-50:#f6faf8;--gray-100:#eaf2ef;--gray-200:#d6e2de;--gray-300:#b6c5c0;--gray-400:#8a9c97;--gray-500:#5d706b;--gray-600:#3f504c;--success:#22c55e;--success-bg:#f0fdf4;--warning:#f59e0b;--warning-bg:#fffbeb;--danger:#ef4444;--danger-bg:#fef2f2;--info:var(--teal);--info-bg:#e6f6f5;--radius-sm:6px;--radius:10px;--radius-lg:14px;--shadow-sm:0 1px 3px #0d5c5c14;--shadow:0 2px 8px #0d5c5c1f;--shadow-lg:0 8px 24px #0d5c5c29;--transition:.2s ease}body{background:var(--gray-50);color:var(--dark);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6}a{color:var(--teal-dark);text-decoration:none}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px}.loading-screen{min-height:60vh;color:var(--gray-400);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--green);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.navbar{background:linear-gradient(135deg, var(--dark-deep) 0%, var(--dark) 60%, var(--teal-dark) 100%);color:var(--white);min-height:64px;box-shadow:var(--shadow-lg);z-index:100;align-items:center;gap:24px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-brand{flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.navbar-logo{color:var(--white);flex-direction:column;text-decoration:none;display:flex}.logo-text{background:linear-gradient(90deg, var(--green) 0%, var(--teal-light) 100%);-webkit-text-fill-color:transparent;letter-spacing:.5px;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:800;line-height:1.2}.logo-sub{color:#ffffffb3;text-transform:uppercase;letter-spacing:2px;font-size:11px}.navbar-toggle{color:var(--white);cursor:pointer;background:0 0;border:none;padding:8px;display:none}.navbar-menu{flex:1;justify-content:space-between;align-items:center;gap:16px;display:flex}.navbar-links{gap:4px;display:flex}.nav-link{color:#ffffffbf;border-radius:var(--radius-sm);transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;display:flex}.nav-link:hover{color:var(--white);background:#ffffff14}.nav-link.active{color:var(--white);background:var(--green)}.navbar-user{align-items:center;gap:12px;margin-left:auto;display:flex}.user-name{font-size:14px;font-weight:600}.user-role{text-transform:uppercase;color:var(--green-light);letter-spacing:1px;font-size:11px}.nav-dropdown{display:inline-flex;position:relative}.nav-dropdown-trigger{cursor:pointer;font:inherit;background:0 0;border:none}.nav-dropdown-trigger.icon-only{margin-left:8px;padding:8px 10px}.nav-dropdown-panel{background:var(--dark-deep,#0b2424);border-radius:var(--radius-sm);min-width:200px;box-shadow:var(--shadow-lg);z-index:200;border:1px solid #ffffff14;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);left:0}.nav-dropdown-panel.align-right{left:auto;right:0}.nav-dropdown-item{color:#fffc;border-radius:var(--radius-sm);white-space:nowrap;transition:all var(--transition);align-items:center;gap:8px;padding:8px 12px;font-size:14px;text-decoration:none;display:flex}.nav-dropdown-item:hover{color:var(--white);background:#ffffff14}.nav-dropdown-item.active{background:var(--green);color:var(--white)}.page{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{color:var(--dark);font-size:28px;font-weight:800}.page-message{text-align:center;color:var(--gray-400);padding:48px}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:box-shadow var(--transition);overflow:hidden}.card:hover{box-shadow:var(--shadow)}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title-group{align-items:center;gap:10px;display:flex}.card-icon{color:var(--teal)}.card-title{color:var(--dark);font-size:16px;font-weight:700}.card-subtitle{color:var(--gray-400);margin-top:2px;font-size:13px}.card-body{padding:20px}.card-warning{border-left:4px solid var(--warning)}.card-info{border-left:4px solid var(--info)}.card-success{border-left:4px solid var(--success);background:var(--success-bg)}.card-highlight{border-left:4px solid var(--green)}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-number{color:var(--dark);font-size:36px;font-weight:800}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:var(--gray-50)}th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);border-bottom:2px solid var(--gray-200);padding:10px 14px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:12px 14px;font-size:14px}tr:hover{background:var(--gray-50)}tr.row-muted{opacity:.5}.font-medium{font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:10px 18px;font-size:14px;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--green);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--green-dark)}.btn-secondary{background:var(--gray-100);color:var(--dark)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-ghost{color:var(--gray-500);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--dark)}.btn-danger{background:var(--danger);color:var(--white)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--success);color:var(--white)}.btn-success:hover:not(:disabled){background:#16a34a}.btn-gold{background:var(--teal);color:var(--white)}.btn-gold:hover:not(:disabled){background:var(--teal-dark)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-full{justify-content:center;width:100%}.btn-icon{padding:6px}.action-buttons{gap:4px;display:flex}.form-group{margin-bottom:16px}.form-group label{color:var(--dark);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition);background:var(--white);color:var(--dark);padding:10px 14px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);outline:none;box-shadow:0 0 0 3px #6dc5332e}.form-group textarea{resize:vertical}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-info{background:var(--info-bg);color:var(--info);border-radius:var(--radius-sm);margin-bottom:16px;padding:12px;font-size:13px}.form-actions{justify-content:flex-end;gap:12px;display:flex}.child-input-row{gap:8px;margin-bottom:8px;display:flex}.child-input-row input{flex:1}.checkbox-label{cursor:pointer;align-items:center;gap:8px;display:flex!important}.checkbox-label input[type=checkbox]{width:auto}.input-with-prefix{align-items:center;gap:0;display:flex}.input-prefix{background:var(--gray-100);border:1px solid var(--gray-300);border-radius:var(--radius-sm) 0 0 var(--radius-sm);color:var(--gray-500);border-right:none;padding:10px 12px;font-weight:600}.input-with-prefix input{border-radius:0 var(--radius-sm) var(--radius-sm) 0!important}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;line-height:1.4;display:inline-flex}.badge-gold{color:var(--green-dark);background:#6dc53329}.badge-navy{color:var(--teal-dark);background:#1aafaa24}.badge-success{background:var(--success-bg);color:#16a34a}.badge-warning{background:var(--warning-bg);color:#b45309}.badge-error{background:var(--danger-bg);color:var(--danger)}.badge-muted{background:var(--gray-100);color:var(--gray-500)}.attended-toggle{cursor:pointer;border:none;font-family:inherit;transition:filter .12s,transform 80ms}.attended-toggle:hover:not(:disabled){filter:brightness(.95);transform:translateY(-1px)}.attended-toggle:disabled{opacity:.55;cursor:progress}.badge-outline{border:1px solid var(--gray-300);color:var(--gray-600);background:0 0}.alert{border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fca5a5}.alert-warning{background:var(--warning-bg);color:#b45309;border:1px solid #fcd34d}.alert-info{background:var(--info-bg);color:var(--info);border:1px solid #93c5fd}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#08403f8c;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-wide{max-width:800px}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-size:18px;font-weight:700}.modal-body{padding:24px}.modal-actions{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;display:flex}.auth-page{background:linear-gradient(135deg, var(--dark-deep) 0%, var(--dark) 45%, var(--teal-dark) 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;padding:40px}.auth-card-wide{max-width:520px}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{background:linear-gradient(90deg, var(--green) 0%, var(--teal) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800}.auth-logo p{text-transform:uppercase;letter-spacing:3px;color:var(--gray-500);font-size:13px}.auth-card h2{text-align:center;color:var(--dark);margin-bottom:24px;font-size:20px}.filter-bar{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.points-display{text-align:center}.points-big{margin-bottom:8px;font-size:48px;font-weight:800}.points-earned{color:var(--green)}.points-sep{color:var(--gray-300);margin:0 4px}.points-req{color:var(--dark)}.points-formula{color:var(--gray-500);margin-bottom:16px;font-size:14px}.points-bar{background:var(--gray-200);border-radius:4px;height:8px;margin:12px 0;overflow:hidden}.points-bar-fill{background:linear-gradient(90deg, var(--green), var(--teal));border-radius:4px;height:100%;transition:width .5s}.surplus-prompt{background:var(--warning-bg);border-radius:var(--radius-sm);margin-top:16px;padding:12px}.surplus-chosen{justify-content:center;align-items:center;gap:8px;margin-top:12px;display:flex}.surplus-options{flex-direction:column;gap:8px;margin:16px 0;display:flex}.radio-card{border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);align-items:center;gap:10px;padding:14px;display:flex}.radio-card:hover{border-color:var(--green)}.radio-card input:checked+span{font-weight:600}.radio-card:has(input:checked){border-color:var(--green);background:#6dc53312}.shift-list{flex-direction:column;gap:8px;display:flex}.shift-item{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.shift-item:last-child{border-bottom:none}.shift-info{flex-direction:column;display:flex}.shift-venue{font-size:14px;font-weight:600}.shift-date{color:var(--gray-400);font-size:13px}.shift-meta{align-items:center;gap:8px;display:flex}.events-list{flex-direction:column;gap:16px;display:flex}.event-card .event-meta{color:var(--gray-500);gap:24px;margin-bottom:16px;font-size:14px;display:flex}.event-meta span{align-items:center;gap:6px;display:flex}.positions-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.position-slot{border-radius:var(--radius-sm);flex-direction:column;gap:6px;padding:12px;display:flex}.position-slot.open{background:var(--gray-50);border:2px dashed var(--gray-300)}.position-slot.filled{border:1px solid var(--gray-200);background:#6dc53312}.position-name{color:var(--dark);font-size:13px;font-weight:600}.position-worker{color:var(--gray-500);font-size:13px}.waitlist-prompt{text-align:center;background:var(--gray-50);border-radius:var(--radius);margin-top:16px;padding:16px}.venue-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.venue-details p{margin-bottom:4px;font-size:14px}.positions-list{margin-top:8px}.positions-list ul{flex-wrap:wrap;gap:6px;margin-top:6px;list-style:none;display:flex}.positions-list li{background:var(--gray-100);color:var(--gray-600);border-radius:12px;padding:3px 10px;font-size:12px}.seasons-list{flex-direction:column;gap:12px;display:flex}.season-card{justify-content:space-between;align-items:center;gap:16px;display:flex}.season-info h3{font-size:18px;font-weight:700}.season-info p{color:var(--gray-500);font-size:14px}.season-actions{align-items:center;gap:12px;display:flex}.cancel-requests{flex-direction:column;gap:12px;display:flex}.cancel-request-details{grid-template-columns:1fr 1fr;gap:16px;margin:12px 0;display:grid}.cancel-request-details p{margin-bottom:4px;font-size:14px}.cancel-note{background:var(--gray-50);border-radius:var(--radius-sm);margin:8px 0;padding:12px;font-size:14px}.cancel-actions{gap:12px;margin-top:12px;display:flex}.attendance-checkbox{cursor:pointer;width:20px;height:20px;accent-color:var(--green)}.contact-link{color:var(--gray-500);align-items:center;gap:4px;font-size:13px;display:flex}.contact-link:hover{color:var(--dark)}.confirmed-banner{text-align:center;padding:32px}.confirmed-banner svg{color:var(--success);margin-bottom:16px}.confirmed-banner h2{color:var(--dark);margin-bottom:8px}.password-input{position:relative}.password-input input{width:100%;padding-right:44px!important}.password-toggle{cursor:pointer;color:var(--gray-500);border-radius:var(--radius-sm);transition:color var(--transition), background var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.password-toggle:hover{color:var(--dark);background:var(--gray-100)}.password-toggle:focus-visible{outline:2px solid var(--green);outline-offset:1px}.family-picker-list{border:1px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--white);max-height:220px;margin-top:6px;overflow-y:auto}.family-picker-item{text-align:left;border:none;border-bottom:1px solid var(--gray-100);cursor:pointer;width:100%;color:var(--dark);transition:background var(--transition);background:0 0;padding:8px 12px;font-size:14px;display:block}.family-picker-item:last-child{border-bottom:none}.family-picker-item:hover{background:var(--gray-50)}.family-picker-empty{color:var(--gray-500);text-align:center;padding:12px;font-size:13px}.text-muted{color:var(--gray-400)}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:24px}.mb-3{margin-bottom:12px}.ml-1{margin-left:4px}@media (width<=768px){.navbar{flex-wrap:wrap;padding:12px 16px}.navbar-brand{width:100%}.navbar-toggle{display:block}.navbar-menu{flex-direction:column;gap:8px;width:100%;padding:12px 0;display:none}.navbar-menu.open{display:flex}.navbar-links{flex-direction:column}.nav-link{padding:10px 14px}.nav-dropdown{flex-direction:column;width:100%;display:flex}.nav-dropdown-trigger.icon-only{justify-content:flex-start;width:100%;margin-left:0}.nav-dropdown-panel,.nav-dropdown-panel.align-right{width:100%;box-shadow:none;background:#ffffff0a;border:none;margin-top:4px;margin-left:16px;position:static}.navbar-user{border-top:1px solid #ffffff1a;flex-direction:column;align-items:flex-start;width:100%;padding-top:12px}.main-content{padding:16px}.page-header h1{font-size:22px}.dashboard-grid,.form-row,.cancel-request-details,.positions-grid{grid-template-columns:1fr}.season-card{flex-direction:column;align-items:flex-start}.points-big{font-size:36px}.event-card .event-meta{flex-direction:column;gap:6px}.auth-card{padding:24px}.modal{margin:16px}}@media (width<=480px){.table-wrapper{font-size:13px}th,td{padding:8px 10px}}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.stat{background:var(--gray-50,#f8fafc);border:1px solid var(--gray-100,#e5e7eb);border-radius:var(--radius-sm);text-align:center;padding:12px 16px}.stat-warn{background:var(--warning-bg);border-color:#fcd34d}.stat-value{color:var(--dark);font-size:24px;font-weight:700}.stat-warn .stat-value{color:#b45309}.stat-label{text-transform:uppercase;letter-spacing:1px;color:var(--gray-500);margin-top:4px;font-size:12px}.form-help{color:var(--gray-500);margin-top:6px;font-size:13px}.warning-list{margin:0;padding:0;list-style:none}.warning-list li{border-bottom:1px solid var(--gray-100,#e5e7eb);padding:6px 0;font-size:13px}.warning-list li:last-child{border-bottom:none}
