.header{color:#fff;box-shadow:var(--shadow-md);z-index:100;background:linear-gradient(135deg,#0891b2 0%,#0e7490 100%);position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;gap:2rem;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex}.header-brand h1{color:#fff;margin:0;font-size:1.75rem;font-weight:700}.header-subtitle{color:#ffffffe6;margin:.25rem 0 0;font-size:.875rem}.header-nav{gap:1rem;display:flex}.nav-link{color:#fff;border-radius:var(--border-radius);font-family:inherit;font-weight:500;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:.625rem 1.25rem;text-decoration:none;transition:background-color .2s,transform .2s}.nav-link:hover{background-color:#ffffff26;text-decoration:none;transform:translateY(-1px)}.nav-link.active{background-color:#ffffff40}.admin-link{background-color:#ffffff1a;border:1px solid #ffffff4d!important}.admin-link:hover{background-color:#fff3;border-color:#ffffff80!important}.btn-logout{background-color:#ef444433;border:1px solid #ef444466!important}.btn-logout:hover{background-color:#ef44444d;border-color:#ef444499!important}@media (width<=768px){.header-container{flex-direction:column;align-items:flex-start;padding:1rem}.header-nav{flex-wrap:wrap;justify-content:flex-start;width:100%}.nav-link{padding:.5rem 1rem;font-size:.875rem}}.app-footer{background-color:var(--bg-secondary,#f8f9fa);border-top:1px solid var(--border-color,#e9ecef);text-align:center;color:var(--text-secondary,#6c757d);margin-top:auto;padding:1.5rem 2rem;font-size:.875rem}.footer-content{max-width:1200px;margin:0 auto}.footer-version{color:var(--text-tertiary,#adb5bd);font-family:Courier New,monospace;font-size:.75rem}.footer-version:hover{color:var(--primary-color,#0d6efd);cursor:help}.auto-fill-notice{color:#1e40af;border-radius:var(--border-radius);background-color:#dbeafe;border-left:4px solid #3b82f6;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.875rem 1rem;font-size:.9375rem;display:flex}.booking-form-overlay{z-index:1000;background-color:#0009;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.booking-form-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.3s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.booking-form-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);z-index:10;justify-content:space-between;align-items:center;padding:1.5rem;display:flex;position:sticky;top:0}.booking-form-header h2{margin:0;font-size:1.5rem}.btn-close{width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;border-radius:var(--border-radius-sm);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.5rem;transition:background-color .2s,color .2s;display:flex}.btn-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.booking-form{padding:1.5rem}.form-section{margin-bottom:2rem}.form-section h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.125rem}.form-group label{color:var(--text-primary);margin-bottom:.5rem;font-weight:500;display:block}.form-group input,.form-group textarea{border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-group input.error,.form-group textarea.error{border-color:var(--error-color)}.form-group input.error:focus,.form-group textarea.error:focus{box-shadow:0 0 0 3px #ef44441a}.error-message{color:var(--error-color);margin-top:.375rem;font-size:.875rem;display:block}.booking-info{background-color:var(--bg-secondary);border-radius:var(--border-radius);color:var(--text-secondary);margin-top:.75rem;padding:.75rem;font-size:.875rem}.booking-summary{background-color:var(--bg-secondary);border-radius:var(--border-radius);margin-bottom:1.5rem;padding:1.25rem}.summary-row{justify-content:space-between;padding:.5rem 0;font-size:.9375rem;display:flex}.summary-row.total{border-top:2px solid var(--border-color);color:var(--primary-color);margin-top:.5rem;padding-top:.75rem;font-size:1.125rem;font-weight:600}.summary-info{color:#1e40af;border-radius:var(--border-radius);background-color:#dbeafe;border-left:3px solid #3b82f6;margin:.5rem 0;padding:.75rem;font-size:.875rem}.form-actions{justify-content:flex-end;gap:1rem;display:flex}.btn-primary,.btn-secondary{border-radius:var(--border-radius);cursor:pointer;border:none;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}.btn-primary:disabled{background-color:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border-color);background-color:#0000}.btn-secondary:hover:not(:disabled){background-color:var(--bg-tertiary)}.membership-toggle{margin-bottom:1rem}.toggle-label{cursor:pointer;background-color:var(--bg-secondary);border-radius:var(--border-radius);align-items:center;gap:.75rem;padding:1rem;transition:background-color .2s;display:flex}.toggle-label:hover{background-color:var(--bg-tertiary)}.toggle-label input[type=checkbox]{cursor:pointer;width:1.5rem;height:1.5rem}.toggle-text{font-size:1rem;font-weight:500}.pricing-tiers{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.pricing-tier-card{background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius);text-align:center;cursor:pointer;width:100%;padding:1rem;transition:all .2s;position:relative}.pricing-tier-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb26}.pricing-tier-card.selected{border-color:var(--primary-color);background-color:#2563eb1a;box-shadow:0 0 0 3px #2563eb33}.pricing-tier-card.selected:after{content:"✓";background-color:var(--primary-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.875rem;font-weight:700;display:flex;position:absolute;top:.5rem;right:.5rem}.section-description{color:var(--text-secondary);margin-bottom:1rem;font-size:.9375rem;line-height:1.5}.tier-badge{background-color:var(--success-color);color:#fff;border-radius:12px;margin:.5rem 0;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.tier-duration{color:var(--primary-color);margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.tier-prices{flex-direction:column;gap:.5rem;display:flex}.tier-price{justify-content:space-between;align-items:center;font-size:.875rem;display:flex}.price-label{color:var(--text-secondary)}.price-value{color:var(--text-primary);font-weight:600}.tier-price.member .price-value{color:var(--success-color)}.tier-price.non-member .price-value{color:var(--text-primary)}.pricing-notes{color:#856404;border-radius:var(--border-radius);background-color:#fff3cd;border:1px solid #ffc107;padding:.75rem;font-size:.875rem;line-height:1.5}.loading-price{text-align:center;color:var(--text-secondary);padding:1rem;font-style:italic}.no-price{text-align:center;color:var(--text-tertiary);padding:1rem;font-style:italic}.additional-services{flex-direction:column;gap:1rem;display:flex}.service-item{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);justify-content:space-between;align-items:center;gap:1rem;padding:1rem;transition:border-color .2s;display:flex}.service-item:hover{border-color:var(--primary-color)}.service-info{flex:1}.service-info h4{color:var(--text-primary);margin:0 0 .25rem;font-size:1rem}.service-info p{color:var(--text-secondary);margin:0 0 .5rem;font-size:.875rem}.service-price{background-color:var(--primary-color);color:#fff;border-radius:12px;margin-bottom:.25rem;padding:.25rem .75rem;font-size:.875rem;font-weight:600;display:inline-block}.service-info small{color:var(--text-tertiary);margin-top:.25rem;font-size:.8125rem;display:block}.service-quantity{align-items:center;gap:.5rem;display:flex}.service-quantity label{color:var(--text-secondary);margin:0;font-size:.875rem}.service-quantity input[type=number]{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);text-align:center;width:80px;padding:.5rem;font-size:1rem}.service-checkbox{align-items:center;display:flex}.service-checkbox label{cursor:pointer;align-items:center;gap:.5rem;margin:0;display:flex}.service-checkbox input[type=checkbox]{cursor:pointer;width:1.25rem;height:1.25rem}.service-checkbox span{color:var(--text-primary);font-weight:500}@media (width<=640px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.pricing-tiers{grid-template-columns:1fr}.service-item{flex-direction:column;align-items:flex-start}.service-quantity,.service-checkbox{justify-content:space-between;width:100%}}.loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:4rem 2rem;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{color:var(--text-secondary);margin-top:1.5rem;font-size:1rem;font-weight:500}.error-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:4rem 2rem;display:flex}.error-icon{opacity:.8;margin-bottom:1rem;font-size:4rem}.error-container h3{color:var(--text-primary);margin-bottom:.75rem;font-size:1.5rem}.error-text{color:var(--text-secondary);max-width:500px;margin-bottom:2rem;font-size:1rem;line-height:1.6}.btn-retry{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-retry:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.btn-retry:active{transform:translateY(0)}.boat-card{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;transition:transform .2s,box-shadow .2s;overflow:hidden}.boat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.boat-image{object-fit:cover;width:100%;height:200px}.boat-info{padding:1.5rem}.boat-info h2{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem}.boat-description{color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.boat-details{color:var(--text-secondary);gap:1rem;margin-bottom:1rem;font-size:.9375rem;display:flex}.pricing-notes{color:var(--text-tertiary);margin-bottom:1rem;font-size:.875rem;font-style:italic}.btn-book-boat{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-book-boat:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.boats-page{animation:.4s fadeIn}.hero-section{color:#fff;background:linear-gradient(135deg,#0891b2 0%,#0e7490 100%);margin-bottom:3rem;padding:4rem 2rem}.hero-content{text-align:center;max-width:1200px;margin:0 auto}.hero-content h1{color:#fff;margin-bottom:1rem;font-size:2.5rem;font-weight:700}.hero-description{color:#fffffff2;max-width:700px;margin:0 auto;font-size:1.125rem;line-height:1.7}.boats-section{max-width:1200px;margin:0 auto;padding:0 2rem 3rem}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{color:var(--text-primary);margin-bottom:.75rem;font-size:2rem}.section-header p{color:var(--text-secondary);font-size:1.0625rem}.boats-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem;display:grid}.no-boats{text-align:center;background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);padding:4rem 2rem}.no-boats p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.125rem}.btn-refresh{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-refresh:hover{background-color:var(--primary-hover);transform:translateY(-1px)}@media (width<=768px){.hero-content h1{font-size:2rem}.hero-description{font-size:1rem}.boats-grid{grid-template-columns:1fr;gap:1.5rem}.section-header h2{font-size:1.75rem}}@media (width<=640px){.hero-section{padding:3rem 1rem}.hero-content h1{font-size:1.75rem}.boats-section{padding:0 1rem 2rem}.section-header{margin-bottom:2rem}}.upcoming-reservations-page{max-width:1200px;margin:0 auto;padding:2rem}.subtitle{color:var(--text-secondary);font-size:1rem}.loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.spinner{border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:3rem;height:3rem;animation:1s linear infinite spin}.error-message{text-align:center;border-radius:var(--border-radius);color:#991b1b;background-color:#fee2e2;border:1px solid #ef4444;padding:2rem}.btn-retry{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem;transition:background-color .2s}.btn-retry:hover{background-color:var(--primary-hover)}.no-reservations{text-align:center;color:var(--text-secondary);padding:4rem 2rem;font-size:1.125rem}.reservation-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.5rem;transition:box-shadow .2s,transform .2s}.reservation-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.reservation-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.reservation-header h3{color:var(--text-primary);margin:0;font-size:1.25rem}.status-badge{text-transform:uppercase;border-radius:12px;padding:.375rem .875rem;font-size:.875rem;font-weight:600}.status-pending{color:#92400e;background-color:#fef3c7}.status-confirmed{color:#065f46;background-color:#d1fae5}.status-cancelled{color:#991b1b;background-color:#fee2e2}.status-completed{color:#1e40af;background-color:#dbeafe}.status-default{background-color:var(--bg-secondary);color:var(--text-secondary)}.reservation-times{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}.time-slot{flex-direction:column;gap:.25rem;display:flex}.time-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.time-value{color:var(--text-primary);font-size:1.125rem;font-weight:600}.reservation-notes{background-color:var(--bg-secondary);border-radius:var(--border-radius);margin-top:1rem;padding:1rem}.notes-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.reservation-notes p{color:var(--text-primary);margin:0;line-height:1.5}@media (width<=768px){.upcoming-reservations-page{padding:1rem}.page-header h1{font-size:1.5rem}.reservation-times{grid-template-columns:1fr}.reservation-header{flex-direction:column;align-items:flex-start;gap:.75rem}}.reservation-card{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);transition:box-shadow .2s;overflow:hidden}.reservation-card:hover{box-shadow:var(--shadow-md)}.reservation-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.5rem;display:flex}.reservation-card-header h3{color:var(--text-primary);margin:0;font-size:1.25rem}.reservation-date{color:var(--text-secondary);margin:.375rem 0 0;font-size:.9375rem}.status-badge{border-radius:var(--border-radius-sm);white-space:nowrap;padding:.375rem .875rem;font-size:.875rem;font-weight:600;display:inline-block}.status-badge.status-pending{color:#92400e;background-color:#fef3c7}.status-badge.status-confirmed{color:#166534;background-color:#dcfce7}.status-badge.status-cancelled{color:#991b1b;background-color:#fee2e2}.status-badge.status-completed{color:#1e40af;background-color:#dbeafe}.reservation-card-body{padding:1.5rem}.reservation-info{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.info-row{color:var(--text-secondary);align-items:flex-start;gap:.75rem;font-size:.9375rem;display:flex}.info-icon{flex-shrink:0;font-size:1.125rem}.info-row .notes{color:var(--text-primary);font-style:italic}.reservation-meta{border-top:1px solid var(--border-color);padding-top:1rem}.reservation-meta small{color:var(--text-tertiary);font-size:.8125rem}.reservation-card-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.btn-cancel-reservation{color:var(--error-color);border:1px solid var(--error-color);border-radius:var(--border-radius);cursor:pointer;background-color:#0000;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;transition:background-color .2s,color .2s,border-color .2s}.btn-cancel-reservation:hover{background-color:var(--error-color);color:#fff}.btn-view-details-card{background-color:var(--info-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-view-details-card:hover{background-color:#2563eb;transform:translateY(-1px)}.btn-edit-card{background-color:var(--info-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-edit-card:hover{background-color:#2563eb;transform:translateY(-1px)}@media (width<=640px){.reservation-card-header{flex-direction:column;align-items:flex-start}.reservation-card-footer{flex-direction:column;gap:.5rem}.btn-view-details-card,.btn-cancel-reservation{width:100%}}.reservation-modal-overlay{z-index:1000;background-color:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.reservation-modal-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);width:100%;max-width:700px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.3s slideUp;overflow-y:auto}.reservation-modal-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);z-index:10;justify-content:space-between;align-items:center;padding:1.5rem;display:flex;position:sticky;top:0}.reservation-modal-header h2{color:var(--text-primary);margin:0;font-size:1.5rem}.reservation-modal-body{padding:1.5rem}.detail-section{border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:1.5rem}.detail-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-section h3{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.125rem;display:flex}.detail-row{justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;display:flex}.detail-row.highlight{background-color:var(--bg-secondary);border-radius:var(--border-radius);margin-bottom:.5rem;padding:1rem}.detail-label{color:var(--text-secondary);flex-shrink:0;font-weight:500}.detail-value{color:var(--text-primary);text-align:right;word-break:break-word}.detail-value.code{background-color:var(--bg-secondary);border-radius:var(--border-radius-sm);padding:.25rem .5rem;font-family:Courier New,monospace;font-size:.875rem}.member-badge{color:#166534;background-color:#dcfce7;border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:600}.services-list{flex-direction:column;gap:.75rem;display:flex}.service-detail-item{background-color:var(--bg-secondary);border-radius:var(--border-radius);justify-content:space-between;align-items:center;gap:1rem;padding:1rem;display:flex}.service-detail-info{flex-direction:column;flex:1;gap:.25rem;display:flex}.service-name{color:var(--text-primary);font-weight:600}.service-quantity{color:var(--text-secondary);font-size:.875rem}.service-total{color:var(--primary-color);font-size:1.125rem;font-weight:700}.price-section{background-color:var(--bg-secondary);border-radius:var(--border-radius);padding:1.25rem}.price-section .detail-row{padding:.5rem 0}.total-row{border-top:2px solid var(--border-color);margin-top:.5rem;font-size:1.125rem;padding-top:1rem!important}.total-row .detail-label{color:var(--text-primary);font-weight:700}.total-price{color:var(--primary-color);font-weight:700;font-size:1.5rem!important}.notes-content{background-color:var(--bg-secondary);border-radius:var(--border-radius);color:var(--text-primary);white-space:pre-wrap;padding:1rem;line-height:1.6}.meta-section{background-color:var(--bg-tertiary);border-radius:var(--border-radius);padding:1rem;font-size:.875rem}.meta-section .detail-row{padding:.25rem 0}.meta-section .detail-value{color:var(--text-tertiary)}.reservation-modal-footer{border-top:1px solid var(--border-color);background:var(--bg-primary);justify-content:flex-end;padding:1rem 1.5rem;display:flex;position:sticky;bottom:0}.btn-close-modal{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-close-modal:hover{background-color:var(--primary-hover);transform:translateY(-1px)}@media (width<=640px){.reservation-modal-container{border-radius:0;max-width:100%;max-height:100vh}.detail-row{flex-direction:column;align-items:flex-start}.detail-value{text-align:left}.service-detail-item{flex-direction:column;align-items:flex-start}}.customer-edit-modal{max-width:600px}.info-banner{color:#1e40af;border-radius:var(--border-radius);background-color:#dbeafe;border-left:4px solid #3b82f6;margin-bottom:1.5rem;padding:.875rem 1rem;font-size:.9375rem}.warning-message{color:#92400e;border-radius:var(--border-radius);text-align:center;background-color:#fef3c7;border-left:4px solid #f59e0b;margin-bottom:1.5rem;padding:1rem;font-weight:500}.my-reservations-page{max-width:1200px;margin:0 auto;padding:3rem 2rem;animation:.4s fadeIn}.page-header{text-align:center;margin-bottom:3rem}.page-header h1{color:var(--text-primary);margin-bottom:.75rem;font-size:2.25rem}.page-header p{color:var(--text-secondary);font-size:1.0625rem}.search-section{margin-bottom:2rem}.search-container{max-width:500px;margin:0 auto 1rem;position:relative}.search-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #0891b21a}.search-input::placeholder{color:var(--text-tertiary)}.btn-clear-search{width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;border-radius:var(--border-radius-sm);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.25rem;transition:background-color .2s,color .2s;display:flex;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.btn-clear-search:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.search-info{text-align:center;color:var(--text-secondary);font-size:.9375rem}.reservations-section{margin-top:2rem}.reservations-list{gap:1.5rem;display:grid}.reservation-card-wrapper{position:relative}.no-reservations{text-align:center;background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);padding:4rem 2rem}.no-reservations-icon{opacity:.5;margin-bottom:1rem;font-size:4rem}.no-reservations h3{color:var(--text-primary);margin-bottom:.75rem;font-size:1.5rem}.no-reservations p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.0625rem}.btn-clear-search-alt{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-clear-search-alt:hover{background-color:var(--primary-hover);transform:translateY(-1px)}@media (width<=768px){.my-reservations-page{padding:2rem 1rem}.page-header h1{font-size:1.875rem}.search-section{margin-bottom:1.5rem}}@media (width<=640px){.page-header{margin-bottom:2rem}.page-header h1{font-size:1.625rem}}.login-page{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem 1rem;display:flex}.login-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:450px;padding:2.5rem}.login-header p{color:var(--text-secondary);font-size:.9375rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.error-banner{color:#991b1b;border-radius:var(--border-radius);background-color:#fee2e2;border-left:4px solid #dc2626;padding:.875rem 1rem;font-size:.9375rem}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-primary);font-size:.9375rem;font-weight:500}.form-group input{border:1px solid var(--border-color);border-radius:var(--border-radius);padding:.875rem 1rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #2563eb1a}.btn-login{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-login:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}.btn-login:disabled{background-color:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.login-footer{text-align:center;border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1.5rem}.login-footer p{color:var(--text-secondary);font-size:.9375rem}.login-footer a{color:var(--primary-color);font-weight:600;text-decoration:none}.login-footer a:hover{text-decoration:underline}.loading-container{min-height:calc(100vh - 200px);color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.125rem;display:flex}@media (width<=640px){.login-container{padding:2rem 1.5rem}.login-header h1{font-size:1.75rem}}.register-page{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem 1rem;display:flex}.register-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:600px;padding:2.5rem}.register-header{text-align:center;margin-bottom:2rem}.register-header h1{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem}.register-header p{color:var(--text-secondary);font-size:.9375rem}.register-form{flex-direction:column;gap:1.25rem;display:flex}.form-group small{color:var(--text-tertiary);font-size:.8125rem}.btn-register{background-color:var(--success-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-register:hover:not(:disabled){background-color:#059669;transform:translateY(-1px)}.btn-register:disabled{background-color:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.register-footer{text-align:center;border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1.5rem}.register-footer p{color:var(--text-secondary);font-size:.9375rem}.register-footer a{color:var(--primary-color);font-weight:600;text-decoration:none}.register-footer a:hover{text-decoration:underline}@media (width<=640px){.register-container{padding:2rem 1.5rem}.register-header h1{font-size:1.75rem}.form-row{grid-template-columns:1fr}}.cancel-reservation-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem;display:flex}.cancel-container{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:600px;padding:3rem;animation:.4s ease-out slideIn;box-shadow:0 20px 60px #0000004d}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.cancel-icon{margin-bottom:1.5rem;font-size:5rem;animation:.6s ease-in-out bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.cancel-icon.warning{animation:2s infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.cancel-confirmation h1,.cancel-success h1,.cancel-error h1{color:#1f2937;margin-bottom:1rem;font-size:2rem}.cancel-description{color:#6b7280;margin-bottom:1.5rem;font-size:1.125rem;line-height:1.6}.cancel-warning{color:#92400e;background-color:#fff7ed;border-left:4px solid #f59e0b;border-radius:8px;margin:1.5rem 0;padding:1rem}.cancel-info-box{text-align:left;background-color:#dbeafe;border-left:4px solid #3b82f6;border-radius:8px;margin:1.5rem 0;padding:1rem}.cancel-info-box.error{background-color:#fee2e2;border-left-color:#ef4444}.cancel-info-box h3{color:#1f2937;margin-top:0;margin-bottom:.75rem;font-size:1rem}.cancel-info-box ul{color:#4b5563;margin:0;padding-left:1.5rem}.cancel-info-box ul li{margin-bottom:.5rem}.cancel-error-message{color:#991b1b;background-color:#fee2e2;border-radius:8px;margin-bottom:1.5rem;padding:1rem;font-weight:500}.cancel-contact{color:#6b7280;margin:1.5rem 0;font-size:.9375rem;line-height:1.8}.cancel-contact a{color:#2563eb;text-decoration:none}.cancel-contact a:hover{text-decoration:underline}.cancel-actions{flex-direction:column;gap:1rem;margin-top:2rem;display:flex}.btn-cancel-confirm{color:#fff;cursor:pointer;background-color:#dc2626;border:none;border-radius:8px;padding:1rem 2rem;font-size:1.0625rem;font-weight:600;transition:all .2s}.btn-cancel-confirm:hover{background-color:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc262666}.btn-cancel-confirm:active{transform:translateY(0)}.btn-cancel-confirm:disabled{cursor:not-allowed;background-color:#9ca3af;transform:none}.btn-cancel-back,.btn-home{color:#374151;cursor:pointer;background-color:#f3f4f6;border:2px solid #e5e7eb;border-radius:8px;padding:1rem 2rem;font-size:1.0625rem;font-weight:600;transition:all .2s}.btn-cancel-back:hover,.btn-home:hover{background-color:#e5e7eb;border-color:#d1d5db;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn-cancel-back:active,.btn-home:active{transform:translateY(0)}@media (width<=768px){.cancel-container{padding:2rem}.cancel-icon{font-size:4rem}.cancel-confirmation h1,.cancel-success h1,.cancel-error h1{font-size:1.5rem}.cancel-description{font-size:1rem}}.admin-login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem;display:flex}.login-container{border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:450px;padding:3rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem}.login-header p{color:var(--text-secondary)}.login-form{margin-bottom:2rem}.btn-login{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;width:100%;padding:1rem;font-size:1.0625rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-login:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.login-footer{text-align:center;border-top:1px solid var(--border-color);padding-top:1.5rem}.demo-info{background-color:var(--bg-secondary);border-radius:var(--border-radius);color:var(--text-secondary);padding:1rem;font-size:.875rem}.modal-overlay{z-index:1001;background-color:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);width:100%;max-width:700px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);z-index:10;justify-content:space-between;align-items:center;padding:1.5rem;display:flex;position:sticky;top:0}.modal-form{padding:1.5rem}.form-section{border-bottom:1px solid var(--border-color);margin-bottom:2rem;padding-bottom:1.5rem}.form-section:last-of-type{border-bottom:none}.form-section h3{margin-bottom:1rem;font-size:1.125rem}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.5rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;padding:.75rem;font-size:1rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.modal-actions{justify-content:flex-end;gap:1rem;padding-top:1rem;display:flex}.error-banner{color:#991b1b;border-radius:var(--border-radius);background-color:#fee2e2;margin-bottom:1.5rem;padding:.875rem 1rem}.help-text{color:var(--text-tertiary);margin-top:.5rem;font-size:.875rem;line-height:1.5;display:block}@media (width<=640px){.form-row{grid-template-columns:1fr}}.admin-reservations-page{max-width:1600px;margin:0 auto;padding:2rem}.page-header-admin{justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2rem;display:flex}.page-subtitle{color:var(--text-secondary);margin-top:.5rem;font-size:.9375rem}.header-actions{align-items:center;gap:1rem;display:flex}.view-toggle{border-radius:var(--border-radius);box-shadow:var(--shadow);background:#fff;gap:.25rem;padding:.25rem;display:flex}.view-toggle button{border-radius:var(--border-radius-sm);cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:1.25rem;transition:background-color .2s}.view-toggle button.active{background-color:var(--primary-color)}.view-toggle button:hover:not(.active){background-color:var(--bg-secondary)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);border-left:4px solid var(--border-color);background:#fff;flex-direction:column;gap:.5rem;padding:1.5rem;display:flex}.stat-card.today{border-left-color:#f59e0b}.stat-card.pending{border-left-color:var(--warning-color)}.stat-card.confirmed{border-left-color:var(--success-color)}.stat-card.cancelled{border-left-color:var(--error-color)}.stat-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.stat-value{color:var(--text-primary);font-size:2rem;font-weight:700}.filters-container{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;flex-direction:column;gap:1rem;margin-bottom:2rem;padding:1.5rem;display:flex}.search-box{max-width:500px;position:relative}.search-input{border:2px solid var(--border-color);border-radius:var(--border-radius);width:100%;padding:.875rem 3rem .875rem 1rem;font-size:1rem;transition:border-color .2s}.search-input:focus{border-color:var(--primary-color);outline:none}.clear-search{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;padding:.25rem;font-size:1.25rem;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.clear-search:hover{color:var(--text-primary)}.filters{flex-wrap:wrap;gap:.5rem;display:flex}.filters button{color:var(--text-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;background-color:#fff;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.filters button:hover{border-color:var(--primary-color);color:var(--primary-color)}.filters button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.filters button.status-pending{color:#92400e;border-color:#fbbf24}.filters button.status-pending.active{color:#fff;background-color:#fbbf24}.filters button.status-confirmed{color:#166534;border-color:#10b981}.filters button.status-confirmed.active{color:#fff;background-color:#10b981}.filters button.status-cancelled{color:#991b1b;border-color:#ef4444}.filters button.status-cancelled.active{color:#fff;background-color:#ef4444}.filters button.status-completed{color:#1e40af;border-color:#3b82f6}.filters button.status-completed.active{color:#fff;background-color:#3b82f6}.date-filters{flex-wrap:wrap;gap:.5rem;display:flex}.date-filters button{color:var(--text-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;background-color:#fff;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.date-filters button:hover{border-color:var(--primary-color);color:var(--primary-color)}.date-filters button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.date-range{align-items:center;gap:.75rem;display:flex}.date-range input[type=date]{border:2px solid var(--border-color);border-radius:var(--border-radius);padding:.625rem;font-size:.9375rem;transition:border-color .2s}.date-range input[type=date]:focus{border-color:var(--primary-color);outline:none}.reservations-table{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;overflow:hidden}.reservations-table table{border-collapse:collapse;width:100%;font-size:.9375rem}.reservations-table thead{background:var(--bg-secondary);z-index:10;position:sticky;top:0}.reservations-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;padding:1rem;font-size:.875rem;font-weight:600}.reservations-table tbody tr.reservation-row{border-bottom:1px solid var(--border-color);transition:background-color .2s}.reservations-table tbody tr.reservation-row:hover{background-color:var(--bg-secondary)}.reservations-table tbody tr.reservation-row.today{background-color:#fef3c7}.reservations-table tbody tr.reservation-row.tomorrow{background-color:#dbeafe}.reservations-table tbody tr.reservation-row.soon{background-color:#fce7f3}.reservations-table tbody tr.reservation-row.past{opacity:.6}.reservations-table td{vertical-align:top;padding:1rem}.expand-cell{text-align:center;width:60px}.expand-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:.25rem .5rem;font-size:1rem;transition:color .2s,transform .2s}.expand-btn:hover{color:var(--primary-color);transform:scale(1.1)}.priority-badge{white-space:nowrap;margin-top:.25rem;font-size:.75rem;display:block}.priority-badge.today{color:#92400e}.priority-badge.tomorrow{color:#1e40af}.priority-badge.soon{color:#be185d}.customer-info{flex-direction:column;gap:.25rem;display:flex}.customer-info strong{color:var(--text-primary)}.customer-info small{color:var(--text-tertiary);font-size:.8125rem}.customer-info .created-by{color:var(--text-tertiary);margin-top:.25rem}.date-info{flex-direction:column;gap:.25rem;display:flex}.date-info small{color:var(--text-tertiary);font-size:.8125rem}.date-info .duration{color:var(--primary-color);font-weight:600}.type-badge{background-color:var(--bg-secondary);white-space:nowrap;border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.status-select.compact,.handler-select.compact{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;max-width:150px;padding:.375rem .5rem;font-size:.875rem}.status-select.compact.pending{color:#92400e;background-color:#fef3c7;border-color:#fbbf24}.status-select.compact.confirmed{color:#166534;background-color:#dcfce7;border-color:#10b981}.status-select.compact.cancelled{color:#991b1b;background-color:#fee2e2;border-color:#ef4444}.status-select.compact.completed{color:#1e40af;background-color:#dbeafe;border-color:#3b82f6}.actions-cell{align-items:center;gap:.5rem;display:flex}.btn-icon{cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:1.25rem;transition:transform .2s,opacity .2s}.btn-icon:hover{transform:scale(1.2)}.btn-icon.danger:hover{opacity:.7}.expanded-details{border-top:2px solid var(--primary-color);background-color:#f8fafc}.details-content{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;padding:1.5rem;display:grid}.detail-section{border-radius:var(--border-radius);background:#fff;padding:1rem;box-shadow:0 1px 3px #0000001a}.detail-section.full-width{grid-column:1/-1}.detail-section h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;margin:0 0 .75rem;font-size:.9375rem}.detail-section p{color:var(--text-primary);margin:.5rem 0}.detail-section ul{margin:0;padding:0;list-style:none}.detail-section ul li{border-bottom:1px solid var(--border-color);padding:.5rem 0}.detail-section ul li:last-child{border-bottom:none}.reservations-cards{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;display:grid}.reservation-card-admin{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);border-left:4px solid var(--border-color);background:#fff;transition:transform .2s,box-shadow .2s;overflow:hidden}.reservation-card-admin:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.reservation-card-admin.today{border-left-color:#f59e0b}.reservation-card-admin.tomorrow{border-left-color:#3b82f6}.reservation-card-admin.soon{border-left-color:#ec4899}.reservation-card-admin.past{opacity:.6}.card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.card-header h3{color:var(--text-primary);margin:0;font-size:1.125rem}.card-email{color:var(--text-tertiary);margin-top:.25rem;font-size:.875rem}.card-badges{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.badge{white-space:nowrap;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.badge.today{color:#92400e;background-color:#fef3c7}.badge.tomorrow{color:#1e40af;background-color:#dbeafe}.badge.soon{color:#be185d;background-color:#fce7f3}.badge.status-pending{color:#92400e;background-color:#fef3c7}.badge.status-confirmed{color:#166534;background-color:#dcfce7}.badge.status-cancelled{color:#991b1b;background-color:#fee2e2}.badge.status-completed{color:#1e40af;background-color:#dbeafe}.card-body{flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.card-row{align-items:center;gap:.75rem;font-size:.9375rem;display:flex}.card-row span:first-child{font-size:1.25rem}.card-actions{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);gap:.75rem;padding:1rem 1.25rem;display:flex}.btn-card{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;flex:1;padding:.625rem 1rem;font-size:.9375rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-card:hover{background-color:var(--primary-hover);transform:translateY(-1px)}@media (width<=1024px){.filters-container{padding:1rem}.reservations-table{overflow-x:auto}.reservations-table table{min-width:900px}.details-content{grid-template-columns:1fr}}@media (width<=768px){.admin-reservations-page{padding:1rem}.page-header-admin{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr)}.filters,.date-filters{gap:.375rem}.filters button,.date-filters button{padding:.5rem 1rem;font-size:.875rem}.reservations-cards{grid-template-columns:1fr}}@media (width<=640px){.date-range{flex-direction:column;align-items:stretch}.date-range input[type=date]{width:100%}}.resource-form-overlay{z-index:1000;background-color:#0009;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.resource-form-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.3s slideUp;overflow-y:auto}.form-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);z-index:10;justify-content:space-between;align-items:center;padding:1.5rem;display:flex;position:sticky;top:0}.form-header h2{margin:0;font-size:1.5rem}.resource-form{padding:1.5rem}.checkbox-group{align-items:center;padding-top:2rem;display:flex}.checkbox-group label{cursor:pointer;align-items:center;gap:.5rem;margin:0;display:flex}.checkbox-group input[type=checkbox]{cursor:pointer;width:1.25rem;height:1.25rem}@media (width<=640px){.resource-form-container{max-height:95vh}}.admin-resources-page{max-width:1400px;margin:0 auto;padding:2rem}.page-header-admin{border-bottom:2px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.page-header-admin h1{color:var(--text-primary);font-size:2rem}.btn-add-resource{background-color:var(--success-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-add-resource:hover{background-color:#059669;transform:translateY(-1px)}.resources-section{margin-bottom:3rem}.resources-section h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem}.resources-table{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;overflow:hidden}.resources-table table{border-collapse:collapse;width:100%}.resources-table th{background-color:var(--bg-secondary);text-align:left;color:var(--text-primary);border-bottom:2px solid var(--border-color);padding:1rem;font-weight:600}.resources-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:1rem}.resources-table tr:last-child td{border-bottom:none}.resources-table tr:hover{background-color:var(--bg-secondary)}.description-cell{text-overflow:ellipsis;white-space:nowrap;max-width:400px;overflow:hidden}.status-dot{border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.status-dot.available{color:#166534;background-color:#dcfce7}.status-dot.unavailable{color:#991b1b;background-color:#fee2e2}.actions-cell{gap:.5rem;display:flex}.btn-edit,.btn-delete{border-radius:var(--border-radius-sm);cursor:pointer;border:none;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s,transform .2s}.no-data{text-align:center;color:var(--text-tertiary);padding:2rem;font-style:italic}@media (width<=768px){.page-header-admin{flex-direction:column;align-items:flex-start;gap:1rem}.btn-add-resource{width:100%}.resources-table{overflow-x:auto}.description-cell{max-width:200px}}.admin-pricing-page{max-width:1200px;margin:0 auto;padding:2rem}.resource-selector{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;display:flex}.resource-selector label{color:var(--text-primary);font-weight:600}.resource-selector select{border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;flex:1;max-width:400px;padding:.75rem;font-size:1rem;transition:border-color .2s}.resource-selector select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #2563eb1a}.resource-info{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;margin-bottom:2rem;padding:1.5rem}.resource-info h3{color:var(--text-primary);margin:0 0 .5rem}.resource-info p{color:var(--text-secondary);margin:.5rem 0}.pricing-section{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;padding:2rem}.section-header-row{border-bottom:2px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.section-header-row h2{color:var(--text-primary);margin:0}.btn-add{background-color:var(--success-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-add:hover{background-color:#059669;transform:translateY(-1px)}.pricing-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;display:grid}.pricing-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.5rem;transition:border-color .2s,transform .2s}.pricing-card:hover{border-color:var(--primary-color);transform:translateY(-2px)}.pricing-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;display:flex}.pricing-card-header h3{color:var(--primary-color);margin:0;font-size:2rem}.status-badge.active{color:#166534;background-color:#dcfce7;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.status-badge.inactive{color:#991b1b;background-color:#fee2e2;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.pricing-card-body{margin-bottom:1rem}.price-row{justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.price-row.member{border-bottom:1px solid var(--border-color)}.price-row span{color:var(--text-secondary);font-size:.9375rem}.price-row strong{color:var(--text-primary);font-size:1.125rem}.price-row.member strong{color:var(--success-color)}.pricing-card-actions{gap:.5rem;margin-top:1rem;display:flex}.btn-edit-small,.btn-delete-small{border-radius:var(--border-radius-sm);cursor:pointer;border:none;flex:1;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s,transform .2s}.btn-edit-small{background-color:var(--info-color);color:#fff}.btn-edit-small:hover{background-color:#2563eb;transform:translateY(-1px)}.btn-delete-small{background-color:var(--error-color);color:#fff}.btn-delete-small:hover{background-color:#dc2626;transform:translateY(-1px)}.no-data{text-align:center;color:var(--text-tertiary);background:var(--bg-secondary);border-radius:var(--border-radius);padding:3rem;font-style:italic}.pricing-form-overlay{z-index:1000;background-color:#0009;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.pricing-form-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);padding:2rem;animation:.3s slideUp}.pricing-form-container h2{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.5rem}.pricing-form-container .form-group{margin-bottom:1.25rem}.pricing-form-container label{color:var(--text-primary);margin-bottom:.5rem;font-weight:500;display:block}.pricing-form-container input{border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}.pricing-form-container input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #2563eb1a}.pricing-form-container .form-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}@media (width<=768px){.admin-pricing-page{padding:1rem}.resource-selector{flex-direction:column;align-items:stretch}.resource-selector select{max-width:100%}.pricing-grid{grid-template-columns:1fr}.section-header-row{flex-direction:column;align-items:stretch;gap:1rem}.btn-add{width:100%}}.admin-services-page{max-width:1400px;margin:0 auto;padding:2rem}.add-service-section{text-align:center;margin:2rem 0}.btn-add-service{background-color:var(--success-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:1rem 2rem;font-size:1.0625rem;font-weight:600;transition:background-color .2s,transform .2s}.btn-add-service:hover{background-color:#059669;transform:translateY(-1px)}.services-section{margin-bottom:3rem}.services-section h2{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.5rem;display:flex}.services-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.service-card{border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;transition:transform .2s,box-shadow .2s;overflow:hidden}.service-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.service-card-header{background:linear-gradient(135deg, var(--primary-color) 0%, #1e40af 100%);color:#fff;align-items:center;gap:.75rem;padding:1.25rem;display:flex}.service-icon{font-size:1.75rem}.service-card-header h3{color:#fff;margin:0;font-size:1.125rem}.service-card-body{padding:1.25rem}.service-description{color:var(--text-secondary);margin-bottom:1rem;font-size:.9375rem;line-height:1.5}.service-details{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.service-price-tag{background-color:var(--success-color);color:#fff;border-radius:12px;padding:.375rem .875rem;font-size:.9375rem;font-weight:600}.service-meta{background-color:var(--bg-secondary);color:var(--text-secondary);border-radius:12px;padding:.375rem .875rem;font-size:.8125rem}.service-status{margin-bottom:1rem}.service-card-actions{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);gap:.75rem;padding:1rem 1.25rem;display:flex}.btn-edit,.btn-delete{border-radius:var(--border-radius-sm);cursor:pointer;border:none;flex:1;padding:.625rem 1rem;font-size:.9375rem;font-weight:500;transition:background-color .2s,transform .2s}.btn-edit{background-color:var(--info-color);color:#fff}.btn-edit:hover{background-color:#2563eb;transform:translateY(-1px)}.btn-delete{background-color:var(--error-color);color:#fff}.btn-delete:hover{background-color:#dc2626;transform:translateY(-1px)}.no-services{text-align:center;border-radius:var(--border-radius-lg);box-shadow:var(--shadow);background:#fff;padding:4rem 2rem}.no-services p{color:var(--text-tertiary);font-size:1.125rem}.service-form-overlay{z-index:1000;background-color:#0009;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.service-form-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-lg);max-height:90vh;padding:2rem;animation:.3s slideUp;overflow-y:auto}.service-form-container h2{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.5rem}@media (width<=768px){.admin-services-page{padding:1rem}.services-grid{grid-template-columns:1fr}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%}.app-footer{background-color:var(--bg-primary);border-top:1px solid var(--border-color);margin-top:4rem;padding:2rem 1rem}.footer-content{text-align:center;max-width:1200px;color:var(--text-secondary);margin:0 auto;font-size:.875rem}.footer-content p{margin:.5rem 0}.footer-links a{color:var(--text-secondary);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--primary-color);text-decoration:underline}:root{--primary-color:#0891b2;--primary-hover:#0e7490;--secondary-color:#64748b;--success-color:#10b981;--warning-color:#f59e0b;--error-color:#ef4444;--info-color:#3b82f6;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--text-primary:#1e293b;--text-secondary:#64748b;--text-tertiary:#94a3b8;--border-color:#e2e8f0;--border-radius:8px;--border-radius-sm:4px;--border-radius-lg:12px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-weight:400;line-height:1.6}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-secondary);color:var(--text-primary);min-height:100vh;margin:0}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.2}a{color:var(--primary-color);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover);text-decoration:underline}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}.required{color:var(--error-color)}
