/* ═══════════════════════════════════
   SHREE SHYAM CAFE — style.css
   ═══════════════════════════════════ */
:root{
  --p:#c8522a;--p-lt:#f5e8e2;--p-dk:#8b3415;
  --accent:#f0a500;--dark:#1a1208;--gray:#6b6560;
  --bg:#fdf9f5;--card:#ffffff;--bdr:#e8ddd5;
  --ok:#2d7a4f;--err:#e24b4a;
  --r:14px;--sh:0 4px 20px rgba(0,0,0,.08);--sh-lg:0 12px 40px rgba(0,0,0,.15);
  --fh:'Playfair Display',serif;--fb:'DM Sans',sans-serif;
  --nav:64px;--tr:.22s ease;
}
body.dark{
  --dark:#f0ebe4;--gray:#9a918a;--bg:#131008;
  --card:#1e1a14;--bdr:#2e2820;--p-lt:#2a1a10;
  --sh:0 4px 20px rgba(0,0,0,.5);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);background:var(--bg);color:var(--dark);line-height:1.6;transition:background var(--tr),color var(--tr)}
img{max-width:100%;display:block;object-fit:cover}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:var(--fb);border:none;background:none}
input,textarea,select{font-family:var(--fb)}
ul{list-style:none}
[hidden]{display:none!important}
.muted{color:var(--gray);font-size:.85rem}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}

/* ── Loader ── */
.app-loader{position:fixed;inset:0;z-index:99999;background:linear-gradient(135deg,#1a0a05,#3d1a08);display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
.app-loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-box{text-align:center;color:#fff}
.loader-emoji{font-size:4rem;margin-bottom:.75rem;animation:lp 1.5s infinite}
@keyframes lp{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.loader-name{font-family:var(--fh);font-size:1.6rem;font-weight:700;color:var(--accent);margin-bottom:1.5rem}
.loader-bar{width:200px;height:4px;background:rgba(255,255,255,.2);border-radius:50px;margin:0 auto .75rem;overflow:hidden}
.loader-fill{height:100%;background:var(--accent);border-radius:50px;width:0;transition:width .3s}
.loader-msg{font-size:.83rem;color:rgba(255,255,255,.6)}

/* ── Toast ── */
.toast{position:fixed;top:calc(var(--nav)+10px);right:1.5rem;z-index:9999;background:var(--dark);color:#fff;padding:11px 18px;border-radius:12px;font-size:.875rem;max-width:300px;box-shadow:var(--sh-lg);opacity:0;transform:translateX(110%);pointer-events:none;transition:opacity .3s,transform .3s}
.toast.show{opacity:1;transform:translateX(0);pointer-events:auto}
.toast.ok{background:var(--ok)}.toast.err{background:var(--err)}

/* ── Navbar ── */
#navbar{position:fixed;inset:0 0 auto 0;height:var(--nav);z-index:1000;background:rgba(255,255,255,.97);border-bottom:1px solid var(--bdr);backdrop-filter:blur(10px);transition:background var(--tr),box-shadow var(--tr)}
body.dark #navbar{background:rgba(19,16,8,.97)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;gap:1rem;height:100%}
.logo-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0;padding:0;border:none;background:none;cursor:pointer}
.logo-img{width:42px;height:42px;border-radius:50%;overflow:hidden;background:var(--p);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.logo-img img{width:100%;height:100%}
.logo-name{font-family:var(--fh);font-size:.95rem;font-weight:700;line-height:1.2;color:var(--dark);text-align:left}
.logo-tag{font-size:.68rem;color:var(--gray)}
.nav-links{display:flex;gap:1.6rem;margin:0 auto}
.nav-links a{font-size:.875rem;font-weight:500;color:var(--gray);transition:color var(--tr)}
.nav-links a:hover{color:var(--p)}
.nav-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.icon-btn{width:36px;height:36px;border-radius:50%;background:var(--p-lt);display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background var(--tr)}
.icon-btn:hover{background:var(--bdr)}
.cart-btn{display:flex;align-items:center;gap:6px;background:var(--p);color:#fff;padding:8px 18px;border-radius:50px;font-size:.875rem;font-weight:600;transition:background var(--tr)}
.cart-btn:hover{background:var(--p-dk)}
.cart-badge{background:#fff;color:var(--p);border-radius:50%;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;padding:0 3px}
.ham-btn{display:none;font-size:1.5rem;color:var(--dark);padding:4px}
.mobile-nav{display:none;flex-direction:column;background:var(--card);border-top:1px solid var(--bdr);position:absolute;top:var(--nav);left:0;right:0;z-index:999;box-shadow:var(--sh-lg)}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:.875rem 2rem;font-size:.95rem;font-weight:500;color:var(--gray);border-bottom:1px solid var(--bdr);transition:color var(--tr)}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav a:hover{color:var(--p)}

/* ── Section common ── */
.sec-head{text-align:center;margin-bottom:3rem}
.sec-tag{display:inline-block;color:var(--p);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.5rem}
.accent-tag{color:var(--accent)}.sec-title{font-family:var(--fh);font-size:clamp(1.7rem,4vw,2.6rem);font-weight:700}
.light-title{color:#fff}.sec-sub{color:var(--gray);margin-top:.5rem;font-size:.9rem}

/* ── Hero ── */
.hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,#1a0a05 0%,#3d1a08 50%,#6b2d0a 100%);padding:calc(var(--nav)+2rem) 2rem 3rem;position:relative;overflow:hidden}
.hero-overlay{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .5s;pointer-events:none}
.hero-body{max-width:1200px;margin:0 auto;width:100%;position:relative;z-index:1}
.hero-badge{display:inline-block;background:rgba(200,82,42,.2);color:#f5a372;border:1px solid rgba(200,82,42,.4);padding:6px 16px;border-radius:50px;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1.5rem}
.hero-h1{font-family:var(--fh);font-size:clamp(2rem,5.5vw,4.5rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:1.5rem}
.hero-h1 span{color:var(--accent)}
.hero-p{color:rgba(255,255,255,.75);font-size:1rem;max-width:520px;margin-bottom:2rem;line-height:1.75}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-solid{display:inline-block;background:var(--p);color:#fff;padding:12px 28px;border-radius:50px;font-size:.9rem;font-weight:600;transition:background var(--tr),transform var(--tr);border:none;cursor:pointer}
.btn-solid:hover{background:var(--p-dk);transform:translateY(-2px)}
.btn-solid:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn-solid.sm{padding:8px 16px;font-size:.8rem}
.btn-ghost{display:inline-block;background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5);padding:12px 28px;border-radius:50px;font-size:.9rem;transition:border-color var(--tr),background var(--tr)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;flex-wrap:wrap}
.hstat-n{font-family:var(--fh);font-size:2.1rem;font-weight:700;color:var(--accent)}
.hstat-l{font-size:.75rem;color:rgba(255,255,255,.6);margin-top:2px}

/* ── Alt sections ── */
.alt-sec{padding:4rem 0;background:#fff8f0;border-top:1px solid var(--bdr)}
body.dark .alt-sec{background:var(--card)}
.offer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.offer-card{background:var(--card);border-radius:var(--r);padding:1.4rem;border:1px solid var(--bdr);display:flex;align-items:center;gap:1rem}
.offer-icon{font-size:2.2rem;flex-shrink:0}
.offer-card h3{font-family:var(--fh);font-size:1rem;margin-bottom:3px}
.offer-card p{color:var(--gray);font-size:.83rem}
.offer-badge{background:var(--p);color:#fff;padding:4px 10px;border-radius:50px;font-size:.72rem;font-weight:700;white-space:nowrap;margin-left:auto}

/* ── Menu ── */
.menu-sec{padding:5rem 0}
.menu-controls{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.search-box{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--bdr);border-radius:50px;padding:9px 16px;flex:1;max-width:320px;transition:border-color var(--tr)}
.search-box:focus-within{border-color:var(--p)}
.search-box input{border:none;outline:none;font-size:.875rem;flex:1;background:transparent;color:var(--dark)}
.cat-filter{display:flex;gap:.5rem;flex-wrap:wrap}
.cat-btn{padding:7px 15px;border-radius:50px;border:1.5px solid var(--bdr);background:var(--card);font-size:.8rem;color:var(--gray);font-weight:500;transition:all var(--tr)}
.cat-btn:hover,.cat-btn.active{background:var(--p);color:#fff;border-color:var(--p)}
.food-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:1.5rem}
.loading-msg{grid-column:1/-1;text-align:center;padding:3rem;color:var(--gray)}
.food-card{background:var(--card);border-radius:var(--r);overflow:hidden;border:1px solid var(--bdr);transition:transform var(--tr),box-shadow var(--tr)}
.food-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.fc-img{width:100%;height:155px;background:var(--p-lt);display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;overflow:hidden}
.fc-img img{position:absolute;inset:0;width:100%;height:100%}
.fc-em{position:relative;z-index:1}
.fc-veg{position:absolute;top:8px;left:8px;width:18px;height:18px;border-radius:3px;border:2px solid;background:var(--card);display:flex;align-items:center;justify-content:center;z-index:2}
.fc-veg::after{content:'';width:8px;height:8px;border-radius:50%;display:block}
.fc-veg.veg{border-color:var(--ok)}.fc-veg.veg::after{background:var(--ok)}
.fc-veg.nonveg{border-color:var(--err)}.fc-veg.nonveg::after{background:var(--err)}
.fc-sp{position:absolute;top:8px;right:8px;background:var(--accent);color:#fff;font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:50px;z-index:2}
.fc-body{padding:.875rem 1.1rem 1.1rem}
.fc-cat{font-size:.68rem;color:var(--p);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.fc-name{font-family:var(--fh);font-size:1.05rem;font-weight:600;margin-bottom:4px}
.fc-desc{color:var(--gray);font-size:.8rem;line-height:1.5;margin-bottom:.75rem}
.fc-bot{display:flex;align-items:center;justify-content:space-between}
.fc-price{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--p)}
.add-btn{background:var(--p);color:#fff;padding:7px 14px;border-radius:50px;font-size:.83rem;font-weight:600;transition:background var(--tr)}
.add-btn:hover{background:var(--p-dk)}
.qty-ctrl{display:flex;align-items:center;gap:6px;background:var(--p-lt);border-radius:50px;padding:3px 7px}
.qty-btn{width:25px;height:25px;border-radius:50%;background:var(--p);color:#fff;font-size:.95rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background var(--tr)}
.qty-btn:hover{background:var(--p-dk)}
.qty-n{font-weight:700;font-size:.875rem;min-width:18px;text-align:center;color:var(--p)}

/* ── Info ── */
.info-sec{padding:4rem 0;background:var(--card);border-top:1px solid var(--bdr)}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(228px,1fr));gap:1.5rem}
.info-card{background:var(--bg);border-radius:var(--r);padding:1.5rem;border:1px solid var(--bdr)}
.info-icon{font-size:1.8rem;margin-bottom:.75rem}
.info-card h3{font-family:var(--fh);font-size:1rem;margin-bottom:.75rem}
.irow,.hours-row-d{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--bdr);font-size:.83rem;color:var(--gray)}
.irow:last-child,.hours-row-d:last-child{border-bottom:none}
.irow span:last-child,.hours-row-d span:last-child{font-weight:600;color:var(--dark)}

/* ── About ── */
.about-sec{padding:5rem 0}
.about-body{max-width:720px;margin:0 auto;font-size:1rem;line-height:1.8;color:var(--gray);white-space:pre-wrap}

/* ── Gallery ── */
.gallery-sec{padding:5rem 0}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(188px,1fr));gap:1rem}
.gal-item{border-radius:var(--r);overflow:hidden;aspect-ratio:1;cursor:zoom-in}
.gal-item img{width:100%;height:100%;transition:transform .3s}
.gal-item:hover img{transform:scale(1.06)}

/* ── Reviews ── */
.reviews-sec{padding:5rem 0}
.dark-sec{background:var(--dark)}
body.dark .dark-sec{background:#0e0b06}
.review-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:1.5rem}
.rev-card{background:rgba(255,255,255,.06);border-radius:var(--r);padding:1.5rem;border:1px solid rgba(255,255,255,.1)}
.rev-stars{color:var(--accent);font-size:.95rem;margin-bottom:.75rem}
.rev-txt{color:rgba(255,255,255,.75);font-size:.875rem;line-height:1.7;margin-bottom:1rem}
.rev-by{color:#fff;font-weight:600;font-size:.83rem}

/* ── Contact ── */
.contact-sec{padding:5rem 0}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.contact-cards{display:flex;flex-direction:column;gap:1rem}
.c-card{background:var(--card);border-radius:var(--r);padding:1.2rem 1.4rem;border:1px solid var(--bdr);display:flex;align-items:flex-start;gap:1rem}
.c-icon{width:42px;height:42px;background:var(--p-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.c-card h4{font-family:var(--fh);font-size:.9rem;margin-bottom:3px}
.c-card p{color:var(--gray);font-size:.83rem;line-height:1.5}
.c-card a{color:var(--p)}
.social-row{display:flex;gap:.75rem;flex-wrap:wrap;padding:.25rem 0}
.soc-btn{width:40px;height:40px;border-radius:50%;background:var(--p-lt);display:flex;align-items:center;justify-content:center;transition:background var(--tr),color var(--tr);color:var(--p)}
.soc-btn svg{width:20px;height:20px;display:block}
.soc-btn:hover{color:#fff}
.soc-instagram:hover{background:#E1306C}
.soc-facebook:hover{background:#1877F2}
.soc-youtube:hover{background:#FF0000}
.soc-twitter:hover{background:#000}
.soc-pinterest:hover{background:#E60023}
.map-wrap{border-radius:var(--r);overflow:hidden;min-height:320px;border:1px solid var(--bdr)}
.map-wrap iframe{display:block;min-height:320px}

/* ── Footer ── */
footer{background:var(--dark);color:rgba(255,255,255,.7);padding:3rem 2rem 1.5rem}
body.dark footer{background:#0e0b06}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
.f-logo{font-family:var(--fh);font-size:1.25rem;color:#fff;margin-bottom:.75rem}
.f-tag{font-size:.83rem;line-height:1.7}
footer h4{color:#fff;font-weight:600;margin-bottom:1rem;font-size:.875rem}
.f-links{display:flex;flex-direction:column;gap:.5rem}
.f-links a{color:rgba(255,255,255,.6);font-size:.83rem;transition:color var(--tr)}
.f-links a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.78rem}
.admin-trigger{color:rgba(255,255,255,.3);font-size:.7rem;transition:color var(--tr);padding:4px 8px}
.admin-trigger:hover{color:rgba(255,255,255,.7)}

/* ── Float WA ── */
.float-wa{position:fixed;bottom:2rem;right:2rem;z-index:900;width:54px;height:54px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;font-size:1.7rem;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform var(--tr)}
.float-wa:hover{transform:scale(1.1)}

/* ── Overlay ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:2000;opacity:0;pointer-events:none;transition:opacity .3s}
.overlay.open{opacity:1;pointer-events:auto}

/* ── Cart Drawer ── */
.cart-drawer{position:fixed;top:0;right:-430px;width:420px;max-width:100vw;height:100vh;background:var(--card);z-index:2001;display:flex;flex-direction:column;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh-lg)}
.cart-drawer.open{right:0}
.drawer-head{padding:1.4rem 1.5rem;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.drawer-head h2{font-family:var(--fh);font-size:1.25rem}
.close-x{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--gray);transition:background var(--tr),color var(--tr)}
.close-x:hover{background:var(--p-lt);color:var(--p)}
.cart-body{flex:1;overflow-y:auto;padding:1rem 1.5rem}
.cart-empty-msg{text-align:center;padding:3rem 1rem;color:var(--gray)}
.ce-icon{font-size:3rem;margin-bottom:1rem}
.ci{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--bdr)}
.ci:last-child{border-bottom:none}
.ci-img{width:48px;height:48px;border-radius:10px;flex-shrink:0;background:var(--p-lt);display:flex;align-items:center;justify-content:center;font-size:1.5rem;overflow:hidden}
.ci-img img{width:100%;height:100%}
.ci-det{flex:1;min-width:0}
.ci-name{font-weight:600;font-size:.875rem;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-price{color:var(--p);font-weight:600;font-size:.83rem}
.ci-row{display:flex;align-items:center;gap:8px;margin-top:6px}
.cq-btn{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--bdr);background:var(--card);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all var(--tr)}
.cq-btn:hover{border-color:var(--p);background:var(--p-lt)}
.ci-sub{margin-left:8px;font-weight:700;color:var(--p);font-size:.875rem}
.cart-foot{padding:1.25rem 1.5rem;border-top:1px solid var(--bdr);flex-shrink:0}
.charge-rows{margin-bottom:1.25rem}
.crow{display:flex;justify-content:space-between;padding:4px 0;font-size:.85rem;color:var(--gray)}
.crow.total{border-top:1px solid var(--bdr);margin-top:8px;padding-top:8px;font-size:.95rem;font-weight:700;color:var(--dark)}
.full-w{width:100%}

/* ── Modals ── */
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-60%) scale(.96);width:480px;max-width:95vw;max-height:90vh;background:var(--card);border-radius:20px;z-index:2002;display:flex;flex-direction:column;box-shadow:var(--sh-lg);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}
.modal.open{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}
.modal-head{padding:1.4rem 1.5rem 1rem;border-bottom:1px solid var(--bdr);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.modal-head h2{font-family:var(--fh);font-size:1.25rem}
.modal-body{padding:1.5rem;overflow-y:auto}
.slim-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-60%) scale(.96);width:400px;max-width:95vw;background:var(--card);border-radius:20px;padding:2.5rem;z-index:2002;text-align:center;box-shadow:var(--sh-lg);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}
.slim-modal.open{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}
.modal-icon{font-size:3rem;margin-bottom:1rem}
.slim-modal h2{font-family:var(--fh);font-size:1.4rem;margin-bottom:.4rem}
.modal-sub{color:var(--gray);font-size:.875rem;margin-bottom:1.5rem}
.fb-badge{display:inline-block;padding:2px 8px;border-radius:50px;font-size:.72rem;font-weight:700;background:rgba(240,165,0,.15);color:var(--accent)}
.fb-badge.ok{background:rgba(45,122,79,.15);color:var(--ok)}
.fb-badge.err{background:rgba(226,75,74,.15);color:var(--err)}
.login-err{color:var(--err);font-size:.83rem;margin:.5rem 0}
.login-warn{color:#c47d00;background:#fff8e1;padding:8px 12px;border-radius:8px;font-size:.83rem;margin:.5rem 0}
.btn-ghost-sm{color:var(--gray);font-size:.875rem;margin-top:.5rem;padding:4px}
.btn-ghost-sm:hover{color:var(--p)}
.order-preview{background:var(--bg);border-radius:10px;padding:1rem;margin:1rem 0;font-size:.83rem;color:var(--gray);border:1px solid var(--bdr);line-height:1.8}
.wa-btn{width:100%;background:#25D366;color:#fff;border:none;padding:14px;border-radius:50px;font-size:.95rem;font-weight:700;transition:background var(--tr);margin-top:.75rem;cursor:pointer}
.wa-btn:hover{background:#1da851}
.wa-btn:disabled{opacity:.55;cursor:not-allowed}
.setup-hint{text-align:left;margin-top:1rem;font-size:.8rem;color:var(--gray);background:var(--bg);border-radius:10px;padding:.75rem 1rem;border:1px solid var(--bdr)}
.setup-hint code{background:var(--p-lt);padding:2px 5px;border-radius:4px;color:var(--p);font-size:.78rem}

/* ── Forms ── */
.fgrp{margin-bottom:1rem}
.fgrp label{display:block;font-size:.75rem;font-weight:700;color:var(--gray);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.finput{width:100%;padding:10px 13px;border:1.5px solid var(--bdr);border-radius:10px;font-size:.9rem;background:var(--card);color:var(--dark);transition:border-color var(--tr);resize:vertical}
.finput:focus{outline:none;border-color:var(--p)}
.finput.err{border-color:var(--err);animation:shake .35s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
.fselect{width:100%;padding:10px 13px;border:1.5px solid var(--bdr);border-radius:10px;font-size:.9rem;background:var(--card);color:var(--dark)}
.frow{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:1rem;margin-bottom:0}
.btn-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}
.inline-form{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}
.btn-cancel{background:var(--bdr);color:var(--gray);padding:10px 22px;border-radius:50px;font-size:.875rem;font-weight:600;transition:all var(--tr)}
.btn-cancel:hover{background:var(--err);color:#fff}
.tgl-wrap{position:relative;display:inline-block;width:44px;height:23px;flex-shrink:0}
.tgl-wrap input{opacity:0;width:0;height:0;position:absolute}
.tgl{position:absolute;inset:0;background:var(--bdr);border-radius:50px;cursor:pointer;transition:background .3s}
.tgl::before{content:'';position:absolute;width:17px;height:17px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .3s}
.tgl-wrap input:checked+.tgl{background:var(--p)}
.tgl-wrap input:checked+.tgl::before{transform:translateX(21px)}
.tgl-lbl{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:500;cursor:pointer}
.toggle-row{display:flex;gap:2rem;flex-wrap:wrap;align-items:center;margin-bottom:.5rem}

/* ── Admin Panel ── */
.admin-panel{position:fixed;inset:0;background:#f4f1ed;z-index:4000;display:none;flex-direction:column}
.admin-panel.open{display:flex}
body.dark .admin-panel{background:#181410}
.admin-nav{background:var(--dark);height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;flex-shrink:0}
body.dark .admin-nav{background:#0e0b06}
.admin-nav-title{font-family:var(--fh);color:#fff;font-size:1rem;font-weight:700}
.admin-nav-r{display:flex;align-items:center;gap:.75rem}
.admin-role-badge{background:rgba(240,165,0,.2);color:var(--accent);border:1px solid rgba(240,165,0,.4);padding:3px 12px;border-radius:50px;font-size:.72rem;font-weight:700}
.a-btn-ghost{background:rgba(255,255,255,.12);color:#fff;padding:7px 16px;border-radius:50px;font-size:.83rem;transition:background var(--tr)}
.a-btn-ghost:hover{background:rgba(255,255,255,.22)}
.a-btn-danger{background:rgba(200,82,42,.3);color:#f5a372;padding:7px 16px;border-radius:50px;font-size:.83rem;transition:background var(--tr)}
.a-btn-danger:hover{background:rgba(200,82,42,.5)}
.admin-layout{display:flex;flex:1;overflow:hidden}
.admin-sidebar{width:210px;background:var(--dark);flex-shrink:0;overflow-y:auto;padding:.75rem 0;border-right:1px solid rgba(255,255,255,.06)}
body.dark .admin-sidebar{background:#0e0b06}
.sbar-item{display:block;width:100%;text-align:left;padding:11px 1.5rem;font-size:.83rem;color:rgba(255,255,255,.65);font-weight:500;transition:all var(--tr);border:none;background:none;border-left:3px solid transparent}
.sbar-item:hover{background:rgba(255,255,255,.08);color:#fff}
.sbar-item.active{background:var(--p);color:#fff;border-left-color:rgba(255,255,255,.4)}
.sbar-item.sa-only.hidden{display:none}
.admin-main{flex:1;overflow-y:auto;padding:2rem}
.a-tab{display:none}.a-tab.active{display:block}
.a-title{font-family:var(--fh);font-size:1.45rem;margin-bottom:1.5rem;color:var(--dark)}
.a-card{background:var(--card);border-radius:var(--r);padding:1.75rem;border:1px solid var(--bdr);margin-bottom:1.5rem}
.a-card h3{font-family:var(--fh);font-size:1.05rem;margin-bottom:1.25rem}
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(115px,1fr));gap:1rem}
.dstat{background:var(--card);border-radius:var(--r);padding:1.4rem;border:1px solid var(--bdr);text-align:center}
.dstat-n{font-family:var(--fh);font-size:2rem;font-weight:700;color:var(--p)}
.dstat-l{font-size:.75rem;color:var(--gray);margin-top:4px;font-weight:500}
.tbl-wrap{overflow-x:auto}
.a-table{width:100%;border-collapse:collapse;font-size:.83rem}
.a-table th{text-align:left;padding:9px 12px;background:#f4f1ed;color:var(--gray);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}
body.dark .a-table th{background:var(--bg)}
.a-table td{padding:10px 12px;border-bottom:1px solid var(--bdr);vertical-align:middle}
.a-table tr:last-child td{border-bottom:none}
.t-img{width:40px;height:40px;border-radius:8px;overflow:hidden;background:var(--p-lt);display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.t-img img{width:100%;height:100%}
.t-cat{background:var(--p-lt);color:var(--p);padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;white-space:nowrap}
.act-btn{padding:5px 11px;border-radius:50px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all var(--tr);margin-right:4px}
.act-edit{background:#e8f4fd;color:#1a6ca8;border:none}.act-edit:hover{background:#1a6ca8;color:#fff}
.act-del{background:#fff0ee;color:var(--p);border:1px solid #fcc5b5}.act-del:hover{background:var(--p);color:#fff}
.order-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.filt-btn{padding:7px 15px;border-radius:50px;border:1.5px solid var(--bdr);background:var(--card);font-size:.8rem;color:var(--gray);font-weight:500;cursor:pointer;transition:all var(--tr)}
.filt-btn.active,.filt-btn:hover{background:var(--p);color:#fff;border-color:var(--p)}
.o-card{background:var(--card);border-radius:var(--r);padding:1.25rem 1.5rem;border:1px solid var(--bdr);margin-bottom:1rem}
.o-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}
.o-id{font-family:var(--fh);font-size:.95rem;font-weight:700}
.o-st{padding:4px 12px;border-radius:50px;font-size:.72rem;font-weight:700}
.s-Pending{background:#fff8e1;color:#c47d00}.s-Preparing{background:#fce8d4;color:#8b3415}
.s-Ready{background:#e8f5e9;color:var(--ok)}.s-Delivered{background:#e8f0fe;color:#1a56db}
.s-Cancelled{background:#fce8e8;color:var(--err)}
.o-info{font-size:.83rem;color:var(--gray);margin-bottom:.4rem}
.o-items{font-size:.83rem;color:var(--dark);margin-bottom:.75rem;line-height:1.7}
.o-total{font-size:.875rem;font-weight:700;color:var(--p);margin-bottom:.75rem}
.o-acts{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.o-sel{padding:6px 12px;border:1.5px solid var(--bdr);border-radius:8px;font-size:.83rem;background:var(--card);color:var(--dark);cursor:pointer}
.upload-zone{border:2px dashed var(--bdr);border-radius:12px;padding:1.5rem;text-align:center;cursor:pointer;transition:border-color var(--tr);color:var(--gray);font-size:.875rem}
.upload-zone:hover{border-color:var(--p);color:var(--p)}
.upload-hint{font-size:2.2rem;margin-bottom:.5rem}
.upload-progress{margin-top:1rem}
.progress-bar{background:var(--bdr);border-radius:50px;height:8px;overflow:hidden}
.progress-fill{height:100%;background:var(--p);border-radius:50px;width:0;transition:width .3s}
.progress-txt{font-size:.8rem;color:var(--gray);margin-top:.4rem;text-align:center}
.gal-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:1rem}
.ga-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:1;border:1px solid var(--bdr)}
.ga-item img{width:100%;height:100%}
.ga-del{position:absolute;top:5px;right:5px;background:rgba(226,75,74,.85);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;border:none}
.ga-del:hover{background:var(--err)}
.cat-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.c-tag{display:flex;align-items:center;gap:6px;background:var(--p-lt);color:var(--p);border:1.5px solid var(--p);border-radius:50px;padding:5px 12px;font-size:.8rem;font-weight:600}
.c-tag-x{color:var(--p);cursor:pointer;border:none;background:none;font-size:.9rem;line-height:1;padding:0}
.c-tag-x:hover{color:var(--err)}
.he-row{display:grid;grid-template-columns:130px 1fr 1fr;gap:.75rem;align-items:center;margin-bottom:.75rem}
.he-row label{font-size:.83rem;font-weight:600}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--bdr)}
.setting-row:last-child{border-bottom:none}
.setting-row span{font-size:.875rem;font-weight:500}
.of-item{display:flex;align-items:center;gap:.75rem;padding:10px 0;border-bottom:1px solid var(--bdr);font-size:.875rem}
.of-item:last-child{border-bottom:none}
/* Setup card */
.setup-card{border:2px solid rgba(240,165,0,.3);background:rgba(240,165,0,.04)}
.setup-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}
.setup-step{display:flex;gap:1rem;align-items:flex-start}
.step-n{width:28px;height:28px;border-radius:50%;background:var(--p);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;margin-top:2px}
.setup-step p{color:var(--gray);font-size:.83rem;margin-top:3px;line-height:1.6}
.setup-step strong{font-size:.9rem}
.setup-step code{background:var(--p-lt);padding:2px 6px;border-radius:4px;color:var(--p);font-size:.78rem}
.info-box{background:rgba(200,82,42,.08);border:1px solid rgba(200,82,42,.25);border-radius:10px;padding:1rem;font-size:.83rem;color:var(--p-dk);line-height:1.6}

/* ── Responsive ── */
@media(max-width:920px){
  .nav-links{display:none}.ham-btn{display:block}
  .contact-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .admin-sidebar{display:none}.admin-layout{flex-direction:column}
}
@media(max-width:600px){
  .container{padding:0 1rem}
  .hero{padding:calc(var(--nav)+1.5rem) 1rem 2rem}
  .sec-title{font-size:1.55rem}
  .footer-grid{grid-template-columns:1fr;gap:1.5rem}
  .cart-drawer{width:100vw;right:-100vw}
  .admin-main{padding:1rem}
  .frow{grid-template-columns:1fr}
  .menu-controls{flex-direction:column}.search-box{max-width:100%}
  .hero-stats{gap:1.5rem}
  .food-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}
  .he-row{grid-template-columns:1fr}.he-row label{font-weight:700;margin-bottom:.25rem}
}

/* ── Social preview box (admin) ── */
.soc-preview-box{background:var(--bg);border:1.5px solid var(--bdr);border-radius:10px;padding:1rem;margin:1rem 0;}
/* ── Footer social links ── */
.footer-social{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.75rem;}
.footer-social .soc-btn{background:rgba(255,255,255,.12);color:#fff;}
.footer-social .soc-btn:hover{background:var(--p);}
