/* ==========================================================================
   VarStan Design System  ·  vsr-styles.css
   Forest & Gold identity  ·  Bookkeeping · Tax · Strategy
   All selectors are .vsr- prefixed to avoid Avada theme collisions.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --vsr-forest:       #1B4332;
  --vsr-forest-deep:  #12301F;
  --vsr-forest-soft:  #2D5A45;
  --vsr-gold:         #C0962B;
  --vsr-gold-soft:    #D9B65A;
  --vsr-cream:        #FBF8F0;
  --vsr-cream-deep:   #F2ECDD;
  --vsr-ink:          #1A1A17;
  --vsr-ink-soft:     #4A4A42;
  --vsr-line:         #E2D9C4;
  --vsr-white:        #FFFFFF;

  --vsr-display: 'Cormorant Garamond', Georgia, serif;
  --vsr-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --vsr-wrap: 1120px;
  --vsr-radius: 4px;
  --vsr-shadow: 0 1px 3px rgba(18,48,31,0.06), 0 8px 28px rgba(18,48,31,0.07);
  --vsr-shadow-lift: 0 4px 12px rgba(18,48,31,0.10), 0 18px 48px rgba(18,48,31,0.12);
}

/* ---- Reset (scoped where practical) ---- */
.vsr-root *,
.vsr-root *::before,
.vsr-root *::after { box-sizing: border-box; }

.vsr-root {
  margin: 0;
  font-family: var(--vsr-body);
  color: var(--vsr-ink);
  background: var(--vsr-cream);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  font-size: 17px;
}

.vsr-root img { max-width: 100%; display: block; }
.vsr-root a { color: var(--vsr-forest); text-decoration: none; }
.vsr-root a:hover { color: var(--vsr-gold); }

/* ---- Layout ---- */
.vsr-wrap { max-width: var(--vsr-wrap); margin: 0 auto; padding: 0 24px; }
.vsr-narrow { max-width: 760px; margin: 0 auto; padding: 0 24px; }

.vsr-section { padding: 84px 0; }
.vsr-section--tight { padding: 56px 0; }
.vsr-section--cream { background: var(--vsr-cream); }
.vsr-section--paper { background: var(--vsr-cream-deep); }
.vsr-section--forest { background: var(--vsr-forest); color: var(--vsr-cream); }

/* ---- Typography ---- */
.vsr-root h1, .vsr-root h2, .vsr-root h3 {
  font-family: var(--vsr-display);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin: 0 0 0.5em;
  color: var(--vsr-forest);
}
.vsr-section--forest h1, .vsr-section--forest h2, .vsr-section--forest h3 { color: var(--vsr-cream); }

.vsr-root h1 { font-size: clamp(2.6rem, 5vw, 4rem); }
.vsr-root h2 { font-size: clamp(2rem, 3.6vw, 2.9rem); }
.vsr-root h3 { font-size: 1.5rem; }
.vsr-root p { margin: 0 0 1.1em; }

.vsr-eyebrow {
  font-family: var(--vsr-body);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--vsr-gold);
  margin: 0 0 1rem;
  display: block;
}
.vsr-lede { font-size: 1.22rem; color: var(--vsr-ink-soft); }
.vsr-section--forest .vsr-lede { color: var(--vsr-cream-deep); }

/* hairline gold divider */
.vsr-rule { width: 56px; height: 2px; background: var(--vsr-gold); border: 0; margin: 0 0 1.6rem; }
.vsr-rule--center { margin-left: auto; margin-right: auto; }

/* ---- Buttons ---- */
.vsr-btn {
  display: inline-block;
  font-family: var(--vsr-body);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  padding: 15px 32px;
  border-radius: var(--vsr-radius);
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.vsr-btn:hover { transform: translateY(-1px); }
.vsr-btn--primary { background: var(--vsr-gold); color: var(--vsr-forest-deep); }
.vsr-btn--primary:hover { background: var(--vsr-gold-soft); color: var(--vsr-forest-deep); box-shadow: var(--vsr-shadow-lift); }
.vsr-btn--ghost { background: transparent; border-color: var(--vsr-cream); color: var(--vsr-cream); }
.vsr-btn--ghost:hover { background: var(--vsr-cream); color: var(--vsr-forest); }
.vsr-btn--wire { background: transparent; border-color: var(--vsr-forest); color: var(--vsr-forest); }
.vsr-btn--wire:hover { background: var(--vsr-forest); color: var(--vsr-cream); }

/* ---- Header / nav ---- */
.vsr-header {
  background: var(--vsr-forest);
  color: var(--vsr-cream);
  position: sticky; top: 0; z-index: 50;
}
.vsr-nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; max-width: var(--vsr-wrap); margin: 0 auto; }
.vsr-logo { font-family: var(--vsr-display); font-size: 1.7rem; font-weight: 700; color: var(--vsr-cream); letter-spacing: 0.01em; }
.vsr-root a.vsr-logo { color: var(--vsr-cream); }
.vsr-root a.vsr-logo:hover { color: var(--vsr-cream); }
.vsr-logo em { color: var(--vsr-gold); font-style: normal; }
.vsr-navlinks { display: flex; gap: 28px; align-items: center; list-style: none; margin: 0; padding: 0; }
.vsr-navlinks a { color: var(--vsr-cream); font-size: 0.92rem; font-weight: 500; }
.vsr-navlinks a:hover { color: var(--vsr-gold); }
@media (max-width: 820px){ .vsr-navlinks { display: none; } }

/* ---- Hero ---- */
.vsr-hero { background: var(--vsr-forest); color: var(--vsr-cream); padding: 96px 0 88px; position: relative; overflow: hidden; }
.vsr-hero::after {
  content:""; position:absolute; right:-120px; top:-120px; width:420px; height:420px;
  background: radial-gradient(circle, rgba(192,150,43,0.18), transparent 70%);
  pointer-events:none;
}
.vsr-hero .vsr-eyebrow { color: var(--vsr-gold-soft); }
.vsr-hero h1 { color: var(--vsr-cream); max-width: 16ch; }
.vsr-hero .vsr-lede { color: var(--vsr-cream-deep); max-width: 56ch; }
.vsr-hero-meta { display: flex; flex-wrap: wrap; gap: 28px; margin: 28px 0 32px; }
.vsr-hero-meta div { border-left: 2px solid var(--vsr-gold); padding-left: 14px; }
.vsr-hero-meta .k { font-family: var(--vsr-display); font-size: 1.5rem; color: var(--vsr-cream); line-height: 1; }
.vsr-hero-meta .l { font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--vsr-gold-soft); }
.vsr-hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* ---- Cards / grids ---- */
.vsr-grid { display: grid; gap: 22px; }
.vsr-grid--2 { grid-template-columns: repeat(2, 1fr); }
.vsr-grid--3 { grid-template-columns: repeat(3, 1fr); }
.vsr-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px){ .vsr-grid--3, .vsr-grid--4 { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 620px){ .vsr-grid--2, .vsr-grid--3, .vsr-grid--4 { grid-template-columns: 1fr; } }

.vsr-card {
  background: var(--vsr-white);
  border: 1px solid var(--vsr-line);
  border-radius: var(--vsr-radius);
  padding: 28px;
  transition: transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}
.vsr-card:hover { transform: translateY(-3px); box-shadow: var(--vsr-shadow); border-color: var(--vsr-gold); }
.vsr-card h3 { font-size: 1.35rem; margin-bottom: .35em; }
.vsr-card .vsr-code { font-family: var(--vsr-body); font-weight: 700; font-size: 0.8rem; letter-spacing: 0.12em; color: var(--vsr-gold); }
.vsr-card p { font-size: 0.96rem; color: var(--vsr-ink-soft); margin: 0; }
.vsr-card a.vsr-cardlink { display:inline-block; margin-top: 14px; font-weight:600; font-size:0.9rem; color: var(--vsr-forest); }
.vsr-card a.vsr-cardlink::after { content:" \2192"; color: var(--vsr-gold); }

/* ---- Pricing tiers ---- */
.vsr-tier { background: var(--vsr-white); border:1px solid var(--vsr-line); border-radius: var(--vsr-radius); padding: 30px; }
.vsr-tier--featured { border:2px solid var(--vsr-gold); box-shadow: var(--vsr-shadow); position: relative; }
.vsr-tier--featured::before { content:"Most common"; position:absolute; top:-12px; left:24px; background: var(--vsr-gold); color: var(--vsr-forest-deep); font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:4px 12px; border-radius:3px; }
.vsr-tier .vsr-price { font-family: var(--vsr-display); font-size: 2.4rem; color: var(--vsr-forest); line-height:1; margin:.2em 0; }
.vsr-tier .vsr-price small { font-family: var(--vsr-body); font-size:0.85rem; color: var(--vsr-ink-soft); font-weight:500; }
.vsr-tier ul { list-style:none; padding:0; margin: 16px 0 0; }
.vsr-tier li { padding: 7px 0 7px 24px; position: relative; font-size:0.94rem; color: var(--vsr-ink-soft); }
.vsr-tier li::before { content:"\2713"; position:absolute; left:0; color: var(--vsr-gold); font-weight:700; }

/* ---- Callout ---- */
.vsr-callout { background: var(--vsr-cream-deep); border-left: 3px solid var(--vsr-gold); border-radius: 0 var(--vsr-radius) var(--vsr-radius) 0; padding: 22px 26px; margin: 28px 0; }
.vsr-callout .vsr-callout-label { font-size:0.72rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color: var(--vsr-gold); margin-bottom:6px; }
.vsr-callout p { margin: 0; color: var(--vsr-ink-soft); font-size: 0.96rem; }

/* ---- FAQ accordion ---- */
.vsr-faq { border-top: 1px solid var(--vsr-line); }
.vsr-faq details { border-bottom: 1px solid var(--vsr-line); }
.vsr-faq summary { cursor: pointer; list-style: none; padding: 20px 0; font-family: var(--vsr-display); font-size: 1.3rem; color: var(--vsr-forest); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.vsr-faq summary::-webkit-details-marker { display:none; }
.vsr-faq summary::after { content:"+"; color: var(--vsr-gold); font-family: var(--vsr-body); font-weight:400; font-size:1.6rem; transition: transform .2s ease; }
.vsr-faq details[open] summary::after { content:"\2212"; }
.vsr-faq details > div { padding: 0 0 22px; color: var(--vsr-ink-soft); font-size: 0.98rem; }

/* ---- Breadcrumb ---- */
.vsr-crumb { font-size: 0.82rem; color: var(--vsr-cream-deep); padding-top: 4px; }
.vsr-crumb a { color: var(--vsr-gold-soft); }
.vsr-crumb span { opacity: 0.6; margin: 0 6px; }

/* ---- Steps (numbered process) ---- */
.vsr-steps { counter-reset: vsr-step; display: grid; gap: 20px; }
.vsr-step { display: grid; grid-template-columns: 48px 1fr; gap: 18px; align-items: start; }
.vsr-step::before { counter-increment: vsr-step; content: counter(vsr-step,decimal-leading-zero); font-family: var(--vsr-display); font-size: 1.6rem; color: var(--vsr-gold); border:1.5px solid var(--vsr-gold); border-radius: 50%; width:48px; height:48px; display:flex; align-items:center; justify-content:center; }
.vsr-step h3 { font-size: 1.2rem; margin: 6px 0 .2em; }
.vsr-step p { margin:0; color: var(--vsr-ink-soft); font-size: 0.96rem; }

/* ---- CTA band ---- */
.vsr-cta-band { background: var(--vsr-forest-deep); color: var(--vsr-cream); text-align:center; padding: 72px 0; }
.vsr-cta-band h2 { color: var(--vsr-cream); }
.vsr-cta-band p { color: var(--vsr-cream-deep); max-width: 50ch; margin: 0 auto 28px; }

/* ---- Footer ---- */
.vsr-footer { background: var(--vsr-forest-deep); color: var(--vsr-cream-deep); padding: 48px 0 36px; font-size: 0.9rem; }
.vsr-footer .vsr-footer-inner { display:flex; flex-wrap:wrap; justify-content:space-between; gap: 28px; align-items: flex-end; }
.vsr-footer .vsr-logo { font-size: 1.5rem; }
.vsr-footer-tagline { color: var(--vsr-gold-soft); letter-spacing: 0.04em; margin-top: 4px; }
.vsr-footer a { color: var(--vsr-cream-deep); }
.vsr-footer a:hover { color: var(--vsr-gold); }
.vsr-footer-meta { text-align: right; line-height: 1.8; }
@media (max-width: 620px){ .vsr-footer-meta { text-align:left; } }

/* ---- Utility ---- */
.vsr-center { text-align: center; }
.vsr-mt-0 { margin-top: 0; }
.vsr-maxw { max-width: 60ch; }

/* ---- Accessibility / motion ---- */
.vsr-root :focus-visible { outline: 2px solid var(--vsr-gold); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
  .vsr-root *, .vsr-root *::before, .vsr-root *::after { transition: none !important; animation: none !important; }
}
