:root{
  /* dark editorial — cream on warm near-black */
  --linen:#0F0D0B;       /* canvas */
  --sand:#0F0D0B;        /* unified — no alternation */
  --paper:#0F0D0B;       /* unified — cards differ via hairline border, not fill */
  --hair:rgba(242,237,218,.10);
  --hair-2:rgba(242,237,218,.18);
  --ink:#F2EDDA;         /* primary cream */
  --ink-soft:#D8D1BC;
  --muted:#A09A8E;
  --muted-2:#7A766C;
  --night:#0F0D0B;       /* alias for inverted blocks */

  --serif:'Bricolage Grotesque', system-ui, sans-serif;
  --sans:'DM Sans', system-ui, sans-serif;

  --sp-1:8px; --sp-2:16px; --sp-3:24px; --sp-4:32px; --sp-5:48px; --sp-6:64px; --sp-7:80px; --sp-8:96px; --sp-9:128px;

  --container:1320px;
  --gutter:48px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;width:100%;max-width:100%}
html{scroll-padding-top:80px;scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden;position:relative} /* fix scroll horizontal en iOS Safari: necesita hidden en html Y body */
body{
  font-family:var(--sans);
  background:var(--linen);
  color:var(--ink);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);width:100%;box-sizing:border-box}
.rule{height:1px;background:var(--hair);width:100%}
.rule-ink{height:1px;background:var(--ink);width:100%}

/* MICRO TYPE */
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--ink);
}
.eyebrow--muted{color:var(--muted)}
.eyebrow em{font-family:var(--serif);font-style:italic}
.num{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  color:var(--muted);
}

/* NAV */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(15,13,11,.78);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--hair);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
}
/* Brand wordmark — SVG vectorial, pixel-perfect a cualquier escala */
.mark{
  display:inline-block;
  width:120px;
  height:48px;
  background:url('assets/logos/ovrpwr-cream.svg') left center / 110px 110px no-repeat;
  text-indent:-9999px;
  overflow:hidden;
  transition:opacity .2s;
}
.mark:hover{opacity:.82}
.mark .mark-o,
.mark .mark-p,
.mark .mark-r{display:none}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);font-weight:500;
  position:relative;padding:6px 0;
}
/* Línea underline siempre presente, escala desde 0 hacia 1 al hover (origen
   izquierda). Eso da el efecto "fill left-to-right" smooth. */
.nav-links a::after{
  content:"";
  position:absolute;left:0;right:0;bottom:0;
  height:1px;background:var(--ink);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s cubic-bezier(0.22, 1, 0.36, 1);
}
.nav-links a:hover::after{
  transform:scaleX(1);
}
.nav-cta{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  padding:10px 18px;border:1px solid var(--ink);border-radius:999px;
  transition:background .2s,color .2s;
}
.nav-cta:hover{background:var(--ink);color:var(--night)}

/* SCROLL REVEALS — fade + translateY al entrar viewport */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .9s cubic-bezier(0.22, 1, 0.36, 1),
             transform .9s cubic-bezier(0.22, 1, 0.36, 1);
  will-change:opacity, transform;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
/* Stagger sutil cuando varios elementos del mismo padre se revelan juntos. */
.reveal:nth-child(2){transition-delay:.06s}
.reveal:nth-child(3){transition-delay:.12s}
.reveal:nth-child(4){transition-delay:.18s}
.reveal:nth-child(5){transition-delay:.24s}
.reveal:nth-child(6){transition-delay:.30s}

/* HERO INTRO — fade-in al cargar la página (CSS-only, GPU-aceleirado) */
@keyframes heroFadeIn{
  from{opacity:0;transform:translate3d(0,12px,0)}
  to{opacity:1;transform:translate3d(0,0,0)}
}
.hero{
  opacity:0;
  will-change:opacity,transform;
  animation:heroFadeIn 600ms cubic-bezier(0.22,1,0.36,1) 40ms forwards;
}
@media (prefers-reduced-motion: reduce){
  .hero{opacity:1;animation:none}
}

/* HERO */
.hero{
  position:relative;
  min-height:calc(100svh - 64px);
  display:flex;
  align-items:center;
  padding:28px 0 44px;
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.3fr) minmax(0, 1fr);
  gap:56px;
  align-items:center;
  width:100%;
}

.hero-left{display:flex;flex-direction:column;gap:24px;min-width:0}

.badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px 7px 10px;
  border:1px solid var(--hair-2);
  border-radius:999px;
  background:rgba(242,237,218,.04);
  backdrop-filter:blur(6px);
  font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  font-weight:500;color:var(--ink);
  align-self:flex-start;
}
.badge-dot{
  width:14px;height:14px;border-radius:4px;
  background:var(--ink);
  display:inline-block;
}

.hero-headline{
  font-family:var(--serif);
  font-weight:700;
  font-size:clamp(38px, 4.3vw, 64px);
  line-height:1.04;
  letter-spacing:-.02em;
  margin:0;color:var(--ink);
}
/* Headline setup/payoff system — light setup + heavy italic payoff */
.hl-setup{
  font-weight:300;
  color:var(--ink-soft);
}
.hero-headline .hl-setup{color:var(--muted)} /* more dramatic in hero */
.hero-headline em{
  font-style:italic;
  font-weight:700;
  color:var(--ink);
  font-size:1.08em;
  display:block;
  white-space:nowrap;
}

.hero-sub{
  font-family:var(--sans);
  font-size:clamp(15.5px, 1.25vw, 18px);
  line-height:1.6;
  color:var(--ink-soft);
  max-width:480px;
  margin:0;font-weight:400;
}
.hero-sub em{font-family:var(--serif);font-style:italic;color:var(--ink)}

.cta-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:4px}

.trust{
  display:flex;align-items:center;gap:14px;margin-top:8px;
}
.trust-avatars{display:flex}
.trust-avatars .avatar{
  width:30px;height:30px;border-radius:50%;
  border:2px solid var(--linen);
  margin-left:-9px;
  background:var(--sand);
}
.trust-avatars .avatar:first-child{margin-left:0}
.trust-avatars .a1{background:linear-gradient(135deg,#C7BFB1,#8E887F)}
.trust-avatars .a2{background:linear-gradient(135deg,#3A3530,#1A1816)}
.trust-avatars .a3{background:linear-gradient(135deg,#F1EDE7,#C7BFB1)}
.trust-avatars .a4{background:linear-gradient(135deg,#6B6660,#3A3530)}
.trust p{
  font-size:12px;line-height:1.6;margin:0;color:var(--muted);
  letter-spacing:.02em;
}
.trust p em{font-family:var(--serif);font-style:italic;color:var(--ink)}
.trust .dot{
  width:8px;height:8px;border-radius:50%;
  background:#5fd17a;
  box-shadow:0 0 0 0 rgba(95,209,122,.55);
  animation:livePulse 2s ease-out infinite;
  display:inline-block;
  vertical-align:middle;
  margin-right:6px;
  position:relative;
  top:-1px;
}
@keyframes livePulse{
  0%{box-shadow:0 0 0 0 rgba(95,209,122,.55)}
  70%{box-shadow:0 0 0 8px rgba(95,209,122,0)}
  100%{box-shadow:0 0 0 0 rgba(95,209,122,0)}
}
@media (prefers-reduced-motion: reduce){
  .trust .dot{animation:none}
}

/* HERO RIGHT — image card with feature overlay */
.hero-right{min-width:0}
.hero-card{
  position:relative;
  border-radius:28px;
  overflow:hidden;
  aspect-ratio:5/6;
  max-height:calc(100svh - 140px);
  display:flex;flex-direction:column;
  background:var(--paper);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.5);
}
.hero-card-image{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 25% 30%, rgba(242,210,150,.22), transparent 55%),
    radial-gradient(circle at 75% 85%, rgba(0,0,0,.55), transparent 65%),
    linear-gradient(135deg, #3A2A1A 0%, #1F1810 50%, #0A0705 100%);
}
.hero-card-image::after{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg, transparent 0 18px, rgba(242,237,218,.03) 18px 19px);
}
/* When a real <img> or <video> is dropped in, it fills the card edge-to-edge */
.hero-card-image img,
.hero-card-image video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center;
}
.hero-card-image:has(img),
.hero-card-image:has(video){background:#000}
.hero-card-image:has(img)::after,
.hero-card-image:has(video)::after{display:none}

/* Carousel slides — only .is-active is visible, fade between */
.hero-slide{
  position:absolute;inset:0;
  opacity:0;visibility:hidden;
  transition:opacity .6s ease;
}
.hero-slide.is-active{opacity:1;visibility:visible}
.hero-card-top{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:center;
  padding:20px;
}
.card-top-left{display:flex;align-items:center;gap:14px}
.card-num{
  display:inline-block;
  padding:7px 14px;
  background:rgba(15,13,11,.5);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  border:1px solid rgba(242,237,218,.15);
  border-radius:999px;
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:13px;color:var(--ink);
}
.card-dots{display:flex;gap:6px;align-items:center}
.cdot{
  width:14px;height:2px;border-radius:2px;
  background:rgba(242,237,218,.3);
  display:inline-block;
  transition:width .2s, background .2s;
}
.cdot.active{width:22px;background:var(--ink)}
.card-arrow{
  width:36px;height:36px;
  background:rgba(15,13,11,.5);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  border:1px solid rgba(242,237,218,.15);
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink);
  transition:background .2s,color .2s,transform .2s;
  cursor:pointer;
  padding:0;font:inherit;
}
.card-arrow:hover{background:var(--ink);color:var(--night)}
.card-arrow:active{transform:scale(.94)}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  padding:16px 24px;border-radius:999px;border:1px solid var(--ink);
  transition:background .2s,color .2s,transform .2s;
  white-space:nowrap;
}
.btn--ink{background:var(--ink);color:var(--night)}
.btn--ink:hover{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--night)}
.btn .arrow{
  width:14px;height:1px;background:currentColor;position:relative;display:inline-block;
  transition:width .2s;
}
.btn .arrow::after{
  content:"";position:absolute;right:0;top:-3px;
  border-top:1px solid currentColor;border-right:1px solid currentColor;
  width:6px;height:6px;transform:rotate(45deg);
}
.btn:hover .arrow{width:22px}

/* MARQUEE STRIP — two identical sequences, translate by exactly one sequence width for a seamless loop */
.strip{
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  overflow:hidden;
  background:var(--linen);
}
.strip-track{
  display:flex;
  width:max-content;
  animation:marquee 38s linear infinite;
  font-family:var(--serif);
  font-size:clamp(20px, 2.2vw, 32px);
  letter-spacing:-.005em;
  will-change:transform;
}
.strip-seq{
  display:flex;align-items:center;gap:64px;
  padding:22px 64px 22px 0;
  white-space:nowrap;
  flex-shrink:0;
}
.strip-seq em{font-style:italic;color:var(--ink)}
.strip-seq span{display:inline-flex;align-items:center}
.strip-seq .dot{
  width:6px;height:6px;border-radius:50%;background:var(--ink);
  display:inline-block;flex-shrink:0;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* SECTION CHROME */
section{position:relative}
.sec{padding:128px 0}
.sec--sand{background:var(--sand)}
.sec-head{
  display:grid;grid-template-columns:80px 1fr 1fr;gap:48px;
  margin-bottom:80px;align-items:start;
}
.sec-head .num{font-size:18px}
.sec-head .label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-top:6px}
.sec-head h2{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(36px,4.4vw,64px);
  line-height:1.05;
  letter-spacing:-.015em;
  margin:0;
}
.sec-head h2 em{font-style:italic;font-weight:700;color:var(--ink)}
.sec-head .lede{
  font-size:16px;line-height:1.6;color:var(--ink-soft);max-width:420px;
}
.sec-head .lede em{font-family:var(--serif);font-style:italic;color:var(--ink)}

/* VALUE PROPS */
.props{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--ink);
}
.prop{
  padding:48px 32px 56px 0;
  border-right:1px solid var(--hair);
  display:flex;flex-direction:column;gap:20px;
  min-height:380px;
}
.prop:last-child{border-right:0;padding-right:0}
.prop:not(:first-child){padding-left:32px}
.prop .ptop{display:flex;justify-content:space-between;align-items:baseline;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.prop .ptop .pnum{font-family:var(--serif);font-style:italic;font-size:14px;letter-spacing:0;color:var(--ink);text-transform:none}
.prop h3{
  font-family:var(--serif);font-weight:600;font-size:clamp(28px, 3vw, 42px);line-height:1.02;letter-spacing:-.01em;margin:0;
}
.prop h3 em{font-style:italic}
.prop p{font-size:15px;line-height:1.6;color:var(--ink-soft);margin:0;max-width:32ch}
.prop .pglyph{
  margin-top:auto;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
}

/* PORTFOLIO */
.gallery{
  display:grid;grid-template-columns:repeat(12,1fr);
  gap:24px;
}
.frame{
  position:relative;
  background:var(--linen);
  overflow:hidden;
}
.frame::after{
  content:"";position:absolute;inset:0;border:1px solid rgba(242,237,218,.08);pointer-events:none;
}
.f-tall{grid-column:span 5;aspect-ratio:4/5}
.f-wide{grid-column:span 7;aspect-ratio:7/5}
.f-sq{grid-column:span 4;aspect-ratio:1/1}
.f-pano{grid-column:span 8;aspect-ratio:8/5}
.f-half{grid-column:span 6;aspect-ratio:6/5}
.f-mid{grid-column:span 6;aspect-ratio:6/5}
.f-wine{grid-column:span 6;aspect-ratio:4/5}
/* Browser-chrome wrapper: hace que el iframe se vea como una preview de monitor */
.browser-frame{
  grid-column:1 / -1;
  background:#1a1714;
  border:1px solid rgba(242,237,218,.08);
  border-radius:14px;
  padding:0;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(0,0,0,.4);
}
.browser-chrome{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;
  background:#0F0D0B;
  border-bottom:1px solid rgba(242,237,218,.06);
}
.browser-dots{display:flex;gap:7px}
.browser-dots span{
  width:11px;height:11px;border-radius:50%;
  background:rgba(242,237,218,.18);
}
.browser-dots span:nth-child(1){background:#ff5f57}
.browser-dots span:nth-child(2){background:#febc2e}
.browser-dots span:nth-child(3){background:#28c840}
.browser-url{
  flex:1;
  background:rgba(242,237,218,.06);
  border-radius:6px;
  padding:6px 14px;
  font-size:12px;color:rgba(242,237,218,.55);
  letter-spacing:.04em;
  text-align:center;
  font-family:var(--sans);
}
.f-website{
  position:relative;
  aspect-ratio:16/9;
  background:#000;
  overflow:hidden;
}
.website-iframe{
  position:absolute;
  top:0;left:0;
  width:1920px;
  height:1084px; /* +4px buffer absorbs subpixel rounding when scaled */
  border:0;
  display:block;
  pointer-events:none;
  transform-origin:top left;
  transform:scale(1);
}
/* Preview estático en mobile (PNG HD del desktop, escala perfecto en cualquier
   pantalla). Desktop conserva el iframe live con motion. */
.website-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:none;
  pointer-events:none;
}
@media (max-width: 768px){
  .website-iframe{ display:none; }
  .website-img{ display:block; }
}
.frame-meta{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-top:14px;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500;
}
.frame-meta .ftitle{color:var(--ink);font-family:var(--serif);font-style:italic;font-size:18px;letter-spacing:0;text-transform:none;font-weight:400}
.frame-wrap{display:flex;flex-direction:column}

.slot{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:
    repeating-linear-gradient(45deg, transparent 0 14px, rgba(242,237,218,.025) 14px 15px);
  position:relative;
}
.slot::after{
  content:attr(data-caption);
  font-family:var(--serif);font-style:italic;font-size:14px;
  color:var(--muted);
  letter-spacing:.01em;
  padding:0 24px;text-align:center;
}
.slot img,
.slot video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.slot:has(img)::after,
.slot:has(video)::after{display:none}

/* Tile overlay chip — surfaces a key stat directly on the proof piece */
.frame-stat{
  position:absolute;left:14px;bottom:14px;z-index:3;
  font-family:var(--sans);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  padding:8px 14px;border-radius:999px;
  background:rgba(15,13,11,.55);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(242,237,218,.16);
  color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;
  pointer-events:none;
}
.frame-stat em{
  font-family:var(--serif);font-style:italic;font-weight:700;
  font-size:15px;letter-spacing:-.01em;
  text-transform:none;
  color:var(--ink);
}

/* WEB STACK — dedicated section for website redesigns */
.web-stack{
  display:flex;flex-direction:column;
  gap:48px;
}
.web-item{display:flex;flex-direction:column}
.web-item .frame{
  position:relative;
  aspect-ratio:16/9;
  background:#000;
  overflow:hidden;
  border-radius:0;
}

/* COMPARISON SLIDER — before/after, accepts <img> or <video> on either side */
.compare{
  position:absolute;inset:0;
  overflow:hidden;
  cursor:ew-resize;
  user-select:none;
  touch-action:none;
  --cmp:50%;
}
.cmp-media{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
  pointer-events:none;
}
.cmp-after{z-index:1}

/* (removido) — el comparador antes/después fue reemplazado por el showcase
   directo del Nativa con iframe. Ver .f-website + .website-iframe arriba. */
.cmp-before{
  z-index:2;
  clip-path:inset(0 calc(100% - var(--cmp)) 0 0);
}
/* Back-compat alias if any tile still uses .cmp-img */
.cmp-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
}
.cmp-handle{
  position:absolute;top:0;bottom:0;
  left:var(--cmp);
  width:2px;
  background:var(--ink);
  transform:translateX(-50%);
  z-index:3;
  pointer-events:none;
}
.cmp-handle-line{
  position:absolute;inset:0;
  background:var(--ink);
  box-shadow:0 0 24px rgba(0,0,0,.4);
}
.cmp-handle-dot{
  position:absolute;top:50%;left:50%;
  width:44px;height:44px;border-radius:50%;
  background:var(--ink);
  transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 40px rgba(0,0,0,.5);
}
.cmp-handle-dot::before,
.cmp-handle-dot::after{
  content:"";
  position:absolute;top:50%;
  width:0;height:0;
  border-top:5px solid transparent;
  border-bottom:5px solid transparent;
  transform:translateY(-50%);
}
.cmp-handle-dot::before{
  left:11px;
  border-right:6px solid var(--night);
}
.cmp-handle-dot::after{
  right:11px;
  border-left:6px solid var(--night);
}
.cmp-tag{
  position:absolute;top:50%;
  transform:translateY(-50%);
  font-family:var(--sans);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  padding:6px 12px;border-radius:999px;
  background:rgba(15,13,11,.55);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  border:1px solid rgba(242,237,218,.18);
  color:var(--ink);
  z-index:4;
  pointer-events:none;
}
.cmp-tag-before{left:18px}
.cmp-tag-after{right:18px}

/* PROCESS */
.process-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--ink);
}
.step{
  padding:56px 40px 80px 0;
  border-right:1px solid var(--hair);
  position:relative;
}
.step:last-child{border-right:0}
.step:not(:first-child){padding-left:40px}
.step .stepnum{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:clamp(56px, 7.5vw, 96px);line-height:1;color:var(--muted);
  letter-spacing:-.02em;
  margin-bottom:clamp(20px, 2.5vw, 32px);display:block;
}
.step h4{
  font-family:var(--serif);font-weight:600;font-size:clamp(24px, 2.6vw, 32px);line-height:1.05;letter-spacing:-.01em;margin:0 0 16px;
}
.step h4 em{font-style:italic}
.step p{font-size:15px;color:var(--ink-soft);line-height:1.6;margin:0;max-width:34ch}
.step .stepfoot{
  margin-top:32px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:500;
}

/* PRICING */
.pricing{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.tier{
  background:var(--paper);
  border:1px solid var(--hair);
  padding:40px 36px 36px;
  display:flex;flex-direction:column;gap:24px;
  min-height:560px;
}
.tier--feature{
  background:var(--ink);
  color:var(--night);
  border-color:var(--ink);
  transform:translateY(-16px);
}
.tier-head{display:flex;justify-content:space-between;align-items:baseline;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.tier--feature .tier-head{color:rgba(15,13,11,.65)}
.tier-head .badge{
  font-family:var(--serif);font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;color:var(--ink-soft);font-weight:400;
  border:0;background:transparent;padding:0;
}
.tier--feature .tier-head .badge{color:var(--night)}
.tier h3{
  font-family:var(--serif);font-weight:600;font-size:clamp(34px, 4vw, 48px);line-height:1;letter-spacing:-.015em;margin:0;
}
.tier h3 em{font-style:italic}
.tier .price{
  font-family:var(--sans);font-weight:500;font-size:15px;line-height:1.4;letter-spacing:.02em;
  color:var(--muted);text-transform:uppercase;
  padding-bottom:4px;
}
.tier .price em{
  font-family:var(--serif);font-style:italic;font-weight:600;
  color:var(--ink);text-transform:none;
  font-size:1.05em;letter-spacing:-.01em;
}
.tier--feature .price{color:rgba(15,13,11,.6)}
.tier--feature .price em{color:var(--night)}
.tier .desc{font-size:14px;line-height:1.6;color:var(--ink-soft);margin:0}
.tier--feature .desc{color:rgba(15,13,11,.75)}
.tier ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--hair);padding-top:24px}
.tier--feature ul{border-top-color:rgba(15,13,11,.2)}
.tier li{
  font-size:14px;line-height:1.5;color:var(--ink-soft);
  padding-left:22px;position:relative;
}
.tier--feature li{color:rgba(15,13,11,.85)}
.tier li::before{
  content:"";position:absolute;left:0;top:.65em;width:10px;height:1px;background:var(--ink);
}
.tier--feature li::before{background:var(--night)}
.tier .tier-cta{
  margin-top:auto;
  display:inline-flex;align-items:center;justify-content:space-between;
  padding:16px 22px;border:1px solid var(--ink);border-radius:999px;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  transition:background .2s,color .2s;
}
.tier .tier-cta:hover{background:var(--ink);color:var(--night)}
.tier--feature .tier-cta{
  border-color:var(--night);background:var(--night);color:var(--ink);
}
.tier--feature .tier-cta:hover{background:transparent;color:var(--night)}

/* FAQ */
.faq{display:flex;flex-direction:column;border-top:1px solid var(--ink)}
.qa{
  border-bottom:1px solid var(--hair);
  padding:28px 0;
  display:grid;grid-template-columns:60px 1fr 40px;gap:32px;align-items:start;
  cursor:pointer;
}
.qa:focus-visible{outline:1px solid var(--ink);outline-offset:4px}
.qa .qn{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:18px;padding-top:4px}
.qa .qq{
  font-family:var(--serif);font-weight:600;font-size:28px;line-height:1.2;letter-spacing:-.005em;margin:0;
}
.qa .qq em{font-style:italic}
.qa .qa-toggle{
  width:32px;height:32px;border:1px solid var(--ink);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  align-self:start;margin-top:4px;
  transition:background .2s,color .2s,transform .3s;
}
.qa .qa-toggle::before{content:"+";font-family:var(--serif);font-size:20px;line-height:1;font-weight:400}
.qa[open] .qa-toggle{background:var(--ink);color:var(--night);transform:rotate(45deg)}
.qa-answer{
  font-size:15px;line-height:1.65;color:var(--ink-soft);
  max-width:60ch;margin-top:12px;display:none;
}
.qa-answer em{font-family:var(--serif);font-style:italic;color:var(--ink)}
.qa[open] .qa-answer{display:block}

/* BIG CTA */
.bigcta{
  padding:clamp(80px, 12vw, 160px) 0;
  text-align:center;
  background:var(--linen);
  border-top:1px solid var(--hair);
}
.bigcta .eyebrow{margin-bottom:32px;display:block}
.bigcta h2{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(40px,8.5vw,128px);
  line-height:.98;letter-spacing:-.02em;
  margin:0 0 40px;
  word-break:break-word;
  hyphens:auto;
}
.bigcta h2 em{font-style:italic;font-weight:700;color:var(--ink)}

/* FOOTER — cream block (single inversion against dark canvas) */
footer{background:var(--ink);color:var(--night);padding:72px 0 28px}
.foot-inner{display:flex;flex-direction:column;gap:56px}

.foot-top{
  display:grid;grid-template-columns:1.1fr 1.4fr;gap:64px;
  align-items:start;
}

.foot-brand{display:flex;flex-direction:column;gap:20px}
.foot-mark{
  display:inline-block;
  align-self:flex-start;
  width:120px;
  height:48px;
  background:url('assets/logos/ovrpwr-cream.svg') left center / 110px 110px no-repeat;
  filter:invert(1);
  text-indent:-9999px;
  overflow:hidden;
  transition:opacity .2s;
}
.foot-mark:hover{opacity:.82}

.foot-tag{
  font-family:var(--serif);
  font-size:clamp(15px, 1.2vw, 18px);
  color:rgba(15,13,11,.72);
  margin:0;max-width:34ch;line-height:1.5;
  font-weight:400;
}
.foot-tag em{font-family:var(--serif);font-style:italic;color:var(--night);font-weight:600}

.foot-cols{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
}
.foot-col h5{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  color:rgba(15,13,11,.45);margin:0 0 18px;
  padding-bottom:14px;border-bottom:1px solid rgba(15,13,11,.12);
}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot-col li{font-size:14px;line-height:1.4}
.foot-col a,
.foot-col li > span{
  color:var(--night);opacity:.78;
  transition:opacity .2s;
  font-size:14px;
}
.foot-col a:hover{opacity:1;text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px}

.foot-bot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:28px;border-top:1px solid rgba(15,13,11,.14);
  font-size:12px;color:rgba(15,13,11,.55);letter-spacing:.02em;
  gap:24px;
}
.foot-bot em{font-family:var(--serif);font-style:italic;color:var(--night);font-weight:500}

/* TABLET — compact 2-col hero */
@media (max-width:1180px){
  .hero-grid{gap:40px}
}

/* MOBILE */
@media (max-width:920px){
  :root{--gutter:24px}
  .nav-links{display:none}
  .hero{min-height:auto;padding:24px 0 24px}
  .hero-grid{grid-template-columns:1fr;gap:18px}
  .hero-left{display:contents}
  .badge{display:none}
  /* Orden mobile: headline → sub → CTAs → card. Trust line oculto para liberar
     espacio vertical y que la marquee de servicios quede above-the-fold. */
  .hero-headline{order:2}
  .hero-sub{order:3}
  .cta-row{order:4;margin-top:8px}
  .hero-right{order:5}
  .trust{display:none}
  .hero-card{aspect-ratio:4/3;max-height:none}
  .hero-headline{font-size:clamp(30px,7.2vw,44px);line-height:1.05}
  .hero-sub{font-size:15px}
  .cta-row{flex-direction:column;align-items:stretch}
  .cta-row .btn{width:100%;text-align:center;justify-content:center}
  .hide-mobile{display:none !important}
  .sec{padding:80px 0}
  .sec-head{grid-template-columns:1fr;gap:24px;margin-bottom:48px}
  .props,.process-grid{grid-template-columns:1fr;border-top:1px solid var(--ink)}
  .prop,.step{border-right:0;border-bottom:1px solid var(--hair);padding:40px 0 !important;min-height:auto}
  .prop:last-child,.step:last-child{border-bottom:0}
  .gallery{grid-template-columns:1fr}
  .f-wide,.f-sq,.f-pano,.f-half,.f-mid{grid-column:span 1;aspect-ratio:4/3}
  /* f-tall mantiene aspect vertical en mobile porque el video de Strongest es un reel vertical */
  .f-tall{grid-column:span 1;aspect-ratio:9/16}
  .f-compare{grid-column:span 1;aspect-ratio:auto}
  .monitor-bezel{padding:8px 8px 12px 8px;border-radius:10px}
  .monitor-stand{height:18px;width:24%}
  .monitor-base{height:5px;width:38%}
  .frame-wrap{grid-column:span 1 !important}
  .web-stack{gap:32px}
  .web-item .frame{aspect-ratio:16/9} /* match PNG: 1920x1080, evita crop lateral */
  /* Labels de portfolio: stack vertical consistente en mobile */
  .frame-meta{
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
  }
  .frame-meta .ftitle{font-size:16px;line-height:1.3}
  .frame-meta > span:not(.ftitle){font-size:11px}
  .cmp-handle-dot{width:38px;height:38px}
  .cmp-tag{font-size:10px;padding:5px 10px}
  .cmp-tag-before{left:12px}
  .cmp-tag-after{right:12px}
  .frame-stat{font-size:10px;padding:6px 12px;left:10px;bottom:10px}
  .frame-stat em{font-size:13px}
  .pricing{grid-template-columns:1fr}
  .tier--feature{transform:none}
  .qa{grid-template-columns:40px 1fr 32px;gap:16px}
  .qa .qq{font-size:20px}
  footer{padding:40px 0 20px}
  .foot-inner{gap:28px}
  .foot-top{grid-template-columns:1fr;gap:28px}
  .foot-brand{gap:14px}
  .foot-mark{width:96px;height:38px;background-size:88px 88px}
  .foot-tag{font-size:14px;line-height:1.5}
  .foot-cols{grid-template-columns:1fr 1fr;gap:24px 18px}
  .foot-col h5{font-size:11px;padding-bottom:8px;margin-bottom:10px;letter-spacing:.18em}
  .foot-col ul{gap:7px}
  .foot-col li,.foot-col a,.foot-col li > span{font-size:13px}
  .foot-bot{flex-direction:column;gap:6px;align-items:flex-start;padding-top:18px;font-size:11px}
  .strip-seq{gap:32px;padding:18px 32px 18px 0}
}
