/* ==========================================================================
   D-NOME — Design System
   Brand: Navy #22457D / Teal #6FD7C9 / Ink #0B1B33
   ========================================================================== */

:root{
  /* Brand colors sampled from logo */
  --navy-900:#0B1B33;
  --navy-800:#102A4D;
  --navy-700:#16365F;
  --navy-600:#1C4274;
  --navy:#22457D;
  --navy-400:#345A99;
  --teal:#6FD7C9;
  --teal-300:#99E0DB;
  --teal-200:#C3EFE9;
  --teal-bright:#3FE6CB;
  --coral:#FF6B5A;
  --ink:#0B1320;
  --paper:#F6F9FC;
  --white:#FFFFFF;
  --gray-100:#EEF2F7;
  --gray-300:#C9D4E2;
  --gray-500:#7C8AA0;
  --gray-700:#4B5876;

  --font-display:'Space Grotesk', 'Segoe UI', sans-serif;
  --font-body:'Inter', 'Segoe UI', sans-serif;

  --container:1240px;
  --radius-sm:10px;
  --radius:18px;
  --radius-lg:28px;
  --shadow-sm:0 4px 16px rgba(11,27,51,0.08);
  --shadow-md:0 12px 40px rgba(11,27,51,0.14);
  --shadow-lg:0 24px 70px rgba(11,27,51,0.22);
  --ease:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4,h5{font-family:var(--font-display);margin:0 0 .5em;line-height:1.12;letter-spacing:-0.01em;color:var(--navy-900);}
p{margin:0 0 1em;color:var(--gray-700);line-height:1.7;}
button{font-family:inherit;}

.skip-link{
  position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:.6em 1em;z-index:999;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0;}

:focus-visible{outline:3px solid var(--teal-bright);outline-offset:2px;}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}
.section{padding:96px 0;position:relative;}
.section-tight{padding:56px 0;}
@media (max-width:768px){
  .section{padding:64px 0;}
}
.grid{display:grid;gap:28px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:980px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:640px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy);font-weight:600;margin-bottom:14px;
}
.eyebrow::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 0 4px rgba(63,230,203,.25);}
.eyebrow.on-dark{color:var(--teal-300);}

.section-head{max-width:720px;margin-bottom:48px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.lede{font-size:1.15rem;color:var(--gray-700);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 28px;border-radius:100px;font-weight:600;font-size:.95rem;
  border:1px solid transparent;cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s,border-color .3s;
  white-space:nowrap;
}
.btn-primary{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:var(--navy-600);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.btn-accent{background:var(--teal-bright);color:var(--navy-900);box-shadow:0 10px 30px rgba(63,230,203,.35);}
.btn-accent:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(63,230,203,.45);}
.btn-ghost{background:transparent;color:var(--navy-900);border-color:var(--gray-300);}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-3px);}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.3);}
.btn-ghost.on-dark:hover{border-color:var(--teal-bright);}
.btn-sm{padding:10px 20px;font-size:.85rem;}
.btn-block{width:100%;}
.btn svg{width:18px;height:18px;transition:transform .3s var(--ease);}
.btn:hover svg{transform:translateX(4px);}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:18px 0;transition:padding .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.site-header.scrolled{padding:10px 0;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);box-shadow:0 6px 24px rgba(11,27,51,.08);}
.site-header.menu-open{backdrop-filter:none;}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.brand img{height:34px;width:auto;display:block;}
.brand svg{height:34px;width:auto;}
.site-header:not(.scrolled) .brand img{filter:brightness(0) invert(1);}

.main-nav{display:flex;align-items:center;gap:6px;}
.main-nav>ul{display:flex;align-items:center;gap:2px;}
.main-nav a.nav-link{
  display:flex;align-items:center;gap:4px;padding:10px 16px;border-radius:100px;font-weight:600;font-size:.92rem;color:#fff;
  transition:background .25s,color .25s;white-space:nowrap;
}
.site-header.scrolled .main-nav a.nav-link{color:var(--navy-900);}
.site-header:not(.scrolled) .main-nav a.nav-link:hover{background:rgba(255,255,255,.12);color:var(--teal-300);}
.site-header.scrolled .main-nav a.nav-link:hover, .site-header.scrolled .main-nav li.has-dropdown:hover a.nav-link{background:var(--gray-100);color:var(--navy);}
.main-nav li{position:relative;}
.dropdown{
  position:absolute;top:calc(100% + 10px);left:0;min-width:280px;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;
}
li.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown a{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:12px;transition:background .2s;}
.dropdown a:hover{background:var(--gray-100);}
.dropdown a strong{font-size:.92rem;color:var(--navy-900);}
.dropdown a span{font-size:.78rem;color:var(--gray-500);}
.header-cta{display:flex;align-items:center;gap:10px;}
.site-header:not(.scrolled) .header-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.35);}
.site-header:not(.scrolled) .header-cta .btn-ghost:hover{border-color:var(--teal-bright);}
.site-header.scrolled .header-cta .btn-ghost{color:var(--navy-900);border-color:var(--gray-300);}
.nav-toggle{display:none;background:none;border:none;padding:12px;cursor:pointer;min-width:48px;min-height:48px;}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;margin:5px 0;transition:.3s;}
.site-header.scrolled .nav-toggle span{background:var(--navy-900);}

@media (max-width:980px){
  .main-nav{
    position:fixed;inset:0;top:0;background:var(--navy-900);flex-direction:column;justify-content:center;
    transform:translateX(100%);transition:transform .4s var(--ease);padding:40px 24px;z-index:400;
  }
  .main-nav.open{transform:translateX(0);}
  .main-nav>ul{flex-direction:column;width:100%;gap:6px;}
  .main-nav a.nav-link{color:#fff;width:100%;font-size:1.1rem;padding:14px 18px;}
  .main-nav a.nav-link:hover{background:rgba(255,255,255,.08);color:var(--teal-300);}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;background:rgba(255,255,255,.04);box-shadow:none;display:none;margin-top:4px;}
  li.has-dropdown.open .dropdown{display:block;}
  .dropdown a strong{color:#fff;}
  .header-cta .btn-ghost{display:none;}
  .header-cta .btn-sm{padding:13px 20px;min-height:48px;}
  .nav-toggle{display:block;z-index:600;}
  .nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.active span:nth-child(2){opacity:0;}
  .nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .nav-toggle.active span{background:var(--navy-900);}
  .site-header.menu-open .nav-toggle span{background:#fff;}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;background:radial-gradient(120% 120% at 15% 0%,var(--navy-700) 0%,var(--navy-900) 55%,var(--ink) 100%);
  color:#fff;padding:200px 0 130px;overflow:hidden;isolation:isolate;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;}}
.hero-content{max-width:720px;}
.hero h1{color:#fff;font-size:clamp(2.4rem,4.6vw,4rem);}
.hero .lede{color:rgba(255,255,255,.78);max-width:540px;}
.hero-stats{display:flex;gap:36px;margin-top:42px;flex-wrap:wrap;}
.hero-stat strong{display:block;font-family:var(--font-display);font-size:2rem;color:var(--teal-bright);}
.hero-stat > span{font-size:.82rem;color:rgba(255,255,255,.65);}
.hero-actions{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap;}
.hero-visual{position:relative;}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.65;}
.hero-orb{
  position:relative;z-index:1;border-radius:32px;background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);padding:30px;backdrop-filter:blur(8px);box-shadow:var(--shadow-lg);
}
.hero-orb img{border-radius:18px;}
.page-hero{
  background:radial-gradient(120% 140% at 10% 0%,var(--navy-700),var(--navy-900) 60%,var(--ink));
  color:#fff;padding:170px 0 90px;position:relative;overflow:hidden;
}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4vw,3.2rem);}
.page-hero .lede{color:rgba(255,255,255,.78);max-width:680px;}
.breadcrumbs{display:flex;gap:8px;align-items:center;font-size:.85rem;color:rgba(255,255,255,.55);margin-bottom:22px;flex-wrap:wrap;}
.breadcrumbs a{color:rgba(255,255,255,.75);}
.breadcrumbs a:hover{color:var(--teal-bright);}
.breadcrumbs.on-light{color:var(--gray-500);}
.breadcrumbs.on-light a{color:var(--navy);}

/* ---------- DNA decorative ---------- */
.dna-strand{position:absolute;pointer-events:none;opacity:.5;z-index:0;}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.35;z-index:0;}

/* ---------- Cards ---------- */
.card{
  background:#fff;border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm);
  border:1px solid var(--gray-100);transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.card .icon-tile{
  width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--navy-600));
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.card .icon-tile svg{width:26px;height:26px;color:#fff;}
.card h3{font-size:1.2rem;}
.card p{margin-bottom:0;}
.card.dark{background:var(--navy-900);border-color:var(--navy-700);}
.card.dark h3,.card.dark p{color:#fff;}
.card.dark p{color:rgba(255,255,255,.7);}
.card.dark picture{display:block;aspect-ratio:4/3;overflow:hidden;border-radius:14px;margin-bottom:20px;}
.card.dark picture img{width:100%;height:100%;object-fit:cover;border-radius:0;margin-bottom:0;}
.card-img{display:block;aspect-ratio:4/3;overflow:hidden;border-radius:14px;margin-bottom:20px;background:var(--gray-100);}
.card-img img{width:100%;height:100%;object-fit:cover;border-radius:0;margin-bottom:0;}

.card-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:600;color:var(--navy);font-size:.9rem;}
.card-link svg{width:16px;height:16px;transition:transform .3s var(--ease);}
.card-link:hover svg{transform:translateX(4px);}

.tag{
  display:inline-flex;align-items:center;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;background:var(--teal-200);color:var(--navy-700);
}
.tag.navy{background:var(--navy);color:#fff;}
.tag.coral{background:#FFE6E1;color:#C5402C;}

/* ---------- Stats / counters ---------- */
.stat-strip{background:var(--navy-900);color:#fff;padding:54px 0;}
.stat-strip .grid{text-align:center;}
.stat-strip strong{display:block;font-family:var(--font-display);font-size:clamp(2rem,3.2vw,2.8rem);color:var(--teal-bright);}
.stat-strip .grid div > span{font-size:.85rem;color:rgba(255,255,255,.65);}

/* ---------- Logo / partner strip ---------- */
.marquee{overflow:hidden;position:relative;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);}
.marquee-track{display:flex;gap:64px;align-items:center;animation:marquee 28s linear infinite;width:max-content;}
.marquee-track span{font-family:var(--font-display);font-weight:600;color:var(--gray-500);font-size:1.05rem;white-space:nowrap;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---------- Timeline ---------- */
.timeline{position:relative;padding-left:40px;border-left:2px solid var(--gray-300);}
.timeline-item{position:relative;padding-bottom:42px;}
.timeline-item:last-child{padding-bottom:0;}
.timeline-item::before{content:'';position:absolute;left:-46px;top:2px;width:14px;height:14px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 0 5px rgba(63,230,203,.2);}
.timeline-item time{font-family:var(--font-display);color:var(--navy);font-weight:600;font-size:.9rem;}

/* ---------- Testimonials ---------- */
.testimonial{background:var(--paper);border-radius:var(--radius-lg);padding:44px;position:relative;}
.testimonial .quote-mark{font-family:var(--font-display);font-size:4rem;color:var(--teal-300);line-height:1;}
.testimonial p{font-size:1.15rem;color:var(--navy-900);font-style:italic;}
.testimonial cite{display:block;font-style:normal;font-weight:700;color:var(--navy);margin-top:12px;}
.testimonial cite span{display:block;font-weight:400;color:var(--gray-500);font-size:.85rem;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7);padding:80px 0 30px;position:relative;overflow:hidden;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:32px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1);}
@media (max-width:980px){.footer-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:640px){.footer-grid{grid-template-columns:1fr;}}
.footer-grid h3,.footer-grid h4{color:#fff;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px;}
.timeline-item h3{font-size:1rem;}
.footer-grid ul li{margin-bottom:10px;}
.footer-grid a{color:rgba(255,255,255,.65);font-size:.92rem;transition:color .2s;}
.footer-grid a:hover{color:var(--teal-bright);}
.footer-brand p{color:rgba(255,255,255,.6);max-width:280px;}
.footer-brand img{height:32px;margin-bottom:16px;filter:brightness(0) invert(1);}
.social-row{display:flex;gap:10px;margin-top:18px;}
.social-row a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;transition:.25s;}
.social-row a:hover{background:var(--teal-bright);border-color:var(--teal-bright);}
.social-row svg{width:16px;height:16px;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:12px;font-size:.82rem;}
.footer-bottom a{margin-left:18px;color:rgba(255,255,255,.55);}
.footer-bottom a:hover{color:var(--teal-bright);}
.newsletter-form{display:flex;gap:8px;margin-top:10px;}
.newsletter-form input{flex:1;padding:12px 16px;border-radius:100px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font-size:.88rem;}
.newsletter-form input::placeholder{color:rgba(255,255,255,.45);}
.newsletter-form button{border-radius:100px;}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-stagger > *{transition-delay:calc(var(--i,0) * 90ms);}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media (max-width:640px){.form-grid{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;}
.field label{font-size:.85rem;font-weight:600;color:var(--navy-900);}
.field input,.field select,.field textarea{
  padding:14px 16px;border:1.5px solid var(--gray-300);border-radius:12px;font-family:inherit;font-size:.95rem;
  transition:border-color .25s,box-shadow .25s;background:#fff;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy);box-shadow:0 0 0 4px rgba(34,69,125,.1);outline:none;}
.field.col-2{grid-column:1/-1;}
.field-hint{font-size:.78rem;color:var(--gray-500);}
.honey{position:absolute;left:-9999px;opacity:0;}
.form-status{margin-top:14px;font-size:.9rem;font-weight:600;}
.form-status.success{color:#1A8B5F;}
.form-status.error{color:#C5402C;}

/* ---------- Misc page sections ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
@media (max-width:900px){.split{grid-template-columns:1fr;}}
.split.reverse{direction:rtl;}
.split.reverse>*{direction:ltr;}
.media-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);background:var(--gray-100);}
@media (max-width:640px){.media-frame{max-width:300px;margin-left:auto;margin-right:auto;aspect-ratio:1/1;}.media-frame img{width:100%;height:100%;object-fit:contain;}}

/* Progressive image loading: low-quality placeholder tone fades to full image */
picture img, .hero-orb img{
  background:linear-gradient(135deg,var(--gray-100),var(--gray-300));
  opacity:0;transition:opacity .5s var(--ease);
}
picture img.is-loaded, .hero-orb img.is-loaded{opacity:1;}
.checklist li{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;color:var(--gray-700);}
.checklist svg{flex-shrink:0;width:22px;height:22px;color:var(--teal-bright);margin-top:1px;}

.cta-band{
  background:linear-gradient(120deg,var(--navy-900),var(--navy-700));border-radius:var(--radius-lg);
  padding:64px;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.cta-band h2{color:#fff;margin-bottom:8px;}
.cta-band p{color:rgba(255,255,255,.75);margin-bottom:0;}

.pagination{display:flex;justify-content:center;gap:10px;margin-top:50px;}
.pagination a{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--gray-300);font-weight:600;transition:.25s;}
.pagination a.active,.pagination a:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--gray-100);}
table{width:100%;border-collapse:collapse;font-size:.92rem;}
table th,table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--gray-100);}
table th{background:var(--paper);font-family:var(--font-display);color:var(--navy-900);}

.toc{background:var(--paper);border-radius:var(--radius);padding:24px 28px;margin-bottom:30px;}
.toc h4{margin-bottom:10px;font-size:.95rem;}
.toc a{display:block;padding:4px 0;color:var(--navy);font-size:.9rem;}

.share-row{display:flex;gap:10px;align-items:center;margin-top:30px;}
.share-row a{width:38px;height:38px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center;}
.share-row svg{width:16px;height:16px;color:var(--navy);}

.back-to-top{
  position:fixed;bottom:28px;right:28px;width:48px;height:48px;border-radius:50%;background:var(--navy);
  color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);z-index:300;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s;border:none;cursor:pointer;
}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0);}

.alt-bg{background:var(--paper);}
.navy-bg{background:var(--navy-900);color:#fff;}
.navy-bg h2,.navy-bg h3{color:#fff;}
.navy-bg p{color:rgba(255,255,255,.72);}
.navy-bg .card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);}
.navy-bg .card h3,.navy-bg .card p{color:#fff;}
.navy-bg .card p{color:rgba(255,255,255,.65);}

.text-center{text-align:center;}
.mt-0{margin-top:0;}
.mb-0{margin-bottom:0;}
