/* ============================================================
   JOXA CAPITAL — premium financial advisory
   Palette: obsidian navy + amber gold
   ============================================================ */

:root{
  --navy-900:#070b16;
  --navy-800:#0a0f1e;
  --navy-700:#0e1528;
  --navy-600:#141d36;
  --navy-500:#1b2747;
  --gold:#F5A623;
  --gold-bright:#ffc35a;
  --gold-deep:#c9821a;
  --cream:#f4ead7;
  --text:#e8ecf6;
  --text-dim:#9aa6c2;
  --text-faint:#5d6987;
  --line:rgba(245,166,35,.16);
  --maxw:1280px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--navy-800);
  color:var(--text);
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
}
body.loading{overflow:hidden}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--navy-900)}

/* ---------- background canvas & atmosphere ---------- */
#bg-canvas{
  position:fixed;inset:0;width:100vw;height:100vh;
  z-index:0;display:block;
}
.vignette{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 8%, rgba(245,166,35,.10), transparent 42%),
    radial-gradient(140% 120% at 50% 50%, transparent 45%, rgba(5,8,17,.55) 78%, rgba(5,8,17,.92) 100%);
}
.grain{
  position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- loader ---------- */
#loader{
  position:fixed;inset:0;z-index:200;
  background:var(--navy-900);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  transition:opacity .8s var(--ease),visibility .8s;
}
#loader.hidden{opacity:0;visibility:hidden}
.loader-logo{width:min(46vw,210px);height:auto;display:block}
.loader-mark .hex{fill:none;stroke:var(--gold);stroke-width:3;opacity:.35}
.loader-mark .jd{fill:none;stroke:var(--gold);stroke-width:5;stroke-linecap:round;
  stroke-dasharray:200;stroke-dashoffset:200;animation:draw 1.8s var(--ease) infinite alternate}
@keyframes draw{to{stroke-dashoffset:0}}
.loader-bar{width:180px;height:2px;background:rgba(245,166,35,.15);overflow:hidden;border-radius:2px}
.loader-bar span{display:block;height:100%;width:0;background:var(--gold);
  box-shadow:0 0 12px var(--gold);animation:fill 1.6s var(--ease) forwards}
@keyframes fill{to{width:100%}}
.loader-text{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--text-faint)}

/* ---------- nav ---------- */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,5vw,56px);
  transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s;
  border-bottom:1px solid transparent;
}
#nav.scrolled{
  background:rgba(8,12,24,.72);backdrop-filter:blur(16px);
  padding-top:14px;padding-bottom:14px;border-color:var(--line);
}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{height:21px;width:auto;display:block;max-width:62vw}
.footer-logo{height:19px}
.brand-fallback{display:flex;align-items:center;gap:10px}
@media (max-width:540px){ .brand-logo{height:17px} }
.brand-mark .hex{fill:none;stroke:var(--gold);stroke-width:4;opacity:.7}
.brand-mark .jd{fill:none;stroke:var(--gold);stroke-width:6;stroke-linecap:round}
.brand-text{font-family:'Bebas Neue';letter-spacing:.12em;font-size:1.3rem;color:#fff}
.brand-text b{color:var(--gold);font-weight:400}
.brand-text i{font-style:normal;color:var(--text-dim);font-size:.8em}
.brand.small .brand-text{font-size:1.05rem}

.nav-links{display:flex;gap:28px}
.nav-links a{
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);
  position:relative;transition:color .3s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}

.nav-right{display:flex;align-items:center;gap:18px}
.lang-toggle{
  background:none;border:1px solid var(--line);border-radius:40px;
  padding:7px 13px;cursor:pointer;color:var(--text-faint);
  font-family:'Inter';font-size:.72rem;letter-spacing:.12em;font-weight:600;
  display:flex;align-items:center;gap:4px;transition:border-color .3s;
}
.lang-toggle:hover{border-color:var(--gold)}
.lang-toggle span{transition:color .3s}
.lang-toggle span.active{color:var(--gold)}
.lang-sep{color:var(--text-faint)!important}
.nav-cta{
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:10px 20px;border:1px solid var(--gold);border-radius:40px;color:var(--gold);
  transition:all .35s var(--ease);
}
.nav-cta:hover{background:var(--gold);color:var(--navy-900);box-shadow:0 0 26px rgba(245,166,35,.4)}

/* ---------- layout primitives ---------- */
main{position:relative;z-index:10}
.section{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding:120px clamp(20px,6vw,90px);
}
.eyebrow,.chapter-kicker{
  font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  font-weight:600;margin-bottom:22px;
}
.chapter-num{
  font-family:'Bebas Neue';font-size:clamp(3rem,8vw,6rem);line-height:.8;
  color:transparent;-webkit-text-stroke:1px rgba(245,166,35,.34);margin-bottom:18px;
}
.gold{color:var(--gold)}
.dim{color:var(--text-faint)}

/* buttons */
.btn{
  display:inline-block;font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
  padding:15px 30px;border-radius:46px;transition:all .4s var(--ease);cursor:pointer;
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));
  color:var(--navy-900);box-shadow:0 0 0 rgba(245,166,35,.0),0 8px 30px rgba(245,166,35,.22);
  position:relative;
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 0 38px rgba(245,166,35,.55),0 14px 40px rgba(245,166,35,.3)}
.btn-ghost{border:1px solid var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 0 26px rgba(245,166,35,.18)}
.btn-lg{padding:19px 44px;font-size:.9rem}

/* ---------- hero ---------- */
.hero{align-items:flex-start;justify-content:center}
.hero-inner{max-width:920px}
.hero-title{
  font-family:'Bebas Neue';font-weight:400;
  font-size:clamp(3.6rem,12vw,9.5rem);line-height:.92;letter-spacing:.01em;
  margin:6px 0 30px;
}
.hero-title .line{display:block;overflow:hidden}
.hero-title .gold{
  color:var(--gold);
  text-shadow:0 0 50px rgba(245,166,35,.4);
}
.hero-sub{
  font-family:'Cormorant Garamond';font-size:clamp(1.15rem,2.3vw,1.6rem);
  line-height:1.55;color:var(--text-dim);max-width:640px;margin-bottom:38px;font-weight:500;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.scroll-cue{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--text-faint);
}
.cue-line{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.cue-line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-bright);animation:cue 2s var(--ease) infinite}
@keyframes cue{to{top:100%}}

/* ---------- manifesto ---------- */
.manifesto-inner{max-width:1000px}
.big-statement{
  font-family:'Bebas Neue';font-weight:400;
  font-size:clamp(2.8rem,8.5vw,7rem);line-height:.96;margin-bottom:34px;
}
.big-statement span{display:block}
.manifesto-body{
  font-family:'Cormorant Garamond';font-size:clamp(1.2rem,2.4vw,1.75rem);
  line-height:1.55;color:var(--text-dim);max-width:720px;font-weight:500;
}

/* ---------- stats ---------- */
.stats{min-height:70vh}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  max-width:var(--maxw);width:100%;margin:0 auto;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:60px 0;
}
.stat{text-align:center;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:15%;height:70%;width:1px;background:var(--line)}
.stat-num{
  font-family:'Bebas Neue';font-size:clamp(3.2rem,7vw,5.6rem);line-height:1;color:var(--gold);
  text-shadow:0 0 36px rgba(245,166,35,.32);
}
.stat-label{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);margin-top:8px}

/* ---------- chapters ---------- */
.chapter{min-height:120vh}
.chapter-grid{max-width:var(--maxw);width:100%;margin:0 auto;display:flex}
.chapter.align-right .chapter-grid{justify-content:flex-end}
.chapter-copy{max-width:560px;
  background:linear-gradient(160deg,rgba(14,21,40,.62),rgba(10,15,30,.34));
  backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:20px;
  padding:clamp(28px,4vw,52px);
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  position:relative;overflow:hidden;
}
.chapter-copy::before{
  content:"";position:absolute;inset:0;border-radius:20px;padding:1px;
  background:linear-gradient(160deg,rgba(245,166,35,.5),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s;
}
.chapter-copy:hover::before{opacity:1}
.chapter-title{
  font-family:'Bebas Neue';font-weight:400;font-size:clamp(2.2rem,4.5vw,3.6rem);
  line-height:1.02;margin-bottom:20px;
}
.chapter-lead{font-family:'Cormorant Garamond';font-size:clamp(1.1rem,1.8vw,1.35rem);
  color:var(--text-dim);margin-bottom:28px;font-weight:500;line-height:1.5}
.feature-list{list-style:none;margin-bottom:34px;display:flex;flex-direction:column;gap:13px}
.feature-list li{
  position:relative;padding-left:28px;font-size:.94rem;color:var(--text);line-height:1.45;
}
.feature-list li::before{
  content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;
  border:1px solid var(--gold);transform:rotate(45deg);
  box-shadow:0 0 10px rgba(245,166,35,.4);
}

/* ---------- process ---------- */
.process{min-height:110vh}
.process-inner{max-width:var(--maxw);width:100%;margin:0 auto}
.section-title{
  font-family:'Bebas Neue';font-weight:400;font-size:clamp(2.4rem,6vw,4.6rem);
  line-height:1;margin-bottom:60px;
}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.pstep{
  border-top:2px solid var(--line);padding-top:24px;transition:border-color .4s;
}
.pstep:hover{border-color:var(--gold)}
.pstep-num{font-family:'Bebas Neue';font-size:1.6rem;color:var(--gold);letter-spacing:.06em}
.pstep h3{font-family:'Bebas Neue';font-weight:400;font-size:1.6rem;letter-spacing:.04em;margin:8px 0 10px}
.pstep p{font-size:.92rem;color:var(--text-dim);line-height:1.5}

/* ---------- contact ---------- */
.contact{align-items:center;text-align:center;min-height:100vh}
.contact-inner{max-width:880px;width:100%}
.cta-headline{
  font-family:'Bebas Neue';font-weight:400;font-size:clamp(3rem,10vw,7.5rem);
  line-height:.94;margin-bottom:22px;
}
.cta-headline span{display:block}
.contact-lead{font-family:'Cormorant Garamond';font-size:clamp(1.2rem,2.4vw,1.7rem);
  color:var(--text-dim);margin-bottom:36px;font-weight:500}
.contact-actions{margin-bottom:60px}
.contact-cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px;
}
.ccard{
  border:1px solid var(--line);border-radius:14px;padding:22px 18px;
  display:flex;flex-direction:column;gap:6px;text-align:left;
  transition:all .4s var(--ease);background:rgba(14,21,40,.4);
}
a.ccard:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.4)}
.ccard-label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.ccard-value{font-size:.95rem;color:var(--text);white-space:nowrap}
.ccard-value.email{font-size:clamp(.72rem,1.25vw,.9rem);letter-spacing:-.01em}

.footer{
  max-width:var(--maxw);margin:90px auto 0;width:100%;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding-top:28px;border-top:1px solid var(--line);
}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 22px;width:100%;order:3;margin-top:6px}
.footer-legal a{font-size:.74rem;letter-spacing:.08em;color:var(--text-dim);transition:color .3s}
.footer-legal a:hover{color:var(--gold)}
.footer-note{font-size:.78rem;color:var(--text-faint);letter-spacing:.04em}

/* ---------- whatsapp float ---------- */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:70;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));
  color:var(--navy-900);display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(245,166,35,.4);transition:transform .35s var(--ease);
  animation:floaty 3s ease-in-out infinite;
}
.wa-float:hover{transform:scale(1.1)}
@keyframes floaty{50%{transform:translateY(-7px)}}

/* ---------- reveal animation base ---------- */
.reveal,.reveal-line>*,.reveal-line{will-change:transform,opacity}
.reveal{opacity:0;transform:translateY(28px)}
.reveal-line{opacity:0;transform:translateY(110%)}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .nav-links{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px 20px}
  .stat:nth-child(2)::after{display:none}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:36px 24px}
  .contact-cards{grid-template-columns:repeat(2,1fr)}
  .chapter.align-right .chapter-grid{justify-content:flex-start}
  .chapter{min-height:auto;padding-top:100px;padding-bottom:100px}
  .section{min-height:auto}
  .hero{min-height:100vh}
}
@media (max-width:540px){
  .stats-grid{grid-template-columns:1fr}
  .stat::after{display:none!important}
  .process-steps,.contact-cards{grid-template-columns:1fr}
  .nav-cta{display:none}
  .footer{flex-direction:column;text-align:center}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  html{scroll-behavior:auto}
}
