/* =====================================================================
   Paytools — Payroll Processing solutions page
   Shared tokens + fonts come from home.css; this file is page-specific.
   ===================================================================== */

@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 ptsheen { 0%{left:-55%} 14%{left:135%} 100%{left:135%} }
@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-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; }
.pt-nav-cta:hover { background:#2E2823; transform:translateY(-1px); }
.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 ============ */
.proc-hero { padding:clamp(48px,6vw,88px) 0 clamp(40px,5vw,72px); }
.proc-hero-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); display:grid; grid-template-columns:.82fr 1.3fr; gap:clamp(28px,4vw,56px); align-items:center; }
.proc-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; }
.proc-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; }
.proc-hero-sub { font-size:clamp(15.39px,1.81vw,18.43px); line-height:1.55; color:var(--ink-soft); margin:24px 0 0; max-width:46ch; }
.proc-hero-btns { display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.proc-btn-primary { font-size:16.2px; font-weight:500; color:var(--paper); background:var(--accent); border:none; padding:15px 28px; border-radius:999px; transition:transform .18s,background-color .18s; }
.proc-btn-primary:hover { background:#4A37C8; transform:translateY(-2px); }
.proc-btn-ghost { font-size:16.2px; font-weight:500; color:var(--ink); background:transparent; border:1.5px solid #C9BBB0; padding:15px 28px; border-radius:999px; transition:transform .18s; }
.proc-btn-ghost:hover { transform:translateY(-2px); }

/* Hero pay-cycle mock is fully self-contained in lib/mocks/ProcHeroMock.jsx */

/* ============ STORYBOARD ============ */
.proc-storyboard { background:var(--paper-alt); padding:clamp(64px,8vw,112px) 0; }
.proc-sb-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); }
.proc-sb-intro { max-width:700px; margin-bottom:clamp(44px,5.5vw,68px); }
.proc-sb-eyebrow { font-size:16px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; }
.proc-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; }
.proc-sb-lead { font-size:18.4px; line-height:1.6; color:#6B6259; margin:0; max-width:56ch; }

.proc-sb-steps { display:grid; grid-template-columns:56px 1fr; gap:clamp(16px,2.6vw,32px); max-width:85%; }
.proc-sb-spine { display:flex; flex-direction:column; align-items:center; }
.proc-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); }
.proc-sb-line { flex:1; width:2px; background:var(--border); margin-top:6px; }
.proc-sb-step { padding-bottom:clamp(56px,6.5vw,96px); display:flex; flex-direction:column; gap:clamp(22px,3vw,34px); }
.proc-sb-day { font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.proc-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); }
.proc-sb-step-p { font-size:17.3px; line-height:1.6; color:var(--ink-soft); margin:0; }

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

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

/* ============ FINAL CTA ============ */
.proc-final { background:#15120F; color:#F1E8E2; padding:clamp(48px,5.5vw,80px) 0; position:relative; overflow:hidden; }
.proc-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; }
.proc-final-inner { max-width:900px; margin:0 auto; padding:0 clamp(20px,5vw,48px); text-align:center; position:relative; }
.proc-final-h2 { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(30.78px,4.09vw,53.39px); line-height:1.04; letter-spacing:-.025em; margin:0 0 18px; }
.proc-final-sub { font-size:clamp(17.3px,2.1vw,21.6px); line-height:1.55; color:#C7BEB6; margin:0 auto 34px; max-width:48ch; }
.proc-final-actions { display:flex; flex-direction:column; gap:18px; justify-content:center; align-items:center; }
.proc-btn-final { font-size:16.7px; font-weight:500; color:#F1E8E2; background:var(--accent); border:none; padding:16px 32px; border-radius:999px; transition:transform .18s,background .18s; }
.proc-btn-final:hover { background:#4A37C8; transform:translateY(-2px); }
.proc-self-guided { font-size:16.2px; font-weight:600; color:#C7BEB6; cursor:pointer; background:none; border:none; transition:color .18s; padding:0; }
.proc-self-guided:hover { color:#B6A9F5; }

/* ============ OTHER SOLUTIONS ============ */
.proc-other { background:var(--paper); padding:clamp(64px,8vw,104px) 0; }
.proc-other-inner { max-width:1180px; margin:0 auto; padding:0 clamp(20px,5vw,48px); }
.proc-other-hdr { margin-bottom:clamp(32px,4vw,48px); }
.proc-other-eyebrow { font-size:16px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.proc-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; }
.proc-other-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,28px); }
.proc-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.proc-other-card:hover { transform:translateY(-3px); box-shadow:0 30px 60px -42px rgba(26,22,19,.45); border-color:#D8CCC2; }
.proc-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; }
.proc-other-tag { font-size:13px; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.proc-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); }
.proc-other-card-p { font-size:17.3px; line-height:1.6; color:var(--ink-soft); margin:0; }
.proc-other-card-p + .proc-other-card-p { margin-top:14px; }
.proc-other-card-p a { color:var(--accent); font-weight:600; text-decoration:none; transition:color .15s ease; }
.proc-other-card-p a:hover { color:#7A67E8; }
.proc-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) {
  .proc-hero-inner { grid-template-columns: 1fr; }
  .proc-other-grid { grid-template-columns: 1fr; }
  .proc-sb-steps { max-width: 100%; }
  .pt-footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .pt-footer-inner { grid-template-columns: 1fr; }
}
