/* =========================
Iza Tattoo — style.css (AJUSTADO COMPLETO)
========================= */

:root{
  --wrap: 1160px;
  --radius: 18px;
  --radius2: 24px;

  --bg:#06070a;
  --card:rgba(14,16,22,.72);
  --card2:rgba(20,22,30,.62);
  --stroke:rgba(255,255,255,.10);
  --stroke2:rgba(255,255,255,.14);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.66);
  --muted2:rgba(255,255,255,.52);
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --shadow2: 0 12px 34px rgba(0,0,0,.45);

  --green:#38d26f;
  --accent:#a78bfa;
  --accent2:#22d3ee;
}

html[data-theme="light"]{
  --bg:#f6f7fb;
  --card: rgba(255,255,255,.92);
  --card2: rgba(255,255,255,.88);
  --stroke: rgba(0,0,0,.10);
  --stroke2: rgba(0,0,0,.14);
  --text: rgba(10,12,16,.92);
  --muted: rgba(10,12,16,.66);
  --muted2: rgba(10,12,16,.52);
  --shadow: 0 18px 60px rgba(0,0,0,.12);
  --shadow2: 0 12px 34px rgba(0,0,0,.10);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html, body{
  height:auto;
  min-height:100%;
}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
}
a{ color:inherit; }
img{ max-width:100%; display:block; }

.noSave{
  -webkit-touch-callout:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-user-drag:none;
  user-drag:none;
  pointer-events:auto;
}

/* =========================
   Background
========================= */

.bg{
  position:fixed;
  inset:0;
  z-index:-1;
  height:100svh;
}
.bg__img{
  position:absolute;
  inset:0;
  background-position:center;
  background-size:cover;
  transform:scale(1.08);
  filter:saturate(1.05) contrast(1.06);
  animation:bgPulse 18s ease-in-out infinite;
  will-change:transform;
}
@keyframes bgPulse{
  0%{ transform:scale(1.08); }
  50%{ transform:scale(1.14); }
  100%{ transform:scale(1.08); }
}

.bg__img--desktop{ background-image:url("img/recepcao.jpeg"); }
.bg__img--mobile{ display:none; background-image:url("img/recepcao-2.jpeg"); }

@supports (-webkit-touch-callout: none){
  @media (max-width: 720px){
    .bg{ position:fixed; height:100svh; }
    .bg__img{
      animation:none !important;
      transform:none !important;
      filter:saturate(1.02) contrast(1.03);
    }
  }
}

.bg__overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(1200px 600px at 18% 10%, rgba(167,139,250,.18), transparent 60%),
    radial-gradient(1000px 540px at 80% 18%, rgba(34,211,238,.12), transparent 55%),
    radial-gradient(900px 520px at 55% 82%, rgba(56,210,111,.08), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.88));
}
html[data-theme="light"] .bg__overlay{
  background:
    radial-gradient(1200px 600px at 18% 10%, rgba(167,139,250,.16), transparent 60%),
    radial-gradient(1000px 540px at 80% 18%, rgba(34,211,238,.10), transparent 55%),
    radial-gradient(900px 520px at 55% 82%, rgba(56,210,111,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.30), rgba(255,255,255,.70));
}

.bg__noise{
  position:absolute; inset:0;
  opacity:.12;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
html[data-theme="light"] .bg__noise{
  opacity:.08;
  mix-blend-mode:soft-light;
}

.bg__glow{
  position:absolute;
  inset:-120px -120px auto auto;
  width:520px;
  height:520px;
  background:radial-gradient(circle at 30% 30%, rgba(167,139,250,.28), transparent 60%);
  filter:blur(18px);
  animation:floatGlow 10s ease-in-out infinite;
}
@keyframes floatGlow{
  0%,100%{ transform:translate(0,0) scale(1); opacity:.85; }
  50%{ transform:translate(-30px,20px) scale(1.05); opacity:1; }
}

/* =========================
   Layout base
========================= */

.wrap{
  width:min(var(--wrap), calc(100% - 36px));
  margin:0 auto;
}
.main{
  padding-top:78px;
  min-height:100svh;
}
.section{
  padding:clamp(54px, 5.2vw, 84px) 0;
  padding-bottom:clamp(70px, 8vw, 110px) !important;
}

.h2{
  margin:0;
  font-size:26px;
  letter-spacing:-.5px;
  display:flex;
  align-items:center;
  gap:10px;
}
.h3{
  margin:0;
  font-size:18px;
  display:flex;
  align-items:center;
  gap:10px;
}
.muted{
  color:var(--muted);
  margin:8px 0 0;
  line-height:1.55;
}

/* =========================
   Topbar
========================= */

.topbar{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:linear-gradient(180deg, rgba(10,11,15,.72), rgba(10,11,15,.45));
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:.25s ease;
}
html[data-theme="light"] .topbar{
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.55));
  border-bottom:1px solid rgba(0,0,0,.08);
}
.topbar.is-scrolled{
  background:linear-gradient(180deg, rgba(10,11,15,.86), rgba(10,11,15,.58));
  border-bottom:1px solid rgba(255,255,255,.10);
}
html[data-theme="light"] .topbar.is-scrolled{
  background:linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.68));
  border-bottom:1px solid rgba(0,0,0,.10);
}

.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:78px;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--text);
  flex:0 0 auto;
}
.brand__logo{
  width:40px;
  height:40px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:radial-gradient(circle at 30% 30%, rgba(167,139,250,.34), rgba(255,255,255,.06));
  border:1px solid var(--stroke2);
  box-shadow:var(--shadow2);
}
.brand__name{
  font-weight:800;
  letter-spacing:.2px;
  display:block;
}
.brand__tag{
  font-size:12px;
  color:var(--muted);
  display:block;
  margin-top:2px;
}

.nav{
  display:flex;
  gap:10px;
  align-items:center;
  overflow:auto;
  scrollbar-width:none;
  -ms-overflow-style:none;
  flex:1 1 auto;
}
.nav::-webkit-scrollbar{ display:none; }

.nav a{
  color:var(--muted);
  text-decoration:none;
  font-weight:800;
  font-size:14px;
  padding:10px;
  border-radius:12px;
  transition:.25s ease;
  white-space:nowrap;
}
.nav a:hover{
  color:var(--text);
  background:rgba(255,255,255,.06);
}
html[data-theme="light"] .nav a:hover{ background:rgba(0,0,0,.06); }
.nav a.is-active{
  color:var(--text);
  background:rgba(167,139,250,.14);
  border:1px solid rgba(167,139,250,.20);
}

.nav .navShop{
  color:var(--text);
  border:1px solid rgba(56,210,111,.45);
  background:linear-gradient(135deg, rgba(56,210,111,.22), rgba(34,211,238,.12));
}
.nav .navShop:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg, rgba(56,210,111,.28), rgba(34,211,238,.16));
}

.topbar__actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
}
.themeBtn{ white-space:nowrap; }

/* =========================
   Language
========================= */

.langSwitch{
  display:flex;
  gap:10px;
  padding:10px;
  border-radius:18px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
}
html[data-theme="light"] .langSwitch{ background:rgba(0,0,0,.02); }

.langBtn{
  width:42px;
  height:42px;
  border-radius:16px;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.05);
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:.2s ease;
  padding:0;
  -webkit-appearance:none;
  appearance:none;
  touch-action:manipulation;
  user-select:none;
  -webkit-user-select:none;
  outline:none;
}
html[data-theme="light"] .langBtn{ background:rgba(0,0,0,.02); }

.langBtn:hover{ transform:translateY(-1px); }
.langBtn.is-active{
  outline:2px solid rgba(167,139,250,.55);
  border-color:rgba(167,139,250,.35);
}
.langBtn:focus,
.langBtn:focus-visible{
  outline:2px solid rgba(167,139,250,.55);
  outline-offset:2px;
}

.flag{
  width:26px;
  height:18px;
  border-radius:4px;
  box-shadow:0 6px 14px rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.18);
  background-size:cover;
  background-position:center;
}
.flag--br{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='18' viewBox='0 0 26 18'%3E%3Crect width='26' height='18' fill='%23009b3a'/%3E%3Cpolygon points='13,2 24,9 13,16 2,9' fill='%23ffdf00'/%3E%3Ccircle cx='13' cy='9' r='4.2' fill='%23002776'/%3E%3C/svg%3E");
}
.flag--es{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='18' viewBox='0 0 26 18'%3E%3Crect width='26' height='18' fill='%23aa151b'/%3E%3Crect y='4' width='26' height='10' fill='%23f1bf00'/%3E%3C/svg%3E");
}
.flag--us{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='18' viewBox='0 0 26 18'%3E%3Crect width='26' height='18' fill='%23b22234'/%3E%3Cg fill='%23fff'%3E%3Crect y='2' width='26' height='2'/%3E%3Crect y='6' width='26' height='2'/%3E%3Crect y='10' width='26' height='2'/%3E%3Crect y='14' width='26' height='2'/%3E%3C/g%3E%3Crect width='11' height='8' fill='%233c3b6e'/%3E%3C/svg%3E");
}

/* =========================
   Buttons
========================= */

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  text-decoration:none;
  font-weight:900;
  font-size:14px;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.06);
  color:var(--text);
  transition:.22s ease;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transform:translateZ(0);
}
html[data-theme="light"] .btn{ background:rgba(0,0,0,.03); }

.btn::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(600px 240px at 10% 10%, rgba(34,211,238,.20), transparent 50%),
    radial-gradient(620px 260px at 90% 40%, rgba(167,139,250,.18), transparent 52%);
  opacity:0;
  transition:.25s ease;
  pointer-events:none;
}
.btn:hover{ transform:translateY(-1px); }
.btn:hover::after{ opacity:1; }

.btn--primary{
  border:1px solid rgba(167,139,250,.45);
  background:linear-gradient(135deg, rgba(167,139,250,.42), rgba(34,211,238,.18));
  box-shadow:0 14px 40px rgba(0,0,0,.20);
}
.btn--primary:hover{ transform:translateY(-1px) scale(1.01); }

.btn--ghost{ background:rgba(255,255,255,.05); }
html[data-theme="light"] .btn--ghost{ background:rgba(0,0,0,.03); }

.btn--full{
  width:100%;
  justify-content:center;
}

html[data-theme="light"] .btn--ghost{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.16);
  box-shadow:0 10px 22px rgba(0,0,0,.08);
}
html[data-theme="light"] .btn--primary{
  border:1px solid rgba(79,70,229,.35);
  background:linear-gradient(135deg, rgba(79,70,229,.22), rgba(8,145,178,.14));
  box-shadow:0 14px 34px rgba(0,0,0,.12);
}

/* =========================
   Cards
========================= */

.sectionCard{
  border-radius:var(--radius2);
  border:1px solid var(--stroke2);
  background:var(--card);
  box-shadow:var(--shadow);
  overflow:visible;
}
.sectionCard__head{
  padding:18px 18px 12px;
  border-bottom:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.05), transparent);
}
.sectionCard__body{ padding:16px 18px 18px; }

html[data-theme="light"] .sectionCard{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.14);
  box-shadow:0 18px 50px rgba(0,0,0,.14), 0 1px 0 rgba(255,255,255,.7) inset;
}
html[data-theme="light"] .sectionCard__head{
  background:linear-gradient(180deg, rgba(0,0,0,.04), transparent);
  border-bottom:1px solid rgba(0,0,0,.10);
}

.grid2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:start;
}

.card{
  border-radius:var(--radius2);
  border:1px solid var(--stroke2);
  background:var(--card);
  box-shadow:var(--shadow2);
  overflow:hidden;
  position:relative;
}
.card__head{
  padding:16px 16px 10px;
  border-bottom:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.04), transparent);
}
.card__body{
  padding:14px 16px 16px;
  color:var(--muted);
  line-height:1.7;
}

html[data-theme="light"] .card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.12);
  box-shadow:0 14px 40px rgba(0,0,0,.12), 0 1px 0 rgba(255,255,255,.6) inset;
}
html[data-theme="light"] .card__head{
  background:linear-gradient(180deg, rgba(0,0,0,.03), transparent);
  border-bottom:1px solid rgba(0,0,0,.08);
}
html[data-theme="light"] .card__body{ color:rgba(10,12,16,.78); }

.list{
  margin-top:10px;
  display:grid;
  gap:8px;
}
.li{
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.li i{
  margin-top:3px;
  color:rgba(56,210,111,.95);
}

.divider{
  height:1px;
  background:var(--stroke);
  margin:14px 0;
}
.note{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:var(--muted);
  font-size:13px;
}

/* =========================
   Hero fullscreen logo
========================= */

.hero__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  align-items:stretch;
}

.hero--fullscreen{
  position:relative;
  z-index:1;
  min-height:calc(100svh - 78px);
  display:flex;
  align-items:stretch;
  justify-content:center;
  padding:0 !important;
}

.hero__grid--introOnly{
  width:100%;
  min-height:calc(100svh - 78px);
  display:grid;
  place-items:center;
}

.heroIntro{
  min-height:calc(100svh - 78px);
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}

.heroIntro__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at center, rgba(167,139,250,.18), transparent 34%),
    radial-gradient(circle at center, rgba(34,211,238,.12), transparent 54%);
  filter:blur(12px);
  animation:introGlowMove 4s ease-in-out infinite;
}

.heroIntro__content{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.heroIntro__logo{
  width:min(760px, 82vw);
  max-width:100%;
  height:auto;
  display:block;
  margin:0 auto;
  transform-origin:center center;
  filter:drop-shadow(0 18px 46px rgba(0,0,0,.36));
  animation:
    logoPulse 2.4s ease-in-out infinite,
    logoFloat 4.2s ease-in-out infinite;
}

.heroIntro__logo--light{ display:none; }
html[data-theme="light"] .heroIntro__logo--dark{ display:none; }
html[data-theme="light"] .heroIntro__logo--light{ display:block; }

@keyframes logoPulse{
  0%,100%{ transform:scale(1); }
  50%{ transform:scale(1.06); }
}
@keyframes logoFloat{
  0%,100%{ translate:0 0; }
  50%{ translate:0 -10px; }
}
@keyframes introGlowMove{
  0%,100%{ transform:scale(1); opacity:.75; }
  50%{ transform:scale(1.08); opacity:1; }
}

/* =========================
   Intro welcome
========================= */

.introWelcome{
  position:fixed;
  inset:0;
  z-index:99999;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(1000px 500px at 50% 30%, rgba(167,139,250,.16), transparent 60%),
    linear-gradient(180deg, rgba(6,7,10,.96), rgba(6,7,10,1));
  backdrop-filter:blur(8px);
  opacity:1;
  visibility:visible;
  transition:opacity .8s ease, visibility .8s ease;
}
html[data-theme="light"] .introWelcome{
  background:
    radial-gradient(1000px 500px at 50% 30%, rgba(79,70,229,.10), transparent 60%),
    linear-gradient(180deg, rgba(246,247,251,.96), rgba(246,247,251,1));
}
.introWelcome.is-hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.introWelcome__inner{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.introWelcome__text{
  font-size:clamp(28px, 6vw, 72px);
  font-weight:800;
  letter-spacing:.04em;
  color:var(--text);
  text-align:center;
  animation:welcomePulse 1.2s ease-in-out infinite;
}
@keyframes welcomePulse{
  0%,100%{ transform:scale(1); opacity:.9; }
  50%{ transform:scale(1.06); opacity:1; }
}

/* =========================
   FAQ
========================= */

.faq{
  display:grid;
  gap:10px;
}
.faq__item{
  width:100%;
  display:grid;
  grid-template-columns:1fr 22px;
  column-gap:12px;
  align-items:center;
  min-height:64px;
  padding:14px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.05);
  color:var(--text);
  font-weight:900;
  cursor:pointer;
  transition:.2s ease;
}
.faq__item i{
  transition:.2s ease;
  opacity:.9;
  justify-self:end;
  align-self:center;
}
.faq__item[aria-expanded="true"] i{ transform:rotate(180deg); }
.faq__item span,
.faq__item .faq__q,
.faq__item strong{
  line-height:1.25;
}

.faq__panel{
  max-height:0;
  overflow:hidden;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.03);
  padding:0 12px;
  transition:max-height .38s ease, padding .25s ease;
}
.faq__panel p{
  margin:10px 0 12px;
  line-height:1.6;
}
.faq__panel.is-open{
  padding:10px 12px;
}

/* =========================
   Hours
========================= */

.hours{
  margin-top:12px;
  border-radius:18px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
  padding:14px;
}
.hours__title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  color:var(--text);
  margin-bottom:10px;
}
.hours__grid{
  display:grid;
  gap:10px;
}
.hours__row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:rgba(0,0,0,.14);
}
.hours__note{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
  font-size:13px;
}
.hours__row--stack{
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
html[data-theme="light"] .hours{ background:rgba(0,0,0,.02); }
html[data-theme="light"] .hours__row{ background:rgba(0,0,0,.03); }

.addr{
  display:flex;
  flex-direction:column;
  gap:2px;
  width:100%;
}
.addr__sub{
  color:var(--muted);
  font-size:13px;
  font-weight:800;
  opacity:.95;
}

/* =========================
   Seg buttons
========================= */

.seg{
  display:flex;
  gap:10px;
  padding:10px;
  border-radius:18px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
  width:fit-content;
}
.seg--small{
  width:100%;
  justify-content:space-between;
}
.seg__btn{
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.05);
  color:var(--muted);
  font-weight:900;
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  transition:.2s ease;
  display:inline-flex;
  gap:10px;
  align-items:center;
}
.seg__btn.is-active{
  color:var(--text);
  background:linear-gradient(135deg, rgba(167,139,250,.28), rgba(34,211,238,.14));
  border-color:rgba(167,139,250,.35);
}
html[data-theme="light"] .seg{ background:rgba(0,0,0,.02); }
html[data-theme="light"] .seg__btn{ background:rgba(0,0,0,.02); }

.seg--studio{
  width:100%;
  max-width:520px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:10px;
  padding:10px;
  margin:0 auto;
}
.seg--studio .seg__btn{
  width:100%;
  justify-content:center;
  white-space:nowrap;
  min-height:44px;
}
.seg__btn--shop{
  color:var(--text);
  border:1px solid rgba(56,210,111,.55);
  background:linear-gradient(135deg, rgba(56,210,111,.26), rgba(34,211,238,.14));
  box-shadow:0 14px 34px rgba(0,0,0,.16);
  text-decoration:none;
}
.seg__btn--shop:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg, rgba(56,210,111,.32), rgba(34,211,238,.18));
}
html[data-theme="light"] .seg__btn--shop{
  border:1px solid rgba(22,163,74,.35);
  background:linear-gradient(135deg, rgba(22,163,74,.18), rgba(8,145,178,.12));
  box-shadow:0 14px 30px rgba(0,0,0,.10);
}

/* =========================
   Studio
========================= */

.studioCardBody{ padding:16px 16px 18px; }
.studio{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:14px;
  align-items:center;
  justify-items:center;
  max-width:1040px;
  margin:0 auto;
}
.studio__left{
  width:100%;
  max-width:560px;
  display:grid;
  justify-items:center;
  text-align:center;
}
.studio__left .miniTitle{
  width:100%;
  display:flex;
  justify-content:center;
  text-align:center;
}
.studio__left .seg{
  width:100%;
  max-width:520px;
  justify-content:center;
  margin:0 auto;
}
.studio__left .hours{
  width:100%;
  text-align:left;
}
.studio__right{
  width:100%;
  max-width:560px;
  display:grid;
  justify-items:center;
}

.studioBig{
  width:100%;
  margin-top:10px;
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.04);
  position:relative;
  box-shadow:var(--shadow);
  cursor:zoom-in;
}
.studioBig img{
  width:100%;
  height:360px;
  object-fit:cover;
  transform:scale(1.03);
  filter:contrast(1.04) saturate(1.03);
  transition:transform .8s ease;
}
.studioBig:hover img{ transform:scale(1.07); }

.studioBig__shade{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 380px at 12% 10%, rgba(167,139,250,.14), transparent 55%),
    linear-gradient(180deg, transparent, rgba(0,0,0,.45));
}
html[data-theme="light"] .studioBig__shade{
  background:
    radial-gradient(1200px 380px at 12% 10%, rgba(167,139,250,.12), transparent 55%),
    linear-gradient(180deg, transparent, rgba(0,0,0,.22));
}
.studioBig__label{
  position:absolute;
  left:14px;
  bottom:14px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--stroke2);
  background:rgba(0,0,0,.32);
  font-weight:900;
  display:flex;
  gap:10px;
  align-items:center;
}
html[data-theme="light"] .studioBig__label{ background:rgba(255,255,255,.72); }

.studioNavBtns--below{
  width:100%;
  justify-content:center;
  gap:10px;
  display:flex;
}
.studioNavBtns--below .btn{
  flex:1 1 auto;
  max-width:220px;
  justify-content:center;
}

.thumbs{
  width:100%;
  margin-top:10px;
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:center;
}
.thumbs__nav{
  width:42px;
  height:42px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.05);
  color:var(--text);
  cursor:pointer;
  transition:.2s ease;
}
.thumbs__nav:hover{ transform:translateY(-1px); }

.thumbs__track{
  flex:1;
  max-width:420px;
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:10px;
}
.thumb{
  border:none;
  padding:0;
  overflow:hidden;
  border-radius:12px;
  border:1px solid var(--stroke);
  background:transparent;
  cursor:pointer;
  min-height:70px;
}
.thumb img{
  width:100%;
  height:70px;
  object-fit:cover;
}
.thumb.is-active{
  outline:2px solid rgba(167,139,250,.5);
}

.hintTap{
  width:100%;
  max-width:520px;
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-weight:800;
  font-size:13px;
  text-align:center;
}

/* =========================
   Portfolio
========================= */

.carousels{ display:grid; gap:14px; }

.marquee{
  border-radius:var(--radius2);
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.04);
  overflow:hidden;
  box-shadow:var(--shadow2);
  position:relative;
}
.marquee::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(0,0,0,.62), transparent 18%, transparent 82%, rgba(0,0,0,.62));
  opacity:.62;
}
html[data-theme="light"] .marquee::after{
  background:linear-gradient(90deg, rgba(255,255,255,.78), transparent 18%, transparent 82%, rgba(255,255,255,.78));
  opacity:.80;
}

.marquee__track{
  display:flex;
  gap:12px;
  padding:14px;
  overflow:hidden;
  will-change:transform;
  transform:translate3d(0,0,0);
  user-select:none;
  touch-action:pan-y;
}
.marquee__inner{
  display:flex;
  gap:12px;
  align-items:stretch;
  flex-wrap:nowrap;
  will-change:transform;
}
@keyframes marq-left{
  from{ transform:translate3d(0,0,0); }
  to{ transform:translate3d(-50%,0,0); }
}
@keyframes marq-right{
  from{ transform:translate3d(-50%,0,0); }
  to{ transform:translate3d(0,0,0); }
}
.marquee[data-direction="left"] .marquee__inner{ animation:marq-left 26s linear infinite; }
.marquee[data-direction="right"] .marquee__inner{ animation:marq-right 26s linear infinite; }
.marquee.is-paused .marquee__inner{ animation-play-state:paused; }

.portItem{
  min-width:250px;
  width:250px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--stroke2);
  background:rgba(0,0,0,.18);
  position:relative;
  flex:0 0 auto;
  transition:transform .25s ease;
}
.portItem:hover{ transform:translateY(-2px); }
.portItem img{
  width:100%;
  height:170px;
  object-fit:cover;
  display:block;
  transform:scale(1.06);
  transition:transform .8s ease;
  cursor:zoom-in;
}
.portItem:hover img{ transform:scale(1.12); }
.portItem__cap{
  position:absolute;
  left:10px;
  bottom:10px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--stroke2);
  background:rgba(0,0,0,.32);
  font-weight:900;
  font-size:12px;
}
html[data-theme="light"] .portItem{ background:rgba(0,0,0,.03); }
html[data-theme="light"] .portItem__cap{ background:rgba(255,255,255,.74); }

/* =========================
   Videos
========================= */

.videoGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:start;
}
.videoCard{
  border-radius:var(--radius2);
  border:1px solid var(--stroke2);
  background:var(--card2);
  box-shadow:var(--shadow2);
  overflow:hidden;
  position:relative;
}
.videoCard__top{ padding:14px 14px 0; }
.videoEl{
  width:100%;
  height:360px;
  display:block;
  object-fit:cover;
  background:rgba(0,0,0,.25);
  border-top:1px solid var(--stroke);
  border-bottom:1px solid var(--stroke);
}

/* =========================
   Reviews
========================= */

.reviews{
  display:grid;
  grid-template-columns:52px 1fr 52px;
  gap:14px;
  align-items:center;
  max-width:1040px;
  margin:0 auto;
}
.reviews__nav{
  width:52px;
  height:52px;
  border-radius:18px;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  transition:.2s ease;
  display:grid;
  place-items:center;
}
.reviews__nav:hover{ transform:translateY(-1px); }

.reviewCard{
  border-radius:var(--radius2);
  border:1px solid var(--stroke2);
  background:var(--card2);
  box-shadow:var(--shadow2);
  padding:18px;
  position:relative;
  overflow:hidden;
  transition:opacity .35s ease, transform .35s ease, filter .35s ease;
  will-change:opacity, transform, filter;
  min-height:150px;
}
.reviewCard.is-leaving{
  opacity:0;
  transform:translateY(10px);
  filter:blur(2px);
}
.reviewCard.is-entering{
  opacity:0;
  transform:translateY(-6px);
  filter:blur(2px);
}
.stars{
  display:flex;
  gap:6px;
  opacity:.95;
}
.reviewText{
  margin:10px 0;
  color:var(--muted);
  font-size:15px;
  line-height:1.65;
}
.reviewFoot{
  display:flex;
  justify-content:space-between;
  gap:10px;
  color:var(--muted2);
  font-weight:700;
  font-size:13px;
}
.reviewName{
  color:var(--text);
  font-weight:900;
}

/* =========================
   Form
========================= */

.form{ display:grid; gap:12px; }
.form__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.field label{
  display:block;
  font-weight:900;
  color:var(--text);
  font-size:13px;
  margin-bottom:8px;
}

.input{
  display:flex;
  align-items:center;
  gap:10px;
  border-radius:16px;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.05);
  padding:12px;
  transition:.2s ease;
}
.input input{
  width:100%;
  border:none;
  outline:none;
  background:transparent;
  color:var(--text);
  font-weight:800;
}

.textarea{
  display:flex;
  gap:10px;
  border-radius:16px;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.05);
  padding:12px;
  transition:.2s ease;
}
.textarea textarea{
  width:100%;
  border:none;
  outline:none;
  background:transparent;
  color:var(--text);
  resize:vertical;
  font-weight:800;
  min-height:110px;
}
.form__hint{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
  font-size:13px;
  margin-top:8px;
}
.qa{ display:grid; gap:12px; }
.qa__q{
  font-weight:900;
  color:var(--text);
  display:flex;
  gap:10px;
  align-items:center;
}
.qa__a{
  color:var(--muted);
  margin-top:6px;
  padding-left:26px;
}
html[data-theme="light"] .input,
html[data-theme="light"] .textarea{
  background:rgba(0,0,0,.02);
}

/* =========================
   Contact
========================= */

.contact{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:stretch;
}
.contact__top{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:12px;
}
.contact__info{
  margin-top:12px;
  display:grid;
  gap:10px;
}
.infoRow{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px;
  border-radius:18px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
}
.contactNav{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.map iframe{
  width:100%;
  height:100%;
  min-height:300px;
  border:0;
  border-radius:var(--radius2);
}

/* =========================
   Footer
========================= */

.footer{
  padding:26px 0 32px;
  border-top:1px solid var(--stroke);
  background:rgba(0,0,0,.14);
}
html[data-theme="light"] .footer{ background:rgba(255,255,255,.55); }

.footer__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  color:var(--muted);
  font-weight:800;
}
.footer__left{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  line-height:1.2;
}
.footer__dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  display:inline-block;
}
html[data-theme="light"] .footer__dot{ background:rgba(0,0,0,.18); }
.footer__sep{
  opacity:.45;
  font-weight:900;
}
.footer__by{
  color:var(--muted2);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.footer__link{
  color:var(--text);
  text-decoration:none;
  font-weight:900;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.04);
  transition:.2s ease;
}
.footer__right{
  color:var(--text);
  text-decoration:none;
  font-weight:900;
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
  transition:.2s ease;
  white-space:nowrap;
}

/* =========================
   Reveal
========================= */

.reveal{
  opacity:0;
  transform:translateY(12px);
  filter:blur(2px);
}
.reveal.is-in{
  opacity:1;
  transform:translateY(0);
  filter:blur(0);
  transition:opacity .8s ease, transform .8s ease, filter .8s ease;
}

/* =========================
   Sobre transition
========================= */

#sobre{
  position:relative;
  z-index:3;
  margin-top:-32px;
}
#sobre .wrap{
  transform:translateY(64px);
  opacity:0;
  transition:
    transform .7s cubic-bezier(.22,.61,.36,1),
    opacity .55s ease;
  will-change:transform, opacity;
}
#sobre.is-visible .wrap{
  transform:translateY(0);
  opacity:1;
}
#sobre .sectionCard{
  backdrop-filter:blur(14px);
}

/* =========================
   Lightbox
========================= */

.lb{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
}
.lb.is-on{ display:block; }

.lb__backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(6px);
  animation:lbFade .18s ease;
}
html[data-theme="light"] .lb__backdrop{
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(5px);
}

.lb__panel{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  padding:18px;
}
.lb__img{
  max-width:min(980px, 94vw);
  max-height:84vh;
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 24px 90px rgba(0,0,0,.62);
  animation:lbPop .18s ease;
}
html[data-theme="light"] .lb__img{
  border:1px solid rgba(0,0,0,.12);
}
.lb__close{
  position:absolute;
  top:16px;
  right:16px;
  width:46px;
  height:46px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.35);
  color:rgba(255,255,255,.92);
  cursor:pointer;
  transition:.2s ease;
  display:grid;
  place-items:center;
}
html[data-theme="light"] .lb__close{
  border:1px solid rgba(0,0,0,.14);
  background:rgba(255,255,255,.78);
  color:rgba(10,12,16,.92);
}
.lb__close:hover{ transform:translateY(-1px); }

@keyframes lbFade{
  from{ opacity:0; }
  to{ opacity:1; }
}
@keyframes lbPop{
  from{ transform:scale(.96); opacity:0; filter:blur(2px); }
  to{ transform:scale(1); opacity:1; filter:blur(0); }
}

/* =========================
   Split card
========================= */

.card--split{ overflow:hidden; }
.cardSplit{
  display:grid;
  grid-template-columns:360px 1fr;
  gap:14px;
  align-items:stretch;
}
.cardSplit__media{
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--stroke2);
  background:rgba(255,255,255,.04);
  box-shadow:var(--shadow2);
  cursor:zoom-in;
}
.cardSplit__media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  cursor:zoom-in;
}
.cardSplit__content .card__body{
  padding:14px 16px 16px;
}

/* =========================
   WhatsApp float
========================= */

.waFloat{
  position:fixed;
  right:18px;
  bottom:18px;
  width:58px;
  height:58px;
  border-radius:18px;
  display:grid;
  place-items:center;
  text-decoration:none;
  z-index:12000;
  border:1px solid rgba(56,210,111,.65);
  background:
    radial-gradient(120px 90px at 30% 20%, rgba(255,255,255,.18), transparent 55%),
    linear-gradient(135deg, rgba(56,210,111,.92), rgba(34,211,238,.55));
  box-shadow:
    0 18px 44px rgba(0,0,0,.28),
    0 0 0 6px rgba(56,210,111,.14);
  transition:.2s ease;
  transform:translateZ(0);
  animation:waPulse 1.8s ease-in-out infinite;
}
.waFloat i{
  font-size:27px;
  color:rgba(255,255,255,.96);
}
.waFloat:hover{ transform:translateY(-2px) scale(1.03); }

@keyframes waPulse{
  0%,100%{
    box-shadow:0 18px 44px rgba(0,0,0,.28), 0 0 0 6px rgba(56,210,111,.14);
  }
  50%{
    box-shadow:0 22px 52px rgba(0,0,0,.34), 0 0 0 10px rgba(56,210,111,.18);
  }
}

/* =========================
   Responsive
========================= */

@media (max-width: 980px){
  .grid2{ grid-template-columns:1fr; }
  .studio{
    grid-template-columns:1fr;
    max-width:720px;
  }
  .contact{ grid-template-columns:1fr; }
  .form__grid{ grid-template-columns:1fr; }
  .cardSplit{ grid-template-columns:1fr; }
  .cardSplit__media{ aspect-ratio:3 / 4; }
  .videoGrid{ grid-template-columns:1fr; }

  .topbar__inner{ gap:10px; }
  .nav a{
    padding:10px;
    font-size:13px;
  }
  .topbar__actions .btn span{ display:none; }
  .nav{ display:none !important; }
  .topbar__inner{ justify-content:space-between; }

  .langSwitch{
    padding:8px;
    gap:8px;
  }
  .langBtn{
    width:40px;
    height:40px;
  }

  .hero--fullscreen,
  .hero__grid--introOnly,
  .heroIntro{
    min-height:calc(100svh - 78px);
  }
  .heroIntro__content{ padding:20px; }
  .heroIntro__logo{ width:min(620px, 88vw); }
}

@media (max-width: 720px){
  .bg__img--desktop{ display:none; }
  .bg__img--mobile{ display:block; }

  .hero--fullscreen,
  .hero__grid--introOnly,
  .heroIntro{
    min-height:calc(100svh - 78px);
  }
  .heroIntro__content{ padding:18px; }
  .heroIntro__logo{
    width:min(360px, 86vw);
    max-width:86vw;
  }

  .section{
    padding:46px 0;
    padding-bottom:120px !important;
  }
  .sectionCard__body{ padding-bottom:22px; }

  .studioBig img{ height:280px; }
  .portItem{
    min-width:220px;
    width:220px;
  }
  .portItem img{ height:154px; }

  .videoEl{ height:260px; }

  .footer__inner{
    flex-direction:column;
    align-items:flex-start;
  }
  .footer__right{
    width:100%;
    justify-content:center;
  }

  .topbar{ backdrop-filter:blur(10px); }
  .bg__noise{ opacity:.08; }

  .waFloat{
    width:60px;
    height:60px;
    right:16px;
    bottom:16px;
  }

  .studioCardBody{ padding:14px 14px 16px; }
  .studio,
  .studio__left,
  .studio__right{
    width:100%;
    max-width:100%;
  }
  .studio__left .miniTitle{
    justify-content:center;
    text-align:center;
    gap:8px;
  }
  .studio__left .seg{
    width:100%;
    max-width:520px;
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:10px;
    padding:10px;
    margin:0 auto;
  }
  .studio__left .seg__btn{
    width:100%;
    justify-content:center;
    padding:12px;
    border-radius:14px;
    white-space:nowrap;
    height:46px !important;
  }
  .studio__left .seg > .seg__btn:nth-child(3){
    grid-column:auto !important;
  }

  .studio__left .hours{
    max-width:520px;
    width:100%;
    margin-left:auto;
    margin-right:auto;
  }

  .studioNavBtns--below{
    width:100%;
    max-width:520px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    justify-content:initial;
  }
  .studioNavBtns--below .btn{
    max-width:none;
    width:100%;
  }

  .thumbs{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;
  }
  .thumbs__track{ min-width:420px; }

  #sobre{ margin-top:-18px; }
  #sobre .wrap{ transform:translateY(42px); }

  .introWelcome__text{
    font-size:clamp(24px, 10vw, 46px);
  }
}

@media (prefers-reduced-motion: reduce){
  *{
    animation:none !important;
    transition:none !important;
  }
  .reveal{
    opacity:1;
    transform:none;
    filter:none;
  }
}