/* ═══════════════════════════════════════════════════════════
   YOU ART IT — Front-office v5 · Charte graphique 2026
   Palette  : FAFAF7 · FFFFFF · E9E5DD · 0A0A0A · 6B6B6B · C26A47
   Typo     : Montserrat (300/400/500/600/700/800/900)
   Esprit   : éditorial, minimal, chaud, créatif & tech
═══════════════════════════════════════════════════════════ */

/* ── Imports ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500&display=swap');

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

:root {
  /* Couleurs principales */
  --bg:        #FAFAF7;   /* Warm Paper — fond principal */
  --bg-deep:   #F2EEE5;   /* Sand — section alt chaude */
  --white:     #FFFFFF;   /* Carte / nav */
  --paper:     #E9E5DD;   /* Bordures légères chaudes */
  --light:     #F2EEE5;   /* alt sections */
  --black:     #0A0A0A;   /* Noir Encre — texte principal */
  --ink:       #141312;   /* Section sombre — chaud, pas pur */
  --mid:       #6B6B6B;   /* Texte secondaire */
  --muted:     #9C968B;   /* Très discret, chaud */

  /* Couleur accent — Terracotta */
  --accent:        #C26A47;
  --accent-soft:   #E5BFAB;
  --accent-deep:   #9A4F30;
  --accent-glow:   rgba(194,106,71,.18);

  /* Typo */
  --font:      'Montserrat', system-ui, sans-serif;
  --mono:      'JetBrains Mono', ui-monospace, monospace;

  /* Animation */
  --ease:      cubic-bezier(.22,1,.36,1);
  --ease-out:  cubic-bezier(.16,1,.3,1);

  /* Ombres */
  --shadow:        0 2px 24px rgba(20,15,10,.06);
  --shadow-hover:  0 12px 48px rgba(20,15,10,.10);
  --shadow-accent: 0 8px 36px rgba(194,106,71,.18);
}

html { scroll-behavior:smooth; overflow-x:hidden }
body {
  background: var(--bg);
  color: var(--black);
  font-family: var(--font);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: -.005em;
  cursor: none;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Sélection texte */
::selection { background: var(--accent); color: var(--white) }
::-moz-selection { background: var(--accent); color: var(--white) }

/* Grain texture overlay très subtil sur le body */
body::before {
  content:'';
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/></svg>");
  opacity:.035;
  mix-blend-mode:multiply;
}

/* ══ CURSEUR — point noir permanent ══════════════════════ */
#cur {
  position:fixed; top:0; left:0; z-index:9999; pointer-events:none;
  width:8px; height:8px; background:var(--black); border-radius:50%;
  transform:translate(-50%,-50%);
  transition:width .25s var(--ease), height .25s var(--ease), background .2s;
}
#cur-ring { display:none }
body.inv #cur { background:var(--accent) }
body.cur-big #cur { width:14px; height:14px; background:var(--accent) }

/* ══ PAGE TRANSITIONS ═════════════════════════════════════ */
body.enter-curtain-down  { animation:enterDown  .8s var(--ease) both }
body.enter-slide-right   { animation:enterRight .8s var(--ease) both }
body.enter-slide-left    { animation:enterLeft  .8s var(--ease) both }
body.enter-curtain-up    { animation:enterUp    .8s var(--ease) both }
body.enter-fade-scale    { animation:enterScale .8s var(--ease) both }
body.enter-curtain-center{ animation:enterScale .8s var(--ease) both }
body.exit-fade-up        { animation:exitUp    .55s var(--ease) forwards }
body.exit-fade-left      { animation:exitLeft  .55s var(--ease) forwards }
body.exit-fade-right     { animation:exitRight .55s var(--ease) forwards }
@keyframes enterDown  { from{opacity:0;transform:translateY(-28px)} to{opacity:1;transform:none} }
@keyframes enterRight { from{opacity:0;transform:translateX(36px)}  to{opacity:1;transform:none} }
@keyframes enterLeft  { from{opacity:0;transform:translateX(-36px)} to{opacity:1;transform:none} }
@keyframes enterUp    { from{opacity:0;transform:translateY(28px)}  to{opacity:1;transform:none} }
@keyframes enterScale { from{opacity:0;transform:scale(.97)}        to{opacity:1;transform:none} }
@keyframes exitUp     { to{opacity:0;transform:translateY(-36px)} }
@keyframes exitLeft   { to{opacity:0;transform:translateX(-52px)} }
@keyframes exitRight  { to{opacity:0;transform:translateX(52px)}  }

/* ══ NAV ══════════════════════════════════════════════════ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 6rem;
  background:rgba(250,250,247,.85);
  backdrop-filter:blur(24px) saturate(140%);
  -webkit-backdrop-filter:blur(24px) saturate(140%);
  border-bottom:1px solid transparent;
  transition: border-color .35s, box-shadow .35s, padding .35s, background .35s;
}
nav.scrolled {
  padding:.85rem 6rem;
  border-bottom-color:var(--paper);
  background:rgba(250,250,247,.95);
  box-shadow:0 1px 24px rgba(20,15,10,.05);
}
.logo-svg { height:38px; transition: transform .4s var(--ease); will-change: transform }
.logo-svg:hover { transform: rotate(-2deg) scale(1.04) }

.nav-links { display:flex; gap:2.5rem; list-style:none }
.nav-links a {
  font-size:.7rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  text-decoration:none; color:var(--mid); transition:color .25s; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-6px; left:0; width:0; height:1.5px;
  background:var(--accent); transition:width .35s var(--ease);
}
.nav-links a:hover, .nav-links a.active { color:var(--black) }
.nav-links a.active::after, .nav-links a:hover::after { width:100% }

.nav-cta {
  font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  padding:.62rem 1.5rem; background:var(--black); color:var(--white);
  text-decoration:none; border:1px solid var(--black);
  transition:background .3s,color .3s,border-color .3s, transform .25s var(--ease);
  position:relative; overflow:hidden;
}
.nav-cta::before {
  content:''; position:absolute; inset:0; background:var(--accent);
  transform:translateY(100%); transition:transform .35s var(--ease); z-index:-1;
}
.nav-cta:hover { color:var(--white); border-color:var(--accent) }
.nav-cta:hover::before { transform:translateY(0) }

/* Burger */
.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px }
.burger span { display:block; width:22px; height:1.5px; background:var(--black); transition:transform .3s,opacity .3s }
.burger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg) }
.burger.open span:nth-child(2) { opacity:0 }
.burger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg) }

/* Mobile menu */
.mobile-menu {
  position:fixed; inset:0; z-index:199; background:var(--white);
  border-top:1px solid var(--paper); padding:90px 3rem 3rem;
  display:flex; flex-direction:column; justify-content:center;
  transform:translateX(100%); transition:transform .45s var(--ease);
}
.mobile-menu.open { transform:translateX(0) }
.mobile-menu ul { list-style:none }
.mobile-menu li { border-bottom:1px solid var(--paper) }
.mob-link {
  display:block; font-size:1.6rem; font-weight:800; letter-spacing:-.025em;
  text-decoration:none; color:var(--black); padding:1.15rem 0; transition:color .25s, padding-left .25s;
}
.mob-link:hover { color:var(--accent); padding-left:.5rem }
.mob-cta { display:inline-block; margin-top:1rem; font-size:.82rem }

/* ══ TYPOGRAPHIE ══════════════════════════════════════════ */
.eyebrow {
  font-family: var(--mono);
  font-size:.7rem; font-weight:500; letter-spacing:.22em; text-transform:uppercase;
  color:var(--mid); display:flex; align-items:center; gap:.6rem;
}
.eyebrow::before {
  content:''; width:24px; height:1px; background:var(--accent);
  display:inline-block; transition: width .4s var(--ease);
}
.rv.in .eyebrow::before, section:hover .eyebrow::before { width:40px }

h2.stitle {
  font-weight:800; font-size:clamp(1.9rem,3vw,3rem);
  line-height:1; letter-spacing:-.035em; color:var(--black);
}
h2.stitle em {
  font-style:normal; font-weight:300; letter-spacing:-.01em;
  color:var(--mid); position:relative;
}
h2.stitle em::before {
  content:''; position:absolute; left:-2px; right:-2px; bottom:.12em; height:.12em;
  background:var(--accent-glow); z-index:-1;
  transform:scaleX(0); transform-origin:left; transition:transform .6s var(--ease) .2s;
}
.rv.in h2.stitle em::before { transform:scaleX(1) }

.h-title {
  font-weight:900; font-size:clamp(2.6rem,5vw,4.8rem);
  line-height:.92; letter-spacing:-.045em; color:var(--black);
}
.h-title .lt { font-weight:300; color:var(--mid); font-style:italic }
.hero-bg-img ~ * .h-title,
.h-title { text-shadow: 0 1px 24px rgba(250,250,247,.9), 0 0 56px rgba(250,250,247,.6) }

/* ══ HELPERS ══════════════════════════════════════════════ */
.section { padding:7rem 6rem; position:relative; z-index:1 }
.section-inner { max-width:1080px; margin:0 auto }
.w-bg { background:var(--white) }
.l-bg { background:var(--bg-deep) }

/* Boutons — système amélioré */
.btn-black {
  display:inline-flex; align-items:center; gap:.55rem;
  font-size:.74rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  padding:.95rem 2rem; background:var(--black); color:var(--white);
  text-decoration:none; border:1px solid var(--black);
  transition:color .35s, transform .25s var(--ease), box-shadow .3s, border-color .3s;
  cursor:none; position:relative; overflow:hidden; isolation:isolate;
}
.btn-black::before {
  content:''; position:absolute; inset:0; background:var(--accent);
  transform:translateY(100%); transition:transform .4s var(--ease); z-index:-1;
}
.btn-black:hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:var(--shadow-accent) }
.btn-black:hover::before { transform:translateY(0) }

.btn-outline {
  display:inline-flex; align-items:center; gap:.55rem;
  font-size:.74rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  padding:.95rem 2rem; background:transparent; color:var(--black);
  text-decoration:none; border:1px solid var(--paper);
  transition:border-color .3s, background .3s, transform .25s var(--ease), color .3s;
  cursor:none; position:relative;
}
.btn-outline:hover { border-color:var(--black); background:var(--white); transform:translateY(-2px); color:var(--accent) }

.btn-row { display:flex; gap:.75rem; flex-wrap:wrap }
.btn-magnetic { transition:transform .3s var(--ease) }

/* ══ HERO ══════════════════════════════════════════════════ */
.hero {
  min-height:100vh; display:flex; flex-direction:column; justify-content:flex-end;
  padding:130px 6rem 5rem;
  background:var(--bg); position:relative; overflow:hidden; z-index:1;
}
/* Spot lumineux subtil derrière le hero */
.hero::before {
  content:''; position:absolute; top:-20%; right:-10%;
  width:60vw; height:60vw; max-width:900px; max-height:900px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 60%);
  z-index:0; pointer-events:none;
  animation: heroGlow 18s ease-in-out infinite alternate;
}
@keyframes heroGlow {
  0%   { transform: translate(0,0) scale(1); opacity:.6 }
  100% { transform: translate(-4%,3%) scale(1.15); opacity:1 }
}

.hero-rules { position:absolute; inset:0; z-index:1; pointer-events:none }
.hero-rules::before {
  content:''; position:absolute; top:0; bottom:0; right:38%;
  border-right:1px solid var(--paper);
}
.hero-rules::after {
  content:''; position:absolute; top:52%; left:0; right:0;
  border-top:1px solid var(--paper);
}
.hero-inner { max-width:1080px; margin:0 auto; width:100%; position:relative; z-index:2 }
.hero-layout { display:grid; grid-template-columns:1fr 380px; gap:4rem; align-items:flex-end }
.hero-sub { font-size:1.05rem; color:var(--black); font-weight:400; line-height:1.75; margin-bottom:2.5rem; max-width:360px }
.hero-bg-img { position:absolute; inset:0; z-index:0; overflow:hidden }
.hero-bg-img img {
  width:100%; height:100%; object-fit:cover;
  opacity:var(--hero-img-opacity,.55);
  transition:opacity .4s;
  display:block;
  filter: saturate(.92) contrast(1.02);
}

/* Animations hero */
.h-title .line { display:block; overflow:hidden }
.h-title .word { display:inline-block; animation:wUp .95s var(--ease) both }
.h-title .w1{animation-delay:.05s} .h-title .w2{animation-delay:.15s}
.h-title .w3{animation-delay:.25s} .h-title .w4{animation-delay:.35s}
.h-title .w5{animation-delay:.45s}
@keyframes wUp { from{transform:translateY(110%);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:none} }
.fade-in { animation:fadeUp .9s .55s ease forwards; opacity:0 }

/* Stats strip */
.hero-strip {
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--paper); margin-top:5rem;
  background:var(--white); box-shadow:var(--shadow);
  animation:fadeUp .9s .65s ease forwards;
  opacity:0;
}
.h-stat {
  padding:1.85rem 2rem; border-right:1px solid var(--paper);
  transition:background .3s, color .3s;
  position:relative; overflow:hidden;
}
.h-stat:last-child { border-right:none }
.h-stat::after {
  content:''; position:absolute; left:0; right:0; bottom:0; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.h-stat:hover { background:var(--bg-deep) }
.h-stat:hover::after { transform:scaleX(1) }
.h-stat-val { font-weight:900; font-size:1.95rem; line-height:1; letter-spacing:-.025em }
.h-stat-lbl {
  font-family: var(--mono);
  font-size:.65rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--mid); margin-top:.35rem;
}

/* ══ MARQUEE ══════════════════════════════════════════════ */
.marquee {
  background:var(--black); overflow:hidden; padding:1rem 0; position:relative; z-index:1;
  border-top:1px solid var(--ink); border-bottom:1px solid var(--ink);
}
.marquee::before, .marquee::after {
  content:''; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.marquee::before { left:0; background:linear-gradient(90deg, var(--black), transparent) }
.marquee::after  { right:0; background:linear-gradient(-90deg, var(--black), transparent) }
.mtrack { display:flex; width:max-content; animation:mq 36s linear infinite }
@keyframes mq { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.mitem {
  font-family: var(--mono);
  font-size:.7rem; font-weight:500; letter-spacing:.22em;
  text-transform:uppercase; color:rgba(255,255,255,.5); white-space:nowrap; padding:0 2.5rem;
  transition:color .3s;
}
.mitem:hover { color:var(--accent) }

/* ══ PROCESSUS ════════════════════════════════════════════ */
.process-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:var(--paper); margin-top:4rem;
}
.process-step {
  background:var(--white); padding:2.75rem 2rem;
  transition:background .35s, box-shadow .35s, transform .35s var(--ease);
  position:relative;
}
.process-step::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.process-step:hover { background:var(--bg-deep); box-shadow:var(--shadow); z-index:2 }
.process-step:hover::before { transform:scaleX(1) }
.step-num {
  font-family: var(--mono); font-weight:500; font-size:1.6rem;
  color:var(--accent); line-height:1; margin-bottom:1.4rem;
  letter-spacing:-.02em;
}
.step-title { font-weight:700; font-size:1rem; margin-bottom:.55rem; letter-spacing:-.01em }
.step-body { font-size:.88rem; color:var(--mid); line-height:1.75; font-weight:400 }

/* ══ SPLIT IMAGE + TEXTE ══════════════════════════════════ */
.split-section { display:grid; grid-template-columns:1fr 1fr; min-height:520px }
.split-img { position:relative; overflow:hidden; background:var(--bg-deep) }
.split-img img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .9s var(--ease);
}
.split-img:hover img { transform:scale(1.05) }
.split-img-placeholder {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:5.5rem; color:var(--paper); letter-spacing:.05em;
  font-style:italic;
}
.split-content {
  padding:4.5rem 3.75rem; display:flex; flex-direction:column;
  justify-content:center; background:var(--white);
}

/* ══ IMAGE STRIP ══════════════════════════════════════════ */
.img-strip-section {
  padding:3rem 0; overflow:hidden;
  background:var(--white); border-top:1px solid var(--paper); border-bottom:1px solid var(--paper);
}
.img-strip {
  display:flex; gap:1.5rem; overflow-x:auto; scroll-behavior:auto;
  -ms-overflow-style:none; scrollbar-width:none; padding:0 6rem;
}
.img-strip::-webkit-scrollbar { display:none }
.strip-item {
  flex:0 0 320px; height:230px; overflow:hidden;
  border:1px solid var(--paper); position:relative; cursor:none;
  background:var(--bg-deep);
  transition:box-shadow .35s, transform .4s var(--ease), border-color .3s;
  user-select:none;
}
.strip-item:hover { box-shadow:var(--shadow-hover); transform:translateY(-4px); border-color:var(--accent) }
.strip-item img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); display:block }
.strip-item:hover img { transform:scale(1.06) }
.strip-item-placeholder {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:2.5rem; color:var(--paper); letter-spacing:.1em; font-style:italic;
}
.strip-label {
  position:absolute; bottom:1rem; left:1rem;
  font-family: var(--mono);
  font-size:.62rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  padding:.32rem .7rem; background:var(--white); color:var(--black); border:1px solid var(--paper);
  transition:background .25s, color .25s, border-color .25s;
}
.strip-item:hover .strip-label { background:var(--accent); color:var(--white); border-color:var(--accent) }

/* ══ IMAGE BLOCKS ══════════════════════════════════════════ */
.img-block {
  position:relative; overflow:hidden; background:var(--bg-deep);
  border:1px solid var(--paper);
  transition:box-shadow .35s, border-color .3s;
}
.img-block:hover { box-shadow:var(--shadow-hover); border-color:var(--accent-soft) }
.img-block img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .8s var(--ease) }
.img-block:hover img { transform:scale(1.04) }
.img-block-placeholder {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1rem; width:100%; height:100%; min-height:280px;
  color:var(--muted); font-family:var(--mono); font-size:.7rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
}
.img-block-placeholder svg { opacity:.25; width:42px; height:42px }

/* Parallax */
.parallax-wrap { overflow:hidden; position:relative; background:var(--bg-deep) }
.parallax-wrap img { will-change:transform; display:block; width:100%; height:110%; object-fit:cover }

/* ══ SERVICES ══════════════════════════════════════════════ */
.svc-list { margin-top:3rem }
.svc-item {
  display:grid; grid-template-columns:60px 1fr 200px; gap:2rem;
  align-items:start; padding:2.25rem 0; border-top:1px solid var(--paper);
  transition:background .3s, padding .3s, margin .3s, box-shadow .3s;
  position:relative;
}
.svc-item::before {
  content:''; position:absolute; left:0; top:50%; width:0; height:1px; background:var(--accent);
  transition: width .5s var(--ease); transform:translateY(-50%);
}
.svc-item:hover::before { width:32px }
.svc-item:last-child { border-bottom:1px solid var(--paper) }
.svc-item:hover {
  background:var(--white); margin:0 -3.5rem; padding-left:5rem; padding-right:3.5rem;
  box-shadow:var(--shadow); border-top-color:transparent;
}
.svc-num {
  font-family: var(--mono); font-size:.7rem; font-weight:500;
  letter-spacing:.2em; color:var(--accent); padding-top:6px;
}
.svc-name { font-weight:700; font-size:1.35rem; margin-bottom:.55rem; letter-spacing:-.015em }
.svc-desc { font-size:.9rem; color:var(--mid); line-height:1.75; max-width:480px; margin-bottom:.85rem }
.svc-tags { display:flex; flex-wrap:wrap; gap:.4rem }
.s-tag {
  font-family: var(--mono);
  font-size:.6rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  padding:.25rem .7rem; border:1px solid var(--paper); color:var(--mid);
  background:var(--bg); transition:border-color .25s, color .25s, background .25s;
}
.s-tag:hover { border-color:var(--accent); color:var(--accent); background:var(--white) }
.svc-price-wrap { text-align:right }
.svc-price { font-weight:900; font-size:1.75rem; letter-spacing:-.025em }
.svc-per { font-family:var(--mono); font-size:.62rem; color:var(--muted); letter-spacing:.1em }
.svc-arrow { display:inline-block; font-size:1.1rem; color:var(--muted); margin-top:.5rem; transition:transform .3s,color .3s }
.svc-item:hover .svc-arrow, .svc-item:hover .svc-open-icon { transform:translateX(6px); color:var(--accent) }
.svc-clickable { cursor:none; user-select:none }
.svc-open-icon { transition:transform .3s,color .3s; color:var(--muted) }

/* ══ MODAL SERVICES ════════════════════════════════════════ */
.svc-modal {
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  padding:1.5rem; pointer-events:none; opacity:0;
  transition:opacity .35s ease;
}
.svc-modal.open { opacity:1; pointer-events:all }
.svc-modal-backdrop {
  position:absolute; inset:0;
  background:rgba(20,15,10,.35); backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.svc-modal-card {
  position:relative; z-index:1; background:var(--white);
  border:1px solid var(--paper); box-shadow:0 32px 100px rgba(20,15,10,.18);
  width:100%; max-width:840px; max-height:88vh; overflow-y:auto;
  transform:translateY(28px) scale(.97);
  transition:transform .45s var(--ease);
}
.svc-modal.open .svc-modal-card { transform:none }
.svc-modal-card::-webkit-scrollbar { width:3px }
.svc-modal-card::-webkit-scrollbar-thumb { background:var(--paper) }
.svc-modal-head {
  display:flex; align-items:flex-start; justify-content:space-between;
  padding:2.5rem 2.75rem 1.5rem;
  border-bottom:1px solid var(--paper);
  position:sticky; top:0; background:var(--white); z-index:2;
}
.svc-modal-num {
  font-family:var(--mono);
  font-size:.62rem; font-weight:500; letter-spacing:.25em;
  text-transform:uppercase; color:var(--accent); display:block; margin-bottom:.4rem;
}
.svc-modal-title { font-weight:900; font-size:1.6rem; letter-spacing:-.025em }
.svc-modal-close {
  background:none; border:1px solid var(--paper);
  width:36px; height:36px; border-radius:50%;
  font-size:.9rem; cursor:none; flex-shrink:0; margin-left:1rem; margin-top:.2rem;
  display:flex; align-items:center; justify-content:center;
  color:var(--mid); transition:background .25s,border-color .25s,color .25s, transform .3s;
}
.svc-modal-close:hover { background:var(--accent); color:var(--white); border-color:var(--accent); transform:rotate(90deg) }
.svc-modal-body { padding:2rem 2.75rem 2.75rem }
.svc-modal-desc {
  font-size:.98rem; color:var(--mid); line-height:1.85;
  margin-bottom:2.5rem; border-left:2px solid var(--accent); padding-left:1.5rem;
  font-weight:400;
}
.svc-modal-cols { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start }
.svc-modal-section-title {
  font-family:var(--mono);
  font-size:.65rem; font-weight:500; letter-spacing:.22em;
  text-transform:uppercase; color:var(--mid); margin-bottom:1.25rem;
}
.svc-modal-list { list-style:none }
.svc-modal-list li {
  font-size:.9rem; padding:.55rem 0; border-bottom:1px solid var(--paper);
  display:flex; align-items:center; gap:.8rem; color:var(--black);
}
.svc-modal-list li::before {
  content:''; width:14px; height:14px; flex-shrink:0;
  background: var(--accent);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 13l4 4L19 7' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 13l4 4L19 7' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
}
.svc-modal-delai {
  display:flex; align-items:center; gap:.5rem; margin-top:1.5rem;
  font-family:var(--mono);
  font-size:.78rem; font-weight:500; color:var(--mid);
}
.svc-modal-price-row { margin-top:1.5rem; padding-top:1.5rem; border-top:1px solid var(--paper) }
.svc-modal-price { font-weight:900; font-size:2.4rem; letter-spacing:-.035em }
.svc-modal-period { font-family:var(--mono); font-size:.72rem; color:var(--mid); letter-spacing:.1em; margin-left:.4rem }
.svc-modal-cta {
  display:flex; gap:.75rem; flex-wrap:wrap;
  margin-top:2.5rem; padding-top:2rem; border-top:1px solid var(--paper);
}

/* ══ SKILLS CHART ══════════════════════════════════════════ */
.skills-chart {
  display:flex; gap:.9rem; align-items:flex-end; height:170px; padding:0 .25rem;
}
.skill-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:.4rem; height:100% }
.skill-pct {
  font-family:var(--mono);
  font-weight:500; font-size:.74rem; letter-spacing:-.01em;
  color:var(--black); opacity:0; transition:opacity .5s ease .7s;
}
.skill-bar-wrap {
  flex:1; width:100%; display:flex; align-items:flex-end;
  background:var(--bg); border:1px solid var(--paper);
  position:relative; overflow:hidden;
}
.skill-bar {
  width:100%; height:0%; background:var(--black);
  transition:height 1.1s var(--ease);
}
.skill-col:nth-child(odd) .skill-bar { background:var(--black) }
.skill-col:nth-child(even) .skill-bar { background:var(--accent) }
.skill-label {
  font-family:var(--mono);
  font-size:.58rem; font-weight:500; letter-spacing:.06em;
  text-transform:uppercase; color:var(--mid); text-align:center; line-height:1.3;
}
.svc-modal.open .skill-bar[data-pct] { height:var(--bar-h,0%) }
.svc-modal.open .skill-pct { opacity:1 }

/* ══ PRICING ══════════════════════════════════════════════ */
.p-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  border:1px solid var(--paper); background:var(--paper); gap:1px;
}
.p-card {
  padding:3rem 2.4rem; background:var(--white);
  display:flex; flex-direction:column; position:relative;
  transition:background .35s, box-shadow .35s, transform .35s var(--ease);
}
.p-card:hover { background:var(--bg-deep); box-shadow:var(--shadow); transform:translateY(-3px); z-index:2 }
.p-card.pop {
  background:var(--black); color:var(--white);
  box-shadow: 0 0 0 1px var(--accent), 0 12px 48px rgba(20,15,10,.18);
  z-index:1;
}
.p-card.pop:hover { background:#1a1612 }
.pop-badge {
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  font-family:var(--mono);
  font-size:.6rem; font-weight:500; letter-spacing:.22em; text-transform:uppercase;
  padding:.32rem 1rem; background:var(--accent); color:var(--white);
  border:1px solid var(--accent); white-space:nowrap;
}
.p-card.pop .pop-badge { background:var(--accent); color:var(--white); border-color:var(--accent) }
.plan-tag { font-family:var(--mono); font-size:.62rem; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:var(--mid); margin-bottom:.65rem }
.p-card.pop .plan-tag { color:var(--accent-soft) }
.plan-name { font-weight:900; font-size:1.45rem; letter-spacing:-.025em; margin-bottom:1.6rem }
.plan-price { font-weight:900; font-size:2.6rem; line-height:1; letter-spacing:-.035em; margin-bottom:.25rem }
.plan-price sup { font-size:1.25rem; vertical-align:top; padding-top:.5rem; color:var(--mid); font-weight:600 }
.p-card.pop .plan-price sup { color:var(--accent-soft) }
.plan-per2 { font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; color:var(--mid); margin-bottom:1.6rem }
.p-card.pop .plan-per2 { color:rgba(255,255,255,.4) }
.plan-desc {
  font-size:.88rem; color:var(--mid); margin-bottom:1.85rem;
  border-bottom:1px solid var(--paper); padding-bottom:1.6rem; line-height:1.7;
}
.p-card.pop .plan-desc { color:rgba(255,255,255,.55); border-color:rgba(255,255,255,.08) }
.plan-feats { list-style:none; flex:1; margin-bottom:2.4rem }
.plan-feats li {
  font-size:.88rem; padding:.55rem 0; border-bottom:1px solid var(--paper);
  display:flex; align-items:flex-start; gap:.75rem; line-height:1.55;
}
.p-card.pop .plan-feats li { border-color:rgba(255,255,255,.07); color:rgba(255,255,255,.85) }
.plan-feats li::before {
  content:''; width:5px; height:5px; background:var(--accent);
  border-radius:50%; flex-shrink:0; margin-top:.7rem;
}
.p-card.pop .plan-feats li::before { background:var(--accent) }
.plan-feats li.off { opacity:.3; text-decoration:line-through }
.plan-feats li.off::before { background:var(--muted) }
.btn-inv {
  display:inline-flex; align-items:center; gap:.55rem;
  font-size:.74rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  padding:.9rem 1.8rem; background:var(--accent); color:var(--white);
  text-decoration:none; border:1px solid var(--accent);
  transition:background .3s, color .3s, border-color .3s; cursor:none;
}
.btn-inv:hover { background:transparent; color:var(--accent); border-color:var(--accent) }

/* ══ PORTFOLIO ═════════════════════════════════════════════ */
.port-slider {
  display:flex; gap:1.5rem; padding:0 6rem 2rem;
  overflow-x:auto; cursor:grab; scroll-snap-type:x mandatory;
}
.port-slider::-webkit-scrollbar { height:2px }
.port-slider::-webkit-scrollbar-thumb { background:var(--accent) }
.port-slider.grab { cursor:grabbing }
.port-card {
  flex:0 0 360px; scroll-snap-align:start; background:var(--white);
  border:1px solid var(--paper); overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s, border-color .3s;
}
.port-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-hover); border-color:var(--accent-soft) }
.port-thumb {
  height:220px; position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center; background:var(--bg-deep);
}
.port-thumb img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:.85; transition:opacity .45s, transform .8s var(--ease);
}
.port-card:hover .port-thumb img { opacity:1; transform:scale(1.06) }
.port-code {
  font-weight:900; font-size:4.2rem; color:var(--paper); position:relative; z-index:1;
  font-style:italic; letter-spacing:-.02em;
}
.port-lbl {
  position:absolute; top:1rem; left:1rem;
  font-family:var(--mono);
  font-size:.6rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  padding:.32rem .7rem; background:var(--white); color:var(--black);
  border:1px solid var(--paper);
}
.port-hover {
  position:absolute; inset:0; background:rgba(10,10,10,.55);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .35s;
}
.port-card:hover .port-hover { opacity:1 }
.port-view {
  font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  padding:.7rem 1.45rem; background:var(--accent); color:var(--white); border:none; cursor:none;
}
.port-info { padding:1.6rem }
.port-cat { font-family:var(--mono); font-size:.6rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:.4rem }
.port-name { font-weight:700; font-size:1.05rem; margin-bottom:.45rem; letter-spacing:-.015em }
.port-desc { font-size:.86rem; color:var(--mid); line-height:1.7; margin-bottom:1.2rem }
.port-res { display:flex; gap:1.5rem; padding-top:1.2rem; border-top:1px solid var(--paper) }
.pr-val { font-weight:900; font-size:1.3rem; letter-spacing:-.02em }
.pr-lbl { font-family:var(--mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mid) }

/* ══ TESTIMONIALS ═══════════════════════════════════════════ */
.testi-section { background:var(--ink); padding:7rem 6rem; position:relative; overflow:hidden }
.testi-section::before {
  content:''; position:absolute; top:-30%; left:-10%;
  width:50vw; height:50vw; max-width:700px; max-height:700px;
  background: radial-gradient(circle, rgba(194,106,71,.12) 0%, transparent 60%);
  pointer-events:none;
}
.t-inner { max-width:1280px; margin:0 auto; position:relative }
.testi-section .eyebrow { color:rgba(255,255,255,.4) }
.testi-section .eyebrow::before { background:var(--accent) }
.testi-section h2.stitle { color:var(--white) }
.testi-section h2.stitle em { color:rgba(255,255,255,.4) }
.testi-section h2.stitle em::before { background:var(--accent-glow) }
.t-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; margin-top:5rem; background:rgba(255,255,255,.06);
}
.t-card { background:var(--ink); padding:3rem 2.4rem; transition:background .35s; position:relative }
.t-card:hover { background:#1f1b16 }
.big-quote {
  font-weight:300; font-size:4.5rem; line-height:.8;
  color:var(--accent); opacity:.4; margin-bottom:1.5rem;
  font-style:italic;
}
.stars { font-size:.85rem; letter-spacing:.18em; color:var(--accent); margin-bottom:1.2rem }
.t-text { font-weight:300; font-size:.98rem; line-height:1.85; color:rgba(255,255,255,.75); margin-bottom:2.4rem }
.t-author { display:flex; align-items:center; gap:1rem; border-top:1px solid rgba(255,255,255,.06); padding-top:1.6rem }
.t-av {
  width:42px; height:42px; border:1px solid var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.78rem; color:var(--accent); flex-shrink:0;
  border-radius:50%;
}
.t-name { font-weight:600; font-size:.85rem; color:var(--white); letter-spacing:-.005em }
.t-role { font-family:var(--mono); font-size:.66rem; color:rgba(255,255,255,.4); margin-top:.2rem }

/* ══ FAQ ════════════════════════════════════════════════════ */
.faq-list { margin-top:4rem }
.faq-item { border-top:1px solid var(--paper); transition:padding .25s }
.faq-item:last-child { border-bottom:1px solid var(--paper) }
.faq-item.open { padding-left:1rem; border-left:2px solid var(--accent); margin-left:-1rem }
.faq-btn {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:1.7rem 0; background:transparent; border:none; color:var(--black);
  font-family:var(--font); font-size:1rem; font-weight:600; text-align:left;
  cursor:none; gap:2rem; letter-spacing:-.01em;
}
.faq-icon {
  width:32px; height:32px; border:1px solid var(--paper); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; font-weight:300; flex-shrink:0; color:var(--mid);
  transition:transform .45s, background .35s, border-color .35s, color .35s;
}
.faq-item.open .faq-icon { transform:rotate(45deg); background:var(--accent); color:var(--white); border-color:var(--accent) }
.faq-body {
  max-height:0; overflow:hidden; font-size:.94rem; color:var(--mid);
  line-height:1.85; transition:max-height .5s ease, padding .35s;
}
.faq-item.open .faq-body { max-height:340px; padding-bottom:1.85rem }

/* ══ BLOG ════════════════════════════════════════════════════ */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:4rem }
.blog-card {
  background:var(--white); border:1px solid var(--paper); overflow:hidden;
  text-decoration:none; color:var(--black); display:flex; flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .35s, border-color .3s;
}
.blog-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-hover); border-color:var(--accent-soft) }
.blog-thumb { height:200px; overflow:hidden; background:var(--bg-deep); position:relative }
.blog-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease) }
.blog-card:hover .blog-thumb img { transform:scale(1.05) }
.blog-thumb-placeholder { display:flex; align-items:center; justify-content:center; height:100%; font-weight:900; font-size:3.5rem; color:var(--paper); font-style:italic }
.blog-body { padding:1.6rem; flex:1; display:flex; flex-direction:column }
.blog-cat { font-family:var(--mono); font-size:.6rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:.45rem }
.blog-title { font-weight:800; font-size:1.05rem; margin-bottom:.55rem; line-height:1.3; letter-spacing:-.02em }
.blog-excerpt { font-size:.86rem; color:var(--mid); line-height:1.7; flex:1 }
.blog-meta { display:flex; align-items:center; justify-content:space-between; margin-top:1.2rem; padding-top:1.2rem; border-top:1px solid var(--paper) }
.blog-date { font-family:var(--mono); font-size:.65rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted) }
.blog-read { font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--black); transition:color .25s }
.blog-card:hover .blog-read { color:var(--accent) }

/* Article */
.article-body h2 { font-weight:800; font-size:1.5rem; letter-spacing:-.025em; margin:2.75rem 0 1.1rem }
.article-body h3 { font-weight:700; font-size:1.15rem; margin:2.25rem 0 .8rem; letter-spacing:-.015em }
.article-body p { margin-bottom:1.3rem; color:var(--black); line-height:1.85; font-size:.99rem; font-weight:400 }
.article-body ul,.article-body ol { margin:1rem 0 1.5rem 1.5rem }
.article-body li { margin-bottom:.55rem; line-height:1.7; color:var(--mid) }
.article-body a { color:var(--accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; transition:text-decoration-thickness .2s }
.article-body a:hover { text-decoration-thickness:2px }
.article-body img { max-width:100%; border:1px solid var(--paper); margin:2rem 0; display:block }
.article-body blockquote {
  border-left:3px solid var(--accent); padding:1.25rem 1.75rem; margin:2.25rem 0;
  font-size:1.1rem; color:var(--mid); font-style:italic; line-height:1.7;
  background: var(--bg-deep);
}

/* ══ CONTACT ════════════════════════════════════════════════ */
.c-detail { display:flex; align-items:flex-start; gap:1.1rem; margin-bottom:1.6rem }
.c-icon {
  width:42px; height:42px; border:1px solid var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-size:.92rem; flex-shrink:0; background:var(--white); color:var(--mid);
  transition:background .25s, color .25s, border-color .25s;
}
.c-detail:hover .c-icon { background:var(--accent); color:var(--white); border-color:var(--accent) }
.c-lbl { font-family:var(--mono); font-size:.6rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--muted) }
.c-val { font-size:.92rem; margin-top:.2rem; letter-spacing:-.005em }
.avail-badge {
  display:inline-flex; align-items:center; gap:.55rem; margin-top:2rem;
  padding:.55rem 1.1rem; border:1px solid var(--accent); background:var(--white);
  font-family:var(--mono);
  font-size:.65rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent);
}
.avail-dot { width:7px; height:7px; border-radius:50%; background:var(--accent); animation:pulse 2s infinite }
@keyframes pulse { 0%,100%{opacity:1; box-shadow:0 0 0 0 var(--accent-glow)} 50%{opacity:.5; box-shadow:0 0 0 6px transparent} }
.c-socials { display:flex; gap:.55rem; margin-top:2rem }
.c-soc {
  width:42px; height:42px; border:1px solid var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.74rem; text-decoration:none; color:var(--mid);
  background:var(--white); transition:background .25s,color .25s,border-color .25s, transform .25s; cursor:none;
}
.c-soc:hover { background:var(--accent); color:var(--white); border-color:var(--accent); transform:translateY(-2px) }
.c-form { display:flex; flex-direction:column; gap:1.3rem }
.f-row { display:grid; grid-template-columns:1fr 1fr; gap:1.3rem }
.f-group { display:flex; flex-direction:column; gap:.55rem }
.f-group label { font-family:var(--mono); font-size:.62rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--mid) }
.f-group input,.f-group textarea,.f-group select {
  background:var(--white); border:1px solid var(--paper); color:var(--black);
  font-family:var(--font); font-size:.94rem; padding:.85rem 1.1rem;
  outline:none; width:100%; transition:border-color .25s, box-shadow .25s; appearance:none;
  font-weight:400;
}
.f-group input::placeholder,.f-group textarea::placeholder { color:var(--muted) }
.f-group input:focus,.f-group textarea:focus,.f-group select:focus {
  border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-glow);
}
.f-group textarea { resize:vertical; min-height:130px; line-height:1.65 }
.f-group select option { background:var(--white) }
.f-footer { display:flex; align-items:center; gap:1.5rem; padding-top:.85rem }
.f-note { font-family:var(--mono); font-size:.68rem; color:var(--muted); line-height:1.5 }
.success-msg {
  display:none; padding:.95rem 1.4rem; border:1px solid var(--accent); border-left-width:3px;
  font-size:.85rem; font-weight:600; background:var(--white); margin-bottom:1.5rem;
  color:var(--accent-deep);
}

/* ══ STUDIO ═════════════════════════════════════════════════ */
.portrait-wrap {
  position:relative; aspect-ratio:3/4; background:var(--bg-deep);
  border:1px solid var(--paper); overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.portrait-wrap img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover }
.portrait-placeholder { font-family:var(--mono); font-size:.7rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); text-align:center; z-index:1 }
.timeline-item {
  display:grid; grid-template-columns:140px 1fr; gap:2rem;
  padding:2rem 0; border-top:1px solid var(--paper);
  transition: padding-left .3s;
}
.timeline-item:hover { padding-left:1rem }
.tl-year { font-family:var(--mono); font-weight:500; font-size:.95rem; color:var(--accent); padding-top:3px; letter-spacing:.05em }
.tl-title { font-weight:700; font-size:1.05rem; margin-bottom:.4rem; letter-spacing:-.015em }
.tl-body { font-size:.9rem; color:var(--mid); line-height:1.75 }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--paper); margin-top:3rem }
.val-item { background:var(--white); padding:2.5rem 2.1rem; transition:background .3s; position:relative }
.val-item::after {
  content:''; position:absolute; left:0; top:0; width:2px; height:0; background:var(--accent);
  transition:height .5s var(--ease);
}
.val-item:hover { background:var(--bg-deep) }
.val-item:hover::after { height:100% }
.val-num { font-family:var(--mono); font-weight:500; font-size:1.55rem; color:var(--accent); line-height:1; margin-bottom:1rem; letter-spacing:-.02em }
.val-title { font-weight:700; font-size:1rem; margin-bottom:.4rem; letter-spacing:-.015em }
.val-body { font-size:.88rem; color:var(--mid); line-height:1.75 }

/* ══ IMAGE REVEAL ═══════════════════════════════════════════ */
.img-reveal { opacity:0; transform:translateY(32px) scale(.985); transition:opacity 1s var(--ease),transform 1s var(--ease) }
.img-reveal.revealed { opacity:1; transform:none }
.img-reveal-left { opacity:0; transform:translateX(-52px); transition:opacity 1s var(--ease),transform 1s var(--ease) }
.img-reveal-left.revealed { opacity:1; transform:none }
.img-reveal-right { opacity:0; transform:translateX(52px); transition:opacity 1s var(--ease),transform 1s var(--ease) }
.img-reveal-right.revealed { opacity:1; transform:none }
@keyframes kenBurns { 0%{transform:scale(1) translate(0,0)} 50%{transform:scale(1.07) translate(-1.5%,-1%)} 100%{transform:scale(1.05) translate(1%,.5%)} }
.kb-image { animation:kenBurns 14s ease-in-out infinite alternate; transform-origin:center }
.stagger-grid > * { opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease),transform .8s var(--ease) }
.stagger-grid > *.stagger-in { opacity:1; transform:none }

/* ══ WHATSAPP ═══════════════════════════════════════════════ */
.whatsapp-btn {
  position:fixed; bottom:2rem; right:2rem; z-index:150;
  width:54px; height:54px; border-radius:50%; background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; box-shadow:0 6px 24px rgba(37,211,102,.32);
  transition:transform .3s,box-shadow .3s; animation:fadeUp .6s 1s ease both;
}
.whatsapp-btn:hover { transform:scale(1.1) rotate(-6deg); box-shadow:0 10px 36px rgba(37,211,102,.45) }

/* ══ COOKIE ══════════════════════════════════════════════════ */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:300;
  background:var(--white); border-top:2px solid var(--accent);
  padding:1.4rem 6rem;
  transform:translateY(100%); transition:transform .45s ease; display:none;
  box-shadow:0 -6px 36px rgba(20,15,10,.08);
}
.cookie-banner.show { display:block }
.cookie-banner.visible { transform:translateY(0) }
.cookie-inner { max-width:1080px; margin:0 auto; display:flex; align-items:center; gap:2rem; justify-content:space-between; flex-wrap:wrap }
.cookie-inner p { font-size:.86rem; color:var(--mid); max-width:620px; line-height:1.6 }
.cookie-ok {
  font-family:var(--font); font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  padding:.6rem 1.5rem; background:var(--black); color:var(--white); border:1px solid var(--black);
  cursor:pointer; white-space:nowrap; transition:background .25s, border-color .25s;
}
.cookie-ok:hover { background:var(--accent); border-color:var(--accent) }
.cookie-refuse {
  font-family:var(--font); font-size:.72rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  padding:.55rem 1.1rem; background:transparent; color:var(--muted); border:1px solid var(--paper);
  cursor:pointer; white-space:nowrap; transition:color .25s, border-color .25s;
}
.cookie-refuse:hover { color:var(--black); border-color:var(--mid) }

/* ══ FOOTER ══════════════════════════════════════════════════ */
footer {
  padding:2.25rem 6rem; border-top:1px solid var(--paper);
  background:var(--white); position:relative; z-index:1;
}
.footer-inner { max-width:1080px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:2rem }
.footer-copy { font-family:var(--mono); font-size:.66rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted); margin-bottom:.55rem }
.footer-links { display:flex; gap:1.6rem; flex-wrap:wrap }
.footer-links a { font-family:var(--mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mid); text-decoration:none; transition:color .25s }
.footer-links a:hover { color:var(--accent) }
.back-top {
  width:40px; height:40px; border:1px solid var(--paper);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; color:var(--mid); font-size:.92rem;
  transition:background .25s,color .25s,border-color .25s, transform .25s; flex-shrink:0;
}
.back-top:hover { background:var(--accent); color:var(--white); border-color:var(--accent); transform:translateY(-3px) }

/* ══ SCROLL REVEAL ═══════════════════════════════════════════ */
.rv { opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease),transform .9s var(--ease) }
.rv.in { opacity:1; transform:none }
.rv.d1{transition-delay:.08s} .rv.d2{transition-delay:.16s} .rv.d3{transition-delay:.24s}
.rv.d4{transition-delay:.32s} .rv.d5{transition-delay:.40s}

/* ══ SCROLLBAR ═══════════════════════════════════════════════ */
::-webkit-scrollbar { width:4px; height:4px }
::-webkit-scrollbar-track { background:var(--bg) }
::-webkit-scrollbar-thumb { background:var(--paper); transition:background .3s }
::-webkit-scrollbar-thumb:hover { background:var(--accent) }

/* ══ SCRAMBLE ════════════════════════════════════════════════ */
.scrambling { display:inline-block }

/* ══ MODAL PROJET ════════════════════════════════════════════ */
.proj-modal {
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  padding:1.5rem; pointer-events:none; opacity:0;
  transition:opacity .35s ease;
}
.proj-modal.open { opacity:1; pointer-events:all }
.proj-modal-backdrop {
  position:absolute; inset:0;
  background:rgba(20,15,10,.4); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
}
.proj-modal-card {
  position:relative; z-index:1; background:var(--white);
  border:1px solid var(--paper); box-shadow:0 32px 100px rgba(20,15,10,.18);
  width:100%; max-width:880px; max-height:90vh; overflow-y:auto;
  transform:translateY(28px) scale(.97);
  transition:transform .45s var(--ease);
}
.proj-modal.open .proj-modal-card { transform:none }
.proj-modal-card::-webkit-scrollbar { width:3px }
.proj-modal-card::-webkit-scrollbar-thumb { background:var(--paper) }

.proj-modal-head {
  display:flex; align-items:flex-start; justify-content:space-between;
  padding:2.25rem 2.75rem 1.5rem;
  border-bottom:1px solid var(--paper);
  position:sticky; top:0; background:var(--white); z-index:2;
}
.proj-modal-cat {
  font-family:var(--mono);
  font-size:.62rem; font-weight:500; letter-spacing:.25em;
  text-transform:uppercase; color:var(--accent); display:block; margin-bottom:.4rem;
}
.proj-modal-title { font-weight:900; font-size:1.6rem; letter-spacing:-.025em }
.proj-modal-close {
  background:none; border:1px solid var(--paper); width:36px; height:36px;
  border-radius:50%; font-size:.9rem; cursor:none; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; color:var(--mid);
  transition:background .25s, border-color .25s, color .25s, transform .3s;
  margin-left:1rem; margin-top:.2rem;
}
.proj-modal-close:hover { background:var(--accent); color:var(--white); border-color:var(--accent); transform:rotate(90deg) }

.proj-modal-body { padding:2rem 2.75rem 2.75rem }
.proj-modal-desc {
  font-size:.96rem; color:var(--mid); line-height:1.85;
  margin-bottom:2.5rem; border-left:2px solid var(--accent); padding-left:1.5rem;
}
.proj-modal-cols { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; margin-bottom:2.5rem }
.proj-modal-section-title {
  font-family:var(--mono);
  font-size:.65rem; font-weight:500; letter-spacing:.22em;
  text-transform:uppercase; color:var(--mid); margin-bottom:1.25rem;
}
.proj-results-list { list-style:none }
.proj-results-list li {
  display:flex; justify-content:space-between; align-items:center;
  padding:.6rem 0; border-bottom:1px solid var(--paper); font-size:.92rem;
}
.proj-results-list li:last-child { border-bottom:none }
.proj-res-val { font-weight:900; font-size:1.15rem; color:var(--accent); letter-spacing:-.02em }
.proj-res-lbl { color:var(--mid); font-size:.85rem }
.proj-livrables { list-style:none }
.proj-livrables li {
  font-size:.9rem; padding:.55rem 0; border-bottom:1px solid var(--paper);
  display:flex; align-items:center; gap:.8rem; color:var(--black);
}
.proj-livrables li::before { content:'✓'; color:var(--accent); font-weight:700; font-size:.9rem; flex-shrink:0 }

.proj-gallery { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:.75rem }
.proj-thumb {
  width:54px; height:54px; object-fit:cover;
  border:1px solid var(--paper); cursor:none;
  transition:transform .25s, border-color .25s; flex-shrink:0;
}
.proj-thumb:hover { transform:scale(1.1); border-color:var(--accent) }
.proj-thumb-placeholder {
  width:54px; height:54px; background:var(--bg-deep); border:1px solid var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:.55rem; font-weight:500;
  letter-spacing:.05em; color:var(--mid);
}

.proj-main-img { width:100%; height:260px; object-fit:cover; border:1px solid var(--paper); display:block; margin-bottom:1rem; transition:opacity .35s }
.proj-modal-cta { display:flex; gap:.75rem; flex-wrap:wrap; padding-top:2rem; border-top:1px solid var(--paper) }

/* ══ STRIP HINT ══════════════════════════════════════════════ */
.strip-hint {
  position:absolute; bottom:3rem; right:.85rem;
  font-family:var(--mono);
  font-size:.6rem; font-weight:500; letter-spacing:.15em; text-transform:uppercase;
  padding:.25rem .65rem; background:var(--accent); color:var(--white);
  opacity:0; transition:opacity .3s; pointer-events:none;
}
.strip-item:hover .strip-hint { opacity:1 }

/* ══ SHARE BUTTONS ═══════════════════════════════════════════ */
.share-btn {
  display:inline-flex; align-items:center; justify-content:center;
  width:34px; height:34px; border:1px solid var(--paper); background:var(--white);
  font-family:var(--font); font-size:.74rem; font-weight:700;
  text-decoration:none; color:var(--mid); cursor:pointer;
  transition:background .25s,color .25s,border-color .25s, transform .2s;
}
.share-btn:hover { background:var(--accent); color:var(--white); border-color:var(--accent); transform:translateY(-2px) }

/* ══ READING META BAR ════════════════════════════════════════ */
.article-meta-bar {
  display:flex; align-items:center; gap:1.6rem; flex-wrap:wrap;
  padding:.85rem 0; border-bottom:1px solid var(--paper); margin-bottom:2rem;
  font-family:var(--mono); font-size:.7rem; color:var(--mid); letter-spacing:.06em;
}

/* ══ VIDEO ══════════════════════════════════════════════════ */
.video-wrap {
  position:relative; padding-bottom:56.25%; height:0; overflow:hidden;
  background:var(--black); margin:2rem 0; border:1px solid var(--paper);
}
.video-wrap iframe,
.video-wrap video {
  position:absolute; top:0; left:0;
  width:100%; height:100%; border:none; display:block;
}
.video-wrap video { background:var(--black) }

/* ══ RESPONSIVE ══════════════════════════════════════════════ */
@media(max-width:1100px){
  nav { padding:1rem 2rem }
  nav.scrolled { padding:.8rem 2rem }
  .cookie-banner { padding:1.2rem 2rem }
  footer { padding:1.75rem 2rem }
  .nav-links,.nav-cta { display:none }
  .burger { display:flex }
  body { cursor:auto; font-size:17px }
  #cur,#cur-ring { display:none }
  .hero { padding:110px 2rem 3.5rem }
  .hero-layout { grid-template-columns:1fr }
  .hero-strip { grid-template-columns:1fr 1fr }
  .t-grid { grid-template-columns:1fr; gap:0 }
  .p-grid { grid-template-columns:1fr; border:none; gap:1px }
  .p-card { border:1px solid var(--paper) }
  .section { padding:5rem 2rem }
  .testi-section { padding:5rem 2rem }
  .port-slider { padding:0 2rem 2rem }
  .img-strip { padding:0 2rem }
  .blog-grid { grid-template-columns:1fr 1fr }
  .process-grid { grid-template-columns:1fr 1fr }
  .values-grid { grid-template-columns:1fr }
  .split-section { grid-template-columns:1fr }
  .split-img { min-height:300px; position:relative }
  .split-content { padding:3rem 2rem }
  .svc-modal-cols { grid-template-columns:1fr }
}
@media(max-width:640px){
  .h-title { font-size:3rem }
  .hero-strip { grid-template-columns:1fr 1fr }
  .svc-item { grid-template-columns:50px 1fr }
  .svc-price-wrap { display:none }
  .f-row { grid-template-columns:1fr }
  .blog-grid { grid-template-columns:1fr }
  .process-grid { grid-template-columns:1fr }
  .t-grid { grid-template-columns:1fr }
  footer .footer-inner { flex-direction:column; align-items:flex-start }
  .whatsapp-btn { bottom:1.25rem; right:1.25rem }
  .strip-item { flex:0 0 270px; height:190px }
  .svc-modal-card { max-height:95vh }
  .svc-modal-head,.svc-modal-body { padding:1.5rem }
}

/* ══ MOBILE CTA SPACING ══════════════════════════════════════ */
@media(max-width:480px){
  .btn-row { flex-direction:column }
  .btn-row .btn-black, .btn-row .btn-outline { text-align:center; justify-content:center }
  nav { padding:.85rem 1.25rem }
  .hero-sub { font-size:.94rem }
}

/* ══ REDUCE MOTION ═══════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .hero::before { animation: none !important }
  .kb-image { animation: none !important }
}
