/* FIAG Studio Desarrollos — styles.css */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:       #FAFAF8;
  --surface:  #F2F2EE;
  --border:   #E0E0D8;
  --accent:   #2D5A40;
  --accent-lt:#EAF0EB;
  --dark:     #1A1F1A;
  --muted:    #6B7566;
  --muted2:   #8A9B8A;
  --ff-head:  'Cormorant Garamond', Georgia, serif;
  --ff-body:  'Jost', system-ui, sans-serif;
  --ease:     cubic-bezier(0.16,1,0.3,1);
}

html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--dark);font-family:var(--ff-body);font-weight:300;line-height:1.7;overflow-x:hidden}

/* ── Lenis ── */
html.lenis{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto}

/* ── Typography ── */
h1,h2,h3,h4{font-family:var(--ff-head);font-weight:400;line-height:1.08;letter-spacing:-0.02em;color:var(--dark)}
h1{font-size:clamp(48px,7vw,88px)}
h2{font-size:clamp(34px,4vw,54px)}
h3{font-size:22px}
p{font-size:16px;color:var(--muted)}
em{font-style:italic;color:var(--accent);font-family:var(--ff-head)}
a{color:inherit;text-decoration:none}

.eyebrow{font-family:var(--ff-body);font-size:11px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;display:block;opacity:0;transform:translateX(-16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.eyebrow.in{opacity:1;transform:none}

/* ── Container ── */
.wrap{max-width:1200px;margin:0 auto;padding-left:clamp(1.25rem,5vw,5rem);padding-right:clamp(1.25rem,5vw,5rem)}

/* ── Reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ═══════════════════════════════════════
   NAV
═══════════════════════════════════════ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:64px;display:flex;align-items:center;transition:background .3s,border-color .3s;border-bottom:1px solid transparent}
.site-nav.scrolled{background:rgba(250,250,248,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav-logo{font-family:var(--ff-head);font-size:20px;font-weight:500;color:var(--dark);letter-spacing:-.01em}
.nav-logo em{font-style:italic;color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:13px;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--dark)}
.lang-tog{font-family:monospace;font-size:12px;color:var(--muted);display:flex;gap:.4rem;align-items:center}
.lang-tog a{transition:color .2s}
.lang-tog a:hover,.lang-tog a.active{color:var(--dark)}
.lang-sep{color:var(--border)}
.nav-hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav-hbg span{display:block;width:22px;height:1.5px;background:var(--dark);transition:transform .3s,opacity .3s}
.nav-hbg.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-hbg.open span:nth-child(2){opacity:0}
.nav-hbg.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-nav{position:fixed;inset:0;z-index:99;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.mob-nav.open{opacity:1;pointer-events:all}
.mob-nav a{font-family:var(--ff-head);font-size:clamp(32px,6vw,48px);color:var(--dark)}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
.hero{min-height:100svh;display:flex;align-items:center;padding-top:80px;padding-bottom:60px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-eyebrow{font-family:var(--ff-body);font-size:11px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:2rem;opacity:0;animation:fadeUp .6s var(--ease) .1s forwards}
.hero-h1{margin-bottom:1.75rem}
.clip-line{overflow:hidden;display:block}
.clip-inner{display:block;transform:translateY(105%);opacity:0}
.clip-inner.in{animation:clipReveal .9s var(--ease) forwards}
@keyframes clipReveal{to{transform:translateY(0);opacity:1}}
.hero-sub{font-size:18px;font-weight:300;color:var(--muted);max-width:460px;margin-bottom:2.5rem;opacity:0;animation:fadeUp .7s var(--ease) .55s forwards}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .7s var(--ease) .7s forwards}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-body);font-size:14px;font-weight:500;padding:13px 26px;border-radius:3px;border:1px solid transparent;cursor:pointer;transition:background .22s,color .22s,border-color .22s,transform .2s var(--ease);letter-spacing:.01em}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.btn-primary:hover{background:var(--dark);border-color:var(--dark)}
.btn-outline{background:transparent;color:var(--dark);border-color:var(--dark)}
.btn-outline:hover{background:var(--dark);color:var(--bg)}
.hero-metrics{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2.5rem;opacity:0;animation:fadeUp .7s var(--ease) .9s forwards}
.h-metric{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border);border-radius:40px;padding:7px 16px;background:var(--surface)}
.h-metric-num{font-family:var(--ff-head);font-size:26px;font-weight:400;color:var(--dark);line-height:1}
.h-metric-num em{font-size:18px}
.h-metric-lbl{font-size:12px;color:var(--muted);line-height:1.3}

/* hero mock card */
.hero-mock-wrap{position:relative;display:flex;justify-content:center}
.hero-mock{background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 48px rgba(26,31,26,.09);transform:rotate(2deg);transition:transform 1s var(--ease);overflow:hidden;width:100%;max-width:420px;opacity:0;animation:fadeUp .9s var(--ease) .3s forwards}
.hero-mock:hover{transform:rotate(0deg)}
.mock-bar{background:var(--surface);padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.mock-dots{display:flex;gap:5px}
.mock-dot{width:10px;height:10px;border-radius:50%}
.mock-dot:nth-child(1){background:#FF5F57}
.mock-dot:nth-child(2){background:#FFBD2E}
.mock-dot:nth-child(3){background:#28CA42}
.mock-title{font-size:11px;color:var(--muted);margin-left:4px;font-family:var(--ff-body)}
.mock-table{width:100%;border-collapse:collapse;font-family:var(--ff-body)}
.mock-table th{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:8px 14px;border-bottom:1px solid var(--border);text-align:left;background:var(--surface)}
.mock-table td{font-size:12px;padding:9px 14px;border-bottom:1px solid var(--border);color:var(--dark)}
.mock-table td:first-child{color:var(--muted);font-family:monospace}
.mock-status{display:inline-block;font-size:10px;font-weight:500;padding:2px 8px;border-radius:20px}
.s-enviado{background:#EAF0EB;color:#2D5A40}
.s-aprobado{background:#EAF0EB;color:#1A4430}
.s-pendiente{background:#FEF3E2;color:#92600A}
.mock-footer{padding:8px 14px;font-size:10px;color:var(--muted);background:var(--surface);border-top:1px solid var(--border)}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════════
   SERVICES
═══════════════════════════════════════ */
.services{padding:clamp(80px,10vw,140px) 0;border-top:1px solid var(--border)}
.svc-list{margin-top:3rem}
.svc-row{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:2rem;padding:1.5rem 0;border-bottom:1px solid var(--border);cursor:default;position:relative;transition:background .2s}
.svc-row::before{content:'';position:absolute;left:-5%;width:4px;height:100%;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .25s var(--ease)}
.svc-row:hover{background:var(--surface)}
.svc-row:hover::before{transform:scaleY(1)}
.svc-num{font-family:var(--ff-head);font-size:18px;font-style:italic;color:var(--accent);min-width:32px}
.svc-body{}
.svc-title{font-family:var(--ff-body);font-size:16px;font-weight:500;color:var(--dark);margin-bottom:.2rem}
.svc-desc{font-size:14px;color:var(--muted);font-weight:300}
.svc-arrow{font-size:18px;color:var(--accent);opacity:0;transition:opacity .2s,transform .2s;transform:translateX(-6px)}
.svc-row:hover .svc-arrow{opacity:1;transform:none}

/* ═══════════════════════════════════════
   PROCESS
═══════════════════════════════════════ */
.process{padding:clamp(80px,10vw,140px) 0;background:var(--surface)}
.proc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem}
.proc-card{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:36px;position:relative;overflow:hidden}
.proc-num{font-family:var(--ff-head);font-size:72px;font-weight:400;color:var(--border);line-height:1;margin-bottom:.5rem;display:block}
.proc-title{font-family:var(--ff-body);font-size:18px;font-weight:500;color:var(--dark);margin-bottom:.75rem}
.proc-desc{font-size:14px;color:var(--muted);line-height:1.65}

/* ═══════════════════════════════════════
   PORTFOLIO
═══════════════════════════════════════ */
.portfolio{padding:clamp(80px,10vw,140px) 0;border-top:1px solid var(--border)}
.port-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1.5rem;margin-top:3rem}
.port-right{display:grid;gap:1.5rem}
.port-card{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden;transition:border-color .2s var(--ease);border-top:2px solid var(--border)}
.port-card:hover{border-top-color:var(--accent)}
.port-card:hover .port-title{color:var(--accent)}
.port-img-area{background:var(--accent-lt);padding:28px 28px 0;display:flex;align-items:flex-end;min-height:140px}
.port-stat-big{font-family:var(--ff-head);font-size:72px;font-weight:400;color:var(--accent);line-height:1}
.port-stat-lbl{font-size:13px;color:var(--muted);margin-top:.25rem;padding-bottom:20px}
.port-body{padding:22px}
.port-tag{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-lt);padding:3px 10px;border-radius:20px;display:inline-block;margin-bottom:.75rem}
.port-title{font-family:var(--ff-body);font-size:17px;font-weight:500;color:var(--dark);margin-bottom:.5rem;transition:color .2s;line-height:1.35}
.port-desc{font-size:13px;color:var(--muted);line-height:1.6}
.port-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}
.port-pill{font-size:11px;color:var(--muted);border:1px solid var(--border);border-radius:20px;padding:2px 10px}
/* small cards */
.port-card.small .port-img-area{min-height:90px}
.port-card.small .port-stat-big{font-size:48px}
.port-card.small .port-body{padding:16px}
.port-card.small .port-title{font-size:15px}

/* ═══════════════════════════════════════
   WHY / INDUSTRIES
═══════════════════════════════════════ */
.why{padding:clamp(80px,10vw,140px) 0;background:var(--surface);border-top:1px solid var(--border)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem;align-items:start}
.why-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem}
.why-item{display:flex;align-items:flex-start;gap:1rem;font-size:16px;color:var(--dark)}
.why-check{flex-shrink:0;width:20px;height:20px;margin-top:3px}
.why-card{background:var(--dark);border-radius:4px;padding:36px;position:sticky;top:100px}
.why-card-title{font-family:var(--ff-head);font-size:28px;font-style:italic;color:#EAF0EB;margin-bottom:1rem}
.why-card-body{font-size:14px;color:#8A9B8A;line-height:1.7;margin-bottom:1.5rem}
.why-pills{display:flex;flex-wrap:wrap;gap:.5rem}
.why-pill{font-size:12px;color:#8A9B8A;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:4px 12px;background:rgba(255,255,255,.04)}

/* ═══════════════════════════════════════
   CTA
═══════════════════════════════════════ */
.cta-section{background:var(--dark);padding:clamp(80px,10vw,140px) 0;text-align:center}
.cta-section h2{color:#FAFAF8}
.cta-section h2 em{color:#8FB89A}
.cta-section p{color:#8A9B8A;font-size:18px;max-width:500px;margin:.75rem auto 2.5rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-cta-primary{background:var(--accent);color:#FAFAF8;border-color:var(--accent)}
.btn-cta-primary:hover{background:#1A4430;border-color:#1A4430}
.btn-cta-outline{border:1px solid #8A9B8A;color:#FAFAF8;background:transparent}
.btn-cta-outline:hover{background:rgba(255,255,255,.06)}
.cta-proof{margin-top:2rem;font-size:13px;color:#4A5A4A}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
.site-footer{background:var(--bg);border-top:1px solid var(--border);padding:2rem 0}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-logo{font-family:var(--ff-head);font-size:18px;font-weight:500;color:var(--dark)}
.footer-logo em{font-style:italic;color:var(--accent)}
.footer-copy{font-size:12px;color:var(--muted)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:12px;color:var(--muted);transition:color .2s}
.footer-links a:hover{color:var(--dark)}
.footer-sub{text-align:center;font-size:12px;color:var(--muted);margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);font-style:italic;font-family:var(--ff-head)}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero-mock-wrap{display:none}
  .port-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .why-card{position:static}
  .nav-links{display:none}
  .nav-hbg{display:flex}
  .svc-row{grid-template-columns:40px 1fr auto}
}
@media(max-width:600px){
  .hero-ctas{flex-direction:column}
  .cta-btns{flex-direction:column;align-items:center}
  .footer-row{justify-content:center;text-align:center}
  .port-stat-big{font-size:52px}
}

/* Privacy page */
.privacy-hero{padding:140px 0 40px;border-bottom:1px solid var(--border)}
.privacy-hero h1{font-size:clamp(32px,4vw,52px)}
.privacy-hero p{color:var(--muted);margin-top:.5rem}
.privacy-content{max-width:720px;padding:3rem 0 6rem}
.privacy-content h2{font-size:22px;font-family:var(--ff-body);font-weight:500;margin:2.5rem 0 .75rem;color:var(--dark)}
.privacy-content p,.privacy-content li{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:.75rem}
.privacy-content ul{padding-left:1.5rem;margin-bottom:.75rem}
.privacy-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
