@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=DM+Sans:wght@400;500;700&display=swap');

/* pere-noel-secret.fr — thème géométrique de Noël (rouge / vert / crème) */
:root{
  --cream:#f5efdd;        /* fond papier */
  --cream2:#efe7cf;
  --paper:#fffdf6;
  --ink:#1b2a22;          /* vert très foncé */
  --ink2:#3f4f44;
  --muted:#6f7a70;
  --line:#e1d8bf;
  --line2:#d4c9a6;
  --red:#e23b2e;          /* rouge Noël */
  --red-d:#c52a20;
  --green:#1f6b4f;        /* vert sapin */
  --green-d:#14543d;
  --pink:#f2a9c4;
  --gold:#f3c33b;
  --blue:#2f6fb0;
  --good:#1f6b4f; --bad:#c52a20;
  --radius:18px;
  --maxw:1060px;
  --display:"Fredoka",system-ui,sans-serif;
  --sans:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--ink); font-family:var(--sans); line-height:1.62; font-size:17px;
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand{font-family:var(--display); color:var(--ink); font-weight:700; line-height:1.1}
h1{font-size:clamp(2.2rem,6vw,3.7rem); letter-spacing:-.01em; margin:.1em 0 .28em}
h2{font-size:clamp(1.5rem,3.4vw,2.2rem); margin:1.6em 0 .5em}
h3{font-size:1.22rem; margin:1.2em 0 .4em; color:var(--green-d)}
a{color:var(--red-d); text-underline-offset:3px; font-weight:500}
a:hover{color:var(--green-d)}
p{margin:.65em 0}
code{font-family:ui-monospace,Menlo,Consolas,monospace; background:var(--cream2); padding:2px 6px; border-radius:5px; font-size:.9em}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}

.eyebrow{font-family:var(--sans); text-transform:uppercase; letter-spacing:.22em; font-size:.74rem; color:var(--red); font-weight:700; margin:0}
.lead{font-size:1.18rem; color:var(--ink2); max-width:640px}

/* bandeau géométrique haut/bas (damier de Noël) */
.band{height:18px; width:100%;
  background:
    repeating-linear-gradient(90deg,var(--red) 0 36px,var(--green) 36px 72px,var(--pink) 72px 108px,var(--gold) 108px 144px);
}

/* ===== Header ===== */
header.site{position:sticky; top:0; z-index:40; background:rgba(245,239,221,.92); backdrop-filter:blur(10px); border-bottom:2px solid var(--ink)}
.nav{display:flex; align-items:center; gap:14px; padding:13px 22px; max-width:var(--maxw); margin:0 auto; flex-wrap:wrap}
.brand{font-size:1.34rem; color:var(--ink); text-decoration:none; display:flex; align-items:center; gap:9px; font-weight:700}
.brand .dot{display:inline-block; width:16px; height:16px; border-radius:50%; background:var(--red); box-shadow:0 0 0 4px var(--gold)}
.nav nav{margin-left:auto; display:flex; gap:2px; flex-wrap:wrap}
.nav nav a{color:var(--ink2); text-decoration:none; padding:7px 12px; border-radius:9px; font-size:.92rem; font-weight:500}
.nav nav a:hover{background:var(--cream2)}
.nav nav a[aria-current]{background:var(--green); color:#fff}

/* ===== Hero ===== */
.hero{padding:44px 0 18px}
.hero-grid{display:grid; gap:24px; align-items:center}
@media(min-width:820px){.hero-grid{grid-template-columns:1.1fr .9fr}}
.hero .eyebrow{margin-bottom:10px}
.hero-art{text-align:center}
.hero-art img{width:100%; max-width:420px; height:auto}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}

/* ===== Panneaux ===== */
.panel{background:var(--paper); border:2px solid var(--ink); border-radius:var(--radius); padding:24px; margin:22px 0;
  box-shadow:6px 6px 0 var(--green)}
.panel.red{box-shadow:6px 6px 0 var(--red)}
.panel.flat{box-shadow:none; border:1px solid var(--line2)}
.step-label{display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:700; font-size:1.15rem; color:var(--ink); margin:0 0 4px}
.step-num{display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:50%;
  background:var(--red); color:#fff; font-size:.95rem; box-shadow:0 0 0 3px var(--gold)}

.grid{display:grid; gap:14px}
@media(min-width:680px){.cols-2{grid-template-columns:1fr 1fr}.cols-3{grid-template-columns:1fr 1fr 1fr}}
label{display:block; font-family:var(--sans); font-size:.72rem; color:var(--muted); margin:0 0 6px; text-transform:uppercase; letter-spacing:.1em; font-weight:700}
input[type=text],input[type=number],input[type=date],select{width:100%; padding:12px 13px; border-radius:10px;
  border:1.5px solid var(--line2); background:#fff; color:var(--ink); font-size:1.04rem; font-family:inherit}
input:focus,select:focus{outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(31,107,79,.15)}

/* lignes participants */
.prow{display:flex; gap:10px; align-items:center; margin:8px 0}
.prow .pn{flex:1 1 38%}
.prow .pw{flex:1 1 50%}
.prow .x{flex:0 0 auto}
.iconbtn{border:1.5px solid var(--line2); background:#fff; color:var(--red-d); width:42px; height:42px; border-radius:10px; cursor:pointer; font-size:1.1rem; line-height:1}
.iconbtn:hover{border-color:var(--red); background:#fff5f3}
.exrow{display:flex; gap:10px; align-items:center; margin:8px 0}
.exrow select{flex:1 1 auto}

/* boutons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  border:2px solid var(--ink); border-radius:12px; padding:13px 22px; font-size:1.05rem; font-weight:700;
  font-family:var(--display); background:var(--red); color:#fff; transition:.12s; box-shadow:3px 3px 0 var(--ink)}
.btn:hover{transform:translate(-1px,-1px); box-shadow:5px 5px 0 var(--ink)}
.btn:active{transform:translate(2px,2px); box-shadow:1px 1px 0 var(--ink)}
.btn.green{background:var(--green)}
.btn.gold{background:var(--gold); color:var(--ink)}
.btn.ghost{background:var(--paper); color:var(--ink); box-shadow:3px 3px 0 var(--line2); border-color:var(--ink)}
.btn.sm{padding:8px 14px; font-size:.92rem; box-shadow:2px 2px 0 var(--ink)}
.btn-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:16px}

.note{color:var(--muted); font-size:.9rem}
.alert{padding:14px 16px; border-radius:12px; margin:14px 0; font-weight:500}
.alert.err{background:#fdecea; border:1.5px solid var(--red); color:var(--red-d)}
.alert.ok{background:#e8f3ee; border:1.5px solid var(--green); color:var(--green-d)}

/* résultats : cartes de liens secrets */
.links{display:grid; gap:12px; margin-top:6px}
.linkcard{display:flex; align-items:center; gap:12px; flex-wrap:wrap; background:var(--paper); border:1.5px solid var(--line2); border-radius:12px; padding:14px 16px}
.linkcard .who{font-family:var(--display); font-weight:600; font-size:1.1rem; flex:1 1 140px}
.linkcard .acts{display:flex; gap:8px; flex-wrap:wrap}
.secret-pill{font-family:ui-monospace,Menlo,monospace; font-size:.78rem; color:var(--muted); background:var(--cream2); border-radius:8px; padding:4px 8px; max-width:230px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}

ul.clean{list-style:none; padding:0; margin:.6em 0}
ul.clean li{padding:9px 0 9px 28px; border-bottom:1px solid var(--line); position:relative}
ul.clean li::before{content:"✦"; position:absolute; left:2px; top:10px; color:var(--gold); font-size:.85em}

/* cartes liens internes */
.cards{display:grid; gap:14px; margin-top:8px}
@media(min-width:680px){.cards{grid-template-columns:1fr 1fr}}
.card{display:block; background:var(--paper); border:2px solid var(--ink); border-radius:14px; padding:18px; text-decoration:none; color:var(--ink2); transition:.13s; box-shadow:3px 3px 0 var(--green)}
.card:hover{transform:translate(-1px,-1px); box-shadow:5px 5px 0 var(--green)}
.card b{color:var(--ink); font-family:var(--display); font-size:1.05rem}

/* tableaux (idées cadeaux / budget) */
table{width:100%; border-collapse:collapse; margin:12px 0; font-size:.98rem; background:var(--paper); border:1.5px solid var(--line2); border-radius:12px; overflow:hidden}
th,td{padding:11px 13px; border-bottom:1px solid var(--line); text-align:left}
th{font-family:var(--display); color:#fff; background:var(--green); font-size:.92rem; letter-spacing:.02em}
tr:last-child td{border-bottom:none}

/* AdSense */
.ad{display:flex; align-items:center; justify-content:center; margin:22px auto; max-width:728px;
  background:repeating-linear-gradient(45deg,#ece3c8,#ece3c8 11px,#f1e9d0 11px,#f1e9d0 22px);
  border:1.5px dashed var(--line2); border-radius:10px; color:#a89868; font-size:.72rem; letter-spacing:.12em; font-family:ui-monospace,Menlo,monospace; text-transform:uppercase}
.ad-top{min-height:100px}.ad-mid{min-height:250px}.ad-foot{min-height:100px}

/* reveal */
.reveal-wrap{max-width:560px; margin:0 auto; text-align:center}
.gift-card{background:var(--paper); border:2px solid var(--ink); border-radius:22px; padding:30px 26px; box-shadow:8px 8px 0 var(--red); margin:18px 0}
.reveal-name{font-family:var(--display); font-weight:700; font-size:clamp(2rem,7vw,3.2rem); color:var(--red-d); margin:.1em 0}
.meta-chips{display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:14px}
.chip{background:var(--green); color:#fff; border-radius:999px; padding:7px 15px; font-weight:600; font-size:.92rem}
.chip.gold{background:var(--gold); color:var(--ink)}

footer.site{margin-top:42px; border-top:2px solid var(--ink); background:var(--green-d); color:#f3ead0}
footer.site .wrap{padding:26px 22px; font-size:.92rem}
footer.site a{color:var(--gold); text-decoration:none; margin-right:16px}
footer.site a:hover{color:#fff}

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

.cookie{position:fixed; bottom:16px; left:16px; right:16px; max-width:540px; margin:0 auto; z-index:60;
  background:var(--paper); border:2px solid var(--ink); border-radius:14px; padding:16px 18px; box-shadow:6px 6px 0 var(--red); display:none}
.cookie.show{display:block}
.cookie p{margin:0 0 10px; font-size:.9rem; color:var(--ink2)}

article{font-size:1.04rem}

/* illustrations : fond rond doux derrière les PNG transparents */
.hero-art{position:relative}
.hero-art img{position:relative; z-index:1}
.illus-blob{position:relative; display:inline-block}
.illus-blob::before{content:""; position:absolute; left:4%; top:8%; right:4%; bottom:4%;
  background:radial-gradient(circle at 50% 45%,#fff 0,var(--cream2) 70%); border-radius:50%; z-index:0}
.illus-blob img{position:relative; z-index:1}

/* vitrine image + texte */
.showcase{display:grid; gap:26px; align-items:center; margin:8px 0}
@media(min-width:780px){
  .showcase{grid-template-columns:1fr 1fr}
  .showcase.rev .sc-img{order:2}
}
.sc-img{text-align:center}
.sc-img img{width:100%; max-width:420px; height:auto; display:block; margin:0 auto}

/* 3 étapes illustrées */
.steps{display:grid; gap:16px; margin:18px 0}
@media(min-width:760px){.steps{grid-template-columns:repeat(3,1fr)}}
.stepcard{background:var(--paper); border:2px solid var(--ink); border-radius:16px; padding:22px 18px; box-shadow:4px 4px 0 var(--green); text-align:center}
.stepcard:nth-child(2){box-shadow:4px 4px 0 var(--red)}
.stepcard:nth-child(3){box-shadow:4px 4px 0 var(--gold)}
.stepcard .ico{width:84px; height:84px; margin:0 auto 6px; display:block}
.stepcard .n{display:inline-block; font-family:var(--display); font-weight:700; color:var(--red); font-size:.9rem; letter-spacing:.06em}
.stepcard h3{margin:.25em 0 .3em; color:var(--ink)}
.stepcard p{margin:0; font-size:.96rem; color:var(--ink2)}

/* bande décorative (traîneau) */
.sleigh-band{text-align:center; margin:30px 0 10px}
.sleigh-band img{width:100%; max-width:720px; height:auto}

@media print{
  header.site,footer.site,.ad,.cookie,.btn-row,.band,.sleigh-band,.illus-blob,.showcase img,.steps,.no-print{display:none!important}
  body{background:#fff; color:#000}
  .panel{box-shadow:none; border:1px solid #999; background:#fff}
}
