/* =====================================================================
   Paytools — Governance solutions page (storyboard redesign)
   Shared tokens + fonts come from home.css; this file is page-specific.
   Mirrors the payroll-processing.css storyboard system with governance
   content: a two-column hero ("payroll function at a glance"), five
   numbered narrative beats (each an animated product-mock carousel + a
   customer quote), a dark final CTA and an "Other solutions" grid.
   --accent / --lav remain the page's theming knobs.
   ===================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400..800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap");

:root {
  --accent: #5A45DE;
  --lav: #CEC2EF;
  --paper: #F1E8E2;
  --paper-alt: #FCFAF8;
  --ink: #1A1613;
  --ink-2: #2A2420;
  --ink-soft: #5A514A;
  --ink-mute: #8A8078;
  --border: #E6DBD2;
  --border-card: #ECE2DA;
  --green: #3E9A6D;
  --red: #B4452F;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: 'Aeonik', 'General Sans', 'Hanken Grotesk', -apple-system, sans-serif;
  font-size: 18.4px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { font-family: 'Aeonik', 'General Sans', 'Hanken Grotesk', sans-serif; cursor: pointer; }

@keyframes ptrise  { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes ptfloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
@keyframes ptpop   { from{opacity:0;transform:translateY(14px) scale(.96)} to{opacity:1;transform:translateY(0) scale(1)} }
@keyframes ptbadge { 0%,100%{box-shadow:0 0 0 0 rgba(90,69,222,0)} 50%{box-shadow:0 0 0 5px rgba(90,69,222,.16)} }

/* ============ NAVBAR (reused from home) ============ */
.pt-nav { position:sticky; top:0; z-index:50; background:rgba(241,232,226,.82); backdrop-filter:blur(12px); border-bottom:1px solid #E2D6CD; transition:box-shadow .25s,background .25s; }
.pt-nav--scrolled { box-shadow:0 8px 24px -14px rgba(26,22,19,.4); background:rgba(241,232,226,.96); }
.pt-nav-inner { max-width:1180px; margin:0 auto; padding:16px clamp(20px,5vw,48px); display:flex; align-items:center; justify-content:space-between; gap:24px; }
.pt-nav-links { display:flex; align-items:center; gap:36px; list-style:none; margin:0; padding:0; font-size:17.8px; font-weight:500; color:var(--ink-2); }
.pt-nav-item { position:relative; }
.pt-nav-item > span { cursor:pointer; }
.pt-nav-item > span:hover, .pt-nav-item > a:hover { color:var(--accent); }
.pt-nav-item--active > a, .pt-nav-item--active > span { color:var(--accent); }
.pt-nav-caret { margin-left:3px; font-size:10.8px; opacity:.6; }
.pt-nav-cta { font-size:17.3px; font-weight:500; color:var(--paper); background:var(--ink); border:none; padding:11px 22px; border-radius:999px; transition:background .18s,transform .18s,box-shadow .2s; }
.pt-nav-cta:hover { background:#2E2823; transform:translateY(-1px); box-shadow:0 10px 22px -10px rgba(26,22,19,.45); }
.pt-dropdown { position:absolute; top:calc(100% + 12px); left:0; background:var(--paper-alt); border:1px solid var(--border); border-radius:12px; padding:8px; min-width:200px; box-shadow:0 16px 40px -16px rgba(26,22,19,.2); list-style:none; margin:0; z-index:100; }
.pt-dropdown li a { display:block; padding:9px 14px; border-radius:8px; font-size:15.7px; color:var(--ink-2); transition:background .15s; }
.pt-dropdown li a:hover { background:var(--paper); }

/* ============ HERO ============ */
.gv-hero { padding:clamp(40px,5vw,72px) 0; }
.gv-hero-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); display:grid; grid-template-columns:1fr 1.08fr; gap:clamp(36px,5vw,72px); align-items:center; }
.gv-hero-eyebrow { display:inline-flex; align-items:center; gap:9px; font-size:16px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:22px; }
.gv-hero-h1 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(36.7px,5vw,62.6px); line-height:1.03; letter-spacing:-.025em; margin:0; }
.gv-hero-sub { font-size:clamp(16.44px,1.81vw,18.43px); line-height:1.55; color:var(--ink-soft); margin:24px 0 0; max-width:46ch; }

/* Hero "at a glance" mock is fully self-contained in lib/mocks/gov/HeroMock.jsx */

/* ============ STORYBOARD ============ */
.gv-storyboard { background:var(--paper-alt); padding:clamp(64px,8vw,112px) 0; }
.gv-sb-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); }
.gv-sb-intro { max-width:720px; margin-bottom:clamp(44px,5.5vw,68px); }
.gv-sb-eyebrow { font-size:16px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; }
.gv-sb-h2 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(30.2px,4.1vw,49.7px); line-height:1.04; letter-spacing:-.02em; margin:0 0 18px; }
.gv-sb-lead { font-size:18.4px; line-height:1.6; color:#6B6259; margin:0; max-width:60ch; }

.gv-sb-steps { display:grid; grid-template-columns:56px 1fr; gap:clamp(16px,2.6vw,32px); max-width:85%; }
.gv-sb-spine { display:flex; flex-direction:column; align-items:center; }
.gv-sb-num { flex:none; width:46px; height:46px; border-radius:50%; background:var(--accent); color:var(--paper); display:flex; align-items:center; justify-content:center; font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:18.4px; letter-spacing:-.01em; box-shadow:0 12px 24px -14px var(--accent); }
.gv-sb-line { flex:1; width:2px; background:var(--border); margin-top:6px; }
.gv-sb-step { padding-bottom:clamp(64px,7.5vw,108px); display:flex; flex-direction:column; gap:clamp(22px,3vw,34px); }
.gv-sb-step--last { padding-bottom:0; }
.gv-sb-day { font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.gv-sb-step-h3 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(23.8px,2.7vw,32.4px); line-height:1.08; letter-spacing:-.02em; margin:0 0 14px; color:var(--ink); }
.gv-sb-step-p { font-size:17.3px; line-height:1.6; color:var(--ink-soft); margin:0; }

/* Carousel */
.gv-carousel { position:relative; width:100%; border-radius:18px; box-shadow:0 24px 50px -40px rgba(26,22,19,.4); }
.gv-slide { position:absolute; inset:0; border-radius:18px; overflow:hidden; border:1px solid #E2D6CD; background:#FCFAF8; display:flex; flex-direction:column; opacity:0; transition:opacity .7s ease; }
.gv-slide--active { opacity:1; }
.gv-dots { position:absolute; bottom:12px; left:0; right:0; display:flex; justify-content:center; gap:7px; z-index:2; }
.gv-dot { width:6px; height:6px; border-radius:50%; background:var(--accent); opacity:.3; transition:opacity .4s ease; cursor:pointer; border:none; padding:0; }
.gv-dot--active { opacity:1; }

/* Step callout quote */
.gv-callout { margin-top:24px; border-left:3px solid var(--accent); padding-left:18px; max-width:60ch; }
.gv-callout-quote { margin:0 0 13px; font-size:17.3px; font-style:italic; line-height:1.5; color:#3F362E; }
.gv-callout-meta { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.gv-callout-avatar { flex:none; width:30px; height:30px; border-radius:50%; background:var(--lav); color:#3A2E78; display:flex; align-items:center; justify-content:center; font-size:11.9px; font-weight:700; }
.gv-callout-attr { font-size:13.5px; color:var(--ink-mute); }
.gv-callout-attr strong { font-weight:700; color:#3F362E; }
.gv-callout-stars { display:flex; gap:3px; flex:none; margin-left:2px; }

/* ============ FINAL CTA ============ */
.gv-final { background:#15120F; color:#F1E8E2; padding:clamp(48px,5.5vw,80px) 0; position:relative; overflow:hidden; }
.gv-final-glow { position:absolute; left:-100px; bottom:-140px; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle,rgba(90,69,222,.22),transparent 70%); pointer-events:none; }
.gv-final-inner { max-width:900px; margin:0 auto; padding:0 clamp(20px,5vw,48px); text-align:center; position:relative; }
.gv-final-h2 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(32.4px,4.3vw,56.2px); line-height:1.04; letter-spacing:-.025em; margin:0 0 18px; }
.gv-final-sub { font-size:clamp(17.3px,2.1vw,21.6px); line-height:1.55; color:#C7BEB6; margin:0 auto 34px; max-width:50ch; }
.gv-final-actions { display:flex; flex-direction:column; gap:18px; justify-content:center; align-items:center; }
.gv-btn-final { font-size:16.7px; font-weight:500; color:#F1E8E2; background:var(--accent); border:none; padding:16px 32px; border-radius:999px; display:inline-flex; align-items:center; gap:9px; transition:transform .18s,background .18s; }
.gv-btn-final:hover { background:#4A37C8; transform:translateY(-2px); }

/* ============ OTHER SOLUTIONS ============ */
.gv-other { background:var(--paper); padding:clamp(64px,8vw,104px) 0; }
.gv-other-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); }
.gv-other-hdr { margin-bottom:clamp(32px,4vw,48px); }
.gv-other-eyebrow { font-size:16px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.gv-other-h2 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(28.1px,3.7vw,45.4px); line-height:1.05; letter-spacing:-.02em; margin:0; }
.gv-other-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,28px); align-items:stretch; }
.gv-other-card { display:flex; flex-direction:column; text-decoration:none; background:var(--paper-alt); border:1px solid var(--border); border-radius:22px; padding:clamp(28px,3vw,40px); transition:transform .2s,box-shadow .2s,border-color .2s; }
a.gv-other-card:hover { transform:translateY(-3px); box-shadow:0 30px 60px -42px rgba(26,22,19,.45); border-color:#D8CCC2; }
.gv-other-icon { width:56px; height:56px; border-radius:16px; background:var(--lav); color:#3A2E78; display:flex; align-items:center; justify-content:center; margin-bottom:22px; flex:none; }
.gv-other-tag { font-size:13px; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.gv-other-card-h3 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(23.8px,2.6vw,30.2px); line-height:1.1; letter-spacing:-.02em; margin:0 0 14px; color:var(--ink); }
.gv-other-card-p { font-size:17.3px; line-height:1.6; color:var(--ink-soft); margin:0; }
.gv-other-card-p + .gv-other-card-p { margin-top:14px; }
.gv-other-card-p a { color:var(--accent); font-weight:600; text-decoration:none; transition:color .15s ease; }
.gv-other-card-p a:hover { color:#7A67E8; }
.gv-other-link { display:inline-flex; align-items:center; gap:8px; margin-top:24px; font-size:16.2px; font-weight:600; color:var(--accent); }

/* ============ FOOTER (same as home) ============ */
.pt-footer { background:#15120F; color:#C7BEB6; padding:clamp(48px,6vw,80px) 0 0; }
.pt-footer-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:clamp(24px,3vw,48px); }
.pt-footer-tagline { font-size:15.1px; line-height:1.6; color:#8A8078; margin:16px 0 8px; max-width:28ch; }
.pt-footer-col-h { font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#6B6259; margin-bottom:16px; }
.pt-footer-col ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.pt-footer-col ul li a { font-size:15.1px; color:#8A8078; transition:color .15s; }
.pt-footer-col ul li a:hover { color:#C7BEB6; }
.pt-footer-bottom { max-width:1180px; margin:0 auto; padding:24px clamp(20px,5vw,48px); display:flex; align-items:center; justify-content:space-between; border-top:1px solid #2A2420; margin-top:clamp(40px,5vw,64px); font-size:14px; color:#5A514A; }
.pt-footer-bottom a { color:#5A514A; }
.pt-footer-bottom a:hover { color:#8A8078; }
.pt-footer-socials { display:flex; gap:10px; margin-top:20px; }
.pt-social-badge { display:flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:8px; background:#2A2420; color:#8A8078; transition:background .15s,color .15s; }
.pt-social-badge:hover { background:#3A3430; color:#C7BEB6; }

/* ============ RESPONSIVE ============ */
@media (max-width: 900px) {
  .gv-hero-inner { grid-template-columns: 1fr; }
  .gv-other-grid { grid-template-columns: 1fr; }
  .gv-sb-steps { max-width: 100%; }
  .pt-footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .pt-footer-inner { grid-template-columns: 1fr; }
}
