/* =============================================
   Délices Sucrés — Feuille de style principale
   ============================================= */

/* Reset & Variables */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
    --brown:    #6B3F1E;
    --brown-lt: #9B6343;
    --cream:    #FDF6EC;
    --gold:     #C8962E;
    --gold-lt:  #E8B84B;
    --dark:     #2D1B0E;
    --gray:     #6B7280;
    --light:    #F9F5F0;
    --white:    #FFFFFF;
    --radius:   12px;
    --shadow:   0 4px 24px rgba(107,63,30,0.12);
    --trans:    0.25s ease;
    --font-head:'Playfair Display', serif;
    --font-body:'Lato', sans-serif;
}
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); color: var(--dark); background: var(--cream); line-height: 1.65; }
img  { max-width: 100%; display: block; }
a    { color: inherit; text-decoration: none; }
ul   { list-style: none; }

/* Container */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }

/* ---- HEADER ---- */
.site-header { position: sticky; top: 0; z-index: 100; background: var(--white); box-shadow: 0 2px 12px rgba(0,0,0,.08); }
.header-top  { background: var(--brown); color: var(--cream); font-size: .82rem; padding: .35rem 0; }
.header-top .container { display: flex; gap: 2rem; }
.header-top span { display: flex; align-items: center; gap: .4rem; }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: .9rem 1.5rem; gap: 1rem; }

.logo { display: flex; align-items: center; gap: .75rem; }
.logo-icon      { font-size: 2rem; }
.logo-name      { display: block; font-family: var(--font-head); font-size: 1.4rem; font-weight: 700; color: var(--brown); }
.logo-tagline   { display: block; font-size: .72rem; color: var(--gray); letter-spacing: .08em; text-transform: uppercase; }

.main-nav ul       { display: flex; gap: .25rem; position: relative; }
.main-nav > ul > li{ position: relative; }
.main-nav a        { padding: .55rem 1rem; border-radius: 6px; font-weight: 600; font-size: .9rem; color: var(--dark); transition: var(--trans); }
.main-nav a:hover  { background: var(--cream); color: var(--brown); }
.dropdown          { display: none; position: absolute; top: 100%; left: 0; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); min-width: 180px; padding: .5rem 0; z-index: 200; }
.dropdown li a     { display: block; padding: .5rem 1.2rem; font-weight: 400; border-radius: 0; }
.main-nav > ul > li:hover .dropdown { display: block; }

.header-actions { display: flex; align-items: center; gap: .75rem; }
.cart-btn       { position: relative; background: var(--brown); color: var(--white); border: none; padding: .6rem 1rem; border-radius: 8px; cursor: pointer; font-size: 1.1rem; display: flex; align-items: center; gap: .5rem; }
.cart-count     { background: var(--gold); color: var(--dark); font-size: .72rem; font-weight: 700; border-radius: 50%; width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; }
.nav-toggle     { display: none; background: none; border: 2px solid var(--brown); padding: .4rem .65rem; border-radius: 6px; cursor: pointer; font-size: 1.1rem; color: var(--brown); }

/* Toast */
.cart-toast { position: fixed; bottom: 2rem; right: 2rem; background: var(--brown); color: var(--white); padding: 1rem 1.5rem; border-radius: var(--radius); z-index: 9999; box-shadow: var(--shadow); display: flex; align-items: center; gap: .6rem; transition: opacity .3s; }
.cart-toast.hidden { opacity: 0; pointer-events: none; }

/* ---- HERO ---- */
.hero { background: linear-gradient(135deg, var(--brown) 0%, var(--dark) 100%); color: var(--white); padding: 5rem 2rem; display: flex; align-items: center; justify-content: center; min-height: 90vh; text-align: center; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 70% 50%, rgba(200,150,46,.2) 0%, transparent 60%); }
.hero-content { position: relative; max-width: 680px; }
.hero-sub  { color: var(--gold-lt); font-size: .9rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1rem; }
.hero h1   { font-family: var(--font-head); font-size: clamp(2.2rem, 5vw, 4rem); line-height: 1.15; margin-bottom: 1.2rem; }
.hero h1 span { color: var(--gold-lt); }
.hero-desc { font-size: 1.1rem; color: rgba(255,255,255,.8); margin-bottom: 2.5rem; max-width: 500px; margin-left: auto; margin-right: auto; }
.hero-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.hero-badge { position: absolute; top: 2rem; right: 2rem; background: var(--gold); color: var(--dark); border-radius: 50%; width: 90px; height: 90px; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; }
.hero-image { display: none; }

/* ---- BUTTONS ---- */
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .85rem 2rem; border-radius: 8px; font-weight: 700; font-size: .9rem; border: 2px solid transparent; cursor: pointer; transition: var(--trans); }
.btn-primary { background: var(--gold); color: var(--dark); }
.btn-primary:hover { background: var(--gold-lt); transform: translateY(-2px); }
.btn-outline { border-color: rgba(255,255,255,.5); color: var(--white); }
.btn-outline:hover { background: rgba(255,255,255,.1); }
.btn-full { width: 100%; justify-content: center; }

/* ---- SECTIONS ---- */
.section { padding: 5rem 0; }
.section-header { text-align: center; margin-bottom: 3rem; }
.section-header h2 { font-family: var(--font-head); font-size: clamp(1.8rem, 3vw, 2.5rem); color: var(--brown); margin-bottom: .5rem; }
.section-header p  { color: var(--gray); font-size: 1.05rem; }
.section-footer    { text-align: center; margin-top: 3rem; }

/* ---- CATEGORIES ---- */
.categories-section { background: var(--light); }
.categories-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1.5rem; }
.category-card { background: var(--white); padding: 1.75rem 1rem; border-radius: var(--radius); text-align: center; transition: var(--trans); box-shadow: 0 2px 12px rgba(0,0,0,.06); }
.category-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.cat-icon  { font-size: 2.5rem; margin-bottom: .75rem; }
.category-card h3 { font-family: var(--font-head); font-size: 1.05rem; color: var(--brown); margin-bottom: .4rem; }
.category-card p  { font-size: .82rem; color: var(--gray); }

/* ---- PRODUCTS GRID ---- */
.products-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.75rem; }
.product-card  { background: var(--white); border-radius: var(--radius); overflow: hidden; box-shadow: 0 2px 12px rgba(0,0,0,.06); transition: var(--trans); }
.product-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.product-img   { position: relative; height: 200px; overflow: hidden; background: var(--light); }
.product-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.product-card:hover .product-img img { transform: scale(1.05); }
.product-placeholder { height: 100%; display: flex; align-items: center; justify-content: center; font-size: 4rem; }
.badge-featured { position: absolute; top: .75rem; left: .75rem; background: var(--gold); color: var(--dark); font-size: .7rem; font-weight: 700; padding: .2rem .6rem; border-radius: 20px; text-transform: uppercase; }
.product-info  { padding: 1.25rem; }
.product-cat   { font-size: .75rem; color: var(--brown); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.product-info h3 { font-family: var(--font-head); font-size: 1.05rem; margin: .3rem 0; }
.product-info p  { font-size: .85rem; color: var(--gray); margin-bottom: .75rem; }
.product-footer  { display: flex; align-items: center; justify-content: space-between; }
.product-price   { font-weight: 700; font-size: 1rem; color: var(--brown); }
.btn-add-cart    { background: var(--brown); color: var(--white); border: none; width: 38px; height: 38px; border-radius: 50%; cursor: pointer; font-size: 1rem; transition: var(--trans); display: flex; align-items: center; justify-content: center; }
.btn-add-cart:hover { background: var(--gold); color: var(--dark); }

/* ---- ABOUT ---- */
.about-section { background: var(--dark); color: var(--white); }
.about-grid    { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.label-tag     { background: var(--gold); color: var(--dark); padding: .25rem .8rem; border-radius: 20px; font-size: .8rem; font-weight: 700; text-transform: uppercase; }
.about-text h2 { font-family: var(--font-head); font-size: clamp(1.6rem, 2.5vw, 2.2rem); margin: 1rem 0; }
.about-text p  { color: rgba(255,255,255,.75); margin-bottom: 1.5rem; }
.about-list li { display: flex; align-items: center; gap: .6rem; margin-bottom: .6rem; }
.about-list i  { color: var(--gold); }
.about-stats   { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.stat-card     { background: rgba(255,255,255,.07); padding: 1.5rem; border-radius: var(--radius); text-align: center; border: 1px solid rgba(255,255,255,.1); }
.stat-card span { font-family: var(--font-head); font-size: 2.2rem; color: var(--gold-lt); display: block; }
.stat-card p   { font-size: .85rem; color: rgba(255,255,255,.7); }

/* ---- CONTACT ---- */
.contact-section { background: var(--light); }
.contact-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
.contact-item  { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; }
.contact-item i{ color: var(--brown); font-size: 1.2rem; margin-top: .2rem; }
.contact-item h4 { font-weight: 700; margin-bottom: .2rem; }
.contact-form  { background: var(--white); padding: 2rem; border-radius: var(--radius); box-shadow: 0 2px 16px rgba(0,0,0,.06); }
.contact-form input,
.contact-form textarea { width: 100%; border: 2px solid #E5E7EB; border-radius: 8px; padding: .75rem 1rem; font-family: var(--font-body); font-size: .95rem; transition: var(--trans); margin-bottom: 1rem; background: var(--cream); }
.contact-form input:focus,
.contact-form textarea:focus { outline: none; border-color: var(--brown); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* ---- PAGE BANNER ---- */
.page-banner { background: linear-gradient(135deg, var(--brown), var(--dark)); color: var(--white); padding: 3.5rem 0; text-align: center; }
.page-banner h1 { font-family: var(--font-head); font-size: 2.5rem; }
.page-banner p  { color: rgba(255,255,255,.7); margin-top: .4rem; }

/* ---- BOUTIQUE ---- */
.boutique-layout { display: grid; grid-template-columns: 260px 1fr; gap: 2.5rem; align-items: start; }
.boutique-sidebar { position: sticky; top: 90px; }
.filter-box { background: var(--white); border-radius: var(--radius); padding: 1.5rem; margin-bottom: 1.5rem; box-shadow: 0 2px 12px rgba(0,0,0,.06); }
.filter-box h3 { font-family: var(--font-head); font-size: 1.05rem; color: var(--brown); margin-bottom: 1rem; }
.filter-list li { border-bottom: 1px solid var(--light); }
.filter-list a  { display: flex; justify-content: space-between; padding: .6rem .3rem; font-size: .9rem; color: var(--dark); transition: var(--trans); }
.filter-list a:hover, .filter-list a.active { color: var(--brown); font-weight: 700; }
.filter-list a span { background: var(--light); border-radius: 12px; padding: .1rem .5rem; font-size: .75rem; }
.search-input { display: flex; gap: .5rem; }
.search-input input { flex: 1; border: 2px solid #E5E7EB; border-radius: 8px; padding: .6rem .9rem; font-size: .9rem; }
.search-input button { background: var(--brown); color: var(--white); border: none; border-radius: 8px; padding: .6rem .9rem; cursor: pointer; }
.boutique-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.5rem; }
.boutique-header p { color: var(--gray); }
.boutique-header select { border: 2px solid #E5E7EB; border-radius: 8px; padding: .5rem .9rem; font-size: .9rem; cursor: pointer; }

/* ---- PANIER ---- */
.panier-layout  { display: grid; grid-template-columns: 1fr 380px; gap: 2.5rem; align-items: start; }
.panier-items h2 { font-family: var(--font-head); font-size: 1.5rem; color: var(--brown); margin-bottom: 1.5rem; }
.cart-item      { background: var(--white); border-radius: var(--radius); padding: 1.25rem; margin-bottom: 1rem; display: flex; justify-content: space-between; align-items: center; box-shadow: 0 2px 8px rgba(0,0,0,.05); }
.cart-item-info { display: flex; align-items: center; gap: 1rem; }
.cart-item-emoji { font-size: 2rem; }
.cart-item-info strong { display: block; font-weight: 700; }
.cart-item-info small  { color: var(--gray); font-size: .82rem; }
.cart-item-controls { display: flex; align-items: center; gap: .5rem; }
.cart-item-controls button { background: var(--light); border: none; width: 30px; height: 30px; border-radius: 50%; cursor: pointer; font-size: .9rem; display: flex; align-items: center; justify-content: center; }
.cart-item-controls span { min-width: 24px; text-align: center; font-weight: 700; }
.item-total { color: var(--brown); font-weight: 700; min-width: 100px; text-align: right; }
.remove-btn  { background: #FEE2E2 !important; color: #DC2626; }
.panier-summary { background: var(--white); border-radius: var(--radius); padding: 1.75rem; box-shadow: 0 2px 16px rgba(0,0,0,.08); position: sticky; top: 90px; }
.panier-summary h2 { font-family: var(--font-head); font-size: 1.4rem; color: var(--brown); margin-bottom: 1.5rem; }
.summary-lines { border-top: 2px solid var(--light); border-bottom: 2px solid var(--light); padding: 1rem 0; margin-bottom: 1.5rem; }
.summary-line  { display: flex; justify-content: space-between; padding: .4rem 0; font-size: .9rem; color: var(--gray); }
.summary-line.total { font-weight: 700; font-size: 1.1rem; color: var(--dark); margin-top: .5rem; padding-top: .75rem; border-top: 1px solid var(--light); }
.panier-summary h3 { margin-bottom: 1rem; font-size: 1rem; }
.panier-summary .form-group { margin-bottom: .75rem; }
.panier-summary input,
.panier-summary textarea { width: 100%; border: 2px solid #E5E7EB; border-radius: 8px; padding: .65rem .9rem; font-size: .88rem; font-family: var(--font-body); transition: var(--trans); }
.panier-summary input:focus,
.panier-summary textarea:focus { outline: none; border-color: var(--brown); }

/* ---- FOOTER ---- */
.site-footer   { background: var(--dark); color: rgba(255,255,255,.8); padding: 4rem 0 0; }
.footer-grid   { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 3rem; }
.footer-logo   { font-family: var(--font-head); font-size: 1.5rem; color: var(--gold-lt); margin-bottom: 1rem; }
.footer-brand p { font-size: .88rem; margin-bottom: 1.5rem; line-height: 1.7; }
.social-links a { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; background: rgba(255,255,255,.1); border-radius: 50%; margin-right: .4rem; transition: var(--trans); }
.social-links a:hover { background: var(--gold); color: var(--dark); }
.footer-links h4,
.footer-contact h4 { color: var(--white); font-size: 1rem; margin-bottom: 1rem; }
.footer-links ul li, .footer-contact p { padding: .35rem 0; font-size: .88rem; }
.footer-links a:hover { color: var(--gold-lt); }
.footer-contact i { color: var(--gold); margin-right: .5rem; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 3rem; padding: 1.25rem 0; text-align: center; font-size: .82rem; color: rgba(255,255,255,.5); }

/* ---- ALERTS ---- */
.alert { padding: 1rem 1.25rem; border-radius: 8px; margin-bottom: 1.5rem; display: flex; align-items: center; gap: .6rem; }
.alert-success { background: #DCFCE7; color: #166534; }
.alert-error   { background: #FEE2E2; color: #991B1B; }

/* ---- EMPTY STATE ---- */
.empty-state, .empty-cart { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 3rem; gap: 1rem; }
.empty-state span, .empty-cart span { font-size: 3.5rem; }
.empty-state h3, .empty-cart h3 { font-family: var(--font-head); color: var(--brown); }
.empty-state p  { color: var(--gray); }

/* ---- RESPONSIVE ---- */
@media (max-width: 1024px) {
    .about-grid, .contact-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .boutique-layout { grid-template-columns: 1fr; }
    .boutique-sidebar { position: static; }
    .panier-layout { grid-template-columns: 1fr; }
}
/* ---- ADMIN ACCESS LINK ---- */
.admin-access {
    text-align: center;
    padding: .75rem;
    background: var(--dark);
    border-top: 1px solid rgba(255,255,255,.05);
}
.admin-access a {
    color: rgba(255,255,255,.3);
    font-size: .78rem;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    transition: var(--trans);
}
.admin-access a:hover { color: var(--gold); }
    .main-nav, .header-top { display: none; }
    .main-nav.open { display: block; position: absolute; top: 100%; left: 0; right: 0; background: var(--white); box-shadow: var(--shadow); padding: 1rem; }
    .main-nav.open ul { flex-direction: column; }
    .nav-toggle  { display: block; }
    .hero { min-height: 70vh; padding: 4rem 1.5rem; }
    .form-row    { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
    .products-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}

/* ---- PAIEMENT OPTIONS ---- */
.paiement-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;}
.paiement-option{cursor:pointer;}
.paiement-option input[type="radio"]{display:none;}
.paiement-card{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;border:2px solid #E5E7EB;border-radius:10px;transition:var(--trans);background:var(--cream);}
.paiement-option:hover .paiement-card,
.paiement-option.selected .paiement-card{border-color:var(--brown);background:#FDF0E0;}
.paiement-icon{font-size:1.8rem;}
.paiement-card strong{display:block;font-weight:700;font-size:.92rem;}
.paiement-card small{color:var(--gray);font-size:.78rem;}
.momo-info{background:#FEF3C7;border:1px solid #F59E0B;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;display:flex;gap:.6rem;align-items:flex-start;margin-bottom:1rem;}
.momo-info i{color:#D97706;margin-top:.1rem;}
.alert-momo{background:#ECFDF5;border:1px solid #6EE7B7;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;align-items:flex-start;gap:.6rem;color:#065F46;}
.admin-access{text-align:center;padding:.75rem;background:var(--dark);border-top:1px solid rgba(255,255,255,.05);}
.admin-access a{color:rgba(255,255,255,.3);font-size:.78rem;display:inline-flex;align-items:center;gap:.4rem;transition:var(--trans);}
.admin-access a:hover{color:var(--gold);}

/* FedaPay zone */
.fedapay-zone { max-width:600px;margin:2rem auto;background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 24px rgba(107,63,30,.12); }
.fedapay-header { text-align:center;margin-bottom:1.5rem; }
.fedapay-logo   { font-size:1.1rem;font-weight:700;color:#1E40AF;margin-bottom:.5rem; }
.fedapay-info   { text-align:center;color:var(--gray);font-size:.82rem;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem; }
.fedapay-note   { background:#EFF6FF;border:1px solid #BFDBFE;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;color:#1E40AF;margin-top:.75rem;display:flex;align-items:flex-start;gap:.6rem; }
.btn-outline-brown { display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.5rem;border:2px solid var(--brown);color:var(--brown);border-radius:8px;font-weight:700;font-size:.9rem;cursor:pointer;background:transparent;transition:var(--trans);font-family:var(--font-body); }
.btn-outline-brown:hover { background:var(--brown);color:#fff; }
