@font-face{font-family:"Inter";src:url("assets/Inter-VariableFont_opsz,wght.ttf") format("truetype");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/Inter-Italic-VariableFont_opsz,wght.ttf") format("truetype");font-weight:100 900;font-style:italic;font-display:swap}
:root{
  --dusk:#0F1219;
  --red:#A11818;
  --pearl:#D9D9D9;
  --gray:#A0A0A0;
  --sapphire:#A7B6BC;
  --sapphire-deep:#243D49;
  --cream:#F5F1EA;
  --cloud:#F6F7F7;
  --ink:#13161c;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--dusk);color:var(--pearl);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button,input,textarea{font:inherit}
main{overflow-x:clip}
.tone-dusk{background:var(--dusk);color:var(--pearl)}
.tone-pearl{background:var(--pearl);color:var(--ink)}
.tone-cloud{background:var(--cloud);color:var(--ink)}
.tone-sapphire{background:var(--sapphire);color:var(--ink)}
.tone-sapphire-deep{background:var(--sapphire-deep);color:#f7f9fa}
.tone-cream{background:var(--cream);color:var(--ink)}

/* Intro — Altrum-inspired text reveal on black */
.intro{position:fixed;inset:0;z-index:100;background:#06080c;display:grid;place-items:center;pointer-events:none;overflow:hidden;transition:opacity .9s var(--ease),visibility 0s linear 1.2s}
.intro::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%, rgba(167,182,188,.06), transparent 55%);opacity:0;transition:opacity 1.2s ease}
.intro.lit::before{opacity:1}
.intro-inner{display:flex;align-items:baseline;gap:.55ch;font-size:clamp(18px,1.9vw,26px);font-weight:300;letter-spacing:-.02em;color:rgba(245,241,234,.92);font-family:Inter,system-ui,sans-serif;filter:blur(8px);opacity:0;transition:filter 1.1s var(--ease),opacity 1.1s var(--ease),transform 1.1s var(--ease);transform:translateY(8px)}
.intro.lit .intro-inner{filter:blur(0);opacity:1;transform:none}
.intro-brand em{font-style:normal;font-weight:500}
.intro-brand sup{font-size:.5em;margin-left:.06em;color:rgba(245,241,234,.55)}
.intro-tag{color:rgba(245,241,234,.45);opacity:0;transform:translateX(-6px);transition:opacity .9s ease .45s,transform .9s var(--ease) .45s}
.intro.lit .intro-tag{opacity:1;transform:none}
.intro-bar{position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--red),transparent);transform:scaleX(0);transform-origin:left;transition:transform 1.1s var(--ease) .25s}
.intro.lit .intro-bar{transform:scaleX(1);transform-origin:right;transition:transform 1.4s var(--ease) .15s}
.intro.done{opacity:0;visibility:hidden}
.intro.done .intro-inner{filter:blur(14px);transform:translateY(-6px) scale(.98);transition:filter .7s ease,transform .9s var(--ease),opacity .6s ease}
.cursor-dot{position:fixed;left:50%;top:50%;width:14px;height:14px;border-radius:50%;background:var(--red);pointer-events:none;z-index:120;opacity:0;transform:translate(-50%,-50%) scale(.75);transition:opacity .24s ease,transform .18s ease,width .24s ease,height .24s ease,background-color .24s ease,box-shadow .24s ease;box-shadow:0 0 0 1px rgba(255,255,255,.05),0 0 22px rgba(161,24,24,.32)}
.cursor-dot.active{opacity:1;transform:translate(-50%,-50%) scale(1)}
.cursor-dot.hovering{width:22px;height:22px;box-shadow:0 0 0 1px rgba(255,255,255,.08),0 0 30px rgba(161,24,24,.42)}
body.cursor-active,body.cursor-active a,body.cursor-active button,body.cursor-active input,body.cursor-active textarea{cursor:none}
.cursor-dot{position:fixed;left:50%;top:50%;width:16px;height:16px;border-radius:50%;background:var(--red);pointer-events:none;z-index:120;opacity:0;transform:translate(-50%,-50%) scale(.75);transition:opacity .24s ease,transform .18s ease,width .24s ease,height .24s ease,background-color .24s ease,box-shadow .24s ease;box-shadow:0 0 0 1px rgba(255,255,255,.05),0 0 22px rgba(161,24,24,.32)}
.cursor-dot.active{opacity:1;transform:translate(-50%,-50%) scale(1)}
.cursor-dot.hovering{width:24px;height:24px;box-shadow:0 0 0 1px rgba(255,255,255,.08),0 0 30px rgba(161,24,24,.42)}
body.cursor-active,body.cursor-active a,body.cursor-active button,body.cursor-active input,body.cursor-active textarea{cursor:none}

/* Header */
.site-header{position:fixed;inset:0 0 auto;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:24px 36px;transition:.4s var(--ease)}
.site-header.scrolled{padding-block:15px;background:rgba(15,18,25,.68);backdrop-filter:blur(18px);border-bottom:1px solid rgba(217,217,217,.08)}
.brand{position:relative;display:block}
.brand img{width:228px;filter:brightness(1.18)}
.brand-dot-target{position:absolute;left:11.23%;top:70.8%;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%)}
.header-actions{display:flex;align-items:center;gap:24px}
.header-link{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:rgba(217,217,217,.72)}
.menu-trigger{display:flex;align-items:center;gap:9px;border:0;background:transparent;color:#fff;cursor:pointer;font-size:12px;text-transform:uppercase;letter-spacing:.16em}
.menu-trigger i{width:18px;height:1px;background:#fff;display:block}
.menu-trigger i:last-child{display:none}

/* Menu */
.menu-panel{position:fixed;inset:0;z-index:70;background:rgba(246,247,247,.985);color:var(--ink);transform:translateY(-102%);transition:.75s var(--ease);padding:60px clamp(28px,8vw,140px);display:grid;grid-template-columns:100px 1fr auto;gap:40px}
.menu-panel.open{transform:none}
.menu-close{position:absolute;top:28px;right:34px;width:52px;height:52px;border:0;border-radius:50%;background:var(--ink);color:#fff;font-size:32px;font-weight:300;cursor:pointer}
.menu-panel>p{writing-mode:vertical-rl;font-size:12px;letter-spacing:.2em;font-weight:600}
.menu-panel nav{display:grid;align-content:center;gap:22px}
.menu-panel nav a{font-size:clamp(44px,6vw,88px);line-height:1;font-weight:300;letter-spacing:-.07em;transition:.25s}
.menu-panel nav a:hover{color:var(--red);padding-left:14px}
.menu-meta{display:grid;align-content:end;gap:12px;color:rgba(15,18,25,.52);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.menu-meta b{color:var(--red)}

/* Shared typography */
.kicker{display:flex;align-items:center;gap:10px;margin:0 0 28px;font-size:10px;letter-spacing:.19em;text-transform:uppercase;color:rgba(217,217,217,.66);font-weight:600}
.kicker.dark{color:rgba(15,18,25,.55)}
.kicker span{width:7px;height:7px;border-radius:50%;background:var(--red)}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(64px,10vw,158px);line-height:.86;letter-spacing:-.085em;font-weight:300;margin-bottom:28px}
h1 em{font-style:normal;color:var(--sapphire)}
h1 b,.manifesto h2 b,.contact h2 b{color:var(--red);font-size:.23em;margin-left:.09em;vertical-align:baseline}
.hero-dot-target{display:inline-block;transform:translateY(-.02em);text-shadow:0 0 18px rgba(161,24,24,.22)}
.button{display:inline-flex;gap:8px;align-items:center;justify-content:center;border-radius:999px;padding:10px 18px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;transition:.35s var(--ease)}
.solid{background:var(--pearl);color:var(--ink)}
.solid:hover{background:#fff;transform:translateY(-3px)}
.ghost{border:1px solid rgba(217,217,217,.22);color:var(--pearl)}
.ghost:hover{border-color:var(--red);transform:translateY(-3px)}

/* Hero */
.hero{min-height:100svh;position:relative;overflow:hidden;display:flex;align-items:center;isolation:isolate;background:
  radial-gradient(circle at 82% 14%, rgba(167,182,188,.12), transparent 24%),
  radial-gradient(circle at 8% 92%, rgba(167,182,188,.07), transparent 22%),
  linear-gradient(180deg, #070a0f 0%, #0a0f16 45%, #0e141d 100%)}
.hero-visual{position:absolute;inset:0;z-index:-1}
.hero-visual svg{width:100%;height:100%;position:absolute;inset:0}
.hero-ribbon{position:absolute;border-radius:48% 52% 43% 57% / 56% 42% 58% 44%;filter:blur(4px);opacity:.32;mix-blend-mode:screen;animation:floatRibbon 22s ease-in-out infinite}
.ribbon-a{width:42vw;min-width:340px;height:30vw;min-height:250px;right:-10vw;top:10%;background:linear-gradient(135deg, rgba(245,241,234,.11), rgba(167,182,188,.07), rgba(255,255,255,.02));transform:rotate(-18deg)}
.ribbon-b{width:40vw;min-width:320px;height:28vw;min-height:240px;left:-12vw;bottom:-10%;background:linear-gradient(155deg, rgba(167,182,188,.10), rgba(245,241,234,.04), rgba(161,24,24,.05));transform:rotate(22deg);animation-delay:-7s}
.ribbon-c{width:24vw;min-width:240px;height:18vw;min-height:180px;left:46%;top:14%;background:linear-gradient(165deg, rgba(255,255,255,.03), rgba(167,182,188,.05), rgba(15,18,25,0));transform:rotate(14deg);animation-delay:-12s}
.hero-path{fill:none;stroke:rgba(161,24,24,.22);stroke-width:1.05;stroke-dasharray:10 520;animation:pathMove 8.7s ease-in-out infinite}
.path-two{stroke:rgba(167,182,188,.14);animation-delay:-3.8s}
.travelling-dot{display:none}
/* Hero — Altrum-inspired image + line dividers */
.hero{min-height:100svh;height:100svh;position:relative;overflow:hidden;display:flex;align-items:flex-end;isolation:isolate;background:#06080c;padding-bottom:clamp(96px,12vh,140px)}
.hero-media{position:absolute;inset:0;z-index:-1;overflow:hidden}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:88% center;transform:scale(1.08);transition:transform 1.6s var(--ease),filter 1.6s var(--ease);filter:brightness(.78) contrast(1.05);opacity:0}
.hero.lit .hero-photo{transform:scale(1);opacity:1}
.hero-photo-wash{position:absolute;inset:0;background:
  linear-gradient(90deg, rgba(6,8,12,.95) 0%, rgba(6,8,12,.85) 32%, rgba(6,8,12,.45) 58%, rgba(6,8,12,.15) 78%, rgba(6,8,12,.5) 100%),
  linear-gradient(180deg, rgba(6,8,12,.55) 0%, rgba(6,8,12,0) 30%, rgba(6,8,12,0) 60%, rgba(6,8,12,.85) 100%)}
.hero-lines{position:absolute;inset:0;display:flex;justify-content:space-between;pointer-events:none;padding:0 4vw}
.hero-lines span{display:block;width:1px;height:0;background:linear-gradient(180deg,rgba(245,241,234,0) 0%,rgba(245,241,234,.18) 30%,rgba(245,241,234,.06) 100%);align-self:stretch;transform-origin:top;transition:height 1.1s var(--ease)}
.hero.lit .hero-lines span{height:100%}
.hero-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%, transparent 30%, rgba(6,8,12,.55) 85%);pointer-events:none}
.hero-grain{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle at 20% 20%, rgba(255,255,255,.8) .5px, transparent .6px),radial-gradient(circle at 80% 70%, rgba(255,255,255,.6) .5px, transparent .6px);background-size:26px 26px,31px 31px;pointer-events:none}
.hero-shell,.statement-shell,.portfolio-shell,.experience-shell,.values-shell,.manifesto-shell,.contact-shell{width:min(1320px,calc(100% - 72px));margin:auto}
.hero-shell{padding-top:clamp(110px,14vh,150px);position:relative;z-index:2}
.hero-headline{display:flex;flex-direction:column;gap:.02em;font-size:clamp(46px,6.6vw,108px);line-height:.94;letter-spacing:-.05em;font-weight:300;margin:0 0 22px;color:#fff}
.hero-headline .hero-word{display:block;overflow:hidden}
.hero-headline .hero-word em{font-style:italic;font-weight:300;color:var(--sapphire)}
.hero-headline b.hero-dot-target{color:var(--red);font-weight:400;font-size:1em;margin-left:.04em;display:inline}
.hero-copy{max-width:520px;color:rgba(245,241,234,.72);font-size:clamp(14px,1.15vw,17px);line-height:1.55}
.hero-actions{display:flex;gap:14px;margin-top:22px;flex-wrap:wrap}
.hero-foot{position:absolute;left:0;right:0;bottom:28px;z-index:2;display:flex;justify-content:space-between;align-items:end;padding:0 clamp(28px,4vw,56px);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,241,234,.55)}
.hero-foot-label{font-weight:500}
.scroll-mark{display:grid;justify-items:center;gap:7px;font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:rgba(245,241,234,.6)}
.scroll-mark i{font-style:normal;font-size:16px;animation:scrollHint 2.4s ease-in-out infinite}
@keyframes scrollHint{0%,100%{transform:translateY(0);opacity:.6}50%{transform:translateY(5px);opacity:1}}
@media (max-width:760px){
  .hero{padding-bottom:140px}
  .hero-photo{object-position:80% center}
  .hero-photo-wash{background:linear-gradient(180deg, rgba(6,8,12,.55) 0%, rgba(6,8,12,.4) 35%, rgba(6,8,12,.9) 100%)}
  .hero-foot{flex-direction:column;align-items:flex-start;gap:18px}
}

/* Sections */
.statement{padding:150px 0 125px}
.statement h2{font-size:clamp(50px,7.6vw,118px);line-height:.9;letter-spacing:-.085em;font-weight:300;max-width:1220px}
.statement h2 em{font-style:normal;color:var(--red)}
.statement-bottom{margin-top:72px;display:grid;grid-template-columns:1fr auto;gap:44px;align-items:end;border-top:1px solid rgba(15,18,25,.13);padding-top:22px}
.statement-bottom p{max-width:620px;font-size:18px;line-height:1.65;color:rgba(15,18,25,.58)}
.statement-bottom span{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(15,18,25,.52)}

.transition-band{padding:30px 0;overflow:hidden}
.transition-copy{display:flex;align-items:center;gap:30px;justify-content:center;white-space:nowrap}
.transition-copy p{font-size:clamp(22px,3vw,42px);margin:0;letter-spacing:-.05em;font-weight:300}
.transition-copy b{font-size:12px;color:var(--red)}

/* Portfolio */
.portfolio{padding:135px 0 120px;background:linear-gradient(180deg, #f3f4f5 0%, #f7f7f7 50%, #eef1f2 100%)}
.section-heading{display:grid;grid-template-columns:.38fr 1fr;gap:52px;align-items:start;margin-bottom:56px}
.section-heading h2{font-size:clamp(44px,6vw,88px);line-height:.94;letter-spacing:-.07em;font-weight:300;max-width:900px}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.product-card{position:relative;min-height:520px;border-radius:30px;overflow:hidden;color:#fff;isolation:isolate;box-shadow:0 18px 38px rgba(15,18,25,.09);transition:.55s var(--ease);background:#0f141b}
.product-card:hover{transform:translateY(-9px)}
.product-card:hover .visual{transform:scale(1.03)}
.visual{position:absolute;inset:0;transition:.8s var(--ease);overflow:hidden}
.visual:before,.visual:after{content:"";position:absolute;border-radius:50%}
.brand-mark{position:absolute;width:124px;opacity:.11;filter:brightness(1.25);right:8%;top:9%;transform:rotate(-10deg)}
.product-pack{position:absolute;z-index:1;filter:drop-shadow(0 20px 28px rgba(0,0,0,.22)) drop-shadow(0 34px 60px rgba(15,18,25,.22));transition:transform .6s var(--ease)}
.product-card:hover .product-pack{transform:translateX(-50%) translateY(-6px) rotate(var(--pack-rotate,0deg))}
.visual-brujesin{background:radial-gradient(circle at 78% 20%, rgba(167,182,188,.16), transparent 18%),linear-gradient(145deg,#0d1219,#141d28 42%,#263542 100%)}
.visual-brujesin:before{width:360px;height:360px;background:radial-gradient(circle,rgba(167,182,188,.24),transparent 68%);right:-80px;bottom:18px}
.visual-brujesin:after{width:250px;height:430px;border:1px solid rgba(217,217,217,.14);left:14%;top:-48px;transform:rotate(23deg)}
.product-brujesin{--pack-rotate:-3deg;width:auto;height:68%;left:50%;top:8%;transform:translateX(-50%) rotate(-3deg)}

.visual-melanoderm{background:linear-gradient(155deg,#e8ebec,#c8d1d0 54%,#a7b6bc 100%)}
.visual-melanoderm:before{width:330px;height:520px;background:linear-gradient(180deg,rgba(255,255,255,.65),rgba(161,24,24,.07));left:14%;top:-36px;border-radius:45% 55% 50% 46%;transform:rotate(18deg);filter:blur(1px)}
.visual-melanoderm:after{width:220px;height:220px;background:rgba(255,214,55,.18);right:12%;bottom:18%;filter:blur(48px)}
.product-melanoderm{--pack-rotate:-1deg;width:68%;left:50%;top:12%;transform:translateX(-50%) rotate(-1deg)}

.visual-otosan{background:radial-gradient(circle at 80% 24%, rgba(167,182,188,.18), transparent 16%),linear-gradient(155deg,#161c23,#0d1015 52%,#21313d)}
.visual-otosan:before{width:420px;height:420px;border:1px solid rgba(167,182,188,.36);right:-100px;top:28px}
.visual-otosan:after{width:220px;height:220px;border:1px solid rgba(161,24,24,.42);right:12px;top:138px}
.product-otosan{--pack-rotate:0deg;width:78%;left:50%;top:12%;transform:translateX(-50%)}

.card-gradient{position:absolute;inset:34% 0 0;background:linear-gradient(transparent,rgba(5,8,12,.92));z-index:1}
.card-copy{position:absolute;left:26px;right:84px;bottom:25px;z-index:2}
.card-copy small{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.card-copy h3{font-size:clamp(38px,4.3vw,60px);line-height:.94;letter-spacing:-.08em;font-weight:300;margin:10px 0 7px}
.card-copy p{margin:0;color:rgba(255,255,255,.72);font-size:14px;line-height:1.5}
.card-arrow{position:absolute;right:22px;bottom:22px;z-index:3;width:50px;height:50px;border-radius:50%;background:rgba(217,217,217,.2);backdrop-filter:blur(10px);display:grid;place-items:center;font-size:22px;transition:.35s var(--ease)}
.product-card:hover .card-arrow{background:var(--red);transform:translateX(4px)}
.portfolio-foot{margin-top:36px;display:grid;grid-template-columns:1fr auto;gap:30px;padding-top:22px;border-top:1px solid rgba(15,18,25,.12);align-items:center}
.portfolio-foot p{max-width:640px;color:rgba(15,18,25,.58);font-size:17px;line-height:1.6}
.portfolio-foot a{font-size:12px;text-transform:uppercase;letter-spacing:.11em;font-weight:600}
.portfolio-foot a span{margin-left:10px;color:var(--red)}

/* Bridge */
.bridge{padding:100px 0;background:linear-gradient(180deg, #eff2f2 0%, var(--dusk) 22%, var(--dusk) 100%)}
.bridge-card{width:min(1320px,calc(100% - 72px));margin:auto;display:grid;grid-template-columns:.85fr 1.15fr;border-radius:34px;overflow:hidden;background:#080a0e;min-height:480px}
.bridge-copy{padding:62px}
.bridge-copy h2{font-size:clamp(48px,5.5vw,86px);line-height:.92;letter-spacing:-.075em;font-weight:300}
.bridge-copy>p:not(.kicker){font-size:17px;line-height:1.62;color:rgba(217,217,217,.62);max-width:490px;margin:25px 0 34px}
.bridge-art{position:relative;overflow:hidden;background:linear-gradient(140deg,#203039,#607780 70%,#a7b6bc)}
.bridge-art:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 45%,rgba(245,241,234,.35),transparent 30%)}
.bridge-art img{position:absolute;width:340px;left:50%;top:50%;transform:translate(-50%,-50%);opacity:.46;filter:brightness(1.42)}
.art-line{position:absolute;height:1px;width:120%;background:rgba(217,217,217,.45);left:-10%;transform:rotate(-20deg)}
.art-line.a{top:30%}.art-line.b{top:50%}.art-line.c{top:70%}
.art-dot{position:absolute;width:18px;height:18px;background:var(--red);border-radius:50%;left:50%;top:50%;transform:translate(calc(-50% - 3px),calc(-50% + 46px));z-index:2;animation:dotPulse 3s infinite;box-shadow:0 0 0 0 rgba(161,24,24,.32)}

/* Experience */
.experience{padding:128px 0;background:#fff;color:var(--ink)}
.experience-head{width:min(1320px,calc(100% - 72px));margin:0 auto 56px}
.experience-head h2{font-size:clamp(34px,4.4vw,64px);line-height:.98;letter-spacing:-.06em;font-weight:300;margin:0;color:var(--ink)}
.experience-shell{width:min(1320px,calc(100% - 72px));margin:0 auto;display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:stretch}
.founder-col{display:flex;flex-direction:column;gap:28px}
.founder-media{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;background:#e8e4dc;flex:1}
.founder-media img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(100%) contrast(1.04)}
.experience-right{display:flex;flex-direction:column;gap:32px}
.experience-cards{display:flex;flex-direction:column;gap:20px}
.exp-card{position:relative;background:#0a0a0a;color:#fff;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:38px 36px;display:flex;flex-direction:column;gap:20px}
.exp-card .kicker{margin:0;color:rgba(255,255,255,.6);font-size:10px;letter-spacing:.19em;font-weight:600}
.exp-card .kicker span{background:var(--red)}
.exp-bignum{font-family:Inter,sans-serif;font-size:clamp(110px,13vw,180px);font-weight:800;line-height:.9;letter-spacing:-.05em;color:#fff;display:flex;align-items:flex-start;gap:8px}
.exp-bignum i{font-style:normal;color:rgba(255,255,255,.35);font-weight:600;font-size:.55em;line-height:1;margin-top:.12em}
.exp-card h3{font-family:Inter,sans-serif;font-size:15px;font-weight:500;color:#fff;letter-spacing:.01em;margin:0;line-height:1.4}
.exp-card p{font-family:Inter,sans-serif;font-size:14.5px;line-height:1.65;color:#d4d4d8;font-weight:400;margin:0}
.experience-sign{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding-top:8px}
.experience-sign .founder-signature{width:180px;height:auto;filter:contrast(1.1)}
.experience-sign .sign-name{font-family:Inter,sans-serif;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin:0}
.experience-sign .sign-role{font-family:Inter,sans-serif;font-size:13px;font-weight:300;color:rgba(15,18,25,.7);margin:0;letter-spacing:.02em}


/* Values */
.values{padding:130px 0}
.values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(217,217,217,.15);border:1px solid rgba(217,217,217,.15)}
.values article{padding:32px 22px;background:var(--sapphire-deep);min-height:255px}
.values article b{font-size:11px;color:#ffb7b7;letter-spacing:.14em}
.values article h3{font-size:31px;letter-spacing:-.065em;font-weight:300;margin:56px 0 14px}
.values article p{font-size:14px;line-height:1.6;color:rgba(247,249,250,.65)}

/* Manifesto / Contact */
.manifesto{padding:165px 0}
.manifesto h2{font-size:clamp(48px,7vw,108px);line-height:.91;letter-spacing:-.085em;font-weight:300;max-width:1220px}
.contact{padding:140px 0}
.contact-shell{display:grid;grid-template-columns:1fr .82fr;gap:84px}
.contact h2{font-size:clamp(52px,7vw,102px);line-height:.9;letter-spacing:-.085em;font-weight:300}
.contact-copy>p:not(.kicker){color:rgba(217,217,217,.62);font-size:18px;line-height:1.65;max-width:560px;margin-top:27px}
.contact-form{display:grid;gap:18px}
label{display:grid;gap:8px;color:rgba(217,217,217,.58);font-size:10px;text-transform:uppercase;letter-spacing:.15em}
input,textarea{border:1px solid rgba(217,217,217,.14);background:rgba(217,217,217,.035);padding:17px 15px;color:white;outline:none;transition:.25s}
textarea{min-height:140px;resize:vertical}
input:focus,textarea:focus{border-color:var(--red);box-shadow:inset -5px 0 0 var(--red)}
.contact-form button{border:0;background:var(--pearl);color:var(--ink);padding:18px;cursor:pointer;text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:700;transition:.35s var(--ease)}
.contact-form button:hover{background:#fff;transform:translateY(-3px)}
.contact-form span{float:right;color:var(--red)}
.site-footer{background:#0a0d12;color:rgba(217,217,217,.72);padding:72px 56px 32px;font-family:inherit}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;max-width:1280px;margin:0 auto;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-col h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin:0 0 18px;font-weight:600}
.footer-col p{font-size:13px;line-height:1.6;color:rgba(217,217,217,.6);margin:14px 0 0;max-width:280px;text-transform:none;letter-spacing:0}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col li{font-size:13px;color:rgba(217,217,217,.65);text-transform:none;letter-spacing:0}
.footer-col a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
.footer-col a:hover{color:#fff}
.footer-logo{width:160px;display:block}
.footer-legal{max-width:1280px;margin:0 auto;padding-top:28px;text-align:center;color:rgba(217,217,217,.42)}
.footer-legal-links{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;font-size:11px;letter-spacing:.08em;margin-bottom:14px}
.footer-legal-links a{color:rgba(217,217,217,.6);text-decoration:none}
.footer-legal-links a:hover{color:#fff}
.footer-legal-links span{opacity:.4}
.footer-legal-copy{font-size:11px;letter-spacing:.06em;margin:0 0 10px;color:rgba(217,217,217,.55)}
.footer-disclaimer{font-size:10.5px;line-height:1.65;max-width:780px;margin:0 auto;color:rgba(217,217,217,.38);letter-spacing:.01em}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:1s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.24s}
.delay-3{transition-delay:.36s}

/* keyframes */
@keyframes pathMove{0%{stroke-dashoffset:560;opacity:.15}20%,72%{opacity:1}100%{stroke-dashoffset:-280;opacity:.16}}
@keyframes travel{0%{offset-distance:0%;opacity:0}8%{opacity:1}84%{opacity:1}100%{offset-distance:100%;opacity:0}}
@keyframes dotPulse{50%{transform:scale(1.65);box-shadow:0 0 0 17px rgba(161,24,24,.07),0 0 36px rgba(161,24,24,.42)}}
@keyframes floatRibbon{0%,100%{transform:translate3d(0,0,0) rotate(var(--ribbon-rotate,0deg))}50%{transform:translate3d(0,22px,0) rotate(calc(var(--ribbon-rotate,0deg) + 3deg))}}
.ribbon-a{--ribbon-rotate:-18deg}
.ribbon-b{--ribbon-rotate:22deg}
.ribbon-c{--ribbon-rotate:14deg}

/* responsive */
@media (max-width: 1100px){
  .section-heading{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .site-header{padding:18px 20px}
  .brand img{width:188px}
  .header-link{display:none}
  .hero-shell,.statement-shell,.portfolio-shell,.experience-shell,.values-shell,.manifesto-shell,.contact-shell{width:min(100% - 40px,760px)}
  h1{font-size:clamp(63px,18vw,118px)}
  .scroll-mark{display:none}
  .statement,.portfolio,.experience,.values,.manifesto,.contact{padding:96px 0}
  .statement-bottom,.section-heading,.portfolio-foot,.experience-shell,.contact-shell,.bridge-card{grid-template-columns:1fr;gap:30px}
  .product-grid{grid-template-columns:1fr}
  .product-card{min-height:460px}
  .bridge{padding:74px 0}
  .bridge-card{width:calc(100% - 40px);min-height:auto}
  .bridge-copy{padding:34px 28px}
  .bridge-art{min-height:310px}
  .bridge-art img{width:260px}
  .art-dot{transform:translate(calc(-50% - 2px),calc(-50% + 35px))}
  .values-grid{grid-template-columns:1fr}
  .values article{min-height:auto}
  .values article h3{margin-top:30px}
  .menu-panel{grid-template-columns:1fr;padding:60px 28px}
  .menu-panel>p{writing-mode:initial}
  .menu-meta{display:none}
  .site-footer{padding:48px 22px 24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;padding-bottom:32px}
  .footer-col:first-child{grid-column:1/-1}
  .transition-copy{gap:15px;justify-content:flex-start;padding-left:18px;animation:bandScroll 15s linear infinite}
  .transition-copy p{font-size:26px}
  .metric b{padding-bottom:12px}
  .product-brujesin{width:auto;height:64%;top:10%}
  .product-melanoderm{width:70%;top:14%}
  .product-otosan{width:78%;top:15%}
  @keyframes bandScroll{to{transform:translateX(-35%)}}
}

@media (pointer:coarse){
  .cursor-dot{display:none}
  body.cursor-active,body.cursor-active a,body.cursor-active button,body.cursor-active input,body.cursor-active textarea{cursor:auto}
}

/* ============ HERO TRUSTED BY ============ */
.hero-trust{margin-top:50px;display:flex;flex-direction:column;gap:16px}
.trust-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(217,217,217,.5);font-weight:600}
.trust-logos{display:flex;align-items:center;gap:38px;flex-wrap:wrap}
.trust-logo{font-size:15px;font-weight:600;letter-spacing:-.01em;color:rgba(217,217,217,.82);display:inline-flex;align-items:center;gap:9px}
.trust-logo::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);opacity:.7}
.trust-logo.is-placeholder{color:rgba(217,217,217,.4);font-weight:500}
.trust-logo.is-placeholder::before{opacity:.35}
.trust-logo.is-placeholder i{font-style:normal;font-size:9px;letter-spacing:.12em;color:var(--red);opacity:.85}

/* ============ COMPAÑÍA (statement + 3 cards) ============ */
.company{padding:150px 0 130px}
.company-shell{width:min(1320px,calc(100% - 72px));margin:auto}
.company-statement{font-size:clamp(30px,4.2vw,62px);line-height:1.05;letter-spacing:-.055em;font-weight:300;max-width:17ch;margin:0 0 32px}
.company-sub{max-width:600px;margin:0 0 0 auto;font-size:clamp(16px,1.5vw,19px);line-height:1.6;color:rgba(15,18,25,.58)}
.company-cards{margin-top:74px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ccard{position:relative;display:flex;flex-direction:column;justify-content:space-between;min-height:344px;padding:34px;border-radius:24px;overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.ccard:hover{transform:translateY(-9px)}
.ccard-body h3{font-size:clamp(24px,2vw,31px);line-height:1.04;letter-spacing:-.045em;font-weight:400;margin:0 0 14px}
.ccard-body p{font-size:14.5px;line-height:1.58;margin:0}
.ccard-cta{margin-top:30px;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px}
.ccard-cta i{font-style:normal;transition:transform .35s var(--ease)}
.ccard:hover .ccard-cta i{transform:translateX(5px)}
.ccard-arrow{align-self:flex-end;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:20px;transition:.35s var(--ease)}
.ccard-mark{align-self:flex-end}
.ccard-mark img{width:44px;opacity:.92;filter:brightness(1.3)}
.ccard-accent{background:var(--sapphire-deep);color:#f7f9fa}
.ccard-accent .ccard-body p{color:rgba(247,249,250,.72)}
.ccard-accent .ccard-arrow{background:rgba(255,255,255,.1);color:#fff}
.ccard-accent:hover .ccard-arrow{background:var(--red)}
.ccard-accent .ccard-cta i{color:#ffb7b7}
.ccard-dark{background:var(--dusk);color:var(--pearl)}
.ccard-dark::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 84% 10%,rgba(167,182,188,.16),transparent 42%);pointer-events:none}
.ccard-dark .ccard-body p{color:rgba(217,217,217,.62)}
.ccard-dark .ccard-cta i{color:var(--red)}
.ccard-grad{background:linear-gradient(150deg,#cdd6d8,#a7b6bc 58%,#7f9298);color:var(--ink)}
.ccard-grad .ccard-body p{color:rgba(19,22,28,.7)}
.ccard-grad .ccard-arrow{background:rgba(15,18,25,.12);color:var(--ink)}
.ccard-grad:hover .ccard-arrow{background:var(--red);color:#fff}
.ccard-grad .ccard-cta i{color:var(--red)}

/* ============ PRODUCTOS DESTACADOS (featured, dark) ============ */
.featured{padding:135px 0 128px;background:linear-gradient(180deg,#0b0e14,#0f141d 58%,#0b0e14)}
.featured-shell{width:min(1320px,calc(100% - 72px));margin:auto}
.featured-head{text-align:center;max-width:680px;margin:0 auto 58px}
.featured-head .kicker{justify-content:center}
.featured-head h2{font-size:clamp(40px,5vw,76px);line-height:.96;letter-spacing:-.07em;font-weight:300;margin:0 0 18px}
.featured-sub{color:rgba(217,217,217,.6);font-size:17px;margin:0}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat-card{position:relative;min-height:560px;border-radius:26px;overflow:hidden;isolation:isolate;background:#0f141b;box-shadow:0 24px 60px -32px rgba(0,0,0,.85);transition:transform .55s var(--ease)}
.feat-card:hover{transform:translateY(-10px)}
.feat-card .visual{position:absolute;inset:0;transition:.8s var(--ease)}
.feat-card:hover .visual{transform:scale(1.04)}
.feat-card:hover .product-pack{transform:translateX(-50%) translateY(-8px) rotate(var(--pack-rotate,0deg))}
.feat-card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(transparent 40%,rgba(5,8,12,.86));pointer-events:none}
.feat-chip{position:absolute;z-index:3;top:22px;left:22px;padding:8px 16px;border-radius:999px;background:rgba(217,217,217,.16);backdrop-filter:blur(10px);font-size:12px;font-weight:600;color:#fff}
.feat-go{position:absolute;z-index:3;top:20px;right:20px;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(217,217,217,.35);color:#fff;font-size:17px;transition:.35s var(--ease)}
.feat-card:hover .feat-go{background:var(--red);border-color:var(--red)}
.feat-hover{position:absolute;z-index:3;left:0;right:0;top:45%;text-align:center;transform:translateY(8px);color:#fff;font-size:clamp(26px,2.4vw,34px);font-weight:300;letter-spacing:-.03em;opacity:0;transition:.45s var(--ease);pointer-events:none}
.feat-card:hover .feat-hover{opacity:1;transform:none}
.feat-foot{position:absolute;z-index:3;left:24px;right:24px;bottom:24px;display:flex;justify-content:space-between;align-items:flex-end;gap:16px}
.feat-foot small{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.62)}
.feat-foot h3{font-size:clamp(24px,2.2vw,32px);line-height:1;letter-spacing:-.05em;font-weight:300;margin:8px 0 0;color:#fff}
.feat-tag{font-size:11px;letter-spacing:.03em;color:rgba(255,255,255,.66);text-align:right;max-width:46%}
.featured-foot{margin-top:46px;display:flex;justify-content:space-between;gap:30px;align-items:center;padding-top:24px;border-top:1px solid rgba(217,217,217,.12)}
.featured-foot p{max-width:560px;color:rgba(217,217,217,.62);font-size:16px;margin:0}
.featured-foot a{font-size:12px;text-transform:uppercase;letter-spacing:.11em;font-weight:600;color:#fff;white-space:nowrap}
.featured-foot a span{margin-left:10px;color:var(--red)}

/* ============ SERVICIOS (light, animated bg, Porsche-style) ============ */
.services{position:relative;padding:140px 0;background:linear-gradient(180deg,#eef0f1,#e7eaec 55%,#eceef0);overflow:hidden}
.services-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.services-bg span{position:absolute;border-radius:50%;filter:blur(64px);opacity:.55;animation:svcFloat 26s ease-in-out infinite}
.services-bg span:first-child{width:42vw;height:42vw;left:-8vw;top:-12vw;background:radial-gradient(circle,rgba(167,182,188,.55),transparent 66%)}
.services-bg span:last-child{width:40vw;height:40vw;right:-10vw;bottom:-14vw;background:radial-gradient(circle,rgba(161,24,24,.07),transparent 66%);animation-delay:-13s}
@keyframes svcFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(0,42px)}}
.services-shell{position:relative;z-index:1;width:min(1320px,calc(100% - 72px));margin:auto}
.services-head{margin-bottom:54px;max-width:780px}
.services-head h2{font-size:clamp(34px,4.4vw,64px);line-height:.98;letter-spacing:-.06em;font-weight:300;margin:0;color:var(--ink)}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.svc-card{background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 18px 48px -30px rgba(15,18,25,.42);display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 30px 64px -30px rgba(15,18,25,.5)}
.svc-media{aspect-ratio:4/3;background:linear-gradient(145deg,#dfe4e6,#c3ced1);display:grid;place-items:center;position:relative;overflow:hidden}
.svc-media::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 24%,rgba(167,182,188,.55),transparent 56%)}
.svc-slot{position:relative;z-index:1;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(15,18,25,.42);font-weight:600;border:1px dashed rgba(15,18,25,.25);padding:8px 12px;border-radius:6px}
.svc-body{padding:28px 24px 30px;display:flex;flex-direction:column;flex:1}
.svc-body h3{font-size:20px;line-height:1.13;letter-spacing:-.03em;font-weight:500;color:var(--ink);margin:0 0 12px}
.svc-body p{font-size:14px;line-height:1.55;color:rgba(15,18,25,.6);margin:0 0 22px}
.svc-btn{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(15,18,25,.25);border-radius:999px;padding:11px 18px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);transition:.35s var(--ease)}
.svc-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.svc-btn i{font-style:normal;transition:transform .35s var(--ease)}
.svc-btn:hover i{transform:translateX(4px)}

/* ============ RESPONSIVE — new components ============ */
@media(max-width:1100px){
  .company-cards{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .company,.featured,.services{padding:92px 0}
  .company-shell,.featured-shell,.services-shell{width:min(100% - 40px,760px)}
  .company-sub{margin-left:0}
  .company-cards{gap:16px}
  .feat-grid{grid-template-columns:1fr}
  .feat-card{min-height:470px}
  .svc-grid{grid-template-columns:1fr}
  .hero-trust .trust-logos{gap:18px}
  .featured-foot{flex-direction:column;align-items:flex-start;gap:18px}
}
@media(prefers-reduced-motion:reduce){
  .services-bg span{animation:none}
  .kicker span{animation:none}
}

/* ============ PULSING KICKER DOT ============ */
@keyframes kdot{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.5);opacity:.5}}
.kicker span{animation:kdot 2.4s var(--ease) infinite}

/* ============ PORTAFOLIO DESTACADO (horizontal product cards) ============ */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prod-card{display:flex;align-items:center;gap:18px;background:linear-gradient(152deg,#151c25,#0d1117 72%);border:1px solid rgba(217,217,217,.08);border-radius:22px;padding:22px;min-height:236px;position:relative;overflow:hidden;transition:transform .5s var(--ease),border-color .5s var(--ease)}
.prod-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 26% 30%,rgba(167,182,188,.14),transparent 52%);pointer-events:none}
.prod-card:hover{transform:translateY(-7px);border-color:rgba(167,182,188,.26)}
.prod-media{flex:0 0 42%;align-self:stretch;display:grid;place-items:center;position:relative;z-index:1}
.prod-media img{max-height:188px;width:auto;filter:drop-shadow(0 18px 26px rgba(0,0,0,.55));transition:transform .55s var(--ease)}
.prod-card:hover .prod-media img{transform:scale(1.05)}
.prod-body{flex:1;position:relative;z-index:1}
.prod-body h3{font-size:clamp(22px,1.9vw,28px);font-weight:500;letter-spacing:-.035em;margin:0 0 10px;color:#fff}
.prod-body p{font-size:13.5px;line-height:1.52;color:rgba(217,217,217,.64);margin:0 0 20px}
.prod-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(217,217,217,.28);border-radius:999px;padding:10px 17px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;transition:.35s var(--ease)}
.prod-card:hover .prod-btn{background:#fff;color:var(--ink);border-color:#fff}
.prod-btn i{font-style:normal;color:var(--red);transition:transform .35s var(--ease)}
.prod-card:hover .prod-btn i{transform:translate(2px,-2px);color:var(--ink)}

/* ============ FAQ (accordion) ============ */
.faq{padding:135px 0}
.faq-shell{width:min(960px,calc(100% - 72px));margin:auto}
.faq-head{text-align:center;margin-bottom:50px}
.faq-head .kicker{justify-content:center}
.faq-head h2{font-size:clamp(40px,5vw,72px);font-weight:300;letter-spacing:-.06em;line-height:.96;margin:0 0 16px}
.faq-sub{color:rgba(217,217,217,.6);font-size:16px;margin:0}
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{position:relative;border:1px solid rgba(167,182,188,.22);border-radius:16px;background:rgba(217,217,217,.025);overflow:hidden;transition:border-color .4s var(--ease),background .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease)}
.faq-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.faq-item:hover{border-color:rgba(217,217,217,.42);background:rgba(217,217,217,.06);box-shadow:0 18px 40px -28px rgba(0,0,0,.6)}
.faq-item:hover::before{transform:scaleY(1)}
.faq-item summary{transition:padding-left .4s var(--ease),color .35s var(--ease)}
.faq-item:hover summary{padding-left:34px}
.faq-item[open]{border-color:rgba(161,24,24,.55);background:rgba(161,24,24,.05)}
.faq-item[open]::before{transform:scaleY(1)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:22px;padding:24px 28px;font-size:clamp(15px,1.4vw,18px);font-weight:500;color:#fff}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary i{position:relative;flex:none;width:14px;height:14px}
.faq-item summary i::before,.faq-item summary i::after{content:"";position:absolute;background:var(--red);border-radius:2px}
.faq-item summary i::before{top:6px;left:0;width:14px;height:2px}
.faq-item summary i::after{top:0;left:6px;width:2px;height:14px;transition:transform .35s var(--ease)}
.faq-item[open] summary i::after{transform:scaleY(0)}
.faq-a{padding:0 28px 26px}
.faq-a p{margin:0;max-width:66ch;color:rgba(217,217,217,.72);font-size:15px;line-height:1.64}
.faq-a a{color:#fff;border-bottom:1px solid var(--red);white-space:nowrap}
.faq-item[open] .faq-a{animation:faqOpen .42s var(--ease)}
@keyframes faqOpen{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:none}}

/* ============ NOVEDADES / BLOG ============ */
.blog{padding:130px 0}
.blog-shell{width:min(1320px,calc(100% - 72px));margin:auto}
.blog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:54px}
.blog-head h2{font-size:clamp(34px,4.2vw,60px);font-weight:300;letter-spacing:-.05em;margin:0 0 14px}
.blog-sub{color:rgba(217,217,217,.6);font-size:16px;margin:0;max-width:48ch}
.blog-all{flex:none;display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(217,217,217,.22);border-radius:999px;padding:13px 22px;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--pearl);transition:.35s var(--ease)}
.blog-all:hover{background:#fff;color:var(--ink);border-color:#fff}
.blog-all span{color:var(--red)}.blog-all:hover span{color:var(--ink)}
.blog-grid{display:flex;gap:24px;align-items:stretch;max-width:1200px;margin:0 auto}
.blog-card{display:flex;flex-direction:column;flex:1;min-width:0;transition:flex .6s cubic-bezier(.25,1,.5,1)}
.blog-grid:hover .blog-card{flex:.85}
.blog-grid .blog-card:hover{flex:1.3}
.blog-media{height:300px;border-radius:18px;overflow:hidden;background:linear-gradient(150deg,#1a222b,#0e141b);display:block;margin-bottom:20px;border:1px solid rgba(217,217,217,.08)}
.blog-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,1,.5,1);display:block;filter:saturate(1.05)}
.blog-card:hover .blog-media img{transform:scale(1.05)}
.blog-card h3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(1.26em * 3)}
.blog-media .svc-slot{color:rgba(217,217,217,.4);border-color:rgba(217,217,217,.22)}
.blog-date{font-size:12px;color:rgba(217,217,217,.5);letter-spacing:.04em;margin-bottom:10px;display:flex;align-items:center;gap:9px}
.blog-date::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);opacity:.6}
.blog-card h3{font-size:clamp(18px,1.6vw,22px);font-weight:400;letter-spacing:-.02em;line-height:1.26;color:#fff;margin:0 0 18px}
.blog-more{margin-top:auto;display:inline-flex;align-items:center;gap:9px;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:rgba(217,217,217,.8);padding-top:14px;border-top:1px solid rgba(217,217,217,.12)}
.blog-more i{font-style:normal;color:var(--red);transition:transform .35s var(--ease)}
.blog-card:hover .blog-more i{transform:translateX(4px)}


/* ============ SMOOTH SCROLL BACKGROUND (sections ride on body bg) ============ */
.company,.featured,.services,.bridge,.values,.manifesto,.contact,.faq,.blog{background-color:transparent;background-image:none}

/* ============ RESPONSIVE — batch 2 ============ */
@media(max-width:1100px){
  .prod-grid{grid-template-columns:1fr}
  .blog-grid{flex-wrap:wrap}
  .blog-grid .blog-card{flex:1 1 calc(50% - 12px)}
  .blog-grid:hover .blog-card,.blog-grid .blog-card:hover{flex:1 1 calc(50% - 12px)}
}
@media(max-width:900px){
  .blog-head{flex-direction:column;align-items:flex-start;gap:24px}
}
@media(max-width:760px){
  .faq,.blog{padding:90px 0}
  .faq-shell{width:min(100% - 40px,760px)}
  .blog-grid .blog-card,.blog-grid:hover .blog-card,.blog-grid .blog-card:hover{flex:1 1 100%}
  .faq-item summary{padding:20px 22px}
  .faq-a{padding:0 22px 22px}
}
@media(max-width:560px){
  .prod-card{flex-direction:column;text-align:center;min-height:0}
  .prod-media{flex-basis:auto;width:100%}
  .prod-media img{max-height:170px}
  .prod-btn{margin-top:4px}
}

/* ============ BATCH 3 — refinements ============ */
/* Pilares strip: solid sapphire-deep so text stays legible while scrolling */
.transition-band{background:#243D49;color:#E7ECF2;padding:34px 0}
.transition-copy p{color:#E7ECF2}

/* Product images on clean white tiles (neutralises packshot backgrounds) */
.prod-media{flex:0 0 42%;align-self:stretch;display:grid;place-items:center;position:relative;z-index:1;background:#fff;border-radius:16px;padding:18px;margin:2px 0}
.prod-media img{max-height:176px;width:auto;mix-blend-mode:multiply;filter:none;transition:transform .55s var(--ease)}
.prod-card:hover .prod-media img{transform:scale(1.05)}

/* "Dónde Encontrarnos" → plomo (lead gray), legible light text */
.ccard-grad{background:linear-gradient(150deg,#5b636b,#474e56 60%,#363c43);color:#EDEFF1}
.ccard-grad .ccard-body p{color:rgba(237,239,241,.74)}
.ccard-grad .ccard-arrow{background:rgba(255,255,255,.12);color:#fff}
.ccard-grad:hover .ccard-arrow{background:var(--red);color:#fff}
.ccard-grad .ccard-cta i{color:#ffb7b7}

/* Sobre Avantys — modern two-column hierarchy (eyebrow left, statement right) */
.company-top{display:grid;grid-template-columns:.34fr 1fr;gap:clamp(24px,5vw,72px);align-items:start;margin-bottom:78px}
.company-top .kicker{margin:0;padding-top:12px}
.company-statement{font-size:clamp(28px,3.5vw,54px);line-height:1.07;letter-spacing:-.045em;font-weight:300;max-width:24ch;margin:0 0 26px;color:var(--ink)}
.company-sub{font-size:clamp(16px,1.4vw,18px);line-height:1.62;color:rgba(15,18,25,.6);max-width:56ch;margin:0}

/* Servicios — stock imagery with brand duotone overlay */
.svc-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.svc-media::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(150deg,rgba(36,61,73,.82),rgba(15,18,25,.5) 58%,rgba(161,24,24,.2));mix-blend-mode:multiply}

/* Founder — areas of expertise list */
.founder-list{list-style:none;margin:26px 0 22px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:11px 26px;max-width:560px}
.founder-list li{position:relative;padding-left:20px;font-size:15px;color:rgba(15,18,25,.74);line-height:1.4}
.founder-list li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--red)}

@media(max-width:760px){
  .company-top{grid-template-columns:1fr;gap:20px;margin-bottom:48px}
  .company-top .kicker{padding-top:0}
  .founder-list{grid-template-columns:1fr}
}

/* Intro rotating word */
.intro-tag[data-intro-rotator]{position:relative;display:inline-block;min-width:9ch;height:1.25em;vertical-align:baseline;color:rgba(245,241,234,.92);opacity:0;transform:translateY(6px);transition:opacity .9s ease .35s,transform .9s var(--ease) .35s}
.intro.lit .intro-tag[data-intro-rotator]{opacity:1;transform:none}
.intro-rot-word{position:absolute;left:0;top:0;white-space:nowrap;opacity:0;transform:translateY(10px);transition:opacity .5s var(--ease),transform .55s var(--ease);font-weight:500;color:#fff}
.intro-rot-word.is-active{opacity:1;transform:none}
.intro-rot-word.is-leaving{opacity:0;transform:translateY(-10px);transition:opacity .35s ease,transform .45s var(--ease)}

/* Hero philosophy rotator */
.hero-philosophy{display:flex;flex-direction:column;gap:10px;text-transform:none;letter-spacing:0;font-weight:300;color:rgba(245,241,234,.55);max-width:460px;min-width:340px}
.hero-phil-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,241,234,.45);font-weight:500;line-height:1}
.hero-phil-rotator{position:relative;height:1.4em;overflow:hidden;font-size:clamp(12px,.85vw,13px);line-height:1.4}
.hero-phil-word{position:absolute;left:0;top:0;right:0;color:rgba(245,241,234,.55);font-weight:300;letter-spacing:-.005em;opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease),transform .7s var(--ease);white-space:nowrap}
.hero-phil-word.is-active{opacity:1;transform:none}
.hero-phil-word.is-leaving{opacity:0;transform:translateY(-14px);transition:opacity .45s ease,transform .55s var(--ease)}
/* ccard CTA hover → red */
.ccard .ccard-cta{transition:color .35s var(--ease)}
.ccard:hover .ccard-cta{color:var(--red)}
.ccard:hover .ccard-cta i{color:var(--red)}
.ccard-accent .ccard-mark img,.ccard-grad .ccard-mark img{width:44px;opacity:.92;filter:brightness(1.3)}
.ccard-grad .ccard-mark img{filter:none;opacity:.78}

/* Rounded contact form */
.contact-form input,.contact-form textarea{border-radius:14px}
.contact-form button{border-radius:999px}

/* Services cards unified with Sobre Avantys ccards */
.svc-card{background:var(--dusk);color:var(--pearl);border-radius:24px;padding:34px;min-height:344px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:none;overflow:hidden;position:relative}
.svc-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 84% 10%,rgba(167,182,188,.16),transparent 42%);pointer-events:none}
.svc-card .ccard-mark{align-self:flex-end;position:relative;z-index:1}
.svc-card .ccard-mark img{width:44px;opacity:.92;filter:brightness(1.3)}
.svc-card .svc-body{padding:0;position:relative;z-index:1;margin-top:24px}
.svc-card .svc-body h3{font-size:clamp(22px,1.7vw,28px);line-height:1.06;letter-spacing:-.04em;font-weight:400;color:var(--pearl);margin:0 0 14px}
.svc-card .svc-body p{font-size:14.5px;line-height:1.58;color:rgba(217,217,217,.66);margin:0 0 26px}
.svc-card .svc-btn{border-color:rgba(247,249,250,.32);color:var(--pearl)}
.svc-card .svc-btn:hover{background:var(--pearl);color:var(--ink);border-color:var(--pearl)}

/* ===== Intro stack (centered with isotipo) ===== */
.intro-inner--stack{flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;font-family:Inter,system-ui,sans-serif}
.intro-mark{width:104px;height:104px;object-fit:contain;opacity:0;transform:translateY(8px) scale(.92);transition:opacity 1.1s var(--ease),transform 1.2s var(--ease)}
.intro.lit .intro-mark{opacity:1;transform:none}
.intro-inner--stack .intro-tag[data-intro-rotator]{display:block;min-width:14ch;height:1.35em;text-align:center}
.intro-inner--stack .intro-rot-word{left:50%;transform:translate(-50%,12px);transition:opacity .8s var(--ease),transform .9s var(--ease)}
.intro-inner--stack .intro-rot-word.is-active{transform:translate(-50%,0)}
.intro-inner--stack .intro-rot-word.is-leaving{transform:translate(-50%,-12px);transition:opacity .7s ease,transform .8s var(--ease)}

/* ===== Sobre Avantys — sticky reveal ===== */
.about-sticky{background:#000;color:var(--pearl);font-family:Inter,system-ui,sans-serif;padding:140px 0 160px;position:relative}
.trust-strip{width:min(1320px,calc(100% - 72px));margin:80px auto 0;display:flex;flex-direction:column;align-items:center;gap:24px;padding-top:48px;border-top:1px solid rgba(217,217,217,.08)}
.trust-strip .trust-label{margin:0;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(217,217,217,.5);font-weight:600}
.trust-strip img{width:100%;max-width:1100px;height:auto;opacity:.92}
.about-shell{width:min(1320px,calc(100% - 72px));margin:auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:start;position:relative}
.about-left{position:sticky;top:112px;padding:20px 0;align-self:start}
.about-left .kicker{margin:0 0 28px}
.about-title{font-weight:300;font-size:clamp(40px,5.2vw,84px);line-height:.98;letter-spacing:-.045em;color:#fff;margin:0 0 28px}
.about-title .about-dot{color:var(--red);font-weight:400}
.about-lead{font-size:17px;line-height:1.62;color:rgba(217,217,217,.62);max-width:46ch;margin:0 0 18px;font-weight:400}
.about-right{display:flex;flex-direction:column;gap:0;overflow:visible;padding-bottom:10vh}
.about-slot{display:contents}
.about-card{position:sticky;top:112px;width:100%;max-width:520px;padding:40px;border-radius:20px;background:#0a0a0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);box-shadow:0 30px 80px -40px rgba(0,0,0,.8);margin-bottom:8vh;opacity:1;transform:none;transition:background-color .3s ease,border-color .3s ease}
.about-card:hover{background:#141414;border-color:rgba(255,255,255,.18)}
.about-slot:nth-child(1) .about-card{z-index:10}
.about-slot:nth-child(2) .about-card{z-index:20}
.about-slot:nth-child(3) .about-card{z-index:30}
.about-slot:last-child .about-card{margin-bottom:0}
.about-icon{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);color:#fff;margin-bottom:24px}
.about-icon svg{width:24px;height:24px}
.about-card h3{font-weight:400;font-size:clamp(24px,2vw,30px);line-height:1.15;letter-spacing:-.025em;color:#fff;margin:0 0 16px}
.about-card p{font-size:17px;line-height:1.62;color:rgba(217,217,217,.62);margin:0;font-weight:400}
@media(max-width:900px){
  .about-shell{grid-template-columns:1fr;gap:24px}
  .about-left{position:relative;top:auto;padding:20px 0 8px}
  .about-card{position:relative;top:auto;margin-bottom:20px}
  .about-sticky{padding:80px 0 60px}
}


/* ============ MANIFESTO V2 (scroll-driven expand) ============ */
.manifesto-v2{height:220vh;background:#0b0b0d;position:relative}
.manifesto-v2 .manifesto-sticky{position:sticky;top:0;height:100vh;width:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.manifesto-card{position:relative;overflow:hidden;background:#000;will-change:width,height,border-radius,transform;box-shadow:0 60px 120px -40px rgba(0,0,0,.6)}
.manifesto-grid{position:absolute;inset:0;display:grid;grid-template-columns:repeat(5,1fr);gap:14px;padding:14px}
@media (max-width:900px){.manifesto-grid{grid-template-columns:repeat(3,1fr);gap:10px;padding:10px}}
@media (max-width:560px){.manifesto-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:8px}}
.manifesto-col{overflow:hidden;border-radius:14px;height:100%}
.manifesto-col-track{display:flex;flex-direction:column;gap:14px;will-change:transform}
.manifesto-tile{flex-shrink:0;width:100%;aspect-ratio:3/4;border-radius:14px;overflow:hidden;background:#222}
.manifesto-tile img{width:100%;height:100%;object-fit:cover;display:block}
.manifesto-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(0,0,0,.55) 0%,rgba(0,0,0,.78) 70%,rgba(0,0,0,.9) 100%);pointer-events:none}
.manifesto-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px;color:#fff;z-index:2}
.manifesto-kicker{margin:0 0 28px;justify-content:center}
.manifesto-title{font-family:Inter,sans-serif;font-weight:300;font-size:clamp(30px,4.6vw,68px);line-height:1.08;letter-spacing:-.025em;max-width:1100px;margin:0 0 40px;color:#fff}
.manifesto-title b{color:var(--red);font-weight:400;font-size:.5em;margin-left:.12em;vertical-align:middle}
.manifesto-cta{display:inline-flex;align-items:center;gap:10px;background:#fff;color:#000;padding:16px 34px;border-radius:999px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:transform .35s ease,opacity .35s ease;cursor:pointer}
.manifesto-cta:hover{transform:scale(1.05);opacity:.92}

/* === Contact + Footer en verde petróleo (#243D49) === */
.contact.tone-noir{background:#0a0d12;color:var(--cream);position:relative}
.contact.tone-noir::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(245,241,234,.18),transparent);pointer-events:none}
.contact.tone-noir::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:120px;background:linear-gradient(180deg,transparent,#1d333d);pointer-events:none}
.contact.tone-noir h2{color:var(--cream)}
.contact.tone-noir .contact-copy>p:not(.kicker){color:rgba(245,241,234,.7)}
.contact.tone-noir .kicker{color:rgba(245,241,234,.66)}
.contact.tone-noir label{color:rgba(245,241,234,.6);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.contact.tone-noir input,
.contact.tone-noir textarea{border:1px solid rgba(245,241,234,.16);background:rgba(245,241,234,.035);color:var(--cream)}
.contact.tone-noir input::placeholder,
.contact.tone-noir textarea::placeholder{color:rgba(245,241,234,.32)}
.contact.tone-noir input:focus,
.contact.tone-noir textarea:focus{border-color:var(--cream);box-shadow:inset -5px 0 0 var(--red);background:rgba(245,241,234,.07);outline:none}
.contact.tone-noir .contact-form button{background:var(--cream);color:#0a0d12;font-weight:700;letter-spacing:.14em;padding:22px;font-size:12px;box-shadow:0 10px 30px rgba(0,0,0,.45)}
.contact.tone-noir .contact-form button:hover{background:#fff;color:#0a0d12;transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.55)}
.contact.tone-noir .contact-form span{color:var(--red)}

/* Footer alineado al verde petróleo para un bookend continuo */
.site-footer{background:#1d333d;color:rgba(245,241,234,.72)}
.site-footer .footer-grid{border-bottom:1px solid rgba(245,241,234,.1)}
.site-footer .footer-col h4{color:var(--cream)}
.site-footer .footer-col p,
.site-footer .footer-col li{color:rgba(245,241,234,.62)}
.site-footer .footer-col a:hover{color:var(--cream)}
.site-footer .footer-legal-links a{color:rgba(245,241,234,.58)}
.site-footer .footer-legal-links a:hover{color:var(--cream)}
.site-footer .footer-legal-copy{color:rgba(245,241,234,.55)}
.site-footer .footer-disclaimer{color:rgba(245,241,234,.42)}


/* Bookend continuo: degradado sutil entre hero (tone-dusk) y compañía (about-sticky) */
.hero{position:relative}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:180px;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.55) 55%,#000 100%);pointer-events:none;z-index:1}
.about-sticky{position:relative}
.about-sticky::before{content:"";position:absolute;left:0;right:0;top:0;height:140px;background:linear-gradient(180deg,#06080c 0%,rgba(0,0,0,.85) 45%,rgba(0,0,0,0) 100%);pointer-events:none;z-index:0}
.about-sticky > *{position:relative;z-index:1}

/* Bookend continuo: degradado sutil entre compañía (about-sticky) y portafolio (featured) */
.about-sticky::after{content:"";position:absolute;left:0;right:0;bottom:0;height:160px;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(11,14,20,.5) 55%,#0b0e14 100%);pointer-events:none;z-index:0}
.featured{position:relative}
.featured::before{content:"";position:absolute;left:0;right:0;top:0;height:140px;background:linear-gradient(180deg,#000 0%,rgba(11,14,20,.85) 45%,rgba(11,14,20,0) 100%);pointer-events:none;z-index:0}
.featured-shell{position:relative;z-index:1}
