@import url("https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,700&family=Bebas+Neue&display=swap");:root{--bg:#fafaf8;--surface:#fff;--surface-alt:#f3f2ef;--border:#e5e4e0;--text:#1a1a18;--text-muted:#7c7b77;--accent:#1a1a18;--accent-hover:#2d2d2a;--green:#2e7d32;--green-bg:#e8f5e9;--red:#c62828;--red-bg:#ffebee;--yellow:#f57f17;--yellow-bg:#fff8e1;--radius:10px;--shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-lg:0 10px 30px rgba(0,0,0,.08)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:24px}.font-display{font-family:Bebas Neue,sans-serif}.header{background:var(--accent);padding:0 24px;justify-content:space-between;height:64px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header-logo{color:#fff;display:flex;align-items:center}.header-logo{gap:12px;text-decoration:none}.header-logo h1{font-family:Bebas Neue,sans-serif;font-size:28px;letter-spacing:3px;line-height:1}.header-logo span{font-size:10px;letter-spacing:2px;opacity:.6;text-transform:uppercase;display:block;margin-top:-2px}.header-nav{display:flex;gap:4px;align-items:center}.header-nav a,.header-nav button{background:transparent;border:1px solid hsla(0,0%,100%,.15);color:#fff;padding:8px 18px;border-radius:6px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.header-nav a:hover,.header-nav button:hover{background:hsla(0,0%,100%,.1)}.header-nav a.active,.header-nav button.active{background:#fff;color:var(--accent);border-color:#fff}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card:hover{box-shadow:var(--shadow-lg)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-family:DM Sans,sans-serif;font-size:14px;transition:border .2s;outline:none;background:var(--surface);color:var(--text)}.form-input:focus{border-color:var(--accent)}.btn{padding:12px 24px;border-radius:8px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:var(--accent);color:#fff;width:100%;justify-content:center;padding:14px}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-outline{background:transparent;border:1px solid var(--accent);color:var(--text)}.btn-outline:hover{background:var(--accent);color:#fff}.btn-small{padding:6px 12px;font-size:12px;border:1px solid var(--border);background:none;border-radius:6px}.btn-small:hover{border-color:var(--accent)}.btn-danger{color:var(--red)}.btn-danger:hover{background:var(--red-bg);border-color:var(--red)}.btn-success{color:var(--green)}.btn-success:hover{background:var(--green-bg);border-color:var(--green)}.badge{display:inline-block;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;text-transform:capitalize}.badge-confirmed{background:var(--green-bg);color:var(--green)}.badge-cancelled{background:var(--red-bg);color:var(--red)}.badge-pending{background:var(--yellow-bg);color:var(--yellow)}.badge-completed{background:var(--surface-alt);color:var(--text-muted)}.badge-blocked{background:#ede7f6;color:#5e35b1}.badge-no_show{background:var(--red-bg);color:var(--red)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:6px}.stat-value{font-family:Bebas Neue,sans-serif;font-size:36px;letter-spacing:1px;line-height:1}.stat-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.date-picker{display:flex;gap:6px;overflow-x:auto;padding:4px 0}.date-btn{display:flex;flex-direction:column;align-items:center;padding:10px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-family:DM Sans,sans-serif;transition:all .2s;min-width:68px}.date-btn.active,.date-btn:hover{border-color:var(--accent)}.date-btn.active{background:var(--accent);color:#fff}.date-btn .dow{font-size:10px;text-transform:uppercase;letter-spacing:1px;opacity:.6}.date-btn .day{font-size:20px;font-weight:700;line-height:1.3}.calendar-backdrop{position:fixed;inset:0;z-index:149}.calendar-popup{position:absolute;top:calc(100% + 8px);right:0;z-index:150}.calendar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:20px;width:320px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.calendar-month{font-size:22px;letter-spacing:1.5px}.calendar-nav{width:36px;height:36px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text)}.calendar-nav:hover:not(:disabled){border-color:var(--accent);background:var(--surface-alt)}.calendar-nav:disabled{opacity:.3;cursor:not-allowed}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px;text-align:center}.calendar-dow{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:4px 0 8px;font-weight:600}.calendar-day{width:100%;aspect-ratio:1;border:none;border-radius:8px;background:none;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;color:var(--text)}.calendar-day:hover:not(:disabled){background:var(--surface-alt)}.calendar-day-today{font-weight:700;border:1px solid var(--border)}.calendar-day-selected{background:var(--accent)!important;color:#fff;font-weight:700}.calendar-day-disabled{opacity:.25;cursor:not-allowed}.book-grid-wrap{display:block;overflow-x:auto}.book-grid{border-collapse:collapse;width:100%;min-width:720px;table-layout:fixed;font-size:12px}.book-grid td,.book-grid th{border:1px solid #cfd8dc;padding:0;height:40px;text-align:center;vertical-align:middle;overflow:hidden}.book-grid thead th{background:#1a237e;color:#fff;font-weight:700;letter-spacing:.5px;padding:10px 4px;font-size:11px}.book-grid tbody td.book-grid-time-col{background:var(--surface-alt);font-weight:600;color:var(--text);padding:4px 8px;font-size:11px;line-height:1.3}.book-grid-time-col{width:100px}.book-grid-cell{cursor:pointer;transition:all .12s;font-weight:600}.book-grid-cell-available{background:var(--green-bg);color:var(--green)}.book-grid-cell-available:hover{background:var(--green);color:#fff}.book-grid-cell-selected{background:var(--accent);color:#fff;font-size:16px}.book-grid-cell-booked{background:var(--surface-alt);color:var(--text-muted);cursor:not-allowed;font-size:10px;text-transform:uppercase;letter-spacing:.5px;opacity:.6}.book-grid-cell-blocked{background:repeating-linear-gradient(45deg,#ede7f6,#ede7f6 6px,#d1c4e9 0,#d1c4e9 12px);color:#4527a0;cursor:not-allowed;padding:2px 4px}.courts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:20px;gap:20px}.courts-grid-cards{display:none}@media (max-width:899px){.book-grid-wrap{display:none}.courts-grid-cards{display:grid}}.court-header{padding:18px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.court-type{font-size:11px;padding:3px 10px;border-radius:20px;background:var(--surface-alt);color:var(--text-muted);font-weight:500}.court-rate{font-size:13px;color:var(--text-muted);padding:12px 20px 0}.court-rate strong{color:var(--text);font-size:18px}.court-slots{padding:12px 20px 20px;display:grid;grid-template-columns:repeat(3,1fr);grid-gap:6px;gap:6px}.slot-btn{font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;padding:7px 0;border-radius:6px;border:1px solid var(--border);cursor:pointer;transition:all .15s;text-align:center}.slot-available{background:var(--green-bg);color:var(--green);border-color:#c8e6c9}.slot-available:hover{background:var(--green);color:#fff}.slot-booked{background:var(--surface-alt);color:var(--text-muted);cursor:not-allowed;text-decoration:line-through;opacity:.5}.slot-selected{background:var(--accent);color:#fff;border-color:var(--accent)}.slot-blocked{background:repeating-linear-gradient(45deg,#ede7f6,#ede7f6 6px,#d1c4e9 0,#d1c4e9 12px);color:#4527a0;border-color:#b39ddb;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--surface);border-radius:14px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:24px}.summary{background:var(--surface-alt);padding:16px;border-radius:var(--radius);margin-bottom:20px;display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.summary-item label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);display:block;margin-bottom:2px}.summary-item span{font-weight:600;font-size:14px}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:12px 16px;font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);background:var(--surface-alt)}.data-table td,.data-table th{border-bottom:1px solid var(--border)}.data-table td{padding:14px 16px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface-alt)}.shop-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-gap:20px;gap:20px;align-items:start}.shop-grid>.shop-cart{position:-webkit-sticky;position:sticky;top:80px}.booking-table-wrap{display:block}.booking-card-list{display:none}@media (max-width:768px){.booking-table-wrap{display:none}.booking-card-list{display:flex;flex-direction:column;gap:12px}}.booking-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.booking-card.is-block{background:#faf6ff}.booking-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}.booking-card-name{font-weight:700;font-size:15px;line-height:1.3;word-break:break-word}.booking-card-meta{font-size:11px;color:var(--text-muted);margin-bottom:10px}.booking-card-slot{font-size:13px;padding:2px 0}.booking-card-slot strong{font-weight:600}.booking-card-slot span{color:var(--text-muted);margin-left:6px}.booking-card-total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--border);margin-top:10px;padding-top:10px;font-size:16px;font-weight:700}.booking-card-total-sub{font-size:11px;color:var(--text-muted);font-weight:400;margin-top:2px}.booking-card-payment{font-size:12px;color:var(--text-muted);margin-top:6px}.booking-card-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.booking-card-actions .btn{flex:1 1 auto;min-width:0;font-size:12px;padding:9px 12px}.schedule-grid{border-collapse:collapse;width:100%;table-layout:fixed;font-size:12px}.schedule-grid td,.schedule-grid th{border:1px solid #cfd8dc;padding:0;height:36px;text-align:center;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.schedule-grid thead th{background:#1a237e;color:#fff;font-weight:700;letter-spacing:.5px;padding:8px 4px;font-size:11px}.schedule-grid thead th.schedule-time-col{background:#1a237e}.schedule-grid tbody td.schedule-time-col{background:var(--surface-alt);font-weight:600;color:var(--text);padding:0 8px;font-size:11px}.schedule-time-col{width:110px}.schedule-cell{position:relative;cursor:pointer;padding:4px 6px}.schedule-cell-empty:hover{background:#e3f2fd}.schedule-cell-booked:hover{filter:brightness(.92)}.schedule-cell-editing{padding:0;background:#fffde7}.schedule-input{width:100%;height:100%;min-height:34px;border:2px solid var(--accent);background:#fff;padding:4px 6px;font:inherit;font-weight:600;text-align:center;outline:none}.subtab-strip{display:flex;gap:4px;margin-bottom:16px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.subtab-strip::-webkit-scrollbar{display:none}.subtab-strip>button{flex:0 0 auto;white-space:nowrap}@media (max-width:1024px){.container{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.stat-value{font-size:30px}.stat-card{padding:16px}.shop-grid{grid-template-columns:minmax(0,1fr) 280px;gap:16px}}@media (max-width:768px){.header{padding:0 16px;height:56px}.header-logo h1{font-size:24px;letter-spacing:2px}.header-logo span{font-size:9px;letter-spacing:1.5px}.header-nav a,.header-nav button{padding:6px 12px;font-size:12px}.container{padding:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.stat-card{padding:14px}.stat-value{font-size:26px}.courts-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.court-slots{grid-template-columns:repeat(3,1fr);padding:12px 16px 16px}.shop-grid{grid-template-columns:minmax(0,1fr)}.shop-grid>.shop-cart{position:static}.modal-body{padding:20px}.modal-header{padding:16px 20px}.data-table td,.data-table th{padding:10px 12px;font-size:12px}}@media (max-width:640px){body{font-size:14px}.container{padding:12px}.header{padding:0 12px}.header-logo h1{font-size:22px}.header-nav{gap:2px}.header-nav a,.header-nav button{padding:6px 10px;font-size:11px;border-radius:4px}.courts-grid{grid-template-columns:1fr;gap:12px}.stats-grid{grid-template-columns:1fr 1fr}.stat-card{padding:12px}.stat-value{font-size:24px}.stat-label{font-size:10px;letter-spacing:1px}.form-input{padding:10px 12px;font-size:16px}.btn{padding:10px 18px;font-size:13px}.btn-primary{padding:12px}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:92vh;overflow-y:auto;border-radius:14px 14px 0 0}.modal-overlay.modal-centered{padding:16px;align-items:center}.modal-overlay.modal-centered .modal{max-width:380px;border-radius:var(--radius)}.modal-body{padding:16px}.modal-header{padding:14px 16px}.summary{grid-template-columns:1fr;gap:8px;padding:12px}.selection-bar{padding:10px 12px;flex-wrap:wrap;gap:8px}.data-table td,.data-table th{padding:8px 10px;font-size:11px}.calendar{width:calc(100vw - 32px);max-width:320px}.calendar-popup{left:auto;right:0}.date-picker{gap:4px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.date-btn{min-width:56px;padding:8px 10px;scroll-snap-align:start}.date-btn .day{font-size:18px}.date-btn .dow{font-size:9px}.court-header{padding:14px 16px}.court-header h3{font-size:20px!important}.court-rate{padding:10px 16px 0;font-size:12px}.court-rate strong{font-size:16px}.court-slots{grid-template-columns:repeat(3,1fr);padding:12px 14px 14px;gap:6px}.slot-btn{padding:10px 0;font-size:13px}}@media (max-width:400px){.stats-grid{grid-template-columns:1fr}.header-logo span{display:none}.court-slots{grid-template-columns:repeat(2,1fr)}}@media (min-width:1600px){.container{max-width:1500px;padding:32px}}@media (hover:none) and (pointer:coarse){.btn-small{min-height:36px;padding:8px 14px}.slot-btn{min-height:36px;padding:9px 0;font-size:13px}.calendar-day{font-size:15px}.date-btn{min-height:64px}}.selection-bar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.08);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;z-index:100}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fade-in{animation:fadeIn .3s ease-out}.slide-up{animation:slideUp .25s ease-out}.loading{display:flex;justify-content:center;align-items:center;padding:60px;color:var(--text-muted);font-size:14px}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin-right:12px}@keyframes spin{to{transform:rotate(1turn)}}