/* ============================================================
   MECKLEY LIFE SCIENCES — Premium Design System
   ============================================================ */

:root{
  /* Brand */
  --navy:#1f4e79;
  --navy-deep:#143a5c;
  --navy-ink:#0f2d49;
  --red:#e23a32;
  --red-deep:#c42a23;
  /* Surfaces */
  --cream:#f8f4ee;
  --cream-2:#f1ebe1;
  --white:#fffdfa;
  --paper:#ffffff;
  /* Greys */
  --grey-900:#1c2530;
  --grey-700:#41505f;
  --grey-600:#566370;
  --grey-500:#6b7785;
  --grey-300:#c3cbd4;
  --grey-200:#e4e8ed;
  --line:#e8e2d7;
  /* Effects */
  --shadow-sm:0 2px 10px rgba(20,58,92,.06);
  --shadow-md:0 14px 40px -18px rgba(20,58,92,.28);
  --shadow-lg:0 40px 80px -30px rgba(20,58,92,.35);
  --radius:18px;
  --radius-lg:26px;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-head:"Plus Jakarta Sans",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--grey-900);
  background:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--navy);color:#fff}

h1,h2,h3,h4{font-family:var(--font-head);font-weight:800;line-height:1.1;color:var(--navy-ink);letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,5vw,4rem)}
h2{font-size:clamp(2rem,3.6vw,3rem)}
h3{font-size:clamp(1.3rem,2vw,1.6rem)}
p{color:var(--grey-700)}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.section{padding:clamp(70px,9vw,130px) 0}
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy-deep);color:#fff}
.center{text-align:center}

/* ---------- Eyebrow + headings ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-head);font-weight:700;font-size:.8rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--red);
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.eyebrow.center{justify-content:center}
.section-head{max-width:680px;margin-bottom:54px}
.section-head.center{margin-inline:auto}
.section-head p{font-size:1.08rem;margin-top:16px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-weight:700;font-size:.96rem;
  padding:15px 30px;border-radius:60px;border:1.5px solid transparent;
  cursor:pointer;transition:.35s var(--ease);position:relative;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 12px 26px -12px rgba(31,78,121,.7)}
.btn-primary:hover{background:var(--red);box-shadow:0 16px 32px -12px rgba(226,58,50,.6);transform:translateY(-2px)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--grey-300)}
.btn-ghost:hover{border-color:var(--navy);background:var(--navy);color:#fff;transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{background:var(--red);color:#fff;transform:translateY(-2px)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-outline-light:hover{background:#fff;color:var(--navy)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:.4s var(--ease);
}
.site-header .bar{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;transition:.4s var(--ease);
}
.brand img{height:46px;width:auto;transition:.4s var(--ease)}
.site-header.scrolled{background:rgba(255,253,250,.92);backdrop-filter:blur(14px);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--line)}
.site-header.scrolled .bar{height:70px}
.site-header.scrolled .brand img{height:40px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  font-family:var(--font-head);font-weight:600;font-size:.95rem;color:var(--navy-ink);
  padding:10px 16px;border-radius:30px;transition:.25s;position:relative;
}
.nav a:hover{color:var(--red)}
.nav a.active{color:var(--red)}
.nav a.active::after{content:"";position:absolute;bottom:2px;left:16px;right:16px;height:2px;background:var(--red);border-radius:2px}
.header-cta{display:flex;align-items:center;gap:14px}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle span{width:26px;height:2.5px;background:var(--navy-ink);border-radius:3px;transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;padding-top:140px;padding-bottom:90px;
  background:
    radial-gradient(120% 120% at 85% 0%, #eef4fb 0%, rgba(238,244,251,0) 55%),
    linear-gradient(180deg,var(--white) 0%,var(--cream) 100%);
  overflow:hidden;
}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  padding:8px 16px 8px 8px;border-radius:40px;font-size:.82rem;font-weight:600;color:var(--navy);
  box-shadow:var(--shadow-sm);margin-bottom:24px;
}
.hero-badge b{background:var(--navy);color:#fff;padding:4px 12px;border-radius:30px;font-family:var(--font-head);font-size:.74rem}
.hero h1{margin-bottom:22px}
.hero h1 .accent{color:var(--red)}
.hero-lead{font-size:1.15rem;max-width:520px;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-trust{display:flex;gap:34px;flex-wrap:wrap}
.hero-trust .t b{display:block;font-family:var(--font-head);font-size:1.7rem;color:var(--navy);font-weight:800}
.hero-trust .t span{font-size:.82rem;color:var(--grey-500);font-weight:600}

/* Hero visual — rotating product showcase */
.hero-visual{position:relative;height:520px}
.hero-orbit{position:absolute;inset:0;display:grid;place-items:center}
.hero-ring{position:absolute;border:1.5px dashed rgba(31,78,121,.18);border-radius:50%}
.hero-ring.r1{width:420px;height:420px;animation:spin 40s linear infinite}
.hero-ring.r2{width:300px;height:300px;animation:spin 28s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-stage{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:330px;height:430px;border-radius:30px;
  background:linear-gradient(160deg,#fff,#f3f7fc);
  box-shadow:var(--shadow-lg);border:1px solid #fff;overflow:hidden;
}
.hero-card{position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease),transform .9s var(--ease);transform:scale(.94);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px;text-align:center}
.hero-card.active{opacity:1;transform:scale(1)}
.hero-card img{height:230px;object-fit:contain;filter:drop-shadow(0 24px 30px rgba(20,58,92,.18))}
.hero-card .pill-cat{margin-top:18px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red)}
.hero-card h3{margin-top:6px;font-size:1.5rem}
.hero-card p{font-size:.9rem;margin-top:6px}
.hero-float{
  position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow-md);
  padding:14px 18px;display:flex;align-items:center;gap:12px;font-weight:700;font-size:.85rem;color:var(--navy-ink);
  border:1px solid var(--line);z-index:5;
}
.hero-float .ic{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:var(--cream);color:var(--red)}
.hero-float.f1{top:30px;left:-10px;animation:floaty 5s ease-in-out infinite}
.hero-float.f2{bottom:46px;right:-6px;animation:floaty 6s ease-in-out infinite .8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero-dots{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);display:flex;gap:9px;z-index:6}
.hero-dots button{width:9px;height:9px;border-radius:50%;border:0;background:var(--grey-300);cursor:pointer;transition:.3s}
.hero-dots button.on{background:var(--red);width:26px;border-radius:6px}

/* ============================================================
   GENERIC CARD + PRODUCT TILE
   ============================================================ */
.grid{display:grid;gap:26px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

.product-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:.4s var(--ease);cursor:pointer;position:relative;
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:transparent}
.pc-media{
  position:relative;height:210px;background:radial-gradient(120% 120% at 50% 20%,#fff,#f4f7fb);
  display:grid;place-items:center;padding:20px;overflow:hidden;
}
.pc-media img{height:100%;width:100%;object-fit:contain;transition:transform .5s var(--ease)}
.product-card:hover .pc-media img{transform:scale(1.06)}
.pc-cat{position:absolute;top:14px;left:14px;font-family:var(--font-head);font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;padding:5px 11px;border-radius:30px;z-index:2}
.pc-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.pc-body h3{font-size:1.22rem;margin-bottom:3px}
.pc-mol{font-size:.82rem;color:var(--red);font-weight:600;margin-bottom:10px}
.pc-short{font-size:.9rem;color:var(--grey-600);flex:1}
.pc-foot{display:flex;align-items:center;gap:8px;margin-top:16px;font-family:var(--font-head);font-weight:700;font-size:.9rem;color:var(--navy)}
.pc-foot svg{width:16px;height:16px;transition:transform .3s}
.product-card:hover .pc-foot{color:var(--red)}
.product-card:hover .pc-foot svg{transform:translateX(4px)}

/* CSS-generated pack tile for products without a catalogue pack shot */
.pack-tile{width:100%;height:100%;border-radius:14px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:22px;position:relative;overflow:hidden;color:#fff;text-align:center}
.pack-tile::after{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 50% at 50% 0%,rgba(255,255,255,.18),transparent 70%)}
.pack-tile .pt-cap{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.16);
  display:grid;place-items:center;margin-bottom:14px;border:1px solid rgba(255,255,255,.3)}
.pack-tile .pt-cap svg{width:26px;height:26px;color:#fff}
.pack-tile .pt-name{font-family:var(--font-head);font-weight:800;font-size:1.35rem;line-height:1.1;z-index:1}
.pack-tile .pt-mol{font-size:.72rem;opacity:.85;margin-top:8px;font-weight:600;letter-spacing:.04em;z-index:1;max-width:200px}
.pack-tile .pt-rx{position:absolute;top:14px;right:16px;font-family:var(--font-head);font-style:italic;font-weight:700;opacity:.5}

/* ============================================================
   CATEGORY CARDS
   ============================================================ */
.cat-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:34px;min-height:230px;
  display:flex;flex-direction:column;justify-content:flex-end;color:#fff;cursor:pointer;
  transition:.45s var(--ease);background:var(--navy);
}
.cat-card::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(255,255,255,.12),rgba(0,0,0,.18))}
.cat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.cat-ic{position:relative;width:56px;height:56px;border-radius:16px;background:rgba(255,255,255,.16);display:grid;place-items:center;margin-bottom:auto;border:1px solid rgba(255,255,255,.25)}
.cat-ic svg{width:28px;height:28px}
.cat-card h3{color:#fff;position:relative;margin-top:20px;font-size:1.4rem}
.cat-card .cc-meta{position:relative;display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-size:.86rem;opacity:.92}
.cat-card .cc-meta .arr{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.2);display:grid;place-items:center;transition:.35s}
.cat-card:hover .cc-meta .arr{background:#fff;color:var(--navy);transform:translateX(4px)}

/* ============================================================
   SPLIT / ABOUT PREVIEW / FEATURE BLOCKS
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-figure{position:relative}
.about-figure .frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3;background:var(--navy)}
.about-figure .frame img{width:100%;height:100%;object-fit:cover}
.about-figure .badge-stat{
  position:absolute;bottom:-26px;right:-10px;background:#fff;border-radius:20px;padding:22px 26px;
  box-shadow:var(--shadow-md);border:1px solid var(--line);text-align:center;
}
.about-figure .badge-stat b{display:block;font-family:var(--font-head);font-size:2.4rem;color:var(--red);font-weight:800;line-height:1}
.about-figure .badge-stat span{font-size:.8rem;color:var(--grey-500);font-weight:600}
.tick-list{margin:26px 0 32px;display:grid;gap:14px}
.tick-list li{display:flex;gap:13px;align-items:flex-start;font-weight:500;color:var(--grey-700)}
.tick-list .tk{flex:none;width:24px;height:24px;border-radius:50%;background:var(--cream-2);color:var(--navy);display:grid;place-items:center;margin-top:2px}
.tick-list .tk svg{width:13px;height:13px}

/* visual aid figure (about hero / image substitute) */
.media-collage{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:linear-gradient(150deg,var(--navy),var(--navy-ink));aspect-ratio:4/3;display:grid;place-items:center;color:#fff;text-align:center;padding:40px}
.media-collage .mc-mark{width:88px;height:88px;border-radius:24px;background:rgba(255,255,255,.12);display:grid;place-items:center;margin:0 auto 20px;border:1px solid rgba(255,255,255,.25)}
.media-collage .mc-mark svg{width:44px;height:44px}
.media-collage h3{color:#fff;font-size:1.6rem}
.media-collage p{color:rgba(255,255,255,.8);margin-top:10px;max-width:340px}

/* ============================================================
   WHY CHOOSE — feature cards
   ============================================================ */
.feature-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;
  transition:.4s var(--ease);position:relative;overflow:hidden;
}
.feature-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:.4s var(--ease)}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.feature-card:hover::before{transform:scaleX(1)}
.feature-card .fc-ic{width:62px;height:62px;border-radius:18px;background:linear-gradient(150deg,var(--navy),var(--navy-deep));display:grid;place-items:center;margin-bottom:22px;box-shadow:0 12px 24px -12px rgba(31,78,121,.6)}
.feature-card .fc-ic svg{width:30px;height:30px;color:#fff}
.feature-card h3{font-size:1.18rem;margin-bottom:10px}
.feature-card p{font-size:.92rem}

/* ============================================================
   STATS COUNTER
   ============================================================ */
.stats-section{background:linear-gradient(135deg,var(--navy-ink) 0%,var(--navy-deep) 50%,#1a2d4a 100%);position:relative;overflow:hidden}
.stats-section::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 20% 50%,rgba(226,58,50,.08) 0%,transparent 60%),radial-gradient(ellipse 60% 60% at 80% 50%,rgba(31,78,121,.3) 0%,transparent 60%);pointer-events:none}
.stats-section .section-head h2,.stats-section .section-head p{color:#fff}
.stats-section .section-head p{color:rgba(255,255,255,.7)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;z-index:1}
.stat{text-align:center;padding:36px 24px 32px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:20px;position:relative;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s}
.stat::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),#ff6b62);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.stat::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(226,58,50,.08),transparent 70%);opacity:0;transition:opacity .35s}
.stat:hover{transform:translateY(-8px);box-shadow:0 30px 60px -15px rgba(0,0,0,.5);background:rgba(255,255,255,.1)}
.stat:hover::before{transform:scaleX(1)}
.stat:hover::after{opacity:1}
.stat-ic{width:58px;height:58px;border-radius:16px;background:rgba(226,58,50,.15);border:1px solid rgba(226,58,50,.25);display:grid;place-items:center;margin:0 auto 22px;transition:background .35s,transform .35s}
.stat:hover .stat-ic{background:rgba(226,58,50,.25);transform:scale(1.08)}
.stat-ic svg{width:26px;height:26px;color:var(--red)}
.stat b{font-family:var(--font-head);font-size:clamp(2.6rem,4.5vw,3.6rem);font-weight:800;color:#fff;line-height:1;display:block}
.stat b .suf{color:var(--red)}
.stat>span{display:block;margin-top:12px;font-weight:700;color:#fff;font-size:1rem;letter-spacing:.02em}
.stat-sub{font-size:.82rem;color:rgba(255,255,255,.5);margin-top:8px;line-height:1.5}
.bg-navy .feature-card h3{color:var(--navy)}
.bg-navy .feature-card p{color:var(--grey-700)}
.bg-navy .eyebrow{color:#7fb0e6}
.bg-navy .eyebrow::before{background:#7fb0e6}
.bg-navy h2{color:#fff}
.bg-navy p{color:rgba(255,255,255,.8)}

/* ============================================================
   CTA / ENQUIRY
   ============================================================ */
.cta-split{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.cta-box{border-radius:var(--radius-lg);padding:46px;position:relative;overflow:hidden;color:#fff}
.cta-box.doctor{background:linear-gradient(150deg,var(--navy),var(--navy-ink))}
.cta-box.dist{background:linear-gradient(150deg,var(--red),var(--red-deep))}
.cta-box .ic-lg{width:64px;height:64px;border-radius:18px;background:rgba(255,255,255,.16);display:grid;place-items:center;margin-bottom:24px}
.cta-box .ic-lg svg{width:32px;height:32px}
.cta-box h3{color:#fff;font-size:1.6rem;margin-bottom:12px}
.cta-box p{color:rgba(255,255,255,.85);margin-bottom:26px;font-size:.98rem}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{
  padding:150px 0 80px;background:
   radial-gradient(100% 120% at 90% 0%,#eaf1f9,rgba(234,241,249,0) 60%),
   linear-gradient(180deg,var(--white),var(--cream));
  text-align:center;position:relative;overflow:hidden;
}
.page-hero h1{margin-bottom:18px}
.page-hero p{max-width:620px;margin:0 auto;font-size:1.12rem}
.crumbs{display:flex;gap:8px;justify-content:center;margin-bottom:22px;font-size:.85rem;color:var(--grey-500);font-weight:600}
.crumbs a:hover{color:var(--red)}

/* ============================================================
   ABOUT PAGE — mission/vision/values/timeline
   ============================================================ */
.mv-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:40px;position:relative;height:100%}
.mv-card .ic{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;margin-bottom:22px;background:var(--cream);color:var(--navy)}
.mv-card .ic svg{width:30px;height:30px}
.mv-card h3{margin-bottom:12px}

.value-row{display:flex;gap:20px;padding:26px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.value-row:last-child{border-bottom:0}
.value-row .v-no{font-family:var(--font-head);font-weight:800;font-size:1.6rem;color:var(--grey-300);flex:none;width:60px}
.value-row .v-body h3{font-size:1.2rem;margin-bottom:6px}

/* Timeline */
.timeline{position:relative;max-width:860px;margin:0 auto}
.timeline::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--line);transform:translateX(-50%)}
.tl-item{position:relative;width:50%;padding:0 46px 50px}
.tl-item:nth-child(odd){left:0;text-align:right}
.tl-item:nth-child(even){left:50%}
.tl-dot{position:absolute;top:4px;width:18px;height:18px;border-radius:50%;background:var(--red);border:4px solid var(--white);box-shadow:0 0 0 3px rgba(226,58,50,.2)}
.tl-item:nth-child(odd) .tl-dot{right:-9px}
.tl-item:nth-child(even) .tl-dot{left:-9px}
.tl-year{font-family:var(--font-head);font-weight:800;color:var(--red);font-size:1.4rem;margin-bottom:6px}
.tl-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm)}
.tl-card h3{font-size:1.12rem;margin-bottom:8px}
.tl-card p{font-size:.92rem}

/* ============================================================
   PRODUCTS PAGE — toolbar, search, filters
   ============================================================ */
.products-toolbar{position:sticky;top:70px;z-index:50;background:rgba(255,253,250,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);padding:18px 0}
.toolbar-inner{display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.search-box{position:relative;flex:1;min-width:240px;max-width:440px}
.search-box svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--grey-500)}
.search-box input{
  width:100%;padding:14px 18px 14px 48px;border:1.5px solid var(--line);border-radius:50px;
  font-family:var(--font-body);font-size:.96rem;background:#fff;transition:.3s;
}
.search-box input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 4px rgba(31,78,121,.1)}
.filters{display:flex;gap:9px;flex-wrap:wrap}
.chip{
  font-family:var(--font-head);font-weight:600;font-size:.86rem;padding:10px 18px;border-radius:40px;
  border:1.5px solid var(--line);background:#fff;color:var(--grey-700);cursor:pointer;transition:.25s;
}
.chip:hover{border-color:var(--navy);color:var(--navy)}
.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.results-meta{margin:30px 0 24px;font-size:.92rem;color:var(--grey-500);font-weight:600}
.results-meta b{color:var(--navy)}
.no-results{text-align:center;padding:80px 0;color:var(--grey-500);grid-column:1/-1}
.no-results svg{width:54px;height:54px;color:var(--grey-300);margin:0 auto 18px}

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay{
  position:fixed;inset:0;z-index:2000;background:rgba(15,45,73,.5);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:.35s;
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{
  background:var(--white);border-radius:var(--radius-lg);max-width:980px;width:100%;max-height:90vh;overflow:hidden;
  display:grid;grid-template-columns:.85fr 1.15fr;grid-template-rows:minmax(0,90vh);transform:translateY(26px) scale(.98);transition:.4s var(--ease);
}
.modal-overlay.open .modal{transform:none}
.modal-media{background:radial-gradient(120% 100% at 50% 10%,#fff,#eef3f9);display:grid;place-items:center;padding:36px;position:relative}
.modal-media img{max-height:340px;width:auto;object-fit:contain;filter:drop-shadow(0 30px 40px rgba(20,58,92,.2))}
.modal-media .pack-tile{aspect-ratio:3/4;max-width:280px;height:auto;min-height:360px}
.modal-body{padding:40px;overflow-y:auto;min-height:0}
.modal-cat{font-family:var(--font-head);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;padding:5px 12px;border-radius:30px;display:inline-block;margin-bottom:14px}
.modal-body h2{font-size:2rem;margin-bottom:4px}
.modal-sub{color:var(--red);font-weight:600;margin-bottom:18px;font-size:.95rem}
.modal-body .lead{font-size:1rem;color:var(--grey-700);margin-bottom:24px}
.modal-sect{margin-bottom:22px}
.modal-sect h4{font-family:var(--font-head);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.modal-sect h4::before{content:"";width:16px;height:2px;background:var(--red)}
.comp-list{display:flex;flex-wrap:wrap;gap:8px}
.comp-list span{background:var(--cream);border:1px solid var(--line);padding:7px 13px;border-radius:30px;font-size:.82rem;font-weight:500;color:var(--navy-ink)}
.benefit-list{display:grid;gap:10px}
.benefit-list li{display:flex;gap:11px;font-size:.92rem;color:var(--grey-700)}
.benefit-list .bk{flex:none;width:20px;height:20px;border-radius:50%;background:rgba(46,158,91,.14);color:#2e9e5b;display:grid;place-items:center;margin-top:2px}
.benefit-list .bk svg{width:12px;height:12px}
.modal-use{background:var(--cream);border-radius:14px;padding:16px 18px;font-size:.9rem;color:var(--grey-700)}
.modal-use b{color:var(--navy-ink)}
.modal-actions{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}
.modal-close{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--line);display:grid;place-items:center;cursor:pointer;z-index:3;transition:.25s;box-shadow:var(--shadow-sm)}
.modal-close:hover{background:var(--red);color:#fff;border-color:var(--red);transform:rotate(90deg)}
.modal-close svg{width:18px;height:18px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy-ink);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:48px;margin-bottom:20px}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.92rem;max-width:300px}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px;font-family:var(--font-head)}
.footer-col ul{display:grid;gap:12px}
.footer-col a{font-size:.92rem;transition:.25s}
.footer-col a:hover{color:#fff;padding-left:4px}
.footer-contact li{display:flex;gap:12px;font-size:.92rem;margin-bottom:14px;align-items:flex-start}
.footer-contact svg{width:18px;height:18px;color:var(--red);flex:none;margin-top:2px}
.footer-contact a:hover{color:#fff;padding-left:0}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:26px 0;flex-wrap:wrap;gap:12px;font-size:.85rem}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none!important}
  html{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hero .container{grid-template-columns:1fr;gap:40px}
  .hero-visual{height:440px;order:-1}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:16px}
  .stat{padding:28px 18px 24px}
  .footer-top{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:820px){
  .nav,.header-cta .btn{display:none}
  .menu-toggle{display:flex}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#fff;
    padding:18px;gap:4px;box-shadow:var(--shadow-md);border-top:1px solid var(--line)}
  .nav.open a{width:100%;padding:14px 16px}
  .split,.cta-split,.modal{grid-template-columns:1fr}
  .modal{max-height:92vh;overflow-y:auto;grid-template-rows:auto auto}
  .modal-media{padding:28px}
  .modal-media img{max-height:240px}
  .timeline::before{left:18px}
  .tl-item{width:100%;left:0!important;text-align:left!important;padding:0 0 40px 50px}
  .tl-item .tl-dot{left:9px!important;right:auto!important}
  .about-figure{margin-bottom:30px}
}
@media(max-width:560px){
  .g-2,.g-3{grid-template-columns:1fr}
  .hero-trust{gap:22px}
  .section{padding:60px 0}
  .cta-box{padding:34px}
  .footer-top{grid-template-columns:1fr}
}
