:root{--gold:#C9A84C;--gold-light:#F0D590;--gold-dark:#A07828;--dark:#1A1209;--dark2:#2C2010;--dark3:#3D2B0E;--cream:#FBF6EE;--cream2:#F2E8D5;--cream3:#E8D9BE;--text:#3D2B0E;--text-light:#7A6040;--text-muted:#A08060;--white:#FFFFFF;--green:#25D366;--green-dark:#1aaa52;--red:#E53935;--red-bg:#FFEBEE;--blue:#1565C0;--blue-bg:#E3F2FD;--radius:12px;--radius-lg:18px;--shadow:0 4px 24px rgba(26,18,9,0.10);--shadow-lg:0 8px 40px rgba(26,18,9,0.18)}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--text);min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--cream2)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
nav{background:var(--dark);padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100;box-shadow:0 2px 20px rgba(0,0,0,0.3)}
.logo{font-family:'Playfair Display',serif;color:var(--gold);font-size:1.5rem;font-weight:700;letter-spacing:1px;display:flex;align-items:center;gap:8px}
.logo-icon{width:36px;height:36px;background:var(--gold);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.logo span{color:var(--white);font-weight:400}
.nav-right{display:flex;gap:8px;align-items:center}
.nav-btn{background:none;border:1.5px solid rgba(201,168,76,0.5);color:var(--gold);padding:7px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-family:'DM Sans',sans-serif;transition:all 0.2s;display:flex;align-items:center;gap:5px}
.nav-btn:hover{background:var(--gold);color:var(--dark);border-color:var(--gold)}
.nav-btn.primary{background:var(--gold);color:var(--dark);font-weight:600;border-color:var(--gold)}
.nav-btn.primary:hover{background:var(--gold-light)}
.cart-btn{position:relative}
.cart-badge{position:absolute;top:-7px;right:-7px;background:var(--red);color:white;font-size:10px;font-weight:700;width:19px;height:19px;border-radius:50%;display:none;align-items:center;justify-content:center;border:2px solid var(--dark)}
.search-nav{background:rgba(255,255,255,0.07);border:1px solid rgba(201,168,76,0.3);border-radius:8px;padding:7px 12px;color:var(--white);font-family:'DM Sans',sans-serif;font-size:13px;width:200px;outline:none;transition:all 0.2s}
.search-nav::placeholder{color:rgba(255,255,255,0.35)}.search-nav:focus{border-color:var(--gold);width:240px}
.promo-banner{background:var(--gold);padding:10px 2rem;text-align:center;font-size:13px;font-weight:600;color:var(--dark);display:flex;align-items:center;justify-content:center;gap:10px}
.promo-banner span{opacity:0.65;font-weight:400}
.hero{background:linear-gradient(135deg,var(--dark) 0%,var(--dark2) 55%,#3D2810 100%);padding:5rem 2rem 4rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 65% 35%,rgba(201,168,76,0.18) 0%,transparent 65%)}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(transparent,var(--cream))}
.hero-tag{display:inline-block;background:rgba(201,168,76,0.12);border:1px solid rgba(201,168,76,0.4);color:var(--gold);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;padding:6px 18px;border-radius:20px;margin-bottom:1.5rem}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,5.5vw,4rem);color:var(--white);line-height:1.12;margin-bottom:1rem}
.hero h1 em{color:var(--gold);font-style:italic}
.hero p{color:rgba(255,255,255,0.6);font-size:1.05rem;max-width:480px;margin:0 auto 2rem;line-height:1.7}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}
.hero-stats{display:flex;gap:2rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap;position:relative}
.hero-stat{color:rgba(255,255,255,0.7);font-size:13px;text-align:center}
.hero-stat strong{display:block;color:var(--gold);font-size:1.4rem;font-family:'Playfair Display',serif}
.btn-gold{background:var(--gold);color:var(--dark);border:none;padding:13px 26px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;display:inline-flex;align-items:center;gap:6px}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,168,76,0.4)}
.btn-outline-hero{background:rgba(255,255,255,0.07);color:var(--white);border:1.5px solid rgba(255,255,255,0.25);padding:13px 26px;border-radius:10px;font-size:14px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;display:inline-flex;align-items:center;gap:6px}
.btn-outline-hero:hover{border-color:var(--white);background:rgba(255,255,255,0.12)}
.cats-bar{padding:1.5rem 2rem;display:flex;gap:10px;overflow-x:auto;max-width:1200px;margin:0 auto;scrollbar-width:none}
.cats-bar::-webkit-scrollbar{display:none}
.cat-pill{background:var(--white);border:1.5px solid var(--cream3);color:var(--text-light);padding:8px 18px;border-radius:30px;font-size:13px;cursor:pointer;white-space:nowrap;transition:all 0.2s;font-family:'DM Sans',sans-serif;font-weight:500;flex-shrink:0}
.cat-pill:hover,.cat-pill.active{background:var(--dark);color:var(--gold);border-color:var(--dark)}
.section{padding:1rem 2rem 3rem;max-width:1200px;margin:0 auto}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:8px}
.section-title{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--dark)}
.section-sub{color:var(--text-light);font-size:13px}
.sort-select{background:var(--white);border:1.5px solid var(--cream3);border-radius:8px;padding:6px 12px;font-size:13px;font-family:'DM Sans',sans-serif;color:var(--text);cursor:pointer;outline:none}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px}
.product-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(201,168,76,0.1);transition:all 0.25s;position:relative}
.product-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.product-img-wrap{position:relative;height:200px;background:var(--cream2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.product-img-wrap .emoji-display{font-size:4.5rem}
.product-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.product-card:hover .product-img-wrap img{transform:scale(1.05)}
.product-badge{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:6px;text-transform:uppercase;letter-spacing:0.5px}
.badge-new{background:var(--gold);color:var(--dark)}.badge-promo{background:var(--red);color:white}
.badge-stock{position:absolute;top:10px;right:10px;background:rgba(0,0,0,0.55);color:white;font-size:10px;padding:3px 8px;border-radius:6px}
.btn-fav{position:absolute;bottom:10px;right:10px;background:rgba(255,255,255,0.9);border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all 0.2s;box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.btn-fav:hover,.btn-fav.active{background:var(--red);color:white}
.product-body{padding:1rem 1.1rem 1.2rem}
.product-cat{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);font-weight:600;margin-bottom:4px}
.product-name{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--dark);margin-bottom:5px;line-height:1.3;cursor:pointer}
.product-desc{font-size:12px;color:var(--text-light);margin-bottom:10px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}
.product-price{font-size:1.1rem;font-weight:700;color:var(--dark)}
.btn-add{background:var(--dark);color:var(--white);border:none;padding:9px 14px;border-radius:9px;font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;white-space:nowrap;font-weight:500}
.btn-add:hover{background:var(--gold);color:var(--dark)}.btn-add:active{transform:scale(0.96)}
.empty-state{text-align:center;padding:3rem;color:var(--text-light);grid-column:1/-1}
.empty-state .icon{font-size:3.5rem;margin-bottom:1rem}
.fab{display:none;position:fixed;bottom:24px;right:20px;z-index:99;background:var(--green);color:white;border:none;width:56px;height:56px;border-radius:50%;font-size:1.4rem;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,0.3);align-items:center;justify-content:center;transition:transform 0.2s}
.fab:hover{transform:scale(1.1)}.fab-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:white;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:none;align-items:center;justify-content:center}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:200;display:none;backdrop-filter:blur(2px)}.overlay.open{display:block}
.panel{position:fixed;right:0;top:0;bottom:0;width:430px;max-width:96vw;background:var(--white);z-index:201;display:flex;flex-direction:column;transform:translateX(110%);transition:transform 0.32s cubic-bezier(.4,0,.2,1);box-shadow:-12px 0 50px rgba(0,0,0,0.2)}.panel.open{transform:translateX(0)}
.panel-header{padding:1.2rem 1.5rem;background:var(--dark);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.panel-header h2{font-family:'Playfair Display',serif;color:var(--gold);font-size:1.25rem}
.panel-header p{color:rgba(255,255,255,0.45);font-size:12px;margin-top:2px}
.close-btn{background:rgba(255,255,255,0.1);border:none;color:var(--white);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background 0.2s}.close-btn:hover{background:rgba(255,255,255,0.2)}
.panel-body{flex:1;overflow-y:auto;padding:1.2rem 1.5rem}
.cart-item{display:flex;gap:12px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--cream2)}.cart-item:last-child{border-bottom:none}
.cart-item-img{width:58px;height:58px;border-radius:10px;background:var(--cream2);display:flex;align-items:center;justify-content:center;font-size:1.9rem;flex-shrink:0;overflow:hidden;border:1px solid var(--cream3)}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1}.cart-item-name{font-weight:600;font-size:14px;margin-bottom:2px;color:var(--dark)}
.cart-item-price{color:var(--gold);font-size:13px;font-weight:700}.cart-item-unit{color:var(--text-muted);font-size:11px}
.cart-qty{display:flex;align-items:center;gap:8px;margin-top:8px}
.qty-btn{background:var(--cream2);border:none;width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:all 0.15s;font-weight:600}.qty-btn:hover{background:var(--gold);color:var(--dark)}
.qty-num{font-size:14px;font-weight:600;min-width:22px;text-align:center}
.cart-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px;transition:color 0.2s;margin-left:auto}.cart-remove:hover{color:var(--red)}
.panel-footer{padding:1.2rem 1.5rem;border-top:1.5px solid var(--cream2);flex-shrink:0;background:var(--cream)}
.cart-summary{background:var(--white);border-radius:10px;padding:1rem;margin-bottom:1rem;border:1px solid var(--cream2)}
.cart-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-light);margin-bottom:6px}
.cart-row.total{font-size:1.05rem;font-weight:700;color:var(--dark);border-top:1px solid var(--cream2);padding-top:8px;margin-top:4px;margin-bottom:0}
.btn-whatsapp{width:100%;padding:14px;border-radius:11px;border:none;background:var(--green);color:white;font-size:1rem;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;gap:9px;transition:all 0.2s}
.btn-whatsapp:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,211,102,0.35)}
.btn-whatsapp svg{width:21px;height:21px;fill:white;flex-shrink:0}
.cart-note{font-size:11px;color:var(--text-muted);text-align:center;margin-top:8px}
.empty-cart{text-align:center;padding:3rem 1rem;color:var(--text-light)}
.btn-continue{background:var(--dark);color:var(--gold);border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;margin-top:12px;transition:all 0.2s}.btn-continue:hover{background:var(--dark2)}
.modal-bg{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,0.65);display:none;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(3px)}.modal-bg.open{display:flex}
.modal{background:var(--white);border-radius:var(--radius-lg);padding:2rem;width:460px;max-width:100%;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal h2{font-family:'Playfair Display',serif;margin-bottom:1.3rem;color:var(--dark);font-size:1.4rem;display:flex;align-items:center;gap:8px}
.order-recap{background:var(--cream);border-radius:10px;padding:12px;margin-bottom:1.2rem;font-size:13px;color:var(--text-light);max-height:110px;overflow-y:auto}
.order-recap div{margin-bottom:4px}.order-recap strong{color:var(--dark)}
.form-group{margin-bottom:1rem}
label{display:block;font-size:12px;font-weight:600;margin-bottom:5px;color:var(--text);text-transform:uppercase;letter-spacing:0.5px}
input,textarea,select{width:100%;border:1.5px solid var(--cream3);border-radius:8px;padding:10px 12px;font-size:14px;font-family:'DM Sans',sans-serif;color:var(--text);background:var(--cream);transition:border 0.2s;outline:none}
input:focus,textarea:focus,select:focus{border-color:var(--gold);background:var(--white)}
textarea{resize:vertical;min-height:75px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.delivery-opts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:5px}
.delivery-opt{border:1.5px solid var(--cream3);border-radius:8px;padding:10px;cursor:pointer;text-align:center;transition:all 0.2s}
.delivery-opt:hover,.delivery-opt.active{border-color:var(--gold);background:rgba(201,168,76,0.07)}
.delivery-opt .d-icon{font-size:1.4rem;margin-bottom:3px}.delivery-opt .d-label{font-size:12px;font-weight:600;color:var(--dark)}.delivery-opt .d-price{font-size:11px;color:var(--text-light)}
.pay-opts{display:flex;gap:8px;flex-wrap:wrap;margin-top:5px}
.pay-opt{border:1.5px solid var(--cream3);border-radius:8px;padding:8px 14px;cursor:pointer;font-size:12px;font-weight:600;transition:all 0.2s;display:flex;align-items:center;gap:6px}
.pay-opt:hover,.pay-opt.active{border-color:var(--gold);background:rgba(201,168,76,0.08);color:var(--dark)}
.modal-actions{display:flex;gap:10px;margin-top:1.3rem}
.btn-cancel{flex:1;padding:12px;background:var(--cream2);border:none;border-radius:8px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);transition:background 0.2s}.btn-cancel:hover{background:var(--cream3)}
.btn-confirm{flex:2;padding:12px;background:var(--green);color:white;border:none;border-radius:8px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;transition:all 0.2s}.btn-confirm:hover{background:var(--green-dark)}
.admin-panel{position:fixed;left:0;top:0;bottom:0;width:580px;max-width:96vw;background:var(--white);z-index:201;display:flex;flex-direction:column;transform:translateX(-110%);transition:transform 0.32s cubic-bezier(.4,0,.2,1);box-shadow:12px 0 50px rgba(0,0,0,0.2)}.admin-panel.open{transform:translateX(0)}
.tabs{display:flex;flex-shrink:0;background:var(--cream);border-bottom:none}
.tab{flex:1;padding:13px 8px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--text-light);transition:all 0.2s;text-transform:uppercase;letter-spacing:0.5px;position:relative}.tab.active{color:var(--gold);border-bottom:3px solid var(--gold);background:var(--white)}
.tab-content{display:none;flex:1;overflow-y:auto;padding:1.4rem}.tab-content.active{display:block}
.section-h{font-size:13px;font-weight:700;color:var(--dark);margin-bottom:12px;text-transform:uppercase;letter-spacing:0.5px;display:flex;align-items:center;gap:6px}
.btn-full{width:100%;padding:12px;background:var(--gold);color:var(--dark);border:none;border-radius:9px;font-size:14px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-full:hover{background:var(--gold-light)}
.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;margin-top:6px}
.emoji-opt{width:100%;aspect-ratio:1;background:var(--cream2);border:2px solid transparent;border-radius:7px;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s}.emoji-opt.selected,.emoji-opt:hover{border-color:var(--gold);background:var(--cream)}
.product-admin-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--cream);border-radius:9px;margin-bottom:8px;border:1px solid var(--cream2)}
.pimg{width:46px;height:46px;background:var(--white);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0;overflow:hidden;border:1px solid var(--cream3)}.pimg img{width:100%;height:100%;object-fit:cover}
.pinfo{flex:1;min-width:0}.pname{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pmeta{font-size:11px;color:var(--text-light);margin-top:2px}.pprice{color:var(--gold);font-weight:700}
.pbtn{background:none;border:none;cursor:pointer;font-size:1rem;padding:5px 7px;border-radius:5px;transition:background 0.15s;line-height:1}.pbtn:hover{background:var(--cream2)}.pbtn.del:hover{background:var(--red-bg)}
.order-card{background:var(--cream);border-radius:11px;padding:1rem 1.1rem;margin-bottom:12px;border:1.5px solid var(--cream2);}
.order-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.order-id{font-size:11px;color:var(--text-muted);font-family:monospace}.order-date{font-size:11px;color:var(--text-muted)}
.order-name{font-weight:700;font-size:15px;color:var(--dark);margin-bottom:2px}.order-phone{font-size:12px;color:var(--text-light)}
.status-badge{font-size:10px;padding:3px 10px;border-radius:20px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.status-new{background:#E8F5E9;color:#2E7D5E}.status-done{background:var(--blue-bg);color:var(--blue)}.status-cancel{background:var(--red-bg);color:var(--red)}
.status-validated{background:#e8f5e9;color:#1b5e20}.status-not-validated{background:#fff8e1;color:#e65100}
.status-delivered{background:#e3f2fd;color:#0d47a1}.status-not-delivered{background:#fce4ec;color:#880e4f}
.order-items-list{font-size:12px;color:var(--text);margin-top:7px;line-height:1.6}.order-info{font-size:12px;color:var(--text-light);margin-top:5px}
.order-total-line{font-weight:700;color:var(--gold);font-size:14px;margin-top:6px}
.order-actions{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap}
.btn-sm{padding:6px 12px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;border:none;transition:all 0.2s;display:flex;align-items:center;gap:4px}
.btn-sm.wa{background:var(--green);color:white}.btn-sm.wa:hover{background:var(--green-dark)}.btn-sm.done{background:var(--blue-bg);color:var(--blue)}.btn-sm.done:hover{background:#BBD9F7}.btn-sm.del{background:var(--red-bg);color:var(--red)}.btn-sm.del:hover{background:#FFCDD2}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:1.3rem}
.stat-card{background:var(--cream);border-radius:10px;padding:14px;text-align:center;border:1.5px solid rgba(201,168,76,0.2)}
.stat-num{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--gold);font-weight:700;line-height:1}.stat-label{font-size:11px;color:var(--text-light);margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:0.5px}
.search-bar{width:100%;padding:9px 12px;border:1.5px solid var(--cream3);border-radius:8px;margin-bottom:12px;font-family:'DM Sans',sans-serif;font-size:13px;background:var(--cream);outline:none;transition:border 0.2s}.search-bar:focus{border-color:var(--gold)}
.filter-row{display:flex;gap:7px;margin-bottom:12px;flex-wrap:wrap}
.filter-btn{background:var(--white);border:1.5px solid var(--cream3);border-radius:20px;padding:5px 12px;font-size:11px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;color:var(--text-light);transition:all 0.2s}.filter-btn:hover,.filter-btn.active{background:var(--dark);color:var(--gold);border-color:var(--dark)}
.config-box{background:var(--cream);border-radius:11px;padding:1.1rem;margin-bottom:12px;border:1.5px solid var(--cream2)}
.config-box h3{font-size:12px;font-weight:700;margin-bottom:10px;color:var(--dark);text-transform:uppercase;letter-spacing:0.5px;display:flex;align-items:center;gap:6px}
.export-btn{background:var(--dark);color:var(--gold);border:none;padding:9px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;display:flex;align-items:center;gap:5px;margin-bottom:10px}.export-btn:hover{background:var(--dark2)}
.product-modal-bg{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,0.65);display:none;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(3px)}.product-modal-bg.open{display:flex}
.product-modal{background:var(--white);border-radius:var(--radius-lg);width:520px;max-width:100%;max-height:92vh;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}
.pm-img-gallery{position:relative;height:260px;background:var(--cream2);flex-shrink:0;overflow:hidden}
.pm-img-gallery img{width:100%;height:100%;object-fit:cover}
.pm-img-gallery .emoji-big{display:flex;align-items:center;justify-content:center;height:100%;font-size:6rem}
.pm-gallery-thumbs{display:flex;gap:6px;padding:8px 1rem;background:var(--cream2);overflow-x:auto;scrollbar-width:none}
.pm-gallery-thumbs::-webkit-scrollbar{display:none}
.pm-thumb{width:48px;height:48px;border-radius:7px;object-fit:cover;cursor:pointer;border:2px solid transparent;flex-shrink:0;transition:border-color 0.2s}
.pm-thumb.active,.pm-thumb:hover{border-color:var(--gold)}
.pm-body{padding:1.5rem;overflow-y:auto}
.pm-cat{font-size:11px;color:var(--gold);text-transform:uppercase;letter-spacing:1.5px;font-weight:600;margin-bottom:5px}
.pm-name{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--dark);margin-bottom:8px}
.pm-desc{font-size:14px;color:var(--text-light);line-height:1.65;margin-bottom:1.2rem}
.pm-price{font-size:1.6rem;font-weight:700;color:var(--dark);margin-bottom:1.2rem}
.pm-actions{display:flex;gap:10px}
.btn-pm-add{flex:1;background:var(--dark);color:var(--white);border:none;padding:13px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s}.btn-pm-add:hover{background:var(--gold);color:var(--dark)}
.btn-pm-wa{background:var(--green);color:white;border:none;padding:13px 16px;border-radius:10px;cursor:pointer;font-size:1.1rem;transition:background 0.2s}.btn-pm-wa:hover{background:var(--green-dark)}
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(10px);background:var(--dark);color:var(--white);padding:11px 22px;border-radius:10px;font-size:13px;font-weight:500;z-index:999;opacity:0;transition:all 0.3s;pointer-events:none;border-left:3px solid var(--gold);white-space:nowrap;box-shadow:var(--shadow-lg)}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
footer{background:var(--dark);color:rgba(255,255,255,0.45);text-align:center;padding:1.5rem 1rem;font-size:13px;margin-top:2rem}
footer strong{color:var(--gold)}.footer-links{display:flex;gap:1rem;justify-content:center;margin-bottom:8px;flex-wrap:wrap}.footer-links a{color:rgba(255,255,255,0.5);text-decoration:none;font-size:12px;transition:color 0.2s}.footer-links a:hover{color:var(--gold)}

/* === PHOTO UPLOAD === */
.photo-upload-area{border:2px dashed var(--cream3);border-radius:10px;padding:1rem;text-align:center;cursor:pointer;transition:all 0.2s;background:var(--cream);position:relative;margin-bottom:8px}
.photo-upload-area:hover,.photo-upload-area.drag-over{border-color:var(--gold);background:rgba(201,168,76,0.05)}
.photo-upload-area input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.photo-upload-label{font-size:12px;color:var(--text-light);pointer-events:none}
.photo-upload-label span{display:block;font-size:1.5rem;margin-bottom:4px}
.photo-previews{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.photo-preview-item{position:relative;width:70px;height:70px;border-radius:8px;overflow:hidden;border:2px solid var(--cream3)}
.photo-preview-item img{width:100%;height:100%;object-fit:cover}
.photo-preview-remove{position:absolute;top:2px;right:2px;background:rgba(229,57,53,0.9);color:white;border:none;width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;line-height:1}
.photo-preview-main{position:absolute;bottom:2px;left:2px;background:rgba(201,168,76,0.9);color:var(--dark);font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px}

/* === CATEGORIES MANAGER === */
.cats-manager{margin-bottom:1rem}
.cats-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.cat-chip{display:flex;align-items:center;gap:5px;background:var(--cream2);border:1.5px solid var(--cream3);border-radius:20px;padding:5px 10px;font-size:12px;font-weight:500;color:var(--text)}
.cat-chip-label{cursor:default}
.cat-chip-edit{background:none;border:none;cursor:pointer;font-size:11px;color:var(--text-light);padding:0 2px;line-height:1}
.cat-chip-del{background:none;border:none;cursor:pointer;font-size:11px;color:var(--red);padding:0 2px;line-height:1}
.cat-add-row{display:flex;gap:6px;align-items:center}
.cat-add-row input{flex:1;padding:7px 10px;font-size:13px}
.cat-add-btn{background:var(--gold);color:var(--dark);border:none;padding:7px 14px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif}
.cat-select-styled{appearance:none;background:var(--cream) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A6040' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;padding-right:30px}

/* === LOGO IMAGE UPLOAD === */
.logo-upload-row{display:flex;gap:12px;align-items:flex-start}
.logo-preview-wrap{width:64px;height:64px;flex-shrink:0;border-radius:12px;background:var(--dark);display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--cream3)}
.logo-preview-inner{font-size:1.6rem;color:var(--gold);display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.logo-preview-inner img{width:100%;height:100%;object-fit:cover}

/* === APPEARANCE TAB === */
.color-input-row{display:flex;align-items:center;gap:10px}
.color-picker{width:44px;height:38px;border:none;border-radius:8px;cursor:pointer;padding:2px;background:var(--cream2)}
.color-label{font-size:12px;color:var(--text-light)}
.app-radio-group{display:flex;flex-direction:column;gap:7px}
.app-radio{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer}
.app-radio input{accent-color:var(--gold);width:15px;height:15px}

/* undo button for orders */
.btn-sm.undo{background:#FFF3E0;color:#E65100;border:1.5px solid #FFB74D}
.btn-sm.undo:hover{background:#FFE0B2}
.btn-sm.validate{background:#e8f5e9;color:#1b5e20;border:1.5px solid #a5d6a7}.btn-sm.validate:hover{background:#c8e6c9}
.btn-sm.deliver{background:#e3f2fd;color:#0d47a1;border:1.5px solid #90caf9}.btn-sm.deliver:hover{background:#bbdefb}
.btn-sm.receipt{background:#fdf6e3;color:#C9963A;border:1.5px solid #e0c880}.btn-sm.receipt:hover{background:#f7e9b0}
{nav{padding:0 1rem}.search-nav{display:none}.panel,.admin-panel{width:100%;max-width:100%}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.hero{padding:3rem 1rem 2.5rem}.hero h1{font-size:2.2rem}.section{padding:1rem 1rem 2rem}.fab{display:flex}.products-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.product-img-wrap{height:160px}.product-body{padding:0.8rem}.promo-banner{font-size:12px;padding:8px 1rem}}
@media(min-width:641px){.fab{display:none!important}}

/* === DELIVERY TOGGLES === */
.toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border:1.5px solid var(--cream2);border-radius:9px;padding:10px 12px;margin-bottom:8px;cursor:pointer;gap:10px;transition:border-color 0.2s}
.toggle-row:hover{border-color:var(--gold)}
.toggle-info{display:flex;align-items:center;gap:10px;flex:1}
.toggle-info .toggle-icon{font-size:1.3rem;flex-shrink:0}
.toggle-info div{display:flex;flex-direction:column;line-height:1.3}
.toggle-info strong{font-size:13px;color:var(--dark)}
.toggle-info span{font-size:11px;color:var(--text-muted)}
.toggle-cb{appearance:none;-webkit-appearance:none;width:40px;height:22px;background:var(--cream3);border-radius:20px;position:relative;cursor:pointer;transition:background 0.2s;flex-shrink:0;border:none;outline:none}
.toggle-cb::after{content:'';position:absolute;left:3px;top:3px;width:16px;height:16px;background:white;border-radius:50%;transition:transform 0.2s;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.toggle-cb:checked{background:var(--gold)}
.toggle-cb:checked::after{transform:translateX(18px)}

/* === DELIVERY TOGGLES === */
.toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border:1.5px solid var(--cream2);border-radius:9px;padding:10px 12px;margin-bottom:8px;cursor:pointer;gap:10px;transition:border-color 0.2s}
.toggle-row:hover{border-color:var(--gold)}
.toggle-info{display:flex;align-items:center;gap:10px;flex:1}
.toggle-info .toggle-icon{font-size:1.3rem;flex-shrink:0}
.toggle-info div{display:flex;flex-direction:column;line-height:1.3}
.toggle-info strong{font-size:13px;color:var(--dark)}
.toggle-info span{font-size:11px;color:var(--text-muted)}
.toggle-cb{appearance:none;-webkit-appearance:none;width:40px;height:22px;background:var(--cream3);border-radius:20px;position:relative;cursor:pointer;transition:background 0.2s;flex-shrink:0;border:none;outline:none}
.toggle-cb::after{content:'';position:absolute;left:3px;top:3px;width:16px;height:16px;background:white;border-radius:50%;transition:transform 0.2s;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.toggle-cb:checked{background:var(--gold)}
.toggle-cb:checked::after{transform:translateX(18px)}

/* btn-sm variants */
.btn-sm.undo{background:#FFF3E0;color:#E65100;border:1.5px solid #FFB74D}.btn-sm.undo:hover{background:#FFE0B2}
.btn-sm.validate{background:#e8f5e9;color:#1b5e20;border:1.5px solid #a5d6a7}.btn-sm.validate:hover{background:#c8e6c9}
.btn-sm.deliver{background:#e3f2fd;color:#0d47a1;border:1.5px solid #90caf9}.btn-sm.deliver:hover{background:#bbdefb}
.btn-sm.receipt{background:#fdf6e3;color:#C9963A;border:1.5px solid #e0c880}.btn-sm.receipt:hover{background:#f7e9b0}

/* ═══════════════════════════════════
   RESPONSIVE BASE (toutes tailles)
═══════════════════════════════════ */
/* FAB visible seulement mobile */
@media(min-width:641px){.fab{display:none!important}}

/* ═══════════════════════════════════
   MOBILE ≤ 640px
═══════════════════════════════════ */
@media(max-width:640px){

  /* —— NAV —— */
  nav{padding:0 0.85rem;height:56px;gap:6px}
  .search-nav{display:none!important}
  .logo{font-size:1rem;gap:6px}
  .logo-icon{width:28px;height:28px;font-size:0.9rem;border-radius:6px}
  .nav-btn{font-size:11px;padding:6px 9px;gap:3px}
  .nav-right{gap:5px}

  /* —— BANNIÈRE —— */
  .promo-banner{font-size:11px;padding:7px 0.85rem;gap:6px}

  /* —— HERO —— */
  .hero{padding:2.8rem 1rem 3rem}
  .hero-tag{font-size:10px;padding:5px 14px;letter-spacing:1.5px}
  .hero h1{font-size:1.9rem;margin-bottom:0.75rem}
  .hero p{font-size:13px;margin-bottom:1.5rem}
  .hero-actions{gap:8px;flex-direction:row}
  .btn-gold,.btn-outline-hero{padding:11px 18px;font-size:13px}
  .hero-stats{gap:1.2rem;margin-top:2rem}
  .hero-stat strong{font-size:1.1rem}
  .hero-stat{font-size:10px}

  /* —— CATÉGORIES —— */
  .cats-bar{padding:0.75rem 0.85rem;gap:7px}
  .cat-pill{font-size:12px;padding:6px 13px}

  /* —— PRODUITS —— */
  .section{padding:0.75rem 0.85rem 5rem}
  .section-header{flex-direction:column;align-items:flex-start;gap:8px}
  .section-title{font-size:1.4rem}
  .sort-select{width:100%;font-size:12px}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .product-img-wrap{height:148px}
  .product-img-wrap .emoji-display{font-size:3.5rem}
  .product-body{padding:0.65rem 0.75rem 0.8rem}
  .product-cat{font-size:9px}
  .product-name{font-size:0.9rem;margin-bottom:4px}
  .product-desc{font-size:11px;-webkit-line-clamp:1}
  .product-price{font-size:0.95rem}
  .btn-add{font-size:11px;padding:6px 9px;border-radius:7px}
  .btn-fav{width:28px;height:28px;font-size:12px}

  /* —— PRODUCT MODAL —— */
  .product-modal{width:100%;max-width:100%;max-height:95vh;border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;margin:0}
  .product-modal-bg{align-items:flex-end;padding:0}
  .pm-img-gallery{height:210px}
  .pm-body{padding:1.1rem}
  .pm-name{font-size:1.25rem}
  .pm-price{font-size:1.35rem;margin-bottom:1rem}
  .pm-desc{font-size:13px}

  /* —— FAB —— */
  .fab{display:flex!important;width:54px;height:54px;font-size:1.4rem;bottom:18px;right:16px}

  /* —— PANEL PANIER (slide depuis le bas sur mobile) —— */
  .panel{width:100%!important;max-width:100%!important;top:auto;height:92vh;border-radius:20px 20px 0 0;transform:translateY(110%)}
  .panel.open{transform:translateY(0)}
  .panel-header{padding:1rem 1.1rem}
  .panel-header h2{font-size:1.1rem}
  .panel-body{padding:0.9rem 1rem}
  .panel-footer{padding:0.9rem 1rem}

  /* —— PANEL ADMIN (plein écran sur mobile) —— */
  .admin-panel{width:100%!important;max-width:100%!important;border-radius:0;top:0;left:0;right:0;bottom:0;transform:translateX(-110%)}
  .admin-panel.open{transform:translateX(0)}
  .tabs{overflow-x:auto;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab{flex-shrink:0;font-size:10px;padding:10px 8px;white-space:nowrap}
  .tab-content{padding:1rem}
  .form-row{grid-template-columns:1fr}
  .section-h{font-size:12px}

  /* Stats commandes */
  .stats-grid{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:1rem}
  .stat-card{padding:8px 4px;border-radius:8px}
  .stat-num{font-size:1rem}
  .stat-label{font-size:8px;letter-spacing:0}

  /* Filtres commandes */
  .filter-row{gap:5px}
  .filter-btn{font-size:10px;padding:4px 8px}

  /* Actions commandes */
  .order-card{padding:0.8rem}
  .order-name{font-size:13px}
  .order-actions{gap:4px}
  .btn-sm{font-size:10px;padding:4px 7px;gap:2px}

  /* Liste produits admin */
  .product-admin-item{gap:8px;padding:9px}
  .pimg{width:42px;height:42px;font-size:1.4rem;border-radius:6px}
  .pname{font-size:12px}
  .pmeta{font-size:10px}

  /* Emoji grid admin */
  .emoji-grid{grid-template-columns:repeat(7,1fr)}
  .emoji-opt{font-size:1.15rem}

  /* Config boxes */
  .config-box{padding:0.9rem;border-radius:9px}

  /* —— MODAL COMMANDE —— */
  .modal-bg{padding:0;align-items:flex-end}
  .modal{width:100%;max-width:100%;border-radius:20px 20px 0 0;padding:1.3rem 1rem 1.5rem;max-height:92vh}
  .modal h2{font-size:1.2rem;margin-bottom:1rem}
  .delivery-opts{grid-template-columns:1fr 1fr}
  .delivery-opt{padding:8px;gap:4px}
  .delivery-opt .d-icon{font-size:1.2rem}
  .delivery-opt .d-label{font-size:11px}
  .delivery-opt .d-price{font-size:10px}
  .pay-opts{gap:5px}
  .pay-opt{font-size:11px;padding:7px 9px}
  .modal-actions{gap:8px;margin-top:1rem}
  .btn-cancel,.btn-confirm{padding:11px;font-size:13px}

  /* —— MODAL ANNULATION / AUTH —— */
  .order-recap{max-height:80px}

  /* —— PANIER items —— */
  .cart-item{gap:9px;padding:11px 0}
  .cart-item-img{width:50px;height:50px;font-size:1.6rem}
  .cart-item-name{font-size:13px}
  .cart-item-unit{font-size:10px}
  .cart-item-price{font-size:12px}
  .qty-btn{width:24px;height:24px;font-size:14px}
  .qty-num{font-size:13px}
  .cart-summary{padding:0.8rem}
  .cart-row{font-size:12px}
  .cart-row.total{font-size:0.95rem}
  .btn-whatsapp{font-size:0.9rem;padding:13px}

  /* —— TOAST —— */
  .toast{bottom:80px;font-size:12px;padding:9px 18px;white-space:normal;text-align:center;max-width:85vw}

  /* —— FOOTER —— */
  footer{padding:1.2rem 1rem;font-size:12px;margin-top:0}
}

/* ═══════════════════════════════════
   TABLETTE 641px – 1024px
═══════════════════════════════════ */
@media(min-width:641px) and (max-width:1024px){
  nav{padding:0 1.2rem}
  .search-nav{width:170px}
  .hero{padding:4rem 2rem 3.5rem}
  .hero h1{font-size:2.8rem}
  .cats-bar{padding:1.2rem 1.5rem}
  .section{padding:1rem 1.5rem 3rem}
  .products-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .product-img-wrap{height:180px}
  /* Panel panier : glisse depuis la droite, largeur fixe */
  .panel{width:400px;max-width:90vw}
  /* Panel admin : largeur étendue */
  .admin-panel{width:500px;max-width:90vw}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .form-row{grid-template-columns:1fr 1fr}
  .modal{width:460px}
  .product-modal{width:480px}
}

/* ═══════════════════════════════════
   GRAND ÉCRAN > 1024px
═══════════════════════════════════ */
@media(min-width:1025px){
  .products-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
}
