/*
Theme Name: OakSpire Financial Services
Description: OakSpire Financial Services provides tax preparation, accounting, and financial planning for Austin, TX individuals and businesses, with clear, proactive guidance.
Author: Bespoke Studio
Version: 1.0.0
*/
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --p:#1c3a2e; --s:#b5912f; --a:#2f6b4f; --ink:#0c1a14;
  --bg:#faf9f5; --fg:#1f2a24; --muted:#5b665e; --card:#ffffff; --line:#e7e3d9;
  --p-rgb:28,58,46; --s-rgb:181,145,47; --a-rgb:47,107,79;
  --sdark:#947626; --slight:#ceb777;
  --radius:4px; --btn:4px; --hs:1.16;
  --disp:'Cormorant Garamond', Georgia, serif; --body:'Inter', sans-serif;
  --tint:rgba(28,58,46,.035); --over:rgba(28,58,46,.05);
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--body);color:var(--fg);background:var(--bg);line-height:1.7;font-size:17px}
h1,h2,h3,h4{font-family:var(--disp);line-height:1.08;font-weight:700;letter-spacing:-0.02em;color:var(--fg)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{padding:96px 28px;position:relative}
.tintbg{background:var(--tint)}
.eyebrow{display:inline-block;font-family:var(--body);font-weight:700;font-size:12.5px;letter-spacing:3px;text-transform:uppercase;color:var(--s);margin-bottom:18px}
.lead{font-size:19px;color:var(--muted);font-weight:300;line-height:1.85}
.center{text-align:center}
.shead{max-width:760px;margin:0 auto 64px}
.shead.center{text-align:center}
.shead h2{font-size:calc(40px*var(--hs));margin-bottom:18px}
.shead p{font-size:18px;color:var(--muted);font-weight:300;margin-top:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--body);font-weight:600;font-size:15px;
  padding:15px 30px;border-radius:var(--btn);border:2px solid transparent;cursor:pointer;transition:.25s;letter-spacing:.2px}
.btn-primary{background:var(--s);color:#fff;border-color:var(--s)}
.btn-primary:hover{background:var(--sdark);border-color:var(--sdark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--s);color:var(--s)}
.btn-on-dark{background:#fff;color:var(--p);border-color:#fff}
.btn-on-dark:hover{transform:translateY(-2px);opacity:.92}

/* header / nav */
header{position:sticky;top:0;z-index:100;background:rgba(250,249,245,.86);backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav{max-width:var(--maxw);margin:0 auto;padding:16px 28px;display:flex;align-items:center;gap:30px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--disp);font-weight:700;font-size:21px;color:#1f2a24}
.brand small{display:block;font-family:var(--body);font-weight:600;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-top:2px}
.brand-mark{flex-shrink:0}
nav.links{display:flex;gap:28px;margin-left:auto}
nav.links a{font-family:var(--body);font-weight:500;font-size:15px;color:#1f2a24;position:relative;padding:6px 0}
nav.links a:hover{color:var(--s)}
nav.links a.active{color:var(--s)}
header[data-nav="underline"] nav.links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--s);transition:.25s}
header[data-nav="underline"] nav.links a:hover::after{width:100%}
header[data-nav="center"] .nav{justify-content:center}
header[data-nav="center"] .brand{position:absolute;left:28px}
.nav-cta{margin-left:8px}
header[data-nav="default"] nav.links,header[data-nav="underline"] nav.links{margin-left:auto;margin-right:0}
header[data-nav="pill"] nav.links{margin-left:auto}
.menu-btn{display:none;margin-left:auto;background:var(--s);color:#fff;border:0;width:46px;height:46px;border-radius:calc(var(--btn));font-size:20px;cursor:pointer}

/* hero: centered */
.h-centered{padding:120px 28px 90px;text-align:center}
.h-centered h1{font-size:calc(58px*var(--hs));max-width:14ch;margin:0 auto 22px}
.h-centered .lead{max-width:60ch;margin:0 auto 34px}
.h-centered .hero-img{margin-top:64px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 80px rgba(var(--p-rgb),.18)}
.h-centered .hero-img img{width:100%;height:460px;object-fit:cover}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* hero: split */
.h-split{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;padding:96px 28px}
.h-split.rev{grid-template-columns:.95fr 1.05fr}
.h-split.rev .h-txt{order:2}
.h-split h1{font-size:calc(52px*var(--hs));margin-bottom:22px}
.h-split .hero-actions{justify-content:flex-start;margin-top:30px}
.h-frame{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 80px rgba(var(--p-rgb),.22)}
.h-frame img{width:100%;height:540px;object-fit:cover}
.h-badge{position:absolute;left:22px;bottom:22px;background:var(--card);color:var(--fg);border-radius:calc(var(--radius)*.7);padding:16px 20px;box-shadow:0 16px 40px rgba(0,0,0,.18);display:flex;gap:14px;align-items:center}
.h-badge .b-num{font-family:var(--disp);font-size:30px;color:var(--s);line-height:1}
.h-badge .b-l{font-size:12.5px;color:var(--muted)}
.mini-list{list-style:none;margin-top:26px;display:grid;gap:12px}
.mini-list li{display:flex;gap:12px;align-items:center;font-size:16px}
.mini-list .mk{width:22px;height:22px;border-radius:50%;border:2px solid var(--s);flex-shrink:0;position:relative}
.mini-list .mk::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--s)}

/* hero: fullbleed */
.h-full{min-height:88vh;display:flex;align-items:flex-end;color:#fff;position:relative;padding:0}
.h-full .bgimg{position:absolute;inset:0;z-index:0}
.h-full .bgimg img{width:100%;height:100%;object-fit:cover}
.h-full::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(var(--p-rgb),.2) 0%,rgba(var(--p-rgb),.85) 100%);z-index:1}
.h-full .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 28px 90px}
.h-full h1{color:#fff;font-size:calc(70px*var(--hs));max-width:16ch;margin-bottom:22px}
.h-full .lead{color:rgba(255,255,255,.85);max-width:54ch;margin-bottom:30px}
.h-full .eyebrow{color:var(--slight)}
.h-strip{position:relative;z-index:2;background:var(--p);color:#fff;display:grid;grid-template-columns:repeat(4,1fr)}
.h-strip div{padding:30px;border-right:1px solid rgba(255,255,255,.12)}
.h-strip .n{font-family:var(--disp);font-size:34px;color:var(--slight)}
.h-strip .l{font-size:13px;opacity:.8;margin-top:4px}

/* hero: blob */
.h-blob{position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:110px 28px}
.h-blob .blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:0}
.h-blob .blob.b1{width:420px;height:420px;background:var(--s);top:-120px;right:-60px}
.h-blob .blob.b2{width:360px;height:360px;background:var(--a);bottom:-140px;left:-80px}
.h-blob>*{position:relative;z-index:2}
.h-blob h1{font-size:calc(56px*var(--hs));margin-bottom:20px}
.h-blob .pic{border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 80px rgba(var(--p-rgb),.25);position:relative}
.h-blob .pic img{width:100%;height:500px;object-fit:cover}
.h-blob .chip{position:absolute;background:var(--card);border-radius:14px;padding:14px 18px;box-shadow:0 16px 40px rgba(0,0,0,.16);font-weight:700;color:var(--p);display:flex;gap:10px;align-items:center}
.h-blob .chip .d{width:34px;height:34px;border-radius:9px;background:var(--s);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}
.h-blob .chip.c1{top:26px;left:-14px}
.h-blob .chip.c2{bottom:30px;right:-12px}

/* hero: darktech */
.h-tech{position:relative;overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center;padding:110px 28px;
  background:linear-gradient(180deg,var(--bg),var(--ink))}
.h-tech::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(var(--s-rgb),.06) 1px,transparent 1px),linear-gradient(90deg,rgba(var(--s-rgb),.06) 1px,transparent 1px);background-size:42px 42px;z-index:0}
.h-tech>*{position:relative;z-index:2}
.h-tech .eyebrow{font-family:var(--body)}
.h-tech .eyebrow::before{content:"<";color:var(--s);margin-right:6px}
.h-tech .eyebrow::after{content:"/>";color:var(--s);margin-left:6px}
.h-tech h1{font-size:calc(54px*var(--hs));margin-bottom:20px}
.h-tech .panel{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--card);box-shadow:0 30px 80px rgba(0,0,0,.4)}
.h-tech .panel .bar{display:flex;gap:7px;padding:14px 16px;border-bottom:1px solid var(--line)}
.h-tech .panel .bar i{width:11px;height:11px;border-radius:50%;background:var(--line)}
.h-tech .panel .bar i:first-child{background:var(--s)}
.h-tech .panel img{width:100%;height:340px;object-fit:cover;opacity:.92}

/* mini hero (inner pages) */
.h-mini{padding:90px 28px 70px;text-align:center;background:var(--tint);border-bottom:1px solid var(--line)}
.h-mini h1{font-size:calc(46px*var(--hs));margin-bottom:14px}
.h-mini p{color:var(--muted);max-width:60ch;margin:0 auto;font-weight:300;font-size:18px}

/* stats */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats-row .n{font-family:var(--disp);font-size:54px;color:var(--p);line-height:1}
.stats-row .l{color:var(--muted);font-size:14px;margin-top:10px;letter-spacing:.4px}
.stats-boxed{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stats-boxed .box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:34px 26px;text-align:center}
.stats-boxed .n{font-family:var(--disp);font-size:48px;color:var(--s);line-height:1}
.stats-boxed .l{color:var(--muted);font-size:13.5px;margin-top:8px}

/* cards */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:38px 32px;transition:.3s}
.card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(var(--p-rgb),.14)}
.card h3{font-size:23px;margin-bottom:12px}
.card p{color:var(--muted);font-weight:300;font-size:15.5px}
/* icondot */
.c-icondot .dot{width:20px;height:20px;border-radius:50%;background:var(--s);display:block;margin-bottom:22px;box-shadow:0 0 0 7px rgba(var(--s-rgb),.16)}
/* bordered */
.c-bordered .ic{font-size:30px;margin-bottom:18px;display:inline-flex;width:60px;height:60px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:calc(var(--radius)*.7);background:var(--tint)}
.c-bordered .card:hover{border-color:var(--s)}
/* numbered */
.c-numbered .card{counter-increment:cstep;padding-top:54px;position:relative}
.c-numbered .card::before{content:counter(cstep,decimal-leading-zero);position:absolute;top:30px;left:32px;font-family:var(--disp);font-size:18px;font-weight:700;color:var(--s)}
.c-numbered .grid3{counter-reset:cstep}
.c-numbered .card h3{margin-top:6px}
/* imagetop */
.c-imagetop .card{padding:0;overflow:hidden}
.c-imagetop .card .ci{height:190px}
.c-imagetop .card .ci img{width:100%;height:100%;object-fit:cover}
.c-imagetop .card .cb{padding:30px 30px 34px}
.c-imagetop .card:hover{transform:translateY(-8px)}

/* feature split */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feat.rev .feat-media{order:2}
.feat-media{border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 70px rgba(var(--p-rgb),.2);position:relative}
.feat-media img{width:100%;height:520px;object-fit:cover}
.feat h2{font-size:calc(42px*var(--hs));margin-bottom:18px}
.check{list-style:none;margin-top:26px;display:grid;gap:16px}
.check li{display:flex;gap:14px;align-items:flex-start}
.check .tk{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--s);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.check strong{display:block;margin-bottom:2px}
.check span.t{color:var(--muted);font-size:15px;font-weight:300}

/* process */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;counter-reset:st}
.steps .st{position:relative;padding:44px 24px 30px;border-top:3px solid var(--line)}
.steps .st::before{counter-increment:st;content:counter(st,decimal-leading-zero);font-family:var(--disp);font-size:26px;color:var(--s);font-weight:700}
.steps .st h3{font-size:20px;margin:12px 0 8px}
.steps .st p{color:var(--muted);font-size:14.5px;font-weight:300}
.timeline{max-width:760px;margin:0 auto;display:grid;gap:0}
.timeline .tl{display:grid;grid-template-columns:64px 1fr;gap:22px;padding:0 0 36px;position:relative}
.timeline .tl::before{content:"";position:absolute;left:31px;top:54px;bottom:0;width:2px;background:var(--line)}
.timeline .tl:last-child::before{display:none}
.timeline .tn{counter-increment:st;width:64px;height:64px;border-radius:50%;background:var(--tint);border:2px solid var(--s);color:var(--s);font-family:var(--disp);font-size:24px;display:flex;align-items:center;justify-content:center}
.timeline .tn::before{content:counter(st)}
.timeline{counter-reset:st}
.timeline .tl h3{font-size:22px;margin-bottom:6px}
.timeline .tl p{color:var(--muted);font-weight:300}

/* testimonials */
.tw{max-width:880px;margin:0 auto;position:relative}
.ttrack{position:relative;min-height:300px}
.tcard{position:absolute;inset:0;opacity:0;visibility:hidden;transform:translateY(16px);transition:.5s;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:60px;text-align:center}
.tcard.active{opacity:1;visibility:visible;transform:none}
.tcard .stars{color:var(--s);letter-spacing:4px;margin-bottom:20px}
.tcard blockquote{font-family:var(--disp);font-size:25px;line-height:1.5;color:var(--fg);margin-bottom:26px}
.tcard .who{display:flex;gap:14px;justify-content:center;align-items:center}
.tcard .av{width:52px;height:52px;border-radius:50%;background:var(--s);color:#fff;font-family:var(--disp);font-size:20px;display:flex;align-items:center;justify-content:center}
.tcard .who .nm{font-weight:700}
.tcard .who .rl{color:var(--muted);font-size:14px}
.dots{display:flex;gap:10px;justify-content:center;margin-top:30px}
.dots button{width:11px;height:11px;border-radius:50%;border:0;background:var(--line);cursor:pointer;transition:.2s}
.dots button.active{background:var(--s);transform:scale(1.3)}

/* faq */
.faq{max-width:820px;margin:0 auto}
.fitem{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;background:var(--card)}
.fitem.open{border-color:var(--s)}
.fq{padding:24px 28px;font-family:var(--disp);font-size:19px;cursor:pointer;display:flex;justify-content:space-between;gap:18px;align-items:center}
.fq .sg{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--tint);display:flex;align-items:center;justify-content:center;font-size:20px;transition:.3s}
.fitem.open .fq .sg{background:var(--s);color:#fff;transform:rotate(135deg)}
.fa{max-height:0;overflow:hidden;transition:.4s;padding:0 28px;color:var(--muted);font-weight:300}
.fitem.open .fa{max-height:320px;padding:0 28px 26px}

/* cta */
.cta{background:var(--p);color:#fff;text-align:center;border-radius:0;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(var(--s-rgb),.3),transparent 45%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.08),transparent 45%)}
.cta>*{position:relative;z-index:2}
.cta h2{color:#fff;font-size:calc(46px*var(--hs));margin-bottom:18px}
.cta p{color:rgba(255,255,255,.85);max-width:60ch;margin:0 auto 30px;font-weight:300;font-size:18px}

/* contact */
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:56px;max-width:1040px;margin:0 auto}
.cblock{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-bottom:18px}
.cblock h4{color:var(--s);font-family:var(--body);text-transform:uppercase;letter-spacing:1px;font-size:13px;margin-bottom:8px}
.fgroup{margin-bottom:22px}
.fgroup label{display:block;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;color:var(--fg)}
.fgroup input,.fgroup textarea{width:100%;padding:15px 16px;border:1px solid var(--line);border-radius:calc(var(--btn));background:var(--bg);color:var(--fg);font-family:var(--body);font-size:16px}
.fgroup input:focus,.fgroup textarea:focus{outline:none;border-color:var(--s);box-shadow:0 0 0 4px rgba(var(--s-rgb),.14)}
.fgroup textarea{min-height:150px;resize:vertical}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.82);padding:80px 28px 36px}
.fcols{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:50px}
footer h4{color:#fff;font-family:var(--body);text-transform:uppercase;font-size:13px;letter-spacing:1.5px;margin-bottom:20px;border-bottom:2px solid var(--s);padding-bottom:10px;display:inline-block}
footer ul{list-style:none}
footer li{margin-bottom:11px}
footer a:hover{color:var(--s)}
.fbrand{display:flex;align-items:center;gap:12px;font-family:var(--disp);font-size:22px;color:#fff;margin-bottom:16px}
.fbot{max-width:var(--maxw);margin:54px auto 0;border-top:1px solid rgba(255,255,255,.12);padding-top:28px;text-align:center;font-size:13px;color:rgba(255,255,255,.6)}

/* reveal + toast */
[data-reveal]{opacity:0;transform:translateY(34px);transition:.7s cubic-bezier(.2,.8,.2,1)}
[data-reveal].vis{opacity:1;transform:none}
.toast{position:fixed;top:22px;right:22px;z-index:999;padding:15px 22px;border-radius:10px;color:#fff;font-weight:600;box-shadow:0 18px 50px rgba(0,0,0,.3);transform:translateX(130%);transition:.35s}
.toast.show{transform:none}
.toast.ok{background:#1e9e57}.toast.err{background:#d6453c}

@media(max-width:920px){
  .h-split,.h-blob,.h-tech,.feat,.cgrid{grid-template-columns:1fr;gap:40px}
  .h-split.rev .h-txt,.feat.rev .feat-media{order:0}
  .stats-row,.stats-boxed,.grid3,.steps,.h-strip{grid-template-columns:1fr 1fr}
  nav.links{display:none;position:absolute;top:72px;left:0;right:0;background:var(--bg);flex-direction:column;gap:0;padding:14px 0;border-bottom:1px solid var(--line)}
  nav.links.open{display:flex}
  nav.links a{padding:14px 28px}
  .menu-btn{display:block}
  .nav-cta{display:none}
  header[data-nav="center"] .brand{position:static}
  h1{font-size:42px !important}
  .h-full{min-height:auto;padding-top:60px}
}
@media(max-width:560px){
  .stats-row,.stats-boxed,.grid3,.steps,.h-strip{grid-template-columns:1fr}
  section{padding:64px 22px}
}
