/* ===========================================================================
   Finguard — landing / marketing design system  (professional, editorial)
   Palette: white / cream, wine, red-clay, black. Typeface: Times New Roman.
   Restrained: strong typography, generous whitespace, hairlines. Minimal motion.
   =========================================================================== */

:root{
  --paper:#fbf7f1;        /* warm cream */
  --white:#ffffff;
  --ink:#1c1714;          /* warm black */
  --ink-soft:#3a322d;
  --muted:#6f635c;
  --muted-2:#9a8e85;
  --line:rgba(28,23,20,.13);
  --line-2:rgba(28,23,20,.26);

  --wine:#6a1b2a;
  --wine-d:#511320;
  --wine-wash:#f3e7e8;
  --clay:#b45c38;
  --clay-d:#974628;
  --clay-wash:#f6e9e1;

  --display:"Times New Roman",Times,Georgia,serif;
  --sans:"Times New Roman",Times,Georgia,serif;
  --maxw:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}
::selection{background:var(--clay-wash);}
::-webkit-scrollbar{width:12px;height:12px;}
::-webkit-scrollbar-thumb{background:#d8cfc3;border-radius:20px;border:3px solid var(--paper);}
::-webkit-scrollbar-thumb:hover{background:#c5b8a8;}

/* ---------------- nav ---------------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;gap:22px;
  padding:20px clamp(18px,4vw,46px);transition:background .3s,border-color .3s,padding .3s,box-shadow .3s;border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(251,247,241,.88);backdrop-filter:saturate(1.1) blur(10px);border-bottom-color:var(--line);padding-top:14px;padding-bottom:14px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand__logo{width:36px;height:36px;}
.brand__name{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:.01em;color:var(--ink);}
.brand__name .g{color:var(--wine);}
.nav__links{display:flex;gap:28px;margin-left:16px;}
.nav__links a{font-size:14.5px;color:var(--ink-soft);font-weight:500;position:relative;transition:color .2s;}
.nav__links a:hover{color:var(--wine);}
.nav__right{margin-left:auto;display:flex;align-items:center;gap:12px;}
.nav__burger{display:none;background:none;border:1px solid var(--line-2);color:var(--ink);width:40px;height:40px;border-radius:8px;font-size:18px;}

/* ---------------- buttons ---------------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:600;font-size:14.5px;
  padding:12px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:transform .12s,background .2s,border-color .2s,color .2s;white-space:nowrap;}
.btn:active{transform:translateY(1px);}
.btn--primary{background:var(--wine);color:#fdeef0;}
.btn--primary:hover{background:var(--wine-d);}
.btn--ghost{border-color:var(--line-2);color:var(--ink);}
.btn--ghost:hover{border-color:var(--wine);color:var(--wine);}
.btn--clay{background:var(--clay);color:#fff;}
.btn--clay:hover{background:var(--clay-d);}
.btn--lg{padding:15px 28px;font-size:15.5px;}
.btn--onwine{background:#fdeef0;color:var(--wine);}
.btn--onwine:hover{background:#fff;}
.btn--ghost-onwine{border-color:rgba(255,255,255,.4);color:#fdeef0;}
.btn--ghost-onwine:hover{border-color:#fff;color:#fff;}
.btn .arr{transition:transform .2s;}
.btn:hover .arr{transform:translateX(3px);}

/* ---------------- layout ---------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px);}
section{position:relative;}
.section{padding:clamp(68px,10vh,120px) 0;}
.band-white{background:var(--white);}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);font-weight:600;}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--clay);}

h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.01em;line-height:1.04;margin:0;color:var(--ink);}
.h-xl{font-size:clamp(40px,6.6vw,82px);line-height:1.02;}
.h-lg{font-size:clamp(30px,4.4vw,58px);line-height:1.06;}
.h-md{font-size:clamp(24px,3vw,38px);line-height:1.1;}
.lede{font-size:clamp(17px,1.4vw,20px);color:var(--muted);max-width:60ch;line-height:1.65;}
.muted{color:var(--muted);}
.wine{color:var(--wine);}
.clay{color:var(--clay);}
em.ul{font-style:italic;color:var(--wine);}

/* ---------------- hero ---------------- */
.hero{position:relative;padding:clamp(130px,18vh,180px) 0 clamp(60px,9vh,100px);}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;}
.hero h1{margin:22px 0 0;}
.hero .lede{margin:24px 0 0;}
.hero__cta{margin-top:34px;display:flex;gap:13px;flex-wrap:wrap;}
.hero__meta{margin-top:30px;display:flex;gap:26px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:22px;}
.hero__meta .m .n{font-family:var(--display);font-size:26px;font-weight:600;color:var(--wine);}
.hero__meta .m .l{font-size:12.5px;color:var(--muted);letter-spacing:.02em;}

/* refined hero side card (demo / panel) */
.panel{background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 50px -30px rgba(28,23,20,.35);overflow:hidden;}
.panel__bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line);background:var(--paper);}
.panel__bar .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay);font-weight:600;}
.panel__bar .dot{width:8px;height:8px;border-radius:50%;background:var(--line-2);}
.panel__body{padding:18px;}

/* ---------------- statement ---------------- */
.statement{padding:clamp(80px,12vh,150px) 0;}
.statement p{font-family:var(--display);font-weight:500;font-size:clamp(26px,3.6vw,46px);line-height:1.22;letter-spacing:-.01em;max-width:20ch;}
.statement .sub{font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.5vw,19px);color:var(--muted);max-width:60ch;margin-top:26px;line-height:1.7;}

/* section heads */
.sec-head{margin-bottom:46px;max-width:760px;}
.sec-head h2{margin:16px 0 0;}
.sec-head .lede{margin-top:18px;}

/* ---------------- cards ---------------- */
.grid{display:grid;gap:20px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.card{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:30px;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;}
.card:hover{transform:translateY(-3px);box-shadow:0 22px 44px -28px rgba(28,23,20,.4);border-color:var(--line-2);}
.card__ic{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;margin-bottom:18px;background:var(--wine-wash);color:var(--wine);}
.card h3{font-size:21px;margin-bottom:10px;}
.card p{color:var(--muted);font-size:15px;margin:0;line-height:1.62;}
.card__num{font-family:var(--display);font-size:14px;color:var(--clay);margin-bottom:14px;font-weight:600;}

/* ---------------- stats ---------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0;}
.stat{text-align:center;}
.stat .n{font-family:var(--display);font-weight:600;font-size:clamp(34px,4.2vw,54px);line-height:1;color:var(--wine);}
.stat .l{margin-top:10px;font-size:13.5px;color:var(--muted);}

/* ---------------- curriculum list ---------------- */
.curric{border-top:1px solid var(--line);}
.crow{display:grid;grid-template-columns:54px 1fr auto;gap:22px;align-items:center;padding:26px 8px;border-bottom:1px solid var(--line);transition:background .2s,padding .2s;}
.crow:hover{background:var(--wine-wash);padding-left:16px;}
.crow__n{font-family:var(--display);color:var(--clay);font-size:18px;font-weight:600;}
.crow__t{font-family:var(--display);font-size:clamp(19px,2vw,25px);font-weight:600;}
.crow__d{color:var(--muted);font-size:14.5px;margin-top:5px;max-width:64ch;}
.crow__meta{color:var(--wine);font-size:13px;font-weight:600;white-space:nowrap;}

/* ---------------- teaser / split ---------------- */
.split{display:grid;grid-template-columns:1.02fr .98fr;gap:50px;align-items:center;}

/* ---------------- chips ---------------- */
.chips{display:flex;flex-wrap:wrap;gap:10px;}
.chip{font-size:13.5px;color:var(--ink-soft);border:1px solid var(--line-2);border-radius:999px;padding:9px 16px;background:var(--white);transition:border-color .2s,color .2s;}
.chip:hover{border-color:var(--clay);color:var(--clay);}

/* ---------------- CTA band (wine) ---------------- */
.cta{background:var(--wine);color:#f7e9ea;text-align:center;padding:clamp(76px,11vh,130px) 0;}
.cta .eyebrow{color:#e7b9a6;}
.cta .eyebrow::before{background:#e7b9a6;}
.cta h2{color:#fff;margin:18px auto 0;max-width:18ch;}
.cta .lede{color:#ecd5d8;margin:20px auto 0;}
.cta__btns{margin-top:34px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}

/* ---------------- footer ---------------- */
.footer{border-top:1px solid var(--line);padding:60px 0 40px;}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;}
.footer h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay);margin:0 0 16px;font-weight:600;}
.footer a{display:block;color:var(--muted);font-size:14.5px;padding:5px 0;transition:color .2s;}
.footer a:hover{color:var(--wine);}
.footer__brand p{color:var(--muted);font-size:14px;max-width:36ch;margin:14px 0 0;}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:46px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted-2);font-size:13px;}

/* ---------------- reveal ---------------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.07s;}.reveal.d2{transition-delay:.14s;}.reveal.d3{transition-delay:.21s;}

/* ---------------- responsive ---------------- */
@media (max-width:940px){
  .hero__grid{grid-template-columns:1fr;gap:40px;}
  .split{grid-template-columns:1fr;gap:30px;}
  .grid-3{grid-template-columns:1fr 1fr;}
  .footer__grid{grid-template-columns:1fr 1fr;}
  .stats{grid-template-columns:1fr 1fr;gap:30px 18px;}
}
@media (max-width:720px){
  .nav__links{display:none;}
  .nav__burger{display:grid;place-items:center;}
  .nav.open .nav__links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:6px 0;}
  .nav.open .nav__links a{padding:14px clamp(18px,4vw,46px);}
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .crow{grid-template-columns:40px 1fr;}
  .crow__meta{display:none;}
  .footer__grid{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto;}.reveal{opacity:1;transform:none;transition:none;}}

/* ---------------- legal / document pages ---------------- */
.legal{padding:clamp(120px,16vh,150px) 0 80px;}
.legal .doc{max-width:780px;margin:0 auto;}
.legal h1{font-size:clamp(34px,5vw,52px);margin:0 0 6px;}
.legal .updated{color:var(--muted);font-size:14px;margin:0 0 28px;}
.legal h2{font-size:clamp(22px,2.6vw,28px);margin:38px 0 12px;}
.legal h3{font-size:18px;margin:24px 0 8px;}
.legal p,.legal li{font-size:16.5px;line-height:1.72;color:var(--ink-soft);}
.legal p{margin:0 0 16px;}
.legal ul{padding-left:22px;margin:0 0 18px;}
.legal li{margin-bottom:8px;}
.legal a{color:var(--wine);text-decoration:underline;}
.legal a:hover{color:var(--wine-d);}
.legal strong{color:var(--ink);}
.legal .lead{font-size:19px;color:var(--ink);line-height:1.6;}
.legal .note{background:var(--clay-wash);border:1px solid var(--line);border-left:3px solid var(--clay);border-radius:8px;padding:15px 17px;font-size:14.5px;color:var(--ink-soft);margin:0 0 26px;}
.legal .note p{margin:0;font-size:14.5px;}
.legal table{width:100%;border-collapse:collapse;margin:0 0 18px;font-size:15px;}
.legal th,.legal td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top;}
.legal th{font-weight:700;color:var(--ink);}
.legal__back{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px;margin-bottom:18px;}
.legal__back:hover{color:var(--wine);}

/* error page */
.errwrap{min-height:78vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:130px 0 80px;}
.errwrap .code{font-family:var(--display);font-size:clamp(72px,16vw,160px);line-height:1;color:var(--wine);}

/* ---------------- cookie / storage notice ---------------- */
.cookie-bar{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--ink);color:#efe6df;
  padding:14px clamp(18px,4vw,40px);display:flex;align-items:center;gap:18px;flex-wrap:wrap;border-top:3px solid var(--wine);}
.cookie-bar p{margin:0;font-size:14px;line-height:1.55;flex:1;min-width:240px;color:#e6dad1;}
.cookie-bar a{color:#fff;text-decoration:underline;}
.cookie-bar .btn{padding:9px 20px;}
.footer__legal a{color:var(--muted);}
.footer__legal a:hover{color:var(--wine);}
.footer__legal .sep{color:var(--muted-2);margin:0 8px;}
