:root{--ski-blue: #0066CC;--ski-blue-dark: #003087;--ski-green: #00A86B;--ski-gold: #FFD700;--bg-color: #F5F5F5;--card-bg: #FFFFFF;--text-primary: #1A1A1A;--text-secondary: #666666;--border-color: #E0E0E0;--status-available-bg: #E6F4EA;--status-available-text: #1E8E3E;--status-booked-bg: #FCE8E6;--status-booked-text: #C5221F;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--touch-target: 48px}body{background-color:var(--bg-color);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation}button,a,input,select,textarea{min-height:var(--touch-target);min-width:var(--touch-target)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);min-height:300px;gap:var(--space-lg)}.loading-spinner{font-size:4rem;animation:spin 2s linear infinite}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-metric{height:80px;border-radius:8px}.skeleton-chart{height:300px;border-radius:8px}.skeleton-table-row{height:50px;margin-bottom:8px;border-radius:4px}.error-alert{background:#fce8e6;border:1px solid #EA4335;border-left:4px solid #EA4335;border-radius:8px;padding:var(--space-lg);margin-bottom:var(--space-lg);display:flex;gap:var(--space-md);align-items:flex-start}.error-alert-icon{font-size:1.5rem;flex-shrink:0}.error-alert-content{flex:1}.error-alert h3{margin:0 0 var(--space-xs) 0;color:#c5221f;font-size:16px}.error-alert p{margin:0;color:#c5221f;font-size:14px;opacity:.9}.success-alert{background:#e6f4ea;border:1px solid #34A853;border-left:4px solid #34A853;border-radius:8px;padding:var(--space-lg);margin-bottom:var(--space-lg);display:flex;gap:var(--space-md);align-items:flex-start;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.success-alert-icon{font-size:1.5rem;flex-shrink:0}.success-alert-content{flex:1}.success-alert h3{margin:0 0 var(--space-xs) 0;color:#1e8e3e;font-size:16px}.success-alert p{margin:0;color:#1e8e3e;font-size:14px;opacity:.9}.warning-alert{background:#fff8e1;border:1px solid #F9AB00;border-left:4px solid #F9AB00;border-radius:8px;padding:var(--space-lg);margin-bottom:var(--space-lg);display:flex;gap:var(--space-md);align-items:flex-start}.warning-alert-icon{font-size:1.5rem;flex-shrink:0}.warning-alert-content{flex:1}.warning-alert h3{margin:0 0 var(--space-xs) 0;color:#f57c00;font-size:16px}.warning-alert p{margin:0;color:#f57c00;font-size:14px;opacity:.9}.empty-state{text-align:center;padding:var(--space-xl);color:var(--text-secondary);min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg)}.empty-state-illustration{font-size:5rem;opacity:.5}.empty-state h3{margin:0;color:var(--text-primary);font-size:18px}.empty-state p{margin:0;font-size:14px;max-width:300px}.empty-state-action{margin-top:var(--space-md)}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:var(--space-md);pointer-events:none}.toast{background:#fff;padding:var(--space-lg);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:300px;display:flex;gap:var(--space-md);align-items:center;pointer-events:auto;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-success{border-left:4px solid #34A853}.toast-error{border-left:4px solid #EA4335}.toast-warning{border-left:4px solid #F9AB00}.toast-icon{font-size:1.5rem;flex-shrink:0}.toast-content{flex:1}.toast-content h4{margin:0 0 4px;font-size:14px;font-weight:600}.toast-content p{margin:0;font-size:13px;opacity:.8}.toast-close{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:0;min-height:0;min-width:auto;flex-shrink:0;color:var(--text-secondary)}.toast-close:hover{color:var(--text-primary)}button:disabled{opacity:.6;cursor:not-allowed}button.loading{position:relative;color:transparent}button.loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid #f3f3f3;border-top:2px solid var(--ski-blue);border-radius:50%;animation:spin .8s linear infinite}body{background-color:var(--bg-color);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);margin:0;padding:0;-webkit-tap-highlight-color:transparent}.app-container{max-width:600px;margin:0 auto;min-height:100vh;background-color:var(--bg-color);display:flex;flex-direction:column}.app-header{background-color:var(--ski-blue-dark);color:#fff;padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #00000026;position:sticky;top:0;z-index:100}.app-logo{font-weight:800;font-size:20px;letter-spacing:-.5px;display:flex;align-items:center;gap:var(--space-sm)}.card{background:var(--card-bg);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-md);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05)}.card-title{font-size:18px;font-weight:700;margin:0 0 var(--space-md) 0;color:var(--ski-blue-dark)}.btn{height:56px;border-radius:var(--radius-md);border:none;font-weight:700;font-size:16px;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;transition:transform .1s,background-color .2s}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--ski-gold);color:var(--ski-blue-dark);box-shadow:0 4px 6px #0000001a}.btn-secondary{background-color:#fff;border:2px solid var(--ski-blue-dark);color:var(--ski-blue-dark)}.btn-text{background:none;color:var(--text-secondary);height:auto;padding:var(--space-sm)}.input-group{margin-bottom:var(--space-lg)}.input-label{display:block;font-weight:600;margin-bottom:var(--space-sm);color:var(--ski-blue-dark)}.input-field{width:100%;height:56px;padding:0 var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;background-color:#fff;transition:border-color .2s;box-sizing:border-box}.input-field:focus{outline:none;border-color:var(--ski-blue-dark)}.stepper-container{padding:var(--space-md)}.progress-bar{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg)}.progress-step{height:6px;flex:1;background-color:var(--border-color);border-radius:4px;transition:background-color .3s}.progress-step.active{background-color:var(--ski-gold)}.progress-step.completed{background-color:var(--ski-blue-dark)}.chip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-sm)}.chip{padding:var(--space-sm);border:2px solid var(--border-color);border-radius:var(--radius-sm);text-align:center;font-weight:600;cursor:pointer;background:#fff}.chip.selected{background-color:var(--ski-blue-dark);color:#fff;border-color:var(--ski-blue-dark)}.chip:disabled{opacity:.5;background-color:#eee;cursor:not-allowed}.ski-calendar{background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color)}.ski-calendar-header{background-color:var(--ski-gold);padding:var(--space-md);display:flex;justify-content:space-between;align-items:center}.ski-calendar-month{margin:0;color:var(--ski-blue-dark);font-size:18px;font-weight:700;text-transform:capitalize}.ski-calendar-nav-btn{background:none;border:none;font-size:24px;color:var(--ski-blue-dark);cursor:pointer;padding:0 var(--space-sm);font-weight:700}.ski-calendar-nav-btn:hover{opacity:.7}.ski-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);padding:var(--space-sm);gap:2px}.ski-calendar-day-name{text-align:center;font-weight:600;color:var(--text-secondary);font-size:12px;padding:var(--space-xs)}.ski-calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;cursor:pointer;border-radius:50%;transition:all .2s}.ski-calendar-day:hover:not(.empty):not(.disabled){background-color:var(--bg-color);color:var(--ski-blue-dark)}.ski-calendar-day.selected{background-color:var(--ski-blue-dark);color:#fff}.ski-calendar-day.today{border:2px solid var(--ski-gold)}.ski-calendar-day.disabled{color:#ccc;cursor:not-allowed}.ski-calendar-day.empty{cursor:default}.ski-availability-grid{display:grid;grid-template-columns:60px repeat(5,1fr);gap:1px;background-color:var(--border-color);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;margin-top:var(--space-md)}.ski-grid-header{background-color:var(--ski-blue-dark);color:#fff;padding:var(--space-sm);font-size:12px;font-weight:700;text-align:center;display:flex;align-items:center;justify-content:center}.ski-grid-time{background-color:var(--ski-blue-light);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.ski-grid-cell{background-color:#fff;height:40px;cursor:pointer;transition:background-color .2s}.ski-grid-row-contents{display:contents}.ski-grid-cell:hover{filter:brightness(.95)}.ski-grid-cell.available{background-color:var(--status-available-bg)}@media(min-width:768px){.app-container{max-width:1200px;flex-direction:row;align-items:flex-start;padding:var(--space-lg);gap:var(--space-lg)}.app-header{position:fixed;top:0;left:0;right:0;width:100%}.left-panel{flex:4;position:sticky;top:100px}.right-panel{flex:6;margin-top:80px}.stepper-container{padding:0}}@media(max-width:767px){.left-panel{display:none}}.progress-steps-container{position:relative;padding:var(--space-xl) var(--space-md);margin-bottom:var(--space-lg)}.progress-track{position:absolute;top:50%;left:10%;right:10%;height:4px;background-color:var(--border-color);border-radius:2px;transform:translateY(-50%);z-index:1}.progress-fill{height:100%;background:linear-gradient(90deg,var(--ski-blue),var(--ski-green));border-radius:2px;transition:transform .3s ease;transform-origin:left;width:100%}.steps-row{position:relative;display:flex;justify-content:space-between;align-items:flex-start;z-index:2}.step-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);flex:1;max-width:120px}.step-circle{width:56px;height:56px;border-radius:50%;border:3px solid var(--border-color);background-color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .3s ease;cursor:default;position:relative;box-shadow:0 2px 8px #0000001a}.step-circle.completed{background-color:var(--ski-green);border-color:var(--ski-green);color:#fff}.step-circle.completed.clickable{cursor:pointer}.step-circle.completed.clickable:hover{transform:scale(1.05);box-shadow:0 4px 12px #1e8e3e4d}.step-circle.current{background-color:var(--ski-blue);border-color:var(--ski-blue);color:#fff;animation:pulse 2s ease-in-out infinite}.step-circle.upcoming{background-color:#fff;border-color:var(--border-color);color:var(--text-secondary)}.step-icon{display:flex;align-items:center;justify-content:center}.completed-icon{font-size:28px;font-weight:700}.step-label{text-align:center;max-width:100%}.step-number{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.step-title{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.3}.step-wrapper:has(.step-circle.current) .step-title{color:var(--ski-blue);font-weight:600}.step-wrapper:has(.step-circle.completed) .step-title{color:var(--ski-green)}@keyframes pulse{0%,to{box-shadow:0 2px 8px #0000001a,0 0 #0067b866}50%{box-shadow:0 2px 8px #0000001a,0 0 0 8px #0067b800}}@media(max-width:767px){.progress-steps-container{padding:var(--space-md) var(--space-sm)}.step-wrapper{max-width:80px}.step-circle{width:48px;height:48px;font-size:20px}.step-title{font-size:11px}.step-number{font-size:9px}}.step-container{padding:var(--space-md)}.step-description{color:var(--text-secondary);margin-top:-var(--space-sm);margin-bottom:var(--space-lg);font-size:14px}.hole-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.hole-option{background:#fff;border:2px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);cursor:pointer;transition:all .2s ease;text-align:center;display:flex;flex-direction:column;gap:var(--space-xs)}.hole-option:hover{border-color:var(--ski-blue);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.hole-option.selected{border-color:var(--ski-blue);background:linear-gradient(135deg,#0067b80d,#1e8e3e0d);box-shadow:0 4px 16px #0067b833}.hole-number{font-size:36px;font-weight:700;color:var(--ski-blue);line-height:1}.hole-label{font-size:14px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.hole-duration{font-size:13px;color:var(--text-secondary);margin-top:var(--space-xs)}.hole-price{font-size:15px;font-weight:600;color:var(--ski-green);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border-color)}.price-preview{margin-top:var(--space-lg);padding:var(--space-md);background:linear-gradient(135deg,#0067b80d,#1e8e3e0d);border-radius:var(--radius-sm);border-left:4px solid var(--ski-green)}.price-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.price-range{font-weight:600;color:var(--ski-blue)}.btn-large{padding:16px 24px;font-size:16px;font-weight:600}.cart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin:24px 0}.cart-card{position:relative;border:2px solid var(--input-border);border-radius:var(--border-radius);padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fff}.cart-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #004e9826;transform:translateY(-2px)}.cart-card.selected{border-color:var(--primary-color);background-color:var(--primary-hover)}.cart-card.unavailable{opacity:.6;cursor:not-allowed;background-color:#f5f5f5}.cart-card.unavailable:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.03) 10px,rgba(0,0,0,.03) 20px);pointer-events:none}.cart-icon{font-size:48px;margin-bottom:12px}.cart-name{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.cart-status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.cart-status.available{background-color:var(--status-available-bg);color:var(--status-available-text)}.cart-status.charging{background-color:var(--status-charging-bg);color:var(--status-charging-text)}.cart-status.occupied{background-color:var(--status-booked-bg);color:var(--status-booked-text)}.filter-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background-color:var(--bg-secondary);border-radius:var(--border-radius);margin-bottom:16px}.filter-label{font-size:14px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.cart-count{font-size:14px;color:var(--text-secondary)}.cart-empty{text-align:center;padding:60px 20px;color:var(--text-secondary)}.cart-empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.price-breakdown-card{background-color:var(--bg-secondary);border:2px solid var(--input-border);border-radius:var(--border-radius);padding:20px;margin:24px 0}.price-breakdown-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:16px}.price-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.price-row.discount{color:var(--status-available-text)}.price-row.discount .price-value{font-weight:600}.price-divider{height:1px;background-color:var(--input-border);margin:12px 0}.price-row.total{padding-top:12px;font-size:18px;font-weight:700;color:var(--primary-color)}.total-value{font-size:24px}.payment-info{font-size:12px;color:var(--text-secondary);text-align:center;margin-top:12px;font-style:italic}.contact-preference{display:flex;gap:12px;margin-top:8px}.preference-chip{flex:1;padding:12px;border:2px solid var(--input-border);border-radius:var(--border-radius);text-align:center;cursor:pointer;transition:all .2s ease;background:#fff}.preference-chip:hover{border-color:var(--primary-color)}.preference-chip.selected{border-color:var(--primary-color);background-color:var(--primary-hover);font-weight:600}.preference-icon{font-size:24px;margin-bottom:4px}.review-card{background:#fff;border:2px solid var(--input-border);border-radius:var(--border-radius);overflow:hidden;margin-bottom:20px}.review-section{padding:20px}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.review-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0}.edit-btn{padding:6px 16px;background:transparent;border:1px solid var(--primary-color);border-radius:16px;color:var(--primary-color);font-size:14px;cursor:pointer;transition:all .2s ease}.edit-btn:hover{background-color:var(--primary-hover);transform:scale(1.05)}.review-content{display:flex;flex-direction:column;gap:12px}.review-row{display:flex;justify-content:space-between;align-items:center}.review-label{font-size:14px;color:var(--text-secondary)}.review-value{font-size:14px;color:var(--text-primary);font-weight:500}.review-value.highlight{color:var(--primary-color);font-weight:700}.review-value.discount{color:var(--status-available-text);font-weight:600}.review-divider{height:1px;background-color:var(--input-border)}.price-summary-card{background:linear-gradient(135deg,var(--ski-blue),var(--ski-blue-dark));border-radius:var(--radius-md);padding:24px;color:#fff;margin-bottom:20px}.price-summary-title{font-size:18px;font-weight:700;margin-bottom:16px;color:#fff}.price-breakdown-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#ffffffe6}.price-breakdown-row.discount{color:var(--gold-accent)}.price-summary-divider{height:2px;background-color:#ffffff4d;margin:12px 0}.price-breakdown-row.total{padding-top:12px;font-size:16px}.total-text{font-weight:500}.total-amount{font-size:28px;font-weight:700;color:var(--gold-accent)}.payment-note{font-size:12px;color:#fffc;margin-top:12px;text-align:center}.terms-section{background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius);margin-bottom:24px}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-input{width:20px;height:20px;cursor:pointer}.step-actions{display:flex;gap:12px;justify-content:space-between}.step-actions .btn{flex:1}.btn-large{padding:16px 32px;font-size:16px;font-weight:600}.success-state{text-align:center;padding:40px 20px}.success-icon{font-size:80px;margin-bottom:20px;animation:bounce 1s ease}.success-title{font-size:28px;color:var(--primary-color);margin-bottom:32px}.success-details{background:#fff;border:2px solid var(--status-available-bg);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;text-align:left}.success-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--input-border)}.success-label{color:var(--text-secondary);font-size:14px}.success-value{color:var(--text-primary);font-weight:600;font-size:14px}.success-confirmation{background-color:var(--status-available-bg);color:var(--status-available-text);padding:20px;border-radius:var(--border-radius);margin-bottom:32px}.confirmation-icon{font-size:40px;margin-bottom:12px}.step-description{color:var(--text-secondary);font-size:14px;margin-top:-8px;margin-bottom:24px}.button-group{display:flex;gap:10px}.button-group-margin{display:flex;gap:10px;margin-bottom:10px}.button-group .chip{flex:1;padding:15px}.button-group-margin .chip{flex:1}@media(max-width:768px){.cart-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.step-actions{flex-direction:column}.review-row{flex-direction:column;align-items:flex-start;gap:4px}}.availability-tooltip{position:fixed;z-index:10000;transform:translate(-50%,-100%);pointer-events:none;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,calc(-100% - 5px))}to{opacity:1;transform:translate(-50%,-100%)}}.tooltip-content{background:#fff;border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;padding:var(--space-md);min-width:250px;border:1px solid var(--border-color)}.tooltip-header{display:flex;align-items:center;gap:var(--space-sm);padding-bottom:var(--space-sm);margin-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.tooltip-header strong{font-size:16px;color:var(--text-primary)}.tooltip-badge{background:#0066cc1a;color:var(--ski-blue);padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.tooltip-body{display:flex;flex-direction:column;gap:var(--space-sm)}.tooltip-row{display:flex;align-items:center;gap:var(--space-sm);font-size:14px;color:var(--text-secondary)}.tooltip-icon{font-size:16px;width:20px;display:flex;justify-content:center}.tooltip-note{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:#00a86b1a;border-radius:var(--radius-sm);font-size:13px;color:var(--status-available-text);font-weight:500}.admin-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.admin-header{background-color:var(--ski-blue-dark);color:#fff;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);box-shadow:0 2px 8px #00000026;position:sticky;top:0;z-index:1000}.admin-header-left{display:flex;align-items:center;gap:var(--space-md)}.sidebar-toggle{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:var(--space-sm);border-radius:var(--radius-sm);transition:background-color .2s}.sidebar-toggle:hover{background-color:#ffffff1a}.admin-logo{display:flex;flex-direction:column}.logo-text{font-weight:800;font-size:18px;letter-spacing:-.5px}.logo-subtitle{font-size:11px;opacity:.8;font-weight:400}.admin-header-right{display:flex;align-items:center;gap:var(--space-md)}.header-icon-wrapper{position:relative}.header-icon-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:var(--space-sm);border-radius:var(--radius-sm);transition:background-color .2s;position:relative;min-width:40px;min-height:40px}.header-icon-btn:hover,.header-icon-btn.active{background-color:#ffffff1a}.notification-badge{position:absolute;top:4px;right:4px;background-color:#f44;color:#fff;font-size:10px;font-weight:700;padding:2px 5px;border-radius:10px;min-width:16px;text-align:center}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:var(--radius-md);box-shadow:0 4px 24px #00000026;min-width:320px;max-width:400px;z-index:1000;animation:slideDown .2s ease-out}.dropdown-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.dropdown-header h3{margin:0;font-size:16px;color:var(--text-primary)}.dropdown-footer{padding:12px;border-top:1px solid var(--border-color);text-align:center}.notifications-list{max-height:400px;overflow-y:auto}.notification-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .2s}.notification-item:hover{background-color:#f8f9fa}.notification-item.unread{background-color:#f0f7ff}.notification-icon{font-size:24px;flex-shrink:0}.notification-content{flex:1}.notification-text{margin:0 0 4px;font-size:14px;color:var(--text-primary)}.notification-time{font-size:12px;color:var(--text-secondary)}.mark-read-btn,.view-all-btn{background:none;border:none;color:var(--ski-blue);font-size:13px;cursor:pointer;padding:4px 8px;font-weight:500}.mark-read-btn:hover,.view-all-btn:hover{text-decoration:underline}.settings-list{padding:8px 0}.settings-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-primary);transition:background-color .2s;text-align:left;text-decoration:none}.settings-item:hover{background-color:#f8f9fa}.settings-icon{font-size:20px;width:24px;text-align:center}.profile-header{padding:20px 16px;border-bottom:1px solid var(--border-color);display:flex;gap:12px;align-items:center}.profile-avatar-large{width:48px;height:48px;background:linear-gradient(135deg,var(--ski-blue),var(--ski-blue-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.profile-info h4{margin:0 0 4px;font-size:15px;color:var(--text-primary)}.profile-info p{margin:0;font-size:13px;color:var(--text-secondary)}.profile-links{padding:8px 0}.profile-link{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-primary);transition:background-color .2s;text-align:left}.profile-link:hover{background-color:#f8f9fa}.profile-link.logout{color:#dc3545}.profile-link.logout:hover{background-color:#fff0f0}.profile-link-icon{font-size:18px;width:24px;text-align:center}.profile-divider{margin:8px 0;border:none;border-top:1px solid var(--border-color)}.user-avatar{background:#fff;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s}.user-avatar:hover{transform:scale(1.05)}.mobile-menu-toggle{display:none;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:var(--space-sm)}.admin-body{display:flex;flex:1;overflow:hidden}.admin-sidebar{background-color:#fff;width:240px;border-right:1px solid var(--border-color);transition:width .3s ease;overflow:hidden}.admin-sidebar.closed{width:64px}.sidebar-nav{display:flex;flex-direction:column;padding:var(--space-md) 0}.nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);color:var(--text-primary);text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{background-color:var(--bg-color)}.nav-item.active{background-color:#0066cc1a;border-left-color:var(--ski-blue);color:var(--ski-blue);font-weight:600}.nav-icon{font-size:20px;min-width:24px;display:flex;justify-content:center}.nav-label{white-space:nowrap;font-size:15px}.admin-sidebar.closed .nav-label{display:none}.admin-main{flex:1;overflow-y:auto;background-color:var(--bg-color);padding:var(--space-xl);transition:margin-left .3s ease}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border-color);padding:var(--space-sm) 0;box-shadow:0 -2px 8px #0000001a;z-index:999}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;padding:var(--space-sm);color:var(--text-secondary);text-decoration:none;font-size:11px;transition:color .2s}.mobile-nav-item.active{color:var(--ski-blue)}.mobile-nav-icon{font-size:20px}.mobile-nav-label{font-size:10px}.mobile-menu-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:1001}.mobile-menu-content{background:#fff;width:280px;height:100%;box-shadow:2px 0 8px #00000026}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.mobile-menu-header h3{margin:0;font-size:18px}.mobile-menu-header button{background:none;border:none;font-size:24px;cursor:pointer;padding:var(--space-sm)}.mobile-menu-nav{display:flex;flex-direction:column;padding:var(--space-md) 0}.mobile-menu-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);color:var(--text-primary);text-decoration:none;transition:background-color .2s}.mobile-menu-item:hover,.mobile-menu-item.active{background-color:#0066cc1a;color:var(--ski-blue)}.mobile-menu-icon{font-size:20px}.mobile-menu-label{font-size:15px}.dashboard-container{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:var(--space-xl)}.dashboard-title{font-size:32px;font-weight:700;margin:0 0 var(--space-sm) 0;color:var(--ski-blue-dark)}.dashboard-subtitle{font-size:16px;color:var(--text-secondary);margin:0}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);gap:var(--space-md)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.stat-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-icon{font-size:40px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-color)}.active-rentals .stat-icon{background:#00a86b1a}.completed-today .stat-icon{background:#0066cc1a}.revenue-today .stat-icon{background:#ffd70033}.next-booking .stat-icon{background:#8080801a}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.stat-label{font-size:14px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.dashboard-section{margin-bottom:var(--space-xl)}.section-title{font-size:20px;font-weight:700;margin:0 0 var(--space-lg) 0;color:var(--ski-blue-dark)}.active-rentals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.rental-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);position:relative;transition:transform .2s,box-shadow .2s}.rental-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.rental-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.rental-cart{font-size:16px;font-weight:600;color:var(--text-primary)}.rental-time-badge{background:#00a86b1a;color:var(--status-available-text);padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.rental-body{display:flex;flex-direction:column;gap:var(--space-sm)}.rental-customer{font-size:16px;color:var(--text-primary)}.rental-details{display:flex;gap:var(--space-md);font-size:14px;color:var(--text-secondary)}.rental-time{font-size:14px;color:var(--text-secondary)}.rental-status-badge{position:absolute;top:var(--space-md);right:var(--space-md);padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.rental-status-badge.active{background:#00a86b1a;color:var(--status-available-text)}.empty-state-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);text-align:center;color:var(--text-secondary);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05)}.empty-state-card .empty-state-icon{font-size:48px;margin-bottom:var(--space-md);opacity:.5}.empty-state-card p{margin:0;font-size:16px}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-lg)}.quick-action-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-decoration:none;color:var(--text-primary);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}.quick-action-card:hover{transform:translateY(-4px);box-shadow:0 6px 12px #00000026}.action-icon{font-size:48px}.action-label{font-size:16px;font-weight:600;text-align:center}.booking-page{height:calc(100vh - 64px);overflow:hidden}.booking-page-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);height:100%;overflow:auto}.booking-left-panel,.booking-right-panel{overflow-y:auto;padding:var(--space-md)}.page-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:24px;color:var(--text-secondary)}@media(max-width:1024px){.admin-sidebar{position:fixed;left:-240px;top:64px;height:calc(100vh - 64px);z-index:999;box-shadow:2px 0 8px #00000026}.admin-sidebar.open{left:0}.admin-main{margin-left:0!important}.mobile-bottom-nav{display:flex}.admin-main{padding-bottom:80px}.booking-page-content{grid-template-columns:1fr}}@media(max-width:768px){.mobile-menu-toggle{display:block}.header-icon-btn,.user-menu{display:none}.stats-grid,.active-rentals-grid{grid-template-columns:1fr}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}.dashboard-title{font-size:24px}.admin-main{padding:var(--space-md)}}.page-container{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.page-title{font-size:32px;font-weight:700;margin:0;color:var(--ski-blue-dark)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);gap:var(--space-md)}.filter-buttons{display:flex;gap:var(--space-sm)}.filter-btn{padding:var(--space-sm) var(--space-lg);border:1px solid var(--border-color);background:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.filter-btn:hover{background:var(--bg-color)}.filter-btn.active{background:var(--ski-blue);color:#fff;border-color:var(--ski-blue)}.bookings-table-container{background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05)}.bookings-table{width:100%;border-collapse:collapse}.bookings-table thead{background:var(--bg-color);border-bottom:2px solid var(--border-color)}.bookings-table th{padding:var(--space-md);text-align:left;font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.bookings-table td{padding:var(--space-md);border-bottom:1px solid var(--border-color);font-size:14px}.bookings-table tbody tr:hover{background:var(--bg-color)}.bookings-table tbody tr.active-row{background:#00a86b0d}.time-text{font-size:13px;color:var(--text-secondary)}.cart-badge{display:inline-block;padding:4px 12px;background:var(--bg-color);border-radius:var(--radius-sm);font-size:13px;font-weight:500}.member-badge{display:inline-block;margin-left:var(--space-sm);padding:2px 8px;background:#0066cc1a;color:var(--ski-blue);border-radius:12px;font-size:11px;font-weight:600}.contact-info{font-size:13px;color:var(--text-secondary);line-height:1.6}.status-badge.active{background:#00a86b1a;color:var(--status-available-text)}.status-badge.completed{background:#0066cc1a;color:var(--ski-blue)}.status-badge.upcoming{background:#8080801a;color:var(--text-secondary)}.status-badge.cancelled,.status-badge.suspended{background:#dc35451a;color:#dc3545}.status-badge.inactive{background:#8080801a;color:var(--text-secondary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.form-group label{font-weight:600;color:var(--text-primary);font-size:14px}.form-group input,.form-group textarea,.form-group select{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--ski-blue);box-shadow:0 0 0 3px #0066cc1a}.form-actions{display:flex;gap:var(--space-md);justify-content:flex-end;padding-top:var(--space-md)}.form-card{background:linear-gradient(135deg,#0066cc05,#00a86b05);margin-bottom:var(--space-lg)}.filter-card{margin-bottom:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.search-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;width:100%;box-sizing:border-box;transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--ski-blue);box-shadow:0 0 0 3px #0066cc1a}.members-table{width:100%;border-collapse:collapse}.members-table thead{background:var(--bg-color);border-bottom:2px solid var(--border-color)}.members-table th{padding:var(--space-md);text-align:left;font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.members-table td{padding:var(--space-md);border-bottom:1px solid var(--border-color);font-size:14px}.members-table a{color:var(--ski-blue);text-decoration:none;transition:text-decoration .2s}.members-table a:hover{text-decoration:underline}.members-table tbody tr:hover{background:var(--bg-color)}.btn-small{background:none;border:1px solid var(--border-color);padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.btn-edit{color:var(--ski-blue);border-color:var(--ski-blue)}.btn-edit:hover{background:#0066cc1a}.btn-delete{color:#dc3545;border-color:#dc3545}.btn-delete:hover{background:#dc35451a}.cart-management-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}.cart-management-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.cart-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.cart-icon{font-size:40px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--bg-color);border-radius:var(--radius-md)}.cart-info h3{margin:0 0 var(--space-xs) 0;font-size:18px;color:var(--text-primary)}.cart-id{margin:0;font-size:13px;color:var(--text-secondary)}.cart-status-section{margin-bottom:var(--space-lg)}.status-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);font-size:14px;font-weight:500}.status-indicator.available{background:#00a86b1a;color:var(--status-available-text)}.status-dot{font-size:20px}.btn-primary{padding:var(--space-sm) var(--space-lg);background:var(--ski-blue);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-secondary{flex:1;padding:var(--space-sm) var(--space-md);background:#fff;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--bg-color);border-color:var(--ski-blue);color:var(--ski-blue)}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.report-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);text-align:center;transition:transform .2s,box-shadow .2s}.report-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.report-icon{font-size:48px;margin-bottom:var(--space-md)}.report-card h3{margin:0 0 var(--space-sm) 0;font-size:18px;color:var(--text-primary)}.report-card p{margin:0 0 var(--space-lg) 0;font-size:14px;color:var(--text-secondary)}.info-box{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05)}.info-box h3{margin:0 0 var(--space-md) 0;font-size:20px;color:var(--text-primary)}.info-box p{margin:0 0 var(--space-md) 0;color:var(--text-secondary)}.info-box ul{margin:0;padding-left:var(--space-lg);color:var(--text-secondary);line-height:1.8}.report-card-link{text-decoration:none;color:inherit}.report-controls{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.date-range-buttons{display:flex;gap:var(--space-sm)}.range-btn{padding:var(--space-sm) var(--space-lg);border:1px solid var(--border-color);background:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.range-btn:hover{background:var(--bg-color)}.range-btn.active{background:var(--ski-blue);color:#fff;border-color:var(--ski-blue)}.date-inputs{display:flex;align-items:center;gap:var(--space-sm)}.date-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:inherit}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.metric-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;align-items:center;text-align:center}.metric-icon{font-size:48px;margin-bottom:var(--space-md)}.metric-value{font-size:32px;font-weight:700;color:var(--ski-blue-dark);margin-bottom:var(--space-sm)}.metric-label{font-size:14px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:var(--space-lg)}.chart-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05)}.chart-title{margin:0 0 var(--space-lg) 0;font-size:18px;font-weight:600;color:var(--text-primary)}.chart-description{margin:0 0 var(--space-md) 0;font-size:14px;color:var(--text-secondary)}.legend-item{margin-left:var(--space-lg);font-size:14px;font-weight:500}.full-width{grid-column:1 / -1}.distribution-bars{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-md) 0}.distribution-item{display:flex;flex-direction:column;gap:var(--space-sm)}.distribution-label{display:flex;justify-content:space-between;align-items:center;font-size:14px}.distribution-name{font-weight:600;color:var(--text-primary)}.distribution-value{font-weight:700;color:var(--ski-blue);font-size:16px}.distribution-bar-container{width:100%;height:24px;background:var(--bg-color);border-radius:var(--radius-sm);overflow:hidden}.distribution-bar{height:100%;border-radius:var(--radius-sm);transition:width .5s ease}.distribution-count{font-size:13px;color:var(--text-secondary)}.insights-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);margin-top:var(--space-xl)}.insights-card h3{margin:0 0 var(--space-md) 0;font-size:20px;color:var(--text-primary)}.insights-card ul{margin:0;padding-left:var(--space-lg);color:var(--text-secondary);line-height:1.8}.insights-card li{margin-bottom:var(--space-md)}.insights-card strong{color:var(--text-primary)}.export-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-lg)}.page-header .export-actions{margin-bottom:0}.performance-table-container{background:#fff;padding:var(--space-lg);border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:var(--space-lg) 0}.section-title{margin:0 0 var(--space-md) 0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.performance-table{width:100%;border-collapse:collapse;margin-top:var(--space-md)}.performance-table th{background:#f8f9fa;padding:var(--space-md);text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid #DEE2E6}.performance-table td{padding:var(--space-md);border-bottom:1px solid #E9ECEF}.performance-table tbody tr:hover{background:#f8f9fa}.cart-id-text{font-size:.875rem;color:var(--text-secondary)}.utilization-cell{display:flex;align-items:center;gap:var(--space-sm)}.utilization-bar-bg{flex:1;height:20px;background:#e9ecef;border-radius:10px;overflow:hidden}.utilization-bar-fill{height:100%;border-radius:10px;transition:width .3s ease}.utilization-text{min-width:50px;font-weight:600;color:var(--text-primary)}.performance-badge{padding:4px 12px;border-radius:12px;font-size:.875rem;font-weight:500}.performance-badge.excellent{background:#d4edda;color:#155724}.performance-badge.good{background:#fff3cd;color:#856404}.performance-badge.low{background:#f8d7da;color:#721c24}.empty-state-card{text-align:center;padding:var(--space-xl);color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-md)}@media(max-width:768px){.page-container{padding:var(--space-md)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg)}.page-title{font-size:1.5rem;margin:0}.export-actions{width:100%;flex-direction:column}.export-actions button,.btn-primary,.btn-secondary{width:100%;padding:var(--space-md) var(--space-lg)}.bookings-table-container,.performance-table-container{padding:var(--space-md);margin:var(--space-md) 0;overflow-x:auto}.bookings-table,.performance-table{min-width:600px;font-size:.875rem}.performance-table th,.performance-table td{padding:var(--space-sm) var(--space-xs)}.metrics-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.metric-card{padding:var(--space-lg)}.metric-icon{font-size:32px}.metric-value{font-size:24px}.metric-label{font-size:12px}.charts-grid{grid-template-columns:1fr;gap:var(--space-md)}.legend-item{margin:0 8px;display:inline-block}.legend-item-green{color:#00a86b}.legend-item-gold{color:gold}.legend-item-red{color:#c5221f}.distribution-bar{background:#06c;width:var(--bar-width, 0%)}.distribution-bar-green{background:#00a86b}.progress-track{width:100px;height:8px;background-color:#e0e0e0;border-radius:4px;overflow:hidden}.progress-bar{height:100%;background-color:#00a86b;transition:width .3s;width:var(--progress-width, 0%)}.progress-container{display:flex;align-items:center;gap:8px}.error-details{margin-top:8px;font-size:12px}.error-details summary{cursor:pointer}.error-details pre{overflow:auto;font-size:11px}.modal-cancel-reason{color:#666;margin-bottom:20px}.modal-textarea{width:100%;min-height:80px;padding:10px;border-radius:4px;border:1px solid #ddd;font-family:inherit;font-size:14px;resize:vertical}.modal-button-container{margin-top:20px;display:flex;gap:10px;justify-content:flex-end}.modal-button-cancel{padding:8px 16px;background:#f0f0f0;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:14px}.modal-button-cancel:hover{background:#e0e0e0}.stat-dash{color:#999}.stat-average{color:#999;font-size:.9em;margin-left:5px}.player-stats-header{margin-top:30px}.player-stats-table{margin-top:15px}.cart-utilization-small{font-size:11px}.skeleton-inline{display:inline-block}.skeleton-40x28{width:40px;height:28px}.skeleton-60x28{width:60px;height:28px}.skeleton-50x28{width:50px;height:28px}.availability-tooltip{position:fixed;z-index:1000;left:calc(attr(data-x,0)*1px);top:calc(attr(data-y,0)*1px - 10px)}.utilization-bar-fill{width:var(--progress-width, 0%);height:100%;transition:width .3s}.utilization-bar-fill-high{background-color:#00a86b}.utilization-bar-fill-medium{background-color:gold}.utilization-bar-fill-low{background-color:#c5221f}.btn-primary-danger{background-color:#d32f2f}.btn-primary-danger:hover{background-color:#b71c1c}.skeleton-loader-dynamic{display:inline-block;width:attr(data-width,100%);height:attr(data-height,40px);border-radius:attr(data-radius,4px)}.progress-bar-dynamic{display:inline-block}.alert-close{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:0;color:inherit;opacity:.7}.alert-close:hover{opacity:1}.chart-card{padding:var(--space-md)}.chart-title{font-size:16px;margin:0 0 var(--space-md) 0}.full-width{grid-column:1}.report-controls{flex-direction:column;gap:var(--space-md)}.date-range-buttons{flex-direction:column;gap:var(--space-sm)}.range-btn{padding:var(--space-md);font-size:.875rem;width:100%}.date-inputs{flex-direction:column}.date-input-group{width:100%}.date-input-group label{display:block;margin-bottom:var(--space-xs)}.date-input-group input{width:100%}.distribution-bars{gap:var(--space-md)}.distribution-label,.utilization-cell{flex-direction:column;gap:var(--space-xs)}.utilization-bar-bg{height:16px}.utilization-text{min-width:auto}.report-card{padding:var(--space-lg)}.insights-card{padding:var(--space-lg);margin-top:var(--space-lg)}.insights-card h3{font-size:18px}.insights-card ul{padding-left:var(--space-md)}.insights-card li{padding:var(--space-sm);font-size:.875rem;margin-bottom:var(--space-sm)}.bookings-table{min-width:600px}.filter-buttons{flex-wrap:wrap;gap:var(--space-sm)}.filter-buttons button{flex:1;min-width:80px;padding:var(--space-sm) var(--space-md);font-size:.875rem}.performance-badge{padding:2px 8px;font-size:.75rem}.cart-id-text{font-size:.75rem}.loading-container{padding:var(--space-xl)}.loading-spinner{font-size:3rem}.admin-bottom-nav{display:flex}.admin-bottom-nav-item{flex:1;padding:var(--space-sm);font-size:.75rem}.admin-bottom-nav-icon{font-size:1.5rem;margin-bottom:4px}.admin-sidebar{transform:translate(-100%);transition:transform .3s ease;position:fixed;left:0;top:0;height:100vh;z-index:999}.admin-sidebar.open{transform:translate(0)}.admin-main{width:100%;margin-left:0}}@media(max-width:480px){.page-container{padding:var(--space-sm)}.page-title{font-size:1.25rem}.metrics-grid{grid-template-columns:1fr}.metric-icon{font-size:24px}.metric-value{font-size:20px}.report-card{padding:var(--space-md)}.report-icon{font-size:2.5rem}.btn-primary,.btn-secondary{padding:var(--space-md);font-size:.875rem}.chart-card{padding:var(--space-sm)}.performance-table{min-width:500px;font-size:.75rem}.performance-table th,.performance-table td{padding:var(--space-xs) 4px}.insights-card li{padding:var(--space-xs);font-size:.8125rem}.distribution-item{gap:var(--space-xs)}.utilization-bar-bg{height:14px}}@media(min-width:1200px){.charts-grid{grid-template-columns:repeat(2,1fr)}.full-width{grid-column:1 / -1}.metrics-grid{grid-template-columns:repeat(4,1fr)}.page-header{flex-direction:row;justify-content:space-between;align-items:center}.export-actions{margin-bottom:0}}@media(max-height:600px)and (orientation:landscape){.admin-header{padding:var(--space-sm) var(--space-md)}.admin-logo{font-size:.875rem}.mobile-bottom-nav{padding:var(--space-xs) 0}.mobile-nav-item{padding:var(--space-sm) var(--space-xs)}.page-container{padding:var(--space-sm)}.metrics-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.metric-card{padding:var(--space-md)}.metric-value{font-size:18px}.charts-grid{grid-template-columns:1fr;gap:var(--space-sm)}.chart-card{padding:var(--space-sm)}}@keyframes skeleton-pulse{0%{opacity:.6;background-position:-1000px 0}50%{opacity:1}to{opacity:.6;background-position:1000px 0}}.skeleton-loader{display:inline-block;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-pulse 2s infinite;margin:var(--space-xs) 0}.skeleton-card{opacity:.7;pointer-events:none}.skeleton-table{width:100%}.skeleton-table-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--border-color)}.skeleton-chart{width:100%}.skeleton-chart-title{margin-bottom:var(--space-md)}.skeleton-chart-content{width:100%}.empty-state-card,.error-state-card{text-align:center;padding:var(--space-xl);background:var(--card-bg);border-radius:var(--radius-md);border:1px solid var(--border-color)}.empty-state-icon,.error-state-icon{font-size:48px;margin-bottom:var(--space-md)}.empty-state-card h3,.error-state-card h3{margin:var(--space-md) 0 var(--space-sm);color:var(--text-primary)}.empty-state-card p,.error-state-card p{color:var(--text-secondary);margin:0}.error-state-card{background:#ff00000d;border-color:#ffb3b3}.error-state-card h3{color:#c5221f}@supports (padding: max(0px)){.admin-header{padding-left:max(var(--space-lg),env(safe-area-inset-left));padding-right:max(var(--space-lg),env(safe-area-inset-right));padding-top:max(var(--space-md),env(safe-area-inset-top))}.mobile-bottom-nav{padding-bottom:max(var(--space-lg),env(safe-area-inset-bottom))}.page-container{padding-left:max(var(--space-md),env(safe-area-inset-left));padding-right:max(var(--space-md),env(safe-area-inset-right))}}@media print{.admin-header,.admin-sidebar,.mobile-bottom-nav,.export-actions,.page-header .export-actions{display:none}.admin-main{width:100%;margin-left:0}.page-container{padding:0;background:#fff}.metric-card,.chart-card,.insights-card{page-break-inside:avoid;box-shadow:none;border:1px solid #ddd}.performance-table,.bookings-table,table tr{page-break-inside:avoid}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:24px;max-width:500px;width:90%;box-shadow:0 4px 20px #00000026}.modal-content h2{margin:0 0 8px;color:var(--text-primary);font-size:20px}.btn-cancel-rental{background-color:#ff9800;color:#fff;border:none;padding:8px 12px;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s}.btn-cancel-rental:hover{background-color:#f57c00}.status-badge.cancelled{background-color:#ffebee;color:#c62828;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.btn-secondary{background-color:#e0e0e0;color:#333;border:none;padding:10px 16px;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#d0d0d0}.error-stack{overflow:auto;font-size:11px}.details-expandable{margin-top:8px;font-size:12px}.modal-text-secondary{color:#666;margin-bottom:20px}.modal-button-group{margin-top:20px;display:flex;gap:10px;justify-content:flex-end}.modal-button-close{background-color:#f5f5f5;color:#333;border:1px solid #ddd;padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s}.modal-button-close:hover{background-color:#eee}.booking-row-cancelled{opacity:.6}.skeleton-small{width:40px;height:28px;display:inline-block}.skeleton-large{width:60px;height:28px;display:inline-block}.skeleton-medium{width:50px;height:28px;display:inline-block}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--ski-blue) 0%,var(--ski-blue-dark) 100%);padding:var(--space-md)}.login-container{width:100%;max-width:400px;animation:slideUpFade .4s ease-out}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:0 10px 40px #0003}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{font-size:48px;margin-bottom:var(--space-md)}.login-title{font-size:28px;font-weight:700;color:var(--ski-blue-dark);margin:0 0 var(--space-xs) 0}.login-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-field{display:flex;flex-direction:column;gap:var(--space-sm)}.form-field label{font-weight:600;font-size:14px;color:var(--text-primary);letter-spacing:.3px}.form-field input{padding:var(--space-md) var(--space-lg);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;font-family:inherit;transition:all .2s ease;background:#fff}.form-field input:focus{outline:none;border-color:var(--ski-blue);box-shadow:0 0 0 3px #0066cc1a}.form-field input::placeholder{color:var(--text-secondary)}.login-error{background:#fce8e6;color:#c5221f;padding:var(--space-md);border-radius:var(--radius-md);border-left:4px solid #EA4335;font-size:14px;display:flex;gap:var(--space-sm);align-items:flex-start}.login-error-icon{font-size:18px;flex-shrink:0;margin-top:2px}.login-error-message{flex:1;line-height:1.5}.login-button{padding:var(--space-lg) var(--space-xl);background:linear-gradient(135deg,var(--ski-blue),var(--ski-blue-dark));color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:56px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #0066cc4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-button.loading{color:transparent;position:relative}.login-button.loading:after{content:"";position:absolute;width:18px;height:18px;top:50%;left:50%;margin-left:-9px;margin-top:-9px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border-color);text-align:center}.login-footer-text{font-size:14px;color:var(--text-secondary);margin:0}.login-footer-link{color:var(--ski-blue);text-decoration:none;font-weight:600;transition:text-decoration .2s}.login-footer-link:hover{text-decoration:underline}.login-features{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border-color)}.login-features-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-md) 0}.login-features-list{display:flex;flex-direction:column;gap:var(--space-sm);margin:0;padding:0;list-style:none}.login-features-item{display:flex;align-items:center;gap:var(--space-sm);font-size:13px;color:var(--text-secondary)}.login-features-icon{font-size:16px;color:var(--ski-green)}.login-skeleton{display:flex;flex-direction:column;gap:var(--space-lg)}.skeleton-input{height:48px;background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:skeleton-pulse 1.5s infinite;border-radius:var(--radius-md)}.skeleton-button{height:56px;background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:skeleton-pulse 1.5s infinite;border-radius:var(--radius-md)}@media(max-width:480px){.login-page{min-height:100vh;padding:var(--space-sm)}.login-container{max-width:100%}.login-card{padding:var(--space-lg);border-radius:var(--radius-md)}.login-header{margin-bottom:var(--space-lg)}.login-title{font-size:24px}.login-form{gap:var(--space-md)}.login-button{padding:var(--space-md) var(--space-lg);font-size:15px;min-height:48px}.login-footer,.login-features{margin-top:var(--space-lg)}.login-features-item{font-size:12px}}.booking-portal{min-height:100vh;background:var(--bg-color);padding:var(--space-lg)}.page-container{max-width:1200px;margin:0 auto}.page-header{margin-bottom:var(--space-xl);display:flex;justify-content:space-between;align-items:center}.page-subtitle{font-size:16px;color:var(--text-secondary);margin:0}.carts-browse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.cart-browse-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:2px solid var(--border-color);transition:all .2s ease;display:flex;flex-direction:column;gap:var(--space-md)}.cart-browse-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:var(--ski-blue)}.cart-browse-header{display:flex;justify-content:space-between;align-items:center}.cart-browse-header h3{margin:0;font-size:20px;color:var(--text-primary)}.cart-browse-info{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-color);border-radius:var(--radius-sm)}.cart-browse-info p{margin:0;font-size:14px;color:var(--text-secondary)}.booking-form-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color);max-width:600px;margin:0 auto}.form-section{margin-bottom:var(--space-xl);padding:var(--space-lg);background:var(--bg-color);border-radius:var(--radius-md)}.form-section h3{margin:0 0 var(--space-md) 0;font-size:16px;color:var(--text-primary)}.booking-summary{display:flex;flex-direction:column;gap:var(--space-sm)}.booking-summary p{margin:0;font-size:14px;color:var(--text-secondary)}.booking-summary strong{color:var(--text-primary)}.review-cards-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);max-width:1000px;margin:0 auto}.review-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color)}.review-card h3{margin:0 0 var(--space-md) 0;font-size:18px;color:var(--text-primary)}.review-content{display:flex;flex-direction:column;gap:var(--space-md)}.review-row{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color);font-size:14px}.review-row:last-child{border-bottom:none}.review-label{color:var(--text-secondary);font-weight:500}.review-value{color:var(--text-primary);font-weight:600}.payment-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color);max-width:600px;margin:0 auto}.payment-methods{margin-bottom:var(--space-xl)}.payment-methods h3{margin:0 0 var(--space-lg) 0;font-size:18px;color:var(--text-primary)}.payment-option{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);margin-bottom:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.payment-option:hover{border-color:var(--ski-blue);background:#0066cc0d}.payment-option input[type=radio]{width:20px;height:20px;cursor:pointer}.payment-option input[type=radio]:checked+.payment-label{color:var(--ski-blue);font-weight:600}.payment-label{font-size:16px;color:var(--text-primary);flex:1}.payment-form{padding:var(--space-lg);background:var(--bg-color);border-radius:var(--radius-md);margin-top:var(--space-lg)}.payment-form h4{margin:0 0 var(--space-md) 0;color:var(--text-primary)}.booking-step-indicator{display:flex;justify-content:space-between;margin-bottom:var(--space-xl);padding:var(--space-lg);background:#fff;border-radius:var(--radius-md)}.step-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);flex:1;position:relative}.step-number{width:40px;height:40px;border-radius:50%;background:var(--bg-color);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text-secondary)}.step-item.active .step-number{background:var(--ski-blue);color:#fff;border-color:var(--ski-blue)}.step-item.completed .step-number{background:var(--ski-green);color:#fff;border-color:var(--ski-green)}.step-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-align:center}.step-item.active .step-label,.step-item.completed .step-label{color:var(--text-primary)}.member-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-group label{font-weight:600;font-size:14px;color:var(--text-primary)}.form-group input,.form-group select{padding:var(--space-md) var(--space-lg);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--ski-blue);box-shadow:0 0 0 3px #0066cc1a}.form-actions{display:flex;gap:var(--space-md);justify-content:flex-end;padding-top:var(--space-lg);border-top:1px solid var(--border-color)}.form-actions .btn{flex:1;max-width:200px}.btn{padding:var(--space-lg) var(--space-xl);border-radius:var(--radius-md);border:none;font-weight:700;font-size:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:56px}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--ski-blue),var(--ski-blue-dark));color:#fff}.btn-primary:hover{box-shadow:0 8px 16px #0066cc4d}.btn-secondary{background:#fff;border:2px solid var(--ski-blue);color:var(--ski-blue)}.btn-secondary:hover{background:#0066cc0d}.btn-text{background:none;border:none;color:var(--ski-blue);font-weight:600;cursor:pointer;padding:var(--space-sm);font-size:14px}.btn-text:hover{text-decoration:underline}.success-state{text-align:center;padding:var(--space-xl);max-width:600px;margin:0 auto}.success-icon{font-size:80px;margin-bottom:var(--space-lg);animation:bounce .8s ease}.success-title{font-size:32px;font-weight:700;color:var(--ski-green);margin:0 0 var(--space-lg) 0}.success-details{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color)}.success-item{display:flex;justify-content:space-between;padding:var(--space-md) 0;border-bottom:1px solid var(--border-color);font-size:14px}.success-item:last-child{border-bottom:none}.success-label{color:var(--text-secondary);font-weight:500}.success-value{color:var(--text-primary);font-weight:600}.success-confirmation{background:#00a86b1a;border:2px solid var(--ski-green);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-xl)}.confirmation-icon{font-size:48px;margin-bottom:var(--space-sm)}.success-confirmation p{margin:0;color:var(--text-primary);font-size:14px}.success-confirmation strong{color:var(--ski-blue)}.empty-state-card{text-align:center;padding:var(--space-xl);background:#fff;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color)}.empty-state-icon{font-size:64px;margin-bottom:var(--space-md);opacity:.6}.empty-state-card h3{margin:0 0 var(--space-sm) 0;color:var(--text-primary)}.empty-state-card p{margin:0;color:var(--text-secondary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);gap:var(--space-md);background:#fff;border-radius:var(--radius-md);min-height:300px}.loading-spinner{font-size:48px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-container{background:#fff;border-radius:var(--radius-lg);max-width:600px;width:95%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #00000026;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--ski-blue) 0%,var(--ski-blue-dark) 100%);color:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-header h2{margin:0;font-size:20px;font-weight:600}.modal-close{background:transparent;border:none;font-size:28px;cursor:pointer;color:#fff;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease}.modal-close:hover:not(:disabled){background:#fff3}.modal-close:disabled{cursor:not-allowed;opacity:.6}.modal-body{padding:24px;display:flex;flex-direction:column;gap:20px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px 24px;border-top:1px solid var(--border-color);background:var(--bg-color);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-footer .btn{padding:10px 20px;border-radius:var(--radius-sm);border:none;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.modal-footer .btn:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333;box-shadow:0 4px 12px #dc35454d}.btn-secondary{background:var(--border-color);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#d0d0d0}.cancellation-modal .modal-body{gap:16px}.booking-summary-box{background:#f8f9fa;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px}.booking-summary-box h3{margin:0 0 12px;font-size:16px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color);font-size:14px}.detail-row:last-child{border-bottom:none}.detail-row span{color:var(--text-secondary)}.detail-row strong{color:var(--text-primary);font-weight:600}.refund-info-box{background:linear-gradient(135deg,#e6f4ea,#f1f8e9);border:1px solid #C8E6C9;border-radius:var(--radius-md);padding:16px}.refund-info-box h3{margin:0 0 12px;font-size:16px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.refund-window-info{text-align:center;margin-bottom:12px}.refund-window-label{font-size:14px;color:var(--text-secondary);margin:0}.refund-amount{font-size:28px;font-weight:700;color:#00a86b;margin:8px 0;font-family:Monaco,Courier New,monospace}.refund-percentage{font-size:14px;color:var(--text-secondary);margin:0}.refund-note{font-size:13px;color:var(--text-secondary);margin:12px 0 0;padding:8px;background:#00a86b0d;border-radius:4px}.cancellation-reason-section{display:flex;flex-direction:column;gap:12px}.cancellation-reason-section label{font-weight:600;font-size:14px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.reason-buttons{display:flex;flex-direction:column;gap:8px}.reason-btn{padding:10px 12px;border:1px solid var(--border-color);background:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:all .2s ease;text-align:left;color:var(--text-primary);font-weight:500}.reason-btn:hover:not(:disabled){border-color:var(--ski-blue);background:#f0f7ff}.reason-btn.active{border-color:var(--ski-blue);background:var(--ski-blue);color:#fff}.reason-btn:disabled{opacity:.6;cursor:not-allowed}.custom-reason-textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;resize:vertical;min-height:80px;transition:border-color .2s ease}.custom-reason-textarea:focus{outline:none;border-color:var(--ski-blue);box-shadow:0 0 0 3px #0066cc1a}.custom-reason-textarea:disabled{background:#f5f5f5;cursor:not-allowed}.alert{padding:12px;border-radius:var(--radius-sm);font-size:14px;display:flex;gap:12px;align-items:flex-start}.alert p{margin:0}.alert-error{background:#fce8e6;border:1px solid #F8BBB2;color:#c5221f}.alert-warning{background:#fef7e0;border:1px solid #FED8B1;color:#9f6000}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 20px}.spinner{width:40px;height:40px;border:4px solid rgba(0,102,204,.2);border-top-color:var(--ski-blue);border-radius:50%;animation:spin 1s linear infinite}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.booking-portal{padding:var(--space-md)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.carts-browse-grid,.review-cards-container{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{max-width:100%}.booking-step-indicator{flex-direction:column;gap:var(--space-md)}.step-item{padding:var(--space-md) 0}.modal-container{width:90%;max-height:85vh}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%;min-width:unset}}.settings-page-container{display:flex;flex:1;background-color:var(--light-bg, #f8f9fa);overflow:hidden}.settings-page-header{padding:var(--space-lg);background:linear-gradient(135deg,var(--ski-blue, #0066cc) 0%,var(--ski-green, #00b050) 100%);color:#fff;margin-bottom:var(--space-lg);border-radius:8px}.settings-page-header h1{font-size:1.75rem;margin:0 0 var(--space-xs) 0;font-weight:600}.settings-page-header p{margin:0;opacity:.95;font-size:.95rem}.settings-page-content{display:flex;width:100%;gap:var(--space-lg);padding:var(--space-lg);overflow:hidden}.settings-sidenav{width:220px;background-color:#fff;border-radius:8px;padding:var(--space-md);box-shadow:0 1px 3px #0000001a;overflow-y:auto;flex-shrink:0}.settings-nav-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-xs)}.settings-nav-item{margin:0;padding:0}.settings-nav-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-md);color:var(--text-secondary, #666);background-color:transparent;border:none;border-left:3px solid transparent;border-radius:4px;cursor:pointer;font-size:.95rem;transition:all .2s ease;width:100%;text-align:left}.settings-nav-link:hover{background-color:var(--light-bg, #f8f9fa);color:var(--text-primary, #333)}.settings-nav-link.active{background-color:var(--ski-blue-light, #e6f0ff);color:var(--ski-blue, #0066cc);border-left-color:var(--ski-blue, #0066cc);font-weight:600}.settings-nav-link span:first-child{font-size:1.2rem}.settings-nav-footer{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-color, #e0e0e0);font-size:.85rem;color:var(--text-secondary, #999);line-height:1.4}.settings-main-area{flex:1;background-color:#fff;border-radius:8px;padding:var(--space-lg);box-shadow:0 1px 3px #0000001a;overflow-y:auto}.settings-form-container{max-width:700px}.settings-form-header{margin-bottom:var(--space-lg);border-bottom:2px solid var(--ski-blue, #0066cc);padding-bottom:var(--space-md)}.settings-form-header h2{margin:0 0 var(--space-xs) 0;font-size:1.5rem;color:var(--text-primary, #333)}.settings-form-header p{margin:0;color:var(--text-secondary, #666);font-size:.9rem}.settings-alert{padding:var(--space-md);border-radius:6px;margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-alert.error{background-color:#fee;color:#c33;border-left:4px solid #c33}.settings-alert.success{background-color:#efe;color:#3a3;border-left:4px solid #3a3}.settings-alert.error:before{content:"❌";font-size:1.1rem}.settings-alert.success:before{content:"✅";font-size:1.1rem}.settings-group{margin-bottom:var(--space-lg)}.settings-group label{display:block;margin-bottom:var(--space-sm);font-weight:600;color:var(--text-primary, #333);font-size:.95rem}.settings-group input[type=text],.settings-group input[type=email],.settings-group input[type=number],.settings-group input[type=password],.settings-group select,.settings-group textarea{width:100%;padding:var(--space-md);border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.95rem;font-family:inherit;transition:all .2s ease}.settings-group input:focus,.settings-group select:focus,.settings-group textarea:focus{outline:none;border-color:var(--ski-blue, #0066cc);box-shadow:0 0 0 3px #0066cc1a}.settings-group textarea{resize:vertical;min-height:120px}.settings-group-description{margin-top:var(--space-xs);font-size:.85rem;color:var(--text-secondary, #999)}.selector-group{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.selector-label{font-weight:600;color:var(--text-primary, #333);font-size:.95rem}.selector-buttons{display:flex;gap:var(--space-sm);flex-wrap:wrap}.selector-btn{padding:var(--space-md) var(--space-lg);border:2px solid var(--border-color, #ddd);background-color:#fff;color:var(--text-primary, #333);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;flex:1;min-width:100px}.selector-btn:hover{border-color:var(--ski-blue, #0066cc);background-color:var(--ski-blue-light, #f0f6ff)}.selector-btn.active{background-color:var(--ski-blue, #0066cc);color:#fff;border-color:var(--ski-blue, #0066cc)}.color-input-wrapper{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.color-picker{width:60px;height:50px;border:2px solid var(--border-color, #ddd);border-radius:6px;cursor:pointer;transition:all .2s ease}.color-picker:hover{box-shadow:0 2px 8px #00000026;border-color:var(--ski-blue, #0066cc)}.color-display{display:flex;flex-direction:column;gap:var(--space-xs)}.color-hex{font-family:monospace;font-size:.9rem;padding:var(--space-sm) var(--space-md);background-color:var(--light-bg, #f8f9fa);border:1px solid var(--border-color, #ddd);border-radius:4px;width:120px;text-align:center}.settings-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg);color:var(--text-secondary, #666)}.settings-loading:before{content:"";width:20px;height:20px;border:2px solid var(--border-color, #ddd);border-top-color:var(--ski-blue, #0066cc);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.settings-disabled{opacity:.6;pointer-events:none}.settings-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-color, #ddd)}.settings-btn-save{padding:var(--space-md) var(--space-lg);background-color:var(--ski-blue, #0066cc);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:120px}.settings-btn-save:hover{background-color:#0052a3;box-shadow:0 2px 8px #06c3}.settings-btn-save:disabled{background-color:var(--border-color, #ccc);cursor:not-allowed;box-shadow:none}.settings-btn-reset{padding:var(--space-md) var(--space-lg);background-color:transparent;color:var(--text-secondary, #666);border:2px solid var(--border-color, #ddd);border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.settings-btn-reset:hover{border-color:var(--text-secondary, #666);color:var(--text-primary, #333)}.settings-footer{margin-top:var(--space-lg);padding:var(--space-md);background-color:var(--light-bg, #f8f9fa);border-radius:6px;border-left:4px solid var(--ski-green, #00b050)}.settings-hint{margin:0;font-size:.9rem;color:var(--text-secondary, #666);line-height:1.5}.settings-hint strong{color:var(--text-primary, #333)}@media(max-width:1024px){.settings-page-content{gap:var(--space-md)}.settings-sidenav{width:180px}.settings-nav-link{padding:var(--space-md)}.settings-form-container{max-width:100%}}@media(max-width:768px){.settings-page-container{flex-direction:column;height:auto}.settings-page-header{margin-bottom:var(--space-md)}.settings-page-header h1{font-size:1.5rem}.settings-page-content{flex-direction:column;padding:var(--space-md);gap:var(--space-md)}.settings-sidenav{width:100%;max-width:none}.settings-nav-list{flex-direction:row;gap:0}.settings-nav-link{flex:1;padding:var(--space-sm);border-left:none;border-bottom:3px solid transparent;border-radius:0;text-align:center;font-size:.8rem}.settings-nav-link.active{border-left:none;border-bottom-color:var(--ski-blue, #0066cc)}.settings-main-area{padding:var(--space-md);border-radius:0}.selector-buttons{flex-direction:column}.selector-btn{width:100%}.color-input-wrapper{flex-direction:column}.color-picker{width:100px;height:60px}.settings-actions{flex-direction:column}.settings-btn-save,.settings-btn-reset{width:100%}}.calendar-page{display:flex;flex-direction:column;height:100%}.calendar-container{display:grid;grid-template-columns:1fr 350px;gap:var(--space-lg);flex:1;overflow:hidden}.calendar-main{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;overflow-y:auto}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.calendar-header h2{margin:0;font-size:20px;color:var(--text-primary);flex:1;text-align:center;text-transform:capitalize}.nav-btn{background:var(--ski-blue);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;font-size:16px;font-weight:600;transition:background-color .2s}.nav-btn:hover{background:var(--ski-blue-dark)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.weekday-header{padding:var(--space-md);font-weight:600;text-align:center;color:var(--text-secondary);font-size:12px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;padding:var(--space-sm);position:relative}.calendar-day:hover:not(.empty){border-color:var(--ski-blue);background:#f0f7ff}.calendar-day.today{border:2px solid var(--ski-blue);font-weight:600}.calendar-day.has-bookings{background:#fff8e1}.day-number{font-weight:600;margin-bottom:2px}.day-bookings{display:flex;flex-direction:column;gap:2px;font-size:10px;width:100%}.booking-dot{padding:2px 4px;border-radius:3px;color:#fff;font-weight:600;font-size:9px}.booking-dot.status-active{background:#00b050}.booking-dot.status-pending{background:#ff9800}.more-bookings{font-size:9px;color:var(--text-secondary);text-align:center}.calendar-sidebar{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;overflow-y:auto}.calendar-sidebar h3{margin:0 0 var(--space-md) 0;color:var(--text-primary)}.bookings-list{display:flex;flex-direction:column;gap:var(--space-md)}.booking-card{padding:var(--space-md);background:var(--bg-color);border-radius:var(--radius-sm);border-left:4px solid var(--ski-blue)}.booking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.booking-header h4{margin:0;font-size:14px;color:var(--text-primary)}.booking-details{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary)}.booking-details p{margin:0}@media(max-width:1024px){.calendar-container{grid-template-columns:1fr}.calendar-sidebar{max-height:300px}}.cart-inventory-page{display:flex;flex-direction:column;gap:var(--space-lg)}.carts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.cart-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:var(--space-md)}.cart-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.cart-header{display:flex;justify-content:space-between;align-items:center}.cart-header h3{margin:0;font-size:18px;color:var(--text-primary)}.cart-info{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-secondary)}.cart-info p{margin:0}.cart-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);padding:var(--space-md);background:var(--bg-color);border-radius:var(--radius-sm)}.metric{display:flex;flex-direction:column;gap:4px}.metric label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.metric p{margin:0;font-size:14px;color:var(--text-primary);font-weight:600}.progress-bar{width:100%;height:20px;background:#e0e0e0;border-radius:10px;overflow:hidden;margin:4px 0}.progress-fill{height:100%;border-radius:10px;transition:width .3s}.cart-actions{display:flex;gap:var(--space-sm)}.activity-logging-page{display:flex;flex-direction:column;gap:var(--space-lg)}.activity-timeline{display:flex;flex-direction:column;gap:var(--space-md)}.activity-item{display:grid;grid-template-columns:80px 60px 1fr;gap:var(--space-md);padding:var(--space-md);background:#fff;border-radius:var(--radius-md);border-left:4px solid var(--ski-blue);box-shadow:0 1px 3px #0000000d}.activity-time{font-size:12px;font-weight:600;color:var(--text-secondary);text-align:right}.activity-icon{display:flex;justify-content:center}.icon-badge{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-color);border-radius:50%;font-size:24px}.activity-content{display:flex;flex-direction:column;gap:var(--space-sm)}.activity-header{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.activity-header h4{margin:0;display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;font-size:14px}.user-name{font-weight:600;color:var(--text-primary)}.action-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;color:#fff;font-weight:600}.target-name{color:var(--text-secondary);font-weight:400}.activity-changes{display:flex;flex-direction:column;gap:4px;padding:var(--space-sm);background:var(--bg-color);border-radius:var(--radius-sm);font-size:12px}.change-item{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.old-value,.new-value{font-family:monospace;padding:2px 6px;background:#fff;border-radius:3px;font-size:11px}.old-value{color:#d32f2f}.new-value{color:#388e3c}.arrow{color:var(--text-secondary);font-weight:600}.activity-meta{display:flex;gap:var(--space-md);font-size:11px;color:var(--text-secondary)}.activity-date{font-style:italic}.page-controls{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:250px}.search-box input{width:100%;padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:inherit}.search-box input:focus{outline:none;border-color:var(--ski-blue);box-shadow:0 0 0 3px #0066cc1a}.filter-controls{display:flex;gap:var(--space-sm)}.filter-controls select,.filter-controls input{padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:inherit}.filter-controls select:focus,.filter-controls input:focus{outline:none;border-color:var(--ski-blue)}.card{background:#fff;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05);overflow:hidden}.card-header{padding:var(--space-lg);border-bottom:1px solid var(--border-color);background:var(--bg-color)}.card-header h3{margin:0;font-size:16px;color:var(--text-primary)}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-color);border-bottom:2px solid var(--border-color)}.data-table th{padding:var(--space-md);text-align:left;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:var(--space-md);border-bottom:1px solid var(--border-color);font-size:14px}.data-table tbody tr:hover{background:var(--bg-color)}.empty-state{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.empty-state p{margin:0}.tier-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;color:#fff}.action-buttons{display:flex;gap:var(--space-sm)}.btn{padding:var(--space-md) var(--space-lg);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--ski-blue);color:#fff}.btn-primary:hover{background:var(--ski-blue-dark)}.btn-sm{padding:var(--space-sm) var(--space-md);font-size:12px;min-height:auto}.btn-ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-ghost:hover{background:var(--bg-color);border-color:var(--text-primary)}.page-header{margin-bottom:var(--space-lg)}.page-header h1{margin:0 0 var(--space-sm) 0;font-size:28px;color:var(--text-primary);font-weight:700}.page-header p{margin:0;color:var(--text-secondary)}.stat-card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:0 2px 4px #0000000d;border:1px solid rgba(0,0,0,.05)}.stat-number{font-size:32px;font-weight:700;color:var(--ski-blue);margin-bottom:var(--space-sm)}.stat-label{font-size:13px;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.status-active{background:#e6f4ea;color:#1e8e3e}.status-badge.status-completed{background:#e3f2fd;color:#1976d2}.status-badge.status-pending{background:#fff3e0;color:#e65100}.status-badge.status-cancelled,.status-badge.status-failed{background:#ffebee;color:#c62828}.status-badge.status-success{background:#e6f4ea;color:#1e8e3e}.status-badge.status-inactive{background:#f5f5f5;color:#666}.status-badge.status-suspended{background:#ffebee;color:#c62828}@media(max-width:768px){.calendar-container,.carts-grid{grid-template-columns:1fr}.activity-item{grid-template-columns:1fr;gap:var(--space-sm)}.page-controls{flex-direction:column}.search-box{min-width:auto}.filter-controls{flex-direction:column;width:100%}.filter-controls select,.filter-controls input{width:100%}.cart-metrics{grid-template-columns:repeat(4,1fr)}.data-table{min-width:600px}.data-table th,.data-table td{padding:var(--space-sm);font-size:12px}.action-buttons{flex-direction:column}.btn-sm{width:100%}}
