/* ============================================================
   Comply Direct - stylesheet
   Brand: Ink navy + Signal teal. Fonts: Sora (display) / Inter (text)
   ============================================================ */

:root{
  /* Brand */
  --ink:        #0A2540;   /* primary navy */
  --ink-900:    #071A30;   /* darker navy */
  --teal:       #0FB6A1;   /* signal teal (accent) */
  --teal-300:   #34D8B4;   /* light teal */
  --teal-soft:  #E6FAF6;   /* teal tint */

  /* Neutrals */
  --bg:         #FFFFFF;
  --bg-soft:    #F6F9FC;
  --bg-alt:     #F0F5FA;
  --line:       #E2EAF2;
  --text:       #314B66;   /* body */
  --muted:      #6B7E95;   /* secondary */
  --white:      #FFFFFF;

  --radius:     16px;
  --radius-sm:  10px;
  --shadow:     0 10px 30px rgba(10,37,64,.08);
  --shadow-lg:  0 24px 60px rgba(10,37,64,.14);
  --container:  1140px;

  --font-display: 'Sora', 'Segoe UI', system-ui, sans-serif;
  --font-text: 'Inter', system-ui, -apple-system, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-text);
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ink); line-height:1.15; letter-spacing:-.02em; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }
.container--narrow{ max-width:840px; }

.grad{
  background:linear-gradient(90deg,var(--teal),var(--teal-300));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font-display); font-weight:600; font-size:1rem;
  padding:.8rem 1.4rem; border-radius:999px; cursor:pointer; border:1.5px solid transparent;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn--primary{ background:var(--teal); color:#04201c; }
.btn--primary:hover{ background:var(--teal-300); transform:translateY(-2px); box-shadow:0 12px 24px rgba(15,182,161,.35); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--teal); color:var(--ink); transform:translateY(-2px); }
.btn--lg{ padding:1rem 1.7rem; font-size:1.05rem; }
.btn--sm{ padding:.55rem 1rem; font-size:.95rem; }
.btn--block{ width:100%; }

.eyebrow{
  display:inline-block; font-family:var(--font-display); font-weight:700;
  font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--teal);
  margin-bottom:.9rem;
}
.eyebrow--light{ color:var(--teal-300); }

/* ---------- Nav ---------- */
.nav{ position:sticky; top:0; z-index:50; background:rgba(255,255,255,.85); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.nav__inner{ display:flex; align-items:center; justify-content:space-between; height:88px; }
.nav__brand img{ display:block; }
.nav__links{ display:flex; align-items:center; gap:1.6rem; }
.nav__links a{ font-weight:500; color:var(--ink); font-size:.97rem; }
.nav__links a:not(.btn):hover{ color:var(--teal); }
.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav__toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.2s; }

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; background:linear-gradient(180deg,#F6F9FC 0%, #FFFFFF 100%); }
.hero::before{
  content:""; position:absolute; top:-200px; right:-200px; width:560px; height:560px;
  background:radial-gradient(circle, rgba(15,182,161,.16), transparent 70%); z-index:0;
}
.hero__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; padding:84px 24px 90px; }
.hero h1{ font-size:clamp(2.2rem, 4.4vw, 3.5rem); font-weight:800; margin-bottom:1.2rem; }
.lead{ font-size:1.15rem; color:var(--muted); max-width:36em; margin-bottom:1.8rem; }
.hero__cta{ display:flex; gap:.9rem; flex-wrap:wrap; margin-bottom:1.8rem; }
.hero__trust{ list-style:none; display:flex; flex-wrap:wrap; gap:.6rem 1.6rem; font-weight:500; color:var(--ink); font-size:.95rem; }

/* Floating cards */
.hero__panel{ position:relative; min-height:380px; }
.card-float{
  position:absolute; display:flex; align-items:center; gap:.8rem;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:1rem 1.2rem; box-shadow:var(--shadow-lg); width:max-content; max-width:300px;
}
.card-float strong{ display:block; color:var(--ink); font-family:var(--font-display); font-size:1rem; }
.card-float span{ font-size:.85rem; color:var(--muted); }
.card-float--1{ top:10px; left:0; animation:float 6s ease-in-out infinite; }
.card-float--2{ top:150px; right:0; animation:float 6s ease-in-out infinite .8s; }
.card-float--3{ bottom:10px; left:30px; animation:float 6s ease-in-out infinite 1.6s; }
.cf__dot{ width:38px; height:38px; border-radius:50%; background:var(--teal-soft); position:relative; flex:none; }
.cf__dot::after{ content:""; position:absolute; inset:11px; border-radius:50%; background:var(--teal); }
.cf__dot--alt::after{ background:var(--ink); }
.cf__check{ width:38px; height:38px; border-radius:50%; background:var(--teal); color:#04201c; display:grid; place-items:center; font-weight:800; flex:none; }
@keyframes float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

/* ---------- Strip ---------- */
.strip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-soft); }
.strip__inner{ display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; padding:18px 24px; }
.strip__inner > span{ font-weight:600; color:var(--muted); font-size:.85rem; text-transform:uppercase; letter-spacing:.08em; }
.strip ul{ list-style:none; display:flex; flex-wrap:wrap; gap:.6rem 1.6rem; }
.strip li{ font-family:var(--font-display); font-weight:600; color:var(--ink); opacity:.7; font-size:.95rem; }

/* ---------- Sections ---------- */
.section{ padding:90px 0; }
.section--tight{ padding:70px 0; }
.section--alt{ background:var(--bg-soft); }
.section__head{ max-width:720px; margin:0 auto 52px; text-align:center; }
.section__head h2{ font-size:clamp(1.8rem,3.2vw,2.5rem); font-weight:700; }
.section__sub{ margin-top:1rem; color:var(--muted); font-size:1.08rem; }

.grid{ display:grid; gap:24px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }

/* Pain cards */
.pain{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px; }
.pain h3{ font-size:1.2rem; margin-bottom:.6rem; }
.pain p{ color:var(--muted); }

/* Services */
.service{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:32px; transition:transform .2s, box-shadow .2s, border-color .2s; }
.service:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--teal); }
.service__icon{ width:46px; height:46px; border-radius:12px; background:var(--teal-soft); color:var(--teal); font-family:var(--font-display); font-weight:800; display:grid; place-items:center; font-size:1.25rem; margin-bottom:1rem; }
.service h3{ font-size:1.3rem; margin-bottom:.6rem; }
.service p{ color:var(--muted); margin-bottom:1rem; }
.service ul{ list-style:none; }
.service ul li{ position:relative; padding-left:1.5rem; margin-bottom:.45rem; color:var(--text); }
.service ul li::before{ content:"✓"; position:absolute; left:0; color:var(--teal); font-weight:800; }

/* Why */
.why{ padding:8px 4px; }
.why__num{ font-family:var(--font-display); font-weight:800; font-size:2rem; color:var(--teal); opacity:.4; margin-bottom:.4rem; }
.why h3{ font-size:1.25rem; margin-bottom:.5rem; }
.why p{ color:var(--muted); }

/* Steps */
.steps{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:24px; counter-reset:step; }
.step{ position:relative; background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px 24px; }
.step__n{ display:grid; place-items:center; width:42px; height:42px; border-radius:50%; background:var(--ink); color:#fff; font-family:var(--font-display); font-weight:700; margin-bottom:1rem; }
.step h3{ font-size:1.12rem; margin-bottom:.5rem; }
.step p{ color:var(--muted); font-size:.96rem; }

/* Pricing */
.pricing{ align-items:stretch; }
.plan{ position:relative; background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:34px 30px; display:flex; flex-direction:column; }
.plan--featured{ border:2px solid var(--teal); box-shadow:var(--shadow-lg); }
.plan__badge{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--teal); color:#04201c; font-family:var(--font-display); font-weight:700; font-size:.78rem; letter-spacing:.04em; padding:.35rem .9rem; border-radius:999px; }
.plan__name{ font-size:1.35rem; }
.plan__tag{ color:var(--muted); font-size:.9rem; margin-bottom:1rem; }
.plan__price{ font-family:var(--font-display); font-weight:800; font-size:2.6rem; color:var(--ink); line-height:1; }
.plan__from{ font-size:.9rem; font-weight:600; color:var(--muted); }
.plan__note{ color:var(--muted); font-size:.9rem; margin:.3rem 0 1.3rem; }
.plan ul{ list-style:none; margin-bottom:1.6rem; flex:1; }
.plan ul li{ position:relative; padding-left:1.6rem; margin-bottom:.6rem; }
.plan ul li::before{ content:"✓"; position:absolute; left:0; color:var(--teal); font-weight:800; }
.pricing__foot{ text-align:center; margin-top:28px; color:var(--muted); }
.pricing__foot a{ color:var(--teal); font-weight:600; }

/* Pricing comparison table */
.ptable{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.ptable__head, .ptable__row{ display:grid; grid-template-columns:2fr 1.1fr 1.3fr; align-items:center; gap:16px; padding:18px 26px; }
.ptable__head{ background:var(--ink); color:#fff; font-family:var(--font-display); font-weight:600; font-size:.92rem; letter-spacing:.01em; }
.ptable__head .ptable__muted{ color:#9fb1c6; font-weight:500; }
.ptable__row{ border-top:1px solid var(--line); }
.ptable__row:nth-child(even){ background:var(--bg-soft); }
.ptable__row > span:first-child{ font-family:var(--font-display); font-weight:600; color:var(--ink); }
.ptable__price{ font-family:var(--font-display); font-weight:800; color:var(--teal); font-size:1.15rem; }
.ptable__strike{ color:var(--muted); text-decoration:line-through; text-decoration-color:rgba(107,126,149,.5); }
.pricing__cta{ text-align:center; margin-top:28px; }

/* Testimonials */
.quote{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:30px; box-shadow:var(--shadow); position:relative; }
.quote::before{ content:"\201C"; font-family:var(--font-display); font-size:3.5rem; line-height:1; color:var(--teal); opacity:.35; display:block; margin-bottom:.2rem; }
.quote blockquote{ color:var(--text); font-size:1.02rem; margin-bottom:1rem; }
.quote figcaption{ font-family:var(--font-display); font-weight:600; color:var(--ink); font-size:.92rem; }

/* FAQ */
.faq details{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius-sm); padding:4px 20px; margin-bottom:12px; }
.faq summary{ font-family:var(--font-display); font-weight:600; color:var(--ink); cursor:pointer; padding:16px 0; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq summary::after{ content:"+"; color:var(--teal); font-size:1.5rem; font-weight:400; transition:.2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:var(--muted); padding:0 0 18px; }

/* CTA / contact */
.cta{ background:var(--bg-soft); }
.cta__card{ background:var(--ink); border-radius:28px; padding:64px; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; box-shadow:var(--shadow-lg); overflow:hidden; position:relative; }
.cta__card::before{ content:""; position:absolute; top:-140px; right:-140px; width:440px; height:440px; background:radial-gradient(circle, rgba(15,182,161,.25), transparent 70%); }
.cta__copy{ position:relative; z-index:1; }
.cta__card h2{ color:#fff; font-size:clamp(2.1rem,3vw,3rem); margin-bottom:1.2rem; }
.cta__copy p{ color:#B9C7D8; font-size:1.15rem; margin-bottom:1.6rem; }
.cta__list{ list-style:none; color:#E6EDF5; font-weight:500; font-size:1.08rem; }
.cta__list li{ margin-bottom:.6rem; }

.cform{ position:relative; z-index:1; background:#fff; border-radius:var(--radius); padding:36px; }
.cform label{ display:block; font-family:var(--font-display); font-weight:600; color:var(--ink); font-size:.9rem; margin-bottom:14px; }
.cform input, .cform select, .cform textarea{
  width:100%; margin-top:.4rem; padding:.7rem .85rem; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  font-family:var(--font-text); font-size:.97rem; color:var(--ink); background:#fff; font-weight:400;
}
.cform input:focus, .cform select:focus, .cform textarea:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(15,182,161,.15); }
.cform__row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cform textarea{ resize:vertical; }
.cform__fine{ font-size:.82rem; color:var(--muted); text-align:center; margin-top:.8rem; font-weight:400; }
.cform__status{ text-align:center; font-weight:600; margin-top:.6rem; }
.cform__status.ok{ color:var(--teal); }
.cform__status.err{ color:#d23b3b; }

/* Footer */
.footer{ background:var(--ink-900); color:#B9C7D8; padding:60px 0 28px; }
.footer__inner{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:32px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer__logo{ display:inline-block; background:#fff; padding:10px 14px; border-radius:12px; line-height:0; }
.footer__brand p{ margin-top:1rem; max-width:28em; font-size:.95rem; }
.footer__col h4{ color:#fff; font-size:1rem; margin-bottom:1rem; }
.footer__col a{ display:block; margin-bottom:.6rem; font-size:.95rem; color:#B9C7D8; }
.footer__col a:hover{ color:var(--teal-300); }
.footer__base{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-top:24px; font-size:.85rem; color:#7d90a6; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav__links{ position:fixed; inset:88px 0 auto 0; flex-direction:column; align-items:stretch; gap:0; background:#fff; border-bottom:1px solid var(--line); padding:12px 24px 20px; transform:translateY(-130%); transition:transform .25s ease; box-shadow:var(--shadow); }
  .nav__links.open{ transform:translateY(0); }
  .nav__links a{ padding:14px 0; border-bottom:1px solid var(--line); }
  .nav__links .btn{ margin-top:12px; text-align:center; }
  .nav__toggle{ display:flex; }
  .hero__inner{ grid-template-columns:1fr; padding:56px 24px 64px; }
  .hero__panel{ display:none; }
  .grid-2, .grid-3{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr 1fr; }
  .cta__card{ grid-template-columns:1fr; padding:30px; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:720px){
  .ptable__head{ display:none; }
  .ptable__row{ grid-template-columns:1fr; gap:6px; padding:18px 22px; }
  .ptable__row > span{ display:flex; justify-content:space-between; gap:1rem; }
  .ptable__row > span:first-child{ font-size:1.05rem; margin-bottom:.3rem; }
  .ptable__row > span:not(:first-child)::before{ content:attr(data-label); color:var(--muted); font-weight:500; font-family:var(--font-text); }
}
@media (max-width:560px){
  .section{ padding:62px 0; }
  .cform__row{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .footer__inner{ grid-template-columns:1fr; }
  .hero__cta .btn{ width:100%; }
}
