*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #e8f1f8;--bg-soft: #f0f6fb;--card: #ffffff;--ink: #1a2a3a;--muted: #627080;--line: #c8d8e8;--green: #2f9e6d;--green-dark: #177b52;--mint: #dff5e8;--yellow: #ffd86b;--coral: #ff765f;--blue: #4f8fcf;--purple: #9a72d8;--shadow: 0 16px 35px rgba(20, 50, 80, .12);--radius: 22px}html,body,#root{min-height:100%}body{min-height:100vh;background:linear-gradient(180deg,#78b4dc33,#e8f1f800 300px),var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}button,input,select{font:inherit}button{cursor:pointer}.app{min-height:100vh;display:flex;flex-direction:column}.empty-ball{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,#fff 0,#fff 18%,#ffd86b 19%,#ffd86b 48%,#2f9e6d 49%,#2f9e6d);color:#143b2a;font-size:12px;font-weight:900;border:3px solid #fff;box-shadow:0 7px 18px #2f9e6d40;flex:0 0 auto}.section-kicker{color:var(--green-dark);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.orbit-header{padding:calc(12px + env(safe-area-inset-top)) 14px 20px;display:flex;flex-direction:column;align-items:center;gap:10px}.orbit-mascot{width:210px;height:210px;border-radius:50%;border:4px solid #fff;box-shadow:0 8px 24px #2f9e6d4d;object-fit:cover}.orbit-week-label{color:var(--muted);font-size:12px;font-weight:700}.orbit-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;width:100%}.orbit-pill{position:relative;min-height:52px;border:1px solid var(--line);border-radius:12px;background:#ffffffd9;color:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;box-shadow:0 6px 16px #42321214;cursor:pointer;transition:background .2s,box-shadow .2s}.orbit-pill span{color:var(--muted);font-size:10px;font-weight:800}.orbit-pill strong{font-size:15px;line-height:1}.pb-ball{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--yellow);border:2px solid #fff;box-shadow:0 2px 6px #00000026;font-style:normal}.pb-ball:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:50%;border:1px dashed rgba(180,130,0,.45)}.orbit-pill.is-selected{background:#1a3a5c;color:#fff;border-color:#1a3a5c;box-shadow:0 8px 20px #1a3a5c59;transform:translateY(-2px)}.orbit-pill.is-selected span{color:#ffffffb8}.orbit-pill.has-session:not(.is-selected){border-color:#2f9e6d66}.play-tab,.admin-tab{width:min(760px,100%);margin:0 auto;padding:16px 14px 104px}.intro-panel,.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.intro-panel{margin-bottom:14px}.intro-panel h2,.section-title-row h2{font-size:24px;line-height:1.1}.refresh-btn{border:1px solid var(--line);color:var(--ink);background:#ffffffb8;min-height:38px;padding:0 14px;border-radius:999px;font-size:13px;font-weight:800;box-shadow:0 8px 18px #42321214}.refresh-btn:disabled{opacity:.55}.session-section{display:grid;gap:12px}.session-list{display:grid;gap:14px}.session-card{background:var(--card);border:1px solid rgba(234,223,203,.95);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.session-summary{width:100%;border:0;background:linear-gradient(135deg,#fff,#e8f1f8);color:var(--ink);display:grid;grid-template-columns:auto 1fr;gap:12px;padding:14px;text-align:left}.session-date-badge{width:58px;height:68px;border-radius:18px;display:grid;place-items:center;align-content:center;gap:2px;background:#fff;border:1px solid var(--line);box-shadow:inset 0 -10px #2f9e6d1a}.session-date-badge span{color:var(--green-dark);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.session-date-badge strong{font-size:25px;line-height:1}.session-summary-main{min-width:0;display:grid;gap:3px}.session-summary-main p{color:var(--green-dark);font-size:12px;font-weight:800}.session-summary-main h3{font-size:25px;line-height:1.04}.session-summary-main span{color:var(--muted);font-size:13px;font-weight:650}.session-summary-side{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:12px}.peak-pill{border-radius:999px;background:var(--mint);color:#145a3d;padding:8px 11px;font-size:12px;white-space:nowrap}.peak-pill.is-full{background:#ffe1dc;color:#9d2d1d}.session-detail{padding:14px;display:grid;gap:14px}.capacity-strip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(68px,1fr);gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.capacity-strip::-webkit-scrollbar{display:none}.capacity-dot{min-height:58px;border-radius:16px;display:grid;align-content:center;justify-items:center;gap:4px;background:#edf3f9;border:1px solid var(--line)}.capacity-dot span{color:var(--muted);font-size:11px;font-weight:800}.capacity-dot strong{font-size:15px}.capacity-dot.level-4{background:#fff5cc}.capacity-dot.level-5{background:#ffe7b5}.capacity-dot.level-6{background:#ffe0dc;color:#8f271d}.roster-panel,.join-panel,.chat-panel{border:1px solid var(--line);background:var(--bg-soft);border-radius:18px}.roster-panel{padding:12px}.roster-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.roster-header h4{font-size:18px}.roster-header>span{color:var(--muted);font-size:12px;font-weight:750;margin-top:4px}.roster-list{display:grid;gap:8px}.roster-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;min-height:50px;padding:6px;border-radius:14px;background:#ffffffb8}.roster-row div:nth-child(2){display:grid;gap:2px;min-width:0}.roster-row strong{font-size:14px;overflow:hidden;text-overflow:ellipsis}.roster-row span{color:var(--muted);font-size:12px;font-weight:650}.roster-row em{color:var(--green-dark);background:var(--mint);border-radius:999px;padding:5px 8px;font-size:11px;font-style:normal;font-weight:900}.avatar-stack{display:flex;align-items:center;min-height:38px}.avatar-stack.is-compact .player-avatar:not(:first-child){margin-left:-10px}.player-avatar,.avatar-extra{border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:900;border:3px solid #fff;background-size:cover;background-position:center;box-shadow:0 7px 14px #4232122e;flex:0 0 auto}.avatar-md{width:42px;height:42px;font-size:13px}.avatar-sm,.avatar-extra{width:36px;height:36px;font-size:12px}.avatar-extra{background:#193d2d;margin-left:-10px}.player-avatar.is-you{outline:3px solid var(--yellow)}.player-avatar.has-photo{color:transparent}.player-avatar.color-0{background-color:var(--green)}.player-avatar.color-1{background-color:var(--blue)}.player-avatar.color-2{background-color:var(--coral)}.player-avatar.color-3{background-color:var(--purple)}.player-avatar.color-4{background-color:#d58a2f}.player-avatar.color-5{background-color:#2f8f91}.player-avatar.color-6{background-color:#d85f91}.player-avatar.color-7{background-color:#6b8e23}.join-panel{padding:12px;display:grid;gap:10px}.time-picker-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.time-picker-grid label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:850}.time-picker-grid select{width:100%;min-height:44px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);padding:0 12px;outline:none}.session-actions{display:flex;gap:10px}.btn-primary,.btn-secondary{border:0;min-height:48px;border-radius:16px;padding:0 16px;font-weight:900}.btn-primary{flex:1;color:#fff;background:var(--green);box-shadow:0 12px 20px #2f9e6d38}.btn-primary:disabled{background:#cfc8ba;box-shadow:none}.btn-secondary{color:var(--ink);background:#dce8f0;border:1px solid var(--line)}.btn-secondary.danger{flex:1;color:#9d2d1d;background:#ffe4df}.host-note{width:100%;min-height:46px;display:grid;place-items:center;color:var(--green-dark);background:var(--mint);border-radius:16px;font-weight:900}.slot-error{color:#9d2d1d;background:#ffe4df;border-radius:12px;padding:9px 10px;font-size:12px;font-weight:800}.chat-toggle{width:100%;min-height:44px;border:1px solid var(--line);border-radius:16px;background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:space-between;padding:0 14px;font-size:13px;font-weight:900}.chat-panel{overflow:hidden;display:grid}.chat-messages{max-height:210px;overflow-y:auto;padding:12px;display:grid;gap:9px}.chat-empty{color:var(--muted);font-size:13px;text-align:center;padding:12px 0}.chat-msg{display:grid;gap:3px}.chat-msg-meta{display:flex;align-items:baseline;gap:6px}.chat-msg-name{font-size:12px;font-weight:900}.chat-msg-time{color:var(--muted);font-size:11px;font-weight:700}.chat-msg-text{font-size:14px;line-height:1.35}.chat-input-row{display:grid;grid-template-columns:1fr auto;gap:8px;padding:10px;border-top:1px solid var(--line)}.chat-input{min-width:0;min-height:42px;border:1px solid var(--line);border-radius:14px;color:var(--ink);padding:0 12px;outline:none;font-size:16px}.chat-send-btn{min-height:42px;border:0;border-radius:14px;background:var(--green);color:#fff;padding:0 14px;font-weight:900}.chat-send-btn:disabled{background:#cfc8ba}.loading-screen,.error-screen,.empty-state{min-height:280px;display:grid;place-items:center;align-content:center;gap:12px;text-align:center;color:var(--muted);padding:30px 18px}.empty-state{background:#ffffffb8;border:1px dashed var(--line);border-radius:var(--radius)}.empty-ball{width:58px;height:58px}.empty-state p{color:var(--ink);font-size:16px;font-weight:900}.empty-state span{font-size:13px;max-width:280px}.empty-state.compact{min-height:160px}.bottom-tabs{position:fixed;left:50%;bottom:calc(12px + env(safe-area-inset-bottom));z-index:30;width:min(360px,calc(100% - 28px));transform:translate(-50%);display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px;border:1px solid rgba(234,223,203,.9);border-radius:999px;background:#f0f6fbe0;box-shadow:0 16px 35px #4232122e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.bottom-tabs button{min-height:46px;border:0;border-radius:999px;background:transparent;color:var(--muted);font-weight:950}.bottom-tabs button.is-active{background:#1a3a5c;color:#fff}.admin-tab{display:grid;gap:14px}.admin-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px;border-radius:var(--radius);background:linear-gradient(135deg,#1a3a5c,#4f8fcf);color:#fff;box-shadow:var(--shadow)}.admin-hero .section-kicker{color:#ffffffb8}.admin-hero h2{font-size:25px;line-height:1.05;margin-top:3px}.admin-hero span{display:block;margin-top:8px;color:#ffffffc7;font-size:13px;font-weight:700;line-height:1.35}.admin-status-card,.admin-card,.admin-booking-row{border:1px solid var(--line);border-radius:18px;background:#ffffffc7;box-shadow:0 10px 22px #42321214}.admin-status-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px}.admin-status-card h3{font-size:18px}.admin-status-card span{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:700}.admin-status-card strong{color:#145a3d;background:var(--mint);border-radius:999px;padding:8px 11px;font-size:12px}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.admin-card{min-height:152px;padding:13px;display:flex;flex-direction:column;justify-content:space-between;gap:12px}.admin-card h3{font-size:16px}.admin-card p{margin-top:5px;color:var(--muted);font-size:12px;font-weight:650;line-height:1.35}.admin-card button,.admin-booking-row button{align-self:flex-start;min-height:34px;border:0;border-radius:999px;background:#dce8f0;color:var(--ink);padding:0 12px;font-size:12px;font-weight:900}.admin-card button:disabled,.admin-booking-row button:disabled{opacity:.55;cursor:not-allowed}.admin-notice{color:#145a3d;background:var(--mint);border:1px solid rgba(47,158,109,.25);border-radius:16px;padding:11px 12px;font-size:13px;font-weight:850}.admin-list,.admin-section{display:grid;gap:10px}.admin-section-header{width:100%;border:1px solid var(--line);border-radius:18px;background:#ffffffc7;color:var(--ink);display:flex;align-items:center;justify-content:space-between;text-align:left;padding:13px 14px;box-shadow:0 10px 22px #42321214}.admin-section-header h2{font-size:20px}.admin-section-header span{color:var(--green-dark);background:var(--mint);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900}.admin-section-body{display:grid;gap:10px}.admin-day-group{display:grid;gap:9px;padding:12px;border:1px solid var(--line);border-radius:18px;background:#ffffffc7;box-shadow:0 10px 22px #42321214}.admin-day-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-day-heading div{display:grid;gap:2px}.admin-day-heading strong{font-size:17px}.admin-day-heading span{color:var(--muted);font-size:12px;font-weight:750}.admin-day-heading button{min-height:34px;border:0;border-radius:999px;background:var(--mint);color:#145a3d;padding:0 12px;font-size:12px;font-weight:900;white-space:nowrap}.admin-day-bookings{display:grid;grid-template-columns:repeat(auto-fit,minmax(126px,1fr));gap:8px}.admin-booking-mini{min-height:48px;border-radius:14px;background:var(--bg-soft);border:1px solid var(--line);display:grid;align-content:center;gap:2px;padding:8px 10px}.admin-booking-mini span{color:var(--muted);font-size:12px;font-weight:750}.admin-booking-mini strong{color:var(--green-dark);font-size:14px}.availability-controls{display:grid;grid-template-columns:auto auto 1fr auto;gap:8px}.availability-controls button,.availability-controls input{min-height:40px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);padding:0 10px;font-weight:850}.availability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(98px,1fr));gap:8px}.availability-slot{min-height:58px;border-radius:14px;border:1px solid var(--line);display:grid;align-content:center;gap:3px;padding:8px;background:#f7f2e7}.availability-slot strong{font-size:13px}.availability-slot span{color:var(--muted);font-size:11px;font-weight:750;line-height:1.2}.availability-slot em{color:var(--ink);font-size:11px;font-style:normal;font-weight:850;line-height:1.2}.availability-slot.is-open{background:var(--mint)}.availability-slot.is-mine{background:#fff5cc}.availability-slot.is-full{background:#ffe4df}.admin-booking-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px}.admin-booking-row div{min-width:0;display:grid;gap:3px}.admin-booking-row strong{font-size:15px}.admin-booking-row span{color:var(--muted);font-size:12px;font-weight:700}.admin-booking-row button{white-space:nowrap;background:var(--mint);color:#145a3d}.spinner{width:38px;height:38px;border-radius:50%;border:4px solid #f0e5d2;border-top-color:var(--green);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (min-width: 620px){.session-summary{grid-template-columns:auto 1fr auto;align-items:center}.session-summary-side{grid-column:auto;flex-direction:column;align-items:flex-end}}@media (max-width: 420px){.play-tab,.admin-tab{padding-inline:10px}.orbit-mascot{width:140px;height:140px}.orbit-strip{gap:5px}.orbit-pill{min-height:56px;border-radius:12px}.orbit-pill span{font-size:10px}.orbit-pill strong{font-size:15px}.session-summary-main h3{font-size:22px}.time-picker-grid,.admin-grid{grid-template-columns:1fr}.availability-controls{grid-template-columns:1fr 1fr}.availability-controls input,.availability-controls button:last-child{grid-column:span 2}}
