/* ================================================
WEBMOTIC v6 — Editorial Luxe
Cormorant Garamond + Manrope
Accent : vert sauge
================================================ */

:root {
  --bg: #faf9f7;
  --bg-alt: #f2f0eb;
  --fg: #141210;
  --fg-mid: #4a4540;
  --fg-muted: #9a948a;
  --accent: #3d6b4f;
  --accent-h: #4d8562;
  --accent-dim: rgba(61,107,79,0.09);
  --line: rgba(20,18,16,0.1);
  --nav-h: 68px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --ease-out: cubic-bezier(0,0,0.2,1);
}

body.dark {
  --bg: #0d0d0b;
  --bg-alt: #111110;
  --fg: #ede9e0;
  --fg-mid: #a09888;
  --fg-muted: #5a5448;
  --accent: #5a9e72;
  --accent-h: #6ab882;
  --accent-dim: rgba(90,158,114,0.1);
  --line: rgba(237,233,224,0.08);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: 'Manrope', sans-serif;
  line-height: 1.65;
  overflow-x: hidden;
  transition: background .4s var(--ease), color .4s var(--ease);
}
img, svg { display:block; max-width:100%; }
a { text-decoration:none; color:inherit; }

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

/* ── TYPO ── */
h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(3.2rem, 8.5vw, 9rem);
  font-weight: 300;
  line-height: .93;
  letter-spacing: -.035em;
}
h1 em { font-style:italic; color:var(--accent); }

h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.4rem, 5vw, 4.8rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -.025em;
}
h2 em { font-style:italic; }

h3 {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
}

/* ── CONTAINER ── */
.container { max-width:1280px; margin:0 auto; padding:0 48px; }
@media(max-width:768px){ .container{ padding:0 24px; } }

/* ══════════════════════════════════
HEADER
══════════════════════════════════ */
header {
  position:fixed; top:0; left:0; right:0; height:var(--nav-h);
  background: rgba(250,249,247,.93);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid var(--line);
  z-index:1000;
  transition: background .4s var(--ease), box-shadow .3s;
}
body.dark header { background: rgba(13,13,11,.95); }
header.scrolled { box-shadow: 0 4px 32px rgba(0,0,0,.07); }

nav {
  max-width:1280px; margin:0 auto; padding:0 48px;
  height:100%; display:flex; align-items:center; justify-content:space-between;
}
@media(max-width:768px){ nav{ padding:0 20px; } }

/* Logo */
.logo { display:flex; align-items:center; gap:10px; color:var(--fg); }
.logo-wm {
  font-family:'Cormorant Garamond', serif;
  font-style:italic; font-size:1rem; font-weight:600;
  width:32px; height:32px; border-radius:7px;
  background:var(--fg); color:var(--bg);
  display:flex; align-items:center; justify-content:center;
  transition: background .4s, color .4s;
  flex-shrink:0;
}
.logo-text { font-size:.9rem; font-weight:700; letter-spacing:.05em; }

/* Nav links */
.nav-links { list-style:none; display:flex; align-items:center; gap:2px; }
.nav-links a {
  font-size:.82rem; font-weight:500; color:var(--fg-muted);
  padding:8px 14px; border-radius:100px;
  transition: color .2s, background .2s;
}
.nav-links a:hover { color:var(--fg); background:var(--accent-dim); }
.nav-cta {
  color:var(--bg) !important; background:var(--fg) !important;
  font-weight:600 !important; margin-left:10px;
}
.nav-cta:hover { background:var(--accent) !important; }

/* Right controls */
.nav-right { display:flex; align-items:center; gap:8px; }

.theme-btn {
  background:none; border:1px solid var(--line);
  border-radius:100px; width:36px; height:36px;
  color:var(--fg-muted); font-size:.95rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition: all .2s;
}
.theme-btn:hover { background:var(--accent-dim); color:var(--fg); }

.burger {
  display:none; flex-direction:column; justify-content:center;
  gap:6px; width:36px; height:36px;
  background:none; border:none; cursor:pointer; padding:7px;
}
.burger span { display:block; height:1.5px; background:var(--fg); transition: all .3s var(--ease); }
.burger.open span:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.burger.open span:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

@media(max-width:768px){
  .nav-links {
    display:none; flex-direction:column; align-items:stretch;
    position:fixed; top:var(--nav-h); left:0; right:0;
    background:var(--bg); border-bottom:1px solid var(--line);
    padding:16px 24px 24px; gap:4px; z-index:999;
    transition: background .4s;
  }
  .nav-links.active { display:flex; }
  .nav-links li a { border-radius:10px; padding:10px 14px; }
  .nav-links .nav-cta { margin-left:0; margin-top:8px; justify-content:center; }
  .burger { display:flex; }
}

/* ══════════════════════════════════
HERO
══════════════════════════════════ */
.hero {
  min-height:100svh;
  padding: calc(var(--nav-h) + 72px) 48px 64px;
  max-width:1280px; margin:0 auto;
  display:flex; flex-direction:column; justify-content:space-between; gap:48px;
}

/* Eyebrow */
.hero-eyebrow {
  display:flex; align-items:center; gap:10px;
  font-size:.7rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--fg-muted); width:fit-content;
}
.dot-pulse {
  width:7px; height:7px; border-radius:50%; background:var(--accent);
  animation: blink 2s ease-in-out infinite;
}
@keyframes blink {
  0%,100% { box-shadow:0 0 0 0 rgba(61,107,79,.5); }
  50% { box-shadow:0 0 0 9px rgba(61,107,79,0); }
}
body.dark .dot-pulse { animation-name:blink-d; }
@keyframes blink-d {
  0%,100% { box-shadow:0 0 0 0 rgba(90,158,114,.5); }
  50% { box-shadow:0 0 0 9px rgba(90,158,114,0); }
}

/* Title + aside */
.hero-content {
  display:grid; grid-template-columns:1fr 320px; gap:48px; align-items:flex-end;
}
.h1-line { display:block; }
.h1-indent { padding-left:clamp(40px, 8vw, 120px); }

.hero-aside { display:flex; flex-direction:column; gap:28px; padding-bottom:6px; }
.hero-sub { font-size:1rem; font-weight:300; color:var(--fg-mid); line-height:1.85; }
.hero-actions { display:flex; flex-direction:column; gap:10px; }

@media(max-width:768px){
  .hero { padding: calc(var(--nav-h) + 48px) 24px 48px; }
  .hero-content { grid-template-columns: 1fr !important; gap: 28px; }
  .hero-aside { padding-bottom: 0; }
  .hero-bottom { flex-direction: column; gap: 28px; align-items: flex-start; }
  .stats { gap: 20px; }
}

/* Stats row */
.hero-bottom {
  display:flex; justify-content:space-between; align-items:flex-end;
  padding-top:32px; border-top:1px solid var(--line);
}
.stats { display:flex; align-items:center; gap:28px; }
.stat { display:flex; flex-direction:column; gap:3px; }
.stat strong {
  font-family:'Cormorant Garamond', serif;
  font-size:2.1rem; font-weight:300; line-height:1; color:var(--accent);
}
.stat span {
  font-size:.65rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--fg-muted);
}
.stat-sep { width:1px; height:38px; background:var(--line); }

/* Scroll indicator */
.scroll-indicator { display:flex; flex-direction:column; align-items:center; gap:6px; }
@media(max-width:768px){ .scroll-indicator { display:none !important; } }
.scroll-indicator > span {
  font-size:.58rem; letter-spacing:.15em; text-transform:uppercase;
  color:var(--fg-muted); writing-mode:vertical-lr;
}
.scroll-bar { width:1px; height:44px; background:var(--line); overflow:hidden; position:relative; }
.scroll-cursor {
  position:absolute; top:-100%; left:0; width:100%; height:100%; background:var(--accent);
  animation:scrollDown 1.9s ease-in-out infinite;
}
@keyframes scrollDown { to { transform:translateY(200%); } }

/* ══════════════════════════════════
MARQUEE
══════════════════════════════════ */
.marquee-wrap {
  overflow:hidden;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:15px 0; background:var(--bg-alt);
  transition: background .4s var(--ease);
}
.marquee-inner { display:flex; }
.marquee-track {
  display:flex; align-items:center; gap:24px; width:max-content;
  animation: marquee 24s linear infinite;
  font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--fg-muted);
}
.marquee-track em { color:var(--accent); font-style:normal; }
@keyframes marquee { to { transform:translateX(-50%); } }

/* ══════════════════════════════════
SECTIONS
══════════════════════════════════ */
.section { padding:120px 0; }
.section-alt { background:var(--bg-alt); transition:background .4s var(--ease); }

.section-label {
  display:flex; align-items:flex-start; gap:40px; margin-bottom:72px;
}
.label-num {
  font-family:'Cormorant Garamond', serif;
  font-size:.82rem; font-weight:300; color:var(--fg-muted); letter-spacing:.06em; padding-top:10px;
  flex-shrink:0;
}
@media(max-width:768px){
  .section { padding:80px 0; }
  .section-label { flex-direction:column; gap:8px; margin-bottom:44px; }
}

/* ══════════════════════════════════
SERVICES
══════════════════════════════════ */
.services-list { display:flex; flex-direction:column; }
.svc {
  display:grid; grid-template-columns:52px 1fr auto 28px;
  gap:28px; align-items:center;
  padding:28px 16px; border-bottom:1px solid var(--line);
  cursor:pointer; border-radius:10px;
  transition: background .25s, gap .25s;
}
.svc:first-child { border-top:1px solid var(--line); }
.svc:hover { background:var(--accent-dim); }
.svc:hover .svc-arrow { transform:translate(4px,-4px); color:var(--accent); }

.svc-index {
  font-family:'Cormorant Garamond', serif;
  font-size:1.5rem; font-weight:300; color:var(--fg-muted);
}
.svc-content h3 { margin-bottom:5px; }
.svc-content p { font-size:.87rem; font-weight:300; color:var(--fg-mid); line-height:1.75; max-width:420px; }
.svc-tags { display:flex; gap:7px; flex-wrap:wrap; justify-content:flex-end; }
.svc-tags span {
  font-size:.66rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 12px; border-radius:100px; border:1px solid var(--line); color:var(--fg-muted);
}
.svc-arrow { font-size:1.1rem; color:var(--fg-muted); transition:transform .25s, color .25s; }

@media(max-width:900px){
  .svc { grid-template-columns:40px 1fr 24px; }
  .svc-tags { display:none; }
}
@media(max-width:600px){
  .svc { grid-template-columns:1fr 24px; gap:16px; }
  .svc-index { display:none; }
}

/* ══════════════════════════════════
PORTFOLIO — grandes cartes
══════════════════════════════════ */

.portfolio-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.pf-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 20px;
  overflow: hidden;
  min-height: 420px;
  cursor: pointer;
  transition: transform .45s var(--ease), box-shadow .45s var(--ease);
  text-decoration: none;
}

.pf-card:first-child {
  grid-column: 1 / -1;
  min-height: 500px;
}

.pf-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 32px 80px rgba(0,0,0,.18);
}

.pf-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.pf-card-bg {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.pf-card--wood .pf-card-bg {
  background: linear-gradient(135deg, #d4a96a 0%, #8b5e2e 40%, #5c3a1e 100%);
}

.pf-card--wood .pf-card-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 40%, rgba(255,220,160,.2) 0%, transparent 70%),
    repeating-linear-gradient(
      100deg,
      transparent 0px,
      transparent 3px,
      rgba(0,0,0,.04) 3px,
      rgba(0,0,0,.04) 4px
    );
}

.pf-card--dark .pf-card-bg {
  background: linear-gradient(140deg, #0a1628 0%, #0f2d1a 50%, #0a0a0a 100%);
}

.pf-card--dark .pf-card-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 70% at 70% 30%, rgba(61,107,79,.35) 0%, transparent 60%),
    radial-gradient(ellipse 30% 40% at 20% 80%, rgba(30,80,50,.2) 0%, transparent 50%);
}

.pf-card--rose .pf-card-bg {
  background: linear-gradient(135deg, #f5c6d8 0%, #d4789a 45%, #a0395c 100%);
}

.pf-card--rose .pf-card-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 65% at 75% 35%, rgba(255,255,255,.15) 0%, transparent 60%),
    radial-gradient(ellipse 35% 50% at 15% 85%, rgba(80,0,40,.15) 0%, transparent 50%);
}

.pf-card-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: 28px 32px;
  background: transparent;
}

.pf-card-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pf-badge {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: rgba(255,255,255,.18);
  color: #fff;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.25);
  padding: 5px 14px;
  border-radius: 100px;
}

.pf-year {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 300;
  font-style: italic;
  color: rgba(255,255,255,.55);
}

.pf-card-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: auto;
}

.pf-card-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.pf-card-tags span {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
  border: 1px solid rgba(255,255,255,.2);
  padding: 3px 10px;
  border-radius: 100px;
}

.pf-card-title {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pf-sector {
  font-size: .72rem;
  font-weight: 400;
  letter-spacing: .06em;
  color: rgba(255,255,255,.55);
}

.pf-card-title h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 400;
  letter-spacing: -.02em;
  color: #fff;
  text-transform: none;
  line-height: 1.05;
}

.pf-desc {
  font-size: .84rem;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(255,255,255,.7);
  max-width: 520px;
}

.pf-card-footer {
  margin-top: 20px;
}

.pf-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.35);
  padding-bottom: 2px;
  cursor: pointer;
  transition: gap .25s, border-color .25s, transform .3s ease;
}

.pf-card:hover .pf-cta {
  gap: 10px;
  border-color: rgba(255,255,255,.8);
}

.pf-cta:hover {
  transform: translateX(6px);
}

@media(max-width:900px){
  .portfolio-grid {
    grid-template-columns: 1fr;
  }

  .pf-card:first-child {
    grid-column: 1;
  }

  .pf-card {
    min-height: 360px;
  }

  .pf-card-content {
    padding: 22px 24px;
  }
}

@media(max-width:600px){
  .pf-card {
    min-height: 300px;
  }

  .pf-card-title h3 {
    font-size: 1.6rem;
  }
}

/* ══════════════════════════════════
TARIFS
══════════════════════════════════ */
.pricing-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:stretch;
}
@media(max-width:900px){ .pricing-grid{ grid-template-columns:1fr; max-width:400px; } }

.price-card {
  background:var(--bg); border:1px solid var(--line);
  border-radius:18px; padding:36px 28px;
  display:flex; flex-direction:column; gap:22px; position:relative;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .4s;
}
.price-card:hover { transform:translateY(-5px); box-shadow:0 16px 48px rgba(0,0,0,.1); }

.price-card--star {
  background:var(--fg) !important;
  border-color:transparent !important;
}
.price-card--star h3 { color: rgba(255,255,255,.8) !important; }
.price-card--star .price-val strong { color:var(--bg); }
.price-card--star ul li { color: rgba(255,255,255,.9) !important; }
.price-card--star ul li::before { background: rgba(255,255,255,.7) !important; }

.price-badge {
  position:absolute; top:-12px; left:24px;
  background:var(--accent); color:#fff;
  font-size:.62rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  padding:4px 14px; border-radius:100px;
}

.price-top { display:flex; flex-direction:column; gap:8px; }
.price-val { display:flex; align-items:flex-start; gap:3px; line-height:1; }
.price-val strong {
  font-family:'Cormorant Garamond', serif;
  font-size:3.8rem; font-weight:300; letter-spacing:-.04em; line-height:1;
}
.price-val span { font-size:.82rem; color:var(--fg-muted); padding-top:9px; }
.price-card--star .price-val span { color: rgba(255,255,255,.75) !important; }

.price-card ul { list-style:none; display:flex; flex-direction:column; gap:10px; flex:1; }
.price-card ul li {
  font-size:.86rem; font-weight:300; color:var(--fg-mid);
  display:flex; align-items:center; gap:10px;
}
.price-card ul li::before {
  content:''; width:4px; height:4px; border-radius:50%;
  background:var(--accent); flex-shrink:0;
}

/* ══════════════════════════════════
CONTACT
══════════════════════════════════ */
.contact-layout { display:grid; grid-template-columns:340px 1fr; gap:80px; align-items:flex-start; }
@media(max-width:900px){ .contact-layout{ grid-template-columns:1fr; gap:48px; } }

.contact-left { display:flex; flex-direction:column; gap:22px; }
.contact-intro { font-size:1rem; font-weight:300; color:var(--fg-mid); line-height:1.85; }
.contact-email {
  font-family:'Cormorant Garamond', serif;
  font-size:1.45rem; font-weight:300; font-style:italic;
  color:var(--accent); transition:color .2s;
}
.contact-email:hover { color:var(--accent-h); }
.contact-note {
  display:flex; gap:12px; padding:16px 18px;
  border:1px solid var(--line); border-radius:14px;
  background:var(--bg); transition:background .4s;
}
.note-icon { color:var(--accent); flex-shrink:0; padding-top:3px; font-size:.9rem; }
.contact-note p { font-size:.82rem; font-weight:300; color:var(--fg-muted); line-height:1.75; }

/* Form */
form { display:flex; flex-direction:column; gap:15px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:15px; }
@media(max-width:600px){ .form-row{ grid-template-columns:1fr; } }

.form-field { display:flex; flex-direction:column; gap:7px; }
.form-field label {
  font-size:.67rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--fg-muted);
}

input, textarea, select {
  width:100%; padding:13px 16px;
  background:var(--bg); color:var(--fg);
  border:1px solid var(--line); border-radius:12px;
  font-family:'Manrope', sans-serif; font-size:.9rem; font-weight:300;
  outline:none;
  transition: border-color .2s, box-shadow .2s, background .4s, color .4s;
}
input::placeholder, textarea::placeholder { color:var(--fg-muted); }
input:focus, textarea:focus, select:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-dim);
}
textarea { resize:vertical; min-height:120px; }

#form-status {
  font-size:.84rem; font-weight:500; text-align:center;
  padding:8px; min-height:32px;
}

/* ══════════════════════════════════
   BUTTONS
══════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 26px; border-radius:100px;
  font-family:'Manrope', sans-serif;
  font-size:.82rem; font-weight:700; letter-spacing:.04em;
  border:1.5px solid transparent;
  cursor:pointer; transition:all .25s var(--ease); white-space:nowrap;
  text-decoration:none;
}
.btn-primary { background:var(--fg); color:var(--bg); border-color:var(--fg); }
.btn-primary:hover { background:var(--accent); border-color:var(--accent); transform:translateY(-2px); box-shadow:0 10px 28px rgba(61,107,79,.22); }
.btn-outline { background:transparent; color:var(--fg); border-color:var(--line); }
.btn-outline:hover { border-color:var(--fg); transform:translateY(-2px); }
.btn-ghost { background:none; border:none; color:var(--accent); padding:0; font-size:.82rem; font-weight:600; cursor:pointer; }
.btn-ghost:hover { color:var(--accent-h); }
.btn-full { width:100%; }

/*
══════════════════════════════════
FOOTER
══════════════════════════════════ */
footer {
  padding:48px 0; border-top:1px solid var(--line);
  background:var(--bg); transition:background .4s;
}
.footer-inner {
  display:flex; flex-direction:column; align-items:center;
  gap:10px; text-align:center;
}
.footer-inner > p { font-size:.84rem; color:var(--fg-muted); font-weight:300; }
.footer-copy { font-size:.72rem !important; }

/* ══════════════════════════════════
REVEAL SCROLL
══════════════════════════════════ */
.reveal {
  opacity:0; transform:translateY(24px);
  transition: opacity .6s var(--ease-out) var(--delay,0s),
              transform .6s var(--ease-out) var(--delay,0s);
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ══════════════════════════════════
À PROPOS
══════════════════════════════════ */
.about-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 80px;
  align-items: flex-start;
}
.about-visual {
  display: flex; flex-direction: column; gap: 28px;
  position: sticky; top: calc(var(--nav-h) + 24px);
}
.about-avatar { position: relative; }
.avatar-shape {
  width: 100%; aspect-ratio: 1; border-radius: 28px;
  background: linear-gradient(140deg, var(--fg) 0%, #2a2520 100%);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
}
.avatar-shape::before {
  content: ''; position: absolute; inset: 0; border-radius: 28px;
  background: radial-gradient(ellipse 60% 70% at 30% 20%, rgba(61,107,79,.25) 0%, transparent 60%);
}
.avatar-initial {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(6rem, 10vw, 9rem);
  font-weight: 300; font-style: italic;
  color: rgba(255,255,255,.15); line-height: 1; position: relative; z-index: 1;
}
.avatar-badge {
  position: absolute; bottom: -16px; right: -16px;
  background: var(--bg); border: 1px solid var(--line);
  border-radius: 14px; padding: 12px 16px;
  display: flex; align-items: center; gap: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,.08);
  transition: background .4s;
}
.avatar-badge span { color: var(--accent); font-size: 1rem; }
.avatar-badge p { font-size: .72rem; font-weight: 600; line-height: 1.4; color: var(--fg-mid); }

.about-skills {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 32px;
}
.about-skills span {
  font-size: .68rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase;
  padding: 6px 14px; border-radius: 100px;
  border: 1px solid var(--line); color: var(--fg-muted);
  transition: border-color .2s, color .2s, background .2s;
}
.about-skills span:hover {
  border-color: var(--accent); color: var(--accent); background: var(--accent-dim);
}

.about-text { display: flex; flex-direction: column; gap: 40px; }
.about-block { display: flex; flex-direction: column; gap: 12px; }
.about-block h3 { color: var(--fg); }
.about-block p { font-size: .95rem; font-weight: 300; color: var(--fg-mid); line-height: 1.85; }
.about-cta { align-self: flex-start; margin-top: 8px; }

@media(max-width: 960px) {
  .about-layout { grid-template-columns: 1fr; gap: 48px; }
  .about-visual { position: static; flex-direction: row; align-items: center; gap: 24px; }
  .avatar-shape { width: 120px; flex-shrink: 0; }
  .about-skills { margin-top: 0; }
  .avatar-badge { bottom: -12px; right: -12px; padding: 8px 12px; }
}
@media(max-width: 600px) {
  .about-visual { flex-direction: column; align-items: flex-start; }
  .avatar-shape { width: 100px; }
}

/*
══════════════════════════════════
LANGUAGE SWITCHER
══════════════════════════════════ */
.lang-switcher {
  display: flex; align-items: center; gap: 2px;
  background: var(--bg-alt); border: 1px solid var(--line);
  border-radius: 100px; padding: 3px;
  transition: background .4s;
}
.lang-btn {
  background: none; border: none; cursor: pointer;
  font-family: 'Manrope', sans-serif;
  font-size: .7rem; font-weight: 700; letter-spacing: .06em;
  color: var(--fg-muted);
  padding: 4px 10px; border-radius: 100px;
  transition: all .2s;
}
.lang-btn:hover { color: var(--fg); }
.lang-btn.active {
  background: var(--fg); color: var(--bg);
}

/* RTL pour l'arabe */
[dir="rtl"] .h1-indent { padding-left: 0; padding-right: clamp(40px, 8vw, 120px); }
[dir="rtl"] .hero-content { direction: rtl; }
[dir="rtl"] .section-label { flex-direction: row-reverse; }
[dir="rtl"] .svc { direction: rtl; }
[dir="rtl"] .svc-arrow { transform: rotate(180deg); }
[dir="rtl"] .svc:hover .svc-arrow { transform: rotate(180deg) translate(-4px, 4px); }
[dir="rtl"] .about-layout { direction: rtl; }
[dir="rtl"] .contact-layout { direction: rtl; }
[dir="rtl"] .pf-card-top { flex-direction: row-reverse; }
[dir="rtl"] .pf-card-tags { flex-direction: row-reverse; }
[dir="rtl"] .avatar-badge { right: auto; left: -16px; }
[dir="rtl"] .price-badge { left: auto; right: 24px; }
[dir="rtl"] .nav-links { direction: rtl; }
[dir="rtl"] .stats { direction: rtl; }
[dir="rtl"] .about-cta { align-self: flex-end; }
[dir="rtl"] input, [dir="rtl"] textarea, [dir="rtl"] select { direction: rtl; text-align: right; }

@media(max-width: 768px) {
  .lang-switcher { gap: 1px; }
  .lang-btn { padding: 3px 7px; font-size: .65rem; }
}

/* ══════════════════════════════════
TÉMOIGNAGES
══════════════════════════════════ */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}

.review-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  transition: transform .3s, box-shadow .3s;
}

.review-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.08);
}

.review-card--accent {
  background: var(--fg);
  border-color: var(--fg);
}

.review-stars {
  font-size: 1rem;
  letter-spacing: 3px;
  color: var(--accent);
}
.review-card--accent .review-stars { color: #7fcb96; }

.review-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.1rem, 2vw, 1.3rem);
  font-style: italic;
  line-height: 1.65;
  color: var(--fg);
  margin: 0;
  flex: 1;
}
.review-card--accent .review-quote { color: var(--bg); }

.review-footer {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
  background: transparent;
}
.review-card--accent .review-footer {
  border-color: rgba(250,249,247,.15);
  background: transparent;
}

.review-name {
  font-family: 'Manrope', sans-serif;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--fg);
}
.review-card--accent .review-name { color: var(--bg); }

.review-role {
  font-size: .8rem;
  color: var(--fg-muted);
}
.review-card--accent .review-role { color: rgba(250,249,247,.55); }

[dir="rtl"] .review-footer { align-items: flex-end; }
[dir="rtl"] .review-quote { text-align: right; }

@media(max-width: 900px) {
  .reviews-grid { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
}

/* ===== LEGAL PAGES ===== */
.legal {
  max-width: 760px;
}
.legal h1 {
  font-family:'Cormorant Garamond', serif;
  font-size: 2.2rem;
  font-weight: 300;
  color: var(--fg);
  margin-bottom: 20px;
}
.legal h2 {
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-top: 32px;
}
.legal p {
  font-size: .92rem;
  font-weight: 300;
  line-height: 1.85;
  color: var(--fg-mid);
}
.legal-date {
  font-size: .75rem;
  color: var(--fg-muted);
  margin-bottom: 24px;
}
.legal-important {
  margin: 28px 0;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--accent-dim);
}
.legal-important p {
  color: var(--fg);
}

/* COOKIE BANNER */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: rgba(20,18,16,.95);
  backdrop-filter: blur(20px);
  padding: 16px 24px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: .85rem;
  line-height: 1.4;
}
.cookie-banner p { margin: 0; flex: 1; }
.cookie-banner a { color: #3d6b4f; text-decoration: underline; font-weight: 500; }
.cookie-banner button {
  background: #3d6b4f;
  color: white;
  border: none;
  padding: 8px 18px;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s;
}
.cookie-banner button:hover { background: #4d8562; }

