/*
 * Okocraft — custom.css
 * Fidèle au brief Claude Design (Landing Page.html).
 * Palette, typo et structure extraites du prototype React.
 */

/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
    --c-forest:   #134B42;
    --c-amber:    #EEA83B;
    --c-terra:    #CA763B;
    --c-sage:     #80917D;
    --c-sage-lt:  #AEBA8A;
    --c-cream:    #F5F1EA;
    --c-tinted:   #EDE9E0;
    --c-dark:     #1a1a18;
    --c-muted:    #6b6558;
    --c-border:   #e4ddd3;
    --c-border-lt:#e0d9ce;

    --f-serif: 'Lora', Georgia, serif;
    --f-sans:  'Inter', system-ui, sans-serif;

    --radius:    16px;
    --container: 1280px;
    --pad-v:     140px;
    --pad-h:     40px;
}

/* ── Reset GeneratePress + global ───────────────────────────────────────────── */
html, body.oko-landing {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}
/* overflow-x:clip uniquement sur body — pas sur html pour que scroll-snap-type y fonctionne */
body.oko-landing {
    overflow-x: clip;
}
/* Neutralise les wrappers GP s'ils existent */
body.oko-landing .site,
body.oko-landing .site-inner,
body.oko-landing .content-area,
body.oko-landing .site-content,
body.oko-landing .entry-content {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.oko-landing *, .oko-landing *::before, .oko-landing *::after { box-sizing: border-box; margin: 0; padding: 0; }
.oko-landing { background: var(--c-cream); color: var(--c-dark); font-family: var(--f-sans); }
.oko-landing img { max-width: 100%; display: block; }
.oko-landing input, .oko-landing textarea, .oko-landing button { font-family: inherit; }
.oko-landing ::selection { background: #EEA83B44; }
.oko-landing a { transition: opacity .2s; }
.oko-landing a:hover { opacity: .8; }

/* ── Reveal ─────────────────────────────────────────────────────────────────── */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    transition:
        opacity  .5s cubic-bezier(.22,1,.36,1) var(--delay, 0s),
        transform .5s cubic-bezier(.22,1,.36,1) var(--delay, 0s);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* ── Layout helpers ─────────────────────────────────────────────────────────── */
.oko-container { max-width: var(--container); margin: 0 auto; padding: 0 var(--pad-h); }
.oko-section   { padding: var(--pad-v) 0; }
.oko-section--cream  { background: var(--c-cream); }
.oko-section--tinted { background: var(--c-tinted); }
.oko-section--forest { background: var(--c-forest); }
.oko-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

/* ── Typography helpers ─────────────────────────────────────────────────────── */
.oko-overline {
    display: block;
    font-family: var(--f-sans);
    font-size: 11px; font-weight: 700;
    letter-spacing: 3px; text-transform: uppercase;
    color: var(--c-amber); margin-bottom: 20px;
}
.oko-overline--sage { color: var(--c-sage-lt); }

.oko-heading {
    font-family: var(--f-serif);
    font-size: clamp(48px,5vw,80px);
    font-weight: 700; line-height: 1.06;
    letter-spacing: -1px; color: var(--c-dark);
    margin-bottom: 80px;
}
.oko-heading em       { font-style: italic; color: var(--c-sage); }
.oko-heading--light   { color: #F5F1EA; margin-bottom: 28px; }
.oko-heading--sm      { font-size: clamp(36px,3.5vw,56px); letter-spacing: -.5px; margin-bottom: 0; }

/* ── Buttons ─────────────────────────────────────────────────────────────────── */
.oko-btn {
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px; border: 2px solid transparent;
    font-family: var(--f-sans); font-weight: 600; font-size: 15px;
    letter-spacing: .3px; text-decoration: none;
    padding: 13px 26px; cursor: pointer;
    transition: opacity .2s;
}
.oko-btn--lg            { font-size: 16px; padding: 17px 36px; }
.oko-btn--block         { display: block; text-align: center; width: 100%; }
.oko-btn--primary       { background: var(--c-forest); color: #fff; }
.oko-btn--amber         { background: var(--c-amber);  color: #fff; }
.oko-btn--outline       { background: transparent; color: var(--c-dark); border-color: var(--c-border-lt); }
.oko-btn--outline-accent{ background: transparent; color: var(--c-amber); border-color: var(--c-amber); }
.oko-btn--ghost         { background: transparent; color: var(--c-forest); border-color: var(--c-border); }
.oko-btn--ghost:hover   { border-color: var(--c-forest); opacity: 1; }
.oko-btn:hover          { opacity: .88; }

/* ── Helpers ────────────────────────────────────────────────────────────────── */
.oko-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: #EEA83B18; border: 1px solid #EEA83B44;
    border-radius: 100px; padding: 6px 16px; margin-bottom: 36px;
    font-family: var(--f-sans); font-size: 12px; font-weight: 600;
    letter-spacing: 2.5px; text-transform: uppercase; color: var(--c-amber);
}
.oko-badge__dot { width:7px; height:7px; border-radius:50%; background:var(--c-amber); flex-shrink:0; }
.oko-check      { color: var(--c-sage-lt); font-weight: 700; font-size: 16px; }

.oko-img-placeholder {
    width:100%; height:100%;
    background: repeating-linear-gradient(45deg,#d8d2c8 0,#d8d2c8 14px,#ccc7bc 14px,#ccc7bc 28px);
    display:flex; align-items:center; justify-content:center;
    font-family:monospace; font-size:13px; color:#999; letter-spacing:1.5px;
}
.oko-img-placeholder--post { aspect-ratio: 16/9; }

/* ════════════════════════════════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════════════════════════════════ */
.oko-nav {
    position: fixed; top: 16px; left: 0; right: 0; z-index: 100;
}
.oko-nav__inner {
    max-width: var(--container); margin: 0 auto;
    padding: 0 var(--pad-h); height: 68px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 24px;
}

/* Logo */
.oko-nav__logo-link {
    display: inline-flex; align-items: center; flex-shrink: 0; text-decoration: none;
    isolation: isolate;          /* isole du backdrop-filter du pill */
    transform: translateZ(0);    /* layer GPU propre — évite le flou de backdrop-filter */
}
.oko-nav__logo-img  {
    height: 80px;
    width: auto;
    display: block;
    transition: filter .2s;
}
.oko-nav__logo-link:hover .oko-nav__logo-img { filter: brightness(1.1); }

/* Pill desktop */
.oko-nav__pill {
    display: flex; align-items: center; gap: 2px;
    background: rgba(245,241,234,0.08);
    border: 1px solid rgba(19,75,66,0.15);
    border-radius: 100px;
    padding: 4px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 2px 16px rgba(0,0,0,0.06);
    transition: background .3s, border-color .3s, box-shadow .3s;
}
.oko-nav.is-scrolled .oko-nav__pill {
    background: rgba(245,241,234,0.88);
    border-color: rgba(19,75,66,0.18);
    box-shadow: 0 4px 24px rgba(0,0,0,0.10);
}
.oko-nav__pill a {
    color: var(--c-dark); text-decoration: none;
    font-size: 14px; font-weight: 500;
    padding: 8px 14px; border-radius: 100px;
    opacity: .75; letter-spacing: .1px;
    transition: opacity .2s, background .2s;
    white-space: nowrap;
}
.oko-nav__pill a:hover { opacity: 1; background: rgba(19,75,66,0.06); }
.oko-nav__pill a.is-active { color: var(--c-forest); font-weight: 600; background: rgba(19,75,66,0.08); }

/* CTA dans la pill */
.oko-nav__cta {
    display: inline-flex !important;
    align-items: center; gap: 6px;
    background: var(--c-forest) !important;
    color: #fff !important;
    opacity: 1 !important;
    padding: 9px 18px !important;
    border-radius: 100px;
    font-weight: 600 !important;
    font-size: 14px !important;
    margin-left: 4px;
    transition: opacity .2s, filter .2s !important;
}
.oko-nav__cta:hover { filter: brightness(1.1); background: var(--c-forest) !important; }

/* Hamburger */
.oko-nav__hamburger {
    display: none;
    flex-direction: column; gap: 5px;
    width: 40px; height: 40px;
    align-items: center; justify-content: center;
    background: rgba(245,241,234,0.15);
    border: 1px solid rgba(19,75,66,0.15);
    border-radius: 50%; cursor: pointer;
    backdrop-filter: blur(8px);
    flex-shrink: 0;
}
.oko-nav__hamburger span {
    display: block; width: 18px; height: 2px;
    background: var(--c-dark); border-radius: 2px;
    transition: transform .25s, opacity .25s;
}
.oko-nav__hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.oko-nav__hamburger.is-open span:nth-child(2) { opacity: 0; }
.oko-nav__hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Menu mobile */
.oko-nav__mobile {
    display: none;
    flex-direction: column; gap: 4px;
    padding: 12px 16px 16px;
    margin: 8px 16px 0;
    background: rgba(245,241,234,0.96);
    border: 1px solid rgba(19,75,66,0.12);
    border-radius: 20px;
    backdrop-filter: blur(16px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.10);
}
.oko-nav__mobile.is-open { display: flex; }
.oko-nav__mobile a {
    color: var(--c-dark); text-decoration: none;
    font-size: 15px; font-weight: 500;
    padding: 10px 14px; border-radius: 12px;
    opacity: .8; transition: opacity .15s, background .15s;
}
.oko-nav__mobile a:hover { opacity: 1; background: rgba(19,75,66,0.06); }

@media (max-width: 900px) {
    .oko-nav__pill      { display: none; }
    .oko-nav__hamburger { display: flex; }
}

/* ════════════════════════════════════════════════════════════════════════════
   HERO — design jungle cinématique (Claude Design)
═══════════════════════════════════════════════════════════════════════════ */

/* Grain de film sur toute la page */
body.oko-landing::after {
    content: '';
    position: fixed; inset: 0;
    pointer-events: none; z-index: 9000;
    opacity: .028;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
    background-repeat: repeat; background-size: 200px 200px;
    animation: grainShift 0.12s steps(1) infinite;
}
@keyframes grainShift {
    0%  { transform: translate(0,0); }   10% { transform: translate(-3%,-4%); }
    20% { transform: translate(4%,2%); } 30% { transform: translate(-2%,5%); }
    40% { transform: translate(3%,-1%); } 50% { transform: translate(-4%,3%); }
    60% { transform: translate(2%,-5%); } 70% { transform: translate(-3%,1%); }
    80% { transform: translate(5%,4%); }  90% { transform: translate(-1%,-3%); }
}

/* Hero wrapper */
.oko-hero {
    position: relative;
    width: 100%; min-height: 100vh; height: 100vh;
    display: flex; flex-direction: column;
    overflow: hidden;
    background: #0d2218;
}

/* Arrière-plan */
.bg-layer {
    position: absolute; inset: 0; z-index: 0;
    opacity: 0;
    animation: bgReveal 1.8s cubic-bezier(0.16,1,0.3,1) 0.1s forwards;
}
.bg-img {
    position: absolute; inset: 0;
    background: url('../images/hero-bg.jpg') center center / cover no-repeat;
    transform: scale(1.08);
    animation: kenBurns 28s ease-in-out 0.2s infinite alternate;
    filter: saturate(1.05) brightness(0.52);
}
.bg-gradient {
    position: absolute; inset: 0;
    background:
        linear-gradient(105deg,
            rgba(13, 34, 24, 0.94) 0%,
            rgba(19, 75, 66, 0.55) 45%,
            rgba(13, 34, 24, 0.12) 100%),
        linear-gradient(to top,
            rgba(7, 22, 14, 0.97) 0%,
            transparent 45%);
}
@keyframes bgReveal { from { opacity: 0; } to { opacity: 1; } }
@keyframes kenBurns {
    from { transform: scale(1.08) translate(0, 0); }
    to   { transform: scale(1.0) translate(-1.5%, 1%); }
}

/* Colonne texte */
.hero-body {
    position: relative; z-index: 5; flex: 1;
    display: flex; align-items: center;
    padding: 100px 52px 32px 8%;
    overflow: visible;
}
.hero-text-col { display: flex; flex-direction: column; gap: 0; max-width: 44%; z-index: 6; }

/* Eyebrow */
.eyebrow {
    display: flex; align-items: center; gap: 12px; margin-bottom: 28px;
    opacity: 0;
    animation: fadeSlideUp 0.9s cubic-bezier(0.16,1,0.3,1) 2.2s forwards;
}
.eyebrow-line { width: 32px; height: 1px; background: var(--c-amber); }
.eyebrow-text {
    font-family: var(--f-sans);
    font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em;
    text-transform: uppercase; color: var(--c-amber);
}

/* Titre principal */
.hero-title {
    font-family: var(--f-serif);
    font-size: clamp(3.2rem, 5.5vw, 5.2rem);
    font-weight: 700; line-height: 1.08;
    color: var(--c-cream);
    margin-bottom: 32px;
}
.title-line { display: block; overflow: hidden; min-height: 1.15em; }
.title-word  { display: inline-block; opacity: 0; will-change: transform, opacity, filter; }
.title-word.italic { font-style: italic; color: var(--c-amber); }

/* Séparateur */
.title-sep {
    width: 60px; height: 1px;
    background: linear-gradient(90deg, var(--c-amber), var(--c-sage-lt));
    margin-bottom: 28px; opacity: 0; transform: scaleX(0); transform-origin: left;
    animation: sepReveal 0.9s cubic-bezier(0.16,1,0.3,1) 3.0s forwards;
}
@keyframes sepReveal { to { opacity: 1; transform: scaleX(1); } }

/* Accroche */
.hero-body-text {
    font-family: var(--f-sans);
    font-size: clamp(0.95rem, 1.1vw, 1.05rem); font-weight: 300; font-style: italic;
    line-height: 1.75; color: rgba(245,241,234,0.76);
    max-width: 440px; margin-bottom: 44px;
    opacity: 0;
    animation: fadeSlideUp 0.9s cubic-bezier(0.16,1,0.3,1) 3.3s forwards;
}

/* Boutons hero */
.hero-buttons { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }

.btn-primary {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-size: 0.78rem; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--c-forest); background: var(--c-amber);
    border: none; padding: 15px 32px; border-radius: 100px; cursor: pointer;
    text-decoration: none;
    opacity: 0;
    animation: fadeSlideUp 1s cubic-bezier(0.16,1,0.3,1) 3.8s forwards;
    box-shadow: 0 4px 24px rgba(238,168,59,0.30);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(238,168,59,0.45); opacity: 1; }
.btn-arrow { font-size: 1rem; transition: transform 0.25s ease; }
.btn-primary:hover .btn-arrow { transform: translateX(4px); }

.btn-ghost {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--f-sans); font-size: 0.78rem; font-weight: 500;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: rgba(245,241,234,0.75); background: transparent;
    border: 1.5px solid rgba(245,241,234,0.25);
    border-radius: 100px;
    cursor: pointer; padding: 14px 28px;
    text-decoration: none;
    opacity: 0;
    animation: fadeSlideUp 1s cubic-bezier(0.16,1,0.3,1) 4.1s forwards;
    transition: color 0.25s, border-color 0.25s, background 0.25s;
}
.btn-ghost:hover { color: var(--c-cream); border-color: rgba(245,241,234,0.55); background: rgba(245,241,234,0.06); }

/* Caméléon */
.hero-img-col {
    position: absolute; bottom: 0; left: 36%; right: -5%;
    height: calc(100% - 100px);
    display: flex; align-items: flex-end; justify-content: flex-end;
    overflow: visible; pointer-events: none; z-index: 5;
}
.chameleon-glow {
    position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
    width: 95%; aspect-ratio: 1;
    background: radial-gradient(ellipse at 50% 60%,
        rgba(238,168,59,0.22) 0%, rgba(128,145,125,0.10) 40%, transparent 70%);
    filter: blur(80px); opacity: 0;
    animation: glowPulse 1.2s ease-out 1.5s forwards; pointer-events: none;
}
@keyframes glowPulse { to { opacity: 1; } }
.chameleon-wrap {
    position: relative; z-index: 2;
    width: 110%; max-width: 1050px;
    flex-shrink: 0;
    opacity: 0; transform: translateX(60px) translateY(20px);
    animation: chameleonEntry 1.6s cubic-bezier(0.16,1,0.3,1) 1.2s forwards;
}
.chameleon-img {
    width: auto; height: auto; max-width: 100%; max-height: 88vh;
    display: block; object-fit: contain; object-position: bottom right;
    filter: contrast(1.05) saturate(1.25) brightness(1.0)
            drop-shadow(0 24px 60px oklch(10% 0.04 140 / 0.6));
    animation: chameleonFloat 8s ease-in-out 5.2s infinite alternate;
}
@keyframes chameleonEntry { to { opacity: 1; transform: translateX(0) translateY(0); } }
@keyframes chameleonFloat {
    from { transform: translateY(0px) rotate(-0.5deg); }
    to   { transform: translateY(-12px) rotate(0.5deg); }
}
.chameleon-wrap:hover .chameleon-img {
    filter: contrast(1.08) saturate(1.45) brightness(1.05)
            drop-shadow(0 30px 80px oklch(10% 0.04 140 / 0.7));
}

/* Repères de cadrage */
.corner-mark {
    position: absolute; width: 24px; height: 24px;
    border-color: var(--c-amber); border-style: solid;
    opacity: 0; animation: cornerReveal 0.8s ease-out 1.8s forwards;
}
.corner-mark.tl { top: 8%; left: 4%; border-width: 1px 0 0 1px; }
.corner-mark.br { bottom: 14%; right: 2%; border-width: 0 1px 1px 0; border-color: var(--c-sage-lt); }
@keyframes cornerReveal { to { opacity: 0.55; } }

/* Indicateur de scroll */
.scroll-hint {
    position: absolute; bottom: 32px; left: 52px; z-index: 10;
    display: flex; align-items: center; gap: 12px;
    opacity: 0; animation: fadeSlideUp 1s ease 4.4s forwards;
}
.scroll-line {
    position: relative; width: 1px; height: 48px;
    background: oklch(50% 0.02 90 / 0.3); overflow: hidden;
}
.scroll-line::after {
    content: ''; position: absolute; top: -100%; left: 0; width: 100%; height: 100%;
    background: linear-gradient(to bottom, transparent, var(--c-amber));
    animation: scrollDrop 2s cubic-bezier(0.4, 0, 0.6, 1) 3.8s infinite;
}
@keyframes scrollDrop { 0% { top: -100%; } 50% { top: 100%; } 100% { top: 100%; } }
.scroll-label {
    font-family: var(--f-sans); font-size: 0.65rem;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: rgba(245,241,234,0.45); writing-mode: vertical-rl;
}

@keyframes fadeSlideUp {
    from { opacity: 0; transform: translateY(22px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Nav adaptée au fond sombre du hero (avant le scroll) */
body.home .oko-nav:not(.is-scrolled) .oko-nav__logo-text    { color: oklch(96% 0.01 90); }
body.home .oko-nav:not(.is-scrolled) .oko-nav__logo-tagline { color: oklch(74% 0.02 90); }
body.home .oko-nav:not(.is-scrolled) .oko-nav__pill {
    background: rgba(10, 26, 12, 0.38);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 2px 16px rgba(0,0,0,0.18);
}
body.home .oko-nav:not(.is-scrolled) .oko-nav__pill a            { color: oklch(88% 0.02 90); }
body.home .oko-nav:not(.is-scrolled) .oko-nav__pill a:hover      { background: rgba(255,255,255,0.08); }
body.home .oko-nav:not(.is-scrolled) .oko-nav__hamburger span    { background: oklch(88% 0.02 90); }

/* Responsive */
@media (max-width: 900px) {
    .hero-body { padding: 100px 24px 60px; }
    .hero-text-col { max-width: 68%; }
    .hero-img-col { left: auto; width: 52%; bottom: 0; right: -3%; height: calc(100% - 80px); opacity: 0.65; z-index: 3; }
    .chameleon-wrap { width: 100%; max-width: 380px; }
    .scroll-hint { left: 24px; }
}

/* ── Hero mobile (< 640 px) — caméléon masqué, texte pleine largeur ──────── */
@media (max-width: 640px) {
    .oko-hero { height: auto; min-height: 100vh; min-height: 100svh; }
    .hero-body { padding: 96px 20px 64px; align-items: flex-end; }
    .hero-text-col { max-width: 100%; }
    .hero-title { font-size: clamp(1.85rem, 7vw, 2.6rem); margin-bottom: 20px; }
    .hero-body-text { font-size: 0.9rem; margin-bottom: 28px; max-width: none; }
    .eyebrow { margin-bottom: 18px; }
    .title-sep { margin-bottom: 18px; }
    .hero-buttons { flex-direction: column; align-items: stretch; gap: 12px; }
    .btn-primary,
    .btn-ghost { justify-content: center; text-align: center; width: 100%; box-sizing: border-box; }
    .hero-img-col { display: none; }
    .scroll-hint { display: none; }
}

/* ════════════════════════════════════════════════════════════════════════════
   LOGOS
═══════════════════════════════════════════════════════════════════════════ */
.oko-logos { background:var(--c-tinted); padding:28px var(--pad-h); }
.oko-logos__label { font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:#a09880; text-align:center; margin-bottom:20px; opacity:.7; }
.oko-logos__list  { display:flex; gap:56px; align-items:center; justify-content:center; flex-wrap:wrap; }
.oko-logos__list span { font-size:14px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:#a09880; }

/* ════════════════════════════════════════════════════════════════════════════
   CARDS (Philosophie)
═══════════════════════════════════════════════════════════════════════════ */
.oko-card          { background:#fff; border-radius:var(--radius); padding:48px 40px; border:1px solid var(--c-border); height:100%; }
.oko-card__bar     { width:48px; height:4px; border-radius:2px; margin-bottom:32px; }
.oko-card__num     { font-family:var(--f-serif); font-size:72px; font-weight:700; display:block; margin-bottom:4px; line-height:1; }
.oko-card__title   { font-family:var(--f-serif); font-size:32px; color:var(--c-dark); margin-bottom:20px; font-weight:700; }
.oko-card__body    { font-size:16px; line-height:1.75; color:var(--c-muted); font-weight:300; }

/* ════════════════════════════════════════════════════════════════════════════
   PORTFOLIO
═══════════════════════════════════════════════════════════════════════════ */
.oko-port-item { display:grid; grid-template-columns:58% 1fr; gap:64px; align-items:center; margin-bottom:96px; }
.oko-port-item:last-child { margin-bottom:0; }
.oko-port-item--reverse { grid-template-columns:1fr 58%; }
.oko-port-item--reverse .oko-port-item__img     { order:2; }
.oko-port-item--reverse .oko-port-item__content { order:1; }

.oko-port-item__img { border-radius:var(--radius); overflow:hidden; aspect-ratio:16/10; box-shadow:0 24px 64px #0002; }
.oko-port-item__img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }

.oko-port-item__img-link { display:block; position:relative; width:100%; height:100%; }
.oko-port-item__img-link:hover img { transform:scale(1.03); }
.oko-port-item__img-overlay {
    position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    background:rgba(19,75,66,0.55); backdrop-filter:blur(2px);
    color:#fff; font-family:var(--f-serif); font-size:18px; font-weight:500; letter-spacing:.5px;
    opacity:0; transition:opacity .3s ease;
    border-radius:var(--radius);
}
.oko-port-item__img-link:hover .oko-port-item__img-overlay { opacity:1; }

.oko-port-item__title { font-family:var(--f-serif); font-size:clamp(36px,3.5vw,54px); color:var(--c-dark); margin:16px 0 24px; line-height:1.1; letter-spacing:-.5px; }
.oko-port-item__desc  { font-size:17px; line-height:1.75; color:var(--c-muted); margin-bottom:28px; font-weight:300; }

.oko-result-badge { display:inline-flex; align-items:center; gap:10px; background:#134B4218; border:1px solid #134B4233; border-radius:100px; padding:8px 18px; margin-bottom:32px; font-size:13px; font-weight:600; color:var(--c-forest); }
.oko-link-accent  { font-weight:600; color:var(--c-amber); text-decoration:none; font-size:15px; border-bottom:2px solid var(--c-amber); padding-bottom:3px; display:inline-block; }

/* ════════════════════════════════════════════════════════════════════════════
   TÉMOIGNAGES — colonnes défilantes
═══════════════════════════════════════════════════════════════════════════ */
.oko-testi-section { overflow: hidden; }

.oko-testi-head { text-align: center; margin-bottom: 48px; }
.oko-testi-badge {
    display: inline-block; padding: 4px 16px; border-radius: 8px;
    border: 1px solid var(--c-border); font-size: 13px; font-weight: 600;
    color: var(--c-muted); margin-bottom: 16px;
}
.oko-testi-sub { font-size: 16px; color: var(--c-muted); margin-top: 12px; font-weight: 300; }

/* Conteneur 3 colonnes avec masque gradient */
.oko-testi-cols {
    display: flex;
    justify-content: center;
    gap: 24px;
    max-height: 740px;
    overflow: hidden;
    mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
}

.oko-testi-col { width: 300px; flex-shrink: 0; overflow: hidden; }
.oko-testi-col--md { display: none; }
.oko-testi-col--lg { display: none; }

@media (min-width: 768px)  { .oko-testi-col--md { display: block; } }
@media (min-width: 1024px) { .oko-testi-col--lg { display: block; } }

/* Animation défilement infini */
@keyframes testiScroll {
    from { transform: translateY(0); }
    to   { transform: translateY(-50%); }
}
.oko-testi-track {
    display: flex; flex-direction: column; gap: 24px; padding-bottom: 24px;
    animation: testiScroll var(--dur, 15s) linear infinite;
}
@media (prefers-reduced-motion: reduce) {
    .oko-testi-track { animation: none; }
}

/* Carte témoignage */
.oko-testi-card {
    padding: 28px;
    border-radius: 20px;
    border: 1px solid var(--c-border);
    background: #fff;
    box-shadow: 0 4px 24px rgba(19,75,66,0.07);
}
.oko-testi-card__text {
    font-size: 14px; line-height: 1.7; color: var(--c-dark); font-weight: 300;
}
.oko-testi-card__author { display: flex; align-items: center; gap: 10px; margin-top: 18px; }
.oko-testi-card__avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.oko-testi-card__name   { font-weight: 700; font-size: 13px; color: var(--c-dark); line-height: 1.3; }
.oko-testi-card__role   { font-size: 12px; color: var(--c-muted); line-height: 1.3; margin-top: 2px; }

/* ════════════════════════════════════════════════════════════════════════════
   TARIFS
═══════════════════════════════════════════════════════════════════════════ */
.oko-tarifs__grid { align-items: start; }
.oko-plan {
    background:#fff; border-radius:20px; padding:52px 40px;
    border:1px solid var(--c-border); position:relative;
}
.oko-plan--featured {
    background:var(--c-forest); border:none;
    transform:scale(1.04); box-shadow:0 32px 64px #134B4244;
}
.oko-plan__badge  { position:absolute; top:-15px; left:50%; transform:translateX(-50%); background:var(--c-amber); color:#fff; font-size:11px; font-weight:800; padding:5px 16px; border-radius:100px; white-space:nowrap; letter-spacing:1px; }
.oko-plan__name   { font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--c-muted); margin-bottom:16px; }
.oko-plan--featured .oko-plan__name { color:var(--c-sage-lt); }
.oko-plan__price-row { display:flex; align-items:flex-end; gap:10px; margin-bottom:8px; }
.oko-plan__price   { font-family:var(--f-serif); font-size:60px; font-weight:700; color:var(--c-dark); line-height:1; }
.oko-plan--featured .oko-plan__price { color:#fff; }
.oko-plan__old-price { font-size:20px; color:var(--c-muted); text-decoration:line-through; margin-bottom:8px; }
.oko-plan--featured .oko-plan__old-price { color:var(--c-sage-lt); }
.oko-plan__sub  { font-size:14px; color:var(--c-muted); margin-bottom:36px; font-weight:300; }
.oko-plan--featured .oko-plan__sub { color:#9ecfbf; }
.oko-plan__feats { list-style:none; margin-bottom:40px; display:flex; flex-direction:column; gap:14px; }
.oko-plan__feats li { font-size:15px; color:var(--c-dark); display:flex; gap:12px; align-items:flex-start; font-weight:300; }
.oko-plan--featured .oko-plan__feats li { color:#e0f0eb; }
.oko-plan--featured .oko-plan__feats .oko-check { color:var(--c-sage-lt); }

/* ════════════════════════════════════════════════════════════════════════════
   PORTFOLIO — sticky card stack
═══════════════════════════════════════════════════════════════════════════ */
.oko-port-wrap { background: var(--c-forest); overflow-x: clip; }

/* Intro collante */
.oko-port-intro {
    position: sticky;
    top: 0;
    height: 100vh;
    display: grid;
    place-content: center;
    text-align: center;
    background: var(--c-forest);
    z-index: 0;
    padding: 0 var(--pad-h);
}
.oko-port-scroll-hint { margin-top: 16px; font-size: 14px; color: rgba(245,241,234,0.45); letter-spacing: .5px; }

/* Scène : cartes à gauche + texte décoratif à droite */
.oko-port-stage {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 100px;
    padding: 0 80px;
    background: var(--c-forest);
    position: relative;
    z-index: 1;
}

/* Colonne de cartes */
.oko-port-col { display: grid; }

/* Frame sticky — une par carte */
.oko-port-frame {
    position: sticky;
    top: 0;
    height: 100vh;
    display: grid;
    place-content: center;
    margin: 0; padding: 0;
}

/* Carte */
.oko-port-card {
    width: 440px;
    border-radius: 24px;
    overflow: hidden;
    background: var(--card-bg, #F5F1EA);
    color: var(--card-text, #1a1a18);
    transform: rotate(var(--card-rot, 0deg));
    box-shadow: 0 24px 64px rgba(0,0,0,0.35);
    transition: transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s;
}
.oko-port-card:hover {
    transform: rotate(0deg) translateY(-4px);
    box-shadow: 0 36px 80px rgba(0,0,0,0.40);
}

/* Image */
.oko-port-card__img { aspect-ratio: 3/2; overflow: hidden; }
.oko-port-card__img img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform .6s ease;
}
.oko-port-card:hover .oko-port-card__img img { transform: scale(1.04); }

/* Corps */
.oko-port-card__body { padding: 22px 26px 26px; }
.oko-port-card__cat {
    font-size: 11px; font-weight: 700; letter-spacing: 2.5px;
    text-transform: uppercase; opacity: .6;
}
.oko-port-card__title {
    font-family: var(--f-serif); font-size: 22px; font-weight: 600;
    margin: 8px 0 16px; line-height: 1.25;
}
.oko-port-card__link {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px; font-weight: 600; text-decoration: none;
    padding: 9px 18px; border-radius: 100px;
    border: 1.5px solid currentColor; opacity: .75;
    transition: opacity .2s, gap .2s;
}
.oko-port-card__link:hover { opacity: 1; gap: 10px; }

/* Texte déco latéral */
.oko-port-side {
    position: sticky;
    top: 0;
    height: 100vh;
    display: grid;
    place-content: center;
    flex-shrink: 0;
    pointer-events: none;
}
.oko-port-side__text {
    font-family: var(--f-serif);
    font-size: clamp(2rem, 3vw, 3.5rem);
    font-weight: 700;
    text-align: center;
    line-height: 1.1;
    color: rgba(245,241,234,0.28);
    letter-spacing: -.02em;
}

/* Mobile */
@media (max-width: 768px) {
    .oko-port-stage { flex-direction: column; padding: 0 24px; align-items: center; }
    .oko-port-side  { display: none; }
    .oko-port-card  { width: min(380px, 90vw); }
    .oko-port-intro { padding: 0 24px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   FAQ
═══════════════════════════════════════════════════════════════════════════ */
.oko-faq__grid { display:grid; grid-template-columns:1fr 2fr; gap:96px; align-items:start; }
.oko-faq__left { position:sticky; top:100px; }
.oko-faq__sub  { font-size:17px; color:var(--c-muted); margin-top:20px; font-weight:300; font-style:italic; }
.oko-faq__items { display:flex; flex-direction:column; }
.oko-faq__item  { border-bottom:1px solid var(--c-border); }
.oko-faq__q {
    width:100%; background:none; border:none; cursor:pointer;
    display:flex; justify-content:space-between; align-items:center;
    padding:28px 0; gap:20px; text-align:left;
}
.oko-faq__q span:first-child { font-family:var(--f-serif); font-size:22px; color:var(--c-dark); font-weight:600; line-height:1.3; }
.oko-faq__icon { color:var(--c-amber); font-size:28px; font-weight:300; flex-shrink:0; transition:transform .25s; display:block; }
.oko-faq__item.is-open .oko-faq__icon { transform:rotate(45deg); }
.oko-faq__a { display:grid; grid-template-rows:0fr; opacity:0; transition:grid-template-rows .35s ease, opacity .25s; }
.oko-faq__item.is-open .oko-faq__a { grid-template-rows:1fr; opacity:1; }
.oko-faq__a p { min-height:0; font-size:17px; line-height:1.75; color:var(--c-muted); padding-bottom:28px; font-weight:300; }

/* ════════════════════════════════════════════════════════════════════════════
   BLOG
═══════════════════════════════════════════════════════════════════════════ */
.oko-card--post        { overflow:hidden; padding:0; cursor:pointer; }
.oko-card__thumb       { aspect-ratio:16/9; overflow:hidden; }
.oko-card__thumb img   { width:100%; height:100%; object-fit:cover; }
.oko-card__body-wrap   { padding:32px 32px 36px; }
.oko-card__title--post { font-family:var(--f-serif); font-size:24px; color:var(--c-dark); margin:12px 0 20px; line-height:1.3; font-weight:700; }
.oko-card__title--post a { color:inherit; text-decoration:none; }
.oko-card__title--post a:hover { opacity:.75; }
.oko-card__date { font-size:13px; color:var(--c-muted); }

/* ════════════════════════════════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════════════════════════════════ */
.oko-contact__grid   { display:grid; grid-template-columns:1fr 1fr; gap:96px; align-items:start; }
.oko-contact__intro  { font-size:18px; line-height:1.75; color:#9eb5af; margin-bottom:52px; font-weight:300; }
.oko-contact__email  { display:block; font-size:18px; color:var(--c-sage-lt); text-decoration:none; margin-bottom:16px; font-weight:500; }
.oko-contact__phone  { display:block; font-size:16px; color:rgba(174,186,138,0.70); text-decoration:none; margin-bottom:32px; font-weight:400; letter-spacing:.3px; transition:color .2s; }
.oko-contact__phone:hover { color:var(--c-sage-lt); }
.oko-contact__socials { display:flex; gap:12px; }
.oko-contact__socials a { font-size:13px; font-weight:600; color:#F5F1EA; text-decoration:none; padding:9px 20px; border:1px solid #2d5a4e; border-radius:7px; }

.oko-form { background:#0d3b32; border-radius:20px; padding:52px 48px; border:1px solid #1e4a3e; display:flex; flex-direction:column; gap:22px; }
.oko-form__field { display:flex; flex-direction:column; gap:8px; }
.oko-form__field label { font-size:12px; font-weight:700; color:var(--c-sage-lt); letter-spacing:1.5px; text-transform:uppercase; }
.oko-form__field input,
.oko-form__field textarea { background:#0a2820; border:1px solid #2d5a4e; border-radius:10px; padding:14px 18px; color:#F5F1EA; font-size:15px; outline:none; font-weight:300; width:100%; transition:border-color .2s; }
.oko-form__field input:focus,
.oko-form__field textarea:focus { border-color:var(--c-sage-lt); }
.oko-form__field textarea { resize:vertical; }

.oko-form-confirm        { background:#0d3b32; border-radius:20px; padding:72px 48px; text-align:center; border:1px solid #1e4a3e; }
.oko-form-confirm__icon  { width:64px; height:64px; border-radius:50%; background:#AEBA8A33; border:2px solid var(--c-sage-lt); display:flex; align-items:center; justify-content:center; margin:0 auto 28px; font-size:28px; color:var(--c-sage-lt); }
.oko-form-confirm h3     { font-family:var(--f-serif); font-size:32px; color:#fff; margin-bottom:16px; }
.oko-form-confirm p      { color:#9eb5af; font-size:16px; font-weight:300; }

/* ════════════════════════════════════════════════════════════════════════════
   ALTERNANCE SECTIONS — cascade couleurs de texte
═══════════════════════════════════════════════════════════════════════════ */

/* Titres & overlines dans sections sombres */
.oko-section--forest .oko-heading        { color: #F5F1EA; }
.oko-section--forest .oko-heading em     { color: var(--c-amber); }
.oko-section--forest .oko-overline       { color: var(--c-sage-lt); }

/* Portfolio sur fond sombre */
.oko-section--forest .oko-port-item__title { color: #F5F1EA; }
.oko-section--forest .oko-port-item__desc  { color: rgba(245,241,234,0.72); }
.oko-section--forest .oko-link-accent      { color: var(--c-sage-lt); border-bottom-color: var(--c-sage-lt); }
.oko-section--forest .oko-result-badge     { background: rgba(174,186,138,0.12); border-color: rgba(174,186,138,0.28); color: var(--c-sage-lt); }

/* Tarifs sur fond sombre — glassmorphism */
#tarifs                { position: relative; overflow: hidden; }
.oko-tarifs-canvas     { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; }
#tarifs > .oko-container { position: relative; z-index: 1; }

.oko-section--forest .oko-plan {
    background: linear-gradient(135deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.04) 100%);
    border-color: rgba(255,255,255,0.14);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.10);
    transition: transform 0.35s cubic-bezier(.22,1,.36,1), box-shadow 0.35s ease;
}
.oko-section--forest .oko-plan:hover {
    transform: translateY(-7px);
    box-shadow: 0 24px 60px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.16);
}
.oko-section--forest .oko-plan__name      { color: rgba(245,241,234,0.55); }
.oko-section--forest .oko-plan__price     { color: #F5F1EA; }
.oko-section--forest .oko-plan__old-price { color: rgba(245,241,234,0.4); }
.oko-section--forest .oko-plan__sub       { color: rgba(245,241,234,0.6); }
.oko-section--forest .oko-plan__feats li  { color: rgba(245,241,234,0.8); }
.oko-section--forest .oko-plan--featured {
    background: linear-gradient(145deg, rgba(238,168,59,0.92) 0%, rgba(202,118,59,0.88) 100%);
    border-color: rgba(238,168,59,0.45);
    box-shadow: 0 32px 64px rgba(238,168,59,0.35), inset 0 1px 0 rgba(255,255,255,0.22);
}
.oko-section--forest .oko-plan--featured:hover {
    transform: scale(1.04) translateY(-7px);
    box-shadow: 0 44px 80px rgba(238,168,59,0.48), inset 0 1px 0 rgba(255,255,255,0.28);
}
.oko-section--forest .oko-plan--featured .oko-plan__name      { color: rgba(255,255,255,0.65); }
.oko-section--forest .oko-plan--featured .oko-plan__price     { color: #fff; }
.oko-section--forest .oko-plan--featured .oko-plan__old-price { color: rgba(255,255,255,0.5); }
.oko-section--forest .oko-plan--featured .oko-plan__sub       { color: rgba(255,255,255,0.7); }
.oko-section--forest .oko-plan--featured .oko-plan__feats li  { color: rgba(255,255,255,0.85); }
.oko-section--forest .oko-plan--featured .oko-check           { color: rgba(255,255,255,0.9); }

/* Contact & headings --light sur fond clair */
.oko-section--cream .oko-heading--light   { color: var(--c-dark); }
.oko-section--cream .oko-overline--sage   { color: var(--c-amber); }
.oko-section--cream .oko-contact__intro   { color: var(--c-muted); }
.oko-section--cream .oko-contact__email   { color: var(--c-forest); }
.oko-section--cream .oko-contact__phone   { color: var(--c-muted); }
.oko-section--cream .oko-contact__phone:hover { color: var(--c-forest); }
.oko-section--cream .oko-contact__socials a { color: var(--c-dark); border-color: var(--c-border-lt); }

/* ════════════════════════════════════════════════════════════════════════════
   FOOTER — glassmorphism + lueurs
═══════════════════════════════════════════════════════════════════════════ */
/* ════════════════════════════════════════════════════════════════════════════
   FOOTER CINÉMATIQUE — curtain reveal + contenu original
   Wrapper clip-path → footer position:fixed révélé au scroll.
══════════════════════════════════════════════════════════════════════════════ */

.oko-footer-curtain {
    position: relative;
    height: 100vh;
    clip-path: polygon(0% 0, 100% 0%, 100% 100%, 0 100%);
}

.oko-footer {
    position: fixed;
    bottom: 0; left: 0;
    width: 100%; height: 100vh;
    overflow: hidden;
    background: #071e18;
    color: #F5F1EA;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0;
}
.oko-footer > .oko-container { position: relative; z-index: 1; max-width: none; width: 100%; padding: 0 48px; box-sizing: border-box; }

/* ── Glows ambiants ──────────────────────────────────────────────────────── */
.oko-footer__glow {
    position: absolute; border-radius: 50%;
    filter: blur(90px); pointer-events: none; z-index: 0;
    animation: okofooter-breathe 8s ease-in-out infinite alternate;
}
.oko-footer__glow--left  { width:500px; height:500px; top:-100px; left:5%;  background:rgba(238,168,59,0.15); }
.oko-footer__glow--right { width:420px; height:420px; bottom:-80px; right:8%; background:rgba(174,186,138,0.12); }
@keyframes okofooter-breathe {
    0%   { transform:scale(1);   opacity:.6; }
    100% { transform:scale(1.1); opacity:1;  }
}

/* ── Grille de fond ──────────────────────────────────────────────────────── */
.oko-footer-grid {
    position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background-size: 60px 60px;
    background-image:
        linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
    mask-image: linear-gradient(to bottom, transparent, black 30%, black 70%, transparent);
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 30%, black 70%, transparent);
}

/* ── Texte géant arrière-plan ────────────────────────────────────────────── */
.oko-footer-bgtext {
    position: absolute;
    bottom: -5vh; left: 50%;
    transform: translateX(-50%);
    font-size: 32vw;
    font-weight: 900;
    letter-spacing: -0.05em;
    line-height: 0.8;
    white-space: nowrap;
    pointer-events: none;
    user-select: none;
    z-index: 0;
    color: transparent;
    -webkit-text-stroke: 1px rgba(255,255,255,0.04);
    background: linear-gradient(180deg, rgba(255,255,255,0.09) 0%, transparent 65%);
    -webkit-background-clip: text;
    background-clip: text;
    font-family: var(--f-serif, serif);
}

/* ── Bandeau marquee incliné ─────────────────────────────────────────────── */
.oko-footer-marquee {
    position: absolute; top: 0; left: 0; right: 0;
    z-index: 10; overflow: hidden;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    background: rgba(7,30,24,0.75);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 13px 0;
    transform: rotate(-1.5deg) scaleX(1.06);
    box-shadow: 0 6px 32px rgba(0,0,0,0.30);
}
.oko-footer-marquee__track {
    display: flex; align-items: center; gap: 32px;
    width: max-content;
    animation: okofooter-marquee 38s linear infinite;
}
.oko-footer-marquee__item {
    font-size: 11px; font-weight: 700;
    letter-spacing: 3px; text-transform: uppercase;
    color: rgba(245,241,234,0.50); white-space: nowrap;
}
.oko-footer-marquee__sep { color: #EEA83B; font-size: 10px; flex-shrink: 0; }
@keyframes okofooter-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ── Glass card (contenu original) ──────────────────────────────────────── */
.oko-footer__glass {
    display: flex; gap: 56px; align-items: flex-start;
    backdrop-filter: blur(4px) saturate(160%);
    background: radial-gradient(circle at 20% 50%, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 60%, transparent 100%);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 20px; padding: 44px 48px;
    margin-top: 48px;
}

/* Colonne marque */
.oko-footer__brand    { flex: 0 0 260px; }
.oko-footer__logo-wrap { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }
.oko-footer__logo-img  { height: 56px; width: auto; display: block; opacity: .90; transition: opacity .2s; }
.oko-footer__logo-wrap:hover .oko-footer__logo-img { opacity: 1; }
.oko-footer__desc { margin-top: 18px; font-size: 14px; color: rgba(245,241,234,0.50); line-height: 1.75; font-weight: 300; }
.oko-footer__socials-soon { margin-top: 24px; font-size: 12px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(245,241,234,0.28); font-style: italic; }

/* Colonnes nav */
.oko-footer__nav { flex: 1; display: flex; gap: 36px; }
.oko-footer__col { flex: 1; }
.oko-footer__col-title { font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--c-amber); margin-bottom: 20px; }
.oko-footer__col ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.oko-footer__col a { font-size: 14px; color: rgba(245,241,234,0.52); text-decoration: none; font-weight: 300; transition: color .2s; }
.oko-footer__col a:hover { color: #F5F1EA; }
.oko-footer__col--contact li { display: flex; align-items: flex-start; gap: 10px; }
.oko-footer__col--contact svg { width: 16px; height: 16px; color: var(--c-sage-lt); flex-shrink: 0; margin-top: 2px; }
.oko-footer__col--contact address { font-style: normal; font-size: 14px; color: rgba(245,241,234,0.52); font-weight: 300; }

/* Bas de page */
.oko-footer__bottom {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: 24px; padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.07);
    gap: 16px;
}
.oko-footer__copy  { flex: 1; font-size: 13px; color: rgba(245,241,234,0.28); }
.oko-footer__legal { flex: 1; display: flex; justify-content: flex-end; gap: 24px; }
.oko-footer__legal a { font-size: 13px; color: rgba(245,241,234,0.22); text-decoration: none; transition: color .2s; }
.oko-footer__legal a:hover { color: rgba(245,241,234,0.55); }

/* Badge "Crafted with ❤ by Oko Craft" — centré dans le flux */
.oko-footer__crafted-badge {
    display: inline-flex; align-items: center; gap: 7px;
    flex-shrink: 0;
    font-size: 11px; font-weight: 600; letter-spacing: 1.8px;
    text-transform: uppercase; text-decoration: none;
    color: rgba(245,241,234,0.38);
    padding: 9px 20px; border-radius: 100px;
    border: 1px solid rgba(245,241,234,0.13);
    transition: color .25s, border-color .25s, background .25s;
    white-space: nowrap;
}
.oko-footer__crafted-badge:hover {
    color: rgba(245,241,234,0.82);
    border-color: rgba(245,241,234,0.3);
    background: rgba(245,241,234,0.05);
}
.oko-footer__crafted-badge strong {
    color: rgba(245,241,234,0.75);
    font-weight: 700; letter-spacing: .5px;
}

/* Bouton retour en haut */
.oko-footer-totop {
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.10);
    color: rgba(245,241,234,0.45);
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.oko-footer-totop:hover { background: rgba(255,255,255,0.12); color: #F5F1EA; border-color: rgba(255,255,255,0.28); }
.oko-footer-totop svg { display: block; transition: transform .3s; }
.oko-footer-totop:hover svg { transform: translateY(-2px); }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .oko-footer__glass { flex-direction: column; gap: 36px; padding: 36px 28px; margin-top: 56px; }
    .oko-footer__brand { flex: none; }
    .oko-footer__nav   { gap: 24px; }
    .oko-footer-bgtext { font-size: 42vw; }
}
@media (max-width: 640px) {
    /* Désactive le curtain cinématique : contenu trop haut pour 100vh mobile */
    .oko-footer-curtain { height: auto; overflow: hidden; }
    .oko-footer {
        position: relative; /* garde les absolus contenus dans le footer */
        height: auto;
        overflow: hidden;
        justify-content: flex-start;
        padding-top: 48px;
        padding-bottom: 40px;
    }
    /* Décorations inutiles sur mobile — sources d'overflow */
    .oko-footer-marquee { display: none; }
    .oko-footer__glow   { display: none; }
    .oko-footer-bgtext  { display: none; }
    .oko-footer > .oko-container { padding: 0 20px; }
    .oko-footer__glass { padding: 24px 16px; gap: 24px; margin-top: 32px; }
    .oko-footer__nav { flex-direction: column; gap: 20px; }
    .oko-footer__bottom { flex-direction: column; align-items: flex-start; gap: 14px; }
    .oko-footer__legal { justify-content: flex-start; flex-wrap: wrap; gap: 12px; }
    .oko-footer__crafted-badge { width: 100%; justify-content: center; }
}

/* ════════════════════════════════════════════════════════════════════════════
   PAGES INTERNES — éléments communs
═══════════════════════════════════════════════════════════════════════════ */
.oko-page-hero { padding-top: calc(var(--pad-v) + 80px); padding-bottom: var(--pad-v); }
.oko-page-hero .oko-heading { margin-bottom: 20px; }
.oko-page-hero__sub { font-size: 19px; color: var(--c-muted); line-height: 1.7; max-width: 600px; font-weight: 300; }
.oko-page-hero__sub--light { color: rgba(245,241,234,0.65); }
.oko-page-cta { text-align: center; }
.oko-page-cta .oko-heading--sm { margin-bottom: 40px; }

/* ── PORTFOLIO ─────────────────────────────────────────────────────────── */
.oko-pf-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

.oko-pf-card { background:#fff; border-radius: var(--radius); border:1px solid var(--c-border); overflow:hidden; transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s; }
.oko-pf-card:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(0,0,0,0.10); }

.oko-pf-card__img-wrap { display:block; position:relative; aspect-ratio:4/3; overflow:hidden; }
.oko-pf-card__img { width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.oko-pf-card:hover .oko-pf-card__img { transform: scale(1.05); }
.oko-pf-card__overlay { position:absolute; inset:0; background:rgba(19,75,66,0); display:flex; align-items:center; justify-content:center; transition: background .3s; }
.oko-pf-card:hover .oko-pf-card__overlay { background:rgba(19,75,66,0.55); }
.oko-pf-card__cta { color:#fff; font-size:14px; font-weight:600; opacity:0; transform:translateY(8px); transition: opacity .3s, transform .3s; }
.oko-pf-card:hover .oko-pf-card__cta { opacity:1; transform:translateY(0); }

.oko-pf-card__body { padding: 24px; }
.oko-pf-card__meta { display:flex; justify-content:space-between; margin-bottom:10px; }
.oko-pf-card__cat  { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--c-amber); }
.oko-pf-card__year { font-size:12px; color:var(--c-muted); }
.oko-pf-card__title { font-family:var(--f-serif); font-size:20px; font-weight:600; color:var(--c-dark); margin-bottom:10px; line-height:1.3; }
.oko-pf-card__desc  { font-size:14px; color:var(--c-muted); line-height:1.7; font-weight:300; margin-bottom:16px; }
.oko-pf-card__tags  { display:flex; flex-wrap:wrap; gap:6px; }
.oko-pf-card__tag   { font-size:11px; font-weight:600; padding:3px 10px; border-radius:100px; background:var(--c-tinted); color:var(--c-muted); }

@media (max-width: 900px) { .oko-pf-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .oko-pf-grid { grid-template-columns: 1fr; } }

/* ── CONTACT PAGE ──────────────────────────────────────────────────────── */
.oko-contact__badges { display:flex; gap:24px; margin-top:36px; flex-wrap:wrap; }
.oko-contact-badge { display:flex; flex-direction:column; gap:4px; }
.oko-contact-badge__num   { font-family:var(--f-serif); font-size:36px; font-weight:700; color:var(--c-forest); line-height:1; }
.oko-contact-badge__label { font-size:12px; color:var(--c-muted); text-transform:uppercase; letter-spacing:1px; font-weight:600; }

/* ── BLOG ──────────────────────────────────────────────────────────────── */
.oko-blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }

.oko-blog-card { background:#fff; border-radius:var(--radius); border:1px solid var(--c-border); overflow:hidden; transition:transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s; }
.oko-blog-card:hover { transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,0.08); }

.oko-blog-card__img-wrap { display:block; aspect-ratio:16/9; overflow:hidden; }
.oko-blog-card__img      { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.oko-blog-card:hover .oko-blog-card__img { transform:scale(1.04); }
.oko-blog-card__img-placeholder { width:100%; height:100%; background:linear-gradient(135deg, var(--c-tinted), var(--c-border)); }

.oko-blog-card__body    { padding:24px; }
.oko-blog-card__meta    { display:flex; gap:12px; margin-bottom:10px; font-size:12px; color:var(--c-muted); }
.oko-blog-card__cat     { background:var(--c-tinted); padding:2px 8px; border-radius:100px; font-weight:600; color:var(--c-forest); }
.oko-blog-card__title   { font-family:var(--f-serif); font-size:18px; font-weight:600; color:var(--c-dark); margin-bottom:10px; line-height:1.35; }
.oko-blog-card__title a { color:inherit; text-decoration:none; }
.oko-blog-card__title a:hover { color:var(--c-forest); }
.oko-blog-card__excerpt { font-size:14px; color:var(--c-muted); line-height:1.7; font-weight:300; margin-bottom:16px; }

.oko-blog-empty { text-align:center; padding:80px 0; }
.oko-blog-empty__icon { font-size:56px; margin-bottom:24px; }
.oko-blog-empty h2 { font-family:var(--f-serif); font-size:28px; color:var(--c-dark); margin-bottom:12px; }
.oko-blog-empty p  { font-size:16px; color:var(--c-muted); max-width:480px; margin:0 auto 32px; line-height:1.7; }

@media (max-width: 900px) { .oko-blog-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width: 560px) { .oko-blog-grid { grid-template-columns:1fr; } }

/* ── PROCESSUS (page-tarifs) ───────────────────────────────────────────── */
.oko-process__head { margin-bottom: 64px; }
.oko-process__head .oko-heading--sm { margin-bottom: 0; }

.oko-process__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    position: relative;
    align-items: start;
}

/* Trait de connexion entre étapes */
.oko-process__grid::before {
    content: '';
    position: absolute;
    top: 40px;
    left: calc(12.5% + 14px);
    right: calc(12.5% + 14px);
    height: 1px;
    background: linear-gradient(90deg, var(--c-amber), var(--c-sage-lt));
    opacity: 0.30;
    pointer-events: none;
}

.oko-process-step {
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--c-border);
    padding: 36px 28px 32px;
    position: relative;
    z-index: 1;
    transition: transform 0.3s cubic-bezier(.22,1,.36,1), box-shadow 0.3s;
}

.oko-process-step:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 48px rgba(0,0,0,0.08);
}

.oko-process-step__num {
    display: block;
    font-family: var(--f-serif);
    font-size: 60px;
    font-weight: 700;
    color: var(--c-amber);
    line-height: 1;
    margin-bottom: 20px;
    opacity: 0.88;
}

.oko-process-step__title {
    font-family: var(--f-serif);
    font-size: 20px;
    font-weight: 600;
    color: var(--c-dark);
    margin-bottom: 12px;
    line-height: 1.25;
}

.oko-process-step__desc {
    font-size: 15px;
    color: var(--c-muted);
    line-height: 1.75;
    font-weight: 300;
}

@media (prefers-reduced-motion: reduce) {
    .oko-process-step { transition: none; }
    .oko-process-step:hover { transform: none; box-shadow: none; }
}

@media (max-width: 900px) {
    .oko-process__grid { grid-template-columns: repeat(2,1fr); }
    .oko-process__grid::before { display: none; }
    .oko-process__head { margin-bottom: 48px; }
}
@media (max-width: 480px) {
    .oko-process__grid { grid-template-columns: 1fr; }
    .oko-process__head { margin-bottom: 36px; }
}

/* FAQ page tarifs */
.oko-faq__list { max-width:720px; display:flex; flex-direction:column; gap:0; margin-top:48px; }
.oko-faq__list .oko-faq__item { border-bottom:1px solid var(--c-border); }
.oko-faq__list .oko-faq__q { width:100%; text-align:left; background:none; border:none; cursor:pointer; font-family:var(--f-sans); font-size:16px; font-weight:500; color:var(--c-dark); padding:20px 0; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.oko-faq__list .oko-faq__q::after { content:'＋'; font-size:20px; color:var(--c-amber); flex-shrink:0; transition:transform .25s; }
.oko-faq__list .oko-faq__item.is-open .oko-faq__q::after { transform:rotate(45deg); }
.oko-faq__list .oko-faq__a { display:none; padding-bottom:20px; }
.oko-faq__list .oko-faq__item.is-open .oko-faq__a { display:block; }
.oko-faq__list .oko-faq__a p { font-size:15px; color:var(--c-muted); line-height:1.8; font-weight:300; }

/* Bouton outline light (plans tarifs sur fond sombre) */
.oko-btn--outline-light { background:transparent; border-color:rgba(245,241,234,0.30); color:rgba(245,241,234,0.80); }
.oko-btn--outline-light:hover { border-color:#F5F1EA; color:#F5F1EA; opacity:1; }

/* ════════════════════════════════════════════════════════════════════════════
   PAGE À PROPOS
═══════════════════════════════════════════════════════════════════════════ */

/* Hero */
.oko-about-hero { padding-top: calc(var(--pad-v) + 80px); padding-bottom: var(--pad-v); }
.oko-about-hero .oko-heading { margin-bottom: 24px; }
.oko-about-hero__sub { font-size: 20px; color: var(--c-muted); line-height: 1.7; max-width: 640px; font-weight: 300; }

/* Histoire */
.oko-about-story {
    display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: center;
}
.oko-about-story__img-placeholder {
    aspect-ratio: 3/4; border-radius: 20px;
    background: var(--c-border); display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 16px;
    border: 2px dashed var(--c-border-lt);
}
.oko-about-story__img-placeholder svg { width: 80px; opacity: .5; }
.oko-about-story__img-placeholder span { font-size: 13px; color: var(--c-muted); font-style: italic; }
.oko-about-story__content .oko-heading--sm { margin-bottom: 28px; }
.oko-about-story__text p { font-size: 16px; color: var(--c-muted); line-height: 1.8; font-weight: 300; margin-bottom: 16px; }

/* Valeurs */
.oko-about-values__head { margin-bottom: 56px; }
.oko-about-values__head .oko-heading--sm { margin-bottom: 0; }
.oko-about-value {
    background: #fff; border-radius: var(--radius);
    padding: 36px 32px; border: 1px solid var(--c-border);
    transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s;
}
.oko-about-value:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.08); }
.oko-about-value__icon { font-size: 36px; margin-bottom: 20px; display: block; }
.oko-about-value h3 { font-family: var(--f-serif); font-size: 20px; font-weight: 600; color: var(--c-dark); margin-bottom: 12px; }
.oko-about-value p { font-size: 15px; color: var(--c-muted); line-height: 1.75; font-weight: 300; }

/* Compétences */
.oko-about-skills { display: flex; flex-direction: column; gap: 28px; max-width: 680px; }
.oko-about-skill__bar { display: flex; flex-direction: column; gap: 10px; }
.oko-about-skill__label { font-size: 14px; font-weight: 500; color: rgba(245,241,234,0.75); }
.oko-about-skill__track {
    height: 6px; background: rgba(255,255,255,0.10); border-radius: 100px; overflow: hidden;
}
.oko-about-skill__fill {
    height: 100%; width: var(--pct); border-radius: 100px;
    background: linear-gradient(90deg, var(--c-sage-lt), var(--c-amber));
    transform-origin: left; transform: scaleX(0);
    transition: transform 1s cubic-bezier(.22,1,.36,1);
}
.oko-about-skill__fill.is-visible { transform: scaleX(1); }

/* CTA */
.oko-about-cta { text-align: center; }
.oko-about-cta .oko-heading--sm { margin-bottom: 40px; }
.oko-about-cta__btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* Responsive */
@media (max-width: 900px) {
    .oko-about-story { grid-template-columns: 1fr; gap: 40px; }
    .oko-about-story__img { max-width: 300px; margin: 0 auto; width: 100%; }
}
@media (max-width: 480px) {
    .oko-about-hero__sub { font-size: 17px; }
    .oko-about-cta__btns { flex-direction: column; align-items: center; }
}

/* ════════════════════════════════════════════════════════════════════════════
   BANNIÈRE COOKIE RGPD
═══════════════════════════════════════════════════════════════════════════ */
@keyframes oko-cookie-in {
    from { opacity:0; transform:translateY(24px); }
    to   { opacity:1; transform:translateY(0); }
}
.oko-cookie {
    position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
    z-index: 300; width: calc(100% - 48px); max-width: 860px;
    background: #071e18;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.35);
    font-family: var(--f-sans);
    animation: oko-cookie-in .5s cubic-bezier(.22,1,.36,1) both;
}
.oko-cookie[hidden] { display: none; }
.oko-cookie__inner {
    display: flex; align-items: center; gap: 24px;
    padding: 18px 24px; flex-wrap: wrap;
}
.oko-cookie__text { flex: 1; min-width: 200px; }
.oko-cookie__text p { font-size: 13px; color: rgba(245,241,234,0.65); line-height: 1.6; font-weight: 300; }
.oko-cookie__text a { color: var(--c-sage-lt); font-size: 12px; text-decoration: underline; text-underline-offset: 2px; margin-top: 4px; display: inline-block; }
.oko-cookie__actions { display: flex; gap: 10px; flex-shrink: 0; }
.oko-cookie__btn {
    border: none; border-radius: 8px; cursor: pointer;
    font-family: var(--f-sans); font-size: 13px; font-weight: 600;
    padding: 9px 20px; transition: opacity .2s;
}
.oko-cookie__btn:hover { opacity: .85; }
.oko-cookie__btn--refuse { background: rgba(255,255,255,0.08); color: rgba(245,241,234,0.60); }
.oko-cookie__btn--accept { background: var(--c-amber); color: #fff; }

@media (max-width: 640px) {
    /* left/right au lieu de left:50%+transform pour éviter le débordement horizontal */
    .oko-cookie {
        left: 12px;
        right: 12px;
        bottom: 12px;
        width: auto;
        transform: none;
        border-radius: 12px;
    }
    .oko-cookie__inner {
        padding: 14px 16px;
        gap: 12px;
        flex-direction: column;
        align-items: flex-start;
    }
    .oko-cookie__actions { width: 100%; justify-content: space-between; }
    .oko-cookie__btn { flex: 1; text-align: center; }
}

/* ════════════════════════════════════════════════════════════════════════════
   TOAST
═══════════════════════════════════════════════════════════════════════════ */
@keyframes oko-slide-up {
    from { opacity:0; transform:translateX(-50%) translateY(20px); }
    to   { opacity:1; transform:translateX(-50%) translateY(0); }
}
.oko-toast {
    position:fixed; bottom:28px; left:50%; transform:translateX(-50%);
    z-index:200; display:none; align-items:center; gap:14px;
    background:var(--c-forest); color:#fff;
    padding:13px 22px 13px 18px; border-radius:100px;
    box-shadow:0 12px 40px #00000040;
    font-family:var(--f-sans); font-size:14px; white-space:nowrap;
}
.oko-toast.is-visible { display:flex; animation:oko-slide-up .4s cubic-bezier(.22,1,.36,1); }
.oko-toast__badge  { background:var(--c-amber); color:#fff; font-size:11px; font-weight:800; padding:4px 12px; border-radius:100px; letter-spacing:1px; }
.oko-toast a       { color:var(--c-amber); font-weight:700; text-decoration:none; margin-left:4px; }
.oko-toast__close  { background:none; border:none; color:#fff; cursor:pointer; font-size:20px; line-height:1; padding:0; opacity:.5; margin-left:6px; }

/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE (< 900px)
═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    :root { --pad-v:80px; --pad-h:24px; }

    .oko-nav__links                                  { display:none; }
    .oko-hero__grid, .oko-contact__grid              { grid-template-columns:1fr; }
    .oko-hero__right                                 { display:none; }
    .oko-hero__stats                                 { gap:24px; flex-wrap:wrap; }
    .oko-grid-3                                      { grid-template-columns:1fr; }
    .oko-port-item, .oko-port-item--reverse          { grid-template-columns:1fr; }
    .oko-port-item--reverse .oko-port-item__img,
    .oko-port-item--reverse .oko-port-item__content  { order:unset; }
    .oko-faq__grid                                   { grid-template-columns:1fr; gap:40px; }
    .oko-faq__left                                   { position:static; }
    .oko-plan--featured                              { transform:none; }
    .oko-logos__list                                 { gap:24px; }
    .oko-toast { white-space:normal; max-width:calc(100vw - 48px); flex-wrap:wrap; }

    /* Footer */
    .oko-footer__glass  { flex-direction:column; gap:40px; padding:36px 28px; }
    .oko-footer__brand  { flex:none; width:100%; }
    .oko-footer__nav    { flex-wrap:wrap; gap:32px; }
    .oko-footer__col    { flex:0 0 calc(50% - 16px); }
    .oko-footer__bottom { flex-direction:column; align-items:flex-start; gap:12px; }

    /* Menu mobile — bouton CTA pleine largeur */
    .oko-nav__mobile .oko-btn--block {
        display: flex; width: 100%; margin-top: 8px;
        justify-content: center; padding: 14px 20px;
    }

    /* Tarifs : centrer le badge et le prix */
    .oko-tarifs__grid { gap: 16px; }
    .oko-plan { padding: 28px 24px; }

    /* Contact : réduire le gap */
    .oko-contact__grid { gap: 48px; }

    /* Wheel portfolio */
    .oko-wheel-wrap { overflow: hidden; }

    /* Hero : ajuster les stats */
    .oko-hero__stat-num { font-size: 36px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE (< 480px — petits mobiles)
═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    :root { --pad-v:64px; --pad-h:20px; }

    /* Nav */
    .oko-nav__inner { height: 60px; }
    .oko-nav__logo  { height: 36px; }
    .oko-nav__logo-text { font-size: 18px; }

    /* Hero */
    .oko-hero { padding-top: 100px; }
    .oko-hero__stats { flex-direction: column; gap: 20px; align-items: flex-start; }
    .oko-hero__stat  { flex-direction: row; align-items: center; gap: 12px; }
    .oko-hero__stat-num { font-size: 32px; }

    /* Logos */
    .oko-logos__list { flex-wrap: wrap; gap: 16px; }
    .oko-logos__list span { font-size: 14px; padding: 6px 14px; }

    /* Plans tarifaires */
    .oko-plan__price { font-size: 44px; }
    .oko-plan__feats { gap: 12px; }

    /* Contact */
    .oko-form { padding: 32px 24px; }
    .oko-contact__email { font-size: 16px; }
    .oko-contact__phone { font-size: 14px; }

    /* Footer */
    .oko-footer__glass  { padding: 28px 20px; }
    .oko-footer__col    { flex: 0 0 100%; }
    .oko-footer__legal  { flex-direction: column; gap: 12px; }
    .oko-footer__copy   { font-size: 11px; }

    /* Wheel : réduire encore les cartes */
    .oko-wheel__card       { width: 120px; height: 170px; }
    .oko-wheel__card-title { font-size: 12px; }
    .oko-wheel__card-cat   { font-size: 9px; padding: 3px 7px; }

    /* FAQ */
    .oko-faq__q { font-size: 15px; padding: 18px 16px; }

    /* Toast */
    .oko-toast { bottom: 16px; padding: 10px 16px 10px 14px; font-size: 13px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   OVERRIDES FINAUX MOBILE — après tous les blocs responsives généraux
   (nécessaire pour gagner la cascade sur les blocs 900px / 480px)
═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {

    /* ── Toast → badge pill discret en bas à droite ───────────────────────── */
    .oko-toast.is-visible {
        bottom: 24px;
        right: 16px;
        left: auto;
        transform: none;
        padding: 0;
        gap: 0;
        background: var(--c-amber);
        box-shadow: 0 6px 20px rgba(238,168,59,0.45);
        border-radius: 100px;
        white-space: nowrap;
    }
    .oko-toast .oko-toast__badge {
        background: transparent;
        color: var(--c-forest);
        font-size: 12px;
        font-weight: 900;
        padding: 10px 18px;
        letter-spacing: 1px;
        text-decoration: none;
        display: flex;
        align-items: center;
    }
    .oko-toast > span:not(.oko-toast__badge),
    .oko-toast > a:not(.oko-toast__badge),
    .oko-toast__close { display: none; }

    /* ── Footer nav — Services+Explorer côte à côte, Contact en dessous ───── */
    .oko-footer__nav {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 20px 16px;
    }
    .oko-footer__col {
        flex: 0 0 calc(50% - 8px);
        min-width: 0;
    }
    .oko-footer__col--contact {
        flex: 0 0 100%;
        padding-top: 16px;
        border-top: 1px solid rgba(255,255,255,0.06);
        margin-top: 4px;
    }
    .oko-footer__col--contact ul {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
    .oko-footer__col--contact li { display: flex; align-items: center; gap: 8px; }

    /* ── Footer bottom — badge centré ─────────────────────────────────────── */
    .oko-footer__crafted-badge { width: 100%; justify-content: center; }
    .oko-footer__legal { justify-content: flex-start; flex-wrap: wrap; gap: 12px; }
    .oko-footer__bottom { gap: 14px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   PAGES LÉGALES (mentions légales, CGV, confidentialité)
═══════════════════════════════════════════════════════════════════════════ */
/* Header minimaliste des pages légales */
.oko-legal-header {
    background: var(--c-cream);
    border-bottom: 1px solid var(--c-border);
    padding: 20px 0;
}
.oko-legal-header .oko-container { display: flex; align-items: center; }
.oko-legal-header .oko-nav__logo { height: 40px; width: auto; }
.oko-legal-header .oko-nav__logo-text { font-family: var(--f-serif); font-size: 20px; font-weight: 700; color: var(--c-dark); }

/* Footer minimaliste des pages légales */
.oko-legal-footer {
    background: var(--c-dark);
    padding: 28px 0;
    margin-top: 0;
}
.oko-legal-footer .oko-container {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 16px;
}
.oko-legal-footer p { font-size: 13px; color: rgba(245,241,234,0.35); font-family: var(--f-sans); }
.oko-legal-footer__links { display: flex; gap: 24px; }
.oko-legal-footer__links a { font-size: 13px; color: rgba(245,241,234,0.35); text-decoration: none; font-family: var(--f-sans); transition: color .2s; }
.oko-legal-footer__links a:hover { color: rgba(245,241,234,0.7); }

@media (max-width: 600px) {
    .oko-legal-footer .oko-container { flex-direction: column; align-items: flex-start; }
    .oko-legal-footer__links { flex-wrap: wrap; gap: 16px; }
}

.oko-legal-page {
    background: var(--c-cream);
    min-height: 100vh;
    font-family: var(--f-sans);
    color: var(--c-dark);
}

.oko-legal-container {
    max-width: 760px;
    margin: 0 auto;
    padding: 120px 40px 120px;
}

.oko-legal-back {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    color: var(--c-forest);
    text-decoration: none;
    margin-bottom: 52px;
    opacity: .7;
    transition: opacity .2s;
}
.oko-legal-back:hover { opacity: 1; }

.oko-legal-page h1 {
    font-family: var(--f-serif);
    font-size: clamp(32px, 4vw, 52px);
    font-weight: 700;
    color: var(--c-dark);
    line-height: 1.1;
    letter-spacing: -.5px;
    margin-bottom: 56px;
    padding-bottom: 32px;
    border-bottom: 2px solid var(--c-border);
}

.oko-legal-page section {
    margin-bottom: 44px;
}

.oko-legal-page h2 {
    font-family: var(--f-serif);
    font-size: 22px;
    font-weight: 600;
    color: var(--c-dark);
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--c-border-lt);
}

.oko-legal-page p,
.oko-legal-page li {
    font-size: 15px;
    line-height: 1.8;
    color: var(--c-muted);
    font-weight: 300;
}

.oko-legal-page p + p { margin-top: 12px; }

.oko-legal-page ul {
    padding-left: 20px;
    margin: 12px 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.oko-legal-page a {
    color: var(--c-forest);
    font-weight: 500;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.oko-legal-page a:hover { opacity: .75; }

.oko-legal-intro {
    font-size: 17px !important;
    color: var(--c-dark) !important;
    font-weight: 400 !important;
    margin-bottom: 44px;
    padding: 20px 24px;
    background: rgba(19,75,66,0.05);
    border: 1px solid rgba(19,75,66,0.14);
    border-radius: 8px;
}

.oko-legal-date {
    margin-top: 60px;
    font-size: 12px !important;
    color: rgba(107,101,88,0.55) !important;
    font-style: italic;
}

@media (max-width: 600px) {
    .oko-legal-container { padding: 48px 24px 80px; }
    .oko-legal-page h1 { margin-bottom: 36px; }
}

