/* ============================================================
   KING CADEIRAS · MAGAZINE LUXURY EDITION
   Paleta: pergaminho / oxblood / bronze
   ============================================================ */

:root{
  /* Pergaminho base */
  --paper:        #F2EBDD;   /* fundo principal */
  --paper-2:      #E8DEC8;   /* alternativo, mais escuro */
  --paper-3:      #DCD0B6;
  --paper-edge:   #C9BC9C;

  /* Tinta */
  --ink:          #1F1A14;   /* preto-tinta, não puro */
  --ink-soft:     #3B3128;
  --ink-mute:     #6E5C46;

  /* Oxblood / vermelho-couro */
  --oxblood:      #5B1A1A;
  --oxblood-2:    #3E1419;
  --oxblood-soft: #7A2C2C;

  /* Bronze / ouro velho */
  --bronze:       #8B6F47;
  --bronze-2:     #6E5736;
  --bronze-light: #B0916B;
  --bronze-glow:  #C9A87A;

  /* Verde inglês (acento secundário) */
  --green:        #2E3A2C;
  --green-2:      #20281F;

  /* Linhas / blueprint */
  --line:         rgba(31,26,20,.18);
  --line-strong:  rgba(31,26,20,.42);

  --rad: 4px;
  --rad-lg: 10px;

  --container: 1280px;
  --pad: clamp(20px, 4vw, 56px);

  --f-serif: 'Fraunces', 'Playfair Display', Georgia, serif;
  --f-sans:  'Inter', system-ui, sans-serif;
  --f-mono:  'JetBrains Mono', ui-monospace, monospace;

  --t-base: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  background: var(--paper);
  color: var(--ink);
  font-family: var(--f-sans);
  font-size: 16px;
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;

  /* leve grain de papel */
  background-image:
    radial-gradient(circle at 12% 18%, rgba(139,111,71,.06), transparent 40%),
    radial-gradient(circle at 88% 78%, rgba(91,26,26,.05), transparent 45%);
}

/* texturizado de papel via SVG inline */
body::before{
  content:"";
  position: fixed; inset:0;
  pointer-events: none;
  z-index: 1;
  opacity: .35;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .35   0 0 0 0 .27   0 0 0 0 .15   0 0 0 .12 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

img{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}
a{color:inherit;text-decoration:none}

.container{max-width: var(--container); margin: 0 auto; padding: 0 var(--pad); position:relative; z-index:2}

/* ========== TYPOGRAPHY SYSTEM ========== */

.h-display{
  font-family: var(--f-serif);
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.025em;
  line-height: 0.92;
  font-size: clamp(56px, 9vw, 132px);
  font-variation-settings: "opsz" 144;
  color: var(--ink);
}
.h-display em{font-style: italic; font-weight: 500; color: var(--oxblood)}

.h-section{
  font-family: var(--f-serif);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  font-size: clamp(40px, 5.6vw, 80px);
  font-variation-settings: "opsz" 100;
}
.h-section em{font-style: italic; color: var(--oxblood)}

.eyebrow{
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: inline-flex; align-items:center; gap: 10px;
}
.eyebrow::before{
  content:""; width: 28px; height: 1px;
  background: var(--ink-mute);
}

.lede{
  font-family: var(--f-serif);
  font-size: clamp(17px, 1.4vw, 21px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 56ch;
  font-weight: 400;
}

.section-num{
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 96px;
  line-height: 1;
  color: var(--bronze);
  opacity: .9;
}

/* ========== UTIL: SCROLL PROGRESS / CURSOR / LOADER ========== */

.scroll-progress{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: rgba(31,26,20,.08);
  z-index: 100;
}
.scroll-progress span{
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--bronze), var(--oxblood));
  width: 0%;
  transition: width .12s linear;
}

.cursor{
  position: fixed; top:0;left:0;
  width: 14px; height: 14px;
  border: 1.5px solid var(--ink);
  border-radius: 50%;
  transform: translate(-50%,-50%);
  pointer-events: none;
  mix-blend-mode: multiply;
  z-index: 999;
  transition: transform .12s var(--t-base), border-color .15s, background .15s;
}
.cursor.hover{
  transform: translate(-50%,-50%) scale(2.2);
  background: var(--oxblood);
  border-color: var(--oxblood);
}
@media (max-width: 900px){ .cursor{display:none} }

/* Loader */
.loader{
  position: fixed; inset:0;
  background: var(--paper);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column;
  gap: 22px;
  transition: opacity .8s var(--t-base);
}
.loader.hidden{ opacity: 0; pointer-events:none }
.loader-mark{ position: relative; width: 200px; height: 200px; display:flex; align-items:center; justify-content:center}
.loader-mark img{ width: 110px; height: 110px; object-fit: contain }
.loader-mark svg{ position: absolute; inset:0; width: 100%; height:100%; }
.loader-mark .lp{
  fill: none; stroke: var(--ink); stroke-width: 1;
  stroke-dasharray: 700;
  stroke-dashoffset: 700;
  animation: lpDraw 1.4s var(--t-base) forwards;
}
.loader-mark .h2{ stroke-dasharray: 30; stroke-dashoffset:30 }
@keyframes lpDraw{ to{ stroke-dashoffset: 0 } }
.loader-label{
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: .3em; color: var(--ink-mute);
  position: absolute; bottom: -36px; left: 0; right: 0; text-align:center;
}

/* ========== HEADER ========== */
.site-header{
  position: sticky; top: 0;
  z-index: 50;
  background: rgba(242,235,221,.86);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.header-inner{
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 0;
}
.brand{ display: flex; align-items:center; gap: 12px }
.brand img{ width: 44px; height: 44px; object-fit: contain }
.brand-text{ display:flex; flex-direction: column; line-height: 1 }
.brand-text strong{
  font-family: var(--f-serif);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.brand-text span{
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .24em;
  color: var(--ink-mute);
  margin-top: 4px;
}

.nav-main{ display: flex; gap: 28px; align-items:center }
.nav-main a{
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  position: relative;
  padding: 6px 0;
  transition: color .2s;
}
.nav-main a::after{
  content:""; position: absolute; left:0; bottom:0;
  width: 0; height: 1px; background: var(--oxblood);
  transition: width .25s var(--t-base);
}
.nav-main a:hover{ color: var(--oxblood) }
.nav-main a:hover::after{ width: 100% }

.header-cta{
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--paper);
  padding: 11px 18px;
  border-radius: 999px;
  transition: background .2s;
  cursor: pointer;
}
.header-cta:hover{ background: var(--oxblood) }

.menu-toggle{ display:none }

/* mobile drawer */
.mobile-overlay{
  position: fixed; inset:0;
  background: rgba(31,26,20,.5);
  opacity: 0; pointer-events: none;
  transition: opacity .25s; z-index: 60;
}
.mobile-overlay.open{ opacity: 1; pointer-events: auto }
.mobile-drawer{
  position: fixed; top:0; right:0; bottom:0; width: min(320px, 84%);
  background: var(--paper);
  transform: translateX(100%);
  transition: transform .35s var(--t-base);
  z-index: 70;
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 14px;
  border-left: 1px solid var(--line);
}
.mobile-drawer.open{ transform: translateX(0) }
.mobile-close{ align-self: flex-end; font-size: 28px; line-height: 1; padding: 6px 10px; color: var(--ink); margin-bottom: 8px }
.mobile-drawer a{
  font-family: var(--f-serif);
  font-size: 28px;
  letter-spacing: -.01em;
  padding: 6px 0;
}
.mobile-drawer a.btn{ font-family: var(--f-mono); font-size: 12px; margin-top: 12px }

/* ========== BUTTONS ========== */
.btn{
  display: inline-flex; align-items:center; justify-content:center; gap: 12px;
  padding: 16px 26px;
  border-radius: 999px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .25s var(--t-base);
  white-space: nowrap;
}
.btn .arrow{
  display: inline-block;
  transition: transform .25s var(--t-base);
}
.btn:hover .arrow{ transform: translateX(4px) }

.btn-primary{
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
}
.btn-primary:hover{
  background: var(--oxblood);
  border-color: var(--oxblood);
}
.btn-ghost{
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
}
.btn-ghost:hover{ background: var(--ink); color: var(--paper) }

/* ========== HERO ========== */
.hero{
  position: relative;
  padding: clamp(40px, 6vw, 80px) 0 clamp(60px, 9vw, 120px);
  overflow: hidden;
}
.hero-grid-bg{
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: .55;
  mask-image: radial-gradient(circle at 50% 50%, black 30%, transparent 80%);
  z-index: 0;
}

.hero-inner{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(24px, 4vw, 64px);
  align-items: end;
  min-height: 70vh;
  position: relative;
  z-index: 2;
}

.hero-h1{
  margin: 26px 0 18px;
}
.hero-h1 .line{
  display: block; overflow: hidden;
}
.hero-h1 .line span{
  display: inline-block;
  transform: translateY(110%);
  animation: lineUp 1s var(--t-base) forwards;
}
.hero-h1 .line:nth-child(2) span{ animation-delay: .12s }
.hero-h1 .line:nth-child(3) span{ animation-delay: .24s }
@keyframes lineUp{ to{ transform: translateY(0) } }

.hero-meta{
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: .26em; text-transform: uppercase;
  color: var(--ink-mute);
  display: inline-flex; align-items:center; gap: 12px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
  margin: 12px 0 28px;
  width: fit-content;
}
.hero-lede{
  font-family: var(--f-serif);
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 48ch;
  margin: 0 0 36px;
}
.hero-ctas{ display: flex; flex-wrap: wrap; gap: 14px }

/* lion stage (blueprint area) */
.hero-right{ position: relative }
.lion-stage{
  position: relative;
  aspect-ratio: 4/5;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  border: 1px solid var(--line-strong);
  background:
    repeating-linear-gradient(0deg, transparent 0 39px, var(--line) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, var(--line) 39px 40px),
    var(--paper);
}
.bp-handle{
  position: absolute;
  width: 8px; height: 8px;
  border: 1px solid var(--ink);
  background: var(--paper);
}
.bp-handle.tl{ top:-4px; left:-4px } .bp-handle.tr{ top:-4px; right:-4px }
.bp-handle.bl{ bottom:-4px; left:-4px } .bp-handle.br{ bottom:-4px; right:-4px }

.lion-figure{
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.lion-photo,
.lion-video,
.lion-fallback{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  filter:
    sepia(.55)
    saturate(.65)
    hue-rotate(-15deg)
    contrast(1.2)
    brightness(.92);
  mix-blend-mode: multiply;
  opacity: 0;
  transform: scale(.95);
  animation:
    lionEntry 1.2s cubic-bezier(.22,.61,.36,1) .4s forwards,
    lionBreath 4s ease-in-out 1.6s infinite;
}
@keyframes lionEntry{
  to{ opacity: 1; transform: scale(1) }
}
@keyframes lionBreath{
  0%,100%{ transform: scale(1) }
  50%{ transform: scale(1.015) }
}
.lion-stage::after{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center, transparent 50%, rgba(31,26,20,.28) 100%),
    linear-gradient(180deg, rgba(176,145,107,.06), rgba(91,26,26,.05));
  mix-blend-mode: multiply;
  z-index: 2;
}

/* blueprint annotations */
.bp-annot{
  position: absolute;
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  display: flex; flex-direction: column; gap: 2px;
  background: var(--paper);
  padding: 6px 9px;
  border: 1px solid var(--ink);
  pointer-events: none;
}
.bp-annot::before{
  content:""; position: absolute;
  background: var(--ink);
}
.bp-annot .lbl{ color: var(--ink); font-weight: 500 }
.bp-annot .val{ color: var(--ink-mute); letter-spacing: .12em; text-transform: none; font-size: 10px }
.bp-annot.t1{ top: 8%; left: -10%; }
.bp-annot.t1::before{ width: 60px; height: 1px; right: -60px; top: 50%; }
.bp-annot.t2{ top: 28%; right: -8%; }
.bp-annot.t2::before{ width: 50px; height: 1px; left: -50px; top: 50%; }
.bp-annot.t3{ bottom: 24%; left: -6%; }
.bp-annot.t3::before{ width: 50px; height: 1px; right: -50px; top: 50%; }
.bp-annot.t4{ bottom: 6%; right: 4%; }

@media (max-width: 700px){
  .bp-annot{ display: none }
  .bp-annot.t3, .bp-annot.t4{ display: flex; left:auto; right:auto; bottom:auto; top:auto; position: static; margin: 6px auto 0 }
}

.hero-scroll{
  position: absolute;
  bottom: 24px;
  left: var(--pad);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--ink-mute);
  display: flex; align-items: center; gap: 8px;
  z-index: 3;
}
.hero-scroll i{
  display: block;
  width: 1px; height: 32px;
  background: linear-gradient(180deg, var(--ink-mute), transparent);
  animation: scrollPulse 1.6s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%{ transform: scaleY(0); transform-origin: top }
  50%{ transform: scaleY(1); transform-origin: top }
  51%{ transform: scaleY(1); transform-origin: bottom }
  100%{ transform: scaleY(0); transform-origin: bottom }
}

/* ========== MARQUEE ========== */
.marquee{
  background: var(--ink);
  color: var(--paper);
  padding: 18px 0;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  overflow: hidden;
  position: relative;
  z-index: 2;
}
.marquee-track{
  display: flex; gap: 0;
  animation: marqueeRun 40s linear infinite;
  white-space: nowrap;
}
.marquee-track span{
  font-family: var(--f-serif);
  font-style: italic;
  font-size: clamp(20px, 2.4vw, 30px);
  padding: 0 28px;
  display: inline-flex; align-items: center;
  letter-spacing: -.01em;
}
.marquee-track span::before{
  content:"✦"; margin-right: 28px;
  color: var(--bronze-glow);
  font-style: normal;
}
@keyframes marqueeRun{
  0%{ transform: translateX(0) }
  100%{ transform: translateX(-50%) }
}

/* ========== SECTIONS BASE ========== */
.sct{
  padding: clamp(80px, 11vw, 160px) 0;
  position: relative;
  z-index: 2;
}
.sct--bg2{ background: var(--paper-2) }
.sct--green{
  background: var(--green);
  color: var(--paper);
}
.sct--green .eyebrow{ color: rgba(242,235,221,.6) }
.sct--green .eyebrow::before{ background: rgba(242,235,221,.6) }
.sct--green .lede{ color: rgba(242,235,221,.78) }
.sct--green .h-section em{ color: var(--bronze-glow) }

.sct-head{
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(24px, 5vw, 80px);
  align-items: end;
  margin-bottom: clamp(48px, 7vw, 80px);
}

/* ornamentação */
.section-divider{
  display: flex; align-items: center; gap: 16px;
  padding: 60px 0 0;
}
.section-divider .rl{
  flex: 1; height: 1px;
  background: var(--line-strong);
  position: relative;
}
.section-divider .rl::after{
  content:""; position: absolute; left:0; right:0; top:3px;
  height: 1px; background: var(--line-strong);
}
.section-divider .vg{
  font-family: var(--f-serif);
  font-style: italic;
  color: var(--bronze);
  font-size: 18px;
}

/* ========== MANIFESTO ========== */
.manifesto{
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: clamp(24px, 5vw, 80px);
  padding: clamp(40px, 6vw, 80px) 0 0;
}
.manifesto-quote{
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(24px, 3.2vw, 44px);
  line-height: 1.2;
  letter-spacing: -.01em;
  color: var(--ink);
  max-width: 30ch;
  margin: 0 0 36px;
}
.manifesto-quote em{ color: var(--oxblood) }

.manifesto-cols{
  column-count: 2;
  column-gap: 48px;
  font-family: var(--f-serif);
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-soft);
}
.manifesto-cols p{ margin: 0 0 16px; break-inside: avoid }
.manifesto-cols p:first-child::first-letter{
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 5em;
  line-height: .85;
  float: left;
  padding: 6px 12px 0 0;
  color: var(--oxblood);
  font-weight: 500;
}

@media (max-width: 800px){
  .manifesto{ grid-template-columns: 1fr }
  .manifesto-cols{ column-count: 1 }
  .sct-head{ grid-template-columns: 1fr; gap: 24px }
}

/* ========== VITRINE / PRODUCTS ========== */
.filters{
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 40px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 14px 0;
}
.chip{
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 9px 18px;
  border-radius: 999px;
  border: 1px solid transparent;
  color: var(--ink-soft);
  transition: all .2s;
}
.chip:hover{ color: var(--oxblood); border-color: var(--line-strong) }
.chip.active{
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.vitrine{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px 28px;
}
@media (max-width: 1000px){ .vitrine{ grid-template-columns: repeat(2, 1fr) } }
@media (max-width: 600px){ .vitrine{ grid-template-columns: 1fr } }

.product{
  display: flex; flex-direction: column;
  cursor: pointer;
  transition: transform .35s var(--t-base);
}
.product:hover{ transform: translateY(-4px) }

.product-img{
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--paper-3);
  border: 1px solid var(--line);
  margin-bottom: 18px;
}
.product-img img{
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s var(--t-base);
  filter: saturate(.95);
}
.product:hover .product-img img{ transform: scale(1.04) }

.product-tag{
  position: absolute;
  top: 14px; left: 14px;
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: 6px 10px;
  color: var(--ink);
}
.product-tag.gold{
  background: var(--bronze);
  border-color: var(--bronze);
  color: var(--paper);
}

.product-meta{
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
.product-cat{
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.product-price{
  font-family: var(--f-mono);
  font-size: 12px;
  color: var(--oxblood);
  letter-spacing: .04em;
}
.product-name{
  font-family: var(--f-serif);
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -.01em;
  margin: 0 0 10px;
  font-weight: 500;
}
.product-name em{ font-style: italic; color: var(--oxblood) }
.product-desc{
  font-size: 13.5px;
  color: var(--ink-mute);
  line-height: 1.5;
  margin: 0;
  max-width: 36ch;
}
.product-foot{
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid var(--line);
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.product-foot .arrow{
  transition: transform .25s var(--t-base);
}
.product:hover .product-foot .arrow{ transform: translateX(4px); color: var(--oxblood) }

/* ========== ENGENHARIA / TECH ========== */
.tech-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 1000px){ .tech-grid{ grid-template-columns: repeat(2, 1fr) } }
@media (max-width: 600px){ .tech-grid{ grid-template-columns: 1fr } }

.tech-card{
  border: 1px solid rgba(242,235,221,.18);
  padding: 36px 26px 30px;
  background: var(--green-2);
  position: relative;
  display: flex; flex-direction: column; gap: 18px;
  transition: border-color .3s, transform .3s var(--t-base);
}
.tech-card:hover{ border-color: var(--bronze-glow); transform: translateY(-4px) }
.tech-card .num{
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--bronze-glow);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 500;
}
.tech-card .metric{
  font-family: var(--f-serif);
  font-size: clamp(60px, 6.5vw, 96px);
  line-height: .9;
  font-weight: 500;
  letter-spacing: -.03em;
  color: var(--paper);
}
.tech-card .metric small{
  font-size: .35em;
  font-style: italic;
  color: var(--bronze-glow);
  letter-spacing: 0;
  margin-left: 4px;
  vertical-align: top;
  font-weight: 400;
}
.tech-card .ttl{
  font-family: var(--f-serif);
  font-size: 22px;
  line-height: 1.15;
  margin: 0;
  font-weight: 500;
}
.tech-card .desc{
  font-size: 14px;
  color: rgba(242,235,221,.7);
  margin: 0;
  line-height: 1.55;
}

/* ========== COMPARADOR ========== */
.compare{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line-strong);
  border: 1px solid var(--line-strong);
}
.cmp{
  background: var(--paper);
  padding: clamp(28px, 3.5vw, 48px) clamp(20px, 2.5vw, 32px);
  display: flex; flex-direction: column; gap: 18px;
  position: relative;
  transition: background .25s;
}
.cmp:hover{ background: var(--paper-2) }
.cmp.featured{
  background: var(--ink);
  color: var(--paper);
}
.cmp.featured:hover{ background: var(--oxblood-2) }
.cmp.featured .cmp-tag{
  background: var(--bronze-glow);
  color: var(--ink);
}

.cmp-tag{
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .24em;
  text-transform: uppercase;
  align-self: flex-start;
  padding: 5px 10px;
  background: var(--paper-3);
  color: var(--ink);
}
.cmp-name{
  font-family: var(--f-serif);
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.05;
  margin: 0;
  font-weight: 500;
  letter-spacing: -.01em;
}
.cmp-name em{ font-style: italic; color: var(--oxblood) }
.cmp.featured .cmp-name em{ color: var(--bronze-glow) }
.cmp-price{
  font-family: var(--f-serif);
  font-size: 22px;
  letter-spacing: -.01em;
}
.cmp-price small{ font-size: 12px; color: var(--ink-mute); display:block; margin-top:4px }
.cmp.featured .cmp-price small{ color: rgba(242,235,221,.6) }
.cmp-list{
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 10px;
  font-size: 13.5px;
  border-top: 1px solid var(--line);
  padding-top: 16px;
  flex: 1;
}
.cmp.featured .cmp-list{ border-top-color: rgba(242,235,221,.18) }
.cmp-list li{
  display: flex; align-items: flex-start; gap: 10px;
  color: var(--ink-soft);
}
.cmp.featured .cmp-list li{ color: rgba(242,235,221,.84) }
.cmp-list li::before{
  content:"✦";
  color: var(--bronze);
  font-size: 11px;
  margin-top: 3px;
}
.cmp.featured .cmp-list li::before{ color: var(--bronze-glow) }

@media (max-width: 900px){ .compare{ grid-template-columns: 1fr } }

/* ========== SIMULATOR ========== */
.simulator{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: stretch;
}
@media (max-width: 900px){ .simulator{ grid-template-columns: 1fr } }

.sim-preview{
  position: relative;
  aspect-ratio: 4/5;
  background: var(--paper);
  border: 1px solid var(--ink);
  background-image:
    repeating-linear-gradient(0deg, transparent 0 39px, var(--line) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, var(--line) 39px 40px);
  overflow: hidden;
}
.sim-preview img{
  position: absolute; inset: 8%;
  width: 84%; height: 84%; object-fit: contain;
  filter: drop-shadow(0 16px 30px rgba(31,26,20,.18));
  transition: transform .4s var(--t-base);
}
.sim-stamp{
  position: absolute; top: 14px; left: 14px;
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .24em;
  text-transform: uppercase;
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: 6px 10px;
  color: var(--ink);
  z-index: 2;
}
.sim-controls{
  display: flex; flex-direction: column; gap: 22px;
  padding: 4px 0;
}
.sim-block{
  display: flex; flex-direction: column; gap: 10px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.sim-block:last-of-type{ border-bottom: 0 }
.sim-label{
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.sim-swatches{ display: flex; gap: 10px }
.swatch{
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  padding: 4px;
  transition: transform .2s, border-color .2s;
}
.swatch i{ display: block; width: 100%; height:100%; border-radius: 50% }
.swatch.active{ border-color: var(--ink); transform: scale(1.08) }
.sim-pills{ display: flex; gap: 8px; flex-wrap: wrap }
.pill{
  padding: 9px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  transition: all .2s;
}
.pill:hover{ border-color: var(--ink); color: var(--ink) }
.pill.active{ background: var(--ink); color: var(--paper); border-color: var(--ink) }

.sim-slider input{
  width: 100%;
  -webkit-appearance: none; appearance: none;
  height: 2px;
  background: var(--line-strong);
  border-radius: 999px;
  outline: none;
}
.sim-slider input::-webkit-slider-thumb{
  -webkit-appearance: none; appearance: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ink);
  border: 3px solid var(--paper);
  box-shadow: 0 0 0 1px var(--ink);
  cursor: pointer;
  transition: transform .15s;
}
.sim-slider input::-webkit-slider-thumb:hover{ transform: scale(1.15) }
.sim-slider input::-moz-range-thumb{
  width: 22px; height: 22px;
  border-radius: 50%; background: var(--ink); border: 3px solid var(--paper);
  box-shadow: 0 0 0 1px var(--ink); cursor: pointer;
}
.sim-slider .row{
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 10px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  color: var(--ink-mute);
}
.sim-slider .row strong{
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--oxblood);
  font-weight: 500;
  letter-spacing: 0;
}
.sim-invest{
  display: flex; justify-content: space-between; align-items: baseline;
  border-top: 2px solid var(--ink);
  padding-top: 18px;
  margin-top: 6px;
}
.sim-invest .lbl{
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.sim-invest .val{
  font-family: var(--f-serif);
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 500;
  letter-spacing: -.02em;
  color: var(--ink);
}
.sim-invest .val small{
  font-size: .45em;
  font-style: italic;
  color: var(--bronze);
  margin-right: 4px;
  font-weight: 400;
}

/* ========== INSTAGRAM ========== */
.ig-grid{
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
@media (max-width: 900px){ .ig-grid{ grid-template-columns: repeat(3, 1fr) } }
@media (max-width: 500px){ .ig-grid{ grid-template-columns: repeat(2, 1fr) } }
.ig-tile{
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--paper-3);
  border: 1px solid var(--line);
  cursor: pointer;
}
.ig-tile img{
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s var(--t-base), filter .3s;
  filter: saturate(.92);
}
.ig-tile:hover img{ transform: scale(1.06); filter: saturate(1) }
.ig-tile::after{
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, transparent 50%, rgba(31,26,20,.7));
  opacity: 0;
  transition: opacity .25s;
}
.ig-tile:hover::after{ opacity: 1 }
.ig-tile .ig-meta{
  position: absolute;
  bottom: 10px; left: 12px; right: 12px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .12em;
  color: var(--paper);
  opacity: 0;
  transition: opacity .25s;
  display: flex; gap: 12px;
  z-index: 2;
}
.ig-tile:hover .ig-meta{ opacity: 1 }
.ig-cta-wrap{ display: flex; justify-content: center; margin-top: 40px }

/* ========== PROCESSO ========== */
.process-steps{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  position: relative;
}
.process-steps::before{
  content: "";
  position: absolute;
  top: 32px; left: 4%; right: 4%;
  height: 1px;
  background-image: linear-gradient(90deg, var(--bronze) 50%, transparent 50%);
  background-size: 12px 1px;
}
@media (max-width: 800px){
  .process-steps{ grid-template-columns: 1fr }
  .process-steps::before{ display: none }
}
.step{
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
  z-index: 2;
}
.step-node{
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--paper-2);
  border: 1px solid var(--ink);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  position: relative;
  z-index: 2;
}
.step-title{
  font-family: var(--f-serif);
  font-size: 26px;
  margin: 0;
  font-weight: 500;
}
.step-desc{
  font-size: 14px;
  color: var(--ink-mute);
  margin: 0; line-height: 1.55;
  max-width: 28ch;
}

/* ========== CTA FINAL ========== */
.cta-final{
  background: var(--ink);
  color: var(--paper);
  padding: clamp(80px, 11vw, 160px) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
  z-index: 2;
}
.cta-final::before{
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(176,145,107,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(176,145,107,.05) 1px, transparent 1px);
  background-size: 80px 80px;
}
.cta-final-h{
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: clamp(48px, 7.5vw, 110px);
  line-height: .95;
  letter-spacing: -.025em;
  margin: 0 0 24px;
}
.cta-final-h em{ color: var(--bronze-glow); font-style: italic }
.cta-final-sub{
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(242,235,221,.6);
  margin: 0 0 40px;
}
.cta-final .btn-primary{
  background: var(--bronze);
  border-color: var(--bronze);
  color: var(--ink);
}
.cta-final .btn-primary:hover{
  background: var(--bronze-glow);
  border-color: var(--bronze-glow);
}

/* ========== FOOTER ========== */
.footer{
  background: var(--ink);
  color: rgba(242,235,221,.7);
  padding: 80px 0 30px;
  position: relative; z-index: 2;
}
.footer-grid{
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 60px;
  border-bottom: 1px solid rgba(242,235,221,.1);
}
@media (max-width: 800px){ .footer-grid{ grid-template-columns: 1fr 1fr; gap: 36px } }
@media (max-width: 500px){ .footer-grid{ grid-template-columns: 1fr } }
.footer-tagline{
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 17px;
  margin: 16px 0 0;
  max-width: 32ch;
  color: rgba(242,235,221,.55);
}
.footer .brand-text strong{ color: var(--paper) }
.footer .brand-text span{ color: rgba(242,235,221,.5) }
.footer-col h5{
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bronze-glow);
  margin: 0 0 18px;
  font-weight: 500;
}
.footer-col a{
  display: block;
  padding: 5px 0;
  color: rgba(242,235,221,.7);
  font-size: 14px;
  cursor: pointer;
  transition: color .2s;
}
.footer-col a:hover{ color: var(--paper) }
.footer-bottom{
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 30px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .2em;
  color: rgba(242,235,221,.4);
  text-transform: uppercase;
}

/* ========== WhatsApp Floating ========== */
.wa-float{
  position: fixed;
  right: 22px;
  bottom: 22px;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: #25D366;
  color: white;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 12px 28px rgba(37,211,102,.35);
  z-index: 80;
  cursor: pointer;
  transition: transform .25s var(--t-base), box-shadow .25s;
}
.wa-float:hover{ transform: scale(1.08); box-shadow: 0 16px 32px rgba(37,211,102,.5) }
.wa-float svg{ width: 30px; height: 30px }
.wa-float .lbl{
  position: absolute;
  right: 70px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--ink);
  color: var(--paper);
  padding: 8px 14px;
  border-radius: 999px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.wa-float:hover .lbl{ opacity: 1 }

/* ========== MUSIC BUTTON (small round) ========== */
.music-btn{
  position: fixed;
  left: 22px;
  bottom: 22px;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--oxblood);
  color: var(--paper);
  z-index: 80;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 12px 28px rgba(91,26,26,.35);
  cursor: pointer;
  transition: transform .25s var(--t-base), box-shadow .25s, background .25s;
}
.music-btn:hover{
  transform: scale(1.1);
  background: var(--oxblood-2);
  box-shadow: 0 16px 32px rgba(91,26,26,.5);
}
.music-btn svg{ width: 20px; height: 20px; color: var(--bronze-glow); position: relative; z-index: 2 }
.music-btn .music-pause{ display: none }
.music-btn.playing .music-play{ display: none }
.music-btn.playing .music-pause{ display: block }
.music-ring{
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--bronze-glow);
  border-right-color: var(--bronze-glow);
  opacity: 0;
  transition: opacity .25s;
}
.music-btn.playing .music-ring{
  opacity: 1;
  animation: musicSpin 3s linear infinite;
}
@keyframes musicSpin{ to{ transform: rotate(360deg) } }
.music-tip{
  position: absolute;
  left: 70px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--ink);
  color: var(--paper);
  padding: 8px 14px;
  border-radius: 999px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity .2s, transform .2s;
}
.music-btn:hover .music-tip{ opacity: 1; transform: translateY(-50%) translateX(2px) }
.music-frame-wrap{
  position: fixed;
  width: 100px; height: 60px;
  overflow: hidden;
  opacity: 0.001; pointer-events: none;
  left: 0; top: 0;
  z-index: -1;
}
.music-frame-wrap iframe{ width: 320px; height: 180px; border: 0 }
@media (max-width: 700px){
  .music-btn{ width: 48px; height: 48px; left: 16px; bottom: 16px }
  .music-btn svg{ width: 16px; height: 16px }
}

/* ========== MODAL ========== */
.modal{
  position: fixed; inset: 0;
  background: rgba(31,26,20,.7);
  backdrop-filter: blur(8px);
  z-index: 90;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  opacity: 0; pointer-events: none;
  transition: opacity .3s var(--t-base);
}
.modal.open{ opacity: 1; pointer-events: auto }
.modal-card{
  width: 100%;
  max-width: 980px;
  background: var(--paper);
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
  max-height: 90vh;
  overflow: hidden;
  transform: scale(.96);
  transition: transform .3s var(--t-base);
}
.modal.open .modal-card{ transform: scale(1) }
.modal-close{
  position: absolute;
  top: 16px; right: 16px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--paper);
  font-size: 22px;
  color: var(--ink);
  z-index: 3;
  border: 1px solid var(--line-strong);
}
.modal-close:hover{ background: var(--ink); color: var(--paper) }
.modal-img{
  background: var(--paper-2);
  aspect-ratio: 4/5;
  overflow: hidden;
}
.modal-img img{ width: 100%; height: 100%; object-fit: cover }
.modal-body{
  padding: clamp(28px, 4vw, 48px);
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 18px;
}
.modal-body h3{
  font-family: var(--f-serif);
  font-size: clamp(28px, 3.4vw, 44px);
  margin: 0;
  font-weight: 500;
  letter-spacing: -.01em;
}
.modal-body .desc{
  font-family: var(--f-serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0;
}
.modal-specs{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.modal-specs > div{
  background: var(--paper);
  padding: 12px 14px;
}
.modal-specs .k{
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: block;
  margin-bottom: 4px;
}
.modal-specs .v{
  font-family: var(--f-serif);
  font-size: 17px;
  color: var(--ink);
}
.modal-price{
  display: flex; align-items: baseline; gap: 10px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 16px 0;
}
.modal-price .lbl{
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.modal-price .v{
  font-family: var(--f-serif);
  font-size: 32px;
  color: var(--oxblood);
  font-weight: 500;
}
.modal-cta{ margin-top: auto }

@media (max-width: 800px){
  .modal-card{ grid-template-columns: 1fr; max-height: 92vh; overflow-y: auto }
  .modal-img{ aspect-ratio: 4/3 }
}

/* ========== REVEAL ========== */
.reveal{
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s var(--t-base), transform .9s var(--t-base);
}
.reveal.in{ opacity: 1; transform: translateY(0) }
.reveal[data-delay="1"]{ transition-delay: .08s }
.reveal[data-delay="2"]{ transition-delay: .16s }
.reveal[data-delay="3"]{ transition-delay: .24s }
.reveal[data-delay="4"]{ transition-delay: .32s }

/* ========== RESPONSIVE ========== */
@media (max-width: 1100px){
  .hero-inner{ grid-template-columns: 1fr; gap: 32px }
  .hero-right{ order: -1; max-width: 294px; margin: 0 auto; width: 100% }
  .hero-scroll{ display: none }
  .lion-stage{ min-height: 250px; max-width: 294px }
}
@media (max-width: 900px){
  .nav-main{ display: none }
  .header-cta{ display: none }
  .menu-toggle{
    display: flex; flex-direction: column; gap: 5px;
    width: 36px; height: 36px; align-items: center; justify-content: center;
  }
  .menu-toggle span,
  .menu-toggle::before,
  .menu-toggle::after{
    content:"";
    display: block; width: 22px; height: 1.5px;
    background: var(--ink);
  }
}
@media (max-width: 760px){
  /* Hero — leão extendido lateral, próximo ao texto */
  .hero-h1{ font-size: clamp(32px, 9vw, 48px) !important; line-height: .98 }
  .hero{ padding: 12px 0 24px }
  .hero-inner{ gap: 14px !important }
  .hero-right{ max-width: 100%; width: 100% }
  .lion-stage{ max-width: 100%; min-height: 240px; aspect-ratio: 4/3 }
  .lion-figure{ overflow: visible }
  .lion-video, .lion-photo, .lion-fallback{ object-position: center 30% }
  .hero-meta{ font-size: 11px; letter-spacing: .15em }
  .hero-lede, .hero p{ font-size: 15px; line-height: 1.5 }
  .hero-cta-row{ flex-wrap: wrap; gap: 10px }
  .hero-cta-row .btn{ font-size: 13px; padding: 12px 18px }

  /* Sections gerais */
  .h-section{ font-size: clamp(24px, 6vw, 34px) !important; line-height: 1.06 }
  .eyebrow{ font-size: 10px; letter-spacing: .18em }
  .lede{ font-size: 14px; line-height: 1.55 }
  .sct{ padding: 48px 0 }
  .sct-head{ gap: 18px }
  .container{ padding-left: 18px; padding-right: 18px }

  /* Header */
  .site-header{ padding: 12px 0 }
  .brand img{ width: 32px; height: 32px }
  .brand strong{ font-size: 18px }
  .brand-text span{ font-size: 9px; letter-spacing: .18em }

  /* Marquee */
  .marquee-text{ font-size: 16px }

  /* Manifesto / pull quote */
  .pull-quote, .pq, blockquote{ font-size: clamp(20px, 5vw, 28px) !important; line-height: 1.25 }
  .manifesto-cols, .ed-cols, .columns-2{ grid-template-columns: 1fr !important; gap: 18px }
  .dropcap{ font-size: 56px !important }

  /* Vitrine */
  .vitrine-grid{ grid-template-columns: 1fr !important; gap: 18px }
  .product{ padding: 16px }
  .product-name{ font-size: 20px }
  .product-cat{ font-size: 11px }
  .product-price{ font-size: 16px }
  .chip-row, .chips, .filter-row{ flex-wrap: wrap; gap: 8px }

  /* Comparar */
  .compare-grid, .cmp-grid{ grid-template-columns: 1fr !important; gap: 16px }
  .cmp{ padding: 22px 18px }
  .cmp-name{ font-size: 22px }
  .cmp-price{ font-size: 24px }

  /* Simulador — preview sticky e foto da cadeira maior (+15%) */
  .simulator{ grid-template-columns: 1fr !important; gap: 16px }
  .sim-preview{
    aspect-ratio: 4/3;
    width: 100%;
    max-width: 420px;
    min-height: 280px;
    margin: 0 auto;
    position: sticky;
    top: 8px;
    z-index: 5;
  }
  .sim-preview img{ inset: 0 !important; width: 100% !important; height: 100% !important; object-fit: contain }
  .sim-controls{ width: 100%; gap: 16px }

  /* Vitrine — cadeiras 10% menores no mobile */
  .product{ padding: 14px }
  .product-img{ aspect-ratio: 1/1; display: flex; align-items: center; justify-content: center; }
  .product-img img{ width: 90%; height: 90%; object-fit: contain; margin: 0 auto; display: block; }
  .product-name{ font-size: 19px }
  .sim-row label{ font-size: 11px }
  .pill, .swatch{ font-size: 12px }
  .sim-price{ font-size: 28px }
  .sim-price small{ font-size: 11px }

  /* Instagram */
  .ig-cta-btn, .ig-simple .btn{ font-size: 14px; padding: 14px 22px }

  /* Processo */
  .step-title{ font-size: 18px }
  .step-desc{ font-size: 13px }

  /* Historia */
  .historia-grid{ grid-template-columns: 1fr; gap: 14px }
  .historia-num{ font-size: clamp(72px, 18vw, 120px) }
  .historia-text p, .historia-text{ font-size: 15px; line-height: 1.55 }

  /* CTA final */
  .cta-final-h{ font-size: clamp(28px, 7vw, 42px) !important }
  .cta-final-sub{ font-size: 11px }

  /* Footer */
  .footer{ padding: 40px 0 24px }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap: 24px }
  .footer-col h5{ font-size: 11px }
  .footer-col a{ font-size: 13px }

  /* Stats / numbers */
  .stat-num, .h-display{ font-size: clamp(48px, 14vw, 72px) }

  /* Music button */
  .music-btn{ left: 14px; bottom: 14px; width: 46px; height: 46px }
}

@media (max-width: 420px){
  .hero-h1{ font-size: clamp(28px, 8.5vw, 40px) !important }
  .hero-inner{ gap: 12px !important }
  .hero-right{ max-width: 100% }
  .lion-stage{ max-width: 100%; min-height: 200px; aspect-ratio: 4/3 }
  .h-section{ font-size: clamp(22px, 5.5vw, 30px) !important }
  .footer-grid{ grid-template-columns: 1fr; gap: 22px }
  .container{ padding-left: 14px; padding-right: 14px }
  .sim-preview{ width: 95%; max-width: 320px; min-height: 220px }
  .product-name{ font-size: 17px }
  .cmp-name{ font-size: 20px }
  .cmp-price{ font-size: 22px }
}


/* ============================================
   IG SIMPLES + HISTORIA + ADMIN
   ============================================ */

/* Hide old IG grid styles by overriding any leftover */
.ig-grid { display: none; }
.ig-cta-wrap { display: none; }

/* Instagram simples */
.ig-simple .ig-block {
  text-align: center;
  padding: 40px 0 30px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
}
.ig-icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border: 1px solid var(--bronze, #8B6F4E);
  border-radius: 50%;
  color: var(--bronze, #8B6F4E);
  background: transparent;
  transition: all .35s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.ig-icon-link:hover {
  background: var(--bronze, #8B6F4E);
  color: var(--paper, #F2EDE2);
  transform: scale(1.06);
}
.ig-icon-link svg { width: 24px; height: 24px; }
.ig-h { font-size: clamp(34px, 4vw, 56px); margin: 6px 0 12px; text-align: center; }

/* História */
.historia-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
  padding: 30px 0 50px;
}
.historia-num {
  font-family: var(--serif, 'Fraunces', serif);
  font-size: clamp(140px, 22vw, 280px);
  line-height: .85;
  font-weight: 600;
  font-style: italic;
  color: transparent;
  -webkit-text-stroke: 1.5px var(--bronze, #8B6F4E);
  letter-spacing: -.04em;
  user-select: none;
  text-align: center;
  padding-top: 10px;
}
.historia-text {
  font-family: var(--serif, 'Fraunces', serif);
  font-size: 16px;
  line-height: 1.85;
  color: var(--ink-2, #5C5247);
  font-weight: 400;
  letter-spacing: .005em;
}
.historia-text p { margin: 0 0 20px; text-wrap: pretty; text-align: justify; hyphens: auto; -webkit-hyphens: auto; }
.historia-text .placeholder-note {
  display: inline-block;
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--oxblood, #6E2C30);
  background: rgba(110,44,48,.08);
  border: 1px dashed var(--oxblood, #6E2C30);
  padding: 6px 12px;
  border-radius: 2px;
  margin-bottom: 26px;
}
.historia-text em {
  font-style: italic;
  color: var(--bronze, #8B6F4E);
}
.historia-text .dropcap {
  float: left;
  font-family: var(--serif, 'Fraunces', serif);
  font-size: 64px;
  line-height: .9;
  font-weight: 500;
  font-style: italic;
  color: var(--bronze, #8B6F4E);
  padding: 8px 12px 0 0;
}
@media (max-width: 760px) {
  .historia-grid { grid-template-columns: 1fr; gap: 24px; }
  .historia-num { font-size: 120px; }
  .historia-text { font-size: 16px; }
}

/* Simulador caption */
.sim-caption {
  position: absolute;
  left: 28px;
  bottom: 24px;
  background: rgba(20,18,16,.78);
  backdrop-filter: blur(8px);
  padding: 14px 22px;
  border-left: 2px solid var(--bronze, #8B6F4E);
  z-index: 4;
}
.sim-cap-label {
  display: block;
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(242,237,226,.55);
  margin-bottom: 4px;
}
.sim-caption strong {
  display: block;
  font-family: var(--serif, 'Fraunces', serif);
  font-style: italic;
  font-size: 22px;
  font-weight: 500;
  color: var(--paper, #F2EDE2);
}
.sim-preview { position: relative; }
@media (max-width: 760px) {
  .sim-caption { left: 12px; bottom: 12px; padding: 10px 14px; }
  .sim-caption strong { font-size: 17px; }
}

/* Admin link rodapé */
.admin-link {
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #5A5248;
  text-decoration: none;
  border: 1px solid rgba(90,82,72,.3);
  padding: 4px 10px;
  border-radius: 2px;
  transition: all .25s;
}
.admin-link:hover { color: var(--oxblood, #6E2C30); border-color: var(--oxblood, #6E2C30); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }

/* Admin modais */
.admin-modal {
  position: fixed; inset: 0;
  background: rgba(20, 18, 16, .65);
  backdrop-filter: blur(6px);
  z-index: 5000;
  display: none !important;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.admin-modal.open,
.admin-modal[aria-hidden="false"] { display: flex !important; }
.admin-card {
  background: var(--paper, #F2EDE2);
  width: 100%;
  max-width: 460px;
  padding: 44px 38px 36px;
  border-radius: 4px;
  position: relative;
  border-top: 3px solid var(--bronze, #8B6F4E);
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
}
.admin-card.admin-card-lg { max-width: 540px; }
.admin-h {
  font-family: var(--serif, 'Fraunces', serif);
  font-size: 36px;
  font-weight: 500;
  margin: 8px 0 6px;
  letter-spacing: -.02em;
}
.admin-h em { font-style: italic; color: var(--bronze, #8B6F4E); }
.admin-sub {
  font-family: var(--sans, 'Inter', sans-serif);
  font-size: 14px;
  color: var(--ink-2, #5C5247);
  margin: 0 0 22px;
}
.admin-field {
  display: block;
  margin-bottom: 14px;
}
.admin-field span {
  display: block;
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2, #5C5247);
  margin-bottom: 6px;
}
.admin-field input,
.admin-field select {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--sans, 'Inter', sans-serif);
  font-size: 15px;
  border: 1px solid rgba(90,82,72,.3);
  background: rgba(255,255,255,.6);
  border-radius: 2px;
  color: var(--ink, #2A2620);
  transition: border-color .2s;
}
.admin-field input:focus,
.admin-field select:focus { outline: none; border-color: var(--oxblood, #6E2C30); }
.admin-error {
  font-family: var(--sans, 'Inter', sans-serif);
  font-size: 13px;
  color: var(--oxblood, #6E2C30);
  margin: 8px 0 12px;
  min-height: 18px;
}
.admin-preview {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}
.admin-preview img {
  width: 84px;
  height: 84px;
  object-fit: cover;
  border-radius: 2px;
  border: 1px solid rgba(90,82,72,.2);
}
.admin-edit-ctas {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 8px;
}

/* Admin panel */
.admin-panel {
  display: none !important;
  padding: 60px 0;
  background: var(--paper, #F2EDE2);
  min-height: 100vh;
}
.admin-panel[aria-hidden="false"] { display: block !important; }
.admin-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 30px;
  flex-wrap: wrap;
  margin-bottom: 36px;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(90,82,72,.2);
}
.admin-head h2 { font-size: clamp(36px, 5vw, 56px); margin: 12px 0 4px; }
.admin-warning {
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  letter-spacing: .12em;
  color: var(--oxblood, #6E2C30);
  text-transform: uppercase;
  margin: 0;
}
.admin-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.admin-table-wrap {
  background: rgba(255,255,255,.4);
  border: 1px solid rgba(90,82,72,.18);
  border-radius: 4px;
  overflow-x: auto;
}
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--sans, 'Inter', sans-serif);
  font-size: 14px;
  min-width: 700px;
}
.admin-table thead th {
  text-align: left;
  padding: 14px 18px;
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2, #5C5247);
  background: rgba(90,82,72,.06);
  border-bottom: 1px solid rgba(90,82,72,.2);
}
.admin-table tbody tr {
  border-bottom: 1px solid rgba(90,82,72,.1);
  transition: background .2s;
}
.admin-table tbody tr:hover { background: rgba(139,111,78,.06); }
.admin-table td { padding: 12px 18px; vertical-align: middle; }
.admin-table img.thumb {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: 2px;
  display: block;
}
.admin-table .price-input {
  width: 110px;
  padding: 6px 10px;
  border: 1px solid var(--oxblood, #6E2C30);
  background: white;
  font-family: inherit;
  font-size: 14px;
  border-radius: 2px;
}
.admin-table .price-display {
  cursor: pointer;
  border-bottom: 1px dashed rgba(90,82,72,.4);
  padding-bottom: 1px;
}
.admin-table .price-display:hover { color: var(--oxblood, #6E2C30); border-color: var(--oxblood, #6E2C30); }
.admin-table .row-actions { display: flex; gap: 8px; }
.admin-table .ico-btn {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(90,82,72,.25);
  background: white;
  border-radius: 2px;
  cursor: pointer;
  color: var(--ink, #2A2620);
  transition: all .2s;
}
.admin-table .ico-btn:hover { border-color: var(--oxblood, #6E2C30); color: var(--oxblood, #6E2C30); }
.admin-table .ico-btn.danger:hover { background: var(--oxblood, #6E2C30); color: var(--paper, #F2EDE2); border-color: var(--oxblood, #6E2C30); }
.admin-table .ico-btn svg { width: 16px; height: 16px; }
.admin-tag-pill {
  display: inline-block;
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 8px;
  background: rgba(139,111,78,.14);
  color: var(--bronze, #8B6F4E);
  border-radius: 2px;
}

/* Language switcher pills (PT / EN / ES) */
.lang-switch {
  position: fixed;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  gap: 4px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(139,111,78,.45);
  border-radius: 999px;
  padding: 4px;
  z-index: 999;
  backdrop-filter: blur(8px);
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.lang-pill {
  background: transparent;
  border: 0;
  padding: 6px 12px;
  font-family: var(--f-mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  letter-spacing: .14em;
  cursor: pointer;
  border-radius: 999px;
  color: var(--ink-2, #5C5247);
  transition: all .2s ease;
  font-weight: 500;
}
.lang-pill:hover { color: var(--oxblood, #6E2C30); }
.lang-pill.active {
  background: var(--oxblood, #6E2C30);
  color: var(--paper, #F2EDE2);
}
@media (max-width: 760px){
  .lang-switch { top: 8px; padding: 3px; }
  .lang-pill { padding: 5px 10px; font-size: 10px; }
}
.site-header { padding-top: 50px; }
@media (max-width: 760px){ .site-header { padding-top: 40px !important; } }

/* Esconder a UI nativa do Google Translate (mantendo o select funcional) */
#google_translate_element { position: fixed !important; left: -10000px !important; top: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; opacity: 0 !important; pointer-events: none !important; z-index: -1 !important; }
iframe.skiptranslate, iframe.goog-te-banner-frame, .goog-te-banner-frame, #goog-gt-tt, .VIpgJd-ZVi9od-l4eHX-hSRGPd, .VIpgJd-ZVi9od-ORHb-OEVmcd { display: none !important; visibility: hidden !important; height: 0 !important; }
html, body { top: 0 !important; margin-top: 0 !important; }
.goog-tooltip, .goog-tooltip:hover { display: none !important; }
.goog-text-highlight { background: none !important; box-shadow: none !important; }

/* Sim-stamp menor no mobile, no canto */
@media (max-width: 760px){
  .sim-stamp {
    font-size: 8px !important;
    padding: 4px 7px !important;
    top: 6px !important; left: 6px !important;
    letter-spacing: .14em !important;
  }
  .product-tag {
    font-size: 9px !important;
    padding: 4px 8px !important;
    z-index: 5;
  }
}

/* Botão EDITAR único por linha (web e mobile) */
.btn-edit-row {
  background: var(--oxblood, #6E2C30);
  color: var(--paper, #F2EDE2);
  border: 1px solid var(--oxblood, #6E2C30);
  padding: 8px 18px;
  font-family: var(--f-mono, 'JetBrains Mono', monospace);
  font-size: 12px;
  letter-spacing: .14em;
  cursor: pointer;
  border-radius: 2px;
  transition: all .25s ease;
  text-transform: uppercase;
}
.btn-edit-row:hover {
  background: transparent;
  color: var(--oxblood, #6E2C30);
}

/* Botão Excluir (vermelho) dentro do modal */
.btn-delete-product {
  width: 100%;
  margin-top: 18px;
  padding: 12px 18px;
  background: transparent;
  color: #b03028;
  border: 1px solid #b03028;
  font-family: var(--f-mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  letter-spacing: .18em;
  cursor: pointer;
  border-radius: 2px;
  transition: all .25s ease;
  text-transform: uppercase;
}
.btn-delete-product:hover {
  background: #b03028;
  color: #fff;
}

/* Admin mobile — layout em card claro */
@media (max-width: 760px) {
  .admin-table-wrap { overflow-x: visible !important; }
  .admin-table,
  .admin-table thead,
  .admin-table tbody,
  .admin-table tr,
  .admin-table td { display: block !important; width: 100% !important; min-width: 0 !important; }
  .admin-table thead { display: none !important; }
  .admin-table tr {
    padding: 14px !important;
    border: 1px solid rgba(90,82,72,.25) !important;
    border-radius: 6px;
    margin-bottom: 12px;
    background: #fff;
    display: grid !important;
    grid-template-columns: 64px 1fr;
    grid-template-areas:
      "foto nome"
      "foto cat"
      "foto preco"
      "foto tag"
      "btn btn";
    grid-gap: 6px 12px;
    align-items: center;
  }
  .admin-table td { padding: 0 !important; border: 0 !important; font-size: 14px !important; line-height: 1.3; }
  .