:root {
    --bg: #0e0f12;
    --card: #151821;
    --ink: #f6f7fb;
    --muted: #b8c0d0;
    --accent: #005C45;
    --line: #232733;
    --link: #8bb7ff;
}

/* RESET */
* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Inter, Arial, sans-serif;
    line-height: 1.55;
}

a {
    color: var(--link);
    text-decoration: none;
}

a:hover {
    text-decoration: none;
    color: var(--accent);
}

a:focus {
    text-decoration: none;
    outline: none;
}

a:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.wrap {
    max-width: 1100px;
    margin-inline: auto;
    padding: 24px;
}

/* -------------------------------------------------------
TOPBAR & LANG SWITCH
------------------------------------------------------- */

.topbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    height: 4px;
    margin-bottom: 6px;
    padding: 0px 16px;
    font-size: 0.85rem;
}

.lang-switch {
    margin-top: 0;
    font-size: 0.9rem;
    text-align: right;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.lang-switch a {
    color: var(--muted);
    text-decoration: none;
    padding: 2px 6px;
    border-radius: 4px;
}

.lang-switch a:hover {
    color: var(--ink);
    background: var(--card);
}

.lang-switch span {
    opacity: 0.6;
    margin: 0 4px;
}

.lang-switch a[aria-current="page"] {
    color: var(--ink);
    font-weight: 600;
    background: var(--card);
}

.lang-link {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    text-decoration: none;
    opacity: 0.7;
}

.lang-link.is-current {
    opacity: 1;
    font-weight: 600;
}

.flag-icon {
    width: 16px;
    height: 16px;
    display: block;
}

/* -------------------------------------------------------
HEADER & NAVIGATION
------------------------------------------------------- */

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.brand-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 1.3;
}

.brand-text h1,
.brand h1 {
    font-size: 1.9rem;
    margin: 0 0 6px 0;
    line-height: 1.1;
}

.brand-text small {
    display: block;
    margin-top: 2px;
    font-size: 0.85rem;
    color: var(--muted);
}

.logo {
    width: 80px;
    height: 80px;
    margin-right: 10px;
    flex-shrink: 0;
}

/* En-tête général */
header.site {
    border-bottom: 1px solid var(--line);
}

/* Ligne principale */
header.site .header-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 12px 0 18px;
    border-bottom: 1px solid var(--line);
}

/* Nav principale */
header.site nav {
    margin-top: 58px;
}

header.site nav[aria-label="Navigation principale"] ul {
    display: flex;
    gap: 12px;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: nowrap;
    justify-content: flex-end;
}

header.site nav[aria-label="Navigation principale"] a {
    display: inline-block;
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
}

nav a {
    display: inline-block;
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 0.95rem;
}

nav a:focus,
nav a:focus-visible {
    outline: none;
}

nav a:active {
    color: var(--accent);
    background: rgba(0, 92, 69, 0.15);
}

nav a[aria-current="page"],
nav a:hover {
    background: var(--card);
}

.is-current {
    pointer-events: none;
    opacity: 0.7;
}

/* -------------------------------------------------------
HERO ACCUEIL
------------------------------------------------------- */

.hero {
    padding: 48px 0;
}

.hero#accueil {
    display: flex;
    justify-content: center;
}

.hero h2 {
    font-size: 1.6rem;
    margin: 0.2em 0;
}

.hero .badge {
    font-size: 1rem;
    padding: 6px 12px;
}

.hero p.sub {
    margin-top: 14px;
    font-size: 1rem;
    max-width: 720px;
    color: var(--muted);
}

.hero-intro {
    max-width: 750px;
    margin: 0 auto;
    text-align: center;
    line-height: 1.7;
}

.hero-intro .hero-list {
    list-style: none;
    /* retire les puces trop décalées */
    padding: 0;
    margin: 1rem auto;
    text-align: center;
    /* centre le texte */
}

.hero-intro .hero-list li::before {
    content: "• ";
    color: #ccc;
    /* une puce propre */
}

.hero-vision {
    margin-top: 0.75em;
    font-size: 1.05em;
    opacity: 0.85;
}

/* La Méthode CoinCoin – barre d'accès rapide */
.hero-method {
    padding-top: 40px;
    padding-bottom: 30px;
}

.hero-method .sub {
    max-width: 680px;
    margin: 10px auto 0;
    text-align: center;
}

.method-toolbar {
    margin-top: 20px;
    display: flex;
    justify-content: center;
}

.method-toolbar .btn {
    min-width: 220px;
}

.method-toolbar.right {
    display: flex;
    justify-content: flex-end;
    margin-top: -6px;
    margin-bottom: 20px;
}

.member-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.member-header h1 {
    margin: 0;
}

.member-header .btn {
    white-space: nowrap;
}

.signed-by {
    white-space: normal;
    overflow: visible;
    word-break: break-word;
    margin-top: 12px;
    ;
}

/* -------------------------------------------------------
BUTTONS
------------------------------------------------------- */

.btn,
.pill,
.social-buttons .social-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.02);
    color: var(--ink);
    font-size: 0.95rem;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.25s, border-color 0.25s, color 0.25s, transform 0.15s;
}

/* Conteneur des boutons sociaux (grille responsive) */
.social-buttons {
    margin-top: 32px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 14px;
}

/* Chaque bouton remplit sa cellule et reste centré */
.social-buttons .social-btn {
    width: 100%;
    justify-content: center;
}

.btn.primary {
    background: var(--accent);
    color: #000;
    border-color: rgba(0, 92, 69, 0.9);
}

.btn:hover,
.btn:focus,
.pill:hover,
.pill:focus,
.social-buttons .social-btn:hover,
.social-buttons .social-btn:focus {
    background: rgba(0, 92, 69, 0.15);
    border-color: rgba(0, 92, 69, 0.55);
    color: var(--accent);
}

.social-buttons .social-btn .icon-social {
    width: 20px;
    height: 20px;
    margin-right: 8px;
    display: inline-block;
    vertical-align: middle;
    opacity: 0.9;
}

.social-buttons .social-btn svg,
.social-buttons .social-btn svg * {
    fill: currentColor !important;
    stroke: currentColor !important;
}

/* -------------------------------------------------------
GRID & CARDS
------------------------------------------------------- */

.cta-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 18px;
}

.grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 16px;
}

.card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 18px;
}

.card h2 {
    margin-top: 0.2rem;
    margin-bottom: 0.9rem;
}

.span-6 {
    grid-column: span 6;
}

.span-12 {
    grid-column: span 12;
}

h3 {
    margin-top: 0.2em;
}

.token-kv {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 10px;
    margin: 10px 0;
}

.token-kv .mono {
    display: block;
    word-break: break-all;
    overflow-wrap: anywhere;
}

.mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 999px;
    background: #1f2330;
    color: var(--muted);
    font-size: 0.85rem;
}

.note {
    color: var(--muted);
    font-size: 0.95rem;
}

footer.site {
    border-top: 1px solid var(--line);
    margin-top: 40px;
    padding: 24px 0;
    color: var(--muted);
    font-size: 0.92rem;
}

.row {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* Responsive grid */
@media (max-width: 900px) {
    .grid {
        grid-template-columns: 1fr;
    }

    .span-6,
    .span-12 {
        grid-column: 1;
    }

    .hero h2 {
        font-size: 1.8rem;
    }
}

/* -------------------------------------------------------
AUTH FORMS (login / signup)
------------------------------------------------------- */

.auth-card {
    max-width: 520px;
    margin: 2rem auto 0;
}

.auth-card h2 {
    margin-bottom: 2rem;
}

.auth-card .note {
    margin-bottom: 1.2rem;
}

.auth-form {
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
}

.auth-form .form-row {
    display: grid;
    grid-template-columns: 160px 1fr;
    /* label | input */
    align-items: center;
    gap: 8px 16px;
    margin-bottom: 16px;
}

.auth-form .form-row.button-row {
    margin-top: 1.5rem;
}

.auth-form label {
    text-align: left;
    font-weight: 500;
}

.auth-form input {
    width: 100%;
}

.auth-note {
    margin-top: 1rem;
}

/* Onglets Connexion / Inscription */
.auth-tabs {
    display: inline-flex;
    background: #11131b;
    border-radius: 999px;
    padding: 4px;
    margin-bottom: 1.5rem;
    border: 1px solid var(--line);
}

.auth-tab {
    border: none;
    background: transparent;
    color: var(--muted);
    font-size: 0.95rem;
    padding: 6px 16px;
    border-radius: 999px;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}

.auth-tab.is-active {
    background: var(--accent);
    color: #000;
    font-weight: 600;
}

.auth-tab:focus {
    outline: none;
}

.auth-tab:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

/* Panneaux */
.auth-panel {
    display: none;
}

.auth-panel.is-active {
    display: block;
}

.auth-form input:valid {
    border-color: var(--accent);
}

/* Champs généraux */
.field select,
.field input[type="text"],
.field input[type="email"],
.field input[type="date"],
.field input[type="tel"] {
    width: 100%;
    padding: 0.55rem 0.75rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: #fff;
    box-shadow: 0 0 10px rgba(0, 92, 69, 0.18);
}

/* Checkboxes : halo simulé via wrapper */
.checkbox-field {
    padding: 0.6rem 0.9rem;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 10px rgba(0, 92, 69, 0.18);
    margin-bottom: 0.8rem;
}

.checkbox-field input[type="checkbox"] {
    margin-right: 0.4rem;
}

.form-row.checkbox-row {
    display: grid;
    grid-template-columns: 160px 1fr;
    align-items: flex-start;
    gap: 8px 16px;
    margin-bottom: 16px;
}

.checkbox-row .checkbox-group {
    display: flex;
    align-items: center;
    gap: 10px;
}

.checkbox-row input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.checkbox-group span {
    line-height: 1.4;
}

/* Alignement propre des cases + texte */
.checkbox-group {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Ajuste la ligne globale des lignes "Newsletter" + "Conditions" */
.form-row.checkbox-row {
    align-items: center;
}

/* Champs du formulaire auth (version harmonisée) */
.auth-form input[type="text"],
.auth-form input[type="email"],
.auth-form input[type="password"],
.auth-form input[type="date"],
.auth-form input[type="tel"],
.auth-form select {
    width: 100%;
    padding: 8px 10px;
    border-radius: 4px;
    border: 1px solid rgba(0, 92, 69, 0.25);
    background-color: rgba(0, 0, 0, 0.15);
    color: inherit;
    box-shadow: none;
}

/* Effet focus – uniquement quand on clique dans le champ */
.auth-form input[type="text"]:focus,
.auth-form input[type="email"]:focus,
.auth-form input[type="password"]:focus,
.auth-form input[type="date"]:focus,
.auth-form input[type="tel"]:focus,
.auth-form select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px rgba(0, 92, 69, 0.35);
}

/* Bloc des cases à cocher (newsletter / conditions) */
.auth-card .checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 6px;
    border: 1px solid rgba(0, 92, 69, 0.22);
    background: rgba(0, 0, 0, 0.18);
    box-shadow: none;
}

.auth-card .checkbox-group input[type="checkbox"] {
    margin-top: 2px;
}

/* ============================
AUTH — Messages de statut
============================ */

.tiny.info {
    color: #ccc;
}

.tiny.error {
    color: #ff6b6b;
}

.tiny.success {
    color: #7ddc82;
}

.help {
    opacity: 0.7;
    margin-top: 0.3rem;
    margin-left: 0.2rem;
    line-height: 1.3;
}

/* Mobile : labels au-dessus des champs */
@media (max-width: 520px) {
    .auth-form .form-row {
        grid-template-columns: 1fr;
        gap: 4px 0;
    }

    .auth-form label {
        margin-top: 8px;
    }
}

/* -------------------------------------------------------
LE BON COINCOIN — FICHES PROJET
------------------------------------------------------- */

.market-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 18px;
    margin-top: 18px;
}

.token-card {
    background: var(--card);
    border-radius: 14px;
    border: 1px solid var(--line);
    padding: 18px 18px 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.token-card-header {
    margin-bottom: 4px;
}

.token-name {
    margin: 0 0 4px;
    font-size: 1.1rem;
}

.token-tagline {
    margin: 0;
    font-size: 0.9rem;
    color: var(--muted);
}

.token-meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4px 16px;
    margin: 0;
    padding: 0;
}

.token-meta div {
    display: grid;
    grid-template-columns: minmax(80px, 120px) 1fr;
    gap: 6px;
    font-size: 0.9rem;
}

.token-meta dt {
    font-weight: 600;
    color: var(--muted);
}

.token-meta dd {
    margin: 0;
}

.token-story {
    font-size: 0.95rem;
    line-height: 1.6;
}

.token-links {
    list-style: none;
    margin: 4px 0 0;
    padding: 0;
    font-size: 0.9rem;
}

.token-links li+li {
    margin-top: 2px;
}

.token-warning {
    margin-top: 6px;
    opacity: 0.8;
}

/* Style pour les emplacements "à venir" */
.token-card--placeholder {
    border-style: dashed;
    opacity: 0.9;
}

/* -------------------------------------------------------
PROOF PAGE (signatures)
------------------------------------------------------- */

.copy-wrap {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

.pill {
    background: #0f1117;
}

.tiny {
    font-size: 0.9rem;
    color: var(--muted);
}

pre {
    margin-left: 0;
    white-space: pre-wrap;
}

pre.sig {
    overflow-wrap: break-word;
    white-space: pre-wrap;
    font-size: 0.9em;
    line-height: 1.4;
}

pre.mono {
    white-space: pre;
    /* Empêche les retours à la ligne */
    overflow-x: auto;
    /* Active le scroll horizontal si nécessaire */
    overflow-y: hidden;
    /* Évite l’apparition d’un scroll vertical inutile */
    padding: 12px;
    background: var(--card);
    /* comme tes autres blocs */
    border-radius: 8px;
    font-family: monospace;
    font-size: 0.85rem;
}

/* Blocs de code sur la page Proof */
#proof-main pre,
#proof-main .mono {
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    font-size: 0.85rem;
    line-height: 1.4;
}

/* Longues signatures / adresses */
pre#sig,
.mono#sig,
#sig {
    display: block;
    max-width: 100%;
    white-space: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden;
    word-break: normal !important;
    overflow-wrap: normal !important;
    padding-bottom: 4px;
}

.sig-box {
    height: 43px;
    overflow-x: auto;
    overflow-y: hidden;
    background: #111;
    border: 1px solid #333;
    border-radius: 8px;
    padding: 8px 12px;
    white-space: nowrap;
    display: flex;
    align-items: center;
    scrollbar-gutter: stable both-edges;
}

#result {
    font-size: 0.85rem;
    font-family: inherit;
    white-space: nowrap;
    line-height: 1;
}

#result .addr {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.85rem;
    white-space: nowrap;
}

#result .hex {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.85rem;
    white-space: nowrap;
}

/* Mobile: adaptation des blocs de code */
@media (max-width: 520px) {

    /* 1) Message signé : on garde les retours à la ligne mais sans découper trop violemment */
    #msg {
        white-space: pre-wrap !important;
        word-break: break-word !important;
        overflow-x: hidden !important;
    }

    /* 2) Tous les autres blocs .mono (ex : snippet JS) peuvent se casser plus agressivement */
    .mono {
        white-space: pre-wrap !important;
        word-break: break-all !important;
        overflow-x: visible !important;
        overflow-wrap: anywhere;
    }

    /* 3) EXCEPTION : la signature reste en une seule ligne avec scroll horizontal */
    #sig.sig-box {
        white-space: nowrap !important;
        word-break: normal !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
    }
}

/* Restauration du scroll horizontal sur mobile */
@media (max-width: 520px) {

    /* Bloc message signé */
    #msg {
        overflow-x: auto !important;
        white-space: pre !important;
    }

    /* Bloc snippet (comment la signature a été générée) */
    .mono {
        overflow-x: auto !important;
        white-space: pre !important;
    }

    /* Bloc signature */
    #sig {
        overflow-x: auto !important;
        white-space: nowrap !important;
    }
}

/* Proof layout */
#proof-main {
    margin-top: 32px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

#proof-main section.card {
    padding-top: 20px;
    padding-bottom: 20px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

/* Proof of Ownership : éviter que l'adresse déborde */
#proof-main #result {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.85rem;
    white-space: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
}

#proof-main #result::-webkit-scrollbar {
    height: 3px;
}

/* -------------------------------------------------------
BOITE À OUTILS (modules)
------------------------------------------------------- */

.toolbox {
    margin: 2.5rem auto 3rem;
    max-width: 900px;
    padding: 1.75rem 2rem 2rem;
    border-radius: 12px;
    background: var(--card);
    border: 1px solid var(--line);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45);
    color: var(--ink);
}

.toolbox-title {
    font-size: 1.45rem;
    margin: 0 0 1rem;
}

.toolbox-toggle {
    display: inline-block;
    margin-bottom: 1.25rem;
    padding: 0.5rem 1.1rem;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.03);
    color: var(--ink);
    font-size: 0.95rem;
    cursor: pointer;
}

.toolbox-toggle:hover {
    background: rgba(255, 255, 255, 0.07);
}

.toolbox-intro {
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
    opacity: 0.85;
}

.toolbox-panel {
    animation: toolboxSlide 0.3s ease;
}

@keyframes toolboxSlide {
    from {
        opacity: 0;
        transform: translateY(-6px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.toolbox-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem 1.75rem;
}

.toolbox-module h3 {
    font-size: 1rem;
    margin-bottom: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
}

.toolbox-module ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.toolbox-module li+li {
    margin-top: 0.35rem;
}

.toolbox-module a {
    font-size: 0.9rem;
    text-decoration: underline;
    color: var(--link);
}

.toolbox-module a:hover {
    color: var(--accent);
}

/* -------------------------------------------------------
JOURNAL / ACTUALITÉ
------------------------------------------------------- */

.journal {
    max-width: 1100px;
    margin: 3rem auto 4rem;
    padding: 2rem 2rem 2.5rem;
    background-color: #f5f5f5;
    background-image: url("./actualite/images/paper-texture.png");
    background-repeat: repeat;
    background-size: 600px 600px;
    color: #111;
    border-radius: 12px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.45);
}

.journal-masthead {
    text-align: center;
    margin: 0 auto 32px;
}

.journal-masthead-inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 16px 24px 20px;
    border-bottom: 2px solid rgba(0, 0, 0, 0.14);
    display: flex;
    align-items: center;
    gap: 2rem;
}

.logo-col {
    width: 90px;
    display: block;
    margin-top: -30px;
}

.text-col {
    display: flex;
    flex-direction: column;
    margin-top: -4px
}

.journal-masthead-kicker {
    font-size: 0.8rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.7;
    margin: 0 0 6px;
}

.journal-masthead-title {
    font-family: "Georgia", "Times New Roman", serif;
    font-size: 2.4rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0 0 4px;
}

.journal-masthead-subtitle {
    font-size: 0.95rem;
    opacity: 0.8;
}

.journal-page {
    display: none;
}

.journal-page.is-active {
    display: block;
}

/* Grille principale */
.journal-grid {
    display: grid;
    grid-template-columns: 2fr 2fr 2fr;
    grid-auto-rows: auto;
    gap: 1.5rem;
    padding: 24px 32px 28px;
}

/* Disposition */
.journal-article--origines {
    grid-column: 1 / 3;
    grid-row: 1;
}

.journal-card--picsou {
    grid-column: 3 / 4;
    grid-row: 1;
}

.journal-article--lancement {
    grid-column: 1 / 2;
    grid-row: 2;
}

.journal-article--ownership {
    grid-column: 2 / 3;
    grid-row: 2;
}

.journal-article--lancement {
    border-right: 1px solid rgba(0, 0, 0, 0.15);
    padding-right: 12px;
    margin-right: 12px;
}

.journal-article--teaser {
    grid-column: 3 / 4;
    grid-row: 2;
    border-left: 1px solid rgba(0, 0, 0, 0.15);
    padding-left: 12px;
    margin-left: 12px;
}

/* Articles */
.journal-article,
.journal-card {
    font-size: 0.95rem;
    line-height: 1.7;
}

.journal-article h2,
.journal-article h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.journal-article--origines .meta {
    text-align: center;
}

.main-article-hero {
    text-align: center;
}

.main-article-hero img {
    width: 100%;
    height: auto;
    border-radius: 6px;
    margin: 12px auto 18px;
    display: block;
}

.journal-article h2.main-article-title {
    font-size: 2.2rem;
    line-height: 1.12;
    margin: 4px 0 6px 0;
    text-align: center;
    margin-bottom: 0.25rem;
}

.journal-article .meta {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.7;
    margin-bottom: 0.5rem;
}

.journal-article .excerpt {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 0.75rem;
}

/* Cards */
.journal-card-header {
    margin-bottom: 0.5rem;
}

.journal-card-title {
    font-size: 1.25rem;
    margin: 0 0 0.25rem;
}

.journal-card-meta {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.7;
    margin: 0;
}

.article-link {
    font-size: 0.9rem;
    text-decoration: underline;
}

/* Vignettes */
.journal-card-thumb {
    margin: 8px 0 12px;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
}

.journal-card-thumb img {
    display: block;
    width: 100%;
    height: auto;
}

/* Pagination */
.journal-pagination {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 2rem;
}

.page-btn {
    border: 1px solid rgba(0, 0, 0, 0.25);
    background: transparent;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    font-size: 0.85rem;
    cursor: pointer;
}

.page-btn.is-active {
    background: rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.4);
}

.article-hero {
    margin: 0 0 1.5rem;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
    text-align: center;
    font-size: 0.9rem;
    color: rgba(0, 0, 0, 0.65);
}

.article-hero img {
    display: block;
    width: 100%;
}

.article-hero figcaption {
    padding: 0.6rem 1rem 0.9rem;
}

/* =========================================================
Journal : responsive tablette (<= 900px)
========================================================= */
@media (max-width: 900px) {
    .journal {
        margin: 2rem auto 3rem;
        padding: 1.5rem 1.5rem 2rem;
    }

    .journal-grid {
        grid-template-columns: 1fr;
        padding: 16px 12px 20px;
    }

    .journal-article--origines,
    .journal-card--picsou,
    .journal-article--lancement,
    .journal-article--ownership,
    .journal-article--teaser {
        grid-column: 1 / -1;
        grid-row: auto;
    }

    .journal p {
        overflow-wrap: anywhere;
        word-break: break-word;
    }
}

/* =========================================================
Journal : mobile (<= 720px)
========================================================= */
@media (max-width: 720px) {

    /* Sécuriser le viewport */
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    img {
        max-width: 100%;
        height: auto;
        display: block;
    }

    /* Container du journal : full width */
    .journal {
        margin: 2rem 0 3rem;
        padding: 1.5rem 1rem 2rem;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    /* Grille qui ne déborde jamais */
    .journal-grid {
        width: 100%;
        max-width: 100%;
        padding: 16px 0 20px;
        box-sizing: border-box;
    }

    /* Chaque carte / article prend toute la ligne */
    .journal-article--origines,
    .journal-card--picsou,
    .journal-article--lancement,
    .journal-article--ownership,
    .journal-article--teaser {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    /* Titre de la couverture (page article seul : .journal-cover) */
    .journal-cover h1 {
        font-size: 2rem;
        line-height: 1.2;
        text-align: center;
    }

    /* Lignes verticales à supprimer sur mobile
(séparateurs entre Lancement & Édito) */
    .journal-article--lancement {
        border-right: none !important;
        margin-right: 0 !important;
        padding-right: 0 !important;
    }

    .journal-article--teaser {
        border-left: none !important;
        margin-left: 0 !important;
        padding-left: 0 !important;
    }

    /* Header du journal (logo + titre) en colonne centrée */
    .journal-masthead-inner {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 0.75rem;
    }

    /* Logo du journal */
    .masthead-col.logo-col img {
        width: 64px;
        height: auto;
        margin-bottom: 0.25rem;
    }

    /* "Édition en ligne" */
    .journal-masthead-kicker {
        font-size: 0.8rem;
        letter-spacing: 0.12em;
    }

    /* Titre "Le Canard du CoinCoin" */
    .journal-masthead-title {
        font-size: 1.8rem;
        line-height: 1.2;
        margin: 0.1rem 0 0.3rem;
    }

    /* Sous-titre */
    .journal-masthead-subtitle {
        font-size: 0.9rem;
        line-height: 1.4;
        max-width: 26rem;
        margin: 0 auto;
    }

    /* Titre principal du premier article */
    .journal-article--origines .main-article-title {
        font-size: 1.6rem !important;
        /* lisible mais pas énorme */
        line-height: 1.3 !important;
    }
}

/* h2 — réduction globale sur mobile */
@media (max-width: 720px) {
    h2 {
        font-size: 1.25rem !important;
        line-height: 1.25 !important;
        margin-bottom: 0.8rem !important;
    }

    /* Si certains h2 sont trop gros via des classes spécifiques */
    .section-title,
    .main-title,
    .academy-title {
        font-size: 1.25rem !important;
        line-height: 1.25 !important;
    }
}

/* ============================
Journal – pages d’article seul
============================ */

.main-journal {
    padding: 32px 16px 40px;
}

/* Variante "article unique" du bloc journal */
.journal--single {
    max-width: 980px;
    margin: 0 auto 40px;
    padding: 32px 40px 40px;
}

/* Article plein format */
.full-article {
    font-size: 0.95rem;
    line-height: 1.7;
}

/* En-tête de l’article */
.full-article-header {
    text-align: center;
    margin-bottom: 24px;
}

.full-article-kicker {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    opacity: 0.7;
    margin: 0 0 6px;
}

.full-article-title {
    font-family: "Georgia", "Times New Roman", serif;
    font-size: 2.4rem;
    line-height: 1.15;
    margin: 0 0 8px;
}

.full-article-meta {
    font-size: 0.9rem;
    opacity: 0.7;
    margin: 0;
}

/* Image principale */
.full-article-hero {
    margin: 24px 0 20px;
}

.full-article-hero img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

.full-article-hero figcaption {
    font-size: 0.85rem;
    margin-top: 6px;
    text-align: center;
    opacity: 0.8;
}

/* Corps de l’article */
.full-article-body {
    max-width: 72ch;
    margin: 0 auto;
}

.full-article-body p+p {
    margin-top: 1rem;
}

.back-to-journal {
    margin: 16px 0 24px;
}

.back-to-journal a {
    font-size: 0.95rem;
    color: var(--link-color);
    text-decoration: none;
}

.back-to-journal a:hover {
    text-decoration: underline;
}

/* Version mobile */
@media (max-width: 768px) {
    .journal--single {
        padding: 24px 18px 28px;
        margin-bottom: 24px;
    }

    .full-article-title {
        font-size: 2rem;
    }
}

/* -------------------------------------------------------
ESPACEMENT GLOBAL ENTRE BLOCS
------------------------------------------------------- */

.wrap>section,
.wrap>div:not(.header-main):not(.header-line) {
    margin-top: 16px;
}

.wrap>section:first-child,
.wrap>div:first-child {
    margin-top: 0;
}

/* -------------------------------------------------------
HEADER — Version mobile
------------------------------------------------------- */

@media (max-width: 520px) {
    header.site .header-main {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.9rem;
        padding-bottom: 1.2rem;
    }

    header.site .brand {
        justify-content: flex-start;
        text-align: left;
    }

    header.site .brand-text h1 {
        font-size: 1.4rem;
    }

    header.site .brand-text small {
        font-size: 0.78rem;
    }

    header.site nav[aria-label="Navigation principale"] {
        width: 100%;
        margin-top: 0.5rem;
    }

    header.site nav[aria-label="Navigation principale"] ul {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 0.35rem;
        padding: 0;
        margin: 0;
        list-style: none;
    }

    header.site nav[aria-label="Navigation principale"] a {
        display: inline-block;
        font-size: 0.9rem;
        padding: 0.3rem 0.7rem;
        border-radius: 999px;
        text-align: center;
    }

    header.site .has-submenu {
        position: static;
    }

    header.site .has-submenu .submenu {
        position: static;
        margin-top: 0.25rem;
        padding: 0.4rem 0.6rem;
        width: 100%;
        max-width: 260px;
    }

    /* Mobile : ouverture via .is-open (gérée en JS) */
    .has-submenu.is-open .submenu {
        display: block;
    }

    .token-kv {
        grid-template-columns: 1fr;
    }

    .member-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.6rem;
    }

    .token-kv .mono,
    .token-kv .contract-address {
        display: block;
        max-width: 100%;
        overflow-wrap: anywhere;
        word-break: break-all;
    }
}

/* Adresses longues : une seule ligne + scroll */
.contract-scroll {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    white-space: nowrap;
}

/* le conteneur de scroll */
.scroll-x {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    max-width: 100%;
    display: block;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 520px) {
    .contract-scroll {
        white-space: nowrap !important;
        word-break: normal !important;
        overflow-wrap: normal !important;
        display: inline-block !important;
    }

    .scroll-x {
        overflow-x: auto !important;
    }
}

.scroll-x-box {
    display: block;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    padding: 2px 0;
    -webkit-overflow-scrolling: touch;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.85rem;
}