/* ══════════════════════════════════════════════
   LaBoutiqueDuCode — Dark + Light Theme
   ══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ═══════════════════════════════════════════
   THEME VARIABLES
   ═══════════════════════════════════════════ */
:root,
[data-theme="dark"]{
    --bg:#0d0d0d;
    --bg2:#141414;
    --bg3:#1a1a1a;
    --bg4:#222;
    --border:rgba(255,255,255,.08);
    --border-h:rgba(255,255,255,.18);
    --white:#fff;
    --t1:#e0e0e0;
    --t2:#999;
    --t3:#666;
    --t4:#444;
    --danger:#e74c3c;
    --r:12px;
    --mono:'JetBrains Mono',monospace;
    --max:1140px;
    --header-bg:rgba(13,13,13,.7);
    --card-bg:rgba(255,255,255,.04);
    --card-hover:rgba(255,255,255,.06);
    --glass-bg:rgba(255,255,255,.05);
    --glass-border:rgba(255,255,255,.1);
    --glass-glow:rgba(255,255,255,.08);
    --input-bg:rgba(255,255,255,.04);
    --input-border:rgba(255,255,255,.08);
    --input-focus-border:rgba(255,255,255,.18);
    --input-focus-bg:rgba(255,255,255,.06);
    --btn-bg:rgba(255,255,255,.9);
    --btn-color:#0d0d0d;
    --btn-hover:#fff;
    --shadow-color:rgba(0,0,0,.3);
    --overlay-bg:rgba(0,0,0,.5);
    --notification-bg:rgba(13,13,13,.9);
    --scrollbar-thumb:rgba(255,255,255,.05);
    --scrollbar-hover:rgba(255,255,255,.1);
}

[data-theme="light"]{
    --bg:#f5f5f7;
    --bg2:#ffffff;
    --bg3:#eeeef0;
    --bg4:#e0e0e2;
    --border:rgba(0,0,0,.08);
    --border-h:rgba(0,0,0,.18);
    --white:#111;
    --t1:#222;
    --t2:#555;
    --t3:#888;
    --t4:#bbb;
    --danger:#e74c3c;
    --header-bg:rgba(255,255,255,.8);
    --card-bg:rgba(0,0,0,.03);
    --card-hover:rgba(0,0,0,.06);
    --glass-bg:rgba(255,255,255,.6);
    --glass-border:rgba(0,0,0,.1);
    --glass-glow:rgba(0,0,0,.04);
    --input-bg:rgba(0,0,0,.03);
    --input-border:rgba(0,0,0,.1);
    --input-focus-border:rgba(0,0,0,.2);
    --input-focus-bg:rgba(0,0,0,.05);
    --btn-bg:rgba(0,0,0,.85);
    --btn-color:#fff;
    --btn-hover:#000;
    --shadow-color:rgba(0,0,0,.08);
    --overlay-bg:rgba(0,0,0,.3);
    --notification-bg:rgba(255,255,255,.95);
    --scrollbar-thumb:rgba(0,0,0,.08);
    --scrollbar-hover:rgba(0,0,0,.15);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
img{border:0;max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

body{
    display:flex;flex-direction:column;min-height:100vh;
    font:15px/1.6 'Inter',sans-serif;
    color:var(--t1);background:var(--bg);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
    transition:background .3s,color .3s;
}

.container{max-width:var(--max);width:100%;margin:0 auto;padding:0 32px}

/* ═══════════════════════════════════════════
   THEME TOGGLE BUTTON
   ═══════════════════════════════════════════ */
.theme-toggle{
    display:flex;align-items:center;justify-content:center;
    width:36px;height:36px;margin-left:8px;
    border-radius:50%;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    cursor:pointer;
    transition:all .2s;
    color:var(--t2);
    font-size:1.1em;
    position:relative;
    overflow:hidden;
}
.theme-toggle:hover{
    border-color:var(--border-h);
    background:var(--card-hover);
    color:var(--white);
}
.theme-icon-light,.theme-icon-dark{
    position:absolute;
    transition:opacity .3s,transform .3s;
}
[data-theme="dark"] .theme-icon-light{opacity:1;transform:rotate(0deg)}
[data-theme="dark"] .theme-icon-dark{opacity:0;transform:rotate(-90deg)}
[data-theme="light"] .theme-icon-light{opacity:0;transform:rotate(90deg)}
[data-theme="light"] .theme-icon-dark{opacity:1;transform:rotate(0deg)}

/* ═══════════════════════════════════════════
   HEADER — floating topbar
   ═══════════════════════════════════════════ */
header{
    position:fixed;top:16px;left:50%;
    transform:translateX(-50%);
    z-index:100;
    width:calc(100% - 48px);
    max-width:var(--max);
    background:var(--header-bg);
    backdrop-filter:blur(20px) saturate(1.3);
    -webkit-backdrop-filter:blur(20px) saturate(1.3);
    border:1px solid var(--glass-border);
    border-radius:16px;
    box-shadow:0 8px 32px var(--shadow-color);
    overflow:hidden;
    transition:background .3s,border-color .3s;
}
.header-inner{
    display:flex;align-items:center;
    height:54px;padding:0 24px;
}
a.logo{display:flex;align-items:center;gap:10px}
a.logo i{font-size:1.2em;color:var(--white)}
a.logo span{font:700 1em var(--mono);color:var(--white);letter-spacing:-1px}
a.logo .logo-accent{color:var(--t2)}

nav#menu_haut{margin-left:auto}
nav#menu_haut ul{display:flex;gap:0}
nav#menu_haut li a{
    display:flex;align-items:center;gap:6px;
    color:var(--t2);font-size:.82em;font-weight:500;
    padding:8px 16px;border-radius:8px;
    transition:color .2s;
}
nav#menu_haut li a i{font-size:1.05em}
nav#menu_haut li a:hover{color:var(--white)}

.cart-btn{
    position:relative;
    display:flex;align-items:center;justify-content:center;
    width:36px;height:36px;margin-left:8px;
    border-radius:50%;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    transition:all .2s;
    overflow:visible;
}
.cart-btn i{font-size:1.05em;color:var(--t2)}
.cart-btn:hover{border-color:var(--border-h);background:var(--card-hover)}
.cart-btn:hover i{color:var(--white)}
.cart-count{
    position:absolute;top:-5px;right:-5px;
    min-width:18px;height:18px;
    display:flex;align-items:center;justify-content:center;
    font:700 .6em var(--mono);color:#fff;
    background:var(--danger);
    border:2px solid var(--bg);
    border-radius:50%;padding:0 4px;
    z-index:2;
}

/* ═══════════════════════════════════════════
   HERO — animated background
   ═══════════════════════════════════════════ */
.hero{
    position:relative;
    min-height:100vh;
    display:flex;align-items:center;
    overflow:hidden;
    background:var(--bg);
}

/* ── Animated floating orbs ─────────────── */
.hero-orbs{
    position:absolute;inset:0;z-index:0;
    overflow:hidden;pointer-events:none;
}
.hero-orb{
    position:absolute;
    border-radius:50%;
    filter:blur(80px);
    opacity:0;
    animation:orbFloat 12s ease-in-out infinite;
}
.hero-orb:nth-child(1){
    width:500px;height:500px;
    background:radial-gradient(circle,rgba(255,255,255,.15),transparent 70%);
    top:-10%;left:-5%;
    animation-delay:0s;animation-duration:14s;
}
.hero-orb:nth-child(2){
    width:400px;height:400px;
    background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%);
    bottom:-10%;right:-5%;
    animation-delay:3s;animation-duration:16s;
}
.hero-orb:nth-child(3){
    width:300px;height:300px;
    background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);
    top:40%;left:50%;
    animation-delay:6s;animation-duration:18s;
}
.hero-orb:nth-child(4){
    width:250px;height:250px;
    background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);
    top:20%;right:20%;
    animation-delay:2s;animation-duration:13s;
}

[data-theme="light"] .hero-orb:nth-child(1){background:radial-gradient(circle,rgba(0,0,0,.06),transparent 70%)}
[data-theme="light"] .hero-orb:nth-child(2){background:radial-gradient(circle,rgba(0,0,0,.04),transparent 70%)}
[data-theme="light"] .hero-orb:nth-child(3){background:radial-gradient(circle,rgba(0,0,0,.03),transparent 70%)}
[data-theme="light"] .hero-orb:nth-child(4){background:radial-gradient(circle,rgba(0,0,0,.05),transparent 70%)}

@keyframes orbFloat{
    0%,100%{opacity:0;transform:translate(0,0) scale(.8)}
    25%{opacity:1;transform:translate(40px,-30px) scale(1.1)}
    50%{opacity:.6;transform:translate(-20px,40px) scale(1)}
    75%{opacity:1;transform:translate(30px,20px) scale(1.15)}
}

/* ── Animated grid lines ────────────────── */
.hero-bg{
    position:absolute;inset:0;z-index:0;
    opacity:.4;
}
.hero-grid{width:100%;height:100%}

.hero-layout{
    position:relative;z-index:2;
    max-width:var(--max);width:100%;
    margin:0 auto;padding:0 32px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
    min-height:100vh;
}
.hero-text{padding:40px 0}

.hero-label{
    display:inline-block;
    font:500 .7em var(--mono);
    color:var(--t2);
    text-transform:uppercase;
    letter-spacing:3px;
    margin-bottom:24px;
    padding:8px 18px;
    border-radius:980px;
    background:var(--glass-bg);
    border:1px solid var(--glass-border);
    position:relative;
    overflow:hidden;
}
.hero-title{
    font-size:4.5em;font-weight:900;
    line-height:.95;letter-spacing:-3px;
    color:var(--white);
    margin-bottom:24px;
}
.hero-desc{
    font-size:1em;color:var(--t2);
    line-height:1.7;max-width:380px;
    margin-bottom:36px;
}
.hero-actions{display:flex;gap:12px;align-items:center;margin-bottom:48px}
.btn-main{
    padding:13px 36px;
    background:var(--btn-bg);color:var(--btn-color);
    font-weight:600;font-size:.88em;
    border-radius:980px;
    transition:all .25s;
    position:relative;
    box-shadow:
        0 0 20px var(--glass-glow),
        inset 0 1px 0 rgba(255,255,255,.4);
}
.btn-main:hover{
    background:var(--btn-hover);
    transform:translateY(-2px);
    box-shadow:
        0 10px 40px var(--glass-glow),
        0 0 60px rgba(255,255,255,.04),
        inset 0 1px 0 rgba(255,255,255,.5);
}

.hero-stats{display:flex;gap:20px}

.stat{
    padding:16px 24px;
    border-radius:var(--r);
    position:relative;
    background:var(--glass-bg);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    border:1px solid var(--glass-border);
    box-shadow:
        inset 0 1px 0 var(--glass-glow),
        0 4px 16px var(--shadow-color);
    overflow:hidden;
    transition:background .3s,border-color .3s;
}
.stat::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--glass-glow) 0%,transparent 50%);
    pointer-events:none;
}
.stat strong{
    display:block;font:800 1.8em var(--mono);
    color:var(--white);letter-spacing:-1px;
}
.stat span{font-size:.7em;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px}

.hero-scroll{
    position:absolute;bottom:32px;left:50%;
    transform:translateX(-50%);z-index:10;
    color:var(--t4);font-size:1.6em;
    animation:bounce 2s infinite;
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── 3D Torus ───────────────────────────── */
.hero-visual{
    display:flex;align-items:center;justify-content:center;
    padding:40px 0;
}
.torus-wrapper{
    width:400px;height:400px;
    position:relative;
}
#torusCanvas{
    position:absolute;inset:0;
    width:100%;height:100%;
}
@media(prefers-reduced-motion:reduce){
    .hero-scroll{animation:none !important}
    .hero-orb{animation:none !important}
}

/* ═══════════════════════════════════════════
   PAGE SECTIONS — animated bg
   ═══════════════════════════════════════════ */
.page-section{
    padding:112px 0 70px;flex:1;
    position:relative;
    overflow:hidden;
}
.page-section::before{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse at 50% 0%, var(--glass-glow) 0%, transparent 50%),
        radial-gradient(ellipse at 0% 50%, rgba(255,255,255,.08) 0%, transparent 40%),
        radial-gradient(ellipse at 100% 80%, rgba(255,255,255,.06) 0%, transparent 35%);
    pointer-events:none;
    animation:bgPulse 10s ease-in-out infinite alternate;
}
@keyframes bgPulse{
    0%{opacity:.6;transform:scale(1)}
    100%{opacity:1;transform:scale(1.05)}
}

/* ── Section header + inline categories ─── */
.section-header{
    display:flex;align-items:baseline;gap:24px;
    flex-wrap:wrap;
    margin-bottom:36px;
}
.section-header-left{display:flex;flex-direction:column;gap:4px}
.section-header h2{
    font-size:1.6em;font-weight:700;
    color:var(--white);letter-spacing:-.5px;
}
.section-header h2 i{color:var(--t3);margin-right:8px}
.subtitle{color:var(--t3);font-size:.84em;margin-top:0}

.section-cats{
    display:flex;gap:6px;
    margin-left:auto;
    flex-wrap:wrap;
}
.section-cat-link{
    display:flex;align-items:center;gap:5px;
    padding:6px 14px;
    border-radius:980px;
    font-size:.75em;font-weight:500;
    color:var(--t2);
    background:var(--glass-bg);
    border:1px solid var(--glass-border);
    transition:all .2s;
    position:relative;
    overflow:hidden;
}
.section-cat-link i{font-size:.95em}
.section-cat-link:hover{
    color:var(--white);
    border-color:var(--border-h);
}
.section-cat-link.active{
    color:var(--white);
    border-color:var(--border-h);
}

/* ═══════════════════════════════════════════
   PRODUCT CARDS — HORIZONTAL
   ═══════════════════════════════════════════ */
.products-grid{
    display:flex;flex-direction:column;
    gap:1px;
    background:var(--border);
    border:1px solid var(--border);
    border-radius:var(--r);
    overflow:hidden;
}
.product-card{
    display:grid;
    grid-template-columns:200px 1fr;
    background:var(--bg2);
    transition:background .2s;
    cursor:pointer;
}
.product-card:hover{background:var(--bg3)}

.product-img{
    width:100%;height:100%;min-height:140px;
    background-size:cover;background-position:center;
    background-color:var(--bg3);
}
.product-img-default{
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--bg3),var(--bg4));
}
.product-img-default i{
    font-size:2.5em;color:var(--t4);opacity:.5;
}
.product-body{
    padding:24px 28px;
    display:flex;flex-direction:column;
    justify-content:center;
}
.product-cat{
    font:500 .65em var(--mono);
    color:var(--t3);
    text-transform:uppercase;
    letter-spacing:2px;
    margin-bottom:6px;
}
.product-body h3{
    font-size:1em;font-weight:600;color:var(--white);
    margin:0 0 6px;
}
.product-desc{
    color:var(--t2);font-size:.82em;
    line-height:1.5;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.product-action{
    display:flex;align-items:center;gap:16px;
    margin-top:14px;
}
.product-price{font:700 1.1em var(--mono);color:var(--white)}

.btn-cart{
    display:flex;align-items:center;justify-content:center;
    width:36px;height:36px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:50%;
    transition:all .2s;
}
.btn-cart i{font-size:1em;color:var(--t3)}
.btn-cart:hover{
    border-color:var(--white);
    background:var(--white);
}
.btn-cart:hover i{color:var(--bg)}

/* ═══════════════════════════════════════════
   PRODUCT MODAL
   ═══════════════════════════════════════════ */
.product-modal-overlay{
    position:fixed;inset:0;z-index:300;
    background:var(--overlay-bg);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    display:flex;align-items:center;justify-content:center;
    opacity:0;pointer-events:none;
    transition:opacity .3s;
}
.product-modal-overlay.open{
    opacity:1;pointer-events:auto;
}
.product-modal{
    width:90%;max-width:800px;
    max-height:85vh;
    background:var(--bg2);
    border:1px solid var(--border);
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 24px 80px rgba(0,0,0,.4);
    transform:translateY(40px) scale(.95);
    opacity:0;
    transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s;
}
.product-modal.animate-in{
    transform:translateY(0) scale(1);
    opacity:1;
}
.product-modal.animate-out{
    transform:translateY(40px) scale(.95);
    opacity:0;
}
.product-modal-close{
    position:absolute;top:16px;right:16px;z-index:10;
    display:flex;align-items:center;justify-content:center;
    width:40px;height:40px;border-radius:50%;
    background:var(--card-bg);
    backdrop-filter:blur(12px);
    border:1px solid var(--glass-border);
    color:var(--t2);font-size:1.3em;cursor:pointer;
    transition:all .2s;font-family:inherit;
}
.product-modal-close:hover{background:var(--card-hover);color:var(--white)}
.product-modal-content{
    display:grid;grid-template-columns:1fr 1fr;
    position:relative;
}
.product-modal-image{
    min-height:350px;
    background-size:cover;background-position:center;
    background-color:var(--bg3);
}
.product-modal-image.no-image{
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--bg3),var(--bg4));
}
.product-modal-image.no-image i{font-size:4em;color:var(--t4);opacity:.4}
.product-modal-info{
    padding:40px 36px;
    display:flex;flex-direction:column;
    justify-content:center;
    overflow-y:auto;max-height:85vh;
}
.product-modal-cat{
    font:500 .65em var(--mono);
    color:var(--t3);text-transform:uppercase;
    letter-spacing:2px;margin-bottom:8px;
}
.product-modal-title{
    font-size:1.6em;font-weight:700;
    color:var(--white);margin:0 0 16px;
    letter-spacing:-.5px;
}
.product-modal-desc{
    color:var(--t2);font-size:.9em;
    line-height:1.7;margin-bottom:24px;
}
.product-modal-meta{
    display:flex;align-items:center;gap:20px;
    margin-bottom:28px;
}
.product-modal-price{
    font:800 2em var(--mono);
    color:var(--white);letter-spacing:-1px;
}
.product-modal-price.free{
    color:#2ecc71;
}
.product-modal-fichier{
    display:flex;align-items:center;gap:6px;
    font-size:.82em;color:var(--t3);
    padding:6px 14px;border-radius:980px;
    background:var(--glass-bg);
    border:1px solid var(--glass-border);
}
.product-modal-fichier i{color:var(--t2)}
.product-modal-actions{
    display:flex;gap:12px;flex-wrap:wrap;
}
.btn-modal-cart,.btn-modal-free{
    display:inline-flex;align-items:center;gap:8px;
    padding:13px 32px;border:none;
    border-radius:980px;cursor:pointer;
    font:600 .88em 'Inter',sans-serif;
    transition:all .2s;
}
.btn-modal-cart{
    background:var(--btn-bg);color:var(--btn-color);
}
.btn-modal-cart:hover{
    background:var(--btn-hover);
    transform:translateY(-2px);
    box-shadow:0 8px 24px var(--shadow-color);
}
.btn-modal-free{
    background:#2ecc71;color:#fff;
}
.btn-modal-free:hover{
    background:#27ae60;
    transform:translateY(-2px);
    box-shadow:0 8px 24px rgba(46,204,113,.2);
}

/* ═══════════════════════════════════════════
   NOTIFICATIONS
   ═══════════════════════════════════════════ */
.notification{
    position:fixed;bottom:24px;right:24px;z-index:500;
    display:flex;align-items:center;gap:10px;
    padding:14px 22px;
    border-radius:12px;
    background:var(--notification-bg);
    backdrop-filter:blur(16px);
    border:1px solid var(--glass-border);
    box-shadow:0 8px 32px var(--shadow-color);
    color:var(--t1);font-size:.88em;font-weight:500;
    transform:translateY(20px);opacity:0;
    transition:transform .3s,opacity .3s;
    max-width:400px;
}
.notification.show{
    transform:translateY(0);opacity:1;
}
.notification i{font-size:1.3em}
.notification-success i{color:#2ecc71}
.notification-info i{color:var(--t2)}

/* ═══════════════════════════════════════════
   CONTENT (admin, 404, etc.) — animated bg
   ═══════════════════════════════════════════ */
.content{
    max-width:var(--max);width:100%;
    margin:0 auto;padding:120px 32px 70px;
    flex:1;
    position:relative;
    overflow:hidden;
}
.content::before{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse at 30% 20%, var(--glass-glow) 0%, transparent 45%),
        radial-gradient(ellipse at 70% 70%, rgba(255,255,255,.08) 0%, transparent 40%),
        radial-gradient(ellipse at 10% 90%, rgba(255,255,255,.05) 0%, transparent 30%);
    pointer-events:none;
    animation:bgDrift 15s ease-in-out infinite alternate;
}
@keyframes bgDrift{
    0%{opacity:.7;transform:translate(0,0)}
    100%{opacity:1;transform:translate(-15px,10px)}
}
.content h2{
    font-size:1.4em;font-weight:700;
    color:var(--white);margin-bottom:20px;
    letter-spacing:-.3px;
}
.content h2 i{color:var(--t3);margin-right:6px}
.content h3{
    font-size:.92em;font-weight:600;
    color:var(--t1);margin:24px 0 10px;
}
.content h3 i{color:var(--t3);margin-right:4px}

/* ═══════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════ */
.contact-section{padding-top:100px}
.contact-header{margin-bottom:32px}

.contact-success{
    display:flex;align-items:center;gap:12px;
    padding:16px 24px;
    background:rgba(46,204,113,.08);
    border:1px solid rgba(46,204,113,.2);
    border-radius:var(--r);
    margin-bottom:24px;
    color:#2ecc71;font-size:.9em;
}
.contact-success i{font-size:1.5em}

.contact-layout{
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:40px;
    align-items:start;
}
.contact-form-wrapper{
    padding:32px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    backdrop-filter:blur(12px);
    box-shadow:0 8px 32px var(--shadow-color);
}
.contact-form .form-group{margin-bottom:16px}
.contact-form textarea{
    width:100%;max-width:100%;
}
.contact-info{
    display:flex;flex-direction:column;gap:16px;
}
.contact-info-card{
    display:flex;align-items:center;gap:16px;
    padding:20px 24px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    transition:all .2s;
}
.contact-info-card:hover{
    background:var(--card-hover);
    border-color:var(--border-h);
    transform:translateY(-2px);
}
.contact-info-card i{
    font-size:1.6em;color:var(--t2);
    flex-shrink:0;
}
.contact-info-card h4{
    font-size:.9em;font-weight:600;color:var(--white);
    margin:0 0 2px;
}
.contact-info-card p{
    font-size:.78em;color:var(--t3);margin:0;line-height:1.4;
}

/* ═══════════════════════════════════════════
   404
   ═══════════════════════════════════════════ */
.erreur404{text-align:center;padding:120px 34px}
.erreur404-icon{font-size:2.5em;color:var(--t4);display:block;margin-bottom:8px}
.erreur404 h2{
    font:900 8em var(--mono);line-height:1;
    color:var(--white);margin-bottom:0;letter-spacing:-6px;
}
.erreur404 p{color:var(--t3);font-size:.95em;margin:12px 0 32px}
.btn-primary{
    display:inline-flex;align-items:center;gap:6px;
    padding:12px 28px;
    background:var(--btn-bg);color:var(--btn-color);
    font-weight:600;font-size:.87em;
    border-radius:980px;
    transition:all .2s;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--shadow-color)}

/* ═══════════════════════════════════════════
   ADMIN DASHBOARD
   ═══════════════════════════════════════════ */
.admin-dashboard{padding-top:100px}
.admin-dashboard .admin-topbar{
    display:flex;align-items:flex-start;justify-content:space-between;
    margin-bottom:32px;
}
.admin-dashboard .admin-topbar h2{margin-bottom:4px}
.admin-bienvenue{color:var(--t3);font-size:.85em;margin:0}
.admin-bienvenue strong{color:var(--white);font-weight:600}

.admin-logout{
    display:inline-flex;align-items:center;gap:6px;
    padding:8px 18px;border-radius:8px;
    font-size:.82em;font-weight:500;
    color:var(--danger);
    border:1px solid rgba(231,76,60,.15);
    transition:all .15s;
}
.admin-logout:hover{background:rgba(231,76,60,.08);border-color:rgba(231,76,60,.3)}

.admin-stats{
    display:grid;grid-template-columns:repeat(4,1fr);
    gap:16px;margin-bottom:28px;
}
.admin-stat-card{
    display:flex;align-items:center;gap:16px;
    padding:20px 24px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    transition:all .2s;
}
.admin-stat-card:hover{background:var(--card-hover);border-color:var(--border-h)}
.admin-stat-icon{
    display:flex;align-items:center;justify-content:center;
    width:44px;height:44px;border-radius:10px;
    background:var(--card-bg);
    color:var(--t2);font-size:1.2em;
}
.admin-stat-data strong{
    display:block;font:700 1.3em var(--mono);
    color:var(--white);letter-spacing:-.5px;
}
.admin-stat-data span{
    font-size:.7em;color:var(--t3);text-transform:uppercase;
    letter-spacing:1.5px;
}

/* ── Admin Chart ─────────────────────────── */
.admin-chart-section{
    padding:24px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    margin-bottom:28px;
}
.admin-chart-section h3{
    font-size:.85em;font-weight:600;color:var(--white);
    margin:0 0 20px !important;display:flex;align-items:center;gap:8px;
}
.admin-chart-section h3 i{color:var(--t3)}
.admin-chart{
    display:flex;align-items:flex-end;gap:12px;
    height:180px;padding:0 8px;
}
.admin-chart-bar-wrapper{
    flex:1;display:flex;flex-direction:column;
    align-items:center;gap:6px;height:100%;
}
.admin-chart-value{
    font:600 .7em var(--mono);color:var(--t2);
}
.admin-chart-bar{
    flex:1;width:100%;
    border-radius:6px 6px 0 0;
    background:var(--bg3);
    display:flex;align-items:flex-end;
    overflow:hidden;
}
.admin-chart-fill{
    width:100%;
    border-radius:6px 6px 0 0;
    background:linear-gradient(180deg,rgba(255,255,255,.4),rgba(255,255,255,.15));
    transition:height .6s cubic-bezier(.4,0,.2,1);
    min-height:4px;
}
[data-theme="light"] .admin-chart-fill{
    background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,.1));
}
.admin-chart-label{
    font:500 .65em var(--mono);color:var(--t3);
    text-transform:uppercase;letter-spacing:1px;
}
.admin-chart-total{
    margin-top:14px;font-size:.82em;color:var(--t3);
}
.admin-chart-total strong{color:var(--white);font-weight:600}

.admin-grid{
    display:grid;grid-template-columns:repeat(2,1fr);
    gap:16px;margin-bottom:32px;
}
.admin-card{
    display:flex;align-items:center;gap:18px;
    padding:24px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    transition:all .2s;
    cursor:pointer;
}
.admin-card:hover{
    background:var(--card-hover);
    border-color:var(--border-h);
    transform:translateY(-2px);
    box-shadow:0 8px 24px var(--shadow-color);
}
.admin-card-icon{
    display:flex;align-items:center;justify-content:center;
    width:48px;height:48px;border-radius:12px;flex-shrink:0;
    background:var(--card-bg);
    color:var(--white);font-size:1.3em;
}
.admin-card-body h3{
    font-size:.92em;font-weight:600;color:var(--white);
    margin:0 0 4px;
}
.admin-card-body p{
    font-size:.78em;color:var(--t3);margin:0;line-height:1.4;
}
.admin-card-arrow{
    margin-left:auto;color:var(--t4);font-size:1.2em;
    transition:all .2s;
}
.admin-card:hover .admin-card-arrow{color:var(--white);transform:translateX(4px)}

.admin-overview{
    padding:24px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
}
.admin-overview h3{
    font-size:.85em;font-weight:600;color:var(--white);
    margin:0 0 20px;display:flex;align-items:center;gap:8px;
}
.admin-overview h3 i{color:var(--t3)}

.admin-cat-list{display:flex;flex-direction:column;gap:14px}
.admin-cat-row{
    display:grid;grid-template-columns:100px 1fr 40px;
    align-items:center;gap:14px;
}
.admin-cat-name{font-size:.82em;color:var(--t2);font-weight:500}
.admin-cat-bar{
    height:6px;border-radius:3px;
    background:var(--bg3);
    overflow:hidden;
}
.admin-cat-fill{
    height:100%;border-radius:3px;
    background:rgba(255,255,255,.3);
    transition:width .6s ease;
}
[data-theme="light"] .admin-cat-fill{background:rgba(0,0,0,.2)}
.admin-cat-count{
    font:600 .8em var(--mono);
    color:var(--t3);text-align:right;
}

/* ═══════════════════════════════════════════
   ACCES INTERDIT
   ═══════════════════════════════════════════ */
.acces-interdit{text-align:center;padding:100px 34px}
.acces-interdit-icon{font-size:3.5em;color:var(--danger);opacity:.3;display:block;margin-bottom:14px}
.acces-interdit h2{
    color:var(--danger);font-weight:600;font-size:1.2em;margin-bottom:8px;
    -webkit-text-fill-color:unset;background:none;
}
.acces-interdit p{color:var(--t3);margin-bottom:24px}

/* ═══════════════════════════════════════════
   LOGIN BOX
   ═══════════════════════════════════════════ */
.login-box{
    max-width:380px;padding:32px;
    position:relative;
    background:var(--card-bg);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    box-shadow:
        inset 0 1px 0 var(--glass-glow),
        0 8px 32px var(--shadow-color);
    overflow:hidden;
}
.login-box::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--glass-glow) 0%,transparent 50%);
    pointer-events:none;
}
.checkbox-row{display:flex;align-items:center;gap:7px;margin-top:10px}

/* ═══════════════════════════════════════════
   MESSAGES
   ═══════════════════════════════════════════ */
.message{
    color:var(--t1);font-weight:500;font-size:.85em;
    position:relative;
    background:var(--card-bg);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    padding:12px 18px;border-radius:8px;
    border:1px solid var(--glass-border);
    border-left:3px solid rgba(255,255,255,.3);
    margin-bottom:18px;
    font-family:var(--mono);
    box-shadow:inset 0 1px 0 var(--glass-glow);
}

/* ═══════════════════════════════════════════
   FILE INPUT
   ═══════════════════════════════════════════ */
.file-input{
    display:block;width:100%;max-width:360px;
    padding:10px 14px;border-radius:8px;
    font-size:.85em;font-family:inherit;
    color:var(--t1);
    background:var(--input-bg);
    border:1px solid var(--input-border);
    cursor:pointer;
    transition:all .2s;
}
.file-input:hover{
    border-color:var(--input-focus-border);
    background:var(--input-focus-bg);
}
.file-input::file-selector-button{
    padding:6px 14px;border-radius:6px;
    border:1px solid var(--glass-border);
    background:var(--card-bg);
    color:var(--t1);cursor:pointer;
    font-family:inherit;font-size:.85em;
    margin-right:10px;
    transition:all .2s;
}
.file-input::file-selector-button:hover{
    background:var(--card-hover);
    border-color:var(--border-h);
}

/* ═══════════════════════════════════════════
   TABLES
   ═══════════════════════════════════════════ */
table{width:100%;border-collapse:collapse;margin:10px 0 20px}
table thead th{
    padding:10px 14px;text-align:left;
    font:500 .7em var(--mono);
    color:var(--t3);text-transform:uppercase;
    letter-spacing:1.5px;
    border-bottom:1px solid var(--border);
}
table tbody td{
    padding:12px 14px;font-size:.87em;color:var(--t2);
    border-bottom:1px solid var(--border);
}
table tbody tr:last-child td{border-bottom:none}
table tbody tr{transition:background .1s}
table tbody tr:hover{background:var(--bg2)}

.btn-danger{
    display:inline-flex;align-items:center;gap:4px;
    color:var(--danger);font-weight:500;font-size:.82em;
    padding:4px 10px;border-radius:6px;
    transition:background .15s;
}
.btn-danger:hover{background:rgba(231,76,60,.06)}

.btn-edit{
    display:inline-flex;align-items:center;gap:4px;
    color:var(--t2);font-weight:500;font-size:.82em;
    padding:4px 10px;border-radius:6px;
    border:none;background:none;cursor:pointer;
    font-family:inherit;transition:all .15s;
}
.btn-edit:hover{color:var(--white);background:var(--bg3)}

.btn-annuler{
    display:inline-block;
    padding:10px 24px;border-radius:980px;
    margin-top:12px;margin-left:8px;cursor:pointer;
    font-weight:500;font-size:.85em;font-family:inherit;
    color:var(--t3);
    background:transparent;
    border:1px solid var(--border);
    transition:all .2s;
}
.btn-annuler:hover{border-color:var(--border-h);color:var(--t1)}

/* ═══════════════════════════════════════════
   FORM / SELECT
   ═══════════════════════════════════════════ */
.form-row{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.form-group{margin-bottom:14px}
.form-group label{display:block;margin-bottom:4px}

.back-link{
    display:inline-flex;align-items:center;gap:4px;
    color:var(--t2);font-weight:500;font-size:.87em;
    transition:color .15s;
}
.back-link:hover{color:var(--white)}

select{
    display:block;width:100%;max-width:340px;
    padding:11px 14px;border-radius:8px;
    font-size:.87em;font-family:inherit;color:var(--t1);
    background:var(--input-bg);
    border:1px solid var(--input-border);
    outline:none;cursor:pointer;
    transition:all .2s;
    -webkit-appearance:none;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6' fill='%23555'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;
}
select:focus{
    border-color:var(--input-focus-border);
    background-color:var(--input-focus-bg);
}

/* ═══════════════════════════════════════════
   SCROLLBAR
   ═══════════════════════════════════════════ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
footer{
    margin-top:auto;
    border-top:1px solid var(--border);
    transition:border-color .3s;
}
.footer-inner{
    max-width:var(--max);margin:0 auto;
    padding:48px 32px 20px;
}
.footer-top{
    display:grid;
    grid-template-columns:1.5fr 1fr 1fr;
    gap:48px;
    padding-bottom:36px;
    border-bottom:1px solid var(--border);
}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{display:flex;align-items:center;gap:8px;transition:opacity .2s}
.footer-logo:hover{opacity:.7}
.footer-logo i{font-size:1.1em;color:var(--white)}
.footer-logo span{font:700 .95em var(--mono);color:var(--white)}
.footer-logo .logo-accent{color:var(--t3)}
.footer-tagline{color:var(--t3);font-size:.82em;line-height:1.6;max-width:300px}
.footer-links h4{
    font:500 .65em var(--mono);
    color:var(--t3);text-transform:uppercase;
    letter-spacing:2px;margin-bottom:16px;
}
.footer-links ul li{margin-bottom:8px}
.footer-links ul li a{
    color:var(--t3);font-size:.82em;
    transition:color .15s;
}
.footer-links ul li a i{margin-right:4px}
.footer-links ul li a:hover{color:var(--white)}
.footer-bottom{text-align:center;padding:24px 0 6px}
.footer-bottom p{
    font:400 .68em var(--mono);
    color:var(--t4);letter-spacing:.5px;
}

/* ═══════════════════════════════════════════
   CART SLIDE-IN PANEL
   ═══════════════════════════════════════════ */
.panier-overlay{
    position:fixed;inset:0;z-index:200;
    background:var(--overlay-bg);backdrop-filter:blur(4px);
    opacity:0;pointer-events:none;
    transition:opacity .3s;
}
.panier-overlay.open{opacity:1;pointer-events:auto}

.panier-panel{
    position:fixed;top:0;right:0;z-index:201;
    width:380px;max-width:90vw;height:100vh;
    display:flex;flex-direction:column;
    background:var(--header-bg);
    backdrop-filter:blur(24px) saturate(1.3);
    -webkit-backdrop-filter:blur(24px) saturate(1.3);
    border-left:1px solid var(--glass-border);
    box-shadow:-8px 0 40px var(--shadow-color);
    transform:translateX(100%);
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    overflow:hidden;
    border-radius:0;
}
.panier-panel.open{transform:translateX(0)}

.panier-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 24px;
    border-bottom:1px solid var(--border);
}
.panier-header h3{
    font-size:.95em;font-weight:600;color:var(--white);
    display:flex;align-items:center;gap:8px;
    margin:0;
}
.panier-header h3 i{color:var(--t3)}
.panier-close{
    display:flex;align-items:center;justify-content:center;
    width:32px;height:32px;border-radius:8px;
    background:var(--card-bg);border:1px solid var(--glass-border);
    color:var(--t2);font-size:1.1em;cursor:pointer;
    transition:all .15s;font-family:inherit;
}
.panier-close:hover{background:var(--card-hover);color:var(--white)}

.panier-body{flex:1;overflow-y:auto;padding:16px 24px}

.panier-empty{text-align:center;padding:60px 0}
.panier-empty i{font-size:2.5em;color:var(--t4);display:block;margin-bottom:12px}
.panier-empty p{color:var(--t2);font-weight:500;margin-bottom:4px}
.panier-empty span{color:var(--t4);font-size:.8em}

.panier-item{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 0;
    border-bottom:1px solid var(--border);
}
.panier-item:last-child{border-bottom:none}
.panier-item-info strong{display:block;font-size:.87em;color:var(--white);font-weight:500}
.panier-item-cat{font:500 .65em var(--mono);color:var(--t3);text-transform:uppercase;letter-spacing:1px}
.panier-item-right{display:flex;align-items:center;gap:12px}
.panier-item-price{font:600 .9em var(--mono);color:var(--white)}
.panier-item-remove{
    display:flex;align-items:center;justify-content:center;
    width:28px;height:28px;border-radius:6px;
    background:none;border:1px solid var(--border);
    color:var(--danger);cursor:pointer;font-size:.85em;
    transition:all .15s;font-family:inherit;
}
.panier-item-remove:hover{background:rgba(231,76,60,.1);border-color:rgba(231,76,60,.2)}

.panier-footer{
    padding:20px 24px;
    border-top:1px solid var(--border);
}
.panier-total{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:14px;
}
.panier-total span{color:var(--t3);font-size:.85em;font-weight:500}
.panier-total strong{font:700 1.15em var(--mono);color:var(--white)}
.panier-checkout{
    width:100%;padding:13px;border:none;
    background:var(--btn-bg);color:var(--btn-color);
    font:600 .88em 'Inter',sans-serif;
    border-radius:980px;cursor:pointer;
    transition:all .2s;
}
.panier-checkout:hover:not(:disabled){background:var(--btn-hover);transform:translateY(-1px);box-shadow:0 6px 20px var(--shadow-color)}
.panier-checkout:disabled{opacity:.3;cursor:not-allowed}

/* ═══════════════════════════════════════════
   CATEGORIES BAR
   ═══════════════════════════════════════════ */
.categories-bar{
    padding:30px 0 40px;
}
.cat-header{
    display:flex;align-items:center;gap:16px;
    margin-bottom:20px;
}
.cat-header h2{
    font-size:1.2em;font-weight:700;
    color:var(--white);letter-spacing:-.3px;
}
.cat-line{flex:1;height:1px;background:var(--border)}
.cat-nav{
    display:flex;gap:10px;flex-wrap:wrap;
}
.cat-card{
    display:flex;align-items:center;gap:10px;
    padding:14px 22px;
    background:var(--card-bg);
    border:1px solid var(--glass-border);
    border-radius:var(--r);
    transition:all .2s;
    font-size:.88em;font-weight:500;
    color:var(--t2);
}
.cat-card:hover{
    background:var(--card-hover);
    border-color:var(--border-h);
    color:var(--white);
    transform:translateY(-2px);
}
.cat-card i{font-size:1.1em}
.cat-arrow{margin-left:auto;color:var(--t4);transition:all .2s}
.cat-card:hover .cat-arrow{color:var(--white);transform:translateX(3px)}

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media(max-width:900px){
    header{
        top:10px;
        width:calc(100% - 24px);
        border-radius:12px;
    }
    .header-inner{height:48px;padding:0 16px}

    .hero-layout{
        grid-template-columns:1fr;
        gap:20px;min-height:auto;
        padding-top:100px;padding-bottom:60px;
    }
    .hero-text{text-align:center;padding:0}
    .hero-title{font-size:3em;letter-spacing:-2px}
    .hero-desc{margin:0 auto 32px}
    .hero-actions{justify-content:center}
    .hero-stats{justify-content:center}
    .hero-visual{display:none}

    nav#menu_haut li a span{display:none}
    nav#menu_haut li a{padding:6px 10px}

    .section-header{flex-direction:column;gap:12px}
    .section-cats{margin-left:0}

    .product-card{grid-template-columns:140px 1fr}
    .product-img{min-height:120px}
    .product-body{padding:16px 20px}

    .product-modal-content{grid-template-columns:1fr}
    .product-modal-image{min-height:200px}
    .product-modal-info{padding:24px 20px}

    .contact-layout{grid-template-columns:1fr;gap:24px}

    .footer-top{grid-template-columns:1fr;gap:24px}
    .content{padding:32px 20px 50px}
    table{font-size:.8em}
    .container{padding:0 20px}

    .admin-stats{grid-template-columns:repeat(2,1fr)}
    .admin-grid{grid-template-columns:1fr}
    .admin-topbar{flex-direction:column;gap:12px}
}
@media(max-width:480px){
    header{top:8px;width:calc(100% - 16px);border-radius:10px}

    .hero-title{font-size:2.4em;letter-spacing:-1.5px}
    .hero-stats{flex-direction:column;gap:14px;align-items:center}
    .hero-actions{flex-direction:column;align-items:center}
    .hero-label{font-size:.6em}

    a.logo span,a.logo .logo-accent{display:none}

    .section-cats{gap:4px}
    .section-cat-link{padding:5px 10px;font-size:.7em}

    .product-card{grid-template-columns:1fr;grid-template-rows:140px auto}
    .product-img{min-height:140px}

    .content h2{font-size:1.15em}
    .login-box{padding:20px}
    .section-header h2{font-size:1.3em}

    .admin-stats{grid-template-columns:1fr}
    .admin-chart{height:140px}
}
