/* ═══════════════════════════════════════════════════════════════
   L'Atelier du Pain — Design System & Styles
   assets/css/style.css
   ═══════════════════════════════════════════════════════════════ */

/* ── Palette & tokens ──────────────────────────────────────────── */
:root {
    --adp-brown:       #92400E;
    --adp-amber:       #B45309;
    --adp-cream:       #FEF3C7;
    --adp-text:        #78350F;
    --adp-light:       #FFFBEB;

    /* Ombres */
    --adp-shadow-sm:   0 1px 4px rgba(120, 53, 15, .06);
    --adp-shadow-md:   0 4px 16px rgba(120, 53, 15, .09);
    --adp-shadow-lg:   0 12px 40px rgba(120, 53, 15, .13);
    --adp-shadow-glow: 0 0 0 4px rgba(180, 83, 9, .12);

    /* Rayons */
    --adp-radius-sm:   0.75rem;
    --adp-radius-md:   1rem;
    --adp-radius-lg:   1.5rem;
    --adp-radius-pill: 50rem;

    /* Transitions */
    --adp-transition:  0.3s cubic-bezier(.4, 0, .2, 1);

    /* Glassmorphism */
    --adp-glass-bg:    rgba(255, 251, 235, .75);
    --adp-glass-blur:  blur(14px);

    /* Bordure ambre transparente (réutilisée partout) */
    --adp-border-amber: rgba(180, 83, 9, .2);
}

/* ── Typographie ───────────────────────────────────────────────── */
body {
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    line-height: 1.75;
    background-color: var(--adp-light);
    color: var(--adp-text);
    -webkit-font-smoothing: antialiased;
    font-optical-sizing: auto;
}
h1, h2, h3, h4, .brand-font {
    font-family: 'Playfair Display', Georgia, serif;
    letter-spacing: -0.015em;
}
.caption {
    font-size: .8125rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--adp-brown);
}

/* ── Bootstrap overrides ───────────────────────────────────────── */
.btn {
    border-radius: var(--adp-radius-pill);
    font-weight: 500;
    letter-spacing: .01em;
    transition: all var(--adp-transition);
}
.btn-primary {
    background-color: var(--adp-brown);
    border-color: var(--adp-brown);
    color: #fff;
    padding: .625rem 1.75rem;
}
.btn-primary:hover, .btn-primary:focus {
    background-color: var(--adp-amber);
    border-color: var(--adp-amber);
    color: #fff;
    box-shadow: var(--adp-shadow-md);
    transform: translateY(-1px);
}
.btn-primary:active {
    transform: scale(.97);
}
.btn-outline-primary {
    color: var(--adp-brown);
    border-color: var(--adp-brown);
    padding: .625rem 1.75rem;
}
.btn-outline-primary:hover, .btn-outline-primary:focus {
    background-color: var(--adp-brown);
    border-color: var(--adp-brown);
    color: #fff;
    box-shadow: var(--adp-shadow-glow);
    transform: translateY(-1px);
}
.btn-lg {
    padding: .8rem 2.25rem;
    font-size: 1rem;
}
.text-primary { color: var(--adp-brown) !important; }
.bg-primary   { background-color: var(--adp-brown) !important; }
.badge.bg-primary { background-color: var(--adp-brown) !important; }

/* Form inputs modernisés */
.form-control, .form-select {
    border-radius: var(--adp-radius-sm);
    border-color: rgba(180, 83, 9, .25);
    transition: border-color var(--adp-transition), box-shadow var(--adp-transition);
}
.form-control:focus, .form-select:focus {
    border-color: var(--adp-amber);
    box-shadow: var(--adp-shadow-glow);
}

/* Breadcrumb */
.breadcrumb {
    font-size: .8125rem;
    letter-spacing: .01em;
}
.breadcrumb-item + .breadcrumb-item::before {
    content: '›';
    color: var(--adp-amber);
}

/* ── Product cards ─────────────────────────────────────────────── */
.product-card {
    background: #fff;
    border-radius: var(--adp-radius-lg) !important;
    box-shadow: var(--adp-shadow-sm);
    transition: transform var(--adp-transition), box-shadow var(--adp-transition);
    cursor: pointer;
}
.product-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--adp-shadow-lg) !important;
}
.product-card .card-img-top {
    object-fit: cover;
    aspect-ratio: 4 / 3;
    height: auto;
    transition: transform var(--adp-transition);
}
.product-card:hover .card-img-top {
    transform: scale(1.04);
}
.product-card .card-body {
    padding: 1.25rem 1.5rem 1.5rem;
}
.product-card .card-title a {
    transition: color var(--adp-transition);
}
.product-card:hover .card-title a {
    color: var(--adp-amber) !important;
}

/* ── Hero ──────────────────────────────────────────────────────── */
.hero-section {
    background: linear-gradient(160deg, var(--adp-cream) 0%, #fde68a 55%, var(--adp-light) 100%);
    position: relative;
    overflow: hidden;
}
.hero-section::before {
    content: '';
    position: absolute;
    top: -40%; right: -15%;
    width: 55%; height: 200%;
    background: radial-gradient(circle, rgba(253, 230, 138, .45) 0%, transparent 70%);
    pointer-events: none;
}
.hero-section h1 {
    font-size: clamp(2.2rem, 5vw, 3.75rem);
    line-height: 1.1;
    font-style: italic;
    letter-spacing: -0.02em;
}

/* ── Category pills ────────────────────────────────────────────── */
.category-pill {
    background: var(--adp-glass-bg);
    backdrop-filter: var(--adp-glass-blur);
    -webkit-backdrop-filter: var(--adp-glass-blur);
    border: 1.5px solid rgba(180, 83, 9, .22) !important;
    color: var(--adp-text);
    border-radius: var(--adp-radius-pill);
    font-family: 'Inter', sans-serif;
    font-size: .8125rem;
    font-weight: 500;
    letter-spacing: .015em;
    transition: all var(--adp-transition);
    cursor: pointer;
}
.category-pill:hover {
    background: var(--adp-amber);
    color: #fff;
    border-color: var(--adp-amber) !important;
    box-shadow: var(--adp-shadow-md);
    transform: translateY(-1px);
}

/* ── Section title ─────────────────────────────────────────────── */
.section-title {
    letter-spacing: -0.01em;
}
.section-title::after {
    content: '';
    display: block;
    width: 40px;
    height: 2px;
    background: linear-gradient(90deg, var(--adp-amber), var(--adp-brown));
    border-radius: var(--adp-radius-pill);
    margin-top: .6rem;
    transition: width var(--adp-transition);
}
.section-title:hover::after {
    width: 64px;
}

/* ── Utilitaires ───────────────────────────────────────────────── */
.section-divider {
    border: none;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(180, 83, 9, .3), transparent);
    margin: 0;
    opacity: 1;
}
.glass-panel {
    background: var(--adp-glass-bg);
    backdrop-filter: var(--adp-glass-blur);
    -webkit-backdrop-filter: var(--adp-glass-blur);
    border: 1px solid rgba(180, 83, 9, .12);
    border-radius: var(--adp-radius-lg);
}
.engagement-icon {
    width: 3.5rem;
    height: 3.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--adp-cream);
    border-radius: 50%;
    margin-bottom: .75rem;
}

/* ── Newsletter band ───────────────────────────────────────────── */
.newsletter-band {
    background: linear-gradient(135deg, var(--adp-brown) 0%, #7c2d12 45%, var(--adp-amber) 100%);
}

/* ── Section spacing ───────────────────────────────────────────── */
section.section-lg {
    padding-top: 4.5rem;
    padding-bottom: 4.5rem;
}
@media (max-width: 767.98px) {
    section.section-lg {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }
}

/* ── Navbar ─────────────────────────────────────────────────────── */
.navbar-glass {
    background: rgba(255, 255, 255, .88);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(180, 83, 9, .1);
}
.nav-main .nav-link {
    font-size: .875rem;
    font-weight: 500;
    letter-spacing: .015em;
    color: var(--adp-text);
    padding: .45rem 1rem;
    border-radius: var(--adp-radius-pill);
    transition: all var(--adp-transition);
}
.nav-main .nav-link:hover,
.nav-main .nav-link.active {
    color: var(--adp-brown);
    background: rgba(254, 243, 199, .55);
}
.nav-main .nav-link.nav-link-promo {
    color: var(--adp-amber);
}
.nav-action-icon {
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background var(--adp-transition);
    color: #333;
    text-decoration: none;
}
.nav-action-icon:hover {
    background: rgba(254, 243, 199, .65);
    color: var(--adp-brown);
}

/* ── Footer ────────────────────────────────────────────────────── */
.site-footer {
    background: linear-gradient(180deg, #1c0a00 0%, #0f0600 100%);
    color: rgba(255, 251, 235, .65);
    padding: 4.5rem 0 2rem;
}
.site-footer a {
    color: rgba(255, 251, 235, .5);
    transition: color var(--adp-transition);
    text-decoration: none;
}
.site-footer a:hover {
    color: #FDE68A;
}
.social-icon {
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1.5px solid rgba(255, 251, 235, .2);
    border-radius: 50%;
    color: rgba(255, 251, 235, .55);
    transition: all var(--adp-transition);
    text-decoration: none;
}
.social-icon:hover {
    border-color: var(--adp-amber);
    color: var(--adp-amber);
    transform: translateY(-2px);
}
.footer-heading {
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255, 251, 235, .9);
    margin-bottom: 1rem;
}

/* ── Cart ──────────────────────────────────────────────────────── */
.cart-table th {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 600;
    color: var(--adp-brown);
    padding: .9rem .75rem;
    border-bottom: 1.5px solid var(--adp-amber);
}
.cart-table td {
    padding: 1.25rem .75rem;
    border-bottom: 1px solid rgba(243, 232, 208, .8);
    vertical-align: middle;
}
.cart-row {
    transition: background-color var(--adp-transition);
}
.cart-row:hover {
    background-color: rgba(254, 243, 199, .4);
}
.cart-qty-input {
    border-color: var(--adp-amber);
    color: var(--adp-text);
    font-weight: 500;
    border-radius: var(--adp-radius-sm) !important;
}
.cart-qty-input:focus {
    border-color: var(--adp-brown);
    box-shadow: var(--adp-shadow-glow);
}
.cart-card {
    background: #fff;
    box-shadow: var(--adp-shadow-sm);
    transition: transform var(--adp-transition), box-shadow var(--adp-transition);
}
.cart-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--adp-shadow-md) !important;
}
.cart-summary {
    background: var(--adp-glass-bg) !important;
    backdrop-filter: var(--adp-glass-blur);
    -webkit-backdrop-filter: var(--adp-glass-blur);
    border: 1.5px solid var(--adp-border-amber) !important;
    border-radius: var(--adp-radius-lg) !important;
    box-shadow: var(--adp-shadow-md);
    transition: box-shadow var(--adp-transition);
}
.cart-summary:hover {
    box-shadow: var(--adp-shadow-lg);
}

/* ── Quantity input — masque les flèches natives ───────────────── */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; appearance: none; margin: 0; }
input[type=number] { -moz-appearance: textfield; appearance: textfield; }

/* ── Commande (checkout) ───────────────────────────────────────── */
.order-section-title::after {
    content: '';
    display: block;
    width: 40px;
    height: 2px;
    background: linear-gradient(90deg, var(--adp-amber), var(--adp-brown));
    border-radius: var(--adp-radius-pill);
    margin-top: .5rem;
}
.order-item {
    padding: .5rem 0;
    border-bottom: 1px solid rgba(243, 232, 208, .6);
    transition: background-color var(--adp-transition);
}
.order-item:last-child {
    border-bottom: none;
}
.order-item:hover {
    background-color: rgba(254, 243, 199, .3);
    border-radius: var(--adp-radius-sm);
}
.order-item-name {
    font-size: .9rem;
    line-height: 1.3;
}

/* ── Accessibility ─────────────────────────────────────────────── */
:focus-visible {
    outline: 3px solid var(--adp-amber);
    outline-offset: 3px;
}

/* ── Reduced motion ────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        transition: none !important;
        animation: none !important;
    }
}

/* ═══════════════════════════════════════════════════════════════
   CLASSES UTILITAIRES — remplacent les inline styles dupliqués
   ═══════════════════════════════════════════════════════════════ */

/* ── Couleurs texte ────────────────────────────────────────────── */
.text-adp       { color: var(--adp-text); }
.text-adp-brown { color: var(--adp-brown); }
.text-adp-amber { color: var(--adp-amber); }

/* ── Couleurs de fond ──────────────────────────────────────────── */
.bg-adp-light { background-color: var(--adp-light); }
.bg-adp-cream { background-color: var(--adp-cream); }

/* ── Typographie spécialisée ───────────────────────────────────── */
.font-serif { font-family: 'Playfair Display', Georgia, serif; }

/* ── Icônes couleur ambre (répétées dans engagements, footer…) ── */
.icon-amber { color: var(--adp-amber); }

/* ── Icônes paiement footer ────────────────────────────────────── */
.icon-footer-muted { color: rgba(255, 251, 235, .45); }

/* ── En-tête de page (breadcrumb zone) ─────────────────────────── */
.page-header {
    background: linear-gradient(160deg, var(--adp-cream) 0%, #fde68a 100%);
}

/* ── Titre h1 de page ──────────────────────────────────────────── */
.page-title {
    color: var(--adp-text);
    font-size: clamp(1.8rem, 4vw, 2.6rem);
}

/* ── Paragraphe d'introduction / description ───────────────────── */
.hero-lead {
    color: var(--adp-brown);
    font-size: 1.05rem;
    line-height: 1.85;
}

/* ── Prix produit ──────────────────────────────────────────────── */
.price-tag {
    color: var(--adp-amber);
    font-size: 1.05rem;
    font-family: 'Playfair Display', Georgia, serif;
}
.price-tag-lg {
    color: var(--adp-text);
    font-size: 2.25rem;
    font-family: 'Playfair Display', Georgia, serif;
}

/* ── Badge compteur (articles, créations) ──────────────────────── */
.count-badge {
    background: rgba(255, 251, 235, .8);
    color: var(--adp-brown);
    font-size: .8rem;
    font-weight: 500;
    border: 1px solid var(--adp-border-amber);
}

/* ── Liens fil d'ariane ────────────────────────────────────────── */
.breadcrumb-link {
    color: var(--adp-amber);
}
.breadcrumb-active {
    color: var(--adp-brown);
}

/* ── Image hero / produit — bordure douce ──────────────────────── */
.hero-img-border {
    border: 3px solid rgba(255, 251, 235, .6);
}

/* ── Image panier (miniature) ──────────────────────────────────── */
.cart-img {
    object-fit: cover;
    border-radius: var(--adp-radius-sm);
}

/* ── Bouton icône circulaire (supprimer, etc.) ─────────────────── */
.btn-icon-circle {
    width: 2rem;
    height: 2rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* ── Sidebar sticky ────────────────────────────────────────────── */
.sticky-aside {
    position: sticky;
    top: 100px;
}

/* ── Wrapper input newsletter ──────────────────────────────────── */
.newsletter-input-wrap {
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .2);
}

/* ── Badge hero (livraison) ────────────────────────────────────── */
.hero-badge {
    background-color: #FDE68A;
    color: var(--adp-brown);
}

/* ── Section title taille standard ─────────────────────────────── */
.section-title-lg {
    font-size: 2rem;
    color: var(--adp-text);
}

/* ── Box promo gradient ────────────────────────────────────────── */
.box-promo-bg {
    background: linear-gradient(135deg, rgba(253, 230, 138, .6) 0%, rgba(254, 243, 199, .8) 100%);
    box-shadow: var(--adp-shadow-lg);
}

/* ── Prix panel detail (gradient) ──────────────────────────────── */
.price-panel-bg {
    background: linear-gradient(135deg, rgba(253, 230, 138, .5) 0%, rgba(254, 243, 199, .7) 100%);
}

/* ── Sélecteur quantité (détail produit) ───────────────────────── */
.qty-selector {
    border: 1.5px solid var(--adp-amber);
    border-radius: var(--adp-radius-pill);
    overflow: hidden;
    background: #fff;
    height: 3rem;
}
.qty-btn {
    width: 3rem;
    height: 100%;
    border: none;
    background: transparent;
    color: var(--adp-amber);
    font-size: 1.1rem;
    cursor: pointer;
    transition: background var(--adp-transition);
    display: flex;
    align-items: center;
    justify-content: center;
}
.qty-btn:hover:not(:disabled) {
    background: var(--adp-cream);
}
.qty-btn:disabled {
    opacity: .4;
}
.qty-input {
    width: 3rem;
    border: none;
    outline: none;
    text-align: center;
    font-weight: 600;
    font-size: 1rem;
    color: var(--adp-text);
    background: transparent;
    -moz-appearance: textfield;
    appearance: textfield;
}

/* ── Récap labels ──────────────────────────────────────────────── */
.recap-label {
    color: var(--adp-brown);
    font-size: .9rem;
}

/* ── Livraison progress bar bg ─────────────────────────────────── */
.progress-delivery {
    height: 4px;
    background: rgba(180, 83, 9, .12);
}

/* ── Info livraison ────────────────────────────────────────────── */
.delivery-info {
    color: var(--adp-brown);
    background-color: rgba(255, 255, 255, .5);
}

/* ── Border HR récap ───────────────────────────────────────────── */
.hr-amber {
    border-color: var(--adp-border-amber);
}

/* ── Footer payment badge ──────────────────────────────────────── */
.footer-payment-badge {
    background: rgba(255, 251, 235, .06);
    border: 1px solid rgba(255, 251, 235, .1);
}

/* ── Navbar logo ───────────────────────────────────────────────── */
.navbar-brand-adp {
    font-size: 1.625rem;
    font-style: italic;
    font-weight: 700;
    letter-spacing: -.01em;
}

/* ── Search bar input (navbar) ─────────────────────────────────── */
.search-input {
    font-size: .875rem;
    border-radius: var(--adp-radius-pill) 0 0 var(--adp-radius-pill) !important;
    border-right: none;
}
.search-btn {
    border-radius: 0 var(--adp-radius-pill) var(--adp-radius-pill) 0 !important;
    border-color: rgba(180, 83, 9, .25);
    color: var(--adp-brown);
}

/* ── Newsletter email input ────────────────────────────────────── */
.newsletter-email {
    border-radius: var(--adp-radius-pill) !important;
    color: #fff;
}

/* ── Newsletter heading ────────────────────────────────────────── */
.newsletter-heading {
    font-size: 2rem;
    font-style: italic;
}

/* ── Engagement icon large (empty state) ───────────────────────── */
.engagement-icon-lg {
    width: 5rem;
    height: 5rem;
}

/* ── Footer branding ───────────────────────────────────────────── */
.footer-brand {
    font-style: italic;
    color: #fff;
}
.footer-accent-bar {
    width: 32px;
    height: 2px;
    background: var(--adp-amber);
    border-radius: 2px;
}
