/* ============================================================
   corpo.css — PRINT3D NERD · Loja Virtual de Impressão 3D
   Paleta:
     Escuro:  #0A0A1A | #12122A | #1E1E3A
     Primário:#E8001C (vermelho) | #0057FF (azul)
     Acento:  #FF6A00 (laranja neon)
     Claro:   #F0F2FF | #FFFFFF | #E8EAF6
   Fontes: Orbitron + Rajdhani + Nunito
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Nunito:wght@400;500;600;700;800&family=Orbitron:wght@400;700;900&display=swap');

/* ═══════════════════════════════════════════════════════════
   RESET
═══════════════════════════════════════════════════════════ */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* ═══════════════════════════════════════════════════════════
   VARIÁVEIS GLOBAIS
═══════════════════════════════════════════════════════════ */
:root {
    /* fundo escuro (menu / footer) */
    --dark-bg:         #0A0A1A;
    --dark-surface:    #12122A;
    --dark-border:     #1E1E3A;

    /* corpo — claro */
    --corpo-bg:        #F0F2FF;
    --corpo-surface:   #FFFFFF;
    --corpo-surface2:  #E8EAF6;
    --corpo-border:    #D0D4EE;

    /* cores primárias */
    --vermelho:        #E8001C;
    --vermelho-esc:    #B8001A;
    --vermelho-claro:  #FF4455;
    --azul:            #0057FF;
    --azul-esc:        #0042CC;
    --azul-claro:      #5BA3FF;
    --azul-suave:      rgba(0,87,255,.08);

    /* acento laranja neon */
    --neon:            #FF6A00;
    --neon-esc:        #CC4400;
    --neon-glow:       rgba(255,106,0,.55);
    --neon-suave:      rgba(255,106,0,.08);

    /* texto */
    --texto:           #0A0A1A;
    --texto-sec:       #3A3A5A;
    --muted:           #7878A8;
    --branco:          #FFFFFF;

    /* sombras */
    --shadow-sm:       0 2px 8px rgba(0,0,0,.08);
    --shadow-md:       0 6px 24px rgba(0,0,0,.12);
    --shadow-lg:       0 16px 48px rgba(0,0,0,.16);
    --shadow-azul:     0 6px 20px rgba(0,87,255,.22);
    --shadow-vermelho: 0 6px 20px rgba(232,0,28,.22);
    --shadow-neon:     0 6px 20px rgba(255,106,0,.30);

    /* tipografia */
    --font-display:    'Orbitron', sans-serif;
    --font-titulo:     'Rajdhani', sans-serif;
    --font-corpo:      'Nunito', sans-serif;

    /* espaço / bordas */
    --radius:          12px;
    --radius-sm:       8px;
    --radius-lg:       18px;
    --radius-pill:     999px;

    /* animações */
    --transition:      0.32s ease;
    --bounce:          0.4s cubic-bezier(.68,-.55,.27,1.55);
    --ease-out:        0.35s cubic-bezier(.25,.46,.45,.94);
}

/* ═══════════════════════════════════════════════════════════
   BODY
═══════════════════════════════════════════════════════════ */
body {
    background-color: var(--corpo-bg);
    color: var(--texto);
    font-family: var(--font-corpo);
    font-size: 15px;
    line-height: 1.65;
    padding-top: 68px; /* altura do menu fixo */
    min-height: 100vh;
    /* textura de pontos suaves no fundo */
    background-image:
        radial-gradient(circle at 70% 20%, rgba(0,87,255,.06) 0%, transparent 40%),
        radial-gradient(circle at 20% 80%, rgba(232,0,28,.04) 0%, transparent 40%);
}

/* cursor personalizado (opcional, remover se não usar) */
/* body { cursor: url('img/cursor.cur'), auto; } */

/* ═══════════════════════════════════════════════════════════
   SCROLL BAR PERSONALIZADA
═══════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--corpo-bg); }
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--azul), var(--vermelho));
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: var(--azul); }

/* ═══════════════════════════════════════════════════════════
   SELEÇÃO DE TEXTO
═══════════════════════════════════════════════════════════ */
::selection {
    background: var(--azul);
    color: var(--branco);
}

/* ═══════════════════════════════════════════════════════════
   CONTEÚDO PRINCIPAL
═══════════════════════════════════════════════════════════ */
.main-content {
    padding: 28px 20px;
}

/* ═══════════════════════════════════════════════════════════
   CONTAINER
═══════════════════════════════════════════════════════════ */
.container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 32px;
    background-color: rgba(255,255,255,.92);
    border-radius: var(--radius);
    border: 1px solid var(--corpo-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.container:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

/* variante escura (seções especiais) */
.container--dark {
    background-color: var(--dark-surface);
    border-color: var(--dark-border);
    color: var(--branco);
}

/* ═══════════════════════════════════════════════════════════
   CARDS
═══════════════════════════════════════════════════════════ */
.card {
    background-color: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    border-top: 3px solid transparent;
    border-radius: var(--radius);
    padding: 22px;
    margin: 12px 0;
    position: relative;
    overflow: hidden;
    transition:
        border-top-color var(--transition),
        box-shadow var(--transition),
        transform var(--transition);
}

/* linha de brilho no canto */
.card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 60px; height: 60px;
    background: radial-gradient(circle, rgba(0,87,255,.08) 0%, transparent 70%);
    transition: opacity var(--transition);
    opacity: 0;
}

.card:hover {
    border-top-color: var(--azul);
    box-shadow: var(--shadow-azul);
    transform: translateY(-4px);
}

.card:hover::before { opacity: 1; }

/* card de produto */
.card-produto {
    background: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    border-radius: var(--radius-lg);
    padding: 0;
    overflow: hidden;
    transition:
        transform var(--transition),
        box-shadow var(--transition),
        border-color var(--transition);
    cursor: pointer;
    position: relative;
}

.card-produto::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--radius-lg);
    border: 2px solid var(--azul);
    opacity: 0;
    transition: opacity var(--transition);
    pointer-events: none;
}

.card-produto:hover {
    transform: translateY(-6px) scale(1.01);
    box-shadow: var(--shadow-azul), var(--shadow-md);
}

.card-produto:hover::after { opacity: 1; }

.card-produto__img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    background: var(--corpo-surface2);
    display: block;
}

.card-produto__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    font-family: var(--font-titulo);
    font-size: .72em;
    font-weight: 700;
    letter-spacing: .8px;
    text-transform: uppercase;
    backdrop-filter: blur(6px);
}

.card-produto__badge--novo     { background: rgba(0,87,255,.85); color: #fff; }
.card-produto__badge--promo    { background: rgba(232,0,28,.85);  color: #fff; }
.card-produto__badge--exclusivo{ background: rgba(255,106,0,.85); color: #fff; }
.card-produto__badge--nerd     { background: rgba(10,10,26,.85);  color: var(--neon); border: 1px solid var(--neon); }

.card-produto__body {
    padding: 16px 18px 18px;
}

.card-produto__nome {
    font-family: var(--font-titulo);
    font-size: 1.05em;
    font-weight: 700;
    color: var(--texto);
    letter-spacing: .3px;
    margin-bottom: 4px;
}

.card-produto__desc {
    font-size: .85em;
    color: var(--muted);
    margin-bottom: 12px;
    line-height: 1.5;
}

.card-produto__preco {
    font-family: var(--font-display);
    font-size: 1.4em;
    font-weight: 700;
    color: var(--azul);
}

.card-produto__preco-antigo {
    font-size: .8em;
    color: var(--muted);
    text-decoration: line-through;
    margin-right: 6px;
}

.card-produto__acoes {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}

/* ═══════════════════════════════════════════════════════════
   GRID DE PRODUTOS
═══════════════════════════════════════════════════════════ */
.produtos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 20px;
}

.produtos-grid--destaque {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}

/* ═══════════════════════════════════════════════════════════
   HERO BANNER
═══════════════════════════════════════════════════════════ */
.hero {
    width: 100%;
    min-height: 480px;
    background: linear-gradient(135deg, var(--dark-bg) 0%, #0E0E28 50%, #16082A 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    margin-bottom: 32px;
}

/* grid de circuito no hero */
.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(0,87,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,87,255,.05) 1px, transparent 1px);
    background-size: 50px 50px;
    pointer-events: none;
}

/* brilho central */
.hero::after {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
    width: 600px; height: 300px;
    background: radial-gradient(ellipse, rgba(0,87,255,.12) 0%, transparent 70%);
    pointer-events: none;
}

.hero__conteudo {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 60px 32px;
}

.hero__eyebrow {
    font-family: var(--font-titulo);
    font-size: .8em;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--neon);
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.hero__eyebrow::before,
.hero__eyebrow::after {
    content: '';
    display: block;
    width: 30px;
    height: 1px;
    background: var(--neon);
    opacity: .5;
}

.hero__titulo {
    font-family: var(--font-display);
    font-size: clamp(2em, 5vw, 3.8em);
    font-weight: 900;
    color: var(--branco);
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: 1.1;
    margin-bottom: 18px;
}

.hero__titulo .destaque-vermelho { color: var(--vermelho); }
.hero__titulo .destaque-azul     { color: var(--azul-claro); }

.hero__subtitulo {
    font-family: var(--font-corpo);
    font-size: 1.05em;
    color: rgba(204,204,221,.85);
    max-width: 580px;
    margin: 0 auto 32px;
    line-height: 1.7;
}

.hero__acoes {
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════════
   DESTAQUE BOX
═══════════════════════════════════════════════════════════ */
.destaque-box {
    background: linear-gradient(135deg, var(--azul) 0%, var(--azul-esc) 100%);
    color: var(--branco);
    padding: 16px 24px;
    border-radius: var(--radius-sm);
    margin: 14px 0;
    text-align: center;
    font-family: var(--font-titulo);
    font-weight: 700;
    letter-spacing: .5px;
    box-shadow: var(--shadow-azul);
    animation: pulseBox 2.5s ease-in-out infinite;
    position: relative;
    overflow: hidden;
}

.destaque-box::before {
    content: '';
    position: absolute;
    top: -50%; left: -50%;
    width: 200%; height: 200%;
    background: radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 50%);
    animation: rotateGlow 6s linear infinite;
}

@keyframes pulseBox {
    0%, 100% { box-shadow: var(--shadow-azul); transform: scale(1); }
    50%       { box-shadow: 0 10px 30px rgba(0,87,255,.40); transform: scale(1.02); }
}

@keyframes rotateGlow {
    0%   { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* destaque vermelho */
.destaque-box--vermelho {
    background: linear-gradient(135deg, var(--vermelho) 0%, var(--vermelho-esc) 100%);
    box-shadow: var(--shadow-vermelho);
}

@keyframes pulseBoxVermelho {
    0%, 100% { box-shadow: var(--shadow-vermelho); transform: scale(1); }
    50%       { box-shadow: 0 10px 30px rgba(232,0,28,.40); transform: scale(1.02); }
}

.destaque-box--vermelho { animation-name: pulseBoxVermelho; }

/* destaque neon */
.destaque-box--neon {
    background: linear-gradient(135deg, var(--neon) 0%, var(--neon-esc) 100%);
    box-shadow: var(--shadow-neon);
}

/* ═══════════════════════════════════════════════════════════
   SEÇÃO COM CABEÇALHO ESTILIZADO
═══════════════════════════════════════════════════════════ */
.secao {
    padding: 48px 0 32px;
}

.secao-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 28px;
    gap: 16px;
    flex-wrap: wrap;
}

.titulo-principal {
    font-family: var(--font-display);
    font-size: clamp(1.8em, 4vw, 2.6em);
    font-weight: 900;
    color: var(--texto);
    text-align: center;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 12px;
    line-height: 1.1;
}

.titulo-secao {
    font-family: var(--font-titulo);
    font-size: 2em;
    font-weight: 700;
    color: var(--texto);
    text-transform: uppercase;
    letter-spacing: 1px;
    padding-bottom: 10px;
    margin-bottom: 8px;
    position: relative;
    line-height: 1.2;
}

/* sublinhado duplo decorativo */
.titulo-secao::before {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 100%;
    height: 2px;
    background: var(--corpo-border);
    border-radius: 2px;
}

.titulo-secao::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 52px;
    height: 3px;
    background: linear-gradient(90deg, var(--vermelho), var(--azul));
    border-radius: 2px;
    z-index: 1;
}

.subtitulo {
    font-family: var(--font-titulo);
    font-size: 1.5em;
    font-weight: 600;
    color: var(--texto-sec);
    text-align: center;
    margin-bottom: 24px;
    letter-spacing: .3px;
}

.titulo-card {
    font-family: var(--font-titulo);
    font-size: 1.1em;
    font-weight: 700;
    color: var(--texto);
    text-transform: uppercase;
    letter-spacing: .5px;
}

/* categoria tags */
.tag-categoria {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 12px;
    border-radius: var(--radius-pill);
    font-family: var(--font-titulo);
    font-size: .72em;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    border: 1px solid currentColor;
    transition: background .25s ease, color .25s ease;
    cursor: pointer;
}

.tag-categoria--azul   { color: var(--azul);    background: var(--azul-suave); border-color: rgba(0,87,255,.25); }
.tag-categoria--vermelho{ color: var(--vermelho); background: rgba(232,0,28,.06); border-color: rgba(232,0,28,.25); }
.tag-categoria--neon   { color: var(--neon);    background: var(--neon-suave); border-color: rgba(255,106,0,.25); }

.tag-categoria--azul:hover    { background: var(--azul);    color: var(--branco); }
.tag-categoria--vermelho:hover { background: var(--vermelho); color: var(--branco); }
.tag-categoria--neon:hover    { background: var(--neon);    color: var(--branco); }

/* ═══════════════════════════════════════════════════════════
   TEXTOS
═══════════════════════════════════════════════════════════ */
.texto-corrido {
    font-size: 1em;
    color: var(--texto-sec);
    margin-bottom: 15px;
    line-height: 1.75;
}

.texto-destaque {
    font-family: var(--font-titulo);
    font-size: 1.15em;
    font-weight: 600;
    color: var(--azul);
}

.texto-muted {
    color: var(--muted);
    font-size: .88em;
}

/* ═══════════════════════════════════════════════════════════
   LISTAS
═══════════════════════════════════════════════════════════ */
.lista-personalizada {
    list-style: none;
    padding-left: 0;
}

.lista-personalizada li {
    padding: 7px 0 7px 28px;
    position: relative;
    color: var(--texto-sec);
    font-weight: 500;
    border-bottom: 1px solid rgba(208,212,238,.5);
    transition: padding-left var(--transition), color var(--transition);
}

.lista-personalizada li:last-child { border-bottom: none; }

.lista-personalizada li::before {
    content: "\f058";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    position: absolute;
    left: 0;
    color: var(--azul);
    transition: transform var(--transition), color var(--transition);
}

.lista-personalizada li:hover {
    padding-left: 34px;
    color: var(--texto);
}

.lista-personalizada li:hover::before {
    transform: scale(1.2);
    color: var(--vermelho);
}

/* lista de features */
.lista-features {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
    padding: 0;
}

.lista-features li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
    background: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--azul);
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}

.lista-features li:hover {
    border-left-color: var(--vermelho);
    box-shadow: var(--shadow-azul);
    transform: translateX(4px);
}

.lista-features li i {
    color: var(--azul);
    font-size: 1.1em;
    flex-shrink: 0;
    margin-top: 2px;
    transition: color var(--transition);
}

.lista-features li:hover i { color: var(--vermelho); }

/* ═══════════════════════════════════════════════════════════
   FORMULÁRIOS
═══════════════════════════════════════════════════════════ */
.formulario {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.formulario label {
    font-family: var(--font-titulo);
    font-size: .78em;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--texto-sec);
    margin-bottom: 5px;
    display: block;
}

.formulario input,
.formulario select,
.formulario textarea {
    width: 100%;
    padding: 12px 16px;
    border: 1.5px solid var(--corpo-border);
    border-radius: var(--radius-sm);
    background: var(--corpo-surface);
    color: var(--texto);
    font-family: var(--font-corpo);
    font-size: 14px;
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
    outline: none;
}

.formulario input::placeholder,
.formulario textarea::placeholder {
    color: var(--muted);
    opacity: .7;
}

.formulario input:focus,
.formulario select:focus,
.formulario textarea:focus {
    border-color: var(--azul);
    box-shadow: 0 0 0 3px rgba(0,87,255,.15);
    background: rgba(0,87,255,.02);
}

.formulario input:invalid:not(:placeholder-shown),
.formulario textarea:invalid:not(:placeholder-shown) {
    border-color: var(--vermelho);
    box-shadow: 0 0 0 3px rgba(232,0,28,.12);
}

.formulario input:valid:not(:placeholder-shown),
.formulario textarea:valid:not(:placeholder-shown) {
    border-color: #16A34A;
    box-shadow: 0 0 0 3px rgba(22,163,74,.10);
}

.formulario textarea {
    resize: vertical;
    min-height: 100px;
}

.formulario select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230057FF' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 12px;
    padding-right: 40px;
}

/* grupo input com ícone */
.input-grupo {
    position: relative;
}

.input-grupo i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--muted);
    font-size: .9em;
    transition: color var(--transition);
    pointer-events: none;
}

.input-grupo input {
    padding-left: 40px;
}

.input-grupo input:focus + i,
.input-grupo:focus-within i {
    color: var(--azul);
}

/* ═══════════════════════════════════════════════════════════
   BOTÕES
═══════════════════════════════════════════════════════════ */
.botoes-centralizados {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 20px;
    flex-wrap: wrap;
}

/* base compartilhada */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 11px 26px;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-family: var(--font-titulo);
    font-size: .95em;
    font-weight: 700;
    letter-spacing: .8px;
    text-transform: uppercase;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition:
        background var(--transition),
        color var(--transition),
        transform var(--bounce),
        box-shadow var(--transition),
        border-color var(--transition);
    box-shadow: var(--shadow-sm);
}

/* shimmer interno */
.btn::before {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 60%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent);
    transition: left .5s ease;
    pointer-events: none;
}

.btn:hover::before { left: 150%; }

/* variantes */
.btn-primario {
    background: linear-gradient(135deg, var(--azul), var(--azul-esc));
    color: var(--branco);
    box-shadow: var(--shadow-azul);
}

.btn-primario:hover {
    background: linear-gradient(135deg, var(--azul-claro), var(--azul));
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 10px 28px rgba(0,87,255,.40);
}

.btn-perigo {
    background: linear-gradient(135deg, var(--vermelho), var(--vermelho-esc));
    color: var(--branco);
    box-shadow: var(--shadow-vermelho);
}

.btn-perigo:hover {
    background: linear-gradient(135deg, var(--vermelho-claro), var(--vermelho));
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 10px 28px rgba(232,0,28,.40);
}

.btn-neon {
    background: linear-gradient(135deg, var(--neon), var(--neon-esc));
    color: var(--branco);
    box-shadow: var(--shadow-neon);
}

.btn-neon:hover {
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 10px 28px rgba(255,106,0,.50);
}

.btn-outline {
    background: transparent;
    color: var(--azul);
    border: 2px solid var(--azul);
    box-shadow: none;
}

.btn-outline:hover {
    background: var(--azul);
    color: var(--branco);
    transform: translateY(-3px) scale(1.04);
    box-shadow: var(--shadow-azul);
}

.btn-outline-vermelho {
    background: transparent;
    color: var(--vermelho);
    border: 2px solid var(--vermelho);
    box-shadow: none;
}

.btn-outline-vermelho:hover {
    background: var(--vermelho);
    color: var(--branco);
    transform: translateY(-3px) scale(1.04);
    box-shadow: var(--shadow-vermelho);
}

.btn-escuro {
    background: linear-gradient(135deg, var(--dark-surface), var(--dark-bg));
    color: var(--branco);
    border: 1px solid var(--dark-border);
}

.btn-escuro:hover {
    background: var(--azul);
    border-color: var(--azul);
    transform: translateY(-3px) scale(1.04);
    box-shadow: var(--shadow-azul);
}

.btn-neutro {
    background: var(--corpo-surface2);
    color: var(--texto-sec);
    border: 1px solid var(--corpo-border);
    box-shadow: none;
}

.btn-neutro:hover {
    background: var(--corpo-border);
    transform: translateY(-2px);
}

/* tamanhos */
.btn--sm  { padding: 7px 16px; font-size: .82em; }
.btn--lg  { padding: 14px 36px; font-size: 1.05em; letter-spacing: 1px; }
.btn--full{ width: 100%; }

/* botão ícone circular */
.btn-ico {
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 50%;
    font-size: 1em;
}

/* estado desativado */
.btn:disabled,
.btn[disabled] {
    opacity: .45;
    cursor: not-allowed;
    transform: none !important;
}

/* compat com nomes antigos */
.btn-neutro-compat  { @extend .btn; @extend .btn-neutro; }
.btn-positivo { composes: btn; background: #16A34A; color: #fff; }
.btn-positivo:hover { background: #15803D; transform: translateY(-3px) scale(1.04); box-shadow: 0 8px 22px rgba(22,163,74,.3); }
.btn-negativo { composes: btn; }
.btn-negativo { background: var(--vermelho); color: var(--branco); }
.btn-negativo:hover { background: var(--vermelho-esc); transform: translateY(-3px) scale(1.04); box-shadow: var(--shadow-vermelho); }

/* ═══════════════════════════════════════════════════════════
   TABS / ABAS
═══════════════════════════════════════════════════════════ */
.tabs {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid var(--corpo-border);
    margin-bottom: 24px;
    overflow-x: auto;
}

.tab-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    color: var(--muted);
    font-family: var(--font-titulo);
    font-size: .88em;
    font-weight: 700;
    letter-spacing: .8px;
    text-transform: uppercase;
    cursor: pointer;
    transition: color var(--transition), border-color var(--transition);
    white-space: nowrap;
}

.tab-btn:hover {
    color: var(--azul);
    border-bottom-color: var(--azul);
}

.tab-btn.active {
    color: var(--vermelho);
    border-bottom-color: var(--vermelho);
}

.tab-painel { display: none; }
.tab-painel.active { display: block; }

/* ═══════════════════════════════════════════════════════════
   BADGES / ETIQUETAS
═══════════════════════════════════════════════════════════ */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: var(--radius-pill);
    font-family: var(--font-titulo);
    font-size: .7em;
    font-weight: 700;
    letter-spacing: .8px;
    text-transform: uppercase;
}

.badge--azul      { background: rgba(0,87,255,.12);   color: var(--azul); }
.badge--vermelho  { background: rgba(232,0,28,.12);   color: var(--vermelho); }
.badge--neon      { background: rgba(255,106,0,.12);  color: var(--neon); }
.badge--sucesso   { background: rgba(22,163,74,.12);  color: #16A34A; }
.badge--aviso     { background: rgba(234,179,8,.12);  color: #CA8A04; }
.badge--escuro    { background: var(--dark-bg);       color: var(--branco); }

/* ═══════════════════════════════════════════════════════════
   ALERTAS / MENSAGENS
═══════════════════════════════════════════════════════════ */
.alerta {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 18px;
    border-radius: var(--radius-sm);
    margin: 12px 0;
    border-left: 4px solid transparent;
    font-family: var(--font-corpo);
    font-size: .92em;
    font-weight: 500;
    line-height: 1.5;
}

.alerta i { font-size: 1.1em; flex-shrink: 0; margin-top: 1px; }

.alerta--info    { background: rgba(0,87,255,.07);  border-color: var(--azul);    color: var(--azul-esc); }
.alerta--sucesso { background: rgba(22,163,74,.07); border-color: #16A34A;        color: #15803D; }
.alerta--aviso   { background: rgba(234,179,8,.08); border-color: #CA8A04;        color: #92400E; }
.alerta--erro    { background: rgba(232,0,28,.07);  border-color: var(--vermelho); color: var(--vermelho-esc); }
.alerta--nerd    { background: rgba(255,106,0,.07); border-color: var(--neon);    color: var(--neon-esc); }

/* ═══════════════════════════════════════════════════════════
   MODAIS
═══════════════════════════════════════════════════════════ */
.modal {
    display: none;
    position: fixed;
    z-index: 1100;
    inset: 0;
    background-color: rgba(10,10,26,.75);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: fadeModal .2s ease;
}

.modal.aberto,
.modal:target {
    display: flex;
}

@keyframes fadeModal {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.modal-box {
    background: var(--corpo-surface);
    border-radius: var(--radius-lg);
    border-top: 4px solid var(--azul);
    padding: 32px 28px;
    width: 100%;
    max-width: 520px;
    max-height: 92vh;
    overflow-y: auto;
    position: relative;
    box-shadow:
        0 24px 64px rgba(0,0,0,.30),
        0 0 0 1px rgba(0,87,255,.15);
    animation: slideModal .3s cubic-bezier(.25,.46,.45,.94);
}

@keyframes slideModal {
    from { opacity: 0; transform: translateY(24px) scale(.97); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

.modal-box--vermelho { border-top-color: var(--vermelho); }
.modal-box--neon     { border-top-color: var(--neon); }

.modal-fechar {
    position: absolute;
    top: 14px;
    right: 14px;
    background: var(--corpo-surface2);
    border: 1px solid var(--corpo-border);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1em;
    color: var(--muted);
    cursor: pointer;
    transition: background var(--transition), color var(--transition), transform var(--transition);
}

.modal-fechar:hover {
    background: var(--vermelho);
    color: var(--branco);
    transform: rotate(90deg);
}

/* ═══════════════════════════════════════════════════════════
   TOAST / NOTIFICAÇÕES
═══════════════════════════════════════════════════════════ */
.toast-container {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
}

.toast {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    border-radius: var(--radius);
    background: var(--dark-surface);
    border: 1px solid var(--dark-border);
    border-left: 4px solid var(--azul);
    color: var(--branco);
    font-family: var(--font-corpo);
    font-size: .9em;
    font-weight: 600;
    box-shadow: 0 8px 24px rgba(0,0,0,.40);
    pointer-events: auto;
    animation: toastIn .35s cubic-bezier(.25,.46,.45,.94) forwards;
    min-width: 280px;
    max-width: 360px;
}

.toast.sair {
    animation: toastOut .3s ease forwards;
}

.toast--sucesso  { border-left-color: #16A34A; }
.toast--erro     { border-left-color: var(--vermelho); }
.toast--aviso    { border-left-color: #CA8A04; }
.toast--neon     { border-left-color: var(--neon); }

.toast i { font-size: 1.2em; flex-shrink: 0; }
.toast--sucesso i  { color: #16A34A; }
.toast--erro i     { color: var(--vermelho); }
.toast--aviso i    { color: #CA8A04; }
.toast--neon i     { color: var(--neon); }

@keyframes toastIn {
    from { opacity: 0; transform: translateX(40px); }
    to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(40px); }
}

/* ═══════════════════════════════════════════════════════════
   CARRINHO / CHECKOUT
═══════════════════════════════════════════════════════════ */
.orc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 16px;
}

.orc-tipo-btns {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.orc-tipo-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border: 2px solid var(--corpo-border);
    border-radius: var(--radius-sm);
    background: var(--corpo-surface);
    color: var(--texto-sec);
    font-family: var(--font-titulo);
    font-size: .88em;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all var(--transition);
}

.orc-tipo-btn:hover {
    border-color: var(--azul);
    color: var(--azul);
}

.orc-tipo-btn.ativo {
    border-color: var(--azul);
    background: var(--azul-suave);
    color: var(--azul);
}

.orc-card {
    background: var(--corpo-surface);
    border: 1.5px solid var(--corpo-border);
    border-radius: var(--radius);
    padding: 18px 16px 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    position: relative;
    overflow: hidden;
}

.orc-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 3px;
    background: linear-gradient(90deg, var(--azul), var(--vermelho));
    opacity: 0;
    transition: opacity var(--transition);
}

.orc-card:hover {
    border-color: var(--azul);
    box-shadow: var(--shadow-azul);
    transform: translateY(-2px);
}

.orc-card:hover::before { opacity: 1; }

.orc-card--selecionado {
    border-color: var(--azul) !important;
    background: var(--azul-suave);
}

.orc-card--selecionado::before { opacity: 1 !important; }

.orc-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}

.orc-card__badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: var(--font-titulo);
    font-size: .7em;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    padding: 3px 9px;
    border-radius: 4px;
}

.orc-card__badge--servico { background: rgba(0,87,255,.12);  color: var(--azul); }
.orc-card__badge--produto { background: rgba(232,0,28,.10);  color: var(--vermelho); }
.orc-card__badge--nerd    { background: rgba(255,106,0,.10); color: var(--neon); }

.orc-card__duracao {
    font-size: .75em;
    color: var(--muted);
    display: flex;
    align-items: center;
    gap: 4px;
}

.orc-card__nome {
    font-family: var(--font-titulo);
    font-size: 1.02em;
    font-weight: 700;
    color: var(--texto);
    line-height: 1.3;
    flex: 1;
}

.orc-card__preco {
    font-family: var(--font-display);
    font-size: 1.3em;
    font-weight: 700;
    color: var(--azul);
}

.orc-card__acoes {
    display: flex;
    gap: 8px;
    margin-top: 4px;
}

.orc-card__btn-detalhe,
.orc-card__btn-sel {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 8px 6px;
    border: none;
    border-radius: var(--radius-sm);
    font-family: var(--font-titulo);
    font-size: .75em;
    font-weight: 700;
    letter-spacing: .4px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all var(--transition);
}

.orc-card__btn-detalhe {
    background: var(--corpo-surface2);
    color: var(--texto-sec);
    border: 1px solid var(--corpo-border);
}
.orc-card__btn-detalhe:hover { background: var(--corpo-border); }

.orc-card__btn-sel {
    background: var(--azul);
    color: var(--branco);
}
.orc-card__btn-sel:hover {
    background: var(--azul-esc);
    box-shadow: var(--shadow-azul);
    transform: translateY(-1px);
}
.orc-card__btn-sel--ativo {
    background: var(--vermelho) !important;
    box-shadow: var(--shadow-vermelho) !important;
}

.orc-sem-resultado {
    text-align: center;
    padding: 40px 20px;
    color: var(--muted);
    font-size: .95em;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

/* ── Resumo / carrinho ── */
.orc-resumo-lista {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
}

.orc-resumo-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.orc-resumo-item:hover {
    border-color: var(--azul);
    box-shadow: var(--shadow-azul);
}

.orc-resumo-item__info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}

.orc-resumo-item__nome {
    font-family: var(--font-titulo);
    font-weight: 700;
    font-size: .95em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--texto);
}

.orc-resumo-item__tipo {
    flex-shrink: 0;
    font-family: var(--font-titulo);
    font-size: .68em;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 4px;
}

.orc-resumo-item__dir {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.orc-resumo-item__preco {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1em;
    color: var(--azul);
}

.orc-resumo-item__remover {
    background: none;
    border: none;
    color: var(--muted);
    cursor: pointer;
    font-size: 1em;
    padding: 4px;
    border-radius: 4px;
    transition: color var(--transition), background var(--transition);
}
.orc-resumo-item__remover:hover {
    color: var(--vermelho);
    background: rgba(232,0,28,.08);
}

/* ── Caixa de total ── */
.orc-total-box {
    background: linear-gradient(135deg, var(--dark-bg), var(--dark-surface));
    border: 1px solid var(--dark-border);
    border-radius: var(--radius);
    padding: 22px 26px;
    margin-bottom: 12px;
    color: var(--branco);
    position: relative;
    overflow: hidden;
}

.orc-total-box::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--azul), var(--vermelho));
}

.orc-total-linha {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: var(--font-titulo);
    font-size: 1em;
    font-weight: 600;
    padding: 6px 0;
    border-bottom: 1px solid var(--dark-border);
    color: rgba(204,204,221,.8);
}

.orc-total-linha:last-of-type { border-bottom: none; }

.orc-total-linha strong {
    font-family: var(--font-display);
    font-size: 1.5em;
    color: var(--branco);
}

.orc-total-aviso {
    margin-top: 10px;
    font-size: .82em;
    color: rgba(204,204,221,.5);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* ── Modal ── */
.orc-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10,10,26,.75);
    backdrop-filter: blur(4px);
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.orc-modal-box {
    background: var(--corpo-surface);
    border-top: 4px solid var(--azul);
    border-radius: var(--radius-lg);
    padding: 30px 28px;
    width: 100%;
    max-width: 500px;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    box-shadow: 0 24px 64px rgba(0,0,0,.30);
    animation: slideModal .25s ease;
}

.orc-modal-fechar {
    position: absolute;
    top: 14px;
    right: 14px;
    background: var(--corpo-surface2);
    border: 1px solid var(--corpo-border);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1em;
    color: var(--muted);
    cursor: pointer;
    transition: background var(--transition), color var(--transition), transform var(--transition);
}
.orc-modal-fechar:hover {
    background: var(--vermelho);
    color: var(--branco);
    transform: rotate(90deg);
}

.orc-modal-tipo-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: var(--font-titulo);
    font-size: .72em;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 4px;
    margin-bottom: 10px;
}

.orc-modal-codigo {
    font-size: .78em;
    color: var(--muted);
    margin-bottom: 10px;
    font-family: monospace;
    background: var(--corpo-surface2);
    padding: 2px 8px;
    border-radius: 4px;
    display: inline-block;
}

.orc-modal-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 16px;
}

.orc-modal-info-item {
    background: var(--corpo-surface2);
    border-radius: var(--radius-sm);
    padding: 12px 14px;
    border-left: 3px solid var(--azul);
}

.orc-modal-info-item span {
    display: block;
    font-size: .75em;
    color: var(--muted);
    margin-bottom: 4px;
    font-family: var(--font-titulo);
    letter-spacing: .5px;
    text-transform: uppercase;
}

.orc-modal-info-item strong {
    font-family: var(--font-titulo);
    font-size: 1.1em;
    font-weight: 800;
    color: var(--texto);
}

/* ═══════════════════════════════════════════════════════════
   TABELAS
═══════════════════════════════════════════════════════════ */
.tabela-wrapper {
    overflow-x: auto;
    border-radius: var(--radius);
    border: 1px solid var(--corpo-border);
    box-shadow: var(--shadow-sm);
}

.tabela {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--font-corpo);
    font-size: .9em;
}

.tabela thead {
    background: linear-gradient(135deg, var(--dark-bg), var(--dark-surface));
    color: var(--branco);
}

.tabela thead th {
    padding: 14px 16px;
    text-align: left;
    font-family: var(--font-titulo);
    font-size: .78em;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    white-space: nowrap;
}

.tabela thead th:first-child { border-radius: var(--radius-sm) 0 0 0; }
.tabela thead th:last-child  { border-radius: 0 var(--radius-sm) 0 0; }

.tabela tbody tr {
    border-bottom: 1px solid var(--corpo-border);
    transition: background var(--transition);
}

.tabela tbody tr:last-child { border-bottom: none; }

.tabela tbody tr:hover {
    background: var(--azul-suave);
}

.tabela tbody td {
    padding: 12px 16px;
    color: var(--texto-sec);
    vertical-align: middle;
}

/* ═══════════════════════════════════════════════════════════
   PAGINAÇÃO
═══════════════════════════════════════════════════════════ */
.paginacao {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.paginacao-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: var(--radius-sm);
    background: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    color: var(--texto-sec);
    font-family: var(--font-titulo);
    font-size: .85em;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    transition: all var(--transition);
}

.paginacao-btn:hover {
    background: var(--azul);
    color: var(--branco);
    border-color: var(--azul);
    box-shadow: var(--shadow-azul);
    transform: translateY(-2px);
}

.paginacao-btn.active {
    background: var(--vermelho);
    color: var(--branco);
    border-color: var(--vermelho);
    box-shadow: var(--shadow-vermelho);
}

/* ═══════════════════════════════════════════════════════════
   LOADING / SKELETON
═══════════════════════════════════════════════════════════ */
.skeleton {
    border-radius: var(--radius-sm);
    background: linear-gradient(90deg, var(--corpo-surface2) 25%, var(--corpo-border) 50%, var(--corpo-surface2) 75%);
    background-size: 200% 100%;
    animation: skeletonLoad 1.5s ease-in-out infinite;
}

@keyframes skeletonLoad {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.spinner {
    width: 36px;
    height: 36px;
    border: 3px solid var(--corpo-border);
    border-top-color: var(--azul);
    border-right-color: var(--vermelho);
    border-radius: 50%;
    animation: spin .8s linear infinite;
    display: inline-block;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ═══════════════════════════════════════════════════════════
   SEÇÃO DE CATEGORIAS NERD
═══════════════════════════════════════════════════════════ */
.categorias-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 14px;
}

.categoria-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 24px 16px;
    background: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--texto-sec);
    font-family: var(--font-titulo);
    font-size: .85em;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    text-align: center;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: all var(--transition);
}

.categoria-card::before {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--azul), var(--vermelho));
    transform: scaleX(0);
    transition: transform var(--transition);
}

.categoria-card i {
    font-size: 2em;
    color: var(--azul);
    transition: color var(--transition), transform var(--bounce);
}

.categoria-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-azul);
    border-color: var(--azul);
    color: var(--texto);
}

.categoria-card:hover::before { transform: scaleX(1); }
.categoria-card:hover i       { color: var(--vermelho); transform: scale(1.2) rotate(-5deg); }

/* ═══════════════════════════════════════════════════════════
   AVALIAÇÕES / ESTRELAS
═══════════════════════════════════════════════════════════ */
.estrelas {
    display: inline-flex;
    gap: 2px;
    color: #FBBF24;
    font-size: .95em;
}

.estrelas .vazia { color: var(--corpo-border); }

/* ═══════════════════════════════════════════════════════════
   PERSONALIZAÇÃO 3D — seção especial
═══════════════════════════════════════════════════════════ */
.personalizacao-box {
    background: linear-gradient(135deg, var(--dark-bg) 0%, #0E0E30 100%);
    border-radius: var(--radius-lg);
    border: 1px solid var(--dark-border);
    padding: 40px;
    color: var(--branco);
    position: relative;
    overflow: hidden;
}

/* grade de circuito interna */
.personalizacao-box::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(0,87,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,87,255,.04) 1px, transparent 1px);
    background-size: 30px 30px;
    pointer-events: none;
}

/* brilho de acento laranja */
.personalizacao-box::after {
    content: '';
    position: absolute;
    bottom: -40px; right: -40px;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(255,106,0,.12) 0%, transparent 70%);
    pointer-events: none;
}

.personalizacao-box__titulo {
    font-family: var(--font-display);
    font-size: 1.8em;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 10px;
    position: relative;
    z-index: 1;
}

.personalizacao-box__titulo span { color: var(--neon); }

.personalizacao-box__desc {
    font-family: var(--font-corpo);
    color: rgba(204,204,221,.8);
    line-height: 1.7;
    margin-bottom: 24px;
    position: relative;
    z-index: 1;
}

.personalizacao-box__acoes {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVIDADE
═══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .container { padding: 24px; }
    .footer-superior { grid-template-columns: 1fr 1fr; }
    .produtos-grid--destaque { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
}

@media (max-width: 768px) {
    body { padding-top: 60px; }

    .container { padding: 18px; border-radius: var(--radius-sm); }

    .titulo-principal { font-size: 1.8em; }
    .titulo-secao     { font-size: 1.5em; }

    .hero { min-height: 360px; border-radius: var(--radius); }
    .hero__conteudo { padding: 40px 20px; }

    .produtos-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }

    .orc-grid { grid-template-columns: 1fr 1fr; }
    .orc-tipo-btns { flex-direction: column; }
    .orc-modal-info-grid { grid-template-columns: 1fr; }
    .orc-resumo-item__info { flex-direction: column; align-items: flex-start; gap: 4px; }

    .tabs { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 2px; }

    .personalizacao-box { padding: 24px 20px; }
    .personalizacao-box__titulo { font-size: 1.4em; }

    .categorias-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }

    .lista-features { grid-template-columns: 1fr; }

    .hero__acoes { flex-direction: column; align-items: center; }
}

@media (max-width: 480px) {
    .container { padding: 14px; }
    .orc-grid  { grid-template-columns: 1fr; }
    .produtos-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .categorias-grid { grid-template-columns: repeat(2, 1fr); }
    .botoes-centralizados { flex-direction: column; }
    .btn--lg { padding: 12px 24px; }
}

/* animação de entrada global para elementos da loja */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.fade-in-up {
    animation: fadeInUp .5s ease forwards;
}

.fade-in-up:nth-child(2) { animation-delay: .08s; }
.fade-in-up:nth-child(3) { animation-delay: .16s; }
.fade-in-up:nth-child(4) { animation-delay: .24s; }
.fade-in-up:nth-child(5) { animation-delay: .32s; }
.fade-in-up:nth-child(6) { animation-delay: .40s; }

/* ═══════════════════════════════════════════════════════════
   PAINEL ADMINISTRATIVO — componentes compartilhados
   Usado por: gestao_produtos, gestao_estoque,
              gestao_receitas, gestao_despesas,
              gestao_vendas e demais páginas admin
═══════════════════════════════════════════════════════════ */

/* ── TOPBAR DO PAINEL ── */
.admin-topbar {
    background: linear-gradient(135deg, var(--dark-bg), var(--dark-surface));
    border-bottom: 2px solid var(--azul);
    padding: 10px 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.admin-topbar--verde   { border-bottom-color: #16A34A; }
.admin-topbar--neon    { border-bottom-color: var(--neon); }
.admin-topbar--roxo    { border-bottom-color: #7C3AED; }
.admin-topbar--amarelo { border-bottom-color: #CA8A04; }

.admin-topbar-titulo {
    font-family: var(--font-titulo);
    font-size: .8em;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(204,204,221,.5);
    display: flex;
    align-items: center;
    gap: 10px;
}
.admin-topbar-titulo i { color: var(--azul); }
.admin-topbar--verde   .admin-topbar-titulo i { color: #16A34A; }
.admin-topbar--neon    .admin-topbar-titulo i { color: var(--neon); }
.admin-topbar--roxo    .admin-topbar-titulo i { color: #7C3AED; }
.admin-topbar--amarelo .admin-topbar-titulo i { color: #CA8A04; }

.admin-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-titulo);
    font-size: .75em;
    font-weight: 600;
    letter-spacing: .5px;
    color: rgba(204,204,221,.4);
}
.admin-breadcrumb a { color: var(--azul-claro); text-decoration: none; transition: color var(--transition); }
.admin-breadcrumb a:hover { color: var(--branco); }
.admin-breadcrumb span { color: var(--azul-claro); }

/* ── STATS GRID ── */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
    gap: 14px;
    margin-bottom: 24px;
}

.stat-card {
    background: var(--corpo-surface);
    border: 1px solid var(--corpo-border);
    border-radius: var(--radius);
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 14px;
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-azul); border-color: var(--azul); }
.stat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }

.stat-card--azul::before     { background: linear-gradient(90deg, var(--azul), var(--azul-claro)); }
.stat-card--verde::before    { background: linear-gradient(90deg, #16A34A, #4ADE80); }
.stat-card--vermelho::before { background: linear-gradient(90deg, var(--vermelho), var(--neon)); }
.stat-card--neon::before     { background: linear-gradient(90deg, var(--neon), var(--neon-esc)); }
.stat-card--amarelo::before  { background: linear-gradient(90deg, #CA8A04, #FBBF24); }
.stat-card--roxo::before     { background: linear-gradient(90deg, #7C3AED, #A78BFA); }
.stat-card--muted::before    { background: linear-gradient(90deg, var(--muted), var(--corpo-border)); }

.stat-card__ico {
    width: 44px; height: 44px;
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2em; flex-shrink: 0;
}
.stat-card--azul     .stat-card__ico { background: rgba(0,87,255,.1);   color: var(--azul); }
.stat-card--verde    .stat-card__ico { background: rgba(22,163,74,.1);  color: #16A34A; }
.stat-card--vermelho .stat-card__ico { background: rgba(232,0,28,.1);   color: var(--vermelho); }
.stat-card--neon     .stat-card__ico { background: rgba(255,106,0,.1);  color: var(--neon); }
.stat-card--amarelo  .stat-card__ico { background: rgba(202,138,4,.1);  color: #CA8A04; }
.stat-card--roxo     .stat-card__ico { background: rgba(124,58,237,.1); color: #7C3AED; }
.stat-card--muted    .stat-card__ico { background: rgba(120,120,168,.1);color: var(--muted); }

.stat-card__num   { font-family: var(--font-display); font-size: 1.5em; font-weight: 900; color: var(--texto); line-height: 1; }
.stat-card__label { font-family: var(--font-titulo); font-size: .68em; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); margin-top: 3px; }

/* ── ABAS DE PÁGINA ── */
.page-tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--corpo-border); margin-bottom: 20px; overflow-x: auto; }
.page-tab {
    flex-shrink: 0;
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 18px;
    background: transparent; border: none;
    border-bottom: 3px solid transparent; margin-bottom: -2px;
    color: var(--muted);
    font-family: var(--font-titulo); font-size: .88em; font-weight: 700;
    letter-spacing: .8px; text-transform: uppercase;
    cursor: pointer; text-decoration: none; white-space: nowrap;
    transition: color var(--transition), border-color var(--transition);
}
.page-tab:hover             { color: var(--azul);     border-bottom-color: var(--azul); }
.page-tab.active            { color: var(--azul);     border-bottom-color: var(--azul); }
.page-tab.active--verde     { color: #16A34A;         border-bottom-color: #16A34A; }
.page-tab.active--vermelho  { color: var(--vermelho); border-bottom-color: var(--vermelho); }
.page-tab.active--neon      { color: var(--neon);     border-bottom-color: var(--neon); }
.page-tab.active--roxo      { color: #7C3AED;         border-bottom-color: #7C3AED; }
.page-tab.active--amarelo   { color: #CA8A04;         border-bottom-color: #CA8A04; }

/* ── TOOLBAR DE FILTROS ── */
.toolbar {
    background: var(--corpo-surface); border: 1px solid var(--corpo-border);
    border-radius: var(--radius); padding: 14px 18px; margin-bottom: 18px;
    display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
}
.toolbar-busca { position: relative; flex: 1; min-width: 180px; }
.toolbar-busca i { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: .88em; pointer-events: none; }
.toolbar-busca input {
    width: 100%; padding: 8px 11px 8px 33px;
    border: 1.5px solid var(--corpo-border); border-radius: var(--radius-sm);
    font-family: var(--font-corpo); font-size: .88em;
    background: var(--corpo-bg); color: var(--texto); outline: none;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.toolbar-busca input:focus { border-color: var(--azul); box-shadow: 0 0 0 3px rgba(0,87,255,.12); }
.toolbar select {
    padding: 8px 11px; border: 1.5px solid var(--corpo-border);
    border-radius: var(--radius-sm); font-family: var(--font-corpo); font-size: .86em;
    background: var(--corpo-bg); color: var(--texto); cursor: pointer; outline: none;
    transition: border-color var(--transition);
}
.toolbar select:focus { border-color: var(--azul); }
.toolbar-check {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--font-titulo); font-size: .78em; font-weight: 700;
    text-transform: uppercase; letter-spacing: .5px;
    color: var(--muted); cursor: pointer; white-space: nowrap;
}
.toolbar-check input { accent-color: var(--azul); width: 14px; height: 14px; }

/* ── BOTÃO DE AÇÃO LINHA TABELA ── */
.btn-acao {
    width: 31px; height: 31px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--corpo-border);
    background: var(--corpo-surface2); color: var(--texto-sec);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer; text-decoration: none; font-size: .86em;
    transition: all var(--transition);
}
.btn-acao:hover             { background: var(--azul);     color: #fff; border-color: var(--azul);     transform: scale(1.1); }
.btn-acao--perigo:hover     { background: var(--vermelho); color: #fff; border-color: var(--vermelho); }
.btn-acao--verde:hover      { background: #16A34A;         color: #fff; border-color: #16A34A; }
.btn-acao--neon:hover       { background: var(--neon);     color: #fff; border-color: var(--neon); }
.btn-acao--amarelo:hover    { background: #CA8A04;         color: #fff; border-color: #CA8A04; }
.btn-acao--roxo:hover       { background: #7C3AED;         color: #fff; border-color: #7C3AED; }
.acoes-linha { display: flex; gap: 5px; align-items: center; }

/* ── TOGGLE ── */
.toggle-ativo { position: relative; width: 40px; height: 22px; cursor: pointer; flex-shrink: 0; }
.toggle-ativo input { opacity: 0; width: 0; height: 0; }
.toggle-slider { position: absolute; inset: 0; background: var(--corpo-border); border-radius: 22px; transition: background .3s; }
.toggle-slider::before { content: ''; position: absolute; width: 16px; height: 16px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: transform .3s; box-shadow: var(--shadow-sm); }
.toggle-ativo input:checked + .toggle-slider               { background: #16A34A; }
.toggle-ativo input:checked + .toggle-slider::before       { transform: translateX(18px); }
.toggle-ativo input:checked + .toggle-slider--azul         { background: var(--azul); }
.toggle-ativo input:checked + .toggle-slider--vermelho     { background: var(--vermelho); }

/* ── MODAL OVERLAY (painel) ── */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(10,10,26,.78); backdrop-filter: blur(5px); z-index: 1100; align-items: center; justify-content: center; padding: 20px; }
.modal-overlay.aberto { display: flex; }

/* ── CAMPOS DE FORMULÁRIO ADMIN ── */
.form-grid    { display: grid; grid-template-columns: 1fr 1fr;       gap: 14px; }
.form-grid--3 { display: grid; grid-template-columns: 1fr 1fr 1fr;   gap: 14px; }
.form-grid--4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.form-col-full { grid-column: 1 / -1; }
.campo-grupo  { display: flex; flex-direction: column; gap: 5px; }
.campo-label  { font-family: var(--font-titulo); font-size: .7em; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--texto-sec); }
.campo-label .obrig { color: var(--vermelho); margin-left: 2px; }
.campo-input,
.campo-select,
.campo-textarea {
    padding: 9px 13px; border: 1.5px solid var(--corpo-border); border-radius: var(--radius-sm);
    font-family: var(--font-corpo); font-size: .9em; color: var(--texto);
    background: var(--corpo-bg); outline: none; width: 100%;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.campo-input:focus, .campo-select:focus, .campo-textarea:focus { border-color: var(--azul); box-shadow: 0 0 0 3px rgba(0,87,255,.12); }
.campo-textarea { resize: vertical; min-height: 72px; }
.campo-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230057FF' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 11px center; background-size: 11px;
    cursor: pointer; padding-right: 32px;
}
.campo-check-wrap {
    display: flex; align-items: center; gap: 8px;
    padding: 9px 13px; border: 1.5px solid var(--corpo-border); border-radius: var(--radius-sm);
    background: var(--corpo-bg); cursor: pointer;
    transition: border-color var(--transition), background var(--transition);
}
.campo-check-wrap:hover { border-color: var(--azul); background: var(--azul-suave); }
.campo-check-wrap input { accent-color: var(--azul); width: 15px; height: 15px; }
.campo-check-wrap span  { font-family: var(--font-titulo); font-size: .83em; font-weight: 700; color: var(--texto-sec); }

/* ── ABAS DENTRO DE MODAL ── */
.cfg-tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--corpo-border); margin-bottom: 14px; overflow-x: auto; }
.cfg-tab { flex-shrink: 0; padding: 7px 14px; background: none; border: none; border-bottom: 3px solid transparent; margin-bottom: -2px; font-family: var(--font-titulo); font-size: .78em; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--muted); cursor: pointer; white-space: nowrap; transition: color var(--transition), border-color var(--transition); }
.cfg-tab:hover { color: var(--azul); }
.cfg-tab.ativa { color: var(--azul); border-bottom-color: var(--azul); }

/* ── LISTA DE DOMÍNIO ── */
.dom-lista { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; max-height: 250px; overflow-y: auto; padding-right: 2px; }
.dom-item { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: var(--corpo-surface); border: 1px solid var(--corpo-border); border-radius: var(--radius-sm); transition: border-color var(--transition); }
.dom-item:hover    { border-color: var(--azul); }
.dom-item--inativo { opacity: .55; }
.dom-item__nome    { flex: 1; font-family: var(--font-titulo); font-size: .88em; font-weight: 700; color: var(--texto); }
.dom-mini-form     { background: var(--corpo-surface2); border: 1px solid var(--corpo-border); border-radius: var(--radius-sm); border-top: 3px solid var(--azul); padding: 14px; margin-top: 6px; }

/* ── CONFIRM BOX ── */
.confirm-box { background: rgba(232,0,28,.07); border: 1px solid rgba(232,0,28,.3); border-radius: var(--radius-sm); padding: 12px 14px; margin-bottom: 16px; color: var(--vermelho-esc); font-size: .88em; line-height: 1.55; display: flex; align-items: flex-start; gap: 10px; }
.confirm-box i { flex-shrink: 0; margin-top: 2px; }

/* ── EMPTY STATE ── */
.empty-state { text-align: center; padding: 52px 20px; color: var(--muted); }
.empty-state i { font-size: 3.2em; display: block; margin-bottom: 14px; opacity: .35; }
.empty-state p { font-size: .95em; }

/* ── VALORES NUMÉRICOS EM TABELA ── */
.td-num          { font-family: var(--font-display); font-size: .9em; font-weight: 900; }
.td-num--azul    { color: var(--azul); }
.td-num--verde   { color: #16A34A; }
.td-num--vermelho{ color: var(--vermelho); }
.td-num--neon    { color: var(--neon); }
.td-num--amarelo { color: #CA8A04; }
.td-num--muted   { color: var(--muted); }
.td-num--roxo    { color: #7C3AED; }

/* ── INFO BOX ── */
.info-box { display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px; border-radius: var(--radius-sm); font-size: .88em; line-height: 1.55; margin-bottom: 16px; }
.info-box i { flex-shrink: 0; margin-top: 2px; }
.info-box--azul    { background: rgba(0,87,255,.07);  border: 1px solid rgba(0,87,255,.2);  color: var(--azul-esc); }
.info-box--verde   { background: rgba(22,163,74,.07); border: 1px solid rgba(22,163,74,.2); color: #15803D; }
.info-box--neon    { background: rgba(255,106,0,.07); border: 1px solid rgba(255,106,0,.2); color: var(--neon-esc); }
.info-box--amarelo { background: rgba(202,138,4,.07); border: 1px solid rgba(202,138,4,.2); color: #92400E; }

/* ── DETALHE LINHA ── */
.detalhe-linha { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 9px 0; border-bottom: 1px solid var(--corpo-border); font-size: .9em; }
.detalhe-linha:last-child { border-bottom: none; }
.detalhe-linha__label { font-family: var(--font-titulo); font-size: .78em; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--muted); flex-shrink: 0; white-space: nowrap; }
.detalhe-linha__valor { color: var(--texto); font-weight: 600; text-align: right; }

/* ── PAGINAÇÃO INFO ── */
.pag-info { font-family: var(--font-titulo); font-size: .78em; color: var(--muted); letter-spacing: .5px; }

/* ── RESPONSIVO ADMIN ── */
@media (max-width: 768px) {
    .stats-grid { grid-template-columns: 1fr 1fr; }
    .form-grid  { grid-template-columns: 1fr; }
    .form-grid--3, .form-grid--4 { grid-template-columns: 1fr 1fr; }
    .admin-topbar { padding: 10px 14px; }
}
@media (max-width: 480px) {
    .stats-grid { grid-template-columns: 1fr 1fr; }
    .form-grid--3, .form-grid--4 { grid-template-columns: 1fr; }
}
