*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#f5f5f5;color:#333}#root{width:100%}:root{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e8e8e8;--text-primary: #333333;--text-secondary: #555555;--text-muted: #666666;--border-color: #dddddd;--accent-green: #4CAF50;--accent-green-hover: #45a049;--accent-blue: #2196F3;--accent-orange: #ff9800;--accent-red: #f44336;--status-active-bg: #e8f5e9;--status-waiting-bg: #fff8f0;--booking-bg: #e3f2fd;--compound-color: #ff5722}body{background:var(--bg-primary);color:var(--text-primary);margin:0;padding:0}.App,.Admin{max-width:900px;margin:0 auto;padding:20px 20px 40px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-header{background:var(--bg-primary);margin:-20px -20px 0;padding:20px;border-bottom:1px solid var(--border-color)}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.header-top h1{margin:0;border:none;padding:0;font-size:24px;color:var(--text-primary)}.header-nav{display:flex;gap:16px}.header-nav a{color:var(--text-muted);text-decoration:none;padding:6px 12px;border-radius:4px;font-size:14px;transition:all .15s}.header-nav a:hover{background:var(--bg-tertiary);color:var(--text-primary)}.instructions-banner{background:linear-gradient(135deg,var(--status-active-bg),#e8f5e9);border:1px solid var(--accent-green);border-radius:12px;padding:16px 20px;margin-bottom:20px;margin-top:20px;display:flex;gap:16px;align-items:flex-start}.instructions-content{flex:1}.instructions-content h3{margin:0 0 8px;font-size:16px;color:var(--text-primary)}.instructions-content p{margin:0 0 12px;font-size:14px;color:var(--text-secondary);line-height:1.5}.instructions-content ul{margin:0;padding-left:20px;font-size:13px;color:var(--text-secondary)}.instructions-content li{margin-bottom:4px}.instructions-banner .dismiss-btn{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;transition:color .15s}.instructions-banner .dismiss-btn:hover{color:var(--text-primary)}.team-selector{margin-bottom:0}.team-selector select{max-width:400px;width:100%;padding:12px;font-size:16px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary)}.team-selector select:focus{outline:none;border-color:var(--accent-green)}.admin-team-selector{padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.admin-team-selector select{max-width:400px;width:100%;padding:12px;font-size:16px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary)}.admin-team-selector select:focus{outline:none;border-color:var(--accent-green)}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:16px;color:var(--text-muted)}.no-team-message{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:16px}.booking-steps-layout{max-width:800px}.steps-container{margin-top:24px}.steps-progress{margin-bottom:24px;padding:16px 20px;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 3px #0000001a}.progress-text{display:block;font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-green);border-radius:4px;transition:width .3s ease}.step-card{background:var(--bg-secondary);border-radius:12px;margin-bottom:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:box-shadow .2s}.step-card:hover{box-shadow:0 2px 8px #0000001f}.step-card.active{border:2px solid var(--accent-green)}.step-card.completed{border-left:4px solid var(--accent-green)}.step-card.waiting{opacity:.85}.step-card.not_started{opacity:.6}.step-header{display:flex;align-items:center;padding:16px 20px;gap:16px;cursor:pointer}.step-card.waiting .step-header,.step-card.not_started .step-header{cursor:default}.step-number{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;flex-shrink:0}.step-card.active .step-number,.step-card.completed .step-number{background:var(--accent-green);color:#fff}.step-info{flex:1;min-width:0}.step-info h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.step-description{margin:0;font-size:13px;color:var(--text-muted)}.step-status{text-align:right;flex-shrink:0}.status-completed,.status-active,.status-waiting,.status-not-started{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.status-label{font-size:12px;font-weight:600;color:var(--accent-green);text-transform:uppercase}.booking-summary{font-size:14px;color:var(--text-secondary);font-weight:500}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.active{background:var(--accent-green);color:#fff}.status-badge.waiting{background:var(--accent-orange);color:#fff}.status-badge.not-started{background:var(--bg-tertiary);color:var(--text-muted)}.slots-available,.queue-info{font-size:12px;color:var(--text-muted)}.step-expand-icon{color:var(--text-muted);font-size:12px;margin-left:8px}.step-content{padding:20px;border-top:1px solid var(--border-color);margin-top:0}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.slot-card{border:2px solid var(--border-color);border-radius:8px;padding:14px;background:var(--bg-secondary);transition:transform .15s,box-shadow .15s,border-color .15s}.slot-card.available:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--accent-green)}.slot-card.booked{background:var(--bg-tertiary);opacity:.7}.slot-day{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.slot-time{font-size:14px;font-weight:700;color:var(--accent-green);margin-bottom:6px}.slot-name{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.slot-compound{font-size:12px;color:var(--compound-color);font-weight:500;margin-bottom:8px}.slot-booked-info{display:flex;flex-direction:column;gap:2px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color)}.booked-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.booked-team{font-size:13px;font-weight:600;color:var(--text-secondary)}.book-btn{width:100%;padding:10px 16px;margin-top:12px;background:var(--accent-green);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s}.book-btn:hover{background:var(--accent-green-hover)}.book-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.slots-by-day{display:flex;flex-direction:column;gap:16px}.day-group{background:var(--bg-primary);border-radius:8px;overflow:hidden}.day-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.day-name{font-weight:600;font-size:15px;color:var(--text-primary)}.day-availability{font-size:12px;color:var(--text-muted)}.day-slots{display:flex;flex-direction:column}.slot-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color);transition:background .15s}.slot-row:last-child{border-bottom:none}.slot-row.available:hover{background:#fafafa}.slot-row.booked{background:var(--bg-tertiary);opacity:.7}.slot-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.slot-time-compact{font-weight:600;font-size:14px;color:var(--text-primary);min-width:110px}.slot-field{font-size:14px;color:var(--text-secondary)}.slot-rotation-detail{font-size:12px;color:var(--text-muted);padding-left:8px;border-left:2px solid var(--border-color)}.rotation-segment{display:inline}.rotation-segment:not(:last-child):after{content:", "}.slot-restriction-tag{font-size:10px;font-weight:600;text-transform:uppercase;background:#fff3e0;color:#e65100;padding:2px 6px;border-radius:3px;letter-spacing:.3px}.slot-row.restricted{border-left:3px solid #ffa000}.not-eligible{font-size:12px;color:var(--text-muted);font-style:italic}.slot-action{flex-shrink:0;margin-left:12px}.booked-by{font-size:13px;color:var(--text-muted);font-style:italic}.select-btn{padding:6px 16px;background:var(--accent-green);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s}.select-btn:hover{background:var(--accent-green-hover)}.select-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.booking-details{background:var(--status-active-bg);border-radius:8px;padding:16px}.booking-detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05)}.booking-detail-row:last-child{border-bottom:none}.detail-label{font-size:13px;color:var(--text-muted)}.detail-value{font-size:14px;font-weight:600;color:var(--text-primary)}@media(max-width:600px){.header-top{flex-direction:column;align-items:flex-start;gap:12px}.header-top h1{font-size:20px}.header-nav{width:100%;justify-content:flex-start}.step-header{flex-wrap:wrap;gap:12px}.step-info{flex:1 1 calc(100% - 56px)}.step-status{flex:1 1 100%;text-align:left;padding-left:56px;margin-top:-8px}.status-completed,.status-active,.status-waiting,.status-not-started{flex-direction:row;align-items:center;gap:8px}.step-expand-icon{position:absolute;right:20px;top:50%;transform:translateY(-50%)}.step-header{position:relative;padding-right:40px}.slots-grid{grid-template-columns:1fr}.slot-row{flex-direction:column;align-items:flex-start;gap:8px;padding:12px 16px}.slot-info{flex-wrap:wrap;gap:6px 12px;width:100%}.slot-time-compact{min-width:auto;flex-shrink:0}.slot-field{flex:1;min-width:0}.slot-restriction-tag{flex-shrink:0}.slot-rotation-detail{flex-basis:100%;order:10;border-left:none;padding-left:0;font-size:11px;margin-top:4px;display:flex;flex-direction:column;gap:2px}.rotation-segment{display:block}.rotation-segment:not(:last-child):after{content:none}.slot-action{margin-left:0;align-self:flex-end}.not-eligible{font-size:11px;padding:6px 0}.select-btn{padding:8px 20px}.booked-by{font-size:12px}}h1{color:var(--text-primary);border-bottom:3px solid var(--accent-green);padding-bottom:10px}h2{color:var(--text-secondary);margin-top:0}h3{color:var(--text-primary);margin:0 0 10px}a{color:var(--accent-blue)}.section{background:var(--bg-secondary);border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 2px 4px #0000001a}select,input[type=text],input[type=time]{width:100%;padding:10px;font-size:16px;border:2px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);box-sizing:border-box}select:focus,input:focus{outline:none;border-color:var(--accent-green)}.tabs{display:flex;gap:10px;flex-wrap:wrap}.tabs button{padding:10px 20px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:14px;color:var(--text-primary);transition:all .2s;display:inline-flex;align-items:center;gap:8px}.tabs button:hover{background:var(--border-color)}.tabs button.active{background:var(--accent-green);color:#fff;border-color:var(--accent-green)}.message{padding:10px 15px;margin-bottom:20px;border-radius:4px;display:flex;justify-content:space-between;align-items:center}.message.success{background:var(--status-active-bg);border:1px solid var(--accent-green)}.message.error{background:#ffebee;border:1px solid var(--accent-red)}table{width:100%;border-collapse:collapse}th{padding:12px 10px;text-align:left;border-bottom:2px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary)}td{padding:10px;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}tr:hover td{background:#f9f9f9}.badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700;color:#fff}.badge.active{background:var(--accent-green)}.badge.completed{background:var(--accent-blue)}.badge.waiting{background:var(--accent-orange)}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:opacity .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-green);color:#fff}.btn-primary:hover{background:var(--accent-green-hover)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{background:#d32f2f}.compound-form{background:#fff3e0;padding:15px;border-radius:4px;margin-bottom:15px;border:1px solid var(--accent-orange)}.nav-brand a{font-size:18px;font-weight:700;color:#333;text-decoration:none}.nav-brand a:hover{color:#4caf50}.nav-links{display:flex;gap:8px}.nav-links a{color:#666;text-decoration:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;transition:all .15s}.nav-links a:hover{background:#f0f0f0;color:#333}.nav-links a.active{background:#4caf50;color:#fff}.nav-links a.active:hover{background:#45a049}.site-header{background:#fff;border-bottom:1px solid #ddd;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #00000014}.nav-brand{text-align:center;padding:12px 24px 8px;border-bottom:1px solid #eee}.main-nav{display:flex;justify-content:space-between;align-items:center;padding:10px 24px}.nav-user{display:flex;align-items:center;gap:12px}.user-name{font-size:14px;color:#666;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sign-out-btn{padding:6px 12px;background:transparent;border:1px solid #ddd;border-radius:6px;color:#666;font-size:13px;cursor:pointer;transition:all .15s}.sign-out-btn:hover{background:#f5f5f5;border-color:#ccc;color:#333}.sign-in-link{padding:6px 12px;background:#4caf50;border-radius:6px;color:#fff;font-size:13px;text-decoration:none;font-weight:500}.sign-in-link:hover{background:#45a049}@media(max-width:600px){.nav-brand{padding:10px 16px 6px}.nav-brand a{font-size:16px}.main-nav{flex-wrap:wrap;justify-content:center;gap:8px;padding:8px 16px}.nav-links{order:2;width:100%;justify-content:center}.nav-user{order:1}.nav-links a{padding:8px 12px;font-size:13px}}.calendar-container{max-width:1600px;margin:0 auto;padding:20px}.calendar-controls{display:flex;gap:30px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.calendar-controls .section{display:flex;align-items:center;gap:10px}.calendar-controls label{font-weight:600;color:#555}.calendar-loading,.calendar-error{text-align:center;padding:40px;color:#666}.calendar-grid{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto;margin-top:20px}.calendar-header{display:grid;grid-template-columns:120px repeat(5,1.4fr) repeat(2,1.5fr);background:#f5f5f5;border-bottom:2px solid #ddd;position:sticky;top:0;z-index:10}.fields-horizontal .calendar-header{grid-template-columns:120px 100px repeat(var(--field-count, 4),1fr)}.field-label-header,.day-header{padding:12px 8px;font-weight:700;text-align:center;border-right:1px solid #ddd}.field-label-header{position:sticky;left:0;z-index:11;background:#f5f5f5}.day-header{font-size:14px}.day-header.weekend{background:#fff3e0;color:#e65100}.day-cell.weekend{background:#fffaf5}.calendar-row{display:grid;grid-template-columns:120px repeat(5,1.4fr) repeat(2,1.5fr);border-bottom:2px solid #ccc}.calendar-row:hover{background:#fafafa}.calendar-row.weekend{background:#fffaf5}.calendar-row.weekend:hover{background:#fff5eb}.fields-horizontal .calendar-row{grid-template-columns:120px 100px repeat(var(--field-count, 4),1fr)}.field-label{padding:12px 8px 12px 12px;font-weight:600;background:#f9f9f9;border-right:1px solid #ddd;border-left:4px solid #9e9e9e;display:flex;align-items:flex-start;font-size:13px;position:sticky;left:0;z-index:5}.field-label span{position:sticky;top:60px}.field-label.day-label{font-weight:700}.field-label.field-friends-north{border-left-color:#1976d2}.field-label.field-friends-south{border-left-color:#0097a7}.field-label.field-friends-outfield{border-left-color:#00838f}.field-label.field-alto{border-left-color:#f57c00}.field-label.field-boyle{border-left-color:#7b1fa2}.calendar-row.field-row-friends-north:hover{background:#f5faff}.calendar-row.field-row-friends-south:hover{background:#f5fcfd}.calendar-row.field-row-friends-outfield:hover{background:#f5fbfa}.calendar-row.field-row-alto:hover{background:#fffbf5}.calendar-row.field-row-boyle:hover{background:#fdf5ff}.field-label.continuation{border-top:none}.time-label{padding:12px 8px;font-weight:500;background:#fafafa;border-right:1px solid #ddd;display:flex;align-items:center;justify-content:center;font-size:12px;color:#666}.day-cell{padding:8px;min-height:80px;border-right:1px solid #eee;display:flex;flex-direction:column;gap:4px}.fields-horizontal .day-cell{min-height:50px;justify-content:center}.no-slots{color:#ccc;text-align:center;padding:20px 0}.slot-block{padding:8px;border-radius:4px;font-size:12px;cursor:default;transition:transform .1s}.slot-block:hover{transform:scale(1.02)}.slot-block.available{background:#e8f5e9;border:1px solid #4CAF50;color:#2e7d32}.slot-block.booked{background:#e3f2fd;border:1px solid #2196F3;color:#1565c0}.slot-block.restricted{border-style:dashed}.slot-block.available.restricted{background:#fff8e1;border-color:#ffa000;color:#e65100}.slot-restriction{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;opacity:.8;margin-bottom:2px}.slot-time{font-weight:600;margin-bottom:2px}.slot-segment{display:flex;gap:0px;align-items:baseline}.segment-location{display:inline;padding-left:4px}.slot-status{font-size:11px;opacity:.9}.reserve-link{background:none;border:none;color:#2196f3;cursor:pointer;font-size:11px;padding:0;margin-left:6px;text-decoration:underline;font-weight:500}.reserve-link:hover{color:#1565c0}.reserve-link:disabled{color:#999;cursor:not-allowed}.calendar-legend{display:flex;gap:20px;margin-top:20px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.legend-item{display:flex;align-items:center;gap:8px}.legend-box{width:20px;height:20px;border-radius:4px}.legend-box.available{background:#e8f5e9;border:1px solid #4CAF50}.legend-box.booked{background:#e3f2fd;border:1px solid #2196F3}.legend-box.weekend{background:#fff3e0;border:1px solid #ff9800}.legend-box.restricted{background:#fff8e1;border:1px dashed #ffa000}@media(max-width:1400px){.calendar-header,.calendar-row{grid-template-columns:100px repeat(5,minmax(130px,1fr)) repeat(2,minmax(140px,1fr))}.fields-horizontal .calendar-header,.fields-horizontal .calendar-row{grid-template-columns:100px 80px repeat(var(--field-count, 4),minmax(80px,1fr))}.field-label{font-size:11px}.slot-block{font-size:10px;padding:6px}.time-label{font-size:10px;padding:8px 4px}}@media(max-width:900px){.calendar-controls{flex-direction:column;align-items:flex-start}}.status-container{max-width:1400px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:3px solid #4CAF50}.status-header h1{margin:0;font-size:24px;color:#333}.status-nav{display:flex;gap:16px}.status-nav a{color:#666;text-decoration:none;padding:6px 12px;border-radius:4px;font-size:14px;transition:all .15s}.status-nav a:hover{background:#e8e8e8;color:#333}.status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}@media(max-width:1200px){.status-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.status-grid{grid-template-columns:1fr}}.status-column{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;min-height:300px}.status-column h2{margin:0 0 16px;font-size:14px;font-weight:600;color:#333;padding-bottom:8px;border-bottom:2px solid #4CAF50}.status-empty{color:#999;font-size:13px;text-align:center;padding:40px 0}.status-divisions{display:flex;flex-direction:column;gap:16px}.status-division h3{margin:0 0 8px;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #ddd;padding-bottom:4px}.status-entries{display:flex;flex-direction:column;gap:2px}.status-entry{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:4px;font-size:13px;border:1px solid transparent;background:#f9f9f9}.status-entry.active{background:#fff3e0;border-color:#ff9800}.status-entry.completed{background:#f5f5f5}.status-position{color:#999;width:20px;font-size:12px;flex-shrink:0}.status-team-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-entry.completed .status-team-name{text-decoration:line-through;color:#999}.status-badge{font-size:10px;padding:2px 6px;border-radius:3px;flex-shrink:0;font-weight:600}.status-badge.now{background:#ff9800;color:#fff}.status-badge.done{color:#4caf50}.refresh-btn{display:block;margin:24px auto 0;padding:10px 24px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .15s}.refresh-btn:hover{background:#45a049}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:20px}.login-container{background:#fff;padding:40px;border-radius:12px;box-shadow:0 2px 10px #0000001a;max-width:400px;width:100%;text-align:center}.login-container h1{margin:0 0 24px;color:#333;font-size:24px}.login-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.login-message{color:#666;font-size:14px;line-height:1.6}.login-message p{margin:0 0 12px}.login-message p:last-child{margin-bottom:0}.admin-login-form{display:flex;flex-direction:column;gap:12px}.admin-login-form input{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px}.admin-login-form input:focus{outline:none;border-color:#4caf50}.admin-login-form button{padding:12px 16px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer}.admin-login-form button:hover:not(:disabled){background:#45a049}.admin-login-form button:disabled{background:#ccc;cursor:not-allowed}
