/* =========================================================
   CreativePixeLamb — Global Stylesheet
   Aesthetic: editorial-tech · warm neutrals · deep ink · ember accent
   ========================================================= */

:root{
  --bone:#f5f1ea;
  --paper:#ece6d9;
  --ink:#111111;
  --ink-soft:#2b2a27;
  --muted:#6a665d;
  --rule:#d9d2c2;
  --ember:#d34e24;
  --ember-deep:#a73a18;
  --moss:#2f3a2a;
  --shadow: 0 20px 50px -20px rgba(17,17,17,.25);
  --radius: 14px;
  --max: 1240px;
  --step: clamp(1rem, .6rem + 1vw, 1.125rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family: "Instrument Sans", system-ui, sans-serif;
  font-size: var(--step);
  line-height:1.55;
  color:var(--ink);
  background:var(--bone);
  background-image:
    radial-gradient(1200px 500px at 85% -10%, rgba(211,78,36,.08), transparent 60%),
    radial-gradient(900px 400px at 0% 110%, rgba(47,58,42,.08), transparent 60%);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

h1,h2,h3,h4{
  font-family:"Fraunces", Georgia, serif;
  font-weight:500;
  letter-spacing:-0.02em;
  line-height:1.05;
  color:var(--ink);
}
h1{font-size:clamp(2.6rem, 5.5vw, 5rem); font-variation-settings:"opsz" 96, "SOFT" 40}
h2{font-size:clamp(2rem, 3.4vw, 3.2rem); font-variation-settings:"opsz" 60}
h3{font-size:clamp(1.25rem, 1.6vw, 1.6rem)}
.mono{font-family:"JetBrains Mono", ui-monospace, monospace; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase}

.wrap{max-width:var(--max); margin:0 auto; padding:0 clamp(1.2rem, 3vw, 2rem)}
section{padding:clamp(4rem, 8vw, 7rem) 0}

/* ========== HEADER ========== */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background: rgba(245,241,234,.78);
  border-bottom:1px solid var(--rule);
}
.nav{
  max-width:var(--max); margin:0 auto;
  padding: .9rem clamp(1.2rem, 3vw, 2rem);
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.brand{display:flex;align-items:center;gap:.6rem;font-family:"Fraunces",serif;font-size:1.2rem;letter-spacing:-.02em}
.brand-mark{
  width:30px;height:30px;display:grid;place-items:center;
  background:var(--ink); color:var(--bone);
  border-radius:8px; font-family:"JetBrains Mono",monospace; font-size:.85rem; font-weight:700;
}
.brand strong{font-weight:600}
.brand em{font-style:normal;color:var(--ember);font-weight:600}

.nav-links{display:flex;gap:1.4rem;align-items:center;list-style:none}
.nav-links a{
  position:relative; font-size:.93rem; color:var(--ink-soft);
  padding:.35rem 0; transition:color .2s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:2px; background:var(--ember); transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after, .nav-links a.active::after{transform:scaleX(1)}
.nav-cta{
  background:var(--ink); color:var(--bone);
  padding:.55rem 1rem; border-radius:999px; font-size:.88rem;
  transition:background .2s, transform .2s;
}
.nav-cta:hover{background:var(--ember); transform:translateY(-1px)}
.nav-cta::after{display:none !important}

.burger{display:none; width:36px;height:36px; border:1px solid var(--rule); border-radius:8px; align-items:center;justify-content:center}
.burger span{width:16px;height:2px;background:var(--ink);position:relative;display:block}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:16px;height:2px;background:var(--ink)}
.burger span::before{top:-5px}.burger span::after{top:5px}

@media (max-width: 880px){
  .burger{display:flex}
  .nav-links{
    position:absolute; inset:100% 0 auto 0;
    flex-direction:column; align-items:flex-start; gap:0;
    background:var(--bone); border-bottom:1px solid var(--rule);
    padding:.5rem 1.5rem 1.2rem; display:none;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%; border-bottom:1px dashed var(--rule)}
  .nav-links li:last-child{border-bottom:none}
  .nav-links a{display:block; padding:.9rem 0; width:100%}
  .nav-cta{margin-top:.6rem}
}

/* ========== HERO ========== */
.hero{padding-top:clamp(3rem, 6vw, 5rem); padding-bottom:clamp(3rem, 6vw, 5rem); position:relative; overflow:hidden}
.hero-grid{display:grid; grid-template-columns: 1.2fr .9fr; gap:clamp(2rem, 4vw, 4rem); align-items:center}
@media (max-width:880px){.hero-grid{grid-template-columns:1fr}}
.eyebrow{display:inline-flex; align-items:center; gap:.6rem; padding:.35rem .7rem; border:1px solid var(--rule); border-radius:999px; background:rgba(255,255,255,.5); font-family:"JetBrains Mono",monospace; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 4px rgba(211,78,36,.18)}
.hero h1{margin:1.2rem 0 1.4rem}
.hero h1 em{font-style:italic;color:var(--ember); font-variation-settings:"SOFT" 100}
.hero p.lede{font-size:1.15rem; color:var(--ink-soft); max-width:52ch}
.hero-cta{display:flex; gap:.7rem; margin-top:2rem; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.85rem 1.3rem; border-radius:999px; font-weight:500; font-size:.95rem;
  transition:transform .2s, background .2s, color .2s, box-shadow .2s;
}
.btn-primary{background:var(--ink); color:var(--bone)}
.btn-primary:hover{background:var(--ember); transform:translateY(-2px); box-shadow:var(--shadow)}
.btn-ghost{border:1px solid var(--ink); color:var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--bone)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

.hero-visual{
  position:relative; aspect-ratio: 4/5; border-radius:var(--radius);
  background:
    linear-gradient(145deg, #1a1a1a 0%, #2b2a27 100%);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.hero-visual::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(245,241,234,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,241,234,.06) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at 30% 20%, #000 30%, transparent 80%);
}
.hero-visual .pixel-lamb{
  position:absolute; inset:0; display:grid; place-items:center;
  color:var(--bone);
}
.hero-visual .tag{
  position:absolute; bottom:1.2rem; left:1.2rem; right:1.2rem;
  display:flex; justify-content:space-between; color:var(--bone);
  font-family:"JetBrains Mono",monospace; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  opacity:.78;
}
.hero-visual .ember-spot{
  position:absolute; width:220px; height:220px; top:-40px; right:-40px;
  background: radial-gradient(circle, rgba(211,78,36,.55), transparent 60%);
  filter:blur(20px);
}

/* Marquee strip */
.marquee{
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
  padding:1.1rem 0; overflow:hidden; background:var(--paper);
}
.marquee-track{display:flex; gap:3rem; white-space:nowrap; animation: mq 40s linear infinite; font-family:"Fraunces",serif; font-size:1.1rem; color:var(--ink-soft)}
.marquee-track span{display:inline-flex; align-items:center; gap:3rem}
.marquee-track span::after{content:"✦"; color:var(--ember)}
@keyframes mq{to{transform:translateX(-50%)}}

/* ========== SECTION HEADINGS ========== */
.section-head{display:flex; align-items:end; justify-content:space-between; gap:2rem; margin-bottom:3rem; flex-wrap:wrap}
.section-head .num{font-family:"JetBrains Mono",monospace; color:var(--ember); font-size:.8rem; letter-spacing:.2em}
.section-head p{color:var(--ink-soft); max-width:48ch}

/* ========== CARDS / GRIDS ========== */
.grid{display:grid; gap:1.5rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:880px){.grid-3,.grid-2{grid-template-columns:1fr}}

.card{
  background:#fff; border:1px solid var(--rule); border-radius:var(--radius);
  padding:1.8rem; transition:transform .25s, box-shadow .25s, border-color .25s;
}
.card:hover{transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--ink)}
.card .icon{
  width:44px;height:44px;border-radius:10px;background:var(--ink);color:var(--bone);
  display:grid;place-items:center; margin-bottom:1.2rem;
}
.card h3{margin-bottom:.6rem}
.card p{color:var(--ink-soft); font-size:.98rem}

/* Feature split (Sobre Nosotros values) */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,4rem); align-items:start}
@media(max-width:880px){.split{grid-template-columns:1fr}}
.values{list-style:none; display:grid; gap:1rem}
.values li{
  background:#fff; border:1px solid var(--rule); border-radius:12px; padding:1.2rem 1.3rem;
  display:grid; grid-template-columns:auto 1fr; gap:1rem; align-items:start;
}
.values li .num{font-family:"JetBrains Mono",monospace; color:var(--ember); font-size:.78rem}
.values li strong{display:block; font-family:"Fraunces",serif; font-size:1.2rem; margin-bottom:.3rem}
.values li span{color:var(--ink-soft); font-size:.95rem}

/* Mission / Vision big cards */
.mv{display:grid; grid-template-columns:1fr 1fr; gap:1.5rem}
@media(max-width:880px){.mv{grid-template-columns:1fr}}
.mv .card{padding:2.2rem; background:var(--ink); color:var(--bone); border-color:var(--ink)}
.mv .card.alt{background:var(--ember); border-color:var(--ember)}
.mv .card h3{color:inherit; font-size:1.8rem; margin-bottom:1rem}
.mv .card p{color:rgba(255,255,255,.85); font-size:1.05rem}
.mv .card .mono{opacity:.7}

/* Projects */
.project{
  display:grid; grid-template-columns:1.05fr .95fr; gap:2rem; align-items:center;
  padding:2rem 0; border-bottom:1px solid var(--rule);
}
.project:last-child{border-bottom:none}
.project:nth-child(even){grid-template-columns:.95fr 1.05fr}
.project:nth-child(even) .project-art{order:-1}
@media(max-width:880px){.project,.project:nth-child(even){grid-template-columns:1fr} .project:nth-child(even) .project-art{order:0}}
.project-art{
  aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden;
  background:linear-gradient(145deg,#1a1a1a,#2b2a27);
  position:relative; display:grid; place-items:center;
  box-shadow:var(--shadow);
}
.project-art svg{width:80%; height:80%}
.project-meta{display:flex; gap:.6rem; flex-wrap:wrap; margin:.8rem 0 1rem}
.tag-chip{font-family:"JetBrains Mono",monospace; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; padding:.35rem .65rem; border:1px solid var(--rule); border-radius:999px; background:#fff}

/* Developers */
.devs{display:grid; grid-template-columns:repeat(5,1fr); gap:1.2rem}
@media(max-width:1100px){.devs{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.devs{grid-template-columns:repeat(2,1fr)}}
.dev{
  text-align:left; background:#fff; border:1px solid var(--rule); border-radius:var(--radius);
  padding:1rem; transition:transform .25s, border-color .25s;
  cursor:pointer;
}
.dev:hover{transform:translateY(-4px); border-color:var(--ink)}
.dev-avatar{
  aspect-ratio:1; border-radius:10px; overflow:hidden; margin-bottom:.9rem;
  background:linear-gradient(145deg,#2b2a27,#111); display:grid; place-items:center;
}
.dev-avatar svg{width:60%; height:60%}
.dev h3{font-size:1.1rem; margin-bottom:.15rem}
.dev .role{font-family:"JetBrains Mono",monospace; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ember)}
.dev p{font-size:.88rem; color:var(--ink-soft); margin-top:.5rem}

/* Modal */
.modal-backdrop{
  position:fixed; inset:0; background:rgba(17,17,17,.7); backdrop-filter:blur(4px);
  display:none; align-items:center; justify-content:center; z-index:100; padding:1rem;
}
.modal-backdrop.open{display:flex; animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{
  background:var(--bone); max-width:640px; width:100%; border-radius:var(--radius);
  max-height:85vh; overflow-y:auto; position:relative; padding:2.2rem;
  box-shadow:var(--shadow);
}
.modal-close{
  position:absolute; top:1rem; right:1rem;
  width:36px;height:36px; border-radius:50%; background:var(--ink); color:var(--bone);
  display:grid; place-items:center; font-size:1.2rem;
}
.modal h2{margin-bottom:.3rem}
.modal .role{font-family:"JetBrains Mono",monospace; font-size:.75rem; color:var(--ember); letter-spacing:.14em; text-transform:uppercase}
.modal .modal-story{margin-top:1.3rem; color:var(--ink-soft)}
.modal .modal-story p{margin-bottom:1rem}

/* FAQ */
.faq{display:grid; gap:.8rem}
.faq details{
  background:#fff; border:1px solid var(--rule); border-radius:12px; padding:1.2rem 1.4rem;
  transition:border-color .2s;
}
.faq details[open]{border-color:var(--ink)}
.faq summary{
  font-family:"Fraunces",serif; font-size:1.15rem; cursor:pointer;
  list-style:none; display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; font-family:"JetBrains Mono",monospace; color:var(--ember); font-size:1.3rem; transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:.8rem; color:var(--ink-soft)}

/* Contact */
.contact-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:2rem}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.form{display:grid; gap:1rem; background:#fff; border:1px solid var(--rule); border-radius:var(--radius); padding:1.8rem}
.field{display:grid; gap:.4rem}
.field label{font-family:"JetBrains Mono",monospace; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}
.field input,.field textarea{
  font:inherit; padding:.8rem 1rem; border:1px solid var(--rule); border-radius:10px;
  background:var(--bone); transition:border-color .2s;
}
.field input:focus,.field textarea:focus{outline:none; border-color:var(--ink)}
.field textarea{min-height:140px; resize:vertical}
.contact-info{display:grid; gap:1rem; align-content:start}
.info-card{background:var(--ink); color:var(--bone); padding:1.5rem; border-radius:var(--radius)}
.info-card h3{color:var(--bone)}
.info-card a{color:var(--bone); border-bottom:1px dashed rgba(255,255,255,.4)}
.info-card .mono{color:var(--ember)}
.map-wrap{border-radius:var(--radius); overflow:hidden; border:1px solid var(--rule); aspect-ratio:16/10}
.map-wrap iframe{width:100%; height:100%; border:0; display:block}

/* Blog */
.posts{display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem}
@media(max-width:880px){.posts{grid-template-columns:1fr}}
.post{background:#fff; border:1px solid var(--rule); border-radius:var(--radius); overflow:hidden; transition:transform .25s, border-color .25s}
.post:hover{transform:translateY(-4px); border-color:var(--ink)}
.post-cover{aspect-ratio:16/10; background:linear-gradient(145deg,#2b2a27,#111); display:grid; place-items:center; color:var(--bone)}
.post-cover svg{width:50%; height:50%; opacity:.9}
.post-body{padding:1.4rem}
.post .date{font-family:"JetBrains Mono",monospace; font-size:.72rem; color:var(--ember); letter-spacing:.14em; text-transform:uppercase}
.post h3{margin:.5rem 0 .4rem; font-size:1.2rem}
.post p{color:var(--ink-soft); font-size:.95rem}

/* Legal pages */
.legal{max-width:780px; margin:0 auto}
.legal h2{margin:2rem 0 .8rem}
.legal h3{margin:1.5rem 0 .6rem; font-size:1.3rem}
.legal p,.legal li{color:var(--ink-soft); margin-bottom:.8rem}
.legal ul{padding-left:1.2rem}

/* ========== FOOTER ========== */
.site-footer{
  background:var(--ink); color:var(--bone); padding:4rem 0 2rem; margin-top:4rem;
  position:relative; overflow:hidden;
}
.site-footer::before{
  content:""; position:absolute; top:-1px; left:0; right:0; height:1px; background:var(--rule); opacity:.2;
}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; margin-bottom:3rem}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{font-family:"JetBrains Mono",monospace; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ember); margin-bottom:1rem}
.footer-grid a{display:block; padding:.3rem 0; opacity:.85; transition:opacity .2s, color .2s}
.footer-grid a:hover{opacity:1; color:var(--ember)}
.footer-brand{font-family:"Fraunces",serif; font-size:1.8rem; margin-bottom:.6rem}
.footer-brand em{font-style:italic; color:var(--ember)}
.footer-desc{opacity:.72; font-size:.95rem; max-width:34ch}
.socials{display:flex; gap:.6rem; margin-top:1.2rem}
.socials a{
  width:40px;height:40px;border-radius:50%; border:1px solid rgba(255,255,255,.2);
  display:grid; place-items:center; opacity:.8; transition:all .2s; padding:0;
}
.socials a:hover{background:var(--ember); border-color:var(--ember); opacity:1; transform:translateY(-2px)}
.socials svg{width:18px;height:18px; fill:currentColor}

.legal-bar{
  border-top:1px solid rgba(255,255,255,.12); padding-top:1.5rem;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-family:"JetBrains Mono",monospace; font-size:.75rem; letter-spacing:.1em; opacity:.6;
}
.legal-bar a:hover{color:var(--ember); opacity:1}

/* Reveal on scroll */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}

/* Utility */
.center{text-align:center}
.muted{color:var(--ink-soft)}
.divider{height:1px;background:var(--rule);margin:2rem 0}

/* Accessible focus */
:focus-visible{outline:2px solid var(--ember); outline-offset:3px; border-radius:4px}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}

/* ========== 4-COLUMN FOOTER ========== */
.footer-grid-4{grid-template-columns:1.4fr 1fr 1fr 1fr}
@media(max-width:880px){.footer-grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid-4{grid-template-columns:1fr}}

/* ========== CONTACT FULL WIDTH ========== */
.contact-grid{grid-template-columns:1fr 1fr}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}

/* =========================================================
   ADDITIONS v2 — Language toggle, Portfolio, Changelog,
   Photo placeholders, Improved team cards
   ========================================================= */

/* ── Language toggle ─────────────────────────────────────── */
.nav-actions{display:flex; align-items:center; gap:.5rem}
.lang-toggle{
  font-family:"JetBrains Mono",monospace; font-size:.78rem; letter-spacing:.14em;
  padding:.42rem .75rem; border-radius:999px; border:1px solid var(--rule);
  background:transparent; color:var(--ink-soft); cursor:pointer;
  transition:all .2s;
}
.lang-toggle:hover{background:var(--ink); color:var(--bone); border-color:var(--ink)}

/* ── Photo placeholder ──────────────────────────────────── */
.photo-placeholder{
  aspect-ratio:1; border-radius:10px; overflow:hidden; margin-bottom:.9rem;
  background:var(--paper); border:2px dashed var(--rule);
  display:grid; place-items:center; flex-direction:column; text-align:center;
  position:relative;
}
.photo-placeholder-inner{
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
  pointer-events:none; user-select:none;
}
.photo-placeholder svg{width:38px; height:38px; stroke:var(--rule); fill:none; stroke-width:1.5}
.photo-placeholder span{
  font-family:"JetBrains Mono",monospace; font-size:.65rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--rule);
}
/* real photo override: img inside .photo-placeholder fills it */
.photo-placeholder img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}

/* ── Portfolio / Gallery ───────────────────────────────── */
.portfolio-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
}
@media(max-width:1000px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.portfolio-grid{grid-template-columns:1fr}}

.pf-card{
  background:#fff; border:1px solid var(--rule); border-radius:var(--radius);
  overflow:hidden; transition:transform .25s, box-shadow .25s, border-color .25s;
  display:flex; flex-direction:column;
}
.pf-card:hover{transform:translateY(-5px); box-shadow:var(--shadow); border-color:var(--ink)}

.pf-thumb{
  aspect-ratio:16/10; background:linear-gradient(145deg,#1a1a1a,#2b2a27);
  display:grid; place-items:center; position:relative; overflow:hidden;
}
.pf-thumb svg{width:55%; height:55%; opacity:.9}
.pf-thumb .pf-ember{
  position:absolute; width:160px; height:160px; top:-40px; right:-40px;
  background:radial-gradient(circle, rgba(211,78,36,.5), transparent 65%);
  filter:blur(16px);
}
.pf-thumb .pf-moss{
  position:absolute; width:160px; height:160px; bottom:-40px; left:-40px;
  background:radial-gradient(circle, rgba(47,58,42,.55), transparent 65%);
  filter:blur(16px);
}
.pf-body{padding:1.3rem 1.4rem; display:flex; flex-direction:column; flex:1}
.pf-body h3{font-size:1.15rem; margin-bottom:.4rem}
.pf-body p{color:var(--ink-soft); font-size:.9rem; flex:1}
.pf-meta{display:flex; gap:.5rem; flex-wrap:wrap; margin:.9rem 0 1rem}
.pf-status{
  font-family:"JetBrains Mono",monospace; font-size:.68rem; letter-spacing:.1em;
  text-transform:uppercase; padding:.28rem .6rem; border-radius:999px;
  border:1px solid currentColor;
}
.pf-status.live{color:#2f8a2f; border-color:#2f8a2f; background:rgba(47,138,47,.08)}
.pf-status.wip{color:var(--ember); border-color:var(--ember); background:rgba(211,78,36,.08)}
.pf-status.upcoming{color:var(--muted); border-color:var(--rule)}

.pf-filter-bar{display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:2rem}
.pf-filter{
  font-family:"JetBrains Mono",monospace; font-size:.75rem; letter-spacing:.12em;
  text-transform:uppercase; padding:.4rem .85rem; border-radius:999px;
  border:1px solid var(--rule); background:#fff; color:var(--ink-soft);
  cursor:pointer; transition:all .2s;
}
.pf-filter:hover,.pf-filter.active{background:var(--ink); color:var(--bone); border-color:var(--ink)}

/* ── Changelog / Updates ────────────────────────────────── */
.changelog-timeline{display:grid; gap:0; position:relative}
.changelog-timeline::before{
  content:""; position:absolute; left:94px; top:0; bottom:0; width:2px;
  background:linear-gradient(to bottom, var(--ember), var(--rule) 80%);
}
@media(max-width:680px){
  .changelog-timeline::before{left:0; top:28px; bottom:0}
}

.cl-entry{
  display:grid; grid-template-columns:90px 2rem 1fr; gap:0 1.2rem;
  align-items:start; padding-bottom:2.8rem;
}
@media(max-width:680px){
  .cl-entry{grid-template-columns:1fr; padding-left:1.2rem}
}

.cl-date{
  font-family:"JetBrains Mono",monospace; font-size:.72rem; letter-spacing:.1em;
  color:var(--muted); text-align:right; padding-top:.3rem; text-transform:uppercase;
}
@media(max-width:680px){.cl-date{text-align:left; margin-bottom:.3rem}}

.cl-dot{
  width:14px; height:14px; border-radius:50%; background:var(--ember);
  border:3px solid var(--bone); margin-top:.42rem;
  box-shadow:0 0 0 3px rgba(211,78,36,.25);
  position:relative; z-index:1; justify-self:center;
}
@media(max-width:680px){display:none}

.cl-body{
  background:#fff; border:1px solid var(--rule); border-radius:var(--radius);
  padding:1.4rem 1.5rem;
}
.cl-version{
  font-family:"JetBrains Mono",monospace; font-size:.72rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ember); margin-bottom:.3rem;
}
.cl-body h3{font-size:1.2rem; margin-bottom:.8rem}
.cl-changes{list-style:none; display:grid; gap:.4rem}
.cl-changes li{
  display:flex; gap:.7rem; align-items:baseline;
  font-size:.94rem; color:var(--ink-soft);
}
.cl-changes li::before{
  content:""; width:6px; height:6px; border-radius:50%; background:var(--ember);
  flex-shrink:0; margin-top:.45rem;
}
.cl-badge{
  font-family:"JetBrains Mono",monospace; font-size:.65rem; letter-spacing:.1em;
  text-transform:uppercase; padding:.22rem .55rem; border-radius:999px;
  border:1px solid; flex-shrink:0;
}
.cl-badge.feat{color:#2f6a8a; border-color:#2f6a8a; background:rgba(47,106,138,.1)}
.cl-badge.fix{color:#8a6a2f; border-color:#8a6a2f; background:rgba(138,106,47,.1)}
.cl-badge.new{color:#2f8a5f; border-color:#2f8a5f; background:rgba(47,138,95,.1)}
.cl-badge.design{color:#6a2f8a; border-color:#6a2f8a; background:rgba(106,47,138,.1)}
.cl-badge.i18n{color:var(--ember); border-color:var(--ember); background:rgba(211,78,36,.1)}

/* ── Improved dev cards with photo-placeholder ──────────── */
.devs-v2{display:grid; grid-template-columns:repeat(5,1fr); gap:1.2rem}
@media(max-width:1100px){.devs-v2{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.devs-v2{grid-template-columns:repeat(2,1fr)}}

.dev-v2{
  text-align:left; background:#fff; border:1px solid var(--rule); border-radius:var(--radius);
  padding:1rem; transition:transform .25s, border-color .25s; cursor:pointer;
}
.dev-v2:hover{transform:translateY(-4px); border-color:var(--ink)}
.dev-v2 h3{font-size:1rem; margin-bottom:.15rem; line-height:1.2}
.dev-v2 .role{font-family:"JetBrains Mono",monospace; font-size:.67rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ember); display:block; margin-bottom:.4rem}
.dev-v2 p{font-size:.86rem; color:var(--ink-soft); margin-top:.4rem}

/* ── Animated marquee track update ─────────────────────── */
.marquee-track span{display:inline-flex; align-items:center; gap:3rem; margin-right:3rem}

/* ========== STATS SECTION ========== */
.stats-section{background:var(--paper);border-radius:var(--radius);padding:clamp(3rem,6vw,5rem) clamp(1.5rem,3vw,2.5rem);margin:0 auto}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2rem}
@media(max-width:880px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}
.stat-card{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:1.8rem;text-align:center;transition:transform .25s,box-shadow .25s}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stat-number{display:block;font-family:"Fraunces",serif;font-size:clamp(2.2rem,4vw,3.2rem);color:var(--ember);line-height:1;margin-bottom:.4rem;font-weight:500}
.stat-label{display:block;font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.8rem}
.stat-desc{font-size:.88rem;color:var(--muted);line-height:1.5}

/* ========== PROCESS STEPS ========== */
.process-steps{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap;justify-content:center}
.process-step{flex:1;min-width:180px;max-width:240px;background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:1.6rem 1.4rem;text-align:center}
.process-step:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--ink);transition:transform .25s,box-shadow .25s,border-color .25s}
.process-num{display:block;font-family:"JetBrains Mono",monospace;font-size:.75rem;letter-spacing:.18em;color:var(--ember);margin-bottom:.8rem}
.process-step h3{font-size:1.1rem;margin-bottom:.5rem}
.process-step p{font-size:.88rem;color:var(--muted);line-height:1.5}
.process-connector{color:var(--rule);flex-shrink:0;margin-top:3.5rem;display:flex;align-items:center}
@media(max-width:760px){.process-connector{display:none}.process-steps{flex-direction:column;align-items:stretch}.process-step{max-width:100%}}

/* ========== TECH TAGS ========== */
.tech-preview-section{background:var(--ink);border-radius:var(--radius);padding:clamp(3rem,6vw,5rem) clamp(1.5rem,3vw,2.5rem);margin:0 auto}
.tech-preview-section .section-head{color:var(--bone)}
.tech-preview-section .section-head h2{color:var(--bone)}
.tech-preview-section .section-head .num{color:var(--ember)}
.tech-preview-section .section-head p{color:rgba(245,241,234,.7)}
.tech-tags{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}
.tech-tag{background:rgba(245,241,234,.1);border:1px solid rgba(245,241,234,.2);color:var(--bone);padding:.55rem 1.1rem;border-radius:999px;font-family:"JetBrains Mono",monospace;font-size:.8rem;letter-spacing:.08em;transition:background .2s,border-color .2s}
.tech-tag:hover{background:var(--ember);border-color:var(--ember)}
.tech-preview-section .btn-ghost{border-color:rgba(245,241,234,.4);color:var(--bone)}
.tech-preview-section .btn-ghost:hover{background:var(--ember);border-color:var(--ember);color:#fff}

/* ========== TESTIMONIAL CARDS ========== */
.testimonial-card{display:flex;flex-direction:column;gap:1.2rem}
.testimonial-text{font-family:"Fraunces",serif;font-size:1.1rem;line-height:1.5;color:var(--ink-soft);font-style:italic;flex:1}
.testimonial-text::before{content:'"';font-size:2.5rem;color:var(--ember);line-height:0;vertical-align:-.5em;margin-right:.2rem}
.testimonial-author{display:flex;flex-direction:column;gap:.2rem;border-top:1px solid var(--rule);padding-top:1rem;margin-top:auto}
.testimonial-name{font-weight:600;font-size:.95rem}
.testimonial-role{font-size:.82rem;color:var(--muted);font-family:"JetBrains Mono",monospace;letter-spacing:.06em}

/* ========== FLOATING WHATSAPP BUTTON ========== */
.whatsapp-float{
  position:fixed;bottom:1.8rem;right:1.8rem;z-index:999;
  display:flex;align-items:center;gap:.6rem;
  background:#25d366;color:#fff;
  padding:.85rem 1.2rem;border-radius:999px;
  box-shadow:0 4px 20px rgba(37,211,102,.45);
  font-weight:600;font-size:.9rem;
  transition:transform .25s,box-shadow .25s,background .2s;
  text-decoration:none;
}
.whatsapp-float:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 8px 28px rgba(37,211,102,.55);background:#1ebe5d}
.whatsapp-float svg{flex-shrink:0}
@media(max-width:600px){.whatsapp-label{display:none}.whatsapp-float{padding:.9rem;border-radius:50%;width:54px;height:54px;justify-content:center}}
