@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --bg:#F8FAFC;
  --surface:#FFFFFF;
  --surface-alt:#F1F5F9;
  --text:#1E293B;
  --muted:#64748B;
  --border:#E2E8F0;
  --primary:#1E40AF;
  --primary-2:#3B82F6;
  --primary-light:rgba(59,130,246,.08);
  --accent:#0EA5A4;
  --accent-hover:#0d9494;
  --text-on-bg:#ffffff;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow:0 10px 30px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --shadow-lg:0 20px 50px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.06);
  --radius:14px;
  --radius-sm:8px;
  --max:1100px;
  --header-footer-bg:#0F172A;
}

html{font-size:16px;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{color:inherit;text-decoration:none;transition:color .2s}

.container{max-width:var(--max);margin:0 auto;padding:0 24px}

.site-header{
  position:sticky;
  top:0;
  z-index:10;
  background:#0F172A;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 1px 12px rgba(0,0,0,.2);
}

.header-inner{display:flex;align-items:center;padding:16px 0;gap:16px;position:relative}

.brand{display:flex;align-items:center;gap:12px;flex-shrink:0;transition:opacity .2s}
.brand:hover{opacity:.85}
.brand-logo{width:44px;height:44px;border-radius:50%;object-fit:contain;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.brand-name{font-weight:750;letter-spacing:.3px;color:#D4AF37;font-size:17px}/* keep gold */

.nav-center{display:flex;gap:2px;align-items:center;white-space:nowrap;flex-wrap:nowrap;flex:1;justify-content:flex-start;min-width:0;overflow:hidden}
.header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto}
.header-icon-btn{background:transparent;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:color .2s;border-radius:4px}
.header-icon-btn:hover{color:#fff}
.nav-link{color:rgba(255,255,255,.75);padding:8px 12px;border-radius:var(--radius-sm);border:none;border-bottom:none;transition:all .25s;font-weight:500;text-decoration:none;font-size:13px;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-link.is-active{color:#fff;background:rgba(59,130,246,.25);font-weight:700}
.nav-toggle{display:none;background:none;border:none;color:rgba(255,255,255,.8);font-size:22px;cursor:pointer;padding:8px;line-height:1;align-items:center;transition:color .2s}
.nav-toggle:hover{color:#fff}
.nav-dropdown{display:none;position:absolute;top:100%;right:0;background:#1E293B;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:12px 8px;flex-direction:column;gap:4px;z-index:1000;box-shadow:0 8px 24px rgba(0,0,0,.3);min-width:180px}
.nav-dropdown .nav-link{text-transform:none;font-size:15px;padding:10px 12px;border-bottom:none;color:rgba(255,255,255,.8)}
.nav-dropdown .nav-link:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-dropdown.open{display:flex}
.user-menu-dropdown{position:relative}
.user-menu-dropdown-content{display:none;position:absolute;top:calc(100% + 8px);right:0;background:#1E293B;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:8px;flex-direction:column;gap:2px;z-index:1000;box-shadow:0 8px 24px rgba(0,0,0,.4);min-width:200px}
.user-menu-dropdown-content.open{display:flex}
.user-menu-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;color:rgba(255,255,255,.8);font-size:14px;transition:all .2s;text-decoration:none}
.user-menu-link:hover{background:rgba(255,255,255,.08);color:#fff}
.user-menu-link svg{flex-shrink:0;opacity:.7}
.user-menu-logout{color:#ff6b6b}
.user-menu-logout:hover{background:rgba(255,107,107,.1);color:#ff6b6b}
.user-menu-divider{height:1px;background:var(--border);margin:6px 0}
.booking-search{position:relative}
.search-dropdown{display:none;position:absolute;top:calc(100% + 12px);right:0;background:#1E293B;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:12px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:1000;min-width:320px;flex-direction:row;align-items:center;gap:8px}
.search-dropdown.open{display:flex}
.booking-search-input{padding:8px 14px;border:1px solid rgba(255,255,255,.15);border-radius:20px;background:rgba(255,255,255,.1);color:#fff;font-size:14px;flex:1;transition:all .3s}
.booking-search-input:focus{outline:none;border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(59,130,246,.2)}
.booking-search-input::placeholder{color:rgba(255,255,255,.5)}
.booking-search-btn{background:var(--primary-2);border:none;border-radius:50%;width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff}
.booking-search-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(59,130,246,.4)}
.booking-search-result{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:1000;display:none;min-width:320px}
.booking-search-result.show{display:block}
.booking-result-success{color:var(--primary);font-weight:600;margin-bottom:12px}
.booking-result-error{color:#e74c3c;font-weight:600}
.booking-result-details{font-size:14px;line-height:1.6}
.booking-result-details strong{color:var(--primary)}
.booking-result-loading{text-align:center;color:var(--muted)}
@media (max-width: 1180px){
  .nav-center{display:none}
  .nav-toggle{display:inline-flex}
  .nav-dropdown{left:0;right:0;border-radius:0;top:68px;position:fixed}
}

@media (max-width: 760px){
  .nav-center{display:none}
  .nav-toggle{display:inline-flex}
  .nav-dropdown{left:0;right:0;border-radius:0;top:56px;position:fixed}
  .hero-emblem{max-width:100%}
  .hero-emblem .hero-logo{max-width:100%;min-height:250px}
  .hero-tagline{font-size:18px}
  .hero-with-image{padding:0;min-height:auto}
  .hero-emblem-text{bottom:8%;width:95%}
}

.hero{background:linear-gradient(160deg,#1E40AF 0%,#3B82F6 100%);padding:48px 0 36px;position:relative}
.hero-with-image{background:linear-gradient(160deg,#1E40AF 0%,#3B82F6 100%);padding:0;min-height:auto;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.1) 50%,rgba(0,0,0,0.3) 100%);pointer-events:none}
.hero-inner{display:flex;align-items:center;justify-content:center;min-height:auto;flex-direction:column;position:relative;z-index:1;width:100%;padding:0}
.hero-emblem{position:relative;display:flex;align-items:center;justify-content:center;width:100%;max-width:100%;margin:0;animation:fadeIn 1.2s ease-out both;overflow:hidden}
.hero-emblem .hero-logo{width:100%;max-width:100%;height:auto;min-height:280px;display:block;filter:none;mix-blend-mode:normal;object-fit:cover}
.hero-logo-fade{position:absolute;bottom:0;left:0;right:0;height:65%;background:linear-gradient(to bottom,transparent 0%,rgba(30,64,175,0.4) 30%,rgba(30,64,175,0.8) 60%,#1E40AF 100%);pointer-events:none;z-index:1}
.hero-emblem-text{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:2;text-align:center;width:90%}
.hero-tagline{font-size:22px;font-weight:800;text-align:center;color:#fff !important;margin:0 0 14px;text-shadow:0 2px 24px rgba(0,0,0,0.9),0 0 60px rgba(0,0,0,0.7);animation:fadeInUp 1s ease-out 0.5s both;letter-spacing:.2px;line-height:1.3}
@keyframes fadeIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
.hero-copy{max-width:720px;text-align:center}
.hero h1:not(.hero-tagline){font-size:48px;font-weight:700;line-height:1.2;margin:0 0 24px;color:#fff}
.hero .lead{font-size:18px;line-height:1.6;margin:0 0 32px;color:rgba(255,255,255,.85)}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;animation:fadeInUp 1s ease-out 0.6s both;width:100%}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

.booking-search-bar{background:var(--surface-alt);padding:16px;border-radius:var(--radius);box-shadow:var(--shadow)}
.booking-search-bar input[type="search"]{width:100%;padding:12px 16px;border:none;border-radius:var(--radius-sm);background:var(--surface);color:var(--text)}
.booking-search-bar input[type="search"]:focus{outline:none;border-color:var(--primary-2)}
.booking-search-bar button[type="submit"]{background:var(--primary);color:#fff;padding:12px 16px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}
.booking-search-bar button[type="submit"]:hover{background:#1d3a9e;transform:translateY(-2px)}

.section{padding:40px 0}
.section-alt{background:linear-gradient(135deg,#1E40AF 0%,#3B82F6 100%);border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
.section-header{margin-bottom:24px}
.section-header h1,.section-header h2{margin:0 0 8px;letter-spacing:-.3px;color:var(--text)}
.section-header h1{font-size:32px;font-weight:800}
.section-header h2{font-size:24px;font-weight:700}
.section-header .muted,.section-header-center .muted{font-size:15px;line-height:1.6;color:var(--muted)}
.section-alt .section-header h1,.section-alt .section-header h2{color:#fff}
.section-alt .section-header .muted,.section-alt .section-header-center .muted{color:rgba(255,255,255,.8)}
.section-alt .section-header .muted,.section-alt .section-header-center .muted,.section-alt > .container > .muted,.section-alt > .container > p.muted{color:rgba(255,255,255,.8)}
.section-alt .section-header h1,.section-alt .section-header h2,.section-alt .section-header h3,.section-alt .section-header-center h1,.section-alt .section-header-center h2,.section-alt .section-header-center h3{color:#fff}
.section-why-choose .section-header-center h2,.section-why-choose .muted{color:#fff}
.section-why-choose .section-header-center .muted{color:rgba(255,255,255,.8)}

.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid-tight{gap:12px}

.card{
  background:#FFFFFF;
  border:1px solid #E2E8F0;
  border-radius:var(--radius);
  color:#1E293B;
  padding:20px;
  box-shadow:var(--shadow-sm);
  transition:transform .3s ease, border-color .3s, box-shadow .3s;
}
.card:hover{transform:translateY(-4px);border-color:rgba(59,130,246,.3);box-shadow:var(--shadow-lg)}
.service-card{cursor:default;text-align:center;padding:20px 16px}
.service-card .card-title{color:var(--primary);margin-top:14px}
.service-icon{width:48px;height:48px;margin:0 auto;display:flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(30,64,175,.08);border:1px solid rgba(30,64,175,.15);transition:all .3s}
.service-card:hover .service-icon{background:var(--primary);border-color:var(--primary)}
.service-card:hover .service-icon svg{stroke:#fff}
.service-icon svg{width:24px;height:24px;stroke:var(--primary);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s}

.card-title{margin:0 0 8px;font-size:17px;font-weight:700;letter-spacing:-.2px;color:#1E293B}
.card-subtitle{margin:0 0 12px;color:#64748B;font-size:14px}
.card-text{margin:0;color:#64748B;line-height:1.7;font-size:14px}

.card-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.pill{font-size:12px;color:#1E40AF;padding:7px 10px;border-radius:999px;border:1px solid rgba(30,64,175,.2);background:rgba(30,64,175,.06)}

.list{margin:10px 0 0;padding-left:18px;color:var(--muted);line-height:1.7}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-weight:600;
  border-radius:var(--radius-sm);
  padding:12px 22px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  cursor:pointer;
  transition:all .25s ease;
  font-size:14px;
  letter-spacing:.2px;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}

.btn-primary{border-color:var(--primary);background:linear-gradient(135deg,#1E40AF 0%,#3B82F6 100%);color:#fff;font-weight:700;min-width:300px;padding:16px 48px;box-shadow:0 8px 20px rgba(59,130,246,.25)}
.btn-primary:hover{box-shadow:0 12px 32px rgba(59,130,246,.4);background:linear-gradient(135deg,#1d3a9e 0%,#2563eb 100%);transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:rgba(30,64,175,.3);color:var(--primary)}
.btn-ghost:hover{background:rgba(30,64,175,.06);border-color:var(--primary)}
.btn-danger{border-color:rgba(255,77,109,.3);background:rgba(255,77,109,.06);color:#dc2626}
.btn-danger:hover{background:rgba(255,77,109,.12);border-color:rgba(255,77,109,.5)}
.btn-success{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.06);color:#16a34a}
.btn-success:hover{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.5)}
.btn-block{width:100%}

.link{color:var(--muted);transition:color .2s}
.link:hover{color:var(--primary)}

.divider{height:1px;background:var(--border);margin:14px 0}
.muted{color:var(--muted)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}

.form{margin-top:10px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field label{display:block;margin-bottom:6px;font-weight:600;color:var(--text);font-size:14px}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:15px;font-family:inherit;transition:all .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.field select[size]{padding:4px;overflow-y:auto}
.field select[size] option{padding:8px 12px;cursor:pointer;border-radius:4px;margin:2px 4px}
.field select[size] option:hover{background:rgba(30,64,175,.08)}
.field select[size] option:checked{background:var(--primary);color:#fff;font-weight:600}

textarea{resize:vertical;min-height:110px}

.form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

.alert{
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,77,109,.35);
  background:rgba(255,77,109,.10);
  color:var(--text);
  margin:12px 0 14px;
}

.stack{display:flex;flex-direction:column;gap:16px}

.summary{margin:14px 0 0}
.summary-row{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px dashed rgba(30,64,175,.12)}
.summary-row:last-child{border-bottom:none}
.summary dt{color:var(--muted)}
.summary dd{margin:0;text-align:right;max-width:62%;overflow-wrap:anywhere}

.card-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}
.card-actions{display:flex;gap:10px;flex-wrap:wrap}

.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface) !important;box-shadow:var(--shadow-sm)}
.table{width:100%;border-collapse:collapse;min-width:680px;background:var(--surface) !important}
.table thead{background:var(--surface-alt) !important}
.table tbody tr{background:var(--surface) !important;transition:background .15s}
.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top;background:transparent !important}
.table th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.table tbody tr:hover,.table tbody tr:hover td{background:var(--primary-light) !important}

.row-actions{display:flex;gap:8px;flex-wrap:wrap}

.booking-container{display:flex;gap:24px;max-width:1100px;margin:0 auto;align-items:flex-start}
.booking-form-card{flex:1;max-width:700px;margin:0 auto}

.booking-layout{display:grid;grid-template-columns:1fr 400px;gap:24px;align-items:start}
.booking-form-section{flex:1}
.payment-breakdown-section{position:sticky;top:80px}
.service-item{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.service-select{flex:1}
.btn-remove-service{background:#ff4444;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:opacity .2s}
.btn-remove-service:hover{opacity:.8}
.btn-add-service{background:transparent;border:1px dashed var(--primary-2);color:var(--primary);padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;margin-top:8px;transition:all .2s;width:100%}
.btn-add-service:hover{background:rgba(30,64,175,.06)}
.field-note{font-size:13px;color:var(--muted);margin-top:4px}
/* Service-page selection in breakdown */
.sp-breakdown-section{background:rgba(30,64,175,.04);border:1.5px solid rgba(30,64,175,.12);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px}
.sp-breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.sp-badge{display:inline-flex;align-items:center;gap:4px;background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:50px;letter-spacing:.3px;text-transform:uppercase}
.sp-actions{display:flex;gap:6px;align-items:center}
.sp-edit-btn{background:none;border:1px solid var(--primary);color:var(--primary);font-size:12px;font-weight:600;padding:4px 12px;border-radius:50px;cursor:pointer;transition:all .2s}
.sp-edit-btn:hover{background:var(--primary);color:#fff}
.sp-remove-btn{background:none;border:1px solid var(--border);color:var(--muted);font-size:18px;width:28px;height:28px;border-radius:50%;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1}
.sp-remove-btn:hover{background:#ff4444;color:#fff;border-color:#ff4444}
.sp-breakdown-section .breakdown-item{border-bottom:none;padding:6px 0 0}
.bp-breakdown-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:4px 0 2px;border-top:1px dashed var(--border);margin-top:4px}

/* Service-page form banner */
.sp-form-banner{background:rgba(30,64,175,.04);border:1.5px solid rgba(30,64,175,.12);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:16px}
.sp-form-banner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sp-banner-close{background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}
.sp-banner-close:hover{color:#ff4444}
.sp-form-banner-body{font-size:14px;color:var(--text);display:flex;flex-direction:column;gap:4px}
.sp-form-banner-body strong{color:var(--primary)}

.breakdown-empty{text-align:center;padding:32px 16px;color:var(--muted);font-size:14px}
.breakdown-items{display:flex;flex-direction:column;gap:12px}
.breakdown-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.breakdown-item-name{font-weight:600;color:var(--text)}
.breakdown-item-price{color:var(--primary);font-weight:700}
.breakdown-item.breakdown-item-header{padding:10px 0 2px 0;border-bottom:none}
.breakdown-item.breakdown-item-header .breakdown-item-name{font-weight:700;font-size:14px;color:var(--primary);text-transform:uppercase;letter-spacing:.3px}
.breakdown-item.breakdown-item-detail{padding:6px 0 6px 16px;border-bottom:1px dashed var(--border)}
.breakdown-item.breakdown-item-detail .breakdown-item-name{font-weight:400;font-size:13px;color:var(--muted)}
.breakdown-item.breakdown-item-detail .breakdown-item-price{font-size:13px}
.breakdown-subtotal{display:flex;justify-content:space-between;padding:16px 0;font-size:16px;font-weight:600;border-top:2px solid var(--border);margin-top:8px}
.breakdown-total{display:flex;justify-content:space-between;padding:16px 0;font-size:20px;font-weight:700;color:var(--primary);border-top:2px solid var(--primary);margin-top:8px}
.breakdown-confirm-btn{width:100%;margin-top:16px}

.payment-options{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.payment-option{cursor:pointer;position:relative}
.payment-option input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.payment-card{border:2px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;transition:all .3s;background:var(--surface);display:flex;flex-direction:column;align-items:center;gap:8px;height:100%}
.payment-card img{width:80px;height:54px;object-fit:contain;border-radius:4px}
.payment-card span{font-size:14px;font-weight:600;color:var(--text)}
.payment-option:hover .payment-card{border-color:var(--primary-2);transform:translateY(-2px);box-shadow:0 4px 12px rgba(59,130,246,.15)}
.payment-option input[type="radio"]:checked + .payment-card{border-color:var(--primary-2);border-width:2px;background:rgba(59,130,246,.06);box-shadow:0 4px 16px rgba(59,130,246,.12)}

.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .35s ease;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.product-card:hover{transform:translateY(-6px);border-color:rgba(59,130,246,.3);box-shadow:var(--shadow-lg)}
.product-image{width:100%;height:240px;overflow:hidden;background:rgba(0,0,0,.3);position:relative}
.product-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.product-card:hover .product-image img{transform:scale(1.06)}
.product-info{padding:20px;display:flex;flex-direction:column;gap:12px;flex:1}
.product-title{font-size:20px;font-weight:700;color:var(--primary);margin:0}
.product-description{font-size:14px;color:var(--muted);line-height:1.5;margin:0}
.product-specs{display:flex;gap:8px;flex-wrap:wrap}
.spec-item{font-size:12px;padding:4px 10px;background:rgba(30,64,175,.06);border:1px solid rgba(30,64,175,.12);border-radius:12px;color:var(--text)}
.product-price{font-size:22px;font-weight:700;color:var(--primary);margin-top:auto;padding-top:8px}

.cart-notification{position:fixed;top:80px;right:20px;background:var(--primary);color:#fff;padding:16px 24px;border-radius:var(--radius);font-weight:600;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:9999;opacity:0;transform:translateX(100px);transition:all .3s}
.cart-notification.show{opacity:1;transform:translateX(0)}
.cart-badge{position:absolute;top:-8px;right:-8px;background:#ff4444;color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;display:none}

.cart-icon-btn{background:transparent;border:none;color:rgba(255,255,255,.85);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:4px}
.cart-icon-btn:hover{background:rgba(255,255,255,.15);color:#fff}
.cart-icon-btn svg{width:24px;height:24px}

.cart-dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9998;display:none!important}
.cart-dropdown-overlay.show{display:block!important}
.cart-dropdown{position:fixed;top:0;right:0;width:420px;max-width:90vw;height:100vh;background:var(--surface);box-shadow:-4px 0 24px rgba(0,0,0,.3);z-index:9999;display:none!important;flex-direction:column;transform:translateX(100%);transition:transform .3s}
.cart-dropdown.show{display:flex!important;transform:translateX(0)}
.cart-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border)}
.cart-dropdown-header h3{margin:0;font-size:20px;color:var(--primary)}
.cart-dropdown-close{background:transparent;border:none;color:var(--text);font-size:32px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}
.cart-dropdown-close:hover{color:var(--primary)}
.cart-dropdown-body{flex:1;overflow-y:auto;padding:20px}
.cart-dropdown-footer{padding:20px;border-top:1px solid var(--border);background:var(--surface-alt)}

.cart-section{background:rgba(30,64,175,.04);border:1px solid rgba(30,64,175,.1);border-radius:var(--radius);padding:20px;margin-bottom:24px}
.cart-select-all{padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:12px}
.cart-items{display:flex;flex-direction:column;gap:12px}
.cart-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.cart-item-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--primary);flex-shrink:0}
.cart-item-info{flex:1}
.cart-item-name{font-weight:700;color:var(--text);margin-bottom:4px}
.cart-item-specs{font-size:13px;color:var(--muted);margin-bottom:8px}
.cart-item-price{font-size:16px;font-weight:600;color:var(--text)}
.cart-item-controls{display:flex;align-items:center;gap:12px}
.cart-qty-btn{width:32px;height:32px;border:1px solid var(--border);background:var(--surface-alt);color:var(--text);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}
.cart-qty-btn:hover{border-color:var(--primary-2);color:var(--primary)}
.cart-qty{font-weight:700;min-width:30px;text-align:center}
.cart-remove-btn{color:#ff4444;cursor:pointer;padding:8px;transition:opacity .2s}
.cart-remove-btn:hover{opacity:.7}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);font-size:20px;font-weight:700}
.cart-total-label{color:var(--text)}
.cart-total-amount{color:var(--primary)}
.cart-actions{display:flex;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.cart-actions .btn{flex:1}
.cart-actions .btn-sm{padding:10px 16px;font-size:14px}
.cart-empty{text-align:center;padding:32px;color:var(--muted)}

.site-footer{padding:32px 0;border-top:1px solid rgba(255,255,255,.08);background:#0F172A}
.footer-contacts{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:center;margin-bottom:24px}
.footer-contact-item{display:flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:50px;transition:all .25s;font-size:13px;color:rgba(255,255,255,.75)}
.footer-contact-item:hover{background:rgba(59,130,246,.15);border-color:rgba(59,130,246,.4);transform:translateY(-2px);color:#fff}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;color:var(--primary-2)}
.footer-contact-item span{white-space:nowrap}
.footer-copyright{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;color:rgba(255,255,255,.4);font-size:13px}
.footer-logo{width:72px;height:72px;border-radius:50%;object-fit:contain;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.footer-brand{font-weight:750;color:#D4AF37;font-size:17px;letter-spacing:.3px}/* keep gold */

/* Service Wizard */
.service-wizard{background:#FFFFFF;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.wizard-step{display:none;opacity:0;transform:translateX(50px);transition:all .5s ease}
.wizard-step.active{display:block;opacity:1;transform:translateX(0)}
.step-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.step-header .back-btn{display:flex;align-items:center;gap:8px;background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:8px 16px;color:var(--text);cursor:pointer;transition:all .3s;font-size:14px}
.step-header .back-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.step-title{font-size:24px;font-weight:700;color:var(--primary);margin:0}

/* Step 1: Service Grid */
.service-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.service-grid .service-card-wizard{flex:0 1 calc(33.333% - 14px);min-width:220px;max-width:320px}
.service-card-wizard{background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:24px;text-align:center;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.service-card-wizard::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--primary),transparent);opacity:0;transition:opacity .3s}
.service-card-wizard:hover{transform:translateY(-8px);border-color:var(--primary-2);box-shadow:0 12px 32px rgba(59,130,246,.15)}
.service-card-wizard:hover::before{opacity:.05}
.service-card-wizard.selected{border-color:var(--primary-2);background:rgba(59,130,246,.06);box-shadow:0 0 0 4px rgba(59,130,246,.1)}
.service-icon-wizard{width:60px;height:60px;margin:0 auto 16px;color:var(--primary);display:flex;align-items:center;justify-content:center;background:rgba(30,64,175,.08);border-radius:50%;transition:all .3s}
.service-card-wizard:hover .service-icon-wizard{transform:scale(1.1);background:var(--primary);color:#fff}
.service-icon-wizard svg{width:30px;height:30px}
.service-card-wizard h4{font-size:18px;font-weight:700;color:var(--primary);margin:0 0 8px}
.service-card-wizard p{font-size:14px;color:var(--muted);line-height:1.5;margin:0}

/* Step 2: Types Grid */
.types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.type-card{background:var(--surface);border:2px solid var(--border);border-radius:10px;padding:20px;cursor:pointer;transition:all .3s;text-align:center}
.type-card:hover{transform:translateY(-4px);border-color:var(--primary-2);box-shadow:0 8px 24px rgba(59,130,246,.12)}
.type-card.selected{border-color:var(--primary-2);background:rgba(59,130,246,.06)}
.type-card h4{font-size:16px;font-weight:600;color:var(--primary);margin:0 0 8px}
.type-card p{font-size:13px;color:var(--muted);margin:0}

/* Step 3: Specs Grid */
.specs-grid{display:grid;gap:16px}
.spec-card{background:var(--surface);border:2px solid var(--border);border-radius:10px;padding:20px;cursor:pointer;transition:all .3s;display:flex;justify-content:space-between;align-items:center}
.spec-card:hover{transform:translateX(8px);border-color:var(--primary-2);box-shadow:0 8px 24px rgba(59,130,246,.12)}
.spec-card.selected{border-color:var(--primary-2);background:rgba(59,130,246,.06)}
.spec-info h4{font-size:16px;font-weight:600;color:var(--primary);margin:0 0 4px}
.spec-info p{font-size:14px;color:var(--muted);margin:0}
.spec-price{font-size:20px;font-weight:700;color:var(--primary)}

/* Step 4: Summary */
.summary-content{background:var(--surface);border-radius:12px;padding:32px;text-align:center}
.selected-service{margin-bottom:32px}
.selected-service h4{font-size:18px;color:var(--primary);margin:0 0 16px}
.selected-service .service-path{font-size:16px;color:var(--text);margin:4px 0}
.selected-service .final-price{font-size:28px;font-weight:700;color:var(--primary);margin:16px 0}
.summary-actions{display:flex;gap:16px;justify-content:center;align-items:center}
.btn-secondary{background:var(--accent);color:#fff;border:2px solid var(--accent)}
.btn-secondary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff;transform:translateY(-2px)}

/* Mobile Responsive */
@media (max-width: 768px){
  .service-grid .service-card-wizard{flex:0 1 100%;max-width:100%}
  .types-grid{grid-template-columns:1fr}
  .summary-actions{flex-direction:column}
  .step-title{font-size:20px}
}

.carousel{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border);background:#000;box-shadow:var(--shadow)}
.carousel-track{position:relative;width:100%;aspect-ratio:16/9}
.carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s ease;display:flex;align-items:center;justify-content:center;background:#000}
.carousel-slide.active{opacity:1}
.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block;cursor:pointer;transition:transform .3s}
.carousel-slide img:hover{transform:scale(1.02)}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(0,0,0,.55);color:#fff;border:1px solid rgba(255,255,255,.25);width:44px;height:44px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;backdrop-filter:blur(4px)}
.carousel-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.5)}
.carousel-prev{left:14px}
.carousel-next{right:14px}
.carousel-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:5}
.carousel-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:all .2s;border:1px solid rgba(255,255,255,.15)}
.carousel-dot.active{background:#fff;border-color:#fff;transform:scale(1.2)}

/* All content images are clickable for full view */
.carousel-slide img,
.client-logo-img,
.client-gallery-main img,
main img{cursor:pointer}

.lightbox{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.95);backdrop-filter:blur(12px);align-items:center;justify-content:center;flex-direction:column;gap:8px;padding:40px 0 12px}
.lightbox.open{display:flex}
.lightbox-main{position:relative;display:flex;align-items:center;justify-content:center}
.lightbox img{max-width:88vw;max-height:70vh;object-fit:contain;border-radius:8px;box-shadow:0 12px 40px rgba(0,0,0,.6);display:block}
.lightbox-close{position:fixed;top:16px;right:24px;color:#fff;font-size:36px;cursor:pointer;background:none;border:none;line-height:1;opacity:.7;transition:opacity .2s;z-index:2001}
.lightbox-close:hover{opacity:1}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:2001;background:rgba(0,0,0,.6);color:#fff;border:1px solid rgba(255,255,255,.2);width:48px;height:48px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;backdrop-filter:blur(4px)}
.lightbox-nav:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4)}
.lightbox-nav:disabled{opacity:.3;cursor:default}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-counter{color:rgba(255,255,255,.7);font-size:14px;font-weight:600;letter-spacing:1px}
.lightbox-thumbs{display:flex;gap:6px;overflow-x:auto;padding:4px 20px;max-width:92vw;justify-content:center}
.lightbox-thumb{width:56px;height:56px;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid transparent;opacity:.5;transition:all .2s;flex-shrink:0}
.lightbox-thumb:hover{opacity:.8}
.lightbox-thumb.active{opacity:1;border-color:#fff}

@media (max-width: 760px){.carousel-track{aspect-ratio:16/9}.carousel-btn{width:36px;height:36px;font-size:16px}.lightbox-nav{width:36px;height:36px;font-size:16px}.lightbox-prev{left:8px}.lightbox-next{right:8px}.lightbox-thumbs{gap:4px;padding:4px 8px 8px}.lightbox-thumb{width:44px;height:44px}}
@media (max-width: 480px){.carousel-track{aspect-ratio:4/3}}

.clients-pyramid{display:flex;flex-direction:column;gap:16px;align-items:center}
.clients-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.client-logo{background:#FFFFFF;border-radius:var(--radius);padding:20px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:140px;width:220px;border:1px solid #E2E8F0;transition:all .3s ease;cursor:pointer;box-shadow:var(--shadow-sm)}

.flatpickr-calendar{font-family:inherit;border-radius:var(--radius-sm);box-shadow:0 4px 20px rgba(0,0,0,.12);border:1px solid var(--border)}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.flatpickr-day.today{border-color:var(--primary-2);color:var(--primary)}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover{color:#e74c3c !important;text-decoration:line-through;opacity:.5;cursor:not-allowed}
.flatpickr-months .flatpickr-month{color:var(--text);fill:var(--text)}
.flatpickr-current-month .flatpickr-monthDropdown-months,.flatpickr-current-month input.cur-year{color:var(--text);font-weight:600}

.service-info-grid{margin-top:16px;display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.service-info-item{display:flex;align-items:center;gap:10px;padding:12px 14px;font-size:13px;color:var(--text);border-bottom:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface);transition:background .2s}
.service-info-item:hover{background:rgba(30,64,175,.04)}
.service-info-item:nth-child(2n){border-right:none}
.service-info-item:nth-last-child(-n+2){border-bottom:none}
.service-info-item svg{flex-shrink:0;color:var(--primary)}
.service-info-item a{color:var(--primary);text-decoration:none;font-weight:500;transition:opacity .2s}
.service-info-item a:hover{opacity:.75;text-decoration:underline}
@media(max-width:480px){.service-info-grid{grid-template-columns:1fr}.service-info-item:nth-child(2n){border-right:none}.service-info-item{border-right:none!important}.service-info-item:last-child{border-bottom:none}}

.fb-carousel{position:relative}
.fb-carousel-track{min-height:200px}
.fb-page{display:flex;flex-direction:column;gap:12px;animation:fbFadeIn .4s ease}
@keyframes fbFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fb-carousel-controls{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px}
.fb-prev,.fb-next{background:none;border:1px solid var(--border);color:var(--text);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.fb-prev:hover,.fb-next:hover{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px rgba(30,64,175,.2)}
.fb-dots{display:flex;gap:6px}
.fb-dot{background:none;border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s}
.fb-dot.fb-dot-active{background:var(--primary);color:#fff;border-color:var(--primary)}
.feedback-item{padding:18px 20px;background:#F8FAFC;border-left:3px solid var(--primary-2);border-radius:var(--radius-sm);transition:all .3s;flex-shrink:0;box-shadow:var(--shadow-sm)}
.feedback-item:hover{background:#F1F5F9;transform:translateX(4px);box-shadow:var(--shadow)}
.feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.feedback-header strong{color:#1E293B;font-size:14px;font-weight:600}
.feedback-rating{color:#f4c430;font-size:13px;letter-spacing:2px}
.feedback-text{margin:0;color:var(--muted);font-size:13px;line-height:1.7;font-style:italic}

.star-rating{display:flex;gap:6px;margin:4px 0 8px}
.star-rating .star{font-size:32px;color:#CBD5E1;cursor:pointer;transition:color .2s,transform .2s;user-select:none}
.star-rating .star:hover,.star-rating .star.hovered{color:#f4c430;transform:scale(1.15)}
.star-rating .star.active{color:#f4c430}
.client-logo:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(59,130,246,.3)}
.client-logo-img{max-width:100%;max-height:120px;width:auto;height:auto;object-fit:contain;padding:8px}

.client-gallery-modal{display:none;position:fixed;inset:0;z-index:3000;align-items:center;justify-content:center}
.client-gallery-modal.open{display:flex}
.client-gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,.95);backdrop-filter:blur(12px)}
.client-gallery-content{position:relative;z-index:1;background:rgba(10,10,10,.98);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:32px 24px 24px;max-width:90vw;max-height:90vh;width:900px;display:flex;flex-direction:column;gap:16px}
.client-gallery-close{position:absolute;top:12px;right:16px;color:#fff;font-size:36px;cursor:pointer;background:none;border:none;line-height:1;opacity:.7;transition:opacity .2s;z-index:10}
.client-gallery-close:hover{opacity:1}
.client-gallery-title{margin:0;font-size:22px;text-align:center;color:#fff;padding:0 40px}
.client-gallery-slider{position:relative;display:flex;align-items:center;gap:12px;flex:1;min-height:300px;max-height:400px}
.client-gallery-main{flex:1;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);border-radius:8px;overflow:hidden;min-height:300px;max-height:400px}
.client-gallery-main img{max-width:100%;max-height:350px;object-fit:contain;border-radius:4px}
.client-gallery-nav{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:24px;width:48px;height:48px;border-radius:50%;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.client-gallery-nav:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.4)}
.client-gallery-nav:disabled{opacity:.3;cursor:not-allowed}
.client-gallery-counter{text-align:center;color:var(--muted);font-size:14px}
.client-gallery-thumbnails{display:flex;gap:8px;overflow-x:auto;padding:8px 0;justify-content:center}
.client-gallery-thumb{width:80px;height:60px;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:all .2s;opacity:.6}
.client-gallery-thumb:hover{opacity:1;border-color:rgba(255,255,255,.4)}
.client-gallery-thumb.active{opacity:1;border-color:#fff}

@media (max-width: 480px){.client-logo{width:calc(50% - 8px);min-height:120px;padding:14px 10px}.clients-row{gap:10px}.clients-pyramid{gap:10px}}

.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:fadeIn .25s;overflow-y:auto;align-items:center;justify-content:center;flex-direction:column}
.modal[style*="block"]{display:flex}
.modal-content{background:var(--surface);color:var(--text);margin:40px auto;padding:28px;border:1px solid var(--border);border-radius:16px;width:88%;max-width:460px;box-shadow:0 24px 64px rgba(0,0,0,.4);position:relative;animation:slideIn .3s ease;flex-shrink:0}
.close-button{position:absolute;top:12px;right:16px;color:var(--muted);font-size:28px;font-weight:700;cursor:pointer;line-height:1}
.close-button:hover{color:var(--text)}
.modal h2{margin:0 0 16px;color:var(--text)}
#modalBookingDetails dl.summary{margin:0}
#modalBookingDetails .summary-row{padding:8px 0;border-bottom:1px dashed var(--border)}
#modalBookingDetails .summary-row:last-child{border-bottom:none}
#modalBookingDetails dt{color:var(--muted)}
#modalBookingDetails dd{margin:0;text-align:right;color:var(--text)}
.modal-breakdown{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:22px;margin-top:20px}
.modal-breakdown-title{font-size:16px;font-weight:700;color:var(--text);margin:0 0 14px}
.modal-breakdown .breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}
.modal-breakdown .breakdown-row:last-child{border-bottom:none}
.modal-breakdown .breakdown-row span:last-child{font-weight:600;color:var(--primary)}
.modal-breakdown .breakdown-total-row{border-bottom:none;border-top:2px solid var(--primary);margin-top:6px;padding-top:12px}
.modal-breakdown .breakdown-total-row span{font-size:16px;font-weight:700;color:var(--primary)}
.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}

@media (max-width: 900px){
  .hero-inner{grid-template-columns:1fr}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .hero h1:not(.hero-tagline){font-size:36px}
}

@media (max-width: 760px){
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .brand{min-width:auto}
  .table{min-width:760px}
  .container{padding:0 16px}
  .section{padding:40px 0}
  .hero{padding:40px 0 28px}
  .hero h1:not(.hero-tagline){font-size:32px}
  .booking-container{flex-direction:column}
  .booking-form-card{max-width:100%}
  .booking-layout{grid-template-columns:1fr;gap:16px}
  .payment-breakdown-section{position:static}
  .payment-options{grid-template-columns:1fr;gap:10px}
  .products-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
  .product-image{height:200px}
  .product-title{font-size:18px}
  .product-price{font-size:20px}
}

@media (max-width: 480px){
  .hero h1:not(.hero-tagline){font-size:28px}
  .lead{font-size:15px}
  .container{padding:0 12px}
  .section{padding:32px 0}
  .card{padding:14px}
  .btn{padding:10px 14px;font-size:14px}
  .nav{gap:6px}
  .nav-link{font-size:13px}
  .card-title{font-size:16px}
  .footer-contacts{gap:8px}
  .footer-contact-item{font-size:12px;padding:6px 10px;flex:1 1 auto;justify-content:center}
  .footer-contact-item svg{width:16px;height:16px}
  .footer-contact-item span{font-size:11px}
  .pill{font-size:11px;padding:6px 8px}
  .page-back-btn{padding:6px 14px;font-size:13px}
  .page-back-btn svg{width:14px;height:14px}
}

/* Back Button (pill with border) */
.page-back-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 18px;
  background:var(--surface);
  color:var(--muted);
  border:1px solid var(--border);
  border-radius:50px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:all .3s ease;
  font-family:inherit;
  margin-bottom:12px;
  box-shadow:var(--shadow-sm);
}
.page-back-btn:hover{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
  box-shadow:0 4px 16px rgba(30,64,175,.2);
  transform:translateX(-3px);
}
.page-back-btn svg{
  flex-shrink:0;
  transition:transform .3s;
}
.page-back-btn:hover svg{
  transform:translateX(-3px);
}

/* ============================================
   BOOKING WIZARD — 3-Step Flow
   ============================================ */

/* Progress Bar */
.bw-progress{max-width:680px;margin:0 auto 32px;position:relative}
.bw-progress-track{height:4px;background:var(--border);border-radius:4px;position:absolute;top:18px;left:40px;right:40px;z-index:0}
.bw-progress-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .45s cubic-bezier(.4,0,.2,1);width:0}
.bw-steps{display:flex;justify-content:space-between;position:relative;z-index:1}
.bw-step{display:flex;flex-direction:column;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:opacity .2s}
.bw-step-num{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border:2.5px solid var(--border);background:var(--surface);color:var(--muted);transition:all .35s cubic-bezier(.4,0,.2,1)}
.bw-step-label{font-size:12px;font-weight:600;color:var(--muted);transition:color .3s;white-space:nowrap}
.bw-step.active .bw-step-num{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 3px 12px rgba(30,64,175,.25)}
.bw-step.active .bw-step-label{color:var(--primary);font-weight:700}
.bw-step.completed .bw-step-num{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 3px 12px rgba(30,64,175,.25)}
.bw-step.completed .bw-step-label{color:var(--primary)}

/* Step Panels */
.bw-panel{display:none;animation:bwFadeIn .35s ease}
.bw-panel.active{display:block}
@keyframes bwFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Card Styling */
.bw-card{max-width:720px;margin:0 auto}
.bw-card-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.bw-card-icon{flex-shrink:0;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(30,64,175,.08);color:var(--primary)}
.bw-divider{border:none;border-top:1px dashed var(--border);margin:24px 0}

/* Navigation Buttons */
.bw-nav{display:flex;justify-content:space-between;align-items:center;max-width:720px;margin:20px auto 0;gap:12px}
.bw-next-btn,.bw-submit-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;font-size:15px;font-weight:700;border-radius:50px;transition:all .3s}
.bw-next-btn svg,.bw-submit-btn svg,.bw-back-btn svg{flex-shrink:0;transition:transform .3s}
.bw-next-btn:hover svg{transform:translateX(3px)}
.bw-back-btn:hover svg{transform:translateX(-3px)}
.bw-back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:50px;font-size:14px;font-weight:600}

/* Add Row Button */
.bw-add-row-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;background:transparent;border:1.5px dashed var(--primary-2);color:var(--primary);padding:10px 16px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .25s}
.bw-add-row-btn:hover{background:rgba(30,64,175,.04);border-style:solid}

/* Mini Breakdown (Step 2) */
.bw-mini-breakdown{margin-top:20px;padding:16px;background:rgba(30,64,175,.04);border:1px solid rgba(30,64,175,.1);border-radius:12px}
.bw-mini-title{font-size:13px;font-weight:700;color:var(--primary);margin:0 0 12px;display:flex;align-items:center;gap:6px}
.bw-mini-title svg{flex-shrink:0}
.bw-mini-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text);border-bottom:1px solid rgba(30,64,175,.08)}
.bw-mini-row:last-of-type{border-bottom:none}
.bw-mini-row span:last-child{font-weight:700;color:var(--primary);white-space:nowrap}
.bw-mini-total{display:flex;justify-content:space-between;align-items:center;padding:10px 0 0;margin-top:8px;border-top:2px solid var(--primary);font-size:15px;font-weight:800;color:var(--primary)}
.bw-mini-empty{font-size:13px;color:var(--muted);text-align:center;padding:8px 0}

/* Step 3 Payment Layout */
.bw-payment-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:960px;margin:0 auto;align-items:start}
.bw-payment-layout .bw-card{max-width:none}
.bw-breakdown-card{position:sticky;top:80px}
#bwStep3 > .bw-nav{max-width:960px}

/* ---- Responsive Booking Wizard ---- */
@media (max-width: 760px){
  .bw-progress{margin-bottom:24px}
  .bw-progress-track{left:28px;right:28px}
  .bw-step-num{width:32px;height:32px;font-size:13px}
  .bw-step-label{font-size:11px}
  .bw-card{padding:18px}
  .bw-nav{flex-direction:column-reverse;gap:10px}
  .bw-nav .btn{width:100%;justify-content:center}
  .bw-payment-layout{grid-template-columns:1fr;gap:16px}
  .bw-breakdown-card{position:static}
}
@media (max-width: 480px){
  .bw-progress-track{left:20px;right:20px;top:14px}
  .bw-step-num{width:28px;height:28px;font-size:12px;border-width:2px}
  .bw-step-label{font-size:10px}
  .bw-card-header{gap:10px}
  .bw-card-icon{width:36px;height:36px;border-radius:10px}
  .bw-card-icon svg{width:18px;height:18px}
  .bw-next-btn,.bw-submit-btn{padding:11px 22px;font-size:14px}
}
