/* compteur-belote.fr — thème clair éditorial (refonte grand public) */
:root{
  --bg:#f4f0e6;          /* ivoire */
  --bg2:#ece7d8;
  --paper:#fbf9f3;       /* cartes / panneaux */
  --ink:#191813;         /* presque noir */
  --ink2:#3a382f;
  --muted:#74715f;
  --line:#ddd6c4;        /* filets fins */
  --line2:#cabfa6;
  --accent:#1f7a47;      /* vert tapis, éclairci */
  --accent-d:#155c34;
  --accent-soft:#e6efe6;
  --red:#c0392b;         /* rouge cartes (cœur/carreau) */
  --good:#1f7a47; --bad:#c0392b;
  --radius:12px;
  --maxw:1040px;
  --serif:Georgia,"Iowan Old Style","Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","Cascadia Mono",Menlo,Consolas,"Liberation Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); line-height:1.62; font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand{font-family:var(--serif); line-height:1.12; color:var(--ink); font-weight:700}
h1{font-size:clamp(2rem,5.4vw,3.4rem); letter-spacing:-.01em; margin:.1em 0 .25em}
h2{font-size:clamp(1.4rem,3vw,2rem); margin:1.7em 0 .5em; letter-spacing:-.01em}
h3{font-size:1.2rem; margin:1.3em 0 .4em}
a{color:var(--accent-d); text-underline-offset:3px}
a:hover{color:var(--ink)}
p{margin:.65em 0}
code{font-family:var(--mono); background:#efe9da; padding:2px 6px; border-radius:5px; font-size:.92em}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}

/* libellé mono "eyebrow" */
.eyebrow{font-family:var(--mono); text-transform:uppercase; letter-spacing:.24em; font-size:.72rem; color:var(--muted); margin:0}

/* enseignes de cartes */
.suits{font-size:1.5rem; letter-spacing:.45em; line-height:1; margin:.7em 0 .2em; padding-left:.45em}
.suits .r{color:var(--red)}
.suits .b{color:var(--ink)}

/* ===== Header ===== */
header.site{position:sticky; top:0; z-index:40; background:rgba(244,240,230,.88); backdrop-filter:blur(10px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; gap:16px; padding:14px 22px; max-width:var(--maxw); margin:0 auto; flex-wrap:wrap}
.brand{font-size:1.25rem; color:var(--ink); text-decoration:none; display:flex; align-items:center; gap:8px; font-weight:700}
.brand b{color:var(--accent-d)}
.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:8px; font-size:.92rem}
.nav nav a:hover{background:var(--bg2)}
.nav nav a[aria-current]{background:var(--ink); color:#fff}

/* ===== Hero ===== */
.hero{padding:46px 0 14px; text-align:center}
.hero .eyebrow{margin-bottom:6px}
.hero p.lead{color:var(--ink2); max-width:660px; margin:.5em auto 0; font-size:1.12rem}
.hero .suits{display:inline-block}

/* éventail de cartes (illustration glyphe, accueil) */
.card-fan{position:relative; height:230px; margin:18px auto 6px; max-width:520px}
.pcard{position:absolute; left:50%; top:18px; width:122px; height:172px; margin-left:-61px;
  background:var(--paper); border:1px solid var(--line2); border-radius:14px;
  box-shadow:0 12px 26px rgba(60,50,20,.12); display:flex; align-items:center; justify-content:center;
  font-size:3.1rem; transform-origin:50% 120%}
.pcard.b{color:var(--ink)}
.pcard.r{color:var(--red)}
.pcard:nth-child(1){transform:rotate(-21deg) translateX(-12px)}
.pcard:nth-child(2){transform:rotate(-7deg)}
.pcard:nth-child(3){transform:rotate(7deg)}
.pcard:nth-child(4){transform:rotate(21deg) translateX(12px)}
@media(max-width:520px){.card-fan{transform:scale(.8)}}

/* filets de section */
.rule{border:0; border-top:1px solid var(--line); margin:30px 0}

/* ===== Panneaux ===== */
.panel{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:24px; margin:22px 0}
.panel.bracket{position:relative}
.panel.bracket::before,.panel.bracket::after{content:""; position:absolute; width:16px; height:16px; pointer-events:none}
.panel.bracket::before{top:10px; left:10px; border-top:2px solid var(--accent); border-left:2px solid var(--accent)}
.panel.bracket::after{bottom:10px; right:10px; border-bottom:2px solid var(--accent); border-right:2px solid var(--accent)}

.grid{display:grid; gap:16px}
@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(--mono); font-size:.7rem; color:var(--muted); margin:0 0 6px; text-transform:uppercase; letter-spacing:.12em}
select,input[type=number],input[type=text]{width:100%; padding:12px 13px; border-radius:9px;
  border:1px solid var(--line2); background:#fff; color:var(--ink); font-size:1.04rem; font-family:inherit}
select:focus,input:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}

/* boutons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  border:1px solid var(--accent); border-radius:10px; padding:12px 20px; font-size:1rem; font-weight:600;
  font-family:var(--sans); background:var(--accent); color:#fff; transition:.14s}
.btn:hover{background:var(--accent-d); border-color:var(--accent-d)}
.btn.ghost{background:transparent; color:var(--ink); border:1px solid var(--line2)}
.btn.ghost:hover{background:var(--bg2); border-color:var(--ink); color:var(--ink)}
.btn.alt{background:var(--ink); color:#fff; border-color:var(--ink)}
.btn.alt:hover{background:#000}
.btn-row{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}

/* segments */
.seg{display:flex; flex-wrap:wrap; gap:7px}
.seg button{flex:1 1 auto; padding:11px 10px; border-radius:9px; border:1px solid var(--line2); background:#fff;
  color:var(--ink2); cursor:pointer; font-family:inherit; font-size:.96rem; transition:.12s}
.seg button:hover{border-color:var(--accent)}
.seg button[aria-pressed=true]{background:var(--accent); color:#fff; border-color:var(--accent); font-weight:700}

/* onglets de mode */
.tabs{display:flex; gap:28px; margin:24px 0 0; border-bottom:1px solid var(--line)}
.tabs button{background:none; border:none; padding:0 2px 14px; margin-bottom:-1px; cursor:pointer;
  font-family:var(--serif); font-size:1.25rem; font-weight:700; color:var(--muted); border-bottom:2px solid transparent}
.tabs button[aria-selected=true]{color:var(--ink); border-bottom-color:var(--accent)}
.mode{display:none}
.mode.active{display:block}

.result{font-size:1.05rem}
.result .big{font-size:1.55rem; font-family:var(--serif); color:var(--ink); margin:.1em 0}

/* tableau */
table{width:100%; border-collapse:collapse; margin:12px 0; font-size:.98rem}
th,td{padding:11px 12px; border-bottom:1px solid var(--line); text-align:center}
th{font-family:var(--mono); color:var(--muted); font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; font-weight:600}
td:first-child,th:first-child{text-align:left}
td.pos{color:var(--good); font-weight:600}
td.neg{color:var(--bad); font-weight:600}
tfoot td{font-weight:700; color:var(--ink); border-top:2px solid var(--ink); font-size:1.12rem}

.winner-banner{margin:14px 0; padding:15px; border-radius:10px; text-align:center; font-size:1.1rem; font-weight:600;
  background:var(--accent-soft); border:1px solid var(--accent); color:var(--accent-d); display:none}
.winner-banner.show{display:block}
.note{color:var(--muted); font-size:.9rem}

ul.clean{list-style:none; padding:0; margin:.6em 0}
ul.clean li{padding:9px 0 9px 26px; border-bottom:1px solid var(--line); position:relative}
ul.clean li::before{content:"\25C6"; position:absolute; left:0; top:9px; color:var(--accent); font-size:.7em}

/* cartes liens */
.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:1px solid var(--line); border-radius:12px; padding:18px; text-decoration:none; color:var(--ink2); transition:.14s}
.card:hover{border-color:var(--accent); transform:translateY(-2px); box-shadow:0 10px 22px rgba(60,50,20,.08)}
.card b{color:var(--ink); font-family:var(--serif)}

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

footer.site{margin-top:48px; border-top:1px solid var(--line); background:var(--bg2)}
footer.site .wrap{padding:26px 22px; color:var(--muted); font-size:.92rem}
footer.site a{color:var(--ink2); text-decoration:none; margin-right:16px}
footer.site a:hover{color:var(--ink)}

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

.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(--line2); border-radius:12px; padding:16px 18px; box-shadow:0 16px 40px rgba(60,50,20,.18); display:none}
.cookie.show{display:block}
.cookie p{margin:0 0 10px; font-size:.9rem; color:var(--ink2)}

article{font-size:1.04rem}
article h2{position:relative}

@media print{
  header.site,footer.site,.ad,.cookie,.btn-row,.tabs,.card-fan,.suits,.no-print{display:none!important}
  body{background:#fff; color:#000}
  .panel{box-shadow:none; border:1px solid #999; background:#fff}
}
