/* DA SILVA CANTO - Paysage / Toiture (dual theme) */
:root {
  --t-primary: #3D5A40;
  --t-primary-dark: #2A4A2D;
  --t-primary-deeper: #1B3520;
  --t-accent: #C7825F;
  --t-accent-light: #D9A185;
  --t-cream: #F5EFE2;
  --t-paper: #FBF8F1;
  --t-ink: #1A2620;
  --t-ink-2: #3D4D44;
  --t-ink-3: #6B776F;
  --t-line: rgba(26,38,32,.10);
  --shadow-sm: 0 2px 8px rgba(26,38,32,.06);
  --shadow: 0 8px 24px rgba(26,38,32,.10);
  --shadow-lg: 0 20px 48px rgba(26,38,32,.16);
  --header-h: 64px;
  --container: 1240px;
  --t-trans: 600ms;
}
@media (min-width: 1024px) { :root { --header-h: 80px; } }

[data-theme="toiture"] {
  --t-primary: #8B2D1F;
  --t-primary-dark: #6E2018;
  --t-primary-deeper: #4A1610;
  --t-accent: #D4A574;
  --t-accent-light: #E8C99B;
  --t-cream: #F4EEE4;
  --t-paper: #FCF9F4;
  --t-ink: #1F1612;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent; scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 16px); }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } html { scroll-behavior: auto; } }
body { font-family: 'Inter', -apple-system, system-ui, sans-serif; font-size: 16px; line-height: 1.65; color: var(--t-ink); background: var(--t-paper); -webkit-font-smoothing: antialiased; overflow-x: hidden; padding-bottom: calc(64px + env(safe-area-inset-bottom)); transition: background-color var(--t-trans) ease; }
@media (min-width: 1024px) { body { padding-bottom: 0; } }
img, svg { display: block; max-width: 100%; }
img { height: auto; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; color: inherit; }
button { background: 0; border: 0; cursor: pointer; }
ul, ol { list-style: none; }
::selection { background: var(--t-accent); color: white; }

/* SVG ICONS */
.ico { display: inline-block; vertical-align: middle; flex-shrink: 0; stroke-width: 2; }
.ico--sm { width: 16px; height: 16px; }
.ico--md { width: 22px; height: 22px; }
.ico--lg { width: 32px; height: 32px; }

/* Fallback gradients quand pas de photo */
.hero__bg--grad-j { background: radial-gradient(circle at 20% 30%, #5A7A55 0%, #3D5A40 40%, #1B3520 100%); }
.hero__bg--grad-t { background: radial-gradient(circle at 70% 30%, #C04929 0%, #8B2D1F 40%, #4A1610 100%); }
.hero__bg--grad-j::before, .hero__bg--grad-t::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(135deg, transparent 0 60px, rgba(255,255,255,.03) 60px 120px); }
.about__img-fb { position: absolute; inset: 0; }
.about__img-fb svg { width: 100%; height: 100%; display: block; }

/* MAP */
.map { padding: 80px 0 100px; background: var(--t-paper); transition: background-color var(--t-trans) ease; }
.map__wrap { position: relative; border-radius: 22px; overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--t-line); aspect-ratio: 16/10; max-width: 1100px; margin: 0 auto; isolation: isolate; }
@media (max-width: 640px) { .map__wrap { aspect-ratio: 4/5; } }
.map__frame { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; filter: saturate(.92) contrast(1.02); }
.map__pin { position: absolute; top: 28px; left: 28px; right: 28px; max-width: 360px; display: flex; gap: 14px; padding: 18px 20px; background: rgba(255,255,255,.95); backdrop-filter: blur(20px) saturate(180%); -webkit-backdrop-filter: blur(20px) saturate(180%); border-radius: 18px; box-shadow: 0 12px 32px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.6); z-index: 2; border: 1px solid rgba(255,255,255,.6); }
@media (max-width: 640px) { .map__pin { top: 16px; left: 16px; right: 16px; padding: 14px 16px; gap: 12px; } }
.map__pin-icon { display: grid; place-items: center; flex-shrink: 0; width: 48px; height: 48px; border-radius: 14px; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); color: white; box-shadow: 0 6px 14px color-mix(in oklab, var(--t-primary) 35%, transparent); }
.map__pin-c { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.map__pin-c strong { font-size: 15px; font-weight: 800; color: var(--t-ink); line-height: 1.2; }
.map__pin-c span { font-size: 13px; color: var(--t-ink-3); line-height: 1.4; }
.map__route { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; color: var(--t-primary); margin-top: 6px; }
.map__route:hover { color: var(--t-primary-dark); }
.map__route .ico { transition: transform .25s; }
.map__route:hover .ico { transform: translateX(3px); }

[data-show="jardins"], [data-show="toiture"] { display: none !important; }
[data-theme="jardins"] [data-show="jardins"],
[data-theme="toiture"] [data-show="toiture"] { display: revert !important; }
[data-theme="jardins"] .logo__m[data-show="jardins"],
[data-theme="toiture"] .logo__m[data-show="toiture"] { display: grid !important; }
[data-theme="jardins"] .hd__cta[data-show="jardins"],
[data-theme="toiture"] .hd__cta[data-show="toiture"] { display: inline-flex !important; }
[data-theme="jardins"] .stk__b[data-show="jardins"],
[data-theme="toiture"] .stk__b[data-show="toiture"] { display: flex !important; }
[data-theme="jardins"] .hero__bg[data-show="jardins"],
[data-theme="toiture"] .hero__bg[data-show="toiture"] { display: block !important; opacity: 1; }
[data-theme="jardins"] .gallery[data-show="jardins"],
[data-theme="toiture"] .gallery[data-show="toiture"] { display: grid !important; }
[data-theme="jardins"] .srv__g[data-show="jardins"],
[data-theme="toiture"] .srv__g[data-show="toiture"] { display: grid !important; }
[data-theme="jardins"] .sh[data-show="jardins"],
[data-theme="toiture"] .sh[data-show="toiture"] { display: block !important; }

.skip { position: fixed; top: -100px; left: 8px; background: var(--t-primary); color: white; padding: 10px 16px; border-radius: 8px; font-weight: 700; z-index: 1000; transition: top .2s; }
.skip:focus { top: 8px; }

.ct { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 20px; }
@media (min-width: 768px) { .ct { padding: 0 32px; } }

.sh { text-align: center; max-width: 720px; margin: 0 auto 40px; }
.eb { display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: .25em; text-transform: uppercase; color: var(--t-primary); padding: 6px 14px; border: 1.5px solid var(--t-primary); border-radius: 999px; margin-bottom: 16px; background: rgba(255,255,255,.6); }
.sh h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 6vw, 56px); line-height: 1.1; font-weight: 600; letter-spacing: -.02em; margin-bottom: 14px; color: var(--t-ink); }
.sh h2 em { font-style: italic; color: var(--t-primary); font-weight: 700; }
.sh p { color: var(--t-ink-3); font-size: clamp(15px, 1.8vw, 17px); line-height: 1.65; max-width: 580px; margin: 0 auto; }
.sh--lt h2 { color: white; }
.sh--lt .eb { color: var(--t-accent-light); border-color: rgba(255,255,255,.3); background: rgba(255,255,255,.05); }
.sh--lt p { color: rgba(255,255,255,.75); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 22px; border-radius: 999px; font-weight: 700; font-size: 15px; white-space: nowrap; cursor: pointer; transition: transform .25s, box-shadow .25s; min-height: 48px; }
.btn--w { width: 100%; }
.btn--p { background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); color: white; box-shadow: 0 6px 16px rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.1); }
.btn--p:hover { transform: translateY(-2px); box-shadow: 0 12px 24px rgba(0,0,0,.2); }
.btn--g { background: rgba(255,255,255,.12); color: white; border: 1.5px solid rgba(255,255,255,.3); backdrop-filter: blur(10px); }
.btn--g:hover { background: rgba(255,255,255,.2); border-color: rgba(255,255,255,.5); }

/* THEME SWITCH */
/* Theme switcher inside menu */
.tsw { display: inline-flex; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); border-radius: 999px; padding: 4px; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.tsw__b { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; font-size: 13px; font-weight: 700; color: rgba(255,255,255,.78); border-radius: 999px; transition: color .25s, background .25s, box-shadow .25s; white-space: nowrap; }
.tsw__b:hover { color: white; }
.tsw__b.is-active { color: white; background: linear-gradient(135deg, var(--t-accent), var(--t-accent-light)); box-shadow: 0 3px 10px color-mix(in oklab, var(--t-accent) 40%, transparent); }
.tsw__ico { display: inline-flex; }
.tsw__ico svg { width: 16px; height: 16px; }
@media (max-width: 1023px) { .nv:not(.is-on) .tsw { display: none; } }
@media (min-width: 1024px) { .tsw { margin-right: 8px; } }
@media (min-width: 768px) { .tsw__b { padding: 9px 18px; font-size: 14px; } .tsw__ico { font-size: 16px; } }

/* HEADER - frosted glass */
.hd { position: fixed; top: 0; left: 0; right: 0; height: var(--header-h); z-index: 100; transition: background .35s, box-shadow .35s, backdrop-filter .35s; background: linear-gradient(180deg, rgba(15,30,20,.55), rgba(15,30,20,.30)); backdrop-filter: saturate(160%) blur(14px); -webkit-backdrop-filter: saturate(160%) blur(14px); border-bottom: 1px solid rgba(255,255,255,.10); }
[data-theme="toiture"] .hd { background: linear-gradient(180deg, rgba(40,15,10,.55), rgba(40,15,10,.30)); }
.hd.is-scr { background: rgba(255,255,255,.78); backdrop-filter: saturate(180%) blur(22px); -webkit-backdrop-filter: saturate(180%) blur(22px); box-shadow: 0 1px 0 var(--t-line), 0 10px 28px rgba(26,38,32,.08); border-bottom-color: var(--t-line); }
[data-theme="toiture"] .hd.is-scr { background: rgba(252,249,244,.85); }
.hd__in { height: 100%; max-width: var(--container); margin: 0 auto; padding: 0 20px; display: flex; align-items: center; gap: 20px; }
@media (min-width: 768px) { .hd__in { padding: 0 32px; } }
.logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; color: white; transition: color .3s; }
.hd.is-scr .logo { color: var(--t-ink); }
.logo__m { width: 36px; height: 36px; border-radius: 10px; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); display: grid; place-items: center; box-shadow: 0 4px 10px rgba(0,0,0,.2); flex-shrink: 0; }
.logo__m svg { width: 22px; height: 22px; }
.logo__t { display: flex; flex-direction: column; line-height: 1.1; }
.logo__t b { font-family: 'Cormorant Garamond', serif; font-weight: 700; font-size: 17px; letter-spacing: -.01em; }
.logo__t em { font-style: normal; font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; opacity: .65; margin-top: 3px; }
.nv { display: none; margin-left: auto; gap: 24px; }
.nv a { font-weight: 600; font-size: 14px; color: rgba(255,255,255,.92); transition: color .2s; padding: 6px 0; }
.hd.is-scr .nv a { color: var(--t-ink); }
.nv a:hover { color: var(--t-accent-light); }
.hd.is-scr .nv a:hover { color: var(--t-primary); }
.nv-back { font-size: 12px !important; opacity: .7; }
.hd__cta { display: none; align-items: center; gap: 6px; padding: 10px 16px; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); color: white; border-radius: 999px; font-weight: 800; font-size: 13px; box-shadow: 0 4px 12px rgba(0,0,0,.2); transition: transform .2s; }
[data-theme="jardins"] .hd__cta[data-show="toiture"] { display: none !important; }
[data-theme="toiture"] .hd__cta[data-show="jardins"] { display: none !important; }
.hd__cta:hover { transform: translateY(-1px); }
.bg { margin-left: auto; width: 48px; height: 48px; display: grid; place-items: center; position: relative; color: white; z-index: 101; border-radius: 14px; transition: background .25s; }
.bg:hover, .bg:focus-visible { background: rgba(255,255,255,.12); }
.bg.is-on { background: rgba(255,255,255,.16); color: white; }
.hd.is-scr .bg { color: var(--t-ink); }
.hd.is-scr .bg.is-on { color: white; }
.bg span { position: absolute; width: 24px; height: 2.5px; background: currentColor; border-radius: 2px; transition: all .3s cubic-bezier(.4,0,.2,1); }
.bg span:nth-child(1) { top: 16px; }
.bg span:nth-child(2) { top: 23px; }
.bg span:nth-child(3) { top: 30px; }
.bg.is-on span:nth-child(1) { top: 23px; transform: rotate(45deg); }
.bg.is-on span:nth-child(2) { opacity: 0; transform: scale(0); }
.bg.is-on span:nth-child(3) { top: 23px; transform: rotate(-45deg); }
@media (min-width: 1024px) { .nv { display: flex; } [data-theme="jardins"] .hd__cta[data-show="jardins"], [data-theme="toiture"] .hd__cta[data-show="toiture"] { display: inline-flex; } .bg { display: none; } }
.nv.is-on { display: flex; position: fixed; inset: 0; background: linear-gradient(160deg, var(--t-primary-deeper) 0%, var(--t-primary) 70%, var(--t-primary-dark) 100%); flex-direction: column; justify-content: center; align-items: center; gap: 26px; padding: calc(80px + env(safe-area-inset-top, 0)) 24px calc(80px + env(safe-area-inset-bottom, 0)); z-index: 99; height: 100vh; height: 100dvh; -webkit-overflow-scrolling: touch; overflow-y: auto; }
.nv.is-on a { color: white !important; font-size: 26px; font-weight: 700; letter-spacing: -.01em; padding: 8px 24px; border-radius: 999px; transition: background .2s, transform .15s; }
.nv.is-on a:active { transform: scale(.96); background: rgba(255,255,255,.10); }
.nv.is-on .tsw { display: inline-flex; margin-bottom: 12px; padding: 5px; background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.18); }
.nv.is-on .tsw__b { padding: 10px 18px; font-size: 14px; }
body.lock { overflow: hidden; }

/* HERO */
.hero { position: relative; min-height: 92vh; min-height: 92svh; padding: calc(var(--header-h) + 60px) 0 80px; display: flex; align-items: center; color: white; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: 0; opacity: 0; transition: opacity .8s ease; }
[data-theme="jardins"] .hero__bg[data-show="jardins"], [data-theme="toiture"] .hero__bg[data-show="toiture"] { opacity: 1; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.6) 60%, rgba(0,0,0,.92) 100%); z-index: 1; }
.hero__in { position: relative; z-index: 2; width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 20px; }
@media (min-width: 768px) { .hero__in { padding: 0 32px; } }
.hero__eb { display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.22); border-radius: 999px; font-size: 12px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; backdrop-filter: blur(10px); margin-bottom: 20px; }
.dot { width: 7px; height: 7px; border-radius: 50%; background: var(--t-accent-light); box-shadow: 0 0 0 3px rgba(255,255,255,.15); }
.hero h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(44px, 9vw, 92px); line-height: .98; font-weight: 600; letter-spacing: -.025em; margin-bottom: 20px; }
.hero p { font-size: clamp(15px, 2vw, 18px); line-height: 1.6; color: rgba(255,255,255,.92); max-width: 600px; margin-bottom: 32px; }
.hero__cta { display: flex; flex-direction: column; gap: 10px; margin-bottom: 48px; }
@media (min-width: 480px) { .hero__cta { flex-direction: row; } }
.hero__feat { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.18); }
@media (min-width: 640px) { .hero__feat { grid-template-columns: repeat(4, 1fr); gap: 24px; } }
.hero__feat b { display: block; font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 5vw, 40px); line-height: 1; color: var(--t-accent-light); font-style: italic; font-weight: 600; }
.hero__feat span { display: block; font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.7); margin-top: 4px; }

/* SERVICES */
.srv { padding: 80px 0; background: var(--t-paper); transition: background-color var(--t-trans) ease; }
.srv__g { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 768px) { .srv__g { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
@media (min-width: 1024px) { .srv__g { grid-template-columns: repeat(3, 1fr); grid-auto-flow: dense; } .service-card--lg { grid-column: span 2; grid-row: span 2; } }
.service-card { background: white; padding: 28px 24px; border-radius: 22px; border: 1px solid var(--t-line); box-shadow: var(--shadow-sm); position: relative; transition: transform .35s, box-shadow .35s; }
.service-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.service-card--lg { padding: 36px 32px; background: linear-gradient(135deg, var(--t-cream) 0%, var(--t-paper) 100%); }
.service-card__ico { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 64px; margin-bottom: 18px; border-radius: 18px; background: linear-gradient(135deg, color-mix(in oklab, var(--t-primary) 14%, transparent), color-mix(in oklab, var(--t-primary) 5%, transparent)); color: var(--t-primary); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--t-primary) 18%, transparent); }
.service-card--lg .service-card__ico { width: 80px; height: 80px; border-radius: 22px; }
.service-card__ico .ico { width: 32px; height: 32px; }
.service-card--lg .service-card__ico .ico { width: 40px; height: 40px; }
.service-card__num { position: absolute; top: 24px; right: 24px; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; font-weight: 600; color: var(--t-primary); opacity: .4; }
.service-card h3 { font-family: 'Cormorant Garamond', serif; font-size: clamp(22px, 3vw, 28px); font-weight: 700; line-height: 1.15; margin-bottom: 10px; color: var(--t-ink); }
.service-card--lg h3 { font-size: clamp(26px, 3.5vw, 34px); }
.service-card p { color: var(--t-ink-3); font-size: 14px; line-height: 1.6; }
.service-card--lg p { font-size: 16px; }

/* WORKS / GALLERY */
.works { padding: 80px 0; background: linear-gradient(180deg, var(--t-primary-deeper) 0%, var(--t-primary-dark) 100%); color: white; transition: background var(--t-trans) ease; position: relative; overflow: hidden; }
.works::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(255,255,255,.06), transparent 50%); }
.gallery { position: relative; display: grid; grid-template-columns: 1fr; gap: 20px; margin-top: 28px; }
@media (min-width: 768px) { .gallery { grid-template-columns: repeat(3, 1fr); gap: 24px; } }
.gallery-item { position: relative; border-radius: 20px; overflow: hidden; aspect-ratio: 4/3; background: var(--t-cream); box-shadow: var(--shadow); cursor: pointer; transition: transform .35s, box-shadow .35s; display: block; }
.gallery-item:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s ease; }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.7) 100%); z-index: 1; }
.gallery-cap { position: absolute; bottom: 14px; left: 14px; right: 14px; z-index: 2; color: white; font-size: 13px; font-weight: 700; }

/* BEFORE / AFTER SLIDER */
.gallery-item--ba { grid-column: 1 / -1; aspect-ratio: auto; height: auto; }
.ba-slider { position: relative; aspect-ratio: 4/3; border-radius: 20px; overflow: hidden; user-select: none; -webkit-user-select: none; touch-action: pan-y; cursor: ew-resize; box-shadow: var(--shadow-lg); }
@media (min-width: 640px) { .ba-slider { aspect-ratio: 16/10; } }
@media (min-width: 1024px) { .ba-slider { aspect-ratio: 21/9; max-height: 560px; } }
.ba-slider img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; pointer-events: none; }
.ba-slider .ba-after { clip-path: inset(0 0 0 50%); will-change: clip-path; }
.ba-slider .ba-handle { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 3px; height: 100%; background: white; box-shadow: 0 0 0 1px rgba(0,0,0,.18), 0 2px 14px rgba(0,0,0,.45); cursor: ew-resize; z-index: 3; padding: 0; border: 0; pointer-events: none; }
.ba-slider .ba-handle::before { content: ''; position: absolute; top: 0; bottom: 0; left: -22px; right: -22px; }
.ba-slider .ba-handle span { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 52px; height: 52px; border-radius: 50%; background: white; color: var(--t-primary); display: grid; place-items: center; box-shadow: 0 6px 20px rgba(0,0,0,.35), inset 0 0 0 2px color-mix(in oklab, var(--t-primary) 18%, white); pointer-events: none; }
.ba-slider .ba-handle span svg { width: 22px; height: 22px; }
.ba-lbl { position: absolute; top: 16px; padding: 6px 12px; background: rgba(0,0,0,.72); color: white; font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; border-radius: 999px; backdrop-filter: blur(8px); z-index: 4; pointer-events: none; box-shadow: 0 4px 12px rgba(0,0,0,.25); }
.ba-lbl--b { left: 16px; }
.ba-lbl--a { right: 16px; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); }
.ba-slider .gallery-cap { position: absolute; bottom: 14px; left: 14px; right: 14px; z-index: 4; color: white; font-size: 13px; font-weight: 700; text-shadow: 0 2px 8px rgba(0,0,0,.5); }

/* ABOUT */
.about { padding: 80px 0; background: var(--t-cream); transition: background-color var(--t-trans) ease; }
.about__in { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; }
@media (min-width: 1024px) { .about__in { grid-template-columns: 1fr 1fr; gap: 64px; } }
.about__img { position: relative; border-radius: 22px; overflow: hidden; aspect-ratio: 4/5; box-shadow: var(--shadow-lg); }
.about__img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity .6s; opacity: 0; }
[data-theme="jardins"] .about__img img[data-show="jardins"], [data-theme="toiture"] .about__img img[data-show="toiture"] { opacity: 1; }
.about__sticker { position: absolute; bottom: 20px; right: 20px; z-index: 2; background: white; padding: 12px 18px; border-radius: 12px; font-family: 'Cormorant Garamond', serif; font-size: 16px; font-weight: 700; font-style: italic; color: var(--t-primary); line-height: 1.2; text-align: right; box-shadow: var(--shadow); transform: rotate(-2deg); }
.about__c h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 5vw, 44px); font-weight: 600; line-height: 1.1; letter-spacing: -.02em; margin-bottom: 14px; color: var(--t-ink); }
.about__c h2 em { font-style: italic; color: var(--t-primary); }
.about__c > p { color: var(--t-ink-3); font-size: clamp(15px, 1.8vw, 17px); margin-bottom: 24px; }
.abt-l { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 28px; }
.abt-l li { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 600; color: var(--t-ink-2); }
.abt-l span, .abt-l__c { display: grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); color: white; font-size: 12px; font-weight: 800; flex-shrink: 0; }
.abt-l__c .ico { width: 12px; height: 12px; }

/* CONTACT */
.ctc { padding: 80px 0; background: var(--t-paper); transition: background-color var(--t-trans) ease; }
.grid-4 { display: grid; grid-template-columns: 1fr; gap: 12px; margin-bottom: 32px; }
@media (min-width: 480px) { .grid-4 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .grid-4 { grid-template-columns: repeat(4, 1fr); } }
.cards { margin-bottom: 32px; }
.cc { display: flex; align-items: center; gap: 14px; padding: 16px 18px; background: white; border: 1px solid var(--t-line); border-radius: 14px; transition: transform .25s, border-color .25s, box-shadow .25s; box-shadow: var(--shadow-sm); }
.cc:hover { transform: translateY(-3px); border-color: var(--t-primary); box-shadow: var(--shadow); }
.cc__i { width: 42px; height: 42px; border-radius: 10px; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); color: white; display: grid; place-items: center; font-size: 18px; flex-shrink: 0; box-shadow: 0 3px 8px color-mix(in oklab, var(--t-primary) 30%, transparent); }
.cc__i svg { width: 22px; height: 22px; }
.stk__b svg { width: 20px; height: 20px; }
.stk__t { display: none; }
@media (min-width: 480px) { .stk__t { display: inline; } }
.tsw__ico svg { width: 16px; height: 16px; }
.cc__l { display: block; font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--t-ink-3); margin-bottom: 2px; }
.cc b { font-size: 14px; font-weight: 700; color: var(--t-ink); line-height: 1.3; word-break: break-word; }
.cc .em { font-size: 11px; }

.form { background: var(--t-cream); border-radius: 22px; padding: 28px 22px; border: 1px solid var(--t-line); box-shadow: var(--shadow-sm); }
@media (min-width: 768px) { .form { padding: 40px; } }
.form h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 700; margin-bottom: 22px; }
.row { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 600px) { .row { grid-template-columns: 1fr 1fr; } }
.form label { display: block; margin-bottom: 14px; font-size: 13px; font-weight: 700; color: var(--t-ink-2); }
.form input, .form select, .form textarea { display: block; width: 100%; margin-top: 6px; padding: 13px 14px; background: white; border: 1.5px solid transparent; border-radius: 12px; font-size: 16px; font-weight: 500; color: var(--t-ink); transition: border-color .2s, box-shadow .2s; font-family: inherit; }
.form input:focus, .form select:focus, .form textarea:focus { outline: none; border-color: var(--t-primary); box-shadow: 0 0 0 4px rgba(61,90,64,.12); }
.form textarea { resize: vertical; min-height: 90px; }
.note { text-align: center; font-size: 12px; color: var(--t-ink-3); margin-top: 14px; }

/* FOOTER */
.ft { background: linear-gradient(180deg, var(--t-primary-deeper), #0E1813); color: rgba(255,255,255,.75); padding: 56px 0 calc(40px + 80px); font-size: 13px; transition: background-image var(--t-trans); }
[data-theme="toiture"] .ft { background: linear-gradient(180deg, var(--t-primary-deeper), #1A0A06); }
.ft__g { display: grid; grid-template-columns: 1fr; gap: 32px; padding-bottom: 32px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 20px; }
@media (min-width: 640px) { .ft__g { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ft__g { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; } }
.ft .logo { color: rgba(255,255,255,.95); margin-bottom: 12px; }
.ft .logo__m { background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); }
.ft p { line-height: 1.6; }
.ft h4 { font-size: 11px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; color: var(--t-accent-light); margin-bottom: 14px; }
.ft ul li { margin-bottom: 8px; }
.ft a { transition: color .2s; }
.ft a:hover { color: var(--t-accent-light); }
.ft__b { display: flex; flex-direction: column; gap: 6px; align-items: center; text-align: center; font-size: 12px; color: rgba(255,255,255,.5); }
@media (min-width: 768px) { .ft__b { flex-direction: row; justify-content: space-between; text-align: left; } }

/* STICKY */
.stk { position: fixed; bottom: 0; left: 0; right: 0; display: flex; background: var(--t-primary-deeper); z-index: 90; padding-bottom: env(safe-area-inset-bottom, 0); box-shadow: 0 -4px 16px rgba(0,0,0,.18); transition: background-color var(--t-trans); transform: translateZ(0); -webkit-transform: translateZ(0); will-change: transform; }
.stk__b { flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 14px 8px; font-size: 13px; font-weight: 700; color: white; border-right: 1px solid rgba(255,255,255,.08); min-height: 52px; }
.stk__b:last-child { border-right: 0; }
.stk__b--call { flex: 2; background: linear-gradient(135deg, var(--t-primary), var(--t-primary-dark)); font-size: 14px; font-weight: 800; }
@media (min-width: 1024px) { .stk { display: none; } .ft { padding-bottom: 40px; } }

@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.hero__eb { animation: fadeUp .7s .1s both; }
.hero h1 { animation: fadeUp .8s .2s both; }
.hero p { animation: fadeUp .8s .3s both; }
.hero__cta { animation: fadeUp .8s .4s both; }
.hero__feat { animation: fadeUp .8s .5s both; }
.rv { opacity: 0; transform: translateY(20px); transition: opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1); }
.rv.is-in { opacity: 1; transform: translateY(0); }

/* === POLISH PASS === */
@keyframes pulseHandle { 0%, 100% { transform: translate(-50%, -50%) scale(1); box-shadow: 0 6px 20px rgba(0,0,0,.35), inset 0 0 0 2px color-mix(in oklab, var(--t-primary) 18%, white); } 50% { transform: translate(-50%, -50%) scale(1.08); box-shadow: 0 10px 28px rgba(0,0,0,.45), inset 0 0 0 2px color-mix(in oklab, var(--t-primary) 30%, white); } }
.ba-slider:not(.is-drag) .ba-handle span { animation: pulseHandle 2.4s ease-in-out infinite; }
.ba-slider.is-drag .ba-handle span { transform: translate(-50%, -50%) scale(1.12); transition: transform .1s; }
.ba-slider:hover .ba-after, .ba-slider.is-drag .ba-after { transition: none; }

.service-card { transform-origin: center bottom; }
.service-card::before { content: ''; position: absolute; inset: 0; border-radius: inherit; background: radial-gradient(circle at 50% 0%, color-mix(in oklab, var(--t-primary) 6%, transparent), transparent 50%); opacity: 0; transition: opacity .35s; pointer-events: none; }
.service-card:hover::before { opacity: 1; }
.service-card:hover .service-card__ico { transform: scale(1.06) rotate(-3deg); box-shadow: 0 8px 18px color-mix(in oklab, var(--t-primary) 28%, transparent); }
.service-card__ico { transition: transform .4s cubic-bezier(.34,1.56,.64,1), box-shadow .35s; }

.btn { position: relative; overflow: hidden; isolation: isolate; }
.btn::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.18), transparent 60%); opacity: 0; transition: opacity .3s; }
.btn:hover::before { opacity: 1; }
.btn:active { transform: scale(.97); }

.cc { position: relative; isolation: isolate; }
.cc::before { content: ''; position: absolute; inset: 0; border-radius: inherit; background: linear-gradient(135deg, color-mix(in oklab, var(--t-primary) 8%, transparent), transparent); opacity: 0; transition: opacity .3s; pointer-events: none; }
.cc:hover::before { opacity: 1; }
.cc:active { transform: translateY(-1px) scale(.99); }

.gallery-item { transition: transform .45s cubic-bezier(.22,.61,.36,1), box-shadow .45s; }
.gallery-item:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,.25); }

@keyframes pinBounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
.map__pin-icon { animation: pinBounce 2.6s ease-in-out infinite; }

.tsw__b { position: relative; }
.tsw__b:active { transform: scale(.96); }

.stk__b { transition: background .2s, transform .15s; }
.stk__b:active { background: rgba(255,255,255,.08); transform: scale(.97); }

@keyframes shineSticker { 0% { transform: translateX(-100%) skewX(-20deg); } 100% { transform: translateX(200%) skewX(-20deg); } }
.about__sticker { position: absolute; bottom: -16px; right: -16px; padding: 14px 22px; background: linear-gradient(135deg, var(--t-accent), var(--t-accent-light)); color: white; font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; border-radius: 999px; box-shadow: 0 8px 24px color-mix(in oklab, var(--t-accent) 35%, transparent); line-height: 1.3; text-align: center; overflow: hidden; }
.about__sticker::after { content: ''; position: absolute; top: 0; left: 0; width: 30%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent); animation: shineSticker 3.5s linear infinite; }

.form input::placeholder, .form textarea::placeholder { color: var(--t-ink-3); opacity: .55; }
.form input:hover:not(:focus), .form select:hover:not(:focus), .form textarea:hover:not(:focus) { border-color: color-mix(in oklab, var(--t-primary) 25%, transparent); }
.form button[type="submit"] { font-size: 16px; padding: 16px 24px; min-height: 54px; }

.hero__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.20) 0%, rgba(0,0,0,.50) 60%, rgba(0,0,0,.78) 100%); }
.hero__bg img { transform: scale(1.04); transition: transform 12s ease-out; }
.hero__bg.is-loaded img { transform: scale(1); }

@keyframes scrollHint { 0% { opacity: 0; transform: translateY(-6px); } 50% { opacity: 1; } 100% { opacity: 0; transform: translateY(6px); } }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--t-paper); }
::-webkit-scrollbar-thumb { background: color-mix(in oklab, var(--t-primary) 35%, transparent); border-radius: 10px; border: 2px solid var(--t-paper); }
::-webkit-scrollbar-thumb:hover { background: var(--t-primary); }

a:focus-visible, button:focus-visible { outline: 3px solid var(--t-accent); outline-offset: 2px; border-radius: 4px; }

@media (hover: none) {
  .gallery-item:hover { transform: none; }
  .service-card:hover { transform: none; }
  .cc:hover { transform: none; }
}

/* Scroll progress bar */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--t-accent), var(--t-accent-light), var(--t-accent)); transform-origin: left center; transform: scaleX(0); z-index: 1000; pointer-events: none; box-shadow: 0 0 10px color-mix(in oklab, var(--t-accent) 50%, transparent); }
[data-theme="toiture"] .scroll-progress { background: linear-gradient(90deg, var(--t-accent), #F5C518, var(--t-accent)); }

/* CTA buttons stronger depth */
.btn--p { box-shadow: 0 8px 22px color-mix(in oklab, var(--t-primary) 30%, transparent), inset 0 1px 0 rgba(255,255,255,.18), 0 0 0 1px color-mix(in oklab, var(--t-primary) 40%, transparent); }
.btn--p:hover { box-shadow: 0 14px 30px color-mix(in oklab, var(--t-primary) 35%, transparent), inset 0 1px 0 rgba(255,255,255,.25); }

/* Better KPIs */
.hero__feat li { position: relative; padding-right: 14px; }
.hero__feat li:not(:last-child)::after { content: ''; position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 32px; background: rgba(255,255,255,.18); }
@media (max-width: 639px) { .hero__feat li:nth-child(2)::after { display: none; } }

/* About list polish */
.abt-l { gap: 12px; }
.abt-l li { padding: 10px 14px; background: rgba(255,255,255,.04); border-radius: 12px; border: 1px solid var(--t-line); transition: background .2s, border-color .2s; }
.abt-l li:hover { background: rgba(255,255,255,.08); border-color: color-mix(in oklab, var(--t-primary) 25%, transparent); }

/* Section header refinement */
.eb { backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }

/* Smooth font rendering */
body { text-rendering: optimizeLegibility; }
