*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f5f5f7;min-height:100vh;font-family:Inter,system-ui,sans-serif}.loading-screen{color:#666;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.spinner{border:3px solid #e0e0e0;border-top-color:#6c63ff;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-wrap{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:300px;display:flex}.spinner-text{color:#666;font-size:14px}.setup-screen{background:linear-gradient(135deg,#6c63ff 0%,#3f3d8f 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.setup-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:480px;padding:40px 32px;box-shadow:0 20px 60px #00000026}.setup-steps{text-align:left;background:#f5f3ff;border-radius:12px;margin-top:24px;padding:20px}.setup-steps p{color:#555;margin-bottom:14px;font-size:14px;line-height:1.6}.setup-steps code{background:#e8e4ff;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:13px}.setup-steps ol{flex-direction:column;gap:8px;padding-left:20px;display:flex}.setup-steps li{color:#444;font-size:13.5px;line-height:1.5}.setup-steps strong{color:#6c63ff}.login-page{background:linear-gradient(135deg,#6c63ff 0%,#3f3d8f 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.login-card{background:#fff;border-radius:20px;width:100%;max-width:420px;padding:40px 32px;box-shadow:0 20px 60px #00000026}.login-brand{text-align:center;margin-bottom:32px}.brand-icon{margin-bottom:8px;font-size:52px;display:block}.brand-name{color:#6c63ff;letter-spacing:-.5px;font-size:28px;font-weight:800}.brand-event{color:#f59e0b;letter-spacing:1px;text-transform:uppercase;margin-top:2px;font-size:11px;font-weight:700}.brand-tagline{color:#888;margin-top:6px;font-size:13px}.auth-form{flex-direction:column;gap:20px;display:flex}.form-title{color:#1a1a2e;font-size:22px;font-weight:700}.form-subtitle{color:#666;margin-top:-12px;font-size:14px;line-height:1.5}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:#444;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.input{color:#1a1a2e;background:#fafafa;border:1.5px solid #ddd;border-radius:10px;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.input:focus{background:#fff;border-color:#6c63ff;outline:none}select.input{cursor:pointer}.phone-input-wrapper{background:#fafafa;border:1.5px solid #ddd;border-radius:10px;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.phone-input-wrapper:focus-within{background:#fff;border-color:#6c63ff}.phone-prefix{color:#555;white-space:nowrap;background:#f0f0f0;border-right:1.5px solid #ddd;padding:12px;font-size:15px;font-weight:600}.phone-input{letter-spacing:1px;background:0 0;border:none;border-radius:0;flex:1}.phone-input:focus{outline:none}.otp-input{letter-spacing:8px;text-align:center;font-size:24px}.btn{cursor:pointer;border:none;border-radius:10px;padding:13px 20px;font-family:inherit;font-size:15px;font-weight:600;transition:all .15s}.btn-primary{color:#fff;background:#6c63ff}.btn-primary:hover:not(:disabled){background:#5b53e8}.btn-ghost{color:#6c63ff;background:0 0;border:1.5px solid #ddd}.btn-ghost:hover:not(:disabled){background:#f5f3ff;border-color:#6c63ff}.btn:disabled{opacity:.55;cursor:not-allowed}.error-msg{color:#dc2626;background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;font-size:13.5px}.error-banner{color:#dc2626;background:#fff5f5;border:1px solid #fecaca;border-radius:10px;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.error-retry-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#dc2626;border:none;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:13px}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:100;background:#fff;border-bottom:1px solid #e8e8f0;position:sticky;top:0;box-shadow:0 2px 8px #0000000f}.header-inner{align-items:center;gap:16px;max-width:1100px;height:60px;margin:0 auto;padding:0 20px;display:flex}.header-logo-btn{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:10px;padding:0;display:flex}.logo-icon{font-size:28px}.logo-text-wrap{text-align:left;flex-direction:column;display:flex}.logo-text{color:#6c63ff;font-size:17px;font-weight:800;line-height:1.1}.logo-subtext{color:#999;letter-spacing:.3px;font-size:11px}.header-nav{align-items:center;gap:4px;margin-left:auto;display:flex}.nav-btn{cursor:pointer;color:#555;background:0 0;border:none;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:14px;font-weight:500;transition:all .15s}.nav-btn:hover{color:#6c63ff;background:#f5f3ff}.nav-btn.active{color:#6c63ff;background:#f0edff;font-weight:600}.nav-btn-admin{color:#f59e0b}.nav-btn-admin:hover,.nav-btn-admin.active{color:#d97706;background:#fffbeb}.sign-out-btn{cursor:pointer;color:#888;white-space:nowrap;background:0 0;border:1.5px solid #ddd;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:13px;transition:all .15s}.sign-out-btn:hover{color:#dc2626;background:#fff5f5;border-color:#dc2626}.sign-in-btn{cursor:pointer;color:#fff;white-space:nowrap;background:#6c63ff;border:none;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.sign-in-btn:hover{background:#5a52e0}.app-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 20px}.home-hero{text-align:center;margin-bottom:40px;padding:12px 0 4px}.hero-badge{color:#6c63ff;letter-spacing:.06em;text-transform:uppercase;background:#ede9fe;border-radius:999px;margin-bottom:14px;padding:5px 14px;font-size:12px;font-weight:700;display:inline-block}.home-title{color:#1a1a2e;letter-spacing:-.5px;font-size:36px;font-weight:800}.home-subtitle{color:#888;margin-top:10px;font-size:15px;line-height:1.7}.home-section{margin-bottom:52px}.home-section-title{color:#1a1a2e;letter-spacing:-.3px;margin-bottom:24px;font-size:22px;font-weight:700}.sport-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.why-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.why-card{background:#fff;border:1px solid #e8e8f0;border-radius:14px;padding:22px 20px}.why-icon{margin-bottom:10px;font-size:26px;display:block}.why-card h3{color:#1a1a2e;margin-bottom:6px;font-size:15px;font-weight:700}.why-card p{color:#666;font-size:13px;line-height:1.6}.home-about{background:#fff;border:1px solid #e8e8f0;border-radius:16px;padding:28px 28px 24px}.about-content p{color:#444;margin-bottom:14px;font-size:14px;line-height:1.8}.about-details{border-top:1px solid #f0f0f5;flex-wrap:wrap;gap:16px;margin-top:18px;padding-top:18px;display:flex}.about-detail-item{color:#333;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.about-detail-icon{font-size:16px}.home-footer{text-align:center;color:#aaa;border-top:1px solid #eee;margin-top:8px;padding:24px 0 8px;font-size:12px;line-height:2}.footer-keywords{color:#ccc;font-size:11px}.sport-card{cursor:pointer;text-align:center;background:#fff;border:2px solid #eee;border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:28px 20px;font-family:inherit;transition:all .2s;display:flex}.sport-card:hover{border-color:#6c63ff;transform:translateY(-2px);box-shadow:0 8px 30px #6c63ff1f}.sport-card-icon{font-size:48px;line-height:1}.sport-card-name{color:#1a1a2e;font-size:17px;font-weight:700}.sport-card-price{color:#6c63ff;font-size:20px;font-weight:800}.sport-card-unit{color:#999;font-size:13px;font-weight:500}.sport-card-badge{letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.badge-dedicated{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.badge-shared{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe}.badge-walkin{color:#a21caf;background:#fdf4ff;border:1px solid #f0abfc}.sport-card-desc{color:#999;font-size:12.5px;line-height:1.4}.booking-page{max-width:700px}.page-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.back-btn{cursor:pointer;color:#666;background:0 0;border:1.5px solid #ddd;border-radius:8px;flex-shrink:0;padding:8px 14px;font-family:inherit;font-size:14px;transition:all .15s}.back-btn:hover{color:#6c63ff;border-color:#6c63ff}.page-header-sport{align-items:center;gap:12px;display:flex}.page-sport-icon{font-size:36px}.page-title{color:#1a1a2e;margin:0;font-size:24px;font-weight:800}.page-subtitle{color:#888;margin-top:2px;font-size:13px}.booking-section{margin-bottom:32px}.section-label{color:#888;text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;font-size:12px;font-weight:700}.date-picker{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.date-picker::-webkit-scrollbar{display:none}.date-pill{cursor:pointer;background:#fff;border:1.5px solid #e0e0e0;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;min-width:64px;padding:10px 14px;font-family:inherit;transition:all .15s;display:flex}.date-pill:hover{background:#f5f3ff;border-color:#6c63ff}.date-pill.selected{color:#fff;background:#6c63ff;border-color:#6c63ff}.date-pill.today .date-pill-day{font-weight:700}.date-pill-day{text-transform:uppercase;letter-spacing:.3px;color:#888;font-size:11px;font-weight:600}.date-pill-num{color:#1a1a2e;font-size:20px;font-weight:800;line-height:1}.date-pill-month{color:#aaa;font-size:11px}.date-pill.selected .date-pill-day,.date-pill.selected .date-pill-num,.date-pill.selected .date-pill-month{color:#fff}.slot-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.slot-cell{cursor:pointer;background:#fff;border:1.5px solid #e0e0e0;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;font-family:inherit;transition:all .15s;display:flex}.slot-time{color:#1a1a2e;font-size:13px;font-weight:600}.slot-sub{color:#aaa;font-size:11px}.slot-available:hover{background:#f5f3ff;border-color:#6c63ff}.slot-available:hover .slot-time{color:#6c63ff}.slot-selected{background:#6c63ff;border-color:#6c63ff}.slot-selected .slot-time{color:#fff}.slot-booked{cursor:not-allowed;background:#f9fafb;border-color:#f0f0f0}.slot-booked .slot-time{color:#ccc}.slot-past{cursor:not-allowed;background:#fafafa;border-color:#f0f0f0}.slot-past .slot-time{color:#ccc}.slot-skeleton{cursor:default;background:#f0f0f0;border-color:#e8e8e8;height:56px;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.booking-summary{background:#fff;border:2px solid #e8e4ff;border-radius:16px;padding:24px}.summary-title{color:#1a1a2e;margin-bottom:16px;font-size:16px;font-weight:700}.summary-rows{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.summary-row{justify-content:space-between;font-size:14px;display:flex}.summary-label{color:#888}.summary-value{color:#1a1a2e;font-weight:500}.summary-total{border-top:1px solid #f0f0f0;margin-top:4px;padding-top:10px}.summary-amount{color:#6c63ff;font-size:18px;font-weight:800}.summary-actions{flex-direction:column;gap:10px;display:flex}.minigolf-entry{background:#fff;border:2px solid #f0e6ff;border-radius:16px;flex-direction:column;gap:20px;max-width:460px;padding:28px 24px;display:flex}.minigolf-header{align-items:center;gap:16px;display:flex}.minigolf-icon{font-size:48px}.minigolf-title{color:#1a1a2e;font-size:20px;font-weight:800}.minigolf-note{color:#888;margin-top:2px;font-size:13px}.participant-selector{flex-direction:column;gap:10px;display:flex}.participant-counter{align-items:center;gap:16px;display:flex}.counter-btn{color:#6c63ff;cursor:pointer;background:#fff;border:2px solid #6c63ff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-family:inherit;font-size:20px;transition:all .15s;display:flex}.counter-btn:hover:not(:disabled){color:#fff;background:#6c63ff}.counter-btn:disabled{color:#ccc;cursor:not-allowed;border-color:#ddd}.counter-val{color:#1a1a2e;text-align:center;min-width:32px;font-size:24px;font-weight:800}.minigolf-total{background:#f5f3ff;border-radius:10px;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.minigolf-total span:first-child{color:#666;font-size:14px}.minigolf-total-amt{color:#6c63ff;font-size:22px;font-weight:800}.minigolf-info{color:#aaa;text-align:center;font-size:12.5px;line-height:1.5}.checkout-page{max-width:520px}.checkout-note{color:#aaa;text-align:center;margin-top:16px;font-size:12.5px;line-height:1.5}.confirmation-page{justify-content:center;padding:20px 0;display:flex}.confirmation-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:480px;padding:40px 32px;box-shadow:0 4px 30px #00000014}.confirmation-icon{margin-bottom:8px;font-size:64px}.confirmation-title{color:#1a1a2e;margin-bottom:4px;font-size:26px;font-weight:800}.confirmation-subtitle{color:#888;margin-bottom:24px;font-size:14px}.booking-ref-box{background:linear-gradient(135deg,#6c63ff,#a78bfa);border-radius:12px;flex-direction:column;gap:4px;margin-bottom:24px;padding:20px;display:flex}.booking-ref-label{color:#ffffffb3;text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:600}.booking-ref-code{color:#fff;letter-spacing:2px;font-size:26px;font-weight:900}.booking-ref-hint{color:#ffffffa6;font-size:11px}.confirmation-details{text-align:left;flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.confirm-row{border-bottom:1px solid #f5f5f7;justify-content:space-between;padding-bottom:8px;font-size:14px;display:flex}.confirm-row span:first-child{color:#888}.confirm-row span:last-child{color:#1a1a2e;font-weight:600}.confirm-row-total span:last-child{color:#6c63ff;font-size:16px;font-weight:800}.confirmation-actions{flex-direction:column;gap:10px;display:flex}.tabs{background:#f0f0f5;border-radius:10px;gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.tab-btn{color:#666;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:14px;font-weight:500;transition:all .15s}.tab-btn.active{color:#6c63ff;background:#fff;font-weight:600;box-shadow:0 2px 8px #0000000f}.empty-state{text-align:center;color:#aaa;flex-direction:column;align-items:center;gap:8px;padding:60px 20px;display:flex}.empty-icon{margin-bottom:8px;font-size:52px}.bookings-list{flex-direction:column;gap:14px;display:flex}.booking-card{background:#fff;border:1.5px solid #eee;border-radius:14px;flex-direction:column;gap:8px;padding:18px 20px;display:flex}.booking-card-top{align-items:flex-start;gap:14px;display:flex}.booking-sport-icon{flex-shrink:0;font-size:32px}.booking-card-info{flex:1}.booking-card-name{color:#1a1a2e;font-size:16px;font-weight:700}.booking-card-date{color:#666;margin-top:2px;font-size:13px}.booking-card-slot{color:#888;font-size:13px}.booking-card-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.booking-card-amount{color:#6c63ff;font-size:16px;font-weight:800}.booking-card-ref{color:#bbb;letter-spacing:.5px;font-size:11.5px;font-weight:500}.status-badge{text-transform:capitalize;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.status-confirmed{color:#16a34a;background:#f0fdf4}.status-pending,.status-pending-payment{color:#d97706;background:#fffbeb}.status-cancelled{color:#dc2626;background:#fff5f5}.admin-header{margin-bottom:24px}.admin-filters{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:20px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.admin-content{margin-top:24px}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13.5px}.admin-table th{text-align:left;color:#666;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;background:#f5f5f7;border-bottom:1.5px solid #eee;padding:10px 12px;font-size:12px;font-weight:600}.admin-table td{color:#1a1a2e;vertical-align:middle;border-bottom:1px solid #f0f0f0;padding:12px}.admin-table tr:hover td{background:#fafafa}.row-cancelled td{opacity:.55}.ref-cell{color:#6c63ff;letter-spacing:.5px;font-size:12px;font-weight:700}.table-sub{color:#aaa;margin-top:2px;font-size:11.5px}.actions-cell{flex-wrap:wrap;gap:6px;display:flex}.action-btn{cursor:pointer;border:1.5px solid;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.action-confirm{color:#16a34a;background:#f0fdf4;border-color:#16a34a}.action-confirm:hover:not(:disabled){color:#fff;background:#16a34a}.action-cancel{color:#dc2626;background:#fff5f5;border-color:#dc2626}.action-cancel:hover:not(:disabled){color:#fff;background:#dc2626}.action-btn:disabled{opacity:.5;cursor:not-allowed}.schedule-grid-wrap{overflow-x:auto}.schedule-grid{min-width:560px}.schedule-header,.schedule-row{grid-template-columns:160px 1fr 1fr;display:grid}.schedule-cell{border:1px solid #f0f0f0;align-items:center;min-height:50px;padding:10px 14px;font-size:13.5px;display:flex}.schedule-corner,.schedule-col-header{color:#666;text-transform:uppercase;letter-spacing:.4px;background:#f5f5f7;font-size:12px;font-weight:700}.schedule-time{color:#666;background:#fafafa;font-size:12.5px;font-weight:600}.schedule-booking{color:#fff;border-radius:8px;padding:6px 10px;font-size:12.5px;font-weight:600}.schedule-free{color:#ccc;font-size:13px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:#fff;border:1.5px solid #eee;border-radius:14px;padding:20px 18px}.stat-label{color:#aaa;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600}.stat-value{color:#6c63ff;font-size:36px;font-weight:900;line-height:1}.stat-sub{color:#aaa;margin-top:4px;font-size:12px}.sport-breakdown{background:#fff;border:1.5px solid #eee;border-radius:14px;padding:20px}.breakdown-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.breakdown-sport{color:#1a1a2e;flex-shrink:0;width:160px;font-size:13.5px;font-weight:600}.breakdown-bar-wrap{background:#f0f0f5;border-radius:6px;flex:1;height:10px;overflow:hidden}.breakdown-bar{background:linear-gradient(90deg,#6c63ff,#a78bfa);border-radius:6px;min-width:4px;height:100%;transition:width .5s}.breakdown-count{color:#666;text-align:right;width:28px;font-size:13px;font-weight:700}@media (width<=640px){.app-main{padding:20px 16px}.header-inner{padding:0 16px}.logo-subtext{display:none}.home-title{font-size:26px}.sport-grid{grid-template-columns:repeat(2,1fr);gap:12px}.sport-card{padding:18px 12px}.sport-card-icon{font-size:36px}.sport-card-name{font-size:14px}.sport-card-price{font-size:16px}.slot-grid{grid-template-columns:repeat(3,1fr)}.page-title{font-size:20px}.admin-table{font-size:12px}.admin-table th,.admin-table td{padding:8px}.stats-grid{grid-template-columns:repeat(2,1fr)}.sign-out-btn{display:none}}@media (width<=400px){.sport-grid{grid-template-columns:1fr}.slot-grid{grid-template-columns:repeat(2,1fr)}}.login-modal-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.login-modal-card{background:#fff;border-radius:16px;width:100%;max-width:420px;max-height:90vh;padding:32px 28px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #00000040}.login-modal-card .login-card{box-shadow:none;padding:0}.modal-close-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:18px;line-height:1;transition:color .15s,background .15s;position:absolute;top:12px;right:14px}.modal-close-btn:hover{color:#333;background:#f0f0f0}.addons-selector,.addons-list{flex-direction:column;gap:8px;display:flex}.addon-item{cursor:pointer;background:#fff;border:1.5px solid #e8e8f0;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.addon-item:hover{background:#faf9ff;border-color:#c4bfff}.addon-item-checked{background:#f5f3ff;border-color:#6c63ff}.addon-checkbox{accent-color:#6c63ff;cursor:pointer;flex-shrink:0;width:17px;height:17px}.addon-icon{flex-shrink:0;font-size:20px}.addon-info{flex-direction:column;flex:1;gap:2px;display:flex}.addon-label{color:#1a1a2e;font-size:14px;font-weight:600}.addon-desc{color:#888;font-size:12px}.addon-price{color:#6c63ff;flex-shrink:0;font-size:14px;font-weight:700}.addons-subtotal{text-align:right;color:#555;margin-top:4px;padding-right:4px;font-size:13px}.section-label-optional{color:#aaa;font-size:13px;font-weight:400}.summary-addon-row .summary-label,.summary-addon-row .summary-value{color:#555;font-size:13px}.minigolf-addons-section{margin:20px 0 4px}.minigolf-addons-row{opacity:.8}.minigolf-grand-total{border-top:2px solid #eee;margin-top:4px;padding-top:12px;font-weight:700}.coupon-section{background:#fff;border:1px solid #e8e8f0;border-radius:12px;margin-bottom:16px;padding:16px}.coupon-input-row{gap:10px;display:flex}.coupon-input{text-transform:uppercase;letter-spacing:.05em;border:1.5px solid #e0e0e0;border-radius:8px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.coupon-input:focus{border-color:#6c63ff}.coupon-input::placeholder{text-transform:none;letter-spacing:normal;color:#aaa}.coupon-apply-btn{white-space:nowrap;color:#6c63ff;cursor:pointer;background:0 0;border:1.5px solid #6c63ff;border-radius:8px;flex-shrink:0;padding:10px 18px;font-size:14px;font-weight:600;transition:background .15s,color .15s}.coupon-apply-btn:hover:not(:disabled){color:#fff;background:#6c63ff}.coupon-apply-btn:disabled{opacity:.4;cursor:not-allowed}.coupon-error{color:#e53e3e;margin-top:8px;font-size:12px}.coupon-applied{background:#f0fdf4;border:1.5px solid #86efac;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.coupon-applied-text{color:#166534;font-size:14px}.coupon-remove-btn{color:#e53e3e;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:12px;transition:background .15s}.coupon-remove-btn:hover{background:#fee2e2}.summary-original-price{color:#999;text-decoration:line-through}.summary-discount-row .summary-label{color:#16a34a}.summary-discount{color:#16a34a;font-weight:600}.court2-warning{color:#92400e;background:#fffbeb;border:1.5px solid #fbbf24;border-radius:10px;margin-bottom:16px;padding:12px 14px;font-size:13px;line-height:1.5}.confirm-row-payment-id .payment-id-value{color:#555;word-break:break-all;font-family:monospace;font-size:11px}.summary-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.summary-kpi-card{background:#fff;border:1px solid #e8e8f0;border-top:4px solid #6c63ff;border-radius:12px;padding:18px 20px}.kpi-label{color:#888;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:12px;font-weight:600}.kpi-value{margin-bottom:6px;font-size:28px;font-weight:700;line-height:1}.kpi-sub{color:#888;font-size:12px}.summary-bottom-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=700px){.summary-bottom-grid{grid-template-columns:1fr}}.summary-section{background:#fff;border:1px solid #e8e8f0;border-radius:12px;padding:18px 20px}.summary-booking-list{flex-direction:column;gap:8px;display:flex}.summary-booking-row{background:#f9f9fb;border-radius:8px;grid-template-columns:120px 1fr auto auto auto;align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:grid}.summary-booking-time{color:#6c63ff;font-size:12px;font-weight:600}.summary-booking-sport{color:#333}.summary-booking-user{color:#555}.summary-booking-court{color:#888;font-size:11px}.summary-booking-amount{color:#16a34a;font-weight:600}.badge-count{color:#fff;vertical-align:middle;background:#6c63ff;border-radius:999px;justify-content:center;align-items:center;margin-left:6px;padding:1px 7px;font-size:11px;font-weight:700;display:inline-flex}.row-today{background:#f0f9ff}.coupon-admin-form{background:#fff;border:1px solid #e8e8f0;border-radius:12px;margin-bottom:8px;padding:20px 20px 24px}.coupon-form-grid{flex-wrap:wrap;align-items:flex-end;gap:14px;display:flex}.coupon-form-grid .filter-group{min-width:140px}.coupon-success{color:#16a34a;margin-top:10px;font-size:13px;font-weight:500}.payment-id-cell{color:#666;word-break:break-all;max-width:160px;font-family:monospace;font-size:11px}
