/* Base */
:root{
  --ink:#e7f6ea; --muted:#b7d0bc; --line:#163424;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  color:#0b1f0b;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:url("assets/bg-bosque-dia.png") center/cover no-repeat fixed;
  min-height:100vh;
}
.wrap{max-width:1120px;margin:0 auto;padding:0 18px}

/* Hero */
.hero{
  display:grid; align-items:center; gap:24px;
  grid-template-columns: 1.2fr 1fr;      /* texto | logo (desktop) */
  padding:28px 0 10px;
}
.hero-text h1{
  font-family:'Cormorant Garamond', serif;
  font-size: clamp(32px, 6vw, 72px);
  line-height:1.05; margin:0 0 10px;
  color:#1b3426;
  text-shadow:0 2px 10px rgba(0,0,0,.15);
}
.hero-text p{ font-size: clamp(16px, 2.2vw, 20px); color:#d9ead7; max-width:52ch }
.hero-logo img{
  width:100%; height:auto; display:block;
  filter: drop-shadow(0 12px 40px rgba(0,0,0,.35));
  image-rendering: pixelated;
}

/* CTAs */
.btn{display:inline-block;border:1px solid var(--line);border-radius:12px;padding:12px 16px;font-weight:700}
.primary{background:#123e22;color:#caffca;box-shadow:0 0 10px rgba(0,255,150,.25)}
.ghost{background:rgba(26,107,60,.08);color:#e8ffcf}
.ctas{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0}

/* Cart FAB (arriba-derecha) */
.cart-fab{
  position:fixed; top:12px; right:12px; z-index:1100;
  padding:8px 12px; border-radius:999px; font-weight:800;
  background:rgba(8,20,14,.85); color:#caffca; text-decoration:none;
  box-shadow: var(--shadow); backdrop-filter: blur(6px);
}

/* Chats */
.chat{
  position:fixed; z-index:600; width:112px; height:112px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; text-align:center;
  font-weight:800; color:#fff; box-shadow:0 6px 22px rgba(0,0,0,.28); line-height:1.15; text-decoration:none;
  top:80px;
}
.chat-left { left:12px;  background:radial-gradient(circle at 30% 30%, #58a6ff 0%, #2460d1 95%); }
.chat-right{ right:12px; background:radial-gradient(circle at 70% 30%, #ff82b5 0%, #b63c8a 95%); }

/* Secciones genéricas (para migrar contenido) */
.section{padding:36px 0}
.title{font-family:'Cormorant Garamond', serif; font-size:28px; margin:0 0 14px}
.grid{display:grid; gap:18px}
.cards{grid-template-columns:repeat(4,1fr)}
.gallery{grid-template-columns:repeat(4,1fr)}
.nfts{grid-template-columns:repeat(3,1fr)}
.card{background:linear-gradient(180deg, rgba(13,30,22,.8), rgba(13,30,22,.6));border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.card img{width:100%;height:auto;display:block;object-fit:cover;background:#0b1a13}
.gallery img,
.nfts img{width:100%;height:auto;display:block;border-radius:16px;box-shadow:0 0 24px rgba(0,0,0,.45);object-fit:contain;image-rendering:pixelated}

/* Footer */
.footer{padding:40px 0 60px;text-align:center;color:var(--muted)}

/* Responsive */
@media (max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .nfts{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .hero{
    grid-template-columns: 1fr; 
    text-align:center;
  }
  .hero-text p{ margin: 0 auto; }
  .hero-logo{ order:-1 }                /* logo arriba */
  .hero-logo img{ max-width: 360px; margin:0 auto; }

  .ctas{flex-direction:column;align-items:center}
  .cards,.gallery,.nfts{grid-template-columns:1fr}

  .chat{ top:auto; bottom:14px; width:88px; height:88px; font-size:12px }
  .chat-left{ left:10px } .chat-right{ right:10px }
}

/* --- Ajustes hero y botones --- */
.hero .ctas {
  margin-top: 12px;
  gap: 12px;
  display: flex;
  flex-wrap: wrap;
}

/* Ancho máximo del texto */
.hero-text {
  max-width: 720px;
}

/* Logo y orden móvil */
@media (max-width:768px){
  .hero-logo { order:-1; }
  .hero-logo img { max-width: 260px; }
}

/* Unificamos estilo de botones */
.btn.primary,
.btn.ghost {
  background: #064d26;        /* verde bosque */
  color: #fff;
  border: 2px solid #0a5c32;
  border-radius: 10px;
  padding: 10px 18px;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  box-shadow: 0 3px 8px rgba(0,0,0,.25);
  transition: transform .15s ease, background .2s ease;
}

.btn.primary:hover,
.btn.ghost:hover {
  background: #0a6f3c;
  transform: scale(1.05);
}

/* --- Animación de hover para los chats --- */
.chat {
  transition: transform .2s ease, box-shadow .2s ease;
}

.chat:hover {
  transform: scale(1.08);
  box-shadow: 0 8px 26px rgba(0,0,0,.4);
  filter: brightness(1.15);
}

/* === SAGA: portadas uniformes + tipografía elegante === */

/* Título de sección más grande y bonito */
#saga .title{
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(28px, 3.6vw, 44px);
  letter-spacing: .5px;
  color: #12311f;
  margin-bottom: 18px;
  text-shadow: 0 2px 10px rgba(0,0,0,.12);
}

/* Tarjeta: caja y sombra suaves */
#saga .card{
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(16,34,25,.85), rgba(16,34,25,.65));
  border: 1px solid rgba(12,40,28,.6);
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
}

/* Portadas con mismo tamaño (recorte sutil) */
#saga .card img{
  width: 100%;
  aspect-ratio: 3 / 4;       /* todas igual */
  object-fit: cover;         /* recorta sin deformar */
  display: block;
  background: #0b1a13;
}

/* Tipografía del título del libro */
#saga .card h3{
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 700;
  color: #102a1c;
  margin: 12px 14px 6px;
  line-height: 1.2;
}

/* Descripción legible */
#saga .card p{
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(15px, 1.6vw, 18px);
  color: #e6f6e6;
  opacity: .92;
  margin: 0 14px 16px;
  line-height: 1.35;
}

/* Hover suave: levanta la tarjeta */
#saga .card{
  transition: transform .18s ease, box-shadow .18s ease;
}
#saga .card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.4);
}

/* --- Versión móvil: dos portadas por fila --- */
@media (max-width: 768px){
  #saga .grid.cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  #saga .card img {
    aspect-ratio: 3 / 4;
    border-radius: 16px 16px 0 0;
  }

  #saga .card h3 {
    font-size: 16px;
    margin: 8px 10px 4px;
  }

  #saga .card p {
    font-size: 14px;
    margin: 0 10px 10px;
  }

  #saga .title {
    font-size: 24px;
    text-align: center;
    margin-bottom: 14px;
  }
}

/* ——— Título “madera” ——— */
#galeria .title.wood{
  font-family:'Cormorant Garamond', serif;
  font-size: clamp(28px, 3.6vw, 44px);
  letter-spacing:.5px;
  color:#62421b;                       /* marrón madera */
  text-shadow:0 2px 8px rgba(0,0,0,.12);
  margin-bottom:18px;
}

/* ——— Grid 4×2 en desktop; 2×? en móvil ——— */
#galeria .gallery{
  display:grid; gap:18px;
  grid-template-columns:repeat(4,1fr);
}
@media (max-width:1024px){
  #galeria .gallery{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:768px){
  #galeria .gallery{ grid-template-columns:repeat(2,1fr); gap:12px; }
}

/* ——— Tarjetas de imagen: tamaño uniforme ——— */
#galeria .g-item{
  margin:0; border-radius:20px; overflow:hidden;
  background:linear-gradient(180deg,rgba(13,30,22,.55),rgba(13,30,22,.35));
  border:1px solid rgba(12,40,28,.45);
  box-shadow:0 12px 28px rgba(0,0,0,.32);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
#galeria .g-item img{
  width:100%; aspect-ratio: 4 / 5;     /* mismas proporciones */
  object-fit: cover; display:block;    /* recorte elegante */
  image-rendering:auto;
}
#galeria .g-item:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(0,0,0,.38);
  filter:brightness(1.05);
}

/* ——— Lightbox ——— */
.lb.hidden{ display:none; }
.lb{
  position:fixed; inset:0; z-index:1200;
  background:rgba(0,0,0,.7);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
}
.lb-img{
  max-width: min(1080px, 92vw);
  max-height: 90vh;
  border-radius:14px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.lb-close{
  position:absolute; top:14px; right:14px;
  background:rgba(0,0,0,.55); color:#fff; border:0;
  width:38px; height:38px; border-radius:10px; font-size:18px;
  cursor:pointer; box-shadow:0 6px 18px rgba(0,0,0,.35);
}
.lb-close:hover{ filter:brightness(1.15); }

/* --- NFTs colecciones --- */
#nfts .title.red{
  font-family:'Cormorant Garamond', serif;
  font-size: clamp(28px, 3.6vw, 44px);
  color:#7c1919;                      /* rojo cálido */
  letter-spacing:.4px;
  margin-bottom:18px;
  text-shadow:0 2px 8px rgba(0,0,0,.12);
}

/* Grid de 3 por fila */
#nfts .nfts{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(3,1fr);
  justify-items:center;
}

/* Ajuste automático de gifs */
#nfts .gif{
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
  border-radius:20px;
  background:rgba(0,0,0,.1);
  box-shadow:0 10px 30px rgba(0,0,0,.3);
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

/* Animación suave */
#nfts .gif:hover{
  transform:translateY(-4px) scale(1.03);
  box-shadow:0 18px 50px rgba(0,0,0,.4);
  filter:brightness(1.08);
}

/* Móvil: 2 por fila */
@media (max-width:768px){
  #nfts .nfts{
    grid-template-columns:repeat(2,1fr);
    gap:12px;
  }
}

/* --- Botones secundarios (verde más claro) --- */
.ctas.secondary {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
}

.btn.light {
  background: #1a7b3f;          /* verde más claro */
  color: #e8ffe8;
  border: 2px solid #228c4d;
  border-radius: 10px;
  padding: 10px 18px;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  box-shadow: 0 3px 8px rgba(0,0,0,.25);
  transition: transform .15s ease, background .2s ease;
}

.btn.light:hover {
  background: #24a25b;
  transform: scale(1.05);
}

/* En móvil, los dos nuevos botones centrados y uno debajo del otro */
@media (max-width:768px){
  .ctas.secondary {
    flex-direction: column;
    align-items: center;
  }
}

/* Separación suave entre las dos filas de botones — solo en escritorio */
@media (min-width: 769px) {
  .hero-text .ctas.secondary {
    margin-top: 14px;        /* separación natural sin romper equilibrio */
    filter: brightness(1.02); /* leve realce para diferenciar fila */
  }
}

.pixel-bird {
  width: 28px;
  height: 28px;
  image-rendering: pixelated;
  background-image: url("assets/bird-off.png");
  background-size: cover;
  position: fixed;
  top: 18px;     /* mismo alto que la cesta más o menos */
  right: 80px;   /* separarlo un poco de la cesta 🛒 */
  cursor: pointer;
  z-index: 999;
  transition: transform 0.15s ease;
}

.pixel-bird:hover {
  transform: translateY(-2px);
}

.pixel-bird.is-playing {
  background-image: url("assets/bird-on.png");
  animation: bird-bounce 0.6s infinite alternate;
}

@keyframes bird-bounce {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-3px); }
}

/* 📱 Ajustes para móvil */
@media (max-width: 768px) {
  .pixel-bird {
    width: 26px;
    height: 26px;
    top: 14px;        /* más bajo para que no toque la barra superior */
    right: 80px;      /* un poco más a la izquierda en móvil */
  }

  .token-fab {
    top: 14px;
    right: 45px;      /* mantiene la separación respecto a la cesta también en móvil */
  }
}

/* Botón flotante del token GKU (junto a la cesta) */
.token-fab {
  position: fixed;
  top: 10px;          /* misma altura que el pájaro en escritorio */
  right: 120px;        /* entre el pájaro y la cesta */
  z-index: 1200;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.token-fab img {
  width: 40px;        /* ajusta el tamaño si quieres */
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}

/* Efecto al pasar el ratón */
.token-fab img:hover {
  transform: scale(1.1);
  opacity: 0.95;
  box-shadow: 0 0 12px rgba(0, 255, 120, 0.7);
}

/* CONTACTO — estilo GLK */
#contacto {
  padding: 20px 0;
}

#contacto .title {
  font-size: 1.8rem;          /* título más grande */
  color: #18e07c;             /* verde GLK brillante */
  font-weight: 800;
  margin-bottom: 10px;
  text-align: left;
}

#contacto p {
  font-size: 1.2rem;          /* texto más grande */
  color: #c7fddd;             /* verde muy claro / blanco cálido */
  font-weight: 500;
  margin: 6px 0;
}

#contacto a {
  color: #18e07c;             /* verde potente GLK */
  font-weight: 800;           /* super negrita */
  text-decoration: none;
  font-size: 1.25rem;         /* un poco más grande */
}

#contacto a:hover {
  text-decoration: underline;
  opacity: 0.9;
}

