@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,700;0,900;1,500&family=Inter:wght@400;500;600&family=Noto+Music&display=swap');

/* papier-musique.fr — éditorial noir & blanc, accent ocre */
:root{
  --paper:#ffffff;
  --bg:#f4f2ec;          /* blanc cassé chaud */
  --bg2:#eceae2;
  --ink:#161412;         /* presque noir */
  --ink2:#3c3a35;
  --muted:#8a867c;
  --line:#e0ddd2;
  --line2:#cfcabb;
  --accent:#b5532a;      /* terracotta (réf. PianoPlay) */
  --accent-d:#8f3f1f;
  --maxw:1180px;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--bg); color:var(--ink); font-family:var(--sans); font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden}
h1,h2,h3{font-family:var(--serif); color:var(--ink); font-weight:700; line-height:1.08}
h1{font-size:clamp(2.6rem,6.5vw,5rem); letter-spacing:-.01em; margin:.05em 0 .25em}
h1 em,h2 em{font-style:italic; font-weight:500}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem); margin:1.4em 0 .5em}
h3{font-size:1.18rem; font-family:var(--sans); font-weight:600; letter-spacing:.01em}
a{color:var(--accent-d); text-underline-offset:3px}
a:hover{color:var(--ink)}
p{margin:.65em 0}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 26px}
.eyebrow{font-family:var(--sans); text-transform:uppercase; letter-spacing:.26em; font-size:.72rem; color:var(--muted); font-weight:600; margin:0}
.lead{font-size:1.16rem; color:var(--ink2); max-width:560px}

/* header */
header.site{position:sticky; top:0; z-index:40; background:rgba(244,242,236,.9); backdrop-filter:blur(10px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; gap:18px; padding:16px 26px; max-width:var(--maxw); margin:0 auto; flex-wrap:wrap}
.brand{font-family:var(--serif); font-size:1.4rem; font-weight:700; color:var(--ink); text-decoration:none; letter-spacing:.01em}
.brand span{color:var(--accent)}
.nav nav{margin-left:auto; display:flex; gap:4px; flex-wrap:wrap}
.nav nav a{color:var(--ink2); text-decoration:none; padding:7px 12px; border-radius:7px; font-size:.92rem}
.nav nav a:hover{background:var(--bg2)}
.nav nav a[aria-current]{color:var(--accent-d); font-weight:600}

/* hero / générateur */
.hero{padding:40px 0 8px}
.hero .eyebrow{margin-bottom:10px}
.gen-grid{display:grid; gap:30px; align-items:start}
@media(min-width:920px){.gen-grid{grid-template-columns:380px 1fr}}

.controls{background:var(--paper); border:1px solid var(--line2); border-radius:14px; padding:22px}
.controls .field{margin:0 0 16px}
.controls label{display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); font-weight:600; margin:0 0 6px}
select,input[type=number]{width:100%; padding:11px 12px; border:1px solid var(--line2); border-radius:9px; background:#fff; color:var(--ink); font-family:inherit; font-size:1rem}
select:focus,input:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(181,83,42,.14)}
select:disabled{opacity:.45; cursor:not-allowed}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer; width:100%;
  border:1px solid var(--ink); border-radius:10px; padding:14px 18px; font-size:1rem; font-weight:600; font-family:var(--sans);
  background:var(--ink); color:#fff; transition:.14s}
.btn:hover{background:var(--accent-d); border-color:var(--accent-d)}
.btn.ghost{background:transparent; color:var(--ink); margin-top:10px}
.btn.ghost:hover{background:var(--bg2); color:var(--ink)}
.btn.sm{width:auto; padding:10px 16px; font-size:.92rem}
.hint{font-size:.82rem; color:var(--muted); margin-top:10px}

/* feuille d'aperçu */
.sheet-wrap{display:flex; justify-content:center}
.sheet{background:var(--paper); box-shadow:0 24px 60px rgba(22,20,18,.16), 0 2px 0 var(--line2); border:1px solid var(--line); max-width:100%}
.sheet svg{display:block; width:100%; height:auto; max-height:80vh}
.preview-cap{text-align:center; color:var(--muted); font-size:.82rem; margin-top:12px; letter-spacing:.04em}

/* sections éditoriales */
.section{padding:30px 0}
.rule{border:0; border-top:1px solid var(--line); margin:24px 0}
.two-col{display:grid; gap:30px}
@media(min-width:820px){.two-col{grid-template-columns:1fr 1fr}}

/* emplacements photos N&B (à remplir étape 2) */
.photo{position:relative; background:#e7e4da; border:1px solid var(--line2); border-radius:10px; overflow:hidden; filter:grayscale(1); aspect-ratio:4/3}
.photo img{width:100%; height:100%; object-fit:cover; display:block; filter:grayscale(1) contrast(1.02)}
.photo.tall{aspect-ratio:3/4}
.photo .ph-note{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#9a958a; font-size:.8rem; text-align:center; padding:10px}
.photo-row{display:grid; gap:16px; grid-template-columns:repeat(3,1fr)}
@media(max-width:640px){.photo-row{grid-template-columns:1fr 1fr}}

/* grille des variantes (maillage) */
.variants{display:grid; gap:14px; margin:14px 0}
@media(min-width:600px){.variants{grid-template-columns:1fr 1fr}}
@media(min-width:920px){.variants{grid-template-columns:1fr 1fr 1fr}}
.variant{display:block; background:var(--paper); border:1px solid var(--line2); border-radius:12px; padding:18px 20px; text-decoration:none; color:var(--ink2); transition:.14s}
.variant:hover{border-color:var(--ink); transform:translateY(-2px)}
.variant b{display:block; font-family:var(--serif); font-size:1.18rem; color:var(--ink); margin-bottom:2px}
.variant span{font-size:.9rem}

ul.clean{list-style:none; padding:0; margin:.6em 0}
ul.clean li{padding:9px 0 9px 24px; border-bottom:1px solid var(--line); position:relative}
ul.clean li::before{content:"♪"; position:absolute; left:0; top:9px; color:var(--accent); font-family:"Noto Music",serif}

.faq dt{font-weight:600; color:var(--ink); margin-top:16px; font-size:1.04rem}
.faq dd{margin:.3em 0 0; color:var(--ink2)}

.ad{display:flex; align-items:center; justify-content:center; margin:22px auto; max-width:728px;
  background:repeating-linear-gradient(45deg,#e9e6dc,#e9e6dc 11px,#efece3 11px,#efece3 22px);
  border:1px dashed var(--line2); border-radius:9px; color:#aaa493; font-size:.72rem; letter-spacing:.12em; font-family:var(--sans); text-transform:uppercase}
.ad-top{min-height:90px}.ad-mid{min-height:250px}.ad-foot{min-height:90px}

footer.site{margin-top:46px; border-top:1px solid var(--line); background:var(--ink); color:#cfcabb}
footer.site .wrap{padding:30px 26px; font-size:.92rem}
footer.site a{color:#fff; text-decoration:none; margin-right:16px}
footer.site a:hover{color:var(--accent)}
footer.site .fcols{display:grid; gap:18px; grid-template-columns:1fr; margin-bottom:18px}
@media(min-width:700px){footer.site .fcols{grid-template-columns:2fr 1fr 1fr}}
footer.site h4{font-family:var(--sans); font-size:.74rem; text-transform:uppercase; letter-spacing:.16em; color:#8a867c; margin:0 0 8px}
footer.site .fcols a{display:block; margin:0 0 6px; color:#cfcabb}
footer.site .fcols a:hover{color:#fff}

.cookie{position:fixed; bottom:16px; left:16px; right:16px; max-width:540px; margin:0 auto; z-index:60;
  background:var(--paper); border:1px solid var(--ink); border-radius:12px; padding:16px 18px; box-shadow:0 16px 44px rgba(22,20,18,.22); display:none}
.cookie.show{display:block}
.cookie p{margin:0 0 10px; font-size:.9rem; color:var(--ink2)}
.cookie .btn{width:auto; display:inline-flex}

article{font-size:1.05rem}

/* utilitaire pleine largeur (breakout) */
.bleed{width:100vw; margin-left:calc(50% - 50vw)}

/* bandeau héros photo */
.hero-banner{position:relative; min-height:clamp(440px,72vh,720px); display:flex; align-items:flex-end; overflow:hidden; background:#100f0d}
.hero-banner>img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 35%}
.hero-banner::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(16,15,13,.22) 0%,rgba(16,15,13,.32) 45%,rgba(16,15,13,.82) 100%); z-index:1}
.hero-banner .hb-inner{position:relative; z-index:2; width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px 54px; color:#fff}
.hero-banner h1{color:#fff; text-shadow:0 2px 24px rgba(0,0,0,.4); max-width:18ch}
.hero-banner .lead{color:#ece9e2; max-width:48ch}
.hero-banner .eyebrow{color:#e4c4ad}
.hero-banner .btn-light{display:inline-flex; align-items:center; gap:8px; margin-top:18px; background:#fff; color:var(--ink); border:1px solid #fff; border-radius:10px; padding:13px 22px; font-weight:600; text-decoration:none; transition:.14s}
.hero-banner .btn-light:hover{background:var(--accent); border-color:var(--accent); color:#fff}

/* bande photo dramatique (full-bleed) */
.feature{position:relative; overflow:hidden; background:#100f0d; min-height:clamp(360px,56vh,560px); display:flex; align-items:center}
.feature>img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 30%; opacity:.82}
.feature::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(16,15,13,.78) 0%,rgba(16,15,13,.4) 55%,rgba(16,15,13,.15) 100%); z-index:1}
.feature .cap{position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:48px 26px; color:#fff; width:100%}
.feature .cap blockquote{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.6rem,3.6vw,2.8rem); line-height:1.18; margin:0; max-width:18ch; color:#fff}
.feature .cap p{color:#d9d5cc; max-width:44ch}

/* galerie de photos */
.gallery{display:grid; gap:16px; grid-template-columns:1fr 1fr}
.gallery figure{margin:0; overflow:hidden; border-radius:12px; background:#e7e4da}
.gallery img{width:100%; height:100%; object-fit:cover; display:block; aspect-ratio:1/1; transition:transform .5s ease}
.gallery figure:hover img{transform:scale(1.04)}
.gallery .span2{grid-column:1 / -1; aspect-ratio:auto}
.gallery .span2 img{aspect-ratio:21/9}

/* zone d'impression (cachée à l'écran) */
#print-root{display:none}

@media print{
  @page{margin:0}
  body{background:#fff}
  body>*{display:none !important}
  #print-root{display:block !important}
  #print-root svg{width:100%; height:auto; display:block}
}
