/* ===== Design tokens ===== */
:root{
  --orange:#f57b1f;
  --orange-2:#e85b14;
  --blue:#1e4fd6;
  --blue-2:#2c6bff;
  --bg:#ffffff;
  --fg:#0f172a;
  --muted:#f4f6fb;
  --muted-fg:#64748b;
  --border:#e5e9f2;
  --card:#ffffff;
  --shadow-card:0 4px 20px -8px rgba(30,79,214,.18);
  --shadow-md:0 10px 30px -12px rgba(15,23,42,.18);
  --gradient-hero:linear-gradient(135deg,#1e4fd6 0%,#2c6bff 100%);
  --gradient-cta:linear-gradient(135deg,#f88a2c 0%,#ea5a12 100%);
  --radius:12px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--fg);
  background:var(--bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:800;letter-spacing:-.02em;line-height:1.15}
h2{font-size:clamp(1.6rem,3vw,2.25rem)}
h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#fff}
.container{max-width:1200px;margin:0 auto;padding:0 1rem}
.muted{color:var(--muted-fg);font-size:.95rem;margin:.25rem 0 0}
.muted-light{color:rgba(255,255,255,.7);font-size:.9rem;margin-top:.5rem}
.small{font-size:.75rem}
.hidden{display:none!important}
.orange{color:var(--orange)}
.blue{color:var(--blue)}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.7rem 1.2rem;border-radius:10px;border:none;cursor:pointer;
  font-weight:600;font-size:.95rem;transition:transform .15s,opacity .15s,box-shadow .15s,background-color .15s;
  font-family:inherit;
}
.btn-cta{background:var(--gradient-cta);color:#fff;box-shadow:var(--shadow-md)}
.btn-cta:hover{opacity:.92;transform:translateY(-1px)}
.btn-block{width:100%}
.btn-ghost{
  background:transparent;color:var(--fg);border:1px solid var(--border);
}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn-google{
  background:#fff;color:#0f172a;border:1px solid var(--border);
}
.btn-google:hover{background:#f8fafc;border-color:#cbd5e1}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.88);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem}
.logo{display:flex;align-items:center;gap:.6rem}
.logo-badge{
  width:36px;height:36px;border-radius:10px;display:grid;place-items:center;
  background:var(--gradient-cta);color:#fff;box-shadow:var(--shadow-md);
}
.logo-badge svg{width:18px;height:18px}
.logo-text{font-weight:800;font-size:1.1rem;letter-spacing:-.02em}
.main-nav{display:none;gap:1.5rem;font-weight:500;font-size:.95rem}
.main-nav a{color:rgba(15,23,42,.8);transition:color .2s}
.main-nav a:hover{color:var(--orange)}
@media(min-width:768px){.main-nav{display:flex}}

/* ===== Auth area in header ===== */
.auth-area{display:flex;align-items:center;gap:.5rem}
.auth-area .btn{padding:.55rem 1rem;font-size:.875rem}
.user-chip{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--muted);border:1px solid var(--border);
  padding:.35rem .6rem .35rem .35rem;border-radius:999px;font-size:.85rem;font-weight:600;
}
.user-chip .avatar{
  width:28px;height:28px;border-radius:999px;display:grid;place-items:center;
  background:var(--gradient-cta);color:#fff;font-size:.75rem;font-weight:700;
}
.user-chip button{
  background:none;border:none;cursor:pointer;color:var(--muted-fg);
  font-weight:600;font-size:.8rem;padding:0 .3rem;
}
.user-chip button:hover{color:var(--orange)}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;color:#fff;background:var(--gradient-hero)}
.hero-pattern{
  position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(circle at 20% 20%,#fff 1px,transparent 1px),radial-gradient(circle at 80% 60%,#fff 1px,transparent 1px);
  background-size:40px 40px;
}
.hero-inner{position:relative;padding:4rem 1rem;text-align:center;max-width:820px}
@media(min-width:768px){.hero-inner{padding:6rem 1rem}}
.badge-pill{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);
  padding:.4rem 1rem;border-radius:999px;font-size:.75rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;
}
.hero h1{margin-top:1.25rem;font-size:clamp(2rem,5vw,3.75rem);font-weight:800}
.hero-sub{margin-top:1rem;font-size:1.1rem;color:rgba(255,255,255,.9)}
@media(min-width:768px){.hero-sub{font-size:1.25rem}}

.search-bar{
  display:flex;align-items:center;gap:.5rem;
  background:#fff;padding:.5rem;border-radius:18px;
  box-shadow:0 25px 50px -12px rgba(0,0,0,.4);
  margin:2rem auto 0;max-width:640px;
}
.search-bar input{
  flex:1;border:none;outline:none;background:transparent;
  padding:.75rem .5rem;font-size:1rem;color:var(--fg);font-family:inherit;
}
.search-icon{width:20px;height:20px;color:var(--muted-fg);margin-left:.5rem;flex-shrink:0}

.trust-row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:1.25rem;
  margin-top:2rem;font-size:.9rem;color:rgba(255,255,255,.92);
}

/* ===== Sections ===== */
.section{padding:3.5rem 0}
.section-muted{background:var(--muted);border-top:1px solid var(--border)}
.section-head{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}
@media(min-width:768px){.section-head{flex-direction:row;justify-content:space-between;align-items:flex-end}}

/* ===== Filters ===== */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.chip{
  padding:.45rem 1rem;border-radius:999px;border:1px solid var(--border);
  background:#fff;font-size:.875rem;font-weight:500;cursor:pointer;
  transition:all .2s;font-family:inherit;color:var(--fg);
}
.chip:hover{border-color:var(--orange);color:var(--orange)}
.chip.active{background:var(--gradient-cta);color:#fff;border-color:transparent;box-shadow:var(--shadow-md)}

/* ===== Product Grid ===== */
.product-grid{
  display:grid;gap:1rem;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:768px){.product-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}}
@media(min-width:1024px){.product-grid{grid-template-columns:repeat(4,1fr)}}

.product-card{
  position:relative;
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  color:inherit;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--orange)}
.product-img-wrap{position:relative;aspect-ratio:1/1;overflow:hidden;background:#f1f5f9}
.product-img-wrap img,.product-img-wrap video{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block}
.product-card:hover .product-img-wrap img,.product-card:hover .product-img-wrap video{transform:scale(1.06)}
.discount-badge{
  position:absolute;top:.75rem;left:.75rem;
  background:var(--orange);color:#fff;padding:.25rem .75rem;border-radius:999px;
  font-size:.7rem;font-weight:700;box-shadow:var(--shadow-md);
}
.cat-badge{
  position:absolute;top:.75rem;right:.75rem;
  background:rgba(255,255,255,.92);color:var(--blue);
  padding:.25rem .55rem;border-radius:999px;
  font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;
}
.fav-btn{
  position:absolute;bottom:.6rem;right:.6rem;
  width:38px;height:38px;border-radius:999px;border:none;cursor:pointer;
  background:rgba(255,255,255,.95);color:#94a3b8;font-size:1.15rem;line-height:1;
  display:grid;place-items:center;box-shadow:var(--shadow-md);
  transition:transform .15s,color .2s;
}
.fav-btn:hover{transform:scale(1.08);color:#ef4444}
.fav-btn.active{color:#ef4444}
.product-body{display:flex;flex-direction:column;gap:.5rem;padding:1rem;flex:1}
.title-row{display:flex;align-items:flex-start;gap:.5rem}
.product-title{
  font-size:.875rem;font-weight:500;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  height:auto;
}
.store-logo{
  flex-shrink:0;
  width:28px;height:28px;border-radius:8px;
  display:grid;place-items:center;
  font-size:.7rem;font-weight:800;letter-spacing:-.02em;
  box-shadow:0 2px 6px rgba(15,23,42,.18);
  border:1px solid rgba(0,0,0,.05);
}
.product-card:hover .product-title{color:var(--blue)}
.product-prices{margin-top:auto}
.old-price{font-size:.75rem;color:var(--muted-fg);text-decoration:line-through;margin:0}
.price{font-size:1.25rem;font-weight:800;color:var(--orange);margin:0}
.see-offer{
  margin-top:.5rem;background:var(--gradient-cta);color:#fff;
  padding:.55rem 1rem;border-radius:8px;text-align:center;font-size:.875rem;font-weight:600;
  text-decoration:none;display:block;
}
.see-offer:hover{opacity:.92}

/* ===== Empty ===== */
.empty{
  border:2px dashed var(--border);border-radius:14px;
  padding:3rem 1rem;text-align:center;
}
.empty-title{font-size:1.1rem;font-weight:600;margin:0}

/* ===== Pagination ===== */
.pagination{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:2.5rem}
.page-btn{
  min-width:40px;height:40px;padding:0 .75rem;
  border:1px solid var(--border);background:#fff;border-radius:8px;
  font-weight:600;font-size:.875rem;cursor:pointer;font-family:inherit;color:var(--fg);
  transition:all .2s;
}
.page-btn:hover:not(:disabled){border-color:var(--orange)}
.page-btn:disabled{opacity:.45;cursor:not-allowed}
.page-btn.active{background:var(--gradient-cta);color:#fff;border-color:transparent;box-shadow:var(--shadow-md)}

/* ===== Contact ===== */
.contact-grid{display:grid;gap:2.5rem}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info{list-style:none;padding:0;margin-top:1.5rem;display:flex;flex-direction:column;gap:.6rem;font-size:.95rem}
.contact-info a{color:var(--blue);font-weight:500}
.contact-info a:hover{color:var(--orange)}
.card-form{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:1.5rem;box-shadow:var(--shadow-card);
  display:flex;flex-direction:column;gap:1rem;
}
.field label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.4rem}
.field input,.field textarea,.field select{
  width:100%;padding:.65rem .85rem;border:1px solid var(--border);border-radius:8px;
  font-family:inherit;font-size:.95rem;color:var(--fg);background:#fff;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(245,123,31,.15);
}
.form-status{margin:0;font-size:.85rem;min-height:1.2em}
.form-status.error{color:#dc2626}
.form-status.success{color:#16a34a}

/* ===== Footer ===== */
.site-footer{background:#0f172a;color:rgba(255,255,255,.85);margin-top:0}
.footer-grid{display:grid;gap:2.5rem;padding:3rem 1rem}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(3,1fr)}}
.footer-logo{margin-bottom:.5rem}
.footer-links{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}
.footer-links a:hover{color:var(--orange)}
.socials{display:flex;gap:.6rem;margin-top:.75rem}
.socials a{
  width:40px;height:40px;border-radius:999px;display:grid;place-items:center;
  background:rgba(255,255,255,.1);font-weight:700;font-size:.75rem;
  transition:background-color .2s;
}
.socials a:hover{background:var(--orange);color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom-inner{
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:.5rem;
  padding:1.25rem 1rem;font-size:.75rem;color:rgba(255,255,255,.6);
}
@media(min-width:768px){.footer-bottom-inner{flex-direction:row}}

/* ===== Toast ===== */
.toast{
  position:fixed;top:1rem;left:50%;transform:translateX(-50%) translateY(-150%);
  background:#0f172a;color:#fff;padding:.75rem 1.25rem;border-radius:10px;
  box-shadow:var(--shadow-md);font-size:.9rem;font-weight:500;z-index:100;
  transition:transform .35s ease;pointer-events:none;max-width:90vw;
}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.error{background:#dc2626}
.toast.success{background:#16a34a}

/* ===== Modal / Auth ===== */
.modal{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:1rem}
.modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(3px)}
.modal-card{
  position:relative;width:100%;max-width:440px;
  background:#fff;border-radius:18px;padding:1.5rem;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.4);
  max-height:92vh;overflow-y:auto;
  animation:pop .25s ease;
}
@keyframes pop{from{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-close{
  position:absolute;top:.6rem;right:.6rem;
  width:34px;height:34px;border-radius:999px;border:none;
  background:transparent;font-size:1.5rem;cursor:pointer;color:var(--muted-fg);
}
.modal-close:hover{background:var(--muted);color:var(--fg)}
.auth-tabs{display:flex;gap:.4rem;background:var(--muted);padding:.3rem;border-radius:10px;margin-bottom:1.25rem}
.auth-tab{
  flex:1;padding:.55rem;border:none;background:transparent;border-radius:8px;
  cursor:pointer;font-weight:600;font-size:.9rem;color:var(--muted-fg);font-family:inherit;
  transition:all .2s;
}
.auth-tab.active{background:#fff;color:var(--fg);box-shadow:0 2px 6px rgba(15,23,42,.08)}
.auth-title{font-size:1.25rem;margin-bottom:1rem}
.auth-form{display:flex;flex-direction:column;gap:.85rem}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
@media(max-width:480px){.row-2{grid-template-columns:1fr}}
.input-pass{position:relative}
.input-pass input{padding-right:2.5rem}
.pass-toggle{
  position:absolute;right:.4rem;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:8px;border:none;background:transparent;
  cursor:pointer;font-size:1rem;color:var(--muted-fg);
}
.pass-toggle:hover{background:var(--muted);color:var(--fg)}
.divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:var(--muted-fg);font-size:.8rem}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--border)}
.auth-status{margin:.25rem 0 0;font-size:.85rem;min-height:1.2em}
.auth-status.error{color:#dc2626}
.auth-status.success{color:#16a34a}

/* ===== Section head actions ===== */
.head-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}

/* ===== Sort dropdown ===== */
.sort-wrap{position:relative}
.sort-menu{
  position:absolute;right:0;top:calc(100% + .4rem);
  min-width:240px;background:#fff;border:1px solid var(--border);
  border-radius:12px;box-shadow:var(--shadow-md);z-index:30;
  padding:.35rem;display:flex;flex-direction:column;
}
.sort-opt{
  text-align:left;background:transparent;border:none;cursor:pointer;
  padding:.6rem .75rem;border-radius:8px;font:inherit;color:var(--fg);
  font-size:.9rem;font-weight:500;
}
.sort-opt:hover{background:var(--muted);color:var(--orange)}
.sort-opt.active{background:var(--gradient-cta);color:#fff}

/* ===== Stars ===== */
.stars{display:inline-flex;align-items:center;gap:1px;line-height:1;color:#cbd5e1}
.stars .star,.stars .star-btn{font-size:1rem;display:inline-block}
.stars-md .star,.stars-md .star-btn{font-size:1.15rem}
.stars-lg .star,.stars-lg .star-btn{font-size:1.5rem}
.stars .star.filled,.stars .star-btn.filled{color:#facc15}
.stars-interactive .star-btn{
  background:transparent;border:none;cursor:pointer;padding:0 2px;color:#cbd5e1;
  transition:transform .1s,color .15s;
}
.stars-interactive .star-btn:hover{transform:scale(1.1);color:#facc15}
.rating-row{display:flex;align-items:center;gap:.4rem;margin-top:-.15rem}
.rating-count{font-size:.75rem;color:var(--muted-fg)}

/* ===== Product card cursor ===== */
.product-card{cursor:pointer}
.see-offer{cursor:pointer}

/* ===== Product details modal ===== */
.modal-card.modal-lg{max-width:880px}
.pm-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:720px){.pm-grid{grid-template-columns:280px 1fr}}
.pm-img{position:relative;border-radius:14px;overflow:hidden;background:#f1f5f9;aspect-ratio:1/1}
.pm-img img{width:100%;height:100%;object-fit:cover}
.pm-info{display:flex;flex-direction:column;gap:.6rem}
.pm-store-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.pm-store-name{font-size:.85rem;font-weight:600;color:var(--muted-fg)}
.pm-cat{position:static;background:var(--muted);color:var(--blue)}
.pm-title{font-size:1.4rem}
.pm-desc{color:#334155;font-size:.95rem;margin:.25rem 0}
.pm-prices{display:flex;align-items:baseline;gap:.6rem;margin-top:.25rem}
.pm-price{font-size:1.75rem}
.pm-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}
.pm-actions .btn{flex:1;min-width:160px}
.pm-hr{border:none;border-top:1px solid var(--border);margin:1.5rem 0 1rem}
.pm-rating-title{font-size:1rem;margin-bottom:.5rem}
.pm-rating-summary{display:flex;align-items:center;gap:.75rem;margin-bottom:.85rem}
.pm-avg{font-size:1.4rem;color:var(--fg)}
.pm-myrate{background:var(--muted);border-radius:12px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.4rem;align-items:flex-start}

.link-btn{
  background:none;border:none;color:var(--blue);font:inherit;cursor:pointer;
  padding:0;text-decoration:underline;font-weight:600;
}
.link-btn:hover{color:var(--orange)}

/* Login required hints */
.login-hint{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;color:#6b7280}
.login-required{
  background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;
  padding:12px 14px;margin-top:8px;text-align:center;
}
.login-required p{margin:0;color:#7c2d12}

/* ===== Galeria do detalhamento (v3.3) ===== */
.pm-img{aspect-ratio:auto}
.pm-img .pm-main-media{width:100%;height:100%;max-height:420px;object-fit:cover;display:block}
.pm-img video.pm-main-media{background:#000}
.pm-vol{position:absolute;top:.5rem;right:.5rem;background:rgba(0,0,0,.55);color:#fff;border:0;border-radius:999px;width:36px;height:36px;cursor:pointer;font-size:1rem;line-height:1;z-index:2}
.pm-thumbs{display:flex;gap:.5rem;padding:.5rem;background:#fff;border-top:1px solid var(--border);overflow-x:auto}
.pm-thumb{position:relative;flex:0 0 auto;width:64px;height:64px;border-radius:8px;overflow:hidden;border:2px solid transparent;background:#f1f5f9;cursor:pointer;padding:0}
.pm-thumb.is-active{border-color:var(--blue)}
.pm-thumb img,.pm-thumb video{width:100%;height:100%;object-fit:cover;display:block}
.pm-thumb-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.55);color:#fff;border-radius:999px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.7rem;pointer-events:none}


/* ===== Galeria do detalhamento (v3.5) ===== */
.pm-gallery{display:flex;flex-direction:column;gap:.5rem}
.pm-gallery .pm-img{aspect-ratio:auto;border-radius:14px;overflow:hidden;background:#0b1220;position:relative;min-height:220px}
.pm-gallery .pm-img .pm-main-media{width:100%;height:auto;max-height:420px;object-fit:contain;display:block;background:#0b1220}
.pm-gallery .pm-img video.pm-main-media{background:#000}
.pm-gallery .pm-thumbs{display:flex !important;gap:.5rem;padding:.25rem 0;background:transparent;border-top:0;overflow-x:auto}
.pm-gallery .pm-thumb{position:relative;flex:0 0 auto;width:64px;height:64px;border-radius:8px;overflow:hidden;border:2px solid transparent;background:#f1f5f9;cursor:pointer;padding:0}
.pm-gallery .pm-thumb.is-active{border-color:var(--blue,#2563eb)}
.pm-gallery .pm-thumb img,.pm-gallery .pm-thumb video{width:100%;height:100%;object-fit:cover;display:block}
.pm-gallery .pm-thumb-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.55);color:#fff;border-radius:999px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.7rem;pointer-events:none}
.pm-main-empty{display:flex;align-items:center;justify-content:center;color:#94a3b8;min-height:220px;background:#0b1220;border-radius:14px}


/* ===== Galeria do detalhamento (v3.5) ===== */
.pm-gallery{display:flex;flex-direction:column;gap:.5rem}
.pm-gallery .pm-img{aspect-ratio:auto;border-radius:14px;overflow:hidden;background:#0b1220;position:relative;min-height:220px}
.pm-gallery .pm-img .pm-main-media{width:100%;height:auto;max-height:420px;object-fit:contain;display:block;background:#0b1220}
.pm-gallery .pm-img video.pm-main-media{background:#000}
.pm-gallery .pm-thumbs{display:flex !important;gap:.5rem;padding:.25rem 0;background:transparent;border-top:0;overflow-x:auto}
.pm-gallery .pm-thumb{position:relative;flex:0 0 auto;width:64px;height:64px;border-radius:8px;overflow:hidden;border:2px solid transparent;background:#f1f5f9;cursor:pointer;padding:0}
.pm-gallery .pm-thumb.is-active{border-color:var(--blue,#2563eb)}
.pm-gallery .pm-thumb img,.pm-gallery .pm-thumb video{width:100%;height:100%;object-fit:cover;display:block}
.pm-gallery .pm-thumb-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.55);color:#fff;border-radius:999px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.7rem;pointer-events:none}
.pm-main-empty{display:flex;align-items:center;justify-content:center;color:#94a3b8;min-height:220px;background:#0b1220;border-radius:14px}

/* ===== Lupa (v3.6) ===== */
.pm-gallery .pm-img img.pm-main-media{cursor:zoom-in}
.pm-lens{
  position:absolute;width:180px;height:180px;border-radius:999px;
  border:2px solid rgba(255,255,255,.85);
  box-shadow:0 4px 18px rgba(0,0,0,.35);
  background-repeat:no-repeat;background-color:#fff;
  pointer-events:none;opacity:0;transition:opacity .12s ease;
  z-index:3;left:0;top:0;
}
.pm-lens.is-on{opacity:1}
@media (max-width:560px){ .pm-lens{display:none} }

/* ===== User chip menu (v3.9) ===== */
.user-chip-wrap{ position:relative; display:inline-block; }
.user-chip{
  display:inline-flex; align-items:center; gap:8px;
  background:#f1f5f9; border:1px solid #e2e8f0; color:#0f172a;
  padding:6px 12px; border-radius:999px; cursor:pointer;
  font-weight:600; font-size:14px; transition:.15s;
}
.user-chip:hover{ background:#e2e8f0; }
.user-chip .avatar{
  width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg,#6366f1,#ec4899);
  color:#fff; display:inline-flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px;
}
.user-chip .caret{ font-size:12px; opacity:.7; margin-left:2px; }
.user-menu{
  position:absolute; right:0; top:calc(100% + 8px);
  background:#fff; border:1px solid #e5e7eb; border-radius:12px;
  box-shadow:0 10px 30px rgba(15,23,42,.12);
  min-width:180px; padding:6px; z-index:100;
}
.user-menu.hidden{ display:none; }
.user-menu button{
  display:block; width:100%; text-align:left;
  background:transparent; border:0; padding:10px 12px;
  border-radius:8px; cursor:pointer; font-size:14px; color:#0f172a;
}
.user-menu button:hover{ background:#f1f5f9; }
