/* ═══════════════════════════════════════════════════════════════
   CRISOLO — Catálogo · Editorial Industrial (paleta azul del logo)
═══════════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --bg:#0A0D14; --bg-1:#0F131C; --bg-2:#161C28; --bg-3:#1E2634;
  --line:#222A39; --line-2:#36415A;
  --cream:#EEF2F9; --text:#DBE1ED; --text-dim:#8A95A9; --text-low:#5A6478;
  --accent:#336BE6; --accent-2:#6FA8FF; --steel:#4A5A72; --navy:#21408F;
  --ff-display:'Big Shoulders Display','Impact',sans-serif;
  --ff-body:'Manrope',system-ui,sans-serif;
  --ff-mono:'JetBrains Mono',ui-monospace,monospace;
  --pad-x:clamp(20px,4vw,80px);
  --maxw:1440px;
}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:var(--ff-body);font-size:16px;line-height:1.55;overflow-x:hidden;position:relative;}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--accent);color:#fff;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);}
.eyebrow{font-family:var(--ff-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);font-weight:500;}
.accent{color:var(--accent);}

/* ═══ NAV ═══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:120;padding:16px var(--pad-x);display:flex;align-items:center;justify-content:space-between;
  background:rgba(10,13,20,.82);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line);}
.brand-logo{height:36px;width:auto;display:block;}
.nav-links{display:flex;gap:26px;list-style:none;}
.nav-links a{font-family:var(--ff-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);transition:color .2s;}
.nav-links a:hover,.nav-links a.active{color:var(--cream);}
.nav-links a.active{color:var(--accent);}
.nav-cta{font-family:var(--ff-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--accent);padding:10px 20px;font-weight:500;transition:background .2s,transform .2s;}
.nav-cta:hover{background:var(--accent-2);color:var(--bg);transform:translateY(-1px);}
@media(max-width:1080px){.nav-links{display:none;}}

/* ═══ BREADCRUMB ═══ */
.breadcrumb{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.breadcrumb a:hover{color:var(--cream);}
.breadcrumb .sep{color:var(--line-2);}
.breadcrumb .cur{color:var(--accent);}

/* ═══ MASTHEAD ═══ */
.masthead{position:relative;min-height:64vh;display:flex;align-items:flex-end;overflow:hidden;padding-top:120px;}
.masthead-media{position:absolute;inset:0;z-index:0;}
.masthead-media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.92) brightness(.5);}
.masthead-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,13,20,.55) 0%,transparent 30%,rgba(10,13,20,.65) 72%,var(--bg) 100%),linear-gradient(90deg,rgba(10,13,20,.7),transparent 60%);}
.masthead-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x) clamp(40px,6vh,72px);}
.masthead .mh-num{font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;color:var(--accent);margin:22px 0 16px;}
.masthead h1{font-family:var(--ff-display);font-weight:900;font-size:clamp(52px,11vw,168px);line-height:.82;letter-spacing:-.02em;text-transform:uppercase;color:var(--cream);}
.masthead .mh-sub{display:flex;gap:28px;flex-wrap:wrap;align-items:baseline;margin-top:22px;}
.masthead .mh-sub p{max-width:560px;color:var(--text);font-size:clamp(15px,1.4vw,18px);}
.masthead .mh-count{font-family:var(--ff-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);white-space:nowrap;}

/* ═══ SECTOR PILLS ═══ */
.pills{display:flex;gap:10px;flex-wrap:wrap;padding:clamp(28px,4vh,44px) 0;border-bottom:1px solid var(--line);}
.pill{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);border:1px solid var(--line-2);padding:9px 16px;transition:all .2s;}
.pill:hover{border-color:var(--accent);color:var(--cream);}
.pill.active{background:var(--accent);border-color:var(--accent);color:#fff;}

/* ═══ PRODUCT GRID ═══ */
.section-title{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;padding:clamp(48px,7vh,90px) 0 clamp(26px,4vh,40px);}
.section-title h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(28px,3.6vw,52px);line-height:.96;text-transform:uppercase;color:var(--cream);}
.section-title p{max-width:420px;color:var(--text-dim);font-size:14.5px;}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding-bottom:clamp(60px,9vh,120px);}
@media(max-width:1000px){.prod-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.prod-grid{grid-template-columns:1fr;}}
.prod-card{position:relative;background:var(--bg-1);border:1px solid var(--line);display:flex;flex-direction:column;transition:border-color .25s,transform .25s;overflow:hidden;}
.prod-card:hover{border-color:var(--line-2);transform:translateY(-4px);}
.prod-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:radial-gradient(120% 120% at 50% 30%,var(--bg-2),var(--bg));}
.prod-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;filter:contrast(1.03) brightness(.92);}
.prod-card:hover .prod-media img{transform:scale(1.06);}
.prod-media .badge{position:absolute;top:12px;left:12px;font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;background:rgba(10,13,20,.78);color:var(--accent-2);padding:5px 10px;border:1px solid var(--line-2);}
.prod-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1;}
.prod-cat{font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:9px;}
.prod-name{font-family:var(--ff-display);font-weight:800;font-size:clamp(21px,2vw,27px);line-height:.98;text-transform:uppercase;color:var(--cream);}
.prod-tag{font-size:13.5px;color:var(--text-dim);margin-top:9px;line-height:1.5;}
.prod-specs{display:flex;flex-direction:column;gap:7px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);}
.prod-specs .sp{display:flex;justify-content:space-between;gap:14px;font-family:var(--ff-mono);font-size:11.5px;}
.prod-specs .sp span{color:var(--text-dim);}
.prod-specs .sp b{color:var(--cream);font-weight:500;text-align:right;}
.prod-cta{margin-top:18px;display:flex;align-items:center;gap:8px;font-family:var(--ff-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);transition:gap .2s,color .2s;}
.prod-card:hover .prod-cta{gap:14px;color:var(--cream);}

/* ═══ HUB — sector tiles ═══ */
.hub-intro{padding:clamp(40px,6vh,70px) 0 clamp(20px,3vh,36px);border-bottom:1px solid var(--line);}
.hub-intro p{max-width:680px;color:var(--text-dim);font-size:clamp(15px,1.4vw,18px);}
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;padding:clamp(40px,6vh,70px) 0 clamp(60px,9vh,120px);}
@media(max-width:760px){.tiles{grid-template-columns:1fr;}}
.tile{position:relative;min-height:340px;overflow:hidden;border:1px solid var(--line);display:flex;align-items:flex-end;transition:border-color .25s;}
.tile:hover{border-color:var(--accent);}
.tile:first-child{grid-column:1 / -1;min-height:380px;}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.52) contrast(1.05);transition:transform .6s ease,filter .3s;}
.tile:hover img{transform:scale(1.05);filter:brightness(.62) contrast(1.05);}
.tile::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(10,13,20,.55) 65%,rgba(10,13,20,.95) 100%);}
.tile-body{position:relative;z-index:2;padding:32px;width:100%;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;}
.tile-num{font-family:var(--ff-mono);font-size:11px;letter-spacing:.16em;color:var(--accent);margin-bottom:12px;}
.tile h3{font-family:var(--ff-display);font-weight:900;font-size:clamp(32px,4.5vw,64px);line-height:.86;text-transform:uppercase;color:var(--cream);}
.tile .tile-count{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-top:10px;}
.tile .arrow{font-family:var(--ff-display);font-size:42px;color:var(--accent);line-height:1;flex-shrink:0;transition:transform .25s;}
.tile:hover .arrow{transform:translateX(8px);}

/* ═══ FOOTER ═══ */
.footer{padding:clamp(56px,8vh,100px) 0 40px;border-top:1px solid var(--line);}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:46px;border-bottom:1px solid var(--line);}
.footer-logo{height:clamp(50px,6vw,78px);width:auto;display:block;}
.footer-cols{display:flex;gap:clamp(30px,6vw,80px);flex-wrap:wrap;}
.footer-col h5{font-family:var(--ff-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.footer-col a,.footer-col p{display:block;font-size:13.5px;color:var(--text-dim);margin-bottom:8px;transition:color .2s;}
.footer-col a:hover{color:var(--cream);}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:32px;font-family:var(--ff-mono);font-size:11px;letter-spacing:.06em;color:var(--text-low);text-transform:uppercase;}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;}}

/* ═══════════════════════════════════════════════════════════════
   CONTENT PAGES — heads, prose, cards, forms, accordion, tables
═══════════════════════════════════════════════════════════════ */
.page-head{position:relative;padding:150px 0 clamp(40px,6vh,72px);border-bottom:1px solid var(--line);overflow:hidden;}
.page-head::before{content:'';position:absolute;top:-40%;right:-10%;width:60%;height:180%;background:radial-gradient(circle,rgba(51,107,230,.14),transparent 65%);pointer-events:none;}
.page-head .ph-num{font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;color:var(--accent);margin:18px 0 14px;}
.page-head h1{font-family:var(--ff-display);font-weight:900;font-size:clamp(46px,9vw,128px);line-height:.84;letter-spacing:-.02em;text-transform:uppercase;color:var(--cream);position:relative;}
.page-head h1 .accent{color:var(--accent);}
.page-head .ph-sub{max-width:620px;margin-top:22px;color:var(--text);font-size:clamp(15px,1.5vw,19px);line-height:1.6;}
.sec{padding:clamp(56px,8vh,110px) 0;}
.sec-num{font-family:var(--ff-mono);font-size:12px;letter-spacing:.16em;color:var(--accent);margin-bottom:18px;}
.sec h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(30px,4.4vw,64px);line-height:.96;text-transform:uppercase;color:var(--cream);}
.sec h2 .accent{color:var(--accent);}
.lead{font-size:clamp(17px,2vw,26px);line-height:1.45;color:var(--cream);max-width:900px;font-weight:300;}
.lead strong{font-weight:600;color:var(--accent);}
.prose{max-width:760px;}
.prose p{color:var(--text-dim);margin-bottom:18px;font-size:15.5px;line-height:1.7;}
.prose p strong{color:var(--cream);font-weight:600;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,48px);}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}}
.split{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(24px,5vw,80px);align-items:start;}
@media(max-width:900px){.split{grid-template-columns:1fr;}}

/* numbered / value cards */
.vcard{border:1px solid var(--line);background:var(--bg-1);padding:30px;position:relative;transition:border-color .25s,transform .25s;}
.vcard:hover{border-color:var(--line-2);transform:translateY(-4px);}
.vcard .vn{font-family:var(--ff-mono);font-size:12px;color:var(--accent);letter-spacing:.1em;}
.vcard h3{font-family:var(--ff-display);font-weight:800;font-size:clamp(22px,2.2vw,30px);line-height:.98;text-transform:uppercase;color:var(--cream);margin:14px 0 12px;}
.vcard p{color:var(--text-dim);font-size:14px;line-height:1.6;}
.vcard .ic{font-size:26px;margin-bottom:6px;display:block;}

/* stat strip */
.statstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(40px,6vh,72px) 0;}
@media(max-width:760px){.statstrip{grid-template-columns:1fr 1fr;gap:36px 24px;}}
.statstrip .st .n{font-family:var(--ff-display);font-weight:800;font-size:clamp(40px,6vw,84px);line-height:.86;color:var(--cream);}
.statstrip .st .n .u{color:var(--accent);}
.statstrip .st .l{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-top:8px;}

/* industries / media cards */
.media-card{position:relative;min-height:300px;overflow:hidden;border:1px solid var(--line);display:flex;align-items:flex-end;}
.media-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.5) contrast(1.05);transition:transform .6s;}
.media-card:hover img{transform:scale(1.05);}
.media-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(10,13,20,.6) 70%,rgba(10,13,20,.95));}
.media-card .mc-body{position:relative;z-index:2;padding:26px;}
.media-card .mc-tag{font-family:var(--ff-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin-bottom:8px;}
.media-card h3{font-family:var(--ff-display);font-weight:800;font-size:clamp(22px,2.4vw,32px);text-transform:uppercase;color:var(--cream);line-height:.98;}
.media-card p{color:var(--text-dim);font-size:13.5px;margin-top:8px;max-width:42ch;}

/* accordion (FAQ) */
.acc{border-top:1px solid var(--line);}
.acc-item{border-bottom:1px solid var(--line);}
.acc-q{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 0;font-family:var(--ff-display);font-weight:700;font-size:clamp(18px,2vw,26px);text-transform:uppercase;color:var(--cream);letter-spacing:.01em;}
.acc-q .pm{font-family:var(--ff-mono);font-size:22px;color:var(--accent);transition:transform .3s;flex-shrink:0;}
.acc-item.open .acc-q .pm{transform:rotate(45deg);}
.acc-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.acc-a .inner{padding:0 0 24px;color:var(--text-dim);font-size:15px;line-height:1.7;max-width:760px;}

/* form */
.form{display:grid;gap:18px;}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:680px){.form .row{grid-template-columns:1fr;}}
.field label{display:block;font-family:var(--ff-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;background:var(--bg-1);border:1px solid var(--line-2);color:var(--cream);padding:13px 14px;font-family:var(--ff-body);font-size:15px;transition:border-color .2s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);}
.field textarea{resize:vertical;min-height:130px;}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--ff-mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:15px 30px;font-weight:500;transition:all .2s;cursor:pointer;border:1px solid transparent;}
.btn-fill{background:var(--accent);color:#fff;}
.btn-fill:hover{background:var(--accent-2);color:var(--bg);transform:translateY(-2px);}
.btn-ghost{border-color:var(--line-2);color:var(--cream);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}

/* contact tiles */
.contact-tile{border:1px solid var(--line);background:var(--bg-1);padding:28px;}
.contact-tile .flag{font-family:var(--ff-mono);font-weight:700;font-size:13px;letter-spacing:.1em;color:var(--accent);border:1px solid var(--accent);display:inline-block;padding:4px 10px;margin-bottom:16px;}
.contact-tile h3{font-family:var(--ff-display);font-weight:800;font-size:26px;text-transform:uppercase;color:var(--cream);margin-bottom:12px;}
.contact-tile p{color:var(--text-dim);font-size:14.5px;margin-bottom:6px;font-family:var(--ff-mono);}
.contact-tile a{color:var(--text);}
.contact-tile a:hover{color:var(--accent);}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:14px;}
.tbl th,.tbl td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);}
.tbl th{font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.tbl td{color:var(--text-dim);}
.tbl td:first-child{color:var(--cream);font-weight:500;}

/* cta band */
.cta-band{text-align:center;padding:clamp(70px,12vh,140px) 0;border-top:1px solid var(--line);position:relative;overflow:hidden;}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(51,107,230,.16),transparent 60%);}
.cta-band h2{position:relative;font-family:var(--ff-display);font-weight:900;font-size:clamp(38px,7vw,104px);line-height:.84;text-transform:uppercase;color:var(--cream);letter-spacing:-.02em;}
.cta-band p{position:relative;max-width:520px;margin:20px auto 32px;color:var(--text);font-size:16px;}
.cta-band .row{position:relative;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* breadcrumb spacing on content pages */
.page-head .breadcrumb{margin-bottom:6px;}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.tag-list span{font-family:var(--ff-mono);font-size:11px;letter-spacing:.06em;color:var(--text-dim);border:1px solid var(--line-2);padding:7px 13px;}
