/* ============================================================
   RELIABLE — Feuille de style principale
   Design moderne, premium, mobile-first
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
    --primary:       #6a11cb;
    --secondary:     #2575fc;
    --grad:          linear-gradient(135deg, var(--primary), var(--secondary));
    --grad-rev:      linear-gradient(135deg, var(--secondary), var(--primary));
    --accent:        #f72585;
    --success:       #10b981;
    --warning:       #f59e0b;
    --danger:        #ef4444;
    --info:          #3b82f6;

    --bg:            #f0f2f8;
    --surface:       #ffffff;
    --surface-2:     #f8f9ff;
    --border:        #e5e7f0;
    --text:          #1a1a2e;
    --text-2:        #4a4a6a;
    --text-3:        #8888aa;

    --radius:        14px;
    --radius-sm:     8px;
    --radius-xl:     24px;
    --shadow:        0 4px 20px rgba(106,17,203,.08);
    --shadow-md:     0 8px 32px rgba(106,17,203,.14);
    --shadow-lg:     0 16px 48px rgba(106,17,203,.20);
    --transition:    all .3s cubic-bezier(.4,0,.2,1);

    --header-h:      68px;
}

.dark-mode {
    --bg:        #0f0f1a;
    --surface:   #1a1a2e;
    --surface-2: #16213e;
    --border:    #2a2a45;
    --text:      #e8e8ff;
    --text-2:    #a0a0c0;
    --text-3:    #606080;
    --shadow:    0 4px 20px rgba(0,0,0,.3);
    --shadow-md: 0 8px 32px rgba(0,0,0,.4);
}

/* ── Reset & Base ──────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }

body {
    font-family: 'Poppins', sans-serif !important;
    background: var(--bg);
    color: var(--text);
    overflow-x: hidden;
    transition: background .3s, color .3s;
    -webkit-tap-highlight-color: transparent;
}
img { max-width:100%; display:block; }
a  { text-decoration:none; color:inherit; }
button { cursor:pointer; font-family:inherit; border:none; outline:none; }

/* ── Loading Screen ────────────────────────────────────────── */
#loading-screen {
    position:fixed; inset:0; z-index:9999;
    background: var(--surface);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    transition: opacity .5s;
}
.loading-logo {
    width:100px; height:100px; border-radius:50%;
    object-fit:cover;
    animation: loadingPulse 1.6s ease-in-out infinite;
    box-shadow: 0 0 0 0 rgba(106,17,203,.5);
}
@keyframes loadingPulse {
    0%,100% { box-shadow:0 0 0 0 rgba(106,17,203,.4); }
    50%      { box-shadow:0 0 0 20px rgba(106,17,203,0); }
}
.loading-text {
    margin-top:1.2rem; font-size:1.5rem; font-weight:700;
    background: var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.loading-bar {
    margin-top:1.5rem; width:120px; height:3px;
    background: var(--border); border-radius:2px; overflow:hidden;
}
.loading-bar::after {
    content:''; display:block; height:100%;
    background: var(--grad);
    animation: loadBar 1.5s ease-in-out infinite;
}
@keyframes loadBar { 0%{width:0%} 60%{width:100%} 100%{width:100%;opacity:0} }

/* ── Offline Screen ─────────────────────────────────────────── */
#offline-screen {
    position:fixed; inset:0; z-index:9998;
    background:var(--surface);
    display:none; flex-direction:column;
    align-items:center; justify-content:center;
    text-align:center; padding:2rem;
}
#offline-screen .offline-icon { font-size:4rem; color:var(--text-3); margin-bottom:1rem; }
.retry-btn {
    padding:.8rem 2.5rem; margin-top:1.5rem;
    background:var(--grad); color:#fff;
    border-radius:50px; font-size:1rem; font-weight:600;
    transition:var(--transition);
}
.retry-btn:hover { opacity:.9; transform:translateY(-2px); }

/* ── Header ─────────────────────────────────────────────────── */
header {
    height:var(--header-h);
    display:flex; align-items:center; gap:.8rem;
    padding:0 1.2rem;
    background:var(--surface);
    box-shadow:var(--shadow);
    position:sticky; top:0; z-index:100;
    border-bottom:1px solid var(--border);
}
.logo { width:44px; height:44px; border-radius:50%; object-fit:cover; }
.logo-link { display:flex; align-items:center; margin-right:auto; }

.theme-toggle, .vehicle-filter-btn, .menu-toggle {
    width:40px; height:40px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    background:var(--surface-2); color:var(--text-2);
    border:1px solid var(--border); transition:var(--transition);
    flex-shrink:0;
}
.theme-toggle:hover, .vehicle-filter-btn:hover, .menu-toggle:hover {
    background:var(--grad); color:#fff; border-color:transparent;
}

.location-filter {
    display:flex; align-items:center; gap:.5rem;
    background:var(--surface-2); border:1px solid var(--border);
    border-radius:50px; padding:.4rem .8rem;
    color:var(--text-2); font-size:.85rem;
}
.location-filter select {
    background:none; border:none; outline:none;
    color:var(--text); font-family:inherit; font-size:.85rem;
    cursor:pointer;
}

.vehicle-filter-menu {
    position:absolute; top:calc(var(--header-h) + .5rem); right:4.5rem;
    background:var(--surface);
    border:1px solid var(--border); border-radius:var(--radius);
    box-shadow:var(--shadow-md);
    padding:.5rem; display:none; z-index:200; min-width:140px;
}
.vehicle-filter-menu.active { display:block; }
.vehicle-filter-option {
    display:flex; align-items:center; gap:.7rem;
    padding:.7rem 1rem; border-radius:var(--radius-sm);
    cursor:pointer; color:var(--text-2); font-size:.9rem;
    transition:var(--transition);
}
.vehicle-filter-option:hover, .vehicle-filter-option.active {
    background:rgba(106,17,203,.08); color:var(--primary);
}

/* ── Nav Menu ───────────────────────────────────────────────── */
.nav-menu {
    position:fixed; top:0; right:-320px; width:300px; height:100vh;
    background:var(--surface);
    box-shadow:-4px 0 32px rgba(0,0,0,.15);
    z-index:300; transition:right .35s cubic-bezier(.4,0,.2,1);
    padding:2rem 1.5rem; overflow-y:auto;
}
.nav-menu.active { right:0; }
.nav-menu ul { list-style:none; padding-top:2rem; }
.nav-menu ul li { margin-bottom:.3rem; }
.nav-menu ul li a {
    display:flex; align-items:center; gap:.8rem;
    padding:.9rem 1rem; border-radius:var(--radius-sm);
    color:var(--text-2); font-weight:500; transition:var(--transition);
}
.nav-menu ul li a:hover { background:rgba(106,17,203,.06); color:var(--primary); }

.overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.5);
    z-index:299; display:none; backdrop-filter:blur(2px);
}
.overlay.active { display:block; }

/* Invite friends */
.invite-friends {
    display:flex; align-items:center; gap:.7rem;
    padding:.9rem 1rem; border-radius:var(--radius-sm);
    cursor:pointer; color:var(--text-2); font-weight:500;
    transition:var(--transition); position:relative;
}
.invite-friends:hover { background:rgba(106,17,203,.06); color:var(--primary); }
.invite-menu {
    position:absolute; left:0; top:calc(100% + .5rem);
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); box-shadow:var(--shadow-md);
    padding:.5rem; min-width:180px; display:none; z-index:400;
}
.invite-menu.active { display:block; }
.invite-option {
    display:flex; align-items:center; gap:.8rem;
    padding:.7rem 1rem; border-radius:var(--radius-sm);
    cursor:pointer; font-size:.9rem; color:var(--text-2);
    transition:var(--transition);
}
.invite-option:hover { background:var(--surface-2); color:var(--text); }

/* ── Sections / Pages ──────────────────────────────────────── */
.page { display:none; min-height:calc(100vh - var(--header-h)); }
.page.active { display:block; }

/* ── Banner ─────────────────────────────────────────────────── */
.banner {
    background:var(--grad);
    padding:3rem 1.5rem; text-align:center; color:#fff;
    position:relative; overflow:hidden;
}
.banner::before {
    content:''; position:absolute; inset:0;
    background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.banner-logo img {
    width:90px; height:90px; border-radius:50%; object-fit:cover;
    border:3px solid rgba(255,255,255,.4); margin:0 auto 1.2rem;
    box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.banner h1 { font-size:1.8rem; font-weight:700; margin-bottom:.5rem; }
.banner h1 span { opacity:.85; }
.banner p { opacity:.85; font-size:1rem; max-width:460px; margin:0 auto; }

/* ── Search Bar ─────────────────────────────────────────────── */
.search-bar { padding:1.2rem 1rem; background:var(--surface); border-bottom:1px solid var(--border); }
.search-container {
    display:flex; max-width:600px; margin:0 auto;
    background:var(--surface-2); border:2px solid var(--border);
    border-radius:50px; overflow:hidden; transition:var(--transition);
}
.search-container:focus-within { border-color:var(--primary); box-shadow:0 0 0 3px rgba(106,17,203,.1); }
.search-container input {
    flex:1; padding:.75rem 1.2rem; background:none; border:none; outline:none;
    font-family:inherit; font-size:.95rem; color:var(--text);
}
.search-container button {
    padding:.75rem 1.4rem; background:var(--grad); color:#fff;
    transition:var(--transition);
}
.search-container button:hover { opacity:.9; }

/* ── Scrolling Text ─────────────────────────────────────────── */
.scrolling-text {
    background:linear-gradient(135deg, var(--primary), var(--accent));
    overflow:hidden; padding:.55rem 0;
}
.scrolling-text p {
    white-space:nowrap; color:#fff; font-size:.85rem; font-weight:500;
    animation: scrollText 22s linear infinite;
    padding-left:100%;
}
@keyframes scrollText { from{transform:translateX(0)} to{transform:translateX(-100%)} }

/* ── Filters ─────────────────────────────────────────────────── */
.filters {
    padding:1.5rem 1rem .5rem;
    display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:.8rem;
}
.filters h2 { font-size:1.2rem; font-weight:700; color:var(--text); }
.filter-buttons { display:flex; gap:.5rem; flex-wrap:wrap; }
.filter-btn {
    padding:.45rem 1.2rem; border-radius:50px; font-size:.85rem; font-weight:500;
    background:var(--surface); border:2px solid var(--border); color:var(--text-2);
    transition:var(--transition);
}
.filter-btn.active, .filter-btn:hover {
    background:var(--grad); color:#fff; border-color:transparent;
}

/* ── Delivery Grid ───────────────────────────────────────────── */
.delivery-grid, .top-delivery-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap:1.2rem; padding:1rem 1rem 2rem;
}

/* ── Delivery Card ───────────────────────────────────────────── */
.delivery-card {
    background:var(--surface); border-radius:var(--radius);
    box-shadow:var(--shadow); overflow:hidden;
    transition:var(--transition); border:1px solid var(--border);
}
.delivery-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }

.delivery-card.perfect-rating {
    border-color:rgba(106,17,203,.3);
    box-shadow:0 4px 20px rgba(106,17,203,.12);
}
.delivery-card.warning-rating {
    border-color:rgba(239,68,68,.25);
    box-shadow:0 4px 16px rgba(239,68,68,.1);
}

.delivery-img-container {
    position:relative; aspect-ratio:4/3; overflow:hidden;
    background:var(--surface-2);
}
.delivery-img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .4s ease;
}
.delivery-card:hover .delivery-img { transform:scale(1.05); }

.vehicle-badge {
    position:absolute; bottom:.7rem; left:.7rem;
    width:34px; height:34px; border-radius:50%;
    background:var(--grad); color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:.8rem; box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.share-btn {
    position:absolute; top:.7rem; right:.7rem;
    width:34px; height:34px; border-radius:50%;
    background:rgba(255,255,255,.9); color:var(--text-2);
    display:flex; align-items:center; justify-content:center;
    font-size:.8rem; transition:var(--transition);
    box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.share-btn:hover { background:var(--grad); color:#fff; }
.share-menu {
    position:absolute; top:3.2rem; right:.7rem;
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-sm); box-shadow:var(--shadow-md);
    padding:.4rem; min-width:150px; z-index:10;
    display:none; animation:fadeIn .2s ease;
}
.share-menu.open { display:block; }
@keyframes fadeIn { from{opacity:0;transform:scale(.95)} to{opacity:1;transform:scale(1)} }
.share-option {
    display:flex; align-items:center; gap:.7rem;
    padding:.6rem .8rem; border-radius:var(--radius-sm);
    cursor:pointer; font-size:.85rem; color:var(--text-2);
    transition:var(--transition);
}
.share-option:hover { background:var(--surface-2); color:var(--text); }

.delivery-info { padding:1rem 1.1rem 1.1rem; }
.delivery-name-row {
    display:flex; align-items:center; gap:.5rem; margin-bottom:.6rem;
    flex-wrap:wrap;
}
.delivery-name-row h3 {
    font-size:1rem; font-weight:700; color:var(--text); flex:1;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.certification-badge {
    width:22px; height:22px; border-radius:50%;
    background:var(--grad); color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:.6rem; flex-shrink:0;
}
.edit-btn {
    width:26px; height:26px; border-radius:50%;
    background:var(--surface-2); border:1px solid var(--border);
    color:var(--text-3); display:flex; align-items:center; justify-content:center;
    font-size:.75rem; transition:var(--transition);
}
.edit-btn:hover { background:var(--info); color:#fff; border-color:transparent; }

.delivery-details {
    display:flex; flex-direction:column; gap:.25rem; margin-bottom:.7rem;
}
.detail-item {
    display:flex; align-items:center; gap:.5rem;
    font-size:.82rem; color:var(--text-2);
}
.detail-item i { color:var(--primary); width:14px; text-align:center; }

.rating-stars { display:flex; gap:.15rem; margin:.5rem 0; }
.star { font-size:.85rem; color:#d1d5db; transition:color .2s; }
.star.active { color:#f59e0b; }

.contact-buttons { display:flex; gap:.6rem; margin-top:.7rem; }
.contact-btn {
    flex:1; padding:.6rem; border-radius:var(--radius-sm);
    display:flex; align-items:center; justify-content:center;
    font-size:1rem; transition:var(--transition);
    border:1.5px solid var(--border); color:var(--text-2);
}
.contact-btn.whatsapp-btn { color:#25D366; border-color:rgba(37,211,102,.3); }
.contact-btn.whatsapp-btn:hover { background:#25D366; color:#fff; border-color:#25D366; }
.contact-btn.phone-btn:hover { background:var(--grad); color:#fff; border-color:transparent; }

.rate-btn {
    width:100%; padding:.65rem; margin-top:.7rem;
    background:var(--grad); color:#fff; border-radius:var(--radius-sm);
    font-size:.9rem; font-weight:600; transition:var(--transition);
    display:flex; align-items:center; justify-content:center; gap:.5rem;
}
.rate-btn:hover { opacity:.9; transform:translateY(-1px); }

.blocked-badge {
    display:inline-flex; align-items:center; gap:.4rem;
    padding:.3rem .7rem; border-radius:50px; font-size:.78rem; font-weight:600;
    background:rgba(239,68,68,.1); color:var(--danger);
}
.countdown {
    display:inline-flex; align-items:center; gap:.4rem;
    padding:.3rem .7rem; border-radius:50px; font-size:.78rem; font-weight:600;
    background:rgba(245,158,11,.1); color:var(--warning);
}

/* ── TOP Section ─────────────────────────────────────────────── */
.top-section { padding-bottom:3rem; }
.top-section h2 {
    text-align:center; font-size:2rem; font-weight:800; padding:2rem 1rem 0;
    background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.top-delivery-card {
    position:relative;
    background: linear-gradient(135deg,rgba(106,17,203,.04),rgba(37,117,252,.04));
    border-color:rgba(106,17,203,.2) !important;
}
.top-crown {
    position:absolute; top:-.6rem; left:50%; transform:translateX(-50%);
    width:30px; height:30px; border-radius:50%;
    background:linear-gradient(135deg,#f59e0b,#f72585);
    color:#fff; display:flex; align-items:center; justify-content:center;
    font-size:.75rem; z-index:5; box-shadow:0 2px 8px rgba(247,37,133,.4);
}

/* ── Voir plus ──────────────────────────────────────────────── */
.see-more { text-align:center; padding:1.5rem; }
.see-more-btn {
    padding:.8rem 2.5rem; background:var(--grad); color:#fff;
    border-radius:50px; font-size:1rem; font-weight:600; transition:var(--transition);
}
.see-more-btn:hover { opacity:.9; transform:translateY(-2px); box-shadow:var(--shadow-md); }

/* ── Promo / Carousel ────────────────────────────────────────── */
.promo-section {
    padding:2.5rem 1rem; background:var(--surface);
    border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    text-align:center;
}
.promo-section h2 { font-size:1.4rem; font-weight:700; margin-bottom:.5rem; }
.promo-section > p { color:var(--text-2); margin-bottom:1.5rem; font-size:.95rem; }

.carousel { overflow:hidden; border-radius:var(--radius); max-width:700px; margin:0 auto; }
.carousel-inner {
    display:flex; transition:transform .5s ease;
}
.carousel-slide { min-width:100%; }
.carousel-slide img { width:100%; aspect-ratio:16/9; object-fit:cover; }
.carousel-indicators { display:flex; justify-content:center; gap:.5rem; margin-top:.8rem; }
.carousel-dot {
    width:8px; height:8px; border-radius:50%;
    background:var(--border); cursor:pointer; transition:var(--transition);
}
.carousel-dot.active { background:var(--primary); transform:scale(1.3); }

/* ── How It Works ────────────────────────────────────────────── */
.how-it-works {
    padding:3rem 1.2rem;
    background: linear-gradient(180deg, var(--bg) 0%, var(--surface) 100%);
}
.how-it-works h2 { font-size:1.5rem; font-weight:700; text-align:center; margin-bottom:2rem; }
.how-it-works h2 span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.steps { display:flex; flex-direction:column; gap:1.5rem; max-width:600px; margin:0 auto; }
.step {
    display:flex; gap:1rem; align-items:flex-start;
    background:var(--surface); padding:1.2rem; border-radius:var(--radius);
    box-shadow:var(--shadow); border:1px solid var(--border);
}
.step-icon {
    width:48px; height:48px; border-radius:50%; flex-shrink:0;
    background:var(--grad); color:#fff;
    display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.step-content h3 { font-size:.95rem; font-weight:600; margin-bottom:.3rem; }
.step-content p { font-size:.85rem; color:var(--text-2); line-height:1.5; }

/* ── Comments ────────────────────────────────────────────────── */
.comments-section { padding:2rem 1rem; }
.comments-section h2 { font-size:1.3rem; font-weight:700; margin-bottom:1.2rem; }
.comments-carousel {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
    gap:1rem;
}
.comment-card {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); padding:1.2rem; box-shadow:var(--shadow);
}
.comment-header {
    display:flex; justify-content:space-between; align-items:center; margin-bottom:.6rem;
}
.comment-author { font-weight:600; font-size:.9rem; color:var(--primary); }
.comment-stars { display:flex; gap:.1rem; }
.comment-text { font-size:.85rem; color:var(--text-2); line-height:1.5; margin-bottom:.6rem; }
.comment-date { font-size:.75rem; color:var(--text-3); }
.no-comments { text-align:center; color:var(--text-3); padding:2rem; }
.add-comment-btn {
    display:block; margin:1.5rem auto 0;
    padding:.7rem 2rem; background:var(--grad); color:#fff;
    border-radius:50px; font-size:.9rem; font-weight:600; transition:var(--transition);
}
.add-comment-btn:hover { opacity:.9; transform:translateY(-2px); }

/* ── Page Header (Ajouter / À propos / Note) ─────────────────── */
.page-header {
    display:flex; align-items:center; gap:1rem;
    padding:1.2rem; background:var(--surface);
    border-bottom:1px solid var(--border); position:sticky; top:var(--header-h); z-index:50;
}
.back-btn {
    width:38px; height:38px; border-radius:50%;
    background:var(--surface-2); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-2); transition:var(--transition);
}
.back-btn:hover { background:var(--grad); color:#fff; border-color:transparent; }
.page-title { font-size:1.2rem; font-weight:700; }

/* ── Forms ───────────────────────────────────────────────────── */
.add-form-container, .form-container {
    max-width:560px; margin:0 auto; padding:1.5rem 1.2rem 3rem;
}
.form-header { text-align:center; margin-bottom:2rem; padding:1.5rem; background:var(--surface); border-radius:var(--radius); }
.form-header h2 { font-size:1.4rem; font-weight:700; margin-bottom:.4rem; }
.form-header p { color:var(--text-2); font-size:.9rem; }

.form-group { margin-bottom:1.3rem; }
.form-group label { display:block; font-size:.85rem; font-weight:600; color:var(--text-2); margin-bottom:.5rem; }
.form-group input, .form-group select, .form-group textarea {
    width:100%; padding:.8rem 1rem;
    background:var(--surface); border:2px solid var(--border);
    border-radius:var(--radius-sm); font-family:inherit; font-size:.95rem;
    color:var(--text); outline:none; transition:var(--transition);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    border-color:var(--primary); box-shadow:0 0 0 3px rgba(106,17,203,.1);
}
.form-group textarea { resize:vertical; min-height:100px; }

.photo-upload { text-align:center; margin-bottom:1.5rem; }
.photo-preview-container { position:relative; display:inline-block; }
.photo-preview {
    width:100px; height:100px; border-radius:50%; object-fit:cover;
    border:3px solid var(--primary); box-shadow:var(--shadow-md);
}
.photo-upload-btn {
    position:absolute; bottom:4px; right:4px;
    width:32px; height:32px; border-radius:50%;
    background:var(--grad); color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:.8rem; box-shadow:0 2px 8px rgba(106,17,203,.4);
    transition:var(--transition);
}
.photo-upload-btn:hover { transform:scale(1.1); }

.submit-btn {
    width:100%; padding:.9rem; margin-top:1rem;
    background:var(--grad); color:#fff; border-radius:var(--radius-sm);
    font-size:1rem; font-weight:600; transition:var(--transition);
}
.submit-btn:hover { opacity:.9; transform:translateY(-2px); box-shadow:var(--shadow-md); }
.submit-btn:disabled { opacity:.6; cursor:not-allowed; transform:none; }

/* ── Footer ──────────────────────────────────────────────────── */
footer {
    text-align:center; padding:2rem; background:var(--surface);
    border-top:1px solid var(--border); color:var(--text-3); font-size:.85rem;
}

/* ── Modales ─────────────────────────────────────────────────── */
.modal {
    position:fixed; inset:0; z-index:500;
    background:rgba(0,0,0,.55); backdrop-filter:blur(4px);
    display:none; align-items:center; justify-content:center; padding:1rem;
}
.modal.active { display:flex; }
.modal-content {
    background:var(--surface); border-radius:var(--radius-xl);
    width:100%; max-width:480px; max-height:90vh; overflow-y:auto;
    box-shadow:var(--shadow-lg); animation:modalIn .3s ease;
}
@keyframes modalIn { from{opacity:0;transform:scale(.92)translateY(20px)} to{opacity:1;transform:none} }
.modal-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:1.5rem 1.5rem 0; border-bottom:1px solid var(--border); padding-bottom:1rem;
}
.modal-title { font-size:1.1rem; font-weight:700; }
.modal-close {
    width:32px; height:32px; border-radius:50%;
    background:var(--surface-2); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-2); transition:var(--transition);
}
.modal-close:hover { background:var(--danger); color:#fff; border-color:transparent; }
.modal-body { padding:1.5rem; }
.modal-footer {
    padding:1rem 1.5rem 1.5rem;
    display:flex; justify-content:flex-end; gap:.7rem; flex-wrap:wrap;
}

/* Rating/Comment modal */
.rating-form {
    background:var(--surface); border-radius:var(--radius-xl);
    padding:2rem; width:100%; max-width:440px; position:relative;
    box-shadow:var(--shadow-lg); animation:modalIn .3s ease;
}
.rating-form h3 { font-size:1.2rem; font-weight:700; margin-bottom:1.5rem; text-align:center; }
.close-modal {
    position:absolute; top:1rem; right:1rem;
    width:32px; height:32px; border-radius:50%;
    background:var(--surface-2); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-2); transition:var(--transition);
}
.close-modal:hover { background:var(--danger); color:#fff; }

.rating-stars-large {
    display:flex; justify-content:center; gap:.6rem; margin:1rem 0;
}
.star-large {
    font-size:1.8rem; color:#d1d5db; cursor:pointer;
    transition:color .15s, transform .15s;
}
.star-large:hover, .star-large.active { color:#f59e0b; transform:scale(1.2); }

.rating-submit-btn {
    width:100%; padding:.85rem; background:var(--grad); color:#fff;
    border-radius:var(--radius-sm); font-size:1rem; font-weight:600;
    transition:var(--transition); margin-top:1rem;
}
.rating-submit-btn:hover { opacity:.9; }
.rating-submit-btn:disabled { opacity:.6; cursor:not-allowed; }

/* ── Auth Modal (login inline sur index) ─────────────────────── */
.modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.7);
    backdrop-filter:blur(5px); display:none; justify-content:center;
    align-items:center; z-index:600; opacity:0; transition:opacity .3s;
}
.modal-overlay.active { display:flex; opacity:1; }
.auth-modal {
    background:var(--surface); border-radius:var(--radius-xl);
    padding:2.5rem; width:100%; max-width:420px;
    box-shadow:var(--shadow-lg); animation:modalIn .3s ease;
}
.auth-modal h2 { font-size:1.4rem; font-weight:700; margin-bottom:1.5rem; text-align:center; }
.scrolling-text-auth {
    background:var(--grad); color:#fff; font-weight:600;
    text-align:center; padding:.5rem; border-radius:var(--radius-sm);
    font-size:.9rem; margin-bottom:1.5rem;
}
.auth-btn {
    width:100%; padding:.85rem; background:var(--grad); color:#fff;
    border-radius:var(--radius-sm); font-size:1rem; font-weight:600;
    transition:var(--transition); margin-top:.5rem;
}
.auth-btn:hover { opacity:.9; transform:translateY(-1px); }

/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
    padding:.6rem 1.2rem; border-radius:var(--radius-sm);
    font-size:.9rem; font-weight:600; transition:var(--transition);
    display:inline-flex; align-items:center; gap:.4rem;
}
.btn-primary   { background:var(--grad);    color:#fff; }
.btn-secondary { background:var(--surface-2); border:1px solid var(--border); color:var(--text-2); }
.btn-danger    { background:var(--danger);   color:#fff; }
.btn-success   { background:var(--success);  color:#fff; }
.btn-warning   { background:var(--warning);  color:#fff; }
.btn:hover { opacity:.88; transform:translateY(-1px); }

/* ── Toast Notification ──────────────────────────────────────── */
.toast {
    position:fixed; bottom:2rem; left:50%; transform:translateX(-50%) translateY(80px);
    padding:.85rem 1.8rem; border-radius:50px; font-size:.9rem; font-weight:600;
    color:#fff; z-index:9000; opacity:0; transition:all .35s ease;
    box-shadow:var(--shadow-md); white-space:nowrap; pointer-events:none;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.success { background:var(--success); }
.toast.error   { background:var(--danger); }
.toast.info    { background:var(--info); }

/* ── Modification success banner ─────────────────────────────── */
.modification-success {
    position:fixed; top:calc(var(--header-h) + 1rem); left:50%;
    transform:translateX(-50%) translateY(-20px);
    background:var(--success); color:#fff; padding:.75rem 1.5rem;
    border-radius:50px; font-size:.9rem; font-weight:600;
    opacity:0; transition:all .35s ease; z-index:800; white-space:nowrap;
    display:flex; align-items:center; gap:.6rem;
}
.modification-success.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ── Loading cards placeholder ───────────────────────────────── */
.loading-cards {
    grid-column:1/-1; text-align:center; padding:3rem;
    color:var(--text-3); font-size:2rem;
    animation:spin .8s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }
.no-results {
    grid-column:1/-1; text-align:center; padding:3rem;
    color:var(--text-3); display:flex; align-items:center;
    justify-content:center; gap:.7rem; font-size:.95rem;
}

/* ── Admin Panel ─────────────────────────────────────────────── */
#admin-space { display:flex; flex-direction:column; min-height:100vh; }

.admin-header {
    height:var(--header-h); display:flex; align-items:center;
    justify-content:space-between; padding:0 1.2rem;
    background:var(--grad); color:#fff;
    position:sticky; top:0; z-index:200; box-shadow:var(--shadow-md);
}
.admin-name { font-weight:600; font-size:1rem; }
.logout-btn {
    width:38px; height:38px; border-radius:50%;
    background:rgba(255,255,255,.2); color:#fff;
    display:flex; align-items:center; justify-content:center;
    transition:var(--transition);
}
.logout-btn:hover { background:rgba(255,255,255,.3); transform:scale(1.05); }
.admin-menu-toggle {
    width:38px; height:38px; border-radius:50%;
    background:rgba(255,255,255,.15); color:#fff;
    display:flex; align-items:center; justify-content:center;
    transition:var(--transition);
}

.admin-sidebar {
    position:fixed; top:0; left:-300px; width:280px; height:100vh;
    background:var(--surface); z-index:300;
    transition:left .35s cubic-bezier(.4,0,.2,1);
    box-shadow:4px 0 24px rgba(0,0,0,.15); overflow-y:auto;
    display:flex; flex-direction:column;
}
.admin-sidebar.active { left:0; }

.admin-profile {
    padding:2rem 1.5rem; text-align:center;
    background:var(--grad);
}
.admin-profile.founder { background:linear-gradient(135deg,#1a1a2e,#16213e); }
.admin-profile-img {
    width:72px; height:72px; border-radius:50%; object-fit:cover;
    border:3px solid rgba(255,255,255,.5); margin:0 auto .8rem;
}
.admin-profile-name { color:#fff; font-weight:700; font-size:1rem; }
.admin-profile-role { color:rgba(255,255,255,.75); font-size:.8rem; margin-top:.2rem; }

.admin-nav { padding:1rem .8rem; flex:1; }
.admin-nav-item {
    display:flex; align-items:center; gap:.8rem;
    padding:.85rem 1rem; border-radius:var(--radius-sm);
    color:var(--text-2); font-weight:500; font-size:.9rem;
    transition:var(--transition); margin-bottom:.2rem;
}
.admin-nav-item:hover { background:rgba(106,17,203,.06); color:var(--primary); }
.admin-nav-item.active { background:var(--grad); color:#fff; }
.admin-nav-item i { width:18px; text-align:center; }

.admin-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.5);
    z-index:299; display:none; backdrop-filter:blur(2px);
}
.admin-overlay.active { display:block; }

.admin-content { flex:1; padding:1.5rem 1rem 3rem; background:var(--bg); }
.admin-section { display:none; }
.admin-section.active { display:block; }

.admin-section-header {
    display:flex; align-items:center; justify-content:space-between;
    flex-wrap:wrap; gap:.8rem; margin-bottom:1.5rem;
}
.admin-section-title { font-size:1.3rem; font-weight:700; }

/* Stats cards */
.admin-stats {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
    gap:1rem; margin-bottom:2rem;
}
.admin-stat-card {
    background:var(--surface); border-radius:var(--radius);
    padding:1.3rem; text-align:center; box-shadow:var(--shadow);
    border:1px solid var(--border); transition:var(--transition);
}
.admin-stat-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.admin-stat-value {
    font-size:2rem; font-weight:800;
    background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.admin-stat-label { font-size:.8rem; color:var(--text-2); margin-top:.3rem; }

/* Admin card controls */
.admin-card .delivery-info { padding:.9rem; }
.admin-actions { display:flex; gap:.4rem; flex-wrap:wrap; margin-top:.8rem; }
.admin-btn {
    width:34px; height:34px; border-radius:var(--radius-sm);
    display:flex; align-items:center; justify-content:center;
    font-size:.82rem; transition:var(--transition); border:1px solid var(--border);
    background:var(--surface-2); color:var(--text-2);
}
.admin-btn:hover { transform:scale(1.08); }
.admin-btn.edit-btn:hover     { background:var(--info);    color:#fff; border-color:transparent; }
.admin-btn.block-btn:hover    { background:var(--warning); color:#fff; border-color:transparent; }
.admin-btn.certify-btn:hover  { background:var(--success); color:#fff; border-color:transparent; }
.admin-btn.stars-btn:hover    { background:#f59e0b;        color:#fff; border-color:transparent; }
.admin-btn.delete-btn:hover   { background:var(--danger);  color:#fff; border-color:transparent; }
.admin-btn.promote-btn:hover  { background:var(--primary); color:#fff; border-color:transparent; }
.admin-btn.danger-btn  { background:rgba(239,68,68,.1); color:var(--danger); }
.admin-btn.success-btn { background:rgba(16,185,129,.1); color:var(--success); }

.admin-filters, .admin-search {
    display:flex; gap:.8rem; flex-wrap:wrap; margin-bottom:1rem;
}
.admin-filter {
    display:flex; align-items:center; gap:.5rem;
    background:var(--surface); border:1px solid var(--border);
    border-radius:50px; padding:.45rem .9rem; color:var(--text-2); font-size:.85rem;
}
.admin-filter select {
    background:none; border:none; outline:none; font-family:inherit;
    font-size:.85rem; color:var(--text); cursor:pointer;
}
.admin-search { flex-wrap:nowrap; }
.admin-search input {
    flex:1; padding:.65rem 1rem;
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-sm); font-family:inherit; font-size:.9rem;
    color:var(--text); outline:none; transition:var(--transition);
}
.admin-search input:focus { border-color:var(--primary); }
.admin-search button {
    padding:.65rem 1.2rem; background:var(--grad); color:#fff;
    border-radius:var(--radius-sm); font-size:.9rem; transition:var(--transition);
}

/* Status badges */
.status-badge {
    display:inline-flex; align-items:center; gap:.3rem;
    padding:.2rem .6rem; border-radius:50px; font-size:.72rem; font-weight:600;
}
.status-badge.certified { background:rgba(16,185,129,.1); color:var(--success); }
.status-badge.blocked   { background:rgba(239,68,68,.1);  color:var(--danger); }
.status-badge.banned    { background:rgba(107,114,128,.1); color:#6b7280; }

.me-badge {
    display:inline-flex; align-items:center;
    padding:.15rem .5rem; border-radius:50px; font-size:.7rem; font-weight:600;
    background:rgba(106,17,203,.15); color:var(--primary);
}

/* Carousel admin */
.carousel-images-container {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
    gap:1rem; margin-bottom:2rem;
}
.carousel-image-item {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); overflow:hidden;
}
.carousel-image-header {
    padding:.7rem; display:flex; justify-content:space-between; align-items:center;
    border-bottom:1px solid var(--border);
}
.carousel-image-header h4 { font-size:.85rem; font-weight:600; }
.carousel-image-preview { width:100%; aspect-ratio:4/3; object-fit:cover; }

/* Notifications */
.notification-item {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-sm); padding:1rem; margin-bottom:.7rem;
    transition:var(--transition);
}
.notification-item:hover { border-color:var(--primary); }
.notification-header {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:.4rem; flex-wrap:wrap; gap:.3rem;
}
.notification-title { font-weight:600; font-size:.9rem; color:var(--primary); }
.notification-time  { font-size:.75rem; color:var(--text-3); }
.notification-body  { font-size:.85rem; color:var(--text-2); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 480px) {
    .delivery-grid, .top-delivery-grid {
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    }
    .admin-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    .banner h1 { font-size:1.4rem; }
    .modal-content { border-radius:var(--radius); }
}

@media (min-width: 768px) {
    header { padding:0 2rem; }
    .delivery-grid, .top-delivery-grid {
        padding:1.5rem 2rem 3rem;
        grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
    }
    .admin-content { padding:2rem; }
    .add-form-container, .form-container { padding:2rem 2rem 4rem; }
}

@media (min-width: 1024px) {
    .admin-sidebar {
        position:sticky; top:0; left:0; height:calc(100vh - var(--header-h));
        display:flex !important;
    }
    #admin-space { flex-direction:row; }
    .admin-overlay { display:none !important; }
    .admin-content { padding:2.5rem; }
}

/* ── Bouton Commander ──────────────────────────────────────── */
.contact-btn.commande-btn {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    border-color: transparent;
    font-size: .8rem;
    cursor: pointer;
}
.contact-btn.commande-btn:hover {
    opacity: .9;
    transform: translateY(-1px);
}

/* ── Favori button ───────────────────────────────────────────── */
.fav-btn {
    position:absolute; top:.7rem; left:.7rem;
    width:34px; height:34px; border-radius:50%;
    background:rgba(255,255,255,.85);
    border:none; cursor:pointer; display:flex;
    align-items:center; justify-content:center;
    font-size:.85rem; color:#ccc;
    transition:var(--transition);
    box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.fav-btn:hover, .fav-btn.active { color:#ef4444; background:#fff; transform:scale(1.1); }
.fav-btn.active { color:#ef4444; }

/* ── User topbar button ─────────────────────────────────────── */
.user-topbar-btn {
    display:flex; align-items:center; gap:.4rem;
    padding:.4rem .85rem; border-radius:50px;
    font-size:.78rem; font-weight:600;
    background:var(--grad); color:#fff;
    text-decoration:none; flex-shrink:0;
    transition:opacity .2s;
}
.user-topbar-btn:hover { opacity:.9; }

/* ── Commande button ────────────────────────────────────────── */
.contact-btn.commande-btn {
    background:linear-gradient(135deg, var(--primary), var(--secondary));
    color:#fff; border-color:transparent; cursor:pointer;
    font-size:.82rem;
}
.contact-btn.commande-btn:hover { opacity:.9; transform:translateY(-1px); }

/* ── Notification dot on bell ───────────────────────────────── */
.notif-dot {
    position:absolute; top:-2px; right:-2px;
    width:8px; height:8px; border-radius:50%;
    background:var(--accent); border:2px solid var(--surface);
}
