/* ============================================================
   R&B Optical — Landing styles
   Brand system: Carmín #C8174F · Newsreader · Hanken Grotesk · IBM Plex Mono
   ============================================================ */
:root{
  --carmin:#C8174F;
  --carmin-bright:#E2174F;
  --wine:#7E0E33;
  --rose:#F6E5EB;
  --ink:#1A1418;
  --ink-soft:#241D22;
  --graphite:#464043;
  --stone:#988F92;
  --mist:#D9D2D5;
  --paper:#FAF6F4;
  --paper-2:#F1EAE6;
  --white:#FFFFFF;
  --serif:'Newsreader', serif;
  --sans:'Hanken Grotesk', sans-serif;
  --mono:'IBM Plex Mono', monospace;
  --maxw:1280px;
  --pad:56px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
::selection{background:var(--carmin);color:#fff;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);}

/* ---------- typographic helpers ---------- */
.mono{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);}
.serif{font-family:var(--serif);}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--carmin);display:inline-flex;align-items:center;gap:12px;}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--carmin);display:inline-block;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.02;letter-spacing:-.01em;text-wrap:balance;}
.display{font-size:clamp(34px,5.2vw,76px);font-weight:500;line-height:.98;}
.focus-target{animation:focusIn 1.25s cubic-bezier(.16,1,.3,1) both;will-change:filter,opacity;}
@keyframes focusIn{from{filter:blur(20px);opacity:0;}to{filter:blur(0);opacity:1;}}
/* Focus-in (desenfoque → nítido) en TODO el hero y los banners secundarios/terciarios */
.hero,.page-banner{animation:focusIn 1.05s cubic-bezier(.16,1,.3,1) both;will-change:filter,opacity;}
@media (prefers-reduced-motion:reduce){.focus-target,.hero,.page-banner{animation:none;}}
.h2{font-size:clamp(34px,5vw,68px);}
.lede{font-size:clamp(17px,1.4vw,20px);color:var(--graphite);line-height:1.6;max-width:60ch;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:15px;font-weight:600;padding:15px 26px;border-radius:999px;transition:transform .25s,background .25s,color .25s,border-color .25s;letter-spacing:.01em;}
.btn .arw{transition:transform .3s;}
.btn:hover .arw{transform:translateX(5px);}
.btn-primary{background:var(--carmin);color:#fff;}
.btn-primary:hover{background:var(--wine);transform:translateY(-2px);}
.btn-ghost{border:1px solid currentColor;color:var(--ink);}
.btn-ghost.on-dark{color:#fff;}
.btn-ghost:hover{background:var(--ink);color:#fff;}
.btn-ghost.on-dark:hover{background:#fff;color:var(--ink);}
.link-arrow{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--carmin);display:inline-flex;align-items:center;gap:8px;}
.link-arrow .arw{transition:transform .3s;}
.link-arrow:hover .arw{transform:translateX(5px);}

/* ---------- custom lens cursor (optical reticle) ---------- */
@media (pointer:fine){
  body.lens-on{cursor:none;}
  body.lens-on a,body.lens-on button,body.lens-on .prod-card,body.lens-on input,body.lens-on textarea,body.lens-on select,body.lens-on .faq-q,body.lens-on .rail{cursor:none;}
}
#reticle{position:fixed;top:0;left:0;width:30px;height:30px;border:1.5px solid var(--carmin);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .22s,height .22s,background .22s,border-color .22s,opacity .3s;mix-blend-mode:normal;opacity:0;}
#reticle::before,#reticle::after{content:"";position:absolute;background:var(--carmin);transition:background .22s;}
#reticle::before{left:50%;top:-7px;width:1px;height:6px;transform:translateX(-50%);}
#reticle::after{left:50%;bottom:-7px;width:1px;height:6px;transform:translateX(-50%);}
#reticle .h{position:absolute;top:50%;width:6px;height:1px;background:var(--carmin);transform:translateY(-50%);}
#reticle .h.l{left:-7px;}
#reticle .h.r{right:-7px;}
#reticle.hover{width:56px;height:56px;background:rgba(200,23,79,.08);}
#reticle.on-dark{border-color:#fff;}
#reticle.on-dark::before,#reticle.on-dark::after,#reticle.on-dark .h{background:#fff;}
@media (pointer:coarse){#reticle{display:none;}}

/* ---------- blur→focus zones ---------- */
.focus-zone{position:relative;}
.focus-zone .fz-base{filter:blur(7px);transition:filter .5s;}
.focus-zone .fz-sharp{position:absolute;inset:0;filter:none;clip-path:circle(0px at 50% 50%);}

/* ============================================================ NAV */
.topstrip{background:var(--ink);color:rgba(255,255,255,.7);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;}
.topstrip .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;}
.topstrip a{display:inline-flex;align-items:center;gap:8px;color:#fff;}
.topstrip a:hover{color:var(--carmin-bright);}
.topstrip .ts-left span{color:rgba(255,255,255,.55);}

nav.main{position:sticky;top:0;z-index:200;background:rgba(250,246,244,.85);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s;}
nav.main.scrolled{border-color:var(--mist);}
nav.main .wrap{display:flex;align-items:center;justify-content:space-between;height:76px;}
nav.main .logo img{height:34px;}
nav.main .links{display:flex;gap:34px;align-items:center;}
nav.main .links a{font-size:14.5px;font-weight:500;position:relative;padding:4px 0;color:var(--graphite);}
nav.main .links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--carmin);transition:width .28s;}
nav.main .links a:hover{color:var(--ink);}
nav.main .links a:hover::after{width:100%;}
nav.main .nav-cta{display:flex;gap:12px;align-items:center;}
.nav-toggle{display:none;}

/* ============================================================ HERO */
.hero{background:var(--ink);color:#fff;position:relative;overflow:hidden;min-height:calc(100svh - 116px);display:flex;flex-direction:column;justify-content:center;padding:64px 0 0;}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.hero-bg .layer{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);will-change:transform;}
/* concentric optical rings (iris) */
.hero-bg .iris{width:clamp(0px,150vh,1500px);aspect-ratio:1;border-radius:50%;
  background:repeating-radial-gradient(circle at center, rgba(255,255,255,.055) 0 1.5px, transparent 1.5px 58px);
  animation:breathe 9s ease-in-out infinite;}
/* rotating radar sweep */
.hero-bg .sweep{width:clamp(0px,150vh,1500px);aspect-ratio:1;border-radius:50%;
  background:conic-gradient(from 0deg, transparent 0 68%, rgba(200,23,79,.20) 86%, rgba(226,23,79,.05) 94%, transparent 100%);
  mix-blend-mode:screen;animation:spin 22s linear infinite;}
/* sonar pulses */
.hero-bg .pulse{width:300px;height:300px;border:1px solid rgba(226,23,79,.5);border-radius:50%;opacity:0;animation:pulse 8s ease-out infinite;}
.hero-bg .pulse.p2{animation-delay:2s;}
.hero-bg .pulse.p3{animation-delay:4s;}
.hero-bg .pulse.p4{animation-delay:6s;}
/* out-of-focus bokeh lights */
.hero-bg .bokeh{position:absolute;border-radius:50%;filter:blur(34px);opacity:.45;will-change:transform;}
.hero-bg .b1{width:220px;height:220px;background:var(--carmin);left:8%;top:22%;animation:drift1 19s ease-in-out infinite;}
.hero-bg .b2{width:160px;height:160px;background:#fff;right:12%;top:30%;opacity:.18;animation:drift2 23s ease-in-out infinite;}
.hero-bg .b3{width:280px;height:280px;background:var(--wine);right:6%;bottom:10%;animation:drift3 27s ease-in-out infinite;}
.hero-bg .b4{width:120px;height:120px;background:var(--carmin-bright);left:18%;bottom:16%;opacity:.3;animation:drift1 16s ease-in-out infinite reverse;}
.hero-bg .eye-water{width:620px;opacity:.06;transform:translate(-50%,calc(-55% - 5px));}
@keyframes breathe{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.7;}50%{transform:translate(-50%,-50%) scale(1.06);opacity:1;}}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg);}}
@keyframes pulse{0%{transform:translate(-50%,-50%) scale(.22);opacity:0;}12%{opacity:.6;}100%{transform:translate(-50%,-50%) scale(3.2);opacity:0;}}
@keyframes drift1{0%,100%{transform:translate(0,0);}50%{transform:translate(40px,-30px);}}
@keyframes drift2{0%,100%{transform:translate(0,0);}50%{transform:translate(-50px,40px);}}
@keyframes drift3{0%,100%{transform:translate(0,0);}50%{transform:translate(-30px,-40px);}}
@media (prefers-reduced-motion:reduce){.hero-bg .iris,.hero-bg .sweep,.hero-bg .pulse,.hero-bg .bokeh,.hero-bg .eye-water{animation:none;}}

.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);width:100%;flex:1;display:grid;grid-template-columns:1.18fr .82fr;gap:54px;align-items:center;}
.hero-copy{text-align:left;}
.hero .eyebrow{color:var(--carmin-bright);}
.hero .eyebrow::before{background:var(--carmin-bright);}
.hero h1{margin:18px 0 0;color:#fff;}
.hero h1 em{font-style:italic;color:var(--carmin-bright);}
.hero .sub{margin:22px 0 0;max-width:44ch;color:rgba(255,255,255,.74);font-size:clamp(16px,1.3vw,18px);line-height:1.55;}
.hero .cta-row{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;justify-content:flex-start;}
.hero .scroll-cue{margin-top:34px;font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:14px;}
.hero .scroll-cue .bar{width:40px;height:1px;background:linear-gradient(to right,var(--carmin-bright),transparent);animation:cue 2.2s ease-in-out infinite;transform-origin:left;}
@keyframes cue{0%,100%{transform:scaleX(.4);opacity:.5;}50%{transform:scaleX(1);opacity:1;}}

/* hero side cards */
.hero-cards{display:grid;grid-template-rows:1fr 1fr;gap:18px;}
.hcard{position:relative;border-radius:14px;overflow:hidden;padding:24px;display:flex;flex-direction:column;justify-content:flex-end;border:1px solid rgba(255,255,255,.12);background:var(--ink);transition:transform .35s,border-color .3s;isolation:isolate;color:#fff;min-height:172px;}
.hcard:hover{transform:translateY(-4px);border-color:rgba(226,23,79,.65);}
.hcard .hc-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .7s cubic-bezier(.16,1,.3,1);}
.hcard:hover .hc-bg{transform:scale(1.06);}
.hcard::after{content:"";position:absolute;inset:0;z-index:-1;}
.hcard.empresas::after{background:linear-gradient(150deg,rgba(200,23,79,.48),rgba(110,12,45,.72));}
.hcard.rayban::after{background:linear-gradient(160deg,rgba(26,20,24,.12),rgba(20,14,18,.68));}
.hcard .hc-kick{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:10px;}
.hcard h3{font-size:22px;line-height:1.06;color:#fff;margin-bottom:14px;font-weight:500;text-shadow:0 1px 16px rgba(0,0,0,.3);}
.hcard .link-arrow{color:#fff;font-size:11px;}

/* stats bar */
.stats{border-top:1px solid rgba(255,255,255,.12);position:relative;z-index:2;background:rgba(26,20,24,.55);backdrop-filter:blur(3px);}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);}
.stats .stat{padding:24px 8px 28px;border-left:1px solid rgba(255,255,255,.12);}
.stats .stat:first-child{border-left:none;padding-left:0;}
.stats .stat .num{font-family:var(--serif);font-size:clamp(28px,3.2vw,44px);font-weight:500;line-height:1;color:#fff;}
.stats .stat .num em{color:var(--carmin-bright);font-style:normal;}
.stats .stat .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:12px;}

/* ============================================================ placeholders */
.ph{position:relative;background:var(--paper-2);background-image:repeating-linear-gradient(135deg,transparent,transparent 11px,rgba(152,143,146,.16) 11px,rgba(152,143,146,.16) 12px);border:1px solid var(--mist);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.ph.dark{background:#221b20;background-image:repeating-linear-gradient(135deg,transparent,transparent 11px,rgba(255,255,255,.05) 11px,rgba(255,255,255,.05) 12px);border-color:rgba(255,255,255,.12);}
.ph .ph-lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);text-align:center;padding:8px 14px;border:1px dashed var(--stone);border-radius:3px;background:rgba(250,246,244,.6);}
.ph.dark .ph-lbl{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.3);background:rgba(34,27,32,.5);}

/* ============================================================ section scaffolding */
section.block{padding:120px 0;}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:15px;margin-bottom:15px;flex-wrap:wrap;}
.sec-head .sh-left{max-width:60%;}
.sec-head h2{margin-top:20px;}
.sec-head .sh-note{max-width:34ch;color:var(--graphite);font-size:15.5px;line-height:1.6;}

/* ---------- promo trio ---------- */
.promo-trio{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:20px;}
.promo{position:relative;border-radius:8px;overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;color:#fff;isolation:isolate;}
.promo .ph{position:absolute;inset:0;z-index:-2;border-radius:0;border:none;}
.promo::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(26,20,24,.86),rgba(26,20,24,.2) 60%,rgba(26,20,24,.05));}
.promo.carmin::after{background:linear-gradient(to top,var(--wine),rgba(126,14,51,.55));}
.promo .p-kick{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:12px;}
.promo h3{font-size:30px;color:#fff;line-height:1.04;margin-bottom:18px;}
.promo .link-arrow{color:#fff;}
.promo:hover{transform:translateY(-4px);}
.promo{transition:transform .35s;}

/* ---------- brand marquee ---------- */
.marquee{border-top:1px solid var(--mist);border-bottom:1px solid var(--mist);padding:30px 0;overflow:hidden;background:var(--paper);}
.marquee .track{display:flex;gap:64px;width:max-content;animation:scrollx 28s linear infinite;align-items:center;}
.marquee .track span{font-family:var(--serif);font-size:30px;font-weight:500;color:var(--stone);white-space:nowrap;letter-spacing:.02em;font-style:italic;}
.marquee:hover .track{animation-play-state:paused;}
@keyframes scrollx{to{transform:translateX(-50%);}}

/* ---------- sobre nosotros · editorial + foto real de sucursal ---------- */
.about{background:var(--paper-2);}
.about-head{display:grid;grid-template-columns:1.35fr .65fr;gap:48px;align-items:end;margin-bottom:58px;}
.about-head h2{margin-top:18px;}
.about-head .ah-note{color:var(--graphite);font-size:15.5px;line-height:1.6;}
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,5vw,72px);align-items:center;}
.about-photo{position:relative;}
.about-photo img{width:100%;height:clamp(440px,48vw,580px);object-fit:cover;border-radius:10px;display:block;}
.about-photo .cap{position:absolute;left:16px;bottom:16px;background:rgba(26,20,24,.72);backdrop-filter:blur(6px);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:9px 14px;border-radius:5px;}
.about-photo .badge{position:absolute;right:-22px;top:32px;background:var(--carmin);color:#fff;width:128px;height:128px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 18px 46px rgba(126,14,51,.4);}
.about-photo .badge .big{font-family:var(--serif);font-size:38px;font-weight:500;line-height:1;}
.about-photo .badge .sm{font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;margin-top:5px;padding:0 14px;line-height:1.3;}
.about-copy .lede{margin-bottom:6px;}
.commits{list-style:none;margin-top:28px;border-top:1px solid var(--mist);}
.commit{display:flex;gap:24px;align-items:flex-start;padding:22px 2px;border-bottom:1px solid var(--mist);transition:padding-left .25s;}
.commit:hover{padding-left:10px;}
.commit .idx{font-family:var(--mono);font-size:12px;color:var(--carmin);letter-spacing:.08em;padding-top:5px;flex-shrink:0;}
.commit h4{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:5px;line-height:1.1;}
.commit p{font-size:14.5px;color:var(--graphite);line-height:1.55;}
.about-copy .btn{margin-top:34px;}

/* ---------- promo del mes · banner full-bleed (escalable) ---------- */
.promo-banner{background:var(--ink);}
.banner{position:relative;overflow:hidden;color:#fff;background:var(--ink);min-height:322px;}
/* image covers the WHOLE banner; one continuous ink gradient fades it out → no seam */
.banner-media{position:absolute;inset:0;z-index:0;}
.banner-media img{width:100%;height:100%;object-fit:cover;object-position:78% center;display:block;}
.banner-media::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg, #120d10 0%, #1A1418 34%, rgba(26,20,24,.92) 48%, rgba(26,20,24,.5) 62%, rgba(26,20,24,.12) 74%, rgba(26,20,24,0) 86%);}
.banner-copy{position:relative;z-index:2;max-width:780px;min-height:322px;display:flex;flex-direction:column;justify-content:center;padding:clamp(36px,4vw,56px) clamp(32px,5vw,72px);padding-left:clamp(32px, calc((100vw - var(--maxw))/2 + 8px), 50vw);}
.banner .eyebrow{color:var(--carmin-bright);}
.banner .eyebrow::before{background:var(--carmin-bright);}
.banner h2{color:#fff;font-size:clamp(34px,4.4vw,60px);line-height:1.0;margin:18px 0 0;}
.banner h2 em{font-style:italic;color:var(--carmin-bright);}
.banner .b-sub{color:rgba(255,255,255,.74);margin-top:16px;max-width:56ch;font-size:16px;line-height:1.55;}
.banner .b-cta{margin-top:32px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
.banner .fineprint{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.45);margin-top:22px;}

/* ---------- productos ---------- */
/* ---------- horizontal rails (productos / reseñas / blog) ---------- */
.rail-wrap{position:relative;}
.rail{display:flex;gap:22px;overflow-x:auto;overflow-y:hidden;align-items:stretch;scroll-snap-type:x proximity;padding:8px 4px 10px;margin:0 -4px;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;}
.rail::-webkit-scrollbar{display:none;}
.rail>*{flex:0 0 auto;scroll-snap-align:start;}
.rail.products>*{width:clamp(276px,28vw,345px);}
.rail.reviews>*{width:clamp(280px,32vw,380px);}
.rail.posts>*{width:clamp(260px,28vw,340px);}
.rail.dragging{cursor:grabbing;scroll-behavior:auto;scroll-snap-type:none;}
.rail.dragging *{pointer-events:none;}
.rail-foot{display:flex;align-items:center;gap:28px;margin-top:18px;}
.rail-bar{flex:1;height:2px;background:var(--mist);border-radius:2px;position:relative;overflow:hidden;}
.rail-bar span{position:absolute;left:0;top:0;height:100%;background:var(--carmin);border-radius:2px;width:30%;}
.rail-nav{display:flex;gap:10px;}
.rail-nav button{width:48px;height:48px;border-radius:50%;border:1px solid var(--mist);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:17px;transition:background .2s,border-color .2s,color .2s,opacity .2s;}
.rail-nav button:hover{background:var(--carmin);border-color:var(--carmin);color:#fff;}
.rail-nav button:disabled{opacity:.28;}
.prod-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--mist);border-radius:10px;overflow:hidden;}
.prod-card .pc-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:#fff;margin-bottom:14px;}
.prod-card .pc-img .ph,.prod-card .pc-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:none;border-radius:0;transition:filter .4s,transform .6s;filter:blur(2px) saturate(.9);}
.prod-card:hover .pc-img .ph,.prod-card:hover .pc-img img{filter:none;transform:scale(1.04);}
.prod-card .pc-fade{position:absolute;inset:0;background:rgba(255,255,255,.35);opacity:1;transition:opacity .4s;z-index:1;pointer-events:none;}
.prod-card:hover .pc-fade{opacity:0;}
.prod-card .pc-view{position:absolute;left:14px;bottom:14px;z-index:3;background:#fff;color:var(--ink);font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding:9px 14px;border-radius:3px;opacity:0;transform:translateY(8px);transition:opacity .35s,transform .35s;}
.prod-card:hover .pc-view{opacity:1;transform:translateY(0);}
.prod-card .pc-tag{position:absolute;right:12px;top:12px;z-index:3;background:var(--carmin);color:#fff;font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;border-radius:3px;}
.prod-card h3{font-size:23px;line-height:1.18;margin:0 20px 8px;}
.prod-card .pc-desc{font-size:15.5px;color:var(--graphite);line-height:1.55;margin:0 20px 16px;flex:1;}
.prod-card .pc-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--mist);padding-top:14px;margin:0 20px 20px;}
.prod-card .pc-price{font-family:var(--mono);font-size:16px;font-weight:500;color:var(--ink);letter-spacing:.02em;}
.prod-card .pc-cart{width:36px;height:36px;border-radius:50%;border:1px solid var(--mist);display:flex;align-items:center;justify-content:center;color:var(--graphite);transition:all .25s;font-size:16px;}
.prod-card:hover .pc-cart{background:var(--carmin);border-color:var(--carmin);color:#fff;}

/* ---------- contacto ---------- */
.contact .grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(36px,4vw,60px);align-items:stretch;}
.locations{display:flex;flex-direction:column;}
/* map simulation */
.map-sim{position:relative;flex:1 1 auto;min-height:300px;border-radius:12px;overflow:hidden;border:1px solid var(--mist);background:#e9e3e0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.4);}
.map-sim .streets{position:absolute;inset:-10%;background:
  repeating-linear-gradient(0deg, transparent 0 42px, rgba(152,143,146,.16) 42px 44px),
  repeating-linear-gradient(90deg, transparent 0 60px, rgba(152,143,146,.16) 60px 62px);}
.map-sim .ave{position:absolute;background:rgba(152,143,146,.3);}
.map-sim .ave.a1{left:-10%;right:-10%;top:58%;height:10px;transform:rotate(-7deg);}
.map-sim .ave.a2{top:-10%;bottom:-10%;left:30%;width:9px;transform:rotate(6deg);}
.map-sim .park{position:absolute;background:rgba(31,138,91,.14);border-radius:8px;}
.map-sim .park.p1{width:120px;height:90px;left:8%;top:14%;}
.map-sim .park.p2{width:90px;height:80px;right:12%;bottom:14%;}
.map-sim .river{position:absolute;left:60%;top:-10%;bottom:-10%;width:26px;background:rgba(42,111,219,.16);transform:rotate(10deg);border-radius:20px;}
.pin{position:absolute;transform:translate(-50%,-100%);z-index:3;cursor:pointer;}
.pin .dot{width:24px;height:24px;background:var(--carmin);border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2.5px solid #fff;box-shadow:0 8px 18px rgba(126,14,51,.45);}
.pin .dot::after{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;background:#fff;border-radius:50%;transform:translate(-50%,-50%) rotate(45deg);}
.pin .lbl{position:absolute;left:50%;bottom:150%;transform:translateX(-50%);white-space:nowrap;background:var(--ink);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:6px 10px;border-radius:5px;box-shadow:0 6px 16px rgba(0,0,0,.25);}
.pin .lbl::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink);}
.map-sim .mtag{position:absolute;left:14px;bottom:12px;z-index:4;font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--graphite);background:rgba(250,246,244,.85);backdrop-filter:blur(4px);padding:6px 10px;border-radius:4px;}
/* location cards */
.loc-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px;}
.loc-card{background:var(--white);border:1px solid var(--mist);border-radius:10px;padding:22px 20px;}
.loc-card .ln{font-family:var(--serif);font-size:19px;font-weight:500;margin-bottom:14px;display:flex;align-items:center;gap:9px;}
.loc-card .ln i{width:9px;height:9px;border-radius:50%;background:var(--carmin);flex-shrink:0;}
.loc-card .lr{display:flex;gap:12px;padding:9px 0;border-top:1px solid var(--mist);}
.loc-card .lr .k{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--carmin);width:52px;flex-shrink:0;padding-top:3px;}
.loc-card .lr .v{font-size:13px;color:var(--graphite);line-height:1.5;}
.loc-card .dir{display:inline-flex;margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--carmin);align-items:center;gap:7px;}
.loc-card .dir .arw{transition:transform .3s;}
.loc-card .dir:hover .arw{transform:translateX(4px);}
.contact .info .ci{padding:24px 0;border-top:1px solid var(--mist);}
.contact .info .ci:first-of-type{border-top:none;}
.contact .info .ci .k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--carmin);margin-bottom:8px;}
.contact .info .ci .v{font-size:18px;font-family:var(--serif);}
.contact .info .ci .v small{display:block;font-family:var(--sans);font-size:14px;color:var(--graphite);margin-top:4px;}
.form{background:var(--white);border:1px solid var(--mist);border-radius:10px;padding:clamp(28px,3vw,40px);}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:20px;}
.field label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-bottom:8px;}
.field input,.field textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:var(--paper);border:1px solid var(--mist);border-radius:6px;padding:13px 14px;transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--carmin);box-shadow:0 0 0 3px var(--rose);}
.field textarea{resize:vertical;min-height:96px;}
.form .submit{width:100%;justify-content:center;margin-top:6px;}

/* ---------- fact ribbon (negro / blanco / rosa) ---------- */
.fact-ribbon{background:var(--ink);color:#fff;border-top:1px solid rgba(255,255,255,.08);}
.fact-ribbon .wrap{display:grid;grid-template-columns:repeat(4,1fr);}
.fact-ribbon .fact{padding:24px 26px;border-left:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:6px;}
.fact-ribbon .fact:first-child{border-left:none;}
.fact-ribbon .fact .fv{font-family:var(--serif);font-size:clamp(26px,2.5vw,34px);font-weight:500;line-height:1;}
.fact-ribbon .fact .fv em{font-style:normal;color:var(--carmin-bright);}
.fact-ribbon .fact .fl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);line-height:1.4;}
@media(max-width:760px){
  .fact-ribbon .wrap{grid-template-columns:1fr 1fr;}
  .fact-ribbon .fact:nth-child(odd){border-left:none;}
  .fact-ribbon .fact:nth-child(3),.fact-ribbon .fact:nth-child(4){border-top:1px solid rgba(255,255,255,.12);}
}

/* ---------- reseñas ---------- */
.reviews .sec-head{align-items:center;}
.rating-badge{display:inline-flex;align-items:center;gap:18px;background:var(--white);border:1px solid var(--mist);border-radius:999px;padding:15px 26px;box-shadow:0 12px 30px rgba(26,20,24,.07);flex-shrink:0;}
.rating-badge .rb-stars{color:var(--carmin);font-size:18px;letter-spacing:2px;}
.rating-badge .rb-score{font-family:var(--serif);font-size:25px;font-weight:500;line-height:1;}
.rating-badge .rb-score span{color:var(--stone);font-size:16px;margin-left:4px;}
.rating-badge .rb-count{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);border-left:1px solid var(--mist);padding-left:18px;}
@media(max-width:560px){
  .rating-badge{flex-wrap:wrap;justify-content:center;gap:8px 14px;padding:14px 20px;border-radius:20px;max-width:100%;}
  .rating-badge .rb-count{flex-basis:100%;border-left:none;padding-left:0;text-align:center;}
}
.reviews .rail-wrap{margin-top:48px;}
.review{background:var(--white);border:1px solid var(--mist);border-radius:8px;padding:28px;display:flex;flex-direction:column;}
.review .rh{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.review .av{width:42px;height:42px;border-radius:50%;background:var(--rose);color:var(--carmin);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;font-weight:600;}
.review .who{font-weight:600;font-size:14.5px;}
.review .date{font-family:var(--mono);font-size:10.5px;color:var(--stone);letter-spacing:.08em;}
.review .rstars{color:var(--carmin);font-size:13px;letter-spacing:2px;margin-bottom:10px;}
.review p{font-size:14.5px;color:var(--graphite);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.review .r-more{margin-top:12px;align-self:flex-start;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--carmin);display:none;align-items:center;gap:7px;cursor:pointer;}
.review .r-more.show{display:inline-flex;}
.review .r-more:hover{color:var(--wine);}
.r-pop{position:absolute;top:0;left:0;right:0;background:var(--white);border:1px solid var(--mist);border-radius:8px;padding:28px;box-shadow:0 24px 56px rgba(26,20,24,.2);z-index:40;animation:popIn .2s ease;}
.r-pop .r-full{font-size:14.5px;color:var(--graphite);line-height:1.6;display:block;-webkit-line-clamp:none;}
@keyframes popIn{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:none;}}

/* ---------- blog ---------- */
.blog{background:var(--ink);position:relative;overflow:hidden;}
.blog > .wrap{position:relative;z-index:2;}
.blog .eyebrow{color:var(--carmin-bright);}
.blog .eyebrow::before{background:var(--carmin-bright);}
.blog .h2{color:#fff;}
.blog .sh-note{color:rgba(255,255,255,.7);}
.blog .rail-bar{background:rgba(255,255,255,.2);}
.blog .rail-nav button{border-color:rgba(255,255,255,.32);color:#fff;}
.blog .rail-nav button:hover{background:var(--carmin);border-color:var(--carmin);color:#fff;}
.blog .rail-nav button:disabled{opacity:.3;}
/* reusable animated fx background (radar sweep + sonar pulses) */
.fx-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.fx-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 65% at 50% 50%, rgba(200,23,79,.12), transparent 70%);}
.fx-bg .layer{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);}
.fx-bg .sweep{width:clamp(0px,150vw,1500px);aspect-ratio:1;border-radius:50%;background:conic-gradient(from 0deg, transparent 0 68%, rgba(200,23,79,.2) 86%, rgba(226,23,79,.05) 94%, transparent 100%);mix-blend-mode:screen;animation:spin 22s linear infinite;}
.fx-bg .pulse{width:300px;height:300px;border:1px solid rgba(226,23,79,.45);border-radius:50%;opacity:0;animation:pulse 8s ease-out infinite;}
.fx-bg .pulse.p2{animation-delay:2s;}
.fx-bg .pulse.p3{animation-delay:4s;}
.fx-bg .pulse.p4{animation-delay:6s;}
@media (prefers-reduced-motion:reduce){.fx-bg .sweep,.fx-bg .pulse{animation:none;}}
/* blog cards on the dark animated bg → glassy (base .post stays white for white contexts) */
.blog .post,.blog-cat .post{background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background .3s,border-color .3s,transform .3s;}
.blog .post:hover,.blog-cat .post:hover{background:rgba(255,255,255,.09);border-color:rgba(226,23,79,.45);transform:translateY(-4px);}
.blog .post h3,.blog-cat .post h3{color:#fff;}
.blog .post:hover h3,.blog-cat .post:hover h3{color:var(--carmin-bright);}
.blog .post p,.blog-cat .post p{color:rgba(255,255,255,.68);}
.blog .post .p-cat,.blog-cat .post .p-cat{color:var(--carmin-bright);}
.blog .post .link-arrow,.blog-cat .post .link-arrow{color:#fff;}
.blog .post .p-img .ph,.blog-cat .post .p-img .ph{background:#221b20;background-image:repeating-linear-gradient(135deg,transparent,transparent 11px,rgba(255,255,255,.05) 11px,rgba(255,255,255,.05) 12px);border:none;}
.blog .post .p-img .ph-lbl,.blog-cat .post .p-img .ph-lbl{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.3);background:rgba(34,27,32,.5);}
/* catalog sits on a LIGHT section → cards are solid dark (same look as home glass cards, but opaque) */
.blog-cat .post{background:var(--ink);border-color:rgba(26,20,24,.12);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:0 18px 44px rgba(26,20,24,.1);}
.blog-cat .post:hover{background:var(--ink-soft);border-color:rgba(200,23,79,.5);}
.post{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--mist);border-radius:10px;overflow:hidden;}
.post .p-img{aspect-ratio:3/2;overflow:hidden;margin-bottom:16px;}
.post .p-img .ph{position:absolute;inset:0;border:none;border-radius:0;}
.post .p-img{position:relative;}
.post .p-cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--carmin);margin:0 20px 10px;}
.post h3{font-size:21px;line-height:1.16;margin:0 20px 10px;transition:color .2s;}
.post:hover h3{color:var(--carmin);}
.post p{font-size:14px;color:var(--graphite);line-height:1.55;margin:0 20px 16px;flex:1;}
.post .link-arrow{margin:0 20px 22px;}

/* ---------- faq ---------- */
.faq .grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:64px;align-items:start;}
.faq-list{border-top:1px solid var(--mist);}
.faq-item{border-bottom:1px solid var(--mist);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;text-align:left;padding:26px 0;font-family:var(--serif);font-size:21px;font-weight:500;color:var(--ink);}
.faq-q .ic{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1px solid var(--mist);display:flex;align-items:center;justify-content:center;position:relative;transition:all .25s;}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;background:var(--carmin);transition:transform .3s;}
.faq-q .ic::before{width:12px;height:1.5px;}
.faq-q .ic::after{width:1.5px;height:12px;}
.faq-item.open .faq-q .ic{background:var(--carmin);border-color:var(--carmin);}
.faq-item.open .faq-q .ic::before,.faq-item.open .faq-q .ic::after{background:#fff;}
.faq-item.open .faq-q .ic::after{transform:scaleY(0);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.faq-a .inner{padding:0 0 26px;color:var(--graphite);font-size:15.5px;line-height:1.65;max-width:62ch;}

/* ============================================================ footer */
footer.site{background:var(--ink);color:rgba(255,255,255,.66);padding:88px 0 36px;}
footer.site .top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.12);}
footer.site .brand img{height:38px;margin-bottom:22px;}
footer.site .brand p{font-size:15px;line-height:1.6;max-width:34ch;}
footer.site .col h4{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--carmin-bright);margin-bottom:20px;}
footer.site .col a{display:block;font-size:14.5px;padding:7px 0;color:rgba(255,255,255,.7);transition:color .2s;}
footer.site .col a:hover{color:#fff;}
footer.site .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;flex-wrap:wrap;gap:16px;}
footer.site .bottom .cr{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;}
footer.site .bottom .zen{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;}
footer.site .bottom .zen b{color:var(--carmin-bright);font-weight:500;}

/* ============================================================ secondary page banner (vistas internas) */
.page-banner{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:128px 0 92px;display:flex;align-items:center;min-height:44vh;}
.page-banner .wrap{position:relative;z-index:2;}
.page-banner .crumb{font-family:var(--mono);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:26px;display:flex;gap:11px;align-items:center;}
.page-banner .crumb b{color:#fff;font-weight:600;background:var(--carmin);padding:5px 12px;border-radius:5px;letter-spacing:.14em;}
.page-banner .crumb a{color:rgba(255,255,255,.6);}
.page-banner .crumb a:hover{color:var(--carmin-bright);}
.page-banner .eyebrow{color:var(--carmin-bright);}
.page-banner .eyebrow::before{background:var(--carmin-bright);}
.page-banner h1{font-family:var(--serif);font-weight:500;font-size:clamp(38px,5.6vw,78px);line-height:1.02;color:#fff;margin:20px 0 0;max-width:18ch;}
.page-banner h1 em{font-style:italic;color:var(--carmin-bright);}
.page-banner .pb-sub{margin-top:24px;max-width:62ch;color:rgba(255,255,255,.74);font-size:clamp(16px,1.35vw,19px);line-height:1.62;}

/* flat light variant of the secondary banner (legal pages) */
.page-banner.pb-flat{background:var(--paper-2);color:var(--ink);border-bottom:1px solid var(--mist);}
.page-banner.pb-flat .fx-bg{display:none;}
.page-banner.pb-flat .crumb{color:var(--stone);}
.page-banner.pb-flat .crumb a{color:var(--graphite);}
.page-banner.pb-flat .crumb a:hover{color:var(--carmin);}
.page-banner.pb-flat .eyebrow{color:var(--carmin);}
.page-banner.pb-flat .eyebrow::before{background:var(--carmin);}
.page-banner.pb-flat h1{color:var(--ink);}
.page-banner.pb-flat h1 em{color:var(--carmin);}
.page-banner.pb-flat .pb-sub{color:var(--graphite);}

/* ---------- about page content ---------- */
.about-intro{background:var(--paper);}
.about-intro .grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(40px,5.5vw,84px);align-items:center;}
.about-intro .eyebrow{margin-bottom:22px;}
.about-intro h2{margin-bottom:24px;}
.about-intro h2 em{font-style:italic;color:var(--carmin);}
.about-intro .lede{margin-bottom:28px;}
.about-intro .essence-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:6px;}
.about-intro .essence-tags span{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite);border:1px solid var(--mist);border-radius:999px;padding:8px 15px;display:inline-flex;align-items:center;gap:8px;transition:border-color .25s,color .25s;}
.about-intro .essence-tags span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--carmin);}
.about-intro .essence-tags span:hover{border-color:var(--carmin);color:var(--ink);}
.about-intro .photo{position:relative;}
.about-intro .photo::before{content:"";position:absolute;inset:18px -18px -18px 18px;border:1.5px solid var(--carmin);border-radius:12px;z-index:0;opacity:.55;transition:inset .5s cubic-bezier(.16,1,.3,1);}
.about-intro .photo:hover::before{inset:12px -12px -12px 12px;}
.about-intro .photo img{position:relative;z-index:1;width:100%;height:clamp(380px,44vw,540px);object-fit:cover;border-radius:12px;display:block;}
.about-intro .photo .cap{position:absolute;z-index:2;left:16px;bottom:16px;background:rgba(26,20,24,.72);backdrop-filter:blur(6px);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:9px 14px;border-radius:5px;}
.about-intro .photo .since{position:absolute;z-index:3;right:-16px;top:28px;background:var(--carmin);color:#fff;width:104px;height:104px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 16px 40px rgba(126,14,51,.4);}
.about-intro .photo .since b{font-family:var(--serif);font-size:30px;font-weight:500;line-height:1;}
.about-intro .photo .since span{font-family:var(--mono);font-size:8px;letter-spacing:.12em;text-transform:uppercase;margin-top:4px;}

/* ---------- founder · Ricardo Serna ---------- */
.founder{background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.founder .fx-bg{opacity:.5;}
.founder > .wrap{position:relative;z-index:2;}
.founder .eyebrow{color:var(--carmin-bright);}
.founder .eyebrow::before{background:var(--carmin-bright);}
.founder-top{display:grid;grid-template-columns:.86fr 1.14fr;gap:clamp(36px,5vw,72px);align-items:end;}
.founder-portrait{position:relative;align-self:stretch;}
.founder-portrait img{width:100%;height:100%;min-height:440px;object-fit:cover;object-position:center top;border-radius:14px;display:block;}
.founder-portrait .pill{position:absolute;left:18px;bottom:18px;display:flex;flex-direction:column;gap:2px;background:var(--carmin);color:#fff;padding:14px 20px;border-radius:10px;box-shadow:0 16px 40px rgba(126,14,51,.45);}
.founder-portrait .pill b{font-family:var(--serif);font-size:21px;font-weight:500;}
.founder-portrait .pill span{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.8);}
.founder-copy h2{color:#fff;margin:18px 0 8px;}
.founder-copy h2 em{font-style:italic;color:var(--carmin-bright);}
.founder-role{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:24px;}
.founder-copy p{color:rgba(255,255,255,.76);font-size:16px;line-height:1.72;margin-bottom:16px;}
.founder-copy p:last-child{margin-bottom:0;}
.founder-copy .placeholder-note{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--carmin-bright);border:1px dashed rgba(226,23,79,.5);border-radius:5px;padding:4px 10px;display:inline-block;margin-bottom:18px;}
/* pull quote */
.founder-quote{margin:64px 0 0;padding:48px 0 0;border-top:1px solid rgba(255,255,255,.14);text-align:center;}
.founder-quote blockquote{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(24px,3.2vw,40px);line-height:1.2;max-width:22ch;margin:0 auto;color:#fff;}
.founder-quote .qmark{font-family:var(--serif);font-size:70px;line-height:.4;color:var(--carmin-bright);display:block;height:38px;}
.founder-quote cite{display:block;margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);font-style:normal;}
/* trajectory timeline */
.trajectory{margin-top:64px;}
.trajectory .tj-head{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--carmin-bright);margin-bottom:28px;}
.tj-rail{display:flex;gap:18px;overflow-x:auto;padding:4px 4px 14px;margin:0 -4px;scrollbar-width:none;}
.tj-rail::-webkit-scrollbar{display:none;}
.tj-item{flex:0 0 auto;width:clamp(220px,24vw,272px);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:24px;backdrop-filter:blur(8px);transition:border-color .3s,transform .3s,background .3s;}
.tj-item:hover{border-color:rgba(226,23,79,.5);transform:translateY(-4px);background:rgba(255,255,255,.08);}
.tj-item .yr{font-family:var(--serif);font-size:30px;font-weight:500;color:var(--carmin-bright);line-height:1;margin-bottom:14px;}
.tj-item h4{font-family:var(--serif);font-size:19px;font-weight:500;line-height:1.15;margin-bottom:8px;color:#fff;}
.tj-item p{font-size:13.5px;color:rgba(255,255,255,.66);line-height:1.55;}
/* event gallery */
.founder-gallery{margin-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.founder-gallery figure{position:relative;border-radius:12px;overflow:hidden;margin:0;}
.founder-gallery img{width:100%;height:clamp(200px,24vw,290px);object-fit:cover;display:block;transition:transform .7s cubic-bezier(.16,1,.3,1);}
.founder-gallery figure:hover img{transform:scale(1.05);}
.founder-gallery figcaption{position:absolute;left:14px;bottom:12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(26,20,24,.7);backdrop-filter:blur(4px);padding:6px 11px;border-radius:5px;}
@media(max-width:820px){
  .founder-top{grid-template-columns:1fr;gap:32px;}
  .founder-portrait img{min-height:0;height:auto;max-height:560px;}
  .founder-gallery{grid-template-columns:1fr;}
}
section.mvvc-section{background:var(--paper-2);padding-bottom:0;}
.mvvc-head{margin:0 auto 56px;max-width:680px;text-align:center;}
.mvvc-head h2{margin-top:16px;}
.mvvc-head h2 em{font-style:italic;color:var(--carmin);}
/* editorial numbered rows, magazine feel */
.principles{display:flex;flex-direction:column;}
.principle{display:grid;grid-template-columns:260px 1fr;gap:clamp(32px,5vw,80px);align-items:center;padding:clamp(40px,5vw,60px) 0;border-top:1px solid var(--mist);position:relative;}
.principle:last-child{border-bottom:1px solid var(--mist);}
.principle::after{content:"";position:absolute;left:0;top:-1px;height:1px;width:0;background:var(--carmin);transition:width .6s cubic-bezier(.16,1,.3,1);}
.principle:hover::after{width:100%;}
.principle:nth-child(even){grid-template-columns:1fr 260px;}
.principle:nth-child(even) .pr-figure{order:2;}
.principle:nth-child(even) .pr-text{order:1;text-align:right;}
.principle:nth-child(even) .pr-text .lab{flex-direction:row-reverse;}
.principle:nth-child(even) .pr-text p{margin-left:auto;}
/* figure: ghost numeral + thin ring holding the animated glyph */
.pr-figure{position:relative;width:260px;height:188px;display:flex;align-items:center;justify-content:center;margin:0 auto;}
.pr-num{position:absolute;font-family:var(--serif);font-style:italic;font-weight:500;font-size:170px;line-height:1;color:var(--carmin);opacity:.1;z-index:0;user-select:none;transition:opacity .5s;}
.principle:hover .pr-num{opacity:.18;}
.pr-ring{position:relative;z-index:1;width:128px;height:128px;border-radius:50%;border:1.5px solid var(--carmin);background:var(--paper-2);display:flex;align-items:center;justify-content:center;transition:transform .5s cubic-bezier(.16,1,.3,1),background .5s,box-shadow .5s;}
.principle:hover .pr-ring{transform:scale(1.05);background:var(--rose);box-shadow:0 20px 48px rgba(200,23,79,.18);}
.pr-text .lab{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--carmin);margin-bottom:16px;}
.pr-text .lab i{width:22px;height:1px;background:var(--carmin);}
.pr-text h3{font-family:var(--serif);font-size:clamp(27px,3.4vw,42px);font-weight:500;line-height:1.06;margin-bottom:16px;letter-spacing:-.01em;}
.pr-text h3 em{font-style:italic;color:var(--carmin);}
.pr-text p{color:var(--graphite);font-size:16px;line-height:1.7;max-width:none;}
/* glyphs (simple geometric, brand-colored, animated on hover) */
.ic-target{width:56px;height:56px;border:2.5px solid var(--carmin);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;}
.ic-target::before{content:"";width:30px;height:30px;border:2.5px solid var(--carmin);border-radius:50%;}
.ic-target::after{content:"";position:absolute;width:10px;height:10px;background:var(--carmin);border-radius:50%;}
.ic-target::after{animation:targetPulse 2.6s ease-in-out infinite;}
@keyframes targetPulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.6);opacity:.6;}}
.ic-eye{width:64px;height:38px;border:2.5px solid var(--carmin);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.ic-eye::after{content:"";width:16px;height:16px;border-radius:50%;background:var(--carmin);animation:eyeFocus 3.2s ease-in-out infinite;}
@keyframes eyeFocus{0%,100%{transform:scale(1);}50%{transform:scale(.5);}}
.ic-diamond{width:44px;height:44px;border:2.5px solid var(--carmin);animation:diamondSpin 11s linear infinite;}
@keyframes diamondSpin{from{transform:rotate(45deg);}to{transform:rotate(405deg);}}
.ic-union{position:relative;width:68px;height:42px;}
.ic-union::before,.ic-union::after{content:"";position:absolute;top:1px;width:40px;height:40px;border:2.5px solid var(--carmin);border-radius:50%;}
.ic-union::before{left:0;animation:unionL 3s ease-in-out infinite;}
.ic-union::after{right:0;animation:unionR 3s ease-in-out infinite;}
@keyframes unionL{0%,100%{transform:translateX(0);}50%{transform:translateX(7px);}}
@keyframes unionR{0%,100%{transform:translateX(0);}50%{transform:translateX(-7px);}}
@media (prefers-reduced-motion:reduce){.ic-target::after,.ic-eye::after,.ic-diamond,.ic-union::before,.ic-union::after{animation:none;}}
@media(max-width:680px){
  .about-intro .grid{grid-template-columns:1fr;gap:32px;}
  .principle,.principle:nth-child(even){grid-template-columns:1fr;gap:8px;}
  .principle:nth-child(even) .pr-figure{order:0;}
  .principle:nth-child(even) .pr-text{order:0;text-align:left;}
  .principle:nth-child(even) .pr-text .lab{flex-direction:row;}
  .principle:nth-child(even) .pr-text p{margin-left:0;}
  .pr-figure{margin:0;width:170px;height:140px;justify-content:flex-start;}
  .pr-num{font-size:120px;}
  .pr-ring{width:104px;height:104px;}
}

/* ============================================================ reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1);transition-delay:var(--d,0ms);}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;}.marquee .track{animation:none;}}

/* ============================================================ responsive */
@media(max-width:1080px){
  :root{--pad:32px;}
  .promo-trio{grid-template-columns:1fr 1fr;}
  .promo-trio .promo:first-child{grid-column:1/-1;}
}
/* ============================================================ tertiary banner (shorter) */
.page-banner.pb-tertiary{min-height:32vh;padding:clamp(58px,7vw,76px) 0;align-items:center;}
.page-banner.pb-tertiary h1{font-size:clamp(32px,4.4vw,58px);max-width:20ch;}
.page-banner.pb-tertiary .pb-sub{margin-top:18px;font-size:clamp(15px,1.3vw,18px);}

/* ============================================================ blog catalog */
section.blog-cat{background:var(--paper);padding-top:clamp(36px,4vw,52px);}
.blog-toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px 32px;flex-wrap:wrap;margin-bottom:44px;padding-bottom:24px;border-bottom:1px solid var(--mist);}
.blog-filters{display:flex;gap:10px;flex-wrap:wrap;}
.blog-filters button{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite);background:transparent;border:1px solid var(--mist);border-radius:999px;padding:10px 18px;transition:background .25s,color .25s,border-color .25s;}
.blog-filters button:hover{border-color:var(--carmin);color:var(--carmin);}
.blog-filters button.active{background:var(--carmin);border-color:var(--carmin);color:#fff;}
.blog-count{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);white-space:nowrap;}
.blog-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.blog-cat-grid .post{opacity:1;}
.blog-cat-grid .post.hide{display:none;}
.blog-empty{text-align:center;padding:60px 0;font-family:var(--serif);font-size:22px;color:var(--stone);display:none;}
.blog-empty.show{display:block;}
/* pagination */
.pagination{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap;}
.pagination.pagination-bottom{margin-top:60px;}
.pagination:empty{display:none;}
.blog-cat .pagination button,.prod-cat .pagination button{min-width:44px;height:44px;padding:0 14px;border-radius:999px;border:1px solid var(--mist);background:transparent;font-family:var(--mono);font-size:13px;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:background .25s,color .25s,border-color .25s,opacity .25s;}
.blog-cat .pagination button:hover:not(:disabled),.prod-cat .pagination button:hover:not(:disabled){border-color:var(--carmin);color:var(--carmin);}
.blog-cat .pagination button.active,.prod-cat .pagination button.active{background:var(--carmin);border-color:var(--carmin);color:#fff;}
.blog-cat .pagination button:disabled,.prod-cat .pagination button:disabled{opacity:.32;}

/* ============================================================ products catalog */
section.prod-cat{background:var(--paper);padding-top:clamp(36px,4vw,52px);}
section.prod-cat > .wrap{max-width:1460px;}
.prod-shell{display:grid;grid-template-columns:250px 1fr;gap:clamp(28px,3.2vw,52px);align-items:start;}
.prod-sidebar{position:sticky;top:96px;}
.prod-sidebar .ps-title{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);padding-bottom:16px;border-bottom:1px solid var(--ink);margin-bottom:4px;display:flex;align-items:center;gap:10px;}
.prod-sidebar .ps-title::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--carmin);}
.prod-sidebar .filter-group{display:block;padding:18px 0;border-bottom:1px solid var(--mist);}
.prod-sidebar .filter-group .fg-label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);margin-bottom:12px;}
.prod-sidebar .fg-options{display:flex;flex-wrap:wrap;gap:8px;}
.filter-group button{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite);background:transparent;border:1px solid var(--mist);border-radius:999px;padding:8px 14px;transition:background .25s,color .25s,border-color .25s;}
.filter-group button:hover{border-color:var(--carmin);color:var(--carmin);}
.filter-group button.active{background:var(--carmin);border-color:var(--carmin);color:#fff;}
.prod-reset{margin-top:18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--carmin);display:inline-flex;align-items:center;gap:7px;background:none;border:none;padding:0;cursor:pointer;}
.prod-reset:hover{text-decoration:underline;text-underline-offset:3px;}
.prod-main{min-width:0;}
.prod-main .pm-top{display:flex;justify-content:space-between;align-items:center;gap:16px 24px;flex-wrap:wrap;margin-bottom:28px;padding-bottom:18px;border-bottom:1px solid var(--mist);}
.prod-count{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);white-space:nowrap;}
.prod-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.prod-cat-grid .prod-card.hide{display:none;}
.prod-empty{text-align:center;padding:60px 0;font-family:var(--serif);font-size:22px;color:var(--stone);display:none;}
.prod-empty.show{display:block;}
@media(max-width:1180px){.prod-cat-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:900px){
  .prod-shell{grid-template-columns:1fr;gap:28px;}
  .prod-sidebar{position:static;}
  .prod-sidebar .filter-group{border-bottom:none;padding:8px 0;}
}
@media(max-width:560px){.prod-cat-grid{grid-template-columns:1fr;}}
.pagination .pg-arrow{font-size:16px;}
.blog-cat-grid .post{opacity:1;}
@media(max-width:880px){.blog-cat-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.blog-cat-grid{grid-template-columns:1fr;}}

/* ============================================================ blog article (single note) */
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--carmin);z-index:400;transition:width .08s linear;}
.article{background:var(--paper);padding-top:clamp(40px,5vw,64px);}
.article-head{max-width:760px;margin:0 auto;text-align:center;}
.article-head .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);margin-bottom:26px;display:flex;gap:10px;align-items:center;justify-content:center;}
.article-head .crumb a{color:var(--graphite);}
.article-head .crumb a:hover{color:var(--carmin);}
.article-head .a-cat{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--carmin);margin-bottom:18px;display:inline-block;}
.article-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,4.6vw,58px);line-height:1.05;letter-spacing:-.01em;}
.article-head h1 em{font-style:italic;color:var(--carmin);}
.article-dek{font-size:clamp(17px,1.5vw,20px);color:var(--graphite);line-height:1.6;margin:22px auto 0;max-width:60ch;}
.article-meta{display:flex;align-items:center;justify-content:center;gap:16px;margin:32px 0 0;flex-wrap:wrap;}
.article-meta .av{width:46px;height:46px;border-radius:50%;background:var(--rose);color:var(--carmin);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:19px;font-weight:600;}
.article-meta .who{text-align:left;}
.article-meta .who b{display:block;font-size:14.5px;font-weight:600;color:var(--ink);}
.article-meta .who span{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--mist);}
.article-figure{max-width:1040px;margin:48px auto 0;}
.article-figure .ph{aspect-ratio:16/9;border-radius:12px;}
.article-figure img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:12px;display:block;}
.article-figure figcaption{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);text-align:center;margin-top:14px;}
/* layout: sticky share rail + prose */
.article-layout{display:flex;gap:clamp(24px,4vw,56px);max-width:840px;margin:56px auto 0;align-items:flex-start;}
.share-rail{position:sticky;top:104px;display:flex;flex-direction:column;gap:10px;flex-shrink:0;align-items:center;}
.share-rail .sr-label{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);writing-mode:vertical-rl;margin-bottom:6px;}
.share-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--mist);display:flex;align-items:center;justify-content:center;color:var(--graphite);background:var(--paper);transition:background .25s,color .25s,border-color .25s,transform .25s;}
.share-btn:hover{background:var(--carmin);border-color:var(--carmin);color:#fff;transform:translateY(-2px);}
.share-btn svg{width:18px;height:18px;}
.share-btn.copied{background:var(--wine);border-color:var(--wine);color:#fff;}
.article-body{max-width:720px;flex:1;min-width:0;}
.article-body h2{font-family:var(--serif);font-size:clamp(24px,2.6vw,32px);font-weight:500;margin:40px 0 14px;line-height:1.1;}
.article-body h2:first-child{margin-top:0;}
.article-body p{font-size:17.5px;line-height:1.78;color:var(--graphite);margin-bottom:20px;}
.article-body p .first-cap{}
.article-body strong{color:var(--ink);font-weight:600;}
.article-body ul{margin:0 0 20px;padding-left:22px;}
.article-body li{font-size:17.5px;line-height:1.7;color:var(--graphite);margin-bottom:10px;}
.article-body blockquote{margin:32px 0;padding:8px 0 8px 28px;border-left:3px solid var(--carmin);font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.2vw,26px);line-height:1.35;color:var(--ink);}
.article-body .pull-note{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--carmin);border:1px dashed rgba(200,23,79,.5);border-radius:5px;padding:5px 11px;display:inline-block;margin-bottom:26px;}
/* reactions */
.reactions{max-width:720px;margin:56px auto 0;padding:38px 0 0;border-top:1px solid var(--mist);text-align:center;}
.reactions .rx-h{font-family:var(--serif);font-size:24px;font-weight:500;margin-bottom:22px;}
.reactions .rx-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.rx-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 24px;border:1px solid var(--mist);border-radius:14px;background:var(--white);transition:border-color .25s,transform .25s,background .25s;min-width:96px;}
.rx-btn:hover{border-color:var(--carmin);transform:translateY(-3px);}
.rx-btn.active{border-color:var(--carmin);background:var(--rose);}
.rx-btn svg{width:30px;height:30px;color:var(--carmin);}
.rx-btn .rx-name{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite);}
.rx-btn .rx-count{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);}
/* back to blog */
.article-back{max-width:720px;margin:48px auto 0;text-align:center;padding-bottom:clamp(56px,7vw,88px);}
@media(max-width:720px){
  .article-layout{flex-direction:column;gap:24px;}
  .share-rail{position:static;flex-direction:row;align-self:center;}
  .share-rail .sr-label{writing-mode:horizontal-tb;margin:0 6px 0 0;}
}

/* ============================================================ product detail (PDP) */
section.pdp{background:var(--paper);padding-top:clamp(30px,3.5vw,46px);}
.pdp-crumb{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);margin-bottom:28px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.pdp-crumb a{color:var(--graphite);}
.pdp-crumb a:hover{color:var(--carmin);}
.pdp-top{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,4.5vw,68px);align-items:start;}
.pdp-gallery{position:sticky;top:96px;}
.pdp-main{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:var(--white);border:1px solid var(--mist);}
.pdp-main .ph{position:absolute;inset:0;border:none;border-radius:0;}
.pdp-main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.pdp-main .pdp-badge{position:absolute;left:16px;top:16px;background:var(--carmin);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:7px 12px;border-radius:5px;z-index:2;}
.pdp-thumbs{display:flex;gap:12px;margin-top:14px;}
.pdp-thumb{width:84px;aspect-ratio:1;border-radius:10px;overflow:hidden;border:1.5px solid var(--mist);background:var(--white);cursor:pointer;padding:0;transition:border-color .25s;position:relative;}
.pdp-thumb .ph{position:absolute;inset:0;border:none;border-radius:0;}
.pdp-thumb .ph-lbl{font-size:8px;padding:4px 5px;}
.pdp-thumb.active{border-color:var(--carmin);}
.pdp-info .brand-tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--carmin);margin-bottom:14px;display:inline-block;}
.pdp-info h1{font-family:var(--serif);font-weight:500;font-size:clamp(30px,3.8vw,46px);line-height:1.05;letter-spacing:-.01em;margin-bottom:18px;}
.pdp-info .short{font-size:16.5px;line-height:1.65;color:var(--graphite);margin-bottom:26px;max-width:52ch;}
.pdp-price{display:flex;align-items:baseline;gap:12px;margin-bottom:8px;}
.pdp-price .amt{font-family:var(--serif);font-size:clamp(30px,3.4vw,42px);font-weight:500;color:var(--ink);}
.pdp-price .cur{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);}
.pdp-sku{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-bottom:26px;}
.pdp-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px;}
.pdp-meta span{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);border:1px solid var(--mist);border-radius:999px;padding:8px 14px;display:inline-flex;align-items:center;gap:8px;}
.pdp-meta span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--carmin);}
.pdp-actions{display:flex;gap:14px;align-items:stretch;flex-wrap:wrap;}
.qty{display:inline-flex;align-items:center;border:1px solid var(--mist);border-radius:999px;overflow:hidden;}
.qty button{width:46px;height:52px;font-size:18px;color:var(--ink);background:var(--white);transition:background .2s,color .2s;}
.qty button:hover{background:var(--carmin);color:#fff;}
.qty .qv{min-width:40px;text-align:center;font-family:var(--mono);font-size:15px;}
.pdp-actions .btn{height:52px;}
.pdp-actions .add{flex:1;min-width:200px;justify-content:center;}
.pdp-note{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--carmin);border:1px dashed rgba(200,23,79,.5);border-radius:5px;padding:5px 11px;display:inline-block;margin-top:22px;}
/* about block */
.pdp-about{max-width:760px;margin:clamp(56px,7vw,88px) auto 0;}
.pdp-about .eyebrow{margin-bottom:18px;}
.pdp-about h2{font-family:var(--serif);font-weight:500;font-size:clamp(24px,2.6vw,34px);margin-bottom:18px;}
.pdp-about p{font-size:17px;line-height:1.78;color:var(--graphite);margin-bottom:18px;}
@media(max-width:880px){
  .pdp-top{grid-template-columns:1fr;gap:32px;}
  .pdp-gallery{position:static;}
}

/* ============================================================ social reels */
.social{background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.social .fx-bg{opacity:.4;}
.social > .wrap{position:relative;z-index:2;}
.social-head{text-align:center;max-width:640px;margin:0 auto 48px;}
.social-head .eyebrow{color:var(--carmin-bright);justify-content:center;}
.social-head .eyebrow::before,.social-head .eyebrow::after{content:"";width:28px;height:1px;background:var(--carmin-bright);display:inline-block;}
.social-head h2{color:#fff;margin:18px 0 22px;}
.social-follow{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;}
.social-follow .sf-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);}
.social-follow a{width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .25s,border-color .25s,transform .25s;}
.social-follow a:hover{background:var(--carmin);border-color:var(--carmin);transform:translateY(-2px);}
.social-follow a svg{width:20px;height:20px;}
.reels{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px;}
.reel{position:relative;aspect-ratio:9/16;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:#221b20;transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .3s;}
.reel .ph{position:absolute;inset:0;border:none;border-radius:0;}
.reel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.reel::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,13,16,.7),transparent 45%);z-index:1;}
.reel:hover{transform:translateY(-6px);border-color:rgba(226,23,79,.5);}
.reel .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;width:62px;height:62px;border-radius:50%;background:rgba(26,20,24,.5);backdrop-filter:blur(6px);border:1.5px solid rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;transition:background .25s,transform .25s;}
.reel:hover .play{background:var(--carmin);border-color:var(--carmin);transform:translate(-50%,-50%) scale(1.08);}
.reel .play::before{content:"";width:0;height:0;border-left:15px solid #fff;border-top:9px solid transparent;border-bottom:9px solid transparent;margin-left:4px;}
.reel .r-tag{position:absolute;left:16px;bottom:16px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#fff;}
.reel .r-tag b{display:block;font-family:var(--serif);font-size:15px;font-weight:500;letter-spacing:0;text-transform:none;margin-top:3px;}
@media(max-width:680px){
  .reels{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;max-width:none;margin:0;padding-bottom:8px;scrollbar-width:none;}
  .reels::-webkit-scrollbar{display:none;}
  .reels .reel{flex:0 0 78%;scroll-snap-align:center;}
}

/* ============================================================ error pages (404 / 500) */
.errorpage{background:var(--paper);color:var(--ink);position:relative;overflow:hidden;min-height:calc(100svh - 114px);display:flex;align-items:center;justify-content:center;text-align:center;padding:90px 0;}
.errorpage .fx-bg{display:none;}
.errorpage .err-eye{border-color:var(--ink);}
.errorpage .btn-ghost.on-dark{color:var(--ink);border-color:var(--ink);}
.errorpage .btn-ghost.on-dark:hover{background:var(--ink);color:#fff;}
.errorpage > .wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;}
.errorpage .eyebrow{color:var(--carmin);}
.errorpage .eyebrow::before{background:var(--carmin);}
.errorpage .eyebrow::after{content:"";width:28px;height:1px;background:var(--carmin);display:inline-block;}
.err-code{position:relative;display:flex;align-items:center;justify-content:center;gap:clamp(4px,2vw,22px);margin:28px 0 8px;}
.err-code .digit{font-family:var(--serif);font-weight:500;font-size:clamp(96px,18vw,232px);line-height:.8;letter-spacing:-.03em;}
.err-code .digit em{font-style:italic;color:var(--carmin);}
/* the eye-as-zero */
.err-eye{width:clamp(80px,14vw,176px);height:clamp(80px,14vw,176px);border:clamp(4px,0.9vw,10px) solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.err-eye span{width:42%;height:42%;border-radius:50%;background:var(--carmin);animation:eyeFocus 3.4s ease-in-out infinite;}
.errorpage h1{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4vw,52px);color:var(--ink);margin-top:18px;}
.errorpage h1 em{font-style:italic;color:var(--carmin);}
.errorpage p{color:var(--graphite);font-size:clamp(16px,1.4vw,19px);line-height:1.6;max-width:52ch;margin:20px auto 0;}
.errorpage .cta-row{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;justify-content:center;}
.errorpage .err-links{margin-top:40px;display:flex;gap:10px 26px;flex-wrap:wrap;justify-content:center;}
.errorpage .err-links a{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--graphite);display:inline-flex;align-items:center;gap:8px;transition:color .25s;}
.errorpage .err-links a::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--carmin);}
.errorpage .err-links a:hover{color:var(--carmin);}

/* ============================================================ legal / long-form */
.legal{background:var(--paper);}
.legal .wrap{max-width:1080px;}
.legal-grid{display:grid;grid-template-columns:240px 1fr;gap:clamp(40px,5vw,72px);align-items:start;}
.legal-toc{position:sticky;top:96px;align-self:start;}
.legal-toc .toc-h{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--carmin);margin-bottom:18px;}
.legal-toc a{display:block;font-size:13.5px;color:var(--graphite);padding:8px 0 8px 16px;border-left:2px solid var(--mist);transition:color .2s,border-color .2s;line-height:1.4;}
.legal-toc a:hover{color:var(--carmin);border-color:var(--carmin);}
.legal-body .meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid var(--mist);}
.legal-body .placeholder-note{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--carmin);border:1px dashed rgba(200,23,79,.5);border-radius:5px;padding:5px 11px;display:inline-block;margin-bottom:30px;}
.legal-body h2{font-family:var(--serif);font-size:clamp(24px,2.6vw,32px);font-weight:500;margin:48px 0 16px;scroll-margin-top:96px;}
.legal-body h2:first-of-type{margin-top:0;}
.legal-body p{font-size:16px;line-height:1.75;color:var(--graphite);margin-bottom:16px;max-width:68ch;}
.legal-body ul{margin:0 0 16px 0;padding-left:22px;max-width:68ch;}
.legal-body li{font-size:16px;line-height:1.7;color:var(--graphite);margin-bottom:8px;}
.legal-body a{color:var(--carmin);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--mist);}
.legal-body strong{color:var(--ink);font-weight:600;}
@media(max-width:820px){
  .legal-grid{grid-template-columns:1fr;gap:32px;}
  .legal-toc{position:static;}
  .legal-toc a{display:inline-block;border-left:none;border-bottom:2px solid var(--mist);padding:6px 12px 6px 0;margin-right:12px;}
  .err-code{flex-wrap:nowrap;}
}

@media(max-width:820px){
  .contact .grid,.faq .grid{grid-template-columns:1fr;gap:40px;}
  .loc-cards{grid-template-columns:1fr 1fr;}
  .stats .wrap{grid-template-columns:1fr 1fr;}
  .stats .stat{border-left:none;padding-left:0;border-top:1px solid rgba(255,255,255,.12);}
  nav.main .links,.topstrip .ts-left{display:none;}
  .nav-toggle{display:flex;}
  footer.site .top{grid-template-columns:1fr 1fr;}
  .about-head,.about-grid{grid-template-columns:1fr;gap:38px;}
  .about-photo .badge{width:100px;height:100px;right:14px;top:14px;}
  .about-photo .badge .big{font-size:30px;}
  .banner{display:flex;flex-direction:column;}
  .banner-media{position:relative;inset:auto;height:240px;order:-1;}
  .banner-media img{object-position:center 38%;}
  .banner-media::after{background:linear-gradient(0deg, #1A1418 0%, rgba(26,20,24,.5) 32%, rgba(26,20,24,0) 72%);}
  .banner-copy{min-height:0;max-width:none;background:var(--ink);padding:clamp(32px,7vw,48px);}
  .hero{min-height:auto;padding-top:110px;}
  .hero-inner{grid-template-columns:1fr;gap:38px;}
  .hero-copy{padding:0;}
  .hero-cards{grid-template-rows:none;grid-template-columns:1fr 1fr;}
  .hcard{min-height:210px;}
}
@media(max-width:560px){
  :root{--pad:20px;}
  .promo-trio,footer.site .top{grid-template-columns:1fr;}
  .stats .wrap{grid-template-columns:1fr 1fr;}
  .hero-cards{grid-template-columns:1fr;}
  .loc-cards{grid-template-columns:1fr;}
}

/* ============================================================ Móvil: títulos, subtítulos y párrafos de sección aprovechan todo el ancho */
@media(max-width:680px){
  /* lineas que llenan el ancho en vez de "balancearse" cortas */
  h1,h2,h3,h4{text-wrap:wrap;}
  /* sin saltos de línea forzados del diseño (pensados para desktop) */
  .h2 br,.banner-copy h2 br,.about-head h2 br,.contact-right h2 br{display:none;}
  /* el encabezado de sección ya no se limita al 60% */
  .sec-head .sh-left{max-width:none;}
  /* párrafos descriptivos usan el ancho completo en móvil */
  .sec-head .sh-note,.ah-note,.lede,.hero .sub,.rb-contact__description,.pb-sub{max-width:none;}
}
