@media(min-width:769px){.header{position:relative;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-sm) 0 var(--sp-md);min-height:52px;background:transparent;border-bottom:1px solid var(--border);margin-bottom:var(--sp-md)}}@media(max-width:768px){.header{position:fixed;top:0;left:0;right:0;z-index:95;background:#0f0d0ad1;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:.5px solid rgba(241,232,217,.08);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-base);height:52px;padding-top:var(--safe-top);box-sizing:content-box}}.header-brand{display:flex;align-items:center;gap:var(--sp-sm);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.header-brand .logo{width:30px;height:30px;border-radius:8px;background:var(--court-red);display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:0 2px 8px #d632304d}.header-brand h1{font-size:18px;font-weight:700;letter-spacing:-.02em;color:var(--text-1)}.header-brand h1 span{color:var(--text-2);font-weight:400}.header-actions{display:flex;gap:var(--sp-sm);align-items:center}.user-profile{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--court-red);color:var(--court-cream);font-size:13px;font-weight:700;border:1.5px solid rgba(241,232,217,.2);cursor:pointer;box-shadow:0 2px 6px #0003;transition:transform .12s cubic-bezier(.25,.46,.45,.94),opacity .12s ease;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;padding:0}.user-profile:active{transform:scale(.92);opacity:.85}.view-tab{background:transparent;border:none;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;transition:color .15s ease,background-color .15s ease,transform .1s ease,box-shadow .15s ease}@media(min-width:769px){.view-tabs{position:relative;display:inline-flex;background:var(--bg-surface);border-radius:9px;padding:2px;height:auto;box-sizing:border-box;border:1px solid var(--border);left:50%;transform:translate(-50%);margin-bottom:var(--sp-md)}.view-tab{display:flex;flex-direction:row;align-items:center;justify-content:center;padding:6px 18px;min-height:32px;border-radius:7px;font-size:13px;font-weight:500;color:var(--text-2);flex:initial}.view-tab:active{transform:scale(.97)}.view-tab .tab-icon{display:none}.view-tab .tab-label{font-size:13px;font-weight:500}.view-tab.active{background:var(--bg-elevated);color:var(--text-1);font-weight:600;box-shadow:0 1px 3px #0000004d}}@media(max-width:768px){.view-tabs{position:fixed;bottom:0;left:0;right:0;z-index:90;display:flex;background:#1a1714d1;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:.5px solid rgba(241,232,217,.08);padding-bottom:var(--safe-bottom);height:52px;box-sizing:content-box}.view-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-3);padding:6px 0}.view-tab:active{transform:scale(.95)}.view-tab .tab-icon{display:block;width:22px;height:22px;transition:transform .15s cubic-bezier(.25,.46,.45,.94)}.view-tab .tab-label{font-size:10px;font-weight:500;letter-spacing:-.01em}.view-tab.active{color:var(--court-red)}.view-tab.active .tab-icon{transform:scale(1.05)}}.grid-container{border-radius:var(--r);background:var(--bg-surface);overflow:hidden;border:1px solid var(--border);margin:0 calc(-1 * var(--sp-base));border-radius:0;border-left:none;border-right:none}.grid-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(241,232,217,.06) transparent;max-height:70vh;overflow-y:auto}.grid-scroll::-webkit-scrollbar{width:4px;height:4px}.grid-scroll::-webkit-scrollbar-track{background:transparent}.grid-scroll::-webkit-scrollbar-thumb{background:#f1e8d90f;border-radius:2px}.ctable{border-collapse:collapse;font-size:10px;table-layout:fixed;width:max-content;min-width:100%}.ctable col.col-time,.ctable col.col-court{width:48px}.ctable thead th{position:sticky;top:0;z-index:3;background:var(--bg-surface);padding:6px 0;font-weight:600;font-size:10px;color:var(--text-3);border-bottom:1px solid var(--border);text-align:center}.ctable thead th:first-child{position:sticky;left:0;z-index:4;background:var(--bg-surface);text-align:right;padding-right:6px;border-right:1px solid rgba(241,232,217,.04)}.ctable tbody td{padding:0;text-align:center;border-bottom:1px solid rgba(241,232,217,.02);height:24px}.ctable tbody td:first-child{position:sticky;left:0;z-index:2;background:var(--bg-surface);font-weight:500;font-size:10px;color:var(--text-3);text-align:right;padding-right:6px;font-variant-numeric:tabular-nums;border-right:1px solid rgba(241,232,217,.04)}.ctable tr.hour-start td{border-top:1px solid rgba(241,232,217,.05)}.sc{display:block;width:100%;height:24px;border:none;padding:0;margin:0;font:inherit;cursor:default;transition:opacity .12s ease,transform .12s ease}.sc:active{transform:scale(.92)}.sc-f{background:var(--green);opacity:.25;cursor:pointer}.sc-f:hover{opacity:.45}.sc-f:active{opacity:.65}.sc-p{background:var(--orange);opacity:.2;cursor:pointer}.sc-p:hover{opacity:.45}.sc-p:active{opacity:.6}.sc-t{background:var(--text-3);opacity:.06}.sc-c{background:transparent}.sc-disabled{opacity:.1!important;cursor:not-allowed!important;pointer-events:none}@media(max-width:640px){.ctable col.col-time,.ctable col.col-court{width:40px}.ctable thead th{font-size:10px;padding:5px 0}.ctable tbody td,.sc{height:22px}}.date-nav{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 0 var(--sp-md);min-height:44px}.date-nav .btn-icon{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;font-size:14px}.date-nav .date-label{font-size:15px;font-weight:600;min-width:180px;text-align:center;color:var(--text-1)}.date-nav .today-badge{display:inline-block;background:var(--court-red-dim);color:var(--court-red);font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--r-pill);margin-left:6px;text-transform:uppercase}.legend{display:flex;gap:var(--sp-md);align-items:center;padding:0 var(--sp-xs) var(--sp-sm)}.legend-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-3)}.legend-dot{width:7px;height:7px;border-radius:50%}.legend-dot.free{background:var(--green)}.legend-dot.peak{background:var(--orange)}.legend-dot.taken{background:var(--text-3)}.legend-toggle{display:flex;align-items:center;gap:6px;margin-left:auto;font-size:12px;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:44px}.legend-toggle input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:42px;height:26px;border:none;border-radius:13px;background:var(--text-3);cursor:pointer;position:relative;transition:background .25s cubic-bezier(.25,.46,.45,.94)}.legend-toggle input[type=checkbox]:after{content:"";position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform .25s cubic-bezier(.25,.46,.45,.94),width .2s cubic-bezier(.25,.46,.45,.94)}.legend-toggle input[type=checkbox]:active:after{width:26px}.legend-toggle input[type=checkbox]:checked{background:var(--green)}.legend-toggle input[type=checkbox]:checked:after{transform:translate(16px)}.legend-toggle input[type=checkbox]:checked:active:after{transform:translate(12px)}.pref-header{padding:0 0 var(--sp-md)}.pref-header h2{font-size:15px;font-weight:600;margin-bottom:2px}.pref-header p{font-size:13px;color:var(--text-3)}.pref-cards{display:flex;flex-direction:column;background:var(--bg-surface);border-radius:var(--r);overflow:hidden}.pref-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--sp-sm);padding:var(--sp-md) var(--sp-base);min-height:60px;background:var(--bg-surface)}.pref-row:not(:last-child){border-bottom:1px solid var(--border)}.pref-row.pref-row-all-free{background:var(--green-dim)}.pref-row.pref-row-hot{background:var(--orange-dim)}.pref-row-date{font-size:15px;font-weight:600;display:flex;align-items:center;gap:var(--sp-sm);grid-column:1 / -1}.pref-temp{font-size:13px;font-weight:400;color:var(--text-3)}.pref-temp.hot{color:var(--orange)}.pref-row-courts{display:flex;flex-direction:column;gap:var(--sp-sm);grid-column:1 / -1}.pref-court-chip{display:flex;align-items:center;gap:var(--sp-sm);padding:10px var(--sp-md);border-radius:10px;font-size:15px;flex:1;min-width:0;min-height:44px;background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.pref-court-chip.free{background:var(--green-dim);border-color:#30d15826}.pref-court-chip.taken,.pref-court-chip.unavailable{background:#ffffff05;border-color:#ffffff0a}.pref-court-chip.taken .pref-court-chip-name,.pref-court-chip.unavailable .pref-court-chip-name{opacity:.5}.pref-court-chip.loading{opacity:.3}.pref-court-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pref-court-chip.free .pref-court-chip-dot{background:var(--green)}.pref-court-chip.taken .pref-court-chip-dot{background:var(--text-3);opacity:.35}.pref-court-chip.unavailable .pref-court-chip-dot{background:var(--text-3);opacity:.25}.pref-court-chip-name{font-weight:500;white-space:nowrap}.pref-court-chip-status{margin-left:auto;font-size:13px;color:var(--text-3);white-space:nowrap}.pref-court-chip-status.not-yet{color:var(--orange);font-style:italic}.pref-court-chip-book{margin-left:auto;padding:8px 20px;font-size:15px;font-weight:600;background:var(--court-red);color:var(--court-cream);border:none;border-radius:var(--r-pill);cursor:pointer;min-height:36px;white-space:nowrap;-webkit-touch-callout:none;transition:transform .12s cubic-bezier(.25,.46,.45,.94),opacity .12s ease}.pref-court-chip-book:active{transform:scale(.96);opacity:.85}.booking-detail{background:var(--bg-surface);border-radius:12px;padding:0 var(--sp-base);margin-bottom:var(--sp-base);border:1px solid var(--border)}.booking-detail .detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;min-height:44px}.booking-detail .detail-row:not(:last-child){border-bottom:1px solid var(--border)}.booking-detail .detail-label{font-size:14px;color:var(--text-2)}.booking-detail .detail-value{font-size:15px;font-weight:600;color:var(--text-1)}.modal-hint{font-size:13px;color:var(--text-3);text-align:center;margin-bottom:var(--sp-base);line-height:1.4}.toast{background:#1e1a16d9;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border:1px solid var(--border-strong);border-radius:14px;padding:12px 16px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;text-align:center;box-shadow:0 8px 24px #0006;color:var(--text-1);pointer-events:auto}.toast.success{border-color:#30d15840;box-shadow:0 8px 24px #30d1581a}.toast.error{border-color:#d6323040;box-shadow:0 8px 24px #d632301a}@media(min-width:769px){.toast-container{position:fixed;top:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px;width:320px;pointer-events:none}.toast{animation:toast-in-desktop .35s cubic-bezier(.16,1,.3,1),toast-out-desktop .2s ease 2.8s forwards;width:100%}}@media(max-width:768px){.toast-container{position:fixed;top:calc(var(--safe-top) + 12px);left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;align-items:center;gap:8px;width:calc(100% - 32px);max-width:360px;pointer-events:none}.toast{animation:toast-in-mobile .35s cubic-bezier(.16,1,.3,1),toast-out-mobile .2s ease 2.8s forwards;width:100%}}@keyframes toast-in-mobile{0%{transform:translateY(-40px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes toast-out-mobile{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-10px) scale(.95);opacity:0}}@keyframes toast-in-desktop{0%{transform:translate(40px) scale(.95);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes toast-out-desktop{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(20px) scale(.95);opacity:0}}.profile-container{display:flex;flex-direction:column;gap:var(--sp-lg);max-width:500px;margin:0 auto;padding:4px 0 var(--sp-2xl)}.profile-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:var(--sp-lg) var(--sp-base)}.profile-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--green),hsl(160,60%,40%));display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;letter-spacing:-.02em;box-shadow:0 2px 12px #34c7594d}.profile-name{font-size:20px;font-weight:700;color:var(--text-1);letter-spacing:-.01em}.profile-badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--green);background:#34c7591f;padding:3px 10px;border-radius:6px;border:1px solid rgba(52,199,89,.2)}.ios-section{display:flex;flex-direction:column}.ios-section-header{font-size:12px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px;padding-left:12px}.ios-list{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.ios-row{display:flex;justify-content:space-between;align-items:center;padding:12px var(--sp-base);min-height:48px;font-size:15px}.ios-row:not(:last-child){border-bottom:1px solid var(--border)}.ios-label{font-weight:500;color:var(--text-1)}.ios-value{color:var(--text-2);font-weight:400}.ios-value.text-muted{color:var(--text-3)}.ios-row-link{text-decoration:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s ease}.ios-row-link:active{background:#ffffff0a}.ios-chevron{font-size:20px;font-weight:300;color:var(--text-3);line-height:1}.ios-switch{display:inline-block;position:relative;width:42px;height:26px;cursor:pointer;-webkit-user-select:none;user-select:none}.ios-switch input{opacity:0;width:0;height:0}.ios-switch-slider{position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--text-3);border-radius:13px;transition:background-color .2s ease}.ios-switch-slider:before{content:"";position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform .2s cubic-bezier(.25,.46,.45,.94),width .15s ease}.ios-switch input:checked+.ios-switch-slider{background-color:var(--green)}.ios-switch input:checked+.ios-switch-slider:before{transform:translate(16px)}.ios-switch:active .ios-switch-slider:before{width:26px}.ios-switch input:checked:active+.ios-switch-slider:before{transform:translate(12px)}.ios-signout-btn{width:100%;padding:14px;font-size:16px;border-radius:12px;background:#d632301f!important;color:var(--court-red)!important;border:1px solid rgba(214,50,48,.2)!important;font-weight:600;box-shadow:none}.ios-signout-btn:active{background:#d6323038!important;transform:scale(.97)}:root{--court-cream: #F1E8D9;--court-red: #D63230;--court-red-dim: rgba(214, 50, 48, .08);--court-red-glow: rgba(214, 50, 48, .15);--court-wood: #2A2118;--court-wood-light: #3D3127;--bg-base: #0F0D0A;--bg-surface: #1A1714;--bg-elevated: #252119;--bg-glass: rgba(241, 232, 217, .03);--border: rgba(241, 232, 217, .1);--border-strong: rgba(241, 232, 217, .18);--text-1: var(--court-cream);--text-2: #A89F90;--text-3: #6B6359;--green: #30D158;--green-dim: rgba(48, 209, 88, .08);--orange: #FF9F0A;--orange-dim: rgba(255, 159, 10, .06);--sp-xs: 4px;--sp-sm: 8px;--sp-md: 12px;--sp-base: 16px;--sp-lg: 24px;--sp-xl: 32px;--sp-2xl: 48px;--r: 12px;--r-pill: 980px;--t: .15s ease;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,SF Pro Text,SF Pro Display,system-ui,sans-serif;background:var(--bg-base);color:var(--text-1);min-height:100vh;min-height:100dvh;font-size:15px;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}@media(min-width:769px){.app{padding:var(--sp-lg) var(--sp-base);max-width:900px;margin:0 auto;min-height:100vh;min-height:100dvh}}@media(max-width:768px){.app{padding-top:calc(var(--safe-top) + 52px + var(--sp-md));padding-bottom:calc(var(--safe-bottom) + 64px + var(--sp-base));padding-left:calc(var(--safe-left) + var(--sp-base));padding-right:calc(var(--safe-right) + var(--sp-base));min-height:100vh;min-height:100dvh}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-xs);padding:10px var(--sp-base);min-height:44px;border:none;border-radius:var(--r);background:var(--bg-elevated);color:var(--text-1);font:inherit;font-size:15px;font-weight:500;cursor:pointer;transition:transform .12s cubic-bezier(.25,.46,.45,.94),opacity .12s ease;white-space:nowrap;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.96);opacity:.85}.btn-accent{background:var(--court-red);color:var(--court-cream);font-weight:600}.btn-accent:active{transform:scale(.96);opacity:.9}.btn-ghost{background:transparent;color:var(--court-red)}.btn-ghost:active{transform:scale(.96);opacity:.6}.btn-sm{padding:8px 14px;min-height:36px;font-size:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:var(--sp-sm);padding-bottom:calc(var(--safe-bottom) + var(--sp-sm));opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:#252119d9;backdrop-filter:saturate(180%) blur(25px);-webkit-backdrop-filter:saturate(180%) blur(25px);border:1px solid var(--border);border-radius:16px;padding:var(--sp-lg) var(--sp-base);width:100%;max-width:400px;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);box-shadow:0 -10px 40px #00000080}.modal-overlay.active .modal{transform:translateY(0)}.modal:before{content:"";display:block;width:36px;height:5px;border-radius:3px;background:#f1e8d926;margin:0 auto 16px}.modal h2{font-size:20px;font-weight:700;margin-bottom:var(--sp-xs);letter-spacing:-.02em;text-align:center}.modal .modal-subtitle{font-size:14px;color:var(--text-2);margin-bottom:var(--sp-lg);text-align:center}.modal-actions{display:flex;gap:var(--sp-sm);margin-top:var(--sp-lg)}.modal-actions .btn{flex:1;padding:14px;font-size:16px;border-radius:var(--r)}.form-group{margin-bottom:var(--sp-base)}.form-group label{display:block;font-size:13px;color:var(--text-2);margin-bottom:6px;font-weight:500}.form-group input{width:100%;padding:14px var(--sp-base);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);color:var(--text-1);font:inherit;font-size:16px;outline:none;transition:border-color var(--t)}.form-group input:focus{border-color:var(--court-red);box-shadow:0 0 0 3px var(--court-red-dim)}.form-group input::placeholder{color:var(--text-3)}.form-error{color:var(--court-red);font-size:13px;margin-top:6px}.form-list-group{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:var(--sp-base)}.form-list-group .form-group{margin-bottom:0;display:flex;align-items:center;border-bottom:1px solid var(--border);padding:2px 16px;min-height:48px}.form-list-group .form-group:last-child{border-bottom:none}.form-list-group label{font-size:14px;color:var(--text-2);font-weight:500;min-width:90px;margin-bottom:0}.form-list-group input{border:none;background:transparent;padding:12px 0;border-radius:0;font-size:15px;height:100%}.form-list-group input:focus{border-color:transparent;box-shadow:none}.loading-container{display:flex;flex-direction:column;align-items:center;padding:60px var(--sp-base);gap:var(--sp-md)}.spinner{width:24px;height:24px;border:2.5px solid rgba(241,232,217,.08);border-top-color:var(--court-red);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;color:var(--text-3)}.error-container{display:flex;flex-direction:column;align-items:center;padding:60px var(--sp-base);gap:10px}.error-icon{font-size:28px}.error-message{font-size:15px;color:var(--text-2);text-align:center}
