/* NEXOS STUDIOS — tema global (claro com roxo) */
:root{
  /* Base clara */
  --bg:#ffffff; --card:#ffffff; --text:#1d1d1f; --muted:#5c5c72;
  /* Roxo claro como cor principal */
  --brand-purple:#9b7cff; /* roxo claro */
  --brand-purple-dark:#7c5cff; /* roxo médio para hover */
  --accent:#9b7cff; --accent2:#c0a9ff;
  /* Bordas e sombras suaves para tema claro */
  --border:#e5e7ef; --shadow:0 10px 20px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif}
a,button{outline:none}
a{color:inherit}
/* Nave responsiva (tema claro) */
.nav{position:sticky;top:0;background:#ffffffcc;backdrop-filter:saturate(1.2) blur(6px);border-bottom:1px solid var(--border);z-index:10}
.nav .container{max-width:1100px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:800;letter-spacing:.5px;display:flex;align-items:center;gap:10px}
.brand .logo{width:26px;height:26px;border-radius:6px;object-fit:contain}
@media(max-width:640px){.nav .container{flex-wrap:wrap;gap:10px}.nav .container>div:last-child{width:100%;display:flex;gap:8px;flex-wrap:wrap}}
header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#ffffff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.brand{font-weight:800;letter-spacing:.5px}
/* Marca em roxo claro */
.brand span{color:var(--brand-purple)}
.main{padding:24px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--card);border-radius:14px;padding:16px;box-shadow:var(--shadow);border:1px solid var(--border)}
h1,h2,h3{margin:0 0 12px}
.btn{display:inline-block;background:var(--brand-purple);color:#ffffff;border:none;padding:10px 12px;border-radius:10px;font-weight:700;text-decoration:none;cursor:pointer;
  box-shadow:0 6px 16px rgba(123,92,255,.25);transition:transform .15s ease, box-shadow .15s ease, filter .15s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(123,92,255,.35);filter:brightness(1.02)}
.btn:active{transform:translateY(0) scale(.98);box-shadow:0 6px 16px rgba(123,92,255,.25)}
.btn.pulse{animation:btnPulse 2.8s ease-in-out infinite}
@keyframes btnPulse{0%{box-shadow:0 6px 16px rgba(123,92,255,.25);transform:translateY(0)}50%{box-shadow:0 16px 32px rgba(123,92,255,.36);transform:translateY(-1px)}100%{box-shadow:0 6px 16px rgba(123,92,255,.25);transform:translateY(0)}}
.btn.secondary{background:#f7f8fc;color:#2b2b31;border:1px solid var(--border)}
.btn.outline{background:#ffffff;color:#2b2b31;border:1px solid var(--border)}
.btn.logout{background:#ff6464;color:#ffffff}
.btn.logout:hover{filter:brightness(1.02)}
.btn.secondary.logout{background:#ffecec;color:#c02929}
/* Aplicar estilo a elementos button e inputs submit mesmo sem classe .btn */
button, input[type=submit]{background:var(--brand-purple);color:#ffffff;border:none;padding:10px 12px;border-radius:10px;font-weight:700;cursor:pointer;box-shadow:0 6px 16px rgba(123,92,255,.25);transition:transform .15s ease, box-shadow .15s ease, filter .15s ease}
button:hover, input[type=submit]:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(123,92,255,.35);filter:brightness(1.02)}
button:active, input[type=submit]:active{transform:translateY(0) scale(.98);box-shadow:0 6px 16px rgba(123,92,255,.25)}
button.secondary, input[type=submit].secondary{background:#f7f8fc;color:#2b2b31;border:1px solid var(--border)}
button.outline, input[type=submit].outline{background:#ffffff;color:#2b2b31;border:1px solid var(--border)}
.muted{color:var(--muted)}
input,textarea,select{width:100%;padding:10px;border-radius:10px;border:1px solid var(--border);background:#ffffff;color:var(--text)}
table{width:100%;border-collapse:collapse}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left}
footer{color:var(--muted);text-align:center;padding:16px}
/* Rodapé fixo com links essenciais */
.footer-fixed{position:fixed;left:0;right:0;bottom:0;background:#ffffff;border-top:1px solid var(--border);padding:10px 16px;z-index:20}
.footer-fixed .content{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px}
.footer-fixed .links a.btn{margin-left:8px}
/* Evitar sobreposição do conteúdo pelo rodapé fixo */
.has-footer .main{padding-bottom:80px}
@media(max-width:900px){.grid{grid-template-columns:1fr}}
.ok{color:#3dd9b1}
.warn{color:#ff9f43}
.error{color:#ffb3b3}
.qr{display:flex;gap:16px;align-items:center}
.qr img{background:#fff;border-radius:8px;box-shadow:0 4px 10px rgba(0,0,0,.08)}
/* Barra de botões moderna e responsiva */
.btn-bar{display:flex;gap:10px;flex-wrap:wrap}
.btn-bar .btn{min-width:140px}
.btn-bar .btn.secondary{background:#f7f8fc}
.btn-bar .btn.outline{background:#ffffff}
/* espaçamentos utilitários */
.mt-1{margin-top:8px}.mt-2{margin-top:12px}.mt-3{margin-top:16px}
.toolbar a.btn{margin-left:8px}

/* Estados de processamento em botões (spinner) */
.btn[disabled]{opacity:.75;cursor:not-allowed}
.btn.loading{position:relative}
.spinner{width:14px;height:14px;border:2px solid #0b0f14;border-top-color:transparent;border-radius:50%;display:inline-block;vertical-align:middle;margin-right:8px;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Fundo animado suave */
body{position:relative;overflow-x:hidden}
body::before{
  content:"";
  position:fixed;left:-20%;top:-20%;width:140%;height:140%;
  background:
    radial-gradient(1000px 600px at 20% 15%, rgba(155,124,255,.18), transparent 60%),
    radial-gradient(900px 550px at 80% 85%, rgba(192,169,255,.12), transparent 62%);
  animation:bgfloat 14s ease-in-out infinite alternate;
  z-index:0;pointer-events:none;filter:blur(0px);
}
@keyframes bgfloat{from{transform:translateX(-1%) translateY(-1%)}to{transform:translateX(1%) translateY(1%)}}

/* Orbes roxas navegando pelo fundo (3 unidades, suaves) */
.bg-orbs{position:fixed;left:0;right:0;top:0;bottom:0;pointer-events:none;z-index:-1;overflow:hidden}
.bg-orbs .orb{position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(155,124,255,.45), rgba(155,124,255,.25) 40%, rgba(155,124,255,0) 70%);
  filter:blur(10px);mix-blend-mode:screen;opacity:.6}
.bg-orbs .o1{left:-120px;bottom:-80px;animation:orbFloat1 18s ease-in-out infinite}
.bg-orbs .o2{right:-140px;bottom:120px;width:240px;height:240px;animation:orbFloat2 22s ease-in-out infinite}
.bg-orbs .o3{left:50%;top:-120px;transform:translateX(-50%);width:320px;height:320px;animation:orbFloat3 20s ease-in-out infinite}
@keyframes orbFloat1{0%{transform:translate(0,0)}25%{transform:translate(60px,-30px)}50%{transform:translate(120px,20px)}75%{transform:translate(40px,60px)}100%{transform:translate(0,0)}}
@keyframes orbFloat2{0%{transform:translate(0,0) scale(1)}33%{transform:translate(-50px,-20px) scale(1.05)}66%{transform:translate(-20px,40px) scale(.98)}100%{transform:translate(0,0) scale(1)}}
@keyframes orbFloat3{0%{transform:translateX(-50%) translateY(0)}25%{transform:translateX(-30%) translateY(30px)}50%{transform:translateX(-60%) translateY(10px)}75%{transform:translateX(-45%) translateY(-20px)}100%{transform:translateX(-50%) translateY(0)}}

/* Layout estilo Tebex — topo, herói e loja com sidebar */
/* Removido uso de .topbar; usamos pills no header */
.pill{background:#f0f2fa;color:#333;border:1px solid var(--border);padding:6px 10px;border-radius:999px;font-size:13px;text-decoration:none;transition:transform .15s ease, filter .15s ease}
.pill:hover{filter:brightness(1.08);transform:translateY(-1px)}
.toolbar .pill{margin-left:8px}

.hero{background:
       radial-gradient(1200px 300px at 50% -100px, rgba(155,124,255,.18), transparent),
       linear-gradient(135deg, rgba(240,242,250,1), rgba(255,255,255,1));
  border-bottom:1px solid var(--border);
  padding:26px 20px;}
.hero .title{font-size:28px;font-weight:900;margin:0 0 8px}
.hero .sub{color:var(--muted)}

.shop{display:grid;grid-template-columns:260px 1fr;gap:18px;padding:24px}
.sidebar{background:#ffffff;border:1px solid var(--border);border-radius:12px;padding:12px;color:#2b2b31}
.sidebar .section{margin-bottom:16px}
.sidebar .section h4{margin:0 0 8px;color:#2b2b31}
.sidebar a{display:block;padding:8px 10px;border-radius:8px;color:#2b2b31;text-decoration:none}
.sidebar a:hover{background:#f7f8fc}

.products{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.product-card{background:#ffffff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;position:relative;transition:transform .18s ease,box-shadow .18s ease}
.product-card:hover{transform:translateY(-2px);box-shadow:0 16px 42px rgba(0,0,0,.42)}
.product-card .thumb{height:140px;background:#f7f8fc;display:flex;align-items:center;justify-content:center}
.product-card .thumb-img{max-width:100%;max-height:140px;object-fit:contain}
.product-card .body{padding:14px}
.product-card h3{margin:0 0 6px;font-size:18px}
.product-card p{margin:0 0 10px;color:#2b2b31}
.product-card .price{font-weight:800}
.product-card .actions{display:flex;gap:10px;margin-top:10px}
/* Overlay com ações ao passar o mouse */
.product-card .overlay{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:flex-start;opacity:0;transition:opacity .18s ease;background:linear-gradient(180deg, rgba(255,255,255,0.0), rgba(255,255,255,0.85));padding:12px}
.product-card:hover .overlay{opacity:1}
.overlay .overlay-actions{display:flex;gap:8px}
.btn.small{padding:8px 10px;border-radius:8px;font-size:13px}
@media(max-width:980px){.shop{grid-template-columns:1fr}.products{grid-template-columns:1fr}}

/* Modal básico para detalhes do produto */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;padding:20px;z-index:1000}
.modal .dialog{background:#ffffff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);max-width:720px;width:100%;padding:16px}
.modal .dialog h3{margin-top:0}
.modal .dialog .close{float:right;background:#f7f8fc;color:#2b2b31;border:1px solid var(--border);padding:6px 10px;border-radius:8px;cursor:pointer;transition:filter .15s ease}
.modal .dialog .close:hover{filter:brightness(1.08)}
.brand .logo-small{width:22px;height:22px;margin-right:8px;vertical-align:middle;transform-origin:50% 50%;transition:transform 1.1s cubic-bezier(.2,.8,.2,1);backface-visibility:hidden;will-change:transform;object-fit:contain;display:inline-block}
.brand .logo-small:hover{transform:rotate(360deg) scale(1.02)}

/* Conteúdo rico (descrições) com contraste adequado */
.rich{color:var(--text)}
.rich p, .rich li, .rich ul, .rich ol, .rich h1, .rich h2, .rich h3, .rich h4, .rich h5, .rich h6{color:var(--text)}
.rich img{max-width:100%;height:auto;border-radius:8px}

/* ===== Melhorias de modal com transições suaves ===== */
.modal.show{display:flex;animation:fadeIn .18s ease-out}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal .dialog.anim{animation:popIn .22s ease-out}
@keyframes popIn{from{transform:translateY(8px);opacity:.98}to{transform:none;opacity:1}}

/* ===== Layout do modal Pix ===== */
.pix-layout{display:grid;grid-template-columns:240px 1fr;gap:16px;align-items:start}
.pix-layout .qr-holder{background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:8px;display:flex;align-items:center;justify-content:center}
.pix-layout .qr-holder img{max-width:220px;height:auto;display:block}
.pix-code{display:flex;flex-direction:column;gap:10px}
.pix-code textarea{width:100%;min-height:120px}
.copy-row{display:flex;gap:10px;align-items:center}
.copy-row .btn.small{min-width:140px;display:inline-flex;align-items:center;gap:8px}
.copy-icon{width:16px;height:16px;border-radius:50%;border:2px solid #7c5cff;display:inline-block;position:relative}
.copy-icon::after{content:"";position:absolute;left:4px;top:2px;width:6px;height:10px;border-right:2px solid transparent;border-bottom:2px solid transparent;transform:rotate(45deg)}
.btn.copied .copy-icon{border-color:#22c55e;background:#22c55e33}
.btn.copied .copy-icon::after{border-right-color:#22c55e;border-bottom-color:#22c55e;animation:tick .28s ease-out}
@keyframes tick{from{opacity:.2;transform:rotate(45deg) scale(.92)}to{opacity:1;transform:rotate(45deg) scale(1)}}
@media(max-width:640px){
  .pix-layout{grid-template-columns:1fr}
  .pix-layout .qr-holder img{max-width:200px}
}

/* ===== Página de Checkout PIX (moderna/minimalista) ===== */
.pix-checkout .summary{display:flex;align-items:center;justify-content:space-between}
.pix-checkout .summary .title{font-weight:800}
.amount-pill{display:inline-flex;align-items:center;gap:8px;background:#f7f8fc;border:1px solid var(--border);padding:8px 12px;border-radius:999px;font-weight:700}
.pix-grid{display:grid;grid-template-columns:260px 1fr;gap:16px}
@media(max-width:700px){.pix-grid{grid-template-columns:1fr}}
.code-row{display:flex;gap:8px}
.code-row input{flex:1}
.expire{color:#5c5c72;font-size:12px;margin-top:8px}
.statuspanel{margin-top:12px;display:flex;align-items:center;gap:10px}
.statuspanel .dot{width:10px;height:10px;border-radius:50%;background:#fbbf24}
.statuspanel.paid .dot{background:#22c55e}
.success-card{padding:24px;text-align:center}
.success-card .big-icon{width:80px;height:80px;border-radius:20px;background:#eafff7;border:1px solid #d7f5ea;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:34px}
.receipt{display:grid;gap:6px;color:#5c5c72;margin-top:8px}

/* ===== Responsividade da Área do Cliente (mobile cards + navbar) ===== */
.mobile-cards{display:none}
.mobile-card{background:#ffffff;border:1px solid var(--border);border-radius:12px;padding:12px;margin:10px 0;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.mobile-card .row{display:flex;justify-content:space-between;gap:10px;margin:6px 0}
.mobile-card .label{color:#6b7280;font-size:.88rem}
.mobile-card .value{font-weight:600;color:#111827}
.mobile-card .actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
@media(max-width:640px){.table-wrap{display:none}.mobile-cards{display:block}.brand{font-size:14px}}
/* Status de download em mobile */
.dl-status{margin-top:8px}
.dl-status .label{color:#6b7280;margin-bottom:6px}
.dl-status .progress .bar{transition:width .2s ease}

/* Logo decorativa ao fundo — reduzida e mais discreta no tema claro */
.bg-logo{position:fixed;right:24px;bottom:36px;width:180px;height:180px;z-index:-1;opacity:.04;pointer-events:none;filter:drop-shadow(0 8px 16px rgba(0,0,0,.05))}
.bg-logo img{width:100%;height:100%;display:block;animation:logoFloat 18s ease-in-out infinite alternate;object-fit:contain}
@media(max-width:640px){.bg-logo{display:none}}
@keyframes logoFloat{from{transform:translateY(0) rotate(-3deg)}to{transform:translateY(-8px) rotate(3deg)}}

/* Modal de confirmação genérica */
.confirm-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;z-index:2000}
.confirm-dialog{background:#ffffff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);max-width:420px;width:100%;padding:16px}
.confirm-dialog .title{font-weight:800;margin:0 0 8px}
.confirm-dialog .content{color:var(--muted);margin-bottom:12px}
.confirm-actions{display:flex;gap:8px;justify-content:flex-end}
.confirm-actions .btn{min-width:120px}

/* Seção de avaliações dos clientes */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.review{border:1px solid var(--border);background:#fff;border-radius:12px;padding:12px;box-shadow:var(--shadow)}
.review .avatar{width:36px;height:36px;border-radius:50%;background:#f0f2fa;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:#7c5cff;margin-bottom:8px}
.review .avatar-img{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);object-fit:cover;margin-bottom:8px}
.review .rating{font-weight:800;color:#2b2b31;margin-bottom:4px}
.review .rating .stars{margin-left:6px;display:inline-flex;gap:2px}
.star{fill:#e6e6f2;transition:transform .15s ease}
.star.filled{fill:#7c5cff}
.review:hover .star{transform:translateY(-1px)}
.review .comment{color:#1d1d1f}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr}}

/* Containers auxiliares para landing */
.container{padding:24px}
.two-col{display:grid;grid-template-columns:280px 1fr;gap:18px}
.topbuyers{list-style:none;padding:0;margin:0}
/* Estilos do chat de tickets */
.chat{border:1px solid var(--border);border-radius:12px;background:#ffffff;padding:12px}
.msg{display:flex;margin-bottom:10px}
.msg .bubble{max-width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}
.msg.mine{justify-content:flex-end}
.msg.mine .bubble{background:#f7f8fc}
.msg.other .bubble{background:#ffffff}
.msg .meta{font-size:12px;color:var(--muted);margin-bottom:6px}
.status-badge{display:inline-block;padding:4px 8px;border-radius:999px;border:1px solid var(--border);font-size:12px}
.status-open{background:#eafff7;color:#1d1d1f;border-color:#d7f5ea}
.status-closed{background:#f7f8fc;color:#5c5c72}
.topbuyers li{display:flex;align-items:center;justify-content:space-between;border-bottom:1px dashed var(--border);padding:8px 0}
.topbuyers li:last-child{border-bottom:0}
.name{font-weight:800}
.spent{color:var(--brand-purple)}

/* ===== Animações suaves: fade-in on scroll + parallax ===== */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease, transform .5s ease;will-change:opacity,transform}
.reveal.visible{opacity:1;transform:none}
.parallax{will-change:transform}
