:root{--text:#2f384d;--muted:#8590a6;--text-h:#151b2d;--bg:#edf3fb;--panel-bg:#fff;--field-bg:#f8faff;--soft-bg:#f1f5ff;--border:#e4eaf5;--border-strong:#d2dbeb;--accent:#5264f6;--accent-strong:#4251d8;--accent-soft:#edf0ff;--warm:#6f4fd8;--danger:#d74b67;--danger-soft:#fff0f3;--success:#2ba875;--success-soft:#e8f8f1;--warning:#d28a1e;--warning-soft:#fff5df;--unknown-soft:#f0f3f8;--shadow:0 18px 44px #4d5b8229;--shadow-soft:0 10px 28px #4d5b821a;--sans:Inter, ui-sans-serif, system-ui, "Segoe UI", Roboto, sans-serif;--heading:Inter, ui-sans-serif, system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, SFMono-Regular, Consolas, monospace;font:14px/150% var(--sans);letter-spacing:0;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--text:#cbd5e1;--muted:#92a0b4;--text-h:#f8fbff;--bg:#121722;--panel-bg:#1a2030;--field-bg:#141b29;--soft-bg:#20283a;--border:#2b3448;--border-strong:#3b4660;--accent:#8ea0ff;--accent-strong:#c6d0ff;--accent-soft:#8ea0ff24;--warm:#9a78ff;--danger:#fb7185;--danger-soft:#fb718524;--success:#86efac;--success-soft:#86efac24;--warning:#fbbf24;--warning-soft:#fbbf2429;--unknown-soft:#273144;--shadow:0 18px 44px #00000057;--shadow-soft:0 10px 28px #00000038}}*{box-sizing:border-box}body{background:linear-gradient(#eef4fc 0%,#f7f9ff 100%);min-width:320px;min-height:100svh;margin:0}@media (prefers-color-scheme:dark){body{background:linear-gradient(#121722 0%,#0f131d 100%)}}#root{width:100%;min-height:100svh}h1,h2{font-family:var(--heading);color:var(--text-h);letter-spacing:0}h1{font-weight:760}h2{font-size:1.05rem;font-weight:760;line-height:1.2}p{margin:0}button,input,select,textarea{font:inherit}button{transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s}button:hover{transform:translateY(-1px)}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent-soft);outline-offset:2px}code{font-family:var(--mono)}.app-shell{flex-direction:column;gap:22px;width:min(1120px,100%);margin:0 auto;padding:38px 28px 54px;display:flex}.app-header{box-shadow:var(--shadow-soft);background:#ffffffd1;border:1px solid #ffffffb8;border-radius:16px;justify-content:space-between;align-items:flex-start;gap:24px;padding:22px 24px;display:flex}.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:0;margin:0 0 7px;font-size:.72rem;font-weight:780}.app-header h1{max-width:680px;margin:0;font-size:clamp(1.65rem,3vw,2.45rem);line-height:1.08}.header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.band-switcher{color:#0000;align-items:center;font-size:0;font-weight:760;display:inline-flex}.band-switcher select{width:min(calc(var(--band-name-width,4ch) + 48px), 320px);border:1px solid var(--border);background:var(--field-bg);height:42px;color:var(--text-h);font:inherit;border-radius:12px;padding:0 30px 0 14px;font-size:1rem;font-weight:720}.login-grid,.auth-grid,.dashboard-grid,.admin-grid{gap:22px;display:grid}.login-grid,.dashboard-grid,.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-grid{grid-template-columns:1fr;width:min(430px,100%);margin:0 auto}.panel{background:var(--panel-bg);box-shadow:var(--shadow-soft);border:1px solid #ffffffbd;border-radius:16px;flex-direction:column;gap:20px;padding:24px;display:flex}.setup-panel,.loading-panel,.message-panel{width:min(720px,100%)}.loading-panel,.message-panel{margin-inline:auto}.loading-panel{margin-top:72px}.wide-panel{overflow:hidden}.panel-heading{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.panel-heading h2{margin:0 0 5px}.panel-heading p{color:var(--muted);margin:0;font-size:.82rem;line-height:1.45}.table-heading{align-items:end}.stacked-form{flex-direction:column;gap:14px;display:flex}.stacked-form label,.compact-label{color:var(--text-h);gap:8px;font-size:.78rem;font-weight:720;display:grid}.stacked-form input,.stacked-form select,.stacked-form textarea,.compact-label input{box-sizing:border-box;border:1px solid var(--border);background:var(--field-bg);width:100%;min-height:44px;color:var(--text-h);font:inherit;letter-spacing:0;border-radius:12px;padding:11px 13px;transition:border-color .16s,background-color .16s,box-shadow .16s}.stacked-form input:hover,.stacked-form select:hover,.stacked-form textarea:hover,.compact-label input:hover{border-color:#c5ceff}.stacked-form input:focus,.stacked-form select:focus,.stacked-form textarea:focus,.compact-label input:focus{border-color:var(--accent);background:var(--panel-bg);box-shadow:0 0 0 4px var(--accent-soft)}.stacked-form textarea{resize:vertical}.field-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.week-picker{gap:12px;display:grid}.week-picker-heading,.table-week-controls{justify-content:space-between;align-items:center;gap:12px;display:flex}.week-nav-group{align-items:center;gap:6px;display:inline-flex}.week-picker-heading div{text-align:center;gap:2px;display:grid}.week-picker-heading span{color:var(--muted);font-size:.72rem;font-weight:620}.week-picker-heading strong,.table-week-controls strong{color:var(--text-h);font-size:.86rem;font-weight:780}.week-nav-button{border:1px solid var(--border);background:var(--field-bg);min-height:34px;color:var(--muted);font:inherit;cursor:pointer;border-radius:999px;padding:0 12px;font-size:.76rem;font-weight:780}.week-nav-button:hover{color:var(--accent-strong);border-color:#c5ceff}.week-days{grid-template-columns:repeat(7,minmax(58px,1fr));gap:8px;display:grid}.week-day{border:1px solid var(--border);background:var(--field-bg);min-height:82px;color:var(--muted);font:inherit;letter-spacing:0;cursor:pointer;border-radius:14px;align-content:center;justify-items:center;gap:3px;padding:9px 7px;display:grid}.week-day span{text-transform:uppercase;font-size:.68rem;font-weight:720}.week-day strong{color:var(--text-h);font-size:1.05rem;font-weight:820;line-height:1}.week-day small{max-width:100%;color:var(--muted);text-align:center;overflow-wrap:anywhere;font-size:.64rem;font-weight:660;line-height:1.15}.week-day.booked{border-color:#d7a62f;box-shadow:0 10px 22px #d89a2129}.week-day.selected{background:linear-gradient(135deg, var(--accent), var(--warm));border-color:#0000;box-shadow:0 14px 24px #5264f63d}.week-day.booked.selected{border-color:#d7a62f;box-shadow:0 0 0 2px #f8c84fdb,0 14px 24px #5264f63d}.week-day.selected span,.week-day.selected strong,.week-day.selected small{color:#fff}.segmented-control{border:1px solid var(--border);background:var(--soft-bg);border-radius:14px;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;padding:5px;display:grid}.segmented-control button,.primary-button,.secondary-button,.ghost-button{min-height:42px;font:inherit;letter-spacing:0;cursor:pointer;border-radius:12px;font-weight:760}.segmented-control button{color:var(--muted);background:0 0;border:1px solid #0000}.segmented-control button.selected{background:var(--panel-bg);color:var(--accent-strong);border-color:#0000;box-shadow:0 8px 20px #5264f624}.primary-button,.secondary-button{border:1px solid #0000;width:fit-content;padding:0 18px;box-shadow:0 12px 22px #5264f638}.primary-button{background:linear-gradient(135deg, var(--accent), var(--warm));color:#fff}.secondary-button{background:linear-gradient(135deg, #3f6df4, var(--warm));color:#fff}.primary-button:hover,.secondary-button:hover{box-shadow:var(--shadow)}.ghost-button{border:1px solid var(--border);background:var(--field-bg);color:var(--text-h);box-shadow:none;padding:0 14px}.ghost-button:hover{color:var(--accent-strong);border-color:#c5ceff}.danger-button{color:var(--danger)}.danger-button:hover{color:var(--danger);border-color:#d74b676b}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled{cursor:wait;opacity:.66}.error-message,.success-message,.notice-message{margin:0;font-size:.82rem;font-weight:760}.error-message{color:var(--danger)}.success-message{color:var(--success)}.auth-switch{color:var(--muted);font-size:.86rem}.auth-switch button{min-height:auto;color:var(--accent);font:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:780}.notice-message{color:var(--muted)}.message-stack{gap:8px;display:grid}.code-block{border:1px solid var(--border);background:var(--soft-bg);color:var(--text-h);font-family:var(--mono);text-align:left;border-radius:14px;margin:0;padding:16px;font-size:.82rem;line-height:1.5;overflow-x:auto}.calendar-feed-panel{gap:14px}.feed-copy-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.feed-copy-row input{border:1px solid var(--border);background:var(--field-bg);width:100%;min-height:42px;color:var(--text-h);font:inherit;border-radius:12px;padding:10px 13px;font-size:.82rem}.admin-band-list{gap:14px;display:grid}.admin-band-card{border:1px solid var(--border);background:var(--field-bg);border-radius:14px;gap:14px;padding:16px;display:grid}.admin-band-main,.admin-band-actions,.admin-band-edit,.admin-member-card,.admin-member-edit,.invite-copy-row{gap:10px;display:flex}.admin-band-main{justify-content:space-between;align-items:flex-start}.admin-band-main h3{color:var(--text-h);margin:0 0 3px;font-size:.98rem;line-height:1.2}.admin-band-main p{color:var(--muted);font-size:.76rem;font-weight:700}.admin-band-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center}.admin-band-edit{align-items:end}.admin-band-edit .compact-label{flex:1;min-width:180px}.invite-copy-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;display:grid}.invite-copy-row input{border:1px solid var(--border);background:var(--panel-bg);width:100%;min-height:42px;color:var(--text-h);font:inherit;border-radius:12px;padding:10px 13px;font-size:.78rem}.admin-members{gap:10px;padding-top:4px;display:grid}.admin-members-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.admin-members-heading h4{color:var(--text-h);margin:0;font-size:.82rem;font-weight:780}.admin-members-heading span{background:var(--unknown-soft);min-width:26px;height:26px;color:var(--muted);border-radius:999px;place-items:center;font-size:.72rem;font-weight:820;display:inline-grid}.admin-member-list{gap:8px;display:grid}.admin-member-card{border:1px solid var(--border);background:var(--panel-bg);border-radius:12px;justify-content:space-between;align-items:center;padding:11px 12px}.admin-member-info{gap:2px;min-width:0;display:grid}.admin-member-info strong{color:var(--text-h);overflow-wrap:anywhere;font-size:.84rem;font-weight:780}.admin-member-info span{color:var(--muted);overflow-wrap:anywhere;font-size:.74rem;font-weight:650}.admin-member-edit{align-items:end;width:100%}.admin-member-edit .compact-label{flex:1;min-width:180px}.status-table-wrap{border:1px solid var(--border);background:var(--panel-bg);border-radius:14px;overflow-x:auto}.status-table{border-collapse:separate;border-spacing:0;width:100%;min-width:840px}.status-table th,.status-table td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:13px 14px}.status-table tr:last-child th,.status-table tr:last-child td{border-bottom:none}.status-table thead th{background:var(--soft-bg);color:var(--text-h);font-size:.76rem;font-weight:780}.status-table th.booked-date,.status-table td.booked-date{background:#fffaf0;border-left:1px solid #d7a62f70;border-right:1px solid #d7a62f70}.status-table thead th.booked-date{color:#7a5400;box-shadow:inset 0 3px #d7a62f}.status-table thead th.booked-date small{color:#b07700;margin-top:4px;font-size:.64rem;font-weight:780;display:block}.status-table tbody th{background:var(--panel-bg);width:210px}.member-cell{align-items:center;gap:0;display:flex}.member-cell strong{color:var(--text-h);font-size:.82rem;font-weight:780}.status-pill{border-radius:999px;align-items:center;min-height:26px;padding:0 10px;font-size:.68rem;font-weight:780;display:inline-flex}.status-pill.available{background:var(--success-soft);color:var(--success)}.status-pill.tentative{background:var(--warning-soft);color:var(--warning)}.status-pill.unavailable{background:var(--danger-soft);color:var(--danger)}.status-pill.unknown{background:var(--unknown-soft);color:var(--muted)}.status-note-wrap{align-items:center;max-width:100%;display:inline-flex;position:relative}.note-indicator{z-index:2;background:var(--panel-bg);width:16px;height:16px;color:var(--accent);cursor:pointer;border:1px solid #5264f647;border-radius:999px;place-items:center;padding:0;font-size:.62rem;font-weight:820;line-height:1;display:inline-grid;position:absolute;top:-7px;left:-7px;box-shadow:0 6px 14px #4d5b8224}.note-indicator:hover,.note-indicator:focus-visible{border-color:#5264f685;outline:none;box-shadow:0 8px 18px #4d5b8233}.status-note-popover{z-index:40;border:1px solid var(--border);background:var(--panel-bg);width:max-content;min-width:180px;max-width:min(260px,64vw);color:var(--text);opacity:0;pointer-events:none;visibility:hidden;white-space:normal;border-radius:12px;padding:11px 12px;font-size:.74rem;font-weight:620;line-height:1.4;transition:opacity .14s,transform .14s,visibility .14s;position:absolute;bottom:calc(100% + 10px);left:0;transform:translateY(4px);box-shadow:0 18px 38px #4d5b822e}.status-note-popover:after{border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--panel-bg);content:"";width:10px;height:10px;position:absolute;bottom:-6px;left:16px;transform:rotate(45deg)}.status-note-wrap.note-open .status-note-popover{opacity:1;visibility:visible;transform:translateY(0)}.availability-list{flex-direction:column;gap:12px;display:flex}.availability-card{border:1px solid var(--border);background:var(--field-bg);border-radius:14px;justify-content:space-between;align-items:center;gap:16px;padding:14px;display:flex}.availability-card.booked{background:#fffaf0;border-color:#d7a62f73}.availability-card div{gap:3px;display:grid}.availability-card span{color:var(--muted);font-size:.76rem}.availability-date{color:var(--text-h);margin:0;font-size:.9rem;font-weight:780}.booking-toggle{border:1px solid var(--border);background:var(--panel-bg);min-width:78px;min-height:34px;color:var(--accent-strong);font:inherit;cursor:pointer;border-radius:999px;padding:0 14px;font-size:.76rem;font-weight:820}.booking-toggle.booked{color:#3d2900;background:linear-gradient(135deg,#f8c84f,#d89a21);border-color:#d7a62f;box-shadow:0 12px 24px #d89a213d}.booking-toggle:disabled{cursor:wait;opacity:.72}@media (prefers-color-scheme:dark){.availability-card.booked{background:#f8c84f14;border-color:#f8c84f61}}.empty-state{color:var(--muted);margin:0;font-size:.78rem}@media (prefers-color-scheme:dark){.app-header,.panel{border-color:var(--border);background:var(--panel-bg)}}@media (width<=980px){.app-header{align-items:stretch}.app-header,.login-grid,.dashboard-grid,.admin-grid{grid-template-columns:1fr}.app-header{display:grid}.header-actions{justify-content:flex-start}}@media (width<=640px){.app-shell{padding:24px 14px 36px}.panel,.app-header{padding:18px}.field-row,.segmented-control{grid-template-columns:1fr}.admin-band-main,.admin-band-edit,.admin-member-card,.admin-member-edit,.admin-band-actions{flex-direction:column;align-items:stretch}.band-switcher,.band-switcher select{max-width:100%}.invite-copy-row,.feed-copy-row{grid-template-columns:1fr}}
