/* Uro Formula — uroformula.com */
:root{
  --cream: #f7f4ef;
  --paper: #fffefb;
  --ink: #1c2333;
  --ink-soft: #4d5668;
  --muted: #7a8494;
  --line: #e2ddd4;
  --navy: #1c2333;
  --copper: #b85c38;
  --copper-dark: #9a4a2c;
  --mint: #2a7a6f;
  --mint-soft: #e8f4f1;
  --warn-bg: #fff3e8;
  --warn-border: #e8a87c;
  --font: "Outfit", system-ui, sans-serif;
  --serif: "Libre Baskerville", Georgia, serif;
  --max: 1140px;
  --pad: clamp(16px, 4vw, 32px);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font);
  font-size:15px;
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.shell{ max-width:var(--max); margin:0 auto; padding:0 var(--pad); }

/* Bandeau */
.ribbon{
  background:var(--navy);
  color:rgba(255,255,255,.75);
  text-align:center;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:8px var(--pad);
}

/* Header horizontal */
.topbar{
  background:var(--paper);
  border-bottom:2px solid var(--ink);
  position:sticky;
  top:0;
  z-index:50;
}
.topbar-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:14px var(--pad);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:12px;
}
.logo{
  justify-self:center;
  text-align:center;
}
.logo-mark{
  display:inline-grid;
  place-items:center;
  width:44px;
  height:44px;
  background:var(--copper);
  color:#fff;
  font-weight:800;
  font-size:14px;
  border-radius:4px;
  margin-bottom:6px;
}
.logo strong{
  display:block;
  font-family:var(--serif);
  font-size:20px;
  letter-spacing:-.02em;
}
.logo span{
  font-size:11px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}
.topnav{
  justify-self:start;
  display:flex;
  flex-wrap:wrap;
  gap:4px 14px;
  font-size:13px;
  font-weight:500;
}
.topnav a:hover{ color:var(--copper); }
.topcta{ justify-self:end; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 18px;
  font-size:13px;
  font-weight:600;
  border:2px solid var(--ink);
  border-radius:2px;
  background:var(--paper);
  cursor:pointer;
  transition:background .12s, color .12s;
}
.btn:hover{ background:var(--ink); color:#fff; }
.btn-fill{
  background:var(--copper);
  border-color:var(--copper);
  color:#fff;
}
.btn-fill:hover{
  background:var(--copper-dark);
  border-color:var(--copper-dark);
  color:#fff;
}
.btn-mint{
  background:var(--mint);
  border-color:var(--mint);
  color:#fff;
}
.btn-mint:hover{ filter:brightness(.95); color:#fff; }

/* Hero: image pleine largeur + carte centrée */
.hero-banner{
  position:relative;
  min-height:min(420px, 52vh);
  display:grid;
  place-items:center;
  overflow:hidden;
}
.hero-banner img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 35%;
}
.hero-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(28,35,51,.55) 0%, rgba(28,35,51,.75) 100%);
  z-index:1;
}
.hero-box{
  position:relative;
  z-index:2;
  max-width:640px;
  margin:24px var(--pad);
  padding:28px 32px;
  background:var(--paper);
  border:3px solid var(--ink);
  box-shadow:12px 12px 0 var(--copper);
  text-align:center;
}
.hero-box .tag{
  font-size:10px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--mint);
  margin-bottom:10px;
}
.hero-box h1{
  font-family:var(--serif);
  font-size:clamp(24px, 4vw, 36px);
  line-height:1.15;
  margin:0 0 12px;
}
.hero-box .lead{
  font-size:14px;
  color:var(--ink-soft);
  margin:0 0 18px;
}
.hero-chips{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin-bottom:18px;
  list-style:none;
  padding:0;
}
.hero-chips li{
  font-size:11px;
  font-weight:600;
  padding:5px 10px;
  background:var(--mint-soft);
  color:var(--mint);
  border:1px solid rgba(42,122,111,.25);
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
}
.hero-note{
  display:block;
  margin-top:12px;
  font-size:10px;
  color:var(--muted);
}

/* Sections */
.block{ padding:48px 0; }
.block.alt{ background:var(--paper); border-block:1px solid var(--line); }
.block.dark{ background:var(--navy); color:#fff; }

.head{
  margin-bottom:28px;
  max-width:640px;
}
.head.center{ margin-inline:auto; text-align:center; }
.head h2{
  font-family:var(--serif);
  font-size:clamp(22px, 3vw, 30px);
  margin:0 0 8px;
}
.head p{ margin:0; color:var(--ink-soft); font-size:14px; }
.block.dark .head p{ color:rgba(255,255,255,.65); }

/* 3 étapes — colonnes inversées (grande au centre) */
.trio{
  display:grid;
  grid-template-columns:1fr 1.15fr 1fr;
  gap:0;
  border:2px solid var(--ink);
}
.trio-item{
  padding:24px 20px;
  border-right:2px solid var(--ink);
  background:var(--paper);
}
.trio-item:last-child{ border-right:none; }
.trio-item.featured{
  background:var(--mint-soft);
  transform:scale(1.02);
  z-index:1;
  box-shadow:0 0 0 2px var(--mint);
}
.trio-num{
  font-size:11px;
  font-weight:800;
  color:var(--copper);
  letter-spacing:.1em;
  margin-bottom:8px;
}
.trio-item h3{
  font-family:var(--serif);
  font-size:18px;
  margin:0 0 8px;
}
.trio-item p{ margin:0; font-size:13px; color:var(--ink-soft); }

/* Alerte */
.alert-line{
  padding:20px var(--pad);
  background:var(--warn-bg);
  border-top:3px solid var(--warn-border);
  border-bottom:3px solid var(--warn-border);
}
.alert-line p{ margin:0; max-width:var(--max); margin-inline:auto; font-size:14px; color:var(--ink-soft); }
.alert-line strong{ color:var(--copper); }

/* 5 leviers — liste horizontale empilée */
.lever-list{ display:flex; flex-direction:column; gap:0; }
.lever{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:20px;
  padding:20px 24px;
  border-bottom:1px solid var(--line);
  align-items:start;
}
.lever:nth-child(odd){ background:var(--paper); }
.lever:nth-child(even){ background:var(--cream); }
.lever-n{
  font-family:var(--serif);
  font-size:32px;
  font-weight:700;
  color:var(--copper);
  line-height:1;
}
.lever h3{ margin:0 0 6px; font-size:16px; font-weight:700; }
.lever p{ margin:0; font-size:13px; color:var(--ink-soft); }

/* Contexte — citation large */
.quote-panel{
  padding:40px;
  border-left:8px solid var(--copper);
  background:var(--paper);
  font-family:var(--serif);
  font-size:clamp(18px, 2.5vw, 24px);
  line-height:1.5;
  color:var(--ink);
}
.quote-panel cite{
  display:block;
  margin-top:16px;
  font-family:var(--font);
  font-size:12px;
  font-style:normal;
  color:var(--muted);
}

/* Produit — en bas, layout inverse (texte gauche, image droite) */
.product-final{
  display:grid;
  grid-template-columns:1.2fr 0.8fr;
  gap:32px;
  align-items:center;
  padding:40px;
  background:linear-gradient(135deg, #243047 0%, var(--navy) 100%);
  color:#fff;
  border-radius:0;
}
.product-final h2{
  font-family:var(--serif);
  font-size:36px;
  margin:8px 0 12px;
}
.product-final .sub{ opacity:.85; font-size:14px; margin-bottom:16px; }
.product-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:20px;
  list-style:none;
  padding:0;
}
.product-tags li{
  font-size:11px;
  padding:6px 10px;
  border:1px solid rgba(255,255,255,.3);
}
.product-shot{
  background:rgba(255,255,255,.08);
  padding:20px;
  text-align:center;
}
.product-shot img{ margin:0 auto; max-height:260px; width:auto; }

/* FAQ — 4 cartes, bordure haut colorée */
.faq-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.faq-card{
  padding:20px;
  background:var(--paper);
  border:2px solid var(--line);
  border-top:5px solid var(--mint);
}
.faq-card h3{ margin:0 0 10px; font-size:15px; }
.faq-card p{ margin:0; font-size:13px; color:var(--ink-soft); }

/* Footer */
.site-foot{
  background:var(--ink);
  color:rgba(255,255,255,.7);
  padding:40px var(--pad) 28px;
  font-size:13px;
}
.foot-grid{
  max-width:var(--max);
  margin:0 auto 24px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.foot-grid h4{
  color:var(--copper);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin:0 0 12px;
}
.foot-grid a:hover{ color:#fff; }
.foot-legal{
  max-width:var(--max);
  margin:0 auto;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.12);
  font-size:11px;
  line-height:1.7;
}
.foot-copy{
  text-align:center;
  margin-top:16px;
  font-size:11px;
  opacity:.5;
}

/* Pages légales */
.page-main{ padding:40px var(--pad) 60px; flex:1; }
.doc{
  max-width:720px;
  margin:0 auto;
  padding:36px 40px;
  background:var(--paper);
  border:2px solid var(--ink);
}
.doc h1{ font-family:var(--serif); font-size:32px; margin:0 0 16px; }
.doc h2{ font-family:var(--serif); font-size:20px; margin:24px 0 8px; color:var(--mint); }
.doc p,.doc li{ font-size:14px; color:var(--ink-soft); }
.doc a{ color:var(--copper); text-decoration:underline; }

@media (max-width:900px){
  .topbar-inner{ grid-template-columns:1fr; text-align:center; }
  .topnav,.topcta{ justify-self:center; }
  .trio{ grid-template-columns:1fr; }
  .trio-item{ border-right:none; border-bottom:2px solid var(--ink); }
  .trio-item.featured{ transform:none; }
  .product-final{ grid-template-columns:1fr; padding:28px; }
  .faq-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
}
