/* ================================================================
   ΚΟΡΙΝΘΙΑ LIVE — PREMIUM PLATFORM (psinodino-inspired)
   ================================================================ */

/* ===== ANIMATIONS ===== */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* Animate on scroll - elements start hidden */
.animate{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.animate.visible{opacity:1;transform:translateY(0)}
.animate-delay-1{transition-delay:.1s}
.animate-delay-2{transition-delay:.2s}
.animate-delay-3{transition-delay:.3s}
.animate-delay-4{transition-delay:.4s}

/* Page load animations */
.hero-text{animation:fadeInUp .8s ease both}
.hero-image{animation:fadeInUp .8s ease .3s both}
.hero-stats{animation:fadeInUp .8s ease .5s both}
.hero-search{animation:scaleIn .6s ease .4s both}

/* Card entrance */
.item-card{opacity:0;animation:fadeInUp .5s ease both}
.item-card:nth-child(1){animation-delay:.05s}
.item-card:nth-child(2){animation-delay:.1s}
.item-card:nth-child(3){animation-delay:.15s}
.item-card:nth-child(4){animation-delay:.2s}
.item-card:nth-child(5){animation-delay:.25s}
.item-card:nth-child(6){animation-delay:.3s}
.item-card:nth-child(7){animation-delay:.35s}
.item-card:nth-child(8){animation-delay:.4s}
.item-card:nth-child(9){animation-delay:.45s}

/* Module tiles entrance */
.module-tile{opacity:0;animation:fadeInUp .5s ease both}
.module-tile:nth-child(1){animation-delay:.05s}
.module-tile:nth-child(2){animation-delay:.1s}
.module-tile:nth-child(3){animation-delay:.15s}
.module-tile:nth-child(4){animation-delay:.2s}
.module-tile:nth-child(5){animation-delay:.25s}
.module-tile:nth-child(6){animation-delay:.3s}
.module-tile:nth-child(7){animation-delay:.35s}
.module-tile:nth-child(8){animation-delay:.4s}
.module-tile:nth-child(9){animation-delay:.45s}

/* Feature cards entrance */
.feature-card{opacity:0;animation:fadeInUp .5s ease both}
.feature-card:nth-child(1){animation-delay:.1s}
.feature-card:nth-child(2){animation-delay:.2s}
.feature-card:nth-child(3){animation-delay:.3s}
.feature-card:nth-child(4){animation-delay:.4s}

/* Section headers */
.section-head{animation:fadeInUp .6s ease both}
.section-title-row{animation:fadeInUp .5s ease both}

/* Listing sidebar slide in */
.listing-sidebar{animation:slideInLeft .5s ease both}
.listing-banner{animation:fadeIn .5s ease both}

/* Smooth page transitions */
main{animation:fadeIn .4s ease both}

/* Loading skeleton shimmer */
.skeleton{background:linear-gradient(90deg,var(--g100) 25%,var(--g200) 50%,var(--g100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}

/* Smooth image load */
.item-cover img{opacity:0;transition:opacity .4s ease}
.item-cover img[src]{opacity:1}
.item-cover img.loaded{opacity:1}

/* Button press effect */
.btn:active{transform:scale(.97)!important;transition:transform .1s}
.menu-add-btn:active{transform:scale(.95)!important}

/* Nav link hover underline animation */
.nav-links a::after{transition:width .3s cubic-bezier(.4,0,.2,1)}

/* Smooth scroll snap for category sidebar */
.shop-cats{scroll-behavior:smooth}
.filter-list{scroll-behavior:smooth}

/* Badge pulse for notifications */
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.notif-badge[style*="display: block"],.notif-badge:not([style*="display: none"]){animation:pulse 2s infinite}
.panel-badge{animation:pulse 2s infinite}

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#e63946;--primary-dark:#c1121f;--primary-light:#ff6b6b;
  --secondary:#1d3557;--success:#2a9d8f;--warning:#f4a261;--danger:#e63946;--info:#0ea5e9;
  --white:#fff;
  --g50:#f8fafc;--g100:#f1f5f9;--g200:#e2e8f0;--g300:#cbd5e1;
  --g400:#94a3b8;--g500:#64748b;--g600:#475569;--g700:#334155;--g800:#1e293b;--g900:#0f172a;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);
  --shadow:0 4px 15px rgba(0,0,0,.08);
  --shadow-md:0 8px 25px rgba(0,0,0,.1);
  --shadow-lg:0 15px 45px rgba(0,0,0,.18);
  --shadow-glow:0 10px 35px rgba(230,57,70,.4);
  --r:12px;--r-lg:16px;--r-xl:20px;--r-full:999px;
  --t:.3s ease;--container:1200px;
}
body{font-family:'Inter',system-ui,sans-serif;color:var(--g800);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--primary);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--primary-dark)}
button{font:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4,h5,h6{font-weight:900;line-height:1.15;color:var(--g900);letter-spacing:-.02em}
h1{font-size:clamp(2rem,5vw,3.8rem)}h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}h3{font-size:1.35rem;font-weight:800}h4{font-size:1.1rem;font-weight:800}
.container{max-width:var(--container);margin:0 auto;padding:0 5%}
hr{border:0;border-top:1px solid var(--g200);margin:24px 0}

/* ================================================================ HEADER */
.site-header{position:fixed;top:0;left:0;right:0;height:70px;background:var(--secondary);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06);z-index:100;display:flex;align-items:center;padding:0 5%;transition:all .3s}
.nav-wrap{width:100%;max-width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;gap:10px;transition:transform var(--t)}
.logo:hover{transform:scale(1.03)}
.logo-text{font-size:20px;font-weight:900;color:#fff;letter-spacing:-.02em;line-height:1}
.logo-text span{color:var(--primary-light)}
.logo-mark{width:44px;height:44px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:12px;display:grid;place-items:center;color:#fff;font-size:22px;font-weight:900;box-shadow:var(--shadow-glow)}
.logo span{color:var(--primary)}
.nav-links{display:flex;gap:32px;align-items:center;list-style:none;flex:1;justify-content:center}
.nav-icon{margin-right:5px;font-size:12px;opacity:.6}
.nav-links a{color:rgba(255,255,255,.75);font-weight:600;font-size:14px;position:relative;transition:all .2s;padding:8px 14px;border-radius:8px}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-links a:hover .nav-icon{opacity:1}
.nav-links a::after{display:none}
.nav-links a.active{color:#fff;background:rgba(255,255,255,.12)}

/* Action buttons */
.nav-action-btn{width:38px;height:38px;border-radius:10px;display:inline-grid;place-items:center;color:rgba(255,255,255,.7);font-size:15px;transition:all .2s;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);text-decoration:none;position:relative}
.nav-action-btn:hover{color:#fff;background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.15)}
.notif-dot{position:absolute;top:3px;right:3px;min-width:16px;height:16px;background:var(--primary);color:#fff;border-radius:50%;font-size:9px;font-weight:800;line-height:16px;text-align:center;border:2px solid var(--secondary)}
.nav-user-btn{width:38px;height:38px;border-radius:50%;overflow:hidden;display:inline-grid;place-items:center;border:2px solid rgba(255,255,255,.2);transition:border-color .2s;text-decoration:none}
.nav-user-btn:hover{border-color:var(--primary)}
.nav-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.nav-avatar-letter{width:100%;height:100%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:grid;place-items:center;font-size:14px;font-weight:800;border-radius:50%}

/* Mega menu */
.nav-links li.has-mega{position:static}
.mega-trigger{display:inline-flex;align-items:center;gap:4px}
.mega-trigger svg{transition:transform var(--t)}
.nav-links li.has-mega:hover .mega-trigger svg{transform:rotate(180deg)}
.mega-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);width:min(780px,96vw);background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.2);padding:24px;display:none;grid-template-columns:repeat(3,1fr);gap:20px;z-index:90}
.mega-menu::before{content:'';position:absolute;top:-14px;left:0;right:0;height:14px}
.nav-links li.has-mega:hover .mega-menu,.nav-links li.has-mega:focus-within .mega-menu{display:grid}
.mega-col-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}
.mega-item{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:10px;transition:all var(--t);color:var(--g800)}
.mega-item:hover{background:var(--g50);color:var(--g900)}
.mega-item::after{display:none!important}
.mega-icon{width:44px;height:44px;border-radius:10px;display:grid;place-items:center;font-size:22px;flex-shrink:0;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.08)}
.mega-item strong{display:block;font-size:14px;font-weight:800;color:var(--g900);margin-bottom:2px}
.mega-item small{display:block;font-size:12px;color:var(--g500);font-weight:500}
.nav-actions{display:flex;align-items:center;gap:10px}
.burger{display:none;width:40px;height:40px;border-radius:8px;align-items:center;justify-content:center;color:#fff}
.burger svg{width:22px;height:22px}

/* ================================================================ BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:700;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 4px 15px rgba(230,57,70,.25)}
.btn-primary:hover{transform:translateY(-2px);color:#fff;box-shadow:var(--shadow-glow)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.2)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary-light);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.18);color:#fff}
.btn-white{background:rgba(255,255,255,.15);backdrop-filter:blur(10px);color:#fff;border-color:rgba(255,255,255,.3)}
.btn-white:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);color:#fff}
.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}
.btn-lg{padding:18px 36px;font-size:16px;font-weight:800;border-radius:14px}
.btn-sm{padding:9px 18px;font-size:13px}.btn-block{width:100%}

/* ================================================================ HERO (dark navy + image) */
.hero{margin-top:70px;min-height:90vh;background:linear-gradient(135deg,var(--secondary) 0%,var(--g900) 100%);position:relative;display:flex;align-items:center;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1504674900247-0877df9cc836?w=1920&h=1080&fit=crop') center/cover;opacity:.15;z-index:0}
.hero-inner{position:relative;z-index:1;max-width:var(--container);margin:0 auto;padding:0 5%;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hero-text h1{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:900;color:#fff;margin-bottom:20px;line-height:1.1}
.hero-text h1 .highlight{background:linear-gradient(135deg,var(--primary),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-text p{font-size:1.15rem;color:rgba(255,255,255,.9);margin-bottom:32px;line-height:1.6}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap}
.hero-search{background:#fff;padding:8px;border-radius:12px;display:flex;gap:6px;box-shadow:0 10px 40px rgba(0,0,0,.3);max-width:560px}
.hero-search input{flex:1;border:0;outline:0;padding:14px 18px;font-size:15px;font-family:inherit;background:transparent;color:var(--g800)}
.hero-search .btn{padding:14px 26px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.stat-box{text-align:center;padding:18px 14px;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2)}
.stat-box .num{font-size:28px;font-weight:900;color:var(--primary-light);margin-bottom:4px;line-height:1}
.stat-box .label{font-size:12px;color:rgba(255,255,255,.8);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.hero-image img{width:100%;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.4);transform:rotate(2deg);transition:transform .3s}
.hero-image:hover img{transform:rotate(0) scale(1.02)}

/* ================================================================ SECTIONS */
.section{padding:90px 0}.section-gray{background:var(--g50)}
.section-dark{background:linear-gradient(135deg,var(--secondary) 0%,var(--g900) 100%);color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-head{text-align:center;margin-bottom:56px}
.section-head .eyebrow{display:inline-block;color:var(--primary);font-weight:800;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;margin-bottom:14px}
.section-head p{font-size:1.1rem;color:var(--g600);max-width:640px;margin:0 auto}
.section-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:36px;flex-wrap:wrap;gap:14px}
.section-title-row h2{font-size:2rem;font-weight:900}
.section-title-row>a{color:var(--primary);font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:6px}
.section-title-row>a:hover{gap:10px}

/* ================================================================ MODULE TILES (image cards) */
.modules-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.module-tile{position:relative;display:block;overflow:hidden;border-radius:20px;aspect-ratio:4/3;color:#fff;transition:all var(--t);box-shadow:0 8px 25px rgba(0,0,0,.08)}
.module-tile:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,.2);color:#fff}
.module-tile-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transition:transform .5s ease}
.module-tile:hover .module-tile-bg{transform:scale(1.08)}
.module-tile-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.85) 100%)}
.module-tile-content{position:absolute;inset:0;z-index:2;padding:22px;display:flex;flex-direction:column;justify-content:space-between}
.module-tile-icon{width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.18);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);display:grid;place-items:center;font-size:26px;align-self:flex-start}
.module-tile-info strong{display:block;font-size:1.2rem;font-weight:900;color:#fff;margin-bottom:4px;line-height:1.2;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.module-tile-info small{font-size:13px;color:rgba(255,255,255,.9);font-weight:600;display:inline-flex;align-items:center;gap:6px}
.module-tile-info small::after{content:'→';transition:transform var(--t)}
.module-tile:hover .module-tile-info small::after{transform:translateX(4px)}

/* ================================================================ FEATURE CARDS (4-col) */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:28px}
.feature-card{background:#fff;padding:35px 25px;border-radius:var(--r-lg);text-align:center;box-shadow:var(--shadow);transition:all var(--t)}
.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.feature-icon{width:70px;height:70px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:var(--r-lg);display:grid;place-items:center;font-size:32px;color:#fff;margin:0 auto 20px;box-shadow:0 8px 20px rgba(230,57,70,.25)}
.feature-card h3{font-size:18px;font-weight:800;color:var(--g900);margin-bottom:12px}
.feature-card p{font-size:14px;color:var(--g600);line-height:1.6}

/* ================================================================ LISTING (sidebar + results) */
.listing-wrap{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 70px)}
/* Sidebar — psinodino business style */
.listing-sidebar{
  background:var(--secondary);border-radius:0;padding:0;
  box-shadow:2px 0 15px rgba(0,0,0,.08);
  border:0;
  position:sticky;top:70px;height:calc(100vh - 70px);overflow-y:auto;
}
.listing-sidebar::-webkit-scrollbar{width:6px}.listing-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:3px}
.listing-sidebar h4{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.3);
  margin:0;padding:18px 18px 10px;border:0;
}
.listing-sidebar .filter-group{margin-bottom:0;border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:6px}
.filter-search{position:relative;margin:0;padding:14px 14px 10px}
.filter-search input{
  width:100%;padding:11px 14px 11px 38px;font-size:14px;
  border:1.5px solid rgba(255,255,255,.12);border-radius:10px;
  background:rgba(255,255,255,.06);outline:0;transition:all var(--t);font-weight:500;
  color:#fff;
}
.filter-search input::placeholder{color:rgba(255,255,255,.4)}
.filter-search input:focus{border-color:var(--primary);background:rgba(255,255,255,.1);box-shadow:0 0 0 4px rgba(230,57,70,.15)}
.filter-search::before{content:'\f002';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;left:26px;top:50%;transform:translateY(-50%);font-size:13px;color:rgba(255,255,255,.4);pointer-events:none}
.filter-list{list-style:none;display:flex;flex-direction:column;gap:0;max-height:300px;overflow-y:auto;padding:0 0 4px}
.filter-list::-webkit-scrollbar{width:5px}.filter-list::-webkit-scrollbar-thumb{background:var(--g200);border-radius:3px}
.filter-list a{
  display:flex;align-items:center;gap:10px;
  padding:10px 18px;color:rgba(255,255,255,.6);font-size:13px;font-weight:500;
  border-left:3px solid transparent;transition:all .15s;text-decoration:none;
}
.filter-list a:hover{background:rgba(255,255,255,.06);color:#fff}
.filter-list a.active{
  background:var(--primary);color:#fff;
  border-left-color:#fff;font-weight:700;
}
.filter-list a .count{
  margin-left:auto;font-size:10px;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.4);
  padding:2px 8px;border-radius:10px;font-weight:700;
  min-width:22px;text-align:center;
}
.filter-list a.active .count{background:rgba(255,255,255,.25);color:#fff}
.filter-list a .item-icon{font-size:18px;width:22px;text-align:center;flex-shrink:0}
.filter-list a .item-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Sidebar components */
.sb-section{padding:14px 16px;}
.sb-link{display:flex;align-items:center;gap:10px;padding:9px 16px;color:rgba(255,255,255,.6);font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;border-left:3px solid transparent;}
.sb-link:hover{background:rgba(255,255,255,.06);color:#fff;}
.sb-link.active{background:var(--primary);color:#fff;border-left-color:#fff;font-weight:700;}
.sb-icon{width:18px;text-align:center;font-size:13px;opacity:.7;}
.sb-emoji{font-size:16px;width:22px;text-align:center;}
.sb-count{margin-left:auto;font-size:10px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.4);padding:2px 7px;border-radius:10px;font-weight:700;}
.sb-link.active .sb-count{background:rgba(255,255,255,.25);color:#fff;}
.sb-group{border-top:1px solid rgba(255,255,255,.06);}
.sb-group-title{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;font-size:11px;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.8px;cursor:pointer;transition:color .15s;user-select:none;}
.sb-group-title:hover{color:rgba(255,255,255,.6);}
.sb-arrow{font-size:10px;transition:transform .2s;color:rgba(255,255,255,.2);}
.sb-group.collapsed .sb-arrow{transform:rotate(-90deg);}
.sb-group-links{overflow:hidden;transition:max-height .3s ease;max-height:0;}
.sb-group.open .sb-group-links{max-height:2000px;}
.sb-group.collapsed .sb-group-links{max-height:0!important;}
.sb-arrow{transform:rotate(-90deg);}
.sb-group.open .sb-arrow{transform:rotate(0);}
.listing-results{min-width:0;padding:28px;background:var(--g50)}
.listing-banner{
  background:linear-gradient(135deg,var(--secondary),var(--g900));
  border-radius:var(--r-lg);padding:28px;margin-bottom:24px;
  color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  box-shadow:0 6px 24px rgba(29,53,87,.3);
}
.listing-banner h1{font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:800;color:#fff;margin-bottom:4px}
.listing-banner .count-text{font-size:14px;color:rgba(255,255,255,.8);font-weight:500}
.results-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--g200)}
.results-head h1{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:900;margin-bottom:4px}
.results-head .count-text{color:var(--g600);font-size:14px;font-weight:500}
.sort-select{padding:10px 38px 10px 14px;font-size:14px;font-weight:600;border:1.5px solid var(--g200);border-radius:10px;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23334155' stroke-width='2' viewBox='0 0 24 24'><path d='m6 9 6 6 6-6'/></svg>") no-repeat right 12px center/14px;outline:0;cursor:pointer;appearance:none;-webkit-appearance:none;font-family:inherit;color:var(--g800)}
.active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;align-items:center}
.chip{display:inline-flex;align-items:center;gap:6px;background:rgba(230,57,70,.08);color:var(--primary-dark);padding:6px 12px;border-radius:var(--r-full);font-size:13px;font-weight:700}
.chip a{color:var(--primary-dark);opacity:.7;font-weight:900;font-size:16px;line-height:1;margin-left:2px}.chip a:hover{opacity:1}
.clear-filters{font-size:13px;color:var(--g600);text-decoration:underline;font-weight:600}
.mobile-filters-toggle{display:none;background:#fff;padding:14px 18px;border-radius:10px;border:1.5px solid var(--g200);font-weight:700;width:100%;margin-bottom:14px;align-items:center;justify-content:space-between}
@media(max-width:960px){.listing-wrap{grid-template-columns:1fr}.listing-sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--g200);display:none}.listing-sidebar.open{display:block}.mobile-filters-toggle{display:flex}}

/* ================================================================ CARDS */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:26px}
.item-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);transition:all var(--t);display:flex;flex-direction:column;cursor:pointer;border:1px solid transparent}
.item-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.item-cover{height:220px;background:var(--g100);position:relative;overflow:hidden}
.item-cover img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.item-card:hover .item-cover img{transform:scale(1.08)}
.item-cover .badge-absolute{position:absolute;top:14px;left:14px;z-index:2}
.item-body{padding:22px;flex:1;display:flex;flex-direction:column;gap:10px}
.item-title{font-size:19px;font-weight:800;color:var(--g900);line-height:1.3;letter-spacing:-.01em}
.item-meta{display:flex;gap:14px;font-size:13px;color:var(--g600);flex-wrap:wrap;font-weight:500}
.item-meta span{display:inline-flex;align-items:center;gap:4px}
.item-desc{font-size:14px;color:var(--g600);line-height:1.55;flex:1}
.item-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;margin-top:4px;border-top:1px solid var(--g100);gap:8px}
.rating{display:inline-flex;align-items:center;gap:4px;font-weight:800;font-size:14px;color:var(--g900);font-variant-numeric:tabular-nums}
.rating::before{content:'★';color:var(--warning)}
.product-card .item-cover{height:240px}
.menu-price{font-size:22px;font-weight:900;color:var(--primary)}
.event-card{position:relative}
.event-date{position:absolute;top:14px;left:14px;z-index:3;background:#fff;border-radius:10px;padding:10px 12px;text-align:center;box-shadow:var(--shadow);min-width:56px}
.event-date strong{display:block;font-size:1.6rem;font-weight:900;color:var(--primary);line-height:1}
.event-date small{font-size:11px;text-transform:uppercase;font-weight:800;color:var(--g700);letter-spacing:.05em}

/* ================================================================ BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:var(--r-full);font-size:11px;font-weight:800;line-height:1.4;text-transform:uppercase;letter-spacing:.04em}
.badge-primary{background:rgba(230,57,70,.08);color:var(--primary-dark)}
.badge-success{background:rgba(42,157,143,.1);color:#1d6a5f}
.badge-warning{background:rgba(244,162,97,.15);color:#9a5a1e}
.badge-info{background:rgba(14,165,233,.1);color:#075985}
.badge-dark{background:var(--g900);color:#fff}
.badge-featured{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 4px 12px rgba(230,57,70,.3)}

/* Force 24h time input - hide AM/PM field on webkit browsers */
input[type="time"]::-webkit-datetime-edit-ampm-field{display:none!important;width:0!important;padding:0!important;margin:0!important}
input[type="time"]{font-variant-numeric:tabular-nums}

/* ================================================================ FORMS */
.form-group{margin-bottom:22px}
.form-label{display:block;font-weight:700;font-size:14px;margin-bottom:10px;color:var(--g800);letter-spacing:.2px}
.form-control,.form-select,textarea.form-control{width:100%;padding:16px 20px;font-size:16px;border:2px solid #e5e7eb;border-radius:12px;background:#fafbfc;color:var(--g900);font-family:inherit;transition:all .2s;outline:0;-webkit-appearance:none}
.form-control:hover,.form-select:hover{border-color:#cbd5e1}
.form-control:focus,.form-select:focus,textarea.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(230,57,70,.08);background:#fff}
.form-control::placeholder,textarea.form-control::placeholder{color:#94a3b8;font-weight:400}
textarea.form-control{min-height:140px;resize:vertical;line-height:1.7}
.form-help{font-size:13px;color:var(--g500);margin-top:6px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:640px){.form-row{grid-template-columns:1fr}}

/* ================================================================ AUTH */
.auth-wrap{min-height:calc(100vh - 70px);display:grid;place-items:center;padding:40px 20px;background:linear-gradient(135deg,var(--g50) 0%,#fff 100%)}
.auth-card{width:100%;max-width:460px;background:#fff;padding:44px;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.12);border:1px solid var(--g100)}
.auth-card h2{font-size:1.9rem;font-weight:900;margin-bottom:8px}
.auth-card .auth-subtitle{color:var(--g600);margin-bottom:28px}
.auth-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--g600)}

/* ================================================================ ALERTS */
.alert{padding:14px 18px;border-radius:10px;font-size:14px;font-weight:500;margin-bottom:16px;border-left:4px solid}
.alert-success{background:#ecfdf5;color:#065f46;border-color:var(--success)}
.alert-danger{background:#fef2f2;color:#991b1b;border-color:var(--danger)}
.alert-warning{background:#fffbeb;color:#92400e;border-color:var(--warning)}
.alert-info{background:#f0f9ff;color:#075985;border-color:var(--info)}

/* ================================================================ PAGE HERO */
.page-hero{padding:50px 0 40px;background:linear-gradient(135deg,var(--g50) 0%,#fff 100%);border-bottom:1px solid var(--g200)}
.page-hero h1{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;margin-bottom:8px}
.page-hero p{color:var(--g600);font-size:1rem}

/* ================================================================ SHOP 3-COL LAYOUT */
.shop-layout{display:grid;grid-template-columns:220px 1fr 360px;min-height:calc(100vh - 70px)}
.shop-cats{background:var(--secondary);padding:0;position:sticky;top:70px;height:calc(100vh - 70px);overflow-y:auto;border-right:0}
.shop-cats-title{font-size:11px;font-weight:700;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1px;padding:20px 20px 12px}
.cat-link{display:flex;align-items:center;gap:10px;padding:13px 20px;color:rgba(255,255,255,.7);font-size:14px;font-weight:500;border-left:3px solid transparent;transition:all .2s;cursor:pointer;text-decoration:none}
.cat-link:hover{background:rgba(255,255,255,.08);color:#fff}
.cat-link.active{background:var(--primary);color:#fff;border-left-color:transparent}
.cat-link .item-text{flex:1}
.cat-link .num{margin-left:auto;font-size:11px;background:rgba(255,255,255,.15);color:rgba(255,255,255,.8);padding:2px 8px;border-radius:10px;font-weight:700}
.cat-link.active .num{background:rgba(255,255,255,.25);color:#fff}
.cat-link:hover{background:var(--g50);color:var(--g900)}
.cat-link.active{background:rgba(230,57,70,.05);color:var(--primary);border-left-color:var(--primary);font-weight:700}
.cat-link .num{margin-left:auto;font-size:11px;background:var(--g200);color:var(--g600);padding:2px 8px;border-radius:10px;font-weight:700}
.cat-link.active .num{background:var(--primary);color:#fff}
.shop-main{padding:24px;overflow-y:auto;background:var(--g50)}
/* Shop Header Card */
.shop-header-card{border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.08);margin-bottom:28px}
.shop-cover{height:180px;background-size:cover;background-position:center;position:relative}
.shop-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.5) 100%)}
.shop-header-body{padding:20px 24px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:20px}
.shop-header-left{display:flex;gap:16px;align-items:center}
.shop-header-logo{width:64px;height:64px;border-radius:14px;object-fit:cover;border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.1);margin-top:-44px;position:relative;z-index:2;background:#fff;flex-shrink:0}
.shop-header-name{font-size:22px;font-weight:800;color:var(--g900);margin-bottom:6px}
.shop-header-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--g500);font-weight:500}
.shop-header-meta i{margin-right:4px;font-size:12px}
.shop-open{color:var(--success);font-weight:700}
.shop-open i{font-size:8px;vertical-align:middle;margin-right:4px}
.shop-closed{color:var(--danger);font-weight:700}
.shop-closed i{font-size:8px;vertical-align:middle;margin-right:4px}
.shop-header-stats{display:flex;gap:16px}
.shs{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--g50);border-radius:10px;border:1px solid var(--g200)}
.shs-icon{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;font-size:14px;flex-shrink:0}
.shs:nth-child(1) .shs-icon{background:#fef3c7;color:#d97706}
.shs:nth-child(2) .shs-icon{background:#dbeafe;color:#2563eb}
.shs:nth-child(3) .shs-icon{background:#d1fae5;color:#059669}
.shs strong{display:block;font-size:16px;font-weight:800;color:var(--g900);line-height:1.2}
.shs small{display:block;font-size:11px;color:var(--g500);font-weight:500}
@media(max-width:768px){.shop-header-body{flex-direction:column}.shop-header-stats{width:100%}.shop-cover{height:140px}}
.menu-section{margin-bottom:36px;scroll-margin-top:90px}
.menu-section-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:12px;border-bottom:2px solid var(--g200)}
.menu-section-icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-light));display:grid;place-items:center;color:#fff;font-size:20px}
.menu-section-title{font-size:20px;font-weight:800;color:var(--g900)}
.menu-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.menu-product{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.06);transition:all .2s;display:flex;flex-direction:column}
.menu-product:hover{transform:translateY(-4px);box-shadow:0 10px 25px rgba(0,0,0,.1)}
.menu-product-img{height:150px;background:var(--g100);position:relative}
.menu-product-img img{width:100%;height:100%;object-fit:cover}
.menu-product-img .placeholder{height:100%;display:grid;place-items:center;font-size:52px;background:linear-gradient(135deg,#fef2f2,#fff)}
.menu-product-body{padding:14px;flex:1;display:flex;flex-direction:column}
.menu-product-name{font-size:15px;font-weight:700;color:var(--g900);margin-bottom:4px}
.menu-product-desc{font-size:12px;color:var(--g500);line-height:1.5;margin-bottom:12px;flex:1}
/* Product options inside card */
.product-options{margin:8px 0 10px;padding:10px;background:var(--g50);border-radius:8px;border:1px solid var(--g100)}
.opt-group{margin-bottom:10px}.opt-group:last-child{margin-bottom:0}
.opt-group-name{font-size:12px;font-weight:800;color:var(--g700);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.opt-req{color:var(--primary);font-weight:900}
.opt-label{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--g700);transition:background .15s}
.opt-label:hover{background:var(--g100)}
.opt-label input{accent-color:var(--primary);width:16px;height:16px;flex-shrink:0}
.opt-name{flex:1}
.opt-price{font-size:12px;font-weight:700;color:var(--primary);white-space:nowrap}
/* Options Modal */
.opt-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:200;display:none;align-items:flex-end;justify-content:center;padding:0;opacity:0;transition:opacity .25s}
.opt-modal-overlay.active{display:flex;opacity:1}
.opt-modal{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:600px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 -8px 40px rgba(0,0,0,.2);transform:translateY(30px);transition:transform .3s}
.opt-modal-overlay.active .opt-modal{transform:translateY(0)}
.opt-modal-header{padding:28px 28px 18px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border-bottom:2px solid #f1f3f8}
.opt-modal-header h3{font-size:22px;font-weight:900;color:#1a1a2e;margin-bottom:4px}
.opt-modal-header p{font-size:14px;color:#64748b}
.opt-modal-close{width:44px;height:44px;border-radius:12px;background:#f1f5f9;display:grid;place-items:center;font-size:18px;color:#475569;cursor:pointer;transition:all .2s;border:0;flex-shrink:0}
.opt-modal-close:hover{background:#ef4444;color:#fff}
.opt-modal-body{padding:24px 28px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.opt-modal-body .opt-group{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f1f3f8}
.opt-modal-body .opt-group:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.opt-modal-body .opt-group-name{font-size:15px;font-weight:900;color:#1a1a2e;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.opt-modal-body .opt-req{font-size:11px;font-weight:700;color:var(--primary);background:rgba(230,57,70,.08);padding:3px 10px;border-radius:20px}
.opt-modal-body .opt-label{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:14px;cursor:pointer;font-size:15px;font-weight:500;color:#334155;transition:all .15s;margin-bottom:6px;border:2px solid #f1f3f8;background:#fafbfc}
.opt-modal-body .opt-label:hover{background:#fff;border-color:#e2e8f0}
.opt-modal-body .opt-label:has(input:checked){background:#fef2f2;border-color:#e31837}
.opt-modal-body .opt-label input{accent-color:var(--primary);width:20px;height:20px;flex-shrink:0}
.opt-modal-body .opt-name{flex:1;font-weight:600}
.opt-modal-body .opt-price{font-size:14px;font-weight:800;color:var(--primary);white-space:nowrap}
.opt-modal-footer{padding:20px 28px;border-top:2px solid #f1f3f8;background:#fafbfc;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-shrink:0;position:sticky;bottom:0;z-index:2;}
.opt-modal-price span{font-size:12px;color:#94a3b8;display:block}
.opt-modal-price strong{font-size:24px;font-weight:900;color:#1a1a2e}
.opt-modal-footer .menu-add-btn{border-radius:14px;padding:16px 32px;font-size:16px}
.opt-qty-wrap{display:flex;align-items:center;gap:0;background:#f1f5f9;border-radius:10px;overflow:hidden;border:2px solid #e2e8f0;}
.opt-qty-btn{width:36px;height:36px;border:none;background:none;font-size:18px;font-weight:900;color:#475569;cursor:pointer;display:grid;place-items:center;transition:all .15s;}
.opt-qty-btn:hover{background:#e2e8f0;color:#e31837;}
.opt-qty-input{width:36px;height:36px;border:none;background:#fff;text-align:center;font-size:15px;font-weight:800;color:#1a1a2e;-moz-appearance:textfield;}
.opt-qty-input::-webkit-outer-spin-button,.opt-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
@media(min-width:601px){.opt-modal-overlay{align-items:center;padding:20px}.opt-modal{border-radius:24px;max-height:88vh}}

.menu-product-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.menu-product-price{font-size:18px;font-weight:900;color:var(--primary)}
.menu-add-btn{background:var(--primary);color:#fff;border:0;padding:8px 14px;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}
.menu-add-btn:hover{background:var(--primary-dark);transform:scale(1.05)}
.menu-add-btn:disabled{background:var(--g300);cursor:not-allowed}
/* Cart panel */
.cart-panel{background:#fff;border-left:1px solid var(--g200);position:sticky;top:70px;height:calc(100vh - 70px);display:flex;flex-direction:column}
.cart-panel-header{padding:18px;border-bottom:1px solid var(--g200);display:flex;align-items:center;gap:10px}
.cart-panel-header .icon{color:var(--primary);font-size:20px}
.cart-panel-header h2{font-size:18px;font-weight:800;color:var(--g900);flex:1}
.cart-count-badge{background:var(--primary);color:#fff;font-size:12px;font-weight:800;padding:3px 10px;border-radius:20px}
.cart-panel-items{flex:1;overflow-y:auto;padding:14px 18px}
.cart-empty{text-align:center;padding:50px 20px;color:var(--g400)}.cart-empty .icon{font-size:48px;margin-bottom:12px;display:block}.cart-empty p{font-size:14px}
.cart-line{display:flex;align-items:flex-start;gap:10px;padding:12px 0;border-bottom:1px solid var(--g100)}
.cart-line-qty{width:26px;height:26px;background:var(--primary);color:#fff;border-radius:6px;display:grid;place-items:center;font-size:12px;font-weight:800;flex-shrink:0}
.cart-line-info{flex:1;min-width:0}
.cart-line-name{font-size:13px;font-weight:600;color:var(--g900)}
.cart-line-price{font-size:13px;font-weight:700;color:var(--g800)}
.cart-line-del{background:0;border:0;color:var(--g400);cursor:pointer;padding:4px}.cart-line-del:hover{color:var(--primary)}
.cart-panel-footer{padding:16px 18px;background:var(--g50);border-top:1px solid var(--g200);flex-shrink:0;position:sticky;bottom:0;}
.cart-summary{margin-bottom:14px}
.cart-summary-row{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px;color:var(--g600)}
.cart-summary-row.total{border-top:1px solid var(--g200);padding-top:10px;margin-top:10px;font-size:17px;font-weight:900;color:var(--g900)}
.cart-summary-row.total span:last-child{color:var(--primary)}
.cart-checkout-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:0;border-radius:10px;font-weight:800;font-size:15px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px rgba(230,57,70,.3);font-family:inherit;display:block;text-align:center;text-decoration:none}
.cart-checkout-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);color:#fff}
@media(max-width:1100px){
  .shop-layout{grid-template-columns:200px 1fr}
  .cart-panel{display:none}
  .cart-mobile-btn{display:flex}
}
@media(max-width:720px){
  .shop-layout{grid-template-columns:1fr}
  .shop-cats{position:sticky;top:70px;height:auto;border-right:0;border-bottom:1px solid var(--g200);display:flex;overflow-x:auto;padding:10px 14px;gap:8px;-webkit-overflow-scrolling:touch;background:var(--secondary);z-index:50}
  .shop-cats-title{display:none}
  .cat-link{flex-shrink:0;border-left:0;border-bottom:2px solid transparent;padding:8px 14px;border-radius:10px;background:rgba(255,255,255,.08);color:#fff}
  .cat-link.active{border-left:0;background:var(--primary);color:#fff}
  .cat-link.active .num{background:#fff;color:var(--primary)}
  .shop-header-stats{gap:8px;flex-wrap:wrap}
  .shop-header-stats>div{padding:8px 10px;font-size:12px}
  .shop-header-cover{height:180px!important}
  .menu-product{flex-direction:column}
  .menu-product-img{width:100%!important;height:160px!important}
}
.cart-mobile-btn{display:none;position:fixed;bottom:20px;right:20px;z-index:900;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;box-shadow:0 6px 20px rgba(230,57,70,.4);align-items:center;justify-content:center;font-size:22px;cursor:pointer}

/* ================================================================ ROLE TABS */
.role-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.role-tabs input[type="radio"]{display:none}.role-tabs .role-tab{cursor:pointer}
.role-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;padding:18px 12px;border:2px solid var(--g200);border-radius:12px;background:#fff;transition:all var(--t);height:100%}
.role-card .role-icon{font-size:28px;margin-bottom:4px}
.role-card strong{font-size:14px;font-weight:800;color:var(--g900)}
.role-card small{font-size:11px;color:var(--g600);line-height:1.3}
.role-tabs input:checked+.role-card{border-color:var(--primary);background:rgba(230,57,70,.04);box-shadow:0 0 0 4px rgba(230,57,70,.08)}
@media(max-width:560px){.role-tabs{grid-template-columns:1fr}.role-card{flex-direction:row;text-align:left;padding:14px}.role-card .role-icon{margin:0 12px 0 0}}

/* Star rating */
.star-rating{display:inline-flex;flex-direction:row-reverse;gap:4px}
.star-rating input{display:none}
.star-rating label{font-size:32px;color:var(--g300);cursor:pointer;transition:color var(--t)}
.star-rating input:checked~label,.star-rating label:hover,.star-rating label:hover~label{color:var(--warning)}

/* ================================================================ FOOTER */
.site-footer{background:var(--g900);color:rgba(255,255,255,.7);padding:80px 0 30px;margin-top:0}
.listing-wrap+.site-footer,.listing-wrap~.site-footer{margin-top:0}
main>.section:last-child+.site-footer,.hero~.site-footer{margin-top:0}
main>.container:last-child{margin-bottom:60px}
.footer-grid{max-width:var(--container);margin:0 auto;padding:0 5%;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:44px}
.site-footer h4{color:#fff;font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.site-footer ul{list-style:none}.site-footer li{margin-bottom:10px}
.site-footer a{color:rgba(255,255,255,.7);font-size:14px;font-weight:500}.site-footer a:hover{color:var(--primary-light)}
.footer-brand{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:900;color:#fff;margin-bottom:15px}
.footer-brand .footer-logo-icon{width:45px;height:45px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:10px;display:grid;place-items:center;font-size:20px;color:#fff}
.footer-brand span{color:var(--primary-light)}
.footer-about{font-size:14px;line-height:1.7;max-width:380px;color:rgba(255,255,255,.6)}
.footer-bottom{max-width:var(--container);margin:0 auto;padding:28px 5% 0;text-align:center;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:rgba(255,255,255,.4)}

/* ================================================================ UTILITIES */
.text-center{text-align:center}.text-muted{color:var(--g600)}.text-danger{color:var(--danger)}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}
.d-flex{display:flex}.align-center{align-items:center}.justify-between{justify-content:space-between}
.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}.flex-wrap{flex-wrap:wrap}
.price{font-weight:900;color:var(--primary)}

/* ================================================================ RESPONSIVE */
@media(max-width:960px){
  .hide-mobile{display:none !important}
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#1a1a2e,#0f172a);flex-direction:column;padding:80px 28px 28px;gap:0;z-index:999;overflow-y:auto}
  .nav-links.open{display:flex}
  .nav-links a{width:100%;padding:16px 0;color:#fff;font-size:17px;font-weight:600;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-links a:hover{color:var(--primary-light)}
  .nav-links a .nav-icon{margin-right:12px;width:22px;font-size:16px;opacity:.6}
  .nav-links a::after{display:none}
  .burger{display:flex;z-index:1001}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-search{margin:0 auto}
  .hero-stats{max-width:520px;margin-left:auto;margin-right:auto}
  .footer-grid{grid-template-columns:1fr 1fr}
  .mega-menu{position:static;box-shadow:none;border:none;padding:8px 0;grid-template-columns:1fr !important;gap:4px;background:transparent}
  .mega-menu .mega-col{padding:0}
  .mega-menu .mega-col-title{color:rgba(255,255,255,.4);font-size:11px}
  .mega-menu .mega-item{color:#fff;padding:10px 0}
  .mega-menu .mega-item div strong{color:#fff}
  .mega-menu .mega-item div small{color:rgba(255,255,255,.4)}
  .notif-panel{width:min(380px,calc(100vw - 20px));right:10px}
  .hp-steps{grid-template-columns:1fr !important}
  .hp-services{grid-template-columns:repeat(auto-fill,minmax(140px,1fr)) !important}
  .hp-shops,.hp-deals,.hp-testimonials,.hp-blog{grid-template-columns:1fr !important}
}
@media(max-width:560px){
  .section{padding:50px 0}
  .footer-grid{grid-template-columns:1fr}
  .hero-search{flex-direction:column;padding:12px}
  .hero-search input{padding:14px}
  .hero-search .btn{width:100%}
  .hero-stats{grid-template-columns:1fr}
  .container{padding:0 16px}
  h2{font-size:1.4rem !important}
  .item-card{border-radius:12px}
  .notif-panel{width:calc(100vw - 10px);right:5px;left:5px;max-height:70vh}
  .hp-services{grid-template-columns:repeat(2,1fr) !important;gap:10px !important}
  /* Header mobile */
  .site-header{height:60px;padding:0 12px}
  .logo-text{font-size:16px}
  .logo-mark{width:32px;height:32px;font-size:14px}
  .nav-actions{gap:6px}
  .nav-action-btn{width:34px;height:34px;font-size:13px}
  .nav-user-btn{width:34px;height:34px}
  .btn-sm{padding:7px 12px;font-size:12px}
  .nav-links{top:60px}
  /* Cart sticky bar mobile */
  .cart-sticky-bar{padding:10px 12px}
  .cart-sticky-link{padding:14px 18px;font-size:14px;border-radius:12px}
  .cart-sticky-price{padding:5px 10px;font-size:13px}
}

/* Dashboard old classes compatibility (used in sub-pages that share layout) */
.dash-wrap{max-width:var(--container);margin:0 auto;padding:32px 5%;display:grid;grid-template-columns:260px 1fr;gap:30px;align-items:start}
.dash-sidebar{background:#fff;border-radius:var(--r-lg);border:1px solid var(--g200);padding:22px;box-shadow:var(--shadow-sm);position:sticky;top:86px}
.dash-user{display:flex;gap:12px;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--g200);margin-bottom:14px}
.dash-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:grid;place-items:center;font-weight:900;font-size:20px}
.dash-nav{display:flex;flex-direction:column;gap:2px}
.dash-nav a{padding:10px 12px;border-radius:8px;color:var(--g700);font-size:14px;font-weight:600;transition:all var(--t);text-decoration:none}
.dash-nav a:hover{background:var(--g100);color:var(--g900)}
.dash-nav a.active{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 4px 12px rgba(230,57,70,.25)}
.dash-nav-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--g400);margin:16px 0 4px 12px}
.dash-main{min-width:0}
.dash-head{margin-bottom:24px}.dash-head h1{font-size:1.8rem;font-weight:900;margin-bottom:4px}
.dash-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--g200);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:24px}
.stat-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--g200);padding:22px;display:flex;gap:14px;align-items:center;box-shadow:var(--shadow-sm)}
.stat-icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:grid;place-items:center;font-size:24px;flex-shrink:0;box-shadow:0 4px 12px rgba(230,57,70,.25)}
.stat-num{font-size:1.6rem;font-weight:900;color:var(--g900);line-height:1.1}
.stat-label{font-size:12px;color:var(--g600);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.dash-table{width:100%;border-collapse:collapse;font-size:14px}
.dash-table thead{background:var(--g50)}
.dash-table th{text-align:left;padding:14px 16px;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--g600)}
.dash-table td{padding:14px 16px;border-top:1px solid var(--g100)}.dash-table tr:hover{background:var(--g50)}
@media(max-width:900px){.dash-wrap{grid-template-columns:1fr}.dash-sidebar{position:static}}
.shops-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}
.shop-tile{padding:22px}.shop-tile-head{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.shop-tile-logo{width:54px;height:54px;border-radius:12px;object-fit:cover;flex-shrink:0}
.shop-tile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px;background:var(--g50);border-radius:10px;margin-bottom:14px}
.shop-tile-stats>div{text-align:center}
.shop-tile-stats strong{display:block;font-size:15px;color:var(--g900);font-weight:800}
.shop-tile-stats small{display:block;font-size:11px;color:var(--g600)}
.shop-tile-actions{display:flex;gap:6px;flex-wrap:wrap}
.shop-tile-actions .btn{padding:7px 12px;font-size:12px}

/* ================================================================ MOBILE TOUCH & TABLES ================================================================ */
@media(max-width:768px){
  .dash-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .dash-card{padding:16px}
  .dash-head h1{font-size:1.3rem}
  .shops-grid{grid-template-columns:1fr}
  .shop-tile{padding:16px}
  .stats-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr !important}
  .btn{min-height:44px}
  input,select,textarea{font-size:16px !important}
}
@media(max-width:480px){
  .shop-tile-stats{grid-template-columns:repeat(3,1fr);gap:4px;padding:10px}
  .shop-tile-stats strong{font-size:13px}
  .shop-tile-actions .btn{flex:1;text-align:center}
}
