:root{
  --blue:#1f5cff;
  --blue-dark:#1b4bd6;
  --bg:#eff3f8;
  --text:#0b1220;
  --muted:#657a96;
  --card:#ffffff;
  --border:#e3e8f2;
  --shadow:0 10px 24px rgba(10,20,60,.10);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{height:100%;overflow-x:hidden}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
}
a{color:inherit}
.container{max-width:1100px;margin:0 auto;padding:18px}
main.container{padding-top:30px}
.section{margin-top:18px}
.section:first-child{margin-top:0}

.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:16px;
}
.title{margin:0 0 8px;font-size:26px;letter-spacing:-.2px}
.subtitle{margin:0;color:var(--muted);line-height:1.45}
.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(227,232,242,.95);
  background:#fff;
  text-decoration:none;
  font-weight:800;
  font-size:12px;
  letter-spacing:.3px;
}
.chip.primary{border-color:rgba(31,92,255,.35);background:rgba(31,92,255,.10);color:var(--blue-dark)}
.chip.danger{border-color:rgba(204,31,26,.35);background:rgba(204,31,26,.10);color:#cc1f1a}
.brand{display:flex;flex-direction:column;gap:2px;text-decoration:none}
.brand strong{font-size:14px;letter-spacing:.4px}
.brand span{font-size:11px;color:rgba(255,255,255,.70)}

.site-header{
  position:sticky;
  top:0;
  z-index:80;
  background:transparent;
  border-bottom:0;
  padding:4px 0 6px;
  backdrop-filter:none;
  isolation:isolate;
  overflow:visible;
}
.site-header::before{
  display:none;
}
.topbar{display:none}
.topbar-inner{
  max-width:1100px;
  margin:0 auto;
  padding:8px 14px;
  display:flex;
  align-items:center;
  gap:14px;
  color:#2b3b54;
  font-size:12px;
  font-weight:800;
}
.topbar-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:inherit;
  text-decoration:none;
  white-space:nowrap;
  min-width:0;
}
.topbar-text{
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:46ch;
}
.topbar-ic{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:var(--blue-dark);
}
.topbar-ic svg{display:block}
.topbar-spacer{flex:1 1 auto}
.logo-sticker{
  position:fixed;
  top:10px;
  left:max(18px, calc((100vw - 1100px) / 2 + 18px));
  transform:none;
  width:96px;
  height:96px;
  border-radius:999px;
  background:#fff;
  border:2px solid rgba(18,58,114,.18);
  box-shadow:var(--shadow);
  display:none;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  z-index:35;
  text-decoration:none;
}
.logo-sticker img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.has-logo .site-header-inner{
  padding-top:0;
}
.has-logo .logo-mark{
  display:none;
}
.has-logo .logo-sticker{
  display:flex;
}
.site-header-inner{
  max-width:1100px;
  margin:0 auto;
  padding:0 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  position:relative;
  z-index:1;
}
.header-bar{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  align-items:center;
  gap:10px;
  padding:5px 9px;
  border-radius:13px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.88);
  box-shadow:0 14px 30px rgba(10,20,60,.12);
  position:relative;
  overflow:visible;
}
.header-bar::before{
  content:"";
  position:absolute;
  inset:-120px -140px -140px -140px;
  background:
    conic-gradient(from 230deg at 20% 40%, rgba(31,92,255,.20), transparent 35%, rgba(127,214,255,.12), transparent 62%, rgba(31,92,255,.14), transparent 82%),
    radial-gradient(520px 260px at 80% 30%, rgba(31,92,255,.10), transparent 60%);
  filter:blur(18px);
  opacity:.9;
  transform:translate3d(0,0,0);
  animation:headerMesh 14s ease-in-out infinite alternate;
  clip-path:inset(0 round 13px);
  pointer-events:none;
}
.header-bar::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:13px;
  background:linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,0));
  opacity:.55;
  clip-path:inset(0 round 13px);
  pointer-events:none;
}
.header-bar > *{position:relative;z-index:1}

.nav-mega{position:relative;display:inline-flex;align-items:center}
.nav-mega::after{
  content:"";
  position:absolute;
  left:-14px;
  right:-14px;
  top:100%;
  height:16px;
}
.mega-panel{
  position:absolute;
  left:50%;
  top:calc(100% + 6px);
  transform:translateX(-50%) translateY(6px);
  width:min(920px, calc(100vw - 32px));
  background:rgba(255,255,255,.92);
  border:1px solid rgba(227,232,242,.92);
  border-radius:18px;
  box-shadow:0 30px 70px rgba(10,20,60,.18);
  padding:14px;
  opacity:0;
  pointer-events:none;
  transition:opacity .16s ease, transform .16s ease;
  backdrop-filter:blur(14px) saturate(160%);
  z-index:40;
}
.nav-mega:hover .mega-panel,
.nav-mega:focus-within .mega-panel{
  opacity:1;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}
.mega-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.mega-title{font-weight:1000;letter-spacing:.4px;text-transform:uppercase;font-size:11px;color:#22314a}
.mega-all{text-decoration:none;font-weight:900;color:var(--blue-dark);font-size:12px}
.mega-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
.mega-link{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(227,232,242,.92);
  background:#fff;
  text-decoration:none;
  font-weight:900;
  color:#22314a;
}
.mega-link:hover{border-color:rgba(31,92,255,.26);background:rgba(31,92,255,.06);color:var(--blue-dark)}
@keyframes headerMesh{
  0%{transform:translate3d(-14px,-10px,0) rotate(-4deg) scale(1.02)}
  50%{transform:translate3d(10px,-18px,0) rotate(6deg) scale(1.04)}
  100%{transform:translate3d(18px,8px,0) rotate(2deg) scale(1.05)}
}
@media (prefers-reduced-motion: reduce){
  .header-bar::before{animation:none}
}
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.logo-mark{
  width:38px;height:38px;
  border-radius:10px;
  background:linear-gradient(135deg, rgba(31,92,255,.18), rgba(31,92,255,.06));
  color:var(--blue-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border:1px solid rgba(31,92,255,.20);
}
.logo-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.logo-text{display:flex;flex-direction:column;gap:2px}
.logo-text strong{font-size:14px;letter-spacing:.4px}
.logo-text span{font-size:11px;color:var(--muted)}
.logo-text{display:none}

.site-nav{
  display:flex;
  gap:8px;
  align-items:center;
  flex:1 1 auto;
  min-width:0;
  justify-content:center;
}
.site-nav a{
  text-decoration:none;
  font-size:10.5px;
  letter-spacing:.6px;
  text-transform:uppercase;
  color:#24324a;
  padding:6px 9px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:900;
}
.site-nav a:hover{
  background:rgba(31,92,255,.08);
  border-color:rgba(31,92,255,.16);
  color:var(--blue-dark);
}
.site-nav a.active{
  color:var(--blue-dark);
  background:linear-gradient(180deg, rgba(31,92,255,.14), rgba(31,92,255,.08));
  border-color:rgba(31,92,255,.24);
  box-shadow:0 10px 18px rgba(31,92,255,.12);
}

.site-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}
.lang-switch{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:11px;
}
.lang-switch a{
  text-decoration:none;
  color:#24324a;
  font-weight:600;
}
.lang-switch a.active{color:var(--blue-dark)}
.lang-switch .sep{color:#a1afc5}
.icon-btn{
  width:30px;height:30px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border:1px solid rgba(227,232,242,.9);
  background:rgba(255,255,255,.92);
  position:relative;
}
.icon-btn:hover{border-color:rgba(31,92,255,.22);box-shadow:0 10px 18px rgba(10,20,60,.10)}
.icon-btn.active{border-color:rgba(31,92,255,.35);background:rgba(31,92,255,.08);color:var(--blue-dark)}
.hamburger-btn{
  display:none;
  cursor:pointer;
  color:#24324a;
}
.hamburger-btn svg{display:block}
.mobile-nav-overlay{
  position:fixed;
  inset:0;
  background:rgba(6,10,18,.42);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
  z-index:120;
}
.mobile-nav{
  position:fixed;
  top:0;
  left:0;
  height:100%;
  width:min(86vw, 360px);
  transform:translateX(-110%);
  transition:transform .22s ease;
  z-index:121;
}
.mobile-nav-panel{
  height:100%;
  padding:14px;
  background:rgba(255,255,255,.14);
  border-right:1px solid rgba(255,255,255,.18);
  box-shadow:0 30px 60px rgba(0,0,0,.28);
  backdrop-filter: blur(18px) saturate(170%);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.mobile-nav-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.mobile-nav-brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:#fff;
}
.mobile-nav-logo{
  width:64px;
  height:64px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:2px solid rgba(255,255,255,.22);
  object-fit:contain;
  display:block;
}
.mobile-nav-brand-text{display:flex;flex-direction:column;gap:2px}
.mobile-nav-name{font-weight:1000;letter-spacing:.2px;font-size:16px;line-height:1.1}
.mobile-nav-tagline{font-weight:700;font-size:12px;opacity:.82}
.mobile-nav-close{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.10);color:#fff}
.mobile-nav-links{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.mobile-nav-links a{
  text-decoration:none;
  color:#fff;
  font-weight:900;
  letter-spacing:.4px;
  padding:12px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
}
.mobile-nav-links a.active{background:rgba(31,92,255,.18);border-color:rgba(31,92,255,.28)}
.mobile-nav-section-title{
  margin-top:2px;
  color:rgba(255,255,255,.82);
  font-weight:900;
  letter-spacing:.7px;
  text-transform:uppercase;
  font-size:11px;
}
.mobile-nav-cats{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.mobile-nav-cat{
  text-decoration:none;
  color:#fff;
  font-weight:900;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  letter-spacing:.2px;
}
.mobile-nav-call{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:#fff;
  font-weight:950;
  letter-spacing:.2px;
  padding:12px 12px;
  border-radius:14px;
  background:rgba(31,92,255,.18);
  border:1px solid rgba(31,92,255,.28);
}
.mobile-nav-call-ic{
  width:26px;
  height:26px;
  border-radius:10px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}
.mobile-nav-lang{
  margin-top:auto;
  display:flex;
  gap:10px;
}
.mobile-nav-lang a{
  text-decoration:none;
  color:#fff;
  font-weight:1000;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
}
.mobile-nav-lang a.active{background:rgba(31,92,255,.20);border-color:rgba(31,92,255,.30)}
body.mobile-nav-open{overflow:hidden}
body.mobile-nav-open .mobile-nav-overlay{opacity:1;pointer-events:auto}
body.mobile-nav-open .mobile-nav{transform:translateX(0)}
.fav-badge{
  position:absolute;
  right:-6px;
  top:-6px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:999px;
  background:var(--blue-dark);
  color:#fff;
  font-size:11px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px solid #fff;
}

.toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translate(-50%, 16px);
  opacity:0;
  pointer-events:none;
  background:#0b1a2b;
  color:#fff;
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  padding:10px 12px;
  box-shadow:var(--shadow);
  font-weight:800;
  font-size:12px;
  letter-spacing:.2px;
  transition:opacity .18s ease, transform .18s ease;
  z-index:50;
}
.toast.show{
  opacity:1;
  transform:translate(-50%, 0);
}

.page-hero{
  margin-top:18px;
  margin-bottom:18px;
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:
    radial-gradient(520px 240px at 20% 10%, rgba(31,92,255,.20), transparent 65%),
    linear-gradient(135deg, rgba(15,27,46,.92) 0%, rgba(9,18,33,.88) 55%, rgba(15,27,46,.90) 100%);
  color:#fff;
  background-size:cover;
  background-position:center;
}
.page-hero-inner{
  padding:22px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
}
.page-hero-kicker{
  font-size:11px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:rgba(255,255,255,.78);
  font-weight:900;
}
.page-hero-title{
  margin:8px 0 0;
  font-size:36px;
  line-height:1.05;
  letter-spacing:-.5px;
}
.page-hero-subtitle{
  margin-top:10px;
  max-width:60ch;
  color:rgba(255,255,255,.82);
  line-height:1.5;
  font-size:13px;
  font-weight:700;
}
.page-hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.page-hero-actions .chip{background:rgba(255,255,255,.92);color:#0b1220}
.page-hero-actions .chip.primary{background:rgba(31,92,255,.16);color:#fff}
.chip-ic{display:inline-flex;align-items:center;justify-content:center;margin-right:8px}
.chip-ic svg{display:block}

.card-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap}
.card-title{font-weight:1000;letter-spacing:.2px}
.card-subtitle{color:var(--muted);font-weight:800;font-size:12px}

.scroll-top{
  position:fixed;
  right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom));
  width:44px;
  height:44px;
  border-radius:999px;
  display:none;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(227,232,242,.9);
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 40px rgba(10,20,60,.18);
  color:#24324a;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .18s ease, transform .18s ease, box-shadow .18s ease;
  z-index:55;
}
.scroll-top.show{opacity:1;transform:translateY(0)}
.scroll-top:active{transform:translateY(0) scale(.98)}
.scroll-top:hover{box-shadow:0 22px 48px rgba(10,20,60,.22)}

.call-fab{
  position:fixed;
  right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom));
  display:none;
  align-items:center;
  gap:10px;
  z-index:56;
  text-decoration:none;
}
.call-fab-ic{
  width:54px;
  height:54px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--blue) 0%, var(--blue-dark) 100%);
  border:1px solid rgba(31,92,255,.32);
  color:#fff;
  box-shadow:0 18px 40px rgba(31,92,255,.26);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:visible;
}
.call-fab-ic::before,
.call-fab-ic::after{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius:999px;
  border:2px solid rgba(127,214,255,.32);
  opacity:0;
  transform:scale(.78);
  animation:callPulse 1.6s ease-out infinite;
}
.call-fab-ic::after{
  animation-delay:.8s;
}
.call-fab-ic svg{
  display:block;
  animation:callWiggle 1.2s ease-in-out infinite;
  transform-origin:50% 50%;
}
.call-fab-tip{
  background:rgba(255,255,255,.94);
  color:#0d1b2f;
  border:1px solid rgba(227,232,242,.92);
  border-radius:16px;
  padding:10px 12px;
  font-size:12px;
  font-weight:950;
  letter-spacing:.2px;
  box-shadow:0 18px 40px rgba(10,20,60,.18);
  white-space:nowrap;
  max-width:calc(100vw - 108px);
  overflow:hidden;
  text-overflow:ellipsis;
  opacity:1;
  transform:translateX(0);
  transition:opacity .35s ease, transform .35s ease;
}
.call-fab-tip.hide{
  opacity:0;
  transform:translateX(10px);
}
@keyframes callPulse{
  0%{opacity:0;transform:scale(.78)}
  18%{opacity:.55}
  100%{opacity:0;transform:scale(1.28)}
}
@keyframes callWiggle{
  0%{transform:rotate(0deg) translateY(0)}
  12%{transform:rotate(-10deg) translateY(-1px)}
  24%{transform:rotate(10deg) translateY(0)}
  36%{transform:rotate(-8deg) translateY(-1px)}
  48%{transform:rotate(8deg) translateY(0)}
  60%{transform:rotate(0deg) translateY(0)}
  100%{transform:rotate(0deg) translateY(0)}
}
@media (prefers-reduced-motion: reduce){
  .call-fab-ic::before,.call-fab-ic::after,.call-fab-ic svg{animation:none}
}

.hero-banner{
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background-image:
    linear-gradient(90deg, rgba(0,0,0,.74) 0%, rgba(0,0,0,.32) 55%, rgba(0,0,0,.50) 100%),
    url("/assets/hero.jpg");
  background-size:cover;
  background-position:center;
  margin-top:18px;
  position:relative;
  transform:translate3d(0,0,0);
}
.hero-banner::before{
  content:"";
  position:absolute;
  inset:-140px -160px -160px -160px;
  background:
    conic-gradient(from 210deg at 18% 30%, rgba(31,92,255,.40), transparent 35%, rgba(127,214,255,.18), transparent 62%, rgba(31,92,255,.22), transparent 82%),
    radial-gradient(760px 320px at 80% 20%, rgba(31,92,255,.22), transparent 60%),
    radial-gradient(660px 300px at 40% 120%, rgba(127,214,255,.14), transparent 62%);
  filter:blur(26px);
  opacity:.85;
  mix-blend-mode:screen;
  animation:heroMesh 16s linear infinite;
  pointer-events:none;
}
.hero-banner::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.12) 42%, rgba(255,255,255,0) 58%),
    repeating-radial-gradient(circle at 10% 20%, rgba(255,255,255,.04) 0 1px, rgba(255,255,255,0) 1px 6px);
  background-size:220% 100%, 220px 220px;
  background-position:-120% 0, 0 0;
  opacity:0;
  animation:heroShine 8s ease-in-out infinite;
  pointer-events:none;
}
.hero-inner{position:relative;z-index:1}
@keyframes heroMesh{
  0%{transform:translate3d(-34px,-22px,0) rotate(0deg) scale(1.05)}
  50%{transform:translate3d(22px,-34px,0) rotate(180deg) scale(1.08)}
  100%{transform:translate3d(34px,22px,0) rotate(360deg) scale(1.10)}
}
@keyframes heroShine{
  0%{background-position:-120% 0, 0 0;opacity:0}
  18%{opacity:.55}
  55%{opacity:.20}
  100%{background-position:120% 0, 220px 220px;opacity:0}
}
@media (prefers-reduced-motion: reduce){
  .hero-banner::before,.hero-banner::after{animation:none}
}
.hero-inner{
  padding:34px 26px;
  display:grid;
  grid-template-columns:1.35fr .65fr;
  gap:18px;
  align-items:center;
  align-content:center;
  min-height:340px;
}
.hero-left{
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-left h1{
  margin:0 0 12px;
  font-size:44px;
  letter-spacing:-.6px;
  line-height:1.05;
  color:#fff;
}
.hero-left p{
  margin:0;
  color:rgba(255,255,255,.80);
  font-size:13px;
  max-width:56ch;
  line-height:1.55;
}
.hero-actions{margin-top:16px}
.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:10px;
  background:var(--blue-dark);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  letter-spacing:.5px;
  font-size:12px;
  text-transform:uppercase;
}
.btn-outline{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:10px;
  background:#fff;
  color:var(--blue-dark);
  border:1px solid rgba(31,92,255,.30);
  text-decoration:none;
  font-weight:700;
  letter-spacing:.4px;
  font-size:12px;
  text-transform:uppercase;
}

.hero-status-card{
  align-self:center;
  background:
    radial-gradient(520px 220px at 20% 0%, rgba(31,92,255,.20), transparent 65%),
    linear-gradient(135deg, rgba(15,27,46,.92) 0%, rgba(9,18,33,.88) 55%, rgba(15,27,46,.90) 100%);
  border:1px solid rgba(255,255,255,.22);
  border-radius:18px;
  padding:16px;
  color:#fff;
  box-shadow:0 18px 36px rgba(0,0,0,.22);
  backdrop-filter: blur(10px) saturate(140%);
}
.hero-status-title{
  font-size:11px;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:rgba(255,255,255,.80);
}
.hero-status-chip{
  margin-top:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 14px;
  border-radius:12px;
  font-weight:1000;
  letter-spacing:1px;
  font-size:12px;
  background:#fff;
  color:#0b1220;
  box-shadow:0 12px 22px rgba(0,0,0,.22);
}
.hero-status-chip.closed{color:#0b1220}
.hero-status-chip.open{color:#0b1220}
.hero-status-text{
  margin-top:10px;
  color:rgba(255,255,255,.84);
  font-size:12px;
  line-height:1.45;
}

.features{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:14px;
}
.feature{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:12px;
  display:flex;
  gap:10px;
  align-items:center;
}
.feature-icon{
  width:34px;height:34px;
  border-radius:10px;
  background:rgba(31,92,255,.10);
  color:var(--blue-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
}
.feature-title{
  font-size:11px;
  letter-spacing:.7px;
  text-transform:uppercase;
  font-weight:800;
  color:#24324a;
}
.feature-desc{
  margin-top:2px;
  font-size:12px;
  color:var(--muted);
  line-height:1.35;
}

.menu-preview{
  margin-top:18px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(227,232,242,.9);
  border-radius:18px;
  padding:16px;
}
.section-head{display:flex;justify-content:center}
.section-title{
  font-size:12px;
  letter-spacing:.9px;
  text-transform:uppercase;
  font-weight:900;
  color:#24324a;
}
.section-subtitle{
  margin-top:6px;
  color:var(--muted);
  font-size:12px;
}
.menu-top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}
.category-pills{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-start;
  margin-top:14px;
}
.category-pills-wrap{position:relative}
.cat-toggle{display:none}
.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(227,232,242,.95);
  background:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:12px;
  color:#24324a;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease, background .14s ease;
}
.pill:hover{border-color:rgba(31,92,255,.22);box-shadow:0 12px 24px rgba(10,20,60,.10);transform:translateY(-1px)}
.pill.active{
  background:var(--blue-dark);
  border-color:var(--blue-dark);
  color:#fff;
}

.menu-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:14px;
  margin-top:14px;
}
.menu-card{
  grid-column:span 3;
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  min-height:100%;
}
.js-item-card{cursor:pointer}
.menu-card:hover{transform:translateY(-1px);transition:transform .12s ease}
.menu-card-image{
  position:relative;
  height:140px;
  background:
    radial-gradient(500px 180px at 30% 30%, rgba(31,92,255,.22), transparent 55%),
    linear-gradient(135deg,#0b1a2b 0%,#0d2b62 65%,#071018 100%);
}
.menu-card-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.menu-heart{
  position:absolute;
  right:10px;
  top:10px;
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(227,232,242,.9);
  background:#fff;
  text-decoration:none;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  color:#22314a;
}
.menu-heart.active{
  border-color:rgba(31,92,255,.35);
  background:rgba(31,92,255,.10);
  color:var(--blue-dark);
}
.menu-card-body{
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  flex:1 1 auto;
}
.menu-card-name{
  font-size:13px;
  font-weight:800;
  color:#22314a;
}
.menu-card-desc{
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  min-height:32px;
}
.menu-card-price{
  margin-top:auto;
  font-weight:900;
  color:#22314a;
}
.menu-cta{
  display:flex;
  justify-content:center;
  margin-top:14px;
}

.site-body.item-modal-open{overflow:hidden}
.item-modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:140;
}
.site-body.item-modal-open .item-modal{display:block}
.item-modal-overlay{
  position:absolute;
  inset:0;
  background:rgba(6,10,18,.55);
  backdrop-filter:blur(6px);
}
.item-modal-card{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(860px, calc(100vw - 32px));
  border-radius:20px;
  border:1px solid rgba(227,232,242,.92);
  background:#fff;
  box-shadow:0 40px 90px rgba(10,20,60,.26);
  overflow:hidden;
  display:grid;
  grid-template-columns:360px 1fr;
}
.item-modal-close{
  position:absolute;
  right:12px;
  top:12px;
  z-index:2;
}
.item-modal-media{
  background:
    radial-gradient(600px 260px at 20% 20%, rgba(31,92,255,.22), transparent 60%),
    linear-gradient(135deg,#0b1a2b 0%,#0d2b62 65%,#071018 100%);
  min-height:320px;
}
.item-modal-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.item-modal-body{padding:18px 18px;display:flex;flex-direction:column;gap:10px}
.item-modal-name{font-size:22px;font-weight:950;letter-spacing:-.3px;color:#0d1b2f}
.item-modal-desc{color:var(--muted);font-size:14px;line-height:1.5}
.item-modal-bottom{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px}
.item-modal-price{font-weight:950;font-size:18px;color:#0d1b2f}
.item-modal-fav{white-space:nowrap}
.empty-state{
  margin-top:14px;
  padding:12px;
  border-radius:12px;
  background:#fff;
  border:1px solid var(--border);
  color:var(--muted);
  text-align:center;
}

.logo-strip{
  margin-top:18px;
  padding:0;
  border-radius:0;
  border:0;
  background:transparent;
  overflow:hidden;
}
.logo-strip-head{display:flex;justify-content:center}
.logo-strip-title{
  font-size:12px;
  letter-spacing:.9px;
  text-transform:uppercase;
  font-weight:1000;
  color:#24324a;
}
.logo-marquee{
  margin-top:14px;
  position:relative;
  overflow:hidden;
  border-radius:16px;
  border:0;
  background:transparent;
}
.logo-marquee::before,.logo-marquee::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:64px;
  z-index:2;
  pointer-events:none;
}
.logo-marquee::before{
  left:0;
  background:linear-gradient(90deg, var(--bg) 0%, rgba(239,243,248,0) 100%);
}
.logo-marquee::after{
  right:0;
  background:linear-gradient(270deg, var(--bg) 0%, rgba(239,243,248,0) 100%);
}
.logo-track{
  display:flex;
  align-items:center;
  gap:18px;
  padding:10px 0;
  width:max-content;
  animation:logoMarquee var(--logo-duration, 28s) linear infinite;
  will-change:transform;
}
.logo-item{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 6px;
  border-radius:0;
  border:0;
  background:transparent;
  min-width:140px;
  height:64px;
}
.logo-item img{
  max-width:160px;
  max-height:44px;
  width:auto;
  height:auto;
  object-fit:contain;
  display:block;
  filter:none;
  opacity:.95;
}
.logo-link{display:flex;align-items:center;justify-content:center;width:100%;height:100%;text-decoration:none}
.logo-link:hover img{filter:grayscale(0);opacity:1}
@keyframes logoMarquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@media (prefers-reduced-motion: reduce){
  .logo-track{animation:none}
}

.site-footer{
  margin-top:22px;
  color:#fff;
}
.footer-card{
  background:linear-gradient(180deg,#0b1a2b 0%,#071018 100%);
  border-radius:16px;
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
  isolation:isolate;
}
.footer-card::before{
  content:"";
  position:absolute;
  inset:-160px -140px -40px -140px;
  background:
    radial-gradient(560px 360px at 50% 120%, rgba(255,255,255,.42), transparent 72%),
    radial-gradient(460px 300px at 34% 122%, rgba(127,214,255,.22), transparent 72%),
    radial-gradient(500px 340px at 68% 124%, rgba(255,255,255,.34), transparent 74%),
    radial-gradient(520px 360px at 52% 108%, rgba(255,255,255,.18), transparent 70%);
  filter:blur(18px);
  opacity:.92;
  mix-blend-mode:screen;
  transform:translate3d(0,22px,0) scale(1.08);
  animation:footerSmokeA 9s ease-in-out infinite;
  -webkit-mask-image:linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 70%, rgba(255,255,255,0) 100%);
  mask-image:linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 70%, rgba(255,255,255,0) 100%);
  will-change:transform;
  pointer-events:none;
}
.footer-card::after{
  content:"";
  position:absolute;
  inset:-200px -160px -60px -160px;
  background:
    radial-gradient(600px 380px at 50% 132%, rgba(255,255,255,.22), transparent 72%),
    radial-gradient(520px 340px at 30% 126%, rgba(31,92,255,.18), transparent 74%),
    radial-gradient(560px 380px at 72% 136%, rgba(127,214,255,.18), transparent 74%);
  filter:blur(26px);
  opacity:.70;
  mix-blend-mode:screen;
  transform:translate3d(0,38px,0) scale(1.12);
  animation:footerSmokeB 12s ease-in-out infinite;
  -webkit-mask-image:linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 60%, rgba(255,255,255,0) 100%);
  mask-image:linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 60%, rgba(255,255,255,0) 100%);
  will-change:transform;
  pointer-events:none;
}
.site-footer-inner,.footer-bottom{position:relative;z-index:1}
@keyframes footerSmokeA{
  0%{transform:translate3d(-14px,30px,0) rotate(-2deg) scale(1.06)}
  45%{transform:translate3d(16px,-46px,0) rotate(3deg) scale(1.18)}
  100%{transform:translate3d(-10px,28px,0) rotate(-2deg) scale(1.06)}
}
@keyframes footerSmokeB{
  0%{transform:translate3d(10px,46px,0) rotate(2deg) scale(1.12)}
  50%{transform:translate3d(-18px,-54px,0) rotate(-3deg) scale(1.22)}
  100%{transform:translate3d(8px,44px,0) rotate(2deg) scale(1.12)}
}
@media (prefers-reduced-motion: reduce){
  .footer-card::before,.footer-card::after{animation:none}
}
.site-footer-inner{
  padding:22px 18px;
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:18px;
}
.footer-logo{font-weight:900;letter-spacing:.3px}
.footer-logo-img{
  width:88px;
  height:88px;
  border-radius:999px;
  background:#fff;
  border:2px solid rgba(255,255,255,.14);
  object-fit:contain;
  display:block;
  margin-bottom:10px;
}
.footer-tagline{margin-top:6px;color:rgba(255,255,255,.72);font-size:12px}
.footer-title{font-weight:900;letter-spacing:.6px;text-transform:uppercase;font-size:11px;margin-bottom:10px}
.footer-text{color:rgba(255,255,255,.76);font-size:12px;line-height:1.5}
.footer-ic{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:rgba(255,255,255,.86);
}
.footer-ic svg{display:block}
.footer-item{display:flex;gap:10px;align-items:flex-start;margin-top:8px}
.footer-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.76);
  font-size:12px;
  line-height:1.6;
  padding:6px 8px;
  border-radius:12px;
}
.footer-row.current{
  background:rgba(31,92,255,.22);
  border:1px solid rgba(31,92,255,.28);
  color:#fff;
  font-weight:900;
}
.footer-link{display:block;color:rgba(255,255,255,.76);text-decoration:none;font-size:12px;line-height:1.8}
.footer-social{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.footer-social a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.76);
  text-decoration:none;
  font-size:12px;
}
.footer-social a:hover{background:rgba(255,255,255,.10)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.10);
  text-align:center;
  padding:12px 18px;
  color:rgba(255,255,255,.60);
  font-size:12px;
}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.col-3{grid-column:span 3}
.col-6{grid-column:span 6}
.col-9{grid-column:span 9}
.col-12{grid-column:span 12}
label{display:block;font-size:12px;color:var(--muted);margin:0 0 6px}
input,select,textarea{
  width:100%;
  border-radius:12px;
  border:1px solid var(--border);
  padding:10px 12px;
  font:inherit;
  background:#fff;
}
textarea{min-height:90px;resize:vertical}
.table-wrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table th{font-size:12px;color:var(--muted);text-align:left;padding:0 10px}
.table td{background:#fff;border:1px solid var(--border);padding:10px;border-left:none;border-right:none}
.table tr td:first-child{border-left:1px solid var(--border);border-top-left-radius:12px;border-bottom-left-radius:12px}
.table tr td:last-child{border-right:1px solid var(--border);border-top-right-radius:12px;border-bottom-right-radius:12px}
.btn{
  border:1px solid var(--border);
  background:#fff;border-radius:10px;
  padding:10px 12px;
  cursor:pointer;
  font-weight:800;
}
.btn.primary{border-color:rgba(31,92,255,.35);background:rgba(31,92,255,.10);color:var(--blue-dark)}
.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}

.info-list{display:flex;flex-direction:column;gap:10px}
.info-item{display:flex;gap:10px;align-items:flex-start;color:#22314a;line-height:1.45}
.info-item a{color:inherit}
.info-ic{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:var(--blue-dark);
}
.info-ic svg{display:block}
.info-hours{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.hours-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:9px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  color:#22314a;
  font-weight:800;
}
.hours-row.current{
  border-color:rgba(31,92,255,.28);
  background:rgba(31,92,255,.08);
  color:var(--blue-dark);
}

.map-embed{
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--border);
  background:#fff;
  box-shadow:0 12px 26px rgba(10,20,60,.10);
}
.map-iframe{
  width:100%;
  height:340px;
  border:0;
  display:block;
}

.social-links{display:flex;flex-direction:column;gap:10px}
.social-link{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  text-decoration:none;
  font-weight:900;
  color:#22314a;
}
.social-link:hover{border-color:rgba(31,92,255,.22);box-shadow:0 12px 22px rgba(10,20,60,.10)}
.social-ic{
  width:34px;
  height:34px;
  border-radius:12px;
  background:rgba(31,92,255,.10);
  color:var(--blue-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}
.social-ic svg{display:block}

.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.admin-sidebar{
  position:sticky;
  top:0;
  height:100vh;
  padding:16px 14px;
  background:
    radial-gradient(900px 380px at -20% -10%, rgba(31,92,255,.22), transparent 60%),
    radial-gradient(700px 320px at 120% 20%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg,#0b1a2b 0%,#071018 100%);
  color:#fff;
  border-right:1px solid rgba(255,255,255,.08);
}
.admin-logo{display:flex;gap:10px;align-items:center;text-decoration:none;color:#fff}
.admin-logo-mark{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;overflow:hidden}
.admin-logo-img{width:100%;height:100%;object-fit:cover;display:block}
.admin-logo-text{display:flex;flex-direction:column;gap:2px}
.admin-logo-text strong{font-size:14px;letter-spacing:.4px}
.admin-logo-text span{font-size:11px;color:rgba(255,255,255,.72)}
.admin-nav{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.admin-nav a{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  border-radius:16px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-weight:900;
  letter-spacing:.2px;
  transition:transform .14s ease, background .14s ease, border-color .14s ease, box-shadow .14s ease;
  overflow:hidden;
}
.admin-nav a::before{
  content:"";
  position:absolute;
  left:0;
  top:10px;
  bottom:10px;
  width:3px;
  border-radius:999px;
  background:transparent;
}
.admin-nav a:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.16);
  box-shadow:0 14px 26px rgba(0,0,0,.22);
  transform:translateY(-1px);
}
.admin-ic{
  width:28px;
  height:28px;
  border-radius:10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:1;
  flex:0 0 auto;
}
.admin-nav a.active{
  background:linear-gradient(180deg, rgba(31,92,255,.26), rgba(31,92,255,.12));
  border-color:rgba(31,92,255,.38);
  box-shadow:0 18px 34px rgba(31,92,255,.16);
}
.admin-nav a.active::before{background:linear-gradient(180deg, #7aa7ff, #1f5cff)}
.admin-nav a.active .admin-ic{background:rgba(31,92,255,.20);border-color:rgba(31,92,255,.26)}
.admin-nav a.admin-logout{
  border-color:rgba(204,31,26,.24);
  background:rgba(204,31,26,.14);
}
.admin-nav a.admin-logout:hover{
  border-color:rgba(204,31,26,.34);
  background:rgba(204,31,26,.18);
  box-shadow:0 18px 30px rgba(0,0,0,.24);
}
.admin-nav a.admin-logout .admin-ic{
  background:rgba(204,31,26,.18);
  border-color:rgba(204,31,26,.22);
}

.admin-dash-hero{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  padding:18px 18px;
  border-radius:18px;
  border:1px solid rgba(227,232,242,.92);
  background:
    radial-gradient(900px 400px at 0% 0%, rgba(31,92,255,.16), transparent 60%),
    radial-gradient(700px 340px at 100% 20%, rgba(7,16,35,.10), transparent 60%),
    #fff;
  box-shadow:0 18px 40px rgba(10,20,60,.10);
  margin-bottom:14px;
}
.admin-dash-kicker{font-weight:950;font-size:12px;letter-spacing:.6px;color:rgba(34,49,74,.72);text-transform:uppercase}
.admin-dash-title{font-weight:950;font-size:28px;letter-spacing:-.4px;color:#0d1b2f;margin-top:6px}
.admin-dash-subtitle{font-weight:800;color:var(--muted);margin-top:6px}
.admin-dash-hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.admin-dash-stats{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
  margin-bottom:14px;
}
.admin-stat{
  display:block;
  text-decoration:none;
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(227,232,242,.92);
  background:#fff;
  box-shadow:0 14px 28px rgba(10,20,60,.08);
  color:#0d1b2f;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.admin-stat:hover{transform:translateY(-1px);border-color:rgba(31,92,255,.20);box-shadow:0 18px 38px rgba(10,20,60,.12)}
.admin-stat-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.admin-stat-ic{width:34px;height:34px;border-radius:14px;border:1px solid rgba(227,232,242,.92);background:rgba(31,92,255,.08);display:flex;align-items:center;justify-content:center}
.admin-stat-label{font-weight:950;font-size:12px;letter-spacing:.4px;color:rgba(34,49,74,.82);text-transform:uppercase}
.admin-stat-value{font-weight:950;font-size:24px;letter-spacing:-.4px;margin-top:10px}
.admin-stat-sub{font-weight:800;color:var(--muted);margin-top:4px;font-size:12px}

.admin-dash-card{border-radius:18px}
.admin-dash-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.admin-dash-card-title{font-weight:950;color:#0d1b2f}
.admin-dash-status-line{margin-top:10px;font-weight:900;color:#0d1b2f}
.admin-dash-actions{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.admin-action{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(31,92,255,.06);
  text-decoration:none;
  color:#0d1b2f;
  font-weight:900;
}
.admin-action:hover{background:rgba(31,92,255,.10);border-color:rgba(31,92,255,.20)}
.admin-main{padding:18px;background:var(--bg)}
.admin-toprow{display:flex;align-items:center;justify-content:flex-end;margin-bottom:12px}
.admin-hamburger{display:none}
.admin-login .admin-sidebar{display:none}
.admin-login .admin-toprow{display:none}
.admin-login .admin-main{
  padding:0;
  background:transparent;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.admin-login .admin-shell{grid-template-columns:1fr}
.admin-login-bg{
  position:relative;
  width:min(520px, calc(100% - 32px));
  padding:22px;
  border-radius:22px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.86);
  box-shadow:0 40px 90px rgba(10,20,60,.22);
  backdrop-filter:blur(16px) saturate(160%);
  overflow:hidden;
}
.admin-login-bg::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:
    radial-gradient(closest-side, rgba(31,92,255,.22), transparent 70%),
    radial-gradient(closest-side, rgba(7,16,35,.18), transparent 70%),
    radial-gradient(closest-side, rgba(31,92,255,.14), transparent 70%);
  animation:adminLoginGlow 10s ease-in-out infinite;
  pointer-events:none;
}
.admin-login-bg.has-hero::after{
  content:"";
  position:absolute;
  inset:-10%;
  background:
    linear-gradient(180deg, rgba(8,14,26,.62), rgba(255,255,255,0) 55%),
    var(--login-hero);
  background-size:cover;
  background-position:center;
  opacity:.22;
  filter:saturate(1.12) contrast(1.05);
  pointer-events:none;
}
.admin-login-card{position:relative;z-index:1}
.admin-login-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.admin-login-logo{width:44px;height:44px;border-radius:14px;border:1px solid rgba(227,232,242,.92);background:#fff;object-fit:cover}
.admin-login-brand-text{display:flex;flex-direction:column;gap:2px}
.admin-login-title{font-size:16px;font-weight:950;letter-spacing:.3px;color:#0d1b2f}
.admin-login-subtitle{font-size:12px;font-weight:800;color:var(--muted)}
.admin-login-error{
  margin:10px 0 12px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(204,31,26,.25);
  background:rgba(204,31,26,.06);
  color:#8d1412;
  font-weight:900;
  font-size:13px;
}
.admin-login-form{display:flex;flex-direction:column;gap:12px}
.admin-login-label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:900;color:#22314a}
.admin-login-input{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  outline:none;
  font-size:14px;
  font-weight:800;
}
.admin-login-input:focus{border-color:rgba(31,92,255,.35);box-shadow:0 0 0 4px rgba(31,92,255,.12)}
.admin-login-actions{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-top:4px}
.admin-login-btn{flex:1}
.admin-login-back{
  flex:0 0 auto;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.72);
  text-decoration:none;
  color:#22314a;
  font-weight:900;
  font-size:13px;
}
.admin-login-back:hover{background:#fff;border-color:rgba(31,92,255,.22)}
@keyframes adminLoginGlow{
  0%{transform:translate3d(-2%, -1%, 0) rotate(0deg)}
  50%{transform:translate3d(2%, 1%, 0) rotate(6deg)}
  100%{transform:translate3d(-2%, -1%, 0) rotate(0deg)}
}
.admin-nav-overlay{
  position:fixed;
  inset:0;
  background:rgba(6,10,18,.42);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
  z-index:69;
}
.admin-body.admin-nav-open{overflow:hidden}
.admin-body.admin-nav-open .admin-nav-overlay{opacity:1;pointer-events:auto}
.admin-topright{display:flex;gap:10px;align-items:center}
.admin-user{display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px 10px}
.admin-user-name{font-weight:800;font-size:12px;color:#22314a}
.admin-user-avatar{width:28px;height:28px;border-radius:999px;background:rgba(31,92,255,.10);color:var(--blue-dark);display:flex;align-items:center;justify-content:center}
.admin-flash{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(34,197,94,.28);
  background:rgba(34,197,94,.08);
  color:#14532d;
  font-weight:900;
  margin:0 0 12px;
  box-shadow:0 14px 28px rgba(10,20,60,.08);
}
.admin-flash-msg{font-size:13px}
.admin-flash-close{width:34px;height:34px;border-radius:12px}
.admin-flash.success{border-color:rgba(34,197,94,.28);background:rgba(34,197,94,.08);color:#14532d}
.admin-image-preview{
  width:220px;
  height:140px;
  border-radius:12px;
  border:1px solid var(--border);
  object-fit:cover;
  background:#fff;
  display:block;
}
.admin-image-preview[src=""]{display:none}
.admin-thumb{
  width:38px;
  height:38px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#fff;
  object-fit:cover;
  display:block;
}
.admin-thumb-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue-dark);
  background:rgba(31,92,255,.08);
  font-weight:900;
}
.admin-price-input{
  width:110px;
  padding:8px 10px;
  border-radius:10px;
}
.admin-items-mobile{display:none}
.admin-item-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 12px 26px rgba(10,20,60,.10);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.admin-item-top{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.admin-item-thumb{
  width:54px;
  height:54px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  object-fit:cover;
  display:block;
  flex:0 0 auto;
}
.admin-item-main{min-width:0;flex:1 1 auto}
.admin-item-title-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.admin-item-title{
  font-weight:950;
  letter-spacing:-.2px;
  color:#0d1b2f;
  font-size:14px;
  line-height:1.15;
  min-width:0;
}
.admin-item-meta{
  margin-top:6px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.admin-item-meta-pill{
  display:inline-flex;
  align-items:center;
  padding:5px 8px;
  border-radius:999px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.92);
  font-size:11px;
  font-weight:900;
  color:rgba(34,49,74,.82);
}
.admin-item-subtitle{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
  line-height:1.35;
  font-weight:800;
}
.admin-item-sort{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.admin-item-price{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.admin-item-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.admin-item-actions form{margin:0}
.admin-logos-mobile{display:none}
.admin-logo-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 12px 26px rgba(10,20,60,.10);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.admin-logo-top{display:flex;gap:12px;align-items:flex-start}
.admin-logo-thumb{
  width:54px;
  height:54px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  object-fit:cover;
  display:block;
  flex:0 0 auto;
}
.admin-logo-main{min-width:0;flex:1 1 auto}
.admin-logo-title-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.admin-logo-title{
  font-weight:950;
  letter-spacing:-.2px;
  color:#0d1b2f;
  font-size:14px;
  line-height:1.15;
  min-width:0;
  word-break:break-word;
}
.admin-logo-meta{
  margin-top:6px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.admin-logo-meta-pill{
  display:inline-flex;
  align-items:center;
  padding:5px 8px;
  border-radius:999px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.92);
  font-size:11px;
  font-weight:900;
  color:rgba(34,49,74,.82);
}
.admin-logo-link{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.admin-logo-sort{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.admin-logo-sort form,.admin-logo-delete{margin:0}
.admin-logo-form{gap:10px;margin:0}
.admin-users-mobile{display:none}
.admin-user-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 12px 26px rgba(10,20,60,.10);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.admin-user-title-row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
}
.admin-user-title{
  font-weight:950;
  letter-spacing:-.2px;
  color:#0d1b2f;
  font-size:14px;
  line-height:1.15;
}
.admin-user-id{
  font-size:11px;
  font-weight:950;
  color:rgba(34,49,74,.72);
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.92);
  padding:5px 8px;
  border-radius:999px;
}
.admin-user-meta{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
.admin-user-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.admin-user-actions form{margin:0}
.admin-hours-mobile{display:none}
.admin-hours-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 12px 26px rgba(10,20,60,.10);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.admin-hours-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.admin-hours-day{
  font-weight:950;
  letter-spacing:-.2px;
  color:#0d1b2f;
  font-size:14px;
}
.admin-hours-closed{
  display:flex;
  align-items:center;
  gap:8px;
}
.admin-hours-times{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.admin-hours-time label{margin:0 0 6px}
.admin-hours-time input[type="time"]{width:100%}
.admin-cats-mobile{display:none}
.admin-cat-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 12px 26px rgba(10,20,60,.10);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.admin-cat-title-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.admin-cat-title{
  font-weight:950;
  letter-spacing:-.2px;
  color:#0d1b2f;
  font-size:14px;
  line-height:1.15;
  min-width:0;
  word-break:break-word;
}
.admin-cat-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.admin-cat-meta-pill{
  display:inline-flex;
  align-items:center;
  padding:5px 8px;
  border-radius:999px;
  border:1px solid rgba(227,232,242,.92);
  background:rgba(255,255,255,.92);
  font-size:11px;
  font-weight:900;
  color:rgba(34,49,74,.82);
}
.admin-cat-subtitle{
  font-size:12px;
  color:var(--muted);
  line-height:1.35;
  font-weight:800;
}
.admin-cat-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.admin-cat-actions form{margin:0}
.admin-save-state{
  margin-left:10px;
  font-size:12px;
  font-weight:800;
  color:var(--muted);
}
.admin-move-btn{
  width:30px;
  height:30px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
  font-weight:900;
  color:#22314a;
}
.admin-move-btn:disabled{
  opacity:.35;
  cursor:not-allowed;
}

@media (max-width: 980px){
  body{font-size:16px}
  .container{padding:18px 16px}
  .hero-inner{grid-template-columns:1fr;min-height:380px}
  .features{grid-template-columns:repeat(2,1fr)}
  .menu-card{grid-column:span 6}
  .grid .col-6,.grid .col-3,.grid .col-9{grid-column:span 12}
  .site-nav{display:none}
  .header-bar{flex:0 0 auto;min-width:0;padding:4px 6px}
  .site-actions{margin-left:auto}
  .hamburger-btn{display:flex}
  .hamburger-btn{order:99}
  .hamburger-btn.icon-btn{
    background:linear-gradient(180deg, var(--blue) 0%, var(--blue-dark) 100%);
    border-color:rgba(31,92,255,.30);
    color:#fff;
    box-shadow:0 14px 30px rgba(31,92,255,.22);
  }
  .logo-text{display:flex}
  .has-logo .site-header-inner{padding-top:10px}
  .has-logo .logo-mark{display:flex}
  .has-logo .logo-sticker{display:none}
  .scroll-top{display:flex;bottom:calc(78px + env(safe-area-inset-bottom))}
  .call-fab{display:flex}
  .page-hero-inner{flex-direction:column;align-items:flex-start}
  .page-hero-actions{justify-content:flex-start}
  .hero-left h1{font-size:38px}
  .hero-left p{font-size:15px;max-width:42ch}
  .section-title{font-size:22px}
  .menu-card-name{font-size:15px}
  .menu-card-desc{font-size:13px}
  .menu-card-price{font-size:14px}
  .category-pills{
    flex-wrap:nowrap;
    justify-content:flex-start;
    overflow:auto;
    gap:10px;
    padding:4px 44px 12px 2px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    scroll-snap-type:x proximity;
    -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 20px, #000 calc(100% - 20px), transparent 100%);
    mask-image:linear-gradient(90deg, transparent 0, #000 20px, #000 calc(100% - 20px), transparent 100%);
  }
  .category-pills::-webkit-scrollbar{display:none}
  .cat-toggle{
    display:flex;
    align-items:center;
    justify-content:center;
    position:absolute;
    right:6px;
    top:2px;
    width:36px;
    height:36px;
    border-radius:14px;
    border:1px solid rgba(31,92,255,.28);
    background:linear-gradient(180deg, rgba(31,92,255,.12) 0%, rgba(31,92,255,.06) 100%);
    color:var(--blue-dark);
    box-shadow:0 14px 28px rgba(10,20,60,.12);
  }
  .category-pills-wrap.open .cat-toggle svg{transform:rotate(180deg)}
  .category-pills-wrap.open .category-pills{
    flex-wrap:wrap;
    overflow:visible;
    padding-right:2px;
    -webkit-mask-image:none;
    mask-image:none;
  }
  .pill{
    flex:0 0 auto;
    font-size:14px;
    padding:10px 14px;
    border-radius:14px;
    background:rgba(255,255,255,.92);
    scroll-snap-align:start;
    box-shadow:0 10px 22px rgba(10,20,60,.10);
  }
  .pill.active{
    background:linear-gradient(180deg, var(--blue) 0%, var(--blue-dark) 100%);
    border-color:rgba(31,92,255,.30);
    box-shadow:0 16px 34px rgba(31,92,255,.22);
  }
  .footer-title{font-size:13px}
  .footer-text,.footer-row,.footer-link{font-size:13px}

  .admin-shell{grid-template-columns:1fr}
  .admin-hamburger{display:flex}
  .admin-toprow{justify-content:space-between}
  .admin-dash-hero{flex-direction:column;align-items:flex-start}
  .admin-dash-title{font-size:24px}
  .admin-dash-stats{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .admin-main .col-6,
  .admin-main .col-3,
  .admin-main .col-9{grid-column:span 12}
  .admin-main .admin-image-preview{max-width:100%;height:auto}
  .admin-main .table-wrap .table{min-width:760px}
  .admin-items-filter{flex-direction:column;align-items:stretch}
  .admin-items-filter-left{width:100%}
  .admin-items-filter-left select{width:100%}
  .admin-items-filter-note{align-self:flex-start}
  .admin-items-table{display:none}
  .admin-items-mobile{display:flex;flex-direction:column;gap:12px}
  .admin-item-card .admin-price-input{width:100%;max-width:220px}
  .admin-logos-table{display:none}
  .admin-logos-mobile{display:flex;flex-direction:column;gap:12px}
  .admin-users-table{display:none}
  .admin-users-mobile{display:flex;flex-direction:column;gap:12px}
  .admin-hours-table{display:none}
  .admin-hours-mobile{display:flex;flex-direction:column;gap:12px}
  .admin-cats-table{display:none}
  .admin-cats-mobile{display:flex;flex-direction:column;gap:12px}
  .admin-sidebar{
    position:fixed;
    left:0;
    top:0;
    height:100vh;
    width:min(86vw, 320px);
    transform:translateX(-110%);
    transition:transform .22s ease;
    z-index:70;
    box-shadow:0 30px 60px rgba(0,0,0,.28);
  }
  .admin-body.admin-nav-open .admin-sidebar{transform:translateX(0)}
  .admin-main{padding:16px}
}
@media (min-width: 981px){
  .topbar{display:block}
  .has-logo .topbar-inner{padding-left:130px}
  .has-logo .logo-sticker{top:44px}
  .has-logo .logo{display:none}
  .has-logo .header-bar{margin-left:110px}
}
@media (max-width: 720px){
  .site-footer-inner{grid-template-columns:1fr 1fr;gap:14px}
  .footer-card{border-radius:18px}
  .item-modal-card{grid-template-columns:1fr}
  .item-modal-media{min-height:220px}
}
@media (max-width: 540px){
  .menu-card{grid-column:span 12}
  .features{grid-template-columns:1fr}
  .hero-left h1{font-size:36px}
  .map-iframe{height:260px}
  .site-footer-inner{grid-template-columns:1fr;gap:14px;padding:18px 16px}
  .site-footer-inner .footer-col{padding-top:14px;border-top:1px solid rgba(255,255,255,.10)}
  .site-footer-inner .footer-col:first-child{padding-top:0;border-top:0}
  .footer-brand{text-align:center}
  .footer-logo-img{width:76px;height:76px;margin:0 auto 10px}
  .footer-tagline{margin-left:auto;margin-right:auto;max-width:42ch}
  .footer-social{flex-direction:column;align-items:stretch}
  .footer-social a{width:100%;justify-content:flex-start;padding:10px 12px}
  .footer-item{align-items:center}
  .footer-text{font-size:13px}
  .footer-row{padding:10px 12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10)}
  .footer-row.current{background:rgba(31,92,255,.22);border-color:rgba(31,92,255,.28)}
  .footer-link{
    display:flex;
    align-items:center;
    padding:10px 12px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.06);
    margin-top:8px;
    text-decoration:none;
  }
  .footer-link:hover{background:rgba(255,255,255,.10)}
}
