/* Instinct de partage — design system partagé */
:root{
  --night:#10211A; --forest:#1C3A2C; --forest2:#16291F; --forest3:#0E1D16;
  --cream:#F4EFE3; --cream2:#EDE6D6; --sand:#E2D6C0;
  --ink:#1A231C; --ink-soft:#5A6157;
  --ochre:#E0913B; --ochre-dk:#9C5A16; --glow:#86E6B4;
  --paper:#F4EFE3; --soft:rgba(244,239,227,.7); --soft2:rgba(244,239,227,.46);
  --line:rgba(26,35,28,.12); --line-d:rgba(244,239,227,.16);
  --shadow:0 34px 80px -38px rgba(14,29,22,.55); --shadow-sm:0 18px 44px -22px rgba(14,29,22,.4);
  --r:22px; --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Switzer',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,.disp{font-family:'Clash Display','Switzer',sans-serif;font-weight:600;line-height:1.05;letter-spacing:-.015em}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
@media(max-width:600px){.wrap{padding:0 20px}}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;color:var(--ochre-dk)}
.eyebrow svg{width:16px;height:16px;fill:var(--ochre)}
.eyebrow.on-dark{color:var(--ochre)}

.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:'Switzer';font-weight:600;font-size:.98rem;padding:.95rem 1.65rem;border-radius:100px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s,background .25s,color .25s,border-color .25s}
.btn svg{width:18px;height:18px;fill:currentColor}
.btn-primary{background:var(--ochre);color:#241405;box-shadow:0 16px 30px -14px rgba(168,99,30,.8)}
.btn-primary:hover{background:#EFA24E;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--paper);border-color:rgba(244,239,227,.4)}
.btn-ghost:hover{background:rgba(244,239,227,.1);transform:translateY(-2px)}
.btn-ghost.dark{color:var(--forest);border-color:rgba(28,58,44,.3)}
.btn-ghost.dark:hover{background:rgba(28,58,44,.06)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--ochre);outline-offset:3px}

/* cursor + grain */
.cursor{position:fixed;top:0;left:0;width:30px;height:30px;border:1.5px solid var(--ochre);border-radius:50%;margin:-15px 0 0 -15px;pointer-events:none;z-index:9999;opacity:0;transition:opacity .3s}
@media(pointer:coarse){.cursor{display:none}}
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .35s,box-shadow .35s,padding .35s}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0;transition:padding .35s}
header.scrolled{background:rgba(244,239,227,.9);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
header.solid{background:rgba(244,239,227,.9);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
header.scrolled .nav,header.solid .nav{padding:11px 0}
.logo{display:flex;align-items:center;gap:.55rem}
.logo .mk{width:46px;height:46px;border-radius:50%;overflow:hidden;flex:0 0 auto;border:1.5px solid rgba(224,145,59,.6);box-shadow:0 6px 16px -8px rgba(0,0,0,.5)}
.logo .mk img{width:100%;height:100%;object-fit:cover}
header.scrolled .nav-links a,header.solid .nav-links a{color:var(--ink-soft)}
header.scrolled .nav-links a:hover,header.solid .nav-links a:hover{color:var(--forest)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--soft);position:relative;transition:color .25s}
.nav-links a.current{color:var(--paper)}
header.scrolled .nav-links a.current,header.solid .nav-links a.current{color:var(--forest);font-weight:600}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1.5px;background:var(--ochre);transition:width .25s}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-links a:hover{color:var(--paper)}
.nav-cta{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;padding:.6rem 1.15rem;border-radius:100px;background:var(--ochre);color:#241405!important}
.nav-cta:hover{background:#EFA24E}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:2px;background:var(--paper);position:relative;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--paper);transition:.3s}
.burger span::before{top:-7px}.burger span::after{top:7px}
header.scrolled .burger span,header.solid .burger span,header.scrolled .burger span::before,header.scrolled .burger span::after,header.solid .burger span::before,header.solid .burger span::after{background:var(--forest)}
@media(max-width:880px){
  .nav-links{position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;align-items:flex-start;gap:6px;background:var(--forest);padding:90px 30px 30px;transform:translateY(-100%);transition:transform .4s ease;box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .nav-links a{color:var(--paper);font-size:1.1rem;padding:10px 0;width:100%}
  .nav-links a.nav-cta{margin-top:10px}
  .burger{display:inline-flex;z-index:210}
}

/* HERO accueil */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--night)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 72%;z-index:0;transform:scale(1.08);will-change:transform}
#relief{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.55;mix-blend-mode:screen}
.hero::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(100deg,rgba(14,29,22,.85) 0%,rgba(14,29,22,.55) 34%,rgba(16,33,26,.12) 64%,transparent 82%),linear-gradient(180deg,transparent 42%,rgba(14,29,22,.72) 88%,var(--night) 100%)}
.hero-glow{position:absolute;z-index:2;width:60vw;height:60vw;left:-10vw;bottom:-20vw;border-radius:50%;background:radial-gradient(circle,rgba(134,230,180,.16),transparent 62%);pointer-events:none}
.hero-inner{position:relative;z-index:3;width:100%;padding-bottom:5vh;padding-top:120px}
.hero .eyebrow{color:var(--ochre)}
.hero h1{font-size:clamp(2.3rem,5.2vw,4.4rem);color:var(--paper);max-width:12ch;margin:14px 0 0}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 em{font-style:normal;color:var(--ochre)}
.hero-lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--soft);max-width:42ch;margin:18px 0 26px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.chip{display:inline-flex;align-items:center;gap:.7rem;margin-top:30px;padding:.6rem .95rem;border:1px solid var(--line-d);border-radius:100px;background:rgba(16,33,26,.4);backdrop-filter:blur(6px);font-size:.88rem;color:var(--soft)}
.chip .stars{display:inline-flex;gap:1px}.chip .stars svg{width:15px;height:15px;fill:var(--ochre)}
.chip b{color:var(--paper);font-family:'Clash Display';font-weight:600}

/* PAGE HERO (pages internes) */
.phero{position:relative;background:var(--forest);color:var(--paper);overflow:hidden;padding:140px 0 56px}
.phero::before{content:"";position:absolute;right:-6vw;top:-8vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(134,230,180,.12),transparent 62%);z-index:0}
.phero .wrap{position:relative;z-index:2}
.phero h1{font-size:clamp(2.2rem,5.2vw,3.6rem);color:var(--paper);max-width:18ch;margin-top:12px}
.phero p{color:var(--soft);max-width:52ch;margin-top:14px;font-size:1.08rem}
.crumb{font-size:.82rem;color:var(--soft2)}
.crumb a:hover{color:var(--ochre)}

/* SECTIONS */
section{position:relative}
.pad{padding:clamp(64px,10vw,118px) 0}
.sec-head{max-width:46em;margin-bottom:44px}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.2rem);color:var(--forest);margin:14px 0 12px}
.sec-head p{color:var(--ink-soft);font-size:1.08rem;max-width:44ch}
.bg-soft{background:var(--cream2)}

/* SPLIT + media */
.split{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(34px,5vw,66px);align-items:center}
.split.rev{grid-template-columns:1.05fr 1fr}
@media(max-width:880px){.split,.split.rev{grid-template-columns:1fr;gap:34px}}
.media{position:relative;border-radius:clamp(22px,4vw,40px);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5}
.media img{width:100%;height:108%;object-fit:cover;will-change:transform}
.media.tag-bl{border-bottom-left-radius:84px}.media.tag-tr{border-top-right-radius:84px}
.media .badge{position:absolute;left:18px;bottom:18px;z-index:2;display:flex;align-items:center;gap:.6rem;background:rgba(244,239,227,.92);backdrop-filter:blur(6px);border-radius:14px;padding:.6rem .9rem;font-size:.85rem;font-weight:600;color:var(--forest);box-shadow:var(--shadow-sm)}
.media .badge svg{width:18px;height:18px;fill:var(--ochre-dk)}
.prose h2{font-size:clamp(1.9rem,4vw,2.7rem);color:var(--forest);margin-bottom:18px}
.prose p{color:var(--ink-soft);margin-bottom:14px}
.prose .pull{font-family:'Clash Display';font-weight:500;font-size:clamp(1.25rem,2.4vw,1.5rem);color:var(--forest);line-height:1.32;border-left:2px solid var(--ochre);padding-left:18px;margin:6px 0}

/* CARDS prestations */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column;background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;transition:transform .35s,box-shadow .35s,border-color .35s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--ochre),var(--glow));transition:width .4s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{width:100%}
.card .ic{width:54px;height:54px;border-radius:15px;background:var(--sand);display:grid;place-items:center;margin-bottom:18px;transition:background .35s}
.card:hover .ic{background:var(--forest)}
.card .ic svg{width:26px;height:26px;fill:var(--forest);transition:fill .35s}
.card:hover .ic svg{fill:var(--ochre)}
.card h3{font-size:1.24rem;color:var(--forest);margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:.96rem;flex:1}
.card .price{margin-top:16px;font-family:'Clash Display';font-weight:600;font-size:1.05rem;color:var(--ochre-dk)}
.card .more{margin-top:12px;font-size:.88rem;font-weight:600;color:var(--forest);display:inline-flex;align-items:center;gap:.4rem}
.card .more svg{width:15px;height:15px;fill:currentColor;transition:transform .3s}
.card:hover .more svg{transform:translateX(4px)}

/* BAND */
.band{position:relative;min-height:60vh;display:flex;align-items:center;overflow:hidden;background:var(--night)}
.band-bg{position:absolute;inset:0;width:100%;height:120%;object-fit:cover;z-index:0;opacity:.55;will-change:transform}
.band::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,var(--forest3) 8%,rgba(14,29,22,.55) 60%,rgba(14,29,22,.25))}
.band-glow{position:absolute;z-index:1;right:-8vw;top:-10vw;width:46vw;height:46vw;border-radius:50%;background:radial-gradient(circle,rgba(134,230,180,.14),transparent 60%)}
.band .wrap{position:relative;z-index:2;max-width:34em}
.band h2{font-size:clamp(2rem,5vw,3.2rem);color:var(--paper);margin:12px 0 14px}
.band p{color:var(--soft);font-size:1.12rem}
.band .btn{margin-top:26px}

/* GALERIE */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
@media(max-width:860px){.gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}}
.gal figure{overflow:hidden;border-radius:18px;box-shadow:var(--shadow-sm)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gal figure:hover img{transform:scale(1.06)}
.gal .tall{grid-row:span 2}.gal .wide{grid-column:span 2}

/* ZONE */
.zone-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.zone-chips span{background:var(--cream);border:1px solid var(--line);border-radius:100px;padding:.45rem .9rem;font-size:.9rem;color:var(--ink-soft)}

/* AVIS */
.avis-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(30px,5vw,60px);align-items:center}
@media(max-width:820px){.avis-grid{grid-template-columns:1fr;gap:30px}}
.score b{font-family:'Clash Display';font-weight:600;font-size:clamp(3.4rem,7vw,5rem);color:var(--forest);line-height:.9;display:block}
.score .stars{display:inline-flex;gap:2px;margin:10px 0 6px}.score .stars svg{width:22px;height:22px;fill:var(--ochre)}
.score span{display:block;color:var(--ink-soft);font-size:.95rem}
.score .pj{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-size:.92rem;color:var(--ink-soft)}
.score .pj b{font-family:'Switzer';font-size:1rem;color:var(--forest);display:inline}
.quote{background:var(--cream);border:1px solid var(--line);border-radius:clamp(20px,3vw,30px);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-sm)}
.quote .qm{font-family:'Clash Display';font-size:4rem;color:var(--ochre);line-height:.6;opacity:.5}
.quote p{font-family:'Clash Display';font-weight:500;font-size:clamp(1.25rem,2.4vw,1.5rem);color:var(--forest);line-height:1.4;margin-top:6px}
.quote .who{margin-top:18px;font-weight:600;font-size:.9rem;color:var(--ink-soft)}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.reviews{grid-template-columns:1fr}}
.rev{margin:0;background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:26px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.rev .stars{display:inline-flex;gap:2px;margin-bottom:12px}
.rev .stars svg{width:16px;height:16px;fill:var(--ochre)}
.rev blockquote{margin:0;font-size:.98rem;color:#3a4138;line-height:1.55;flex:1}
.rev figcaption{margin-top:16px;font-weight:600;color:var(--forest);font-size:.92rem}
.rev figcaption span{color:var(--ink-soft);font-weight:500}
.rev-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:28px;padding-top:22px;border-top:1px solid var(--line)}
.rev-cta .score-inline{color:var(--ink-soft);font-size:.95rem}
.rev-cta .score-inline b{font-family:'Clash Display';font-weight:600;font-size:1.5rem;color:var(--forest)}

/* À propos — section Takaya */
.story-wolf{background:var(--forest);color:var(--paper);position:relative;overflow:hidden}
.story-wolf .wrap{padding:clamp(64px,10vw,110px) 30px}
.story-wolf .grid{display:grid;grid-template-columns:.66fr 1.34fr;gap:clamp(28px,5vw,60px);align-items:center}
@media(max-width:780px){.story-wolf .grid{grid-template-columns:1fr;gap:26px;text-align:center}}
.story-wolf .port{max-width:230px;margin:0 auto;border-radius:20px;overflow:hidden;border:1px solid var(--line-d);box-shadow:var(--shadow)}
.story-wolf .port img{width:100%;display:block}
.story-wolf .eyebrow{color:var(--ochre);margin-bottom:8px}
.story-wolf h2{color:var(--paper);font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:16px}
.story-wolf h2 em{font-style:italic;color:var(--ochre)}
.story-wolf p{color:var(--soft);margin-bottom:14px;max-width:56ch}
@media(max-width:780px){.story-wolf p{margin-left:auto;margin-right:auto}}
.story-wolf strong{color:var(--paper)}

/* FAQ */
.faq{max-width:820px}
details.q{border-top:1px solid var(--line);padding:22px 0}
details.q:last-child{border-bottom:1px solid var(--line)}
details.q summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:'Clash Display';font-weight:600;font-size:1.22rem;color:var(--forest)}
details.q summary::-webkit-details-marker{display:none}
details.q summary::after{content:"+";color:var(--ochre);font-size:1.6rem;transition:transform .3s;line-height:1}
details.q[open] summary::after{transform:rotate(45deg)}
details.q p{margin-top:12px;color:var(--ink-soft);max-width:64ch}

/* CONTACT */
.contact{background:var(--forest);color:var(--paper);position:relative;overflow:hidden}
.contact-glow{position:absolute;left:-10vw;bottom:-14vw;width:48vw;height:48vw;border-radius:50%;background:radial-gradient(circle,rgba(134,230,180,.12),transparent 62%);z-index:0}
.contact .wrap{position:relative;z-index:2}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,60px);align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:34px}}
.contact h2{font-size:clamp(2.1rem,4.6vw,3rem);color:var(--paper);margin:12px 0 12px}
.contact .lead{color:var(--soft);margin-bottom:26px;max-width:34ch}
.info{display:flex;gap:14px;padding:15px 0;border-bottom:1px solid var(--line-d)}
.info .ic{width:44px;height:44px;border-radius:13px;background:rgba(224,145,59,.2);display:grid;place-items:center;flex:0 0 auto}
.info .ic svg{width:20px;height:20px;fill:var(--ochre)}
.info b{color:var(--paper);display:block;font-weight:600}
.info a,.info span{color:var(--soft)}.info a:hover{color:var(--paper)}
.map{margin-top:18px;border:0;width:100%;height:200px;border-radius:16px;filter:saturate(.9) brightness(.95)}
.phone-cta{margin:6px 0 14px;padding:22px 24px;border:1px solid var(--line-d);border-radius:var(--r);background:rgba(244,239,227,.05)}
.phone-cta .lab{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ochre);font-weight:600;margin-bottom:10px}
.phone-cta .num{display:inline-flex;align-items:center;gap:.6rem;font-family:'Switzer',sans-serif;font-weight:700;font-size:clamp(1.9rem,5vw,3rem);letter-spacing:.5px;white-space:nowrap;color:#fff;line-height:1.1;transition:color .25s}
.phone-cta .num svg{width:.72em;height:.72em;fill:var(--ochre)}
.phone-cta .num:hover{color:var(--ochre)}
.phone-cta .sms{display:block;margin-top:12px;color:var(--soft);font-size:.96rem}
.form{background:var(--cream);color:var(--ink);border-radius:clamp(20px,3vw,28px);padding:clamp(26px,3.5vw,34px);box-shadow:var(--shadow)}
.form h3{font-family:'Clash Display';font-weight:600;color:var(--forest);font-size:1.3rem;margin-bottom:6px}
.form .fsub{font-size:.9rem;color:var(--ink-soft);margin-bottom:18px}
.form label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;display:block;margin-bottom:6px}
.form input,.form textarea{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:13px;font-family:inherit;font-size:.96rem;background:var(--cream2);color:var(--ink);margin-bottom:14px;transition:border-color .2s}
.form input::placeholder,.form textarea::placeholder{color:#9a9384}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--ochre)}
.form textarea{min-height:96px;resize:vertical}
.form .btn-primary{width:100%;justify-content:center}
.form .rgpd{font-size:.74rem;color:var(--ink-soft);margin-top:12px;line-height:1.5}
.form .form-status{margin-top:12px;font-weight:600;font-size:.95rem;color:var(--forest)}

/* ARTICLE */
.article{max-width:760px;margin:0 auto}
.article .meta{font-size:.85rem;color:var(--ink-soft);margin-bottom:8px}
.article h2{font-size:clamp(1.5rem,3vw,2rem);color:var(--forest);margin:34px 0 12px}
.article p{color:#3a4138;margin-bottom:16px}
.article ul{margin:0 0 16px 1.1rem;color:#3a4138}
.article li{margin-bottom:8px}
.article .lead{font-size:1.15rem;color:var(--ink-soft);margin-bottom:8px}
.article .cta-box{margin-top:40px;background:var(--cream2);border:1px solid var(--line);border-radius:var(--r);padding:28px;text-align:center}
.article .cta-box h3{font-family:'Clash Display';color:var(--forest);font-size:1.4rem;margin-bottom:10px}

/* BLOG list */
.blog{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.blog{grid-template-columns:1fr}}
.post{display:flex;flex-direction:column;background:var(--cream);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .35s,box-shadow .35s}
.post:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post img{width:100%;aspect-ratio:16/10;object-fit:cover}
.post .b{padding:24px;display:flex;flex-direction:column;flex:1}
.post .tag{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ochre-dk);font-weight:600}
.post h3{font-size:1.2rem;color:var(--forest);margin:8px 0}
.post p{color:var(--ink-soft);font-size:.94rem;flex:1}
.post .more{margin-top:14px;font-weight:600;font-size:.88rem;color:var(--forest)}

/* detail list (prestation) */
.feature{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.feature svg{width:22px;height:22px;fill:var(--ochre-dk);flex:0 0 auto;margin-top:2px}
.feature b{color:var(--forest)}
.pricebox{background:var(--forest);color:var(--paper);border-radius:var(--r);padding:28px;position:sticky;top:90px}
.pricebox .p{font-family:'Clash Display';font-weight:600;font-size:2.2rem;color:var(--paper);line-height:1}
.pricebox .sub{color:var(--soft);font-size:.92rem;margin:6px 0 18px}
.pricebox .btn-primary{width:100%;justify-content:center}

/* FOOTER */
footer{background:var(--forest3);color:var(--soft);padding:48px 0 30px}
.foot-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center;padding-bottom:24px;border-bottom:1px solid var(--line-d)}
.foot-legal{margin-top:22px;font-size:.82rem;color:var(--soft);line-height:1.7}
.foot-legal a{color:var(--ochre)}
details.mentions{margin-top:10px}
details.mentions summary{cursor:pointer;font-size:.82rem;color:var(--soft);list-style:none}
details.mentions summary::-webkit-details-marker{display:none}
details.mentions summary::before{content:"+ ";color:var(--ochre)}
details.mentions[open] summary::before{content:"\2013 "}
details.mentions p{font-size:.78rem;color:var(--soft2);margin-top:8px;max-width:72ch;line-height:1.7}

/* sticky mobile CTA */
.mcta{position:fixed;left:0;right:0;bottom:0;z-index:150;display:none;padding:10px 16px calc(10px + env(safe-area-inset-bottom));background:rgba(16,33,26,.92);backdrop-filter:blur(10px);box-shadow:0 -8px 24px -12px rgba(0,0,0,.5)}
.mcta a{display:flex;align-items:center;justify-content:center;gap:.5rem}
@media(max-width:640px){.mcta{display:block}body{padding-bottom:70px}}

/* reveal */
.r{opacity:0;transform:translateY(30px)}
.r.in{opacity:1;transform:none;transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){
  .r{opacity:1!important;transform:none!important}
  #relief{display:none}.hero-bg{transform:none}
}
