/* ============================================================
   RAVONT Accounting — site styles
   Plain CSS. Tokens mirror the design system (colors_and_type.css).
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&family=Open+Sans:wght@400;500;600;700&display=swap');

:root{
  --red:#AE3935; --red-hover:#8F2D29; --red-active:#7A2622; --red-tint:#C75A52;
  --red-100:#F6E4E2; --red-50:#FBF0EE;
  --fg-1:#2A2A2A; --fg-2:#585858; --fg-3:#8A8784;
  --bg:#FFFFFF; --cream:#FFFDF9; --sand:#FCF6EC; --sand-2:#FBF3E4; --muted:#F7F5F2;
  --line:#ECE7E1; --line-2:#E2DDD6; --line-cool:#E8E8E8;
  --r-sm:6px; --r-md:8px; --r-lg:12px; --r-pill:999px;
  --sh-sm:0 2px 8px rgba(43,30,28,.06);
  --sh-card:0 6px 20px rgba(43,30,28,.07);
  --sh-md:0 8px 24px rgba(43,30,28,.08);
  --sh-lg:0 18px 48px rgba(43,30,28,.10);
  --font-display:'Poppins',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:'Open Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --maxw:1140px;
}

/* ---------- reset / base ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--fg-2);background:var(--bg);-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{color:var(--red);text-decoration:none;}
a:hover{color:var(--red-hover);}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--fg-1);margin:0 0 .5em;line-height:1.18;}
h1{font-size:clamp(32px,5vw,46px);color:var(--red);letter-spacing:-.01em;font-weight:700;}
h2{font-size:clamp(26px,3.4vw,34px);color:var(--red);font-weight:700;}
h3{font-size:21px;font-weight:600;}
h4{font-size:18px;font-weight:600;}
p{margin:0 0 1em;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:clamp(56px,8vw,92px) 0;}
.section--tight{padding:clamp(40px,6vw,64px) 0;}
.bg-cream{background:var(--cream);} .bg-sand{background:var(--sand);} .bg-muted{background:var(--muted);}
.center{text-align:center;}
.lead{font-size:clamp(17px,2vw,19px);line-height:1.6;color:var(--fg-2);}
.eyebrow{font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin:0 0 14px;}
.narrow{max-width:720px;margin-left:auto;margin-right:auto;}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--red);color:#fff;padding:10px 16px;border-radius:0 0 var(--r-md) 0;z-index:200;}
.skip-link:focus{left:0;color:#fff;}
:focus-visible{outline:3px solid var(--red-tint);outline-offset:2px;border-radius:4px;}

/* ---------- buttons ---------- */
.btn{font-family:var(--font-display);font-weight:600;font-size:15px;border:none;cursor:pointer;
  padding:13px 26px;border-radius:var(--r-sm);transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none;line-height:1;}
.btn--primary{background:var(--red);color:#fff;}
.btn--primary:hover{background:var(--red-hover);color:#fff;transform:translateY(-1px);box-shadow:var(--sh-sm);}
.btn--primary:active{background:var(--red-active);transform:translateY(0);}
.btn--secondary{background:transparent;color:var(--red);border:1.5px solid var(--red);padding:11.5px 24px;}
.btn--secondary:hover{background:var(--red);color:#fff;}
.btn--white{background:#fff;color:var(--red);} .btn--white:hover{background:var(--sand);}
.btn--lg{padding:15px 32px;font-size:16px;}
.learn{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--red);display:inline-flex;gap:6px;align-items:center;}
.learn .arw{transition:transform .2s ease;}
.learn:hover .arw{transform:translateX(4px);}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px;}
.brand{display:flex;align-items:center;gap:11px;color:var(--red);}
.brand:hover{color:var(--red);}
.brand .mark{width:38px;height:38px;flex:none;}
.brand .wm{display:flex;flex-direction:column;line-height:1;}
.brand .word{font-family:var(--font-display);font-weight:800;font-size:24px;letter-spacing:.04em;color:var(--red);}
.brand .sub{font-family:var(--font-display);font-weight:600;font-size:8px;letter-spacing:.4em;color:var(--fg-3);margin-top:4px;padding-left:1px;}

.nav{display:flex;align-items:center;gap:6px;}
.nav-list{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0;}
.nav-link{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-display);font-weight:500;font-size:14.5px;color:var(--fg-1);
  padding:10px 14px;border-radius:var(--r-sm);background:none;border:none;cursor:pointer;font-family:var(--font-display);}
.nav-link:hover,.nav-link[aria-current="page"]{color:var(--red);}
.nav-link .caret{width:14px;height:14px;transition:transform .2s ease;}

/* dropdown */
.has-dropdown{position:relative;}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:280px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);padding:8px;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s;}
.has-dropdown:hover .dropdown,.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.has-dropdown.open .nav-link .caret,.has-dropdown:hover .nav-link .caret{transform:rotate(180deg);}
.dropdown a{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:var(--r-md);color:var(--fg-1);}
.dropdown a:hover{background:var(--red-50);color:var(--red);}
.dropdown a .d-title{font-family:var(--font-display);font-weight:600;font-size:14.5px;}
.dropdown a .d-desc{font-size:12.5px;color:var(--fg-3);line-height:1.4;}

.menu-toggle{display:none;background:none;border:1px solid var(--line-2);border-radius:var(--r-sm);width:44px;height:44px;cursor:pointer;
  align-items:center;justify-content:center;color:var(--fg-1);}
.menu-toggle svg{width:24px;height:24px;}

/* ---------- hero ---------- */
.hero{background:var(--cream);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:clamp(48px,7vw,84px) 0;}
.hero h1{margin-bottom:18px;}
.hero .lead{margin-bottom:28px;max-width:480px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-badges{display:flex;gap:22px;margin-top:30px;flex-wrap:wrap;}
.hero-badge{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:13.5px;color:var(--fg-2);}
.hero-badge svg{width:20px;height:20px;color:var(--red);}
.hero-figure{position:relative;display:flex;justify-content:center;}
.hero-figure .blob{position:absolute;inset:6% -4% -4% 4%;background:var(--red-50);border-radius:48% 48% 46% 46%;}
.hero-figure img{position:relative;width:100%;max-width:420px;border-radius:var(--r-lg);box-shadow:var(--sh-lg);}
.media-ph{display:flex;align-items:center;justify-content:center;background:var(--red-50);color:var(--red-tint);border-radius:var(--r-lg);}
.media-ph svg{width:64px;height:64px;}

/* ---------- page header ---------- */
.page-header{background:var(--cream);padding:clamp(48px,6vw,72px) 0 clamp(40px,5vw,56px);border-bottom:1px solid var(--line);}
.breadcrumb{font-size:13px;color:var(--fg-3);margin-bottom:14px;font-family:var(--font-display);}
.breadcrumb a{color:var(--fg-3);} .breadcrumb a:hover{color:var(--red);}
.page-header h1{margin-bottom:14px;}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:22px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card);padding:26px;}
.service-card{display:flex;flex-direction:column;gap:10px;transition:transform .2s ease,box-shadow .2s ease;height:100%;}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);}
.service-card .ic{width:46px;height:46px;border-radius:var(--r-md);background:var(--red-50);display:flex;align-items:center;justify-content:center;color:var(--red);margin-bottom:4px;}
.service-card .ic svg{width:26px;height:26px;}
.service-card h3{margin:0;font-size:19px;color:var(--red);}
.service-card p{margin:0;font-size:14.5px;line-height:1.55;}
.service-card .learn{margin-top:auto;padding-top:8px;}

/* value props */
.vp{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;}
.vp .ic{width:54px;height:54px;color:var(--red);}
.vp .ic svg{width:38px;height:38px;}

/* checklist */
.checklist{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px;margin:0;padding:0;list-style:none;}
.checklist li{display:flex;align-items:flex-start;gap:11px;font-family:var(--font-body);font-size:15px;color:var(--fg-1);}
.checklist .tick{width:22px;height:22px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;flex:none;margin-top:1px;}

/* two-column feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,56px);align-items:center;}
.stat-badge{display:inline-flex;flex-direction:column;background:var(--red);color:#fff;border-radius:var(--r-md);padding:16px 22px;box-shadow:var(--sh-md);}
.stat-badge b{font-family:var(--font-display);font-weight:700;font-size:30px;line-height:1;}
.stat-badge span{font-size:13px;color:var(--red-100);margin-top:4px;}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.step{padding:6px 22px;border-left:1px solid var(--line-2);}
.step:first-child{border-left:none;}
.step .num{font-family:var(--font-display);font-weight:700;font-size:32px;color:var(--red-100);}
.step h4{color:var(--red);margin:8px 0 6px;}
.step p{font-size:14px;line-height:1.55;margin:0;}

/* cta band */
.cta-band{background:var(--sand);text-align:center;}
.cta-band p{max-width:600px;margin:0 auto 24px;}

/* ---------- forms ---------- */
.form-grid{display:grid;gap:16px;}
.field{display:grid;gap:6px;}
.field label{font-family:var(--font-display);font-weight:500;font-size:13.5px;color:var(--fg-1);}
.field input,.field select,.field textarea{font-family:var(--font-body);font-size:14.5px;color:var(--fg-1);padding:12px 14px;
  border:1px solid var(--line-cool);border-radius:var(--r-sm);background:#fff;width:100%;outline:none;transition:border-color .15s,box-shadow .15s;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-100);}
.field textarea{resize:vertical;min-height:120px;}
.contact-info{display:flex;flex-direction:column;gap:20px;}
.info-row{display:flex;gap:14px;align-items:flex-start;}
.info-row .ic{width:44px;height:44px;border-radius:50%;background:var(--red-50);display:flex;align-items:center;justify-content:center;color:var(--red);flex:none;}
.info-row .ic svg{width:20px;height:20px;}
.info-row .l{font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-bottom:2px;}
.info-row .v{font-family:var(--font-display);font-weight:600;font-size:15.5px;color:var(--fg-1);}

/* ---------- footer ---------- */
.site-footer{background:var(--red);color:#fff;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding:60px 24px 38px;}
.footer-brand .mark{width:40px;height:40px;color:#fff;margin-bottom:14px;}
.footer-brand .word{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:.04em;color:#fff;}
.footer-brand p{color:#F3D9D6;font-size:14px;line-height:1.7;max-width:300px;margin:14px 0 16px;}
.footer-brand .email{color:#fff;font-weight:600;font-size:14px;}
.site-footer h4{color:#fff;font-size:16px;margin:0 0 16px;}
.footer-links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.footer-links a{color:#F3D9D6;font-size:14px;}
.footer-links a:hover{color:#fff;}
.footer-contact{color:#F3D9D6;font-size:14px;}
.footer-contact strong{color:#fff;display:block;font-weight:600;margin-top:2px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.2);}
.footer-bottom .container{padding-top:18px;padding-bottom:18px;font-size:13px;color:#F3D9D6;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-grid,.split{grid-template-columns:1fr;}
  .hero-figure{order:-1;max-width:420px;margin:0 auto;}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);gap:28px 0;}
  .step:nth-child(odd){border-left:none;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:760px){
  .menu-toggle{display:flex;}
  .nav{position:fixed;inset:74px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;padding:8px 16px 20px;box-shadow:var(--sh-md);
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:all .2s ease;max-height:calc(100vh - 74px);overflow-y:auto;}
  .nav.open{transform:translateY(0);opacity:1;visibility:visible;}
  .nav-list{flex-direction:column;align-items:stretch;gap:0;width:100%;}
  .nav-link{width:100%;justify-content:space-between;padding:14px 8px;font-size:16px;border-radius:0;border-bottom:1px solid var(--line);}
  .nav .btn{margin-top:14px;justify-content:center;}
  .has-dropdown{width:100%;}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-radius:0;
    min-width:0;padding:0 0 8px 8px;max-height:0;overflow:hidden;transition:max-height .25s ease;}
  .has-dropdown.open .dropdown{max-height:520px;}
  .dropdown a{padding:11px 10px;}
  .dropdown a .d-desc{display:none;}
}
@media (max-width:560px){
  .grid-3,.grid-2,.checklist{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .step{border-left:none;padding:6px 0;}
  .footer-grid{grid-template-columns:1fr;}
  .hero-cta .btn,.cta-band .btn{width:100%;justify-content:center;}
}

/* ============================================================
   Scroll animations — reusable, lightweight, accessible
   The hidden state ONLY applies when JS adds .js-anim to <html>
   AND the user has not requested reduced motion. So with no JS,
   in print/PDF, or for reduced-motion users, content is always
   visible and nothing can get stuck hidden.
   Variants: .reveal (fade-up, default) · --fade · --zoom · --left · --right
   ============================================================ */
.reveal{opacity:1;}                                   /* default resting state: visible */

@media (prefers-reduced-motion: no-preference){
  html.js-anim .reveal{
    opacity:0;
    transform:translateY(26px);
    transition:opacity .7s cubic-bezier(.22,.61,.36,1),
               transform .7s cubic-bezier(.22,.61,.36,1);
    will-change:opacity, transform;
  }
  html.js-anim .reveal.reveal--fade { transform:translateY(0); }
  html.js-anim .reveal.reveal--zoom { transform:scale(.955); }
  html.js-anim .reveal.reveal--left { transform:translateX(-30px); }
  html.js-anim .reveal.reveal--right{ transform:translateX(30px); }
  html.js-anim .reveal.is-visible{ opacity:1; transform:none; }
}
