 :root{
    --bg:#f6f7eb;
    --card:#ffffff;
    --ink:#333;
    --muted:#6b7280;
    --brand:#e0cb53;
    --line:#e5e7eb;
    --brand-dark:#000;
  }
  *{box-sizing:border-box}
  html,body{
    font-family:'Raleway',sans-serif;
    margin:0;
    background:radial-gradient(1200px 500px at 80% -10%, rgba(224,203,83,.25), transparent 60%),
    linear-gradient(180deg, #1b1b1b 0%, #202020 100%);
    color:#e0dede;
  }

   @keyframes fadeUp {
      from { opacity: 0; transform: translateY(40px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .fade-section {
      opacity: 0;
      animation: fadeUp 0.8s ease-out forwards;
    }
  a{color:inherit;text-decoration:none}

  /* Header */
  header{background:var(--brand-dark);color:#fff;padding:1rem;text-align:center;opacity: 0;
      animation: fadeUp 0.8s ease-out forwards;}
  header img{height:42px;vertical-align:middle}
  nav{margin-top:.5rem}
  nav a{color:#fff;margin:0 1rem;text-decoration:none}

  /* Hero */
 
  .hero h1{font-size:2rem;margin:0 0 .5rem}
  .hero p{max-width:860px;margin:0 auto}
  .cta{margin-top:1.25rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
  .btn{
    background:var(--brand);color:#000;border:none;
    padding:1rem 1.5rem;font-size:1.05rem;cursor:pointer;border-radius:8px;
    transition:all .3s ease
  }
  .btn:hover{background:#ffec80;transform:scale(1.05);box-shadow:0 4px 12px rgba(0,0,0,.2)}
  .btn-outline{background:#fff;border:1px solid var(--line);color:#000}

  /* Secciones */
  section{padding:2rem 1rem;margin:auto;
      opacity: 0;
      animation: fadeUp 0.8s ease-out forwards}
  h2{margin:.25rem 0 1rem}

  /* Tarjeta única de propiedad */
  .card{
    background:#494848;border-radius:14px;border:1px solid var(--line);
    box-shadow:0 6px 18px rgba(0,0,0,.06);
    padding:1.25rem;
    display:grid;grid-template-columns:1.2fr 1fr;gap:1.25rem;
  }
  @media (max-width:900px){ .card{ grid-template-columns:1fr } }

  .thumb{height:500px;border-radius:12px;overflow:hidden;background:#e8eef7}
  .thumb img{width:100%;height:100%;object-fit:cover}

  .pill{
    display:inline-block;background:#eef6ff;border:1px solid #dbeafe;color:#1d4ed8;
    padding:.25rem .6rem;border-radius:999px;font-weight:700;font-size:.85rem;
  }

  /* Tipografía tarjeta */
  .card h3{margin:.35rem 0 .5rem;line-height:1.2}
  .card p,.card li,.kv{line-height:1.45}

  /* Fila label/valor */
  .kv{
    display:grid;
    grid-template-columns:170px 1fr;
    column-gap:.75rem;
    align-items:start;
    margin:.45rem 0;
    padding:.15rem 0;
    
  }
  .kv:last-of-type{border-bottom:none}
  .kv b{
    color:#c7c7c7;font-weight:700;white-space:nowrap;
  }
  .kv b::after{content:"";}
  .kv>span{color:#111;font-weight:600}
  @media (max-width:560px){
    .kv{grid-template-columns:1fr;row-gap:.2rem}
    .kv b{color:#6b7280}
  }

  /* Botonera */
  .actions{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
  .btn-ghost{background:#fff;border:1px solid var(--line)}

  .actions a.btn:first-child,   /* DOSSIER */
.actions a#btnParticipar {    /* Participar */
 
  
  display:block;
  text-align:center;
}

  /* =========================
     MODALES RESPONSIVOS
     ========================= */

  /* Overlays */
  .backdrop,
  .modal-overlay{
    position:fixed;inset:0;
    display:none;                 /* se muestra por JS */
    align-items:flex-start;       /* mejor en móviles */
    justify-content:center;
    padding:16px;                 /* margen respirable */
    z-index:1000;
    overflow:auto;                /* si el modal es alto, scrollea el overlay */
  }
  .backdrop{background:rgba(15,23,42,.45)}
  .modal-overlay{background:rgba(0,0,0,.6)}

  /* Contenedores de modal (flex column + altura controlada) */
  .modal,
  .modal-content{
    background:#fff;color:#333;
    width:min(100%,720px);
    max-height:92svh;             /* base: no supera el alto visible */
    border-radius:12px;border:1px solid var(--line);
    box-shadow:0 20px 60px rgba(0,0,0,.25);
    padding:8px;
    display:flex;flex-direction:column;
    overflow:hidden;               /* el body interno maneja scroll (por defecto) */
  }

  /* Head y acciones pegajosas */
  .modal .head,
  .modal-content .head{
    display:flex;justify-content:space-between;align-items:center;gap:.5rem;
    position:sticky;top:0;background:inherit;z-index:1;padding-bottom:.15rem;
  }
  .close{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;padding:.4rem .6rem;cursor:pointer}

  .modal-actions{
    display:flex;gap:.5rem;justify-content:flex-end;
    position:sticky;bottom:0;background:inherit;
    padding-top:.5rem;margin-top:.5rem;
  }

  /* Cuerpo desplazable */
  .modal-body,
  .terms{
    color:#555;
    overflow:auto;
    max-height:100%;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    padding:1rem 0;
    margin:1rem 0;
  }

  /* Ajustes móviles */
  @media (max-width:560px){
    .modal, .modal-content{padding:10px;border-radius:10px}
    .modal h2, .modal h3, .modal-content h2, .modal-content h3{font-size:1.05rem}
  }

  /* Iframe del contrato: altura flexible */
  #modalContrato .modal-body iframe{
    width:100%;
    height:clamp(240px,55svh,520px);
    display:block;border:1px solid #ccc;border-radius:8px;
  }

  /* ===== Específicos modalDocumento ===== */
  /* Fondo propio (mantiene estética) */
  #modalDocumento .modal-content{background:#e3fabe;color:#2c2c2c}

  /* Scroll interno y altura exacta descontando el padding del overlay */
  #modalDocumento .modal-content{
    max-height:calc(100svh - 32px);  /* 32px = padding global del overlay */
    overflow:auto;                    /* aquí scrollea el contenido del modal */
  }

  /* Compacidad en la primera vista (botones + deeplinks) */
  #modalDocumento #ow_choice{ 
    margin:.75rem 0; 
    gap:.75rem;
  }

  /* Densificar grilla de deeplinks en mobile */
  @media (max-width:560px){
    #modalDocumento .wallet-grid{
      grid-template-columns:1fr 1fr;   /* 2 columnas */
      gap:.5rem;
    }
    #modalDocumento .wallet-icon img,
    #modalDocumento .wallet-icon svg{ width:40px; height:40px; }
    #modalDocumento .wallet-name{ font-size:.9rem; }
    #modalDocumento .btn{ padding:.8rem 1rem; }
  }

  /* Para bloquear scroll del body con el modal abierto (añade/quita .modal-open por JS) */
  body.modal-open{overflow:hidden}

  /* =========================
     Formularios / KYC
     ========================= */
  .wallet-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
    gap:1rem;margin-top:1rem;
  }
  .wallet-btn{
    display:flex;flex-direction:column;align-items:center;gap:.5rem;
    border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:1rem;
    cursor:pointer;transition:.2s;text-align:center;
  }
  .wallet-btn:hover{box-shadow:0 6px 18px rgba(0,0,0,.08);transform:translateY(-2px)}
  .wallet-icon img,.wallet-icon svg{width:48px;height:48px;object-fit:contain}
  .wallet-name{font-weight:700;font-size:.95rem}

  .kyc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-top:.5rem}
  .upload-card{display:flex;flex-direction:column;gap:.5rem;border:1px solid var(--line);border-radius:12px;padding:.75rem;background:#fff}
  .upload-title{font-weight:700;font-size:.95rem}
  .upload-card input[type="file"]{border:1px dashed #d1d5db;border-radius:8px;padding:.5rem;background:#fafafa}
  .upload-card img{width:100%;height:160px;object-fit:cover;border-radius:8px;border:1px solid #eef1f4}

  .ow-grid{display:flex;flex-direction:column;gap:.9rem;margin-top:.8rem}
  .ow-row.two{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
  .ow-row.one{display:grid;grid-template-columns:1fr;gap:.9rem}
  @media (max-width:720px){ .ow-row.two{grid-template-columns:1fr} }

  .ow-label{font-weight:700;font-size:.92rem;margin-bottom:.25rem;display:block}
  .ow-input{width:100%;padding:.6rem .7rem;border:1px solid #e5e7eb;border-radius:10px;background:#fff}

  .ow-instructions{border:1px solid #e5e7eb;background:#fff;padding:.8rem;border-radius:10px;line-height:1.4}
  .ow-instructions code{background:#f6f7fb;padding:.1rem .3rem;border-radius:6px}

  /* On-chain box */
  .onchain-box{
    background:#d8d8d8;border:1px solid var(--line);border-radius:12px;
    margin-top:.75rem;padding:.75rem;box-shadow:0 4px 14px rgba(0,0,0,.06);
    color:#515a6b
  }
  .onchain-row{display:flex;justify-content:space-between;align-items:center}
  .onchain-key{color:#515a6b;font-weight:700;font-size:.92rem}
  .onchain-val{font-weight:800;font-size:1rem}
  .onchain-status{margin-top:.6rem;font-size:.85rem;color:#4d4d4d}

  /* Footer */
  footer{background:#000;color:#fff;padding:1rem;text-align:center;font-size:.9rem}
  footer a{color:#fff;text-decoration:none;margin:0 .5rem}

  /* Galería */
.gallery { display:flex; flex-direction:column; gap:.5rem; }
.gallery-main { position:relative; border-radius:14px; overflow:hidden; background:#0f0f0f; }
.gallery-main img { width:100%; display:block; object-fit:contain; aspect-ratio:4/3; }

.g-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  border:none; width:42px; height:42px; border-radius:50%;
  background:rgba(0,0,0,.45); color:#fff; font-size:28px; line-height:42px; text-align:center;
  cursor:pointer; user-select:none; backdrop-filter: blur(2px);
}
.g-btn:hover { background:rgba(0,0,0,.65); }
.g-btn.prev { left:8px; }
.g-btn.next { right:8px; }

.gallery-thumbs { display:flex; gap:.5rem; overflow-x:auto; padding-bottom:.25rem; }
.gallery-thumbs img {
  height:70px; width:auto; border-radius:10px; opacity:.6; cursor:pointer;
  outline:2px solid transparent; transition:opacity .2s, outline-color .2s, transform .1s ease;
}
.gallery-thumbs img:hover { opacity:.9; transform: translateY(-1px); }
.gallery-thumbs img.active { opacity:1; outline-color:#9fe870; }

/* =========================
   FIXES MOBILE MODALS
   ========================= */

/* Evita scroll horizontal global en móviles y en overlays */
html, body { overflow-x: hidden; }
.modal-overlay, .backdrop { overflow-x: hidden; }

/* El modal nunca es más ancho que la pantalla y recorta bien */
.modal, .modal-content{
  width: min(100%, 720px);
  max-width: 100%;
  border-radius: 12px;
  overflow: hidden;              /* recorta bordes, separadores, etc. */
}

/* El área desplazable del modal no desborda */
.modal-body, .terms{
  overflow: auto;
  max-height: calc(100svh - 120px); /* head + acciones */
}

/* Hijos de grillas pueden encogerse (clave para inputs largos) */
.ow-row.two > * , .ow-row.one > * , .wallet-grid > * { min-width: 0; }

/* Wrap agresivo para direcciones, hashes, códigos y textos largos */
.safe-wrap, .ow-input, .ow-instructions, .ow-instructions code,
#contratoContainer, .onchain-box, .kv, .kv b, .kv > span {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Inputs, selects, botones no se salen */
.ow-input, .wallet-btn, .btn { max-width: 100%; }

/* Botones en modales: más “tocables” y nunca desbordan */
.modal-actions .btn, .head .close { white-space: nowrap; }

/* Grillas más dóciles en móviles */
@media (max-width: 560px){
  .modal, .modal-content{ padding: 10px; border-radius: 10px; }
  .modal .head h2, .modal-content .head h2 { font-size: 1.05rem; }

  /* Botones apilados y a ancho completo dentro de modales */
  .modal-actions{ flex-wrap: wrap; gap:.5rem; }
  .modal-actions .btn{ flex:1 1 140px; }

  /* Formularios “Tengo/No tengo wallet” */
  .ow-row.two{ grid-template-columns: 1fr; }
  #modalDocumento .wallet-grid{ grid-template-columns: 1fr; } /* en 560px, una sola */
}

/* En pantallas MUY angostas, extrema precaución */
@media (max-width: 380px){
  #modalDocumento .btn, .btn { padding: .75rem 1rem; }
  .kv{ grid-template-columns: 1fr; }
}

/* Separadores punteados que no se “escapan” (opcionalmente sustituye tu border-bottom en .kv) */
.kv{ position: relative; border-bottom: none; }
.kv:not(:last-child)::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  
  margin: 0 .25rem;  /* respeta padding; si querés más margen, subí este valor */
}

/* El iframe del contrato nunca genera scroll horizontal */
#modalContrato .modal-body iframe{ display:block; width:100%; max-width:100%; }

/* Evita que el fondo gif del modalDocumento provoque desplazamientos raros */
#modalDocumento.modal-overlay{ background-attachment: fixed; }

/* ===== HOTFIX: modales en móvil/portrait ===== */

/* centra verticalmente y respeta “notch” */
.modal-overlay, .backdrop{
  align-items: center; /* antes: flex-start */
  padding: max(12px, env(safe-area-inset-top))
           max(12px, env(safe-area-inset-right))
           max(12px, env(safe-area-inset-bottom))
           max(12px, env(safe-area-inset-left));
  overflow-x: hidden;
}

/* el contenedor del modal nunca supera el viewport */
.modal, .modal-content{
  width: min(680px, 96svw);      /* usa svw para móvil */
  max-height: 90svh;             /* cabe en alto visible */
  padding: 12px;                 /* un poco más compacto en móvil */
}

/* el área desplazable sí aprovecha el alto del modal */
.modal-body, .terms{
  max-height: calc(90svh - 112px); /* ~header+acciones */
  overflow: auto;
}

/* iframe del contrato: altura adaptativa sin overflow */
#modalContrato .modal-body iframe{
  height: clamp(240px, 55svh, 520px);
  width: 100%;
  max-width: 100%;
  display: block;
  border: 1px solid #ccc;
  border-radius: 8px;
}

/* evita cualquier desborde horizontal accidental */
html, body { overflow-x: hidden; }
.modal, .modal-content { max-width: 100%; }

/* legibilidad del valor en la tarjeta oscura */
#propiedad .kv > span { color: #e0dede; font-weight: 700; }

/* ===== SocioLand – HERO animado (SVG + CSS) ===== */
.sl-hero{
  position:relative;
  display:grid;
  grid-template-columns: 1fr;
  align-items:center;
  min-height: 520px; /* podés bajar a 440px si querés */
  isolation:isolate;
  overflow:hidden;
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(224,203,83,.25), transparent 60%),
    linear-gradient(180deg, #1b1b1b 0%, #202020 100%);
  color:#fff;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
/* Texto */
.sl-copy{ position:relative; z-index:2; padding: clamp(16px, 4vw, 40px); max-width: 1100px; margin: 0 auto; display:grid; gap: 14px; }
.sl-kicker{ font-size:.95rem; letter-spacing:.12em; text-transform:uppercase; color: rgba(255,255,255,.8); }
.sl-title{ font-size: clamp(1.6rem, 4.2vw, 3rem); line-height:1.1; margin:0; }
.sl-sub{ font-size: clamp(1rem, 1.8vw, 1.15rem); color: rgba(255,255,255,.9); margin:0; }
.sl-steps{ display:flex; flex-wrap:wrap; gap:10px; margin:8px 0 0; padding:0; list-style:none; }
.sl-steps li{ padding:6px 10px; border:1px solid rgba(255,255,255,.2); border-radius:999px; font-size:.9rem; backdrop-filter: blur(2px); }

/* SVG contenedor */
.sl-scene{ position:absolute; inset:0; z-index:1; display:block; width:100%; height:100%; }
.sl-hero svg{ width:100%; height:100%; display:block; }

/* Casa dibujándose */
.house-outline{ stroke:#fefefe; stroke-width:3; fill:none; stroke-linejoin:round; stroke-linecap:round; 
  stroke-dasharray: 1150; stroke-dashoffset: 1150; animation: draw 3.2s ease-out .6s forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }

/* Sol */
.sun{ fill: var(--brand); opacity:.95; }
.sun-glow{ fill:url(#sunGrad); opacity:.55; animation: pulse 4.5s ease-in-out infinite; transform-origin:center; }
@keyframes pulse{ 0%,100%{transform:scale(1)} 50%{transform:scale(1.06)} }

/* Árbol */
.tree{ transform-origin: bottom center; transform: scaleY(0); animation: grow 1.2s ease-out 2.2s forwards; }
@keyframes grow{ to{ transform: scaleY(1); } }

/* Monedas (tokens) */
.coin{ filter: drop-shadow(0 4px 6px rgba(0,0,0,.25)); }
.coin circle{ fill: #ffd166; }
.coin text{ font-weight:700; font-size:9px; fill:#2b2b2b; }
.coin.c1{ animation: fallA 6s cubic-bezier(.2,.9,.25,1) .2s infinite; }
.coin.c2{ animation: fallB 6.2s cubic-bezier(.2,.9,.25,1) .9s infinite; }
.coin.c3{ animation: fallC 6.4s cubic-bezier(.2,.9,.25,1) 1.6s infinite; }
.coin.c4{ animation: fallA 6.1s cubic-bezier(.2,.9,.25,1) 2.0s infinite; }
.coin.c5{ animation: fallB 6.3s cubic-bezier(.2,.9,.25,1) 2.6s infinite; }
@keyframes fallA{
  0%{ transform: translate(-12vw,-12vh) rotate(-15deg); opacity:0 }
  15%{ opacity:1 } 60%{ transform: translate(0, 8vh) rotate(10deg) }
  100%{ transform: translate(2vw, 18vh) rotate(0deg); opacity:0.0 }
}
@keyframes fallB{
  0%{ transform: translate(12vw,-14vh) rotate(10deg); opacity:0 }
  15%{ opacity:1 } 60%{ transform: translate(2vw, 6vh) rotate(-8deg) }
  100%{ transform: translate(0, 18vh) rotate(0deg); opacity:0.0 }
}
@keyframes fallC{
  0%{ transform: translate(-16vw,-16vh) rotate(25deg); opacity:0 }
  15%{ opacity:1 } 60%{ transform: translate(1vw, 8vh) rotate(-6deg) }
  100%{ transform: translate(3vw, 18vh) rotate(0deg); opacity:0.0 }
}

/* Fundación llenándose */
.foundation{ fill: rgba(255,255,255,.09); stroke: rgba(255,255,255,.4); stroke-width:2; }
.foundation-fill{ fill: url(#fillGrad); transform-origin:left center; transform: scaleX(0); animation: fillup 6s ease 1.2s infinite; }
@keyframes fillup{
  0%{ transform: scaleX(0); }
  45%{ transform: scaleX(.85); } 52%{ transform: scaleX(.82); }
  70%{ transform: scaleX(1); } 100%{ transform: scaleX(1); }
}

/* Progreso simbólico */
.sl-progress{ position:absolute; left: clamp(16px, 4vw, 40px); bottom: clamp(14px, 3.6vw, 28px); right: clamp(16px, 4vw, 40px); z-index:2; }
.sl-progress .bar{ height:10px; background: rgba(255,255,255,.18); border-radius:999px; overflow:hidden; border:1px solid rgba(255,255,255,.28) }
.sl-progress .fill{ height:100%; width:0%; background: linear-gradient(90deg, var(--brand), #fff68a); animation: prog 6.2s ease 1s infinite; }
.sl-progress .label{ margin-top:6px; font-size:.85rem; color: rgba(255,255,255,.85); }
@keyframes prog{ 0%{width:0%} 60%{width:92%} 70%{width:88%} 100%{width:100%} }

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .house-outline, .sun-glow, .tree, .coin, .foundation-fill, .sl-progress .fill{ animation: none !important; }
}

/* ==== HERO animado: contraste prioridad texto ==== */

/* Capa más oscura encima del fondo del hero */
.sl-hero{
  /* tu fondo actual abajo; la sobrecapa va primero */
  background:
    linear-gradient(to bottom, rgba(0,0,0,.82) 0%, rgba(0,0,0,.70) 40%, rgba(0,0,0,.86) 100%),
    radial-gradient(1200px 500px at 80% -10%, rgba(224,203,83,.25), transparent 60%),
    linear-gradient(180deg, #1b1b1b 0%, #202020 100%);
  min-height: 560px;          /* un poco más de aire */
  position: relative;
  isolation: isolate;
}

/* Panel sutil detrás del texto (vidrio oscuro) */
.sl-copy{
  background: rgba(0,0,0,.46);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: clamp(24px, 5vw, 48px);
  text-shadow: 0 3px 12px rgba(0,0,0,.85);
}

/* Banda adicional por detrás del bloque de texto hacia la derecha */
.sl-copy::before{
  content:"";
  position:absolute;
  inset: 6% 40% auto 0;           /* ajustá 40% para más/menos ancho */
  background: linear-gradient(90deg, rgba(0,0,0,.45), rgba(0,0,0,0));
  border-radius: 12px;
  z-index:-1;
}

/* La animación baja un poco y se suaviza detrás del copy */
.sl-scene{
  transform: translateY(40px);
  opacity: .85;                   /* si molesta, bajá a .75 */
  pointer-events: none;
}

/* Barra de progreso más legible sobre fondos oscuros */
.sl-progress .bar{
  background: rgba(0,0,0,.5);
  border: 1px solid rgba(255,255,255,.35);
  height: 12px;
}
.sl-progress .label{
  color:#fff;
  text-shadow: 0 1px 4px rgba(0,0,0,.9);
}

/* Tipos más grandes para h1 en desktop */
@media (min-width: 880px){
  .sl-hero{ min-height: 600px; }
  .sl-title{ font-size: clamp(2.2rem, 5.2vw, 3.4rem); line-height:1.05; }
}

.mini-anim{ 
  display:flex; justify-content:center; align-items:center;
  margin:2rem auto; height:60px; 
}
.mini-anim.lines{
  background:repeating-linear-gradient(
    90deg, #e0cb53, #e0cb53 4px, transparent 4px, transparent 12px
  );
  width:120px; animation: pulse 2s infinite;
}
@keyframes pulse{ 0%,100%{opacity:.4} 50%{opacity:1} }

.mini-anim.bubbles span{
  width:12px;height:12px;margin:0 4px;
  background:#e0cb53;border-radius:50%;
  display:inline-block;animation: rise 3s infinite ease-in-out;
}
.mini-anim.bubbles span:nth-child(2){animation-delay:.4s}
.mini-anim.bubbles span:nth-child(3){animation-delay:.8s}
@keyframes rise{
  0%{transform:translateY(0);opacity:1}
  50%{transform:translateY(-20px);opacity:.6}
  100%{transform:translateY(0);opacity:1}
}

.mini-anim.dots span{
  width:10px;height:10px;margin:0 6px;
  background:#e0cb53;border-radius:50%;
  display:inline-block;animation: blink 1.2s infinite;
}
.mini-anim.dots span:nth-child(2){animation-delay:.2s}
.mini-anim.dots span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.2} 40%{opacity:1}}

/* ===== Project Hero (no modal, full-width, responsive) ===== */
.project-hero{
  padding: clamp(16px, 4vw, 32px);
  background: linear-gradient(180deg, #1b1b1b 0%, #202020 100%);
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.project-hero .ph-wrap{
  max-width: 1200px; margin: 0 auto;
  display: grid; gap: clamp(14px, 2.8vw, 28px);
  grid-template-columns: 1.15fr 1fr; align-items: start;
}
@media (max-width: 960px){
  .project-hero .ph-wrap{ grid-template-columns: 1fr; }
}

/* Media column */
.ph-media{
  display: grid; gap: clamp(10px, 2vw, 16px);
}

/* On-chain box: ancho fluido + legible en dark */
#sl_onchain_box{
  width: 100%;
  max-width: none;
  background: #2a2a2a; border-color: #3a3a3a; color: #e9e9e9;
}
#sl_onchain_box .onchain-key{ color:#cfcfcf }
#sl_onchain_box .onchain-val{ color:#fff }

/* Info column */
.ph-info{ min-width: 0; } /* evita desbordes */
.ph-title{
  font-size: clamp(1.4rem, 3.8vw, 2.6rem);
  color:#d8f0c8; margin: 0 0 .5rem; text-align: left;
}
.ph-pills{
  display:flex; flex-wrap: wrap; gap:.5rem; margin:.5rem 0 1rem;
}
.pill{ font-size: clamp(.75rem, 2vw, .95rem); }

/* KV pairs más elásticos */
.kv{
  display:grid; gap:.25rem .75rem; padding:.3rem 0;
  grid-template-columns: minmax(110px, .7fr) 1.6fr;
  border-bottom: 1px dashed rgba(255,255,255,.12);
}
.kv b{ color:#cfcfcf }
.kv > span{ color:#f0f0f0; font-weight:700 }
@media (max-width: 640px){
  .kv{ grid-template-columns: 1fr; }
}

/* Galería: asegura responsividad extrema */
.gallery-main img{
  width:100%; height:auto; aspect-ratio: 4/3; object-fit:contain;
  border-radius: 12px; background:#0f0f0f;
}
.g-btn{
  width: clamp(36px, 6vw, 44px); height: clamp(36px, 6vw, 44px);
  font-size: clamp(20px, 4.5vw, 28px); line-height: 1;
}
.gallery-thumbs img{
  height: clamp(40px, 10vw, 60px);
}

/* Botonera */
.ph-actions{ margin-top: 1rem; display:flex; flex-wrap:wrap; gap:.6rem}
.ph-actions .btn{ flex: 0 1 auto; }
@media (max-width:560px){
  .ph-actions .btn{ flex: 1 1 240px }
}

/* ==== Social panel styles ==== */
.sm-icons{
  display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center;
  margin-top: .75rem;
}
.sm-btn{
  display:inline-flex; align-items:center; gap:.55rem;
  background:#ffffff; color:#111; border:1px solid var(--line);
  border-radius:12px; padding:.75rem 1rem; min-width:190px; justify-content:center;
  transition:transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.sm-btn .icon{ width:22px; height:22px; display:block; fill:currentColor; }
.sm-btn:hover{ transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,0,0,.18); }

/* Brand accents (opcionales) */
.sm-ig{ color:#E1306C; }
.sm-x{ background:#111; color:#fff; border-color:#222; }
.sm-zoom{ color:#2D8CFF; }

.sm-tg { color:#0088cc; }  /* celeste Telegram */

