/* =====================================================
   Migrate to Paraguay — cinematic premium stylesheet
   ===================================================== */

:root{
  /* palette */
  --ink:        #0a1a1f;
  --ink-2:      #0c2026;
  --ink-3:      #0f272e;
  --panel:      #102b33;
  --panel-2:    #143640;
  --gold:       #d9b76a;
  --gold-bright:#f1d99a;
  --gold-deep:  #b8883b;
  --red:        #c0533f;
  --text:       #eef3f1;
  --muted:      #9db0ac;
  --muted-2:    #7e918d;
  --line:       rgba(233,220,190,.14);
  --line-soft:  rgba(233,220,190,.08);

  --grad-gold: linear-gradient(135deg,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  --shadow:    0 24px 60px -20px rgba(0,0,0,.55);
  --shadow-sm: 0 10px 30px -12px rgba(0,0,0,.5);

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --container: 1200px;
  --radius:    18px;
  --radius-sm: 12px;
  --ease:      cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset / base ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--text);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.08; letter-spacing:-.01em; }
::selection{ background:var(--gold); color:var(--ink); }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 28px; }
.section{ padding:clamp(72px,9vw,140px) 0; position:relative; }

/* ---------- typography helpers ---------- */
.kicker{
  display:inline-block;
  font-family:var(--sans);
  font-size:.78rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
.section-head{ max-width:760px; margin:0 auto clamp(44px,5vw,72px); text-align:center; }
.section-head--left{ margin-left:0; text-align:left; }
.section-title{ font-size:clamp(1.9rem,4.2vw,3.2rem); }
.section-lead{ color:var(--muted); font-size:1.08rem; margin-top:20px; }
.section-head .accent{ color:var(--gold); }

/* ---------- buttons ---------- */
.btn{
  --pad:13px 22px;
  display:inline-flex; align-items:center; gap:10px;
  padding:var(--pad);
  font-family:var(--sans); font-size:.96rem; font-weight:600;
  border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s, border-color .25s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; transition:transform .3s var(--ease); }
.btn--primary{ background:var(--grad-gold); color:#1a1205; box-shadow:0 10px 30px -10px rgba(217,183,106,.6); }
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 16px 40px -10px rgba(217,183,106,.75); }
.btn--primary:hover svg{ transform:translateX(4px); }
.btn--ghost{ background:rgba(255,255,255,.04); color:var(--text); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-2px); }
.btn--lg{ --pad:16px 30px; font-size:1.02rem; }
.btn--block{ width:100%; justify-content:center; }

/* ---------- header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding:18px 0;
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(8,20,24,.82);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  padding:11px 0;
  border-bottom-color:var(--line-soft);
}
.site-header.is-static{ position:sticky; background:rgba(8,20,24,.92); backdrop-filter:blur(16px) saturate(140%); -webkit-backdrop-filter:blur(16px) saturate(140%); padding:11px 0; border-bottom-color:var(--line-soft); }
.nav{ display:flex; align-items:center; gap:20px; }
.logo{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.logo-mark{ width:40px; height:40px; }
.logo-text{ display:flex; flex-direction:column; line-height:1; font-family:var(--serif); }
.logo-line1{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-family:var(--sans); font-weight:600; }
.logo-line2{ font-size:1.32rem; color:var(--text); margin-top:3px; }

.primary-nav{ margin-left:auto; }
.nav-links{ display:flex; gap:2px; }
.nav-links a{
  display:block; padding:8px 11px; border-radius:999px;
  font-size:.92rem; font-weight:500; color:var(--muted); white-space:nowrap;
  transition:color .2s, background .2s;
}
.nav-links a:hover{ color:var(--text); background:rgba(255,255,255,.05); }

.nav-actions{ display:flex; align-items:center; gap:14px; }

/* language selector */
.lang-select{ position:relative; }
.lang-toggle{
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.04); border:1px solid var(--line);
  color:var(--text); padding:8px 12px; border-radius:999px; cursor:pointer;
  font-family:var(--sans); font-size:.86rem; font-weight:600;
  transition:border-color .2s, background .2s;
}
.lang-toggle:hover{ border-color:var(--gold); }
.lang-toggle svg{ width:16px; height:16px; }
.lang-toggle .chev{ width:14px; height:14px; opacity:.7; transition:transform .25s; }
.lang-toggle[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; top:calc(100% + 10px); right:0; min-width:170px;
  background:var(--panel); border:1px solid var(--line); border-radius:14px;
  padding:6px; box-shadow:var(--shadow); display:none; flex-direction:column; gap:2px;
}
.lang-menu.open{ display:flex; animation:pop .2s var(--ease); }
@keyframes pop{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }
.lang-menu button{
  display:flex; align-items:center; gap:11px;
  background:none; border:0; color:var(--text); cursor:pointer;
  padding:10px 12px; border-radius:9px; font-family:var(--sans); font-size:.92rem; text-align:left;
  transition:background .15s;
}
.lang-menu button:hover{ background:rgba(255,255,255,.06); }
.lang-menu button.is-active{ color:var(--gold-bright); }
.flag{ width:20px; height:14px; border-radius:3px; flex-shrink:0; box-shadow:0 0 0 1px rgba(255,255,255,.15); background-size:cover; }
.flag-en{ background:linear-gradient(180deg,#012169 0 33%,#fff 33% 66%,#c8102e 66%); }
.flag-es{ background:linear-gradient(180deg,#aa151b 0 27%,#f1bf00 27% 73%,#aa151b 73%); }
.flag-nl{ background:linear-gradient(180deg,#ae1c28 0 33%,#fff 33% 66%,#21468b 66%); }

/* hamburger */
.nav-toggle{ display:none; flex-direction:column; gap:5px; width:42px; height:42px; align-items:center; justify-content:center; background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:12px; cursor:pointer; }
.nav-toggle span{ width:20px; height:2px; background:var(--text); border-radius:2px; transition:transform .3s var(--ease), opacity .2s; }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding:140px 0 96px;
  overflow:hidden;
}
.hero-media{ position:absolute; inset:0; z-index:0; background:var(--ink) center/cover no-repeat url("assets/img/river-landscape.jpg"); }
.hero-video{ width:100%; height:100%; object-fit:cover; }
.hero-scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,18,22,.78) 0%, rgba(8,18,22,.45) 32%, rgba(8,18,22,.55) 62%, var(--ink) 100%),
    radial-gradient(120% 80% at 18% 30%, rgba(8,18,22,.6), transparent 60%);
}
.hero-inner{ position:relative; z-index:2; max-width:860px; margin:0 auto; text-align:center; }
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.06); border:1px solid var(--line);
  padding:8px 16px 8px 12px; border-radius:999px;
  font-size:.84rem; font-weight:500; color:#e7ece9; backdrop-filter:blur(6px);
}
.eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 4px rgba(217,183,106,.25); animation:pulse 2.4s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 3px rgba(217,183,106,.25); } 50%{ box-shadow:0 0 0 7px rgba(217,183,106,0); } }
.hero-title{ font-size:clamp(2.6rem,7vw,5.4rem); margin:24px 0 0; }
.hero-title span{ display:block; }
.hero-title .accent{ background:var(--grad-gold); -webkit-background-clip:text; background-clip:text; color:transparent; font-style:italic; line-height:1.22; padding-bottom:.14em; text-align:center; }
.hero-sub{ font-size:clamp(1.05rem,1.6vw,1.32rem); color:#d4ddd9; max-width:620px; margin:26px auto 0; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; justify-content:center; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:14px 26px; margin-top:40px; justify-content:center; }
.hero-trust li{ display:flex; align-items:center; gap:9px; font-size:.92rem; color:#cdd7d3; }
.hero-trust svg{ width:18px; height:18px; color:var(--gold); flex-shrink:0; }

.hero-scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:7px;
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
}
.hero-scroll svg{ width:20px; height:20px; color:var(--gold); animation:bob 2s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(6px); } }

/* ---------- stats ---------- */
.stats{ padding:0; margin-top:-2px; }
.stats-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  background:linear-gradient(180deg,var(--ink-3),var(--ink-2));
  transform:translateY(-44px);
  box-shadow:var(--shadow);
}
.stat{ padding:34px 26px; text-align:center; border-right:1px solid var(--line-soft); }
.stat:last-child{ border-right:0; }
.stat-num{ display:block; font-family:var(--serif); font-size:clamp(2.1rem,4vw,3rem); color:var(--gold-bright); line-height:1; }
.stat-label{ display:block; margin-top:12px; font-size:.9rem; color:var(--muted); }

/* ---------- why ---------- */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.feature{
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:32px 28px; transition:transform .35s var(--ease), border-color .35s, background .35s;
}
.feature:hover{ transform:translateY(-5px); border-color:rgba(217,183,106,.4); background:linear-gradient(180deg,rgba(217,183,106,.07),rgba(255,255,255,.02)); }
.feature-ico{ display:inline-flex; width:54px; height:54px; align-items:center; justify-content:center; border-radius:14px; background:rgba(217,183,106,.12); border:1px solid rgba(217,183,106,.28); color:var(--gold-bright); margin-bottom:20px; }
.feature-ico svg{ width:26px; height:26px; }
.feature h3{ font-size:1.3rem; margin-bottom:10px; }
.feature p{ color:var(--muted); font-size:.98rem; }

/* ---------- life / gallery ---------- */
.life{ background:linear-gradient(180deg,var(--ink),var(--ink-2)); }
.gallery{
  display:grid; gap:14px; padding:0 28px; max-width:1320px; margin:0 auto;
  grid-template-columns:repeat(4,1fr); grid-auto-rows:200px;
}
.g-item{ position:relative; overflow:hidden; border-radius:var(--radius); border:1px solid var(--line); }
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.g-item:hover img{ transform:scale(1.06); }
.g-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%,rgba(6,14,17,.82)); }
.g-item figcaption{ position:absolute; left:18px; bottom:14px; z-index:2; font-family:var(--serif); font-size:1.05rem; color:#fff; letter-spacing:.01em; }
.g-tall{ grid-row:span 2; }
.g-wide{ grid-column:span 2; }

/* ---------- services ---------- */
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.service{
  position:relative; border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px; background:rgba(255,255,255,.02); overflow:hidden;
  transition:transform .35s var(--ease), border-color .35s;
}
.service::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--grad-gold); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.service:hover{ transform:translateY(-5px); border-color:rgba(217,183,106,.4); }
.service:hover::before{ transform:scaleX(1); }
.service-ico{ display:inline-flex; width:50px; height:50px; align-items:center; justify-content:center; border-radius:13px; background:rgba(255,255,255,.05); border:1px solid var(--line); color:var(--gold-bright); margin-bottom:18px; }
.service-ico svg{ width:25px; height:25px; }
.service h3{ font-size:1.28rem; margin-bottom:10px; }
.service p{ color:var(--muted); font-size:.97rem; }

/* ---------- process ---------- */
.process{ overflow:hidden; }
.process-bg{ position:absolute; inset:0; z-index:0; }
.process-bg img{ width:100%; height:100%; object-fit:cover; opacity:.16; }
.process .container{ position:relative; z-index:1; }
.timeline{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; counter-reset:step; position:relative; }
.timeline::before{ content:""; position:absolute; top:34px; left:6%; right:6%; height:1px; background:linear-gradient(90deg,transparent,var(--line),transparent); z-index:0; }
.step{ position:relative; padding-top:80px; }
.step-num{
  position:absolute; top:0; left:0;
  display:inline-flex; width:64px; height:64px; align-items:center; justify-content:center;
  border-radius:50%; background:var(--ink-3); border:1px solid rgba(217,183,106,.4);
  font-family:var(--serif); font-size:1.2rem; color:var(--gold-bright);
  box-shadow:0 0 0 6px var(--ink);
}
.step h3{ font-size:1.18rem; margin-bottom:8px; }
.step p{ color:var(--muted); font-size:.94rem; }

/* ---------- audiences ---------- */
.aud-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.aud-card{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:var(--ink-2); transition:transform .35s var(--ease); }
.aud-card:hover{ transform:translateY(-5px); }
.aud-media{ aspect-ratio:4/3; overflow:hidden; }
.aud-media img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.aud-card:hover .aud-media img{ transform:scale(1.07); }
.aud-body{ padding:22px 22px 26px; }
.aud-body h3{ font-size:1.22rem; margin-bottom:8px; }
.aud-body p{ color:var(--muted); font-size:.94rem; }

/* ---------- trust / testimonials ---------- */
.trust{ background:linear-gradient(180deg,var(--ink-2),var(--ink)); }
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testi{ border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; background:rgba(255,255,255,.025); }
.stars{ color:var(--gold); letter-spacing:3px; font-size:1.05rem; margin-bottom:16px; }
.testi blockquote{ font-family:var(--serif); font-size:1.18rem; line-height:1.45; color:#e9efec; font-style:italic; }
.testi figcaption{ display:flex; align-items:center; gap:13px; margin-top:22px; }
.avatar{ width:46px; height:46px; border-radius:50%; flex-shrink:0; background:var(--grad-gold); color:#1a1205; display:inline-flex; align-items:center; justify-content:center; font-weight:700; font-size:.9rem; font-family:var(--sans); }
.avatar::after{ content:attr(data-initials); }
.who{ display:flex; flex-direction:column; line-height:1.3; }
.who strong{ font-weight:600; }
.who span{ font-size:.86rem; color:var(--muted); }

/* ---------- pricing ---------- */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
.plan{
  position:relative; border:1px solid var(--line); border-radius:var(--radius);
  padding:36px 30px; background:rgba(255,255,255,.02); display:flex; flex-direction:column;
  transition:transform .35s var(--ease), border-color .35s;
}
.plan:hover{ transform:translateY(-5px); border-color:rgba(217,183,106,.35); }
.plan--featured{ background:linear-gradient(180deg,rgba(217,183,106,.1),rgba(255,255,255,.02)); border-color:rgba(217,183,106,.5); box-shadow:var(--shadow); }
.plan-badge{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--grad-gold); color:#1a1205; font-size:.74rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:6px 16px; border-radius:999px; white-space:nowrap; }
.plan-name{ font-size:1.5rem; }
.plan-desc{ color:var(--muted); font-size:.94rem; margin-top:8px; min-height:42px; }
.plan-price{ margin:20px 0 6px; display:flex; align-items:baseline; gap:4px; }
.plan-price .cur{ font-size:1.05rem; color:var(--muted); }
.plan-price .amt{ font-family:var(--serif); font-size:2.8rem; color:var(--text); }
.plan-feats{ margin:18px 0 26px; display:flex; flex-direction:column; gap:12px; flex-grow:1; }
.plan-feats li{ position:relative; padding-left:28px; font-size:.95rem; color:#d3ddd9; }
.plan-feats li::before{ content:""; position:absolute; left:0; top:6px; width:15px; height:8px; border-left:2px solid var(--gold); border-bottom:2px solid var(--gold); transform:rotate(-45deg); }
.price-note{ text-align:center; color:var(--muted); margin-top:30px; font-size:.96rem; }

/* ---------- faq ---------- */
.faq-wrap{ display:grid; grid-template-columns:1fr 1.3fr; gap:clamp(40px,6vw,90px); align-items:start; }
.faq .section-head{ position:sticky; top:120px; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.qa{ border:1px solid var(--line); border-radius:var(--radius-sm); background:rgba(255,255,255,.025); overflow:hidden; }
.qa summary{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:22px 24px; cursor:pointer; font-weight:600; font-size:1.05rem; list-style:none; }
.qa summary::-webkit-details-marker{ display:none; }
.qa-ico{ position:relative; flex-shrink:0; width:20px; height:20px; }
.qa-ico::before,.qa-ico::after{ content:""; position:absolute; background:var(--gold); border-radius:2px; transition:transform .3s var(--ease); }
.qa-ico::before{ top:9px; left:0; width:20px; height:2px; }
.qa-ico::after{ left:9px; top:0; width:2px; height:20px; }
.qa[open] .qa-ico::after{ transform:scaleY(0); }
.qa-body{ padding:0 24px 24px; color:var(--muted); }
.qa-body p{ max-width:60ch; }

/* ---------- contact ---------- */
.contact{ overflow:hidden; }
.contact-bg{ position:absolute; inset:0; z-index:0; }
.contact-bg img{ width:100%; height:100%; object-fit:cover; opacity:.18; }
.contact-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,var(--ink),rgba(10,26,31,.7)); }
.contact .container{ position:relative; z-index:1; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,72px); align-items:center; }
.contact-points{ display:flex; flex-direction:column; gap:14px; margin-top:30px; }
.contact-points li{ display:flex; align-items:center; gap:12px; color:#d3ddd9; }
.contact-points svg{ width:20px; height:20px; color:var(--gold); flex-shrink:0; }

.contact-form{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,3vw,40px); box-shadow:var(--shadow); }
.field{ margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field label{ display:block; font-size:.85rem; font-weight:600; color:var(--muted); margin-bottom:8px; }
.field input,.field select,.field textarea{
  width:100%; padding:13px 15px; border-radius:11px;
  background:rgba(0,0,0,.25); border:1px solid var(--line); color:var(--text);
  font-family:var(--sans); font-size:.98rem; transition:border-color .2s, background .2s;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); background:rgba(0,0,0,.35); }
.field input.invalid,.field textarea.invalid{ border-color:var(--red); }
.field select option{ background:var(--panel); color:var(--text); }
.form-success{ margin-top:16px; padding:14px 16px; border-radius:11px; background:rgba(217,183,106,.14); border:1px solid rgba(217,183,106,.4); color:var(--gold-bright); font-size:.94rem; }
.form-note{ margin-top:16px; font-size:.82rem; color:var(--muted-2); text-align:center; }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); background:var(--ink-2); padding:64px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer-tag{ color:var(--muted); margin-top:18px; max-width:32ch; font-size:.95rem; }
.logo--footer .logo-mark{ width:44px; height:44px; }
.footer-col h4{ font-family:var(--sans); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer-col a,.footer-col span,.footer-lang{ display:block; color:var(--muted); font-size:.95rem; margin-bottom:11px; transition:color .2s; background:none; border:0; text-align:left; cursor:pointer; font-family:var(--sans); padding:0; }
.footer-col a:hover,.footer-lang:hover{ color:var(--gold-bright); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; margin-top:50px; padding-top:24px; border-top:1px solid var(--line-soft); color:var(--muted-2); font-size:.86rem; }
.footer-legal{ display:flex; gap:22px; }
.footer-legal a:hover{ color:var(--gold-bright); }
.footer-social{ display:flex; gap:10px; margin-top:22px; }
.footer-social a{ display:inline-flex; width:40px; height:40px; align-items:center; justify-content:center; border-radius:11px; border:1px solid var(--line); color:var(--muted); transition:color .2s, border-color .2s, transform .2s, background .2s; }
.footer-social a:hover{ color:var(--gold-bright); border-color:rgba(217,183,106,.5); background:rgba(217,183,106,.06); transform:translateY(-2px); }
.footer-social svg{ width:20px; height:20px; }

/* ---------- follow / social section ---------- */
.follow{ background:linear-gradient(180deg,var(--ink),var(--ink-2)); }
.channels{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:30px; }
.channel{ display:flex; align-items:center; gap:14px; padding:18px 20px; border:1px solid var(--line); border-radius:var(--radius-sm); background:rgba(255,255,255,.025); transition:transform .3s var(--ease), border-color .3s, background .3s; }
.channel:hover{ transform:translateY(-3px); border-color:rgba(217,183,106,.45); background:rgba(217,183,106,.06); }
.channel-ico{ display:inline-flex; width:46px; height:46px; align-items:center; justify-content:center; border-radius:12px; background:rgba(217,183,106,.12); border:1px solid rgba(217,183,106,.28); color:var(--gold-bright); flex-shrink:0; }
.channel-ico svg{ width:24px; height:24px; }
.channel-meta{ display:flex; flex-direction:column; line-height:1.35; min-width:0; }
.channel-meta strong{ font-weight:600; }
.channel-meta span{ font-size:.85rem; color:var(--muted); overflow:hidden; text-overflow:ellipsis; }

.feed{ display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
.feed-tile{ position:relative; aspect-ratio:1; overflow:hidden; border-radius:var(--radius-sm); border:1px solid var(--line); }
.feed-tile img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.feed-tile:hover img{ transform:scale(1.08); }
.feed-tile::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%,rgba(6,14,17,.6)); opacity:0; transition:opacity .3s; }
.feed-tile:hover::after{ opacity:1; }
.feed-badge{ position:absolute; top:8px; right:8px; width:27px; height:27px; display:inline-flex; align-items:center; justify-content:center; border-radius:8px; background:rgba(8,18,22,.55); color:#fff; backdrop-filter:blur(4px); }
.feed-badge svg{ width:15px; height:15px; }
.feed-badge--play{ background:rgba(192,83,63,.82); }
.feed-note{ text-align:center; color:var(--muted); margin-top:24px; font-size:.95rem; }

/* ---------- legal pages ---------- */
.legal-header{ position:sticky; top:0; z-index:50; background:rgba(8,20,24,.9); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--line-soft); }
.legal-header .container{ display:flex; align-items:center; justify-content:space-between; padding-top:15px; padding-bottom:15px; }
.legal-back{ display:inline-flex; align-items:center; gap:8px; color:var(--muted); font-size:.92rem; font-weight:500; }
.legal-back:hover{ color:var(--gold-bright); }
.legal-back svg{ width:18px; height:18px; }
.legal-main{ padding:clamp(44px,7vw,90px) 0 80px; }
.legal{ max-width:800px; margin:0 auto; }
.legal h1{ font-size:clamp(2rem,4.5vw,3rem); margin-bottom:8px; }
.legal .updated{ color:var(--muted-2); font-size:.88rem; margin-bottom:26px; }
.legal-note{ padding:15px 18px; border-radius:12px; background:rgba(192,83,63,.1); border:1px solid rgba(192,83,63,.35); color:#eac6bd; font-size:.9rem; margin-bottom:38px; }
.legal-note strong{ color:#fff; }
.legal h2{ font-size:1.4rem; color:var(--text); margin:38px 0 12px; }
.legal h3{ font-size:1.08rem; color:var(--text); margin:22px 0 8px; }
.legal p,.legal li{ color:var(--muted); margin-bottom:12px; }
.legal ul{ list-style:disc; padding-left:22px; margin-bottom:14px; }
.legal a{ color:var(--gold-bright); text-decoration:underline; }
.legal strong{ color:var(--text); }

/* ---------- tax calculator ---------- */
.hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden; opacity:0; }
.calc{ background:linear-gradient(180deg,var(--ink-2),var(--ink)); }
.calc-card{ display:grid; grid-template-columns:1.15fr 1fr; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:rgba(255,255,255,.02); box-shadow:var(--shadow); }
.calc-inputs{ padding:clamp(26px,3vw,40px); display:flex; flex-direction:column; gap:24px; }
.calc-field label{ display:block; font-size:.85rem; font-weight:600; color:var(--muted); margin-bottom:10px; }
.calc-field input[type="number"]{ width:100%; padding:13px 15px; border-radius:11px; background:rgba(0,0,0,.25); border:1px solid var(--line); color:var(--text); font-family:var(--sans); font-size:1.05rem; }
.calc-field input[type="number"]:focus{ outline:none; border-color:var(--gold); }
.calc-slider-row{ display:flex; align-items:center; gap:14px; }
.calc-slider-row input[type="range"]{ flex:1; accent-color:var(--gold); }
.calc-slider-row span{ font-family:var(--serif); font-size:1.2rem; color:var(--gold-bright); min-width:50px; text-align:right; }
.calc-toggle{ display:flex; gap:8px; }
.calc-toggle button{ flex:1; padding:11px; border-radius:10px; border:1px solid var(--line); background:rgba(255,255,255,.03); color:var(--muted); cursor:pointer; font-family:var(--sans); font-size:.9rem; font-weight:500; transition:border-color .2s, color .2s, background .2s; }
.calc-toggle button.is-active{ border-color:var(--gold); color:var(--gold-bright); background:rgba(217,183,106,.1); }
.calc-result{ padding:clamp(26px,3vw,40px); background:linear-gradient(160deg,rgba(217,183,106,.14),rgba(255,255,255,.02)); display:flex; flex-direction:column; justify-content:center; align-items:flex-start; gap:6px; border-left:1px solid var(--line); }
.calc-result-label{ font-size:.85rem; color:var(--muted); }
.calc-result-num{ font-family:var(--serif); font-size:clamp(2.4rem,5vw,3.4rem); color:var(--gold-bright); line-height:1; }
.calc-breakdown{ display:flex; gap:20px; margin:14px 0 22px; font-size:.9rem; color:var(--muted); flex-wrap:wrap; }
.calc-breakdown strong{ color:var(--text); }
.calc-note{ max-width:760px; margin:22px auto 0; text-align:center; color:var(--muted-2); font-size:.84rem; }
@media (max-width:760px){ .calc-card{ grid-template-columns:1fr; } .calc-result{ border-left:0; border-top:1px solid var(--line); } }

/* ---------- whatsapp fab ---------- */
.wa-fab{ position:fixed; right:20px; bottom:20px; z-index:200; display:inline-flex; align-items:center; gap:10px; background:#25d366; color:#053a1e; padding:13px 18px; border-radius:999px; font-family:var(--sans); font-weight:600; font-size:.95rem; box-shadow:0 14px 34px -10px rgba(0,0,0,.55); transition:transform .25s var(--ease), box-shadow .25s; }
.wa-fab:hover{ transform:translateY(-2px); box-shadow:0 18px 40px -10px rgba(37,211,102,.55); }
.wa-fab svg{ width:26px; height:26px; flex-shrink:0; }
@media (max-width:600px){ .wa-fab{ padding:14px; right:16px; bottom:16px; } .wa-fab-label{ display:none; } }

/* ---------- blog index ---------- */
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.post-card{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:rgba(255,255,255,.02); transition:transform .35s var(--ease), border-color .35s; }
.post-card:hover{ transform:translateY(-5px); border-color:rgba(217,183,106,.4); }
.post-media{ aspect-ratio:16/10; overflow:hidden; }
.post-media img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.post-card:hover .post-media img{ transform:scale(1.06); }
.post-body{ padding:24px 24px 26px; display:flex; flex-direction:column; flex-grow:1; }
.post-cat{ font-size:.74rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.post-card h3{ font-size:1.3rem; margin-bottom:10px; line-height:1.2; }
.post-card p{ color:var(--muted); font-size:.95rem; flex-grow:1; }
.post-readmore{ margin-top:18px; color:var(--gold-bright); font-weight:600; font-size:.92rem; display:inline-flex; align-items:center; gap:7px; }
.post-readmore svg{ width:16px; height:16px; transition:transform .3s var(--ease); }
.post-card:hover .post-readmore svg{ transform:translateX(4px); }

/* ---------- article ---------- */
.article-hero{ max-width:820px; margin:0 auto clamp(26px,4vw,40px); }
.article-cat{ font-size:.76rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.article-hero h1{ font-size:clamp(2rem,4.5vw,3.1rem); margin:14px 0 12px; }
.article-meta{ color:var(--muted-2); font-size:.9rem; }
.article-figure{ max-width:980px; margin:0 auto clamp(28px,4vw,44px); border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); }
.article-figure img{ width:100%; height:auto; display:block; }
.article-body{ max-width:820px; margin:0 auto; }
.article-body h2{ font-size:1.5rem; color:var(--text); margin:36px 0 12px; }
.article-body h3{ font-size:1.12rem; color:var(--text); margin:24px 0 8px; }
.article-body p,.article-body li{ color:var(--muted); margin-bottom:13px; }
.article-body ul{ list-style:disc; padding-left:22px; margin-bottom:14px; }
.article-body a{ color:var(--gold-bright); text-decoration:underline; }
.article-body strong{ color:var(--text); }
.cta-box{ max-width:820px; margin:46px auto 0; padding:32px 28px; border-radius:var(--radius); background:linear-gradient(180deg,rgba(217,183,106,.1),rgba(255,255,255,.02)); border:1px solid rgba(217,183,106,.4); text-align:center; }
.cta-box h3{ font-size:1.5rem; margin-bottom:10px; }
.cta-box p{ color:var(--muted); margin-bottom:20px; }
.cta-box .btn{ margin:0 6px 8px; }
.related{ max-width:1000px; margin:64px auto 0; }
.related h2{ font-size:1.3rem; margin-bottom:18px; }
.related-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
@media (max-width:1000px){ .posts{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .posts{ grid-template-columns:1fr; } .related-grid{ grid-template-columns:1fr; } }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal:nth-child(2){ transition-delay:.06s; }
.reveal:nth-child(3){ transition-delay:.12s; }
.reveal:nth-child(4){ transition-delay:.18s; }
.reveal:nth-child(5){ transition-delay:.24s; }
.reveal:nth-child(6){ transition-delay:.3s; }

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .why-grid,.services-grid,.testi-grid,.price-grid{ grid-template-columns:repeat(2,1fr); }
  .aud-grid{ grid-template-columns:repeat(2,1fr); }
  .channels{ grid-template-columns:repeat(2,1fr); }
  .feed{ grid-template-columns:repeat(3,1fr); }
  .timeline{ grid-template-columns:1fr 1fr; gap:30px 18px; }
  .timeline::before{ display:none; }
  .faq-wrap{ grid-template-columns:1fr; }
  .faq .section-head{ position:static; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
  .g-wide{ grid-column:span 2; }
}
@media (max-width:1180px){
  .primary-nav{
    position:fixed; inset:0 0 0 auto; width:min(82vw,360px);
    background:var(--ink-2); border-left:1px solid var(--line);
    transform:translateX(100%); transition:transform .4s var(--ease);
    padding:100px 28px 40px; margin:0; z-index:99; overflow-y:auto;
  }
  .primary-nav.open{ transform:none; box-shadow:-30px 0 60px rgba(0,0,0,.5); }
  .nav-links{ flex-direction:column; gap:4px; }
  .nav-links a{ font-size:1.1rem; padding:14px 16px; }
  .nav-toggle{ display:flex; }
  .nav-actions .btn--primary{ display:none; }
  .stats-grid{ grid-template-columns:repeat(2,1fr); transform:translateY(-30px); }
  .stat:nth-child(2){ border-right:0; }
  .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid var(--line-soft); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  body{ font-size:16px; }
  .container{ padding:0 20px; }
  .why-grid,.services-grid,.testi-grid,.price-grid,.aud-grid{ grid-template-columns:1fr; }
  .channels{ grid-template-columns:1fr; }
  .feed{ grid-template-columns:repeat(2,1fr); }
  .timeline{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr; grid-auto-rows:220px; padding:0 20px; }
  .g-tall,.g-wide{ grid-column:auto; grid-row:auto; }
  .contact-grid{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:32px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .hero{ padding-top:120px; }
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero-video{ display:none; }
}
