
:root{
  --bg:#07101f;
  --bg2:#0d1730;
  --panel:rgba(255,255,255,.05);
  --panel-2:rgba(255,255,255,.03);
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.16);
  --text:#eef4ff;
  --muted:#b8c5e0;
  --accent:#8b6cff;
  --accent-2:#b39eff;
  --gold:#f1c15b;
  --gold-2:#ffd98a;
  --ok:#67d4aa;
  --danger:#ff7d7d;
  --shadow:0 24px 70px rgba(0,0,0,.38);
  --radius:26px;
  --radius-sm:18px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(1000px 540px at 10% 0%, rgba(139,108,255,.20), transparent 55%),
    radial-gradient(900px 500px at 95% 5%, rgba(241,193,91,.12), transparent 55%),
    linear-gradient(180deg, #0a1326 0%, #050a14 100%);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 18px}
.topbar{
  position:sticky; top:0; z-index:40;
  border-bottom:1px solid var(--line);
  background:rgba(7,16,31,.82);
  backdrop-filter:blur(12px);
}
.topbar .inner{
  display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 0;
}
.brand{display:flex;align-items:center;gap:14px;font-weight:900}
.brand img{
  width:50px;height:50px;border-radius:16px;padding:7px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);
}
.brand small{display:block;color:var(--muted);font-size:.8rem;font-weight:700}
.nav{display:flex;gap:10px;flex-wrap:wrap}
.nav a{
  padding:10px 14px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--muted);font-weight:800;
}
.nav a:hover,.chip:hover{border-color:rgba(241,193,91,.28);color:var(--text)}
.hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  padding:30px;
  margin-top:18px;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.08);
  display:grid;grid-template-columns:1.04fr .96fr;gap:18px;align-items:stretch;
  background:
    radial-gradient(900px 380px at 12% 0%, rgba(139,108,255,.13), transparent 60%),
    radial-gradient(720px 280px at 100% 0%, rgba(241,193,91,.07), transparent 58%),
    linear-gradient(180deg, rgba(9,15,30,.96), rgba(6,10,20,.96));
  box-shadow:var(--shadow);
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0) 28%, rgba(0,0,0,.12) 100%);
  z-index:-1;
}
.hero::after{ content:none; }
@media (max-width:980px){.hero{grid-template-columns:1fr;padding:18px}}
.card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-copy{
  padding:32px;
  background:linear-gradient(180deg, rgba(7,12,24,.82), rgba(7,12,24,.76));
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 14px;border-radius:999px;
  background:rgba(139,108,255,.14);
  border:1px solid rgba(139,108,255,.22);
  color:#d8cfff;font-weight:800;font-size:.82rem;letter-spacing:.2px;text-transform:uppercase;
}
.hero h1{
  margin:16px 0 14px;
  font-size:clamp(2.35rem,5vw,4.6rem);
  line-height:.95;letter-spacing:-1.2px;
}
.hero p{
  margin:0 0 14px;color:var(--muted);font-size:1.05rem;max-width:64ch;
}
.cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 18px;border-radius:16px;font-weight:900;
  transition:transform .15s ease, filter .15s ease;
}
.btn:hover{filter:brightness(1.04)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#241640}
.btn-secondary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#091122}
.btn-ghost{background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--text)}
.note-line{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 12px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);font-weight:700;font-size:.9rem;
}
.hero-side{
  padding:22px;display:grid;gap:14px;
  background:linear-gradient(180deg, rgba(7,12,24,.72), rgba(7,12,24,.64));
}
.logo-stage{
  min-height:280px;border-radius:24px;border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(320px 180px at 50% 8%, rgba(255,255,255,.09), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
  display:grid;place-items:center;padding:30px;
  backdrop-filter:blur(4px);
}
.logo-stage img{width:min(320px,78%);filter:drop-shadow(0 24px 40px rgba(0,0,0,.36))}
.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (max-width:620px){.mini-grid{grid-template-columns:1fr}}
.mini{
  padding:18px;border-radius:22px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);
}
.mini h3{margin:0 0 8px;font-size:1rem}
.mini p{margin:0;color:var(--muted);line-height:1.45}
section{padding:14px 0 18px}
.section-head{
  display:flex;justify-content:space-between;align-items:end;gap:14px;flex-wrap:wrap;
  margin-bottom:14px;
}
.section-head h2{margin:0;font-size:1.7rem;letter-spacing:-.5px}
.section-head p{margin:0;color:var(--muted);max-width:70ch}
.banner{
  padding:24px;border-radius:28px;
  border:1px solid rgba(241,193,91,.22);
  background:linear-gradient(135deg, rgba(241,193,91,.12), rgba(255,255,255,.04));
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
}
.banner h3{margin:0 0 6px;font-size:1.4rem}
.banner p{margin:0;color:var(--muted);max-width:64ch}
.controls{
  display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.search{
  flex:1 1 280px;
  display:flex;align-items:center;gap:10px;
  padding:13px 15px;border-radius:18px;border:1px solid var(--line);
  background:rgba(255,255,255,.04);
}
.search input{
  flex:1;border:0;outline:0;background:transparent;color:var(--text);font:inherit;
}
.search input::placeholder{color:#95a6c7}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{
  cursor:pointer;border:1px solid var(--line);background:rgba(255,255,255,.03);
  color:var(--muted);padding:10px 14px;border-radius:999px;font-weight:800;
}
.chip.active{
  background:rgba(139,108,255,.16);color:var(--text);border-color:rgba(139,108,255,.26);
}
.catalog-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;
}
@media (max-width:1180px){.catalog-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:860px){.catalog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:540px){.catalog-grid{grid-template-columns:1fr}}
.product-card{
  overflow:hidden;border-radius:24px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025));
  display:flex;flex-direction:column;min-height:100%;
}
.product-figure{
  aspect-ratio:1/1;background:
    radial-gradient(320px 150px at 50% 0%, rgba(139,108,255,.10), transparent 60%),
    rgba(255,255,255,.025);
  padding:18px;display:grid;place-items:center;
}
.product-figure img{
  width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.26));
}
.product-body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:12px;flex:1}
.product-top{display:flex;justify-content:space-between;gap:10px;align-items:start}
.category-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;font-weight:900;color:var(--gold-2);
  background:rgba(241,193,91,.10);border:1px solid rgba(241,193,91,.18);
  border-radius:999px;padding:8px 10px;
}
.price{
  font-size:1.12rem;font-weight:900;white-space:nowrap;
  color:#fff;
}
.product-title{margin:0;font-size:1.04rem;line-height:1.18}
.product-desc{margin:0;color:var(--muted);line-height:1.45;font-size:.94rem;min-height:2.7em}
.product-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}
.btn-small{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 13px;border-radius:14px;font-weight:900;font-size:.92rem;
}
.btn-wa{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#241640}
.btn-alt{background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--text)}
.featured-grid,
.info-grid,
.event-grid,
.contact-grid{
  display:grid;gap:14px;
}
.featured-grid{grid-template-columns:repeat(3,1fr)}
.info-grid{grid-template-columns:repeat(3,1fr)}
.event-grid{grid-template-columns:repeat(3,1fr)}
.contact-grid{grid-template-columns:repeat(3,1fr)}
@media (max-width:980px){
  .featured-grid,.info-grid,.event-grid,.contact-grid{grid-template-columns:1fr}
}
.feature-card,.info-card,.event-card,.contact-card{
  padding:22px;border-radius:24px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.03));
}
.feature-card h3,.info-card h3,.event-card h3,.contact-card h3{margin:0 0 10px}
.feature-card p,.info-card p,.event-card p,.contact-card p,.event-card li,.info-card li{
  margin:0;color:var(--muted);line-height:1.5
}
.info-card ul,.event-card ul{margin:0;padding-left:18px}
.public-note{
  margin-top:14px;padding:14px 16px;border-radius:18px;
  border:1px solid rgba(103,212,170,.18);background:rgba(103,212,170,.08);
  color:#d8ffef;font-size:.95rem;
}
.count{
  color:var(--muted);font-size:.95rem;font-weight:700;
}
.empty-state{
  display:none;padding:18px;border-radius:18px;border:1px dashed var(--line);
  background:rgba(255,255,255,.03);color:var(--muted);
}
.footer{
  padding:30px 0 42px;
  color:var(--muted);text-align:center;font-size:.95rem;
}
.subtle-link{color:var(--gold-2)}
.small{font-size:.9rem;color:var(--muted)}


/* Fase collage Fukuro */
@media (max-width:680px){
  .hero::before{
    background:
      linear-gradient(180deg, rgba(4,8,18,.68) 0%, rgba(4,8,18,.54) 40%, rgba(4,8,18,.78) 100%),
      url("fukuro-hero-collage.webp") center/cover no-repeat;
    opacity:1;
  }
  .hero-copy,.hero-side{backdrop-filter:blur(6px)}
}


/* V2 collage visible y más limpio */
.logo-stage{
  min-height:320px;
  position:relative;
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background:#0b1324;
  display:block;
  padding:0;
}
.collage-stage::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(5,10,20,.16) 0%, rgba(5,10,20,.12) 24%, rgba(5,10,20,.48) 100%),
    radial-gradient(460px 180px at 14% 12%, rgba(241,193,91,.18), transparent 55%),
    radial-gradient(420px 220px at 88% 86%, rgba(139,108,255,.16), transparent 60%);
  z-index:1;
}
.logo-stage img.collage-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:saturate(1.04) contrast(1.02);
}
.collage-chip{
  position:absolute;
  top:16px; left:16px;
  z-index:2;
  display:flex; align-items:center; gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(7,12,24,.72);
  backdrop-filter:blur(8px);
  font-weight:800;
  color:#f5f7ff;
  box-shadow:0 12px 34px rgba(0,0,0,.24);
}
.collage-chip img{
  width:34px; height:34px; border-radius:10px; padding:4px;
  background:rgba(241,193,91,.16);
  border:1px solid rgba(241,193,91,.26);
}
.collage-caption{
  position:absolute;
  left:18px; right:18px; bottom:16px;
  z-index:2;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(7,12,24,.66);
  border:1px solid rgba(255,255,255,.10);
  color:#eef4ff;
  font-weight:700;
  line-height:1.35;
  box-shadow:0 16px 42px rgba(0,0,0,.22);
}
@media (max-width:700px){
  .collage-chip{right:16px; font-size:.88rem}
  .collage-caption{font-size:.92rem}
}

.mini strong{color:var(--text)}
.mini-btn{display:inline-flex;margin-top:12px;padding:10px 14px;font-size:.95rem}
.mini-highlight{background:linear-gradient(180deg, rgba(246,194,91,.12), rgba(255,255,255,.03));border-color:rgba(246,194,91,.26)}
