:root{
  --bg:#0B0B0F;
  --bg-2:#111827;
  --bg-3:#0F1320;
  --gold:#D4AF37;
  --gold-soft:#E8C770;
  --gold-deep:#9C7B1F;
  --white:#F5F5F2;
  --violet:#7C3AED;
  --violet-soft:#A78BFA;
  --sky:#38BDF8;
  --mute:#7A7A82;
  --line:rgba(212,175,55,.18);
  --line-strong:rgba(212,175,55,.42);
  --display:'Cinzel', serif;
  --serif:'Cormorant Garamond', serif;
  --body:'Manrope', sans-serif;
  --max:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  font-family:var(--body);
  color:var(--white);
  background:var(--bg);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}

#particles{position:fixed;inset:0;z-index:1;pointer-events:none}
.smoke{
  position:fixed;inset:-10%;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 800px 400px at 20% 30%, rgba(124,58,237,.10), transparent 60%),
    radial-gradient(ellipse 700px 500px at 80% 70%, rgba(56,189,248,.06), transparent 60%),
    radial-gradient(ellipse 600px 600px at 50% 100%, rgba(212,175,55,.05), transparent 70%);
  filter:blur(40px);
  animation:drift 30s ease-in-out infinite alternate;
}
@keyframes drift{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-3%,2%) scale(1.05)}
  100%{transform:translate(3%,-2%) scale(1)}
}

.grain{
  position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
}

main, nav, footer{position:relative;z-index:5}

nav.top{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  background:linear-gradient(180deg, rgba(11,11,15,.85), rgba(11,11,15,.35));
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
nav.top.scrolled{border-bottom-color:var(--line)}
.brand{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:.18em;
  font-size:14px;
  color:var(--white);
  display:flex;align-items:center;gap:12px;
  text-transform:uppercase;
  text-decoration:none;
}
.brand-mark{
  width:34px;height:34px;display:grid;place-items:center;
  border:1px solid var(--line-strong);border-radius:50%;
  position:relative;
}
.brand-mark::before{
  content:"";position:absolute;inset:5px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, var(--gold) 0%, transparent 70%);
  opacity:.6;
  animation:breathe 4s ease-in-out infinite;
}
.brand-mark svg{position:relative;z-index:2;width:18px;height:18px;color:var(--gold)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{
  color:var(--white);text-decoration:none;font-size:13px;
  font-weight:500;letter-spacing:.04em;
  opacity:.78;transition:opacity .2s, color .2s;
}
.nav-links a:hover{opacity:1;color:var(--gold-soft)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:999px;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:#1a1408;font-weight:600;font-size:13px;
  text-decoration:none;letter-spacing:.02em;
  box-shadow:0 0 0 1px rgba(212,175,55,.4), 0 8px 24px -8px rgba(212,175,55,.6);
  transition:transform .2s, box-shadow .3s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(212,175,55,.6), 0 12px 32px -8px rgba(212,175,55,.8)}

@media(max-width:880px){
  .nav-links{display:none}
  .nav-cta{padding:8px 14px;font-size:12px}
}

.hero{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  padding:120px 24px 80px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 1200px 600px at 50% 0%, rgba(124,58,237,.18), transparent 60%),
    radial-gradient(ellipse 800px 400px at 50% 100%, rgba(212,175,55,.08), transparent 70%),
    linear-gradient(180deg, var(--bg) 0%, #0a0a14 100%);
}
.hero-sigil{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(85vmin,720px);height:min(85vmin,720px);z-index:1;
  opacity:.18;
  animation:spin 240s linear infinite;
  pointer-events:none;
}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.hero-inner{
  position:relative;z-index:5;
  max-width:980px;text-align:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(212,175,55,.04);
  font-size:11px;letter-spacing:.32em;
  font-weight:500;text-transform:uppercase;
  color:var(--gold-soft);
  margin-bottom:32px;
  animation:fadeUp 1s .1s both;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px var(--gold)}

h1.hero-title{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(38px, 7vw, 86px);
  line-height:1.04;
  letter-spacing:.01em;
  margin-bottom:28px;
  animation:fadeUp 1.2s .25s both;
}
h1.hero-title .accent{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  background:linear-gradient(135deg, var(--gold-soft), var(--gold) 50%, var(--violet-soft));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  font-family:var(--serif);
  font-size:clamp(17px, 2vw, 22px);
  line-height:1.55;
  max-width:680px;margin:0 auto 44px;
  color:#d6d6d2;
  font-weight:300;
  animation:fadeUp 1.2s .4s both;
}
.hero-actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  animation:fadeUp 1.2s .55s both;
}

.btn-wa{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;border-radius:999px;
  background:linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color:#fff;font-weight:600;font-size:15px;
  text-decoration:none;letter-spacing:.01em;
  position:relative;
  box-shadow:0 0 0 1px rgba(37,211,102,.4), 0 12px 36px -8px rgba(37,211,102,.5);
  transition:transform .25s, box-shadow .3s;
}
.btn-wa::before{
  content:"";position:absolute;inset:-2px;border-radius:999px;
  background:linear-gradient(135deg, #25D366, #128C7E);
  filter:blur(14px);opacity:.4;z-index:-1;
  transition:opacity .3s;
}
.btn-wa:hover{transform:translateY(-2px)}
.btn-wa:hover::before{opacity:.7}
.btn-wa svg{width:20px;height:20px}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;border-radius:999px;
  background:transparent;color:var(--white);
  border:1px solid var(--line-strong);
  font-weight:500;font-size:14px;
  text-decoration:none;letter-spacing:.04em;
  transition:border-color .3s, background .3s, color .3s;
}
.btn-ghost:hover{border-color:var(--gold);background:rgba(212,175,55,.05);color:var(--gold-soft)}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes breathe{
  0%,100%{opacity:.4;transform:scale(.95)}
  50%{opacity:.8;transform:scale(1.05)}
}

.hero-meta{
  display:flex;gap:48px;justify-content:center;flex-wrap:wrap;
  margin-top:64px;
  animation:fadeUp 1.2s .8s both;
}
.hero-meta .m{text-align:center}
.hero-meta .num{
  font-family:var(--display);
  font-size:32px;
  color:var(--gold);
  display:block;line-height:1;
  margin-bottom:6px;
}
.hero-meta .lbl{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--mute);
}

.scroll-hint{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--mute);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  z-index:5;animation:fadeUp 1.5s 1.5s both;
}
.scroll-hint .line{width:1px;height:48px;background:linear-gradient(180deg, transparent, var(--gold));animation:scrollLine 2.2s ease-in-out infinite}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

section{padding:120px 24px;position:relative}
.wrap{max-width:var(--max);margin:0 auto}

.section-head{text-align:center;margin-bottom:72px}
.kicker{
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:18px;
}
.h2{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(30px, 4.6vw, 54px);
  line-height:1.1;
  letter-spacing:.005em;
  margin-bottom:22px;
}
.h2 .italic{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gold-soft)}
.lede{
  font-family:var(--serif);font-size:19px;line-height:1.55;font-weight:300;
  max-width:640px;margin:0 auto;color:#cfcfca;
}

.trust{padding:48px 24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(17,24,39,.3)}
.trust-row{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  flex-wrap:wrap;max-width:1100px;margin:0 auto;
}
.trust-row .country{
  font-family:var(--display);font-size:12px;letter-spacing:.32em;
  text-transform:uppercase;color:#a8a8a2;font-weight:500;
}
.trust-row .country::before{
  content:"";display:inline-block;width:5px;height:5px;border-radius:50%;
  background:var(--gold);margin-right:10px;vertical-align:middle;
  box-shadow:0 0 8px var(--gold);
}

.services{background:linear-gradient(180deg, var(--bg) 0%, #0a0e1a 50%, var(--bg) 100%)}
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:22px;
}
@media(min-width:1100px){
  .services-grid{grid-template-columns:repeat(4,1fr)}
}
.service{
  position:relative;
  padding:36px 28px 32px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(17,24,39,.7), rgba(11,11,15,.7));
  border:1px solid var(--line);
  overflow:hidden;
  transition:border-color .4s, transform .4s;
  isolation:isolate;
}
.service::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 400px 200px at 50% 0%, rgba(124,58,237,.18), transparent 70%);
  opacity:0;transition:opacity .5s;z-index:-1;
}
.service::after{
  content:"";position:absolute;inset:-1px;border-radius:18px;
  background:linear-gradient(135deg, transparent, var(--gold) 50%, transparent);
  opacity:0;transition:opacity .5s;z-index:-2;
}
.service:hover{transform:translateY(-4px);border-color:transparent}
.service:hover::before{opacity:1}
.service:hover::after{opacity:.4}

.service .icon{
  width:54px;height:54px;
  display:grid;place-items:center;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(212,175,55,.15), rgba(124,58,237,.1));
  border:1px solid var(--line);
  margin-bottom:24px;
  color:var(--gold);
}
.service h3{
  font-family:var(--display);font-weight:500;
  font-size:21px;line-height:1.2;margin-bottom:14px;
  letter-spacing:.005em;
}
.service p{
  font-size:15px;color:#bcbcb4;font-weight:300;line-height:1.6;
  margin-bottom:22px;
}
.service-link{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--gold-soft);text-decoration:none;
  font-size:13px;font-weight:500;letter-spacing:.04em;
}
.service-link svg{transition:transform .3s}
.service-link:hover svg{transform:translateX(4px)}

.master{background:#08090F}
.master-grid{
  display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center;
}
.master-portrait{
  position:relative;aspect-ratio:4/5;
  border-radius:8px;overflow:hidden;
  border:1px solid var(--line-strong);
  background:
    radial-gradient(ellipse at 50% 30%, rgba(124,58,237,.4), transparent 60%),
    linear-gradient(180deg, #1a1525, #0a0a14);
  display:grid;place-items:center;
}
.master-portrait::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(11,11,15,.95));
  z-index:2;
}
.master-portrait .sigil-overlay{
  position:absolute;inset:0;opacity:.25;
  background-image:
    radial-gradient(circle at 50% 50%, transparent 38%, var(--gold) 38.5%, transparent 39%),
    radial-gradient(circle at 50% 50%, transparent 24%, var(--gold-soft) 24.4%, transparent 24.8%);
}
.master-portrait .placeholder-note{
  position:relative;z-index:3;text-align:center;color:var(--gold-soft);
  font-family:var(--display);font-size:13px;letter-spacing:.3em;
  padding:0 20px;
  opacity:.6;
  display:grid;place-items:center;width:100%;height:100%;
}
.master-portrait .master-photo{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) brightness(.88);
  mix-blend-mode:luminosity;
}
.master-portrait::after{
  content:"";position:absolute;inset:0;z-index:4;pointer-events:none;
  background:linear-gradient(180deg, transparent 0%, transparent 50%, rgba(11,11,15,.4) 100%),
             radial-gradient(ellipse at center, transparent 40%, rgba(11,11,15,.5) 100%);
}
.master-portrait .frame{
  position:absolute;inset:14px;border:1px solid var(--gold);opacity:.4;z-index:2;
  pointer-events:none;
}
.master-portrait .frame::before,
.master-portrait .frame::after{
  content:"";position:absolute;width:14px;height:14px;
  border:2px solid var(--gold);
}
.master-portrait .frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.master-portrait .frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}

.master-content .kicker{text-align:left}
.master-content h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(28px,3.6vw,42px);line-height:1.12;
  margin-bottom:24px;
}
.master-content h2 .italic{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-weight:400}
.master-content p{
  font-size:16px;line-height:1.75;color:#c5c5be;font-weight:300;
  margin-bottom:18px;
}
.master-content p strong{color:var(--white);font-weight:500}

.master-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin:36px 0;padding:28px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.master-stats .s{text-align:left}
.master-stats .num{font-family:var(--display);color:var(--gold);font-size:30px;display:block;line-height:1}
.master-stats .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-top:8px;display:block}

@media(max-width:880px){
  .master-grid{grid-template-columns:1fr;gap:48px}
  .master-portrait{max-width:380px;margin:0 auto;width:100%}
}

.process{background:var(--bg)}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;margin-top:48px;
}
.process-steps::before{
  content:"";position:absolute;top:42px;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:.4;
}
.step{
  text-align:center;padding:0 18px;position:relative;
}
.step .n{
  width:84px;height:84px;border-radius:50%;
  background:radial-gradient(circle, var(--bg-3), var(--bg));
  border:1px solid var(--line-strong);
  display:grid;place-items:center;margin:0 auto 26px;
  font-family:var(--display);font-size:24px;color:var(--gold);
  position:relative;z-index:2;
  box-shadow:0 0 0 8px var(--bg), 0 0 32px -8px rgba(212,175,55,.4);
  animation:breathe 5s ease-in-out infinite;
}
.step:nth-child(2) .n{animation-delay:.5s}
.step:nth-child(3) .n{animation-delay:1s}
.step:nth-child(4) .n{animation-delay:1.5s}

.step h4{
  font-family:var(--display);font-weight:500;font-size:18px;
  margin-bottom:12px;
}
.step p{font-size:14px;color:#b0b0a8;font-weight:300;line-height:1.55}

@media(max-width:760px){
  .process-steps{grid-template-columns:1fr;gap:36px}
  .process-steps::before{display:none}
}

.testimonials{background:linear-gradient(180deg, var(--bg) 0%, #0a0e1a 100%)}
.testi-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;
}
.testi{
  padding:34px 30px;border-radius:14px;
  background:rgba(17,24,39,.45);
  border:1px solid var(--line);
  position:relative;
  transition:border-color .3s, transform .3s;
}
.testi:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.testi .quote-mark{
  font-family:var(--serif);font-size:60px;line-height:1;color:var(--gold);opacity:.4;
  display:block;margin-bottom:-8px;
}
.testi p{
  font-family:var(--serif);font-size:17px;line-height:1.55;font-weight:300;font-style:italic;
  color:#d6d6d0;margin-bottom:24px;
}
.testi .who{
  display:flex;align-items:center;gap:14px;padding-top:18px;
  border-top:1px solid var(--line);
}
.testi .avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg, var(--violet), var(--gold-deep));
  display:grid;place-items:center;
  font-family:var(--display);font-size:14px;color:#0a0a14;font-weight:600;
}
.testi .who-info span{display:block}
.testi .who-info .name{font-weight:500;font-size:14px;color:var(--white)}
.testi .who-info .loc{font-size:12px;color:var(--mute);letter-spacing:.04em;margin-top:2px}
.testi .stars{color:var(--gold);font-size:13px;letter-spacing:.15em;margin-bottom:14px}

.faq-list{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:none;color:var(--white);
  font-family:var(--body);font-weight:500;font-size:17px;
  padding:26px 0;text-align:left;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  letter-spacing:.005em;
}
.faq-q .plus{
  width:30px;height:30px;border:1px solid var(--line-strong);
  border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  transition:transform .35s, border-color .35s, background .35s;color:var(--gold);
  font-size:14px;
}
.faq-item.open .plus{transform:rotate(45deg);background:rgba(212,175,55,.1);border-color:var(--gold)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .45s ease, padding .35s ease;
}
.faq-item.open .faq-a{max-height:400px;padding-bottom:26px}
.faq-a p{
  font-family:var(--serif);font-size:17px;line-height:1.7;color:#c5c5be;font-weight:300;
}

.cta-final{
  background:radial-gradient(ellipse 1000px 500px at 50% 50%, rgba(124,58,237,.18), transparent 70%), #08080d;
  text-align:center;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:140px 24px;
}
.cta-final h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(34px,5vw,64px);line-height:1.05;
  max-width:880px;margin:0 auto 28px;
}
.cta-final h2 .italic{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-weight:400}
.cta-final .lede{margin-bottom:44px}
.cta-final .btn-wa{font-size:17px;padding:22px 38px}
.cta-final .note{
  margin-top:24px;font-size:13px;color:var(--mute);letter-spacing:.06em;
}

footer{padding:60px 24px 36px;background:#06070b;border-top:1px solid var(--line)}
.foot-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;
  max-width:var(--max);margin:0 auto 36px;
}
.foot-brand .brand{margin-bottom:18px}
.foot-brand p{font-size:14px;color:#9a9a92;font-weight:300;max-width:380px;line-height:1.65}
.foot-col h5{
  font-family:var(--display);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:18px;
}
.foot-col a, .foot-col p{
  display:block;font-size:13px;color:#9a9a92;text-decoration:none;
  margin-bottom:10px;transition:color .2s;line-height:1.6;
}
.foot-col a:hover{color:var(--white)}
.foot-bottom{
  border-top:1px solid var(--line);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:14px;
  max-width:var(--max);margin:0 auto;
  font-size:12px;color:var(--mute);letter-spacing:.04em;
}
@media(max-width:980px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr;gap:36px}}
@media(max-width:560px){.foot-bottom{flex-direction:column;text-align:center}}

.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:60;
  width:62px;height:62px;border-radius:50%;
  background:linear-gradient(135deg, #25D366, #128C7E);
  display:grid;place-items:center;
  box-shadow:0 0 0 4px rgba(37,211,102,.15), 0 18px 36px -8px rgba(37,211,102,.55);
  text-decoration:none;color:#fff;
  transition:transform .25s;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid #25D366;opacity:.6;animation:pulseRing 2.5s ease-out infinite;
}
@keyframes pulseRing{
  0%{transform:scale(.85);opacity:.6}
  100%{transform:scale(1.45);opacity:0}
}
.wa-float svg{width:30px;height:30px}

.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s, transform 1s}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger>*{opacity:0;transform:translateY(30px);transition:opacity .8s, transform .8s}
.reveal-stagger.in>*{opacity:1;transform:translateY(0)}
.reveal-stagger.in>*:nth-child(1){transition-delay:.05s}
.reveal-stagger.in>*:nth-child(2){transition-delay:.15s}
.reveal-stagger.in>*:nth-child(3){transition-delay:.25s}
.reveal-stagger.in>*:nth-child(4){transition-delay:.35s}
.reveal-stagger.in>*:nth-child(5){transition-delay:.45s}
.reveal-stagger.in>*:nth-child(6){transition-delay:.55s}

@media(max-width:640px){
  section{padding:88px 20px}
  .hero{padding:120px 20px 80px}
  .hero-meta{gap:28px}
  .cta-final{padding:96px 20px}
}

/* === Estilos adicionales para páginas internas === */

/* Breadcrumb */
.breadcrumb{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:#7a7a82;margin-bottom:24px;
}
.breadcrumb a{color:var(--gold-soft);text-decoration:none}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{margin:0 10px;opacity:.5}

/* Hero interno (más corto que el del index) */
.hero-inner{
  position:relative;z-index:2;
  padding:160px 24px 80px;
  min-height:auto;
}
.hero-inner .wrap{max-width:960px;margin:0 auto;text-align:center}
.hero-inner h1{
  font-family:var(--display);font-weight:500;
  font-size:clamp(36px,5.5vw,68px);line-height:1.05;
  letter-spacing:.005em;margin-bottom:24px;
}
.hero-inner h1 .italic{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--gold-soft);
}
.hero-inner .lede{
  font-size:clamp(16px,1.3vw,19px);color:#cfcfca;font-weight:300;
  max-width:680px;margin:0 auto 40px;line-height:1.6;
}
.hero-inner .cta-row{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
}

/* Contenido largo (artículos, legal, descripciones largas) */
.content-block{
  max-width:780px;margin:0 auto;
}
.content-block h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(26px,3vw,36px);line-height:1.15;
  margin:48px 0 20px;letter-spacing:.005em;
}
.content-block h2:first-child{margin-top:0}
.content-block h3{
  font-family:var(--display);font-weight:500;
  font-size:22px;line-height:1.2;
  margin:36px 0 14px;color:var(--gold-soft);
}
.content-block p{
  font-size:16px;color:#cfcfca;font-weight:300;line-height:1.75;
  margin-bottom:18px;
}
.content-block p strong{color:var(--white);font-weight:500}
.content-block ul, .content-block ol{
  margin:0 0 24px 0;padding-left:0;list-style:none;
}
.content-block ul li, .content-block ol li{
  font-size:16px;color:#cfcfca;font-weight:300;line-height:1.7;
  padding-left:28px;margin-bottom:10px;position:relative;
}
.content-block ul li::before{
  content:"✦";position:absolute;left:0;top:0;
  color:var(--gold);font-size:14px;
}
.content-block ol{counter-reset:n}
.content-block ol li{counter-increment:n}
.content-block ol li::before{
  content:counter(n);position:absolute;left:0;top:0;
  width:20px;height:20px;display:grid;place-items:center;
  background:linear-gradient(135deg, var(--gold), var(--gold-deep));
  color:#0B0B0F;font-size:11px;font-weight:600;border-radius:50%;
  font-family:var(--body);
}

/* Highlight box (casos donde aplica) */
.highlight-box{
  margin:36px 0;
  padding:32px 30px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(124,58,237,.08), rgba(212,175,55,.04));
  border:1px solid var(--line);
  position:relative;overflow:hidden;
}
.highlight-box::before{
  content:"";position:absolute;inset:-1px;border-radius:18px;
  background:linear-gradient(135deg, transparent, var(--gold-soft) 50%, transparent);
  opacity:.15;z-index:-1;
}
.highlight-box .kicker{
  display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;font-weight:600;
}
.highlight-box h4{
  font-family:var(--display);font-weight:500;
  font-size:20px;line-height:1.25;margin-bottom:16px;
}
.highlight-box ul li{padding-left:24px}
.highlight-box ul li::before{content:"→";color:var(--gold-soft)}

/* Cross-sell (otros servicios) */
.cross-sell{
  background:linear-gradient(180deg, var(--bg) 0%, #0a0e1a 50%, var(--bg) 100%);
}
.cross-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;
}
@media(min-width:900px){
  .cross-grid{grid-template-columns:repeat(4,1fr)}
}
.cross-card{
  padding:24px 22px;
  border-radius:14px;
  background:rgba(17,24,39,.5);
  border:1px solid var(--line);
  text-decoration:none;color:inherit;
  transition:border-color .3s, transform .3s;
  display:block;
}
.cross-card:hover{
  border-color:var(--line-strong);
  transform:translateY(-3px);
}
.cross-card .icon{
  width:38px;height:38px;display:grid;place-items:center;
  border-radius:10px;color:var(--gold);
  background:linear-gradient(135deg, rgba(212,175,55,.12), rgba(124,58,237,.08));
  border:1px solid var(--line);margin-bottom:14px;
}
.cross-card h4{
  font-family:var(--display);font-weight:500;
  font-size:15px;line-height:1.25;margin-bottom:6px;
}
.cross-card p{
  font-size:13px;color:#9a9a92;font-weight:300;line-height:1.5;
}

/* Mobile nav toggle */
.nav-toggle{
  display:none;
  background:none;border:1px solid var(--line);
  width:40px;height:40px;border-radius:10px;
  color:var(--gold);cursor:pointer;
  align-items:center;justify-content:center;
}
@media(max-width:760px){
  .nav-toggle{display:flex}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:rgba(11,11,15,.98);
    padding:24px;flex-direction:column;gap:18px;
    border-top:1px solid var(--line);
  }
  .nav-links.open{display:flex}
}

/* Footer extendido */
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:40px;
  border-bottom:1px solid var(--line);
}
@media(max-width:880px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:520px){
  .footer-grid{grid-template-columns:1fr}
}
.footer-col h5{
  font-family:var(--display);font-weight:500;font-size:14px;
  color:var(--gold-soft);letter-spacing:.04em;
  margin-bottom:18px;text-transform:uppercase;
}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{
  color:#9a9a92;text-decoration:none;font-size:14px;font-weight:300;
  transition:color .3s;
}
.footer-col ul li a:hover{color:var(--gold-soft)}
.footer-brand-text{
  font-size:14px;color:#9a9a92;font-weight:300;line-height:1.7;
  margin-top:14px;max-width:280px;
}
.footer-bottom{
  padding-top:30px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
  font-size:12px;color:#7a7a82;
}
.footer-bottom a{color:#9a9a92;text-decoration:none;margin:0 8px}
.footer-bottom a:hover{color:var(--gold-soft)}
.legal-disclaimer{
  font-size:11px;color:#5a5a62;font-weight:300;line-height:1.6;
  max-width:880px;margin:24px auto 0;text-align:center;
  padding-top:20px;border-top:1px solid rgba(212,175,55,.08);
}


/* =====================================================
   📱 OPTIMIZACIONES MOBILE COMPLETAS
   ===================================================== */

/* Tablet (≤960px) */
@media (max-width: 960px) {
  .hero-inner {
    padding: 130px 22px 60px;
  }
  .hero-inner h1 {
    font-size: clamp(30px, 5.5vw, 48px);
  }
  .content-block h2 {
    font-size: clamp(24px, 4vw, 32px);
  }
}

/* Mobile (≤640px) */
@media (max-width: 640px) {
  /* Hero pages internas */
  .hero-inner {
    padding: 100px 18px 50px;
    background-position: center center !important;
    background-attachment: scroll;
    /* Reforzar el gradiente oscuro en mobile para mejor contraste */
  }
  .hero-inner .wrap {
    text-align: center;
  }
  .hero-inner h1 {
    font-size: clamp(26px, 7vw, 36px);
    line-height: 1.1;
  }
  .hero-inner .lede {
    font-size: 15px;
    line-height: 1.55;
    margin-bottom: 28px;
  }
  .hero-inner .cta-row {
    flex-direction: column;
    gap: 12px;
    align-items: stretch;
  }
  .hero-inner .cta-row .btn-wa,
  .hero-inner .cta-row .btn-ghost {
    width: 100%;
    justify-content: center;
  }

  /* Breadcrumb más chico */
  .breadcrumb {
    font-size: 10px;
    letter-spacing: 0.14em;
    margin-bottom: 18px;
  }
  .breadcrumb span {
    margin: 0 6px;
  }

  /* Contenido largo más legible */
  .content-block h2 {
    font-size: clamp(22px, 5vw, 28px);
    margin: 36px 0 16px;
  }
  .content-block h3 {
    font-size: 18px;
    margin: 28px 0 12px;
  }
  .content-block p {
    font-size: 15px;
    line-height: 1.7;
  }
  .content-block ul li,
  .content-block ol li {
    font-size: 15px;
    padding-left: 24px;
  }

  /* Highlight box compacto */
  .highlight-box {
    padding: 24px 20px;
    margin: 28px 0;
  }
  .highlight-box h4 {
    font-size: 17px;
  }

  /* Process steps en mobile - 1 columna apilada */
  .process-steps {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }

  /* Cross-sell cards más compactas */
  .cross-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  .cross-card {
    padding: 18px 16px;
  }
  .cross-card h4 {
    font-size: 14px;
  }
  .cross-card p {
    font-size: 12px;
  }

  /* Footer mobile más respirado */
  .foot-grid {
    gap: 28px;
    margin-bottom: 28px;
  }

  /* WhatsApp float más pequeño en mobile */
  .wa-float {
    width: 56px;
    height: 56px;
    bottom: 18px;
    right: 18px;
  }
}

/* Mobile chico (≤400px) — celulares antiguos/baratos */
@media (max-width: 400px) {
  .hero-inner {
    padding: 90px 14px 40px;
  }
  .hero-inner h1 {
    font-size: 24px;
  }
  .hero-inner .lede {
    font-size: 14px;
  }
  .cross-grid {
    grid-template-columns: 1fr;
  }
  section {
    padding: 60px 14px;
  }
}

/* Optimización para imágenes de fondo en mobile */
@media (max-width: 640px) {
  .hero-inner {
    /* Asegurar que el degradado mantenga buena legibilidad sobre cualquier imagen */
    background-blend-mode: normal;
  }
}

/* Foto del maestro responsive */
.master-portrait picture {
  position: absolute;
  inset: 0;
  z-index: 3;
}
@media (max-width: 880px) {
  .master-portrait {
    max-width: 340px;
    aspect-ratio: 3/4;
  }
  .master-portrait .master-photo {
    object-position: center top;
  }
}

