/* ============== Bazelet site — shared styles ============== */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --navy:#0A2A40; --navy-deep:#07202E; --brand:#135D8C; --green:#8DC63F;
  --line:rgba(255,255,255,.10);
  --muted:rgba(255,255,255,.72);
  --ink:#15242E; --ink-soft:#48565F; --page:#F5F8FA; --line-d:#E2E8ED;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--navy);color:#fff;
     -webkit-font-smoothing:antialiased;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit}
:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:2px}
.mono{font-family:'IBM Plex Mono',monospace}
.wrap{max-width:1240px;margin:0 auto;width:100%;padding-left:clamp(20px,4vw,40px);padding-right:clamp(20px,4vw,40px)}

/* ---------- header / nav ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(10,42,64,.92);
       backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand .mark{width:16px;height:16px;background:var(--green);border-radius:3px;flex:none}
.brand .name{font-weight:600;font-size:1.05rem;letter-spacing:.22em;color:#fff}
.links{display:flex;gap:clamp(14px,1.7vw,28px);font-size:.94rem;color:var(--muted)}
.links a{text-decoration:none;transition:color .2s}
.links a:hover,.links a.active{color:#fff}
.links a.gmp{color:var(--green)}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:#fff;border-radius:6px;padding:8px 13px;font-size:.8rem;cursor:pointer}

/* ---------- hero ---------- */
.hero{display:flex;flex-direction:column}
.hero-body{display:grid;grid-template-columns:1.04fr .96fr;align-items:center;
           gap:clamp(24px,3vw,48px);padding:clamp(44px,6vh,86px) 0}
.hero-copy{max-width:560px}
.hero h1{font-weight:600;font-size:clamp(2.9rem,5.4vw,4.8rem);line-height:1.06;letter-spacing:-.015em}
.hero h1 .nb{white-space:nowrap}
.rule{width:60px;height:3px;background:var(--green);margin:26px 0 24px}
.hero .sub{font-size:clamp(1.05rem,1.3vw,1.25rem);line-height:1.6;color:var(--muted);max-width:480px}
.btn{display:inline-block;padding:14px 30px;border-radius:8px;font-size:.92rem;
     text-decoration:none;transition:.2s;border:1px solid transparent;cursor:pointer}
.btn-outline{border-color:rgba(255,255,255,.55);color:#fff;margin-top:32px}
.btn-outline:hover{background:#fff;color:var(--navy)}
.btn-solid{background:var(--green);color:var(--navy);font-weight:600}
.btn-solid:hover{filter:brightness(1.08)}
.hero-shot{display:flex;justify-content:flex-end;align-items:center}
.hero-shot img{width:100%;max-width:620px}
.hero-shot img.lineup-card{border-radius:14px;box-shadow:0 22px 55px rgba(0,0,0,.38)}

/* ---------- full-bleed hero ---------- */
.hero-full .hero-stage{position:relative;isolation:isolate;display:flex;align-items:center;
  min-height:clamp(440px,64vh,660px);overflow:hidden}
.hero-full .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:50% 50%;z-index:-2}
.hero-full .hero-scrim{position:absolute;inset:0;z-index:-1;background:
  linear-gradient(90deg,rgba(10,42,64,.97) 0%,rgba(10,42,64,.88) 28%,rgba(10,42,64,.60) 52%,rgba(10,42,64,.20) 78%,rgba(10,42,64,.05) 100%),
  linear-gradient(0deg,rgba(7,32,46,.55) 0%,rgba(7,32,46,0) 45%)}
.hero-full .hero-body{grid-template-columns:1fr;width:100%;padding:clamp(48px,8vh,96px) 0}
.hero-full .hero-copy{max-width:600px}
.hero-full .sub{color:rgba(255,255,255,.88)}

/* ---------- pillars strip ---------- */
.pillars{border-top:1px solid var(--line);background:var(--navy-deep)}
.pillars .grid{display:grid;grid-template-columns:repeat(5,1fr)}
.pillar{padding:24px 18px;border-left:1px solid var(--line);display:flex;gap:10px;align-items:flex-start}
.pillar:first-child{border-left:none;padding-left:0}
.pillar svg{flex:none;margin-top:1px}
.pillar span{font-size:.82rem;line-height:1.45;color:rgba(255,255,255,.85)}

/* ---------- generic section ---------- */
.section{padding:clamp(64px,9vh,118px) 0}
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:.82rem;letter-spacing:.16em;
         text-transform:uppercase;color:var(--brand)}
.section h2{font-weight:600;font-size:clamp(2.2rem,3.6vw,3.3rem);line-height:1.14;letter-spacing:-.01em;margin-top:16px}

/* light section (About on home) */
.s-light{background:var(--page);color:var(--ink)}
.s-light .eyebrow{color:var(--brand)}
.s-light .lead{font-size:clamp(1.6rem,2.4vw,2.2rem);line-height:1.4;font-weight:500;
               margin-top:18px;max-width:900px;color:var(--ink)}
.s-light .cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);margin-top:42px}
.s-light .cols p{font-size:1.04rem;line-height:1.75;color:var(--ink-soft)}
.s-light .close{margin-top:40px;padding-top:30px;border-top:1px solid var(--line-d);
                font-size:clamp(1.3rem,1.8vw,1.55rem);font-weight:500;color:var(--ink);max-width:820px}

/* why-us grid (navy) */
.why .grid{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(20px,2.4vw,34px);margin-top:50px}
.why .card{width:332px;flex:0 0 auto}
.card{padding:26px 24px;background:rgba(255,255,255,.025);border:1px solid var(--line);
      border-top:2px solid var(--green);border-radius:6px}
.card h3{font-size:1.12rem;font-weight:600;letter-spacing:-.005em}
.card p{font-size:.95rem;line-height:1.65;color:var(--muted);margin-top:12px}
.card a.link{display:inline-block;margin-top:14px;color:#fff;font-size:.8rem;font-family:'IBM Plex Mono',monospace;text-decoration:none;border-bottom:1px solid var(--green);padding-bottom:2px}
.card a.link:hover{color:var(--green)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--brand);text-align:center}
.cta-band .wrap{padding:clamp(56px,8vh,90px) clamp(20px,4vw,40px)}
.cta-band h2{font-weight:600;font-size:clamp(1.8rem,2.6vw,2.5rem);letter-spacing:-.01em}
.cta-band p{color:rgba(255,255,255,.85);margin-top:14px;font-size:1.08rem}
.cta-band .btn-solid{margin-top:30px}
.cta-band .mailto{display:block;margin-top:18px;font-family:'IBM Plex Mono',monospace;
                  font-size:.9rem;color:rgba(255,255,255,.8);text-decoration:none}

/* ---------- footer ---------- */
footer{background:var(--navy-deep);border-top:1px solid var(--line)}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;padding:56px 0 30px}
.foot .name{font-weight:600;letter-spacing:.2em;font-size:1rem}
.foot p{color:var(--muted);font-size:.9rem;line-height:1.6;margin-top:14px;max-width:300px}
.foot h4{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);
         font-family:'IBM Plex Mono',monospace;margin-bottom:14px}
.foot a{display:block;color:var(--muted);text-decoration:none;font-size:.9rem;margin-bottom:9px;transition:color .2s}
.foot a:hover{color:#fff}
.foot-bottom{border-top:1px solid var(--line);padding:20px 0;display:flex;justify-content:space-between;
             flex-wrap:wrap;gap:8px;color:rgba(255,255,255,.4);font-size:.78rem}

/* ---------- motion ---------- */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero-copy>*{animation:rise .7s cubic-bezier(.2,.7,.2,1) both}
.hero-copy>*:nth-child(2){animation-delay:.05s}
.hero-copy>*:nth-child(3){animation-delay:.1s}
.hero-copy>*:nth-child(4){animation-delay:.15s}
.hero-shot img{animation:rise .9s .1s cubic-bezier(.2,.7,.2,1) both}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .links{display:none}.menu-btn{display:block}
  .hero-body{grid-template-columns:1fr;gap:10px}.hero-copy{max-width:none}
  .hero-shot{justify-content:center}.hero-shot img{max-width:400px}
  .hero-full .hero-stage{min-height:clamp(420px,74vh,560px)}
  .hero-full .hero-scrim{background:linear-gradient(180deg,rgba(10,42,64,.74) 0%,rgba(10,42,64,.58) 42%,rgba(7,32,46,.86) 100%)}
  .hero-full .hero-bg{object-position:55% 45%}
  .pillars .grid{grid-template-columns:1fr 1fr}
  .pillar{border-left:none;border-top:1px solid var(--line);padding-left:0}
  .pillar:first-child,.pillar:nth-child(2){border-top:none}
  .s-light .cols{grid-template-columns:1fr;gap:18px}
  .why .grid{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr;gap:28px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important}}

/* ============== logo ============== */
.brand .logo{height:30px;width:auto;display:block}
.foot .logo-full{width:210px;height:auto;margin-bottom:10px}

/* ============== inner pages ============== */
.page-head{background:var(--navy);border-bottom:1px solid var(--line);
           padding:clamp(50px,9vh,104px) 0 clamp(40px,6vh,66px)}
.page-head h1{font-weight:600;font-size:clamp(2.6rem,4.7vw,4.1rem);line-height:1.1;
              letter-spacing:-.015em;margin-top:14px;max-width:920px}
.page-head .intro{font-size:clamp(1.05rem,1.35vw,1.24rem);line-height:1.62;color:var(--muted);
                  max-width:760px;margin-top:22px}

.prose p{font-size:1.04rem;line-height:1.78;margin-top:18px;max-width:850px;color:var(--muted)}
.prose p:first-child{margin-top:0}
.s-light .prose p{color:var(--ink-soft)}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);margin-top:34px}
.twocol p{margin-top:0}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,34px);margin-top:46px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:42px}

/* team */
.team-row{display:grid;grid-template-columns:120px 1fr;gap:28px;padding:30px 0;
          border-top:1px solid var(--line);align-items:start}
.team-row:first-child{border-top:none;padding-top:6px}
.avatar{width:116px;height:116px;border-radius:50%;overflow:hidden;flex:none;
        background:rgba(255,255,255,.05);border:1px solid var(--line);
        display:flex;align-items:center;justify-content:center}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.avatar svg{opacity:.3}
.team-row h3{font-size:1.18rem;font-weight:600}
.team-row .role{color:var(--green);font-family:'IBM Plex Mono',monospace;font-size:.74rem;
                letter-spacing:.06em;text-transform:uppercase;margin:5px 0 12px}
.team-row p{color:var(--muted);line-height:1.66;font-size:.96rem;max-width:780px}

/* products */
.product{padding:30px 28px;background:rgba(255,255,255,.028);border:1px solid var(--line);
         border-top:2px solid var(--green);border-radius:8px}
.product h3{font-size:1.3rem;font-weight:600}
.product .ratios{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--green);margin:8px 0 0}
.product p{color:var(--muted);line-height:1.66;margin-top:12px;font-size:.97rem}

/* publications */
.pub{padding:26px 0;border-top:1px solid var(--line)}
.pub:first-child{border-top:none}
.pub h3{font-size:1.06rem;font-weight:600;line-height:1.45;max-width:880px}
.pub .meta{color:var(--green);font-family:'IBM Plex Mono',monospace;font-size:.76rem;margin:7px 0 10px}
.pub p{color:var(--muted);font-size:.95rem;line-height:1.6;max-width:860px}
.pub a.link{display:inline-block;margin-top:11px;color:#fff;font-size:.8rem;
            font-family:'IBM Plex Mono',monospace;text-decoration:none;border-bottom:1px solid var(--green);padding-bottom:2px}
.pub a.link:hover{color:var(--green)}

/* certificates */
.certs{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:44px}
.cert{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 26px;
      background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:8px;text-decoration:none;transition:.2s}
.cert:hover{border-color:var(--green);background:rgba(141,198,63,.05)}
.cert h3{font-size:1.05rem;font-weight:600}
.cert .sub{font-family:'IBM Plex Mono',monospace;font-size:.74rem;color:var(--muted);margin-top:4px}
.cert .dl{color:var(--green);font-family:'IBM Plex Mono',monospace;font-size:.78rem;white-space:nowrap}
.cert-links{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
a.dl{text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
a.dl:hover{border-bottom-color:var(--green)}
.cert.pending{opacity:.62}
.cert.pending .dl{color:var(--muted)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:44px}
.contact-card{padding:28px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:8px}
.contact-card h4{font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.1em;
                 text-transform:uppercase;color:rgba(255,255,255,.5)}
.contact-card a,.contact-card .val{display:block;margin-top:12px;font-size:1.12rem;color:#fff;text-decoration:none}
.contact-card a:hover{color:var(--green)}

@media (max-width:900px){
  .twocol{grid-template-columns:1fr;gap:18px}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .team-row{grid-template-columns:1fr;gap:14px}
  .certs{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}

/* ============== dropdown nav ============== */
.dropdown{position:relative}
.dropdown .drop-toggle{cursor:pointer;display:inline-flex;align-items:center;gap:5px;color:var(--muted);text-decoration:none;transition:color .2s}
.dropdown .drop-toggle:hover,.dropdown .drop-toggle.active{color:#fff}
.caret{font-size:.6em;opacity:.65;transition:transform .2s}
.dropdown.open .caret{transform:rotate(180deg)}
.dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:16px;
  background:#0C3047;border:1px solid var(--line);border-radius:10px;padding:7px;min-width:190px;
  display:none;z-index:60;box-shadow:0 12px 34px rgba(0,0,0,.35)}
.dropdown:hover .dropdown-menu,.dropdown.open .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:10px 14px;border-radius:6px;color:var(--muted);font-size:.84rem;white-space:nowrap;text-decoration:none;transition:.15s}
.dropdown-menu a:hover,.dropdown-menu a.active{color:#fff;background:rgba(255,255,255,.06)}

/* ============== team page ============== */
.page-head .intro{max-width:700px}
.founders{display:flex;justify-content:center;gap:clamp(40px,8vw,120px);margin:8px 0 64px;flex-wrap:wrap}
.tgrid{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(30px,3vw,46px) 20px}
.tgrid .tcard{width:170px}
.tcard{text-align:center}
.tcard .avatar{width:118px;height:118px;margin:0 auto}
.founders .tcard .avatar{width:170px;height:170px}
.tcard h3{font-size:1.05rem;font-weight:600;margin-top:16px}
.founders .tcard h3{font-size:1.22rem}
.trole{color:var(--green);font-family:'IBM Plex Mono',monospace;font-size:.71rem;letter-spacing:.04em;text-transform:uppercase;margin-top:7px;line-height:1.45}
.abtn{margin-top:14px;background:none;border:1px solid rgba(141,198,63,.5);color:var(--green);font-family:'IBM Plex Mono',monospace;font-size:.7rem;letter-spacing:.06em;padding:6px 15px;border-radius:20px;cursor:pointer;transition:.2s}
.abtn:hover{background:rgba(141,198,63,.1)}
.tbio{max-height:0;overflow:hidden;transition:max-height .45s ease;text-align:left}
.tcard.open .tbio{max-height:1000px;margin-top:16px}
.tcard.open .abtn{background:rgba(141,198,63,.14)}
.tbio p{color:var(--muted);font-size:.9rem;line-height:1.62}

/* mobile menu + dropdown */
.links.show{display:flex!important;position:absolute;flex-direction:column;top:62px;right:20px;
  background:#0A2A40;padding:18px 22px;border-radius:10px;border:1px solid var(--line);gap:14px;z-index:70}
@media (max-width:1150px){.tgrid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:720px){.tgrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:900px){
  .dropdown{width:100%}
  .dropdown-menu{position:static;transform:none;display:block;margin-top:8px;box-shadow:none;background:transparent;border:none;padding:0 0 0 14px;min-width:0}
  .dropdown .caret{display:none}
}
@media (max-width:560px){.tgrid{grid-template-columns:1fr}.founders{gap:40px}}

/* constrain card width so hidden bios don't stretch the founders row */
.founders .tcard{width:300px}
.tcard .tbio{max-width:100%}
@media (max-width:560px){.founders .tcard{width:100%;max-width:320px}}

.avatar .mono-avatar{font-family:'IBM Plex Mono',monospace;font-size:1.55rem;color:rgba(255,255,255,.5);letter-spacing:.04em}
@media(max-width:900px){.why .card{width:100%}}

/* ============== product cards with bottle (Products page) ============== */
.product.has-shot{display:flex;gap:22px;align-items:center;background:transparent}
.product.has-shot .pshot{flex:0 0 180px;height:180px;border-radius:8px;overflow:hidden;padding:14px;box-sizing:border-box}
.product.has-shot .pshot img{width:100%;height:100%;object-fit:cover;display:block}
.product.has-shot .pbody{flex:1;min-width:0}
@media(max-width:560px){
  .product.has-shot{flex-direction:row;gap:16px}
  .product.has-shot .pshot{flex:0 0 132px;height:132px;padding:10px;box-sizing:border-box}
}

/* WhatsApp button (contact card + inline) */
.wa-btn{display:inline-flex;align-items:center;gap:9px;margin-top:14px;background:#25D366;color:#fff;
  padding:11px 20px;border-radius:8px;font-size:.92rem;font-weight:600;text-decoration:none;transition:.2s}
.wa-btn:hover{filter:brightness(1.06);color:#fff}
.wa-btn svg{width:18px;height:18px;flex:none}

/* ============== media / figure blocks (lab photography) ============== */
.media{margin:48px 0 0;max-width:850px;border:1px solid var(--line);border-radius:12px;overflow:hidden;
  background:var(--navy-deep);position:relative}
.media img{width:100%;height:auto;display:block}
.media .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 24px 16px;
  background:linear-gradient(180deg,rgba(7,32,46,0) 0%,rgba(7,32,46,.82) 100%);
  font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.04em;color:rgba(255,255,255,.82)}
.s-light .media{border-color:var(--line-d)}

/* two-column feature: text + image */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center;margin-top:8px}
.feature .media{margin-top:0;max-width:none}
.feature .fimg{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--navy-deep)}
.feature .fimg img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3}
@media(max-width:900px){.feature{grid-template-columns:1fr;gap:26px}}

/* ============== floating WhatsApp button ============== */
.wa-float{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:80;
  width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.32);transition:transform .2s,box-shadow .2s;text-decoration:none}
.wa-float:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 12px 30px rgba(0,0,0,.4)}
.wa-float svg{width:30px;height:30px}
@media(max-width:560px){.wa-float{width:52px;height:52px}.wa-float svg{width:28px;height:28px}}
@media(prefers-reduced-motion:reduce){.wa-float{transition:none}}

/* hero-style feather: melt figure edges into the navy page */
.media.blend, .feature .fimg.blend{border:none;background:transparent;border-radius:0;overflow:visible}
.media.blend img, .feature .fimg.blend img{
  -webkit-mask-image:linear-gradient(180deg,#000 60%,transparent 100%);
          mask-image:linear-gradient(180deg,#000 60%,transparent 100%)}

/* photo credit captions on hero + About figure */
.hero-cap{position:absolute;left:clamp(20px,4vw,40px);bottom:14px;z-index:2;
  font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.04em;
  color:rgba(255,255,255,.70);text-shadow:0 1px 10px rgba(7,32,46,.7)}
.feature .fimg{position:relative}
.feature .fimg .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 20px 14px;
  background:linear-gradient(180deg,rgba(7,32,46,0) 0%,rgba(7,32,46,.82) 100%);
  font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.04em;color:rgba(255,255,255,.82)}
