/* ADN Light 2026 — page-proyectos.css
 * Generado desde mockup proyectos.html (Sprint 3, 2026-05-24).
 * NO editar a mano, regenerar con adn-generate-page-templates-2026-05-24.php
 */


  /* HERO PROYECTOS */
  .lhero{padding:clamp(80px,10vw,140px) 0 clamp(40px,6vw,80px);
    background:var(--ink);color:#fff;position:relative;overflow:hidden;
    text-align:center}
  .lhero::before{content:"";position:absolute;inset:0;
    background:
      radial-gradient(1200px 600px at 50% 100%,rgba(245,186,66,.16),transparent 70%),
      radial-gradient(500px 300px at 20% 30%,rgba(245,186,66,.08),transparent 70%)}
  .lhero .wrap{position:relative;z-index:2;max-width:880px}
  .lhero .eyebrow{color:var(--amber);justify-content:center}
  .lhero .eyebrow::before{background:var(--amber)}
  .lhero h1{color:#fff;font-size:clamp(3rem,6vw,5rem);font-weight:800;
    margin:18px 0 22px;line-height:1.04;letter-spacing:-.025em}
  .lhero h1 em{font-style:normal;background:linear-gradient(120deg,
    var(--amber) 0%,#fff3d4 50%,var(--amber) 100%);-webkit-background-clip:text;
    background-clip:text;color:transparent;background-size:200% 100%;
    animation:gradShift 6s ease-in-out infinite}
  @keyframes gradShift{0%,100%{background-position:0% 50%}
    50%{background-position:100% 50%}}
  .lhero p{font-size:1.18rem;color:#dcd3c2;max-width:640px;margin:0 auto;
    line-height:1.65}
  .lhero .stats{display:flex;justify-content:center;gap:50px;margin-top:46px;
    padding-top:36px;border-top:1px solid rgba(245,186,66,.2);flex-wrap:wrap}
  .lhero .stats div{display:flex;flex-direction:column;gap:3px}
  .lhero .stats b{font-family:var(--display);font-size:2.4rem;color:var(--amber);
    font-weight:800;line-height:1}
  .lhero .stats span{font-family:var(--display);font-size:.74rem;
    letter-spacing:.16em;text-transform:uppercase;color:#a59c8d}

  /* FILTROS */
  .lfilter{background:var(--paper);padding:24px 0;border-bottom:1px solid var(--line);
    position:sticky;top:78px;z-index:50;
    box-shadow:0 8px 24px -16px rgba(21,19,15,.08)}
  .lfilter .wrap{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
  .ltag{font-family:var(--display);font-weight:500;font-size:.9rem;
    color:var(--ink);background:var(--cream);border:1px solid var(--line);
    border-radius:100px;padding:10px 20px;cursor:pointer;
    transition:.2s var(--ease);display:inline-flex;align-items:center;gap:8px}
  .ltag:hover{border-color:var(--amber);color:var(--amber);
    transform:translateY(-2px)}
  .ltag.on{background:var(--ink);color:#fff;border-color:var(--ink)}
  .ltag b{font-weight:600;font-size:.78rem;color:var(--amber)}
  .ltag.on b{color:var(--amber)}

  /* GRID PROYECTOS */
  .lgrid{padding:clamp(56px,8vw,90px) 0 clamp(72px,9vw,110px);background:var(--cream)}
  .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
  .pj{position:relative;border-radius:18px;overflow:hidden;background:var(--ink);
    transition:.32s var(--ease);cursor:pointer;display:block}
  .pj img{width:100%;height:100%;object-fit:cover;opacity:.78;
    transition:.7s var(--ease)}
  .pj:hover{transform:translateY(-6px);
    box-shadow:0 40px 80px -36px rgba(21,19,15,.45)}
  .pj:hover img{opacity:1;transform:scale(1.05)}
  .pj::after{content:"";position:absolute;inset:0;
    background:linear-gradient(180deg,transparent 35%,rgba(10,9,8,.92));
    transition:.32s var(--ease);pointer-events:none}
  .pj:hover::after{background:linear-gradient(180deg,
    rgba(10,9,8,.15) 0%,rgba(10,9,8,.94) 100%)}
  .pj .info{position:absolute;left:22px;right:22px;bottom:22px;color:#fff;z-index:2;
    display:flex;flex-direction:column;gap:6px}
  .pj .ptype{font-family:var(--display);font-size:.72rem;letter-spacing:.16em;
    text-transform:uppercase;color:var(--amber);font-weight:600}
  .pj .info h3{color:#fff;font-size:1.3rem;font-weight:700;line-height:1.2}
  .pj .pyr{font-family:var(--display);font-size:.82rem;color:#c8c0b0;
    margin-top:2px}
  .pj .pgo{position:absolute;right:18px;top:18px;width:42px;height:42px;
    border-radius:50%;background:rgba(245,186,66,.95);color:var(--ink);
    display:grid;place-items:center;font-family:var(--display);font-weight:800;
    font-size:1.2rem;opacity:0;transform:translateY(-8px);
    transition:.32s var(--ease);z-index:2}
  .pj:hover .pgo{opacity:1;transform:translateY(0)}
  .pj.featured{grid-column:span 8;aspect-ratio:1.6/1}
  .pj.tall{grid-column:span 4;aspect-ratio:.7/1}
  .pj.wide{grid-column:span 6;aspect-ratio:1.3/1}
  .pj.std{grid-column:span 4;aspect-ratio:1/1}
  .pj.featured .info h3{font-size:2rem}

  /* BANNER CTA */
  .lcta{background:var(--ink);color:#fff;padding:clamp(80px,10vw,140px) 0;
    text-align:center;position:relative;overflow:hidden}
  .lcta::before{content:"";position:absolute;inset:0;
    background:
      radial-gradient(900px 500px at 50% 0%,rgba(245,186,66,.18),transparent 70%),
      radial-gradient(500px 300px at 50% 100%,rgba(245,186,66,.08),transparent 70%)}
  .lcta .wrap{position:relative;z-index:2;max-width:760px}
  .lcta h2{color:#fff;font-size:clamp(2.4rem,5vw,4rem);font-weight:800;
    line-height:1.05;margin:16px 0 22px;letter-spacing:-.02em}
  .lcta h2 em{font-style:normal;font-family:'Kaushan Script',cursive;
    color:var(--amber);font-weight:400}
  .lcta p{color:#c8c0b0;font-size:1.16rem;line-height:1.65;max-width:560px;
    margin:0 auto 32px}
  .lcta .actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

  @media(max-width:1080px){
    .grid{grid-template-columns:repeat(6,1fr);gap:18px}
    .pj.featured,.pj.wide{grid-column:span 6}
    .pj.tall,.pj.std{grid-column:span 3}
  }
  @media(max-width:720px){
    .grid{grid-template-columns:1fr}
    .pj.featured,.pj.wide,.pj.tall,.pj.std{grid-column:span 1;aspect-ratio:1.2/1}
    .lhero .stats{gap:30px}
  }
