/* =========================================================
   Ubee Themes — Site styles
   Mobile-first, system-tokens, minimal editorial
   ========================================================= */

/* Garante que o atributo HTML hidden sempre funcione,
   mesmo quando classes CSS definem display:grid/flex */
[hidden] { display: none !important; }

:root{
  /* Brand */
  --u-primary:#4F46E5;
  --u-primary-dark:#3730A3;
  --u-primary-soft:#EEF2FF;
  --u-secondary:#06B6D4;

  /* Ink scale */
  --u-ink-900:#0B0B14;
  --u-ink-800:#15162B;
  --u-ink-700:#2B2C44;
  --u-ink-600:#454764;
  --u-ink-500:#5B5C75;
  --u-ink-400:#8587A0;
  --u-ink-300:#B8B9CC;
  --u-ink-200:#D6D7E2;
  --u-line:#E7E8F0;
  --u-line-2:#EFF0F6;

  /* Surfaces */
  --u-bg:#FFFFFF;             /* white background */
  --u-paper:#FFFFFF;
  --u-surface:#F7F7FA;

  /* Type */
  --u-sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --u-serif:'Instrument Serif', Georgia, 'Times New Roman', serif;
  --u-mono:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Motion */
  --u-ease:cubic-bezier(.22,.61,.36,1);

  /* Spacing scale (rems mostly) */
  --u-gutter: clamp(20px, 4vw, 32px);
  --u-max: 1280px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}

body{
  margin:0;
  font-family:var(--u-sans);
  font-size:16px;
  line-height:1.55;
  color:var(--u-ink-900);
  background:var(--u-bg);
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img,svg,video{ max-width:100%; display:block; height:auto; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; padding:0; margin:0; }
input,select,textarea{ font:inherit; }

:focus-visible{ outline:2px solid var(--u-primary); outline-offset:3px; border-radius:4px; }

/* Skip link */
.skip-link{
  position:absolute; left:-9999px; top:0; padding:10px 16px;
  background:var(--u-ink-900); color:#fff; font-weight:600; font-size:14px;
  border-radius:0 0 8px 0; z-index:1000;
}
.skip-link:focus{ left:0; }

/* Utility */
.container{ width:100%; max-width:var(--u-max); margin-inline:auto; padding-inline:var(--u-gutter); }
.eyebrow{ font-family:var(--u-mono); font-size:11px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--u-ink-500); }
.mono{ font-family:var(--u-mono); letter-spacing:0; }
.serif{ font-family:var(--u-serif); letter-spacing:-0.015em; font-weight:400; }
em.accent{ font-family:var(--u-serif); font-style:italic; color:var(--u-primary); font-weight:400; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  min-height:44px; padding:0 18px; border-radius:10px;
  font-family:var(--u-sans); font-weight:500; font-size:14px; line-height:1;
  border:1px solid transparent; transition:transform .2s var(--u-ease), background .2s var(--u-ease), border-color .2s var(--u-ease), color .2s var(--u-ease);
  white-space:nowrap; cursor:pointer; text-decoration:none;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--u-ink-900); color:#fff; }
.btn-primary:hover{ background:var(--u-ink-800); }
.btn-accent{ background:var(--u-primary); color:#fff; }
.btn-accent:hover{ background:var(--u-primary-dark); }
.btn-secondary{ background:var(--u-paper); color:var(--u-ink-900); border-color:var(--u-line); }
.btn-secondary:hover{ background:var(--u-surface); border-color:var(--u-ink-300); }
.btn-ghost{ color:var(--u-ink-700); }
.btn-ghost:hover{ color:var(--u-ink-900); }
.btn-lg{ min-height:52px; padding:0 22px; font-size:15px; }
.btn-icon{ width:44px; padding:0; }
.btn .arrow{ transition:transform .2s var(--u-ease); }
.btn:hover .arrow{ transform:translateX(3px); }

/* Pills */
.pill{
  display:inline-flex; align-items:center; gap:8px;
  height:28px; padding:0 12px; border-radius:999px;
  background:var(--u-paper); border:1px solid var(--u-line);
  font-family:var(--u-mono); font-size:11px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:var(--u-ink-700);
}
.pill .dot{ width:6px; height:6px; border-radius:50%; background:var(--u-primary); }

/* =========================================================
   Announcement bar
   ========================================================= */
.bar{
  background:var(--u-ink-900); color:#fff;
  font-size:12px; letter-spacing:.02em;
}
.bar-inner{
  display:flex; align-items:center; justify-content:center; gap:14px;
  min-height:36px; padding:8px 0;
  text-align:center;
}
.bar-inner .mono{ color:rgba(255,255,255,.55); font-size:10px; letter-spacing:.12em; text-transform:uppercase; }
.bar a{ text-decoration:underline; text-underline-offset:3px; text-decoration-color:rgba(255,255,255,.3); }
.bar a:hover{ text-decoration-color:#fff; }
.bar-dots{ display:none; }
@media (min-width: 720px){
  .bar-dots{ display:inline; color:rgba(255,255,255,.3); }
}

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in oklab, var(--u-bg) 88%, transparent);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--u-ease), background .25s var(--u-ease);
}
.site-header.is-scrolled{ border-bottom-color:var(--u-line); }
.header-inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  min-height:64px; padding-block:10px;
}
.brand{ display:inline-flex; align-items:center; gap:10px; }
.brand-mark{ width:32px; height:32px; flex:none; }
.brand-text{ font-family:var(--u-sans); font-weight:700; font-size:18px; letter-spacing:-0.035em; color:var(--u-ink-900); }
.brand-text .dot{ color:var(--u-primary); }
.brand-text .sub{ color:var(--u-ink-500); font-weight:500; }

.nav-primary{ display:none; }
@media (min-width:1024px){
  .nav-primary{ display:flex; gap:28px; }
  .nav-primary a{ font-size:14px; font-weight:500; color:var(--u-ink-700); position:relative; padding:6px 0; transition:color .2s; }
  .nav-primary a::after{
    content:''; position:absolute; left:0; right:0; bottom:0; height:1px;
    background:var(--u-ink-900); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--u-ease);
  }
  .nav-primary a:hover{ color:var(--u-ink-900); }
  .nav-primary a:hover::after{ transform:scaleX(1); }
}

.header-actions{ display:flex; gap:8px; align-items:center; }
.header-cta-desktop{ display:none; }
@media (min-width:1024px){
  .header-cta-desktop{ display:inline-flex; }
}

/* Header icon button (cart, account) */
.icon-btn{
  position:relative;
  width:44px; height:44px; border-radius:10px;
  border:0; background:transparent; color:var(--u-ink-900);
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .2s, color .2s;
}
.icon-btn:hover{ background:var(--u-surface); }
.icon-btn svg{ width:18px; height:18px; }
.icon-btn .cart-count{
  position:absolute; top:-6px; right:-6px;
  min-width:18px; height:18px; padding:0 5px; border-radius:9px;
  background:var(--u-primary); color:#fff;
  font:600 10px/18px var(--u-mono); text-align:center;
  pointer-events:none;
  transition:transform .25s var(--u-ease);
}
.icon-btn .cart-count[hidden]{ display:none; }
.icon-btn.bump .cart-count{ animation: bump .35s var(--u-ease); }
@keyframes bump{
  0%   { transform: scale(1); }
  40%  { transform: scale(1.35); }
  100% { transform: scale(1); }
}
.icon-btn-account{ display:none; }
@media (min-width:720px){ .icon-btn-account{ display:inline-flex; } }

.menu-toggle{
  width:44px; height:44px; display:inline-flex; align-items:center; justify-content:center;
  border-radius:10px; border:1px solid var(--u-line); background:var(--u-paper);
}
.menu-toggle span{
  width:18px; height:1.5px; background:var(--u-ink-900); border-radius:1px;
  position:relative; display:block;
}
.menu-toggle span::before,
.menu-toggle span::after{ content:''; position:absolute; left:0; right:0; height:1.5px; background:var(--u-ink-900); }
.menu-toggle span::before{ top:-6px; }
.menu-toggle span::after{ top:6px; }
@media (min-width:1024px){
  .menu-toggle{ display:none; }
}

/* Mobile drawer */
.mobile-nav{
  position:fixed; inset:0 0 0 auto; width:min(360px, 86vw);
  background:var(--u-paper); z-index:100;
  transform:translateX(100%); transition:transform .35s var(--u-ease);
  display:flex; flex-direction:column;
  box-shadow:-20px 0 60px rgba(11,11,20,.18);
  padding:20px 24px 28px;
}
.mobile-nav.is-open{ transform:translateX(0); }
.mobile-nav-overlay{
  position:fixed; inset:0; background:rgba(11,11,20,.55); z-index:90;
  opacity:0; pointer-events:none; transition:opacity .25s var(--u-ease);
}
.mobile-nav-overlay.is-open{ opacity:1; pointer-events:auto; }
.mobile-nav-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.mobile-nav ul{ display:flex; flex-direction:column; gap:2px; }
.mobile-nav a{
  display:block; padding:14px 4px; font-size:18px; font-weight:500;
  border-bottom:1px solid var(--u-line-2); color:var(--u-ink-900);
}
.mobile-nav a:hover{ color:var(--u-primary); }
.mobile-nav-foot{ margin-top:auto; display:flex; flex-direction:column; gap:10px; }
.close-btn{ width:40px; height:40px; border-radius:10px; border:1px solid var(--u-line); display:inline-flex; align-items:center; justify-content:center; }

/* =========================================================
   Sections
   ========================================================= */
section{ position:relative; }
.section{ padding-block: clamp(56px, 9vw, 112px); }
.section-tight{ padding-block: clamp(40px, 6vw, 72px); }
.section-dark{ background:var(--u-ink-900); color:#fff; }
.section-dark .eyebrow{ color:rgba(255,255,255,.55); }
.section-paper{ background:var(--u-paper); }

.section-head{
  display:flex; flex-direction:column; gap:14px;
  margin-bottom: clamp(32px, 5vw, 56px);
}
.section-head .eyebrow{ display:inline-flex; align-items:center; gap:10px; }
.section-head .eyebrow::before{ content:''; width:18px; height:1px; background:currentColor; opacity:.6; }
.section-head .row{ display:flex; flex-direction:column; gap:14px; align-items:flex-start; }
@media (min-width:880px){
  .section-head .row{ flex-direction:row; justify-content:space-between; align-items:flex-end; gap:48px; }
}

h1,h2,h3,h4{ margin:0; font-weight:600; letter-spacing:-0.02em; }
.h-display{ font-family:var(--u-serif); font-weight:400; letter-spacing:-0.03em; line-height:1; }
.h1{ font-size: clamp(40px, 8vw, 84px); }
.h2{ font-size: clamp(32px, 5.5vw, 56px); }
.h3{ font-size: clamp(24px, 3.4vw, 36px); }
.lede{ font-size: clamp(16px, 1.6vw, 19px); line-height:1.55; color:var(--u-ink-500); }

/* =========================================================
   Hero banner slider — FULL SCREEN
   ========================================================= */
.hero{
  position:relative; padding:0;
  margin-top: 0;
}
.hero > .container{ max-width:none; padding-inline:0; }
.hero-slider{
  position:relative; overflow:hidden;
  background:var(--u-ink-900); color:#fff;
  isolation:isolate;
  /* full viewport minus announcement bar (36) + header (~64) */
  height: calc(100svh - 36px - 64px);
  min-height: 520px;
  border-radius: 0;
}
@media (min-width:720px){
  .hero-slider{ min-height:560px; }
}

.hero-track{
  position:relative;
  display:grid; grid-template-columns:1fr; grid-template-rows:1fr;
  width:100%; height:100%;
}
.hero-slide{
  grid-area: 1 / 1;
  position:relative;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding: clamp(28px, 5vw, 80px);
  padding-bottom: clamp(96px, 11vw, 140px); /* room for controls */
  opacity:0; visibility:hidden;
  transition:visibility 0s linear .6s;
  min-width:0;
}
.hero-slide.is-active{ opacity:1; visibility:visible; transition:visibility 0s; }
.hero-slide-bg{
  position:absolute; inset:0; z-index:-1;
  background: var(--bg, var(--u-ink-900));
}
.hero-slide-bg::before{
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(rgba(255,255,255,.08) 1px, transparent 1.5px);
  background-size: 24px 24px;
  opacity:.5;
}
.hero-slide-bg::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(11,11,20,0) 35%, rgba(11,11,20,.65) 100%);
}
.hero-slide-1 .hero-slide-bg{ background: linear-gradient(135deg, #15162B 0%, #2A1F5A 65%, #4F46E5 100%); }
.hero-slide-2 .hero-slide-bg{ background: linear-gradient(135deg, #0B0B14 0%, #1A2545 60%, #06B6D4 130%); }
.hero-slide-3 .hero-slide-bg{ background: linear-gradient(135deg, #2A1F2F 0%, #4A2247 60%, #C25BB6 130%); }

.hero-slide-tag{ display:inline-flex; align-items:center; gap:10px; margin-bottom:18px;
  font-family:var(--u-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.7);
}
.hero-slide-tag::before{ content:''; width:24px; height:1px; background:rgba(255,255,255,.6); }
.hero-slide h1{
  font-family:var(--u-serif); font-weight:400; letter-spacing:-0.035em; line-height:.96;
  font-size: clamp(44px, 8.5vw, 104px); max-width: 16ch;
  margin-bottom: 22px;
}
.hero-slide h1 em{ font-family:var(--u-serif); font-style:italic; color:rgba(255,255,255,.85); }
.hero-slide p{
  margin:0 0 28px; max-width: 46ch;
  font-size: clamp(15px, 1.5vw, 17px); line-height:1.55; color:rgba(255,255,255,.75);
}
.hero-slide-cta{ display:flex; flex-wrap:wrap; gap:10px; }
.hero-slide-cta .btn-secondary{ background:transparent; border-color:rgba(255,255,255,.2); color:#fff; }
.hero-slide-cta .btn-secondary:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.4); }
.hero-slide-cta .btn-primary{ background:#fff; color:var(--u-ink-900); }
.hero-slide-cta .btn-primary:hover{ background:rgba(255,255,255,.85); }

/* Decorative layered marks in hero */
.hero-deco{
  position:absolute; top:0; right:-10%; width:60%; max-width:560px;
  opacity:.18; pointer-events:none; z-index:0;
}
@media (min-width:720px){
  .hero-deco{ right:-2%; width:48%; opacity:.22; }
}

/* Hero controls */
.hero-controls{
  position:absolute; left: clamp(24px, 5vw, 80px); right: clamp(24px, 5vw, 80px);
  bottom: clamp(28px, 4vw, 48px);
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  z-index:5;
}
.hero-dots{ display:flex; gap:8px; align-items:center; }
.hero-dot{
  width:32px; height:3px; border-radius:2px;
  background:rgba(255,255,255,.25); border:0; cursor:pointer;
  position:relative; overflow:hidden;
}
.hero-dot[aria-current="true"]{ background:rgba(255,255,255,.35); }
.hero-dot[aria-current="true"]::after{
  content:''; position:absolute; left:0; top:0; bottom:0; width:0;
  background:#fff;
  animation: hero-progress 6s linear forwards;
}
.hero-paused .hero-dot[aria-current="true"]::after{ animation-play-state:paused; }
@keyframes hero-progress{ to { width:100%; } }

.hero-arrows{ display:flex; gap:8px; }
.hero-arrow{
  width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.05);
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; transition:background .2s, border-color .2s, transform .2s;
}
.hero-arrow:hover{ background:rgba(255,255,255,.15); border-color:rgba(255,255,255,.5); }
.hero-arrow svg{ width:18px; height:18px; }

.hero-counter{
  position:absolute; top: clamp(24px, 4vw, 56px); right: clamp(24px, 5vw, 80px);
  font-family:var(--u-mono); font-size:12px; color:rgba(255,255,255,.7);
  letter-spacing:.08em; z-index:5;
}
.hero-counter b{ color:#fff; font-weight:600; }

/* =========================================================
   Logos marquee / proof
   ========================================================= */
/* Régua de benefícios */
.benefits-bar{
  padding-block: clamp(22px, 3.5vw, 40px);
  border-block: 1px solid var(--u-line);
  background: var(--u-surface);
}
.benefits-list{
  display: flex; flex-wrap: wrap;
  gap: clamp(16px, 2.5vw, 0px);
  list-style: none; padding: 0; margin: 0;
  justify-content: space-between;
}
.benefit-item{
  display: flex; align-items: center; gap: 12px;
  flex: 1 1 180px;
  padding: 0 clamp(12px, 2vw, 28px);
  border-right: 1px solid var(--u-line);
}
.benefit-item:last-child{ border-right: none; }
.benefit-item svg{
  flex-shrink: 0; color: var(--u-primary);
}
.benefit-item div{
  display: flex; flex-direction: column; gap: 2px;
}
.benefit-item strong{
  font-size: clamp(13px, 1.1vw, 15px); font-weight: 700;
  color: var(--u-ink-900); white-space: nowrap;
}
.benefit-item span{
  font-size: clamp(11px, .9vw, 13px); color: var(--u-ink-400);
  white-space: nowrap;
}
@media (max-width: 768px){
  .benefit-item{ border-right: none; flex: 1 1 45%; }
  .benefits-list{ gap: 16px; }
}
@media (max-width: 480px){
  .benefit-item{ flex: 1 1 100%; }
}

/* =========================================================
   Segments — themes by category
   ========================================================= */
.segments-tabs{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-block: 24px clamp(24px, 4vw, 40px);
}
.tab-chip{
  flex:none; scroll-snap-align:start;
  display:inline-flex; align-items:center; gap:8px;
  height:38px; padding:0 16px; border-radius:999px;
  background:var(--u-paper); border:1px solid var(--u-line);
  font-size:13px; font-weight:500; color:var(--u-ink-700);
  transition:all .2s var(--u-ease); cursor:pointer; white-space:nowrap;
}
.tab-chip .num{ font-family:var(--u-mono); font-size:11px; color:var(--u-ink-400); }
.tab-chip:hover{ border-color:var(--u-ink-300); color:var(--u-ink-900); }
.tab-chip[aria-selected="true"]{ background:var(--u-ink-900); color:#fff; border-color:var(--u-ink-900); }
.tab-chip[aria-selected="true"] .num{ color:rgba(255,255,255,.55); }

.segment-panel{ display:none; }
.segment-panel.is-active{ display:block; }

.themes-slider{
  position:relative;
}
.themes-track{
  display:grid; grid-auto-flow:column; grid-auto-columns:min(82vw, 320px);
  gap:16px;
  overflow-x:auto; overflow-y:hidden;
  scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
  padding-bottom:6px;
  scrollbar-width:none;
}
.themes-track::-webkit-scrollbar{ display:none; }
@media (min-width:720px){
  .themes-track{ grid-auto-columns: minmax(280px, 1fr); gap:20px;
    grid-auto-flow:column; }
}
@media (min-width:1024px){
  .themes-track{ grid-auto-columns: calc((100% - 2 * 20px) / 3.1); gap:20px; }
}

.theme-card{
  scroll-snap-align:start;
  background:var(--u-paper); border:1px solid var(--u-line); border-radius:16px;
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .25s var(--u-ease), border-color .2s var(--u-ease), box-shadow .25s var(--u-ease);
  position:relative;
}
.theme-card:hover{
  transform:translateY(-4px); border-color:var(--u-ink-300);
  box-shadow:0 18px 40px -20px rgba(11,11,20,.18);
}
.theme-thumb{
  aspect-ratio: 4/3;
  background: var(--accent, var(--u-ink-800));
  position:relative; overflow:hidden;
  display:flex; align-items:flex-end; padding:18px;
}
.theme-thumb::before{
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px);
  background-size: 32px 32px;
  opacity:.6;
}
.theme-mock{
  position:relative; width:100%;
  background:#fff; border-radius:8px; box-shadow:0 10px 30px -10px rgba(11,11,20,.25);
  padding:10px; transform:translateY(16px);
}
.theme-mock-bar{ height:6px; background:var(--u-line-2); border-radius:3px; margin-bottom:8px; width:35%; }
.theme-mock-hero{ aspect-ratio:16/7; border-radius:6px; background:var(--accent, var(--u-ink-700)); margin-bottom:8px; opacity:.85; }
.theme-mock-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:6px; }
.theme-mock-grid div{ aspect-ratio:1; border-radius:4px; background:var(--u-line-2); }
.theme-tag{
  position:absolute; top:14px; left:14px; z-index:2;
  height:24px; padding:0 10px; border-radius:999px; background:#fff;
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--u-mono); font-size:10px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--u-ink-900);
}
.theme-tag--tray{
  background:#fff; color:var(--u-ink-900);
}
.theme-add--tray{
  background:var(--u-ink-900) !important; border-color:var(--u-ink-900) !important; color:#fff !important;
}
.theme-add--tray:hover{ background:var(--u-ink-800) !important; border-color:var(--u-ink-800) !important; }

.theme-meta{ padding:18px; display:flex; flex-direction:column; gap:8px; flex:1; }
.theme-meta-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.theme-name{ font-size:18px; font-weight:600; letter-spacing:-0.02em; }
.theme-sub{ font-size:13px; color:var(--u-ink-500); }
.theme-platforms{ display:inline-flex; gap:6px; flex-wrap:wrap; }
.theme-platforms span{
  font-family:var(--u-mono); font-size:10px; font-weight:500; letter-spacing:.06em;
  padding:3px 7px; border-radius:4px; background:var(--u-surface); color:var(--u-ink-600); border:1px solid var(--u-line);
  text-transform:uppercase;
}
.theme-platforms span[data-soon="true"]{
  background:#FFF7ED; color:#92400E; border-color:#FCD9A8;
  position:relative;
}
.theme-platforms span[data-soon="true"]::after{
  content:' · soon'; opacity:.7; font-size:9px; margin-left:2px; text-transform:lowercase;
}
.theme-foot{ display:flex; flex-direction:column; align-items:stretch; margin-top:auto; padding-top:10px; border-top:1px dashed var(--u-line); gap:4px; }
.theme-price{ font-family:var(--u-mono); font-size:15px; font-weight:600; }
.theme-price s{ color:var(--u-ink-400); margin-right:6px; font-weight:400; font-size:12px; }
.theme-installment{ font-family:var(--u-sans); font-size:12px; line-height:1.3; color:var(--u-ink-500); }
.theme-installment b{ font-weight:500; color:var(--u-ink-700); }

.theme-actions{
  display:flex; gap:8px; padding: 0 18px 18px;
}
.theme-add{
  flex:1; min-height:40px; padding:0 14px; border-radius:10px;
  background:var(--u-ink-900); color:#fff;
  font-family:var(--u-sans); font-weight:500; font-size:13px;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:1px solid var(--u-ink-900);
  transition:background .2s, border-color .2s, color .2s, transform .15s;
  cursor:pointer;
}
.theme-add:hover{ background:var(--u-ink-800); border-color:var(--u-ink-800); }
.theme-add.is-added{ background:var(--u-paper); color:var(--u-ink-900); border-color:var(--u-ink-900); }
.theme-add svg{ width:14px; height:14px; }
.theme-demo{
  width:40px; height:40px; flex:none; border-radius:10px;
  border:1px solid var(--u-line); background:var(--u-paper); color:var(--u-ink-700);
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
}
.theme-demo:hover{ background:var(--u-surface); border-color:var(--u-ink-300); color:var(--u-ink-900); }
.theme-demo svg{ width:16px; height:16px; }

/* slider arrows (desktop only over header) */
.slider-arrows{ display:flex; gap:8px; }
.slider-arrow{
  width:40px; height:40px; border-radius:50%;
  background:var(--u-paper); border:1px solid var(--u-line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--u-ink-900); transition:background .2s, border-color .2s;
}
.slider-arrow:hover{ background:var(--u-surface); border-color:var(--u-ink-300); }
.slider-arrow[aria-disabled="true"]{ opacity:.4; pointer-events:none; }
.slider-arrow svg{ width:18px; height:18px; }

/* =========================================================
   Cart drawer
   ========================================================= */
.cart-drawer{
  position:fixed; top:0; right:0; bottom:0;
  width:min(440px, 92vw);
  background:var(--u-paper);
  z-index:120;
  transform: translateX(100%);
  transition: transform .35s var(--u-ease);
  display:flex; flex-direction:column;
  box-shadow:-20px 0 60px rgba(11,11,20,.2);
}
.cart-drawer.is-open{ transform:translateX(0); }
.cart-drawer-overlay{
  position:fixed; inset:0; background:rgba(11,11,20,.55); z-index:110;
  opacity:0; pointer-events:none; transition:opacity .25s var(--u-ease);
}
.cart-drawer-overlay.is-open{ opacity:1; pointer-events:auto; }
.cart-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 20px 24px; border-bottom:1px solid var(--u-line);
}
.cart-head-title{
  display:flex; align-items:center; gap:10px;
  font-size:16px; font-weight:600; letter-spacing:-0.01em;
}
.cart-head-title .pill{ height:22px; font-size:10px; padding:0 8px; }
.cart-body{
  flex:1; overflow-y:auto; padding: 16px 20px;
  display:flex; flex-direction:column; gap:12px;
}
.cart-empty{
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; gap:14px; padding:40px 24px;
}
.cart-empty-ico{
  width:64px; height:64px; border-radius:50%; background:var(--u-surface);
  display:inline-flex; align-items:center; justify-content:center; color:var(--u-ink-400);
}
.cart-empty h3{ font-size:18px; font-weight:600; letter-spacing:-0.01em; }
.cart-empty p{ margin:0; color:var(--u-ink-500); font-size:14px; }
.cart-item{
  display:flex; gap:12px; padding:14px;
  border:1px solid var(--u-line); border-radius:12px; background:var(--u-paper);
}
.cart-item-thumb{
  width:64px; height:64px; flex:none; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font:700 22px/1 var(--u-sans); letter-spacing:-0.03em;
}
.cart-item-body{ flex:1; min-width:0; display:flex; flex-direction:column; gap:6px; }
.cart-item-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.cart-item-name{ font-size:14px; font-weight:600; letter-spacing:-0.01em; }
.cart-item-sub{ font-size:12px; color:var(--u-ink-500); }
.cart-item-remove{
  width:24px; height:24px; border-radius:6px;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--u-ink-400);
}
.cart-item-remove:hover{ background:var(--u-surface); color:var(--u-ink-900); }
.cart-item-foot{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
}
.cart-item-license{
  height:28px; border-radius:6px; border:1px solid var(--u-line); background:var(--u-paper);
  padding:0 8px; font-size:12px; color:var(--u-ink-700); cursor:pointer;
}
.cart-item-license-note{
  font-family:var(--u-mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--u-ink-500);
  padding:4px 8px; border-radius:6px; background:var(--u-surface); border:1px solid var(--u-line);
}
.cart-item-price{ font-family:var(--u-mono); font-size:14px; font-weight:600; }
.cart-foot{
  border-top:1px solid var(--u-line); padding: 18px 24px 24px;
  display:flex; flex-direction:column; gap:12px;
}
.cart-foot-row{ display:flex; justify-content:space-between; font-size:13px; color:var(--u-ink-500); }
.cart-foot-row.total{ font-size:18px; font-weight:700; color:var(--u-ink-900); }
.cart-foot-row.total span:last-child{ font-family:var(--u-mono); }
.cart-foot small{
  text-align:center; font-size:11px; color:var(--u-ink-500);
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.cart-foot small svg{ width:12px; height:12px; }

/* Service banners (cross-sell) */
.services-grid{
  display:grid; gap:16px;
  grid-template-columns: 1fr;
  margin-top: clamp(32px, 5vw, 48px);
}
@media (min-width:880px){
  .services-grid{ grid-template-columns: 1fr 1fr; gap:20px; }
}
.service-banner{
  position:relative; overflow:hidden;
  border-radius:18px; color:#fff;
  padding: clamp(28px, 4vw, 44px);
  display:flex; flex-direction:column; gap:18px;
  min-height: 440px;
  isolation:isolate;
}
.service-banner.svc-install{ background: linear-gradient(135deg, #15162B 0%, #2A1F5A 55%, #4F46E5 130%); }
.service-banner.svc-banners{ background: linear-gradient(135deg, #0B1F2E 0%, #0E4754 55%, #06B6D4 130%); }
.service-banner::before{
  content:''; position:absolute; inset:0; z-index:-1;
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1.5px);
  background-size: 24px 24px;
  opacity:.5; pointer-events:none;
}
.service-banner .tag{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--u-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.7);
}
.service-banner .tag::before{ content:''; width:24px; height:1px; background:rgba(255,255,255,.6); }
.service-banner h3{
  font-family:var(--u-serif); font-weight:400; letter-spacing:-0.03em; line-height:1;
  font-size: clamp(28px, 3.4vw, 40px); max-width: 14ch;
}
.service-banner h3 em{ font-family:var(--u-serif); font-style:italic; color:rgba(255,255,255,.75); }
.service-banner > p{ margin:0; max-width: 44ch; color:rgba(255,255,255,.78); font-size:14.5px; line-height:1.55; }
.service-banner ul{ display:flex; flex-direction:column; gap:8px; margin:0; }
.service-banner li{ display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.88); font-size:13.5px; }
.service-banner li svg{ width:14px; height:14px; flex:none; }
.service-banner.svc-install li svg{ color:#A5B4FC; }
.service-banner.svc-banners li svg{ color:#67E8F9; }
.service-banner .price-row{
  display:flex; align-items:baseline; gap:10px;
  padding-top:18px; margin-top:auto;
  border-top:1px solid rgba(255,255,255,.15);
}
.service-banner .price{ font-family:var(--u-sans); font-weight:600; font-size: clamp(32px, 3.8vw, 44px); letter-spacing:-0.03em; }
.service-banner .price-sub{ font-family:var(--u-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.6); }
.service-banner .meta{ font-size:13px; color:rgba(255,255,255,.7); line-height:1.5; margin:0; }
.service-banner .add-btn{
  min-height:48px; padding:0 22px; border-radius:12px;
  background:#fff; color:var(--u-ink-900);
  font-family:var(--u-sans); font-weight:600; font-size:14px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border:0; cursor:pointer; width:100%;
  transition:background .2s, transform .15s;
}
.service-banner .add-btn:hover{ background:rgba(255,255,255,.88); }
.service-banner .add-btn.is-added{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,.4); }
.service-banner .add-btn svg{ width:16px; height:16px; }

/* Modal addon toggle cards */
.modal-addons{ display:flex; flex-direction:column; gap:10px; }
.modal-addon{
  display:flex; align-items:flex-start; gap:12px;
  padding:16px; border:1px solid var(--u-line); border-radius:12px;
  background:var(--u-paper); cursor:pointer; user-select:none;
  transition:border-color .15s, background .15s;
}
.modal-addon:hover{ border-color:var(--u-ink-300); }
.modal-addon input{ position:absolute; opacity:0; pointer-events:none; }
.modal-addon .checkbox{
  width:20px; height:20px; flex:none; margin-top:2px;
  border:1.5px solid var(--u-ink-300); border-radius:6px;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .15s, border-color .15s;
}
.modal-addon .checkbox svg{ width:14px; height:14px; color:#fff; opacity:0; transition:opacity .15s; }
.modal-addon.is-checked{ border-color:var(--u-ink-900); background:var(--u-surface); }
.modal-addon.is-checked .checkbox{ background:var(--u-ink-900); border-color:var(--u-ink-900); }
.modal-addon.is-checked .checkbox svg{ opacity:1; }
.modal-addon-body{ flex:1; display:flex; justify-content:space-between; align-items:flex-start; gap:14px; min-width:0; }
.modal-addon-l b{ display:block; font-size:14px; font-weight:600; letter-spacing:-0.01em; }
.modal-addon-l span{ font-size:12px; color:var(--u-ink-500); line-height:1.4; display:block; margin-top:2px; }
.modal-addon-r{ text-align:right; flex:none; }
.modal-addon-r b{ font-family:var(--u-mono); font-size:16px; font-weight:600; }
.modal-addon-r span{ display:block; font-family:var(--u-mono); font-size:10px; color:var(--u-ink-500); letter-spacing:.08em; text-transform:uppercase; }

.modal-summary{
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  padding: 12px 16px; border-radius:10px; background:var(--u-surface);
  font-size:13px; color:var(--u-ink-700);
}
.modal-summary b{ font-family:var(--u-mono); font-size:16px; color:var(--u-ink-900); }

/* =========================================================
   Modal (cross-sell)
   ========================================================= */
.modal-overlay{
  position:fixed; inset:0; z-index:140;
  background:rgba(11,11,20,.55);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity .25s var(--u-ease);
}
.modal-overlay.is-open{ opacity:1; pointer-events:auto; }
.modal{
  width:min(540px, 100%);
  background:var(--u-paper);
  border-radius:18px;
  box-shadow: 0 30px 80px -20px rgba(11,11,20,.4);
  padding: clamp(28px, 4vw, 40px);
  display:flex; flex-direction:column; gap:18px;
  transform: translateY(20px) scale(.97);
  transition: transform .3s var(--u-ease);
}
.modal-overlay.is-open .modal{ transform:translateY(0) scale(1); }
.modal-head{ display:flex; gap:14px; align-items:flex-start; }
.modal-icon{
  width:48px; height:48px; flex:none; border-radius:12px;
  background:var(--u-primary-soft); color:var(--u-primary);
  display:inline-flex; align-items:center; justify-content:center;
}
.modal-icon svg{ width:24px; height:24px; }
.modal h3{ font-family:var(--u-serif); font-weight:400; font-size: clamp(24px, 2.8vw, 32px); letter-spacing:-0.02em; line-height:1.05; }
.modal-sub{ color:var(--u-ink-500); font-size:14px; margin-top:4px; }
.modal-body{ color:var(--u-ink-700); font-size:15px; line-height:1.6; margin:0; }
.modal-card{
  display:flex; justify-content:space-between; align-items:center; gap:14px;
  padding: 18px 20px; border:1px solid var(--u-line); border-radius:12px;
  background:var(--u-surface);
}
.modal-card .l{ display:flex; flex-direction:column; gap:2px; }
.modal-card .l b{ font-size:14px; font-weight:600; letter-spacing:-0.01em; }
.modal-card .l span{ font-size:12px; color:var(--u-ink-500); }
.modal-card .r{ text-align:right; }
.modal-card .r b{ font-family:var(--u-mono); font-size:18px; font-weight:600; }
.modal-card .r span{ display:block; font-family:var(--u-mono); font-size:10px; color:var(--u-ink-500); letter-spacing:.08em; text-transform:uppercase; }
.modal-actions{ display:flex; gap:10px; flex-direction:column; margin-top:4px; }
@media (min-width:560px){ .modal-actions{ flex-direction:row-reverse; } .modal-actions .btn{ flex:1; } }
.modal-close{
  position:absolute; top:14px; right:14px;
  width:36px; height:36px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--u-ink-500); background:transparent;
}
.modal-close:hover{ background:var(--u-surface); color:var(--u-ink-900); }
.modal{ position:relative; }

/* Cart item: hide license for fixed items */
.cart-item[data-fixed="true"] .cart-item-license{ display:none; }
.cart-item[data-fixed="true"] .cart-item-foot{ justify-content:flex-end; }

/* =========================================================
   Checkout overlay
   ========================================================= */
.checkout-overlay{
  position:fixed; inset:0; z-index:130;
  background:var(--u-bg); color:var(--u-ink-900);
  overflow-y:auto;
  opacity:0; pointer-events:none;
  transition:opacity .3s var(--u-ease);
}
.checkout-overlay.is-open{ opacity:1; pointer-events:auto; }
.checkout-header{
  position:sticky; top:0; z-index:5;
  background:var(--u-bg);
  border-bottom:1px solid var(--u-line);
}
.checkout-header-inner{
  max-width: 1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding: 16px clamp(20px, 4vw, 32px);
}
.checkout-back{
  display:inline-flex; align-items:center; gap:8px;
  font-size:14px; color:var(--u-ink-700); font-weight:500;
  padding:8px 0;
}
.checkout-back:hover{ color:var(--u-ink-900); }
.checkout-steps{ display:none; }
@media (min-width:720px){
  .checkout-steps{ display:flex; gap:32px; font-family:var(--u-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--u-ink-400); }
  .checkout-steps b{ color:var(--u-ink-900); font-weight:600; }
}

.checkout-body{
  max-width: 1200px; margin: 0 auto;
  padding: clamp(28px, 4vw, 56px) clamp(20px, 4vw, 32px);
  display:grid; gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width:980px){
  .checkout-body{ grid-template-columns: 1fr 400px; gap: 40px; align-items:start; }
}

.checkout-main{ display:flex; flex-direction:column; gap:16px; }

.checkout-card{
  background:var(--u-paper); border:1px solid var(--u-line); border-radius:16px;
  padding: clamp(24px, 3vw, 32px);
}
.checkout-card h2{
  font-family:var(--u-serif); font-size: clamp(22px, 2.6vw, 28px); font-weight:400; letter-spacing:-0.02em;
  margin-bottom: 18px;
}
.checkout-card h2 .num{
  font-family:var(--u-mono); font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--u-ink-400); margin-right:10px;
}

.field-grid{ display:grid; gap:14px; grid-template-columns:1fr; }
@media (min-width:560px){ .field-grid{ grid-template-columns:1fr 1fr; } }
.field-grid .full{ grid-column:1/-1; }
.field-row{ display:flex; flex-direction:column; gap:6px; }
.field-row label{ font-size:12px; font-weight:500; color:var(--u-ink-700); }
.field-row input,
.field-row select{
  height:44px; padding:0 14px; border:1px solid var(--u-line); border-radius:10px;
  background:var(--u-paper); color:var(--u-ink-900); font-size:14px; outline:none;
  transition:border-color .15s, box-shadow .15s;
  width:100%;
}
.field-row input:focus,
.field-row select:focus{ border-color:var(--u-primary); box-shadow:0 0 0 3px rgba(79,70,229,.12); }

/* Payment methods */
.pm-tabs{
  display:grid; gap:10px;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom:18px;
}
.pm-tab{
  display:flex; flex-direction:column; align-items:flex-start; gap:8px;
  padding:18px 16px; border:1.5px solid var(--u-line); border-radius:12px;
  background:var(--u-paper); cursor:pointer; text-align:left;
  transition:border-color .2s, background .2s;
}
.pm-tab:hover{ border-color:var(--u-ink-300); }
.pm-tab.is-active{ border-color:var(--u-ink-900); background:var(--u-surface); }
.pm-tab svg{ width:24px; height:24px; color:var(--u-ink-700); }
.pm-tab.is-active svg{ color:var(--u-primary); }
.pm-tab b{ font-size:14px; font-weight:600; letter-spacing:-0.01em; display:block; }
.pm-tab span{ font-size:11px; color:var(--u-ink-500); }

.pm-content{ display:none; }
.pm-content.is-active{ display:block; }

/* PIX */
.pix-block{
  display:grid; gap:20px;
  grid-template-columns: 1fr;
  padding:24px; background:var(--u-surface); border-radius:12px;
}
@media (min-width:560px){ .pix-block{ grid-template-columns: 200px 1fr; align-items:center; } }
.pix-qr{
  width:200px; height:200px; padding:14px;
  background:#fff; border:1px solid var(--u-line); border-radius:12px;
  margin:0 auto;
}
.pix-qr svg{ width:100%; height:100%; }
.pix-info b{ display:block; font-size:14px; font-weight:600; margin-bottom:4px; }
.pix-info p{ margin:0 0 12px; font-size:13px; color:var(--u-ink-500); line-height:1.5; }
.pix-code{
  display:flex; gap:8px;
  background:#fff; border:1px solid var(--u-line); border-radius:10px;
  padding:10px 12px;
  font-family:var(--u-mono); font-size:11px;
  align-items:center;
}
.pix-code code{
  flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  font-family:var(--u-mono); font-size:11px; color:var(--u-ink-700);
}
.pix-code button{
  font-family:var(--u-sans); font-size:12px; font-weight:600;
  color:var(--u-primary); white-space:nowrap;
  padding:4px 8px;
}

/* Boleto */
.boleto-block{
  display:flex; flex-direction:column; gap:14px;
  padding:24px; background:var(--u-surface); border-radius:12px;
}
.boleto-block .row{ display:flex; align-items:center; gap:14px; }
.boleto-block .ico{
  width:48px; height:48px; flex:none; border-radius:12px;
  background:#FFF7ED; color:#92400E;
  display:inline-flex; align-items:center; justify-content:center;
}
.boleto-block .ico svg{ width:24px; height:24px; }
.boleto-block b{ font-size:14px; font-weight:600; display:block; margin-bottom:2px; }
.boleto-block p{ margin:0; font-size:13px; color:var(--u-ink-500); line-height:1.5; }

/* Card */
.card-form{ display:grid; gap:14px; grid-template-columns:1fr; }
@media (min-width:560px){ .card-form{ grid-template-columns:1fr 1fr; } }
.card-form .full{ grid-column:1/-1; }

/* Summary side */
.checkout-side{ display:flex; flex-direction:column; gap:16px; position:sticky; top:88px; }
.summary-card{
  background:var(--u-paper); border:1px solid var(--u-line); border-radius:16px;
  padding: 24px; display:flex; flex-direction:column; gap:18px;
}
.summary-card h3{
  font-family:var(--u-serif); font-size:22px; font-weight:400; letter-spacing:-0.02em;
}
.summary-items{ display:flex; flex-direction:column; gap:14px; }
.summary-item{
  display:flex; gap:12px; align-items:flex-start;
  padding-bottom:14px; border-bottom:1px dashed var(--u-line);
}
.summary-item:last-of-type{ border-bottom:0; padding-bottom:0; }
.summary-item-thumb{
  width:40px; height:40px; flex:none; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font:700 14px/1 var(--u-sans);
}
.summary-item-body{ flex:1; min-width:0; }
.summary-item-name{ font-size:13px; font-weight:600; letter-spacing:-0.01em; }
.summary-item-sub{ font-size:11px; color:var(--u-ink-500); margin-top:2px; }
.summary-item-price{ font-family:var(--u-mono); font-size:13px; font-weight:600; }

.coupon-block{ display:flex; flex-direction:column; gap:8px; }
.coupon-block label{ font-size:12px; font-weight:500; color:var(--u-ink-700); }
.coupon-row{ display:flex; gap:8px; }
.coupon-row input{
  flex:1; height:42px; padding:0 12px; border:1px solid var(--u-line); border-radius:10px;
  background:var(--u-paper); color:var(--u-ink-900); font-size:13px; text-transform:uppercase;
  letter-spacing:.04em; font-family:var(--u-mono); outline:none;
  transition:border-color .15s, box-shadow .15s;
}
.coupon-row input:focus{ border-color:var(--u-primary); box-shadow:0 0 0 3px rgba(79,70,229,.12); }
.coupon-row button{
  height:42px; padding:0 18px; border-radius:10px;
  background:var(--u-ink-900); color:#fff;
  font-family:var(--u-sans); font-weight:500; font-size:13px;
  border:0; cursor:pointer; white-space:nowrap;
}
.coupon-row button:hover{ background:var(--u-ink-800); }
.coupon-feedback{ font-size:12px; line-height:1.4; }
.coupon-feedback.success{ color:#15803D; display:flex; align-items:center; gap:6px; }
.coupon-feedback.error{ color:#B91C1C; }
.coupon-feedback svg{ width:14px; height:14px; flex:none; }

.summary-totals{ display:flex; flex-direction:column; gap:8px; padding-top:14px; border-top:1px solid var(--u-line); }
.summary-totals .row{ display:flex; justify-content:space-between; font-size:13px; color:var(--u-ink-500); }
.summary-totals .row.discount{ color:#15803D; }
.summary-totals .row.total{ font-size:18px; font-weight:700; color:var(--u-ink-900); padding-top:8px; border-top:1px solid var(--u-line-2); margin-top:4px; }
.summary-totals .row.total span:last-child{ font-family:var(--u-mono); }
.summary-totals .row .mono-l{ font-family:var(--u-mono); }

.checkout-submit{
  min-height:52px; padding:0 22px; border-radius:12px;
  background:var(--u-primary); color:#fff;
  font-family:var(--u-sans); font-weight:600; font-size:15px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border:0; cursor:pointer; width:100%;
  transition:background .2s;
}
.checkout-submit:hover{ background:var(--u-primary-dark); }
.checkout-submit svg{ width:16px; height:16px; }

.checkout-trust{
  font-size:11px; color:var(--u-ink-500);
  display:flex; align-items:center; justify-content:center; gap:8px; text-align:center;
}
.checkout-trust svg{ width:13px; height:13px; }

/* Success */
.checkout-success{
  max-width: 560px; margin: 0 auto;
  padding: clamp(48px, 8vw, 96px) 24px;
  text-align:center;
}
.checkout-success .ico{
  width:80px; height:80px; border-radius:50%;
  background:#F0FDF4; color:#15803D;
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:24px;
}
.checkout-success .ico svg{ width:36px; height:36px; }
.checkout-success h2{
  font-family:var(--u-serif); font-size: clamp(32px, 5vw, 48px); font-weight:400; letter-spacing:-0.025em;
  line-height:1; margin-bottom:14px;
}
.checkout-success p{ color:var(--u-ink-500); font-size:16px; margin-bottom:32px; line-height:1.55; }
.checkout-success .order-num{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--u-mono); font-size:13px;
  padding:10px 16px; border-radius:10px;
  background:var(--u-surface); border:1px solid var(--u-line);
  margin-bottom:32px;
}
.checkout-success .actions{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }

/* =========================================================
   Client panel overlay
   ========================================================= */
.client-overlay{
  position:fixed; inset:0; z-index:130;
  background:var(--u-bg); color:var(--u-ink-900);
  overflow-y:auto;
  opacity:0; pointer-events:none;
  transition:opacity .3s var(--u-ease);
}
.client-overlay.is-open{ opacity:1; pointer-events:auto; }

.client-header{
  position:sticky; top:0; z-index:5;
  background:var(--u-bg); border-bottom:1px solid var(--u-line);
}
.client-header-inner{
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding: 16px clamp(20px, 4vw, 32px);
}
.client-user{
  display:flex; align-items:center; gap:12px;
}
.client-user-avatar{
  width:36px; height:36px; border-radius:50%;
  background:var(--u-primary); color:#fff;
  font:600 14px/1 var(--u-sans);
  display:inline-flex; align-items:center; justify-content:center;
}
.client-user-info{ display:none; }
@media (min-width:560px){
  .client-user-info{ display:flex; flex-direction:column; gap:2px; }
  .client-user-info b{ font-size:13px; font-weight:600; letter-spacing:-0.01em; }
  .client-user-info span{ font-size:11px; color:var(--u-ink-500); font-family:var(--u-mono); }
}

/* Auth wall do painel do cliente */
.cp-auth-inner{
  display:flex; align-items:center; justify-content:center;
  min-height:calc(100vh - 72px);
  padding: clamp(32px,5vw,64px) clamp(16px,4vw,32px);
}
.cp-auth-card{
  width:100%; max-width:480px;
}

.client-body{
  max-width:1280px; margin:0 auto;
  padding: clamp(28px, 4vw, 56px) clamp(20px, 4vw, 32px);
  display:grid; gap:20px;
  grid-template-columns:1fr;
}
@media (min-width:880px){
  .client-body{ grid-template-columns: 240px 1fr; gap:32px; align-items:start; }
}

.client-sidebar{
  display:flex; flex-direction:column; gap:4px;
  position:sticky; top:88px;
}
.client-sidebar h4{
  font-family:var(--u-mono); font-size:11px; font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  color:var(--u-ink-400); margin: 8px 12px 8px;
}
.client-nav-item{
  display:flex; align-items:center; gap:10px;
  padding: 12px 14px; border-radius:10px;
  font-size:14px; font-weight:500; color:var(--u-ink-700);
  background:transparent; border:0; cursor:pointer; text-align:left;
  transition:background .2s, color .2s;
}
.client-nav-item:hover{ background:var(--u-surface); color:var(--u-ink-900); }
.client-nav-item.is-active{ background:var(--u-ink-900); color:#fff; }
.client-nav-item svg{ width:18px; height:18px; flex:none; }
.client-nav-item .badge{
  margin-left:auto; min-width:22px; height:22px; padding:0 7px; border-radius:11px;
  background:var(--u-primary-soft); color:var(--u-primary);
  font-family:var(--u-mono); font-size:10px; font-weight:600;
  display:inline-flex; align-items:center; justify-content:center;
}
.client-nav-item.is-active .badge{ background:rgba(255,255,255,.15); color:#fff; }

.client-content{ display:flex; flex-direction:column; gap:16px; min-width:0; }
.client-section{ display:none; }
.client-section.is-active{ display:flex; flex-direction:column; gap:16px; }

.client-card{
  background:var(--u-paper); border:1px solid var(--u-line); border-radius:16px;
  padding: clamp(24px, 3vw, 32px);
}
.client-card-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:16px; flex-wrap:wrap; margin-bottom:20px; }
.client-card-head h2{ font-family:var(--u-serif); font-size: clamp(24px, 3vw, 32px); font-weight:400; letter-spacing:-0.02em; line-height:1.1; }
.client-card-head .sub{ font-size:13px; color:var(--u-ink-500); margin-top:4px; }

/* Contratações */
.contract-list{ display:flex; flex-direction:column; gap:12px; }
.contract-row{
  display:grid; gap:14px;
  grid-template-columns: 1fr;
  padding:18px; border:1px solid var(--u-line); border-radius:12px;
  background:var(--u-paper);
}
@media (min-width:640px){
  .contract-row{ grid-template-columns: auto 1fr auto auto; align-items:center; }
}
.contract-thumb{
  width:56px; height:56px; border-radius:10px; flex:none;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font:700 20px/1 var(--u-sans); letter-spacing:-0.03em;
}
.contract-meta b{ display:block; font-size:15px; font-weight:600; letter-spacing:-0.01em; }
.contract-meta span{ display:block; font-size:12px; color:var(--u-ink-500); margin-top:2px; }
.contract-status{
  font-family:var(--u-mono); font-size:10px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  padding:5px 10px; border-radius:999px;
  display:inline-flex; align-items:center; gap:6px;
  background:var(--u-surface); border:1px solid var(--u-line); color:var(--u-ink-700);
}
.contract-status::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--u-ink-400); }
.contract-status.is-pending{ background:#FFF7ED; color:#92400E; border-color:#FCD9A8; }
.contract-status.is-pending::before{ background:#D97706; }
.contract-status.is-installed{ background:#F0FDF4; color:#15803D; border-color:#BBF7D0; }
.contract-status.is-installed::before{ background:#15803D; }

.contract-action{
  height:38px; padding:0 14px; border-radius:8px;
  background:var(--u-ink-900); color:#fff;
  font:500 13px/1 var(--u-sans);
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  border:0; white-space:nowrap;
}
.contract-action:hover{ background:var(--u-ink-800); }
.contract-action.secondary{ background:var(--u-paper); color:var(--u-ink-900); border:1px solid var(--u-line); }
.contract-action.secondary:hover{ background:var(--u-surface); }
.contract-action svg{ width:14px; height:14px; }

.empty-state{
  text-align:center; padding: 48px 24px;
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.empty-state .ico{
  width:64px; height:64px; border-radius:50%;
  background:var(--u-surface); color:var(--u-ink-400);
  display:inline-flex; align-items:center; justify-content:center;
}
.empty-state .ico svg{ width:28px; height:28px; }
.empty-state h3{ font-size:18px; font-weight:600; }
.empty-state p{ margin:0; color:var(--u-ink-500); font-size:14px; }

/* Chamados */
.ticket-list{ display:flex; flex-direction:column; gap:8px; }
.ticket-row{
  display:flex; gap:14px; align-items:flex-start;
  padding:16px; border:1px solid var(--u-line); border-radius:12px;
}
.ticket-row b{ display:block; font-size:14px; font-weight:600; }
.ticket-row p{ margin:4px 0 0; font-size:13px; color:var(--u-ink-500); line-height:1.5; }
.ticket-meta{ display:flex; gap:12px; margin-top:8px; font-size:11px; color:var(--u-ink-500); }
.ticket-meta .pill{ height:auto; padding:3px 8px; font-size:10px; }

/* Install-store modal — extends .modal */
.install-store-form{ display:flex; flex-direction:column; gap:14px; }
.install-store-form .ref{
  display:flex; align-items:center; gap:10px;
  padding:12px; background:var(--u-surface); border-radius:10px; border:1px solid var(--u-line);
}
.install-store-form .ref-thumb{
  width:36px; height:36px; flex:none; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font:700 14px/1 var(--u-sans);
}
.install-store-form .ref b{ display:block; font-size:13px; font-weight:600; }
.install-store-form .ref span{ display:block; font-size:11px; color:var(--u-ink-500); font-family:var(--u-mono); }
.install-store-help{
  display:flex; gap:10px; align-items:flex-start;
  padding:14px; border-radius:10px;
  background:#EEF2FF; color:var(--u-primary-dark); font-size:12px; line-height:1.5;
}
.install-store-help svg{ width:16px; height:16px; flex:none; margin-top:1px; color:var(--u-primary); }
.install-progress{
  display:flex; flex-direction:column; align-items:center; gap:20px; padding: 24px 0;
}
.install-spinner{
  width:48px; height:48px; border-radius:50%;
  border: 3px solid var(--u-line);
  border-top-color: var(--u-primary);
  animation: spin 1s linear infinite;
}
@keyframes spin{ to { transform: rotate(360deg); } }

/* =========================================================
   Theme detail page (PDP)
   ========================================================= */
.theme-detail-overlay{
  position:fixed;
  top: var(--detail-top, 0);
  left:0; right:0; bottom:0;
  z-index:125;
  background:var(--u-bg); color:var(--u-ink-900);
  overflow-y:auto;
  opacity:0; pointer-events:none;
  transition:opacity .3s var(--u-ease);
}
.theme-detail-overlay.is-open{ opacity:1; pointer-events:auto; }

.theme-detail-topbar{
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  padding: 20px clamp(20px, 4vw, 32px) 0;
}
.theme-detail-topbar .back{
  display:inline-flex; align-items:center; gap:8px;
  padding: 8px 14px; border-radius:999px;
  border:1px solid var(--u-line); background:var(--u-paper);
  font-size:13px; font-weight:500; color:var(--u-ink-700);
  cursor:pointer; transition:background .2s, color .2s, border-color .2s;
}
.theme-detail-topbar .back:hover{ background:var(--u-surface); color:var(--u-ink-900); border-color:var(--u-ink-300); }
.theme-detail-topbar .back svg{ width:14px; height:14px; }
.theme-detail-breadcrumb{
  display:flex; align-items:center; gap:10px;
  font-family:var(--u-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--u-ink-500);
}
.theme-detail-breadcrumb b{ color:var(--u-ink-900); font-weight:600; }
.theme-detail-breadcrumb svg{ width:12px; height:12px; opacity:.4; }

.theme-detail-body{
  max-width:1280px; margin:0 auto;
  padding: clamp(28px, 4vw, 56px) clamp(20px, 4vw, 32px);
  display:grid; gap:32px;
  grid-template-columns:1fr;
}
@media (min-width:1024px){
  .theme-detail-body{ grid-template-columns: minmax(0, 1fr) 420px; gap: 56px; align-items:start; }
}

/* Gallery */
.gallery{ display:flex; flex-direction:column; gap:12px; }
.gallery-main{
  position:relative;
  aspect-ratio: 4/3;
  border-radius:18px; overflow:hidden;
  background:var(--accent, var(--u-ink-800));
  display:flex; align-items:center; justify-content:center;
  isolation:isolate;
}
.gallery-main::before{
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 36px 36px;
  z-index:0;
}
.gallery-mock{
  position:relative; z-index:1;
  width: clamp(280px, 70%, 580px);
  background:#fff; border-radius:12px;
  box-shadow: 0 30px 60px -20px rgba(11,11,20,.35);
  padding: 14px;
  display:flex; flex-direction:column; gap:10px;
}
.gallery-mock-bar{ height:8px; background:var(--u-line-2); border-radius:4px; width:36%; }
.gallery-mock-hero{ aspect-ratio:16/8; border-radius:8px; background:var(--accent, #15162B); opacity:.9; }
.gallery-mock-row{ display:grid; gap:8px; }
.gallery-mock-row.r3{ grid-template-columns:repeat(3,1fr); }
.gallery-mock-row.r4{ grid-template-columns:repeat(4,1fr); }
.gallery-mock-row > div{ aspect-ratio:1; border-radius:6px; background:var(--u-line-2); }
.gallery-mock-row.alt > div:nth-child(odd){ background:var(--accent, #15162B); opacity:.18; }
.gallery-mock-text{ display:flex; flex-direction:column; gap:5px; padding:8px 0; }
.gallery-mock-text span{ height:5px; background:var(--u-line-2); border-radius:3px; }
.gallery-mock-text span:nth-child(1){ width:80%; }
.gallery-mock-text span:nth-child(2){ width:60%; }
.gallery-mock-text span:nth-child(3){ width:70%; }
.gallery-mock-btn{ height:10px; width:60px; border-radius:5px; background:var(--accent, #15162B); }
.gallery-mobile{
  width:140px; background:#fff; border-radius:18px;
  box-shadow: 0 30px 60px -20px rgba(11,11,20,.35);
  padding: 8px; padding-top: 14px;
  position:relative; z-index:1;
  border:8px solid #0B0B14;
}
.gallery-mobile::before{
  content:''; position:absolute; left:50%; top:6px; transform:translateX(-50%);
  width:40px; height:5px; border-radius:3px; background:#0B0B14;
}
.gallery-mobile-screen{ display:flex; flex-direction:column; gap:6px; padding-top:6px; }
.gallery-mobile-screen .h{ height:60px; border-radius:6px; background:var(--accent); opacity:.9; }
.gallery-mobile-screen .grid{ display:grid; gap:4px; grid-template-columns:1fr 1fr; }
.gallery-mobile-screen .grid div{ aspect-ratio:1; border-radius:4px; background:var(--u-line-2); }
.gallery-video{
  position:relative; aspect-ratio:16/9; width:80%;
  background: linear-gradient(135deg, var(--accent, #15162B) 0%, var(--u-ink-900) 100%);
  border-radius:14px; display:flex; align-items:center; justify-content:center;
}
.gallery-video::after{
  content:''; position:absolute; inset:0; border-radius:14px;
  background:
    radial-gradient(rgba(255,255,255,.15) 1px, transparent 1.5px);
  background-size: 18px 18px; opacity:.6;
}
.gallery-video-play{
  position:relative; z-index:2;
  width:80px; height:80px; border-radius:50%;
  background:rgba(255,255,255,.95); color:var(--u-ink-900);
  display:inline-flex; align-items:center; justify-content:center;
  border:0; cursor:pointer;
  box-shadow: 0 20px 50px -10px rgba(0,0,0,.4);
  transition: transform .2s;
}
.gallery-video-play:hover{ transform: scale(1.05); }
.gallery-video-play svg{ width:28px; height:28px; margin-left:4px; }
.gallery-video-label{
  position:absolute; bottom:14px; left:16px; z-index:2;
  font-family:var(--u-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.7);
}

.gallery-thumbs{
  display:grid; grid-template-columns:repeat(5,1fr); gap:8px;
}
@media (min-width:640px){ .gallery-thumbs{ gap:10px; } }
.gallery-thumb{
  position:relative; aspect-ratio: 4/3;
  border-radius:10px; overflow:hidden; cursor:pointer;
  background:var(--accent); opacity:.55; border:2px solid transparent;
  transition: opacity .2s, border-color .2s;
  padding:0;
}
.gallery-thumb:hover{ opacity:.85; }
.gallery-thumb.is-active{ opacity:1; border-color:var(--u-ink-900); }
.gallery-thumb::after{
  content:''; position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 16px 16px;
}
.gallery-thumb.is-video::before{
  content:''; position:absolute; inset:0; z-index:1;
  background: rgba(11,11,20,.35);
}
.gallery-thumb.is-video::after{
  content:'▶'; position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center; z-index:2;
  color:#fff; font-size:18px;
  background:transparent;
}

/* Info column */
.theme-detail-info{ display:flex; flex-direction:column; gap:18px; position:sticky; top:88px; }
.detail-tag-row{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.detail-segment{ font-family:var(--u-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--u-ink-500); }
.detail-tag{
  height:24px; padding:0 10px; border-radius:999px; background:var(--u-ink-900); color:#fff;
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--u-mono); font-size:10px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
}
.theme-detail-info h1{
  font-family:var(--u-serif); font-weight:400; letter-spacing:-0.03em; line-height:1;
  font-size: clamp(40px, 5.6vw, 64px);
}
.detail-rating{ display:flex; align-items:center; gap:10px; }
.detail-stars{ display:flex; gap:2px; color:#D97706; }
.detail-stars svg{ width:16px; height:16px; }
.detail-rating-num{ font-family:var(--u-mono); font-size:13px; font-weight:600; }
.detail-rating-count{ font-size:13px; color:var(--u-ink-500); }
.detail-price-block{ padding:20px 0; border-block:1px solid var(--u-line); }
.detail-price-row{ display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; }
.detail-price-old{ color:var(--u-ink-400); font-family:var(--u-mono); font-size:14px; text-decoration:line-through; }
.detail-price{ font-family:var(--u-sans); font-weight:600; font-size: clamp(32px, 4vw, 44px); letter-spacing:-0.03em; }
.detail-price-cash{ font-family:var(--u-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--u-ink-500); }
.detail-installments{ margin-top:6px; font-size:14px; color:var(--u-ink-700); }
.detail-installments b{ font-weight:600; color:var(--u-ink-900); }
.detail-platforms-row{ display:flex; flex-direction:column; gap:6px; font-size:13px; }
.detail-platforms-row .l{ font-family:var(--u-mono); font-size:11px; color:var(--u-ink-500); letter-spacing:.08em; text-transform:uppercase; }
.detail-platforms-row .v{ display:flex; gap:6px; flex-wrap:wrap; }
.detail-platforms-row .v span{
  font-family:var(--u-mono); font-size:10px; padding:3px 8px; border-radius:4px;
  background:var(--u-surface); color:var(--u-ink-700); border:1px solid var(--u-line);
  text-transform:uppercase;
}
.detail-platforms-row .v span[data-soon="true"]{
  background:#FFF7ED; color:#92400E; border-color:#FCD9A8;
}
.detail-actions{ display:flex; flex-direction:column; gap:10px; }
.detail-add-btn{
  min-height:54px; padding:0 22px; border-radius:12px;
  background:var(--u-primary); color:#fff;
  font-family:var(--u-sans); font-weight:600; font-size:15px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border:0; cursor:pointer; width:100%;
  transition:background .2s;
}
.detail-add-btn:hover{ background:var(--u-primary-dark); }
.detail-add-btn.is-added{ background:var(--u-ink-900); }
.detail-add-btn svg{ width:18px; height:18px; }
.detail-demo-btn{
  min-height:48px; padding:0 22px; border-radius:12px;
  background:var(--u-paper); color:var(--u-ink-900); border:1px solid var(--u-line);
  font-family:var(--u-sans); font-weight:500; font-size:14px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  cursor:pointer; width:100%;
  transition:background .2s, border-color .2s;
}
.detail-demo-btn:hover{ background:var(--u-surface); border-color:var(--u-ink-300); }
.detail-demo-btn svg{ width:16px; height:16px; }
.detail-meta-list{ display:grid; grid-template-columns:1fr 1fr; gap:14px; padding-top:16px; border-top:1px solid var(--u-line); }
.detail-meta-list .item{ display:flex; flex-direction:column; gap:2px; }
.detail-meta-list .item .l{ font-family:var(--u-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--u-ink-500); }
.detail-meta-list .item .v{ font-size:14px; font-weight:600; letter-spacing:-0.01em; }

/* Content tabs */
.theme-detail-content{
  max-width:1280px; margin:0 auto;
  padding: clamp(20px,4vw,32px) clamp(20px,4vw,32px) clamp(60px,8vw,96px);
}
.detail-tabs-bar{
  display:flex; gap:24px; overflow-x:auto;
  border-bottom:1px solid var(--u-line); margin-bottom: 32px;
  scrollbar-width:none;
}
.detail-tabs-bar::-webkit-scrollbar{ display:none; }
.detail-tab{
  position:relative; padding: 14px 0; flex:none;
  font-size:14px; font-weight:500; color:var(--u-ink-500);
  background:transparent; border:0; cursor:pointer;
  white-space:nowrap;
  transition:color .2s;
}
.detail-tab .count{
  font-family:var(--u-mono); font-size:11px; color:var(--u-ink-400); margin-left:6px;
}
.detail-tab::after{
  content:''; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background:var(--u-ink-900); transform:scaleX(0); transform-origin:left;
  transition:transform .25s var(--u-ease);
}
.detail-tab.is-active{ color:var(--u-ink-900); }
.detail-tab.is-active::after{ transform:scaleX(1); }

.detail-panel{ display:none; }
.detail-panel.is-active{ display:block; }

/* Description panel */
.detail-description{
  display:grid; gap: 40px;
  grid-template-columns: 1fr;
}
@media (min-width:880px){
  .detail-description{ grid-template-columns: 1.6fr 1fr; gap: 64px; }
}
.detail-description h3{
  font-family:var(--u-serif); font-weight:400; font-size: clamp(28px, 3.4vw, 36px); letter-spacing:-0.02em; line-height:1;
  margin-bottom:20px; max-width:18ch;
}
.detail-description p{ font-size:16px; line-height:1.7; color:var(--u-ink-700); margin: 0 0 16px; max-width: 60ch; }
.detail-description .quote{
  border-left:3px solid var(--u-primary);
  padding: 12px 0 12px 22px;
  font-family:var(--u-serif); font-style:italic; font-size:22px; line-height:1.35; color:var(--u-ink-800);
  letter-spacing:-0.01em;
  margin: 24px 0;
}
.detail-aside-card{
  background:var(--u-surface); border:1px solid var(--u-line); border-radius:14px; padding:24px;
  display:flex; flex-direction:column; gap:14px;
}
.detail-aside-card h4{ font-family:var(--u-mono); font-size:11px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--u-ink-500); }
.detail-aside-card ul{ display:flex; flex-direction:column; gap:10px; }
.detail-aside-card li{ display:flex; align-items:flex-start; gap:10px; font-size:14px; line-height:1.55; }
.detail-aside-card li svg{ width:16px; height:16px; flex:none; color:var(--u-primary); margin-top:1px; }

/* Features panel */
.feature-grid{
  display:grid; gap:16px;
  grid-template-columns:1fr;
}
@media (min-width:640px){ .feature-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .feature-grid{ grid-template-columns:repeat(3,1fr); } }
.feature-card{
  background:var(--u-paper); border:1px solid var(--u-line); border-radius:14px;
  padding:24px; display:flex; flex-direction:column; gap:12px;
}
.feature-card .ico{
  width:40px; height:40px; border-radius:10px;
  background:var(--u-primary-soft); color:var(--u-primary);
  display:inline-flex; align-items:center; justify-content:center;
}
.feature-card .ico svg{ width:20px; height:20px; }
.feature-card h4{ font-size:16px; font-weight:600; letter-spacing:-0.01em; }
.feature-card p{ margin:0; font-size:13.5px; line-height:1.55; color:var(--u-ink-500); }

/* Tech panel */
.tech-grid{
  display:grid; gap:14px;
  grid-template-columns:1fr;
}
@media (min-width:640px){ .tech-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .tech-grid{ grid-template-columns:repeat(4,1fr); } }
.tech-item{
  padding:24px; border:1px solid var(--u-line); border-radius:12px; background:var(--u-paper);
}
.tech-item .l{ font-family:var(--u-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--u-ink-500); }
.tech-item .v{ font-family:var(--u-mono); font-size:24px; font-weight:600; margin-top:6px; }
.tech-list{ margin-top:32px; }
.tech-list h4{ font-family:var(--u-serif); font-size:24px; font-weight:400; letter-spacing:-0.02em; margin-bottom:14px; }
.tech-list ul{ display:grid; gap:6px; grid-template-columns:1fr; }
@media (min-width:640px){ .tech-list ul{ grid-template-columns:1fr 1fr; column-gap:32px; } }
.tech-list li{ display:flex; align-items:center; gap:10px; font-size:14px; color:var(--u-ink-700); padding:8px 0; border-bottom:1px solid var(--u-line-2); }
.tech-list li svg{ width:14px; height:14px; color:#15803D; flex:none; }

/* Reviews panel */
.reviews-summary{
  display:grid; gap:24px;
  grid-template-columns:1fr;
  padding:24px; border:1px solid var(--u-line); border-radius:14px; background:var(--u-surface);
  margin-bottom:32px;
}
@media (min-width:720px){
  .reviews-summary{ grid-template-columns: 220px 1fr; align-items:center; gap:40px; }
}
.reviews-score{ display:flex; flex-direction:column; gap:6px; text-align:center; }
@media (min-width:720px){ .reviews-score{ text-align:left; } }
.reviews-score-big{ font-family:var(--u-serif); font-weight:400; font-size:64px; line-height:1; letter-spacing:-0.03em; }
.reviews-score .detail-stars{ justify-content:center; }
@media (min-width:720px){ .reviews-score .detail-stars{ justify-content:flex-start; } }
.reviews-count{ font-size:13px; color:var(--u-ink-500); }
.reviews-bars{ display:flex; flex-direction:column; gap:6px; }
.review-bar-row{ display:flex; align-items:center; gap:10px; }
.review-bar-label{ font-family:var(--u-mono); font-size:12px; color:var(--u-ink-700); min-width:36px; }
.review-bar{ flex:1; height:6px; background:var(--u-line); border-radius:3px; overflow:hidden; }
.review-bar > div{ height:100%; background:var(--u-ink-900); border-radius:3px; }
.review-bar-count{ font-family:var(--u-mono); font-size:11px; color:var(--u-ink-500); min-width:32px; text-align:right; }

.reviews-list{ display:flex; flex-direction:column; gap:12px; }
.review-card{
  background:var(--u-paper); border:1px solid var(--u-line); border-radius:14px;
  padding:24px;
  display:flex; flex-direction:column; gap:12px;
}
.review-head{ display:flex; gap:14px; align-items:center; }
.review-avatar{
  width:44px; height:44px; flex:none; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; font:600 16px/1 var(--u-sans);
}
.review-who b{ display:block; font-size:14px; font-weight:600; letter-spacing:-0.01em; }
.review-who span{ display:block; font-size:12px; color:var(--u-ink-500); margin-top:2px; }
.review-stars-row{ display:flex; align-items:center; gap:10px; }
.review-stars-row time{ font-family:var(--u-mono); font-size:11px; color:var(--u-ink-500); }
.review-card p{ margin:0; font-size:14.5px; line-height:1.6; color:var(--u-ink-700); }
.review-verified{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--u-mono); font-size:10px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:#15803D;
}
.review-verified svg{ width:12px; height:12px; }

/* Related themes */
.related-section{ max-width:1280px; margin:0 auto; padding: 0 clamp(20px,4vw,32px) clamp(56px,8vw,96px); }
.related-head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:24px; }
.related-grid{
  display:grid; gap:20px;
  grid-template-columns:repeat(2, 1fr);
}
@media (min-width:880px){ .related-grid{ grid-template-columns:repeat(4, 1fr); } }
@media (max-width:560px){ .related-grid{ grid-template-columns:1fr; } }

/* =========================================================
   Differentials
   ========================================================= */
.diff-grid{
  display:grid; gap:16px;
  grid-template-columns:1fr;
}
@media (min-width:720px){ .diff-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .diff-grid{ grid-template-columns:repeat(4,1fr); } }
.diff-card{
  background:var(--u-paper); border:1px solid var(--u-line);
  padding:28px 24px; border-radius:14px; display:flex; flex-direction:column; gap:14px;
  transition:border-color .2s, transform .25s var(--u-ease);
}
.diff-card:hover{ border-color:var(--u-ink-300); transform:translateY(-3px); }
.diff-icon{
  width:44px; height:44px; border-radius:11px; background:var(--u-primary-soft); color:var(--u-primary);
  display:inline-flex; align-items:center; justify-content:center;
}
.diff-icon svg{ width:22px; height:22px; }
.diff-card h3{ font-size:18px; font-weight:600; letter-spacing:-0.01em; }
.diff-card p{ margin:0; font-size:14px; line-height:1.55; color:var(--u-ink-500); }

/* =========================================================
   How (steps)
   ========================================================= */
.steps{
  display:grid; gap:24px;
  grid-template-columns:1fr;
  counter-reset: step;
}
@media (min-width:720px){ .steps{ grid-template-columns:repeat(3,1fr); gap:32px; } }
.step{
  display:flex; flex-direction:column; gap:14px;
  border-top:1px solid var(--u-line); padding-top:24px;
  counter-increment: step;
}
.step .num{ font-family:var(--u-mono); font-size:12px; color:var(--u-ink-400); letter-spacing:.08em; }
.step h3{ font-family:var(--u-serif); font-weight:400; font-size:28px; letter-spacing:-0.02em; line-height:1.05; }
.step p{ margin:0; color:var(--u-ink-500); font-size:14.5px; line-height:1.6; }

/* =========================================================
   Platforms split (Tray / Nuvemshop)
   ========================================================= */
.platforms-split{
  display:grid; gap:16px;
  grid-template-columns:1fr;
}
@media (min-width:880px){ .platforms-split{ grid-template-columns:1fr 1fr; gap:24px; } }
.platform-card{
  position:relative; overflow:hidden; border-radius:18px;
  background:var(--u-paper); border:1px solid var(--u-line);
  padding: clamp(28px, 4vw, 48px);
  display:flex; flex-direction:column; gap:20px;
  min-height: 340px;
}
.platform-card .badge{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--u-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--u-ink-500);
}
.platform-card .badge::before{ content:''; width:8px; height:8px; border-radius:50%; background:var(--badge,var(--u-primary)); }
.platform-card h3{ font-family:var(--u-serif); font-weight:400; font-size: clamp(32px,3.8vw,44px); letter-spacing:-0.025em; line-height:1; }
.platform-card p{ margin:0; color:var(--u-ink-500); font-size:15px; line-height:1.55; max-width:42ch; }
.platform-card .stats{ display:flex; gap:24px; padding-top:14px; border-top:1px solid var(--u-line); margin-top:auto; }
.platform-card .stat .n{ font-family:var(--u-mono); font-size:22px; font-weight:600; }
.platform-card .stat .l{ font-size:12px; color:var(--u-ink-500); letter-spacing:.02em; }
.platform-card .btn{ align-self:flex-start; }

.platform-card.is-soon{ opacity:.92; }
.platform-card.is-soon .soon-badge{
  position:absolute; top:24px; right:24px;
  display:inline-flex; align-items:center; gap:8px;
  height:28px; padding:0 12px; border-radius:999px;
  background:#FFF7ED; color:#92400E; border:1px solid #FCD9A8;
  font-family:var(--u-mono); font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
}
.platform-card.is-soon .soon-badge::before{
  content:''; width:6px; height:6px; border-radius:50%; background:#D97706;
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:.5; transform:scale(.85); }
}
.platform-card.is-soon .stats{ opacity:.5; }
.platform-card.is-soon .btn-disabled{
  background:var(--u-surface); color:var(--u-ink-500); border:1px solid var(--u-line); cursor:not-allowed;
  pointer-events:none;
}

/* =========================================================
   Stats row
   ========================================================= */
.stats-row{
  display:grid; gap:24px;
  grid-template-columns:repeat(2,1fr);
}
@media (min-width:720px){ .stats-row{ grid-template-columns:repeat(4,1fr); } }
.stat-block{ display:flex; flex-direction:column; gap:8px; }
.stat-block .n{ font-family:var(--u-mono); font-weight:600; font-size: clamp(28px, 4.4vw, 44px); line-height:1; }
.stat-block .l{ font-size:13px; color:var(--u-ink-500); }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ display:flex; flex-direction:column; }
.faq details{
  border-top:1px solid var(--u-line);
  padding: 22px 0;
}
.faq details:last-of-type{ border-bottom:1px solid var(--u-line); }
.faq summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  font-size:17px; font-weight:500; letter-spacing:-0.01em;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ico{
  flex:none; width:28px; height:28px; border-radius:50%;
  border:1px solid var(--u-line);
  display:inline-flex; align-items:center; justify-content:center;
  transition:transform .25s var(--u-ease), background .2s;
}
.faq details[open] summary .ico{ transform:rotate(45deg); background:var(--u-ink-900); color:#fff; border-color:var(--u-ink-900); }
.faq summary .ico svg{ width:14px; height:14px; }
.faq-body{ padding-top:14px; max-width:64ch; color:var(--u-ink-500); font-size:15px; line-height:1.65; }

/* =========================================================
   CTA
   ========================================================= */
.cta-card{
  position:relative; overflow:hidden; border-radius:22px;
  background:var(--u-ink-900); color:#fff;
  padding: clamp(40px, 6vw, 84px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}
@media (max-width:860px){
  .cta-card{ grid-template-columns:1fr; gap:2.5rem; }
}
.cta-card::before{
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(circle at 70% 110%, rgba(79,70,229,.55), transparent 55%),
    radial-gradient(circle at 10% -10%, rgba(6,182,212,.25), transparent 50%);
  pointer-events:none;
}
.cta-card > *{ position:relative; z-index:1; }
.cta-card h2{ font-family:var(--u-serif); font-weight:400; letter-spacing:-0.02em; line-height:1.1; }
.cta-card p{ margin:0; color:rgba(255,255,255,.7); max-width:48ch; font-size:16px; }
.cta-card .btns{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.cta-card .btn-primary{ background:#fff; color:var(--u-ink-900); }
.cta-card .btn-primary:hover{ background:rgba(255,255,255,.85); }
.cta-card .btn-secondary{ background:transparent; border-color:rgba(255,255,255,.2); color:#fff; }
.cta-card .btn-secondary:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.4); }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  background:var(--u-ink-900); color:#fff;
  padding-block: clamp(56px, 7vw, 88px) 32px;
}
.site-footer .eyebrow{ color:rgba(255,255,255,.55); }
.footer-top{
  display:grid; gap:40px;
  grid-template-columns:1fr;
  padding-bottom: clamp(40px,5vw,56px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
@media (min-width:720px){ .footer-top{ grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
@media (min-width:1024px){ .footer-top{ grid-template-columns: 1.5fr 1fr 1fr 1fr 1.2fr; } }
.footer-brand .brand-text{ color:#fff; }
.footer-brand p{ margin:14px 0 22px; max-width:30ch; color:rgba(255,255,255,.6); font-size:14px; line-height:1.55; }
.footer-socials{ display:flex; gap:8px; }
.footer-socials a{
  width:38px; height:38px; border-radius:10px; border:1px solid rgba(255,255,255,.12);
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; transition:background .2s, border-color .2s;
}
.footer-socials a:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.3); }
.footer-socials svg{ width:16px; height:16px; }
.footer-col h4{ font-size:11px; font-family:var(--u-mono); font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.55); margin-bottom:18px; }
.footer-col ul{ display:flex; flex-direction:column; gap:12px; }
.footer-col a{ font-size:14px; color:rgba(255,255,255,.75); transition:color .2s; }
.footer-col a:hover{ color:#fff; }
.footer-news input{
  width:100%; height:42px; padding:0 14px; border-radius:10px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  color:#fff; font-size:14px; outline:none;
}
.footer-news input::placeholder{ color:rgba(255,255,255,.4); }
.footer-news input:focus-visible{ border-color:rgba(255,255,255,.4); }
.footer-news form{ display:flex; gap:8px; margin-top:12px; }
.footer-news .btn{ background:#fff; color:var(--u-ink-900); flex:none; }
.footer-news .btn:hover{ background:rgba(255,255,255,.85); }

.footer-bottom{
  padding-top:24px;
  display:flex; flex-direction:column; gap:14px; align-items:flex-start;
  font-size:12px; color:rgba(255,255,255,.5);
}
.footer-bottom ul{ display:flex; gap:24px; flex-wrap:wrap; }
.footer-bottom a:hover{ color:#fff; }
@media (min-width:720px){
  .footer-bottom{ flex-direction:row; justify-content:space-between; align-items:center; }
}

/* =========================================================
   Reveal animations (GSAP fallback class)
   ========================================================= */
[data-reveal]{ opacity:0; transform: translateY(24px); will-change: opacity, transform; }
.no-js [data-reveal]{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1; transform:none; }
}

/* =========================================================
   Carousel arrows
   ========================================================= */
.themes-slider{ position:relative; }
.carousel-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border-radius:50%;
  background:var(--u-paper); border:1.5px solid var(--u-line);
  box-shadow:0 4px 16px rgba(11,11,20,.10);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:4; color:var(--u-ink-700);
  transition:background .15s, border-color .15s, box-shadow .15s, opacity .15s;
}
.carousel-arrow:hover{ background:var(--u-primary); border-color:var(--u-primary); color:#fff; box-shadow:0 6px 20px rgba(79,70,229,.28); }
.carousel-arrow[disabled]{ opacity:.28; pointer-events:none; }
.carousel-arrow--prev{ left:-21px; }
.carousel-arrow--next{ right:-21px; }
@media (max-width:640px){
  .carousel-arrow--prev{ left:4px; }
  .carousel-arrow--next{ right:4px; }
}
