:root{
  --bg:#f5f7fc;
  --bg-2:#eef4ff;
  --card:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:#e6edf8;
  --blue:#3b82f6;
  --blue-2:#2563eb;
  --blue-3:#dfeafe;
  --blue-dark:#16386f;
  --soft:#eef4ff;
  --success:#22a95f;
  --shadow:0 14px 34px rgba(27,61,132,.10);
  --shadow-soft:0 8px 24px rgba(27,61,132,.08);
  --radius:22px;
  --radius-sm:16px;
  --container:min(1180px, calc(100% - 40px));
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,Arial,sans-serif;background:var(--bg);color:var(--text)}
body{
  min-height:100vh;
  background:
    radial-gradient(circle at top left, rgba(59,130,246,.08), transparent 26%),
    radial-gradient(circle at bottom right, rgba(59,130,246,.08), transparent 22%),
    linear-gradient(180deg, #f9fbff 0%, #f4f7fc 100%);
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button,input{font:inherit}
.container{width:var(--container);margin:auto}
.page-shell{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}

.nav-wrap{
  position:relative;z-index:100;
  backdrop-filter:blur(12px);
  background:rgba(255,255,255,.92);
  border-bottom:1px solid rgba(232,237,247,.75);
}
.nav{
  min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative;
}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.85rem;letter-spacing:-.02em}
.brand-icon{width:40px;height:28px;position:relative;flex:0 0 auto}
.brand-icon:before,.brand-icon:after,.brand-icon span{content:"";position:absolute;border:2.5px solid #4ba3df;border-radius:999px;background:transparent}
.brand-icon span{left:9px;top:4px;width:19px;height:16px}
.brand-icon:before{left:0;top:9px;width:17px;height:12px}
.brand-icon:after{right:0;top:9px;width:17px;height:12px}
.brand b{color:#1f2937}
.nav-links{display:flex;align-items:center;gap:30px;font-weight:500;color:#1f2937}
.nav-links a.active{color:var(--blue)}
.nav-actions{display:flex;gap:12px;align-items:center;position:relative}
.menu-btn{
  display:none;border:none;background:#fff;border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);
  color:#3b82f6;font-size:1.1rem;min-width:50px;min-height:50px;cursor:pointer
}
.mobile-menu{
  display:none;position:absolute;right:0;top:calc(100% + 12px);width:min(300px, calc(100vw - 24px));
  background:rgba(255,255,255,.98);border:1px solid #e6edf8;border-radius:18px;box-shadow:0 18px 40px rgba(15,23,42,.16);padding:12px;
}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:14px 16px;border-radius:12px;font-weight:600;color:#1f2937}
.mobile-menu a:hover,.mobile-menu a.active{background:#eef4ff;color:#2563eb}
.mobile-divider{height:1px;background:#e8edf7;margin:8px 0}

.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:12px 18px;font-weight:600;border:1px solid transparent;transition:.2s ease;cursor:pointer;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-outline{background:#fff;border-color:#c9d8f4;color:#2563eb}
.btn-primary{background:linear-gradient(180deg,var(--blue),var(--blue-2));color:#fff;box-shadow:0 10px 20px rgba(37,99,235,.18)}
.btn-soft{background:#fff;border-color:var(--line);color:#24406f}
.btn-green{background:#fff;border-color:#d7efdd;color:#208a43}
.btn-icon{width:52px;padding:0}

.footer{margin-top:48px;border-top:1px solid var(--line);background:rgba(255,255,255,.8)}
.footer-inner{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:26px;padding:38px 0 24px}
.footer-brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.4rem}
.footer-text{color:var(--muted);line-height:1.7;margin-top:14px;max-width:420px}
.footer-col h4{margin:0 0 12px;font-size:1rem}
.footer-links{display:grid;gap:10px;color:#4b5563}
.footer-bottom{padding:18px 0 26px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;color:#6b7280;font-size:.95rem}

.section{padding:34px 0}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}
h1,h2,h3,h4,p{margin-top:0}
h2{font-size:clamp(1.8rem,3vw,2.6rem);letter-spacing:-.03em}
.card-glass{background:rgba(255,255,255,.82);border:1px solid rgba(230,236,246,.95);border-radius:24px;box-shadow:var(--shadow);backdrop-filter:blur(8px)}

.hero-home{padding:0 0 42px}
.hero-home-card{
  position:relative;overflow:hidden;min-height:430px;width:100%;border-radius:0;
  background:
    linear-gradient(90deg, rgba(8,21,47,.82) 0%, rgba(17,38,76,.58) 35%, rgba(17,38,76,.18) 100%),
    url('https://images.unsplash.com/photo-1550009158-9ebf69173e03?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
  box-shadow:var(--shadow)
}
.hero-home-inner{width:var(--container);margin:auto;padding:72px 0 46px;position:relative;z-index:2}
.hero-home h1{max-width:640px;margin:0 0 18px;font-size:clamp(2.4rem,5vw,4.2rem);line-height:1.04;letter-spacing:-.04em;color:#fff}
.hero-home p{max-width:720px;margin:0 0 28px;font-size:clamp(1rem,1.8vw,1.38rem);line-height:1.5;color:rgba(255,255,255,.92)}
.search-box{width:min(760px,100%);background:#fff;border-radius:18px;padding:14px;display:flex;gap:14px;align-items:center;box-shadow:0 16px 30px rgba(0,0,0,.18)}
.search-box input{flex:1;border:none;outline:none;font-size:1.05rem;padding:14px 12px;color:#111827;background:transparent}
.search-box .btn{padding:16px 28px;border-radius:14px;font-size:1.05rem}
.chips{display:flex;gap:12px;flex-wrap:wrap}
.chip{border:none;background:#eef3fb;color:#1f2937;padding:12px 18px;border-radius:12px;font-weight:500}
.chip.active{background:#dceaff;color:#2563eb}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.store-card{background:rgba(255,255,255,.9);border:1px solid rgba(230,236,246,.9);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.store-card .card-image{aspect-ratio:1.3 / 1;overflow:hidden;background:#dfe8f7}
.store-card .card-image img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.store-card:hover .card-image img{transform:scale(1.04)}
.store-card .card-body{padding:18px 18px 16px}
.store-card h3{margin:0 0 10px;font-size:1.55rem;letter-spacing:-.03em}
.rating{display:flex;align-items:center;gap:8px;color:#f5b301;font-size:1rem;margin-bottom:14px}
.rating span:last-child{color:#6b7280}
.icons{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding-top:14px;border-top:1px solid var(--line);color:#24324a}
.icon-stat{display:flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:1rem;color:#24324a}
.icon-stat .num{font-size:.98rem;color:#5b6578}
.icon-stat.eye{color:#2563eb}
.explore-wrap{padding:22px;background:rgba(255,255,255,.65);border:1px solid rgba(232,237,247,.95);border-radius:20px;box-shadow:var(--shadow-soft)}
.explore-search{display:grid;grid-template-columns:1.5fr auto;gap:12px;margin-bottom:16px}
.explore-search input{height:52px;border-radius:14px;border:1px solid var(--line);padding:0 16px;background:#fff}
.category-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.category-pill{padding:14px 12px;border-radius:14px;border:1px solid var(--line);background:#fff;text-align:center;font-weight:600;color:#334155}

.shop-hero{padding:26px 0 0}
.shop-hero-card{position:relative;min-height:330px;border-radius:30px;overflow:hidden;box-shadow:var(--shadow);background:linear-gradient(90deg, rgba(15,31,69,.72) 0%, rgba(29,63,122,.52) 36%, rgba(66,117,195,.26) 100%), url('https://images.unsplash.com/photo-1517048676732-d65bc937f952?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat}
.shop-hero-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(5,14,29,.18) 100%)}
.shop-hero-inner{position:relative;z-index:2;padding:34px;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.9fr);gap:28px;min-height:330px;align-items:end}
.badge{align-self:flex-start;display:inline-flex;padding:11px 18px;border-radius:14px;background:linear-gradient(180deg,#4e95ff,#2f79ff);color:#fff;font-weight:800;font-size:1rem;box-shadow:0 12px 22px rgba(47,121,255,.26);margin-bottom:18px}
.shop-head{display:flex;align-items:flex-end;gap:18px}
.shop-logo{width:74px;height:74px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);position:relative}
.shop-logo:before,.shop-logo:after{content:"";position:absolute;inset:16px;border:4px solid #fff;transform:rotate(45deg);border-radius:4px}
.shop-logo:after{inset:30px 6px 6px 30px;border-color:#75d9ff}
.shop-title{font-size:3.6rem;line-height:.95;margin:0;color:#fff;letter-spacing:-.04em;text-shadow:0 10px 25px rgba(0,0,0,.24)}
.shop-meta{display:flex;flex-wrap:wrap;gap:18px;color:#f6f9ff;align-items:center;font-weight:700;margin-top:10px}
.stars{display:flex;gap:4px;color:#ffce45}
.hero-photo-panel{display:flex;align-items:stretch;justify-content:center}
.hero-photo-box{width:100%;min-height:210px;border-radius:24px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);background-image:url('https://images.unsplash.com/photo-1512436991641-6745cdb1723f?auto=format&fit=crop&w=900&q=80');background-size:cover;background-position:center}
.shop-layout{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.9fr);gap:24px;padding-top:22px}
.block{padding:22px}
.gallery-grid{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:14px}
.photo-main,.photo-side,.map-box{border-radius:18px;overflow:hidden;min-height:220px;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.photo-main{background-image:url('https://images.unsplash.com/photo-1519389950473-47ba0277781c?auto=format&fit=crop&w=1200&q=80');min-height:340px}
.photo-side:nth-child(1){background-image:url('https://images.unsplash.com/photo-1496171367470-9ed9a91ea931?auto=format&fit=crop&w=700&q=80')}
.photo-side:nth-child(2){background-image:url('https://images.unsplash.com/photo-1517336714739-489689fd1ca8?auto=format&fit=crop&w=700&q=80')}
.photo-stack{display:grid;gap:14px}
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.product-card{border:1px solid var(--line);background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft)}
.product-media{height:170px;background:#eef4ff;display:flex;align-items:center;justify-content:center}
.product-media img{width:100%;height:100%;object-fit:cover}
.product-body{padding:16px}
.product-body h4{margin:0 0 8px;font-size:1.12rem}
.price{font-weight:800;color:#174392;margin-bottom:14px}
.sidebar-card h3,.sidebar-title{margin:0 0 14px;font-size:1.6rem;letter-spacing:-.03em}
.detail-line,.meta-line{display:flex;gap:12px;align-items:flex-start;color:#374151;margin-bottom:14px;line-height:1.5}
.detail-icon,.mini-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#eef4ff;color:#2563eb;flex:0 0 auto}
.call-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0}
.divider{height:1px;background:var(--line);margin:18px 0}
.category-chip{padding:12px 16px;border-radius:999px;background:#eef4ff;color:#1b4e99;font-weight:700;display:inline-flex}
.map-box{min-height:210px;background-image:url('https://maps.geoapify.com/v1/staticmap?style=osm-carto&width=800&height=500&center=lonlat:-3.70379,40.41678&zoom=13&marker=lonlat:-3.70379,40.41678;color:%232563eb;size:large&apiKey=demo')}
.map-link{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding:14px 16px;border-radius:14px;background:#fff;border:1px solid var(--line);font-weight:700;color:#2563eb}
.socials{display:flex;gap:12px}
.social{width:48px;height:48px;border-radius:14px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;background:#fff;font-weight:800;color:#334155}

.panel-page{padding:26px 0 0}
.panel-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:22px}
.panel-sidebar{padding:0;overflow:hidden;position:sticky;top:102px;align-self:start}
.profile-head{padding:26px 20px 22px;background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(236,243,255,.82));border-bottom:1px solid rgba(120,145,190,.12);display:flex;gap:14px;align-items:center}
.avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#91b5ff,#688fe8);color:#fff;display:grid;place-items:center;font-weight:800;font-size:18px;box-shadow:0 10px 20px rgba(95,143,232,.25);flex:0 0 auto}
.profile-name{font-size:18px;font-weight:700;line-height:1.2}
.profile-mail{color:var(--muted);font-size:14px;margin-top:3px}
.side-menu{padding:12px}
.side-menu a,.side-menu button{display:flex;width:100%;align-items:center;gap:12px;text-decoration:none;color:#33435f;padding:14px 14px;border-radius:16px;font-weight:600;position:relative;transition:.2s ease;background:transparent;border:none;cursor:pointer;text-align:left}
.side-menu a:hover,.side-menu button:hover{background:rgba(255,255,255,.56)}
.side-menu a.active,.side-menu button.active{background:linear-gradient(90deg, rgba(95,143,232,.12), rgba(95,143,232,.04));color:#234377}
.side-menu a.active::before,.side-menu button.active::before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:99px;background:linear-gradient(180deg,#6da0ff,#4d80da)}
.menu-ico{width:18px;height:18px;border:1.7px solid currentColor;border-radius:50%;opacity:.8;position:relative;flex:0 0 auto}
.menu-ico.heart{border-radius:6px;transform:rotate(-45deg);border-top-left-radius:10px}
.menu-ico.chat::before{content:"";position:absolute;width:6px;height:6px;border-left:1.7px solid currentColor;border-bottom:1.7px solid currentColor;bottom:-4px;left:2px;transform:skew(-15deg)}
.menu-ico.gear::before{content:"";position:absolute;inset:4px;border:1.7px solid currentColor;border-radius:50%}
.menu-ico.box{border-radius:4px}
.menu-ico.chart::before{content:"";position:absolute;left:3px;right:3px;bottom:3px;height:7px;border-left:2px solid currentColor;border-bottom:2px solid currentColor}
.badge-count{margin-left:auto;min-width:24px;height:24px;padding:0 8px;border-radius:999px;background:linear-gradient(180deg,#6ca0ff,#4f82db);color:#fff;font-size:12px;display:grid;place-items:center;box-shadow:0 10px 18px rgba(95,143,232,.22)}
.panel-main{display:grid;gap:22px}
.panel-hero{padding:28px;background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(241,246,255,.82))}
.panel-hero h1{margin:0;font-size:2.5rem;line-height:1.05;letter-spacing:-1.2px}
.panel-hero p{margin:10px 0 0;color:var(--muted);font-size:1.05rem}
.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}
.stat-card{padding:18px 16px;min-height:126px;display:flex;flex-direction:column;justify-content:space-between}
.stat-value{font-size:2rem;font-weight:800;letter-spacing:-1px}
.stat-label{color:var(--muted);font-weight:600}
.content-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(300px,.8fr);gap:22px}
.panel-block{padding:20px}
.panel-block h2{font-size:1.6rem;margin-bottom:18px}
.favorites-list,.product-list{display:grid;gap:16px}
.favorite-item,.message-item,.activity-item,.review-card,.storage-box,.store-mini,.product-item{border:1px solid var(--line);background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft)}
.favorite-thumb{height:170px;background-size:cover;background-position:center}
.favorite-item:nth-child(1) .favorite-thumb{background-image:url('https://images.unsplash.com/photo-1517059224940-d4af9eec41e5?auto=format&fit=crop&w=1200&q=80')}
.favorite-item:nth-child(2) .favorite-thumb{background-image:url('https://images.unsplash.com/photo-1496171367470-9ed9a91ea931?auto=format&fit=crop&w=1200&q=80')}
.favorite-body,.message-list,.activity-list,.review-body-box,.store-mini,.storage-box,.product-item .product-meta{padding:16px}
.inline-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:#6b7280;font-size:.95rem}
.message-item,.activity-item{padding:14px 16px}
.message-item strong,.activity-item strong{display:block;margin-bottom:4px}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:12px}
.small-btn{padding:10px 14px;border-radius:12px;font-size:.92rem}
.review-card{padding:18px}
.review-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.review-stat{padding:14px;border-radius:14px;background:#f8fbff;border:1px solid var(--line);text-align:center}
.product-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.search-input{height:48px;border-radius:14px;border:1px solid var(--line);padding:0 14px;min-width:280px;background:#fff}
.product-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.product-item .product-thumb{height:180px;background-size:cover;background-position:center}
.product-item:nth-child(1) .product-thumb{background-image:url('https://images.unsplash.com/photo-1511707171634-5f897ff02aa9?auto=format&fit=crop&w=1200&q=80')}
.product-item:nth-child(2) .product-thumb{background-image:url('https://images.unsplash.com/photo-1541807084-5c52b6b3adef?auto=format&fit=crop&w=1200&q=80')}
.product-item:nth-child(3) .product-thumb{background-image:url('https://images.unsplash.com/photo-1580910051074-3eb694886505?auto=format&fit=crop&w=1200&q=80')}
.product-item:nth-child(4) .product-thumb{background-image:url('https://images.unsplash.com/photo-1517336714739-489689fd1ca8?auto=format&fit=crop&w=1200&q=80')}
.right-stack{display:grid;gap:16px}
.panel-mobile-toggle{display:none;margin-bottom:14px}

.note-box{padding:16px 18px;border-radius:18px;background:#eef4ff;border:1px dashed #bcd3ff;color:#234377;line-height:1.6}
.prompt-box{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9rem;background:#0f172a;color:#e5eefc;border-radius:18px;padding:18px;line-height:1.55;overflow:auto}

@media (max-width: 1180px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .category-row{grid-template-columns:repeat(3,1fr)}
  .shop-layout,.content-grid{grid-template-columns:1fr}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .panel-layout{grid-template-columns:1fr}
  .panel-sidebar{position:static}
}
@media (max-width: 920px){
  .nav-links{display:none}
  .nav-actions .btn{display:none}
  .menu-btn{display:inline-flex;align-items:center;justify-content:center}
  .hero-home-inner{padding:56px 0 38px}
  .search-box{flex-direction:column;align-items:stretch}
  .search-box .btn{width:100%}
  .section-title{flex-direction:column;align-items:flex-start}
  .shop-hero-inner{grid-template-columns:1fr;align-items:start;padding:24px}
  .hero-photo-panel{order:-1}
  .shop-title{font-size:2.7rem}
  .gallery-grid{grid-template-columns:1fr}
  .photo-stack{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .content-grid{grid-template-columns:1fr}
  .panel-mobile-toggle{display:inline-flex}
}
@media (max-width: 720px){
  .grid-4,.products-grid,.product-grid,.review-stats,.footer-inner,.category-row{grid-template-columns:1fr}
  .explore-search{grid-template-columns:1fr}
  .icons{grid-template-columns:repeat(2,1fr)}
  .footer-bottom{flex-direction:column}
  .footer-inner{padding:30px 0 20px}
  .shop-title{font-size:2.2rem}
  .panel-hero h1{font-size:2rem}
  .profile-head{padding:20px 16px}
  .call-row{grid-template-columns:1fr}
}


/* Ajustes portada: sin tocar diseño base */
.store-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 14px;
}
.store-tags span{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:10px;
  background:#f1f5f9;
  color:#334155;
  font-size:.9rem;
  font-weight:700;
}
.pwa-bottom-nav,.pwa-menu-panel{display:none}

@media (max-width: 720px){
  body{
    padding-bottom:calc(78px + env(safe-area-inset-bottom, 0px));
  }
  .nav-wrap{
    position:relative;
    top:auto;
    padding-top:env(safe-area-inset-top, 0px);
  }
  .nav{
    min-height:74px;
    align-items:center;
  }
  .brand{
    font-size:1.55rem;
  }
  .nav-actions{
    gap:8px;
  }
  .nav-actions .btn{
    display:inline-flex;
    padding:9px 11px;
    font-size:.82rem;
    border-radius:10px;
  }

  .hero-home{
    padding-bottom:26px;
  }
  .hero-home-card{
    min-height:360px;
  }
  .hero-home-inner{
    padding:42px 0 32px;
  }
  .hero-home h1{
    font-size:2.45rem;
  }
  .hero-home p{
    font-size:1.05rem;
  }
  .search-box{
    display:grid;
    gap:10px;
    padding:12px;
  }
  .search-box input{
    width:100%;
    font-size:1rem;
  }

  .section{
    padding:24px 0;
  }
  .section-title{
    margin-bottom:16px;
  }
  h2{
    font-size:1.65rem;
  }

  .grid-4{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
  }
  .store-card{
    border-radius:16px;
  }
  .store-card .card-image{
    aspect-ratio:1.05 / .82;
  }
  .store-card .card-body{
    padding:12px;
  }
  .store-card h3{
    font-size:1rem;
    line-height:1.15;
    margin-bottom:8px;
  }
  .store-tags{
    gap:5px;
    margin-bottom:10px;
  }
  .store-tags span{
    padding:5px 7px;
    font-size:.68rem;
    border-radius:8px;
  }
  .icons{
    grid-template-columns:repeat(4,1fr);
    gap:4px;
    padding-top:10px;
  }
  .icon-stat{
    font-size:.82rem;
    gap:3px;
  }
  .icon-stat .num{
    font-size:.72rem;
  }

  .explore-wrap{
    padding:14px;
  }
  .explore-search{
    grid-template-columns:1fr;
    margin-bottom:0;
  }

  .footer{
    display:none;
  }

  .pwa-bottom-nav{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:999;
    display:grid;
    grid-template-columns:repeat(5, 1fr);
    gap:0;
    padding:9px 8px calc(9px + env(safe-area-inset-bottom, 0px));
    background:rgba(255,255,255,.96);
    border-top:1px solid rgba(226,232,240,.95);
    box-shadow:0 -10px 28px rgba(15,23,42,.08);
    backdrop-filter:blur(14px);
  }
  .pwa-bottom-nav a,
  .pwa-bottom-nav button{
    border:0;
    background:transparent;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    min-height:48px;
    color:#7b8494;
    font-weight:700;
  }
  .pwa-bottom-nav span{
    font-size:1.55rem;
    line-height:1;
  }
  .pwa-bottom-nav b{
    font-size:.72rem;
  }
  .pwa-bottom-nav .active{
    color:var(--blue-2);
  }
  .pwa-menu-panel{
    position:fixed;
    right:12px;
    bottom:calc(82px + env(safe-area-inset-bottom, 0px));
    z-index:1000;
    width:min(260px, calc(100vw - 24px));
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    box-shadow:0 20px 42px rgba(15,23,42,.18);
    padding:10px;
  }
  .pwa-menu-panel.open{
    display:block;
  }
  .pwa-menu-panel a{
    display:block;
    padding:13px 14px;
    border-radius:12px;
    font-weight:800;
    color:#1f2937;
  }
  .pwa-menu-panel a:hover{
    background:#eef4ff;
    color:var(--blue-2);
  }
}


/* FIX FINAL: header limpio, sin hueco, tarjetas alineadas */
.nav-wrap{
  position:relative !important;
  top:auto !important;
  margin:0 !important;
  padding:0 !important;
}
.nav{
  margin:0 auto !important;
}
main{
  margin:0 !important;
  padding:0 !important;
}
.hero-home{
  margin:0 !important;
  padding:0 0 42px !important;
}
.hero-home-card{
  margin:0 !important;
}
.nav-actions > a:not(.btn){
  display:none !important;
}

.store-card{
  display:flex !important;
  flex-direction:column !important;
  height:100% !important;
}
.store-card .card-image{
  flex:0 0 auto !important;
}
.store-card .card-body{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 auto !important;
}
.store-tags{
  min-height:76px !important;
  max-height:76px !important;
  overflow:hidden !important;
  align-content:flex-start !important;
}
.icons{
  margin-top:auto !important;
}

/* No permitir que la página móvil se descuadre horizontalmente */
html, body{
  max-width:100% !important;
  overflow-x:hidden !important;
}
.page-shell{
  width:100% !important;
  overflow-x:hidden !important;
}

@media (max-width:720px){
  .nav-wrap{
    padding-top:env(safe-area-inset-top, 0px) !important;
  }
  .nav{
    min-height:72px !important;
    width:calc(100% - 24px) !important;
    gap:10px !important;
  }
  .brand{
    min-width:0 !important;
    font-size:1.32rem !important;
  }
  .brand b{
    white-space:nowrap !important;
  }
  .nav-actions{
    flex:0 0 auto !important;
    gap:6px !important;
  }
  .nav-actions .btn{
    padding:8px 9px !important;
    font-size:.72rem !important;
    border-radius:10px !important;
  }
  .hero-home{
    padding:0 0 22px !important;
  }
  .hero-home-card{
    min-height:390px !important;
  }
  .grid-4{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    align-items:stretch !important;
  }
  .store-card{
    min-height:285px !important;
  }
  .store-tags{
    min-height:58px !important;
    max-height:58px !important;
  }
  .icons{
    min-height:36px !important;
  }
}


/* FIX: en móvil no mostrar Iniciar sesión / Regístrate arriba */
@media (max-width:720px){
  .nav-actions{
    display:none !important;
  }
  .nav{
    justify-content:flex-start !important;
  }
}

/* FIX definitivo botones login móvil */
@media (max-width:720px){
  .nav-actions .btn{
    display:none !important;
  }
}
