:root{
  --blue:#00206B;
  --blue-deep:#03102E;
  --blue-2:#052E8D;
  --yellow:#FFEF00;
  --yellow-warm:#FFE000;
  --red:#EC1C22;
  --red-deep:#C40C12;
  --ink:#0a1024;
  --ink-2:#3b4669;
  --paper:#FAFBFD;
  --paper-2:#F1F4FB;
  --line:rgba(0,32,107,.10);
  --shadow-soft:0 18px 60px -28px rgba(0,32,107,.45), 0 4px 14px -8px rgba(0,32,107,.18);
  --shadow-lift:0 32px 80px -36px rgba(0,32,107,.55), 0 8px 22px -10px rgba(0,32,107,.22);
  --shadow-red:0 16px 40px -16px rgba(236,28,34,.55);
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:34px; --r-pill:999px;
  --display:'Bricolage Grotesque','Inter',system-ui,sans-serif;
  --serif:'Fraunces','Times New Roman',serif;
  --body:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --container:1240px;
  --pad:clamp(20px,4vw,56px);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;background:var(--paper)}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad);position:relative}

/* ========== TICKERTAPE ========== */
.ticker{
  background:var(--blue);
  color:var(--yellow);
  font-family:var(--display);font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;font-size:13px;
  overflow:hidden;border-bottom:1px solid rgba(255,239,0,.12);
  position:relative;z-index:60;
}
.ticker__track{display:flex;gap:60px;padding:11px 0;animation:tick 38s linear infinite;width:max-content}
.ticker span{display:inline-flex;align-items:center;gap:14px;white-space:nowrap}
.ticker .dot{width:6px;height:6px;border-radius:50%;background:var(--red)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ========== HEADER ========== */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid var(--line);
  transition:padding .35s ease, background .35s ease;
}
.header.is-scrolled{background:rgba(255,255,255,.95)}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:46px;width:auto;transition:transform .4s ease}
.brand:hover img{transform:scale(1.04)}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  position:relative;padding:10px 14px;border-radius:var(--r-pill);
  font-weight:600;font-size:14.5px;color:var(--ink);
  transition:color .25s ease, background .25s ease;
}
.nav a:hover{color:var(--blue);background:rgba(0,32,107,.06)}
.nav a.has-arrow::after{content:'›';margin-left:6px;color:var(--red);font-weight:800;transition:transform .3s ease}
.nav a:hover.has-arrow::after{transform:translateX(3px)}
.nav a.has-arrow::after{transition:transform .3s ease}
.nav__has-mega{position:relative}
.nav__has-mega:hover .nav__trigger,.nav__has-mega:focus-within .nav__trigger{color:var(--blue);background:rgba(0,32,107,.06)}
.nav__has-mega:hover .nav__trigger::after,.nav__has-mega:focus-within .nav__trigger::after{transform:rotate(90deg)}

/* MEGA MENU */
.mega{
  position:absolute;left:50%;top:calc(100% + 14px);transform:translateX(-50%) translateY(-8px);
  min-width:780px;max-width:92vw;
  background:#fff;border-radius:var(--r-xl);
  box-shadow:0 36px 80px -32px rgba(0,32,107,.45), 0 8px 30px -10px rgba(0,32,107,.15);
  border:1px solid var(--line);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s ease, transform .35s cubic-bezier(.2,.7,.2,1), visibility .25s;
  z-index:80;
}
.mega::before{
  content:'';position:absolute;left:0;right:0;top:-14px;height:14px;
}
.nav__has-mega:hover .mega,.nav__has-mega:focus-within .mega,.mega.is-open{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
.mega__inner{
  display:grid;grid-template-columns:240px 1fr;gap:0;padding:6px;
}
.mega__head{
  background:linear-gradient(150deg,var(--blue) 0%,var(--blue-deep) 100%);
  color:#fff;border-radius:calc(var(--r-xl) - 6px);
  padding:24px 22px;display:flex;flex-direction:column;
}
.mega__head .eyebrow{
  background:rgba(255,239,0,.15);color:var(--yellow);border:1px solid rgba(255,239,0,.2);
  align-self:flex-start;font-size:11px;
}
.mega__head h4{
  font-family:var(--display);font-weight:800;font-size:22px;
  line-height:1.1;margin:14px 0 8px;letter-spacing:-.01em;color:#fff;
}
.mega__head p{font-size:13px;color:rgba(255,255,255,.75);line-height:1.45;margin-bottom:16px;flex-grow:1}
.mega__head .btn{align-self:flex-start;margin-top:auto}
.mega__grid{
  list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:14px;
}
.mega__grid li{display:block}
.mega__grid a{
  display:flex;align-items:flex-start;gap:12px;padding:12px 14px;
  border-radius:var(--r-md);background:transparent;
  font-weight:500;font-size:13px;color:var(--ink);
  transition:background .2s ease,transform .2s ease;
}
.mega__grid a:hover{background:rgba(0,32,107,.05);transform:translateX(2px)}
.mega__ico{
  flex-shrink:0;width:38px;height:38px;border-radius:11px;
  background:rgba(0,32,107,.06);color:var(--blue);
  display:grid;place-items:center;
  transition:background .2s ease,color .2s ease;
}
.mega__ico svg{width:18px;height:18px}
.mega__grid a:hover .mega__ico{background:var(--red);color:#fff}
.mega__grid strong{display:block;font-family:var(--display);font-weight:700;color:var(--blue);font-size:14px;letter-spacing:-.01em;margin-bottom:1px}
.mega__grid span:not(.mega__ico){display:block;font-size:12px;color:var(--ink-2)}

.header__cta{display:flex;align-items:center;gap:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;border-radius:var(--r-pill);
  font-family:var(--display);font-weight:700;letter-spacing:.01em;
  font-size:15px;line-height:1;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,background .25s ease,color .25s ease;
  position:relative;overflow:hidden;will-change:transform;
}
.btn--primary{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.btn--primary:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 22px 50px -16px rgba(236,28,34,.7)}
.btn--blue{background:var(--blue);color:#fff;box-shadow:0 14px 36px -16px rgba(0,32,107,.6)}
.btn--blue:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--blue);border:2px solid var(--blue)}
.btn--ghost:hover{background:var(--blue);color:#fff;transform:translateY(-2px)}
.btn--yellow{background:var(--yellow);color:var(--blue)}
.btn--yellow:hover{background:var(--yellow-warm);transform:translateY(-2px);box-shadow:0 16px 40px -16px rgba(255,239,0,.55)}
.btn--white{background:#fff;color:var(--blue);box-shadow:0 14px 36px -16px rgba(255,255,255,.4)}
.btn--white:hover{background:var(--yellow) !important;color:var(--blue) !important;transform:translateY(-2px);box-shadow:0 18px 42px -16px rgba(255,239,0,.55)}
.btn--white:hover svg{color:var(--blue)}
.btn svg{width:16px;height:16px}
.btn--call{background:var(--yellow);color:var(--blue)}
.btn--icon{padding:14px;width:48px;height:48px}
.btn--icon svg{width:20px;height:20px;margin:0}
.menu-btn{display:none;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:var(--blue);color:#fff;flex-shrink:0;position:relative;z-index:101}
.menu-btn svg{width:22px;height:22px;transition:transform .3s ease}
.menu-btn[aria-expanded="true"] svg{transform:rotate(90deg)}

/* Mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:99;background:var(--blue);
  display:flex;flex-direction:column;padding:80px 24px 32px;
  opacity:0;visibility:hidden;transition:opacity .35s ease;
}
.drawer.is-open{opacity:1;visibility:visible}
.drawer__nav{display:flex;flex-direction:column;gap:4px;margin-bottom:30px}
.drawer__nav a{
  font-family:var(--display);font-weight:700;font-size:22px;color:#fff;
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);letter-spacing:-.01em;
  display:flex;align-items:center;justify-content:space-between;
}
.drawer__nav > a::after{content:'›';color:var(--yellow);font-size:28px;font-weight:800}
.drawer__group{border-bottom:1px solid rgba(255,255,255,.08)}
.drawer__group summary{
  list-style:none;cursor:pointer;font-family:var(--display);font-weight:700;font-size:22px;
  color:#fff;padding:14px 0;display:flex;align-items:center;justify-content:space-between;letter-spacing:-.01em;
}
.drawer__group summary::-webkit-details-marker{display:none}
.drawer__group summary::after{content:'+';color:var(--yellow);font-size:28px;font-weight:800;line-height:1;transition:transform .25s ease}
.drawer__group[open] summary::after{transform:rotate(45deg)}
.drawer__sub{display:flex;flex-direction:column;gap:2px;padding:6px 0 14px 16px;border-left:2px solid rgba(255,239,0,.25);margin-left:6px}
.drawer__sub a{
  font-family:var(--display);font-weight:600;font-size:15px;color:rgba(255,255,255,.78);
  padding:9px 12px;border-radius:8px;border-bottom:0;display:block;
  transition:color .2s ease,background .2s ease;
}
.drawer__sub a:hover{color:var(--yellow);background:rgba(255,239,0,.06)}
.drawer__cta{display:flex;flex-direction:column;gap:12px;margin-top:auto}
.drawer__cta .btn{padding:18px 24px;font-size:16px;width:100%}
.drawer__meta{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);text-align:center}
.drawer__meta div{color:rgba(255,255,255,.6);font-size:13px;margin-top:4px}
.drawer__meta strong{color:var(--yellow);font-family:var(--display);font-size:15px;letter-spacing:.04em}

/* ========== HERO ========== */
.hero{
  position:relative;
  min-height:min(94vh,860px);
  padding:120px 0 90px;
  display:flex;align-items:center;
  overflow:hidden;
  isolation:isolate;
  background:linear-gradient(180deg,#fff 0%,#F1F4FB 100%);
}
.hero__bg{
  position:absolute;inset:0;z-index:-2;
}
.hero__bg::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(255,239,0,.18), transparent 55%),
    radial-gradient(ellipse at 10% 90%, rgba(236,28,34,.12), transparent 50%),
    linear-gradient(180deg, rgba(0,32,107,.04), transparent 40%);
}
.hero__mesh{position:absolute;inset:0;z-index:-1;opacity:.7}
.hero__grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--line);
  padding:8px 16px;border-radius:var(--r-pill);
  font-family:var(--display);font-weight:600;font-size:13px;
  color:var(--blue);letter-spacing:.04em;
  box-shadow:0 6px 22px -10px rgba(0,32,107,.2);
}
.eyebrow .pulse{
  width:8px;height:8px;border-radius:50%;background:var(--red);
  box-shadow:0 0 0 0 rgba(236,28,34,.55);
  animation:pulse 1.8s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(236,28,34,.6)}
  70%{box-shadow:0 0 0 14px rgba(236,28,34,0)}
  100%{box-shadow:0 0 0 0 rgba(236,28,34,0)}
}
.hero h1{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(40px,6.4vw,82px);
  line-height:.96;
  letter-spacing:-.025em;
  color:var(--blue);
  margin:22px 0 16px;
}
.hero h1 .accent{
  position:relative;display:inline-block;color:var(--red);
}
.hero h1 .accent::after{
  content:'';position:absolute;left:0;right:0;bottom:-2px;height:14px;
  background:var(--yellow);z-index:-1;border-radius:4px;
  transform:skewX(-8deg) scaleX(0);transform-origin:left;
  animation:wipe 1.2s .9s cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes wipe{to{transform:skewX(-8deg) scaleX(1)}}
.hero__sub{
  font-size:clamp(17px,1.6vw,20px);
  color:var(--ink-2);max-width:560px;margin-bottom:32px;
}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:38px}
.hero__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  padding-top:24px;border-top:1px solid var(--line);max-width:540px;
}
.stat .num{
  font-family:var(--display);font-weight:800;
  font-size:clamp(28px,3vw,40px);color:var(--blue);
  line-height:1;letter-spacing:-.02em;
}
.stat .lbl{font-size:13px;color:var(--ink-2);margin-top:6px;letter-spacing:.04em;text-transform:uppercase}

/* hero visual */
.hero__visual{
  position:relative;height:580px;
  perspective:1200px;
}
.hero__photo{
  position:absolute;inset:0;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lift);
  transform:rotate(-2deg);
  background-size:cover;background-position:center;
}
.hero__photo img{width:100%;height:100%;object-fit:cover;transition:transform 14s ease}
.hero__photo:hover img{transform:scale(1.08)}
.hero__photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(0,32,107,.0) 50%,rgba(0,32,107,.55));
}
.hero__badge{
  position:absolute;left:-30px;top:30px;z-index:3;
  background:var(--yellow);color:var(--blue);
  padding:18px 22px;border-radius:var(--r-lg);
  box-shadow:0 22px 40px -18px rgba(255,239,0,.6);
  font-family:var(--display);font-weight:800;font-size:15px;
  display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;
  transform:rotate(-6deg);
  animation:floaty 6s ease-in-out infinite;
}
.hero__badge .big{font-size:30px;letter-spacing:-.02em}
.hero__badge .sub{font-size:11px;color:var(--blue);opacity:.8;letter-spacing:.08em;text-transform:uppercase;margin-top:4px}
@keyframes floaty{0%,100%{transform:rotate(-6deg) translateY(0)}50%{transform:rotate(-6deg) translateY(-12px)}}

.hero__pill{
  position:absolute;right:-20px;bottom:80px;z-index:3;
  background:#fff;border-radius:var(--r-lg);padding:18px 22px;
  display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow-lift);
  animation:floaty 7s -2s ease-in-out infinite;
  max-width:280px;
}
.hero__pill .ico{
  width:48px;height:48px;border-radius:14px;background:var(--red);color:#fff;
  display:grid;place-items:center;flex-shrink:0;
}
.hero__pill .ico svg{width:22px;height:22px}
.hero__pill .t1{font-family:var(--display);font-weight:700;color:var(--blue);font-size:15px}
.hero__pill .t2{font-size:12.5px;color:var(--ink-2);margin-top:2px}

.hero__rating{
  position:absolute;left:-20px;bottom:-30px;z-index:3;
  background:#fff;border-radius:var(--r-lg);padding:16px 20px;
  box-shadow:var(--shadow-lift);
  display:flex;align-items:center;gap:14px;
  animation:floaty 8s -1s ease-in-out infinite;
}
.hero__rating .stars{color:#FFB400;font-size:18px;letter-spacing:2px;line-height:1}
.hero__rating .num{font-family:var(--display);font-weight:800;font-size:22px;color:var(--blue);line-height:1}
.hero__rating .sub{font-size:11px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;margin-top:3px}

/* ========== USP STRIP ========== */
.usp{
  background:var(--blue);color:#fff;
  padding:28px 0;position:relative;overflow:hidden;
}
.usp::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--yellow) 0%,var(--yellow) 33%,var(--red) 33%,var(--red) 66%,#fff 66%);
}
.usp__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:center}
.usp__item{display:flex;align-items:center;gap:14px;font-family:var(--display);font-weight:600}
.usp__item .ico{
  width:48px;height:48px;border-radius:14px;background:rgba(255,239,0,.18);
  display:grid;place-items:center;color:var(--yellow);flex-shrink:0;
}
.usp__item .ico svg{width:22px;height:22px}
.usp__item .t{font-size:14.5px;line-height:1.3}
.usp__item .t strong{display:block;font-size:16px;color:var(--yellow)}

/* ========== SECTION BASE ========== */
section{padding:clamp(70px,9vw,130px) 0;position:relative}
.section-head{text-align:center;max-width:760px;margin:0 auto 60px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{
  font-family:var(--display);font-weight:800;
  font-size:clamp(32px,4.4vw,56px);line-height:1.04;
  letter-spacing:-.02em;color:var(--blue);
}
.section-head h2 em{font-style:normal;color:var(--red)}
.section-head p{margin-top:18px;color:var(--ink-2);font-size:17px;max-width:620px;margin-left:auto;margin-right:auto}

/* ========== ABOUT ========== */
.about{background:var(--paper);position:relative}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about__media{position:relative;height:600px}
.about__photo{
  position:absolute;inset:0;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lift);
}
.about__photo img{width:100%;height:100%;object-fit:cover}
.about__chip{
  position:absolute;left:-30px;bottom:40px;z-index:2;
  background:var(--yellow);color:var(--blue);
  padding:24px 28px;border-radius:var(--r-lg);
  font-family:var(--display);font-weight:800;line-height:1.05;
  box-shadow:var(--shadow-lift);
  transform:rotate(-4deg);
}
.about__chip .big{font-size:48px;display:block;letter-spacing:-.02em}
.about__chip .sub{font-size:13px;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-top:6px}
.about__deco{
  position:absolute;right:-40px;top:-40px;width:140px;height:140px;
  background:var(--red);border-radius:50%;opacity:.9;z-index:1;
  display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:800;
  text-align:center;font-size:13px;line-height:1.15;text-transform:uppercase;letter-spacing:.06em;
  animation:spin-slow 24s linear infinite;
}
@keyframes spin-slow{to{transform:rotate(360deg)}}
.about__copy h2{
  font-family:var(--display);font-weight:800;
  font-size:clamp(34px,4.4vw,52px);line-height:1.04;color:var(--blue);
  letter-spacing:-.02em;margin-bottom:20px;
}
.about__copy h2 em{font-style:normal;font-family:var(--serif);color:var(--red);font-weight:500}
.about__copy p{color:var(--ink-2);font-size:17px;margin-bottom:18px;line-height:1.7}
.about__copy p strong{color:var(--blue)}
.about__feats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:28px 0 32px}
.about__feat{display:flex;gap:12px;align-items:flex-start}
.about__feat .ico{
  width:38px;height:38px;border-radius:12px;background:var(--blue);color:var(--yellow);
  display:grid;place-items:center;flex-shrink:0;
}
.about__feat .ico svg{width:18px;height:18px}
.about__feat .t1{font-family:var(--display);font-weight:700;color:var(--blue);font-size:15px}
.about__feat .t2{font-size:13.5px;color:var(--ink-2);margin-top:2px;line-height:1.4}

/* ========== FREE BAR ========== */
.free-bar{
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-deep) 100%);
  color:#fff;padding:30px 0;position:relative;overflow:hidden;
}
.free-bar::before,.free-bar::after{
  content:'';position:absolute;border-radius:50%;filter:blur(60px);
}
.free-bar::before{width:340px;height:340px;background:rgba(255,239,0,.15);left:-100px;top:-160px}
.free-bar::after{width:300px;height:300px;background:rgba(236,28,34,.15);right:-100px;bottom:-160px}
.free-bar__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative;z-index:1}
.free-bar__item{
  text-align:center;padding:20px;border-radius:var(--r-lg);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  transition:transform .4s ease,background .3s ease;
}
.free-bar__item:hover{background:rgba(255,239,0,.1);transform:translateY(-4px)}
.free-bar__item .ico{
  width:64px;height:64px;border-radius:18px;
  background:var(--yellow);color:var(--blue);
  display:grid;place-items:center;margin:0 auto 14px;
  box-shadow:0 14px 30px -10px rgba(255,239,0,.4);
}
.free-bar__item .ico svg{width:30px;height:30px}
.free-bar__item .label{
  font-family:var(--display);font-weight:800;
  font-size:clamp(20px,2.2vw,26px);
  letter-spacing:-.01em;color:#fff;line-height:1.1;
}
.free-bar__item .label em{font-style:normal;color:var(--yellow)}
.free-bar__item .desc{font-size:13.5px;color:rgba(255,255,255,.7);margin-top:8px}

/* ========== SERVICES GRID ========== */
.services{background:var(--paper)}
.services__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.svc-card{
  position:relative;background:#fff;border-radius:var(--r-lg);
  padding:28px 24px;text-align:left;
  border:1px solid var(--line);
  box-shadow:0 10px 30px -16px rgba(0,32,107,.18);
  overflow:hidden;
  transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,border-color .3s ease;
}
.svc-card::before{
  content:'';position:absolute;left:0;top:0;height:4px;width:0;
  background:linear-gradient(90deg,var(--red),var(--yellow));
  transition:width .45s ease;
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:transparent}
.svc-card:hover::before{width:100%}
.svc-card .ico{
  width:60px;height:60px;border-radius:16px;
  background:linear-gradient(135deg,rgba(0,32,107,.08),rgba(236,28,34,.06));
  color:var(--blue);display:grid;place-items:center;margin-bottom:18px;
  transition:background .3s ease,color .3s ease,transform .4s ease;
}
.svc-card .ico svg{width:28px;height:28px}
.svc-card:hover .ico{background:var(--blue);color:var(--yellow);transform:rotate(-6deg)}
.svc-card h3{
  font-family:var(--display);font-weight:700;font-size:19px;color:var(--blue);
  letter-spacing:-.01em;line-height:1.2;margin-bottom:8px;
}
.svc-card p{font-size:14px;color:var(--ink-2);line-height:1.5;margin-bottom:14px}
.svc-card .more{
  display:inline-flex;align-items:center;gap:6px;font-size:13px;
  color:var(--red);font-weight:700;font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;
}
.svc-card .more svg{transition:transform .3s ease}
.svc-card:hover .more svg{transform:translateX(4px)}

/* ========== VACCINATION CTA ========== */
.vacc{
  background:var(--yellow);color:var(--blue);position:relative;overflow:hidden;
  padding:80px 0;
}
.vacc::before{
  content:'';position:absolute;left:0;top:0;right:0;height:6px;
  background:linear-gradient(90deg,var(--red) 0%,var(--red) 50%,var(--blue) 50%,var(--blue) 100%);
}
.vacc__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.vacc__copy h2{
  font-family:var(--display);font-weight:800;
  font-size:clamp(34px,4.6vw,56px);line-height:1.02;color:var(--blue);
  letter-spacing:-.025em;
}
.vacc__copy h2 .red{color:var(--red)}
.vacc__copy p{margin:18px 0 28px;font-size:17px;color:var(--blue);opacity:.85;max-width:560px}
.vacc__list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px 24px;margin-bottom:34px;max-width:560px;
}
.vacc__list li{
  list-style:none;display:flex;align-items:center;gap:10px;
  font-family:var(--display);font-weight:600;color:var(--blue);font-size:15px;
}
.vacc__list li::before{
  content:'';width:10px;height:10px;border-radius:50%;background:var(--red);flex-shrink:0;
}
.vacc__cta{display:flex;gap:14px;flex-wrap:wrap}
.vacc__visual{
  position:relative;height:480px;
  background:url('/home-devy/images/storefront.jpg') center/cover;
  border-radius:var(--r-xl);
  box-shadow:0 30px 60px -24px rgba(0,32,107,.4);
  overflow:hidden;
}
.vacc__visual::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,transparent 50%,rgba(0,32,107,.6));
}
.vacc__sticker{
  position:absolute;right:-20px;top:30px;z-index:2;
  background:var(--red);color:#fff;
  width:130px;height:130px;border-radius:50%;
  display:grid;place-items:center;text-align:center;
  font-family:var(--display);font-weight:800;font-size:14px;line-height:1.1;
  box-shadow:0 20px 40px -16px rgba(236,28,34,.55);
  transform:rotate(8deg);
  animation:floaty 5s ease-in-out infinite;
}
.vacc__sticker .big{font-size:30px;display:block;color:var(--yellow);letter-spacing:-.02em}

/* ========== STORY / TIMELINE ========== */
.story{background:#fff;position:relative;overflow:hidden}
.story__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.story__media{position:relative;height:600px}
.story__photo{
  position:absolute;inset:0;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lift);
}
.story__photo img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05)}
.story__year{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--display);font-weight:800;
  font-size:clamp(110px,14vw,200px);
  color:#fff;line-height:1;letter-spacing:-.04em;
  text-shadow:0 24px 60px rgba(0,32,107,.45);
  pointer-events:none;
  -webkit-text-stroke:1px rgba(255,255,255,.6);
}
.story__copy h2{
  font-family:var(--display);font-weight:800;font-size:clamp(34px,4.4vw,52px);
  letter-spacing:-.02em;color:var(--blue);line-height:1.04;
  margin-bottom:16px;
}
.story__copy h2 em{font-style:normal;color:var(--red)}
.story__lead{
  font-family:var(--serif);font-style:italic;font-size:22px;color:var(--blue);
  margin:18px 0 24px;line-height:1.4;
}
.story__copy p{color:var(--ink-2);font-size:16.5px;margin-bottom:18px;line-height:1.7}
.story__meta{
  display:flex;gap:36px;margin-top:30px;padding-top:30px;border-top:1px solid var(--line);
}
.story__meta .item{display:flex;flex-direction:column}
.story__meta .num{font-family:var(--display);font-weight:800;font-size:36px;color:var(--red);line-height:1}
.story__meta .lbl{font-size:12.5px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.08em;margin-top:6px}

/* ========== REVIEWS ========== */
.reviews{background:var(--paper);position:relative;overflow:hidden}
.reviews__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:50px;gap:30px;flex-wrap:wrap}
.reviews__head h2{
  font-family:var(--display);font-weight:800;font-size:clamp(32px,4vw,52px);
  color:var(--blue);letter-spacing:-.02em;line-height:1.04;
}
.reviews__head h2 em{font-style:normal;color:var(--red)}
.reviews__rating{
  display:flex;align-items:center;gap:18px;
  background:#fff;padding:18px 22px;border-radius:var(--r-lg);
  box-shadow:var(--shadow-soft);border:1px solid var(--line);
}
.reviews__rating .num{font-family:var(--display);font-weight:800;font-size:38px;color:var(--blue);line-height:1}
.reviews__rating .stars{color:#FFB400;font-size:20px;letter-spacing:3px;line-height:1}
.reviews__rating .meta{font-size:12px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}
.reviews__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.review{
  background:#fff;border-radius:var(--r-lg);padding:28px;
  border:1px solid var(--line);box-shadow:0 10px 30px -16px rgba(0,32,107,.16);
  position:relative;display:flex;flex-direction:column;
  transition:transform .4s ease,box-shadow .3s ease;
}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.review__quote{
  position:absolute;top:18px;right:22px;font-family:var(--serif);font-weight:700;
  font-size:80px;color:var(--yellow);line-height:1;opacity:.6;
}
.review__stars{color:#FFB400;font-size:16px;letter-spacing:2px;margin-bottom:14px}
.review__body{color:var(--ink);font-size:15.5px;line-height:1.6;margin-bottom:22px;flex-grow:1}
.review__author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:16px}
.review__avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue),var(--red));
  color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:16px;
}
.review__name{font-family:var(--display);font-weight:700;color:var(--blue);font-size:15px}
.review__when{font-size:12.5px;color:var(--ink-2)}

/* ========== CONTACT ========== */
.contact{background:var(--blue);color:#fff;position:relative;overflow:hidden}
.contact::before{
  content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,239,0,.08),transparent 70%);
  right:-200px;top:-200px;
}
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:stretch;position:relative;z-index:1}
.contact__copy h2{
  font-family:var(--display);font-weight:800;font-size:clamp(34px,4.4vw,52px);
  letter-spacing:-.02em;line-height:1.04;
}
.contact__copy h2 em{font-style:normal;color:var(--yellow)}
.contact__copy p{margin:18px 0 30px;color:rgba(255,255,255,.78);font-size:17px;max-width:520px}
.contact__list{display:flex;flex-direction:column;gap:18px;margin-bottom:32px}
.contact__row{display:flex;gap:16px;align-items:flex-start}
.contact__row .ico{
  width:48px;height:48px;border-radius:14px;background:rgba(255,239,0,.15);
  color:var(--yellow);display:grid;place-items:center;flex-shrink:0;
}
.contact__row .ico svg{width:22px;height:22px}
.contact__row .t1{font-family:var(--display);font-weight:700;color:#fff;font-size:13.5px;letter-spacing:.06em;text-transform:uppercase;opacity:.7}
.contact__row .t2{font-family:var(--display);font-weight:700;font-size:18px;color:#fff;margin-top:2px}
.contact__row a:hover{color:var(--yellow)}
.contact__cta{display:flex;gap:14px;flex-wrap:wrap}
.contact__map{
  border-radius:var(--r-xl);overflow:hidden;height:520px;
  box-shadow:0 30px 60px -24px rgba(0,0,0,.5);
  border:6px solid #fff;
}
.contact__map iframe{width:100%;height:100%;border:0;display:block}

/* ========== FOOTER ========== */
.footer{background:var(--blue-deep);color:rgba(255,255,255,.72);padding:60px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer__brand img{height:54px;margin-bottom:18px}
.footer__brand p{font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.6);max-width:300px}
.footer__col h4{font-family:var(--display);font-weight:700;color:#fff;font-size:14px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer__col a{font-size:14.5px;color:rgba(255,255,255,.7);transition:color .25s ease}
.footer__col a:hover{color:var(--yellow)}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;
  font-size:13px;color:rgba(255,255,255,.5);
}
.footer__bottom .qcpp{display:flex;align-items:center;gap:14px}
.footer__bottom .qcpp img{height:42px;background:#fff;padding:6px;border-radius:8px}

/* ========== ANIM HELPERS ========== */
.reveal,.reveal-stagger > *{will-change:opacity,transform}

/* ========== RESPONSIVE ========== */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr;gap:60px}
  .hero__visual{height:460px;max-width:540px;margin:0 auto}
  .about__grid,.story__grid,.contact__grid,.vacc__grid{grid-template-columns:1fr;gap:50px}
  .about__media,.story__media{height:460px}
  .services__grid{grid-template-columns:repeat(3,1fr)}
  .free-bar__grid{gap:18px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:860px){
  .nav,.header__cta .btn--primary,.header__cta .btn--ghost,.header__cta .btn--call .btn-label{display:none}
  .menu-btn{display:inline-flex}
  .header__inner{padding:12px 0;gap:10px}
  .brand img{height:38px}
  .header__cta{gap:8px}
  .header__cta .btn--call{padding:12px;width:48px;height:48px}
  .header__cta .btn--call svg{width:20px;height:20px;margin:0}

  .hero{padding:60px 0 80px;min-height:auto}
  .hero h1{font-size:clamp(36px,11vw,48px);line-height:1}
  .hero__sub{font-size:16px;margin-bottom:24px}
  .hero__cta{gap:10px;margin-bottom:30px}
  .hero__cta .btn{flex:1 1 100%;padding:16px 20px;font-size:14.5px}
  .hero__visual{height:480px;width:100%;max-width:none;margin-top:8px}
  .hero__photo{transform:rotate(-1.5deg);border-radius:var(--r-lg)}
  .hero__badge{left:8px;top:-12px;padding:12px 14px;transform:rotate(-4deg)}
  .hero__badge .big{font-size:20px}
  .hero__badge .sub{font-size:10px}
  .hero__pill{right:8px;bottom:auto;top:24px;padding:12px 14px;max-width:200px;border-radius:14px;animation:none;transform:rotate(2deg)}
  .hero__pill .ico{width:38px;height:38px;border-radius:11px}
  .hero__pill .ico svg{width:18px;height:18px}
  .hero__pill .t1{font-size:13px}
  .hero__pill .t2{font-size:11px;line-height:1.3}
  .hero__rating{left:auto;right:8px;bottom:-14px;padding:10px 14px;border-radius:14px;gap:10px;animation:none}
  .hero__rating .num{font-size:18px}
  .hero__rating .stars{font-size:14px;letter-spacing:1px}
  .hero__rating .sub{font-size:10px}
  .hero__stats{gap:14px;max-width:none}
  .hero__stats .num{font-size:24px}
  .hero__stats .lbl{font-size:11px}

  .usp__grid{grid-template-columns:1fr 1fr;gap:18px}
  .free-bar__grid{grid-template-columns:1fr}
  .services__grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .svc-card{padding:22px 18px}
  .vacc__list{grid-template-columns:1fr}
  .reviews__grid{grid-template-columns:1fr}
  .contact__map{height:380px}
  .about__chip{padding:18px 20px}
  .about__chip .big{font-size:36px}
  .footer__grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .services__grid{grid-template-columns:1fr}
  .usp__grid{grid-template-columns:1fr}
  .hero__stats{grid-template-columns:repeat(3,1fr);gap:14px}
  .hero h1{font-size:42px}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
}

/* ========== SERVICE PAGE TEMPLATE ========== */
.svc-hero{
  position:relative;padding:60px 0 80px;
  background:linear-gradient(180deg,#fff 0%,var(--paper-2) 100%);
  overflow:hidden;
}
.svc-hero__bg{position:absolute;inset:0;z-index:-1}
.svc-hero__bg::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 90% 10%, rgba(255,239,0,.18), transparent 55%),
    radial-gradient(ellipse at 0% 100%, rgba(236,28,34,.10), transparent 50%);
}
.svc-hero__grid{display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center}
.crumbs{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  font-size:13px;color:var(--ink-2);margin-bottom:14px;font-weight:500;
}
.crumbs a{color:var(--blue);text-decoration:none}
.crumbs a:hover{color:var(--red)}
.crumbs span{color:var(--ink-2);opacity:.6}
.crumbs span[aria-current]{color:var(--red);font-weight:600;opacity:1}
.svc-hero h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(36px,5.4vw,72px);line-height:1;letter-spacing:-.025em;
  color:var(--blue);margin:18px 0 18px;
}
.svc-hero__lead{
  font-size:clamp(16px,1.4vw,19px);color:var(--ink-2);
  max-width:560px;margin-bottom:28px;line-height:1.55;
}
.svc-hero__cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.svc-hero__pills{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px;
}
.svc-hero__pills li{
  background:#fff;border:1px solid var(--line);
  padding:8px 14px;border-radius:var(--r-pill);
  font-size:13.5px;color:var(--blue);font-weight:600;
  box-shadow:0 4px 14px -8px rgba(0,32,107,.18);
}
.svc-hero__visual{position:relative;height:520px;width:100%}
.svc-hero__photo{
  position:absolute;inset:0;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lift);transform:rotate(2deg);
}
.svc-hero__photo img{width:100%;height:100%;object-fit:cover}
.svc-hero__photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(0,32,107,0) 50%,rgba(0,32,107,.5));
}
.svc-hero__chip{
  position:absolute;left:-30px;bottom:30px;z-index:2;
  background:var(--yellow);color:var(--blue);
  padding:18px 22px;border-radius:var(--r-lg);
  box-shadow:0 22px 40px -18px rgba(255,239,0,.6);
  font-family:var(--display);font-weight:800;line-height:1;
  display:flex;flex-direction:column;
  transform:rotate(-6deg);animation:floaty 6s ease-in-out infinite;
}
.svc-hero__chip .big{font-size:30px;letter-spacing:-.02em}
.svc-hero__chip .sub{font-size:11px;color:var(--blue);opacity:.85;letter-spacing:.08em;text-transform:uppercase;margin-top:6px}

/* SVC BODY */
.svc-body{padding:clamp(60px,7vw,100px) 0;background:var(--paper)}
.svc-body__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:flex-start}
.svc-body__main{
  font-size:17px;line-height:1.7;color:var(--ink);
}
.svc-body__main h2,.svc-body__main h3,.svc-body__main h4{
  font-family:var(--display);color:var(--blue);font-weight:800;
  letter-spacing:-.01em;line-height:1.15;
}
.svc-body__main h2{font-size:clamp(26px,3vw,36px);margin:32px 0 16px}
.svc-body__main h3{font-size:clamp(22px,2.4vw,28px);margin:28px 0 14px}
.svc-body__main h4{font-size:20px;margin:22px 0 10px;color:var(--red)}
.svc-body__main p{margin-bottom:16px;color:var(--ink-2)}
.svc-body__main p strong{color:var(--blue)}
.svc-body__main ul,.svc-body__main ol{margin:14px 0 22px 0;padding-left:22px;color:var(--ink-2)}
.svc-body__main li{margin-bottom:8px}
.svc-body__main a{color:var(--red);font-weight:600;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;text-decoration-color:rgba(236,28,34,.25)}
.svc-body__main a:hover{text-decoration-color:var(--red)}
.svc-body__main img{border-radius:var(--r-lg);margin:18px 0;box-shadow:var(--shadow-soft)}
.svc-body__main blockquote{
  margin:22px 0;padding:18px 22px;border-left:4px solid var(--yellow);
  background:#fff;border-radius:0 var(--r-md) var(--r-md) 0;
  font-family:var(--serif);font-style:italic;color:var(--blue);font-size:18px;
  box-shadow:var(--shadow-soft);
}
.svc-body__side{position:sticky;top:120px}
.svc-card-stack{display:flex;flex-direction:column;gap:16px}
.svc-side-card{
  border-radius:var(--r-lg);padding:24px;
  border:1px solid var(--line);box-shadow:var(--shadow-soft);
}
.svc-side-card--blue{
  background:linear-gradient(145deg,var(--blue) 0%,var(--blue-deep) 100%);
  color:#fff;border-color:transparent;
}
.svc-side-card--blue h3{
  font-family:var(--display);font-weight:800;font-size:22px;color:#fff;
  letter-spacing:-.01em;margin-bottom:10px;
}
.svc-side-card--blue p{font-size:14px;color:rgba(255,255,255,.78);margin-bottom:18px;line-height:1.5}
.svc-side-card--blue .btn{margin-top:8px;display:flex}
.svc-side-card--white{background:#fff}
.svc-side-card h4{
  font-family:var(--display);font-weight:700;font-size:14px;
  color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;
}
.svc-hours{list-style:none;display:flex;flex-direction:column;gap:8px}
.svc-hours li{
  display:flex;justify-content:space-between;align-items:center;
  font-size:14.5px;color:var(--ink);padding:6px 0;border-bottom:1px solid var(--line);
}
.svc-hours li:last-child{border-bottom:0}
.svc-hours strong{font-family:var(--display);font-weight:700;color:var(--blue);font-size:13.5px}
.svc-quote{color:#FFB400;font-size:18px;letter-spacing:2px;margin-bottom:10px}
.svc-side-card--quote blockquote{
  font-family:var(--serif);font-style:italic;color:var(--ink);font-size:15.5px;
  line-height:1.55;margin-bottom:12px;
}
.svc-side-card--quote cite{font-style:normal;font-size:12.5px;color:var(--ink-2)}

/* SVC CROSS-SELL */
.svc-cross{padding:clamp(60px,7vw,100px) 0;background:#fff;border-top:1px solid var(--line)}

/* MOBILE OVERRIDES for service template */
@media (max-width:860px){
  .svc-hero__grid{grid-template-columns:1fr;gap:46px}
  .svc-hero__visual{height:380px;width:100%}
  .svc-hero__photo{transform:rotate(1deg);border-radius:var(--r-lg)}
  .svc-hero__chip{left:8px;bottom:-12px;padding:14px 16px;transform:rotate(-4deg)}
  .svc-hero__chip .big{font-size:22px}
  .svc-body__grid{grid-template-columns:1fr;gap:40px}
  .svc-body__side{position:static;order:-1}
}


/* ========== GENERIC PAGE TEMPLATE ========== */
.page-hero{
  position:relative;padding:60px 0 80px;
  background:linear-gradient(180deg,#fff 0%,var(--paper-2) 100%);
  overflow:hidden;
}
.page-hero__bg{position:absolute;inset:0;z-index:-1}
.page-hero__bg::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 95% 0%, rgba(255,239,0,.18), transparent 55%),
    radial-gradient(ellipse at 5% 100%, rgba(236,28,34,.10), transparent 50%);
}
.page-hero__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:center}
.page-hero h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(36px,5vw,64px);line-height:1.02;letter-spacing:-.025em;
  color:var(--blue);margin:18px 0 18px;
}
.page-hero h1 em{font-style:normal;color:var(--red)}
.page-hero__lead{
  font-size:clamp(16px,1.4vw,19px);color:var(--ink-2);
  max-width:580px;margin-bottom:28px;line-height:1.55;
}
.page-hero__cta{display:flex;flex-wrap:wrap;gap:12px}
.page-hero__visual{position:relative;height:460px;width:100%}
.page-hero__photo{
  position:absolute;inset:0;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lift);transform:rotate(-2deg);
}
.page-hero__photo img{width:100%;height:100%;object-fit:cover}
.page-hero__photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(0,32,107,0) 60%,rgba(0,32,107,.4));
}

/* GENERIC PAGE BODY */
.page-body{padding:clamp(60px,7vw,100px) 0;background:#fff}
.page-body__main{
  max-width:820px;margin:0 auto;
  font-size:17px;line-height:1.7;color:var(--ink);
}
.page-body__main h2,.page-body__main h3,.page-body__main h4{
  font-family:var(--display);color:var(--blue);font-weight:800;
  letter-spacing:-.01em;line-height:1.15;
}
.page-body__main h2{font-size:clamp(28px,3.2vw,40px);margin:36px 0 16px}
.page-body__main h3{font-size:clamp(22px,2.4vw,28px);margin:30px 0 14px}
.page-body__main h4{font-size:20px;margin:24px 0 10px;color:var(--red)}
.page-body__main p{margin-bottom:18px;color:var(--ink-2)}
.page-body__main p strong{color:var(--blue)}
.page-body__main ul,.page-body__main ol{margin:14px 0 22px 0;padding-left:22px;color:var(--ink-2)}
.page-body__main li{margin-bottom:8px}
.page-body__main a{color:var(--red);font-weight:600;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;text-decoration-color:rgba(236,28,34,.25)}
.page-body__main a:hover{text-decoration-color:var(--red)}
.page-body__main img{border-radius:var(--r-lg);margin:18px 0;box-shadow:var(--shadow-soft);max-width:100%;height:auto}
.page-body__main blockquote{
  margin:22px 0;padding:18px 22px;border-left:4px solid var(--yellow);
  background:var(--paper);border-radius:0 var(--r-md) var(--r-md) 0;
  font-family:var(--serif);font-style:italic;color:var(--blue);font-size:18px;
}
.page-body__main hr{border:0;border-top:1px solid var(--line);margin:36px 0}

@media (max-width:860px){
  .page-hero__grid{grid-template-columns:1fr;gap:40px}
  .page-hero__visual{height:360px;width:100%}
  .page-hero__photo{transform:rotate(-1deg);border-radius:var(--r-lg)}
}


/* ========== BLOG TEMPLATE ========== */
.blog-hero .page-hero__grid{align-items:stretch}
.blog-hero h1{font-size:clamp(34px,4.5vw,56px);line-height:1.02}

.blog-feat{
  display:flex;flex-direction:column;
  background:#fff;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lift);border:1px solid var(--line);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease;
  text-decoration:none;color:inherit;
}
.blog-feat:hover{transform:translateY(-4px);box-shadow:0 40px 90px -38px rgba(0,32,107,.55)}
.blog-feat__photo{
  width:100%;aspect-ratio:16/10;background-size:cover;background-position:center;
  position:relative;
}
.blog-feat__photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,32,107,0) 60%,rgba(0,32,107,.35));
}
.blog-feat__body{padding:26px 28px}
.blog-feat__tag{
  display:inline-block;background:var(--yellow);color:var(--blue);
  padding:5px 12px;border-radius:var(--r-pill);
  font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:14px;
}
.blog-feat h2{
  font-family:var(--display);font-weight:800;font-size:clamp(22px,2.4vw,28px);
  letter-spacing:-.01em;line-height:1.2;color:var(--blue);margin-bottom:10px;
}
.blog-feat__meta{display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:13px;margin-bottom:14px}
.blog-feat__more{
  display:inline-flex;align-items:center;gap:8px;color:var(--red);
  font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;
}
.blog-feat:hover .blog-feat__more svg{transform:translateX(3px)}
.blog-feat__more svg{transition:transform .3s ease}

/* GRID */
.blog-grid{padding:clamp(60px,7vw,100px) 0;background:var(--paper)}
.blog-grid__cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.blog-card{
  display:flex;flex-direction:column;background:#fff;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:0 12px 32px -18px rgba(0,32,107,.18);
  text-decoration:none;color:inherit;
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,border-color .3s ease;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:transparent}
.blog-card__photo{
  width:100%;aspect-ratio:16/9;background-size:cover;background-position:center;
  transition:transform .8s ease;
}
.blog-card:hover .blog-card__photo{transform:scale(1.04)}
.blog-card__body{padding:22px 22px 24px;display:flex;flex-direction:column;flex-grow:1}
.blog-card__meta{display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:12.5px;margin-bottom:10px}
.blog-card__dot{width:4px;height:4px;border-radius:50%;background:var(--red);opacity:.6}
.blog-card h3{
  font-family:var(--display);font-weight:700;font-size:18px;color:var(--blue);
  letter-spacing:-.01em;line-height:1.3;margin-bottom:10px;
}
.blog-card p{font-size:14px;color:var(--ink-2);line-height:1.55;margin-bottom:16px;flex-grow:1}
.blog-card__more{
  display:inline-flex;align-items:center;gap:6px;font-size:12.5px;
  color:var(--red);font-weight:700;font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;
}
.blog-card:hover .blog-card__more svg{transform:translateX(3px)}
.blog-card__more svg{transition:transform .3s ease}

.blog-pager{
  display:flex;align-items:center;justify-content:center;gap:18px;margin-top:50px;
}
.blog-pager__btn{
  background:var(--blue);color:#fff;padding:14px 22px;border-radius:var(--r-pill);
  font-family:var(--display);font-weight:700;font-size:14px;
  transition:transform .3s ease,background .25s ease;
}
.blog-pager__btn:hover{background:var(--blue-deep);transform:translateY(-2px)}
.blog-pager__count{font-family:var(--display);font-weight:600;color:var(--ink-2);font-size:14px}

@media (max-width:860px){
  .blog-grid__cards{grid-template-columns:1fr;gap:18px}
  .blog-feat__photo{aspect-ratio:16/9}
  .blog-feat__body{padding:22px 22px}
}


/* ========== SINGLE BLOG POST TEMPLATE ========== */
.post-hero{
  position:relative;
  padding:120px 0 100px;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
}
.post-hero__bg{
  position:absolute;inset:0;z-index:-2;
  background-size:cover;background-position:center;
  filter:saturate(1.05);
}
.post-hero__overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(0,32,107,.55) 0%, rgba(3,16,46,.85) 100%),
    radial-gradient(ellipse at 80% 20%, rgba(255,239,0,.18), transparent 50%);
}
.crumbs--light{color:rgba(255,255,255,.78);margin-bottom:18px}
.crumbs--light a{color:#fff}
.crumbs--light a:hover{color:var(--yellow)}
.crumbs--light span{color:rgba(255,255,255,.4)}
.crumbs--light span[aria-current]{color:var(--yellow);font-weight:600}
.post-hero__tag{
  display:inline-block;background:var(--red);color:#fff;
  padding:6px 14px;border-radius:var(--r-pill);
  font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:18px;
}
.post-hero__title{
  font-family:var(--display);font-weight:800;
  font-size:clamp(32px,5vw,64px);line-height:1.05;
  letter-spacing:-.02em;color:#fff;margin-bottom:24px;max-width:920px;
}
.post-hero__meta{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  color:rgba(255,255,255,.85);font-size:14.5px;font-weight:500;
}
.post-hero__author{display:flex;align-items:center;gap:10px}
.post-hero__avatar{border-radius:50%;border:2px solid rgba(255,255,255,.4)}
.post-hero__sep{opacity:.4}

/* POST BODY */
.post-body{padding:clamp(60px,7vw,100px) 0;background:#fff}
.post-body__grid{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:flex-start}
.post-body__main{
  font-size:17.5px;line-height:1.75;color:var(--ink);
}
.post-body__main h2,.post-body__main h3,.post-body__main h4{
  font-family:var(--display);color:var(--blue);font-weight:800;
  letter-spacing:-.01em;line-height:1.2;
}
.post-body__main h2{font-size:clamp(26px,3vw,36px);margin:36px 0 16px}
.post-body__main h3{font-size:clamp(22px,2.4vw,28px);margin:30px 0 14px}
.post-body__main h4{font-size:20px;margin:24px 0 10px;color:var(--red)}
.post-body__main p{margin-bottom:18px;color:var(--ink-2)}
.post-body__main p strong{color:var(--blue)}
.post-body__main ul,.post-body__main ol{margin:14px 0 22px;padding-left:24px;color:var(--ink-2)}
.post-body__main li{margin-bottom:10px}
.post-body__main a{color:var(--red);font-weight:600;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;text-decoration-color:rgba(236,28,34,.25)}
.post-body__main a:hover{text-decoration-color:var(--red)}
.post-body__main img{border-radius:var(--r-lg);margin:22px 0;box-shadow:var(--shadow-soft);max-width:100%;height:auto}
.post-body__main blockquote{
  margin:30px 0;padding:24px 28px;border-left:5px solid var(--yellow);
  background:var(--paper);border-radius:0 var(--r-md) var(--r-md) 0;
  font-family:var(--serif);font-style:italic;color:var(--blue);font-size:20px;
  box-shadow:var(--shadow-soft);
}
.post-body__main hr{border:0;border-top:1px solid var(--line);margin:36px 0}

.post-body__side{position:sticky;top:120px}

/* TAGS */
.post-tags{margin-top:40px;padding-top:30px;border-top:1px solid var(--line);display:flex;align-items:center;flex-wrap:wrap;gap:10px}
.post-tags__label{font-family:var(--display);font-weight:700;color:var(--blue);font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-right:8px}
.post-tag{
  display:inline-block;background:var(--paper-2);color:var(--blue);
  padding:6px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:600;
  text-decoration:none;transition:background .25s ease,color .25s ease;
}
.post-tag:hover{background:var(--blue);color:#fff}

/* SHARE */
.post-share{display:flex;gap:8px;margin-top:8px}
.post-share a{
  width:40px;height:40px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:grid;place-items:center;
  transition:transform .3s ease,background .25s ease;
}
.post-share a:hover{background:var(--red);transform:translateY(-3px)}
.post-share svg{width:18px;height:18px}

@media (max-width:860px){
  .post-hero{padding:80px 0 60px}
  .post-body__grid{grid-template-columns:1fr;gap:50px}
  .post-body__side{position:static;order:-1}
}


/* === Hero portrait variant (for vertical promo image) === */
.hero__photo--portrait{
  aspect-ratio: 4/5;
  max-height: 620px;
}
.hero__photo--portrait img{
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center;
}

/* === Contact-us page body components === */
.page-lead{
  font-size:18px;
  line-height:1.7;
  color:var(--ink);
  max-width:820px;
  margin:0 0 40px;
}
.ycp-help-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin:30px 0 60px;
}
.ycp-help-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:28px 26px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.ycp-help-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lift);
  border-color:rgba(0,73,144,.18);
}
.ycp-help-card__ico{
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,73,144,.08);
  color:var(--blue);
  margin-bottom:18px;
}
.ycp-help-card h4{
  font-family:var(--display);
  font-weight:700;
  font-size:18px;
  color:var(--blue);
  margin:0 0 10px;
}
.ycp-help-card p{
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.6;
  margin:0;
}

.ycp-section-title{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(24px,2.6vw,32px);
  color:var(--blue);
  margin:60px 0 18px;
  letter-spacing:-.01em;
}
.ycp-section-title em{font-style:normal;color:var(--red)}

/* === Call cards — cinematic, white-on-blue, locked contrast === */
.ycp-call-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
  margin:0 0 60px;
}
.ycp-call-card,
.page-body__main .ycp-call-card,
.page-body__main a.ycp-call-card{
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-end !important;
  position:relative !important;
  min-height:200px !important;
  padding:32px !important;
  border-radius:22px !important;
  text-decoration:none !important;
  overflow:hidden !important;
  isolation:isolate !important;
  color:#fff !important;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(255,239,0,.10) 0%, rgba(255,239,0,0) 55%),
    linear-gradient(135deg, var(--blue) 0%, var(--blue-2) 50%, var(--blue-deep) 100%) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,.06) inset,
    0 24px 48px -22px rgba(0,32,107,.55),
    0 6px 18px -10px rgba(0,32,107,.35) !important;
  transition:transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s ease !important;
  will-change:transform;
}
.ycp-call-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:22px;
  background:linear-gradient(135deg, rgba(255,239,0,.45), rgba(228,0,43,.0) 35%, rgba(255,255,255,.10) 100%);
  -webkit-mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  padding:1px;
  opacity:.7;
  pointer-events:none;
  z-index:1;
}
.ycp-call-card::after{
  content:"";
  position:absolute;
  top:-40%;
  right:-20%;
  width:55%;
  height:180%;
  background:radial-gradient(closest-side, rgba(255,255,255,.18), rgba(255,255,255,0));
  transform:rotate(8deg);
  pointer-events:none;
  z-index:0;
  transition:transform .6s cubic-bezier(.22,1,.36,1), opacity .4s ease;
}
.ycp-call-card:hover,
.ycp-call-card:focus-visible,
.ycp-call-card:active,
.ycp-call-card:visited,
.page-body__main a.ycp-call-card:hover,
.page-body__main a.ycp-call-card:visited{
  transform:translateY(-6px);
  color:#fff !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,.10) inset,
    0 32px 60px -24px rgba(0,32,107,.65),
    0 10px 24px -10px rgba(0,32,107,.45) !important;
  text-decoration:none !important;
}
.ycp-call-card:hover::after{
  transform:rotate(8deg) translateX(-15%);
}
.ycp-call-card__lbl{
  position:relative;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11.5px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--yellow) !important;
  margin-bottom:auto;
  padding-bottom:24px;
}
.ycp-call-card__lbl::before{
  content:"";
  width:6px;height:6px;border-radius:50%;
  background:var(--yellow);
  box-shadow:0 0 12px var(--yellow);
}
.ycp-call-card__num{
  position:relative;
  z-index:2;
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(28px,3.4vw,40px);
  line-height:1.05;
  letter-spacing:-.02em;
  color:#fff !important;
  margin-bottom:8px;
}
.ycp-call-card__sub{
  position:relative;
  z-index:2;
  font-size:14.5px;
  color:rgba(255,255,255,.78) !important;
  line-height:1.5;
}
.ycp-call-card__arrow{
  position:absolute;
  top:30px;
  right:30px;
  width:38px;height:38px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  z-index:2;
  transition:transform .3s ease, background .3s ease;
}
.ycp-call-card:hover .ycp-call-card__arrow{
  transform:rotate(-45deg) scale(1.08);
  background:var(--yellow);
  color:var(--blue);
}
.ycp-call-card__arrow svg{width:16px;height:16px}

/* === Form === */
.ycp-form-lead{
  color:var(--ink-2);
  font-size:16px;
  line-height:1.65;
  margin:0 0 24px;
  max-width:680px;
}
.ycp-form-wrap{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:clamp(28px,3.4vw,44px);
  margin-bottom:40px;
  box-shadow:0 24px 60px -38px rgba(0,32,107,.35);
  overflow:hidden;
}
.ycp-form-wrap::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg, var(--blue), var(--red), var(--yellow));
  border-radius:22px 22px 0 0;
}
.ycp-form-wrap .frm_forms,
.ycp-form-wrap .with_frm_style{max-width:none;background:transparent;border:0;padding:0;box-shadow:none}
.ycp-form-wrap .frm_form_fields > fieldset{border:0;padding:0;margin:0;background:transparent}
.ycp-form-wrap .frm_form_fields legend{display:none}
.ycp-form-wrap .frm_fields_container{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ycp-form-wrap .frm_form_field{margin-bottom:0 !important}
.ycp-form-wrap .frm_form_field.frm_full,
.ycp-form-wrap .frm_form_field[data-frmfield-type=textarea],
.ycp-form-wrap .frm_form_field[data-frmfield-type=submit]{grid-column:1 / -1}
.ycp-form-wrap label,
.ycp-form-wrap .frm_primary_label{
  display:block !important;
  font-family:var(--display) !important;
  font-weight:600 !important;
  font-size:13px !important;
  text-transform:uppercase !important;
  letter-spacing:.12em !important;
  color:var(--blue) !important;
  margin-bottom:8px !important;
}
.ycp-form-wrap .frm_required{color:var(--red) !important;margin-left:4px}
.ycp-form-wrap input[type=text],
.ycp-form-wrap input[type=email],
.ycp-form-wrap input[type=tel],
.ycp-form-wrap input[type=number],
.ycp-form-wrap textarea,
.ycp-form-wrap select{
  width:100% !important;
  border-radius:12px !important;
  border:1px solid var(--line) !important;
  padding:14px 16px !important;
  font-size:15px !important;
  font-family:inherit !important;
  background:var(--paper) !important;
  color:var(--ink) !important;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease !important;
  box-shadow:none !important;
}
.ycp-form-wrap textarea{min-height:140px;resize:vertical}
.ycp-form-wrap input:focus,
.ycp-form-wrap textarea:focus,
.ycp-form-wrap select:focus{
  outline:0 !important;
  border-color:var(--blue) !important;
  background:#fff !important;
  box-shadow:0 0 0 4px rgba(0,32,107,.10) !important;
}
.ycp-form-wrap input::placeholder,
.ycp-form-wrap textarea::placeholder{color:rgba(10,16,36,.4)}
.ycp-form-wrap .frm_submit{margin-top:8px}
.ycp-form-wrap .frm_button_submit,
.ycp-form-wrap button[type=submit],
.ycp-form-wrap input[type=submit]{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
  background:var(--blue) !important;
  color:#fff !important;
  border-radius:999px !important;
  padding:16px 34px !important;
  font-family:var(--display) !important;
  font-size:15px !important;
  font-weight:700 !important;
  letter-spacing:.02em !important;
  border:0 !important;
  cursor:pointer !important;
  text-transform:none !important;
  transition:transform .25s cubic-bezier(.22,1,.36,1), background .25s ease, box-shadow .25s ease !important;
  box-shadow:0 14px 32px -14px rgba(0,32,107,.55) !important;
}
.ycp-form-wrap .frm_button_submit:hover,
.ycp-form-wrap button[type=submit]:hover,
.ycp-form-wrap input[type=submit]:hover{
  background:var(--blue-2) !important;
  transform:translateY(-2px) !important;
  box-shadow:0 22px 44px -18px rgba(0,32,107,.65) !important;
}
.ycp-form-wrap .frm_message,
.ycp-form-wrap .frm_success_style{
  background:rgba(0,32,107,.06) !important;
  border:1px solid var(--line) !important;
  border-left:3px solid var(--blue) !important;
  border-radius:10px !important;
  color:var(--blue) !important;
  padding:14px 18px !important;
}
.ycp-form-wrap .frm_error_style{
  background:rgba(236,28,34,.06) !important;
  border:1px solid rgba(236,28,34,.2) !important;
  border-left:3px solid var(--red) !important;
  color:var(--red-deep) !important;
}
.ycp-form-wrap .frm_error{color:var(--red) !important;font-size:13px;margin-top:6px}

@media (max-width:860px){
  .ycp-help-grid{grid-template-columns:1fr}
  .ycp-call-grid{grid-template-columns:1fr;gap:16px}
  .ycp-call-card{min-height:170px;padding:26px}
  .ycp-call-card__num{font-size:28px}
  .ycp-call-card__arrow{top:24px;right:24px;width:34px;height:34px}
  .ycp-form-wrap .frm_fields_container{grid-template-columns:1fr}
  .hero__photo--portrait{aspect-ratio:1/1;max-height:420px}
}
