:root {
  --navy: #06132f;
  --navy2: #091b43;
  --navy3: #0c265e;
  --blue: #1268ff;
  --cyan: #18c9ff;
  --text: #071229;
  --muted: #64708a;
  --line: #e7edf7;
  --soft: #f5f8fd;
  --white: #fff;
  --success: #00b67a;
  --shadow: 0 24px 70px rgba(7,18,41,.13);
  --shadow-soft: 0 12px 30px rgba(7,18,41,.08);
  --radius: 24px;
  --max: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color:var(--text); background:#fff; line-height:1.55; }
body.lang-zh { font-family: Inter, "Noto Sans SC", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }
.container { width:min(var(--max), calc(100% - 48px)); margin:0 auto; }
.site-header { position:fixed; inset:0 0 auto 0; z-index:1000; transition:.25s ease; }
.site-header.scrolled { background:rgba(6,19,47,.9); border-bottom:1px solid rgba(255,255,255,.08); backdrop-filter:blur(18px); }
.nav-wrap { height:82px; display:flex; align-items:center; justify-content:space-between; gap:28px; }
.brand { flex:0 0 auto; display:flex; align-items:center; }
.brand-logo { width:320px; height:auto; display:block; }
.desktop-nav { display:flex; align-items:center; gap:31px; color:rgba(255,255,255,.86); font-weight:700; font-size:14px; }
.desktop-nav a { position:relative; padding:30px 0; }
.desktop-nav a::after { content:""; position:absolute; left:0; right:0; bottom:19px; height:3px; border-radius:99px; background:linear-gradient(90deg,var(--blue),var(--cyan)); opacity:0; transform:scaleX(.5); transition:.2s; }
.desktop-nav a:hover, .desktop-nav a.active { color:#fff; }
.desktop-nav a.active::after, .desktop-nav a:hover::after { opacity:1; transform:scaleX(1); }
.nav-actions { display:flex; align-items:center; gap:14px; }
.language-switch { display:inline-flex; align-items:center; gap:8px; color:rgba(255,255,255,.72); font-size:14px; font-weight:800; white-space:nowrap; }
.language-switch a:hover, .language-switch .active { color:#fff; }
.language-switch .active { border-bottom:2px solid var(--cyan); padding-bottom:3px; }
.language-switch span:not(.active) { color:rgba(255,255,255,.38); }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; border:0; border-radius:13px; padding:14px 22px; font-weight:900; line-height:1; cursor:pointer; transition:.22s ease; white-space:nowrap; }
.btn:hover { transform:translateY(-2px); }
.btn-primary { color:#fff; background:linear-gradient(135deg,var(--blue),var(--cyan)); box-shadow:0 16px 35px rgba(18,104,255,.32); }
.btn-ghost { color:#fff; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.22); }
.btn-dark { color:var(--blue); background:#fff; box-shadow:var(--shadow-soft); }
.menu-toggle { display:none; width:44px; height:44px; border-radius:12px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.menu-toggle span { width:18px; height:2px; background:#fff; border-radius:20px; }
.mobile-menu { display:none; position:fixed; top:82px; left:24px; right:24px; z-index:999; padding:18px; border-radius:20px; background:rgba(6,19,47,.96); border:1px solid rgba(255,255,255,.12); backdrop-filter:blur(18px); box-shadow:var(--shadow); }
.mobile-menu.open { display:block; }
.mobile-menu a { display:block; color:#fff; font-weight:800; padding:13px 10px; border-bottom:1px solid rgba(255,255,255,.08); }
.mobile-language { display:flex; gap:16px; padding:15px 10px 4px; color:#fff; font-weight:900; }
.mobile-language a { padding:0; border:0; color:var(--cyan); }
.hero, .page-hero { position:relative; overflow:hidden; color:#fff; background:radial-gradient(circle at 78% 18%,rgba(24,201,255,.24),transparent 28%), radial-gradient(circle at 80% 83%,rgba(18,104,255,.32),transparent 34%), linear-gradient(135deg,#050d25,#07183b 52%,#06132f); }
.hero::before, .page-hero::before { content:""; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px, transparent 1px); background-size:46px 46px; mask-image:radial-gradient(circle at 70% 45%,black,transparent 62%); }
.hero { min-height:740px; padding:138px 0 78px; }
.hero .container { width:min(1320px, calc(100% - 120px)); }
.hero-grid { position:relative; z-index:2; display:grid; grid-template-columns:minmax(0,560px) minmax(0,1fr); align-items:center; gap:90px; }
.hero-copy { position:relative; z-index:10; max-width:560px; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; padding:7px 12px; border-radius:999px; color:#b7dcff; background:rgba(18,104,255,.18); border:1px solid rgba(24,201,255,.25); font-size:12px; line-height:1; text-transform:uppercase; letter-spacing:.9px; font-weight:900; }
.hero h1 { margin:25px 0 22px; font-size:clamp(48px,5vw,76px); line-height:.97; letter-spacing:-4px; font-weight:900; }
.lang-zh .hero h1 { font-size:clamp(43px,4.3vw,64px); line-height:1.12; letter-spacing:-2.5px; }
.hero h1 .highlight { background:linear-gradient(135deg,#45ceff,#1268ff 65%); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero p, .page-hero p { margin:0; max-width:500px; color:rgba(255,255,255,.78); font-size:18px; line-height:1.65; }
.hero-buttons { display:flex; gap:16px; flex-wrap:wrap; margin:32px 0 30px; }
.rating { display:flex; align-items:center; gap:14px; color:rgba(255,255,255,.82); font-weight:800; font-size:14px; }
.stars { display:flex; gap:3px; }
.star { width:21px; height:21px; display:grid; place-items:center; background:var(--success); color:#fff; font-size:13px; }
.product-mockup { position:relative; z-index:1; min-height:452px; max-width:670px; margin-left:auto; }
.mock { position:absolute; border-radius:28px; box-shadow:0 28px 80px rgba(0,0,0,.42); border:1px solid rgba(255,255,255,.2); overflow:hidden; }
.phone-screen { left:0; bottom:25px; width:190px; min-height:360px; padding:26px 18px; background:#07132f; border:8px solid #111827; border-radius:35px; transform:rotate(-2deg); }
.mock-logo { font-weight:900; margin-bottom:22px; }
.phone-screen h3 { margin:0 0 10px; font-size:22px; line-height:1.1; letter-spacing:-1px; }
.phone-screen p { margin:0 0 18px; font-size:12px; line-height:1.4; color:rgba(255,255,255,.65); }
.mock-search { height:34px; border-radius:999px; background:rgba(255,255,255,.13); margin-bottom:14px; }
.mock-cats { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:18px; }
.mock-cats span { height:46px; border-radius:12px; background:rgba(255,255,255,.12); }
.mock-lines { display:grid; gap:12px; }
.mock-lines span { height:48px; border-radius:14px; background:rgba(255,255,255,.12); }
.web-screen { right:0; top:0; width:520px; height:318px; background:#fff; color:var(--text); }
.web-hero-mini { height:150px; padding:26px; background:linear-gradient(135deg,#080f29,#0b265a); color:#fff; position:relative; overflow:hidden; }
.web-hero-mini h3 { margin:0; width:55%; font-size:28px; line-height:1.05; letter-spacing:-1px; }
.food-orb { position:absolute; right:34px; top:30px; width:105px; height:105px; border-radius:50%; background:radial-gradient(circle,#ffd266,#ff7c33 42%,#2d1830 44%,#111 62%); border:9px solid rgba(255,255,255,.12); }
.dish-row { padding:22px; display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.dish-row span { height:90px; border-radius:18px; border:1px solid #edf1f7; background:linear-gradient(#fff,#f7faff); }
.dashboard-screen { right:10px; bottom:0; width:360px; height:230px; background:#07132f; color:#fff; padding:20px; transform:rotate(.5deg); }
.dash-head { font-weight:900; margin-bottom:16px; }
.dash-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.dash-stats span { padding:12px; border-radius:12px; background:rgba(255,255,255,.09); font-weight:900; font-size:20px; }
.chart-line { margin-top:16px; height:88px; border-radius:16px; background:linear-gradient(135deg,rgba(18,104,255,.18),rgba(24,201,255,.08)); position:relative; }
.chart-line::after { content:""; position:absolute; left:20px; right:20px; top:44px; height:3px; border-radius:99px; background:linear-gradient(90deg,var(--blue),var(--cyan)); transform:skewY(-10deg); }
.donut { position:absolute; right:30px; bottom:28px; width:72px; height:72px; border-radius:50%; background:conic-gradient(var(--blue) 0 62%, #263757 62% 100%); }
.stats-strip { position:relative; z-index:4; margin-top:-34px; }
.stats-card { display:grid; grid-template-columns:repeat(4,1fr); background:rgba(7,21,54,.94); color:#fff; border:1px solid rgba(255,255,255,.14); border-radius:18px; box-shadow:var(--shadow); overflow:hidden; }
.stat-item { display:flex; align-items:center; gap:18px; padding:22px 30px; border-right:1px solid rgba(255,255,255,.16); }
.stat-item:last-child { border-right:0; }
.stat-item .icon { width:38px; height:38px; color:var(--cyan); flex:0 0 auto; }
.stat-item strong { display:block; color:#35b9ff; font-size:23px; line-height:1; margin-bottom:4px; }
.stat-item span { color:rgba(255,255,255,.78); font-size:14px; }
section { padding:84px 0; }
.section-heading { max-width:760px; margin:0 auto 40px; text-align:center; }
.section-heading h2 { margin:0 0 12px; font-size:clamp(30px,3vw,46px); line-height:1.08; letter-spacing:-1.8px; font-weight:900; }
.lang-zh .section-heading h2 { letter-spacing:-.8px; }
.section-heading p { margin:0; color:var(--muted); font-size:17px; }
.solutions-section { background:linear-gradient(180deg,#fff,#f7faff); }
.card-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.solution-card, .feature-card, .why-card { background:#fff; border:1px solid var(--line); border-radius:22px; padding:28px; box-shadow:var(--shadow-soft); transition:.25s; }
.solution-card:hover, .feature-card:hover, .why-card:hover { transform:translateY(-5px); box-shadow:var(--shadow); }
.icon-circle { width:58px; height:58px; display:grid; place-items:center; border-radius:18px; background:#edf5ff; color:var(--blue); margin-bottom:20px; }
.icon-circle .icon { width:33px; height:33px; }
.solution-card h3, .feature-card h3, .why-card h3 { margin:0 0 9px; font-size:18px; line-height:1.2; }
.solution-card p, .feature-card p, .why-card p { margin:0 0 18px; color:var(--muted); font-size:14px; }
.card-link { color:var(--blue); font-weight:900; font-size:14px; }
.showcase-section { background:#fff; }
.showcase-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.showcase-card { display:grid; grid-template-columns:120px 1fr; gap:18px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:20px; padding:18px; box-shadow:var(--shadow-soft); }
.screen-thumb { height:88px; border-radius:14px; background:linear-gradient(135deg,#07132f,#0b2a68); position:relative; overflow:hidden; }
.screen-thumb::after { content:""; position:absolute; left:16px; right:16px; top:26px; height:8px; border-radius:99px; background:rgba(255,255,255,.28); box-shadow:0 18px 0 rgba(255,255,255,.17),0 36px 0 rgba(255,255,255,.14); }
.showcase-card h3 { margin:0 0 6px; font-size:16px; }
.showcase-card p { margin:0; color:var(--muted); font-size:13px; }
.why-section { background:var(--soft); }
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.page-hero { padding:140px 0 76px; }
.page-hero-grid { position:relative; z-index:2; display:grid; grid-template-columns:minmax(0,620px) 1fr; gap:60px; align-items:center; }
.page-hero h1 { margin:16px 0; font-size:clamp(42px,4.5vw,68px); line-height:1; letter-spacing:-3px; }
.lang-zh .page-hero h1 { line-height:1.12; letter-spacing:-1.6px; }
.page-visual { min-height:300px; position:relative; }
.feature-list { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.detail-section { background:linear-gradient(180deg,#fff,#f7faff); }
.detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:34px; align-items:start; }
.detail-panel { background:#fff; border:1px solid var(--line); border-radius:26px; padding:34px; box-shadow:var(--shadow-soft); }
.detail-panel h2 { margin:0 0 18px; font-size:32px; letter-spacing:-1px; }
.detail-list { padding:0; margin:0; list-style:none; display:grid; gap:14px; }
.detail-list li { display:flex; gap:12px; color:#25304a; font-weight:700; }
.detail-list li::before { content:"✓"; width:24px; height:24px; display:grid; place-items:center; border-radius:8px; background:var(--blue); color:#fff; flex:0 0 auto; font-weight:900; }
.contact-layout { display:grid; grid-template-columns:1fr .82fr; gap:30px; }
.contact-form, .contact-info { background:#fff; border:1px solid var(--line); border-radius:26px; padding:34px; box-shadow:var(--shadow-soft); }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid .full { grid-column:1 / -1; }
.form-field label { display:block; font-weight:800; margin-bottom:7px; font-size:13px; color:#23304d; }
.form-field input, .form-field select, .form-field textarea { width:100%; border:1px solid #dfe6f2; border-radius:13px; padding:14px 15px; outline:none; font:inherit; }
.form-field textarea { min-height:135px; resize:vertical; }
.contact-info h3 { margin-top:0; }
.contact-row { display:flex; gap:12px; padding:14px 0; border-bottom:1px solid var(--line); color:var(--muted); }
.contact-row strong { color:var(--text); }
.cta-section { padding:0; background:linear-gradient(135deg,#06132f,#064ae0); color:#fff; }
.cta-card { display:grid; grid-template-columns:1fr auto; gap:32px; align-items:center; padding:56px 0; }
.cta-card h2 { margin:0 0 10px; font-size:clamp(30px,3vw,46px); line-height:1.08; letter-spacing:-1.5px; }
.cta-card p { margin:0; color:rgba(255,255,255,.76); font-size:17px; }
.cta-actions { display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end; }
.site-footer { background:#040b1e; color:rgba(255,255,255,.72); padding:56px 0 28px; }
.footer-grid { display:grid; grid-template-columns:1.3fr repeat(3,1fr); gap:44px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-logo { width:260px; height:auto; margin-bottom:18px; }
.footer-company p { max-width:330px; margin:0; }
.site-footer h3 { margin:0 0 16px; color:#fff; font-size:15px; }
.site-footer a, .site-footer span { display:block; margin:0 0 10px; font-size:14px; }
.site-footer a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; gap:20px; padding-top:24px; color:rgba(255,255,255,.52); font-size:13px; }
@media (max-width:1100px){
  .brand-logo{width:220px}.desktop-nav{gap:22px}.nav-cta{display:none}.hero .container{width:min(100% - 48px,var(--max))}.hero-grid{grid-template-columns:1fr;gap:45px}.product-mockup{margin:0 auto;max-width:720px}.stats-card{grid-template-columns:repeat(2,1fr)}.stat-item:nth-child(2){border-right:0}.stat-item:nth-child(1),.stat-item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.16)}.card-grid,.why-grid{grid-template-columns:repeat(2,1fr)}.showcase-grid{grid-template-columns:repeat(2,1fr)}.page-hero-grid,.detail-grid,.contact-layout{grid-template-columns:1fr}.footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:800px){
  .desktop-nav,.language-switch{display:none}.menu-toggle{display:flex}.nav-wrap{height:76px}.brand-logo{width:205px}.hero{padding:112px 0 64px;min-height:auto}.hero h1{font-size:43px;letter-spacing:-2.5px}.lang-zh .hero h1{font-size:38px}.hero-buttons .btn{width:100%}.rating{align-items:flex-start;flex-direction:column}.product-mockup{min-height:430px;transform:scale(.86);transform-origin:top center;margin-bottom:-60px}.web-screen{width:430px}.dashboard-screen{width:300px}.phone-screen{width:170px}.stats-strip{margin-top:-12px}.stats-card{grid-template-columns:1fr}.stat-item{border-right:0!important}.stat-item{border-bottom:1px solid rgba(255,255,255,.16)}.stat-item:last-child{border-bottom:0}.card-grid,.why-grid,.showcase-grid,.feature-list{grid-template-columns:1fr}.showcase-card{grid-template-columns:100px 1fr}.page-hero{padding:116px 0 62px}.page-hero h1{font-size:40px}.form-grid{grid-template-columns:1fr}.cta-card{grid-template-columns:1fr}.cta-actions{justify-content:stretch}.cta-actions .btn{width:100%}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column}.container{width:min(100% - 32px,var(--max))}
}
@media (max-width:520px){
  .brand-logo{width:190px}.product-mockup{transform:scale(.72);min-height:360px;margin-left:-70px}.hero p,.page-hero p{font-size:16px}.section-heading h2{font-size:28px}.solution-card,.feature-card,.why-card,.detail-panel,.contact-form,.contact-info{padding:24px}.footer-logo{width:230px}
}
/* ===== Mobile Hero Final Fix ===== */
@media (max-width: 1024px) {
  .hero {
    min-height: auto !important;
    padding: 100px 0 72px !important;
    overflow: hidden !important;
  }

  .hero .container {
    width: min(100% - 32px, 1180px) !important;
  }

  .hero-grid {
    display: block !important;
  }


}
/* ===== Desktop Hero Balance Fix ===== */

@media (min-width: 1025px) {

  .hero .container {

    width: min(1240px, calc(100% - 96px)) !important;

  }

  .hero-grid {

    grid-template-columns: minmax(0, 520px) minmax(0, 1fr) !important;

    gap: 48px !important;

    align-items: center !important;

  }

  .hero-grid > div:first-child {

    max-width: 520px !important;

    position: relative !important;

    z-index: 5 !important;

  }

  .hero h1 {

    max-width: 520px !important;

  }

  .hero p {

    max-width: 480px !important;

  }

  .mockup-stage,

  .hero-grid > div:nth-child(2) {

    max-width: 610px !important;

    margin-left: 0 !important;

    margin-right: 0 !important;

  }

}
/* ===== Hero mockup - V2 restored version ===== */

.mockup-stage {
  position: relative;
  width: 660px;
  height: 520px;
  max-width: 660px;
}

.glow-card {
  position: absolute;
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.36);
  overflow: hidden;
}

.dashboard-card {
  top: 55px;
  left: 58px;
  width: 440px;
  min-height: 318px;
  transform: rotate(-1deg);
  z-index: 2;
}

.website-card {
  right: 0;
  top: 112px;
  width: 330px;
  min-height: 330px;
  transform: rotate(5deg);
  z-index: 3;
}

.phone-card {
  position: absolute;
  left: 0;
  top: 22px;
  width: 205px;
  min-height: 425px;
  border-radius: 38px;
  background: #07132f;
  border: 8px solid #111827;
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.45);
  transform: rotate(-4deg);
  z-index: 4;
  overflow: hidden;
}

.device-top {
  height: 38px;
  background: #f7f9fc;
  display: flex;
  align-items: center;
  padding: 0 16px;
  color: #08122f;
  font-size: 12px;
  font-weight: 800;
  gap: 8px;
  border-bottom: 1px solid #edf1f7;
}

.device-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #1268ff;
}

.dash-body {
  padding: 18px;
  color: #08122f;
}

.dash-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.dash-title h3 {
  margin: 0;
  font-size: 18px;
}

.dash-title span {
  color: #5e6a83;
  font-size: 12px;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.metric {
  padding: 12px;
  border-radius: 14px;
  background: #f5f8fc;
  font-size: 11px;
  color: #5e6a83;
  font-weight: 700;
}

.metric strong {
  display: block;
  margin-top: 4px;
  color: #1268ff;
  font-size: 21px;
  font-weight: 900;
}

.order-list {
  display: grid;
  gap: 8px;
}

.order-row {
  display: grid;
  grid-template-columns: 1fr 1.4fr 0.9fr 0.8fr;
  gap: 8px;
  align-items: center;
  padding: 10px;
  border-radius: 12px;
  background: #fbfcff;
  border: 1px solid #edf1f7;
  font-size: 11px;
  color: #5e6a83;
}

.status {
  padding: 4px 8px;
  border-radius: 999px;
  background: #e7f0ff;
  color: #004fe8;
  font-weight: 800;
  text-align: center;
}

.web-hero {
  background: linear-gradient(135deg, #07132f, #09245a);
  color: white;
  padding: 24px;
  min-height: 162px;
  position: relative;
  overflow: hidden;
}

.web-hero h3 {
  width: 62%;
  margin: 0 0 12px;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -1px;
}

.food-circle {
  position: absolute;
  right: 22px;
  top: 24px;
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: radial-gradient(circle, #ffcf55 0%, #ff8b36 35%, #1b1730 40%, #111827 62%);
  border: 8px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 12px 28px rgba(0,0,0,0.35);
}

.dish-grid {
  padding: 18px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.dish {
  border-radius: 14px;
  border: 1px solid #edf1f7;
  padding: 10px;
  min-height: 94px;
  color: #08122f;
  background: white;
  font-size: 10px;
  font-weight: 800;
}

.dish::before {
  content: "";
  display: block;
  width: 42px;
  height: 42px;
  margin-bottom: 8px;
  border-radius: 50%;
  background: radial-gradient(circle, #f4c35d, #d65a31 58%, #51291e 60%);
}

.phone-inner {
  padding: 18px 14px;
  color: white;
}

.phone-logo {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 22px;
}

.phone-inner h3 {
  margin: 0 0 10px;
  font-size: 19px;
  line-height: 1.12;
  letter-spacing: -0.6px;
}

.phone-inner p {
  font-size: 11px;
  color: rgba(255,255,255,0.66);
  margin: 0 0 14px;
}

.search-bar {
  height: 32px;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
  margin-bottom: 12px;
}

.cat-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 7px;
  margin-bottom: 14px;
}

.cat {
  height: 44px;
  border-radius: 12px;
  background: rgba(255,255,255,0.1);
}

.food-row {
  display: grid;
  gap: 8px;
}

.food-item {
  height: 48px;
  border-radius: 14px;
  background: rgba(255,255,255,0.12);
}
/* ===== Desktop dropdown navigation ===== */

.desktop-nav {
  display: flex;
  align-items: center;
  gap: 34px;
}

.nav-dropdown {
  position: relative;
}

.nav-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.dropdown-arrow {
  font-size: 12px;
  opacity: 0.75;
  transform: translateY(1px);
}

.dropdown-menu {
  position: absolute;
  top: calc(100% + 18px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  width: 390px;
  padding: 14px;
  border-radius: 22px;
  background: rgba(6, 19, 47, 0.96);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 24px 70px rgba(0,0,0,0.35);
  backdrop-filter: blur(18px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: 0.2s ease;
  z-index: 500;
}

.nav-dropdown:hover .dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.dropdown-menu::before {
  content: "";
  position: absolute;
  top: -18px;
  left: 0;
  right: 0;
  height: 18px;
}

.dropdown-menu a {
  display: block;
  padding: 14px 16px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  transition: 0.18s ease;
}

.dropdown-menu a:hover,
.dropdown-menu a.active {
  background: rgba(18, 104, 255, 0.18);
}

.dropdown-menu strong {
  display: block;
  font-size: 15px;
  line-height: 1.2;
  margin-bottom: 5px;
}

.dropdown-menu span {
  display: block;
  color: rgba(255,255,255,0.62);
  font-size: 12px;
  line-height: 1.35;
}

/* ===== Mobile menu nested solutions ===== */

.mobile-menu-group {
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.mobile-menu-main {
  font-weight: 900;
  color: #ffffff !important;
}

.mobile-menu-sub {
  padding-left: 28px !important;
  font-size: 15px !important;
  color: rgba(255,255,255,0.78) !important;
}
/* ===== Final mobile header + hero fix ===== */
@media (max-width: 1024px) {
  body {
    overflow-x: hidden;
  }

  .site-header,
  .nav {
    width: 100%;
    max-width: 100%;
  }

  .nav {
    height: 96px;
    padding: 0 26px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .desktop-nav,
  .nav-actions,
  .language-switch,
  .phone-pill {
    display: none !important;
  }

  .menu-toggle {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    font-size: 28px;
  }

  .brand-logo {
    width: 270px;
    max-width: calc(100vw - 120px);
    height: auto;
    display: block;
  }

  .hero {
    min-height: auto !important;
    padding: 118px 0 72px !important;
    overflow: hidden !important;
  }

  .hero .container {
    width: min(100% - 32px, 1180px) !important;
  }

  .hero-grid {
    display: block !important;
  }

  .hero-grid > div:nth-child(2),
  .mockup-stage,
  .product-mockup {
    display: none !important;
  }

  .hero-grid > div:first-child {
    width: 100% !important;
    max-width: 100% !important;
    position: relative !important;
    z-index: 10 !important;
  }

  .hero .eyebrow {
    max-width: 100% !important;
    white-space: normal !important;
  }

  .hero h1 {
    max-width: 100% !important;
    font-size: clamp(42px, 11vw, 60px) !important;
    line-height: 1.02 !important;
    letter-spacing: -2.2px !important;
    margin: 32px 0 24px !important;
  }

  .hero p {
    max-width: 100% !important;
    font-size: 19px !important;
    line-height: 1.55 !important;
  }

  .hero-buttons {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    margin: 36px 0 30px !important;
  }

  .hero-buttons .btn {
    width: 100% !important;
    min-height: 62px !important;
    font-size: 18px !important;
    border-radius: 18px !important;
  }

  .rating {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
    font-size: 15px !important;
  }
}

@media (max-width: 520px) {
  .nav {
    height: 86px;
    padding: 0 20px;
  }

  .brand-logo {
    width: 235px;
    max-width: calc(100vw - 105px);
  }

  .menu-toggle {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    font-size: 25px;
  }

  .hero {
    padding: 105px 0 62px !important;
  }

  .hero h1 {
    font-size: 43px !important;
    letter-spacing: -1.8px !important;
  }

  .hero p {
    font-size: 18px !important;
  }
}
/* ===== Final mobile nav fix ===== */
@media (max-width: 1024px) {
  .desktop-nav {
    display: none !important;
  }

  .nav-actions {
    display: flex !important;
    align-items: center;
    margin-left: auto;
  }

  .language-switch,
  .phone-pill,
  .nav-actions .btn {
    display: none !important;
  }

  .menu-toggle {
    display: inline-flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.08);
    cursor: pointer;
  }

  .menu-toggle span {
    display: block;
    width: 26px;
    height: 3px;
    border-radius: 999px;
    background: #ffffff;
  }
}

@media (max-width: 520px) {
  .menu-toggle {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    gap: 6px;
  }

  .menu-toggle span {
    width: 24px;
    height: 3px;
  }
}

.mobile-language-switch {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 22px 20px 12px;
  margin-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.65);
  font-size: 18px;
  font-weight: 800;
}

.mobile-language-switch a {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
}

.mobile-language-switch a.active,
.mobile-language-switch span.active {
  color: #ffffff;
}

.mobile-language-switch span {
  color: rgba(255,255,255,0.35);
}

.mobile-demo-btn {
  display: flex !important;
  align-items: center;
  justify-content: center;
  margin: 16px 20px 6px;
  min-height: 54px;
  border-radius: 16px;
  background: linear-gradient(135deg, #1268ff, #00b8ff);
  color: #ffffff !important;
  font-size: 17px;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(18,104,255,0.32);
}
/* Fix dropdown item underline issue */
.dropdown-menu a::after,
.dropdown-menu a::before {
  display: none !important;
  content: none !important;
}

.dropdown-menu a {
  position: relative;
  border-bottom: none !important;
}

.dropdown-menu a:hover,
.dropdown-menu a.active {
  background: rgba(18, 104, 255, 0.18);
}
/* ===== Font weight refinement ===== */

.desktop-nav > a,
.nav-dropdown-toggle {
  font-weight: 700 !important;
}

.dropdown-menu strong {
  font-weight: 700 !important;
}

.dropdown-menu span {
  font-weight: 500 !important;
}

.btn {
  font-weight: 700 !important;
}

.nav-cta,
.btn-primary {
  font-weight: 800 !important;
}
.contact-divider {
  height: 1px;
  background: #e7ecf5;
  margin: 26px 0;
}

.map-box {
  width: 100%;
  height: 320px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid #e7ecf5;
  box-shadow: 0 12px 34px rgba(8, 18, 47, 0.08);
  background: #f5f8fc;
}

.map-box iframe {
  width: 100%;
  height: 100%;
  display: block;
}
@media (max-width: 768px) {
  .map-box {
    height: 260px;
    border-radius: 18px;
  }
}
.required {
  color: #1268ff;
}

.hp-field {
  position: absolute;
  left: -9999px;
  opacity: 0;
  height: 0;
  width: 0;
  pointer-events: none;
}

.char-counter {
  margin-top: 8px;
  color: #6b7488;
  font-size: 13px;
  text-align: right;
}

.char-counter.warning {
  color: #b45309;
}

.char-counter.error {
  color: #dc2626;
}
.form-alert {
  padding: 16px 18px;
  border-radius: 16px;
  margin-bottom: 22px;
  font-weight: 700;
}

.form-alert.success {
  background: #ecfdf5;
  color: #047857;
  border: 1px solid #a7f3d0;
}

.form-alert.error {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca;
}
.form-field input.is-invalid,
.form-field select.is-invalid,
.form-field textarea.is-invalid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.08);
}

.field-error {
  display: none;
  margin-top: 7px;
  color: #dc2626;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

.field-error.show {
  display: block;
}

.form-field input.is-valid,
.form-field textarea.is-valid {
  border-color: #22c55e;
}
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}

.footer-legal-links {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  white-space: nowrap;
}

.footer-legal-links a {
  display: inline;
  color: inherit;
  text-decoration: none;
}

.footer-legal-links a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.footer-legal-links span {
  display: inline;
  color: inherit;
}