
/* Nova Peinture V4.4 — Premium clair / architectural */
:root{
  --np-demo-h:38px;
  --np-max:1180px;
  --np-bg:#f5f0e7;
  --np-bg-soft:#ebe3d7;
  --np-paper:#fffaf1;
  --np-paper-2:#f8f3ea;
  --np-ink:#20231f;
  --np-soft:#62685d;
  --np-muted:#888d82;
  --np-line:rgba(32,35,31,.11);
  --np-line-2:rgba(32,35,31,.18);
  --np-sage:#7f9788;
  --np-sage-dark:#4d6157;
  --np-clay:#b69d7d;
  --np-graphite:#151b17;
  --np-cream:#fffaf1;
  --np-shadow:0 24px 60px -42px rgba(32,35,31,.62);
  --np-shadow-strong:0 48px 120px -62px rgba(32,35,31,.85);
  --np-radius:28px;
  --np-radius-lg:42px;
  --np-ease:cubic-bezier(.16,1,.3,1);
  color-scheme:light;
}
[data-theme="dark"]{
  --np-bg:#111611;
  --np-bg-soft:#171d18;
  --np-paper:#1d241f;
  --np-paper-2:#151b17;
  --np-ink:#fffaf1;
  --np-soft:rgba(255,250,241,.72);
  --np-muted:rgba(255,250,241,.48);
  --np-line:rgba(255,250,241,.12);
  --np-line-2:rgba(255,250,241,.20);
  --np-sage:#98ad9d;
  --np-sage-dark:#c6d4c6;
  --np-clay:#dfc59f;
  --np-graphite:#080d09;
  --np-cream:#fffaf1;
  --np-shadow:0 28px 70px -42px rgba(0,0,0,.9);
  --np-shadow-strong:0 50px 130px -60px rgba(0,0,0,.96);
  color-scheme:dark;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--np-ink);background:radial-gradient(circle at 12% 0,rgba(127,151,136,.16),transparent 34rem),linear-gradient(180deg,var(--np-bg) 0%,var(--np-bg-soft) 100%);overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .4s var(--np-ease),color .4s var(--np-ease)}
body:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.14;background-image:linear-gradient(rgba(32,35,31,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(32,35,31,.04) 1px,transparent 1px);background-size:88px 88px;mask-image:linear-gradient(to bottom,#000,transparent 78%)}
[data-theme="dark"] body:before{opacity:.10;background-image:linear-gradient(rgba(255,250,241,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,250,241,.035) 1px,transparent 1px)}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input,textarea,select{font:inherit}.np-wrap{width:min(calc(100% - 36px),var(--np-max));margin-inline:auto}.np-page{min-height:100svh}.np-sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.np-demo-bar{position:fixed;inset:0 0 auto 0;height:var(--np-demo-h);z-index:500;display:flex;align-items:center;justify-content:center;gap:18px;padding:0 14px;background:var(--np-graphite);color:rgba(255,250,241,.72);border-bottom:1px solid rgba(242,221,189,.28);font-size:12.5px;white-space:nowrap}.np-demo-bar b{color:#f2ddbd}.np-demo-bar a{display:inline-flex;align-items:center;gap:7px;min-height:24px;padding:4px 12px;border-radius:999px;background:#f2ddbd;color:#1b1b18;font-weight:800}.np-demo-bar svg{width:14px;height:14px}
.np-header{position:fixed;top:var(--np-demo-h);left:0;right:0;z-index:420;transition:background .3s var(--np-ease),box-shadow .3s var(--np-ease),padding .3s var(--np-ease);padding:18px 0}.np-header.is-stuck,.np-header.is-open{background:color-mix(in srgb,var(--np-paper) 84%,transparent);backdrop-filter:blur(18px);box-shadow:0 14px 46px -32px rgba(0,0,0,.55)}.np-nav{display:flex;align-items:center;justify-content:space-between;gap:20px}.np-logo{display:inline-flex;align-items:center;gap:12px;min-width:max-content}.np-logo img{width:190px;height:auto}.np-links{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0}.np-links a{font-size:14px;color:var(--np-soft);position:relative}.np-links a:after{content:"";position:absolute;left:0;right:100%;bottom:-8px;height:1px;background:var(--np-sage-dark);transition:right .25s var(--np-ease)}.np-links a:hover,.np-links a.is-active{color:var(--np-ink)}.np-links a:hover:after{right:0}.np-actions{display:flex;align-items:center;gap:10px}.np-lang{display:flex;align-items:center;gap:2px}.np-lang a{font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--np-muted);padding:7px 8px;border-radius:999px}.np-lang a:hover,.np-lang a[aria-current="page"]{color:var(--np-ink);background:rgba(127,151,136,.16)}
.np-theme{width:44px;height:44px;border:1px solid var(--np-line-2);border-radius:999px;background:color-mix(in srgb,var(--np-paper) 70%,transparent);color:var(--np-ink);display:grid;place-items:center;cursor:pointer;transition:transform .22s,border-color .22s}.np-theme:hover{transform:translateY(-2px);border-color:var(--np-sage-dark)}.np-theme svg{width:18px;height:18px}.np-theme .moon{display:none}[data-theme="dark"] .np-theme .sun{display:none}[data-theme="dark"] .np-theme .moon{display:block}
.np-burger{display:none;width:44px;height:44px;border:1px solid var(--np-line-2);border-radius:999px;background:color-mix(in srgb,var(--np-paper) 70%,transparent);color:var(--np-ink);cursor:pointer}.np-burger span{display:block;width:18px;height:2px;margin:4px auto;background:currentColor;border-radius:4px}.np-mobile{position:fixed;top:calc(var(--np-demo-h) + 12px);right:12px;left:12px;z-index:410;background:var(--np-paper);border:1px solid var(--np-line);border-radius:28px;box-shadow:var(--np-shadow-strong);padding:86px 24px 24px;transform:translateY(-120%);opacity:0;visibility:hidden;transition:transform .38s var(--np-ease),opacity .25s var(--np-ease),visibility .25s}.np-mobile.is-open{transform:translateY(0);opacity:1;visibility:visible}.np-mobile a{display:block;padding:14px 0;border-bottom:1px solid var(--np-line);font-family:"Cormorant Garamond",serif;font-size:28px;line-height:1.05}.np-mobile .np-lang-mobile{display:flex;gap:8px;margin:10px 0 18px}.np-mobile .np-lang-mobile a{font-family:Inter,sans-serif;font-size:13px;border:1px solid var(--np-line);padding:8px 12px;border-radius:999px}.np-mobile .np-mobile-cta{margin-top:18px}
.np-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:46px;border:1px solid transparent;border-radius:999px;padding:12px 20px;background:var(--np-graphite);color:#fffaf1;font-weight:800;font-size:14px;letter-spacing:.01em;cursor:pointer;transition:transform .22s var(--np-ease),box-shadow .22s var(--np-ease),background .22s,border-color .22s}.np-btn svg{width:17px;height:17px}.np-btn:hover{transform:translateY(-2px);box-shadow:0 18px 38px -22px rgba(32,35,31,.75)}.np-btn--ghost{background:color-mix(in srgb,var(--np-paper) 55%,transparent);color:var(--np-ink);border-color:var(--np-line-2)}.np-btn--ghost:hover{border-color:rgba(127,151,136,.62);background:var(--np-paper)}.np-btn--sage{background:var(--np-sage-dark);color:#fffaf1}[data-theme="dark"] .np-btn--sage{color:#111611;background:#f2ddbd}:focus-visible{outline:3px solid rgba(127,151,136,.62);outline-offset:4px;border-radius:8px}
.np-hero{position:relative;min-height:100svh;padding:calc(var(--np-demo-h) + 118px) 0 68px;display:grid;align-items:center;overflow:hidden}.np-hero:before{content:"";position:absolute;left:0;right:0;bottom:0;height:30%;background:linear-gradient(to top,var(--np-bg-soft),transparent);pointer-events:none}.np-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,.82fr) minmax(480px,1.18fr);gap:clamp(38px,6vw,78px);align-items:center}.np-kicker{display:inline-flex;align-items:center;gap:12px;color:var(--np-sage-dark);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.18em}.np-kicker:before{content:"";width:34px;height:1px;background:currentColor}.np-hero h1,.np-section-title,.np-large-title{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;letter-spacing:-.045em}.np-hero h1{font-size:clamp(58px,8vw,112px);line-height:.84;margin:22px 0 0;max-width:830px;text-wrap:balance}.np-hero h1 em{font-style:italic;color:var(--np-sage-dark);font-weight:500}.np-lead{max-width:650px;margin:28px 0 0;color:var(--np-soft);font-size:clamp(17px,2vw,20px);line-height:1.75}.np-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}.np-hero-proof{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}.np-proof-chip{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:7px 12px;border:1px solid var(--np-line);border-radius:999px;background:color-mix(in srgb,var(--np-paper) 64%,transparent);color:var(--np-soft);font-size:13px}.np-proof-chip svg{width:15px;height:15px;color:var(--np-sage-dark)}
.np-hero-visual{position:relative;min-height:600px}.np-hero-frame{position:absolute;inset:0;border-radius:36px;overflow:hidden;box-shadow:var(--np-shadow-strong);border:1px solid rgba(255,255,255,.5);background:#ddd}.np-hero-frame img{width:100%;height:100%;object-fit:cover;transform:scale(1.03);transition:transform .4s var(--np-ease)}.np-hero-card{position:absolute;left:22px;bottom:22px;width:min(340px,80%);padding:24px 26px;border-radius:26px;background:color-mix(in srgb,var(--np-paper) 84%,transparent);backdrop-filter:blur(20px) saturate(1.2);border:1px solid rgba(255,255,255,.5);box-shadow:0 30px 70px -38px rgba(42,37,29,.7)}.np-hero-card-eyebrow{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.18em;font-weight:900;color:var(--np-sage-dark);margin-bottom:8px}.np-hero-card b{display:block;font-family:"Cormorant Garamond",serif;font-size:34px;line-height:.98}.np-hero-card p{margin:9px 0 0;color:var(--np-soft);font-size:14px;line-height:1.55}.np-swatch-stack{position:absolute;right:22px;top:22px;display:flex;flex-direction:column;gap:9px}.np-swatch-stack span{width:48px;height:48px;border-radius:16px;border:4px solid color-mix(in srgb,var(--np-paper) 88%,transparent);box-shadow:0 14px 32px -18px rgba(0,0,0,.55)}.np-swatch-stack span:nth-child(1){background:#ede8df}.np-swatch-stack span:nth-child(2){background:#8b9f91}.np-swatch-stack span:nth-child(3){background:#2e3430}
.np-section{position:relative;padding:clamp(70px,9vw,108px) 0}.np-section--paper{background:color-mix(in srgb,var(--np-paper) 50%,transparent);border-block:1px solid var(--np-line)}.np-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:34px;margin-bottom:clamp(34px,5vw,56px)}.np-section-head .np-kicker{margin-bottom:14px}.np-section-title{font-size:clamp(40px,5.6vw,76px);line-height:.92;margin:0;max-width:790px}.np-section-head p{max-width:440px;color:var(--np-soft);line-height:1.72;margin:0}.np-trust-strip{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--np-line);border-radius:30px;overflow:hidden;background:color-mix(in srgb,var(--np-paper) 68%,transparent);box-shadow:var(--np-shadow);margin-top:-32px;position:relative;z-index:3}.np-trust-item{padding:24px 25px;border-right:1px solid var(--np-line)}.np-trust-item:last-child{border-right:0}.np-trust-item small{display:block;color:var(--np-sage-dark);font-weight:900;text-transform:uppercase;letter-spacing:.15em;font-size:11px}.np-trust-item b{display:block;font-family:"Cormorant Garamond",serif;font-size:32px;line-height:1;margin-top:9px}.np-trust-item p{color:var(--np-soft);margin:9px 0 0;line-height:1.55;font-size:14px}
.np-editorial{display:grid;grid-template-columns:.72fr 1.28fr;gap:22px;align-items:stretch}.np-editorial-card{border-radius:var(--np-radius-lg);background:var(--np-graphite);color:#fffaf1;padding:clamp(30px,4vw,48px);min-height:0;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative}.np-editorial-card:after{content:"";position:absolute;right:-100px;bottom:-130px;width:360px;height:360px;border-radius:50%;background:rgba(127,151,136,.26)}.np-editorial-card h2{font-family:"Cormorant Garamond",serif;font-size:clamp(30px,2.8vw,44px);line-height:.98;letter-spacing:-.03em;margin:0;position:relative;z-index:1}.np-editorial-card p{color:rgba(255,250,241,.72);line-height:1.75;position:relative;z-index:1}.np-editorial-photo{border-radius:var(--np-radius-lg);overflow:hidden;box-shadow:var(--np-shadow-strong);min-height:0;position:relative}.np-editorial-photo img{width:100%;height:100%;object-fit:cover}.np-editorial-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.10),transparent 38%,rgba(0,0,0,.05))}.np-feature-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}.np-feature{padding:18px;border:1px solid var(--np-line);border-radius:24px;background:color-mix(in srgb,var(--np-paper) 58%,transparent)}.np-feature b{display:block;font-family:"Cormorant Garamond",serif;font-size:28px;line-height:1}.np-feature span{display:block;color:var(--np-soft);font-size:13px;line-height:1.55;margin-top:6px}
.np-services-layout{display:grid;grid-template-columns:.95fr 1.35fr;gap:20px;align-items:stretch}.np-service-feature{border-radius:36px;overflow:hidden;background:var(--np-graphite);color:#fffaf1;min-height:620px;position:sticky;top:112px;box-shadow:var(--np-shadow)}.np-service-feature img{width:100%;height:48%;object-fit:cover}.np-service-feature div{padding:30px}.np-service-feature h3{font-family:"Cormorant Garamond",serif;font-size:46px;line-height:.95;margin:0 0 12px}.np-service-feature p{color:rgba(255,250,241,.72);line-height:1.72}.np-services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.np-service-card{position:relative;isolation:isolate;min-height:290px;padding:24px;border-radius:30px;background:color-mix(in srgb,var(--np-paper) 70%,transparent);border:1px solid var(--np-line);overflow:hidden;transition:transform .28s var(--np-ease),box-shadow .28s var(--np-ease),border-color .28s}.np-service-card:before{content:"";position:absolute;inset:-1px;z-index:-1;background:radial-gradient(420px circle at var(--x,50%) var(--y,50%),rgba(127,151,136,.30),transparent 42%);opacity:0;transition:opacity .25s}.np-service-card:hover{transform:translateY(-6px);box-shadow:var(--np-shadow);border-color:rgba(127,151,136,.38)}.np-service-card:hover:before{opacity:1}.np-service-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.np-service-num{font-family:"Cormorant Garamond",serif;font-size:46px;line-height:.75;color:color-mix(in srgb,var(--np-sage-dark) 42%,transparent)}.np-service-swatch{width:74px;height:42px;border-radius:999px;border:6px solid color-mix(in srgb,var(--np-paper) 85%,transparent);box-shadow:0 12px 24px -18px rgba(0,0,0,.42)}.np-service-card h3{font-family:"Cormorant Garamond",serif;font-size:34px;line-height:1;margin:42px 0 12px;letter-spacing:-.03em}.np-service-card p{color:var(--np-soft);line-height:1.65;margin:0}.np-service-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}.np-service-meta span{font-size:12px;color:var(--np-sage-dark);font-weight:800;border:1px solid rgba(127,151,136,.28);border-radius:999px;padding:6px 10px;background:rgba(127,151,136,.08)}
.np-materials{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:stretch}.np-material-card{border-radius:36px;background:color-mix(in srgb,var(--np-paper) 66%,transparent);border:1px solid var(--np-line);padding:30px;display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}.np-material-card img{border-radius:26px;width:100%;height:100%;min-height:300px;object-fit:cover;box-shadow:var(--np-shadow)}.np-material-card h2{font-family:"Cormorant Garamond",serif;font-size:clamp(42px,5vw,70px);line-height:.92;margin:0 0 16px}.np-material-card p{color:var(--np-soft);line-height:1.75}.np-mini-grid{display:grid;gap:14px}.np-mini-card{border-radius:28px;border:1px solid var(--np-line);background:color-mix(in srgb,var(--np-paper) 62%,transparent);padding:22px}.np-mini-card b{font-family:"Cormorant Garamond",serif;font-size:32px;line-height:1}.np-mini-card span{display:block;margin-top:7px;color:var(--np-soft);line-height:1.55}
.np-compare-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:center}.np-ba{position:relative;aspect-ratio:16/10;border-radius:40px;overflow:hidden;box-shadow:var(--np-shadow-strong);border:1px solid rgba(255,255,255,.38);background:#ddd;user-select:none}.np-ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.np-ba .after{z-index:1}.np-ba .before{z-index:2;clip-path:inset(0 50% 0 0)}.np-ba-handle{position:absolute;z-index:4;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 0 1px rgba(32,35,31,.18)}.np-ba-handle:after{content:"";position:absolute;top:50%;left:50%;width:52px;height:52px;border-radius:50%;transform:translate(-50%,-50%);background:var(--np-graphite);box-shadow:0 18px 38px -20px rgba(0,0,0,.7)}.np-ba-range{position:absolute;z-index:5;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize}.np-ba-label{position:absolute;z-index:6;top:18px;padding:8px 13px;border-radius:999px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;background:rgba(255,253,248,.86);backdrop-filter:blur(12px);color:#20231f}.np-ba-label.before-l{left:18px}.np-ba-label.after-l{right:18px;background:rgba(32,35,31,.84);color:#fffaf1}.np-compare-copy{padding:12px}.np-compare-copy h2{font-family:"Cormorant Garamond",serif;font-size:clamp(42px,5vw,72px);line-height:.92;margin:0 0 20px;letter-spacing:-.04em}.np-compare-copy p{color:var(--np-soft);line-height:1.74}.np-check-list{display:grid;gap:12px;margin-top:24px}.np-check{display:flex;gap:12px;align-items:flex-start;color:var(--np-soft)}.np-check svg{width:20px;height:20px;color:var(--np-sage-dark);flex:none;margin-top:2px}
.np-gallery{display:grid;grid-template-columns:1.1fr .9fr .9fr;grid-auto-rows:230px;gap:18px}.np-project{position:relative;overflow:hidden;border-radius:30px;background:#ddd;box-shadow:var(--np-shadow);border:1px solid rgba(255,255,255,.38)}.np-project:first-child{grid-row:span 2}.np-project:nth-child(4){grid-column:span 2}.np-project img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--np-ease)}.np-project:hover img{transform:scale(1.045)}.np-project figcaption{position:absolute;left:16px;right:16px;bottom:16px;padding:15px 17px;border-radius:22px;background:rgba(255,253,248,.82);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.55);color:#20231f}.np-project b{display:block;font-family:"Cormorant Garamond",serif;font-size:26px;line-height:1}.np-project span{display:block;margin-top:5px;color:#62685d;font-size:13px}.np-proof-wall{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}.np-proof-card{border:1px solid var(--np-line);border-radius:28px;background:color-mix(in srgb,var(--np-paper) 64%,transparent);padding:24px}.np-proof-card b{font-family:"Cormorant Garamond",serif;font-size:32px}.np-proof-card p{color:var(--np-soft);line-height:1.65;margin:8px 0 0}
.np-process{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.np-step{position:relative;padding:26px;border:1px solid var(--np-line);border-radius:28px;background:color-mix(in srgb,var(--np-paper) 56%,transparent);min-height:250px}.np-step:before{content:"";position:absolute;left:26px;right:26px;top:76px;height:1px;background:linear-gradient(90deg,var(--np-sage-dark),transparent)}.np-step-num{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:var(--np-graphite);color:#fffaf1;font-family:"Cormorant Garamond",serif;font-size:28px}.np-step h3{font-family:"Cormorant Garamond",serif;font-size:31px;line-height:1;margin:54px 0 10px}.np-step p{color:var(--np-soft);line-height:1.62;margin:0}
.np-objections{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:stretch}.np-objections-photo{border-radius:var(--np-radius-lg);overflow:hidden;min-height:570px;box-shadow:var(--np-shadow-strong);position:relative}.np-objections-photo img{width:100%;height:100%;object-fit:cover}.np-objections-note{position:absolute;left:20px;right:20px;bottom:20px;padding:18px;border-radius:24px;background:rgba(21,27,23,.80);color:#fffaf1;backdrop-filter:blur(12px)}.np-objections-note b{font-family:"Cormorant Garamond",serif;font-size:32px}.np-objections-note p{color:rgba(255,250,241,.72);line-height:1.55;margin:6px 0 0}.np-accordion{display:grid;gap:12px}.np-faq-item{border:1px solid var(--np-line);border-radius:22px;background:color-mix(in srgb,var(--np-paper) 62%,transparent);overflow:hidden}.np-faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;text-align:left;border:0;background:transparent;color:var(--np-ink);padding:20px 22px;cursor:pointer;font-weight:900}.np-faq-q span{font-family:"Cormorant Garamond",serif;font-size:27px;font-weight:600;letter-spacing:-.02em}.np-faq-q svg{width:18px;height:18px;transition:transform .25s}.np-faq-item.is-open .np-faq-q svg{transform:rotate(45deg)}.np-faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--np-ease)}.np-faq-a p{padding:0 22px 22px;margin:0;color:var(--np-soft);line-height:1.72}
.np-contact-panel{display:grid;grid-template-columns:.86fr 1.14fr;gap:28px;padding:clamp(24px,4vw,38px);border-radius:44px;background:var(--np-graphite);color:#fffaf1;box-shadow:var(--np-shadow-strong);overflow:hidden}.np-contact-copy{padding:clamp(8px,3vw,26px)}.np-contact-copy h2{font-family:"Cormorant Garamond",serif;font-size:clamp(45px,5.4vw,78px);line-height:.92;letter-spacing:-.04em;margin:0 0 20px}.np-contact-copy p{color:rgba(255,250,241,.72);line-height:1.75}.np-contact-list{display:grid;gap:12px;margin-top:24px;color:rgba(255,250,241,.78)}.np-contact-list a{color:#fffaf1}.np-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;background:rgba(255,250,241,.08);border:1px solid rgba(255,255,255,.12);border-radius:32px;padding:20px}.np-field{display:grid;gap:7px}.np-field.full{grid-column:1/-1}.np-field label{font-size:12px;text-transform:uppercase;letter-spacing:.13em;color:rgba(255,250,241,.56);font-weight:900}.np-field input,.np-field textarea,.np-field select{width:100%;border:1px solid rgba(255,255,255,.13);background:rgba(255,250,241,.08);color:#fffaf1;border-radius:16px;padding:13px 14px;outline:none}.np-field textarea{min-height:118px;resize:vertical}.np-field input:focus,.np-field textarea:focus,.np-field select:focus{border-color:rgba(242,221,189,.65);box-shadow:0 0 0 4px rgba(242,221,189,.09)}.np-form .np-btn{grid-column:1/-1;background:#f2ddbd;color:#1b1b18}.np-form-note{grid-column:1/-1;color:rgba(255,250,241,.56);font-size:12px}.np-form-status{grid-column:1/-1;display:none;padding:12px 14px;border-radius:16px;background:rgba(127,151,136,.2);border:1px solid rgba(127,151,136,.42);color:#f8fff7}.np-form-status.is-visible{display:block}
.np-footer{padding:46px 0 34px;background:#111611;color:rgba(255,250,241,.66)}.np-footer-grid{display:grid;grid-template-columns:1.2fr repeat(3,.7fr);gap:28px}.np-footer img{width:150px;filter:brightness(0) invert(1) sepia(.1);opacity:.92}.np-footer p{line-height:1.72}.np-footer h3{color:#fffaf1;font-size:14px;text-transform:uppercase;letter-spacing:.14em}.np-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}.np-footer a:hover{color:#f2ddbd}.np-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:34px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);font-size:13px}
.np-reveal{opacity:1;transform:none}.np-js .np-reveal{opacity:0;transform:translateY(24px);transition:opacity .72s var(--np-ease),transform .72s var(--np-ease)}.np-js .np-reveal.is-in{opacity:1;transform:none}.np-mask img{transition:transform .8s var(--np-ease),filter .8s var(--np-ease)}.np-mask:hover img{transform:scale(1.035)}
@media(max-width:1120px){.np-links{display:none}.np-burger{display:block}.np-actions>.np-btn{display:none}.np-hero-grid,.np-editorial,.np-compare-grid,.np-objections,.np-contact-panel,.np-services-layout,.np-materials,.np-material-card{grid-template-columns:1fr}.np-hero-visual{min-height:560px}.np-hero-frame{inset:0 0 80px 0}.np-service-feature{position:relative;top:auto;min-height:auto}.np-service-feature img{height:320px}.np-process,.np-trust-strip,.np-proof-wall{grid-template-columns:repeat(2,1fr)}.np-footer-grid{grid-template-columns:1fr 1fr}.np-gallery{grid-template-columns:1fr 1fr}.np-project:nth-child(4){grid-column:auto}.np-project:first-child{grid-row:auto}}
@media(max-width:760px){:root{--np-demo-h:42px}.np-demo-bar{justify-content:space-between;font-size:11px}.np-demo-bar span{max-width:48vw;overflow:hidden;text-overflow:ellipsis}.np-wrap{width:min(calc(100% - 28px),var(--np-max))}.np-header{padding:12px 0}.np-logo img{width:150px}.np-hero{padding-top:calc(var(--np-demo-h) + 108px);min-height:auto}.np-hero h1{font-size:clamp(50px,16vw,78px)}.np-hero-grid{gap:34px}.np-hero-visual{min-height:470px}.np-hero-card{width:86%;padding:18px}.np-hero-mini{display:none}.np-swatch-stack{right:8px}.np-swatch-stack span{width:58px;height:58px}.np-section-head{display:grid;gap:16px}.np-trust-strip,.np-services-grid,.np-process,.np-gallery,.np-footer-grid,.np-proof-wall,.np-feature-list{grid-template-columns:1fr}.np-trust-item{border-right:0;border-bottom:1px solid var(--np-line)}.np-trust-item:last-child{border-bottom:0}.np-gallery{grid-auto-rows:260px}.np-form{grid-template-columns:1fr}.np-contact-panel{border-radius:32px}.np-footer-grid{gap:18px}.np-bottom{display:grid}.np-mobile a{font-size:25px}.np-material-card img{min-height:240px}}
@media(max-width:460px){.np-demo-bar a{padding-inline:10px}.np-demo-bar b{display:none}.np-hero-actions .np-btn{width:100%}.np-service-card{min-height:270px}.np-ba{border-radius:26px}.np-section{padding:62px 0}.np-hero-frame{border-radius:32px}.np-editorial-card,.np-editorial-photo,.np-objections-photo{border-radius:30px}.np-faq-q span{font-size:23px}.np-service-feature div{padding:22px}.np-contact-copy h2{font-size:48px}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.np-reveal{opacity:1!important;transform:none!important}}

/* ═══════════════════════════════════════════════════════════════════
   NOVA PEINTURE V4 — scroll storytelling / GSAP ScrollTrigger layer
   ═══════════════════════════════════════════════════════════════════ */
.np-scroll-projects{
  position:relative;
  min-height:260vh;
  padding:0;
  overflow:clip;
  border-top:1px solid var(--np-line);
  border-bottom:1px solid var(--np-line);
  background:
    radial-gradient(70% 44% at 82% 12%, color-mix(in srgb,var(--np-sage) 18%, transparent), transparent 66%),
    linear-gradient(180deg, color-mix(in srgb,var(--np-graphite) 92%, var(--np-bg)), var(--np-graphite));
  color:#fffaf1;
}
[data-theme="light"] .np-scroll-projects{
  background:
    radial-gradient(70% 44% at 82% 12%, rgba(126,149,135,.18), transparent 66%),
    linear-gradient(180deg,#151b17,#0f1511);
}
.np-work-sticky{
  position:sticky;
  top:0;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:clamp(22px,3.8vw,42px);
  padding:calc(var(--np-demo-h) + 72px) 0 58px;
  overflow:hidden;
}
.np-scroll-head{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(300px,.55fr);
  gap:clamp(24px,5vw,70px);
  align-items:end;
}
.np-scroll-head .np-section-title{color:#fffaf1;margin:14px 0 0;max-width:850px;}
.np-scroll-head p{color:rgba(255,250,241,.68);line-height:1.78;margin:0;max-width:46ch;}
.np-work-rail{
  width:100%;
  overflow:visible;
  padding-left:max(24px,calc((100vw - var(--np-max)) / 2 + 24px));
  padding-right:24px;
}
.np-work-track{
  display:flex;
  gap:clamp(18px,2.8vw,34px);
  will-change:transform;
  transform:translate3d(0,0,0);
}
.np-work-card{
  flex:0 0 min(78vw,920px);
  display:grid;
  grid-template-columns:1.12fr .88fr;
  min-height:clamp(430px,56vh,650px);
  border:1px solid rgba(255,250,241,.14);
  border-radius:42px;
  overflow:hidden;
  background:rgba(255,250,241,.045);
  box-shadow:0 38px 100px -58px rgba(0,0,0,.8);
  opacity:1;
  transform:none;
}
.np-work-image{position:relative;overflow:hidden;background:#263029;}
.np-work-image::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 42%,rgba(15,21,17,.36));pointer-events:none;}
.np-work-image img{width:100%;height:100%;object-fit:cover;transform:scale(1.03);}
.np-work-body{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:16px;
  padding:clamp(24px,4vw,54px);
}
.np-work-body span{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:#d5c1a0;font-weight:900;}
.np-work-body h3{font-family:"Cormorant Garamond",serif;font-size:clamp(42px,5vw,74px);line-height:.92;letter-spacing:-.05em;margin:0;color:#fffaf1;}
.np-work-body p{margin:0;color:rgba(255,250,241,.72);line-height:1.72;max-width:45ch;}
.np-work-body p b{color:#fffaf1;}
.np-work-body small{align-self:flex-start;border:1px solid rgba(255,250,241,.16);border-radius:999px;padding:9px 13px;color:rgba(255,250,241,.75);background:rgba(255,255,255,.045);}
.np-work-progress{
  height:6px;
  border-radius:999px;
  background:rgba(255,250,241,.12);
  overflow:hidden;
  margin-top:clamp(2px,1.8vw,16px);
}
.np-work-progress span{display:block;width:0%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#f2ddbd,#9aa98e);transition:width .08s linear;}

.np-proof-cinema .np-ba{transform-origin:center;}
.np-proof-cinema .np-compare-grid{align-items:center;}
.np-proof-cinema .np-check{transform:translateY(0);}
.np-js .np-proof-cinema .np-check{opacity:.35;transition:opacity .28s ease, transform .28s ease;}
.np-js .np-proof-cinema .np-check.is-hot{opacity:1;transform:translateX(8px);}

.np-journey-section{
  position:relative;
  background:
    linear-gradient(180deg,color-mix(in srgb,var(--np-bg) 72%,var(--np-paper)),var(--np-bg));
  overflow:clip;
}
.np-journey{
  display:grid;
  grid-template-columns:minmax(360px,.82fr) minmax(0,1fr);
  gap:clamp(28px,5vw,72px);
  align-items:start;
}
.np-journey-visual{
  position:sticky;
  top:calc(var(--np-demo-h) + 96px);
  min-height:clamp(520px,70vh,760px);
  border-radius:44px;
  overflow:hidden;
  box-shadow:var(--np-shadow-strong);
  border:1px solid var(--np-line);
  background:var(--np-graphite);
}
.np-journey-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .28s ease, transform .7s var(--np-ease);}
.np-journey-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(12,18,14,.76),transparent 54%);pointer-events:none;}
.np-journey-overlay{position:absolute;left:24px;right:24px;bottom:24px;z-index:2;padding:20px;border-radius:26px;background:rgba(17,22,18,.74);border:1px solid rgba(255,250,241,.16);backdrop-filter:blur(14px);color:#fffaf1;}
.np-journey-overlay span{display:inline-flex;margin-bottom:10px;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:#f2ddbd;font-weight:900;}
.np-journey-overlay b{display:block;font-family:"Cormorant Garamond",serif;font-size:clamp(38px,4.2vw,62px);line-height:.94;letter-spacing:-.045em;}
.np-journey-copy{padding-top:clamp(18px,4vw,52px);}
.np-journey-copy>.np-section-title{margin:16px 0 18px;max-width:800px;}
.np-journey-copy>p{margin:0 0 30px;color:var(--np-soft);line-height:1.76;max-width:62ch;}
.np-journey-steps{display:grid;gap:18px;}
.np-journey-step{
  position:relative;
  display:grid;
  grid-template-columns:72px 1fr;
  gap:18px;
  padding:24px;
  border:1px solid var(--np-line);
  border-radius:28px;
  background:color-mix(in srgb,var(--np-paper) 54%,transparent);
  transition:transform .28s var(--np-ease),border-color .28s var(--np-ease),background .28s var(--np-ease),box-shadow .28s var(--np-ease),opacity .28s;
}
.np-journey-step span{
  width:54px;height:54px;border-radius:18px;display:grid;place-items:center;
  background:var(--np-graphite);color:#fffaf1;font-weight:900;
}
.np-journey-step h3{font-family:"Cormorant Garamond",serif;font-size:clamp(31px,3vw,46px);line-height:.95;margin:0 0 8px;letter-spacing:-.035em;}
.np-journey-step p{margin:0;color:var(--np-soft);line-height:1.72;}
.np-journey-step.is-active{border-color:color-mix(in srgb,var(--np-sage) 65%,var(--np-line));background:color-mix(in srgb,var(--np-paper) 78%,var(--np-sage) 10%);box-shadow:0 26px 70px -44px rgba(0,0,0,.45);transform:translateX(10px);}

@media(min-width:1180px){
  .np-scroll-projects .np-reveal{transition:none;}
}
@media(max-width:980px){
  .np-scroll-projects{min-height:auto;padding:84px 0;background:var(--np-graphite);}
  .np-work-sticky{position:relative;top:auto;min-height:auto;padding:0;display:block;overflow:visible;}
  .np-scroll-head{grid-template-columns:1fr;margin-bottom:28px;}
  .np-work-rail{overflow-x:auto;scroll-snap-type:x mandatory;padding:0 18px 18px;}
  .np-work-track{transform:none!important;width:max-content;}
  .np-work-card{flex-basis:min(86vw,680px);grid-template-columns:1fr;min-height:auto;scroll-snap-align:center;}
  .np-work-image{aspect-ratio:16/10;}
  .np-work-progress{display:none;}
  .np-journey{grid-template-columns:1fr;}
  .np-journey-visual{position:relative;top:auto;min-height:420px;}
  .np-journey-step{transform:none!important;}
}
@media(max-width:620px){
  .np-work-card{flex-basis:88vw;border-radius:30px;}
  .np-work-body{padding:24px;}
  .np-work-body h3{font-size:42px;}
  .np-journey-step{grid-template-columns:1fr;padding:22px;}
  .np-journey-step span{width:48px;height:48px;}
  .np-journey-visual{border-radius:32px;min-height:360px;}
}


/* ═══════════════════════════════════════════════════════════════════
   V4.1/V4.3 fixes — ScrollTrigger end, draggable progress, denser cards
   ═══════════════════════════════════════════════════════════════════ */
@media (min-width:981px){
  .np-scroll-projects{min-height:100svh;overflow:hidden;}
  .np-work-sticky{min-height:100svh;padding-top:calc(var(--np-demo-h) + 112px);padding-bottom:54px;}
  .np-work-rail{padding-left:max(24px,calc((100vw - var(--np-max)) / 2 + 24px));padding-right:max(24px,calc((100vw - var(--np-max)) / 2 + 24px));}
  .np-work-card{flex-basis:min(80vw,980px);}
}
.np-work-progress{position:relative;height:10px;border:1px solid rgba(255,250,241,.16);background:rgba(255,250,241,.10);cursor:grab;touch-action:none;outline-offset:6px;}
.np-work-progress:active{cursor:grabbing;}
.np-work-progress span{position:relative;min-width:0;}
.np-work-progress span i{position:absolute;right:-10px;top:50%;width:22px;height:22px;transform:translateY(-50%);border-radius:999px;background:#f2ddbd;border:3px solid #0f1511;box-shadow:0 12px 28px -14px rgba(0,0,0,.8);}
.np-work-progress:focus-visible{outline:3px solid rgba(242,221,189,.7);border-radius:999px;}
.np-work-hint{margin:10px 0 0;color:rgba(255,250,241,.55);font-size:12px;text-align:right;}
.np-work-result{padding-left:14px;border-left:2px solid rgba(242,221,189,.34);}
.np-work-card .np-work-body{min-width:0;}
.np-work-card .np-work-body p{font-size:clamp(15px,1.2vw,17px);}
.np-work-card .np-work-body small{margin-top:4px;}
.np-services-layout{align-items:start;}
@media(min-width:1121px){.np-service-feature{top:calc(var(--np-demo-h) + 96px);}}
.np-service-card{display:flex;flex-direction:column;}
.np-service-card .np-service-meta{margin-top:auto;padding-top:18px;}
.np-mini-card{min-height:138px;display:flex;flex-direction:column;justify-content:center;}
.np-journey-copy{min-width:0;}
.np-journey-step{overflow:hidden;}
.np-journey-step p{max-width:62ch;}
@media (max-width:1180px){
  .np-journey{grid-template-columns:1fr;}
  .np-journey-visual{position:relative;top:auto;min-height:480px;}
  .np-journey-copy{padding-top:0;}
  .np-journey-step{transform:none!important;}
}
@media (max-width:980px){
  .np-work-hint{display:none;}
  .np-work-rail{scrollbar-width:thin;}
  .np-work-card{flex-basis:min(86vw,720px);}
}
@media (max-width:620px){
  .np-work-card{flex-basis:88vw;}
  .np-work-card .np-work-body p{font-size:15px;}
  .np-journey-visual{min-height:360px;}
}


/* ═══════════════════════════════════════════════════════════════════
   V4.3/V4.4 — Corrections GSAP + densité visuelle
   - card complet visible dans la séquence horizontale
   - fin du scroll sans espace noir inutile
   - méthode scrollée plus compacte et lisible
   ═══════════════════════════════════════════════════════════════════ */
@media (min-width:981px){
  .np-scroll-projects{min-height:100svh!important;overflow:hidden;}
  .np-work-sticky{
    min-height:100svh;
    padding-top:calc(var(--np-demo-h) + 86px)!important;
    padding-bottom:34px!important;
    gap:clamp(16px,2.2vw,26px)!important;
    justify-content:flex-start!important;
  }
  .np-scroll-head{
    grid-template-columns:minmax(0,.92fr) minmax(280px,.48fr)!important;
    gap:clamp(22px,4vw,56px)!important;
    align-items:end;
  }
  .np-scroll-head .np-section-title{
    font-size:clamp(48px,5.2vw,86px)!important;
    line-height:.88!important;
    max-width:780px!important;
  }
  .np-scroll-head p{font-size:clamp(15px,1.2vw,17px);line-height:1.62!important;}
  .np-work-rail{
    padding-left:max(24px,calc((100vw - var(--np-max)) / 2 + 24px))!important;
    padding-right:max(24px,calc((100vw - var(--np-max)) / 2 + 24px))!important;
  }
  .np-work-card{
    flex-basis:min(74vw,900px)!important;
    min-height:clamp(350px,42vh,500px)!important;
    border-radius:34px!important;
  }
  .np-work-body{padding:clamp(20px,3vw,42px)!important;gap:clamp(9px,1.3vw,14px)!important;}
  .np-work-body span{font-size:11px;letter-spacing:.15em;}
  .np-work-body h3{font-size:clamp(34px,4.15vw,58px)!important;line-height:.94!important;}
  .np-work-body p{font-size:clamp(14px,1.05vw,16px)!important;line-height:1.55!important;}
  .np-work-result{padding-left:12px;}
  .np-work-body small{padding:7px 11px;font-size:13px;}
  .np-work-progress{margin-top:4px!important;}
  .np-work-hint{margin-top:7px!important;}
}
@media (min-width:1500px){
  .np-work-sticky{padding-top:calc(var(--np-demo-h) + 76px)!important;}
  .np-work-card{min-height:clamp(360px,44vh,520px)!important;}
}
@media (min-width:981px) and (max-height:840px){
  .np-work-sticky{padding-top:calc(var(--np-demo-h) + 68px)!important;gap:16px!important;}
  .np-scroll-head .np-section-title{font-size:clamp(42px,4.6vw,70px)!important;}
  .np-work-card{min-height:clamp(320px,39vh,440px)!important;}
  .np-work-body h3{font-size:clamp(30px,3.5vw,50px)!important;}
  .np-work-body p{font-size:14px!important;line-height:1.45!important;}
  .np-work-body small{display:none;}
  .np-work-hint{display:none;}
}
@media (min-width:1181px){
  .np-journey{grid-template-columns:minmax(320px,.76fr) minmax(0,1.08fr)!important;gap:clamp(28px,4vw,52px)!important;align-items:start;}
  .np-journey-section{padding-top:clamp(76px,8vw,108px)!important;padding-bottom:clamp(76px,8vw,108px)!important;}
  .np-journey-visual{top:calc(var(--np-demo-h) + 102px)!important;min-height:clamp(390px,54vh,560px)!important;border-radius:34px!important;}
  .np-journey-copy{padding-top:0!important;}
  .np-journey-copy>.np-section-title{font-size:clamp(42px,4.7vw,70px)!important;line-height:.92!important;max-width:720px!important;}
  .np-journey-copy>p{margin-bottom:22px!important;max-width:58ch;}
  .np-journey-steps{gap:14px!important;}
  .np-journey-step{grid-template-columns:58px 1fr!important;gap:14px!important;padding:18px 20px!important;border-radius:22px!important;}
  .np-journey-step span{width:46px!important;height:46px!important;border-radius:14px!important;}
  .np-journey-step h3{font-size:clamp(27px,2.45vw,38px)!important;margin-bottom:6px!important;}
  .np-journey-step p{font-size:15px!important;line-height:1.56!important;}
  .np-journey-step.is-active{transform:translateX(6px)!important;}
}
@media (min-width:981px) and (max-width:1180px){
  .np-journey-step{grid-template-columns:52px 1fr!important;padding:18px!important;}
  .np-journey-step span{width:44px!important;height:44px!important;}
  .np-journey-step h3{font-size:30px!important;}
  .np-journey-step p{font-size:15px!important;line-height:1.55!important;}
}

/* ═══════════════════════════════════════════════════════════════════
   V4.4 — Corrections lisibilité / viewport / GSAP
   Objectif: titres plus courts, cards visibles entièrement, moins d'espace noir
   ═══════════════════════════════════════════════════════════════════ */
:root{--np-header-total:calc(var(--np-demo-h) + 74px);}
.np-hero h1{font-size:clamp(44px,6.2vw,88px)!important;line-height:.88!important;max-width:720px!important;}
.np-section-title{font-size:clamp(34px,4.6vw,66px);line-height:.95;letter-spacing:-.04em;}
.np-large-title{font-size:clamp(38px,5vw,74px);line-height:.94;}
@media (min-width:981px){
  .np-scroll-projects{min-height:auto!important;overflow:hidden!important;}
  .np-work-sticky{
    position:relative!important;
    top:auto!important;
    min-height:auto!important;
    padding-top:calc(var(--np-demo-h) + 82px)!important;
    padding-bottom:24px!important;
    gap:18px!important;
    justify-content:flex-start!important;
  }
  .np-scroll-head{
    grid-template-columns:minmax(0,1fr) minmax(300px,420px)!important;
    align-items:end!important;
    gap:28px!important;
    margin-bottom:6px!important;
  }
  .np-scroll-head .np-kicker{font-size:11px!important;letter-spacing:.20em!important;}
  .np-scroll-head .np-section-title{
    font-size:clamp(36px,4.2vw,62px)!important;
    line-height:.94!important;
    max-width:none!important;
    margin-top:10px!important;
    text-wrap:balance;
  }
  .np-scroll-head p{font-size:15px!important;line-height:1.55!important;max-width:42ch!important;}
  .np-work-rail{
    padding-left:max(20px,calc((100vw - var(--np-max)) / 2 + 20px))!important;
    padding-right:max(20px,calc((100vw - var(--np-max)) / 2 + 20px))!important;
    overflow:visible!important;
  }
  .np-work-track{gap:22px!important;}
  .np-work-card{
    flex-basis:min(64vw,760px)!important;
    grid-template-columns:.98fr 1.02fr!important;
    min-height:clamp(300px,40vh,420px)!important;
    max-height:calc(100svh - var(--np-header-total) - 210px)!important;
    border-radius:28px!important;
  }
  .np-work-body{padding:clamp(18px,2.35vw,30px)!important;gap:8px!important;justify-content:center!important;}
  .np-work-body span{font-size:10px!important;letter-spacing:.16em!important;}
  .np-work-body h3{font-size:clamp(28px,3.0vw,44px)!important;line-height:.96!important;letter-spacing:-.04em!important;}
  .np-work-body p{font-size:14px!important;line-height:1.44!important;max-width:40ch!important;}
  .np-work-result{padding-left:10px!important;border-left-width:1px!important;}
  .np-work-body small{font-size:12px!important;padding:6px 10px!important;margin-top:2px!important;}
  .np-work-progress{height:8px!important;margin-top:2px!important;max-width:var(--np-max);}
  .np-work-hint{display:none!important;}
}
@media (min-width:981px) and (max-height:820px){
  .np-work-sticky{padding-top:calc(var(--np-demo-h) + 70px)!important;gap:12px!important;}
  .np-scroll-head{grid-template-columns:1fr minmax(260px,360px)!important;margin-bottom:2px!important;}
  .np-scroll-head .np-section-title{font-size:clamp(32px,3.6vw,52px)!important;line-height:.96!important;}
  .np-scroll-head p{font-size:14px!important;line-height:1.45!important;}
  .np-work-card{flex-basis:min(60vw,710px)!important;min-height:300px!important;max-height:calc(100svh - var(--np-header-total) - 170px)!important;}
  .np-work-body{padding:18px 22px!important;gap:6px!important;}
  .np-work-body h3{font-size:clamp(25px,2.75vw,38px)!important;}
  .np-work-body p{font-size:13px!important;line-height:1.36!important;}
  .np-work-body small{display:none!important;}
}
@media (min-width:1500px){
  .np-scroll-head .np-section-title{font-size:58px!important;}
  .np-work-card{flex-basis:min(58vw,820px)!important;}
}
@media (max-width:980px){
  .np-hero h1{font-size:clamp(40px,11vw,70px)!important;}
  .np-section-title{font-size:clamp(32px,8.5vw,54px)!important;}
}

/* ═══════════════════════════════════════════════════════════════
   V4.5 — Bug fixes
   1. Progress bar handle visible at all positions (overflow was clipping it)
   2. GSAP pinned section fills full viewport (restore min-height:100svh on sticky)
   3. Mobile rail scrollable (overflow:visible already added above in ≤980px block)
   ═══════════════════════════════════════════════════════════════ */
/* Progress bar drag handle: allow it to protrude slightly outside the track */
.np-work-progress{overflow:visible!important;}
.np-work-progress span{border-radius:999px;}
/* GSAP height fix: V4.4 set min-height:auto on .np-work-sticky which shrank the pinned section.
   Restoring 100svh ensures GSAP pins a full-viewport section. JS also sets section height directly. */
@media (min-width:981px){
  .np-work-sticky{min-height:100svh!important;}
}
/* ───────────────────────────────────────────────────────────────
   4. Méthode scrollée — fix broken grid auto-placement.
   The step is `grid-template-columns: <badge> 1fr` with 3 children
   (span, h3, p). Auto-placement dropped <p> into the narrow badge
   column (72px wide, 330px tall). Pin h3 + p to the content column.
   Scoped >620px because ≤620px is intentionally single-column.
   ─────────────────────────────────────────────────────────────── */
@media (min-width:621px){
  .np-journey-step h3,
  .np-journey-step p{grid-column:2;}
  .np-journey-step span{grid-row:1;align-self:start;}
}
/* ───────────────────────────────────────
   5. Avant/Apres — double-arrow drag hint
   ─────────────────────────────────────── */
.np-ba-handle::after{
  background:var(--np-graphite) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f2ddbd' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 16l-4-4 4-4M17 8l4 4-4 4'/%3E%3C/svg%3E") center/22px no-repeat;
}
/* ───────────────────────────────────────
   6. Progress bar — handle grows on hover
   ─────────────────────────────────────── */
.np-work-progress span i{transition:transform .18s ease;}
.np-work-progress:hover span i,.np-work-progress:active span i{transform:translateY(-50%) scale(1.25);}
.np-work-progress:hover{background:rgba(255,250,241,.18)!important;}

/* ═══════════════════════════════════════════════════════════════
   V4.6 — Interaction layer
   Cursor spotlight on light cards · magnetic CTAs · hero entrance
   ═══════════════════════════════════════════════════════════════ */
.np-hero-card{position:absolute;isolation:isolate;overflow:hidden;}
.np-trust-item,.np-proof-card,.np-mini-card,.np-feature{position:relative;isolation:isolate;overflow:hidden;}
.np-hero-card::before,.np-trust-item::before,.np-proof-card::before,.np-mini-card::before,.np-feature::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(300px circle at var(--x,50%) var(--y,50%),rgba(127,151,136,.20),transparent 46%);
  opacity:0;transition:opacity .3s ease;
}
.np-hero-card:hover::before,.np-trust-item:hover::before,.np-proof-card:hover::before,.np-mini-card:hover::before,.np-feature:hover::before{opacity:1;}
/* Dark mode: warm gold glow reads better on dark cards */
[data-theme="dark"] .np-hero-card::before,
[data-theme="dark"] .np-trust-item::before,
[data-theme="dark"] .np-proof-card::before,
[data-theme="dark"] .np-mini-card::before,
[data-theme="dark"] .np-feature::before{
  background:radial-gradient(300px circle at var(--x,50%) var(--y,50%),rgba(242,221,189,.16),transparent 46%);
}
/* Subtle lift on the free-standing cards (not the bordered trust strip / absolute hero card) */
.np-proof-card,.np-mini-card,.np-feature{transition:transform .3s var(--np-ease),border-color .3s var(--np-ease),box-shadow .3s var(--np-ease);}
.np-proof-card:hover,.np-mini-card:hover,.np-feature:hover{transform:translateY(-4px);border-color:rgba(127,151,136,.42);box-shadow:var(--np-shadow);}

/* Hero entrance — staggered rise on load.
   Transition + JS class (not animation:both) so the base state is ALWAYS visible:
   safe for print, PDF export, reduced-motion and no-JS. */
@media (prefers-reduced-motion:no-preference){
  .np-js .np-hero-grid>div:first-child>*{opacity:0;transform:translateY(22px);transition:opacity .8s var(--np-ease),transform .8s var(--np-ease);}
  .np-js .np-hero-grid>div:first-child.is-lit>*{opacity:1;transform:none;}
  .np-hero-grid>div:first-child>.np-kicker{transition-delay:.05s;}
  .np-hero-grid>div:first-child>h1{transition-delay:.13s;}
  .np-hero-grid>div:first-child>.np-lead{transition-delay:.22s;}
  .np-hero-grid>div:first-child>.np-hero-actions{transition-delay:.31s;}
  .np-hero-grid>div:first-child>.np-hero-proof{transition-delay:.40s;}
}
/* Safety net: never let the staggered hero stay hidden in print/PDF */
@media print{
  .np-hero-grid>div:first-child>*{opacity:1!important;transform:none!important;}
}

/* ═══════════════════════════════════════════════════════════════
   V4.8 — Spotlight on hero frame + journey steps
   ═══════════════════════════════════════════════════════════════ */
/* Hero image frame: glow follows cursor over the photo */
.np-hero-frame::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(400px circle at var(--x,50%) var(--y,50%),rgba(127,151,136,.22),transparent 50%);
  opacity:0;transition:opacity .35s ease;
}
.np-hero-frame:hover::before{opacity:1;}
/* Journey steps: glow within each step card */
.np-journey-step{isolation:isolate;}
.np-journey-step::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(280px circle at var(--x,50%) var(--y,50%),rgba(127,151,136,.18),transparent 50%);
  opacity:0;transition:opacity .3s ease;
}
.np-journey-step:hover::before{opacity:1;}

/* ═══════════════════════════════════════════════════════════════
   V4.7 — Gallery 7th card (Option A: image + gradient overlay)
   Matches the visual language of the other photo cards.
   ═══════════════════════════════════════════════════════════════ */
.np-project--invite{background:#263029;}
.np-project--invite::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(160deg,rgba(12,18,14,.32) 0%,rgba(12,18,14,.82) 100%);
  transition:opacity .4s ease;
}
.np-project--invite:hover::after{opacity:.7;}
.np-invite-inner{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;text-align:center;padding:24px;color:#fffaf1;
}
.np-invite-inner>.np-kicker{color:#f2ddbd;}
.np-invite-inner>b{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(22px,2.4vw,34px);line-height:1.05;display:block;margin:0;
  letter-spacing:-.03em;
}
.np-invite-inner>.np-btn{background:#f2ddbd;color:#1b1b18;font-size:13px;min-height:40px;}
@media(max-width:1120px){
  .np-project--invite{grid-column:1/-1;min-height:220px;}
}

/* ═══════════════════════════════════════════════════════════════
   V4.9 — Progress bar (A) + Section numbers (B3) + Hero mini fix
   ═══════════════════════════════════════════════════════════════ */

/* A: Scroll progress bar — thin sage line at top of page */
.np-scroll-prog{
  position:fixed;top:0;left:0;height:2px;z-index:1001;pointer-events:none;
  background:var(--np-sage);width:0%;transition:width .12s linear;
}

/* B3: Section number prefix in kicker — animation driven by JS MutationObserver */
.np-sec-num{
  display:inline-block;
  font-variant-numeric:tabular-nums;
  font-size:.78em;letter-spacing:.1em;
  margin-right:10px;vertical-align:middle;
  color:var(--np-sage-dark,#5a7a63);
}

/* Hero mini: crop to bottom 70% — shows roller + brush, not dried flowers */
.np-hero-mini img{object-position:center 72%!important;}

/* ═══════════════════════════════════════════════════════════════
   V5.1 — Smooth horizontal projects (native sticky) + Approche sizing
   ═══════════════════════════════════════════════════════════════ */
/* The projects "Chantiers sélectionnés" slider is pinned with NATIVE
   position:sticky (GPU-composited → buttery smooth). For native sticky to
   work, NO ancestor may be a scroll container: overflow MUST be `clip`
   (clips the translated track without establishing a scrollport), never
   `hidden`. JS sets the section height and drives only the horizontal track. */
@media (min-width:981px){
  .np-scroll-projects{overflow:clip!important;}
  .np-work-sticky{
    position:sticky!important;
    top:0!important;
    min-height:100svh!important;
    height:100svh!important;
    overflow:clip!important;
    transform:none!important;   /* never let stray inline transforms fight native sticky */
  }
}

/* Approche editorial block — definitive sizing.
   The photo image file is taller than its declared ratio, so in flow it forced
   the row to ~830px and stretched the card with it. Taking the image OUT OF FLOW
   (absolute, object-fit:cover) means the photo no longer contributes its own
   height: the row height is driven purely by the card's text, the photo fills to
   match it (always perfectly aligned), and trimming the heading/padding keeps
   both cards compact. Scoped to the true two-column layout (>1120px). */
@media (min-width:1121px){
  .np-editorial{align-items:stretch;}
  .np-editorial-card{
    justify-content:flex-start;
    gap:clamp(13px,1.6vw,22px);
    padding:clamp(24px,2.6vw,36px);
  }
  .np-editorial-card h2{font-size:clamp(25px,2vw,36px);}
  .np-editorial-card p{line-height:1.6;}
  .np-editorial-photo{overflow:hidden;}
  .np-editorial-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
}
/* Stacked layout (≤1120px): give the photo a sane aspect ratio instead of the
   tall intrinsic, since there's no side card to match its height. */
@media (max-width:1120px){
  .np-editorial-photo{aspect-ratio:16/11;}
}
