/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
    --bg:             #FAFAFA;
    --surface:        #FFFFFF;
    --text:           #3D2C23;
    --text-muted:     #A09389;
    --accent:         #A66336;
    --accent-light:   #FCEEE6;
    --border:         #EDE6DF;
    --field-bg:       #F9FAFB;
    --field-ring:     rgba(166, 99, 54, .15);
    --success-bg:     #F0FAF4;
    --success-border: #C3E6D1;
    --success-text:   #166534;
    --success-muted:  #15803D;
    --error:          #DC2626;
    --error-bg:       #FEF2F2;
    --error-border:   rgba(220,38,38,.4);

    --r-xs:   6px;
    --r-sm:   12px;
    --r-md:   20px;
    --r-lg:   28px;
    --r-xl:   36px;
    --r-pill: 100px;

    --sh-card:  0 16px 48px rgba(61,44,35,.055);
    --sh-btn:   0 10px 30px rgba(61,44,35,.2);
    --sh-up:    0 -20px 44px rgba(61,44,35,.07);
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
    font-family:'Nunito',sans-serif;
    color:var(--text);
    background:#DEDAD5;
    display:flex;justify-content:center;
    min-height:100dvh;
    -webkit-tap-highlight-color:transparent;
    overscroll-behavior:none;
}
button,input,select,textarea{font-family:inherit;font-size:inherit}
img{display:block;max-width:100%}

/* ============================================================
   APP SHELL
   ============================================================ */
.app-shell{
    width:100%;max-width:430px;
    background:var(--bg);
    min-height:100dvh;
    position:relative;
    overflow-x:hidden;
    box-shadow:0 0 80px rgba(0,0,0,.08);
    display: grid;
    grid-template-columns: 100%;
    align-items: start;
}

/* ============================================================
   VIEW SYSTEM (Spatial Navigation)
   ============================================================ */
.view {
    display: none;
    grid-column: 1;
    grid-row: 1;
    width: 100%;
    will-change: transform, opacity;
    background: var(--bg); /* previne transparência durante animação */
    z-index: 1;
}
.view.active {
    display: block;
    z-index: 2;
}

/* Base transition settings */
.view-push-enter, .view-push-exit, .view-pop-enter, .view-pop-exit {
    display: block;
    animation-duration: 0.4s;
    animation-timing-function: cubic-bezier(0.28, 0.84, 0.22, 1);
    animation-fill-mode: forwards;
}

/* PUSH: Nova view entra da DIREITA (por cima) */
.view-push-enter { animation-name: pushEnter; z-index: 10; }
@keyframes pushEnter {
    from { transform: translateX(100%); opacity: 1; }
    to   { transform: translateX(0); opacity: 1; }
}

/* PUSH: View atual sai para a ESQUERDA (fundo, paralaxe) */
.view-push-exit { animation-name: pushExit; z-index: 5; }
@keyframes pushExit {
    from { transform: translateX(0); opacity: 1; }
    to   { transform: translateX(-25%); opacity: 0.8; }
}

/* POP: Nova view (anterior) entra da ESQUERDA (fundo, paralaxe) */
.view-pop-enter { animation-name: popEnter; z-index: 5; }
@keyframes popEnter {
    from { transform: translateX(-25%); opacity: 0.8; }
    to   { transform: translateX(0); opacity: 1; }
}

/* POP: View atual sai para a DIREITA (por cima) */
.view-pop-exit { animation-name: popExit; z-index: 10; }
@keyframes popExit {
    from { transform: translateX(0); opacity: 1; }
    to   { transform: translateX(100%); opacity: 1; }
}
/* relampago needs flex */
#view-relampago.active{display:flex;flex-direction:column;min-height:100dvh;padding-bottom:96px}

/* ============================================================
   UTILITIES
   ============================================================ */
.pad-h{padding-left:24px;padding-right:24px}
.pad-bottom-sm{padding-bottom:16px}
.mt{margin-top:20px}
.mb{margin-bottom:20px}
.flex-1{flex:1}

/* ============================================================
   SPINNER ANIMATION
   ============================================================ */
@keyframes spin{to{transform:rotate(360deg)}}
.btn-spinner{width:20px;height:20px;animation:spin .8s linear infinite}

/* ============================================================
   HEADER
   ============================================================ */
.header{display:flex;justify-content:space-between;align-items:center;padding:28px 24px 14px}
.header-left{display:flex;align-items:center;gap:12px}
.avatar{width:50px;height:50px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.06)}
.header-sub{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted)}
.header-title{font-family:'Fredoka',sans-serif;font-size:1.15rem;font-weight:600;margin-top:2px}

/* Cart icon button */
.btn-cart{
    position:relative;
    width:48px;height:48px;border-radius:50%;
    background:var(--surface);border:none;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;color:var(--text);
    box-shadow:var(--sh-card);
    transition:transform .15s;
}
.btn-cart svg{width:22px;height:22px}
.btn-cart:active{transform:scale(.9)}

.cart-badge{
    position:absolute;top:-4px;right:-4px;
    background:var(--accent);color:#fff;
    font-size:.7rem;font-weight:800;
    width:20px;height:20px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    border:2px solid var(--bg);
    transform:scale(0);
    transition:transform .2s cubic-bezier(.34,1.56,.64,1);
}
.cart-badge.visible{transform:scale(1)}

/* ============================================================
   SELECT WRAPPER  (custom arrow, no browser default)
   ============================================================ */
.select-wrapper{
    position:relative;display:flex;align-items:center;
    background:var(--field-bg);
    border:1.5px solid var(--border);
    border-radius:var(--r-sm);
    padding:0 14px;
    transition:border-color .2s,box-shadow .2s;
}
.select-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--field-ring)}
.select-icon{width:18px;height:18px;color:var(--accent);flex-shrink:0;margin-right:10px}
.select-arrow{width:16px;height:16px;color:var(--text-muted);position:absolute;right:16px;pointer-events:none}
.field-select{
    flex:1;appearance:none;-webkit-appearance:none;border:none;background:transparent;
    font-weight:700;font-size:.95rem;color:var(--text);
    padding:14px 20px 14px 0;outline:none !important;cursor:pointer;
}
.field-select:invalid,
.field-select option[value=""]{color:var(--text-muted)}

/* ============================================================
   INPUT FIELDS — ring marrom da paleta, sem azul do navegador
   ============================================================ */
.field-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field-label{font-weight:700;font-size:.85rem;color:var(--text-muted)}
.field-input{
    width:100%;
    background:var(--field-bg);
    border:1.5px solid var(--border);
    border-radius:var(--r-sm);
    padding:14px 16px;
    font-size:1rem;font-weight:600;color:var(--text);
    /* Remove COMPLETELY o outline padrão do browser (azul) */
    outline:none !important;
    -webkit-appearance:none;
    transition:border-color .2s,box-shadow .2s,background .2s;
}
.field-input:focus{
    border-color:var(--accent);
    box-shadow:0 0 0 3px var(--field-ring);
    background:#fff;
}
/* Garante que nenhum input/select/textarea herde o ring azul do navegador */
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
    outline:none !important;
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Error states */
.erro-texto{
    font-size:.82rem;font-weight:700;color:var(--error);
    max-height:0;overflow:hidden;opacity:0;
    transition:max-height .25s ease,opacity .25s ease;
}
.erro-texto.visible{max-height:40px;opacity:1}
.field-error .field-input{border-color:var(--error)!important;background:var(--error-bg)!important}
.field-error .select-wrapper{border-color:var(--error)!important;background:var(--error-bg)!important}

@keyframes shakeX{
    0%,100%{transform:translateX(0)}
    20%,60%{transform:translateX(-7px)}
    40%,80%{transform:translateX(7px)}
}
.error-shake{animation:shakeX .35s ease}

/* ============================================================
   HERO TEXT
   ============================================================ */
.hero-text{
    font-family:'Fredoka',sans-serif;
    font-size:2rem;font-weight:500;
    line-height:1.15;letter-spacing:-.5px;
    margin:22px 0 30px;
}
.hero-text strong{font-weight:600;color:var(--accent)}

/* ============================================================
   PRODUCT CARDS  (Vitrine)
   ============================================================ */
.card-list{display:flex;flex-direction:column;gap:28px;padding-bottom:48px}
.card{
    background:var(--surface);border-radius:var(--r-lg);padding:20px;
    box-shadow:var(--sh-card);display:flex;flex-direction:column;
    position:relative;cursor:pointer;
    transition:transform .15s ease,box-shadow .15s ease;
}
.card:active{transform:scale(.985)}

/* Badges — respiro vertical para não colar na imagem */
.badge{
    position:absolute;top:32px;left:32px;
    background:var(--surface);color:var(--text-muted);
    padding:7px 16px;border-radius:var(--r-pill);
    font-size:.78rem;font-weight:800;
    box-shadow:0 4px 16px rgba(0,0,0,.06);
    display:inline-flex;align-items:center;gap:5px;z-index:2;
}
.badge-accent{background:var(--accent-light);color:var(--accent)}
.badge-icon{width:13px;height:13px}

.card-img-wrap{
    width:100%;
    aspect-ratio:4/3;
    margin-bottom:20px;
    display:block;
    border-radius:18px;
    overflow:hidden;
}
.card-img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.card:hover .card-img{transform:scale(1.06)}

.card-body{display:flex;flex-direction:column}
.card-title{font-family:'Fredoka',sans-serif;font-size:1.4rem;font-weight:600;margin-bottom:6px}
.card-desc{font-size:.92rem;color:var(--text-muted);line-height:1.45;margin-bottom:18px;font-weight:600}

.card-footer{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.card-price{font-size:1.6rem;font-weight:800;letter-spacing:-.5px;display:flex;align-items:baseline;gap:4px}
.card-price small{font-size:.9rem;font-weight:700;color:var(--text-muted)}

/* --- Number roll/fade animation on price-display --- */
.price-display{
    display:inline-block;
    transition:opacity .18s ease,transform .18s ease;
}
.price-display.rolling{
    opacity:0;
    transform:translateY(-6px);
}
.price-display.rolling-in{
    animation:priceRollIn .22s ease forwards;
}
@keyframes priceRollIn{
    from{opacity:0;transform:translateY(8px)}
    to{opacity:1;transform:translateY(0)}
}

/* ============================================================
   STEPPER  (Qty control)
   ============================================================ */
.stepper{display:flex;align-items:center;background:var(--field-bg);border-radius:var(--r-pill);padding:4px}
.stepper-btn{
    width:38px;height:38px;border-radius:50%;border:none;
    background:var(--surface);color:var(--text);cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 2px 6px rgba(0,0,0,.03);
    transition:transform .1s,background .15s,opacity .2s;
}
.stepper-btn svg{width:16px;height:16px}
.stepper-btn.minus{color:var(--text-muted)}
.stepper-btn:active{transform:scale(.88);background:#F0EBE5}
/* Disabled state for stepper buttons */
.stepper-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}
.stepper-val{font-weight:800;font-size:1.1rem;min-width:32px;text-align:center}

.stepper-col{display:flex;flex-direction:column;align-items:center;background:var(--field-bg);border-radius:var(--r-pill);padding:4px}

.stepper-dark{background:var(--text);padding:6px}
.stepper-dark .stepper-btn{background:rgba(255,255,255,.15);color:#fff}
.stepper-dark .stepper-btn:active{background:rgba(255,255,255,.25)}
.stepper-dark .stepper-val{color:#fff}

/* ============================================================
   PRIMARY BUTTON — crossfade simples (sem mudança de dimensão)
   Regra: altura/largura NUNCA mudam. Só cor e opacidade do texto.
   ============================================================ */
.btn-primary{
    width:100%;
    /* Altura fixa via padding e line-height — nunca oscila */
    padding:0;height:58px;line-height:58px;
    border-radius:var(--r-md);border:none;
    background:var(--accent);color:#fff;
    font-weight:800;font-size:1.05rem;cursor:pointer;
    box-shadow: 0 4px 14px rgba(166, 99, 54, 0.35);
    /* Transição suave só em cor e sombra — sem afetar layout */
    transition:background .35s ease, box-shadow .35s ease, transform .15s;
    /* label dentro usa opacidade — nunca escala */
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
    position:relative;
}
.btn-primary:active:not(:disabled){transform:scale(.96);background:#8C5029}
.btn-primary:disabled{cursor:wait}

/* Adicionar botão vitrine contido */
.btn-add{
    width: auto;
    padding: 0 24px;
    align-self: flex-start;
}

/* Wrapper de texto: só opacidade transita, sem scale, sem shift */
.btn-label{
    transition:opacity .2s ease;
    white-space:nowrap;
    font-size:inherit;font-weight:inherit;line-height:inherit;
}

/* Spinner: posição absoluta no centro exato, nunca empurra o label */
.btn-spinner{
    position:absolute;
    top:50%;left:50%;
    width:20px;height:20px;
    margin-top:-10px;margin-left:-10px;
    opacity:0;
    transition:opacity .2s ease;
    pointer-events:none;
}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-primary .btn-spinner svg,
.btn-primary .btn-spinner i{animation:spin .75s linear infinite}

/* Estado: carregando */
.btn-primary.is-loading .btn-label{opacity:0}
.btn-primary.is-loading .btn-spinner{opacity:1}

/* Estado: sucesso — só muda a cor de fundo com fade */
.btn-primary.is-success{
    background:#22c55e;
    box-shadow:0 10px 28px rgba(34,197,94,.3);
}

/* ============================================================
   FLASH VIEW (Link Relâmpago)
   ============================================================ */
.flash-hero{
    width:100%;aspect-ratio:4/3;
    position:relative;overflow:hidden;background:var(--bg);flex-shrink:0;
}
.btn-back{
    position:absolute;top:24px;left:20px;
    width:44px;height:44px;border-radius:50%;
    /* Fundo branco com transparência + blur para sobreviver a qualquer foto */
    background:rgba(255,255,255,.80);
    backdrop-filter:blur(4px);
    -webkit-backdrop-filter:blur(4px);
    border:none;color:var(--text);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;z-index:5;
    box-shadow:0 2px 12px rgba(0,0,0,.12);
    transition:transform .15s, background .2s;
}
.btn-back svg{width:22px;height:22px}
.btn-back:active{transform:scale(.9);background:rgba(255,255,255,.95)}
.flash-hero-img{width:100%;height:100%;object-fit:cover;object-position:center}

/* Bottom Sheet */
.flash-sheet{
    background:var(--surface);
    border-radius:var(--r-xl) var(--r-xl) 0 0;
    padding:28px 24px 32px;
    margin-top:-32px;
    position:relative;z-index:4;
    box-shadow:var(--sh-up);flex:1;
}
.sheet-handle{width:44px;height:5px;background:var(--border);border-radius:3px;margin:0 auto 22px}
.flash-sheet .badge{position:static;margin-bottom:18px}
.sheet-row-between{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.sheet-title{font-family:'Fredoka',sans-serif;font-size:2rem;font-weight:600;line-height:1.1;max-width:60%}
.sheet-price-block{text-align:right}
.sheet-price{font-size:1.8rem;font-weight:800;letter-spacing:-.5px;white-space:nowrap}
.sheet-price small{font-size:1rem;font-weight:700;color:var(--text-muted);margin-right:4px;vertical-align:super}
.sheet-desc{font-size:1rem;color:var(--text-muted);line-height:1.55;font-weight:600;margin-bottom:22px}

/* Scarcity badge */
.scarcity{
    display:inline-flex;align-items:center;gap:8px;
    background:#FFF0ED;color:#C0390D;
    font-weight:800;font-size:.9rem;
    padding:12px 18px;border-radius:var(--r-sm);
    border:1px solid rgba(192,57,13,.14);
}
.scarcity-icon{width:17px;height:17px}
.pulse{animation:pulseGlow 2s infinite}
@keyframes pulseGlow{
    0%{box-shadow:0 0 0 0 rgba(192,57,13,.25);transform:scale(1)}
    70%{box-shadow:0 0 0 10px rgba(192,57,13,0);transform:scale(1.02)}
    100%{box-shadow:0 0 0 0 rgba(192,57,13,0);transform:scale(1)}
}

/* Fixed bottom bar */
.flash-bar{
    position:fixed;bottom:0;left:50%;transform:translateX(-50%);
    width:100%;max-width:430px;
    background:rgba(255,255,255,.94);backdrop-filter:blur(14px);
    padding:14px 24px 28px;
    display:flex;gap:14px;align-items:center;
    z-index:20;border-top:1px solid rgba(0,0,0,.04);
}

/* ============================================================
   CART VIEW
   ============================================================ */
#view-cart {
    flex-direction: column;
    height: 100dvh;
    display: none;
}
#view-cart.active,
#view-cart.view-push-enter,
#view-cart.view-push-exit,
#view-cart.view-pop-enter,
#view-cart.view-pop-exit {
    display: flex;
}

#view-cart .pad-h {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding-bottom: 24px;
}

#cart-items-container {
    flex: 1;
    overflow-y: auto;
    /* scrollbar escondida para look clean nativo */
    scrollbar-width: none; 
}
#cart-items-container::-webkit-scrollbar {
    display: none;
}

.cart-item{
    background:var(--surface);border-radius:var(--r-lg);
    padding:16px 20px;box-shadow:var(--sh-card);
    display:flex;align-items:center;gap:14px;margin-bottom:16px;
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease, margin-bottom 0.3s ease, padding 0.3s ease, height 0.3s ease;
    transform-origin: top center;
}
.cart-item.removing {
    opacity: 0;
    transform: scale(0.9);
    margin-bottom: -16px; /* pull up next item */
    padding-top: 0;
    padding-bottom: 0;
    height: 0;
    overflow: hidden;
    pointer-events: none;
}
.cart-item-img{width:64px;height:64px;object-fit:cover;border-radius:12px;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.06)}
.cart-item-info{flex:1;display:flex;flex-direction:column;justify-content:center}
.cart-item-name{font-family:'Fredoka',sans-serif;font-weight:600;font-size:1.05rem;margin-bottom:4px}
.cart-item-price{font-size:.95rem;font-weight:800;color:var(--accent)}

.cart-empty{text-align:center;padding:48px 24px;color:var(--text-muted)}
.cart-empty svg{width:48px;height:48px;margin:0 auto 16px;opacity:.3}
.cart-empty p{font-weight:700;font-size:1.05rem}

.cart-footer{
    width: 100%;
    background: var(--surface);
    border-radius: var(--r-pill);
    padding: 8px 8px 8px 24px;
    box-shadow: 0 10px 40px rgba(0,0,0,.15);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
    margin-top: 16px; /* spacing between list and footer */
}
.cart-footer-total {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 800;
    font-size: 1.15rem;
}
.cart-footer-total span:first-child {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-muted);
}
.cart-footer .btn-primary {
    width: auto;
    height: 48px;
    line-height: 48px;
    border-radius: var(--r-pill);
    padding: 0 32px;
    margin: 0;
}

/* ============================================================
   CHECKOUT VIEW
   ============================================================ */
.progress-bar-wrap{width:100%;height:3px;background:var(--border)}
.progress-bar{height:3px;background:var(--accent);transition:width .4s ease}

.ck-header{display:flex;align-items:center;padding:22px 24px 18px}
.ck-page-title{font-family:'Fredoka',sans-serif;font-size:1.4rem;font-weight:600;margin-left:14px}

.btn-ghost-round{
    width:44px;height:44px;border-radius:50%;
    background:transparent;border:1.5px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;color:var(--text);transition:transform .15s,background .15s;
}
.btn-ghost-round svg{width:20px;height:20px}
.btn-ghost-round:active{transform:scale(.9);background:var(--field-bg)}

.ck-step{padding:0 24px 48px}

.ck-card{
    background:var(--surface);border-radius:var(--r-lg);
    padding:24px;box-shadow:var(--sh-card);margin-bottom:18px;
}
.ck-card-head{display:flex;align-items:center;margin-bottom:22px}
.ck-card-icon{width:22px;height:22px;margin-right:10px;color:var(--accent)}
.ck-card-title{font-family:'Fredoka',sans-serif;font-size:1.25rem;font-weight:600}

/* Resume */
.resume-line{display:flex;justify-content:space-between;font-weight:600;font-size:1rem;margin-bottom:14px}
.resume-line.muted{color:var(--text-muted)}
.resume-line.dashed{border-bottom:2px dashed var(--border);padding-bottom:16px;margin-bottom:16px}
.resume-line.total{font-weight:800;font-size:1.5rem;margin-bottom:0}
.resume-item{display:flex;justify-content:space-between;font-weight:600;font-size:.95rem;margin-bottom:12px;color:var(--text-muted)}

/* Pix */
.card-pix{background:var(--success-bg);border:1px solid var(--success-border)}
.pix-icon{color:var(--success-text)!important}
.pix-title{color:var(--success-text)!important}
.pix-hint{font-size:.9rem;font-weight:600;color:var(--success-muted);margin-bottom:16px}
.pix-row{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--success-border);border-radius:var(--r-sm);padding:12px 14px}
.pix-key{flex:1;font-size:.82rem;font-weight:700;color:var(--text);word-break:break-all}
.btn-copy{
    display:flex;align-items:center;gap:5px;flex-shrink:0;
    background:var(--success-bg);color:var(--success-muted);
    border:1px solid var(--success-border);
    padding:8px 12px;border-radius:var(--r-xs);
    font-weight:700;font-size:.85rem;cursor:pointer;
    transition:transform .1s;
}
.btn-copy-icon{width:15px;height:15px}
.btn-copy:active{transform:scale(.92)}

/* Actions row */
.ck-actions{display:flex;gap:14px;align-items:stretch}
.btn-ghost-square{
    width:56px;min-height:56px;border-radius:var(--r-sm);
    background:transparent;border:1.5px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;color:var(--text);transition:transform .15s;
}
.btn-ghost-square svg{width:20px;height:20px}
.btn-ghost-square:active{transform:scale(.9);background:var(--field-bg)}

/* ============================================================
   TOAST  (Premium notification — no native alert)
   ============================================================ */
.toast{
    position:fixed;bottom:88px;left:50%;
    transform:translateX(-50%) translateY(16px);
    max-width:370px;width:calc(100% - 48px);
    background:rgba(30,23,18,.92);backdrop-filter:blur(10px);
    color:#fff;padding:14px 20px;
    border-radius:var(--r-md);
    font-weight:700;font-size:.9rem;text-align:center;
    box-shadow:0 8px 32px rgba(0,0,0,.2);
    opacity:0;pointer-events:none;
    transition:opacity .25s ease,transform .25s ease;
    z-index:200;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.toast.toast-success{background:rgba(22,101,52,.9)}
.toast.toast-error{background:rgba(185,28,28,.9)}

/* ============================================================
   RESPONSIVE — desktop hover polish
   ============================================================ */
@media(hover:hover){
    .card:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(61,44,35,.08)}
    .btn-primary:hover{background:#2D201A}
    .btn-cart:hover{transform:scale(1.05)}
}
