:root{
  --bg:#0b1020; --card:rgba(15,26,43,.65);
  --text:#e9eef7; --muted:#A8B3C7;
  --brand:#E01E8D; --brand2:#0062A8;
  --radius:20px; --shadow:0 18px 50px rgba(0,0,0,.35),0 4px 14px rgba(0,0,0,.25);
  --ring:0 0 0 3px rgba(224,30,141,.35);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:
    radial-gradient(1100px 520px at 90% -10%,rgba(0,98,168,.22),transparent),
    radial-gradient(900px 480px at -10% 0%,rgba(224,30,141,.16),transparent),
    linear-gradient(180deg,#090f1c,#0e1430 20%,#0a1225 60%,#0a0f1e 100%);
}
body.no-scroll{ overflow:hidden; touch-action:none; }

.wrap{max-width:1200px;margin:0 auto;padding:28px}

/* Hero */
.hero{
  display:grid;grid-template-columns:88px 1fr auto;gap:18px;align-items:center;
  border-radius:28px;padding:28px;border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(135deg,rgba(3,44,68,.85),rgba(107,15,71,.85));
  box-shadow:var(--shadow)
}
.owner-pic{width:88px;height:88px;border-radius:20%;object-fit:cover;border:3px solid rgba(255,255,255,.25)}
h1{margin:0;font:800 28px/1.1 Poppins,Inter,sans-serif;letter-spacing:.2px}
.sub{color:var(--muted);margin-top:6px}
.tag{align-self:center;display:inline-flex;gap:8px;align-items:center;padding:8px 12px;border-radius:999px;font-weight:700;background:linear-gradient(90deg,var(--brand),var(--brand2))}

/* Section & grid */
.section-title{font:800 1.3rem/1.2 Poppins;margin:36px 2px 14px}
.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}

/* Card */
.card{
  position:relative;border-radius:20px;overflow:hidden;
  background:linear-gradient(180deg,rgba(15,26,43,.78),rgba(15,26,43,.55));
  border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(8px);
  box-shadow:var(--shadow);cursor:pointer;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease
}
.card:hover{transform:translateY(-4px);box-shadow:0 22px 60px rgba(0,0,0,.45),0 6px 22px rgba(0,0,0,.3);border-color:rgba(224,30,141,.45)}
.card-header{display:flex;flex-direction:column;gap:6px;padding:14px 14px 12px;background:linear-gradient(90deg,rgba(0,98,168,.20),rgba(224,30,141,.18));border-bottom:1px solid rgba(255,255,255,.06)}
.card-title{margin:0;font:700 1.06rem/1.1 Poppins}
.card-proc{font-size:.9rem;color:#cfe0ff}

/* ===== Tarjetas (galería principal) ===== */
.thumb{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#0a1225;
  border-bottom:1px solid rgba(255,255,255,.06);
  pointer-events:none;
}
.thumb img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 42%;
  display:block;
}

/* ===== Detalle (modal) ===== */
.open-detail{
  position:absolute; inset:0; display:block; z-index:5;
}

/* Modal chrome */
.modal{position:fixed;inset:0;display:none;place-items:center;padding:28px;z-index:40}
.modal.open{display:grid}
.modal::before{content:"";position:absolute;inset:0;background:rgba(6,10,20,.72);backdrop-filter:blur(6px)}
.modal-card{
  position:relative;z-index:1;width:min(100%,1040px);max-height:92vh;
  background:linear-gradient(180deg,rgba(18,26,50,.92),rgba(12,18,34,.92));
  border:1px solid rgba(255,255,255,.08);border-radius:22px;overflow:hidden;
  box-shadow:var(--shadow);display:flex;flex-direction:column
}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.08);background:linear-gradient(90deg,rgba(0,98,168,.22),rgba(224,30,141,.18))}
.modal-title{margin:0;font:800 1.05rem/1 Poppins}
.modal-close{
  background:rgba(255,255,255,.12); border:0; color:#fff; font-weight:800; font-size:1.2rem;
  cursor:pointer; border-radius:12px; padding:8px 12px
}
.modal-close:focus{box-shadow:var(--ring);outline:none}
.modal-body{padding:18px 18px 22px;overflow:auto}
.detail-grid{display:grid;gap:22px;grid-template-columns:1.1fr .9fr;align-items:start}
.section-sub{margin:14px 0 10px;font:800 1rem/1.1 Poppins}
.text-block{white-space:pre-line;line-height:1.65;color:#e9eef7;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px}
.tool-badges{display:flex;flex-wrap:wrap;gap:8px}
.tool{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);font-size:1rem}
.tool .i{font-size:1.05rem}
/* Carousel */
.carousel{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a1225;}
.carousel .track{display:flex;height:100%;transition:transform .3s ease;}
.carousel img{width:100%;height:100%;object-fit:cover;object-position:center 42%;flex-shrink:0;cursor:zoom-in;}
.carousel button{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.4);color:#fff;border:0;width:32px;height:32px;border-radius:50%;cursor:pointer;}
.carousel .prev{left:10px;}
.carousel .next{right:10px;}

/* Modal de imagen completa */
.img-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.85);z-index:50;padding:20px;}
.img-modal.open{display:flex;}
.img-modal img{max-width:100%;max-height:100%;object-fit:contain;cursor:zoom-out;}
.img-modal-close{position:absolute;top:18px;right:18px;background:rgba(0,0,0,.5);color:#fff;border:0;border-radius:50%;width:36px;height:36px;font-size:1.2rem;cursor:pointer;}
.img-modal-close:focus{box-shadow:var(--ring);outline:none}
.img-modal-prev,.img-modal-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);color:#fff;border:0;border-radius:50%;width:36px;height:36px;font-size:1.5rem;cursor:pointer;}
.img-modal-prev{left:18px;}
.img-modal-next{right:18px;}
.img-modal-prev:focus,.img-modal-next:focus{box-shadow:var(--ring);outline:none}

/* ===== Mobile tweaks ===== */
@media (max-width:820px){
  .wrap{padding:18px}
  .hero{grid-template-columns:64px 1fr; padding:18px; gap:14px}
  .owner-pic{width:64px;height:64px;border-radius:18%}
  h1{font-size:22px}
  .tag{display:none}
  .section-title{font-size:1.15rem;margin:24px 2px 12px}
  .grid{gap:14px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
    .card{border-radius:16px}
    .card-header{padding:10px 12px}
    .card-title{font-size:1rem}
    .card-proc{font-size:.85rem}
    .modal{padding:0}
    .modal-card{width:100%;height:100vh;max-height:none;border-radius:0}
    .modal-body{padding:14px}
    .detail-grid{grid-template-columns:1fr;gap:16px}
    .img-modal{padding:10px}
    .img-modal-close{top:10px;right:10px}
    .img-modal-prev{left:10px}
    .img-modal-next{right:10px}
  /* no hover animation on touch */
  }

/* Respect users who prefer less motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
