:root{
  --bg:#F6F8FB;
  --surface:#FFFFFF;
  --surface-2:#F8FAFC;
  --text:#0F172A;
  --muted:#64748B;
  --line:rgba(15,23,42,.08);
  --line-strong:rgba(15,23,42,.12);
  --navy:#0F172A;
  --brand:#F7B500;
  --brand-2:#FF9F1C;
  --teal:#1AA3C8;
  --shadow:0 20px 50px rgba(15,23,42,.08);
  --shadow-sm:0 10px 24px rgba(15,23,42,.06);
  --radius:24px;
  --radius-lg:32px;
}

*{box-sizing:border-box}

.contact-page{
  background:
    radial-gradient(700px 280px at 10% 0%, rgba(247,181,0,.08), transparent 60%),
    radial-gradient(640px 260px at 100% 10%, rgba(26,163,200,.06), transparent 60%),
    linear-gradient(180deg, #f8fafc 0%, #ffffff 26%, #f8fafc 100%);
  overflow:hidden;
}

.section-shell{
  width:min(1280px, calc(100% - 40px));
  margin-inline:auto;
}

.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color: rgba(255,255,255,.90);
  font-size:20px;
  font-weight:1000;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.dot{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 6px rgba(255,183,3,.18);}
.section-kickers {
  display:inline-flex;
  align-items:center;
  gap:8px;
  color: var(--brand);
  font-size:20px;
  font-weight:1000;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.section-titles{
  margin:10px 0 0;
  color:var(--text);
  font-size:clamp(30px, 4vw, 54px);
  line-height:1.04;
  letter-spacing:-.04em;
  font-weight:1000;
}

.section-descs{
  margin:12px 0 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.95;
  max-width:64ch;
}

/* HERO */
.contact-hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
}
.contact-hero__bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.contact-hero__bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.06);
  animation:heroZoom 18s ease-in-out infinite alternate;
}
@keyframes heroZoom{
  0%{ transform:scale(1.06) translateY(0); }
  100%{ transform:scale(1.14) translateY(-12px); }
}
.contact-hero__overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg, rgba(15,23,42,.88) 0%, rgba(15,23,42,.62) 42%, rgba(15,23,42,.26) 100%),
    radial-gradient(760px 320px at 18% 22%, rgba(247,181,0,.16), transparent 60%),
    radial-gradient(620px 260px at 84% 78%, rgba(26,163,200,.10), transparent 60%);
}
html[dir="rtl"] .contact-hero__overlay{
   background:
    linear-gradient(270deg, rgba(15,23,42,.65) 0%, rgba(15,23,42,.35) 45%, rgba(15,23,42,.20) 100%),
    radial-gradient(900px 500px at 75% 35%, rgba(255,183,3,.18), transparent 55%);
}

.contact-hero__grid{
  position:relative;
  z-index:2;
  width:min(1380px, calc(100% - 40px));
  margin-inline:auto;
  padding:132px 0 60px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:28px;
}
@media(max-width:980px){
  .contact-hero__grid{
    grid-template-columns:1fr;
    padding:110px 0 44px;
  }
}

.contact-hero__copy{
  color:#fff;
  max-width:760px;
}
.contact-hero__title{
  margin:18px 0 0;
  color:#fff;
  font-size:clamp(42px, 5vw, 78px);
  line-height:1;
  letter-spacing:-.05em;
  font-weight:1000;
}
.contact-hero__title .accent{
  color:var(--brand);
}
.contact-hero__sub{
  margin:18px 0 0;
  color:rgba(255,255,255,.82);
  font-size:15px;
  line-height:2;
  max-width:58ch;
}
.contact-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:26px;
}

.btnx{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  padding:14px 18px;
  border-radius:18px;
  text-decoration:none;
  font-weight:1000;
  transition:.24s ease;
}
.btnx:hover{ transform:translateY(-2px); }
.btnx-primary{
  background:linear-gradient(135deg, var(--brand), #ffd15f);
  color:#111;
  box-shadow:0 18px 36px rgba(247,181,0,.22);
}
.btnx-ghost{
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(10px);
}

.contact-hero__panel{
  align-self:end;
  justify-self:end;
  width:min(100%, 380px);
  padding:24px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 22px 60px rgba(0,0,0,.26);
  backdrop-filter:blur(14px);
}
@media(max-width:980px){
  .contact-hero__panel{ justify-self:start; }
}
.contact-hero__panelLabel{
  color:rgba(255,255,255,.64);
  font-size:12px;
  font-weight:1000;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.contact-hero__panelTitle{
  margin:10px 0 0;
  color:#fff;
  font-size:28px;
  line-height:1.08;
  font-weight:1000;
}
.contact-hero__panelText{
  margin:12px 0 0;
  color:rgba(255,255,255,.78);
  line-height:1.9;
  font-size:13px;
}
.contact-hero__mini{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:18px;
}
.contact-hero__miniCard{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.contact-hero__miniNum{
  color:#fff;
  font-size:24px;
  font-weight:1000;
  line-height:1;
}
.contact-hero__miniTxt{
  margin-top:8px;
  color:rgba(255,255,255,.70);
  font-size:12px;
  line-height:1.8;
}


/* =========================
   CONTACT PAGE — MOBILE FINAL PATCH
========================= */
@media (max-width: 980px){
  .section-shell{
    width:min(100%, calc(100% - 24px));
  }

  .contact-hero{
    min-height:auto;
    padding-bottom:24px;
  }

  .contact-hero__grid{
    width:min(100%, calc(100% - 24px));
    grid-template-columns:1fr;
    gap:18px;
    padding:110px 0 28px;
  }

  .contact-hero__copy{
    max-width:100%;
    text-align:center;
    margin-inline:auto;
  }

  .contact-hero__sub{
    max-width:36ch;
    margin-inline:auto;
  }

  .contact-hero__actions{
    width:100%;
    justify-content:center;
  }

  .contact-hero__panel{
    justify-self:stretch;
    width:100%;
    max-width:none;
  }

  .quickbar{
    margin-top:0;
  }

  .blockx,
  .contact-main,
  .mapx{
    padding:64px 0 0;
  }

  .finalCta{
    padding:64px 0 80px;
  }
}

@media (max-width: 768px){
  .section-shell{
    width:min(100%, calc(100% - 18px));
  }

  .section-kicker,
  .section-kickers{
    font-size:13px;
    letter-spacing:.08em;
    gap:6px;
    margin-bottom:10px;
  }

  .section-titles{
    font-size:clamp(26px, 8.5vw, 38px);
    line-height:1.06;
    
  }

  .section-descs{
    font-size:13px;
    line-height:1.85;
    max-width:100%;
  }

  .contact-hero{
    min-height:93svh;
  }

  .contact-hero__bg img{
    transform:scale(1.04);
    animation:none;
  }

  .contact-hero__overlay{
    background:
      linear-gradient(180deg, rgba(15,23,42,.82) 0%, rgba(15,23,42,.62) 48%, rgba(15,23,42,.36) 100%),
      radial-gradient(520px 240px at 20% 18%, rgba(247,181,0,.12), transparent 60%);
  }

  html[dir="rtl"] .contact-hero__overlay{
    background:
      linear-gradient(180deg, rgba(15,23,42,.82) 0%, rgba(15,23,42,.62) 48%, rgba(15,23,42,.36) 100%),
      radial-gradient(520px 240px at 80% 18%, rgba(247,181,0,.12), transparent 60%);
  }

  .contact-hero__grid{
  width:min(100%, calc(100% - 18px));
  padding:70px 0 22px;
  gap:14px;
}

  .contact-hero__title{
    font-size:clamp(32px, 11vw, 48px);
    line-height:1.02;
    letter-spacing:-.04em;
    margin-bottom:12px;
    font-weight:1000;
     text-shadow:
    0 6px 20px rgba(0,0,0,.35),
    0 2px 6px rgba(0,0,0,.25);
  }

  .contact-hero__sub{
  margin-top:10px;
  font-size:13px;
  line-height:1.8;
  max-width:26ch;
}

  .contact-hero__actions{
    margin-top:18px;
    flex-direction:column;
    gap:14px;
  }

  .btnx{
    width:100%;
    min-height:50px;
    border-radius:16px;
    font-size:13px;
    padding:12px 14px;
  }
.btnx-primary:hover{
  transform:translateY(-3px) scale(1.01);
}
  .contact-hero__panel{
    padding:18px;
    border-radius:22px;
  }

  .contact-hero__panelTitle{
    font-size:22px;
  }

  .contact-hero__panelText{
    font-size:12px;
    line-height:1.8;
  }

  .contact-hero__mini{
    grid-template-columns:1fr;
    gap:10px;
  }

  .contact-hero__miniCard{
    padding:14px;
    border-radius:16px;
  }

  .contact-hero__miniNum{
    font-size:20px;
  }

  .quickbar__card{
    min-height:80px;
    padding:16px;
    border-radius:22px;
  }

  .quickbar__icon{
    width:44px;
    height:44px;
    border-radius:14px;
    font-size:16px;
  }

  .quickbar__value{
    font-size:14px;
    line-height:1.6;
  }

  .contact-hero__copy{
  background:linear-gradient(180deg, rgba(15,23,42,.25), rgba(15,23,42,.05));
  border-radius:18px;
  padding:10px 6px;
}
}

  .cardx,
  .cardx-dark{
    border-radius:24px;
  }

  .hoursx-body,
  .infoPanel,
  .formPanel,
  .finalCta__box{
    padding:18px;
  }

  .hoursx-row{
    padding:14px 0;
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }

  .hoursx-big{
    font-size:34px;
  }

  .hoursx-note{
    font-size:13px;
    line-height:1.8;
  }

  .contact-main__grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .infoPanel__title{
    font-size:clamp(24px, 8vw, 34px);
    line-height:1.08;
  }

  .infoPanel__text{
    font-size:13px;
    line-height:1.85;
  }

  .infoPanel__list{
    gap:12px;
    margin-top:18px;
  }

  .infoItem{
    padding:14px;
    border-radius:18px;
    gap:12px;
    align-items:flex-start;
  }

  .infoItem__icon{
    width:42px;
    height:42px;
    border-radius:14px;
    font-size:15px;
  }

  .infoItem__label{
    font-size:11px;
  }

  .infoItem__value{
    font-size:14px;
    line-height:1.75;
  }

  .phonesRow{
    gap:6px;
  }

  .phoneDivider{
    display:none;
  }

  .infoPanel__actions{
    grid-template-columns:1fr;
    gap:10px;
  }

  .infoAction{
    min-height:48px;
    border-radius:16px;
    font-size:13px;
    padding:12px 14px;
  }

  .formShell{
    padding:18px;
    border-radius:22px;
  }

  .formPanel__title{
    font-size:26px;
  }

  .formPanel__text{
    font-size:12px;
    line-height:1.8;
  }

  .form-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .field{
    min-height:50px;
    padding:12px 14px;
    border-radius:14px;
    font-size:14px;
  }

  .field-textarea{
    min-height:150px !important;
    margin-top:10px;
  }

  .submitBtn{
    min-height:52px;
    font-size:14px;
    border-radius:16px;
    margin-top:12px;
  }

  .mapx-topbar{
    gap:10px;
    margin-bottom:12px;
  }

  .mapx-chip{
    width:100%;
    justify-content:center;
    min-height:42px;
    font-size:12px;
    padding:10px 12px;
  }

  .mapx-actions{
    grid-template-columns:1fr;
    gap:10px;
  }

  .mapx-btn{
    min-height:48px;
    border-radius:16px;
    font-size:13px;
    padding:12px 14px;
  }

  .mapx-frame{
    height:320px;
  }

  .mapx-note{
    font-size:12px;
    line-height:1.75;
  }

  .finalCta__grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .finalCta__title{
    font-size:clamp(26px, 8.5vw, 36px);
    line-height:1.06;
  }

  .finalCta__text{
    font-size:13px;
    line-height:1.85;
  }

  .finalCta__actions{
    flex-direction:column;
    justify-content:flex-start;
    gap:10px;
  }

  .finalCta__actions .btnx{
    width:100%;
  }

  
@media (max-width: 480px){
  .section-shell{
    width:min(100%, calc(100% - 14px));
  }

  .contact-hero__grid{
    width:min(100%, calc(100% - 14px));
    padding:88px 0 18px;
  }

  .contact-hero__title{
    font-size:clamp(28px, 10vw, 38px);
  }

  .contact-hero__sub{
    max-width:28ch;
    font-size:12.5px;
  }

  .hoursx-big{
    font-size:30px;
  }

  .infoPanel,
  .formPanel,
  .hoursx-body,
  .finalCta__box{
    padding:14px;
  }

  .formShell{
    padding:14px;
  }

  .mapx-frame{
    height:280px;
  }
}

/* floating quick bar */
.quickbar{
  position:relative;
  margin-top:-34px;
  z-index:5;
}
.quickbar__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
@media(max-width:900px){
  .quickbar__grid{ grid-template-columns:1fr; }
}
.quickbar__card{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:92px;
  padding:20px 20px;
  border-radius:26px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(255,255,255,.74);
  backdrop-filter:blur(14px);
  box-shadow:var(--shadow);
  transition:.24s ease;
}
.quickbar__card:hover{
  transform:translateY(-4px);
  box-shadow:0 28px 56px rgba(15,23,42,.10);
}
.quickbar__icon{
  width:52px;
  height:52px;
  border-radius:18px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  color:#111;
  background:linear-gradient(135deg, var(--brand), #ffd15f);
}
.quickbar__label{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.quickbar__value{
  margin-top:4px;
  color:var(--text);
  font-size:15px;
  font-weight:1000;
  line-height:1.7;
  word-break:break-word;
}

/* generic cards */
.blockx{
  padding:84px 0 0;
}
.cardx{
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.90));
  border:1px solid rgba(255,255,255,.86);
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
}
.cardx-dark{
  color:#fff;
  background:
    linear-gradient(180deg, rgba(15,23,42,.98), rgba(15,23,42,.92)),
    radial-gradient(500px 240px at 16% 12%, rgba(247,181,0,.12), transparent 60%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 26px 70px rgba(2,6,23,.18);
}

/* hours */
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:24px;
}
.hoursx-status{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  color:var(--text);
  font-weight:1000;
}
.hoursx-status .dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#94a3b8;
  box-shadow:0 0 0 6px rgba(148,163,184,.18);
}
.hoursx-status.is-open .dot{
  background:#22c55e;
  box-shadow:0 0 0 6px rgba(34,197,94,.16);
}
.hoursx-status.is-closed .dot{
  background:#ef4444;
  box-shadow:0 0 0 6px rgba(239,68,68,.15);
}

.hoursx-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
@media(max-width:900px){
  .hoursx-grid{ grid-template-columns:1fr; }
}
.hoursx-body{ padding:26px; }
.hoursx-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 0;
  border-bottom:1px solid var(--line);
}
.hoursx-row:last-child{ border-bottom:0; }
.hoursx-row b{
  color:var(--text);
  font-size:15px;
  font-weight:1000;
}
.hoursx-row span{
  color:var(--muted);
  font-size:14px;
  font-weight:800;
}

.hoursx-liveTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.hoursx-small{
  color:rgba(255,255,255,.66);
  font-size:12px;
  font-weight:1000;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.hoursx-big{
  margin-top:6px;
  font-size:42px;
  color:#fff;
  font-weight:1000;
  letter-spacing:-.04em;
}
.hoursx-pill{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(247,181,0,.10);
  border:1px solid rgba(247,181,0,.24);
  color:#ffe19a;
  font-size:12px;
  font-weight:1000;
}
.hoursx-note{
  margin-top:16px;
  color:rgba(255,255,255,.80);
  line-height:1.9;
  font-size:14px;
}

/* main contact split */
.contact-main{
  padding:84px 0 0;
}
.contact-main__grid{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:18px;
}
@media(max-width:980px){
  .contact-main__grid{ grid-template-columns:1fr; }
}

.infoPanel{
  padding:28px;
}

.infoPanel__title{
  margin:10px 0 0;
  color:var(--text);
  font-size:clamp(28px, 3vw, 42px);
  line-height:1.06;
  font-weight:1000;
  letter-spacing:-.03em;
}

.infoPanel__text{
  margin:12px 0 0;
  color:var(--muted);
  line-height:1.95;
  font-size:14px;
}

.infoPanel__list{
  display:grid;
  gap:14px;
  margin-top:24px;
}

/* item */
.infoItem{
  display:flex;
  gap:14px;
  align-items:center;
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  border:1px solid var(--line);
  box-shadow:0 10px 24px rgba(15,23,42,.04);
}

/* RTL FIX */
html[dir="rtl"] .infoItem{
  flex-direction:row-reverse;
  text-align:right;
}

/* icon */
.infoItem__icon{
  width:50px;
  height:50px;
  border-radius:18px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  color:#9a6700;
  background:linear-gradient(135deg, rgba(247,181,0,.18), rgba(255,209,95,.28));
  border:1px solid rgba(247,181,0,.24);
}

/* content wrapper */
.infoItem__content{
  flex:1;
  min-width:0;
}

/* RTL content alignment */
html[dir="rtl"] .infoItem__content{
  text-align:right;
}

/* label */
.infoItem__label{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* value */
.infoItem__value{
  margin-top:5px;
  color:var(--text);
  font-size:15px;
  font-weight:1000;
  line-height:1.8;
  word-break:break-word;
}

.infoItem__value a{
  color:inherit;
  text-decoration:none;
}

/* actions */
.infoPanel__actions{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-top:18px;
}

@media(max-width:620px){
  .infoPanel__actions{
    grid-template-columns:1fr;
  }
}

.infoAction{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:52px;
  padding:12px 14px;
  border-radius:18px;
  text-decoration:none;
  color:var(--text);
  font-weight:1000;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:.22s ease;
}

.infoAction:hover{
  transform:translateY(-2px);
  border-color:rgba(247,181,0,.34);
}

.infoAction--primary{
  background:linear-gradient(135deg,var(--brand),#ffd15f);
  color:#111;
  border-color:transparent;
}

.phonesRow{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.phoneDivider{
  color:var(--muted);
}
/* form */
.formPanel{
  padding:28px;
}
.formShell{
  padding:26px;
  border-radius:28px;
  background:
    linear-gradient(180deg, rgba(15,23,42,.98), rgba(15,23,42,.94)),
    radial-gradient(520px 240px at 14% 10%, rgba(247,181,0,.12), transparent 60%);
  box-shadow:0 24px 60px rgba(2,6,23,.18);
}
.formPanel__title{
  margin:10px 0 0;
  color:#fff;
  font-size:32px;
  line-height:1.06;
  font-weight:1000;
  letter-spacing:-.03em;
}
.formPanel__text{
  margin:12px 0 0;
  color:rgba(255,255,255,.74);
  font-size:13px;
  line-height:1.9;
}
.alertx{
  border-radius:16px;
  padding:12px 14px;
  margin-top:16px;
  font-size:13px;
  font-weight:900;
}
.alertx-success{
  background:rgba(34,197,94,.12);
  color:#dcfce7;
  border:1px solid rgba(34,197,94,.24);
}
.alertx-error{
  background:rgba(239,68,68,.12);
  color:#fee2e2;
  border:1px solid rgba(239,68,68,.22);
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:14px;
}
@media(max-width:700px){
  .form-grid{ grid-template-columns:1fr; }
}
.field{
  width:100%;
  min-height:56px;
  padding:14px 16px;
  border-radius:16px;
  outline:none;
  color:#fff;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  transition:.22s ease;
}
.field::placeholder{
  color:rgba(255,255,255,.42);
}
.field:focus{
  border-color:rgba(247,181,0,.50);
  box-shadow:0 0 0 4px rgba(247,181,0,.14);
}
.field-textarea{
  min-height:180px !important;
  resize:vertical;
  margin-top:14px;
}
.submitBtn{
  width:100%;
  min-height:58px;
  margin-top:14px;
  border:0;
  cursor:pointer;
  border-radius:18px;
  background:linear-gradient(135deg, var(--brand), #ffd15f);
  color:#111;
  font-size:15px;
  font-weight:1000;
  box-shadow:0 18px 36px rgba(247,181,0,.22);
  transition:.22s ease;
}
.submitBtn:hover{
  transform:translateY(-2px);
}

/* map */
.mapx{
  padding:84px 0 0;
}
.mapx-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.mapx-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:44px;
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  color:var(--text);
  font-size:13px;
  font-weight:1000;
}
.mapx-actions{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-bottom:16px;
}
@media(max-width:900px){
  .mapx-actions{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:560px){
  .mapx-actions{ grid-template-columns:1fr; }
}
.mapx-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  text-decoration:none;
  font-size:14px;
  font-weight:1000;
  box-shadow:var(--shadow-sm);
  transition:.22s ease;
  cursor:pointer;
}
.mapx-btn:hover{
  transform:translateY(-2px);
  border-color:rgba(247,181,0,.34);
}
.mapx-btn--primary{
  background:linear-gradient(135deg, var(--brand), #ffd15f);
  color:#111;
  border-color:transparent;
}
.mapx-card{
  overflow:hidden;
}
.mapx-frame{
  width:100%;
  height:500px;
  display:block;
  border:0;
}
@media(max-width:700px){
  .mapx-frame{ height:340px; }
}
.mapx-note{
  margin-top:14px;
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}

/* final cta */
.finalCta{
  padding:84px 0 100px;
}
.finalCta__box{
  padding:34px;
}
.finalCta__grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:center;
}
@media(max-width:920px){
  .finalCta__grid{ grid-template-columns:1fr; }
}
.finalCta__title{
  margin:10px 0 0;
  color:#fff;
  font-size:clamp(30px, 4vw, 48px);
  line-height:1.04;
  font-weight:1000;
  letter-spacing:-.04em;
}
.finalCta__text{
  margin:12px 0 0;
  color:rgba(255,255,255,.78);
  font-size:14px;
  line-height:1.95;
  max-width:58ch;
}
.finalCta__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
}
@media(max-width:920px){
  .finalCta__actions{ justify-content:flex-start; }
}

/* subtle motion */
.quickbar__card,
.cardx,
.infoAction,
.mapx-btn,
.btnx,
.submitBtn{
  transition:
    transform .26s ease,
    box-shadow .26s ease,
    border-color .26s ease,
    background .26s ease;
}
.cardx:hover{
  transform:translateY(-3px);
}