:root{
  --ivory:#F2EEE6;
  --vellum:#E4DCCB;
  --fog:#A8B0B8;
  --cog:#5C7A8F;
  --slate:#2C3138;
  --slate-soft:#3B424B;
  --ink:#23272C;
  --line:rgba(44,49,56,.14);
  --radius:14px;
  --maxw:1140px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--slate);
  background:var(--ivory);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:400}
h1 em{font-style:italic;color:var(--cog)}
h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
.section-title{margin-bottom:2.2rem;max-width:18ch}

.eyebrow{
  font-family:var(--sans);font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--cog);
  margin-bottom:1.1rem;
}
.eyebrow.dark{color:var(--cog)}
.eyebrow.light{color:var(--fog)}

/* BUTTONS */
.btn{
  display:inline-block;background:var(--slate);color:var(--ivory);
  font-weight:500;font-size:.95rem;padding:.85em 1.6em;border-radius:999px;
  border:1px solid var(--slate);cursor:pointer;transition:.25s ease;
}
.btn:hover{background:var(--cog);border-color:var(--cog);transform:translateY(-1px)}
.btn-sm{padding:.6em 1.2em;font-size:.88rem}
.btn-ghost{background:transparent;color:var(--slate)}
.btn-ghost:hover{background:var(--slate);color:var(--ivory)}
.btn-ghost.light{color:var(--ivory);border-color:rgba(242,238,230,.4)}
.btn-ghost.light:hover{background:var(--ivory);color:var(--slate);border-color:var(--ivory)}
.btn-ghost.dark{color:var(--slate);border-color:var(--line)}
.btn.light{background:var(--ivory);color:var(--slate);border-color:var(--ivory)}
.btn.light:hover{background:var(--cog);color:var(--ivory);border-color:var(--cog)}
.link-btn{background:none;border:none;color:var(--slate);font:inherit;cursor:pointer;text-decoration:underline;opacity:.7}
.link-btn:hover{opacity:1}

/* HEADER */
.site-head{position:sticky;top:0;z-index:50;background:rgba(242,238,230,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;gap:1.5rem;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.35rem;color:var(--slate)}
.brand-mark{width:30px;height:30px;color:var(--cog)}
.main-nav{display:flex;gap:1.8rem;margin-left:auto;font-size:.95rem}
.main-nav a{position:relative;padding:.2em 0;color:var(--slate-soft)}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--cog);transition:width .25s}
.main-nav a:hover{color:var(--slate)}
.main-nav a:hover::after{width:100%}
.head-inner .btn{margin-left:0}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}
.nav-toggle span{width:24px;height:2px;background:var(--slate);transition:.3s}
.mobile-nav{display:none;flex-direction:column;background:var(--ivory);border-bottom:1px solid var(--line)}
.mobile-nav:not([hidden]){display:flex}
[hidden]{display:none!important}
.mobile-nav a{padding:1rem 24px;border-top:1px solid var(--line)}

/* HERO */
.hero{position:relative;overflow:hidden;padding:5.5rem 0 4.5rem;background:linear-gradient(180deg,var(--ivory),var(--vellum))}
.mist{position:absolute;inset:0;pointer-events:none}
.strata{position:absolute;left:-10%;width:120%;height:50%;border-radius:50%;filter:blur(60px);opacity:.5}
.s1{top:-20%;background:radial-gradient(closest-side,rgba(92,122,143,.45),transparent);animation:drift 22s ease-in-out infinite}
.s2{top:25%;background:radial-gradient(closest-side,rgba(168,176,184,.5),transparent);animation:drift 28s ease-in-out infinite reverse}
.s3{top:55%;background:radial-gradient(closest-side,rgba(228,220,203,.7),transparent);animation:drift 34s ease-in-out infinite}
@keyframes drift{0%,100%{transform:translateX(0) translateY(0)}50%{transform:translateX(6%) translateY(4%)}}
.hero-inner{position:relative;z-index:1}
.hero h1{margin:.4rem 0 1.4rem}
.lede{font-size:1.18rem;max-width:54ch;color:var(--slate-soft)}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin:2rem 0 2.8rem}
.hero-stats{display:flex;gap:2.6rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1.6rem}
.hero-stats dt{font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cog);margin-bottom:.3rem}
.hero-stats dd{font-family:var(--serif);font-size:1.9rem}

/* BANDS */
.band{padding:5rem 0}
.band-soft{background:var(--vellum)}
.band-dark{background:var(--slate);color:var(--ivory)}
.band-dark .tarif-note{color:var(--fog)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.two-col.reverse .col-media{order:-1}
.col-text p{margin-bottom:1.1rem;color:var(--slate-soft);max-width:52ch}
.band-dark .col-text p{color:var(--fog)}
.col-media img{border-radius:var(--radius);box-shadow:0 30px 60px -30px rgba(44,49,56,.4)}
.col-media figcaption{margin-top:.8rem;font-size:.85rem;color:var(--cog);font-style:italic}

.ticks{list-style:none;margin-top:1.4rem;display:grid;gap:.7rem}
.ticks li{padding-left:1.7rem;position:relative;color:var(--slate-soft)}
.ticks li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--cog)}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:.5rem}
.card{background:var(--ivory);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem 1.4rem;transition:.3s}
.band-soft .card{background:rgba(242,238,230,.7)}
.card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -24px rgba(44,49,56,.4);border-color:var(--cog)}
.card-no{font-family:var(--serif);font-size:1.1rem;color:var(--cog);opacity:.7}
.card h3{font-size:1.25rem;margin:.6rem 0 .6rem}
.card p{font-size:.95rem;color:var(--slate-soft)}

/* STEPS */
.steps{list-style:none;counter-reset:s;display:grid;gap:1.4rem;margin-top:.5rem}
.steps li{counter-increment:s;padding-left:3.2rem;position:relative;color:var(--slate-soft)}
.steps li::before{content:counter(s,decimal-leading-zero);position:absolute;left:0;top:-.1em;font-family:var(--serif);font-size:1.4rem;color:var(--cog)}
.steps strong{color:var(--slate);font-weight:600}

/* PRICES */
.tarif-note{max-width:60ch;margin-bottom:2.4rem}
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:start}
.price{background:var(--slate-soft);border:1px solid rgba(242,238,230,.14);border-radius:var(--radius);padding:2rem 1.7rem;position:relative}
.price.featured{background:var(--ivory);color:var(--slate);transform:translateY(-8px)}
.price h3{font-size:1.3rem;margin-bottom:.6rem}
.amount{font-family:var(--serif);font-size:2.3rem;line-height:1}
.amount span{font-size:1rem;font-family:var(--sans);color:var(--fog)}
.price.featured .amount span{color:var(--cog)}
.per{font-size:.85rem;color:var(--fog);margin:.4rem 0 1.3rem}
.price.featured .per{color:var(--cog)}
.price ul{list-style:none;display:grid;gap:.6rem;margin-bottom:1.6rem;font-size:.93rem;color:var(--fog)}
.price.featured ul{color:var(--slate-soft)}
.price ul li{padding-left:1.4rem;position:relative}
.price ul li::before{content:"–";position:absolute;left:0;color:var(--cog)}
.tag{position:absolute;top:-.8rem;right:1.5rem;background:var(--cog);color:var(--ivory);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.35em .9em;border-radius:999px}

/* CONTACT FORM */
.coords{font-style:normal;margin-top:1.6rem;line-height:1.7}
.coords a{color:var(--cog)}
.coords a:hover{text-decoration:underline}
.form{background:var(--ivory);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field label{font-size:.85rem;font-weight:600;letter-spacing:.02em}
.field input,.field select,.field textarea{
  font:inherit;padding:.7em .9em;border:1px solid var(--line);border-radius:9px;
  background:#fff;color:var(--slate);transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cog);box-shadow:0 0 0 3px rgba(92,122,143,.18)}
.field textarea{resize:vertical}
.consent{display:flex;gap:.7rem;font-size:.85rem;color:var(--slate-soft);align-items:flex-start}
.consent input{margin-top:.25em;accent-color:var(--cog)}
.consent a{color:var(--cog);text-decoration:underline}
.form-status{font-size:.9rem;min-height:1.2em}
.form-status.ok{color:var(--cog);font-weight:600}
.form-status.err{color:#9a3b3b;font-weight:600}

/* FOOTER */
.site-foot{background:var(--ink);color:var(--fog);padding:3.5rem 0 1.5rem}
.foot-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(242,238,230,.12)}
.brand.small{font-size:1.25rem;color:var(--ivory)}
.foot-brand p{margin-top:.7rem;font-size:.9rem;max-width:34ch}
.foot-nav h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ivory);margin-bottom:1rem;font-weight:600}
.foot-nav a{display:block;font-size:.92rem;padding:.3em 0;color:var(--fog);transition:.2s}
.foot-nav a:hover{color:var(--ivory)}
.foot-base{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;font-size:.85rem;flex-wrap:wrap;gap:1rem}
.foot-base .link-btn{color:var(--fog)}

/* COOKIE BANNER */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:80;background:var(--slate);color:var(--ivory);box-shadow:0 -10px 40px -20px rgba(0,0,0,.5)}
.cookie-inner{max-width:var(--maxw);margin:0 auto;padding:1.3rem 24px;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.cookie-inner p{font-size:.9rem;flex:1;min-width:260px;color:var(--fog)}
.cookie-inner a{color:var(--ivory);text-decoration:underline}
.cookie-actions{display:flex;gap:.8rem}

/* LEGAL PAGES */
.legal{padding:4rem 0 5rem;max-width:760px}
.legal h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:.6rem}
.legal .updated{color:var(--cog);font-size:.9rem;margin-bottom:2.4rem}
.legal h2{font-size:1.5rem;margin:2.2rem 0 .8rem}
.legal h3{font-size:1.15rem;margin:1.4rem 0 .5rem}
.legal p,.legal li{color:var(--slate-soft);margin-bottom:.9rem}
.legal ul{padding-left:1.3rem;margin-bottom:1rem}
.legal a{color:var(--cog);text-decoration:underline}
.back-link{display:inline-block;margin-top:2.5rem;font-size:.9rem;color:var(--cog)}

/* RESPONSIVE */
@media(max-width:900px){
  .main-nav,.head-inner>.btn{display:none}
  .nav-toggle{display:flex}
  .two-col{grid-template-columns:1fr;gap:2.2rem}
  .two-col.reverse .col-media{order:0}
  .cards{grid-template-columns:repeat(2,1fr)}
  .prices{grid-template-columns:1fr}
  .price.featured{transform:none}
  .foot-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .band{padding:3.5rem 0}
  .hero{padding:3.5rem 0}
  .cards{grid-template-columns:1fr}
  .hero-stats{gap:1.6rem}
  .foot-inner{grid-template-columns:1fr}
  .cookie-inner{gap:1rem}
  .cookie-actions{width:100%}
  .cookie-actions .btn{flex:1}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
}
