/* ===== LOJA PAGE STYLES — Paleta Miolli ===== */
/* #ccc7c0 areia | #cead84 dourado | #886150 terracota | #1a1923 noite */

:root {
    --areia:     #ccc7c0;
    --dourado:   #cead84;
    --terracota: #886150;
    --noite:     #1a1923;
    /* aliases */
    --preto:       var(--noite);
    --branco:      #f7f4f0;
    --ouro:        var(--dourado);
    --ouro-claro:  #d8bc9a;
    --ouro-escuro: var(--terracota);
    --cinza:       #9a9490;
    --cinza-claro: #e5dfd8;
    --cinza-escuro:#3a3530;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Montserrat',sans-serif; background:var(--branco); color:var(--noite); overflow-x:hidden; }

/* BANNER */
.page-banner { margin-top:80px; background:var(--noite); padding:64px 40px; position:relative; overflow:hidden; text-align:center; }
.page-banner::before { content:'LOJA'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:'Cormorant Garamond',serif; font-size:14rem; font-weight:700; color:rgba(206,173,132,0.05); letter-spacing:24px; white-space:nowrap; pointer-events:none; }
.banner-inner { position:relative; z-index:1; max-width:1140px; margin:0 auto; }
.banner-pre { display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:20px; }
.banner-pre-line { width:40px; height:1px; background:var(--dourado); }
.banner-pre-text { font-size:0.6rem; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--dourado); }
.banner-title { font-family:'Cormorant Garamond',serif; font-size:3.6rem; font-weight:300; color:var(--areia); line-height:1.15; margin-bottom:12px; }
.banner-title em { font-style:italic; color:var(--dourado); }
.banner-desc { font-size:0.75rem; font-weight:300; letter-spacing:0.5px; color:rgba(204,199,192,0.5); line-height:2; }

/* LOJA LAYOUT */
.loja-section { padding:64px 0 100px; }
.loja-container { max-width:1140px; margin:0 auto; padding:0 40px; display:flex; gap:48px; align-items:flex-start; }

/* SIDEBAR */
.sidebar { width:220px; flex-shrink:0; position:sticky; top:104px; }
.filter-block { margin-bottom:40px; }
.filter-block-title { font-size:0.68rem; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--noite); margin-bottom:18px; padding-bottom:10px; border-bottom:2px solid var(--noite); }

.cat-list { list-style:none; }
.cat-list li { margin-bottom:2px; }
.cat-list a { display:block; font-size:0.62rem; font-weight:500; letter-spacing:1.8px; text-transform:uppercase; color:var(--cinza); text-decoration:none; padding:7px 0; border-bottom:1px solid transparent; transition:color 0.2s,border-color 0.2s; cursor:pointer; }
.cat-list a:hover { color:var(--noite); }
.cat-list a.active { color:var(--terracota); border-bottom-color:var(--terracota); }

.price-range-wrap { display:flex; flex-direction:column; gap:12px; }
.price-track { position:relative; height:3px; background:var(--cinza-claro); border-radius:2px; margin:8px 0 4px; }
.price-fill { position:absolute; height:100%; background:var(--terracota); border-radius:2px; }
input[type="range"].range-min,input[type="range"].range-max { -webkit-appearance:none; appearance:none; position:absolute; top:-6px; left:0; width:100%; height:16px; background:transparent; pointer-events:none; }
input[type="range"].range-min::-webkit-slider-thumb,input[type="range"].range-max::-webkit-slider-thumb { -webkit-appearance:none; width:14px; height:14px; background:var(--terracota); border-radius:50%; pointer-events:all; cursor:pointer; border:2px solid var(--branco); box-shadow:0 0 0 1px var(--terracota); transition:background 0.2s; }
input[type="range"].range-min::-webkit-slider-thumb:hover,input[type="range"].range-max::-webkit-slider-thumb:hover { background:var(--dourado); box-shadow:0 0 0 1px var(--dourado); }
.price-display { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.price-input { width:68px; border:1px solid var(--cinza-claro); padding:8px; font-family:'Montserrat',sans-serif; font-size:0.66rem; font-weight:500; color:var(--noite); text-align:center; outline:none; transition:border-color 0.2s; background:transparent; }
.price-input:focus { border-color:var(--terracota); }
.price-sep { font-size:0.6rem; color:var(--cinza); }
.btn-filtrar { padding:9px 16px; background:var(--noite); color:var(--areia); border:none; font-family:'Montserrat',sans-serif; font-size:0.58rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:background 0.25s; }
.btn-filtrar:hover { background:var(--terracota); }

.size-grid { display:flex; flex-wrap:wrap; gap:8px; }
.size-btn { min-width:42px; height:42px; padding:0 6px; border:1px solid var(--cinza-claro); background:none; font-family:'Montserrat',sans-serif; font-size:0.58rem; font-weight:600; letter-spacing:0.5px; text-transform:uppercase; color:var(--cinza); cursor:pointer; transition:all 0.2s; display:flex; align-items:center; justify-content:center; border-radius:50%; }
.size-btn:hover { border-color:var(--noite); color:var(--noite); }
.size-btn.active { background:var(--noite); border-color:var(--noite); color:var(--areia); }

.tipo-list { list-style:none; }
.tipo-list li { margin-bottom:2px; }
.tipo-list a { display:flex; align-items:center; gap:10px; font-size:0.6rem; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; color:var(--cinza); text-decoration:none; padding:7px 0; border-bottom:1px solid transparent; transition:color 0.2s; cursor:pointer; }
.tipo-list a:hover { color:var(--noite); }
.tipo-list a.active { color:var(--terracota); border-bottom-color:var(--terracota); }
.tipo-dot { width:6px; height:6px; border-radius:50%; background:var(--cinza-claro); flex-shrink:0; transition:background 0.2s; }
.tipo-list a.active .tipo-dot { background:var(--terracota); }
.tipo-list a:hover .tipo-dot { background:var(--noite); }

.clear-filters { display:inline-flex; align-items:center; gap:6px; font-size:0.58rem; font-weight:500; letter-spacing:2px; text-transform:uppercase; color:var(--cinza); background:none; border:none; cursor:pointer; transition:color 0.2s; padding:0; margin-top:8px; }
.clear-filters:hover { color:var(--terracota); }
.clear-filters svg { width:11px; height:11px; stroke:currentColor; stroke-width:2; fill:none; }

/* ÁREA PRODUTOS */
.produtos-area { flex:1; min-width:0; }
.produtos-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:32px; padding-bottom:20px; border-bottom:1px solid var(--cinza-claro); flex-wrap:wrap; gap:12px; }
.toolbar-count { font-size:0.62rem; letter-spacing:1.5px; color:var(--cinza); text-transform:uppercase; }
.toolbar-count strong { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:400; color:var(--noite); margin-right:6px; }
.sort-select { appearance:none; background:transparent; border:1px solid var(--cinza-claro); padding:9px 36px 9px 14px; font-family:'Montserrat',sans-serif; font-size:0.6rem; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; color:var(--cinza-escuro); cursor:pointer; outline:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a9490' stroke-width='1.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; transition:border-color 0.3s; }
.sort-select:hover,.sort-select:focus { border-color:var(--terracota); }

.produtos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:36px 20px; }
.prod-card { position:relative; cursor:pointer; }
.prod-img-wrap { position:relative; overflow:hidden; aspect-ratio:3/4; margin-bottom:16px; }
.prod-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; display:block; }
.prod-card:hover .prod-img-wrap img { transform:scale(1.04); }
.prod-badge { position:absolute; top:12px; left:12px; background:var(--terracota); color:var(--areia); font-size:0.48rem; font-weight:700; letter-spacing:2px; padding:4px 10px; text-transform:uppercase; }
.prod-badge-new { position:absolute; top:12px; right:12px; background:var(--noite); color:var(--areia); font-size:0.48rem; font-weight:700; letter-spacing:2px; padding:4px 10px; text-transform:uppercase; }
.prod-add { position:absolute; bottom:0; left:0; right:0; background:var(--noite); color:var(--areia); padding:13px; font-size:0.55rem; font-weight:600; letter-spacing:2px; text-transform:uppercase; border:none; cursor:pointer; transform:translateY(100%); transition:transform 0.3s ease; display:flex; align-items:center; justify-content:center; gap:8px; }
.prod-add svg { width:13px; height:13px; stroke:var(--dourado); stroke-width:2; fill:none; }
.prod-card:hover .prod-add { transform:translateY(0); }
.prod-brand { font-size:0.52rem; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--terracota); margin-bottom:5px; }
.prod-name { font-family:'Cormorant Garamond',serif; font-size:1.05rem; font-weight:400; color:var(--noite); line-height:1.3; margin-bottom:10px; }
.prod-prices { display:flex; align-items:baseline; gap:10px; }
.price-old { font-size:0.67rem; color:var(--cinza); text-decoration:line-through; }
.price-now { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:600; color:var(--noite); }
.prod-sizes-preview { display:flex; gap:4px; margin-top:8px; flex-wrap:wrap; }
.size-dot { font-size:0.46rem; letter-spacing:0.5px; font-weight:600; color:var(--cinza); text-transform:uppercase; border:1px solid var(--cinza-claro); padding:3px 6px; }

.empty-state { grid-column:1/-1; text-align:center; padding:80px 0; display:none; }
.empty-state.show { display:block; }
.empty-state p { font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:300; color:var(--cinza); }

/* STRIP */
.strip-section { background:var(--areia); padding:64px 40px; text-align:center; }
.strip-inner { max-width:700px; margin:0 auto; }
.strip-ornament { display:flex; align-items:center; justify-content:center; gap:20px; margin-bottom:28px; }
.ornament-line { width:60px; height:1px; background:var(--dourado); opacity:0.6; }
.ornament-diamond { width:6px; height:6px; background:var(--dourado); transform:rotate(45deg); }
.strip-title { font-family:'Cormorant Garamond',serif; font-size:2.2rem; font-weight:300; color:var(--noite); line-height:1.4; margin-bottom:16px; }
.strip-title em { font-style:italic; color:var(--terracota); }
.strip-text { font-size:0.76rem; font-weight:300; color:var(--cinza); line-height:2; letter-spacing:0.3px; }

/* MOBILE FILTER TOGGLE */
.mobile-filter-toggle { display:none; align-items:center; gap:8px; background:var(--noite); color:var(--areia); border:none; padding:11px 20px; font-family:'Montserrat',sans-serif; font-size:0.6rem; font-weight:600; letter-spacing:2px; text-transform:uppercase; cursor:pointer; margin-bottom:20px; }
.mobile-filter-toggle svg { width:14px; height:14px; stroke:var(--areia); stroke-width:2; fill:none; }
.sidebar.mobile-open { display:block !important; }

@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.banner-pre   { animation:fadeUp 0.7s ease both; animation-delay:0.1s; }
.banner-title { animation:fadeUp 0.8s ease both; animation-delay:0.25s; }
.banner-desc  { animation:fadeUp 0.8s ease both; animation-delay:0.4s; }

@media(max-width:1024px){
    .loja-container{padding:0 32px;gap:32px}
    .produtos-grid{grid-template-columns:repeat(2,1fr)} .sidebar{width:190px}
}
@media(max-width:768px){
    .page-banner{padding:52px 24px} .banner-title{font-size:2.4rem}
    .loja-section{padding:32px 0 80px} .loja-container{padding:0 24px;flex-direction:column;gap:0}
    .sidebar{width:100%;position:static;display:none;margin-bottom:24px} .mobile-filter-toggle{display:flex}
    .produtos-grid{grid-template-columns:repeat(2,1fr);gap:24px 12px}
    .strip-section{padding:52px 24px}
}
@media(max-width:480px){ .produtos-grid{grid-template-columns:1fr} }
