/* ===== Advokacy — landing + solutions pages =====
   Static marketing pages. Built on the v2 design system (styles.css tokens:
   --brand/--ink/--surface/--r-*/--sh-*, Hanken Grotesk + IBM Plex Mono).
   No React — plain semantic HTML. Themed by the shared inline theme-init
   script so brand hue / dark mode stay consistent with the app. */

body{overflow-y:auto}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
img{max-width:100%}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media (prefers-reduced-motion:reduce){*{animation:none!important}}

/* ---------- top nav ---------- */
.lnav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklch,var(--bg),transparent 12%);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--border);
}
.lnav-in{display:flex;align-items:center;gap:22px;height:64px}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{
  width:34px;height:34px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(150deg,var(--brand),var(--brand-ink));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:19px;
  box-shadow:0 2px 8px color-mix(in oklch,var(--brand),transparent 60%);
}
.brand-name{font-weight:700;font-size:19px;letter-spacing:-.02em}
.brand-name b{color:var(--brand)}
.lnav-links{display:flex;align-items:center;gap:6px;margin-left:auto}
.lnav-links a{
  font-size:14px;font-weight:500;color:var(--ink-2);
  padding:8px 12px;border-radius:var(--r-sm);transition:var(--tr);
}
.lnav-links a:hover{color:var(--ink);background:var(--surface-2)}
.lnav-links a.active{color:var(--brand-ink);font-weight:600}
.lnav-links a.lnav-signin{color:var(--ink);font-weight:600}
.lnav-links a.lnav-signin:hover{color:var(--brand-ink);background:var(--surface-2)}
.btn{
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
  font-weight:600;font-size:14px;padding:10px 18px;border-radius:var(--r-md);
  transition:var(--tr);border:1px solid transparent;
}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-ink));color:#fff;box-shadow:0 2px 10px color-mix(in oklch,var(--brand),transparent 62%)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-2px);box-shadow:0 6px 18px color-mix(in oklch,var(--brand),transparent 55%)}
.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--border-2)}
.btn-ghost:hover{border-color:var(--brand-line);color:var(--brand-ink)}
.btn-lg{padding:14px 26px;font-size:15.5px;border-radius:var(--r-md)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:40px 0 48px}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(58% 60% at 82% 0%,color-mix(in oklch,var(--brand),transparent 82%),transparent 68%),
    radial-gradient(46% 55% at 6% 100%,color-mix(in oklch,var(--brand),transparent 88%),transparent 70%);
}
/* faint legal-grid texture behind the hero for depth + energy */
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(color-mix(in oklch,var(--brand),transparent 93%) 1px,transparent 1px),
    linear-gradient(90deg,color-mix(in oklch,var(--brand),transparent 93%) 1px,transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(70% 60% at 60% 20%,#000,transparent 75%);
  mask-image:radial-gradient(70% 60% at 60% 20%,#000,transparent 75%);
}
.hero-in{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero-copy{animation:fadeUp .6s cubic-bezier(.4,0,.2,1) both}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand-ink);background:var(--brand-soft);border:1px solid var(--brand-line);
  padding:5px 12px;border-radius:100px;margin-bottom:22px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--ok)}
h1.hero-h{
  font-size:50px;line-height:1.05;letter-spacing:-.03em;font-weight:800;
  margin-bottom:16px;
}
h1.hero-h .accent{
  background:linear-gradient(120deg,var(--brand),var(--brand-ink));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-sub{font-size:18px;line-height:1.5;color:var(--ink-2);max-width:40ch;margin-bottom:22px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-note{margin-top:18px;font-size:13px;color:var(--ink-3);display:flex;align-items:center;gap:8px}
.hero-note svg{width:15px;height:15px;color:var(--ok);flex-shrink:0}

/* hero visual — stylised verified-case card stack */
.hero-art{position:relative;min-height:340px;animation:fadeUp .7s .1s cubic-bezier(.4,0,.2,1) both}
.vcard{
  position:absolute;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--sh-3);padding:18px 20px;
  animation:floaty 7s ease-in-out infinite;
}
.vcard-1{top:0;left:8%;right:6%;z-index:3}
.vcard-2{top:120px;left:0;right:22%;z-index:2;opacity:.96;animation-delay:.9s}
.vcard-3{top:232px;left:16%;right:0;z-index:1;opacity:.9;animation-delay:1.8s}
.vc-head{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.vc-badge{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;font-weight:600;
  padding:3px 9px;border-radius:100px;
  background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-line);
  display:inline-flex;align-items:center;gap:5px;
}
.vc-badge .tick{width:11px;height:11px}
.vc-court{font-size:12px;color:var(--ink-3);font-weight:600;margin-left:auto}
.vc-title{font-weight:700;font-size:15px;letter-spacing:-.01em;margin-bottom:6px}
.vc-cite{font-family:var(--mono);font-size:11.5px;color:var(--ink-3)}
.vc-lines{margin-top:12px;display:flex;flex-direction:column;gap:7px}
.vc-lines i{display:block;height:7px;border-radius:4px;background:var(--surface-3)}
.vc-lines i:nth-child(2){width:88%}
.vc-lines i:nth-child(3){width:66%}

/* ---------- trust strip ---------- */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface)}
.trust-in{display:flex;flex-wrap:wrap;gap:14px 44px;justify-content:center;padding:22px 0}
.trust-item{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:120px}
.trust-num{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--brand-ink)}
.trust-lbl{font-size:12.5px;color:var(--ink-3);margin-top:2px}

/* ---------- section scaffolding ---------- */
section.band{padding:46px 0}
.band-alt{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sec-head{max-width:640px;margin:0 auto 34px;text-align:center}
.sec-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-ink);margin-bottom:12px}
.sec-head h2{font-size:34px;line-height:1.1;letter-spacing:-.025em;font-weight:800;margin-bottom:14px}
.sec-head p{font-size:16.5px;color:var(--ink-2);line-height:1.55}

/* feature grid */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.fcard{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:26px 24px;transition:var(--tr);
}
.fcard:hover{border-color:var(--brand-line);box-shadow:var(--sh-2);transform:translateY(-2px)}
.ficon{
  width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;
  background:var(--brand-soft);color:var(--brand-ink);border:1px solid var(--brand-line);margin-bottom:16px;
}
.ficon svg{width:22px;height:22px}
.fcard h3{font-size:17px;letter-spacing:-.01em;margin-bottom:8px}
.fcard p{font-size:14.5px;color:var(--ink-2);line-height:1.55}

/* India-law feature list */
.india{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.india-list{display:flex;flex-direction:column;gap:18px}
.ilist-item{display:flex;gap:14px}
.ilist-item .ck{
  width:26px;height:26px;border-radius:8px;flex-shrink:0;margin-top:1px;
  background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-line);
  display:flex;align-items:center;justify-content:center;
}
.ilist-item .ck svg{width:15px;height:15px}
.ilist-item h4{font-size:15.5px;margin-bottom:3px}
.ilist-item p{font-size:14px;color:var(--ink-2);line-height:1.5}
.pillars{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.pillar{
  font-family:var(--mono);font-size:12px;font-weight:600;padding:8px 13px;border-radius:var(--r-sm);
  background:var(--surface);border:1px solid var(--border-2);color:var(--ink-2);
}
.pillar b{color:var(--brand-ink)}

/* anatomy of a case — what data we surface */
.anat{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:start}
.anat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  box-shadow:var(--sh-3);padding:24px 26px;
}
.anat-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.anat-court{font-size:12.5px;font-weight:600;color:var(--ink-3)}
.anat-good{margin-left:auto;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:100px;background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-line)}
.anat-title{font-size:21px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:6px}
.anat-cite{font-size:12px;color:var(--ink-3);padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:6px}
.anat-rows{display:flex;flex-direction:column}
.anat-row{display:grid;grid-template-columns:120px 1fr;gap:14px;padding:11px 0;border-bottom:1px solid var(--border)}
.anat-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-ink);padding-top:2px}
.anat-val{font-size:14px;color:var(--ink-2);line-height:1.5}
.anat-quote .anat-val{font-style:italic;color:var(--ink);border-left:3px solid var(--brand-line);padding-left:12px}
.anat-chips{display:flex;flex-wrap:wrap;gap:6px}
.achip{font-size:11.5px;font-weight:600;padding:4px 9px;border-radius:var(--r-xs);background:var(--brand-soft);color:var(--brand-ink);border:1px solid var(--brand-line)}
.anat-full{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:13.5px;font-weight:600;color:var(--brand-ink)}
.anat-full svg{width:15px;height:15px}
.anat-full:hover{gap:10px}
.anat-legend{display:flex;flex-direction:column;gap:20px;padding-top:6px}
.anat-leg{display:flex;gap:14px}
.anat-leg .ck{width:26px;height:26px;border-radius:8px;flex-shrink:0;margin-top:1px;background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-line);display:flex;align-items:center;justify-content:center}
.anat-leg .ck svg{width:15px;height:15px}
.anat-leg h4{font-size:15.5px;margin-bottom:3px}
.anat-leg p{font-size:14px;color:var(--ink-2);line-height:1.5}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 24px}
.step::before{
  counter-increment:step;content:counter(step);
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;margin-bottom:16px;
  background:var(--brand);color:#fff;font-weight:800;font-size:17px;
}
.step h3{font-size:17px;margin-bottom:8px;letter-spacing:-.01em}
.step p{font-size:14.5px;color:var(--ink-2);line-height:1.55}

/* audience split */
.aud{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.aud-card{
  border-radius:var(--r-xl);padding:34px 32px;border:1px solid var(--border);
  background:var(--surface);position:relative;overflow:hidden;
}
.aud-card.pro{background:linear-gradient(160deg,var(--brand-soft),var(--surface) 65%);border-color:var(--brand-line)}
.aud-tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-ink);margin-bottom:12px}
.aud-card h3{font-size:23px;letter-spacing:-.02em;margin-bottom:12px}
.aud-card ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:22px}
.aud-card li{display:flex;gap:11px;font-size:14.5px;color:var(--ink-2);line-height:1.5}
.aud-card li svg{width:17px;height:17px;color:var(--brand);flex-shrink:0;margin-top:2px}

/* CTA band */
.cta{
  text-align:center;border-radius:var(--r-xl);padding:60px 32px;
  background:linear-gradient(150deg,var(--brand),var(--brand-ink));color:#fff;
  box-shadow:var(--sh-3);position:relative;overflow:hidden;
}
.cta::before{content:"⚖";position:absolute;font-size:280px;opacity:.06;right:-20px;bottom:-90px;line-height:1}
.cta h2{font-size:34px;letter-spacing:-.02em;margin-bottom:14px;color:#fff}
.cta p{font-size:17px;opacity:.9;max-width:44ch;margin:0 auto 28px}
.cta .btn-primary{background:#fff;color:var(--brand-ink)}
.cta .btn-primary:hover{background:#fff;opacity:.92}
.cta .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta .btn-ghost:hover{border-color:#fff;color:#fff}

/* ---------- footer ---------- */
.foot{background:var(--surface);border-top:1px solid var(--border);padding:48px 0 32px}
.foot-in{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px}
.foot-brand p{font-size:14px;color:var(--ink-3);line-height:1.55;margin-top:14px;max-width:34ch}
.foot-col h5{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.foot-col a{display:block;font-size:14.5px;color:var(--ink-2);padding:5px 0;transition:var(--tr)}
.foot-col a:hover{color:var(--brand-ink)}
.foot-bot{border-top:1px solid var(--border);margin-top:36px;padding-top:22px;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center}
.foot-bot small{font-size:12.5px;color:var(--ink-3)}
.disc{
  font-size:12.5px;color:var(--ink-3);line-height:1.5;background:var(--surface-2);
  border:1px solid var(--border);border-radius:var(--r-md);padding:12px 15px;margin-top:24px;
}
.disc b{color:var(--ink-2)}

/* ---------- solutions page specifics ---------- */
.sol-hero{padding:26px 0 2px;text-align:center}
.sol-hero .eyebrow{margin-bottom:12px}
.sol-hero h1{font-size:38px;letter-spacing:-.03em;font-weight:800;margin-bottom:10px}
.sol-hero p{font-size:16.5px;color:var(--ink-2);max-width:56ch;margin:0 auto;line-height:1.5}
.solgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.solcard{
  display:flex;flex-direction:column;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-xl);padding:30px 28px;transition:var(--tr);
}
.solcard:hover{border-color:var(--brand-line);box-shadow:var(--sh-3);transform:translateY(-3px)}
.solcard .ficon{width:50px;height:50px}
.solcard .ficon svg{width:25px;height:25px}
.solcard .pill{
  align-self:flex-start;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;margin-bottom:14px;
  background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-line);
}
.solcard .pill.soon{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-line)}
.solcard h3{font-size:21px;letter-spacing:-.02em;margin-bottom:10px}
.solcard>p{font-size:15px;color:var(--ink-2);line-height:1.6;margin-bottom:20px;text-align:justify;text-justify:inter-word;hyphens:auto}
.solcard ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.solcard li{display:flex;gap:10px;font-size:14px;color:var(--ink-2)}
.solcard li svg{width:16px;height:16px;color:var(--brand);flex-shrink:0;margin-top:2px}
.solcard .solcta{margin-top:auto}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero-in{grid-template-columns:1fr;gap:44px}
  .hero-art{min-height:300px;order:-1}
  h1.hero-h{font-size:42px}
  .india{grid-template-columns:1fr;gap:32px}
  .anat{grid-template-columns:1fr;gap:28px}
  .fgrid,.steps{grid-template-columns:1fr 1fr}
  .aud{grid-template-columns:1fr}
  .foot-in{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .lnav-links .hide-sm{display:none}
  h1.hero-h{font-size:34px}
  .hero-sub{font-size:16.5px}
  .fgrid,.steps{grid-template-columns:1fr}
  .foot-in{grid-template-columns:1fr}
  .sec-head h2,.cta h2{font-size:27px}
  .sol-hero h1{font-size:33px}
}
