/* ===== Inna Shapira — Insurance landing page ===== */
:root{
  --navy:#143b66;          /* deep brand navy (from logo) */
  --blue:#2f6fce;          /* primary action (tweakable) */
  --blue-soft:#5a8fc7;     /* logo light blue */
  --ink:#13233a;           /* headings */
  --text:#54637a;          /* body */
  --bg:#ffffff;
  --bg-soft:#f3f7fc;       /* light section */
  --line:#e4ecf5;
  --card:#ffffff;
  --font:'Heebo', system-ui, sans-serif;
  --shadow-sm:0 2px 10px rgba(20,59,102,.06);
  --shadow:0 18px 50px rgba(20,59,102,.10);
  --shadow-lg:0 30px 70px rgba(20,59,102,.16);
  --r:22px;
  --maxw:1200px;
  scroll-behavior:smooth;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--text);
  background-color:#eaf2fb;
  background-image:url('assets/bg-pattern.svg');
  background-size:185px auto;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{color:var(--ink);margin:0;line-height:1.18;font-weight:800;letter-spacing:-.01em}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{scroll-margin-top:96px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;justify-content:center;
  font-family:inherit;font-weight:700;font-size:1.02rem;cursor:pointer;border:none;
  padding:15px 30px;border-radius:999px;transition:.25s ease;white-space:nowrap;
}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 12px 28px color-mix(in srgb,var(--blue) 35%,transparent)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-2px);box-shadow:0 18px 38px color-mix(in srgb,var(--blue) 42%,transparent)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.65)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-ghost.dark{color:var(--navy);border-color:color-mix(in srgb,var(--navy) 30%,transparent)}
.btn-ghost.dark:hover{background:color-mix(in srgb,var(--navy) 6%,transparent)}

/* ---------- header ---------- */
.hdr{
  position:fixed;inset:0 0 auto 0;z-index:200;
  background:rgba(255,255,255,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:.3s ease;
}
.hdr.scrolled{box-shadow:0 6px 24px rgba(20,59,102,.08);border-bottom-color:var(--line)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:84px;gap:20px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:60px;width:auto}
.brand-txt{display:flex;flex-direction:column;line-height:1.1;text-align:right}
.brand-txt .nm{font-weight:800;font-size:1.22rem;color:var(--navy);letter-spacing:-.01em}
.brand-txt .rl{font-weight:600;font-size:.78rem;color:var(--blue);letter-spacing:.06em}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-weight:600;font-size:1.02rem;color:var(--ink);position:relative;padding:6px 0;transition:.2s}
.nav a::after{content:'';position:absolute;bottom:-2px;right:0;height:2.5px;width:0;background:var(--blue);transition:.25s;border-radius:2px}
.nav a:hover{color:var(--blue)}
.nav a:hover::after{width:100%}
.hdr-side{display:flex;align-items:center;gap:14px}
.phone-link{display:flex;align-items:center;gap:9px;font-weight:800;color:var(--navy);font-size:1.06rem;direction:ltr}
.phone-link .ph-ic{width:38px;height:38px;border-radius:50%;background:color-mix(in srgb,var(--blue) 12%,#fff);display:grid;place-items:center;color:var(--blue)}
.soc{display:flex;gap:9px}
.soc a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;transition:.2s}
.soc a:hover{transform:translateY(-2px)}
.soc .wa{background:#25d366}.soc .fb{background:#1877f2}.soc .ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.6px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---------- HERO (shared) ---------- */
.hero{display:none;position:relative;align-items:center;min-height:92vh;padding:140px 0 70px;overflow:hidden}
body.hero-photo .hero.v-photo{display:flex}
body.hero-split .hero.v-split{display:flex}
body.hero-shape .hero.v-shape{display:flex}
.hero-content{max-width:620px;position:relative;z-index:3}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.95rem;letter-spacing:.02em;
  padding:8px 16px;border-radius:999px;margin-bottom:22px}
.hero h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:900;line-height:1.08;margin-bottom:20px}
.hero .lead{font-size:1.22rem;line-height:1.65;margin-bottom:26px;max-width:540px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.checks{display:flex;flex-direction:column;gap:13px}
.checks li{display:flex;align-items:center;gap:12px;font-weight:600;font-size:1.06rem;list-style:none}
.checks .ck{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:var(--blue);display:grid;place-items:center;color:#fff}
.checks ul{margin:0;padding:0}
.checks li strong{font-weight:800;text-decoration:underline;text-decoration-color:var(--blue-soft);text-decoration-thickness:2px;text-underline-offset:4px}
.hero.v-photo .checks li strong{text-decoration-color:#fff}

/* hero variant: photo */
.hero.v-photo{color:#fff}
.hero.v-photo .hero-bg{position:absolute;inset:0;width:100%;height:100%;z-index:1;
  background:#0a1a2e url('assets/hero-family.png') center 38%/cover no-repeat;
  filter:saturate(.9) brightness(.98) contrast(1.03)}
.hero.v-photo .scrim{position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(to left, rgba(9,23,45,.90) 0%, rgba(9,23,45,.66) 40%, rgba(9,23,45,.20) 74%, rgba(9,23,45,.06) 100%),
    linear-gradient(to top, rgba(9,23,45,.42) 0%, rgba(9,23,45,0) 38%),
    linear-gradient(0deg, rgba(20,59,102,.18), rgba(20,59,102,.18))}
.hero.v-photo h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero.v-photo .lead{color:rgba(255,255,255,.92)}
.hero.v-photo .eyebrow{background:rgba(255,255,255,.16);color:#fff;backdrop-filter:blur(4px)}
.hero.v-photo .checks li{color:#fff}

/* hero variant: split */
.hero.v-split{background:transparent}
.hero.v-split .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;width:100%}
.hero.v-split .eyebrow{background:color-mix(in srgb,var(--blue) 12%,#fff);color:var(--blue)}
.hero.v-split .lead{color:var(--text)}
.split-photo{position:relative}
.split-photo image-slot{width:100%;height:520px;box-shadow:var(--shadow-lg)}
.split-photo .badge{position:absolute;bottom:-22px;right:-18px;background:#fff;border-radius:18px;padding:16px 22px;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:13px}
.split-photo .badge b{font-size:1.7rem;color:var(--navy);display:block;line-height:1}
.split-photo .badge span{font-size:.92rem;color:var(--text)}
.split-photo .badge .ic{width:46px;height:46px;border-radius:12px;background:color-mix(in srgb,var(--blue) 12%,#fff);display:grid;place-items:center;color:var(--blue)}

/* hero variant: shape */
.hero.v-shape{background:
  radial-gradient(120% 90% at 90% 0%, color-mix(in srgb,var(--blue) 16%,transparent) 0%, transparent 55%),
  radial-gradient(90% 80% at 0% 100%, color-mix(in srgb,var(--blue-soft) 18%,transparent) 0%, transparent 50%)}
.hero.v-shape .hero-content{max-width:760px;margin-right:0}
.hero.v-shape .eyebrow{background:#fff;color:var(--blue);box-shadow:var(--shadow-sm)}
.hero.v-shape h1{font-size:clamp(2.6rem,5.6vw,4.6rem)}
.hero.v-shape .lead{color:var(--text)}
.hero.v-shape .checks{flex-direction:row;flex-wrap:wrap;gap:12px 26px}

/* decorative shapes */
.deco{position:absolute;pointer-events:none;z-index:0;opacity:.6}
.deco.plus{color:color-mix(in srgb,var(--blue) 26%,transparent);font-weight:800}
.deco.tri{width:0;height:0;border-style:solid}
.deco.ring{border-radius:50%;border:14px solid color-mix(in srgb,var(--blue-soft) 22%,transparent)}

/* ---------- section heading ---------- */
.section{padding:96px 0}
.section{background:var(--bg)}
.section.soft{background:transparent}
.section.plain{background:transparent}
.section-head{text-align:center;max-width:760px;margin:0 auto 56px;position:relative}
.kick{color:#fff;font-weight:700;letter-spacing:.05em;font-size:1.02rem;text-transform:uppercase;
  margin-bottom:20px;display:inline-flex;align-items:center;gap:10px;padding:10px 22px;border-radius:999px;
  background:var(--blue);box-shadow:0 8px 20px color-mix(in srgb,var(--blue) 30%,transparent)}
.kick::before{content:'';width:8px;height:8px;border-radius:50%;background:#fff}
.section-head h2{font-size:clamp(2.1rem,3.8vw,3.1rem);font-weight:900;line-height:1.12;margin-bottom:16px}
.section-head p{font-size:1.12rem}
.section-head .rule{width:70px;height:4px;background:var(--blue);border-radius:4px;margin:20px auto 0}

/* ---------- about ---------- */
.about .wrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:center}
.about-photo{position:relative}
.about-photo image-slot{width:100%;height:500px;box-shadow:var(--shadow-lg)}
.about-photo .about-portrait-img{width:100%;height:500px;border-radius:22px;background:#dce8f5 center/cover no-repeat;box-shadow:var(--shadow-lg)}
.about-photo .frame{position:absolute;inset:-18px -18px auto auto;width:70%;height:70%;border:3px solid color-mix(in srgb,var(--blue) 30%,transparent);border-radius:var(--r);z-index:-1}
.about-text h2{font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:900;margin-bottom:20px}
.about-text p{font-size:1.12rem;margin-bottom:18px}
.sign{display:flex;align-items:center;gap:16px;margin-top:28px}
.sign .nm{font-weight:800;color:var(--navy);font-size:1.15rem}
.sign .nm span{display:block;font-weight:500;color:var(--text);font-size:.96rem}
.about-foot .sign{margin-top:0}
.about-foot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;
  margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}

/* ---------- features (why me) ---------- */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.feat{background:var(--card);border-radius:var(--r);padding:38px 26px;text-align:center;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:.3s ease}
.feat:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.feat .ic{width:84px;height:84px;border-radius:50%;margin:0 auto 22px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--blue) 11%,#fff);color:var(--blue)}
.feat h3{font-size:1.28rem;font-weight:800;margin-bottom:12px}
.feat p{font-size:1.02rem}

/* ---------- services ---------- */
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.serv{background:var(--card);border-radius:var(--r);padding:36px 30px 30px;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:.3s ease;position:relative;overflow:hidden}
.serv::before{content:'';position:absolute;top:0;right:0;left:0;height:4px;background:var(--blue);transform:scaleX(0);transform-origin:right;transition:.35s}
.serv:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.serv:hover::before{transform:scaleX(1)}
.serv .ic{width:72px;height:72px;border-radius:18px;display:grid;place-items:center;margin-bottom:22px;
  background:color-mix(in srgb,var(--blue) 11%,#fff);color:var(--blue)}
.serv h3{font-size:1.32rem;font-weight:800;margin-bottom:12px}
.serv p{font-size:1.02rem;margin-bottom:22px;flex:1}
.serv .more{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--blue);font-size:1.02rem}
.serv .more svg{transition:.25s}
.serv:hover .more svg{transform:translateX(-5px)}

/* ---------- contact band ---------- */
.contact{background:linear-gradient(135deg,var(--navy) 0%,color-mix(in srgb,var(--navy) 70%,var(--blue)) 100%);
  color:#fff;position:relative;overflow:hidden}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.contact .kick{color:#cfe2fb;background:rgba(255,255,255,.12);box-shadow:none}
.contact .kick::before{background:#cfe2fb}
.contact h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:900;margin-bottom:18px}
.contact .lead{color:rgba(255,255,255,.85);font-size:1.12rem;margin-bottom:28px}
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-info a,.contact-info div{display:flex;align-items:center;gap:14px;font-size:1.1rem;font-weight:600;color:#fff}
.contact-info .ic{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.12);display:grid;place-items:center;flex:0 0 auto}
.contact-info small{display:block;font-weight:400;color:rgba(255,255,255,.6);font-size:.85rem}
.form{background:#fff;border-radius:24px;padding:38px;box-shadow:var(--shadow-lg)}
.form h3{color:var(--ink);font-size:1.4rem;font-weight:800;margin-bottom:6px}
.form .sub{color:var(--text);margin-bottom:24px;font-size:1rem}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;color:var(--ink);font-size:.95rem;margin-bottom:7px}
.field input,.field textarea{width:100%;font-family:inherit;font-size:1rem;padding:13px 16px;border:1.5px solid var(--line);
  border-radius:13px;background:#fafcfe;color:var(--ink);transition:.2s;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 12%,transparent)}
.form .btn{width:100%;margin-top:6px}
.form-done{text-align:center;padding:30px 10px}
.form-done .big{width:72px;height:72px;border-radius:50%;background:color-mix(in srgb,var(--blue) 13%,#fff);color:var(--blue);display:grid;place-items:center;margin:0 auto 18px}
.form-done h3{margin-bottom:8px}
.hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;opacity:0;overflow:hidden;pointer-events:none}
.form-err{margin:14px 0 0;text-align:center;font-weight:600;font-size:.98rem;color:#b23b34;
  background:color-mix(in srgb,#b23b34 8%,#fff);border:1px solid color-mix(in srgb,#b23b34 24%,#fff);
  border-radius:12px;padding:11px 14px}

/* ---------- footer ---------- */
.footer{background:#0c2138;color:rgba(255,255,255,.7);padding:60px 0 26px}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer img{height:74px;background:#fff;border-radius:14px;padding:8px;margin-bottom:18px}
.footer p{font-size:1rem;line-height:1.7;max-width:340px}
.footer h4{color:#fff;font-size:1.1rem;margin-bottom:18px;font-weight:700}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer ul a:hover{color:#fff}
.footer .fcontact li{display:flex;gap:10px;align-items:center;margin-bottom:11px}
.footer .copy{padding-top:24px;text-align:center;font-size:.9rem;color:rgba(255,255,255,.5)}

/* ---------- whatsapp float ---------- */
.wa-float{position:fixed;bottom:26px;left:26px;z-index:300;width:62px;height:62px;border-radius:50%;
  background:#25d366;display:grid;place-items:center;color:#fff;box-shadow:0 12px 30px rgba(37,211,102,.45);transition:.25s}
.wa-float:hover{transform:scale(1.08)}
.wa-float::before{content:'';position:absolute;inset:0;border-radius:50%;background:#25d366;z-index:-1;animation:wapulse 2.6s ease-out infinite}
@keyframes wapulse{0%{transform:scale(1);opacity:.45}100%{transform:scale(1.55);opacity:0}}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav,.hdr-side .phone-link span,.hdr-side .soc{display:none}
  .burger{display:flex}
  .hdr-inner{height:72px}
  .brand img{height:48px}
  .brand-txt .nm{font-size:1.06rem}
  .brand-txt .rl{font-size:.72rem}
  .nav.open{display:flex;position:absolute;top:72px;right:0;left:0;flex-direction:column;background:#fff;
    padding:22px 28px;gap:18px;box-shadow:var(--shadow);border-top:1px solid var(--line)}
  .nav.open a{font-size:1.15rem}
  .about .wrap,.contact .wrap,.hero.v-split .wrap{grid-template-columns:1fr;gap:40px}
  .about-photo{order:2}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .serv-grid{grid-template-columns:repeat(2,1fr)}
  .footer .top{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:620px){
  .wrap{padding:0 18px}
  .section{padding:64px 0}
  .hero{padding:120px 0 56px;min-height:auto}
  .features-grid,.serv-grid{grid-template-columns:1fr}
  .footer .top{grid-template-columns:1fr}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero .lead{font-size:1.1rem}
  .split-photo image-slot,.about-photo image-slot,.about-photo .about-portrait-img{height:380px}
  .wa-float{width:52px;height:52px;bottom:16px;left:14px}
  .wa-float svg{width:26px;height:26px}
}

/* ================= MULTI-PAGE ADDITIONS ================= */
.nav a.active{color:var(--blue)}
.nav a.active::after{width:100%}

/* ---------- page banner (sub-page hero) ---------- */
.page-banner{position:relative;overflow:hidden;padding:150px 0 70px;
  background:linear-gradient(135deg,var(--navy) 0%,color-mix(in srgb,var(--navy) 64%,var(--blue)) 100%);
  color:#fff;text-align:center}
.page-banner::before{content:'';position:absolute;inset:0;background-image:url('assets/bg-pattern.svg');
  background-size:185px auto;opacity:.10;mix-blend-mode:screen;z-index:1}
.page-banner .deco{opacity:.12}
.page-banner .wrap{position:relative;z-index:2}
/* photo banner variant */
.page-banner.photo{background:#0c2138}
.page-banner.photo::before{display:none}
.banner-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;
  filter:saturate(.95) brightness(.72) contrast(1.04)}
.banner-scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(120deg, rgba(11,30,54,.82) 0%, rgba(20,59,102,.58) 44%, rgba(47,111,206,.40) 100%),
    radial-gradient(120% 130% at 50% 28%, rgba(47,111,206,.22) 0%, rgba(9,23,43,.5) 72%)}
.page-banner .kick{color:#cfe2fb;background:rgba(255,255,255,.12);box-shadow:none}
.page-banner .kick::before{background:#cfe2fb}
.page-banner h1{color:#fff;font-size:clamp(2.2rem,4.4vw,3.4rem);font-weight:900;margin-bottom:16px}
.page-banner p{color:rgba(255,255,255,.85);font-size:1.16rem;max-width:640px;margin:0 auto}
.breadcrumb{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:22px;font-size:.95rem;color:rgba(255,255,255,.7)}
.breadcrumb a{color:rgba(255,255,255,.85);font-weight:600}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{opacity:.6}

/* ---------- prose / generic content ---------- */
.prose p{font-size:1.12rem;margin-bottom:18px}
.lead-p{font-size:1.22rem;color:var(--ink);font-weight:600;margin-bottom:22px;line-height:1.6}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.two-col image-slot{width:100%;height:460px;box-shadow:var(--shadow-lg)}
.two-col .portrait-img{width:100%;height:500px;border-radius:var(--r);box-shadow:var(--shadow-lg);
  background:#dce8f5 center/cover no-repeat;filter:saturate(1.02)}
.media-frame{position:relative}
.media-frame .frame{position:absolute;inset:auto -18px -18px auto;width:66%;height:66%;
  border:3px solid color-mix(in srgb,var(--blue) 30%,transparent);border-radius:var(--r);z-index:-1}

/* ---------- services detail page ---------- */
.svc-block{margin-bottom:30px}
.svc-block:last-child{margin-bottom:0}
.svc-block .cat-head{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.svc-block .cat-head .ic{width:62px;height:62px;border-radius:16px;flex:0 0 auto;
  background:color-mix(in srgb,var(--blue) 12%,#fff);color:var(--blue);display:grid;place-items:center}
.svc-block .cat-head h2{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:800;margin:0}
.svc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc-item{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px 26px;
  box-shadow:var(--shadow-sm);transition:.3s;display:flex;gap:16px;align-items:flex-start}
.svc-item:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.svc-item .dot{flex:0 0 auto;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--blue) 11%,#fff);color:var(--blue)}
.svc-item h3{font-size:1.18rem;font-weight:800;margin-bottom:7px}
.svc-item p{font-size:1rem}

/* ---------- FAQ accordion ---------- */
.faq-wrap{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden;transition:.25s}
.faq[open]{box-shadow:var(--shadow);border-color:transparent}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 26px;font-weight:700;font-size:1.14rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q-ic{flex:0 0 auto;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:color-mix(in srgb,var(--blue) 12%,#fff);color:var(--blue);transition:.3s}
.faq[open] summary .q-ic{transform:rotate(45deg);background:var(--blue);color:#fff}
.faq .ans{padding:0 26px 24px;font-size:1.05rem;color:var(--text)}
.faq .ans ul{margin:10px 0 0;padding-inline-start:22px}
.faq .ans li{margin-bottom:8px}

/* ---------- contact page extras ---------- */
.contact.light{background:transparent;color:inherit}
.contact.light h2{color:var(--ink)}
.contact.light .kick{color:#fff;background:var(--blue);box-shadow:0 8px 20px color-mix(in srgb,var(--blue) 30%,transparent)}
.contact.light .kick::before{background:#fff}
.contact.light .lead{color:var(--text)}
.contact.light .contact-info a,.contact.light .contact-info div{color:var(--ink)}
.contact.light .contact-info .ic{background:color-mix(in srgb,var(--blue) 11%,#fff);color:var(--blue)}
.contact.light .contact-info small{color:var(--text)}
.map-card{margin-top:0;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);height:300px;
  background:color-mix(in srgb,var(--blue) 7%,#fff);display:grid;place-items:center;text-align:center;color:var(--blue)}
.map-card .mc-in{display:flex;flex-direction:column;align-items:center;gap:10px;font-weight:700}

@media(max-width:980px){
  .svc-list{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr;gap:40px}
  .two-col .media-frame{order:2}
}
