/*
Theme Name: GetItDone
Theme URI: https://getitdone.ng
Author: GetItDone.ng
Author URI: https://getitdone.ng
Description: Custom marketing + product theme for GetItDone.ng - Nigerian vehicle document renewal & registration. Mirrors the in-app design system (green/cream, Fraunces + DM Sans) and wraps the [getitdone_vehicle_docs] app.
Version: 1.4.4
License: GPL-2.0+
Text Domain: getitdone
*/

/* ============================================================
   THEME-LOCAL VARS  (all design tokens come from gid-tokens.css)
   ============================================================ */
:root{
  --maxw:1180px;
  --header-h:72px;
  --gold:#f1b434; /* real gold accent (tokens map --gold->teal; override for buttons/eyebrows) */
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--white);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none}
a:hover{color:var(--green-mid)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.15;color:var(--ink);margin:0 0 .5em}
p{margin:0 0 1em}
ul{margin:0 0 1em;padding-left:1.2em}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px 14px;z-index:1000;border-radius:8px}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.container-narrow{max-width:820px;margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section-sm{padding:48px 0}
.section-mist{background:var(--mist)}
.section-tint{background:var(--green-tint)}
.section-dark{background:var(--teal-700);color:#cfe7dd}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.section-dark .eyebrow{color:var(--gold)}
.section-head{max-width:680px;margin:0 auto 44px;text-align:center}
.section-head h2{font-size:clamp(26px,4.2vw,40px)}
.section-head p{color:var(--text-muted);font-size:17px}
.section-dark .section-head p{color:#aeccbb}
.text-center{text-align:center}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:700;font-size:15px;
  padding:13px 24px;border-radius:var(--radius-pill);border:2px solid transparent;cursor:pointer;transition:all .18s;text-align:center;line-height:1}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green);box-shadow:var(--shadow-brand-sm)}
.btn-primary:hover{background:var(--green-mid);border-color:var(--green-mid);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-brand)}
.btn-gold{background:var(--gold);color:#3a2a08;border-color:var(--gold)}
.btn-gold:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:var(--shadow);color:#3a2a08}
.btn-outline{background:transparent;color:var(--green);border-color:var(--border)}
.btn-outline:hover{border-color:var(--green);background:var(--green-light);color:var(--green)}
.btn-ghost-light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.3)}
.btn-ghost-light:hover{background:rgba(255,255,255,.22);color:#fff}
.btn-lg{padding:16px 30px;font-size:16px}
.btn-block{display:flex;width:100%;justify-content:center}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:20px;color:var(--ink);text-decoration:none}
.brand-mark{height:38px;width:auto}
.brand-word{font-family:var(--font-display);font-weight:800;font-size:19px;color:var(--text-strong);line-height:1;letter-spacing:-.01em}
.brand-word b{color:var(--brand);font-weight:900}
.brand--light .brand-word{color:#fff}
.brand img,.brand svg{height:34px;width:auto}
.nav{display:flex;align-items:center;gap:6px}
.nav a{padding:9px 14px;border-radius:var(--radius-pill);font-size:15px;font-weight:500;color:var(--ink);transition:all .15s}
.nav a:hover,.nav a.active{background:var(--green-light);color:var(--green)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* Nav dropdown group */
.nav-group{position:relative}
.nav-group__btn{display:flex;align-items:center;gap:5px;padding:9px 14px;border-radius:var(--radius-pill);font-size:15px;font-weight:500;color:var(--ink);background:none;border:0;cursor:pointer;font-family:inherit;transition:all .15s}
.nav-group:hover .nav-group__btn,.nav-group.is-active .nav-group__btn,.nav-group__btn[aria-expanded="true"]{background:var(--green-light);color:var(--green)}
.nav-group__caret{transition:transform .2s}
.nav-group:hover .nav-group__caret,.nav-group__btn[aria-expanded="true"] .nav-group__caret{transform:rotate(180deg)}
.nav-sub{position:absolute;top:100%;left:0;min-width:240px;padding-top:10px;display:none;z-index:60}
.nav-sub__inner{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:8px}
.nav-group:hover .nav-sub,.nav-group:focus-within .nav-sub,.nav-group__btn[aria-expanded="true"]+.nav-sub{display:block}
.nav-sub__link{display:block;padding:11px 14px;border-radius:10px;font-size:15px;font-weight:500;color:var(--ink);transition:all .15s}
.nav-sub__link:hover,.nav-sub__link.active{background:var(--green-light);color:var(--green)}

@media(max-width:980px){
  .nav,.nav-cta .btn-tel{display:none}
  .nav-toggle{display:flex}
  .nav.open{display:flex;position:absolute;top:var(--header-h);left:0;right:0;flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--border);padding:14px 20px;gap:2px;box-shadow:var(--shadow)}
  .nav.open a{padding:13px 14px;border-radius:12px}
  .nav.open .nav-group{position:static}
  .nav.open .nav-group__btn{width:100%;justify-content:space-between;padding:13px 14px;border-radius:12px;font-size:15px}
  .nav.open .nav-sub{position:static;padding-top:0;min-width:0}
  .nav.open .nav-sub__inner{border:0;box-shadow:none;padding:0 0 4px 10px}
  .nav.open .nav-sub__link{padding:11px 14px}
}
/* On phones the bottom sticky bar carries the CTA - keep the header tidy */
@media(max-width:680px){
  .nav-cta .btn-primary{display:none}
}
.btn-acct{font-weight:700}
.cta-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;margin-left:4px;border-radius:999px;font-size:12px;font-weight:800;line-height:1;color:#fff;vertical-align:middle}
.cta-badge--warn{background:#ef8a17}
.cta-badge--danger{background:#e23b3b}
.card-date{display:inline-block;background:var(--green-light);color:var(--green);font-size:12px;font-weight:700;letter-spacing:.02em;padding:4px 11px;border-radius:999px;margin-bottom:10px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:var(--gradient-brand-soft);color:var(--text-body);overflow:hidden}
.hero .container{position:relative;z-index:1;padding-top:84px;padding-bottom:84px;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{color:var(--text-strong);font-size:clamp(34px,5.2vw,58px);line-height:1.05;letter-spacing:-.5px}
.hero h1 .accent{color:var(--teal-600)}
.hero-sub{font-size:clamp(17px,2.2vw,20px);color:var(--text-body);max-width:520px;margin-bottom:28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{display:flex;gap:26px;margin-top:36px;flex-wrap:wrap}
.hero-trust .t{font-size:14px;color:var(--text-muted);display:flex;align-items:center;gap:8px}
.hero-trust .t b{color:var(--text-strong);font-size:22px;font-family:var(--font-display);font-weight:800;display:block;line-height:1}
.hero-card{background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow-lg)}
.hero-card h3{color:var(--text-strong);font-size:18px;margin-bottom:16px}
.hero-step{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--border-subtle)}
.hero-step:last-child{border-bottom:0}
.hero-step .n{flex:0 0 30px;height:30px;border-radius:50%;background:var(--green);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:14px}
.hero-step .tx b{color:var(--text-strong);display:block;font-size:15px}
.hero-step .tx span{color:var(--text-muted);font-size:13px}

@media(max-width:860px){
  .hero .container{grid-template-columns:1fr;gap:36px;padding-top:56px;padding-bottom:64px}
  .hero-card{order:2}
}

/* ============================================================
   GENERIC PAGE HEADER (non-home)
   ============================================================ */
.page-hero{background:var(--gradient-brand-soft);color:var(--text-body);padding:64px 0 56px;text-align:center}
.page-hero h1{color:var(--text-strong);font-size:clamp(30px,5vw,46px)}
.page-hero p{color:var(--text-body);font-size:18px;max-width:640px;margin:0 auto}
.breadcrumbs{font-size:13px;color:var(--text-muted);margin-bottom:8px}
.breadcrumbs a{color:var(--text-muted)}

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.ucard{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:26px;transition:all .18s;height:100%}
.ucard:hover{border-color:var(--green-mid);box-shadow:var(--shadow);transform:translateY(-3px)}
.ucard .ic{width:50px;height:50px;border-radius:14px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px;color:var(--green)}
.ucard h3{font-size:19px;margin-bottom:8px}
.ucard p{color:var(--text-muted);font-size:15px;margin-bottom:14px}
.ucard .more{font-weight:600;font-size:14px;color:var(--green);display:inline-flex;gap:6px;align-items:center}
a.ucard{color:inherit;display:block}

/* steps (how it works) */
.steps{counter-reset:step}
.step{position:relative;padding-left:0}
.step .num{width:46px;height:46px;border-radius:50%;background:var(--green);color:#fff;font-family:var(--serif);font-size:20px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.step h3{font-size:18px;margin-bottom:6px}
.step p{color:var(--text-muted);font-size:15px}

/* feature list */
.feature{display:flex;gap:14px;align-items:flex-start}
.feature .ic{flex:0 0 44px;height:44px;border-radius:12px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--green)}
.feature h3{font-size:17px;margin-bottom:4px}
.feature p{color:var(--text-muted);font-size:14px;margin:0}

/* ============================================================
   PRICING TABLE
   ============================================================ */
.ptable{width:100%;border-collapse:collapse;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.ptable th,.ptable td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:15px}
.ptable th{background:var(--green-light);font-family:var(--serif);font-weight:600;color:var(--green-dark)}
.ptable tr:last-child td{border-bottom:0}
.ptable td.price{font-weight:700;color:var(--green);white-space:nowrap;font-family:var(--font-mono)}
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg)}
.pill{display:inline-block;background:var(--gold-light);color:var(--gold);font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--radius-pill)}

/* fee callout */
.fee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:700px){.fee-grid{grid-template-columns:1fr}}
.fee-box{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-align:center}
.fee-box .amt{font-family:var(--serif);font-size:32px;color:var(--green);font-weight:600}
.fee-box .lbl{color:var(--text-muted);font-size:14px}

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq{max-width:760px;margin:0 auto}
.faq-item{border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:12px;background:#fff;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:18px 20px;font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-q .ic{flex:0 0 auto;transition:transform .2s;color:var(--green)}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;padding:0 20px}
.faq-item.open .faq-a{max-height:500px;padding:0 20px 18px}
.faq-a p{color:var(--text-muted);margin:0;font-size:15px}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quote{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:26px}
.quote .stars{color:var(--gold);margin-bottom:10px;letter-spacing:2px}
.quote p{font-size:16px;color:var(--ink)}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.quote .av{width:42px;height:42px;border-radius:50%;background:var(--green-light);color:var(--green);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--serif)}
.quote .who b{display:block;font-size:14px}
.quote .who span{font-size:13px;color:var(--text-muted)}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{background:var(--gradient-brand);border-radius:var(--radius-lg);padding:54px 40px;text-align:center;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-brand)}
.cta-banner::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(255,255,255,.18),transparent 50%);pointer-events:none}
.cta-banner h2{color:#fff;font-size:clamp(26px,4vw,38px);position:relative}
.cta-banner p{color:#d6ecdf;font-size:18px;max-width:520px;margin:0 auto 26px;position:relative}
.cta-banner .btn{position:relative;z-index:1}

/* ============================================================
   PROSE (legal / blog / generic page content)
   ============================================================ */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:26px;margin-top:1.6em}
.prose h3{font-size:20px;margin-top:1.4em}
.prose p,.prose li{color:#33493b;font-size:16px}
.prose a{text-decoration:underline}
.prose hr{border:0;border-top:1px solid var(--border);margin:2em 0}
.muted{color:var(--text-muted)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--green-dark);color:#bcd0c2;padding:64px 0 28px;font-size:15px}
.site-footer a{color:#bcd0c2}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
@media(max-width:840px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{color:#fff;font-size:15px;letter-spacing:.5px;margin-bottom:16px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:10px}
.footer-brand .brand{color:#fff;margin-bottom:14px}
.footer-brand p{color:#9bb6a6;max-width:280px;font-size:14px}
.footer-contact div{margin-bottom:10px;display:flex;gap:8px;align-items:flex-start}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:#9bb6a6}
.footer-bottom a{color:#9bb6a6}
.socials{display:flex;gap:10px;margin-top:16px}
.socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff}
.socials a:hover{background:var(--green)}

/* ============================================================
   WHATSAPP FLOAT + MOBILE STICKY CTA
   ============================================================ */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:90;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.25);transition:transform .15s}
.wa-float:hover{transform:scale(1.07)}
.wa-float svg{width:30px;height:30px}
.mobile-cta{display:none}
@media(max-width:680px){
  .mobile-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;background:#fff;border-top:1px solid var(--border);padding:10px 14px;gap:10px;box-shadow:0 -4px 20px rgba(0,0,0,.08)}
  .mobile-cta .btn{flex:1}
  .wa-float{bottom:74px}
  body{padding-bottom:68px}
}

/* ============================================================
   APP PAGE WRAPPER (welcome / pay) - keep app full-bleed, no double chrome
   ============================================================ */
.app-page-intro{background:var(--surface-page);padding:30px 0 10px;text-align:center}
.app-page-intro h1{font-size:clamp(24px,4vw,34px);margin-bottom:6px;color:var(--text-strong)}
.app-page-intro p{color:var(--text-muted);max-width:560px;margin:0 auto}
.app-mount{background:var(--surface-page);min-height:60vh;padding-bottom:40px}

/* ============================================================
   UTILITIES
   ============================================================ */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.flex{display:flex}.gap{gap:14px}.wrap{flex-wrap:wrap}.center{align-items:center}.justify{justify-content:center}
.lead{font-size:18px;color:var(--text-muted)}
.mono{font-family:var(--font-mono)}
.gid-ic{display:inline-block;vertical-align:middle}

/* ============================================================
   HERO CAROUSEL (two slides, auto-rotating)
   ============================================================ */
.hero-carousel{position:relative;overflow:hidden}
.hero-track{display:flex;transition:transform .7s var(--ease-out,cubic-bezier(.16,1,.3,1))}
.hero-slide{min-width:100%;flex:0 0 100%}
.hero-dots{position:absolute;left:0;right:0;bottom:18px;display:flex;justify-content:center;gap:8px;z-index:2}
.hero-dots button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(24,32,28,.2);cursor:pointer;padding:0;transition:all .25s}
.hero-dots button.is-active{background:var(--brand);width:26px;border-radius:6px}
.hero-rating{display:flex;align-items:center;gap:10px;margin-top:28px;font-size:14px;color:var(--text-body)}
.hero-rating .stars{color:var(--gold);letter-spacing:1px;font-size:15px}
.hero-rating b{color:var(--text-strong)}

/* document card (slide 1 panel) */
.hero-panel{display:flex;justify-content:center}
.doccard{width:100%;max-width:380px;background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:24px}
.doccard-top{display:flex;align-items:center;justify-content:space-between}
.doccard-title{font-family:var(--font-display);font-weight:800;color:var(--text-strong);font-size:18px}
.doccard-badge{display:inline-flex;align-items:center;gap:6px;background:var(--success-50);color:var(--green-700);font-size:12px;font-weight:700;padding:5px 12px;border-radius:var(--radius-pill)}
.doccard-badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.doccard-plate{font-family:var(--font-mono);font-weight:700;font-size:clamp(26px,4vw,34px);color:var(--text-strong);letter-spacing:2px;margin:16px 0;padding:16px;background:var(--surface-sunken);border-radius:var(--radius-md);text-align:center}
.doccard-rows{display:flex;flex-direction:column;gap:10px}
.doccard-rows>div{display:flex;justify-content:space-between;gap:16px;font-size:14px}
.doccard-rows span{color:var(--text-muted)}
.doccard-rows b{color:var(--text-strong);font-family:var(--font-mono)}
.doccard-foot{display:flex;align-items:center;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle);color:var(--brand);font-weight:700;font-size:14px}
.doccard-foot .gid-ic{flex:0 0 auto}
