/* ===========================================================
   CARTA · ASOCIACIÓN CANNÁBICA — maqueta
   Paleta: verde muy oscuro + oro premium
   Mobile-first (sagrado). Desktop a partir de 760px.
   =========================================================== */

:root{
  --bg:        #080c08;   /* fondo base, verde casi negro */
  --bg-flores: #080c08;   /* sección flores: verde muy oscuro */
  --bg-hachis: #14110b;   /* sección hachís: más cálido/claro */
  --surface:   #11160f;   /* tarjetas */
  --surface-2: #171c14;
  --text:      #f3efe3;   /* blanco cálido */
  --text-dim:  #a7ad9c;   /* texto secundario */
  --accent:    #c9a44c;   /* oro */
  --accent-2:  #5aa06a;   /* verde cannabis */
  --line:      rgba(243,239,227,.10);
  --line-2:    rgba(243,239,227,.18);
  --radius:    14px;
  --maxw:      1180px;
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.05; }

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent);
}

.btn{
  display:inline-block; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:.95rem;
  padding:.95em 1.8em; border-radius:100px;
  border:1px solid var(--line-2); background:transparent; color:var(--text);
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.btn:hover{ transform:translateY(-2px); }
.btn--gold{ background:var(--accent); color:#1a1405; border-color:var(--accent); }
.btn--gold:hover{ background:#d8b663; }

/* ============ NAV ============ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1rem 1.2rem;
  transition:background .35s ease, padding .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
.nav.is-solid{
  background:rgba(8,12,8,.82);
  backdrop-filter:blur(10px);
  border-bottom-color:var(--line);
  padding:.7rem 1.2rem;
}
.nav-mark{ font-size:1.3rem; color:var(--accent); line-height:1; }
.nav-links{ display:flex; gap:1.4rem; }
.nav-links a{
  font-size:.82rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--text); opacity:.85; transition:opacity .2s, color .2s;
}
.nav-links a:hover{ color:var(--accent); opacity:1; }

/* ============ HERO ============ */
.hero{ position:relative; height:100svh; min-height:560px; display:flex; align-items:flex-end; }
.hero-media{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.bgvideo{ width:100%; height:100%; object-fit:cover; }
.hero-scrim{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(6,8,6,.45) 0%, rgba(6,8,6,.15) 40%, rgba(6,8,6,.85) 100%);
}
.hero-inner{ position:relative; z-index:1; padding:0 1.4rem 3.4rem; max-width:var(--maxw); margin:0 auto; width:100%; }
.hero .eyebrow{ margin-bottom:.9rem; }
.hero-title{ font-size:clamp(3.4rem, 16vw, 7rem); letter-spacing:-.01em; }
.hero-sub{ font-size:1.1rem; color:var(--text-dim); margin-top:.6rem; max-width:30ch; }
.hero-cue{
  display:inline-flex; align-items:center; gap:.6rem; margin-top:1.8rem;
  font-size:.82rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--text);
}
.cue-arrow{ display:inline-block; animation:bob 1.8s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(5px);} }

/* ============ SECCIONES ============ */
.section{ padding:5rem 1.4rem; }
.section--flores{
  background:
    radial-gradient(130% 55% at 50% -8%, rgba(90,160,106,.07), transparent 62%),
    radial-gradient(90% 40% at 100% 0%, rgba(201,164,76,.05), transparent 55%),
    var(--bg-flores);
}
.section--hachis{
  background:
    radial-gradient(110% 45% at 50% -6%, rgba(201,164,76,.05), transparent 60%),
    var(--bg-flores);
}

/* ---- Vegetación decorativa: follaje real solo en las esquinas/bordes, muy sutil.
        El catálogo queda sobre fondo liso (el contenido va por encima, z-index:1). ---- */
.section{ position:relative; overflow:hidden; }
.section-head, .grid{ position:relative; z-index:1; }
.section--flores::before, .section--flores::after,
.section--hachis::before, .section--hachis::after{
  content:""; position:absolute; z-index:0; pointer-events:none;
  mix-blend-mode:screen; background-repeat:no-repeat;
}
/* Flores — las dos esquinas inferiores enmarcan la rejilla */
.section--flores::before{
  left:0; bottom:0; width:min(62vw,560px); height:min(96vw,840px);
  background-image:url("../galeria/bg-follaje-flores.jpg"); background-position:left bottom; background-size:cover;
  opacity:.26;
  -webkit-mask-image:radial-gradient(125% 125% at 0% 100%, #000 8%, transparent 62%);
          mask-image:radial-gradient(125% 125% at 0% 100%, #000 8%, transparent 62%);
}
.section--flores::after{
  right:0; top:0; width:min(58vw,450px); height:min(94vw,780px);
  background-image:url("../galeria/bg-follaje-flores-2.jpg"); background-position:center bottom; background-size:cover;
  transform:scale(-1,-1); opacity:.24;
  -webkit-mask-image:radial-gradient(125% 125% at 0% 100%, #000 8%, transparent 60%);
          mask-image:radial-gradient(125% 125% at 0% 100%, #000 8%, transparent 60%);
}
/* Hachís — hoja elegante arriba-dcha + follaje abajo-izq */
.section--hachis::before{
  right:0; top:0; width:min(48vw,380px); height:min(85vw,680px);
  background-image:url("../galeria/bg-follaje-hachis.jpg"); background-position:left top; background-size:contain;
  transform:scaleX(-1); opacity:.22;
  -webkit-mask-image:radial-gradient(120% 120% at 0% 0%, #000 8%, transparent 58%);
          mask-image:radial-gradient(120% 120% at 0% 0%, #000 8%, transparent 58%);
}
.section--hachis::after{
  left:0; bottom:0; width:min(56vw,460px); height:min(92vw,720px);
  background-image:url("../galeria/bg-follaje-hachis-2.jpg"); background-position:left bottom; background-size:cover;
  opacity:.18;
  -webkit-mask-image:radial-gradient(125% 125% at 0% 100%, #000 6%, transparent 56%);
          mask-image:radial-gradient(125% 125% at 0% 100%, #000 6%, transparent 56%);
}
.section-head{ max-width:var(--maxw); margin:0 auto 2.6rem; }
.section-head h2{ font-size:clamp(2.6rem, 9vw, 4rem); margin:.4rem 0 .5rem; }
.section-lead{ color:var(--text-dim); font-size:1.05rem; max-width:42ch; }

/* ============ GRID + TARJETAS (glass · foto arriba + cuerpo de cristal) ============ */
.grid{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1fr; gap:1.3rem;
}
.card{
  position:relative; cursor:pointer;
  display:flex; flex-direction:column;
  background:linear-gradient(180deg, rgba(28,34,24,.55) 0%, rgba(14,18,12,.62) 100%);
  border:1px solid var(--line-2);
  border-radius:20px; overflow:hidden;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 18px 40px -24px rgba(0,0,0,.9);
  transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.card:hover,.card:focus-visible{
  transform:translateY(-6px);
  border-color:rgba(201,164,76,.45);
  box-shadow:0 26px 60px -26px rgba(0,0,0,.95), 0 0 0 1px rgba(201,164,76,.12);
  outline:none;
}
/* --- foto superior: NICHO DE CRISTAL iluminado (efecto "molde") --- */
.card-media{
  position:relative; aspect-ratio:4/5; overflow:hidden;
  margin:.55rem .55rem 0; border-radius:15px;
  background:
    radial-gradient(58% 46% at 50% 47%, rgba(201,164,76,.24), transparent 62%),
    radial-gradient(135% 95% at 50% 4%, #131a10 0%, #050705 74%);
}
.card-media img{ position:relative; z-index:1; width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.card:hover .card-media img{ transform:scale(1.06); }
/* Producto recortado (transparente): flota en el nicho y proyecta sombra → "sale del molde" */
.card-media--cutout img{
  object-fit:contain; object-position:50% 50%; padding:7% 12% 7%;
  transform:scale(var(--img-scale,1)); transform-origin:center;
  filter:drop-shadow(0 24px 24px rgba(0,0,0,.62));
}
.card:hover .card-media--cutout img{ transform:scale(calc(var(--img-scale,1) * 1.05)) translateY(-4px); }
/* Foco dorado que ILUMINA el producto (vitrina retroiluminada) */
.cm-glow{
  content:""; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:radial-gradient(50% 40% at 50% 47%, rgba(201,164,76,.45), transparent 66%);
  mix-blend-mode:screen; opacity:.4;
  transition:opacity .35s ease;
}
.card:hover .cm-glow{ opacity:.56; }
/* Base/sombra inferior del nicho: el producto “apoya” en el cristal */
.card-media::after{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none; border-radius:15px;
  background:
    radial-gradient(58% 12% at 50% 92%, rgba(0,0,0,.5), transparent 70%),
    linear-gradient(180deg, transparent 60%, rgba(4,6,4,.55) 100%);
}
/* Reflejo de cristal + borde biselado por encima (la “pared” del molde) */
.card-media::before{
  content:""; position:absolute; inset:0; z-index:4; pointer-events:none; border-radius:15px;
  background:linear-gradient(122deg, rgba(255,255,255,.16) 0%, rgba(255,255,255,.04) 20%, transparent 40%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), inset 0 0 0 1px rgba(243,239,227,.08);
}
.card-tag{
  position:absolute; top:.7rem; left:.7rem; z-index:6;
  font-size:.64rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  padding:.36em .8em; border-radius:100px;
  background:rgba(8,10,7,.5); color:var(--text); border:1px solid rgba(243,239,227,.22);
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
}
/* --- cuerpo de cristal --- */
.card-body{ padding:1rem 1.15rem 1.15rem; display:flex; flex-direction:column; gap:.25rem; }
.card-name{ font-family:var(--serif); font-size:1.5rem; font-weight:600; line-height:1.1; letter-spacing:.01em; }
.card-type{ font-size:.82rem; color:var(--text-dim); line-height:1.4; }
.card-meta{
  display:flex; align-items:baseline; justify-content:space-between; gap:.6rem;
  margin-top:.5rem; padding-top:.7rem; border-top:1px solid var(--line);
}
.card-thc{ font-size:.78rem; font-weight:700; letter-spacing:.04em; color:var(--text-dim); }
.card-price{ font-family:var(--serif); font-size:1.5rem; font-weight:600; color:var(--accent); line-height:1; }
.card-price .unit{ font-family:var(--sans); font-size:.72rem; font-weight:600; color:var(--text-dim); margin-left:.1em; }
.card-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  margin-top:.9rem; padding:.7em 1em; border-radius:100px;
  font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent); background:rgba(201,164,76,.08); border:1px solid rgba(201,164,76,.3);
  transition:background .25s ease, color .25s ease, gap .25s ease;
}
.card-btn i{ font-style:normal; transition:transform .25s ease; }
.card:hover .card-btn{ background:var(--accent); color:#1a1405; border-color:var(--accent); }
.card:hover .card-btn i{ transform:translateX(3px); }
.dot{ width:3px; height:3px; border-radius:50%; background:var(--text-dim); display:inline-block; }

/* ============ MODAL ============ */
.modal{ position:fixed; inset:0; z-index:300; display:none; }
.modal.is-open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(4,6,4,.78); backdrop-filter:blur(6px); }
.modal-card{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(640px, 94vw); max-height:92svh; overflow-y:auto;
  background:var(--surface); border:1px solid var(--line-2); border-radius:18px;
  -webkit-overflow-scrolling:touch;
}
.modal-x{
  position:absolute; top:.7rem; right:.7rem; z-index:5;
  width:40px; height:40px; border-radius:50%; cursor:pointer;
  background:rgba(8,10,7,.6); border:1px solid var(--line-2); color:var(--text);
  font-size:1.5rem; line-height:1; display:flex; align-items:center; justify-content:center;
}
.modal-x:hover{ background:rgba(8,10,7,.9); }
.modal-hero{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.modal-hero img{ width:100%; height:100%; object-fit:cover; }
.modal-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(17,22,15,0) 50%, rgba(17,22,15,1) 100%); }
.modal-title{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.2rem 1.5rem; }
.modal-title h2{ font-size:2.3rem; }
.modal-tagline{ font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--accent); margin-top:.2rem; }
.modal-content{ padding:1.4rem 1.5rem 2rem; }

.stats{ display:flex; gap:.7rem; flex-wrap:wrap; margin-bottom:1.4rem; }
.stat{ flex:1 1 90px; background:var(--surface-2); border:1px solid var(--line); border-radius:10px; padding:.7rem .8rem; }
.stat-k{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.stat-v{ font-size:1.05rem; font-weight:700; margin-top:.15rem; }
.stat-v.gold{ color:var(--accent); }

.ficha-row{ padding:.95rem 0; border-top:1px solid var(--line); }
.ficha-row:first-of-type{ border-top:none; }
.ficha-k{ font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); margin-bottom:.3rem; }
.ficha-v{ color:var(--text); font-size:1rem; }
.ficha-v .dim{ color:var(--text-dim); }

.chips{ display:flex; flex-wrap:wrap; gap:.45rem; }
.chip{ font-size:.82rem; padding:.32em .8em; border-radius:100px; background:var(--surface-2); border:1px solid var(--line-2); color:var(--text); }

.modal-foot{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  margin-top:1.5rem; padding-top:1.3rem; border-top:1px solid var(--line-2);
}
.modal-donativo{ display:flex; flex-direction:column; gap:.15rem; }
.donativo-k{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.donativo-v{ font-family:var(--serif); font-size:1.9rem; font-weight:600; color:var(--accent); line-height:1; }
.donativo-v .dim{ font-family:var(--sans); font-size:.85rem; font-weight:500; color:var(--text-dim); }
.avail{ display:inline-flex; align-items:center; gap:.5rem; font-size:.85rem; font-weight:600; }
.avail .led{ width:8px; height:8px; border-radius:50%; background:var(--accent-2); box-shadow:0 0 8px var(--accent-2); }

/* ============ FOOTER ============ */
.footer{ background:#060806; padding:3rem 1.4rem 3.4rem; text-align:center; border-top:1px solid var(--line); }
.footer-line{ font-size:.82rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.footer-small{ color:var(--text-dim); font-size:.85rem; max-width:52ch; margin:1rem auto 0; }
.footer-credits{ color:var(--text-dim); opacity:.6; font-size:.76rem; margin-top:1rem; }

/* ============ REVEAL ============ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-in{ opacity:1; transform:none; }

/* ============ DESKTOP ============ */
@media (min-width:760px){
  .section{ padding:7rem 2rem; }
  .hero-inner{ padding-bottom:4.5rem; }
  .grid{ grid-template-columns:repeat(3, 1fr); gap:1.4rem; }
}
@media (min-width:1080px){
  .grid{ gap:1.6rem; }
}

/* Respeta reduce-motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
