/* =============================================================================
   componentes.css — blocos reutilizaveis (botao, card, hero, badge, etc.)
   ============================================================================= */

/* --------- Botoes --------- */
.cw-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--espaco-2);
    padding: var(--espaco-3) var(--espaco-5);
    border-radius: var(--raio-md);
    font-weight: 700;
    font-size: var(--texto-md);
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    transition: background var(--transicao-rapida), color var(--transicao-rapida), transform var(--transicao-rapida);
    border: 2px solid transparent;
}
.cw-btn:active { transform: translateY(1px); }

.cw-btn--primario {
    background: var(--cor-marca);
    color: #fff;
}
.cw-btn--primario:hover { background: var(--cor-marca-escura); }

.cw-btn--secundario {
    background: transparent;
    color: var(--cor-marca);
    border-color: var(--cor-marca);
}
.cw-btn--secundario:hover { background: var(--cor-marca); color: #fff; }

.cw-btn--destaque {
    background: var(--cor-destaque);
    color: #fff;
}
.cw-btn--destaque:hover { background: #6a1bb1; }

.cw-btn--lg { padding: var(--espaco-4) var(--espaco-6); font-size: var(--texto-lg); }
.cw-btn--sm { padding: var(--espaco-2) var(--espaco-3); font-size: var(--texto-sm); }
.cw-btn--block { width: 100%; }

/* --------- Card --------- */
.cw-card {
    background: #fff;
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-lg);
    overflow: hidden;
    transition: box-shadow var(--transicao-media), transform var(--transicao-media), border-color var(--transicao-rapida);
    display: flex;
    flex-direction: column;
}
.cw-card:hover {
    border-color: var(--cor-borda-forte);
    box-shadow: var(--sombra-md);
    transform: translateY(-2px);
}

.cw-card__imagem {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    background: var(--cor-fundo-suave);
}

.cw-card__body {
    padding: var(--espaco-4);
    display: flex;
    flex-direction: column;
    gap: var(--espaco-2);
    flex: 1;
}

.cw-card__titulo {
    font-size: var(--texto-md);
    font-weight: 600;
    color: var(--cor-texto);
    line-height: 1.3;
}

.cw-card__subtitulo {
    font-size: var(--texto-sm);
    color: var(--cor-texto-suave);
}

.cw-card__preco {
    font-size: var(--texto-xl);
    font-weight: 700;
    color: var(--cor-marca);
    margin-top: auto;
}

/* --------- Hero --------- */
.cw-hero {
    background: linear-gradient(135deg, var(--cor-marca), var(--cor-marca-escura));
    color: #fff;
    padding: var(--espaco-8) var(--espaco-4);
    text-align: center;
    border-radius: var(--raio-xl);
    margin-bottom: var(--espaco-7);
}

.cw-hero__titulo {
    font-family: var(--fonte-destaque);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 700;
    margin-bottom: var(--espaco-3);
    line-height: 1.1;
}

.cw-hero__subtitulo {
    font-size: var(--texto-lg);
    opacity: 0.9;
    max-width: 650px;
    margin: 0 auto var(--espaco-5);
    line-height: 1.5;
}

.cw-hero__acoes {
    display: flex;
    gap: var(--espaco-3);
    justify-content: center;
    flex-wrap: wrap;
}

/* --------- Grid de cards --------- */
.cw-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--espaco-4);
}

/* --------- Secao com titulo --------- */
.cw-secao { margin-bottom: var(--espaco-7); }

.cw-secao__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--espaco-4);
    margin-bottom: var(--espaco-5);
    padding-bottom: var(--espaco-3);
    border-bottom: 2px solid var(--cor-borda);
}

.cw-secao__titulo {
    font-size: var(--texto-2xl);
    font-weight: 700;
    color: var(--cor-texto);
}

.cw-secao__link {
    font-size: var(--texto-sm);
    color: var(--cor-marca);
    font-weight: 600;
}
.cw-secao__link:hover { text-decoration: underline; }

/* --------- Badge --------- */
.cw-badge {
    display: inline-block;
    padding: 2px var(--espaco-2);
    border-radius: var(--raio-pill);
    font-size: var(--texto-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.cw-badge--sucesso { background: #dcfce7; color: #15803d; }
.cw-badge--aviso   { background: #fef3c7; color: #92400e; }
.cw-badge--erro    { background: #fee2e2; color: #991b1b; }
.cw-badge--info    { background: #dbeafe; color: #1e40af; }

/* --------- Alert / Mensagem --------- */
.cw-alert {
    padding: var(--espaco-3) var(--espaco-4);
    border-radius: var(--raio-md);
    border-left: 4px solid;
    margin-bottom: var(--espaco-4);
    font-size: var(--texto-sm);
    line-height: 1.5;
}
.cw-alert--info    { background: #eff6ff; border-color: #3b82f6; color: #1e40af; }
.cw-alert--sucesso { background: #f0fdf4; border-color: #22c55e; color: #15803d; }
.cw-alert--aviso   { background: #fffbeb; border-color: #f59e0b; color: #92400e; }
.cw-alert--erro    { background: #fef2f2; border-color: #ef4444; color: #991b1b; }

/* =============================================================================
   Stories (categorias circulares — faixa horizontal no topo da home)
   ============================================================================= */
.cw-stories {
    display: flex;
    gap: var(--espaco-4);
    overflow-x: auto;
    overflow-y: hidden;
    padding: var(--espaco-4) var(--espaco-2);
    margin-bottom: var(--espaco-6);
    scrollbar-width: thin;
    scroll-snap-type: x proximity;
}
.cw-stories::-webkit-scrollbar { height: 6px; }
.cw-stories::-webkit-scrollbar-thumb { background: var(--cor-borda-forte); border-radius: 3px; }

.cw-story {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--espaco-2);
    text-align: center;
    scroll-snap-align: start;
    max-width: 96px;
}
.cw-story__avatar {
    width: 80px; height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--cor-marca);
    padding: 3px;
    background: #fff;
    transition: transform var(--transicao-rapida), border-color var(--transicao-rapida);
}
.cw-story:hover .cw-story__avatar {
    transform: scale(1.05);
    border-color: var(--cor-destaque);
}
.cw-story__nome {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--cor-texto);
    line-height: 1.2;
    max-width: 90px;
    word-wrap: break-word;
}

/* =============================================================================
   Card de produto — usado em grids e carrosseis
   ============================================================================= */
.cw-produto {
    background: #fff;
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-md);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    transition: box-shadow var(--transicao-media), transform var(--transicao-media), border-color var(--transicao-rapida);
}
.cw-produto:hover {
    border-color: var(--cor-marca-clara);
    box-shadow: var(--sombra-md);
    transform: translateY(-3px);
}

.cw-produto__imagem {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background: #fff;
}

.cw-produto__body {
    padding: var(--espaco-3);
    display: flex;
    flex-direction: column;
    gap: var(--espaco-1);
    flex: 1;
}

.cw-produto__nome {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--cor-texto);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.6em;
}

.cw-produto__preco {
    font-size: var(--texto-lg);
    font-weight: 700;
    color: var(--cor-marca);
    margin-top: var(--espaco-1);
    text-align: center;
}


/* =============================================================================
   Carrossel horizontal (usado pelas categorias da home)
   ============================================================================= */
.cw-carrossel { margin-bottom: var(--espaco-6); }

.cw-carrossel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--espaco-3);
    margin-bottom: var(--espaco-3);
    padding-bottom: var(--espaco-2);
    border-bottom: 2px solid var(--cor-marca);
}

.cw-carrossel__titulo {
    font-size: var(--texto-xl);
    font-weight: 700;
    color: var(--cor-texto);
}

.cw-carrossel__link {
    font-size: var(--texto-sm);
    color: var(--cor-marca);
    font-weight: 600;
    white-space: nowrap;
}
.cw-carrossel__link:hover { text-decoration: underline; }

.cw-carrossel__area {
    position: relative;
}

.cw-carrossel__trilho {
    display: flex;
    gap: var(--espaco-3);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    padding-bottom: var(--espaco-3);
    scrollbar-width: thin;
}
.cw-carrossel__trilho::-webkit-scrollbar { height: 8px; }
.cw-carrossel__trilho::-webkit-scrollbar-thumb { background: var(--cor-borda-forte); border-radius: 4px; }

.cw-carrossel__trilho > .cw-produto {
    flex: 0 0 220px;
    scroll-snap-align: start;
}

.cw-carrossel__seta {
    position: absolute;
    top: 45%;
    transform: translateY(-50%);
    z-index: 5;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--cor-fundo-esc);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    box-shadow: var(--sombra-md);
    opacity: 0;
    transition: opacity var(--transicao-rapida), transform var(--transicao-rapida);
    pointer-events: none;
}
.cw-carrossel__seta--esquerda { left: 8px;  }
.cw-carrossel__seta--direita  { right: 8px; }
.cw-carrossel__area:hover .cw-carrossel__seta {
    opacity: 0.9;
    pointer-events: auto;
}
.cw-carrossel__seta:hover { transform: translateY(-50%) scale(1.1); opacity: 1; }
.cw-carrossel__seta.is-oculto { display: none; }

/* =============================================================================
   Grid (ultimos lancamentos, listagens)
   ============================================================================= */
.cw-grid-produtos {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--espaco-3);
}

/* =============================================================================
   Newsletter
   ============================================================================= */
.cw-newsletter {
    background: var(--cor-fundo-esc);
    color: #fff;
    border-radius: var(--raio-xl);
    padding: var(--espaco-6);
    margin-bottom: var(--espaco-6);
    text-align: center;
}

.cw-newsletter__titulo {
    font-size: var(--texto-2xl);
    font-weight: 700;
    margin-bottom: var(--espaco-2);
}
.cw-newsletter__titulo span { color: var(--cor-marca-clara); }

.cw-newsletter__texto {
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: var(--espaco-4);
    max-width: 540px;
    margin-inline: auto;
}

.cw-newsletter__form {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: var(--espaco-2);
    max-width: 720px;
    margin-inline: auto;
}
.cw-newsletter__form input {
    padding: var(--espaco-3) var(--espaco-4);
    border: 2px solid transparent;
    border-radius: var(--raio-md);
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: var(--texto-md);
}
.cw-newsletter__form button { grid-column: 1 / -1; }
.cw-newsletter__form input::placeholder { color: rgba(255, 255, 255, 0.6); }
.cw-newsletter__form input:focus {
    outline: none;
    background: #fff;
    color: var(--cor-texto);
    border-color: var(--cor-marca);
}
.cw-newsletter__msg { margin-top: var(--espaco-3); font-size: var(--texto-sm); }
.cw-newsletter__msg--ok  { color: var(--cor-marca-clara); }
.cw-newsletter__msg--err { color: #fca5a5; }

@media (max-width: 720px) {
    .cw-newsletter__form { grid-template-columns: 1fr; }
}

/* =============================================================================
   Modal de aviso generico (cw-aviso-modal*) — pop-up centralizado com OK.
   Reutilizavel em qualquer feedback (newsletter, formularios, etc).
   ============================================================================= */
.cw-aviso-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--espaco-4);
    animation: cw-aviso-modal-fade 0.2s ease-out;
}

.cw-aviso-modal[hidden] { display: none; }

.cw-aviso-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.65);
    backdrop-filter: blur(4px);
    cursor: pointer;
}

.cw-aviso-modal__box {
    position: relative;
    background: var(--cor-fundo);
    border-radius: var(--raio-xl);
    padding: var(--espaco-6) var(--espaco-5);
    max-width: 480px;
    width: 100%;
    text-align: center;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.25);
    animation: cw-aviso-modal-slide 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--espaco-3);
}

.cw-aviso-modal__icone {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 42px;
    font-weight: 900;
    line-height: 1;
    margin-bottom: var(--espaco-1);
}

.cw-aviso-modal--sucesso .cw-aviso-modal__icone {
    background: #d1fae5;
    color: var(--cor-marca);
}
.cw-aviso-modal--sucesso .cw-aviso-modal__icone::before { content: '✓'; }

.cw-aviso-modal--erro .cw-aviso-modal__icone {
    background: #fee2e2;
    color: var(--cor-alerta);
}
.cw-aviso-modal--erro .cw-aviso-modal__icone::before { content: '✕'; }

.cw-aviso-modal__titulo {
    font-size: var(--texto-xl);
    color: var(--cor-texto);
    margin: 0;
    line-height: 1.3;
}
.cw-aviso-modal--sucesso .cw-aviso-modal__titulo { color: var(--cor-marca-escura); }
.cw-aviso-modal--erro    .cw-aviso-modal__titulo { color: var(--cor-alerta); }

.cw-aviso-modal__msg {
    font-size: var(--texto-md);
    line-height: 1.6;
    color: var(--cor-texto-suave);
    margin: 0;
}

.cw-aviso-modal__ok {
    margin-top: var(--espaco-3);
    min-width: 160px;
}

@keyframes cw-aviso-modal-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes cw-aviso-modal-slide {
    from { opacity: 0; transform: translateY(20px) scale(0.95); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* =============================================================================
   Campo de formulario (cw-campo*) — reutilizavel em vendedor, assinante etc.
   ============================================================================= */
.cw-campo {
    display: flex;
    flex-direction: column;
    gap: var(--espaco-2);
}

.cw-campo__label {
    font-weight: 600;
    font-size: var(--texto-sm);
    color: var(--cor-texto);
    display: flex;
    align-items: center;
    gap: var(--espaco-1);
}

.cw-campo__obrig {
    color: var(--cor-alerta);
    font-weight: 700;
}

.cw-campo__hint {
    font-weight: 400;
    color: var(--cor-texto-fraco);
    font-size: var(--texto-xs);
    margin: 0;
}

.cw-campo__input,
.cw-campo__select,
.cw-campo__textarea {
    font-family: inherit;
    font-size: var(--texto-md);
    padding: var(--espaco-3) var(--espaco-4);
    border: 1px solid var(--cor-borda-forte);
    border-radius: var(--raio-md);
    background: var(--cor-fundo);
    color: var(--cor-texto);
    transition: border-color var(--transicao-rapida), box-shadow var(--transicao-rapida);
    width: 100%;
}

.cw-campo__input:focus,
.cw-campo__select:focus,
.cw-campo__textarea:focus {
    outline: none;
    border-color: var(--cor-marca);
    box-shadow: 0 0 0 3px rgba(0, 138, 32, 0.15);
}

.cw-campo__input:invalid:not(:placeholder-shown),
.cw-campo__select:invalid:not([value=""]),
.cw-campo__textarea:invalid:not(:placeholder-shown) {
    border-color: var(--cor-alerta);
}

.cw-campo__input.is-invalido,
.cw-campo__select.is-invalido,
.cw-campo__textarea.is-invalido {
    border-color: var(--cor-alerta);
    background: #fff5f5;
}

.cw-campo__textarea {
    resize: vertical;
    min-height: 110px;
    line-height: 1.5;
}

/* =============================================================================
   Lightbox — reutilizavel em produto, pacote, blog etc.
   Ativado via JS: document.body.appendChild(lb) com classe .cw-lightbox
   ============================================================================= */
.cw-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--espaco-4);
    animation: cw-lightbox-fade 0.2s ease-out;
}
.cw-lightbox[hidden] { display: none; }

.cw-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.92);
    backdrop-filter: blur(4px);
    cursor: zoom-out;
}

.cw-lightbox__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--espaco-3);
    width: 100%;
    height: 88vh;
    max-width: 100%;
}

.cw-lightbox__img {
    max-width: 80vw;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: var(--raio-md);
    box-shadow: 0 10px 60px rgba(0, 0, 0, 0.6);
    animation: cw-lightbox-zoom 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    align-self: center;
}

.cw-lightbox__close {
    position: absolute;
    top: var(--espaco-4);
    right: var(--espaco-4);
    width: 44px; height: 44px;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transicao-rapida), transform var(--transicao-rapida);
}
.cw-lightbox__close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: scale(1.1);
}

.cw-lightbox__seta {
    flex: 0 0 auto;
    align-self: center;
    width: 56px; height: 56px;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    font-size: 40px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transicao-rapida), transform var(--transicao-rapida);
}
.cw-lightbox__seta:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: scale(1.08);
}

.cw-lightbox__contador {
    position: absolute;
    bottom: var(--espaco-4);
    left: 50%;
    transform: translateX(-50%);
    padding: 6px 14px;
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    border-radius: 999px;
    font-size: var(--texto-sm);
    font-weight: 700;
}

/* Uma imagem so: esconde setas + contador */
.cw-lightbox--solo .cw-lightbox__seta,
.cw-lightbox--solo .cw-lightbox__contador {
    display: none;
}

@keyframes cw-lightbox-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes cw-lightbox-zoom {
    from { opacity: 0; transform: scale(0.9); }
    to   { opacity: 1; transform: scale(1); }
}

@media (max-width: 600px) {
    .cw-lightbox__inner { gap: var(--espaco-1); }
    .cw-lightbox__seta  { width: 40px; height: 40px; font-size: 28px; }
    .cw-lightbox__img   { max-width: 72vw; }
    .cw-lightbox__close { top: var(--espaco-2); right: var(--espaco-2); }
}
