/* =========================================================
   R4 HEALTH CARE — Design System
   Primary: Trust Blue | Accent: Maroon | CTA: Amber
   Display: Fraunces | Body: Inter | Utility: IBM Plex Mono
   ========================================================= */

:root{
  --ink:#0F1B33;
  --ink-soft:#46556E;
  --paper:#F6F7FB;
  --paper-raised:#FFFFFF;
  --line:#E2E6EF;

  --blue-900:#0C3B2A;
  --blue-700:#15623F;
  --blue-600:#1E8E55;
  --blue-100:#E3F5EA;

  --maroon-700:#0E4D38;
  --maroon-600:#2F8F5B;
  --maroon-100:#E9F7EE;

  --amber-600:#E0900B;
  --amber-500:#F0A521;
  --amber-100:#FCEDD3;

  --green-600:#1E8E55;
  --pink-500:#E16E8C;
  --purple-500:#8E5BA8;
  --gray-600:#4B5468;

  --radius-s:10px;
  --radius-m:18px;
  --radius-l:28px;

  --shadow-sm:0 2px 10px rgba(15,27,51,.06);
  --shadow-md:0 16px 40px -12px rgba(15,27,51,.18);
  --shadow-lg:0 30px 70px -20px rgba(11,46,102,.28);

  --container:1180px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,select,textarea{font-family:inherit;font-size:1rem;}

h1,h2,h3,h4{
  font-family:'Fraunces',serif;
  font-weight:600;
  line-height:1.12;
  letter-spacing:-0.01em;
  color:var(--blue-900);
}
.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--maroon-600);
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:18px;height:2px;
  background:var(--amber-500);
  display:inline-block;
}
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}
.lede{color:var(--ink-soft);font-size:1.06rem;max-width:620px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  border-radius:999px;
  font-weight:600;font-size:.95rem;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  white-space:nowrap;
}
.btn-primary{
  background:var(--blue-600);color:#fff;
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-amber{
  background:var(--amber-500);color:var(--blue-900);
}
.btn-amber:hover{background:var(--amber-600);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-ghost{
  border:1.5px solid var(--line);color:var(--blue-900);background:transparent;
}
.btn-ghost:hover{border-color:var(--blue-600);background:var(--blue-100);}
.btn-on-dark{border:1.5px solid rgba(255,255,255,.4);color:#fff;}
.btn-on-dark:hover{background:rgba(255,255,255,.12);border-color:#fff;}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(246,247,251,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;
  max-width:var(--container);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:700;font-size:1.25rem;color:var(--blue-900);}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--maroon-600);box-shadow:0 0 0 4px var(--amber-100);}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-weight:600;font-size:.95rem;color:var(--ink-soft);position:relative;padding:4px 0;}
.nav-links a:hover, .nav-links a.active{color:var(--blue-700);}
.nav-links a.active::after{
  content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--amber-500);
}
.nav-cta{display:flex;align-items:center;gap:14px;}
.nav-call{font-weight:700;color:var(--maroon-600);font-size:.92rem;display:flex;align-items:center;gap:6px;}
.menu-toggle{display:none;flex-direction:column;gap:5px;}
.menu-toggle span{width:24px;height:2px;background:var(--blue-900);border-radius:2px;}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:168px 0 110px;
  background:
    radial-gradient(900px 500px at 85% -10%, var(--blue-100) 0%, transparent 60%),
    linear-gradient(180deg,#FAFBFE 0%, var(--paper) 100%);
  overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;}
.hero h1{font-size:clamp(2.4rem,4.4vw,3.7rem);margin:18px 0 22px;}
.hero h1 em{font-style:normal;color:var(--maroon-600);}
.hero-actions{display:flex;gap:16px;margin-top:32px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:28px;margin-top:46px;flex-wrap:wrap;}
.hero-stat b{font-family:'Fraunces',serif;font-size:1.7rem;color:var(--blue-900);display:block;}
.hero-stat span{font-size:.82rem;color:var(--ink-soft);}
.hero-art{position:relative;}
.hero-card{
  background:var(--paper-raised);border-radius:var(--radius-l);
  box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line);
}
.hero-card img{height:380px;object-fit:cover;width:100%;}
.float-chip{
  position:absolute;background:#fff;border-radius:14px;padding:14px 16px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:10px;
  font-size:.82rem;font-weight:700;border:1px solid var(--line);
}
.float-chip .swatch{width:10px;height:32px;border-radius:4px;}
.chip-1{top:-26px;left:-26px;}
.chip-2{bottom:-22px;right:-18px;}

/* ---------- Section scaffolding ---------- */
.section{padding:96px 0;}
.section-head{max-width:680px;margin-bottom:56px;}
.section-head h2{font-size:clamp(1.9rem,3vw,2.6rem);margin-top:14px;}
.section.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section.dark{
  background:linear-gradient(160deg,var(--blue-900),var(--blue-700) 55%, var(--maroon-700));
  color:#EAF7EF;
}
.section.dark h2,.section.dark h3,.section.dark h4{color:#fff;}
.section.dark .eyebrow{color:var(--amber-500);}
.section.dark .eyebrow::before{background:#fff;}

/* ---------- Cards: services grid ---------- */
.grid{display:grid;gap:26px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}

.svc-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  padding:30px 26px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
  position:relative;overflow:hidden;
}
.svc-card::before{
  content:"";position:absolute;top:0;left:0;width:5px;height:0;background:var(--amber-500);
  transition:height .35s ease;
}
.svc-card:hover::before{height:100%;}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent;}
.svc-num{font-family:'IBM Plex Mono',monospace;color:var(--maroon-600);font-size:.78rem;font-weight:600;}
.svc-card h3{font-size:1.18rem;margin:14px 0 10px;}
.svc-card p{color:var(--ink-soft);font-size:.95rem;}
.svc-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:700;color:var(--blue-700);font-size:.88rem;}

/* ---------- Process / milestones ---------- */
.process-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;}
.process-row::before{
  content:"";position:absolute;top:34px;left:6%;right:6%;height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 10px, transparent 10px 18px);
}
.process-step{position:relative;text-align:left;padding-right:18px;}
.process-num{
  width:66px;height:66px;border-radius:50%;
  background:var(--blue-900);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:1.3rem;
  position:relative;z-index:2;margin-bottom:20px;
  box-shadow:0 8px 22px -8px rgba(11,46,102,.5);
}
.process-step:nth-child(2) .process-num{background:var(--maroon-600);}
.process-step:nth-child(3) .process-num{background:var(--amber-500);color:var(--blue-900);}
.process-step:nth-child(4) .process-num{background:var(--green-600);}
.process-step h3{font-size:1.15rem;margin-bottom:8px;}
.process-step p{color:var(--ink-soft);font-size:.92rem;}

/* ---------- Stats strip ---------- */
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);border-radius:var(--radius-m);
  overflow:hidden;background:#fff;
}
.stat-cell{padding:30px 22px;text-align:center;border-right:1px solid var(--line);}
.stat-cell:last-child{border-right:none;}
.stat-cell b{font-family:'Fraunces',serif;font-size:2.1rem;color:var(--blue-700);display:block;}
.stat-cell span{font-size:.82rem;color:var(--ink-soft);}

/* ---------- Case studies ---------- */
.case-card{border-radius:var(--radius-m);overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);}
.case-img{height:200px;overflow:hidden;}
.case-img img{height:100%;width:100%;object-fit:cover;transition:transform .5s ease;}
.case-card:hover .case-img img{transform:scale(1.06);}
.case-body{padding:24px;}
.case-tag{font-size:.74rem;font-weight:700;color:var(--maroon-600);text-transform:uppercase;letter-spacing:.08em;}
.case-body h3{font-size:1.15rem;margin:10px 0;}
.case-body p{font-size:.92rem;color:var(--ink-soft);}

/* ---------- Testimonials ---------- */
.test-card{
  background:#fff;border-radius:var(--radius-m);padding:30px;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.test-quote{font-size:.98rem;color:var(--ink-soft);font-style:italic;margin-bottom:22px;}
.test-person{display:flex;align-items:center;gap:14px;}
.test-person img{width:50px;height:50px;border-radius:50%;object-fit:cover;}
.test-person b{display:block;font-size:.95rem;color:var(--blue-900);}
.test-person span{font-size:.8rem;color:var(--ink-soft);}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--line);padding:22px 0;}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:700;color:var(--blue-900);gap:20px;}
.faq-q .plus{
  width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .3s ease, background .3s ease;font-size:1.1rem;color:var(--maroon-600);
}
.faq-item.open .faq-q .plus{transform:rotate(45deg);background:var(--amber-100);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a p{padding-top:14px;color:var(--ink-soft);font-size:.95rem;max-width:680px;}
.faq-item.open .faq-a{max-height:240px;}

/* ---------- Newsletter / CTA banner ---------- */
.cta-banner{
  border-radius:var(--radius-l);
  background:linear-gradient(135deg,var(--blue-900),var(--maroon-700));
  color:#fff;padding:60px;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-banner::after{
  content:"";position:absolute;right:-60px;top:-60px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.14),transparent 70%);
}
.cta-banner h2{color:#fff;font-size:1.9rem;}
.cta-banner p{color:#D9E2F7;margin-top:10px;}
.cta-form{display:flex;gap:10px;}
.cta-form input{flex:1;padding:14px 18px;border-radius:999px;border:none;font-size:.92rem;}

/* ---------- Color code / values (About page signature) ---------- */
.value-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.value-card{
  background:#fff;border-radius:var(--radius-m);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease;
}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.value-swatch{height:96px;position:relative;}
.value-num{
  position:absolute;top:12px;left:14px;font-family:'IBM Plex Mono',monospace;
  font-size:.74rem;color:#fff;font-weight:700;opacity:.85;
}
.value-body{padding:18px 20px 22px;}
.value-body h4{font-size:1.02rem;margin-bottom:6px;}
.value-body p{font-size:.85rem;color:var(--ink-soft);}

/* ---------- About specific ---------- */
.about-gallery{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;}
.about-gallery .tall{grid-row:span 2;border-radius:var(--radius-m);overflow:hidden;box-shadow:var(--shadow-md);}
.about-gallery img{width:100%;height:100%;object-fit:cover;}
.about-gallery .pair{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.about-gallery .pair > div{border-radius:var(--radius-m);overflow:hidden;box-shadow:var(--shadow-sm);height:170px;}
.mission-block{display:grid;grid-template-columns:.95fr 1.05fr;gap:60px;align-items:center;}

/* ---------- Services page detail blocks ---------- */
.service-detail{
  border-bottom:1px solid var(--line);
  padding:64px 0;
  display:grid;grid-template-columns:.6fr 1.4fr;gap:50px;
}
.service-detail:first-of-type{padding-top:0;}
.service-detail-sticky{position:sticky;top:120px;align-self:start;}
.service-detail-sticky .svc-num{font-size:.85rem;}
.service-detail-sticky h3{font-size:1.5rem;margin:10px 0 14px;}
.service-detail-sticky p{color:var(--ink-soft);font-size:.96rem;}
.service-tag{
  display:inline-block;margin-top:16px;padding:6px 14px;border-radius:999px;
  background:var(--blue-100);color:var(--blue-700);font-size:.78rem;font-weight:700;
}
.service-points{display:grid;gap:16px;}
.point{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);
  padding:18px 20px;display:grid;grid-template-columns:auto 1fr;gap:14px;
}
.point .bullet{width:8px;height:8px;border-radius:50%;background:var(--amber-500);margin-top:7px;}
.point b{display:block;color:var(--blue-900);margin-bottom:4px;font-size:.96rem;}
.point span{color:var(--ink-soft);font-size:.9rem;}
.service-summary{
  margin-top:24px;padding:20px 22px;border-left:3px solid var(--maroon-600);
  background:var(--maroon-100);border-radius:0 var(--radius-s) var(--radius-s) 0;
  color:var(--maroon-700);font-size:.93rem;
}

/* ---------- Service nav pills (services page top) ---------- */
.service-pills{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px;}
.pill{
  padding:9px 16px;border-radius:999px;border:1px solid var(--line);font-size:.82rem;
  font-weight:600;color:var(--ink-soft);background:#fff;transition:all .25s ease;
}
.pill:hover, .pill.active{background:var(--blue-600);color:#fff;border-color:var(--blue-600);}

/* ---------- Contact page ---------- */
.contact-wrap{display:grid;grid-template-columns:1fr .85fr;gap:50px;}
.contact-form-card{
  background:#fff;border-radius:var(--radius-l);border:1px solid var(--line);
  padding:44px;box-shadow:var(--shadow-md);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field label{font-size:.82rem;font-weight:700;color:var(--blue-900);}
.field input,.field select,.field textarea{
  padding:13px 16px;border:1.5px solid var(--line);border-radius:var(--radius-s);
  background:var(--paper);transition:border-color .2s ease, background .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--blue-600);background:#fff;
}
.field.full{grid-column:1/-1;}
.contact-side .info-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  padding:26px;margin-bottom:18px;display:flex;gap:16px;align-items:flex-start;
}
.info-icon{
  width:44px;height:44px;border-radius:12px;background:var(--blue-100);
  display:flex;align-items:center;justify-content:center;color:var(--blue-700);font-size:1.2rem;flex-shrink:0;
}
.info-card h4{font-size:1rem;margin-bottom:6px;}
.info-card p,.info-card a{font-size:.9rem;color:var(--ink-soft);line-height:1.55;}
.map-embed{border-radius:var(--radius-m);overflow:hidden;border:1px solid var(--line);height:220px;}
.map-embed iframe{width:100%;height:100%;border:0;}
.social-row{display:flex;gap:12px;margin-top:6px;}
.social-row a{
  width:38px;height:38px;border-radius:50%;background:var(--blue-100);color:var(--blue-700);
  display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:.25s;
}
.social-row a:hover{background:var(--blue-600);color:#fff;}

/* ---------- Team page ---------- */
.team-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;
}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.team-photo{height:260px;overflow:hidden;position:relative;}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.team-card:hover .team-photo img{transform:scale(1.06);}
.team-tag{
  position:absolute;top:14px;left:14px;padding:5px 12px;border-radius:999px;
  background:rgba(255,255,255,.92);color:var(--maroon-600);font-size:.72rem;font-weight:700;
}
.team-body{padding:22px 22px 24px;}
.team-body h3{font-size:1.08rem;margin-bottom:2px;}
.team-role{font-size:.82rem;color:var(--blue-700);font-weight:700;margin-bottom:10px;display:block;}
.team-body p{font-size:.88rem;color:var(--ink-soft);}
.team-social{display:flex;gap:10px;margin-top:14px;}
.team-social a{
  width:32px;height:32px;border-radius:50%;background:var(--blue-100);color:var(--blue-700);
  display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;transition:.25s;
}
.team-social a:hover{background:var(--blue-600);color:#fff;}
.dept-strip{display:flex;gap:12px;flex-wrap:wrap;}
.dept-chip{
  padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;
  font-size:.82rem;font-weight:600;color:var(--ink-soft);
}

/* ---------- Blog page ---------- */
.blog-feature{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;border-radius:var(--radius-l);
  overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-md);
}
.blog-feature .img{height:100%;min-height:320px;overflow:hidden;}
.blog-feature .img img{width:100%;height:100%;object-fit:cover;}
.blog-feature .body{padding:44px;display:flex;flex-direction:column;justify-content:center;}
.blog-cat{
  display:inline-block;padding:5px 14px;border-radius:999px;background:var(--amber-100);
  color:var(--amber-600);font-size:.74rem;font-weight:700;width:fit-content;margin-bottom:14px;
}
.blog-feature h2{font-size:1.6rem;}
.blog-meta{display:flex;gap:16px;align-items:center;margin-top:18px;font-size:.82rem;color:var(--ink-soft);}
.blog-meta img{width:30px;height:30px;border-radius:50%;object-fit:cover;}

.blog-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.blog-img{height:190px;overflow:hidden;}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.blog-card:hover .blog-img img{transform:scale(1.06);}
.blog-body{padding:22px;flex:1;display:flex;flex-direction:column;}
.blog-body h3{font-size:1.08rem;margin:6px 0 10px;}
.blog-body p{font-size:.9rem;color:var(--ink-soft);flex:1;}
.blog-read{margin-top:16px;font-weight:700;font-size:.86rem;color:var(--blue-700);}
.blog-filter{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--blue-900);color:#C9D6F1;padding:70px 0 26px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.3fr;gap:50px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12);}
.footer-brand .brand{color:#fff;}
.footer-brand p{margin-top:16px;color:#A9BBE3;font-size:.92rem;max-width:320px;}
.footer-col h5{color:#fff;font-family:'Fraunces',serif;font-size:1rem;margin-bottom:18px;}
.footer-col a{display:block;margin-bottom:12px;color:#A9BBE3;font-size:.92rem;}
.footer-col a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;font-size:.82rem;color:#7E90BE;flex-wrap:wrap;gap:10px;}
.wa-float{
  position:fixed;bottom:26px;right:26px;z-index:90;
  width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;
  box-shadow:0 10px 24px -6px rgba(0,0,0,.35);transition:transform .25s ease;
}
.wa-float:hover{transform:scale(1.08);}

/* ---------- Breadcrumb / page hero (inner pages) ---------- */
.page-hero{
  padding:160px 0 80px;
  background:
    radial-gradient(800px 420px at 90% -10%, var(--blue-100), transparent 60%),
    linear-gradient(180deg,#FAFBFE,var(--paper));
  position:relative;
}
.crumb{
  font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--ink-soft);
  display:flex;gap:8px;align-items:center;margin-bottom:16px;
}
.crumb b{color:var(--maroon-600);}
.page-hero h1{font-size:clamp(2.1rem,4vw,3.1rem);max-width:760px;}
.page-hero .lede{margin-top:16px;}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px) scale(.985);transition:opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);}
.reveal.in{opacity:1;transform:translateY(0) scale(1);}

/* =========================================================
   WOW ANIMATIONS — site-wide motion layer
   ========================================================= */

/* Animated gradient text for hero headline emphasis */
.text-shimmer{
  background:linear-gradient(90deg,var(--blue-900) 0%, var(--blue-600) 25%, var(--amber-500) 50%, var(--blue-600) 75%, var(--blue-900) 100%);
  background-size:300% auto;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  animation:shimmerMove 7s linear infinite;
}
.hero h1 em.text-shimmer{color:transparent;-webkit-text-fill-color:transparent;}
@keyframes shimmerMove{0%{background-position:0% 50%;}100%{background-position:300% 50%;}}

/* Floating ambient orbs behind hero */
.ambient-orb{
  position:absolute;border-radius:50%;filter:blur(40px);opacity:.55;z-index:0;pointer-events:none;
  animation:orbFloat 9s ease-in-out infinite;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1);}
  50%{transform:translate(18px,-22px) scale(1.08);}
}

/* Count-up number animation trigger class (JS adds .counted) */
.count-up{display:inline-block;}

/* Magnetic / shine buttons */
.btn{position:relative;overflow:hidden;}
.btn::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent, rgba(255,255,255,.55), transparent);
  transform:skewX(-20deg);transition:left .6s ease;
}
.btn:hover::after{left:130%;}
.btn-primary, .btn-amber{
  transition:transform .35s cubic-bezier(.34,1.56,.64,1), box-shadow .35s ease, background .3s ease;
}
.btn-primary:hover, .btn-amber:hover{transform:translateY(-3px) scale(1.035);}

/* Card lift + glow on hover, applied broadly */
.svc-card, .case-card, .test-card, .point, .blog-card, .info-card, .side-card{
  transition:transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s ease, border-color .4s ease;
}
.svc-card:hover, .blog-card:hover{box-shadow:0 24px 50px -16px rgba(11,46,102,.22);}

/* Eyebrow underline draw-in */
.eyebrow::before{
  width:0;animation:drawLine .6s ease forwards;animation-delay:.15s;
}
@keyframes drawLine{to{width:18px;}}

/* Process number pop + connecting line draw */
.process-num{animation:numPop .6s cubic-bezier(.34,1.56,.64,1) both;}
@keyframes numPop{from{transform:scale(.4);opacity:0;}to{transform:scale(1);opacity:1;}}
.process-row::before{
  background-size:0% 100%;
  animation:none;
}
.process-row.in::before{
  animation:lineDraw 1.4s ease forwards;
}
@keyframes lineDraw{from{clip-path:inset(0 100% 0 0);}to{clip-path:inset(0 0 0 0);}}

/* Stat cells count-in pulse */
.stat-cell{position:relative;overflow:hidden;}
.stat-cell::before{
  content:"";position:absolute;inset:0;background:var(--blue-100);
  transform:scaleY(0);transform-origin:bottom;z-index:0;opacity:.5;
  transition:transform .5s cubic-bezier(.22,1,.36,1);
}
.stat-cell:hover::before{transform:scaleY(1);}
.stat-cell b, .stat-cell span{position:relative;z-index:1;}

/* FAQ icon micro animation already via .open rotate — add bounce */
.faq-q{transition:color .25s ease;}
.faq-item .plus{transition:transform .35s cubic-bezier(.34,1.56,.64,1), background .3s ease;}

/* Hero float-chip entrance bounce */
.float-chip{animation:chipDrop .7s cubic-bezier(.34,1.56,.64,1) both;}
.chip-1{animation-delay:.5s;}
.chip-2{animation-delay:.7s;}
@keyframes chipDrop{from{opacity:0;transform:translateY(-14px) scale(.85);}to{opacity:1;transform:translateY(0) scale(1);}}

/* Visual panel breathing glow */
.visual-panel{position:relative;}
.visual-panel .vp-icon{
  display:inline-block;animation:vpFloat 3.4s ease-in-out infinite;
}
@keyframes vpFloat{0%,100%{transform:translateY(0) rotate(0deg);}50%{transform:translateY(-7px) rotate(-3deg);}}

/* Nav link underline grow from center */
.nav-links a{position:relative;}
.nav-links a::before{
  content:"";position:absolute;left:50%;bottom:-4px;width:0;height:2px;
  background:var(--amber-500);transition:width .3s ease, left .3s ease;
}
.nav-links a:hover::before{width:100%;left:0;}
.nav-links a.active::after{display:none;}
.nav-links a.active::before{width:100%;left:0;background:var(--amber-500);}

/* Brand dot pulse */
.brand .dot{animation:dotPulse 2.4s ease-in-out infinite;}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 4px var(--amber-100);}50%{box-shadow:0 0 0 8px rgba(240,165,33,.12);}}

/* CTA banner ambient glow drift */
.cta-banner::after{animation:glowDrift 6s ease-in-out infinite;}
@keyframes glowDrift{0%,100%{transform:translate(0,0);}50%{transform:translate(-20px,20px);}}
.section.dark{position:relative;overflow:hidden;}
.section.dark::before{
  content:"";position:absolute;top:-30%;right:-10%;width:50%;height:160%;
  background:radial-gradient(circle, rgba(255,255,255,.06), transparent 65%);
  animation:glowDrift 8s ease-in-out infinite;pointer-events:none;
}

/* WhatsApp float attention pulse */
.wa-float{animation:waPulse 2.6s ease-in-out infinite;}
@keyframes waPulse{
  0%,100%{box-shadow:0 10px 24px -6px rgba(0,0,0,.35), 0 0 0 0 rgba(37,211,102,.5);}
  50%{box-shadow:0 10px 24px -6px rgba(0,0,0,.35), 0 0 0 10px rgba(37,211,102,0);}
}

/* Pill hover sweep */
.pill{position:relative;overflow:hidden;}

/* Service detail point slide-in stagger handled via JS adding .in with index delay */
.point.reveal{opacity:0;transform:translateY(28px) scale(.985) translateX(-14px);}
.point.reveal.in{opacity:1;transform:translateY(0) scale(1) translateX(0);}

/* Hero art subtle parallax float */
.hero-art{animation:heroFloat 6s ease-in-out infinite;}
@keyframes heroFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* Value/team-row cards already animate via .in — add slight rotate-in */
.svc-card.reveal.in{animation:cardSettle .8s cubic-bezier(.22,1,.36,1);}
@keyframes cardSettle{0%{}100%{}}

/* Cascading stagger for grid cards (Home/About/Services/Blog/Contact only) */
.grid > .reveal:nth-child(1),.value-grid > .reveal:nth-child(1){transition-delay:.02s;}
.grid > .reveal:nth-child(2),.value-grid > .reveal:nth-child(2){transition-delay:.08s;}
.grid > .reveal:nth-child(3),.value-grid > .reveal:nth-child(3){transition-delay:.14s;}
.grid > .reveal:nth-child(4),.value-grid > .reveal:nth-child(4){transition-delay:.20s;}
.grid > .reveal:nth-child(5),.value-grid > .reveal:nth-child(5){transition-delay:.26s;}
.grid > .reveal:nth-child(6),.value-grid > .reveal:nth-child(6){transition-delay:.32s;}
.grid > .reveal:nth-child(7),.value-grid > .reveal:nth-child(7){transition-delay:.38s;}
.grid > .reveal:nth-child(8),.value-grid > .reveal:nth-child(8){transition-delay:.44s;}
.grid > .reveal:nth-child(9),.value-grid > .reveal:nth-child(9){transition-delay:.50s;}
.grid > .reveal:nth-child(10),.value-grid > .reveal:nth-child(10){transition-delay:.56s;}

.service-points > .point.reveal:nth-child(1){transition-delay:.02s;}
.service-points > .point.reveal:nth-child(2){transition-delay:.07s;}
.service-points > .point.reveal:nth-child(3){transition-delay:.12s;}
.service-points > .point.reveal:nth-child(4){transition-delay:.17s;}
.service-points > .point.reveal:nth-child(5){transition-delay:.22s;}
.service-points > .point.reveal:nth-child(6){transition-delay:.27s;}

/* =========================================================
   GROWTH ORB — circular animated hero centerpiece
   ========================================================= */
.growth-orb{
  position:relative;width:100%;max-width:380px;aspect-ratio:1;margin:0 auto;
}
.orb-ring-svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);}
.orb-ring-bg{fill:none;stroke:var(--blue-100);stroke-width:9;}
.orb-ring-fg{
  fill:none;stroke:url(#orbGradient);stroke-width:9;stroke-linecap:round;
  stroke-dasharray:597;stroke-dashoffset:597;
  transition:stroke-dashoffset 1.8s cubic-bezier(.22,1,.36,1);
  filter:drop-shadow(0 0 6px rgba(30,142,85,.45));
}
.growth-orb.in .orb-ring-fg{stroke-dashoffset:var(--orb-offset, 140);}

.orb-tick{
  position:absolute;inset:0;border-radius:50%;
  background:
    repeating-conic-gradient(from 0deg, var(--line) 0deg 1.2deg, transparent 1.2deg 9deg);
  -webkit-mask:radial-gradient(circle, transparent 64%, #000 65%, #000 70%, transparent 71%);
  mask:radial-gradient(circle, transparent 64%, #000 65%, #000 70%, transparent 71%);
  animation:orbitSpin 60s linear infinite;
  opacity:.5;
}

.orb-core{
  position:absolute;inset:17%;border-radius:50%;
  background:linear-gradient(150deg,var(--blue-900),var(--blue-600) 65%, var(--maroon-700));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:#fff;box-shadow:var(--shadow-lg);text-align:center;padding:6%;
  animation:floaty 5s ease-in-out infinite;
}
.orb-core::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 32% 26%, rgba(255,255,255,.22), transparent 55%);
}
.orb-percent{
  font-family:'Fraunces',serif;font-weight:700;font-size:clamp(1.6rem,6vw,2.3rem);
  position:relative;z-index:1;line-height:1;
}
.orb-tagline{font-size:clamp(.62rem,1.6vw,.74rem);color:var(--amber-500);font-weight:700;letter-spacing:.04em;text-transform:uppercase;position:relative;z-index:1;margin-bottom:4px;}
.orb-sub{font-size:clamp(.66rem,1.7vw,.76rem);color:#D9E2F7;margin-top:6px;max-width:88%;position:relative;z-index:1;}

.orb-orbit{position:absolute;inset:0;animation:orbitSpin 26s linear infinite;}
.orb-sat{
  position:absolute;width:clamp(52px,17vw,76px);height:clamp(52px,17vw,76px);
}
.orb-sat.sat-1{top:0;left:50%;transform:translate(-50%,-50%);}
.orb-sat.sat-2{top:50%;right:0;transform:translate(50%,-50%);}
.orb-sat.sat-3{bottom:0;left:50%;transform:translate(-50%,50%);}
.orb-sat.sat-4{top:50%;left:0;transform:translate(-50%,-50%);}
.sat-inner{
  width:100%;height:100%;border-radius:50%;background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  box-shadow:var(--shadow-md);animation:counterSpin 26s linear infinite;
  transition:transform .3s ease, box-shadow .3s ease;
}
.orb-sat:hover .sat-inner{transform:scale(1.12);box-shadow:var(--shadow-lg);z-index:5;}
.sat-inner .sat-icon{font-size:clamp(1rem,3.6vw,1.3rem);}
.sat-inner small{font-size:clamp(.5rem,1.6vw,.62rem);font-weight:800;color:var(--blue-900);line-height:1.1;text-align:center;}

@keyframes orbitSpin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
@keyframes counterSpin{from{transform:rotate(0deg);}to{transform:rotate(-360deg);}}

@media (max-width:520px){
  .growth-orb{max-width:280px;}
}


/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .value-grid{grid-template-columns:repeat(3,1fr);}
  .process-row{grid-template-columns:repeat(2,1fr);row-gap:40px;}
  .process-row::before{display:none;}
  .service-detail{grid-template-columns:1fr;}
  .service-detail-sticky{position:relative;top:0;}
  .stats-strip{grid-template-columns:repeat(2,1fr);}
  .stat-cell:nth-child(2){border-right:none;}
  .contact-wrap{grid-template-columns:1fr;}
}
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-art{order:-1;}
  .mission-block{grid-template-columns:1fr;}
  .about-gallery{grid-template-columns:1fr 1fr;}
  .cta-banner{grid-template-columns:1fr;padding:40px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:760px){
  .nav-links{
    position:fixed;top:64px;left:0;right:0;bottom:0;
    background:#fff;flex-direction:column;align-items:flex-start;
    padding:30px 28px;gap:22px;
    transform:translateX(100%);transition:transform .35s ease;
    overflow-y:auto;
  }
  .nav-links.open{transform:translateX(0);}
  .menu-toggle{display:flex;}
  .nav-call{display:none;}
  .grid-3, .grid-2, .grid-4{grid-template-columns:1fr;}
  .value-grid{grid-template-columns:repeat(2,1fr);}
  .hero{padding-top:140px;}
  .process-row{grid-template-columns:1fr;}
  .stats-strip{grid-template-columns:repeat(2,1fr);}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:34px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .section{padding:64px 0;}
  .hero-stats{gap:20px;}
  .about-gallery{grid-template-columns:1fr;}
  .about-gallery .tall{grid-row:auto;height:240px;}
.about-gallery .pair > div{height:140px;}
}

/* =========================================================
   TEAM PAGE
   ========================================================= */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;}
.team-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;
}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.team-photo{height:240px;position:relative;overflow:hidden;}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.team-card:hover .team-photo img{transform:scale(1.06);}
.team-tag{
  position:absolute;bottom:12px;left:12px;background:rgba(255,255,255,.92);
  color:var(--maroon-600);font-size:.7rem;font-weight:700;letter-spacing:.04em;
  padding:5px 10px;border-radius:999px;text-transform:uppercase;
}
.team-body{padding:20px 22px;}
.team-body h3{font-size:1.08rem;margin-bottom:3px;}
.team-role{font-size:.82rem;color:var(--maroon-600);font-weight:700;margin-bottom:10px;display:block;}
.team-body p{font-size:.88rem;color:var(--ink-soft);}
.team-socials{display:flex;gap:8px;margin-top:14px;}
.team-socials a{
  width:30px;height:30px;border-radius:50%;background:var(--blue-100);color:var(--blue-700);
  display:flex;align-items:center;justify-content:center;font-size:.78rem;transition:.25s;
}
.team-socials a:hover{background:var(--blue-600);color:#fff;}

.dept-strip{display:flex;gap:14px;flex-wrap:wrap;}
.dept-chip{
  display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:var(--radius-s);
  background:#fff;border:1px solid var(--line);font-weight:700;font-size:.9rem;color:var(--blue-900);
}
.dept-chip .swatch-dot{width:10px;height:10px;border-radius:50%;}

.join-banner{
  border-radius:var(--radius-l);background:var(--blue-100);padding:54px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center;
}
.join-banner h2{font-size:1.7rem;}

/* =========================================================
   BLOG PAGES
   ========================================================= */
.blog-filter{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px;}

.blog-feature{
  display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-radius:var(--radius-l);
  overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-md);
}
.blog-feature .img-wrap{height:100%;min-height:340px;overflow:hidden;}
.blog-feature .img-wrap img{width:100%;height:100%;object-fit:cover;}
.blog-feature-body{padding:46px;display:flex;flex-direction:column;justify-content:center;}
.blog-cat{
  display:inline-block;background:var(--amber-100);color:var(--amber-600);
  font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;width:fit-content;margin-bottom:16px;
}
.blog-feature-body h2{font-size:1.7rem;margin-bottom:14px;}
.blog-meta{display:flex;gap:16px;align-items:center;margin-top:20px;font-size:.82rem;color:var(--ink-soft);}
.blog-meta .author{display:flex;align-items:center;gap:8px;}
.blog-meta img{width:30px;height:30px;border-radius:50%;object-fit:cover;}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.blog-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.blog-card .img-wrap{height:190px;overflow:hidden;}
.blog-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.blog-card:hover .img-wrap img{transform:scale(1.07);}
.blog-card-body{padding:22px;flex:1;display:flex;flex-direction:column;}
.blog-card-body h3{font-size:1.05rem;margin:6px 0 10px;}
.blog-card-body p{font-size:.88rem;color:var(--ink-soft);flex:1;}
.blog-read{margin-top:16px;font-weight:700;font-size:.85rem;color:var(--blue-700);display:inline-flex;align-items:center;gap:6px;}

.blog-sidebar{display:flex;flex-direction:column;gap:22px;}
.side-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);padding:24px;}
.side-card h4{font-size:1rem;margin-bottom:16px;}
.side-tags{display:flex;gap:8px;flex-wrap:wrap;}
.side-tags a{
  font-size:.78rem;padding:7px 13px;border-radius:999px;background:var(--paper);
  border:1px solid var(--line);color:var(--ink-soft);font-weight:600;
}
.side-tags a:hover{background:var(--blue-100);color:var(--blue-700);}
.side-post{display:flex;gap:12px;margin-bottom:16px;}
.side-post img{width:60px;height:60px;border-radius:10px;object-fit:cover;flex-shrink:0;}
.side-post .t{font-size:.86rem;font-weight:700;color:var(--blue-900);line-height:1.35;}
.side-post .d{font-size:.76rem;color:var(--ink-soft);margin-top:4px;}

@media (max-width:1080px){
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .blog-grid{grid-template-columns:repeat(2,1fr);}
  .blog-feature{grid-template-columns:1fr;}
  .blog-feature .img-wrap{min-height:240px;}
  .join-banner{grid-template-columns:1fr;text-align:left;}
}
@media (max-width:760px){
  .team-grid{grid-template-columns:1fr 1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .blog-feature-body{padding:30px;}
  .dept-strip{gap:10px;}
}
@media (max-width:520px){
  .team-grid{grid-template-columns:1fr;}
}

/* =========================================================
   VISUAL PANELS — graphic cards replacing stock photography
   ========================================================= */
.visual-panel{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;color:#fff;text-align:center;width:100%;height:100%;
  position:relative;overflow:hidden;
}
.visual-panel::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.16), transparent 55%);
}
.visual-panel .vp-icon{font-size:3rem;position:relative;z-index:1;}
.visual-panel .vp-label{font-weight:700;font-size:1rem;letter-spacing:.01em;position:relative;z-index:1;max-width:240px;}
.visual-panel .vp-sub{font-size:.78rem;color:rgba(255,255,255,.8);position:relative;z-index:1;}
.visual-panel.sm .vp-icon{font-size:2.1rem;}
.visual-panel.sm .vp-label{font-size:.9rem;}

.vp-green{background:linear-gradient(135deg,var(--blue-900),var(--blue-600));}
.vp-deep{background:linear-gradient(135deg,var(--blue-900),var(--maroon-700));}
.vp-amber{background:linear-gradient(135deg,var(--amber-600),var(--amber-500));color:var(--blue-900);}
.vp-amber .vp-sub{color:rgba(15,27,51,.65);}
.vp-mint{background:linear-gradient(135deg,var(--maroon-600),var(--blue-600));}

/* =========================================================
   TEAM PAGE v2 — founder spotlight + member rows
   ========================================================= */
.avatar{
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-weight:700;color:#fff;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-900));
}
.avatar.alt{background:linear-gradient(135deg,var(--amber-500),var(--amber-600));color:var(--blue-900);}
.avatar.alt2{background:linear-gradient(135deg,var(--maroon-600),var(--blue-700));}

.team-intro-banner{
  border-radius:var(--radius-l);
  background:linear-gradient(120deg,var(--blue-100),#fff 55%, var(--amber-100));
  padding:64px 50px;text-align:center;position:relative;overflow:hidden;
}
.team-intro-banner .dot-mark{
  width:14px;height:14px;border-radius:50%;background:var(--line);margin:0 auto 22px;
}
.team-intro-banner h2{font-size:clamp(1.9rem,3.2vw,2.6rem);}
.team-intro-banner p{color:var(--ink-soft);max-width:620px;margin:16px auto 0;}

.founder-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);
  box-shadow:var(--shadow-md);padding:54px;text-align:center;
}
.founder-card .avatar{width:130px;height:130px;font-size:1.7rem;margin:0 auto 22px;}
.founder-role{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--maroon-600);font-weight:700;}
.founder-card h2{font-size:1.6rem;margin:8px 0 22px;}
.founder-card p{color:var(--ink-soft);max-width:760px;margin:0 auto;font-size:.96rem;}
.founder-card .team-socials{justify-content:center;margin-top:26px;}

.team-row-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.team-row{
  display:grid;grid-template-columns:auto 1fr;gap:20px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  padding:26px;transition:transform .3s ease, box-shadow .3s ease;
}
.team-row:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.team-row .avatar{width:62px;height:62px;font-size:1.05rem;}
.team-row h3{font-size:1.08rem;margin-bottom:3px;}
.team-row .row-role{font-size:.82rem;color:var(--maroon-600);font-weight:700;display:block;margin-bottom:10px;}
.team-row p{font-size:.88rem;color:var(--ink-soft);}

@media (max-width:760px){
  .team-row-grid{grid-template-columns:1fr;}
  .founder-card{padding:34px 24px;}
  .team-intro-banner{padding:44px 26px;}
}

/* =========================================================
   TEAM PAGE v3 — animated flip cards
   ========================================================= */
@keyframes floaty{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}
@keyframes ringPulse{
  0%{box-shadow:0 0 0 0 rgba(30,142,85,.35);}
  70%{box-shadow:0 0 0 14px rgba(30,142,85,0);}
  100%{box-shadow:0 0 0 0 rgba(30,142,85,0);}
}
@keyframes popIn{
  from{opacity:0;transform:translateY(28px) scale(.96);}
  to{opacity:1;transform:translateY(0) scale(1);}
}

.flip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
.flip-card{
  perspective:1400px;height:320px;
  opacity:0;
}
.flip-card.in{animation:popIn .6s cubic-bezier(.22,1,.36,1) forwards;}
.flip-inner{
  position:relative;width:100%;height:100%;
  transition:transform .7s cubic-bezier(.4,.2,.2,1);
  transform-style:preserve-3d;
}
.flip-card:hover .flip-inner, .flip-card.flipped .flip-inner{transform:rotateY(180deg);}

.flip-face{
  position:absolute;inset:0;backface-visibility:hidden;
  border-radius:var(--radius-m);overflow:hidden;
  border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:28px 22px;text-align:center;
}
.flip-front{
  background:#fff;
  box-shadow:var(--shadow-sm);
}
.flip-front .avatar{
  width:84px;height:84px;font-size:1.3rem;margin-bottom:16px;
  animation:floaty 4s ease-in-out infinite;
  border:3px solid #fff;outline:3px solid var(--blue-100);
}
.flip-card:hover .flip-front .avatar{animation-play-state:paused;}
.flip-front h3{font-size:1.05rem;margin-bottom:4px;}
.flip-front .row-role{font-size:.78rem;color:var(--maroon-600);font-weight:700;}
.flip-front .flip-hint{
  margin-top:18px;font-size:.7rem;color:var(--ink-soft);
  display:flex;align-items:center;gap:6px;opacity:.7;
}
.flip-front .flip-hint .spin{
  width:16px;height:16px;border-radius:50%;border:1.5px dashed var(--line);
  display:inline-block;animation:spin 6s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

.flip-back{
  background:linear-gradient(150deg,var(--blue-900),var(--blue-700) 70%, var(--maroon-700));
  color:#fff;transform:rotateY(180deg);
  justify-content:space-between;
}
.flip-back .row-role{font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--amber-500);font-weight:700;margin-bottom:10px;}
.flip-back h3{color:#fff;font-size:1rem;margin-bottom:6px;}
.flip-back p{font-size:.82rem;color:#D9E2F7;line-height:1.5;}
.flip-back .team-socials{margin-top:14px;justify-content:center;}
.flip-back .team-socials a{background:rgba(255,255,255,.14);color:#fff;}
.flip-back .team-socials a:hover{background:var(--amber-500);color:var(--blue-900);}

.flip-card:nth-child(1){animation-delay:.02s;}
.flip-card:nth-child(2){animation-delay:.08s;}
.flip-card:nth-child(3){animation-delay:.14s;}
.flip-card:nth-child(4){animation-delay:.20s;}
.flip-card:nth-child(5){animation-delay:.26s;}
.flip-card:nth-child(6){animation-delay:.32s;}
.flip-card:nth-child(7){animation-delay:.38s;}
.flip-card:nth-child(8){animation-delay:.44s;}

/* Founder card — animated ring + glow */
.founder-card{position:relative;}
.founder-card .avatar{
  position:relative;animation:floaty 5s ease-in-out infinite;
}
.founder-card .avatar::after{
  content:"";position:absolute;inset:-8px;border-radius:50%;
  border:2px solid var(--blue-100);animation:ringPulse 2.6s ease-out infinite;
}
.founder-card::before{
  content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;
  background:radial-gradient(circle,var(--blue-100),transparent 70%);border-radius:50%;z-index:0;
}

@media (max-width:1080px){
  .flip-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:520px){
  .flip-grid{grid-template-columns:1fr;}
  .flip-card{height:300px;}
}

/* =========================================================
   TEAM PAGE v4 — illustrated avatar cards (reference match)
   ========================================================= */
.avatar-badge{
  position:relative;border-radius:50%;flex-shrink:0;overflow:visible;
  display:flex;align-items:center;justify-content:center;
}
.avatar-badge svg{width:62%;height:62%;}
.avatar-badge .avatar-status{
  position:absolute;bottom:-2px;right:-2px;border-radius:50%;
  background:#22C55E;border:3px solid #fff;
}

.av-1{background:linear-gradient(135deg,#C9B8F2,#8FD3E8);}
.av-2{background:linear-gradient(135deg,#FBD786,#F58B6B);}
.av-3{background:linear-gradient(135deg,#9BE8D8,#7FB9F0);}
.av-4{background:linear-gradient(135deg,#F7C6D9,#F2A6B8);}
.av-5{background:linear-gradient(135deg,#BFE3C2,#F4E29A);}
.av-6{background:linear-gradient(135deg,#AFD8F8,#C8B6F0);}
.av-7{background:linear-gradient(135deg,#FAD0A0,#F0A6A6);}
.av-8{background:linear-gradient(135deg,#B7E4C7,#9AD0E6);}

.founder-card .avatar-badge{width:128px;height:128px;margin:0 auto 18px;}
.founder-card .avatar-badge .avatar-status{width:20px;height:20px;}
.team-row .avatar-badge{width:64px;height:64px;}
.team-row .avatar-badge .avatar-status{width:14px;height:14px;}

.team-row-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.team-row{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  padding:26px;transition:transform .3s ease, box-shadow .3s ease;
  opacity:0;transform:translateY(18px);
}
.team-row.in{opacity:1;transform:translateY(0);transition:opacity .55s ease, transform .55s ease;}
.team-row:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.team-row h3{font-size:1.06rem;margin-bottom:2px;}
.team-row .row-role{font-size:.82rem;color:var(--maroon-600);font-weight:700;display:block;margin-bottom:10px;}
.team-row p{font-size:.88rem;color:var(--ink-soft);}

.team-row:nth-child(1){transition-delay:.02s;}
.team-row:nth-child(2){transition-delay:.06s;}
.team-row:nth-child(3){transition-delay:.10s;}
.team-row:nth-child(4){transition-delay:.14s;}
.team-row:nth-child(5){transition-delay:.18s;}
.team-row:nth-child(6){transition-delay:.22s;}
.team-row:nth-child(7){transition-delay:.26s;}
.team-row:nth-child(8){transition-delay:.30s;}

@media (max-width:760px){
  .team-row-grid{grid-template-columns:1fr;}
}



.social-row a svg { width:15px; height:15px; display:block; }
