/*
Theme Name: ADOLICAM Industrial Pro
Description: Tema premium de ingeniería industrial para ADOLICAM
Version: 3.0
Text Domain: adolicam
*/
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700&family=Barlow+Condensed:wght@600;700;800;900&display=swap');

/* ── VARIABLES ─────────────────────────── */
:root {
  --c0: #0A0A0A;
  --c1: #111111;
  --c2: #181818;
  --c3: #222222;
  --gold: #C8922A;
  --gold2: #E4AA35;
  --gold-a: rgba(200,146,42,.15);
  --cream: #F4EFE4;
  --white: #FAFAFA;
  --muted: rgba(250,250,250,.45);
  --dim: rgba(250,250,250,.12);
  --border: rgba(200,146,42,.2);
  --border-dim: rgba(250,250,250,.07);
  --FH: 'Bebas Neue', sans-serif;
  --FB: 'Inter', sans-serif;
  --FC: 'Barlow Condensed', sans-serif;
  --ease: cubic-bezier(.25,.46,.45,.94);
}

/* ── RESET ─────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; font-size:16px }
body { font-family:var(--FB); background:var(--c0); color:var(--white); overflow-x:hidden; cursor:none; -webkit-font-smoothing:antialiased }
a { text-decoration:none; color:inherit }
img { display:block; max-width:100%; height:auto }
button { cursor:none; font-family:inherit }
::-webkit-scrollbar { width:2px }
::-webkit-scrollbar-thumb { background:var(--gold) }

/* ── CURSOR ────────────────────────────── */
#cur { position:fixed; top:0; left:0; width:10px; height:10px; background:var(--gold); border-radius:50%; pointer-events:none; z-index:99999; transform:translate(-50%,-50%); transition:width .3s var(--ease), height .3s var(--ease), background .3s; mix-blend-mode:normal }
#cur-ring { position:fixed; top:0; left:0; width:40px; height:40px; border:1px solid rgba(200,146,42,.6); border-radius:50%; pointer-events:none; z-index:99998; transform:translate(-50%,-50%); transition:width .3s, height .3s, opacity .3s }
body.hover-link #cur { width:48px; height:48px; background:rgba(200,146,42,.15) }
body.hover-link #cur-ring { width:56px; height:56px; opacity:.3 }

/* ── NAV ───────────────────────────────── */
.site-header { position:fixed; top:0; left:0; right:0; z-index:500; height:72px; display:flex; align-items:center; justify-content:space-between; padding:0 5vw; background:rgba(10,10,10,.92); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); transition:background .4s }
.site-header.solid { background:rgba(10,10,10,.99) }
.site-header::after { content:''; position:absolute; bottom:0; left:5vw; right:5vw; height:1px; background:var(--border); opacity:.6 }
.site-logo { font-family:var(--FH); font-size:1.75rem; letter-spacing:.1em; color:var(--white); display:flex; align-items:center; gap:2px; line-height:1 }
.site-logo b { color:var(--gold); font-weight:400 }
.site-logo sup { font-family:var(--FC); font-size:.55rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--muted); margin-left:6px; margin-top:-8px }
.nav-links { display:flex; align-items:center; gap:2.5rem }
.nav-links a { font-size:.68rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); position:relative; transition:color .25s }
.nav-links a::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:1px; background:var(--gold); transition:width .3s var(--ease) }
.nav-links a:hover, .nav-links a.active { color:var(--white) }
.nav-links a:hover::after, .nav-links a.active::after { width:100% }
.nav-btn { font-size:.68rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; padding:.6rem 1.6rem; background:var(--gold); color:var(--c0); border:none; transition:background .25s, transform .2s }
.nav-btn:hover { background:var(--gold2); transform:translateY(-1px) }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px }
.nav-toggle span { display:block; width:24px; height:1.5px; background:var(--white); transition:all .3s }

/* ── TICKER ────────────────────────────── */
.ticker-band { height:44px; background:var(--gold); overflow:hidden; display:flex; align-items:center; position:relative; border-top:1px solid rgba(0,0,0,.15); border-bottom:1px solid rgba(0,0,0,.15) }
.ticker-track { display:flex; align-items:center; white-space:nowrap; will-change:transform; animation:marquee 45s linear infinite }
.ticker-track .item { font-family:var(--FC); font-size:.9rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--c0); padding:0 2.5rem; flex-shrink:0 }
.ticker-track .sep { color:rgba(0,0,0,.3); font-size:.6rem; flex-shrink:0 }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── SECTIONS ──────────────────────────── */
.sec { padding:8rem 5vw; position:relative }
.sec-sm { padding:5rem 5vw }
.sec-dark { background:var(--c1) }
.sec-darker { background:var(--c2) }

/* ── LABELS ────────────────────────────── */
.lbl { display:flex; align-items:center; gap:.75rem; font-size:.62rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:1.25rem }
.lbl::before { content:''; width:28px; height:1px; background:var(--gold); flex-shrink:0 }

/* ── HEADINGS ──────────────────────────── */
.h-hero { font-family:var(--FH); font-size:clamp(5rem,13vw,13rem); line-height:.88; letter-spacing:.02em; text-transform:uppercase }
.h-big  { font-family:var(--FH); font-size:clamp(3.5rem,7vw,7rem);  line-height:.9;  letter-spacing:.02em; text-transform:uppercase }
.h-med  { font-family:var(--FC); font-size:clamp(2rem,4vw,3.5rem);  line-height:.95; font-weight:900; text-transform:uppercase; letter-spacing:.02em }
.h-sm   { font-family:var(--FC); font-size:clamp(1.2rem,2vw,1.6rem); line-height:1.1; font-weight:800; text-transform:uppercase; letter-spacing:.03em }
.gold   { color:var(--gold) }
.stroke { -webkit-text-stroke:1px var(--gold); color:transparent }
.stroke-w { -webkit-text-stroke:1px rgba(250,250,250,.25); color:transparent }

/* ── BUTTONS ───────────────────────────── */
.btn-primary { display:inline-flex; align-items:center; gap:.75rem; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:1rem 2.5rem; background:var(--gold); color:var(--c0); border:none; position:relative; overflow:hidden; transition:transform .25s, box-shadow .25s }
.btn-primary::before { content:''; position:absolute; inset:0; background:var(--gold2); transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease) }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 40px rgba(200,146,42,.3) }
.btn-primary:hover::before { transform:scaleX(1); transform-origin:left }
.btn-primary span { position:relative; z-index:1 }
.btn-outline { display:inline-flex; align-items:center; gap:.75rem; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:1rem 2.5rem; background:transparent; color:var(--white); border:1px solid var(--dim); transition:border-color .3s, color .3s }
.btn-outline:hover { border-color:var(--gold); color:var(--gold) }
.btn-text { display:inline-flex; align-items:center; gap:.6rem; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); transition:gap .3s }
.btn-text svg { width:16px; height:16px; stroke:var(--gold); fill:none; stroke-width:2; transition:transform .3s }
.btn-text:hover { gap:1rem }
.btn-text:hover svg { transform:translateX(4px) }
.btn-cta-dark { display:inline-flex; align-items:center; gap:.75rem; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:1rem 2.5rem; background:var(--c0); color:var(--white); border:none; transition:background .25s }
.btn-cta-dark:hover { background:#1a1a1a }

/* ── CARDS ─────────────────────────────── */
.card { background:var(--c2); border:1px solid var(--border-dim); position:relative; overflow:hidden; transition:border-color .35s, transform .35s }
.card:hover { border-color:var(--border); transform:translateY(-4px) }
.card::after { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease) }
.card:hover::after { transform:scaleX(1) }

/* ── SERVICE ROWS ──────────────────────── */
.srv-row { display:grid; grid-template-columns:100px 1fr 280px; align-items:start; gap:3rem; padding:3rem 0; border-bottom:1px solid var(--border-dim); position:relative; transition:background .3s }
.srv-row::before { content:''; position:absolute; inset:0 -5vw; background:var(--c1); opacity:0; transition:opacity .3s; z-index:-1 }
.srv-row:hover::before { opacity:1 }
.srv-row:hover .srv-num { color:var(--gold) }
.srv-num { font-family:var(--FH); font-size:4rem; color:var(--border-dim); line-height:1; transition:color .35s }
.srv-title { font-family:var(--FC); font-size:1.4rem; font-weight:900; text-transform:uppercase; color:var(--white); margin-bottom:.85rem; letter-spacing:.03em }
.srv-desc { font-size:.83rem; line-height:1.9; color:var(--muted) }
.srv-tags { font-size:.6rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); line-height:2; margin-top:1rem }

/* ── PORTFOLIO ─────────────────────────── */
.port-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--border-dim) }
.port-item { position:relative; overflow:hidden; aspect-ratio:4/3; background:var(--c2); display:flex; align-items:center; justify-content:center }
.port-item img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:brightness(.45) saturate(.5); transition:filter .6s var(--ease), transform .6s var(--ease) }
.port-item:hover img { filter:brightness(.65) saturate(.8); transform:scale(1.04) }
.port-cap { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:2rem; background:linear-gradient(to top, rgba(10,10,10,.95) 0%, transparent 60%); transform:translateY(8px); opacity:0; transition:opacity .35s, transform .35s }
.port-item:hover .port-cap { opacity:1; transform:translateY(0) }
.port-cat { font-size:.6rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:.4rem }
.port-cap h3 { font-family:var(--FC); font-size:1.15rem; font-weight:900; text-transform:uppercase; color:var(--white) }
.port-badge { position:absolute; top:1.25rem; left:1.25rem; background:var(--gold); padding:.3rem .9rem; font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--c0) }

/* ── STATS ─────────────────────────────── */
.stat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--border-dim) }
.stat-box { padding:3.5rem 2rem; text-align:center; border-right:1px solid var(--border-dim); position:relative }
.stat-box:last-child { border-right:none }
.stat-box::after { content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:0; height:3px; background:var(--gold); transition:width .5s var(--ease) }
.stat-box.on::after { width:60% }
.stat-n { font-family:var(--FH); font-size:4.5rem; color:var(--gold); line-height:1 }
.stat-l { font-size:.62rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:.6rem }

/* ── CTA SECTION ───────────────────────── */
.cta-sec { background:var(--gold); padding:6rem 5vw; position:relative; overflow:hidden }
.cta-sec::before { content:'ADOLICAM'; position:absolute; right:-1rem; top:-2rem; font-family:var(--FH); font-size:22rem; color:rgba(0,0,0,.07); line-height:1; pointer-events:none; white-space:nowrap }
.cta-sec .inner { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:2rem }
.cta-sec h2 { font-family:var(--FH); font-size:clamp(3rem,6vw,6rem); color:var(--c0); line-height:.9; text-transform:uppercase }

/* ── IMAGE ─────────────────────────────── */
.img-wrap { position:relative; overflow:hidden }
.img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease), filter .5s }
.img-wrap:hover img { transform:scale(1.04) }
.img-dim img { filter:brightness(.45) saturate(.6) }
.img-dim:hover img { filter:brightness(.6) saturate(.75) }
.img-ov { position:absolute; inset:0; background:linear-gradient(135deg, rgba(200,146,42,.08) 0%, rgba(10,10,10,.5) 100%) }

/* ── PAGE HERO ─────────────────────────── */
.ph { padding:160px 5vw 80px; min-height:440px; background:var(--c1); display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden }
.ph .grid { position:absolute; inset:0; background-image:linear-gradient(rgba(200,146,42,.04) 1px,transparent 1px), linear-gradient(90deg,rgba(200,146,42,.04) 1px,transparent 1px); background-size:80px 80px }
.ph .bg-num { position:absolute; right:4vw; bottom:-1rem; font-family:var(--FH); font-size:22rem; color:rgba(200,146,42,.05); line-height:1; pointer-events:none; white-space:nowrap }
.ph-inner { position:relative; z-index:1 }
.ph-inner p { font-size:1.05rem; line-height:1.8; color:var(--muted); max-width:580px; margin-top:1.5rem }

/* ── CONTACT ───────────────────────────── */
.contact-gold { background:var(--gold); padding:3rem }
.contact-gold h3 { font-family:var(--FC); font-size:1.4rem; font-weight:900; text-transform:uppercase; color:var(--c0); margin-bottom:2rem }
.ci { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.5rem }
.ci svg { width:18px; height:18px; flex-shrink:0; stroke:var(--c0); fill:none; stroke-width:2; margin-top:3px }
.ci-label { font-size:.6rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(10,10,10,.55); display:block; margin-bottom:.2rem }
.ci-val { font-size:.95rem; font-weight:600; color:var(--c0) }

/* ── FORM ──────────────────────────────── */
.ff { margin-bottom:1.25rem }
.ff label { display:block; font-size:.6rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:.5rem }
.ff input, .ff select, .ff textarea { width:100%; background:rgba(200,146,42,.06); border:1px solid rgba(200,146,42,.2); border-radius:0; padding:.9rem 1.1rem; font-family:var(--FB); font-size:.88rem; color:var(--white); outline:none; transition:border-color .25s, background .25s; appearance:none; -webkit-appearance:none }
.ff input::placeholder, .ff textarea::placeholder { color:rgba(250,250,250,.2) }
.ff input:focus, .ff select:focus, .ff textarea:focus { border-color:var(--gold); background:rgba(200,146,42,.1) }
.ff select option { background:var(--c1) }
.ff textarea { resize:vertical; min-height:130px }
.f2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem }

/* ── DIVIDER ───────────────────────────── */
.gold-div { height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:.4 }
.dim-div  { height:1px; background:var(--border-dim) }

/* ── STRIP FEATURES ────────────────────── */
.feat-strip { display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim) }
.feat-strip-item { padding:3.5rem 2.5rem; border-right:1px solid var(--border-dim); transition:background .3s }
.feat-strip-item:last-child { border-right:none }
.feat-strip-item:hover { background:var(--c2) }
.feat-icon { width:48px; height:48px; background:var(--gold); display:flex; align-items:center; justify-content:center; margin-bottom:1.75rem; flex-shrink:0 }
.feat-icon svg { width:24px; height:24px; stroke:var(--c0); fill:none; stroke-width:1.8 }

/* ── PROCESS STEPS ─────────────────────── */
.steps { display:flex; flex-direction:column }
.step { display:grid; grid-template-columns:80px 1fr; gap:2rem; padding:2rem 0; border-bottom:1px solid var(--border-dim); transition:background .3s }
.step:hover { background:rgba(200,146,42,.04); padding-left:1rem; padding-right:1rem; margin:0 -1rem }
.step-n { font-family:var(--FH); font-size:3.5rem; color:rgba(200,146,42,.2); line-height:1; transition:color .3s }
.step:hover .step-n { color:var(--gold) }
.step-title { font-family:var(--FC); font-size:1.1rem; font-weight:900; text-transform:uppercase; color:var(--white); margin-bottom:.6rem }
.step-text { font-size:.82rem; line-height:1.9; color:var(--muted) }
.step-tags { font-size:.58rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-top:.75rem; line-height:2 }

/* ── SECTOR LIST ───────────────────────── */
.sector-list { display:grid; grid-template-columns:1fr 1fr; gap:.6rem }
.sector-item { display:flex; align-items:center; gap:.75rem; padding:.85rem 1rem; background:var(--c0); border:1px solid var(--border-dim); border-left:2px solid var(--gold); font-size:.78rem; font-weight:500; color:var(--white) }

/* ── REVEAL ────────────────────────────── */
.rv  { opacity:0; transform:translateY(30px); transition:opacity .85s var(--ease), transform .85s var(--ease) }
.rl  { opacity:0; transform:translateX(-30px); transition:opacity .85s var(--ease), transform .85s var(--ease) }
.rr  { opacity:0; transform:translateX(30px);  transition:opacity .85s var(--ease), transform .85s var(--ease) }
.rsc { opacity:0; transform:scale(.95);         transition:opacity .85s var(--ease), transform .85s var(--ease) }
.rv.on,.rl.on,.rr.on,.rsc.on { opacity:1; transform:none }

/* ── FOOTER ────────────────────────────── */
.site-footer { background:#060606; border-top:1px solid var(--border-dim); padding:5rem 5vw 2.5rem }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; margin-bottom:4rem }
.footer-logo { font-family:var(--FH); font-size:1.6rem; letter-spacing:.1em; margin-bottom:1rem; display:flex; align-items:center; gap:2px }
.footer-logo b { color:var(--gold); font-weight:400 }
.footer-about { font-size:.78rem; line-height:1.9; color:var(--muted); max-width:280px }
.footer-col h5 { font-size:.6rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:1.25rem }
.footer-col a { display:block; font-size:.78rem; color:var(--muted); margin-bottom:.55rem; transition:color .2s }
.footer-col a:hover { color:var(--white) }
.footer-bottom { border-top:1px solid var(--border-dim); padding-top:1.5rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem }
.footer-bottom p { font-size:.65rem; letter-spacing:.06em; color:rgba(250,250,250,.18) }

/* ── WP ────────────────────────────────── */
.site-content { padding-top:72px }
.wpcf7-submit { background:var(--gold)!important; color:var(--c0)!important; border:none!important; font-family:var(--FB)!important; font-size:.7rem!important; font-weight:700!important; letter-spacing:.14em!important; text-transform:uppercase!important; padding:1rem 2.5rem!important; width:100%!important; border-radius:0!important; cursor:none!important }
.wpcf7-submit:hover { background:var(--gold2)!important }

/* ── RESPONSIVE ────────────────────────── */
@media(max-width:1024px){
  .footer-grid { grid-template-columns:1fr 1fr }
  .stat-grid { grid-template-columns:1fr 1fr }
  .stat-box { border-right:none; border-bottom:1px solid var(--border-dim) }
}
@media(max-width:900px){
  .nav-links { display:none }
  .nav-toggle { display:flex }
  .nav-links.open { display:flex; flex-direction:column; position:fixed; top:72px; left:0; right:0; background:rgba(10,10,10,.98); backdrop-filter:blur(20px); padding:2rem 5vw; gap:1.5rem; border-bottom:1px solid var(--border); z-index:499 }
  .port-grid { grid-template-columns:1fr 1fr }
  .feat-strip { grid-template-columns:1fr }
  .feat-strip-item { border-right:none; border-bottom:1px solid var(--border-dim) }
  .srv-row { grid-template-columns:60px 1fr; }
  .srv-row > a { grid-column:2 }
  .f2 { grid-template-columns:1fr }
}
@media(max-width:600px){
  .port-grid { grid-template-columns:1fr }
  .stat-grid { grid-template-columns:1fr 1fr }
  .footer-grid { grid-template-columns:1fr }
  .cta-sec .inner { flex-direction:column }
  .sector-list { grid-template-columns:1fr }
  .sec { padding:5rem 5vw }
  .h-hero { font-size:clamp(4rem,18vw,8rem) }
  #cur, #cur-ring { display:none }
  body { cursor:auto }
  a, button { cursor:pointer }
}
