/* =========================
   RESET
========================= */
*{margin:0;padding:0;box-sizing:border-box}
img{max-width:100%;display:block}
button{font:inherit}
html{scroll-behavior:smooth}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:#0f172a;
  background:#ffffff;
  line-height:1.6;
}

/* =========================
   TOKENS
========================= */
:root{
  --ink:#0f172a;
  --ink2:#334155;
  --muted:#f6f7fb;
  --line:#e6e8ef;

  --brand:#0b4aa2;
  --brand2:#2b6fff;
  --accent:#06b6d4;

  --radius: 18px;
  --radius2: 26px;
  --shadow: 0 18px 40px rgba(2,8,23,.10);
  --shadow2: 0 10px 26px rgba(2,8,23,.08);

  --max: 1200px;
}

/* =========================
   PROGRESS BAR
========================= */
.progress{
  position:fixed;
  top:0; left:0; right:0;
  height:3px;
  z-index: 80;
  background: transparent;
}
.progress__bar{
  height:100%;
  width:0%;
  background: linear-gradient(90deg, var(--brand2), var(--accent));
}

/* =========================
   LAYOUT
========================= */
.container{
  width:min(var(--max), calc(100% - 2rem));
  margin-inline:auto;
}
.section{
  padding: clamp(3.5rem, 6vw, 6.5rem) 0;
}
.section--muted{background: var(--muted)}
.section--primary{background: var(--brand); color:#fff}

.section__head{
  text-align:center;
  max-width: 52rem;
  margin: 0 auto clamp(2rem, 4vw, 3.5rem);
}
.section__title{
  font-size: clamp(1.85rem, 3.3vw, 3rem);
  letter-spacing:-.03em;
  margin-bottom:.75rem;
}
.section__desc{
  color: var(--ink2);
  font-size: clamp(1rem, 1.6vw, 1.15rem);
}
.section--primary .section__desc{color: rgba(255,255,255,.86)}

/* =========================
   HEADER
========================= */
.header{
  position: sticky;
  top:0;
  z-index:60;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(230,232,239,.85);
}
.header__inner{
  height: 84px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
}
.header.is-shrink .header__inner{height: 72px}
.header.is-shrink .brand__img{height: 44px}

.brand{
  background:none;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
}
.brand__img{
  height: auto;
  width:15rem;
  object-fit:contain;
}

.nav{
  display:flex;
  align-items:center;
  gap: 1.1rem;
}
.nav--desktop{display:none}
@media (min-width: 920px){
  .nav--desktop{display:flex}
}
.nav--mobile{
  flex-direction:column;
  align-items:stretch;
  padding: 1rem;
  gap:.75rem;
}

.nav__link{
  background:none;
  border:none;
  cursor:pointer;
  font-weight:800;
  font-size:.95rem;
  color: rgba(15,23,42,.82);
  padding:.4rem .25rem;
  position:relative;
  transition: color .2s ease, transform .2s ease;
}
.nav__link:hover{color: rgba(15,23,42,1); transform: translateY(-1px)}
.nav__link.is-active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-8px;
  height:2px;
  background: linear-gradient(90deg, var(--brand2), var(--accent));
  border-radius: 999px;
}

.burger{
  width:44px;height:44px;
  border:1px solid var(--line);
  border-radius: 14px;
  background:#fff;
  display:grid;
  place-items:center;
  gap:6px;
  cursor:pointer;
}
.burger span{
  width:18px;height:2px;
  background:#0f172a;
  display:block;
  border-radius:99px;
  transition: transform .25s ease, opacity .25s ease;
}
.burger.is-open span:nth-child(1){transform: translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform: translateY(-7px) rotate(-45deg)}
@media (min-width: 920px){
  .burger{display:none}
}

.mobile{
  overflow:hidden;
  max-height:0;
  transition: max-height .28s ease;
  border-top:1px solid rgba(230,232,239,.8);
}
.mobile.is-open{max-height: 520px}
.nav--mobile .nav__link{
  text-align:left;
  padding:.75rem .75rem;
  border:1px solid var(--line);
  border-radius: 14px;
  background:#fff;
}

/* =========================
   SIDE CONTACT (desktop)
========================= */
.sideContact{
  position: fixed;
  right: 18px;
  top: 110px;
  z-index: 40;
  display:none;
  gap: .7rem;
  flex-direction:column;
}
@media (min-width: 1100px){
  .sideContact{display:flex}
}
.sideContact__item{
  width: 260px;
  text-decoration:none;
  color: var(--ink);
  background:#fff;
  border:1px solid var(--line);
  border-radius: 18px;
  padding: .85rem .95rem;
  box-shadow: var(--shadow2);
  transition: transform .2s ease, box-shadow .2s ease;
}
.sideContact__item:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.sideContact__label{
  display:block;
  color: rgba(15,23,42,.55);
  font-weight:800;
  font-size: .82rem;
}
.sideContact__value{
  display:block;
  margin-top: .08rem;
  font-weight: 950;
  color: var(--brand);
}

/* =========================
   BUTTONS
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  text-decoration:none;
  border-radius: 16px;
  border:1px solid transparent;
  cursor:pointer;
  font-weight:900;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn:active{transform: translateY(1px)}
.btn--sm{padding:.6rem .9rem; font-size:.92rem}
.btn--lg{padding: .95rem 1.15rem; font-size:1rem}
.btn--full{width:100%}

.btn--primary{
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  color:#fff;
  box-shadow: 0 16px 34px rgba(43,111,255,.22);
}
.btn--primary:hover{transform: translateY(-1px)}

.btn--ghost{
  background: transparent;
  border-color: rgba(15,23,42,.22);
  color: var(--ink);
}
.btn--ghost:hover{background: rgba(15,23,42,.05)}
.btn--light{
  background:#fff;
  color: var(--brand);
  border-color: rgba(255,255,255,.45);
}
.btn__arrow{transition: transform .2s ease}
.btn:hover .btn__arrow{transform: translateX(3px)}

/* =========================
   HERO
========================= */
.hero{
  position:relative;
  padding: 3.5rem 0 2.5rem;
  overflow:hidden;
  background:
    radial-gradient(900px 420px at 15% 15%, rgba(43,111,255,.10), transparent 60%),
    radial-gradient(700px 420px at 85% 20%, rgba(6,182,212,.10), transparent 60%);
}
.hero__grid{
  display:grid;
  gap: 2rem;
  align-items:start;
}
@media (min-width: 980px){
  .hero__grid{grid-template-columns: 1.05fr .95fr}
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.5rem .85rem;
  border-radius:999px;
  background: rgba(43,111,255,.10);
  color: var(--brand);
  border: 1px solid rgba(43,111,255,.18);
  font-weight: 900;
  font-size:.92rem;
}

.hero__title{
  font-size: clamp(2.2rem, 4.2vw, 4.1rem);
  line-height:1.07;
  letter-spacing:-.04em;
  margin:.9rem 0 1rem;
}
.hero__desc{
  color: var(--ink2);
  font-size: clamp(1.05rem, 1.75vw, 1.2rem);
  max-width: 54ch;
}
.hero__actions{
  margin-top: 1.25rem;
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
}
.hero__mini{
  margin-top: 1.2rem;
  display:flex;
  flex-wrap:wrap;
  gap: .6rem;
}
.mini{
  display:flex;
  align-items:center;
  gap:.5rem;
  background:#fff;
  border:1px solid var(--line);
  border-radius: 999px;
  padding: .55rem .75rem;
  box-shadow: 0 10px 24px rgba(2,8,23,.06);
}
.mini__k{
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(6,182,212,.12);
  color: #0e7490;
  font-weight: 1000;
}
.mini__t{
  font-weight: 850;
  color: rgba(15,23,42,.78);
  font-size: .95rem;
}

.hero__media{
  display:grid;
  gap: 1rem;
}

/* =========================
   HERO SLIDER
========================= */
.heroSlider{
  position:relative;
  border-radius: var(--radius2);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  background:#fff;
  isolation:isolate;
}
.heroSlider__track{
  position:relative;
  width:100%;
  height: 360px;
}
@media (max-width: 560px){
  .heroSlider__track{height: 280px}
}
.heroSlide{
  position:absolute;
  inset:0;
  opacity:0;
  transform: scale(1.02);
  transition: opacity .45s ease, transform .55s ease;
}
.heroSlide.is-active{
  opacity:1;
  transform: scale(1);
}
.heroSlide img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.heroSlider__btn{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:44px;
  height:44px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(2,6,23,.28);
  color:#fff;
  font-size: 28px;
  line-height: 1;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition: transform .18s ease, background .2s ease;
  z-index: 2;
}
.heroSlider__btn:hover{background: rgba(2,6,23,.38)}
.heroSlider__btn:active{transform: translateY(-50%) scale(.98)}
.heroSlider__btn--prev{left: 12px}
.heroSlider__btn--next{right: 12px}

.heroSlider__dots{
  position:absolute;
  left:0; right:0; bottom: 10px;
  display:flex;
  justify-content:center;
  gap: .5rem;
  z-index:2;
}
.heroDot{
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.55);
  background: rgba(255,255,255,.28);
  cursor:pointer;
  transition: transform .18s ease, background .2s ease;
}
.heroDot.is-active{
  background:#fff;
  transform: scale(1.1);
}

/* =========================
   STATS
========================= */
.stats{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .9rem;
}
.stat{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 18px;
  padding: .95rem 1rem;
  box-shadow: 0 10px 26px rgba(2,8,23,.06);
}
.stat__num{
  font-size: 1.9rem;
  font-weight: 1000;
  letter-spacing: -.02em;
  color: var(--brand);
}
.stat__label{
  margin-top: .1rem;
  color: rgba(15,23,42,.64);
  font-weight: 800;
  font-size: .95rem;
}

/* =========================
   SERVICES
========================= */
.services{
  display:grid;
  gap: 1rem;
}
@media (min-width: 860px){
  .services{grid-template-columns: repeat(3, 1fr)}
}
.svc{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 22px;
  padding: 1.25rem 1.15rem;
  box-shadow: var(--shadow2);
  transition: transform .18s ease, box-shadow .22s ease, border-color .22s ease;
}
.svc:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow);
  border-color: rgba(43,111,255,.30);
}
.svc__top{
  display:flex;
  align-items:center;
  gap: .75rem;
  margin-bottom: .55rem;
}
.svc__icon{
  width: 50px;height:50px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: rgba(43,111,255,.10);
  color: var(--brand);
  font-weight: 1000;
}
.svc__title{font-size: 1.2rem; letter-spacing:-.01em}
.svc__text{color: var(--ink2)}

/* =========================
   ABOUT
========================= */
.about{
  display:grid;
  gap: 1.8rem;
  align-items:start;
}
@media (min-width: 980px){
  .about{grid-template-columns: 1.05fr .95fr}
}
.about__copy p{color: var(--ink2); margin-top:.85rem; font-size:1.05rem}

.about__panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 26px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.about__panelHead{
  display:flex;
  gap: .5rem;
  flex-wrap:wrap;
  padding: 1rem 1rem;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(90deg, rgba(43,111,255,.06), rgba(6,182,212,.05));
}
.pill{
  display:inline-flex;
  padding: .45rem .7rem;
  border-radius: 999px;
  background:#fff;
  border:1px solid rgba(43,111,255,.18);
  color: var(--brand);
  font-weight: 900;
  font-size: .9rem;
}
.about__panelBody{padding: 1.1rem 1rem 1.2rem}
.quote{position:relative;padding-left: .2rem;}
.quote__mark{
  font-size: 2.6rem;
  line-height: 1;
  color: rgba(43,111,255,.28);
  font-weight: 1000;
}
.quote p{
  margin-top: .25rem;
  color: rgba(15,23,42,.78);
  font-weight: 850;
  font-size: 1.05rem;
}
.quote__by{
  margin-top: .55rem;
  color: rgba(15,23,42,.55);
  font-weight: 850;
}

/* =========================
   TABS
========================= */
.tabs{
  max-width: 900px;
  margin: 0 auto;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 22px;
  padding: 1rem;
}
.tabs__nav{
  display:flex;
  gap: .6rem;
  flex-wrap:wrap;
  justify-content:center;
}
.tabs__btn{
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.20);
  color: rgba(255,255,255,.90);
  padding: .6rem .9rem;
  border-radius: 999px;
  font-weight: 950;
  cursor:pointer;
  transition: transform .18s ease, background .2s ease;
}
.tabs__btn:hover{transform: translateY(-1px)}
.tabs__btn.is-active{
  background: #fff;
  color: var(--brand);
  border-color: rgba(255,255,255,.75);
}
.tabs__panes{margin-top: 1rem}
.tabs__pane{
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 18px;
  padding: 1rem 1rem;
}
.checklist{
  list-style:none;
  display:grid;
  gap:.65rem;
  color: rgba(255,255,255,.90);
  font-weight: 900;
}

/* =========================
   GALLERY + LIGHTBOX
========================= */
.gallery{
  display:grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 820px){
  .gallery{grid-template-columns: repeat(3, 1fr)}
}
.tile{
  border-radius: 22px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  box-shadow: var(--shadow2);
  cursor:pointer;
  transition: transform .2s ease, box-shadow .22s ease;
}
.tile:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow);
}
.tile img{
  width:100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  transition: transform .35s ease;
}
.tile:hover img{transform: scale(1.05)}
.tile figcaption{padding: 1rem 1rem 1.1rem}
.tile strong{display:block; font-size:1.05rem}
.tile span{color: var(--ink2); font-weight:700; font-size:.92rem}

/* lightbox */
.lightbox{
  position: fixed;
  inset: 0;
  background: rgba(2,6,23,.72);
  display:none;
  place-items:center;
  padding: 1.25rem;
  z-index: 90;
}
.lightbox.is-open{display:grid}
.lightbox__img{
  width: min(980px, 100%);
  max-height: 78vh;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,.40);
  background:#fff;
}
.lightbox__cap{
  width: min(980px, 100%);
  margin-top: .8rem;
  color: rgba(255,255,255,.92);
  font-weight: 850;
  text-align:center;
}
.lightbox__close{
  position:absolute;
  top: 14px;
  right: 14px;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  color:#fff;
  font-size: 28px;
  line-height: 1;
  cursor:pointer;
}

/* =========================
   TIMELINE
========================= */
.timeline{
  max-width: 920px;
  margin: 0 auto;
  display:grid;
  gap: 1rem;
  position:relative;
}
.timeline::before{
  content:"";
  position:absolute;
  left: 22px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: linear-gradient(180deg, rgba(43,111,255,.20), rgba(6,182,212,.20));
}
.node{
  display:flex;
  gap: 1rem;
  align-items:flex-start;
}
.node__dot{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: #fff;
  border: 1px solid rgba(43,111,255,.25);
  color: var(--brand);
  font-weight: 1000;
  box-shadow: 0 10px 26px rgba(2,8,23,.06);
  flex: 0 0 auto;
}
.node__card{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 22px;
  padding: 1.05rem 1.1rem;
  box-shadow: var(--shadow2);
  width: 100%;
}
.node__card h3{margin-bottom:.25rem}
.node__card p{color: var(--ink2); font-weight:650}

/* =========================
   REVIEWS
========================= */
.reviews{
  display:grid;
  gap: 1rem;
}
@media (min-width: 920px){
  .reviews{grid-template-columns: repeat(3, 1fr)}
}
.review{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 22px;
  padding: 1.1rem 1.1rem;
  box-shadow: var(--shadow2);
  transition: transform .18s ease, box-shadow .22s ease, border-color .22s ease;
}
.review:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow);
  border-color: rgba(43,111,255,.26);
}
.review__top{
  display:flex;
  align-items:center;
  gap: .75rem;
  justify-content:space-between;
}
.review__top > div{
  display:flex;
  gap: .75rem;
  align-items:center;
}
.review__avatar{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(90deg, rgba(43,111,255,.16), rgba(6,182,212,.14));
  border: 1px solid rgba(43,111,255,.18);
  color: var(--brand);
  font-weight: 1000;
}
.review__name{font-weight: 1000; letter-spacing:-.01em}
.review__meta{color: rgba(15,23,42,.55); font-weight: 850; font-size: .9rem; margin-top: .08rem}
.review__stars{
  color: #f59e0b;
  font-weight: 1000;
  letter-spacing: .08em;
  white-space:nowrap;
  margin-left: .5rem;
}
.review__text{
  margin-top: .85rem;
  color: var(--ink2);
  font-weight: 650;
}

/* =========================
   MAP
========================= */
.mapCard{
  display:grid;
  gap: 1rem;
  background:#fff;
  border:1px solid var(--line);
  border-radius: 26px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
@media (min-width: 980px){
  .mapCard{grid-template-columns: 1.2fr .8fr}
}
.mapCard iframe{
  width:100%;
  min-height: 380px;
  border:0;
}
@media (max-width: 600px){
  .mapCard iframe{min-height: 320px}
}
.mapCard__info{
  padding: 1.1rem 1.1rem;
  display:grid;
  gap: .9rem;
}
.mapInfo{
  border:1px solid var(--line);
  border-radius: 18px;
  padding: .85rem .95rem;
  background: linear-gradient(90deg, rgba(43,111,255,.05), rgba(6,182,212,.04));
}
.mapInfo__k{
  color: rgba(15,23,42,.60);
  font-weight: 900;
  font-size: .9rem;
}
.mapInfo__v{
  margin-top: .15rem;
  font-weight: 1000;
  color: var(--brand);
  text-decoration:none;
  display:inline-block;
}
.mapInfo__v:hover{text-decoration:underline}

/* =========================
   CONTACT FORM
========================= */
.formWrap{
  max-width: 920px;
  margin: 0 auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius: 26px;
  box-shadow: var(--shadow);
  padding: 1.2rem 1.2rem;
}
.form{
  display:grid;
  gap: 1rem;
}
.form__row{
  display:grid;
  gap: 1rem;
}
@media (min-width: 860px){
  .form__row{grid-template-columns: 1fr 1fr}
}
.field label{
  display:block;
  font-weight: 950;
  margin-bottom: .45rem;
  color: rgba(15,23,42,.88);
}
.field input,
.field textarea,
.field select{
  width:100%;
  padding: .9rem .95rem;
  border-radius: 16px;
  border:1px solid var(--line);
  outline:none;
  font: inherit;
  background:#fff;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.field textarea{resize: vertical; min-height: 140px}
.field input:focus,
.field textarea:focus,
.field select:focus{
  border-color: rgba(43,111,255,.45);
  box-shadow: 0 0 0 4px rgba(43,111,255,.10);
}
.field.is-error input,
.field.is-error textarea,
.field.is-error select{
  border-color: rgba(239,68,68,.55);
  box-shadow: 0 0 0 4px rgba(239,68,68,.10);
}
.field__error{
  display:block;
  min-height: 1.1rem;
  margin-top: .35rem;
  color: rgba(239,68,68,.92);
  font-weight: 850;
  font-size: .92rem;
}
.form__bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  flex-wrap:wrap;
  margin-top: .25rem;
}
.form__hint{
  color: rgba(15,23,42,.62);
  font-weight: 800;
}
.form__hint a{color: var(--brand); text-decoration:none; font-weight:1000}
.form__hint a:hover{text-decoration:underline}

.formMsg{
  margin-top: .25rem;
  border-radius: 18px;
  padding: .9rem 1rem;
  border:1px solid var(--line);
  background: rgba(2,6,23,.02);
  color: rgba(15,23,42,.80);
  font-weight: 850;
  display:none;
}
.formMsg.is-show{display:block}
.formMsg.is-ok{
  border-color: rgba(34,197,94,.30);
  background: rgba(34,197,94,.08);
}
.formMsg.is-bad{
  border-color: rgba(239,68,68,.30);
  background: rgba(239,68,68,.08);
}

/* =========================
   FAQ (details)
========================= */
.faq{
  max-width: 920px;
  margin: 0 auto;
  display:flex;
  flex-direction:column;
  gap: .9rem;
}
.qa{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 22px;
  padding: .2rem 0;
  box-shadow: var(--shadow2);
  overflow:hidden;
}
.qa summary{
  list-style:none;
  cursor:pointer;
  padding: 1rem 1.1rem;
  font-weight: 950;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{
  content:"+";
  width: 36px;
  height: 36px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  border:1px solid var(--line);
  background:#fff;
  color: var(--ink);
  font-weight: 1000;
  flex: 0 0 auto;
  transition: transform .2s ease;
}
.qa[open] summary::after{transform: rotate(45deg)}
.qa p{
  padding: 0 1.1rem 1.1rem;
  color: var(--ink2);
  font-weight:650;
}

/* =========================
   CTA + FOOTER
========================= */
.cta{text-align:center; max-width: 860px}
.cta__title{font-size: clamp(1.85rem, 3.2vw, 3rem); letter-spacing:-.03em}
.cta__desc{opacity:.9; margin-top:.7rem; font-size:1.1rem}
.cta__buttons{
  margin-top: 1.4rem;
  display:flex;
  gap:.8rem;
  justify-content:center;
  flex-wrap:wrap;
}
.cta__hours{margin-top: 1.1rem; opacity:.85; font-weight:800}

.footer{
  background: #0b1730;
  color:#fff;
  padding: 3rem 0 1.8rem;
}
.footer__grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items:start;
}
@media (min-width: 860px){
  .footer__grid{grid-template-columns: 1.2fr 1fr 1fr}
}
.footer__brand{font-size:1.4rem; font-weight:1000; margin-bottom:.5rem}
.footer__title{font-weight:950; margin-bottom:.65rem}
.footer__text{opacity:.85; max-width: 42ch}
.footer__links{list-style:none; display:flex; flex-direction:column; gap:.55rem}
.footer__links a{color: rgba(255,255,255,.86); text-decoration:none; font-weight:800}
.footer__links a:hover{color:#fff}
.footer__bottom{
  margin-top: 2rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(255,255,255,.18);
  text-align:center;
  opacity:.85;
  font-weight:800;
}

/* =========================
   REVEAL
========================= */
.js-reveal{
  opacity:0;
  transform: translateY(18px);
  transition: opacity .55s ease, transform .55s ease;
  transition-delay: var(--d, 0ms);
  will-change: transform, opacity;
}
.js-reveal.is-in{
  opacity:1;
  transform: translateY(0);
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .js-reveal{opacity:1; transform:none; transition:none}
  .heroSlide{transition:none}
}
