/* GRUPO IDEA — CSS v5.0 — All fixes applied */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --c-ink:#08192A;--c-navy:#0A2540;--c-deep:#0D3257;--c-mid:#1A5276;
  --c-teal:#2E8899;--c-turq:#4DBED2;--c-sky:#7FD3E2;--c-mist:#CDEFF5;--c-foam:#E6F7FA;
  --c-800:#243744;--c-700:#3F515D;--c-600:#5C6F7C;--c-500:#7A909F;
  --c-400:#9FB0BD;--c-300:#D2DCE5;--c-200:#E6EDF3;--c-100:#F2F6FA;--c-50:#FAFCFF;--c-wh:#fff;
  --f-sans:'Syne',sans-serif;--f-mono:'DM Mono',monospace;--f-serif:'Playfair Display',serif;
  --ease-bounce:cubic-bezier(0.34,1.56,0.64,1);
  --ease-smooth:cubic-bezier(0.16,1,0.3,1);
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --r-sm:6px;--r-md:14px;--r-lg:22px;--nav-h:78px;
  --sh-sm:0 2px 12px rgba(10,37,64,.07);
  --sh-md:0 8px 32px rgba(10,37,64,.1);
  --sh-lg:0 20px 60px rgba(10,37,64,.15);
  --sh-xl:0 40px 80px rgba(10,37,64,.2);
}

html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--f-sans);background:var(--c-wh);color:var(--c-navy);overflow-x:hidden;-webkit-font-smoothing:antialiased;cursor:none}
@media(max-width:768px){body{cursor:auto}}
img{max-width:100%;height:auto;display:block}
svg{display:block;flex-shrink:0}
a{color:inherit;text-decoration:none}
button{font-family:var(--f-sans);cursor:pointer;border:none;background:none}
:focus-visible{outline:2px solid var(--c-turq);outline-offset:3px}

/* ── LOADER ── */
#loader{
  position:fixed;inset:0;background:var(--c-navy);z-index:10000;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s var(--ease-smooth),visibility .5s;
  will-change:opacity;
}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:1.5rem;animation:loaderIn .5s var(--ease-smooth) both}
@keyframes loaderIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.loader-logo{font-weight:800;font-size:1.3rem;letter-spacing:.4em;color:var(--c-wh);text-transform:uppercase}
.loader-bar{width:200px;height:1.5px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.loader-fill{height:100%;background:var(--c-turq);border-radius:2px;width:0;animation:loaderFill 1.3s var(--ease-smooth) .2s forwards}
@keyframes loaderFill{0%{width:0}65%{width:70%}100%{width:100%}}
.loader-label{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.22em;color:var(--c-600);text-transform:uppercase}

/* ── CURSOR ── */
#cursor{
  position:fixed;width:36px;height:36px;
  border:1.5px solid rgba(77,190,210,.45);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease-bounce),height .3s var(--ease-bounce),border-color .2s,background-color .2s,border-radius .3s var(--ease-bounce);
  will-change:left,top;
}
#cursor-dot{
  position:fixed;width:5px;height:5px;background:var(--c-turq);
  border-radius:50%;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);will-change:left,top;
}

/* ── NAV ── */
#main-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0 3rem;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .4s ease,box-shadow .4s ease;
}
#main-nav.scrolled{
  background:rgba(10,37,64,.96);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(255,255,255,.04),0 4px 24px rgba(0,0,0,.2);
}

/* ── NAV LOGO with image slot ── */
.nav-logo{color:var(--c-wh);display:flex;align-items:center;gap:.75rem}
.nav-logo-img-wrap{
  width:38px;height:38px;flex-shrink:0;
  border-radius:8px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s;
}
.nav-logo:hover .nav-logo-img-wrap{border-color:rgba(77,190,210,.4)}
.nav-logo-img{width:100%;height:100%;object-fit:contain;display:block}
.nav-logo-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.72rem;letter-spacing:.06em;
  color:var(--c-turq);font-family:var(--f-sans);
}
.logo-text{font-weight:800;font-size:.9rem;letter-spacing:.28em;text-transform:uppercase}

.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none}
.nav-link{
  font-family:var(--f-mono);font-size:.67rem;letter-spacing:.1em;
  color:rgba(255,255,255,.55);padding:.5rem .9rem;border-radius:var(--r-sm);
  text-transform:uppercase;transition:color .2s,background .2s;
}
.nav-link:hover{color:var(--c-wh);background:rgba(255,255,255,.06)}
.nav-cta-link{
  font-size:.78rem;font-weight:700;color:var(--c-wh);
  padding:.55rem 1.35rem;background:var(--c-teal);border-radius:var(--r-sm);margin-left:.75rem;
  transition:background .2s,transform .2s,box-shadow .2s;
}
.nav-cta-link:hover{background:var(--c-mid);transform:translateY(-1px);box-shadow:0 4px 16px rgba(46,136,153,.4)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:.5rem}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--c-wh);border-radius:2px;transition:transform .3s var(--ease-smooth),opacity .25s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{
  position:fixed;inset:0;background:var(--c-navy);z-index:999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease-smooth),visibility .3s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu ul{list-style:none;text-align:center;display:flex;flex-direction:column;gap:.2rem}
.mobile-link{display:block;font-size:2.4rem;font-weight:800;letter-spacing:-.03em;color:rgba(255,255,255,.7);padding:.4rem 2rem;transition:color .2s}
.mobile-link:hover{color:var(--c-sky)}
.mobile-cta{margin-top:1.25rem;background:var(--c-teal);border-radius:var(--r-sm);padding:.8rem 2.5rem;font-size:1.1rem;color:var(--c-wh)!important}
.mobile-menu-footer{position:absolute;bottom:3rem;display:flex;gap:2rem;font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;color:var(--c-700);text-transform:uppercase}

/* ── SCROLL DOTS ── */
#scroll-progress{position:fixed;right:1.75rem;top:50%;transform:translateY(-50%);z-index:100;display:flex;flex-direction:column;gap:.5rem}
.progress-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.18);cursor:pointer;transition:all .35s var(--ease-smooth)}
.progress-dot.active{background:var(--c-turq);height:20px;border-radius:2px}

/* ── LAYOUT ── */
.container{max-width:1240px;margin:0 auto;padding:0 3rem;width:100%}
section{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.section-dark{background:var(--c-navy)}
.section-alt{background:var(--c-50)}
.section-light{background:var(--c-wh)}
.section-contact{background:var(--c-navy)}

/* ── SECTION HEADER ── */
.section-header{margin-bottom:4rem;max-width:680px}
.section-label{
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.22em;
  color:var(--c-turq);text-transform:uppercase;margin-bottom:1.25rem;
  display:flex;align-items:center;gap:.75rem;
}
.section-label::before{content:'';width:22px;height:1px;background:currentColor;flex-shrink:0}
.section-label-light{color:var(--c-sky)}
.section-title{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:800;line-height:1.06;letter-spacing:-.04em;color:var(--c-navy);margin-bottom:1.25rem}
.section-title-light{color:var(--c-wh)}
.section-title em,.contact-title em{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--c-teal)}
.section-title-light em{color:var(--c-sky)}
.section-sub{font-size:.95rem;color:var(--c-500);line-height:1.8;max-width:480px}

/* ── HOVER TITLE — lightweight CSS-only, no gradient repaint ── */
/* Replaces heavy gradient-background-clip animation with transform-based approach */
.hover-title{
  color:var(--c-navy);
  transition:color .3s ease;
}
.hover-title:hover{
  color:var(--c-teal);
}
.section-title-light.hover-title,
.estudio-hero-title.hover-title{
  color:var(--c-wh);
  transition:color .3s ease;
}
.section-title-light.hover-title:hover,
.estudio-hero-title.hover-title:hover{
  color:var(--c-sky);
}

/* ── BUTTONS ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--c-teal);color:var(--c-wh);
  font-size:.88rem;font-weight:700;letter-spacing:.02em;
  padding:.9rem 2rem;border-radius:var(--r-sm);
  transition:background .25s,transform .25s var(--ease-smooth),box-shadow .25s;
}
.btn-primary:hover{background:var(--c-mid);transform:translateY(-2px);box-shadow:0 8px 28px rgba(46,136,153,.35)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.6);
  font-size:.88rem;font-weight:500;padding:.9rem 1.5rem;
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-sm);
  transition:color .2s,border-color .2s,background .2s;
}
.btn-ghost:hover{color:var(--c-wh);border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.05)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.5rem;color:var(--c-navy);
  font-size:.88rem;font-weight:600;padding:.9rem 2rem;
  border:1.5px solid var(--c-200);border-radius:var(--r-sm);
  transition:border-color .2s,color .2s,background .2s;
}
.btn-outline:hover{border-color:var(--c-turq);color:var(--c-teal);background:var(--c-foam)}

/* ── GRAIN ── */
.grain-overlay{
  position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.25;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
}
.grain-overlay-light{opacity:.1}

/* ── HERO ── */
.section-hero{background:var(--c-navy);min-height:100vh;flex-direction:column;align-items:stretch;padding:0}
.hero-grid-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
}
.hero-shapes{position:absolute;inset:0;z-index:1;pointer-events:none;contain:strict}
.hero-shape{position:absolute;border-radius:50%;filter:blur(90px);will-change:transform}
.hero-shape-1{width:700px;height:700px;background:radial-gradient(circle,rgba(77,190,210,.09) 0%,transparent 70%);top:-25%;right:-10%;animation:floatA 14s ease-in-out infinite}
.hero-shape-2{width:500px;height:500px;background:radial-gradient(circle,rgba(46,136,153,.07) 0%,transparent 70%);bottom:-15%;left:-8%;animation:floatB 18s ease-in-out infinite}
.hero-shape-3{width:280px;height:280px;background:radial-gradient(circle,rgba(127,211,226,.07) 0%,transparent 70%);top:45%;left:30%;animation:floatA 10s ease-in-out infinite;animation-delay:-5s}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(18px,-28px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(-12px,22px)}}

.hero-content{
  position:relative;z-index:2;max-width:960px;width:100%;margin:0 auto;
  text-align:center;
  padding:calc(var(--nav-h) + 5rem) 3rem 4rem;
}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.75rem;font-family:var(--f-mono);font-size:.62rem;letter-spacing:.16em;color:rgba(255,255,255,.45);text-transform:uppercase;margin-bottom:2.5rem;opacity:0;animation:fadeUp .8s var(--ease-smooth) 1.5s forwards}
.eyebrow-line{width:20px;height:1px;background:rgba(255,255,255,.3)}

/* ── HERO TITLE — elegant stretch/skew hover effect ── */
.hero-title{
  font-size:clamp(3.2rem,8.5vw,8rem);
  font-weight:700;line-height:.98;letter-spacing:-.05em;
  color:var(--c-wh);margin-bottom:2rem;
  cursor:default;
}
.hero-line{
  display:block;opacity:0;transform:translateY(28px);filter:blur(6px);
  animation:revealLine 1.1s var(--ease-smooth) forwards;
  transition:letter-spacing .5s var(--ease-smooth), transform .4s var(--ease-smooth);
  will-change:letter-spacing;
}
/* Individual line hover — subtle letter-spacing stretch */
.hero-title:hover .hero-line:nth-child(1){letter-spacing:-.02em}
.hero-title:hover .hero-line:nth-child(2){letter-spacing:.01em}
.hero-title:hover .hero-line:nth-child(3){letter-spacing:-.02em}
/* Teal accent line stays italic serif */
.hero-line:nth-child(1){animation-delay:1.7s}
.hero-line:nth-child(2){animation-delay:1.9s;color:var(--c-turq);font-family:var(--f-serif);font-style:italic;font-weight:400}
.hero-line:nth-child(3){animation-delay:2.1s}
@keyframes revealLine{to{opacity:1;transform:none;filter:blur(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.hero-sub{font-family:var(--f-mono);font-size:.82rem;color:var(--c-400);line-height:2;margin-bottom:3rem;opacity:0;animation:fadeUp .8s var(--ease-smooth) 2.4s forwards}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;opacity:0;animation:fadeUp .8s var(--ease-smooth) 2.6s forwards}
.hero-stats{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  display:flex;align-items:stretch;border-top:1px solid rgba(255,255,255,.05);
  opacity:0;animation:fadeUp .8s var(--ease-smooth) 3s forwards;
}
.hero-stat{flex:1;padding:1.5rem 2.5rem;display:flex;flex-direction:column;gap:.3rem;border-right:1px solid rgba(255,255,255,.05);transition:background .25s}
.hero-stat:last-child{border-right:none}
.hero-stat:hover{background:rgba(255,255,255,.02)}
.hero-stat-div{display:none}
.stat-num{font-size:1.9rem;font-weight:800;letter-spacing:-.05em;color:var(--c-wh);line-height:1}
.stat-label{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.1em;color:var(--c-600);text-transform:uppercase}
.scroll-hint{position:absolute;right:3rem;bottom:7rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:fadeUp .8s var(--ease-smooth) 3.3s forwards}
.scroll-line{width:1px;height:52px;background:linear-gradient(to bottom,var(--c-turq),transparent);animation:scrollPulse 2.5s ease-in-out infinite}
.scroll-hint span{font-family:var(--f-mono);font-size:.55rem;letter-spacing:.22em;color:var(--c-600);text-transform:uppercase;writing-mode:vertical-rl}
@keyframes scrollPulse{0%,100%{opacity:.25}50%{opacity:1}}

/* ── SERVICES ── */
.section-alt{padding:8rem 0}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.service-card{
  background:var(--c-wh);border:1.5px solid var(--c-200);border-radius:var(--r-md);
  padding:2rem 1.75rem;position:relative;cursor:pointer;
  transition:border-color .25s,transform .35s var(--ease-out),box-shadow .25s;
  display:flex;flex-direction:column;gap:.7rem;overflow:hidden;
}
.service-card:hover{border-color:var(--c-sky);transform:translateY(-5px);box-shadow:var(--sh-lg)}
.service-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 35% 30%,rgba(77,190,210,.07),transparent 55%);opacity:0;transition:opacity .35s}
.service-card:hover .service-glow{opacity:1}
.service-top{display:flex;align-items:flex-start;justify-content:space-between}
.service-icon{width:46px;height:46px;background:var(--c-100);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--c-teal);transition:background .25s,color .25s,transform .3s var(--ease-bounce)}
.service-card:hover .service-icon{background:var(--c-foam);color:var(--c-deep);transform:scale(1.06) rotate(-3deg)}
.service-num{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.18em;color:var(--c-turq)}
.service-title{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:var(--c-navy)}
.service-desc{font-size:.83rem;color:var(--c-500);line-height:1.75;flex:1}
.service-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.service-tags span{font-family:var(--f-mono);font-size:.57rem;letter-spacing:.05em;color:var(--c-500);background:var(--c-100);padding:.2rem .55rem;border-radius:100px;transition:background .2s,color .2s}
.service-card:hover .service-tags span{background:var(--c-foam);color:var(--c-deep)}
.service-cta{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--f-mono);font-size:.63rem;letter-spacing:.09em;color:var(--c-teal);text-transform:uppercase;margin-top:.5rem;transition:gap .2s}
.service-card:hover .service-cta{gap:.75rem}
.service-cta svg{transition:transform .2s var(--ease-bounce)}
.service-card:hover .service-cta svg{transform:translateX(4px)}
.service-card-wide{grid-column:1/-1}

/* ── PROCESS ── */
.section-dark{padding:8rem 0}
.process-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.process-visual{position:sticky;top:calc(var(--nav-h) + 2rem)}
.process-screen{background:var(--c-800);border-radius:var(--r-md);overflow:hidden;border:1px solid rgba(255,255,255,.05);box-shadow:0 32px 80px rgba(0,0,0,.4)}
.pscreen-bar{background:rgba(255,255,255,.03);padding:.8rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.04)}
.pscreen-dots{display:flex;gap:6px}
.pd{width:10px;height:10px;border-radius:50%}
.pd.red{background:#FF5F57}.pd.yellow{background:#FFBD2E}.pd.green{background:#28C840}
.pscreen-url{margin-left:.75rem;font-family:var(--f-mono);font-size:.58rem;color:rgba(255,255,255,.2);background:rgba(255,255,255,.05);padding:.22rem .75rem;border-radius:4px}
.pscreen-body{padding:1.5rem;min-height:240px;position:relative;overflow:hidden}
.pstep{
  position:absolute;inset:1.5rem;
  opacity:0;transform:translateY(8px);
  transition:opacity .4s ease,transform .4s var(--ease-smooth);
  pointer-events:none;
}
.pstep.active{position:relative;inset:auto;opacity:1;transform:none;pointer-events:auto}
.pv-label{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.16em;color:var(--c-turq);text-transform:uppercase}
.pv-lines{display:flex;flex-direction:column;gap:.4rem;margin:.25rem 0}
.pv-line{height:7px;background:rgba(255,255,255,.07);border-radius:3px}
.pv-line.long{width:88%}.pv-line.medium{width:62%}.pv-line.short{width:42%}
.pv-notes{display:flex;gap:.75rem}
.pv-note{height:55px;flex:1;background:rgba(77,190,210,.07);border-radius:6px;border:1px solid rgba(77,190,210,.14)}
.pv-check{font-family:var(--f-mono);font-size:.62rem;color:#28C840;margin-top:.25rem}
.pv-palette{display:flex;gap:.5rem}
.pv-swatch{height:36px;flex:1;border-radius:5px}
.pv-typo{font-family:var(--f-serif);font-style:italic;font-size:2.5rem;color:var(--c-wh);opacity:.65;line-height:1}
.pv-sketch{height:70px;background:rgba(255,255,255,.03);border-radius:5px;border:1px dashed rgba(255,255,255,.1)}
.pv-code{display:flex;flex-direction:column;gap:.5rem;font-family:var(--f-mono);font-size:.72rem;line-height:1.5}
.pv-code-line{color:rgba(255,255,255,.65)}
.pv-kw{color:var(--c-sky)}.pv-str{color:#A3E4A3}.pv-fn{color:#FFD580}.pv-comment{color:rgba(255,255,255,.22)}
.pv-files{display:flex;flex-direction:column;gap:.7rem}
.pv-file{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;background:rgba(255,255,255,.04);border-radius:7px;border:1px solid rgba(255,255,255,.05)}
.pv-file span{font-size:.76rem;color:rgba(255,255,255,.6)}
.pv-file-icon{width:34px;height:34px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:.52rem;font-weight:700}
.pv-file-icon.pdf{background:rgba(255,95,87,.15);color:#FF5F57}
.pv-file-icon.fig{background:rgba(77,190,210,.15);color:var(--c-turq)}
.pv-file-icon.web{background:rgba(40,200,64,.15);color:#28C840}
.process-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.25rem}
.pm-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);border-radius:var(--r-sm);padding:1rem;text-align:center}
.pm-num{font-size:1.4rem;font-weight:800;color:var(--c-wh);letter-spacing:-.04em;line-height:1}
.pm-label{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.1em;color:var(--c-600);text-transform:uppercase;margin-top:.3rem}
.process-steps-list{display:flex;flex-direction:column;padding-top:1.5rem}
.process-item{padding:1.5rem 0 1.5rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;position:relative}
.process-item:last-child{border-bottom:none}
.process-item.active{border-left:2px solid var(--c-turq)}
.process-item-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}
.process-num{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.18em;color:var(--c-turq);min-width:1.75rem}
.process-name{font-size:1.08rem;font-weight:700;color:rgba(255,255,255,.6);letter-spacing:-.01em;transition:color .2s}
.process-item.active .process-name{color:var(--c-sky)}
.process-desc,.process-deliverables,.process-duration{max-height:0;overflow:hidden;opacity:0;transition:max-height .45s var(--ease-smooth),opacity .35s}
.process-desc{font-size:.83rem;color:var(--c-500);line-height:1.8}
.process-item.active .process-desc{max-height:120px;opacity:1}
.process-deliverables{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem;transition-delay:0s,.1s,0s}
.process-item.active .process-deliverables{max-height:60px;opacity:1}
.process-deliverables span{font-family:var(--f-mono);font-size:.57rem;letter-spacing:.07em;color:var(--c-teal);background:rgba(77,190,210,.08);border:1px solid rgba(77,190,210,.15);padding:.18rem .55rem;border-radius:4px}
.process-item.active .process-duration{max-height:40px;opacity:1}
.process-duration{margin-top:.6rem;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.1em;color:var(--c-700)}
.process-guarantees{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:4rem;padding-top:3rem;border-top:1px solid rgba(255,255,255,.05)}
.pg-item{padding:1.5rem;background:rgba(255,255,255,.03);border-radius:var(--r-md);border:1px solid rgba(255,255,255,.05)}
.pg-icon{color:var(--c-turq);font-size:1rem;margin-bottom:.75rem}
.pg-title{font-size:.9rem;font-weight:700;color:var(--c-wh);margin-bottom:.5rem}
.pg-desc{font-size:.78rem;color:var(--c-600);line-height:1.7}

/* ── PROJECTS ── */
.section-light{padding:8rem 0}
.projects-filters{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:3rem}
.filter-btn{font-family:var(--f-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.48rem 1.1rem;border:1.5px solid var(--c-200);border-radius:100px;color:var(--c-500);transition:border-color .2s,color .2s,background .2s;background:transparent}
.filter-btn:hover{border-color:var(--c-sky);color:var(--c-teal)}
.filter-btn.active{background:var(--c-navy);border-color:var(--c-navy);color:var(--c-wh)}
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:3rem}
.project-card{border-radius:var(--r-md);overflow:hidden;background:var(--c-100);border:1px solid var(--c-200);transition:transform .35s var(--ease-out),box-shadow .35s;cursor:pointer}
.project-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl)}
.project-card.hidden{display:none!important}
.project-featured{grid-column:1/3;display:grid;grid-template-columns:1.3fr .7fr}
.project-wide{grid-column:1/3;display:grid;grid-template-columns:1.5fr .5fr}
.project-visual{position:relative;overflow:hidden;aspect-ratio:4/3}
.project-featured .project-visual,.project-wide .project-visual{aspect-ratio:auto;min-height:280px}
.project-img-bg{width:100%;height:100%;transition:transform .55s var(--ease-smooth)}
.project-card:hover .project-img-bg{transform:scale(1.03)}
.project-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(8,25,42,.7);backdrop-filter:blur(4px);opacity:0;transition:opacity .25s}
.project-card:hover .project-overlay{opacity:1}
.project-open-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--c-wh);color:var(--c-navy);font-size:.8rem;font-weight:700;padding:.65rem 1.35rem;border-radius:var(--r-sm);transition:background .2s,transform .2s var(--ease-bounce)}
.project-open-btn:hover{background:var(--c-foam);transform:scale(1.05)}
.pv-1{background:linear-gradient(135deg,#0A2540,#1a4a75,#2E8899)}
.pv-2{background:linear-gradient(135deg,#0d2035,#14395a,#1a5a7a)}
.pv-3{background:linear-gradient(135deg,#0e2d3f,#15495e,#1e6880)}
.pv-4{background:linear-gradient(135deg,#0a1f2e,#102840,#1a3d5c)}
.pv-5{background:linear-gradient(135deg,#071927,#0d2a3f,#124060)}
.pv-6{background:linear-gradient(135deg,#0f2535,#1a3f55,#244d68)}
.project-placeholder-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.project-info{padding:1.75rem;display:flex;flex-direction:column;gap:.65rem;background:var(--c-wh)}
.project-featured .project-info,.project-wide .project-info{padding:2.25rem;justify-content:center}
.project-meta{display:flex;align-items:center;justify-content:space-between}
.project-cat{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.14em;color:var(--c-teal);text-transform:uppercase}
.project-year{font-family:var(--f-mono);font-size:.58rem;color:var(--c-400)}
.project-name{font-size:1.12rem;font-weight:700;letter-spacing:-.02em;color:var(--c-navy);line-height:1.2}
.project-featured .project-name{font-size:1.45rem}
.project-excerpt{font-size:.81rem;color:var(--c-500);line-height:1.7}
.project-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}
.project-tags-mini{display:flex;flex-wrap:wrap;gap:.32rem}
.project-tags-mini span{font-family:var(--f-mono);font-size:.54rem;letter-spacing:.06em;color:var(--c-500);background:var(--c-100);padding:.16rem .5rem;border-radius:100px}
.project-link{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.1em;color:var(--c-teal);text-transform:uppercase;transition:letter-spacing .2s;white-space:nowrap}
.project-card:hover .project-link{letter-spacing:.18em}
.projects-cta{text-align:center;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}
.btn-portfolio{display:inline-flex;align-items:center;gap:.75rem;background:var(--c-navy);color:var(--c-wh);font-size:.88rem;font-weight:700;padding:.9rem 2rem;border-radius:var(--r-sm);transition:background .25s,transform .25s,box-shadow .25s}
.btn-portfolio:hover{background:var(--c-deep);transform:translateY(-2px);box-shadow:var(--sh-md)}
.portfolio-count-badge{display:inline-flex;align-items:center;font-family:var(--f-mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c-turq);background:rgba(77,190,210,.12);border:1px solid rgba(77,190,210,.25);padding:.18rem .65rem;border-radius:100px;margin-left:.25rem}

/* ── PORTFOLIO PAGE ── */
.portfolio-page{position:fixed;inset:0;background:var(--c-50);z-index:1500;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(30px);transition:opacity .4s var(--ease-smooth),visibility .4s,transform .4s var(--ease-smooth)}
.portfolio-page.open{opacity:1;visibility:visible;transform:none}
.portfolio-header{position:sticky;top:0;z-index:10;background:rgba(250,252,255,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--c-200);padding:1rem 3rem}
.portfolio-header-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.portfolio-back{display:flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.1em;color:var(--c-600);text-transform:uppercase;padding:.45rem .9rem;border:1px solid var(--c-300);border-radius:var(--r-sm);transition:color .2s,border-color .2s}
.portfolio-back:hover{color:var(--c-navy);border-color:var(--c-navy)}
.portfolio-logo{font-weight:800;font-size:.85rem;letter-spacing:.22em;color:var(--c-navy);text-transform:uppercase;flex:1;text-align:center}
.portfolio-filters-mini{display:flex;gap:.35rem;flex-wrap:wrap}
.pf-btn{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.09em;text-transform:uppercase;padding:.35rem .8rem;border:1px solid var(--c-200);border-radius:100px;color:var(--c-500);background:transparent;transition:border-color .2s,color .2s,background .2s}
.pf-btn:hover{border-color:var(--c-turq);color:var(--c-teal)}
.pf-btn.active{background:var(--c-navy);border-color:var(--c-navy);color:var(--c-wh)}
.portfolio-results-bar{background:var(--c-100);border-bottom:1px solid var(--c-200);padding:.6rem 3rem}
.portfolio-results-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:.5rem}
.portfolio-results-count{font-weight:700;font-size:.82rem;color:var(--c-navy)}
.portfolio-results-label{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;color:var(--c-500);text-transform:uppercase}
.portfolio-body{max-width:1240px;margin:0 auto;padding:3rem 3rem 6rem}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.portfolio-item{border-radius:var(--r-md);overflow:hidden;background:var(--c-wh);border:1px solid var(--c-200);cursor:pointer;transition:transform .3s var(--ease-out),box-shadow .3s,border-color .25s}
.portfolio-item:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--c-sky)}
.portfolio-item.hidden{display:none!important}
.portfolio-item.tall{grid-row:span 2}
.portfolio-item.wide{grid-column:span 2}
.pi-visual{position:relative;overflow:hidden;aspect-ratio:4/3}
.portfolio-item.tall .pi-visual{aspect-ratio:3/4}
.portfolio-item.wide .pi-visual{aspect-ratio:16/7}
.pi-visual-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .5s var(--ease-smooth)}
.portfolio-item:hover .pi-visual-bg{transform:scale(1.04)}
.pi-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(8,25,42,.65);backdrop-filter:blur(4px);opacity:0;transition:opacity .25s}
.portfolio-item:hover .pi-overlay{opacity:1}
.pi-open{display:inline-flex;align-items:center;gap:.4rem;background:var(--c-wh);color:var(--c-navy);font-size:.76rem;font-weight:700;padding:.55rem 1.1rem;border-radius:var(--r-sm)}
.pi-info{padding:1.35rem;display:flex;flex-direction:column;gap:.5rem}
.pi-cat{font-family:var(--f-mono);font-size:.57rem;letter-spacing:.14em;color:var(--c-teal);text-transform:uppercase}
.pi-name{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--c-navy)}
.pi-excerpt{font-size:.78rem;color:var(--c-500);line-height:1.6}
.pi-new-badge{display:inline-flex;align-items:center;font-family:var(--f-mono);font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c-teal);background:var(--c-foam);border:1px solid rgba(77,190,210,.25);padding:.14rem .5rem;border-radius:100px;white-space:nowrap;flex-shrink:0}

/* ── MODAL ── */
.project-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:flex-end;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s}
.project-modal.open{opacity:1;visibility:visible}
.modal-overlay{position:absolute;inset:0;background:rgba(8,25,42,.7);backdrop-filter:blur(8px);cursor:pointer}
.modal-panel{position:relative;z-index:1;background:var(--c-wh);border-radius:var(--r-lg) var(--r-lg) 0 0;width:100%;max-width:1020px;max-height:92vh;overflow-y:auto;transform:translateY(100%);transition:transform .45s var(--ease-smooth);scrollbar-width:thin;scrollbar-color:var(--c-200) transparent}
.project-modal.open .modal-panel{transform:none}
.modal-close{position:sticky;top:1.25rem;float:right;margin:1.25rem 1.25rem 0 0;background:var(--c-100);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background .2s,transform .2s}
.modal-close:hover{background:var(--c-200);transform:rotate(90deg)}
.modal-content{padding:2.5rem;clear:both}
.modal-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.5rem}
.modal-tag{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.14em;color:var(--c-teal);background:var(--c-foam);padding:.25rem .7rem;border-radius:100px;text-transform:uppercase}
.modal-title{font-size:1.8rem;font-weight:800;letter-spacing:-.04em;color:var(--c-navy);margin-bottom:1rem;line-height:1.1}
.modal-lead{font-size:1.05rem;color:var(--c-700);line-height:1.75;margin-bottom:1.5rem;font-weight:500;border-left:3px solid var(--c-turq);padding-left:1.25rem}
.modal-desc{font-size:.9rem;color:var(--c-600);line-height:1.85;margin-bottom:2rem}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}
.modal-detail{padding:1.2rem;background:var(--c-50);border-radius:var(--r-sm);border:1px solid var(--c-100)}
.modal-detail-label{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.16em;color:var(--c-400);text-transform:uppercase;margin-bottom:.4rem}
.modal-detail-value{font-size:.86rem;font-weight:600;color:var(--c-navy);line-height:1.4}
.modal-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:2rem}
.modal-gallery-item{aspect-ratio:4/3;border-radius:var(--r-sm);overflow:hidden;background:var(--c-100);border:1px solid var(--c-200);cursor:zoom-in;transition:transform .25s var(--ease-bounce),box-shadow .25s}
.modal-gallery-item:hover{transform:scale(1.02);box-shadow:var(--sh-md)}
.modal-gallery-item.wide{grid-column:span 2}
.modal-result{padding:1.5rem;margin-bottom:2rem;background:linear-gradient(135deg,var(--c-foam),rgba(77,190,210,.04));border-radius:var(--r-md);border-left:3px solid var(--c-turq)}
.modal-result-label{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.16em;color:var(--c-teal);text-transform:uppercase;margin-bottom:.5rem}
.modal-result-value{font-size:1rem;font-weight:700;color:var(--c-navy);line-height:1.4}
.modal-scope{margin-bottom:2rem}
.modal-scope-title{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--c-700);text-transform:uppercase;margin-bottom:.75rem}
.modal-scope-items{display:flex;flex-wrap:wrap;gap:.5rem}
.modal-scope-item{font-family:var(--f-mono);font-size:.63rem;color:var(--c-600);background:var(--c-wh);border:1px solid var(--c-200);padding:.32rem .8rem;border-radius:var(--r-sm);transition:border-color .2s,color .2s}
.modal-scope-item:hover{border-color:var(--c-turq);color:var(--c-teal)}
.modal-testimonial{background:var(--c-navy);border-radius:var(--r-md);padding:2rem;margin-bottom:2rem;position:relative;overflow:hidden}
.modal-testimonial::before{content:'"';position:absolute;top:-1rem;left:1.5rem;font-family:var(--f-serif);font-size:8rem;color:rgba(77,190,210,.1);line-height:1;pointer-events:none}
.modal-quote{font-size:1rem;color:rgba(255,255,255,.8);line-height:1.7;font-style:italic;font-family:var(--f-serif);position:relative;z-index:1;margin-bottom:.75rem}
.modal-author{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;color:var(--c-600);text-transform:uppercase;position:relative;z-index:1}
.modal-cta-row{display:flex;justify-content:flex-end;padding-top:1.25rem;border-top:1px solid var(--c-100)}

/* ══════════════════════════════════════════════════════
   SECCIÓN EQUIPO — Photo groupe grande + Adrianna à côté
══════════════════════════════════════════════════════ */
.estudio-equipo{padding:6rem 0;background:var(--c-50);position:relative}
.estudio-equipo::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--c-200),transparent)}
.estudio-equipo-header{margin-bottom:3rem}
.equipo-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;letter-spacing:-.04em;color:var(--c-navy);line-height:1.1;margin-top:.75rem}

/* 
  LAYOUT: Photo groupe (2/3) + Adrianna (1/3)
  Hiérarchie visuelle claire: la photo de groupe domine
*/
.equipo-layout{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:1.5rem;
  align-items:start;
}

/* ── PHOTO GRUPAL — Grand bloc principal ── */
.equipo-foto-grupo{
  background:var(--c-wh);border:1.5px solid var(--c-200);
  border-radius:var(--r-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:box-shadow .35s,border-color .25s;
  position:relative;
}
.equipo-foto-grupo:hover{box-shadow:var(--sh-lg);border-color:var(--c-sky)}

.foto-grupo-wrap{
  position:relative;overflow:hidden;
  /* Taller ratio for the group photo — more impactful */
  aspect-ratio:16/9;
  background:var(--c-800);
}
.foto-grupo-img{
  width:100%;height:100%;
  object-fit:cover;object-position:center center;
  display:block;transition:transform .5s var(--ease-smooth);
}
.equipo-foto-grupo:hover .foto-grupo-img{transform:scale(1.03)}

.foto-grupo-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:1.5rem 2rem;
  background:linear-gradient(to top,rgba(8,25,42,.92) 0%,rgba(8,25,42,.3) 60%,transparent 100%);
}
.foto-grupo-label{font-size:1.2rem;font-weight:700;color:var(--c-wh);letter-spacing:-.02em;margin-bottom:.25rem}
.foto-grupo-sub{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.14em;color:rgba(255,255,255,.45);text-transform:uppercase}

.foto-grupo-placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.75rem;padding:1.75rem;
  background:var(--c-50);border-top:1px dashed var(--c-300);
  color:var(--c-500);text-align:center;
}
.foto-grupo-placeholder p{font-size:.85rem;font-weight:600;color:var(--c-700)}
.foto-grupo-placeholder span{font-family:var(--f-mono);font-size:.62rem;color:var(--c-500);letter-spacing:.05em}
.foto-grupo-placeholder code{font-family:var(--f-mono);color:var(--c-turq);font-size:.65rem}
.foto-grupo-placeholder svg{color:var(--c-400)}

/* ── CARTE ADRIANNA — Colonne secondaire à droite ── */
.equipo-card-adrianna{
  background:var(--c-wh);border:1.5px solid var(--c-200);
  border-radius:var(--r-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:box-shadow .35s,border-color .25s;
  /* Match height with group photo via self-stretch */
  align-self:stretch;
}
.equipo-card-adrianna:hover{box-shadow:var(--sh-lg);border-color:var(--c-sky)}

.adrianna-photo-wrap{
  position:relative;overflow:hidden;
  /* Portrait ratio for the individual card */
  aspect-ratio:4/3;
  background:var(--c-800);
  flex-shrink:0;
}
.adrianna-photo{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  display:block;transition:transform .5s var(--ease-smooth);
}
.equipo-card-adrianna:hover .adrianna-photo{transform:scale(1.04)}
.adrianna-photo-tag{
  position:absolute;bottom:0;left:0;right:0;padding:.65rem 1rem;
  background:linear-gradient(to top,rgba(8,25,42,.88),transparent);
  font-family:var(--f-mono);font-size:.55rem;letter-spacing:.16em;color:var(--c-sky);text-transform:uppercase;
}
.adrianna-info{padding:1.35rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.adrianna-name{font-size:1.5rem;font-weight:800;letter-spacing:-.05em;color:var(--c-navy);line-height:1}
.adrianna-bio{font-size:.8rem;color:var(--c-600);line-height:1.75}
.adrianna-skills{display:flex;flex-wrap:wrap;gap:.35rem}
.adrianna-skills span{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.07em;color:var(--c-700);background:var(--c-100);border:1px solid var(--c-200);padding:.24rem .6rem;border-radius:6px;transition:border-color .2s,color .2s,background .2s}
.adrianna-skills span:hover{border-color:var(--c-turq);color:var(--c-teal);background:var(--c-foam)}
.adrianna-quote{
  margin:0;padding:.9rem 1.1rem;
  background:var(--c-navy);border-radius:var(--r-md);
  font-family:var(--f-serif);font-style:italic;font-size:.82rem;
  color:rgba(255,255,255,.78);line-height:1.6;
  border-left:3px solid var(--c-turq);
}

/* ── ESTUDIO ── */
.section-estudio{min-height:unset;display:block;overflow:visible}
.estudio-hero{min-height:65vh;position:relative;display:flex;align-items:center;background:var(--c-navy);overflow:hidden}
.estudio-hero-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 60% 70% at 80% 40%,rgba(46,136,153,.2),transparent),radial-gradient(ellipse 50% 60% at 20% 70%,rgba(10,50,87,.4),transparent),var(--c-navy)}
.estudio-hero-content{position:relative;z-index:2;padding:6rem 3rem 5rem;max-width:1240px;margin:0 auto;width:100%}
.estudio-hero-title{font-size:clamp(2.4rem,5.5vw,5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--c-wh);margin:.75rem 0 0;max-width:720px}
.estudio-hero-title em{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--c-sky)}
.estudio-hero-year{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.25em;color:var(--c-600);text-transform:uppercase;margin-top:1.5rem}
.estudio-story{padding:6rem 0;background:var(--c-wh)}
.estudio-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.estudio-p-large{font-size:1.2rem;font-weight:600;color:var(--c-navy);line-height:1.55;letter-spacing:-.01em;margin-bottom:1.5rem}
.estudio-p{font-size:.92rem;color:var(--c-600);line-height:1.85;margin-bottom:1rem}
.estudio-story-visual{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.estudio-photo-card{border-radius:var(--r-md);overflow:hidden;aspect-ratio:3/4}
.estudio-photo-1{margin-top:2.5rem}
.estudio-photo-2{margin-top:-2.5rem}
.ephoto-inner{width:100%;height:100%;position:relative;overflow:hidden;display:block}
.estudio-photo-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .5s var(--ease-smooth)}
.estudio-photo-card:hover .estudio-photo-img{transform:scale(1.03)}
.ephoto-label{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.25rem;background:linear-gradient(to top,rgba(8,25,42,.85),transparent);font-family:var(--f-mono);font-size:.58rem;letter-spacing:.18em;color:rgba(255,255,255,.5);text-transform:uppercase;z-index:2}
.estudio-stats-strip{background:var(--c-navy);padding:4rem 0}
.estudio-stats-row{display:grid;grid-template-columns:repeat(4,1fr)}
.es-stat{padding:1.5rem 2rem;border-right:1px solid rgba(255,255,255,.05);text-align:center}
.es-stat:last-child{border-right:none}
.es-num{font-size:2.8rem;font-weight:800;letter-spacing:-.05em;color:var(--c-wh);line-height:1;margin-bottom:.35rem}
.es-label{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.12em;color:var(--c-600);text-transform:uppercase}
.estudio-values{padding:5rem 0;background:var(--c-50)}
.estudio-values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:2rem}
.ev-card{padding:2rem 1.5rem;background:var(--c-wh);border:1px solid var(--c-200);border-radius:var(--r-md);transition:transform .3s var(--ease-out),box-shadow .25s,border-color .25s}
.ev-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  margin-bottom: 1rem;
  object-fit: contain;   /* contain = logo affiché en entier, sans crop */
  object-position: center;
  background: var(--c-100); /* fond neutre si image transparente */
  display: block;
  /* Évite un saut de layout si l'image tarde à charger */
  min-height: 60px;
}
.ev-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--c-sky)}
.ev-num{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.18em;color:var(--c-turq);margin-bottom:1rem}
.ev-title{font-size:.95rem;font-weight:700;color:var(--c-navy);margin-bottom:.6rem}
.ev-desc{font-size:.8rem;color:var(--c-500);line-height:1.7}
.estudio-tools-section{padding:5rem 0 6rem;background:var(--c-wh)}
.estudio-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem}
.tools-list{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.5rem}
.tool-tag{font-family:var(--f-mono);font-size:.7rem;color:var(--c-700);background:var(--c-50);border:1px solid var(--c-200);padding:.35rem .85rem;border-radius:6px;display:inline-block;transition:border-color .2s,color .2s,background .2s,transform .15s var(--ease-bounce);cursor:default}
.tool-tag:hover{border-color:var(--c-turq);color:var(--c-teal);background:var(--c-foam);transform:translateY(-2px)}
.estudio-location-card{margin-top:1.5rem;background:var(--c-50);border:1px solid var(--c-200);border-radius:var(--r-md);padding:2rem;display:flex;align-items:center;gap:1.5rem}
.elc-map{position:relative;width:56px;height:56px;flex-shrink:0}
.elc-map-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:var(--c-turq);border-radius:50%;box-shadow:0 0 0 4px rgba(77,190,210,.2)}
.elc-map-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(77,190,210,.3);animation:mapPulse 2.5s ease-out infinite}
@keyframes mapPulse{0%{transform:translate(-50%,-50%) scale(.4);opacity:1}100%{transform:translate(-50%,-50%) scale(1);opacity:0}}
.elc-city{font-size:1rem;font-weight:700;color:var(--c-navy);margin-bottom:.2rem}
.elc-country{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;color:var(--c-500);text-transform:uppercase;margin-bottom:.5rem}
.elc-remote{font-size:.8rem;color:var(--c-teal)}

/* ── CONTACT ── */
.section-contact{padding:8rem 0;flex-direction:column}
.contact-bg-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden;z-index:0}
.contact-bg-text span{font-size:clamp(8rem,22vw,18rem);font-weight:800;letter-spacing:-.06em;color:rgba(255,255,255,.018);white-space:nowrap}
.contact-layout{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start;position:relative;z-index:2}
.contact-title{font-size:clamp(2.5rem,5vw,4.2rem);font-weight:800;letter-spacing:-.05em;line-height:1.02;color:var(--c-wh);margin-top:1.5rem;margin-bottom:1.25rem}
.contact-sub{font-size:.87rem;color:var(--c-600);line-height:1.85;margin-bottom:2.5rem;font-family:var(--f-mono)}
.contact-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}
.contact-info-item{display:flex;align-items:center;gap:1rem;transition:opacity .2s}
.contact-info-item:hover{opacity:.75}
.ci-icon{width:42px;height:42px;background:rgba(255,255,255,.05);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.ci-label{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.12em;color:var(--c-600);text-transform:uppercase;margin-bottom:.15rem}
.ci-value{font-size:.88rem;color:var(--c-wh);font-weight:500}
.contact-socials{display:flex;gap:1.5rem}
.social-link{font-family:var(--f-mono);font-size:.63rem;letter-spacing:.12em;color:var(--c-600);text-transform:uppercase;transition:color .2s;position:relative}
.social-link::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--c-turq);transform:scaleX(0);transform-origin:left;transition:transform .2s var(--ease-smooth)}
.social-link:hover{color:var(--c-sky)}
.social-link:hover::after{transform:scaleX(1)}
.contact-form{display:flex;flex-direction:column;gap:1.15rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-label{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.14em;color:var(--c-600);text-transform:uppercase}
.form-input{background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.09);border-radius:var(--r-sm);padding:.85rem 1rem;font-family:var(--f-sans);font-size:.88rem;color:var(--c-wh);transition:border-color .2s,background .2s;width:100%;outline:none;appearance:none;-webkit-appearance:none}
.form-input::placeholder{color:rgba(255,255,255,.18)}
.form-input:focus{border-color:var(--c-turq);background:rgba(77,190,210,.05)}
.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,0.28)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-select option{background:var(--c-navy);color:var(--c-wh)}
.form-textarea{resize:vertical;min-height:108px}
.form-submit{display:flex;align-items:center;justify-content:center;gap:.75rem;background:var(--c-teal);color:var(--c-wh);font-size:.9rem;font-weight:700;padding:1rem 2rem;border-radius:var(--r-sm);transition:background .25s,transform .25s,box-shadow .25s}
.form-submit:hover{background:var(--c-mid);transform:translateY(-2px);box-shadow:0 8px 28px rgba(46,136,153,.35)}
.form-submit.loading{pointer-events:none;opacity:.7}
.form-success{display:none;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:rgba(40,200,64,.09);border:1px solid rgba(40,200,64,.2);border-radius:var(--r-sm);font-size:.85rem;color:#28C840}
.form-success.visible{display:flex}

/* ── FOOTER ── */
footer{background:var(--c-ink);border-top:1px solid rgba(255,255,255,.04);padding:2.5rem 3rem}
.footer-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}
.footer-logo{font-weight:800;font-size:.9rem;letter-spacing:.22em;color:var(--c-wh);margin-bottom:.2rem}
.footer-tagline{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.1em;color:var(--c-700);text-transform:uppercase}
.footer-links{display:flex;gap:1.75rem}
.footer-links a{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.09em;color:var(--c-700);text-transform:uppercase;transition:color .2s}
.footer-links a:hover{color:var(--c-turq)}
.footer-copy{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.05em;color:var(--c-700)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease-smooth),transform .8s var(--ease-smooth);will-change:opacity,transform}
.reveal.visible{opacity:1;transform:none;will-change:auto}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .process-layout{grid-template-columns:1fr;gap:3rem}
  .process-visual{position:static}
  .process-guarantees{grid-template-columns:repeat(2,1fr)}
  .estudio-values-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  /* Team: stack vertically on medium screens */
  .equipo-layout{grid-template-columns:1fr}
  .foto-grupo-wrap{aspect-ratio:16/8}
  .adrianna-photo-wrap{aspect-ratio:16/6;width:100%}
  .equipo-card-adrianna{flex-direction:row;align-items:stretch}
  .adrianna-photo-wrap{flex-shrink:0;width:260px;aspect-ratio:auto}
}

@media(max-width:900px){
  .contact-layout,.estudio-story-grid,.estudio-tools-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .project-featured,.project-wide{grid-column:1;grid-template-columns:1fr}
  .project-featured .project-visual,.project-wide .project-visual{min-height:220px}
  .modal-grid{grid-template-columns:1fr}
  .modal-gallery{grid-template-columns:1fr 1fr}
  .modal-gallery-item.wide{grid-column:span 2}
  .estudio-stats-row{grid-template-columns:repeat(2,1fr)}
}

/* ── MOBILE — Main breakpoint ── */
@media(max-width:768px){
  :root{--nav-h:66px}
  body{cursor:auto}
  #cursor,#cursor-dot,#scroll-progress{display:none}
  #main-nav{padding:0 1.25rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  .container{padding:0 1.25rem}

  /* ── HERO MOBILE — Corrected alignment & centering ── */
  .section-hero{
    min-height:100svh; /* use svh for mobile browsers */
    align-items:center;
  }
  .hero-content{
    padding:calc(var(--nav-h) + 3rem) 1.25rem 2.5rem;
    text-align:center;
    display:flex;
    flex-direction:column;
    align-items:center;
    width:100%;
    max-width:100%;
  }
  .hero-eyebrow{
    justify-content:center;
    margin-bottom:1.75rem;
  }
  .hero-title{
    font-size:clamp(2.6rem,10vw,4rem);
    text-align:center;
    width:100%;
    letter-spacing:-.04em;
    line-height:1;
    margin-bottom:1.5rem;
  }
  .hero-line{
    display:block;
    text-align:center;
    width:100%;
  }
  /* Disable hover letter-spacing on mobile */
  .hero-title:hover .hero-line:nth-child(1),
  .hero-title:hover .hero-line:nth-child(2),
  .hero-title:hover .hero-line:nth-child(3){
    letter-spacing:-.04em;
  }
  .hero-sub{
    font-size:.78rem;
    text-align:center;
    max-width:90%;
    margin-bottom:2rem;
  }
  .hero-actions{
    flex-direction:column;
    align-items:center;
    width:100%;
    gap:.75rem;
  }
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost{
    width:100%;
    justify-content:center;
    max-width:280px;
  }
  /* Stats below hero on mobile */
  .hero-stats{
    position:static;
    margin-top:0;
    border-top:1px solid rgba(255,255,255,.07);
    flex-direction:row;
  }
  .hero-stat{
    padding:1rem;
    flex:1;
    text-align:center;
    border-right:1px solid rgba(255,255,255,.05);
  }
  .hero-stat:last-child{border-right:none}
  .stat-num{font-size:1.4rem}
  .stat-label{font-size:.5rem}
  .scroll-hint{display:none}

  /* Services */
  .section-alt,.section-dark,.section-light,.section-contact{padding:4.5rem 0}
  .services-grid,.process-guarantees{grid-template-columns:1fr}

  /* Equipo — fully stacked on mobile */
  .equipo-layout{grid-template-columns:1fr}
  .equipo-card-adrianna{flex-direction:column}
  .adrianna-photo-wrap{width:100%;aspect-ratio:4/3}
  .foto-grupo-wrap{aspect-ratio:4/3}

  /* Estudio */
  .estudio-hero-content{padding:4.5rem 1.25rem 4rem}
  .estudio-story,.estudio-values,.estudio-tools-section,.estudio-equipo{padding:3.5rem 0}

  /* Forms */
  .form-row{grid-template-columns:1fr}

  /* Modal */
  .modal-content{padding:1.25rem}
  .modal-gallery{grid-template-columns:1fr}
  .modal-gallery-item.wide{grid-column:1}

  /* Footer */
  footer{padding:2rem 1.25rem}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:1rem}
  .footer-links{flex-wrap:wrap;gap:1rem}

  /* Contact */
  .contact-bg-text{display:none}

  /* Portfolio */
  .portfolio-header{padding:.75rem 1.25rem}
  .portfolio-results-bar{padding:.5rem 1.25rem}
  .portfolio-body{padding:2rem 1.25rem 5rem}
  .portfolio-grid{grid-template-columns:1fr}
  .portfolio-item.wide,.portfolio-item.tall{grid-column:1;grid-row:auto}

  /* Nav logo compact on mobile */
  .nav-logo-img-wrap{width:32px;height:32px}
  .logo-text{font-size:.78rem;letter-spacing:.2em}
}

@media(max-width:480px){
  .section-title{font-size:1.75rem}
  .hero-title{font-size:clamp(2.2rem,9vw,3rem)}
  .estudio-values-grid{grid-template-columns:1fr}
  .estudio-stats-row{grid-template-columns:1fr 1fr}
  .equipo-title{font-size:1.6rem}
  .hero-stat{padding:.75rem .5rem}
  .stat-num{font-size:1.2rem}
}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero-line{opacity:1!important;transform:none!important;filter:none!important}
  .hero-eyebrow,.hero-sub,.hero-actions,.hero-stats,.scroll-hint{opacity:1!important;transform:none!important}
}

.project-card {
  width: 100%;
  height: auto;       /* ← était 300px → casse le layout featured */
  overflow: hidden;
}
.project-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
 
/* project-visual garde son aspect-ratio naturel */
.project-featured .project-visual,
.project-wide .project-visual {
  min-height: 240px;
}
 
/* Sur mobile, les cartes featured passent en colonne */
@media (max-width: 768px) {
  .project-featured,
  .project-wide {
    grid-column: 1;
    grid-template-columns: 1fr;   /* empile image + info */
    display: flex;
    flex-direction: column;
  }
  .project-featured .project-visual,
  .project-wide .project-visual {
    width: 100%;
    min-height: 200px;
    aspect-ratio: 16 / 9;
  }
  .project-featured .project-info,
  .project-wide .project-info {
    padding: 1.25rem;
  }
  .projects-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}


/* ══════════════════════════════════════════════════════════════
   SOUS-FILTRES DISEÑO — patch à ajouter à la fin de style.css
   ══════════════════════════════════════════════════════════════ */

/* ── Conteneur de la barre de sous-filtres ── */
.subfilter-bar {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;

  /* État initial : masqué et replié */
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  margin-bottom: 0;
  pointer-events: none;

  /* Transition d'apparition fluide */
  transition:
    max-height .42s cubic-bezier(0.16,1,0.3,1),
    opacity    .35s cubic-bezier(0.16,1,0.3,1),
    margin-bottom .35s cubic-bezier(0.16,1,0.3,1);
}

/* ── État visible (classe ajoutée par JS) ── */
.subfilter-bar.visible {
  max-height: 120px;   /* assez grand pour 2 lignes sur mobile */
  opacity: 1;
  margin-bottom: 1.5rem;
  pointer-events: auto;
}

/* ── Label "Tipo:" ── */
.subfilter-label {
  font-family: var(--f-mono);
  font-size: .6rem;
  letter-spacing: .18em;
  color: var(--c-400);
  text-transform: uppercase;
  white-space: nowrap;
  padding-right: .25rem;
  /* Petite ligne de séparation à droite */
  border-right: 1px solid var(--c-200);
  margin-right: .1rem;
  padding-right: .65rem;
}

/* ── Boutons de sous-filtre ── */
.subfilter-btn {
  font-family: var(--f-mono);
  font-size: .62rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .38rem 1rem;

  /* Aspect visuel distinct des filtres principaux (bords arrondis plus petits) */
  border: 1.5px solid var(--c-turq);
  border-radius: 5px;
  color: var(--c-teal);
  background: transparent;
  cursor: pointer;

  transition:
    border-color .2s,
    color        .2s,
    background   .2s,
    transform    .15s cubic-bezier(0.34,1.56,0.64,1);

  /* Apparition en cascade gérée par JS via style.animationDelay */
  animation: subfilterIn .35s cubic-bezier(0.34,1.56,0.64,1) both;
}

@keyframes subfilterIn {
  from { opacity: 0; transform: translateY(6px) scale(.92); }
  to   { opacity: 1; transform: none; }
}

.subfilter-btn:hover {
  background: var(--c-foam);
  transform: translateY(-1px);
}

.subfilter-btn.active {
  background: var(--c-teal);
  border-color: var(--c-teal);
  color: var(--c-wh);
  box-shadow: 0 2px 12px rgba(46,136,153,.3);
}

/* ── Séparateur visuel entre filtres principaux et sous-filtres ── */
.filters-stack {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 3rem;
}

/* Quand la barre principale est dans filters-stack, on retire son margin-bottom */
.filters-stack .projects-filters {
  margin-bottom: .85rem;
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .subfilter-label {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--c-200);
    padding-bottom: .4rem;
    padding-right: 0;
    margin-right: 0;
    margin-bottom: .1rem;
  }

  .subfilter-bar.visible {
    max-height: 180px; /* plus grand pour permettre le retour à la ligne */
  }

  .subfilter-btn {
    font-size: .58rem;
    padding: .32rem .8rem;
  }
}

/* ══════════════════════════════════════════════════════════════
   SOUS-FILTRES — Diseño & Interiorismo (et toute future catégorie)
   patch à ajouter à la fin de style.css
   ══════════════════════════════════════════════════════════════ */

/* ── Conteneur de la barre de sous-filtres ── */
.subfilter-bar {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;

  /* État initial : masqué et replié */
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  margin-bottom: 0;
  pointer-events: none;

  transition:
    max-height .42s cubic-bezier(0.16,1,0.3,1),
    opacity    .35s cubic-bezier(0.16,1,0.3,1),
    margin-bottom .35s cubic-bezier(0.16,1,0.3,1);
}

/* ── État visible ── */
.subfilter-bar.visible {
  max-height: 160px;   /* assez grand pour 2 lignes avec 8 boutons */
  opacity: 1;
  margin-bottom: 1.5rem;
  pointer-events: auto;
}

/* ── Label "Tipo:" ── */
.subfilter-label {
  font-family: var(--f-mono);
  font-size: .6rem;
  letter-spacing: .18em;
  color: var(--c-400);
  text-transform: uppercase;
  white-space: nowrap;
  border-right: 1px solid var(--c-200);
  padding-right: .65rem;
  margin-right: .1rem;
  flex-shrink: 0;
}

/* ── Boutons de sous-filtre ── */
.subfilter-btn {
  font-family: var(--f-mono);
  font-size: .62rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .38rem 1rem;
  border: 1.5px solid var(--c-turq);
  border-radius: 5px;
  color: var(--c-teal);
  background: transparent;
  cursor: pointer;
  white-space: nowrap;

  transition:
    border-color .2s,
    color        .2s,
    background   .2s,
    transform    .15s cubic-bezier(0.34,1.56,0.64,1);

  animation: subfilterIn .35s cubic-bezier(0.34,1.56,0.64,1) both;
}

@keyframes subfilterIn {
  from { opacity: 0; transform: translateY(6px) scale(.92); }
  to   { opacity: 1; transform: none; }
}

.subfilter-btn:hover {
  background: var(--c-foam);
  transform: translateY(-1px);
}

.subfilter-btn.active {
  background: var(--c-teal);
  border-color: var(--c-teal);
  color: var(--c-wh);
  box-shadow: 0 2px 12px rgba(46,136,153,.3);
}

/* ── Stack : espace entre filtres principaux et barre ── */
.filters-stack {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 3rem;
}

.filters-stack .projects-filters {
  margin-bottom: .85rem;
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .subfilter-label {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--c-200);
    padding-right: 0;
    padding-bottom: .4rem;
    margin-right: 0;
    margin-bottom: .25rem;
  }

  .subfilter-bar.visible {
    max-height: 240px; /* plus grand pour 8 boutons sur 3 lignes */
  }

  .subfilter-btn {
    font-size: .56rem;
    padding: .3rem .7rem;
    letter-spacing: .08em;
  }
}

/* La barre de sous-filtres du portfolio vit dans .portfolio-body,
   pas dans le header — on lui donne un vrai rendu */
#portfolio-subfilter-bar {
  max-width: 1240px;
  margin: 0 auto 1.5rem;
  padding: 0 0 0 0;
}
 
/* Hauteur suffisante pour 8 boutons sur 2-3 lignes */
#portfolio-subfilter-bar.visible {
  max-height: 240px;
}
 
/* Sur mobile, les boutons peuvent passer sur 3 lignes */
@media (max-width: 768px) {
  #portfolio-subfilter-bar.visible {
    max-height: 300px;
  }
  #portfolio-subfilter-bar .subfilter-btn {
    font-size: .54rem;
    padding: .28rem .65rem;
    letter-spacing: .07em;
  }
  #portfolio-subfilter-bar .subfilter-label {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--c-200);
    padding-right: 0;
    padding-bottom: .4rem;
    margin-bottom: .2rem;
  }
}
 
/* La barre principale de sous-filtres (page projets)
   hérite déjà des règles existantes — on s'assure juste
   qu'elle est bien visible à toutes les tailles */
.subfilter-bar.visible {
  max-height: 240px;
}
 
@media (max-width: 480px) {
  .subfilter-bar.visible {
    max-height: 320px;
  }
}

/* ── Grille projets principale — cartes uniformes ── */
.projects-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}
.projects-grid .project-card {
  display: flex;
  flex-direction: column;
  height: auto;
}
.projects-grid .project-card .project-visual {
  aspect-ratio: 16 / 9;
  min-height: unset;
  width: 100%;
}
.projects-grid .project-card .project-info {
  padding: 1.5rem;
  justify-content: flex-start;
}
.projects-grid .project-card .project-name {
  font-size: 1.12rem;
}
@media (max-width: 768px) {
  .projects-grid {
    grid-template-columns: 1fr;
  }
}

/* ── Galerie modal — pas de cadres vides ── */
.modal-gallery {
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

.modal-gallery-item:empty {
  display: none;
}