/* ============================================================================
   Marketing Website UI Kit — kit styles
   Imports the system tokens, then adds page-level layout, atmosphere, and
   component classes used by the Hub & Spoke landing page.
   ============================================================================ */
@import url('tokens.css');

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg-0);color:var(--fg-1);
  font-family:var(--font-body);-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:rgba(61,123,255,.32);color:#fff}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);width:100%}
.eyebrow{font-family:var(--font-mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--accent-bright)}

/* ---- Buttons -------------------------------------------------------------- */
.btn{font-weight:600;font-size:15px;border-radius:var(--r-md);padding:14px 24px;
  display:inline-flex;align-items:center;gap:9px;border:1px solid transparent;cursor:pointer;
  transition:transform var(--dur-fast) var(--ease-out),background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
  white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--glow-accent)}
.btn-primary:hover{background:var(--accent-bright);box-shadow:0 0 0 1px var(--accent-bright),0 0 54px -6px rgba(91,147,255,.7)}
.btn-primary:active{transform:scale(.98)}
.btn-secondary{background:transparent;color:var(--fg-1);border-color:var(--border-strong)}
.btn-secondary:hover{border-color:var(--fg-2);background:rgba(255,255,255,.03)}
.btn-secondary:active{transform:scale(.98)}
.btn-ghost{background:transparent;color:var(--fg-2);padding:10px 14px}
.btn-ghost:hover{color:var(--fg-1)}

/* ---- Header --------------------------------------------------------------- */
.hdr{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:rgba(7,9,14,.72);border-bottom:1px solid var(--border-subtle)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.hdr-nav{display:flex;align-items:center;gap:28px}
.hdr-nav a{font-size:14.5px;color:var(--fg-2);font-weight:500;transition:color var(--dur) var(--ease);white-space:nowrap}
.hdr-nav a:hover{color:var(--fg-1)}
.hdr-cta{display:flex;align-items:center;gap:14px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-.01em}
.logo .t2{color:var(--fg-3)}
.menu-btn{display:none;background:none;border:none;color:var(--fg-1);cursor:pointer}

/* ---- Atmosphere ----------------------------------------------------------- */
.atmos{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.atmos .grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:56px 56px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%)}
.atmos .glow{position:absolute;left:50%;top:-260px;transform:translateX(-50%);
  width:1100px;height:700px;border-radius:50%;
  background:radial-gradient(ellipse at center,rgba(61,123,255,.22),transparent 62%);filter:blur(20px)}

/* ---- Hero ----------------------------------------------------------------- */
.hero{position:relative;padding:96px 0 64px;text-align:center}
.hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(40px,6.4vw,72px);line-height:1.03;letter-spacing:-.025em;margin:24px auto 0;max-width:14ch}
.hero h1 .accent{color:var(--accent-bright)}
.hero p{font-size:clamp(16px,1.8vw,19px);line-height:1.6;color:var(--fg-2);max-width:60ch;margin:24px auto 0}
.hero-cta{display:flex;gap:14px;justify-content:center;margin-top:36px;flex-wrap:wrap}
.hero-strip{display:flex;gap:26px;justify-content:center;align-items:center;margin-top:46px;flex-wrap:wrap}
.hero-strip .stat{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--fg-3);font-family:var(--font-mono);letter-spacing:.02em}
.hero-strip .stat svg{width:15px;height:15px;color:var(--success)}
.hero-strip .sep{width:1px;height:16px;background:var(--border)}

/* ---- Section headers ------------------------------------------------------ */
.sec{padding:88px 0}
.sec-head{text-align:center;max-width:60ch;margin:0 auto 48px}
.sec-head h2{font-family:var(--font-display);font-weight:600;font-size:clamp(28px,3.6vw,40px);line-height:1.1;letter-spacing:-.02em;margin:14px 0 0}
.sec-head p{font-size:17px;color:var(--fg-2);margin:16px auto 0;max-width:54ch}

/* ---- Division grid -------------------------------------------------------- */
.div-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.div-card{position:relative;border:1px solid var(--border);border-radius:var(--r-xl);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--bg-2);
  box-shadow:var(--inset-top),var(--shadow-md);padding:30px;cursor:pointer;
  display:flex;flex-direction:column;text-align:left;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.div-card:hover{transform:translateY(-6px)}
.div-card .chip{width:54px;height:54px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;border:1px solid;margin-bottom:22px;transition:box-shadow var(--dur) var(--ease)}
.div-card .chip svg{width:26px;height:26px}
.div-card .eyebrow{font-size:11.5px;letter-spacing:.16em;color:var(--fg-3)}
.div-card h3{font-family:var(--font-display);font-weight:600;font-size:23px;letter-spacing:-.01em;margin:10px 0 12px;color:var(--fg-1)}
.div-card .desc{font-size:14.5px;line-height:1.55;color:var(--fg-2);margin:0 0 22px}
.div-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;margin-bottom:26px}
.div-card li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--fg-1)}
.div-card li svg{width:16px;height:16px;flex:none}
.div-card .go{margin-top:auto;display:flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px}
.div-card .go svg{width:16px;height:16px;transition:transform var(--dur) var(--ease)}
.div-card:hover .go svg{transform:translateX(4px)}
/* per-division theming via data attribute */
.div-card[data-div="it"]{--c:var(--div-it);--c-soft:var(--div-it-soft);--c-line:rgba(61,123,255,.4)}
.div-card[data-div="ai"]{--c:var(--div-ai);--c-soft:var(--div-ai-soft);--c-line:rgba(52,214,232,.4)}
.div-card[data-div="growth"]{--c:var(--div-growth);--c-soft:var(--div-growth-soft);--c-line:rgba(54,201,136,.4)}
.div-card .chip{background:var(--c-soft);border-color:var(--c-line);color:var(--c)}
.div-card li svg{color:var(--c)}
.div-card .go{color:var(--c)}
.div-card:hover,.div-card.active{border-color:var(--c-line);box-shadow:var(--inset-top),0 0 0 1px var(--c-line),0 24px 60px -28px rgba(0,0,0,.8),0 0 60px -16px var(--c)}
.div-card:hover .chip,.div-card.active .chip{box-shadow:0 0 30px -6px var(--c)}

/* ---- Trust marquee -------------------------------------------------------- */
.trust-sec{padding:54px 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}
.trust-label{text-align:center;font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);margin-bottom:28px}
.marquee{position:relative;overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:56px;width:max-content;animation:marquee 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .item{display:flex;align-items:center;gap:11px;color:var(--fg-2);font-family:var(--font-display);font-weight:600;font-size:19px;white-space:nowrap;opacity:.72}
.marquee .item svg{width:21px;height:21px;color:var(--fg-3)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- Footer + contact ----------------------------------------------------- */
.footer{position:relative}
.contact-wrap{padding:88px 0 24px}
.contact{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.contact h2{font-family:var(--font-display);font-weight:600;font-size:clamp(26px,3.2vw,36px);letter-spacing:-.02em;margin:14px 0 16px;line-height:1.1}
.contact p{font-size:16px;color:var(--fg-2);line-height:1.6;max-width:42ch}
.contact .points{list-style:none;padding:0;margin:28px 0 0;display:flex;flex-direction:column;gap:16px}
.contact .points li{display:flex;gap:13px;align-items:flex-start;font-size:14.5px;color:var(--fg-1)}
.contact .points .pi{width:34px;height:34px;border-radius:var(--r-md);background:var(--accent-soft);border:1px solid var(--accent-line);display:flex;align-items:center;justify-content:center;flex:none;color:var(--accent-bright)}
.contact .points .pi svg{width:16px;height:16px}
.contact .points .pt{color:var(--fg-3);font-size:13px;margin-top:2px}

.form{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--inset-top),var(--shadow-md);padding:28px}
.form .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-group{margin-bottom:16px}
.field-group:last-of-type{margin-bottom:22px}
label{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--fg-3);text-transform:uppercase;display:block;margin-bottom:8px}
.field{font-family:var(--font-body);font-size:15px;color:var(--fg-1);background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;width:100%;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.field::placeholder{color:var(--fg-3)}
.field:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
select.field{appearance:none;cursor:pointer}
textarea.field{resize:none;min-height:96px}
.form .btn-primary{width:100%;justify-content:center}
.form-success{text-align:center;padding:36px 12px}
.form-success .ok{width:56px;height:56px;border-radius:50%;background:rgba(54,201,136,.13);border:1px solid rgba(54,201,136,.4);color:var(--success);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.form-success .ok svg{width:26px;height:26px}
/* Center the success copy as a block. The global `.contact p{max-width:42ch}`
   rule applies here too, and without auto margins the paragraph block hugs the
   left — making its centered text read as off-center next to the heading. */
.form-success h3,.form-success p{max-width:46ch;margin-left:auto;margin-right:auto}
/* When the audit request is submitted, collapse the two-column contact area to
   a single centered success card (otherwise the thank-you sits in the right
   column and reads as off-center next to the still-visible intro copy). */
.contact.is-sent{grid-template-columns:1fr;max-width:560px;margin:0 auto}
.contact.is-sent .contact-intro{display:none}

.foot-nav{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding:48px 0;border-top:1px solid var(--border-subtle)}
.foot-col h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3);margin:0 0 18px}
.foot-col a{display:block;font-size:14px;color:var(--fg-2);margin-bottom:12px;transition:color var(--dur) var(--ease)}
.foot-col a:hover{color:var(--fg-1)}
.foot-brand p{font-size:14px;color:var(--fg-3);line-height:1.6;max-width:30ch;margin:16px 0 0}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:26px 0 40px;border-top:1px solid var(--border-subtle);flex-wrap:wrap;gap:14px}
.foot-bottom .copy{font-size:13px;color:var(--fg-3);font-family:var(--font-mono);letter-spacing:.02em}
.foot-bottom .socials{display:flex;gap:14px}
.foot-bottom .socials a{width:34px;height:34px;border-radius:var(--r-md);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--fg-2);transition:all var(--dur) var(--ease)}
.foot-bottom .socials a:hover{color:var(--fg-1);border-color:var(--border-strong)}
.foot-bottom .socials svg{width:16px;height:16px}

/* ---- Scroll reveal -------------------------------------------------------- */
/* Intentionally a no-op: content is always visible. (Entrance animations were
   removed because paused/hidden render contexts — print, PDF, offscreen
   capture — would otherwise freeze elements in their hidden keyframe.) */
.reveal{opacity:1}

/* ---- Header active + mobile menu ----------------------------------------- */
.hdr-nav a.active{color:var(--fg-1)}
.hdr-nav a.active::after{content:"";display:block;height:2px;border-radius:2px;margin-top:6px;background:var(--accent)}
.mobile-menu{border-top:1px solid var(--border-subtle);background:rgba(7,9,14,.96);backdrop-filter:blur(14px)}
.mobile-menu .wrap{display:flex;flex-direction:column;padding-top:10px;padding-bottom:16px}
.mobile-menu a{padding:13px 2px;font-size:15px;color:var(--fg-2);border-bottom:1px solid var(--border-subtle)}
.mobile-menu a.active,.mobile-menu a:hover{color:var(--fg-1)}
.mobile-menu .mm-portal{margin-top:14px;display:flex;align-items:center;gap:9px;background:transparent;border:1px solid var(--border-strong);color:var(--fg-1);border-radius:var(--r-md);padding:12px;font-size:15px;font-weight:600;cursor:pointer;justify-content:center}
.mobile-menu .mm-portal svg{width:16px;height:16px}

/* ---- Client Portal modal -------------------------------------------------- */
.portal-overlay{position:fixed;inset:0;z-index:100;background:rgba(5,6,10,.7);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px}
.portal-overlay[hidden]{display:none}
.portal-card{max-width:380px;width:100%}
.portal-card .logo{margin-bottom:6px}
.portal-card h3{font-family:var(--font-display);font-weight:600;font-size:21px;margin:14px 0 4px}
.portal-card .sub{color:var(--fg-2);font-size:14px;margin:0 0 20px}
.btn.full{width:100%;justify-content:center}

/* ---- Service page hero ---------------------------------------------------- */
.page{--c:var(--accent);--c-soft:var(--accent-soft);--c-line:var(--accent-line)}
.page-hero{position:relative;padding:84px 0 56px;overflow:hidden}
.page-hero .atmos .glow{background:radial-gradient(ellipse at center,color-mix(in srgb,var(--c) 26%,transparent),transparent 62%)}
.page-hero .inner{position:relative;max-width:760px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;color:var(--fg-3);letter-spacing:.04em;margin-bottom:22px}
.breadcrumb a{color:var(--fg-3)}
.breadcrumb a:hover{color:var(--fg-2)}
.breadcrumb svg{width:13px;height:13px}
.page-hero .ico{width:60px;height:60px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;border:1px solid var(--c-line);background:var(--c-soft);color:var(--c);box-shadow:0 0 34px -8px var(--c);margin-bottom:22px}
.page-hero .ico svg{width:28px;height:28px}
.page-hero .eyebrow{color:var(--c)}
.page-hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(36px,5vw,56px);line-height:1.04;letter-spacing:-.025em;margin:14px 0 0}
.page-hero .lede{font-size:clamp(16px,1.8vw,19px);line-height:1.6;color:var(--fg-2);max-width:56ch;margin:20px 0 0}
.page-hero .cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.page-hero .btn-primary{background:var(--c);box-shadow:0 0 0 1px var(--c-line),0 0 44px -8px var(--c)}
.page-hero .btn-primary:hover{filter:brightness(1.08)}

/* ---- Service grid --------------------------------------------------------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-2);box-shadow:var(--inset-top),var(--shadow-md);padding:26px;transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.svc-card:hover{transform:translateY(-4px);border-color:var(--c-line);box-shadow:var(--inset-top),0 0 0 1px var(--c-line),0 22px 50px -28px rgba(0,0,0,.8)}
.svc-card .ico{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;border:1px solid var(--c-line);background:var(--c-soft);color:var(--c);margin-bottom:18px}
.svc-card .ico svg{width:21px;height:21px}
.svc-card h3{font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-.01em;margin:0 0 9px;color:var(--fg-1)}
.svc-card p{font-size:14.5px;line-height:1.6;color:var(--fg-2);margin:0}

/* ---- Process steps -------------------------------------------------------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{position:relative;padding:24px;border:1px solid var(--border-subtle);border-radius:var(--r-lg);background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}
.step .num{font-family:var(--font-mono);font-size:13px;color:var(--c);border:1px solid var(--c-line);background:var(--c-soft);width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-weight:600}
.step h4{font-family:var(--font-display);font-weight:600;font-size:17px;margin:0 0 8px;color:var(--fg-1)}
.step p{font-size:13.5px;line-height:1.55;color:var(--fg-2);margin:0}

/* ---- Feature split (highlight band) --------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split .copy h2{margin-top:14px}
.split ul{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:14px}
.split li{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--fg-1);line-height:1.5}
.split li svg{width:19px;height:19px;color:var(--c);flex:none;margin-top:1px}
.panel{border:1px solid var(--border);border-radius:var(--r-xl);background:var(--bg-2);box-shadow:var(--inset-top),var(--shadow-md);padding:28px}
.panel .prow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 0;border-bottom:1px solid var(--border-subtle)}
.panel .prow:last-child{border-bottom:none}
.panel .pl{display:flex;align-items:center;gap:12px;font-size:14.5px;color:var(--fg-1)}
.panel .pl .pico{width:34px;height:34px;border-radius:var(--r-sm);background:var(--c-soft);border:1px solid var(--c-line);color:var(--c);display:flex;align-items:center;justify-content:center}
.panel .pl .pico svg{width:16px;height:16px}
.panel .tag{font-family:var(--font-mono);font-size:12px;color:var(--c);background:var(--c-soft);border:1px solid var(--c-line);border-radius:var(--r-full);padding:4px 11px}

/* ---- CTA band ------------------------------------------------------------- */
.cta-band{position:relative;border:1px solid var(--c-line);border-radius:var(--r-xl);background:linear-gradient(180deg,color-mix(in srgb,var(--c) 12%,var(--bg-2)),var(--bg-2));box-shadow:var(--inset-top),0 0 60px -24px var(--c);padding:48px;text-align:center;overflow:hidden}
.cta-band h2{font-family:var(--font-display);font-weight:600;font-size:clamp(26px,3.2vw,34px);letter-spacing:-.02em;margin:0 auto;max-width:22ch;line-height:1.1}
.cta-band p{font-size:16px;color:var(--fg-2);margin:14px auto 0;max-width:50ch}
.cta-band .cta{display:flex;gap:14px;justify-content:center;margin-top:28px;flex-wrap:wrap}
.cta-band .btn-primary{background:var(--c);box-shadow:0 0 0 1px var(--c-line),0 0 44px -8px var(--c)}

/* ---- Section helpers ------------------------------------------------------ */
.sec-head.left{text-align:left;margin:0 0 40px}

/* ---- Contact methods chips ------------------------------------------------ */
.methods{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.methods .m{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:var(--r-md);padding:12px 16px;background:var(--bg-2);box-shadow:var(--inset-top)}
.methods .m .mi{width:34px;height:34px;border-radius:var(--r-sm);background:var(--accent-soft);border:1px solid var(--accent-line);color:var(--accent-bright);display:flex;align-items:center;justify-content:center;flex:none}
.methods .m .mi svg{width:16px;height:16px}
.methods .m .mt{font-size:11px;color:var(--fg-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}
.methods .m .mv{font-size:14.5px;color:var(--fg-1);font-weight:600;margin-top:2px}

/* ---- Mobile --------------------------------------------------------------- */
@media (max-width:1024px){
  .hdr-nav{display:none}
  .menu-btn{display:flex}
}
@media (max-width:900px){
  .div-grid{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr;gap:34px}
  .foot-nav{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr 1fr}
  .process{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:32px}
  .cta-band{padding:36px 24px}
}
@media (max-width:680px){
  .hdr .btn-secondary,.hdr .btn-ghost{display:none}
  .menu-btn{display:flex}
  .form .grid2{grid-template-columns:1fr}
  .foot-nav{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .reveal{opacity:1}
  .reveal.in{animation:none}
}

/* ---- Legal pages ---------------------------------------------------------- */
.legal-page{padding:var(--space-9) 0}
.legal-prose{max-width:800px;margin:0 auto}
.legal-prose h1{margin-bottom:0}
.legal-prose h2{font-size:20px;line-height:1.3;margin:40px 0 10px;letter-spacing:-.01em}
.legal-prose h3{font-size:16px;line-height:1.4;margin:24px 0 8px}
.legal-prose p,.legal-prose li{line-height:1.7;font-size:15px}
.legal-prose ul,.legal-prose ol{margin-top:12px;padding-left:26px}
.legal-prose .toc ol{list-style:decimal;padding-left:26px}
.legal-prose li{margin-top:6px}
.legal-prose a{color:var(--accent-bright)}
.legal-prose a:hover{text-decoration:underline}
.legal-prose address{font-style:normal;margin-top:12px;line-height:1.9}

/* ---- Legal pages: Termly-exported policy on the dark brand ---------------- */
/* The exported content carries Termly's own [data-custom-class] !important
   rules (black/gray text for a white page) plus inline rgb() colors. These
   .legal-card/.legal-prose-scoped rules have higher specificity, so they win
   and recolor everything to the UmnikTech dark theme — no need to edit the
   generated content blob. */
.legal-card{max-width:840px;margin:0 auto;background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--inset-top),var(--shadow-md);padding:clamp(22px,4vw,48px)}

/* baseline: force readable text + kill white backgrounds/black borders from inline styles */
:is(.legal-card,.legal-prose) *{color:var(--fg-2)!important;background-color:transparent!important;border-color:var(--border)!important}
:is(.legal-card,.legal-prose) strong,:is(.legal-card,.legal-prose) b{color:var(--fg-1)!important;font-weight:600!important}
/* keep semantic headings bright (covers the hand-written terms page) */
:is(.legal-card,.legal-prose) :is(h1,h2,h3,h4){color:var(--fg-1)!important;font-family:var(--font-display)!important}
:is(.legal-card,.legal-prose) a,
:is(.legal-card,.legal-prose) [data-custom-class='link'],
:is(.legal-card,.legal-prose) [data-custom-class='link'] *{color:var(--accent-bright)!important;word-break:break-word}
:is(.legal-card,.legal-prose) a:hover{text-decoration:underline}

/* Termly semantic classes -> brand type */
:is(.legal-card,.legal-prose) [data-custom-class='title'],:is(.legal-card,.legal-prose) [data-custom-class='title'] *{font-family:var(--font-display)!important;font-weight:600!important;color:var(--fg-1)!important;font-size:clamp(28px,4.5vw,40px)!important;line-height:1.1!important;letter-spacing:-.02em!important}
:is(.legal-card,.legal-prose) [data-custom-class='subtitle'],:is(.legal-card,.legal-prose) [data-custom-class='subtitle'] *{font-family:var(--font-mono)!important;color:var(--fg-3)!important;font-size:13px!important;letter-spacing:.02em!important}
:is(.legal-card,.legal-prose) [data-custom-class='heading_1'],:is(.legal-card,.legal-prose) [data-custom-class='heading_1'] *{font-family:var(--font-display)!important;font-weight:600!important;color:var(--fg-1)!important;font-size:23px!important;letter-spacing:-.01em!important}
:is(.legal-card,.legal-prose) [data-custom-class='heading_2'],:is(.legal-card,.legal-prose) [data-custom-class='heading_2'] *{font-family:var(--font-display)!important;font-weight:600!important;color:var(--fg-1)!important;font-size:18px!important}
:is(.legal-card,.legal-prose) [data-custom-class='body_text'],:is(.legal-card,.legal-prose) [data-custom-class='body_text'] *{font-family:var(--font-body)!important;color:var(--fg-2)!important;font-size:15px!important;line-height:1.7!important}

/* spacing + lists + tables for the policy body */
:is(.legal-card,.legal-prose) [data-custom-class='heading_1']{display:block;margin:34px 0 10px}
:is(.legal-card,.legal-prose) [data-custom-class='heading_2']{display:block;margin:22px 0 8px}
:is(.legal-card,.legal-prose) ul,:is(.legal-card,.legal-prose) ol{padding-left:24px;margin:10px 0}
:is(.legal-card,.legal-prose) li{margin:6px 0;font-family:var(--font-body)!important}
:is(.legal-card,.legal-prose) table{width:100%!important;border-collapse:collapse!important;margin:14px 0}
:is(.legal-card,.legal-prose) td,:is(.legal-card,.legal-prose) th{border:1px solid var(--border)!important;padding:10px 12px!important;text-align:left}
/* links last + high-specificity so they beat the body_text color on nested links */
:is(.legal-card,.legal-prose) a,
:is(.legal-card,.legal-prose) [data-custom-class='link'],
:is(.legal-card,.legal-prose) [data-custom-class='link'] *,
:is(.legal-card,.legal-prose) [data-custom-class='body_text'] a,
:is(.legal-card,.legal-prose) [data-custom-class='body_text'] a *{color:var(--accent-bright)!important;word-break:break-word}
.legal-meta{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);margin-top:8px}
.legal-divider{border:none;border-top:1px solid var(--border-subtle);margin:48px 0 24px}
/* (.legal-card is styled above as a dark brand surface; the old white-card rule
   was removed so the Termly content inherits the UmnikTech theme.) */
@media (max-width:600px){.legal-card{padding:24px 18px}}
