/*
 * Polish — règles de finition globales pour donner un sentiment de site
 * professionnel et aéré au lieu de "amateur/étouffant".
 *
 * Charge en dernier après tokens-overrides et responsive-fixes pour
 * pouvoir fignoler sans réécrire les règles existantes.
 */

/* ========== 1. Hierarchy typographique homogène ========== */
/* Échelle modulaire claire : H1 > H2 > H3 avec contrastes nets. */
.section h1,
.about-page-grid h1,
.product-banner-copy h1 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2rem, 5vw, 3.6rem);
    line-height: 1.1;
    letter-spacing: -0.01em;
    margin: 0 0 1rem;
    text-wrap: balance;
    font-weight: 400;
}

.section h2,
.about-page-grid h2 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.45rem, 3.4vw, 2.2rem);
    line-height: 1.2;
    margin: 0 0 1rem;
    text-wrap: balance;
    font-weight: 400;
    letter-spacing: -0.005em;
}

.section h3,
.about-page-grid h3 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.15rem, 2.4vw, 1.4rem);
    line-height: 1.25;
    margin: 0 0 0.6rem;
    font-weight: 500;
    letter-spacing: -0.005em;
}

/* ========== 2. Paragraphes lisibles : largeur de lecture, line-height ========== */
.section p,
.about-page-grid p,
.detail-panel p,
.dossier-card p {
    line-height: 1.7;
    max-width: 68ch;
    margin: 0 0 0.85rem;
}

/* Quand le panel est en flex column centré, on centre le paragraphe */
.archive-cta-panel p,
.special-offer-copy p,
.about-hero-intro,
.hero-copy-sub {
    margin-inline: auto;
}

/* ========== 3. Panels : padding généreux + gap interne aéré ========== */
.detail-panel,
.about-hero-shell,
.about-mission-shell,
.about-heritage-card,
.about-renaissance-card,
.about-future-shell,
.about-proof-shell,
.dossier-card,
.product-story-shell,
.product-hero-shell,
.section-container-surface,
.checkout-form-panel,
.checkout-summary-panel,
.account-identity-card,
.account-security-panel,
.account-orders-panel,
.account-conversation-card {
    padding: clamp(1.6rem, 3.5vw, 2.6rem);
    border-radius: clamp(14px, 2vw, 22px);
}

/* Variante grands panels héros (gardent leur padding plus large) */
.about-hero-shell,
.about-mission-shell,
.product-hero-shell {
    padding: clamp(2rem, 5vw, 3.8rem);
}

/* ========== 4. Sections : gap vertical entre groupes de panels ========== */
.section,
.about-page-section {
    padding-block: clamp(1.5rem, 4vw, 3rem);
}

.about-hero-band {
    width: 100%;
    padding-block: clamp(1.5rem, 4vw, 3rem);
}

.about-hero-band > .container.about-hero-shell {
    width: min(1600px, calc(100% - var(--em-container-padding-x, 1rem) * 2)) !important;
    max-width: 1600px !important;
    margin-inline: auto !important;
}

/* Les sections About ont besoin d'un peu plus pour respirer entre les
   gros pavés de texte. */
.about-page-section > .container.about-page-grid {
    display: grid;
    width: 100% !important;
    max-width: none !important;
    gap: clamp(1.5rem, 3.5vw, 2.5rem);
}

/* ========== 5. Eyebrows propres et discrets ========== */
.section .eyebrow,
.detail-panel .eyebrow,
.dossier-card .eyebrow {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin: 0 0 0.6rem;
    line-height: 1.3;
}

/* ========== 6. Listes : puces propres, espacement lisible ========== */
.section ul:not([class]),
.section ol:not([class]),
.detail-panel ul:not([class]),
.detail-panel ol:not([class]),
.dossier-card ul:not([class]),
.dossier-card ol:not([class]) {
    padding-left: 1.4rem;
    line-height: 1.7;
    margin: 0 0 1rem;
}

.section ul:not([class]) li + li,
.detail-panel ul:not([class]) li + li,
.dossier-card ul:not([class]) li + li {
    margin-top: 0.4rem;
}

/* ========== 7. Tables propres ========== */
.about-proof-table,
.dossier-card table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.about-proof-table th,
.about-proof-table td {
    padding: 1rem 1.1rem;
    border-bottom: 1px solid rgba(90, 66, 40, 0.12);
}

.about-proof-table thead th {
    background: rgba(216, 161, 90, 0.08);
    font-weight: 600;
    font-size: 0.8rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #5a4737;
    border-bottom: 2px solid rgba(216, 161, 90, 0.4);
}

.about-proof-table tbody tr:hover {
    background: rgba(255, 252, 247, 0.6);
}

/* ========== 8. Cards intérieures (mission points, story cards) ========== */
.about-mission-point,
.about-heritage-value,
.about-future-card,
.dossier-card,
.product-story-card {
    background: var(--em-paper-50, #fbf7f1);
    border: 1px solid rgba(154, 90, 0, 0.14);
    border-radius: 16px;
    padding: clamp(1.2rem, 2.5vw, 1.8rem);
    transition: transform 200ms ease, box-shadow 200ms ease;
}

@media (hover: hover) {
    .about-mission-point:hover,
    .about-heritage-value:hover,
    .about-future-card:hover,
    .product-story-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 12px 32px rgba(15, 10, 6, 0.10);
    }
}

/* ========== 9. Hero About : aérer la disposition ========== */
.about-hero-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(1.5rem, 3vw, 2.5rem);
    align-items: center;
}

@media (min-width: 900px) {
    .about-hero-layout {
        grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
    }
}

.about-hero-intro {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: baseline;
    align-content: space-around;
    justify-content: center;
    gap: 0.95rem;
    max-width: 58rem !important;
    font-size: clamp(1.05rem, 2vw, 1.2rem);
    line-height: 1.7;
    color: #5a4737;
}

.about-hero-intro > * {
    min-width: 0;
}

/* ========== 10. Quote / blockquote stylé ========== */
.about-quote-card blockquote,
blockquote {
    margin: 0;
    padding: clamp(1rem, 2.5vw, 1.5rem) clamp(1.2rem, 3vw, 2rem);
    border-left: 3px solid var(--em-amber-500, #d8a15a);
    background: rgba(243, 201, 138, 0.08);
    border-radius: 0 12px 12px 0;
    font-family: Georgia, serif;
    font-style: italic;
    line-height: 1.65;
    color: #251a13;
}

/* ========== 11. Boutons d'action : présence forte et homogène ========== */
.button-primary {
    background: linear-gradient(135deg, var(--em-amber-500, #d8a15a), var(--em-amber-700, #9a5a00));
    color: var(--em-ink-900, #0f0c0a);
    padding: 0.95rem 1.8rem;
    border-radius: 999px;
    border: none;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.86rem;
    box-shadow: 0 10px 24px rgba(154, 90, 0, 0.32);
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    cursor: pointer;
    min-height: 48px;
}

@media (hover: hover) {
    .button-primary:hover {
        transform: translateY(-2px);
        box-shadow: 0 16px 32px rgba(154, 90, 0, 0.42);
        filter: brightness(1.05);
    }
}

.button-secondary {
    background: transparent;
    color: var(--em-amber-700, #9a5a00);
    padding: 0.85rem 1.6rem;
    border-radius: 999px;
    border: 1.5px solid rgba(154, 90, 0, 0.4);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.82rem;
    transition: background 180ms ease, border-color 180ms ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    cursor: pointer;
    min-height: 44px;
}

@media (hover: hover) {
    .button-secondary:hover {
        background: rgba(216, 161, 90, 0.1);
        border-color: var(--em-amber-700, #9a5a00);
    }
}

/* ========== 12. Page banner (titre de section haute) plus aéré ========== */
.page-banner,
.about-page-section,
.product-banner {
    padding-top: clamp(2rem, 5vw, 4rem);
}

/* ========== 13. Scroll behavior smooth pour les anchor links ========== */
html {
    scroll-behavior: smooth;
    scroll-padding-top: var(--header-offset, 88px);
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
}

/* ========== 14. Focus rings homogènes et accessibles ========== */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
    outline: 2px solid var(--em-amber-700, #9a5a00);
    outline-offset: 3px;
    border-radius: 4px;
}

/* ========== 15. Eviter les doubles bordures/shadows sur panels imbriqués ========== */
.detail-panel .detail-panel,
.section-container-surface .detail-panel {
    box-shadow: none;
    border: none;
    padding: 0;
    background: transparent;
}

/* ========== 16. Hero produit : style Apple Store / Stripe ========== */
/* Refonte UX/UI : breadcrumb minimal hors du shell, hero clair et aéré,
   image grande à gauche, infos hierarchisées à droite, CTA propre,
   chapter-nav sticky qui apparaît au scroll. */

/* === Breadcrumb minimal (style Apple) — hors du shell, discret === */
.product-breadcrumb-minimal {
    width: min(1600px, calc(100% - var(--em-container-padding-x, 1rem) * 2));
    max-width: 1600px;
    margin: 0 auto 1rem;
    padding-top: 0.5rem;
    font-size: 0.82rem;
    color: var(--em-ink-300, #5a4737);
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.product-breadcrumb-minimal a {
    color: inherit;
    text-decoration: none;
    transition: color 180ms ease;
}

.product-breadcrumb-minimal a:hover {
    color: var(--em-amber-700, #9a5a00);
    text-decoration: underline;
}

.product-breadcrumb-minimal span[aria-hidden] {
    opacity: 0.4;
    margin: 0 0.1rem;
}

.product-breadcrumb-minimal span[aria-current] {
    color: var(--em-ink-700, #251a13);
    font-weight: 500;
}

/* === Container hero : fond sombre, FLEX (pas grid hérité) === */
/* Note : app.css:3596 met .page-banner .container en display: grid.
   On force flex column ici pour que le layout interne soit propre. */
.page-banner .container.product-hero-shell,
.product-hero-shell {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: min(1600px, calc(100% - var(--em-container-padding-x, 1rem) * 2)) !important;
    max-width: 1600px !important;
    margin-inline: auto !important;
    padding: clamp(1.5rem, 3vw, 3rem) !important;
    border-radius: clamp(16px, 2vw, 24px);
    background:
        radial-gradient(ellipse at top left, rgba(216, 161, 90, 0.18), transparent 55%),
        linear-gradient(135deg, #1f1813 0%, #0f0c0a 100%) !important;
    border: 1px solid rgba(216, 161, 90, 0.18) !important;
    box-shadow: 0 18px 60px rgba(0, 0, 0, 0.35) !important;
    color: #f5efe5 !important;
    grid-template-columns: none !important;
    grid-template-areas: none !important;
    gap: clamp(1rem, 2vw, 1.5rem) !important;
    /* Tokens locaux cohérents avec le fond sombre */
    --text: #f5efe5;
    --muted: rgba(245, 239, 229, 0.8);
    --panel: rgba(31, 24, 19, 0.6);
    --line: rgba(216, 161, 90, 0.22);
    --shadow: 0 18px 60px rgba(0, 0, 0, 0.35);
    --surface-heading-color: #fff8ee;
    --surface-text-color: rgba(245, 239, 229, 0.88);
}

/* Couleurs claires pour le contenu sur fond sombre */
.product-hero-shell h1,
.product-hero-shell h2,
.product-hero-shell h3 {
    color: #fff8ee !important;
}

.product-hero-shell p,
.product-hero-shell li,
.product-hero-shell label,
.product-hero-shell span:not(.eyebrow):not(.product-status-badge):not(.product-purchase-price) {
    color: rgba(245, 239, 229, 0.88);
}

/* === Layout flex : image à gauche, intro + achat à droite empilés === */
.product-hero-layout {
    display: flex !important;
    flex-direction: column;
    gap: clamp(1.5rem, 3vw, 2.5rem);
    align-items: stretch;
    /* Annule les éventuels grid-template hérités */
    grid-template-columns: none !important;
    grid-template-areas: none !important;
}

@media (min-width: 900px) {
    .product-hero-layout {
        flex-direction: row;
        gap: clamp(2rem, 4vw, 3.5rem);
        align-items: stretch;
    }
}

.product-hero-layout > .product-media-column {
    flex: 0 1 clamp(320px, 42%, 540px);
    min-width: 0;
    grid-area: unset !important;
    align-self: stretch;
}

.product-hero-layout > .product-hero-intro {
    flex: 1 1 320px;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    grid-area: unset !important;
    align-self: stretch;
}

.product-hero-layout > .product-purchase-card {
    flex: 0 0 clamp(280px, 30%, 360px);
    width: auto;
    grid-area: unset !important;
    align-self: stretch;
}

@media (max-width: 899px) {
    .product-hero-layout > .product-media-column,
    .product-hero-layout > .product-hero-intro,
    .product-hero-layout > .product-purchase-card {
        flex: 1 1 100%;
        width: 100%;
    }
}

/* === Image principale : grande mais raisonnable === */
.product-hero-shell .product-hero-media,
.product-hero-shell .detail-media {
    aspect-ratio: 1 / 1 !important; /* carré, plus harmonieux et moins écrasant */
    min-height: 0 !important;
    max-height: none !important;
    width: 100%;
    border-radius: clamp(14px, 1.8vw, 20px);
    overflow: hidden;
    background: var(--em-paper-100, #f8f3ea);
    box-shadow: 0 12px 36px rgba(15, 10, 6, 0.10);
    position: relative;
}

.product-hero-shell .product-hero-media img,
.product-hero-shell .detail-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Galerie miniatures : ligne discrète sous l'image, sans boutons << >> visuels lourds */
.product-hero-shell .product-gallery-carousel {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 1rem;
}

.product-hero-shell .product-gallery-viewport {
    flex: 0 1 auto;
    overflow: hidden;
}

.product-hero-shell .product-gallery-strip {
    display: flex;
    gap: 0.6rem;
}

.product-hero-shell .product-gallery-thumb {
    width: 56px;
    height: 56px;
    padding: 0;
    border-radius: 10px;
    border: 2px solid transparent;
    background: var(--em-paper-100, #f8f3ea);
    overflow: hidden;
    cursor: pointer;
    flex: 0 0 56px;
    opacity: 0.65;
    transition: opacity 200ms ease, border-color 200ms ease, transform 200ms ease;
}

.product-hero-shell .product-gallery-thumb:hover {
    opacity: 1;
    transform: translateY(-2px);
}

.product-hero-shell .product-gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-hero-shell .product-gallery-thumb.is-active,
.product-hero-shell .product-gallery-thumb[aria-pressed="true"] {
    border-color: var(--em-ink-700, #251a13);
    opacity: 1;
}

/* Boutons < > du carousel : discrets ou cachés si peu d'images */
.product-hero-shell .product-gallery-control {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(154, 90, 0, 0.2);
    background: transparent;
    color: var(--em-ink-700, #251a13);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    transition: background 180ms ease;
}

.product-hero-shell .product-gallery-control:hover {
    background: rgba(216, 161, 90, 0.14);
}

/* === Bloc intro sur fond sombre : tons clairs et ambre === */
.product-hero-shell .eyebrow {
    margin: 0;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--em-amber-300, #f3c98a) !important;
}

.product-hero-shell h1 {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: clamp(2rem, 4.4vw, 3.4rem) !important;
    line-height: 1.05 !important;
    letter-spacing: 0;
    margin: 0.15rem 0 0.35rem !important;
    font-weight: 400 !important;
    color: #fff8ee !important;
    text-wrap: balance;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.35);
}

.product-hero-shell .hero-copy {
    font-family: Georgia, serif;
    font-size: clamp(1.05rem, 1.5vw, 1.18rem);
    line-height: 1.55;
    margin: 0 !important;
    color: rgba(245, 239, 229, 0.85) !important;
    font-style: normal;
    overflow: visible;
    display: block;
}

.product-hero-shell .product-hero-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 0.8rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(216, 161, 90, 0.18);
    font-size: 0.85rem;
    color: rgba(245, 239, 229, 0.85);
}

.product-hero-shell .stock-pill {
    background: transparent;
    border: 0;
    padding: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(245, 239, 229, 0.92) !important;
}

.product-hero-shell .stock-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #4ec76a;
    box-shadow: 0 0 0 3px rgba(78, 199, 106, 0.22);
}

.product-hero-shell .stock-pill[aria-label*="Difficulté"]::before {
    background: var(--em-amber-300, #f3c98a);
    box-shadow: 0 0 0 3px rgba(243, 201, 138, 0.22);
}

/* Badge offre du mois — discret sur fond sombre */
.product-hero-shell .product-status-badge {
    align-self: flex-start;
    background: linear-gradient(135deg, var(--em-amber-500, #d8a15a), var(--em-amber-700, #9a5a00));
    color: var(--em-ink-900, #0f0c0a) !important;
    padding: 0.35rem 0.75rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* === Carte d'achat sur fond sombre : ambre + or === */
.product-hero-shell .product-purchase-card {
    background: rgba(255, 252, 247, 0.05);
    border: 1px solid rgba(216, 161, 90, 0.28);
    border-radius: clamp(14px, 1.8vw, 20px);
    padding: clamp(1.4rem, 2.2vw, 1.8rem);
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    backdrop-filter: blur(8px);
    color: rgba(245, 239, 229, 0.95);
}

.product-hero-shell .product-purchase-head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.3rem;
    margin: 0;
    padding: 0;
}

.product-hero-shell .product-purchase-head h2 {
    font-size: 0.78rem !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    margin: 0 !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(245, 239, 229, 0.7) !important;
}

.product-hero-shell .product-purchase-price {
    font-family: Georgia, serif;
    font-size: clamp(2rem, 3.4vw, 2.6rem);
    font-weight: 600;
    color: var(--em-amber-300, #f3c98a) !important;
    line-height: 1;
    letter-spacing: -0.01em;
}

.product-hero-shell .product-order-note {
    font-size: 0.85rem;
    line-height: 1.5;
    margin: 0 !important;
    color: rgba(245, 239, 229, 0.75) !important;
}

.product-hero-shell .detail-buy-box {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding-top: 0.9rem;
    border-top: 1px solid rgba(216, 161, 90, 0.18);
}

.product-hero-shell .detail-buy-box label {
    font-size: 0.76rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: rgba(245, 239, 229, 0.7) !important;
    margin: 0;
    font-weight: 600;
}

.product-hero-shell .detail-buy-box .quantity-input {
    width: 100%;
    max-width: 110px;
    padding: 0.65rem 0.8rem;
    border-radius: 8px;
    border: 1px solid rgba(216, 161, 90, 0.3);
    background: rgba(15, 10, 6, 0.5);
    color: #f5efe5;
    font-size: 1rem;
    font-family: inherit;
}

.product-hero-shell .detail-buy-box .quantity-input:focus {
    outline: 2px solid var(--em-amber-300, #f3c98a);
    outline-offset: 2px;
    border-color: var(--em-amber-300, #f3c98a);
}

.product-hero-shell .detail-buy-box .quantity-help {
    font-size: 0.76rem;
    color: rgba(245, 239, 229, 0.6) !important;
    margin: 0 !important;
}

.product-hero-shell .detail-buy-box .button-primary {
    margin-top: 0.5rem;
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: 0.95rem;
    background: linear-gradient(135deg, var(--em-amber-500, #d8a15a), var(--em-amber-700, #9a5a00)) !important;
    color: var(--em-ink-900, #0f0c0a) !important;
    border: none !important;
    border-radius: 999px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
    box-shadow: 0 10px 24px rgba(154, 90, 0, 0.32);
}

.product-hero-shell .detail-buy-box .button-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 32px rgba(154, 90, 0, 0.42);
    filter: brightness(1.05);
}

.product-hero-shell .product-trust-list {
    list-style: none;
    padding: 0.9rem 0 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    font-size: 0.82rem;
    color: rgba(245, 239, 229, 0.85) !important;
    border-top: 1px solid rgba(216, 161, 90, 0.18);
}

.product-hero-shell .product-trust-list li::before {
    content: "✓ ";
    color: var(--em-amber-300, #f3c98a);
    font-weight: 700;
    margin-right: 0.4rem;
}

@media (max-width: 720px) {
    .page-banner .container.product-hero-shell,
    .product-hero-shell {
        box-sizing: border-box !important;
        align-items: stretch !important;
        width: auto !important;
        max-width: none !important;
        margin-inline: 1rem !important;
        padding: 1rem !important;
        overflow: hidden;
    }

    .product-hero-layout {
        gap: 1rem;
    }

    .product-hero-layout > .product-media-column,
    .product-hero-layout > .product-hero-intro,
    .product-hero-layout > .product-purchase-card,
    .product-hero-layout > .product-hero-purchase,
    .product-hero-layout > .product-hero-actions {
        flex-basis: auto;
        width: 100%;
        max-width: 100%;
    }

    .product-hero-shell h1 {
        max-width: 100% !important;
        font-size: clamp(1.95rem, 8.8vw, 2.45rem) !important;
        line-height: 1.08 !important;
        overflow-wrap: break-word;
        text-wrap: balance;
    }

    .product-hero-shell .hero-copy {
        max-width: 29ch;
        font-size: 1rem;
        line-height: 1.52;
        overflow-wrap: break-word;
        text-wrap: pretty;
    }

    .product-hero-shell .product-hero-meta {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.55rem;
        justify-items: start;
    }

    .product-hero-shell .stock-pill {
        width: fit-content;
        max-width: 100%;
    }

    .product-hero-shell .product-hero-media,
    .product-hero-shell .detail-media {
        box-sizing: border-box;
        width: min(100%, 19.5rem);
        margin-inline: auto;
        padding: 0.7rem;
        background:
            radial-gradient(circle at 50% 24%, rgba(180, 230, 222, 0.14), transparent 34%),
            #10201f;
    }

    .product-hero-shell .product-hero-media img,
    .product-hero-shell .detail-media img {
        border-radius: 10px;
        object-fit: contain;
        object-position: center;
    }

    .product-hero-shell .product-gallery-carousel {
        max-width: 100%;
        overflow: hidden;
    }

    .product-hero-shell .product-gallery-viewport {
        flex: 1 1 auto;
        min-width: 0;
        max-width: calc(100vw - 7rem);
    }

    .product-hero-shell .product-gallery-strip {
        overflow-x: auto;
        scrollbar-width: none;
    }

    .product-hero-shell .product-gallery-strip::-webkit-scrollbar {
        display: none;
    }
}

/* === Chapter-nav sticky : style Apple, apparaît sous le hero === */
.product-chapter-nav-sticky {
    position: sticky;
    top: var(--header-offset, 88px);
    z-index: 5;
    width: min(1600px, calc(100% - var(--em-container-padding-x, 1rem) * 2));
    margin: 1.2rem auto 0;
    padding: 0.6rem 1rem;
    background: rgba(251, 247, 241, 0.92);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(154, 90, 0, 0.15);
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    flex-wrap: wrap;
    box-shadow: 0 6px 20px rgba(15, 10, 6, 0.06);
}

.product-chapter-nav-sticky a {
    color: var(--em-ink-700, #251a13);
    text-decoration: none;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 500;
    transition: background 180ms ease, color 180ms ease;
    white-space: nowrap;
}

.product-chapter-nav-sticky a:hover {
    background: var(--em-ink-700, #251a13);
    color: #fff;
}

@media (max-width: 720px) {
    .product-chapter-nav-sticky {
        position: relative;
        top: auto;
        gap: 0.3rem;
        overflow-x: auto;
        flex-wrap: nowrap;
        justify-content: flex-start;
        scrollbar-width: thin;
    }
    .product-chapter-nav-sticky a {
        font-size: 0.78rem;
        padding: 0.35rem 0.7rem;
    }
}

/* === Header : le hover apres scroll ne doit pas changer la hauteur === */
@media (min-width: 901px) {
    .site-header.is-condensed:is(:hover, :focus-within) .nav-row {
        padding: 0.6rem 0.85rem !important;
        gap: 1rem !important;
    }

    .site-header.is-condensed:is(:hover, :focus-within) .brand-logo {
        max-height: 46px !important;
    }

    .site-header.is-condensed:is(:hover, :focus-within) .main-nav {
        gap: 0.2rem 0.4rem !important;
    }

    .site-header.is-condensed:is(:hover, :focus-within) .main-nav a,
    .site-header.is-condensed:is(:hover, :focus-within) .nav-ghost {
        min-height: 40px !important;
        padding: 0.6rem 0.8rem !important;
    }
}

/* === About page : finition premium, largeur produit et mobile sans rognage === */
.about-hero-band,
.about-page-section {
    width: 100% !important;
    max-width: none !important;
    margin-inline: 0 !important;
    overflow-x: clip;
}

.about-hero-band > .container.about-hero-shell {
    box-sizing: border-box;
    width: min(1760px, calc(100% - clamp(1rem, 2vw, 2rem) * 2)) !important;
    max-width: 1760px !important;
    margin-inline: auto !important;
}

.about-page-section > .container.about-page-grid {
    box-sizing: border-box;
    width: min(1600px, calc(100% - clamp(1rem, 3vw, 2.5rem) * 2)) !important;
    max-width: 1600px !important;
    margin-inline: auto !important;
}

.about-hero-shell {
    display: grid;
    min-height: min(75vh, 48rem);
    gap: clamp(0.9rem, 1.6vw, 1.5rem) !important;
    align-items: stretch;
    align-content: center;
    padding: clamp(1.25rem, 2.4vw, 2.25rem) !important;
}

.about-hero-intro {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: flex-end !important;
    align-content: space-around !important;
    justify-content: flex-start !important;
    width: 100%;
    max-width: none !important;
    margin-inline: 0 !important;
    gap: clamp(0.75rem, 1.4vw, 1.2rem) clamp(1.3rem, 4vw, 3rem) !important;
    color: #5a4737;
}

.about-hero-intro .eyebrow {
    flex: 0 0 100%;
    margin: 0 !important;
}

.about-hero-intro h1 {
    flex: 0 1 56%;
    max-width: 56rem !important;
    margin: 0 !important;
    font-size: clamp(2.35rem, 3.65vw, 3.85rem) !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
    text-wrap: balance;
}

.about-hero-intro .section-intro {
    flex: 1 1 22rem;
    max-width: 38rem !important;
    margin: 0 !important;
    font-size: clamp(1rem, 1.2vw, 1.16rem) !important;
    line-height: 1.62 !important;
    text-wrap: pretty;
}

.about-trust-strip {
    flex: 0 0 100%;
    justify-content: flex-start;
    margin-top: 0.15rem;
}

.about-trust-strip span {
    min-height: 2.2rem;
    padding: 0.4rem 0.9rem;
}

.about-hero-layout {
    grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr) !important;
    gap: clamp(0.9rem, 1.6vw, 1.3rem) !important;
    align-items: stretch !important;
}

.about-founders-card,
.about-hero-side,
.about-evidence-card,
.about-quote-card {
    min-width: 0;
}

.about-founders-card {
    margin: 0 !important;
    align-content: start;
    grid-template-rows: auto auto;
    min-height: 100%;
}

.about-founders-card img {
    height: clamp(12rem, 20vh, 15.5rem);
    min-height: 0;
    object-fit: cover;
}

.about-hero-side {
    grid-template-rows: minmax(0, 1fr) auto;
    align-content: stretch !important;
}

.about-evidence-card,
.about-quote-card {
    align-content: center;
}

@media (min-width: 1101px) {
    .about-founders-card,
    .about-evidence-card,
    .about-quote-card {
        padding: clamp(0.9rem, 1.5vw, 1.15rem) !important;
    }
}

.about-evidence-card h2,
.about-mission-shell h2,
.about-heritage-card h2,
.about-renaissance-card h2,
.about-proof-shell h2,
.about-future-shell h2,
.about-future-card h3 {
    letter-spacing: 0 !important;
}

.about-mission-shell,
.about-heritage-card,
.about-renaissance-card,
.about-proof-shell,
.about-future-shell {
    box-sizing: border-box;
}

.about-mission-grid {
    grid-template-columns: minmax(320px, 0.88fr) minmax(0, 1.12fr) !important;
    align-items: stretch !important;
}

.about-mission-visual {
    margin: 0 !important;
    min-height: 100%;
}

.about-mission-visual img {
    height: 100%;
    min-height: 24rem;
}

.about-mission-content,
.about-heritage-card,
.about-renaissance-card,
.about-proof-shell,
.about-future-card {
    min-width: 0;
}

.about-heritage-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(340px, 0.85fr) !important;
    align-items: stretch !important;
}

.about-renaissance-card {
    min-height: 100%;
}

.about-proof-grid {
    grid-template-columns: minmax(0, 1.16fr) minmax(330px, 0.84fr) !important;
    align-items: stretch !important;
}

.about-proof-support-shell {
    grid-template-columns: 1fr !important;
    align-content: start;
}

.about-proof-image-card,
.about-testimonial-panel,
.about-future-card {
    height: 100%;
}

.about-proof-image-card,
.about-support-visual {
    margin: 0 !important;
}

.about-testimonial-list li {
    min-width: 0;
}

@media (max-width: 1100px) {
    .about-hero-layout,
    .about-mission-grid,
    .about-heritage-grid,
    .about-proof-grid,
    .about-proof-support-shell {
        grid-template-columns: 1fr !important;
    }

    .about-founders-card img,
    .about-mission-visual img {
        min-height: 0;
        height: auto;
    }
}

@media (min-width: 1101px) and (max-height: 820px) {
    .about-hero-shell {
        min-height: 75vh;
    }

    .about-hero-intro h1 {
        font-size: clamp(2.25rem, 3.45vw, 3.5rem) !important;
    }

    .about-founders-card,
    .about-evidence-card,
    .about-quote-card {
        padding: 1rem !important;
    }
}

@media (max-width: 720px) {
    .about-hero-band {
        padding-block: 1rem 1.35rem;
    }

    .about-hero-band > .container.about-hero-shell {
        inline-size: min(calc(100% - 2rem), calc(100vw - 2rem)) !important;
        width: min(calc(100% - 2rem), calc(100vw - 2rem)) !important;
        max-width: calc(100vw - 2rem) !important;
        margin-inline: auto !important;
    }

    .about-page-section > .container.about-page-grid {
        inline-size: min(calc(100% - 1rem), calc(100vw - 1rem)) !important;
        width: min(calc(100% - 1rem), calc(100vw - 1rem)) !important;
        max-width: calc(100vw - 1rem) !important;
        margin-inline: auto !important;
    }

    .about-hero-band > .container.about-hero-shell {
        min-height: auto;
        padding: 1.15rem !important;
        overflow: hidden;
    }

    .about-hero-intro {
        align-items: flex-start !important;
        justify-content: flex-start !important;
        width: 100% !important;
        max-width: 100% !important;
        gap: 0.95rem !important;
    }

    .about-hero-intro h1 {
        flex-basis: 100%;
        width: 100% !important;
        max-width: 100% !important;
        font-size: clamp(2rem, 10vw, 3.05rem) !important;
        line-height: 1 !important;
        overflow-wrap: break-word;
        word-break: normal;
        hyphens: none;
    }

    .about-hero-intro .section-intro {
        flex-basis: 100%;
        width: 100% !important;
        max-width: 100% !important;
        font-size: 1rem !important;
        line-height: 1.64 !important;
        overflow-wrap: break-word;
    }

    .about-trust-strip {
        display: grid !important;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .about-trust-strip span {
        box-sizing: border-box;
        justify-content: center;
        width: 100%;
    }

    .about-founders-card,
    .about-evidence-card,
    .about-quote-card {
        width: 100% !important;
        max-width: 100% !important;
        margin-inline: 0 !important;
        padding: 1rem !important;
    }

    .about-evidence-card h2 {
        font-size: clamp(1.45rem, 8vw, 2rem) !important;
    }
}

/* === Checkout : resume de commande visible pendant le scroll === */
@media (min-width: 1101px) {
    .checkout-side-column {
        position: sticky !important;
        top: calc(var(--header-offset, 88px) + 1rem) !important;
        align-self: start !important;
        max-height: calc(100vh - var(--header-offset, 88px) - 2rem);
        overflow: visible;
    }

    .checkout-side-column .checkout-summary-panel {
        position: static !important;
        max-height: calc(100vh - var(--header-offset, 88px) - 2rem);
        overflow: auto;
        overscroll-behavior: contain;
    }
}

@media (max-width: 1100px) {
    .checkout-side-column,
    .checkout-side-column .checkout-summary-panel {
        position: static !important;
        max-height: none;
        overflow: visible;
    }
}

/* === Account + conversations : polish UX/UI final === */
.account-page-section,
.section:has(.account-chat-layout) {
    width: 100% !important;
    max-width: none !important;
    margin-inline: 0 !important;
}

.account-page-container,
.section > .container.account-chat-layout,
.page-banner > .container.account-conversation-hero {
    box-sizing: border-box;
    width: min(1600px, calc(100% - clamp(1rem, 3vw, 2.5rem) * 2)) !important;
    max-width: 1600px !important;
    margin-inline: auto !important;
}

.account-dashboard {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.32fr) !important;
    gap: clamp(1rem, 2vw, 1.6rem) !important;
    align-items: start;
}

.account-main-column,
.account-side-column,
.account-bottom-grid,
.account-order-list,
.account-conversation-list {
    min-width: 0;
}

.account-side-column {
    position: sticky;
    top: calc(var(--header-offset, 88px) + 1rem);
}

.account-identity-card,
.account-security-panel,
.account-conversation-card,
.account-orders-panel,
.account-chat-thread-panel,
.account-chat-compose-panel,
.account-conversation-reference-panel {
    border-radius: clamp(16px, 1.4vw, 22px) !important;
}

.account-identity-card,
.account-security-panel {
    padding: clamp(1.15rem, 2vw, 1.65rem) !important;
}

.account-identity-shell {
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: clamp(0.95rem, 1.7vw, 1.35rem) !important;
}

.account-identity-copy h1 {
    max-width: none !important;
    font-size: clamp(2rem, 3vw, 3rem) !important;
    line-height: 1.02 !important;
    letter-spacing: 0 !important;
}

.account-contact-line {
    gap: 0.5rem !important;
}

.account-contact-line span {
    min-height: 2.15rem;
    padding: 0.35rem 0.72rem !important;
    border-radius: 999px;
    background: rgba(255, 246, 231, 0.1);
    border: 1px solid rgba(255, 229, 187, 0.16);
}

.account-contact-line span::after {
    display: none !important;
}

.account-editor-drawer {
    margin-top: 0.35rem !important;
}

.account-editor-toggle {
    justify-content: flex-start !important;
}

.account-editor-toggle-label {
    min-height: 2.45rem !important;
    padding-inline: 1.05rem !important;
}

.account-editor-drawer-body {
    padding-top: 1.15rem !important;
}

.account-bottom-grid {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr) !important;
    gap: clamp(1rem, 2vw, 1.35rem) !important;
    align-items: stretch !important;
}

.account-conversation-card,
.account-orders-panel {
    align-content: start;
    padding: clamp(1.15rem, 2vw, 1.6rem) !important;
    background: rgba(255, 253, 249, 0.96);
}

.account-conversation-item,
.account-order-card {
    border-radius: 16px !important;
    padding: 1rem !important;
    background: linear-gradient(180deg, rgba(255, 255, 253, 0.98), rgba(248, 242, 233, 0.98)) !important;
    box-shadow: 0 10px 24px rgba(31, 22, 15, 0.055) !important;
}

.account-conversation-item .summary-line,
.account-order-card .summary-line {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: start !important;
}

.account-conversation-badges {
    justify-content: flex-end;
}

.account-security-list {
    gap: 0.6rem !important;
}

.account-security-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
}

.account-security-item > * {
    min-width: 0;
}

.account-security-panel .button-primary,
.account-security-panel .button-secondary,
.account-security-panel .button-ghost {
    width: 100%;
}

.account-conversation-hero {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.34fr) !important;
    gap: clamp(1rem, 2vw, 1.5rem) !important;
    align-items: stretch !important;
}

.account-conversation-hero .detail-content,
.account-conversation-reference-panel,
.account-chat-thread-panel,
.account-chat-compose-panel {
    min-width: 0;
}

.account-conversation-hero .detail-content {
    padding: clamp(1.3rem, 2.4vw, 2rem);
    border-radius: clamp(16px, 1.4vw, 22px);
    background:
        radial-gradient(circle at top right, rgba(237, 193, 117, 0.15), transparent 34%),
        linear-gradient(180deg, #2b1e14, #1e150f);
    border: 1px solid rgba(255, 233, 188, 0.16);
    color: #fff7ec;
    box-shadow: 0 20px 40px rgba(18, 12, 8, 0.18);
}

.account-conversation-hero .detail-content h1 {
    max-width: 16ch;
    margin: 0 !important;
    color: #fff7ec;
    font-size: clamp(2.25rem, 4vw, 4rem) !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
}

.account-conversation-hero .detail-content > p:not(.eyebrow) {
    max-width: 58ch;
    color: rgba(255, 245, 232, 0.9);
}

.account-conversation-reference-panel {
    align-content: start;
    padding: clamp(1.15rem, 2vw, 1.55rem) !important;
}

.account-chat-layout {
    grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr) !important;
    gap: clamp(1rem, 2vw, 1.6rem) !important;
    align-items: start !important;
}

.account-chat-thread-panel,
.account-chat-compose-panel {
    padding: clamp(1.15rem, 2vw, 1.55rem) !important;
    background: rgba(255, 253, 249, 0.96);
}

.account-chat-thread-head {
    align-items: flex-start !important;
    padding-bottom: 0.95rem;
    border-bottom: 1px solid rgba(112, 85, 58, 0.1);
}

.account-message-thread {
    gap: 1.05rem !important;
}

.account-message-shell {
    width: min(100%, 44rem) !important;
}

.account-chat-thread-panel .account-message {
    border-radius: 18px !important;
    padding: 0.95rem 1.05rem !important;
    box-shadow: 0 10px 22px rgba(33, 23, 16, 0.055) !important;
}

.account-chat-thread-panel .account-message::after {
    display: none;
}

.account-chat-compose-panel {
    top: calc(var(--header-offset, 88px) + 1rem) !important;
}

.account-chat-compose-card {
    gap: 0.95rem !important;
}

.account-chat-compose-field {
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.account-chat-compose-form textarea,
.account-chat-compose-form input[type="text"] {
    border-radius: 14px !important;
    background: #fffdfa !important;
}

.account-chat-compose-actions .button-primary {
    width: 100%;
}

.account-shell {
    width: min(980px, calc(100% - clamp(1rem, 3vw, 2.5rem) * 2)) !important;
    max-width: 980px !important;
    padding-top: calc(var(--header-offset, 88px) + 1rem) !important;
}

.account-shell .account-header,
.account-shell .account-panel {
    border-radius: clamp(16px, 1.4vw, 22px) !important;
}

.account-shell .account-header {
    padding: clamp(1.25rem, 2.2vw, 1.8rem);
    background:
        radial-gradient(circle at top right, rgba(237, 193, 117, 0.14), transparent 36%),
        linear-gradient(180deg, #2b1e14, #1e150f);
    border: 1px solid rgba(255, 233, 188, 0.16);
    color: #fff7ec;
}

.account-shell .account-header h1,
.account-shell .account-header .eyebrow {
    color: #fff7ec;
}

.account-shell .account-header p:not(.eyebrow) {
    max-width: 66ch;
    color: rgba(255, 245, 232, 0.9);
}

.account-shell .account-panel {
    background: rgba(255, 253, 249, 0.96) !important;
    border-color: rgba(112, 85, 58, 0.12) !important;
    box-shadow: 0 18px 38px rgba(31, 22, 15, 0.08) !important;
}

.cart-page-banner {
    padding-bottom: clamp(1rem, 2.4vw, 1.8rem) !important;
}

.page-banner > .container.cart-hero-panel,
.section > .container.cart-page-grid {
    width: min(1280px, calc(100% - clamp(1rem, 3vw, 2.5rem) * 2)) !important;
    max-width: 1280px !important;
    margin-inline: auto !important;
}

.cart-hero-panel {
    display: grid !important;
    gap: 0.85rem !important;
    min-height: auto !important;
    padding-block: clamp(1.35rem, 3vw, 2.2rem) !important;
}

.cart-hero-panel h1 {
    margin: 0 !important;
    max-width: 10ch;
}

.cart-hero-panel > p:not(.eyebrow) {
    max-width: 62ch;
    margin: 0 !important;
    color: #5a4737;
}

.cart-hero-assurance {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.35rem;
}

.cart-hero-assurance span,
.cart-unit-price {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 2rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    border: 1px solid rgba(112, 85, 58, 0.13);
    background: rgba(255, 252, 247, 0.72);
    color: #5a4737 !important;
    font-size: 0.82rem;
    font-weight: 700;
}

.cart-page-section {
    padding-top: clamp(0.85rem, 2vw, 1.5rem) !important;
}

.cart-page-grid {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.38fr) !important;
    gap: clamp(1rem, 2vw, 1.5rem) !important;
    align-items: start !important;
}

.cart-page-list {
    gap: 0.95rem !important;
}

.cart-page-card {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
        "main price"
        "actions actions";
    gap: clamp(1rem, 2vw, 1.35rem) !important;
    align-items: start;
    padding: clamp(1rem, 2vw, 1.35rem) !important;
    border-radius: 18px !important;
    background: rgba(255, 253, 249, 0.97) !important;
    border-color: rgba(112, 85, 58, 0.12) !important;
    box-shadow: 0 14px 32px rgba(31, 22, 15, 0.075) !important;
}

.cart-page-card .cart-card-main {
    grid-area: main;
    display: grid !important;
    grid-template-columns: clamp(88px, 11vw, 118px) minmax(0, 1fr);
    gap: clamp(0.9rem, 2vw, 1.25rem);
    align-items: center;
    min-width: 0;
}

.cart-product-media-link {
    display: block;
    width: 100%;
    min-width: 0;
}

.cart-product-media {
    width: 100% !important;
    aspect-ratio: 3 / 4 !important;
    min-height: 0 !important;
    border-radius: 14px !important;
    overflow: hidden;
    box-shadow: 0 12px 26px rgba(35, 24, 16, 0.12);
}

.cart-product-media .product-media-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cart-product-copy {
    display: grid;
    gap: 0.35rem;
    min-width: 0;
}

.cart-product-copy .product-meta,
.cart-product-copy h2,
.cart-product-copy p {
    margin: 0 !important;
}

.cart-product-copy h2 {
    font-size: clamp(1.35rem, 2.4vw, 1.8rem) !important;
    line-height: 1.08 !important;
}

.cart-product-copy p:not(.product-meta) {
    color: #5a4737 !important;
}

.cart-unit-price {
    margin-top: 0.25rem;
    font-size: 0.8rem;
}

.cart-page-card .cart-price {
    grid-area: price;
    justify-self: end;
    min-width: max-content;
    padding-top: 0.15rem;
    color: #6b4a24 !important;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.25rem, 2.2vw, 1.65rem);
    font-weight: 700;
    line-height: 1;
}

.cart-page-card .cart-actions {
    grid-area: actions;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem;
    padding-top: 0.95rem;
    border-top: 1px solid rgba(112, 85, 58, 0.1);
}

.cart-quantity-form {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: end;
}

.cart-quantity-label {
    display: grid;
    gap: 0.35rem;
    min-width: 6rem;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #6b5541 !important;
}

.cart-page-card .quantity-input {
    width: 5.25rem;
    min-height: 2.75rem;
    padding: 0.65rem 0.75rem;
    border-radius: 12px;
    border: 1px solid rgba(112, 85, 58, 0.2) !important;
    background: #fffdfa !important;
    color: #251a13 !important;
    text-align: center;
    font-weight: 800;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.cart-page-card .quantity-input:focus {
    outline: 2px solid rgba(216, 161, 90, 0.45);
    outline-offset: 2px;
    border-color: rgba(154, 90, 0, 0.42) !important;
    background: #ffffff !important;
}

.cart-page-card .button-secondary,
.cart-page-card .button-ghost,
.cart-summary-card .button-primary,
.cart-empty-state .button-primary {
    min-height: 2.75rem;
}

.cart-summary-card {
    position: sticky;
    top: calc(var(--header-offset, 88px) + 1rem);
    display: grid;
    gap: 0.95rem;
    padding: clamp(1.15rem, 2vw, 1.5rem) !important;
    border-radius: 18px !important;
    background:
        radial-gradient(circle at top right, rgba(237, 193, 117, 0.14), transparent 34%),
        linear-gradient(180deg, #2b1e14, #1e150f) !important;
    border: 1px solid rgba(255, 233, 188, 0.16) !important;
    color: #fff7ec;
}

.cart-summary-card h2,
.cart-summary-card p,
.cart-summary-card span,
.cart-summary-card strong {
    color: #fff7ec !important;
}

.cart-summary-card h2,
.cart-summary-card p {
    margin: 0 !important;
}

.cart-summary-card > p:not(.eyebrow) {
    color: rgba(255, 245, 232, 0.88) !important;
}

.cart-summary-list {
    display: grid;
    gap: 0.7rem;
    padding-block: 0.25rem;
}

.cart-summary-list .summary-line {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: baseline;
    padding: 0;
    color: rgba(255, 245, 232, 0.9) !important;
}

.cart-summary-list .summary-line strong {
    text-align: right;
}

.cart-summary-list .summary-line.total {
    margin-top: 0.2rem;
    padding-top: 0.8rem;
    border-top: 1px solid rgba(255, 231, 197, 0.16);
}

.cart-empty-state {
    min-height: 20rem;
    align-content: center;
    justify-items: start;
    padding: clamp(1.4rem, 3vw, 2rem) !important;
    border-radius: 18px !important;
    background: rgba(255, 253, 249, 0.97) !important;
}

@media (max-width: 1100px) {
    .account-dashboard,
    .account-bottom-grid,
    .account-conversation-hero,
    .account-chat-layout,
    .cart-page-grid {
        grid-template-columns: 1fr !important;
    }

    .account-side-column,
    .account-chat-compose-panel,
    .cart-summary-card {
        position: static !important;
    }
}

@media (max-width: 720px) {
    .account-page-container,
    .section > .container.account-chat-layout,
    .page-banner > .container.account-conversation-hero,
    .account-shell {
        width: calc(100% - 1rem) !important;
        max-width: calc(100% - 1rem) !important;
    }

    .account-identity-shell,
    .account-security-item,
    .account-conversation-item .summary-line,
    .account-order-card .summary-line {
        grid-template-columns: 1fr !important;
    }

    .account-conversation-badges {
        justify-content: flex-start;
    }

    .account-conversation-hero .detail-content h1 {
        max-width: 100%;
        font-size: clamp(2rem, 10vw, 3.1rem) !important;
    }

    .page-banner > .container.cart-hero-panel,
    .section > .container.cart-page-grid {
        width: calc(100% - 1rem) !important;
        max-width: calc(100% - 1rem) !important;
    }

    .cart-hero-panel h1 {
        max-width: 100%;
    }

    .cart-page-card {
        grid-template-columns: 1fr;
        grid-template-areas:
            "main"
            "price"
            "actions";
    }

    .cart-page-card .cart-card-main {
        grid-template-columns: 84px minmax(0, 1fr);
    }

    .cart-page-card .cart-price {
        justify-self: start;
    }

    .cart-page-card .cart-actions,
    .cart-quantity-form {
        width: 100%;
    }

    .cart-page-banner,
    .cart-page-section {
        overflow-x: clip;
    }

    .cart-hero-panel,
    .cart-page-grid,
    .cart-page-card,
    .cart-empty-state,
    .cart-summary-card,
    .cart-summary-list,
    .cart-summary-list .summary-line {
        box-sizing: border-box;
        min-width: 0;
        max-width: 100%;
    }

    .cart-hero-panel > p,
    .cart-empty-state h2,
    .cart-empty-state p,
    .cart-summary-card p,
    .cart-summary-list span,
    .cart-summary-list strong {
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .cart-empty-state {
        justify-items: stretch;
    }

    .cart-summary-list .summary-line {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.25rem;
        align-items: start;
    }

    .cart-summary-list .summary-line strong {
        text-align: left;
    }

    .cart-page-card .button-secondary,
    .cart-page-card .button-ghost,
    .cart-summary-card .button-primary,
    .cart-empty-state .button-primary {
        box-sizing: border-box;
        min-width: 0;
        max-width: 100%;
        width: 100%;
    }
}
