/*
Theme Name: Alimento Foods
Theme URI: https://alimentofoods.com
Author: Alimento Foods Enterprises
Author URI: https://alimentofoods.com
Description: A seamless online-store theme for Alimento Foods — premium African food distribution & export. Branded storefront with products, prices, cart, checkout and a built-in Product Manager. Edit products in assets/js/products.js.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: alimento-foods
Tags: e-commerce, full-site, custom-colors, custom-logo, food
*/

/* ============================================================
   ALIMENTO FOODS STORE — STYLES
   Brand colours live in the :root block below.
   ============================================================ */
:root{
  --orange:#F5A300; --orange-d:#d98e00; --green:#7AC70C; --green-d:#5fa400;
  --ink:#1f2a2e; --muted:#6b7780; --line:#e9ecee; --bg:#f6f7f5; --white:#fff;
  --shadow:0 6px 24px rgba(20,30,20,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 18px}
.btn{background:var(--orange);color:#fff;font-weight:700;padding:11px 20px;border-radius:9px;transition:.15s;display:inline-flex;align-items:center;gap:8px;font-size:14px}
.btn:hover{background:var(--orange-d)}
.btn.green{background:var(--green)}.btn.green:hover{background:var(--green-d)}
.btn.ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn.ghost:hover{border-color:var(--orange);color:var(--orange-d)}
.btn.sm{padding:8px 13px;font-size:13px;border-radius:8px}

.announce{background:var(--green);color:#fff;font-size:13px;font-weight:600;text-align:center;padding:7px 10px}

header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.admin-bar header{top:32px}
.hbar{display:flex;align-items:center;gap:20px;padding:13px 0}
.logo img{height:46px;width:auto}
.search{flex:1;display:flex;border:1.6px solid var(--orange);border-radius:10px;overflow:hidden;max-width:560px}
.search input{flex:1;border:none;outline:none;padding:11px 14px;font-size:14px}
.search button{background:var(--orange);color:#fff;padding:0 18px;font-size:18px}
.hicons{display:flex;align-items:center;gap:18px;margin-left:auto}
.hicon{display:flex;flex-direction:column;align-items:center;font-size:11px;color:var(--muted);font-weight:600;position:relative}
.hicon .big{font-size:21px;line-height:1}
.badge{position:absolute;top:-7px;right:-11px;background:var(--green);color:#fff;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.cart-btn .badge{background:var(--orange)}

nav.cats{background:#fff;border-bottom:1px solid var(--line)}
.cats .wrap{display:flex;gap:6px;overflow-x:auto;padding-top:4px;padding-bottom:4px}
.cats a{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;padding:10px 14px;font-size:13.5px;font-weight:600;color:var(--ink);border-bottom:3px solid transparent;cursor:pointer}
.cats a:hover,.cats a.active{color:var(--orange-d);border-color:var(--orange)}
.cats a .ico-badge.sm{background:var(--green)}
.cats a.active .ico-badge.sm,.cats a:hover .ico-badge.sm{background:var(--orange)}

.hero{background:linear-gradient(105deg,#fff7e6 0%,#eefbe0 100%);border-radius:18px;margin-top:22px;padding:46px 44px;display:flex;align-items:center;gap:30px;overflow:hidden}
.hero-txt{flex:1;min-width:0}
.hero .eyebrow{color:var(--green-d);font-weight:800;letter-spacing:.5px;text-transform:uppercase;font-size:13px}
.hero h1{font-size:38px;line-height:1.12;margin:10px 0 12px;color:var(--ink)}
.hero h1 span{color:var(--orange-d)}
.hero p{color:var(--muted);font-size:16px;max-width:480px;margin-bottom:22px}
.hero-art{flex:0 0 320px;display:flex;gap:12px}
.hero-art img{border-radius:14px;box-shadow:var(--shadow);background:#fff}
@media(max-width:860px){.hero-art{display:none}.hero h1{font-size:30px}}

/* ---- flat icon badges (Alimento green) ---- */
.ico-badge{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;min-width:52px;border-radius:14px;background:var(--green);color:#fff;box-shadow:0 4px 12px rgba(122,199,12,.32)}
.ico-badge svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ico-badge.lg{width:62px;height:62px;min-width:62px;border-radius:18px}
.ico-badge.lg svg{width:32px;height:32px}
.ico-badge.sm{width:30px;height:30px;min-width:30px;border-radius:9px}
.ico-badge.sm svg{width:17px;height:17px}
.ico-badge.ghost{background:#eef9dd;color:var(--green-d);box-shadow:none}

.features{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0}
.feat{background:#fff;border-radius:13px;padding:16px 18px;display:flex;gap:13px;align-items:center;box-shadow:var(--shadow)}
.feat h4{font-size:14px}.feat p{font-size:12px;color:var(--muted)}
@media(max-width:860px){.features{grid-template-columns:repeat(2,1fr)}}

.sec{margin:34px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sec-head h2{font-size:23px}
.sec-head .line{flex:1;height:1px;background:var(--line);margin:0 16px}
.sec-head .tag{color:var(--green-d);font-weight:700;font-size:13px}

.catgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.catcard{background:#fff;border-radius:14px;padding:20px 12px;text-align:center;box-shadow:var(--shadow);cursor:pointer;transition:.15s;border:1.5px solid transparent;display:flex;flex-direction:column;align-items:center}
.catcard:hover{transform:translateY(-3px);border-color:var(--orange)}
.catcard:hover .ico-badge{background:var(--orange);box-shadow:0 4px 12px rgba(245,163,0,.32)}
.catcard h4{font-size:13.5px;margin-top:11px}
.catcard p{font-size:11.5px;color:var(--muted)}
@media(max-width:860px){.catgrid{grid-template-columns:repeat(2,1fr)}}

.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:1040px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.pgrid{grid-template-columns:repeat(2,1fr)}}
.card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.15s;position:relative}
.card:hover{transform:translateY(-4px)}
.card .pimg{aspect-ratio:1;background:#fafaf8;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.card .pimg img{width:100%;height:100%;object-fit:cover}
.tile{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff6e3,#eef9dd)}
.tile .te{font-size:54px}
.tile .tn{font-size:11px;color:var(--muted);margin-top:6px;padding:0 10px;text-align:center}
.stockpill{position:absolute;top:10px;left:10px;background:rgba(122,199,12,.95);color:#fff;font-size:10.5px;font-weight:800;padding:3px 9px;border-radius:20px}
.stockpill.out{background:#c0392b}
.salepill{position:absolute;top:10px;right:10px;background:var(--orange);color:#fff;font-size:10.5px;font-weight:800;padding:3px 9px;border-radius:20px}
.card .body{padding:13px 14px 15px;display:flex;flex-direction:column;flex:1}
.card .ccat{font-size:11px;color:var(--green-d);font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.card h3{font-size:14.5px;margin:4px 0 2px;line-height:1.25;min-height:36px}
.card .size{font-size:12px;color:var(--muted)}
.card .priced{margin-top:9px;display:flex;align-items:baseline;gap:7px}
.card .price{font-size:18px;font-weight:800;color:var(--ink)}
.card .old{font-size:13px;color:#aaa;text-decoration:line-through}
.card .add{margin-top:11px;width:100%;justify-content:center}
.card .add[disabled]{background:#cdd2d4;cursor:not-allowed}

.overlay{position:fixed;inset:0;background:rgba(15,22,18,.45);opacity:0;visibility:hidden;transition:.2s;z-index:90}
.overlay.show{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:415px;max-width:92vw;background:#fff;z-index:100;transform:translateX(100%);transition:.25s;display:flex;flex-direction:column;box-shadow:-8px 0 30px rgba(0,0,0,.15)}
.drawer.show{transform:none}
.dhead{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.dhead h3{font-size:18px}
.dclose{font-size:24px;color:var(--muted);width:34px;height:34px;border-radius:8px}
.dclose:hover{background:var(--bg)}
.ditems{flex:1;overflow-y:auto;padding:8px 20px}
.citem{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.citem .ci-img{width:62px;height:62px;border-radius:9px;overflow:hidden;flex:0 0 62px;background:#faf9f6;display:flex;align-items:center;justify-content:center;font-size:30px}
.citem .ci-img img{width:100%;height:100%;object-fit:cover}
.citem .ci-main{flex:1;min-width:0}
.citem h5{font-size:13.5px;line-height:1.25}
.citem .ci-price{color:var(--orange-d);font-weight:800;font-size:13.5px;margin-top:2px}
.qty{display:inline-flex;align-items:center;border:1.4px solid var(--line);border-radius:8px;margin-top:7px}
.qty button{width:28px;height:28px;font-size:16px;font-weight:700;color:var(--ink)}
.qty span{min-width:30px;text-align:center;font-size:13px;font-weight:700}
.ci-rm{color:#c0392b;font-size:12px;font-weight:600;margin-top:6px;cursor:pointer}
.empty{text-align:center;color:var(--muted);padding:60px 20px}
.empty .e-emoji{font-size:50px}
.dfoot{border-top:1px solid var(--line);padding:18px 20px;background:#fff}
.drow{display:flex;justify-content:space-between;font-size:14px;margin-bottom:7px;color:var(--muted)}
.drow.total{font-size:19px;font-weight:800;color:var(--ink);margin:10px 0 4px}
.deliv-note{font-size:11.5px;color:var(--green-d);background:#f0fae0;padding:7px 10px;border-radius:8px;margin-bottom:12px}
.dfoot .btn{width:100%;justify-content:center;font-size:15px;padding:13px}

.modal{position:fixed;inset:0;z-index:110;display:none;align-items:flex-start;justify-content:center;padding:30px 16px;overflow-y:auto}
.modal.show{display:flex}
.mcard{background:#fff;border-radius:16px;width:100%;max-width:560px;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:pop .2s}
@keyframes pop{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.mhead{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.mhead h3{font-size:19px}
.mbody{padding:20px 22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:700;margin-bottom:5px;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--orange)}
.frow{display:flex;gap:12px}.frow .field{flex:1}
.osum{background:var(--bg);border-radius:11px;padding:14px 16px;margin-bottom:16px;max-height:180px;overflow-y:auto}
.osum .orow{display:flex;justify-content:space-between;font-size:13px;padding:4px 0}
.osum .orow.tot{font-weight:800;font-size:15px;border-top:1px solid var(--line);margin-top:6px;padding-top:8px}

.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th,.admin-table td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line)}
.admin-table th{font-size:11.5px;text-transform:uppercase;color:var(--muted);letter-spacing:.4px}
.admin-table tr:hover{background:var(--bg)}
.admin-table .ta-img{width:40px;height:40px;border-radius:7px;object-fit:cover;background:#f3f3ef;display:flex;align-items:center;justify-content:center;font-size:20px}
.mini{padding:5px 10px;font-size:12px;border-radius:7px;font-weight:700;cursor:pointer}
.mini.edit{background:#eef4ff;color:#2a64d8}.mini.edit:hover{background:#dce8ff}
.mini.del{background:#fdeceb;color:#c0392b}.mini.del:hover{background:#fbd9d6}
.admin-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.admin-toolbar input{flex:1;min-width:160px;border:1.5px solid var(--line);border-radius:9px;padding:9px 12px;font-size:13px}
.adm-stats{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.adm-stat{background:var(--bg);border-radius:11px;padding:11px 16px;flex:1;min-width:120px}
.adm-stat .n{font-size:22px;font-weight:800}.adm-stat .l{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}

footer{background:#20312a;color:#cfe0d2;margin-top:50px;padding:46px 0 22px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:30px}
footer h4{color:#fff;font-size:15px;margin-bottom:14px}
footer a,footer p{font-size:13.5px;color:#aebfb1;margin-bottom:8px;cursor:pointer}
footer a:hover{color:var(--orange)}
.flogo{background:#fff;border-radius:10px;padding:10px 12px;display:inline-block;margin-bottom:14px}
.flogo img{height:40px;width:auto}
.fbot{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:18px;text-align:center;font-size:12.5px;color:#8ea394}
@media(max-width:860px){.fgrid{grid-template-columns:1fr 1fr}}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--ink);color:#fff;padding:13px 22px;border-radius:12px;font-size:14px;font-weight:600;z-index:200;opacity:0;transition:.25s;box-shadow:var(--shadow);display:flex;gap:10px;align-items:center}
.toast.show{transform:translateX(-50%);opacity:1}
.hide{display:none!important}

/* ============================================================
   MOBILE / RESPONSIVE
   ============================================================ */
/* WordPress admin bar offset on small screens */
@media screen and (max-width:782px){ .admin-bar header{top:46px} }

@media(max-width:780px){
  .hero{padding:32px 24px;gap:20px}
  .hero h1{font-size:27px}
  .hero p{font-size:15px}
  .sec-head h2{font-size:21px}
}

@media(max-width:640px){
  .announce{font-size:11.5px;padding:7px 9px;line-height:1.35}
  /* header wraps: logo + cart on row 1, search full-width on row 2 */
  .hbar{flex-wrap:wrap;gap:10px 14px;padding:10px 0}
  .logo img{height:38px}
  .search{order:3;flex-basis:100%;max-width:none}
  .hicons{margin-left:auto;gap:16px}
  .hero{padding:24px 18px;margin-top:16px}
  .hero h1{font-size:23px}
  .hero p{font-size:14px;margin-bottom:18px}
  .hero-txt .btn{padding:10px 16px;font-size:13.5px}
  .sec{margin:26px 0}
  .sec-head h2{font-size:19px}
  .sec-head .line{margin:0 12px}
  .features{grid-template-columns:1fr 1fr;gap:10px}
  .feat{padding:13px 12px;gap:11px}
  .feat h4{font-size:13px}.feat p{font-size:11px}
  .ico-badge{width:46px;height:46px;min-width:46px;border-radius:12px}
  .ico-badge svg{width:23px;height:23px}
  .ico-badge.lg{width:54px;height:54px;min-width:54px}
  .ico-badge.lg svg{width:28px;height:28px}
  /* checkout fields stack */
  .frow{flex-direction:column;gap:0}
  .modal{padding:14px 10px}
  .mcard{border-radius:14px}
  .mhead{padding:15px 18px}.mbody{padding:16px 18px}
  /* cart drawer fills the screen */
  .drawer{width:100%;max-width:100%}
  .fgrid{grid-template-columns:1fr 1fr;gap:24px}
}

@media(max-width:430px){
  .wrap{padding:0 14px}
  .pgrid{gap:12px}
  .card h3{font-size:13.5px;min-height:32px}
  .card .price{font-size:16px}
  .card .add{font-size:13px;padding:9px}
  .catgrid{gap:10px}
  .catcard{padding:16px 8px}
  .fgrid{grid-template-columns:1fr;gap:20px}
}

/* ============================================================
   ANIMATED PROMO BANNER (free-delivery) + HERO SLIDER
   ============================================================ */
.promo{position:relative;overflow:hidden;background:linear-gradient(90deg,var(--green-d),var(--green))}
.promo-inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 14px;text-align:center;color:#fff}
.promo-text{font-weight:700;font-size:13.5px;letter-spacing:.2px}
.promo-sub{font-weight:500;opacity:.92;margin-left:8px}
.promo-truck{display:inline-flex;color:#fff;animation:almDrive 3.4s ease-in-out infinite}
.promo-truck svg{width:22px;height:22px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
@keyframes almDrive{0%{transform:translateX(-7px)}50%{transform:translateX(7px)}100%{transform:translateX(-7px)}}
.promo-road{position:absolute;left:0;right:0;bottom:0;height:3px;background-image:repeating-linear-gradient(90deg,#fff 0 14px,transparent 14px 28px);opacity:.5;animation:almRoad .6s linear infinite}
@keyframes almRoad{from{background-position:0 0}to{background-position:28px 0}}
@media(prefers-reduced-motion:reduce){.promo-truck,.promo-road{animation:none}}

.hero-slider{position:relative;margin-top:22px;border-radius:18px;overflow:hidden;background:linear-gradient(105deg,#fff7e6,#eefbe0)}
.slides-track{display:flex;transition:transform .5s ease;will-change:transform}
.slide{min-width:100%}
.slide-inner{display:flex;align-items:center;gap:30px;padding:46px 46px}
.slide-txt{flex:1;min-width:0}
.slide .eyebrow{color:var(--green-d);font-weight:800;letter-spacing:.5px;text-transform:uppercase;font-size:13px}
.slide h1{font-size:34px;line-height:1.13;margin:10px 0 12px;color:var(--ink)}
.slide p{color:var(--muted);font-size:16px;max-width:480px;margin-bottom:20px}
.slide-art{flex:0 0 300px;display:flex;justify-content:center}
.slide-art img{max-height:230px;border-radius:14px;box-shadow:var(--shadow);background:#fff}
.slide-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.9);box-shadow:var(--shadow);font-size:24px;color:var(--ink);display:flex;align-items:center;justify-content:center;z-index:3}
.slide-nav:hover{background:#fff;color:var(--orange-d)}
.slide-nav.prev{left:14px}.slide-nav.next{right:14px}
.slide-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:center;gap:8px;z-index:3}
.slide-dots .dot{width:9px;height:9px;border-radius:50%;background:rgba(31,42,46,.28);transition:.2s;padding:0}
.slide-dots .dot.active{background:var(--orange);width:24px;border-radius:6px}

@media(max-width:780px){ .slide-inner{padding:34px 26px} .slide h1{font-size:27px} }
@media(max-width:640px){
  .hero-slider{margin-top:16px;border-radius:14px}
  .slide-art{display:none}
  .slide-inner{padding:26px 18px 34px}
  .slide h1{font-size:22px}
  .slide p{font-size:14px;margin-bottom:16px}
  .slide-nav{display:none}
  .slide-dots{bottom:10px}
  .promo-text{font-size:12px}
  .promo-sub{display:none}
}

/* footer social icons */
#footerSocial.social{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.social-ico{text-decoration:none}
.social-ico:hover{background:var(--orange)}
#footerContact p{margin-bottom:6px}
