@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&display=swap');

/* ─── Design tokens ─────────────────────────────────────── */
:root{
  --bg:#f7f8fb;
  --bg-card:#ffffff;
  --bg-subtle:#f0f2f7;
  --text:#0a0f1e;
  --text-2:#1e2540;
  --muted:#5e6687;
  --muted-light:#9198b4;
  --primary:#e23744;
  --primary-2:#c01f2d;
  --primary-3:#f85c67;
  --primary-light:rgba(226,55,68,.10);
  --primary-glow:rgba(226,55,68,.22);
  --accent:#0f52ba;
  --accent-light:rgba(15,82,186,.10);
  --gold:#c98f1a;
  --success:#059669;
  --line:rgba(10,15,30,.08);
  --line-strong:rgba(10,15,30,.16);
  --shadow:0 1px 3px rgba(10,15,30,.04),0 8px 32px rgba(10,15,30,.07),0 2px 8px rgba(10,15,30,.04);
  --shadow-md:0 4px 16px rgba(10,15,30,.08),0 12px 40px rgba(10,15,30,.10);
  --shadow-lift:0 8px 32px rgba(10,15,30,.12),0 24px 64px rgba(10,15,30,.14);
  --shadow-primary:0 8px 28px rgba(226,55,68,.30);
  --radius:20px;
  --radius-sm:12px;
  --radius-xs:8px;
  --font-display:'Bricolage Grotesque',system-ui,sans-serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --transition:.18s cubic-bezier(.4,0,.2,1);
  --header-h:68px;
}

/* ─── Reset & base ──────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  min-height:100vh;
  background-image:
    radial-gradient(ellipse 700px 500px at 85% -5%,rgba(226,55,68,.06),transparent),
    radial-gradient(ellipse 600px 600px at -10% 95%,rgba(15,82,186,.05),transparent);
}
body.is-loading{overflow:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
ul{list-style:none}

/* ─── Layout ────────────────────────────────────────────── */
.container{width:min(1240px,calc(100% - 40px));margin-inline:auto}

/* ─── Background orbs ───────────────────────────────────── */
.bg-orb{position:fixed;inset:auto;z-index:-1;border-radius:50%;filter:blur(90px);opacity:.12;pointer-events:none;animation:orbFloat 18s ease-in-out infinite alternate}
.bg-orb-1{width:600px;height:600px;background:radial-gradient(circle,#e23744,#f97316);top:-200px;right:-180px;animation-delay:0s}
.bg-orb-2{width:700px;height:700px;background:radial-gradient(circle,#0f52ba,#6366f1);bottom:-250px;left:-200px;animation-delay:-9s}
@keyframes orbFloat{from{transform:translateY(0) scale(1)}to{transform:translateY(40px) scale(1.06)}}

/* ─── Page loader ───────────────────────────────────────── */
.page-loader{position:fixed;inset:0;z-index:900;background:var(--bg);display:grid;place-items:center;transition:opacity .4s ease,visibility .4s ease}
.page-loader-card{text-align:center;display:grid;gap:16px;place-items:center}
.page-loader-spinner{width:44px;height:44px;border:3px solid var(--line-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
body:not(.is-loading) .page-loader{opacity:0;visibility:hidden;pointer-events:none}

/* ─── Top progress bar ──────────────────────────────────── */
.top-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:999;background:linear-gradient(90deg,var(--primary),var(--primary-3),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .3s ease;border-radius:0 2px 2px 0}

/* ─── Toast ─────────────────────────────────────────────── */
.toast-stack{position:fixed;bottom:24px;right:24px;z-index:800;display:grid;gap:10px;max-width:360px}
.toast{padding:14px 18px;border-radius:var(--radius-sm);background:#fff;border:1px solid var(--line-strong);box-shadow:var(--shadow-md);display:flex;gap:12px;align-items:flex-start;font-size:.9rem}
.toast-success{border-left:4px solid var(--success)}
.toast-error,.toast-danger{border-left:4px solid var(--primary)}
.toast-info{border-left:4px solid var(--accent)}
.toast-warning{border-left:4px solid var(--gold)}

/* ─── Site header ───────────────────────────────────────── */
.site-header{
  position:sticky;top:0;
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  background:rgba(247,248,251,.88);
  border-bottom:1px solid var(--line);
  z-index:20;
  height:var(--header-h);
}
.header-inner{
  display:flex;align-items:center;
  justify-content:space-between;
  gap:16px;height:100%;
}

/* ─── Logo / Brand ──────────────────────────────────────── */
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.brand-icon{width:36px;height:36px;flex-shrink:0}
.brand-wordmark{
  font-family:var(--font-display);
  font-weight:800;
  font-size:1.18rem;
  letter-spacing:-.04em;
  color:var(--text);
  line-height:1;
}
.brand-wordmark em{color:var(--primary);font-style:normal}
.brand-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--primary);
  flex-shrink:0;
  box-shadow:0 0 0 3px var(--primary-light);
}

/* ─── Navigation ────────────────────────────────────────── */
.top-nav{display:flex;flex-wrap:wrap;gap:2px;align-items:center;flex:1 1 auto}
.top-nav a{
  color:var(--muted);font-size:.875rem;font-weight:600;
  padding:7px 12px;border-radius:999px;
  transition:color var(--transition),background var(--transition);
  display:flex;align-items:center;gap:6px;white-space:nowrap;
}
.top-nav .nav-icon{width:15px;height:15px;display:inline-flex;align-items:center}
.top-nav .nav-icon svg{width:15px;height:15px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.top-nav a:hover{color:var(--text);background:rgba(10,15,30,.06)}
.top-nav a.active{color:var(--primary);background:var(--primary-light)}
.header-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.header-action{padding:9px 18px !important;white-space:nowrap}

/* ─── Page shell ────────────────────────────────────────── */
.page-shell{padding:36px 0 72px}

/* ─── Buttons ───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:var(--radius-sm);border:1px solid transparent;
  font-family:var(--font-body);font-weight:600;font-size:.9rem;letter-spacing:.005em;
  transition:transform var(--transition),box-shadow var(--transition),background var(--transition),border-color var(--transition);
  cursor:pointer;white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0);transition-duration:.08s}
.btn-primary{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-2) 100%);
  color:#fff;box-shadow:var(--shadow-primary);
}
.btn-primary:hover{box-shadow:0 12px 36px rgba(226,55,68,.40);background:linear-gradient(135deg,var(--primary-3) 0%,var(--primary) 100%)}
.btn-secondary{background:#fff;border-color:var(--line-strong);color:var(--text);box-shadow:var(--shadow)}
.btn-secondary:hover{border-color:rgba(10,15,30,.22);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;border-color:var(--line-strong);color:var(--muted)}
.btn-ghost:hover{color:var(--text);background:rgba(10,15,30,.04)}
.btn-accent{background:linear-gradient(135deg,var(--accent),#3b6fd4);color:#fff;box-shadow:0 8px 24px rgba(15,82,186,.28)}

/* ─── Pill / Badge row ──────────────────────────────────── */
.pill-row,.badges-row{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0}
.pill{padding:6px 14px;border-radius:999px;background:#fff;border:1px solid var(--line-strong);font-size:.8rem;font-weight:700;letter-spacing:.02em;color:var(--muted)}
.pill.accent{background:var(--primary-light);border-color:rgba(226,55,68,.2);color:var(--primary)}
.badge{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid transparent}
.badge.green{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}
.badge.red{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.badge.gold{background:#fffbeb;color:#92400e;border-color:#fde68a}
.badge.blue{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}
.badge.muted{background:var(--bg-subtle);color:var(--muted);border-color:var(--line-strong)}

/* ─── CTA row ───────────────────────────────────────────── */
.cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}

/* ─── Eyebrow / Label ───────────────────────────────────── */
.eyebrow{font-size:.75rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--primary);margin-bottom:10px}
.label-muted{font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ─── Card surfaces ─────────────────────────────────────── */
.hero-card,.panel,.stat,.menu-item,.order-card,.project-card,.ad-card,.login-card,.profile-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.panel h2,.panel h3,.login-card h2{font-family:var(--font-display);letter-spacing:-.03em}

/* ─── Hero ──────────────────────────────────────────────── */
.hero{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;align-items:center;
  padding:40px 0 20px;
}
.hero-copy h1,.section-title{
  font-family:var(--font-display);
  font-size:clamp(2rem,4.8vw,3.8rem);
  line-height:1.04;
  letter-spacing:-.05em;
  margin-bottom:18px;
  color:var(--text);
}
.hero-copy h1 strong,.hero-copy h1 em{color:var(--primary);font-style:normal}
.hero-copy p{font-size:1.06rem;color:var(--muted);max-width:54ch;line-height:1.75}
.hero-side{padding:24px}
.hero-visual{display:grid;gap:16px}

/* ─── Hero visual panel (dashboard mock) ───────────────── */
.hero-visual-panel{
  padding:22px;border-radius:28px;
  border:1px solid var(--line);
  background:linear-gradient(160deg,#fff 0%,#f3f6ff 100%);
  box-shadow:var(--shadow-md);
  position:relative;overflow:hidden;
}
.hero-visual-panel::before{
  content:"";position:absolute;
  inset:auto -40px -50px auto;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(226,55,68,.12),transparent 70%);
  pointer-events:none;
}
.hero-mock{display:grid;gap:14px}
.hero-mock-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.hero-mock-title{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;font-size:1rem}
.hero-mock-chip{
  padding:5px 11px;border-radius:999px;
  background:linear-gradient(90deg,rgba(5,150,105,.12),rgba(5,150,105,.06));
  color:#059669;font-weight:800;font-size:.76rem;
  display:flex;align-items:center;gap:5px;
}
.hero-mock-chip::before{content:"";width:7px;height:7px;border-radius:50%;background:#059669;display:block;box-shadow:0 0 0 3px rgba(5,150,105,.2)}
.hero-mock-grid{display:grid;grid-template-columns:1fr 108px;gap:14px;align-items:center}
.hero-mock-card{padding:16px;border-radius:16px;background:#fff;border:1px solid var(--line);display:grid;gap:10px;box-shadow:0 2px 8px rgba(10,15,30,.06)}
.hero-mock-line{height:9px;border-radius:999px;background:linear-gradient(90deg,rgba(226,55,68,.20),rgba(226,55,68,.05));width:100%}
.hero-mock-line.small{width:70%}
.hero-mock-line.xs{width:44%}
.hero-phone{padding:10px;border-radius:26px;background:linear-gradient(180deg,#0a1628,#1a2744);box-shadow:0 20px 40px rgba(10,15,30,.22),inset 0 1px 0 rgba(255,255,255,.08)}
.hero-phone-screen{display:grid;gap:10px;padding:12px;border-radius:18px;background:linear-gradient(180deg,#fff,#f0f4ff);min-height:200px}
.hero-phone-qr{display:grid;grid-template-columns:repeat(6,1fr);gap:3px;padding:10px;border-radius:14px;background:#fff;border:1px solid var(--line);box-shadow:inset 0 1px 3px rgba(10,15,30,.05)}
.hero-phone-qr span{aspect-ratio:1;border-radius:3px;background:#0a1628}
.hero-phone-qr span:nth-child(3n){background:var(--primary)}
.hero-phone-qr span:nth-child(4n){background:#94a3b8}
.hero-phone-qr span:nth-child(7n){background:var(--accent)}
.hero-phone-meta{display:grid;gap:6px}
.hero-phone-meta strong{font-family:var(--font-display);letter-spacing:-.03em;font-size:.9rem}
.hero-phone-meta span{color:var(--muted);font-size:.82rem;line-height:1.4}
.hero-spark{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;align-items:end;height:46px}
.hero-spark span{display:block;border-radius:999px 999px 4px 4px;opacity:.92}
.hero-spark span:nth-child(1){height:52%;background:linear-gradient(180deg,var(--primary-light),rgba(226,55,68,.04));border:1px solid rgba(226,55,68,.2)}
.hero-spark span:nth-child(2){height:78%;background:linear-gradient(180deg,var(--primary),var(--primary-2))}
.hero-spark span:nth-child(3){height:62%;background:linear-gradient(180deg,var(--primary),var(--primary-2));opacity:.7}
.hero-spark span:nth-child(4){height:92%;background:linear-gradient(180deg,var(--primary-3),var(--primary))}

/* ─── Stats grid ────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:20px}
.stat,.panel,.menu-item,.order-card,.project-card,.ad-card,.login-card,.profile-card{padding:20px}
.stat{border-radius:16px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.stat .label,.muted{color:var(--muted);font-size:.85rem}
.stat .value{font-family:var(--font-display);font-size:1.9rem;font-weight:800;letter-spacing:-.05em;line-height:1.1;margin-top:4px;color:var(--text)}

/* ─── Section styles ────────────────────────────────────── */
.section{margin-top:56px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px}
.section-divider{width:48px;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--primary-3));margin:14px 0}

/* ─── Section highlight (pricing banner) ───────────────── */
.section-highlight{
  display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;
  padding:48px 52px;border-radius:28px;
  background:linear-gradient(135deg,var(--text-2) 0%,#0a1628 60%,#101830 100%);
  color:#fff;position:relative;overflow:hidden;
  margin-top:56px;
}
.section-highlight::before{
  content:"";position:absolute;inset:auto -80px -80px auto;
  width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(226,55,68,.18),transparent 70%);
  pointer-events:none;
}
.section-highlight::after{
  content:"";position:absolute;inset:auto auto -60px -60px;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(15,82,186,.15),transparent 70%);
  pointer-events:none;
}
.section-highlight .eyebrow{color:var(--primary-3)}
.section-highlight h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.1;letter-spacing:-.04em;color:#fff;margin-bottom:10px}
.section-highlight p,.section-highlight .lead{color:rgba(255,255,255,.72);line-height:1.7}

/* ─── Benefit grid ──────────────────────────────────────── */
.benefit-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.benefit-card{
  padding:26px;border-radius:20px;
  background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow);
  transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition);
  position:relative;overflow:hidden;
}
.benefit-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--primary-3));
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;border-radius:20px 20px 0 0;
}
.benefit-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px);border-color:rgba(226,55,68,.15)}
.benefit-card:hover::before{transform:scaleX(1)}
.benefit-card h3{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:10px;font-size:1.05rem}
.benefit-card .benefit-icon{
  width:40px;height:40px;border-radius:12px;
  background:var(--primary-light);
  display:grid;place-items:center;margin-bottom:14px;
}
.benefit-card .benefit-icon svg{width:20px;height:20px;stroke:var(--primary);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* ─── Feature list (how it works) ──────────────────────── */
.feature-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature{
  padding:28px;border-radius:20px;
  background:rgba(255,255,255,.88);border:1px solid var(--line);
  transition:box-shadow var(--transition),transform var(--transition);
  position:relative;
}
.feature-num{
  font-family:var(--font-display);font-size:2.8rem;font-weight:800;
  color:var(--primary-light);letter-spacing:-.06em;line-height:1;
  margin-bottom:14px;
}
.feature-num-inner{
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.feature:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px)}
.feature h3{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:10px;font-size:1.05rem}

/* ─── Price card ────────────────────────────────────────── */
.price-card{
  padding:30px;border-radius:24px;
  background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-md);
}
.price-badge{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:var(--primary-light);color:var(--primary);
  font-size:.8rem;font-weight:800;letter-spacing:.02em;
  margin-bottom:18px;
}
.price{font-family:var(--font-display);font-size:2.8rem;font-weight:800;letter-spacing:-.05em;line-height:1.1;margin-bottom:8px;color:var(--text)}
.price-note{color:var(--muted);font-size:.9rem;line-height:1.6;margin-bottom:20px}
.price-card ul{display:grid;gap:10px}
.price-card ul li{display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:500}
.price-card ul li::before{
  content:"";width:18px;height:18px;flex-shrink:0;border-radius:50%;
  background:linear-gradient(135deg,var(--success),#34d399);
  display:block;
  mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 13l4 4L19 7' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") center/contain no-repeat;
  -webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 13l4 4L19 7' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ─── FAQ cards ─────────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.faq-card{
  padding:26px;border-radius:20px;
  background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow);
  transition:box-shadow var(--transition),border-color var(--transition);
}
.faq-card:hover{box-shadow:var(--shadow-md);border-color:rgba(226,55,68,.12)}
.faq-card h3{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:10px;font-size:1rem;line-height:1.3}
.faq-answer{color:var(--muted);font-size:.9rem;line-height:1.7}

/* ─── Blog grid ─────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.blog-card{
  border-radius:22px;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow);overflow:hidden;
  transition:box-shadow var(--transition),transform var(--transition);
  display:grid;grid-template-rows:auto 1fr auto auto;
}
.blog-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-4px)}
.blog-thumb{
  height:140px;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:800;font-size:1.1rem;letter-spacing:-.02em;
  color:rgba(255,255,255,.9);
  background:linear-gradient(135deg,var(--text-2) 0%,#1e3a6e 100%);
  position:relative;overflow:hidden;
}
.blog-thumb::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(226,55,68,.35),rgba(15,82,186,.25));
}
.blog-thumb span{position:relative;z-index:1;padding:0 20px;text-align:center}
.blog-meta{display:flex;justify-content:space-between;padding:16px 20px 0;font-size:.78rem;color:var(--muted);font-weight:600}
.blog-card h3{padding:10px 20px 8px;font-family:var(--font-display);letter-spacing:-.02em;font-size:1rem;line-height:1.35}
.blog-card p{padding:0 20px 6px;color:var(--muted);font-size:.875rem;line-height:1.6}
.blog-card .btn{margin:8px 20px 20px;width:calc(100% - 40px)}

/* ─── Booking banner ────────────────────────────────────── */
.booking-banner{
  border-radius:28px;
  background:linear-gradient(135deg,#fff 0%,#fef9f9 100%);
  border:1px solid rgba(226,55,68,.16);
  box-shadow:var(--shadow-md);
  overflow:hidden;position:relative;
}
.booking-banner::before{
  content:"";position:absolute;right:0;top:0;bottom:0;width:40%;
  background:linear-gradient(to left,rgba(226,55,68,.04),transparent);
}
.banner-inner{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:36px 44px;position:relative;z-index:1;flex-wrap:wrap}
.phone{font-family:var(--font-display);font-size:2.2rem;font-weight:800;letter-spacing:-.05em;color:var(--text)}
.phone a{color:inherit}

/* ─── Site footer ───────────────────────────────────────── */
.site-footer{
  padding:48px 0 32px;
  border-top:1px solid var(--line);
  margin-top:64px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(10px);
}
.footer-inner{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:48px;align-items:flex-start;
}
.footer-brand{display:grid;gap:14px}
.footer-brand-logo{display:flex;align-items:center;gap:10px}
.footer-brand-logo .brand-icon{width:32px;height:32px}
.footer-brand-logo .brand-wordmark{font-size:1.05rem}
.footer-tagline{color:var(--muted);font-size:.875rem;line-height:1.7;max-width:24ch}
.footer-contact{display:flex;flex-direction:column;gap:6px}
.footer-contact a{color:var(--muted);font-size:.875rem;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:color var(--transition)}
.footer-contact a:hover{color:var(--primary)}
.footer-nav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer-nav-col h4{font-size:.8rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-light);margin-bottom:14px}
.footer-nav-col ul{display:grid;gap:8px}
.footer-nav-col ul a{color:var(--muted);font-size:.875rem;font-weight:500;transition:color var(--transition)}
.footer-nav-col ul a:hover{color:var(--text)}
.footer-bottom{
  margin-top:32px;padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  font-size:.82rem;color:var(--muted);
}
.footer-links{display:flex;gap:4px;flex-wrap:wrap}
.footer-links a{color:var(--muted);font-size:.82rem;font-weight:500;padding:4px 8px;border-radius:6px;transition:color var(--transition),background var(--transition)}
.footer-links a:hover{color:var(--text);background:rgba(10,15,30,.05)}

/* ─── Grids ─────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.menu-grid,.orders-grid{display:grid;gap:16px}

/* ─── Alerts ────────────────────────────────────────────── */
.alert{padding:14px 18px;border-radius:var(--radius-sm);margin:14px 0;font-size:.9rem;font-weight:600;border:1px solid transparent}
.alert-success{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}
.alert-error,.alert-danger{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.alert-warning{background:#fffbeb;border-color:#fde68a;color:#92400e}
.alert-info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.alert-solid{border-left:4px solid currentColor}

/* ─── Forms ─────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:grid;gap:6px}
.field label{font-size:.875rem;font-weight:600;color:var(--text)}
.field input,.field select,.field textarea{
  width:100%;padding:12px 16px;border-radius:var(--radius-sm);
  border:1px solid var(--line-strong);font-family:inherit;font-size:.95rem;
  background:#fff;color:var(--text);outline:none;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:rgba(226,55,68,.40);box-shadow:0 0 0 3px var(--primary-light)}
.field textarea{min-height:110px;resize:vertical}
.password-group{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:stretch}
.password-group input{min-width:0}
.password-toggle{min-width:92px;padding-inline:14px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:#fff;font-weight:700;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;gap:8px}
.password-toggle:hover{color:var(--text)}
.password-meter{font-size:.82rem;font-weight:700;color:var(--muted)}
.password-meter[data-score='1']{color:#b91c1c}
.password-meter[data-score='2']{color:#b45309}
.password-meter[data-score='3']{color:#15803d}
.password-meter[data-score='4']{color:#0f766e}

/* ─── Tables ────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-size:.9rem}
.table th{padding:10px 14px;border-bottom:2px solid var(--line);text-align:left;font-size:.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.table td{padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background:rgba(226,55,68,.02)}

/* ─── Menu toolbar & cats ───────────────────────────────── */
.menu-toolbar,.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}
.menu-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.menu-cats a{padding:9px 18px;border-radius:999px;border:1px solid var(--line-strong);background:#fff;font-size:.875rem;font-weight:600;color:var(--muted);transition:all var(--transition)}
.menu-cats a:hover{color:var(--text);border-color:var(--line-strong);background:var(--bg-subtle)}
.menu-cats a.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--shadow-primary)}

/* ─── Menu items ────────────────────────────────────────── */
.menu-grid{perspective:1400px}
.menu-item{
  transform-style:preserve-3d;
  transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .22s cubic-bezier(.4,0,.2,1);
  overflow:hidden;border-radius:var(--radius);
}
.menu-item:hover{transform:translateY(-5px) rotateX(1.5deg) rotateY(-1.5deg);box-shadow:var(--shadow-lift)}
.menu-image-frame{
  padding:12px;border-radius:16px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  border:1px solid var(--line);
  display:grid;place-items:center;
  margin-bottom:14px;position:relative;overflow:hidden;
}

/* ─── Login card ────────────────────────────────────────── */
.login-card{border-radius:28px;box-shadow:var(--shadow-md);max-width:460px;margin:0 auto}

/* ─── Admin shell ───────────────────────────────────────── */
.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{
  border-right:1px solid var(--line);
  background:rgba(255,255,255,.88);
  padding:24px 16px;position:sticky;top:0;height:100vh;overflow-y:auto;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.brand-block{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.side-nav{display:grid;gap:2px}
.side-nav a{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--radius-sm);
  font-size:.875rem;font-weight:600;color:var(--muted);
  transition:color var(--transition),background var(--transition);
}
.side-nav a:hover{color:var(--text);background:rgba(10,15,30,.06)}
.side-nav a.active{color:var(--primary);background:var(--primary-light)}
.admin-main{padding:28px 32px 40px}
.admin-top{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--line);
}
.admin-top h1{font-family:var(--font-display);letter-spacing:-.04em;font-size:1.8rem}
.nav-icon{width:18px;height:18px;display:inline-flex;align-items:center;flex-shrink:0}
.nav-icon svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* ─── Menu hero (public menu page) ─────────────────────── */
.menu-hero-shell{display:grid;gap:20px}
.menu-hero-panel{display:grid;gap:20px}
.menu-hero-copy{display:grid;gap:10px}
.menu-hero-summary{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.9fr);gap:16px;align-items:stretch;margin-top:0}
.menu-hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.menu-hero-actions{display:grid;gap:14px}


/* ─── Immersive public menu app ───────────────────────── */
.menu-page .site-header{display:none}
.menu-page .page-shell{padding-top:0}
.menu-page{background:
  radial-gradient(circle at 15% 10%, rgba(93, 63, 211, .12), transparent 28%),
  radial-gradient(circle at 85% 0%, rgba(93, 63, 211, .18), transparent 22%),
  #f7f3ff;
}
.menu-app-shell{display:grid;gap:22px}
.menu-app-hero{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch;margin-top:12px}
.menu-app-hero-panel,
.menu-app-hero-card,
.menu-app-summary,
.menu-app-detail,
.menu-app-cart{border-radius:32px;overflow:hidden;box-shadow:0 18px 50px rgba(32,14,74,.10)}
.menu-app-hero-panel{position:relative;min-height:560px;background:linear-gradient(180deg,#5f35d6 0%,#5130bb 100%);color:#fff;padding:28px;display:grid;align-content:space-between}
.menu-app-hero-panel::after{content:"";position:absolute;inset:auto -90px -110px auto;width:270px;height:270px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.15),transparent 68%);filter:blur(2px)}
.menu-app-hero-image{width:min(100%,360px);aspect-ratio:1;border-radius:50%;overflow:hidden;border:12px solid rgba(255,255,255,.88);box-shadow:0 18px 50px rgba(0,0,0,.18);margin-top:12px}
.menu-app-hero-image img{width:100%;height:100%;object-fit:cover}
.menu-app-hero-copy{display:grid;gap:14px;position:relative;z-index:1;padding:10px 4px 0}
.menu-app-hero-copy h1{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3.6rem);line-height:1;letter-spacing:-.06em;color:#fff;max-width:7ch}
.menu-app-hero-copy p{color:rgba(255,255,255,.84);max-width:26ch;font-size:1.08rem;line-height:1.6}
.menu-app-hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.menu-app-hero-cta .btn{box-shadow:none}
.menu-app-hero-cta .btn-primary{background:#fff;color:#4527a0}
.menu-app-hero-cta .btn-secondary{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#fff}
.menu-app-hero-cta .btn-ghost{background:transparent;border-color:rgba(255,255,255,.18);color:#fff}
.menu-app-hero-panel .menu-mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative;z-index:1}
.menu-mini-stats .stat{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.12);box-shadow:none;color:#fff}
.menu-mini-stats .label,.menu-mini-stats .value{color:#fff}
.menu-mini-stats .value{font-size:1.35rem}
.menu-app-right{display:grid;gap:18px}
.menu-app-hero-card,.menu-app-summary,.menu-app-detail,.menu-app-cart{background:#fff;border:1px solid rgba(64,24,122,.08);padding:20px}
.menu-app-hero-card{display:grid;gap:18px}
.menu-app-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.menu-app-title{font-family:var(--font-display);font-size:2rem;letter-spacing:-.05em}
.menu-app-search{display:grid;gap:12px}
.menu-app-search input[type="search"]{width:100%;border:0;background:#eef0f6;padding:15px 16px;border-radius:999px;font-size:1rem;outline:none}
.menu-app-search input[type="search"]::placeholder{color:#9aa0b7}
.menu-chip-row{display:flex;gap:10px;overflow:auto;padding-bottom:4px;scrollbar-width:none}
.menu-chip-row::-webkit-scrollbar{display:none}
.menu-chip{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;padding:10px 15px;border-radius:999px;background:#f3efff;border:1px solid rgba(93,63,211,.1);color:#5d3fd3;font-weight:700}
.menu-chip.active{background:#5d3fd3;color:#fff;box-shadow:0 8px 20px rgba(93,63,211,.22)}
.menu-promo-card{display:grid;grid-template-columns:1.3fr .9fr;gap:16px;align-items:center;padding:18px;border-radius:24px;background:linear-gradient(135deg,#8d73f5 0%,#b08bff 100%);color:#fff}
.menu-promo-card h3{font-family:var(--font-display);font-size:1.35rem;letter-spacing:-.04em;color:#fff}
.menu-promo-card p{color:rgba(255,255,255,.86);font-size:.95rem}
.menu-promo-image{justify-self:end;width:132px;height:132px;border-radius:18px;overflow:hidden;box-shadow:0 16px 30px rgba(0,0,0,.18)}
.menu-promo-image img{width:100%;height:100%;object-fit:cover}
.menu-popular-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.menu-popular-card{padding:14px;border-radius:22px;background:#f8f7ff;border:1px solid rgba(93,63,211,.08);display:grid;gap:10px}
.menu-popular-thumb{width:100%;aspect-ratio:1;overflow:hidden;border-radius:18px;background:#ddd}
.menu-popular-thumb img{width:100%;height:100%;object-fit:cover}
.menu-popular-name{font-weight:700;line-height:1.2}
.menu-popular-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}
.menu-popular-price{color:#7b7b2d;font-weight:800}
.menu-app-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:start}
.menu-app-detail{display:grid;gap:14px}
.menu-detail-visual{display:grid;grid-template-columns:1fr .95fr;gap:16px;align-items:center}
.menu-detail-image{width:100%;aspect-ratio:1;border-radius:28px;overflow:hidden;background:#efeaff;box-shadow:inset 0 1px 0 rgba(255,255,255,.6)}
.menu-detail-image img{width:100%;height:100%;object-fit:cover}
.menu-detail-rating{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;background:#5d3fd3;color:#fff;font-weight:700;width:max-content}
.menu-detail-title{font-family:var(--font-display);font-size:1.8rem;letter-spacing:-.05em}
.menu-addons{display:flex;gap:12px;flex-wrap:wrap}
.menu-addon{width:74px;height:74px;border-radius:18px;overflow:hidden;border:1px solid rgba(93,63,211,.1);background:#fff;position:relative}
.menu-addon img{width:100%;height:100%;object-fit:cover}
.menu-addon span{position:absolute;right:6px;bottom:6px;width:24px;height:24px;border-radius:50%;background:#5d3fd3;color:#fff;display:grid;place-items:center;font-size:1rem;font-weight:800;box-shadow:0 4px 10px rgba(93,63,211,.25)}
.menu-app-cart{display:grid;gap:14px;position:sticky;top:88px}
.menu-cart-item{display:grid;grid-template-columns:92px 1fr;gap:12px;align-items:center;padding:12px;border-radius:20px;background:#faf8ff;border:1px solid rgba(93,63,211,.08)}
.menu-cart-item img{width:92px;height:92px;object-fit:cover;border-radius:16px}
.menu-cart-price{color:#7b7b2d;font-weight:800}
.menu-cart-stepper{display:flex;align-items:center;gap:10px;margin-top:10px}
.menu-step-pill{width:30px;height:30px;border-radius:50%;border:0;background:#5d3fd3;color:#fff;font-weight:900}
.menu-total-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:8px;border-top:1px solid var(--line)}
.menu-bottom-cta{display:flex;flex-direction:column;gap:10px}
.menu-bottom-nav{position:sticky;bottom:14px;z-index:20;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:10px;border-radius:20px;background:rgba(255,255,255,.88);border:1px solid rgba(64,24,122,.10);backdrop-filter:blur(18px)}
.menu-bottom-nav a{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:14px;color:var(--muted);font-weight:700;background:transparent}
.menu-bottom-nav a.active{background:#5d3fd3;color:#fff}
.menu-item-app{border-radius:24px;background:#fff}
.menu-item-app .menu-card-top{display:block}
.menu-item-app .menu-card-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}
.menu-item-app .menu-image-frame{border-radius:24px;overflow:hidden}
.menu-item-app .menu-card-thumb{width:100%;aspect-ratio:1.15;object-fit:cover}
.menu-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:14px}
.menu-section-head h2{font-family:var(--font-display);font-size:1.5rem;letter-spacing:-.04em}
.menu-grid-app{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:1025px){
  .menu-page .site-header{display:none}
}
@media(max-width:1024px){
  .menu-app-hero{grid-template-columns:1fr}
  .menu-app-layout{grid-template-columns:1fr}
}
@media(max-width:768px){
  .menu-app-hero-panel{min-height:auto;padding:22px}
  .menu-app-hero-image{width:min(100%,280px)}
  .menu-app-hero-copy h1{max-width:none}
  .menu-app-hero-panel .menu-mini-stats{grid-template-columns:repeat(3,minmax(0,1fr))}
  .menu-promo-card,.menu-detail-visual,.menu-cart-item{grid-template-columns:1fr}
  .menu-popular-grid,.menu-grid-app{grid-template-columns:1fr}
  .menu-app-cart{position:static}
  .menu-bottom-nav{grid-template-columns:repeat(2,1fr)}
  .menu-app-title{font-size:1.7rem}
}
/* ─── Cart ──────────────────────────────────────────────── */
.cart-hero-panel{display:grid;gap:18px}

/* ─── Order status ──────────────────────────────────────── */
.status-steps{display:grid;gap:8px}
.status-step{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--radius-sm);background:#fff;border:1px solid var(--line)}
.status-step.done{background:var(--primary-light);border-color:rgba(226,55,68,.2)}
.status-dot{width:10px;height:10px;border-radius:50%;background:var(--line-strong);flex-shrink:0}
.status-step.done .status-dot{background:var(--primary)}

/* ─── QR Poster ─────────────────────────────────────────── */
.qr-poster-footer{font-size:.9rem;opacity:.9;padding-top:8px}

/* ─── Image viewer ──────────────────────────────────────── */
.image-viewer-footer{padding:0 4px 2px}

/* ─── Waiting page ──────────────────────────────────────── */
.wait-card{border-radius:28px;padding:32px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-md)}

/* ─── Pricing tiers ─────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.pricing-card{
  padding:32px;border-radius:24px;
  background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow);
  transition:box-shadow var(--transition),transform var(--transition);
  position:relative;
}
.pricing-card.featured{
  border-color:rgba(226,55,68,.25);
  box-shadow:var(--shadow-md),0 0 0 2px rgba(226,55,68,.12);
  transform:scale(1.02);
}
.pricing-card:hover{box-shadow:var(--shadow-lift)}

/* ─── Trusted bar ───────────────────────────────────────── */
.trusted-bar{
  display:flex;align-items:center;gap:10px;
  margin-top:28px;flex-wrap:wrap;
}
.trusted-item{
  display:flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  font-size:.8rem;font-weight:700;color:var(--muted);
  box-shadow:var(--shadow);
}
.trusted-item svg{width:14px;height:14px;stroke:var(--success);stroke-width:2;fill:none}

/* ─── About hero visual ─────────────────────────────────── */
.about-visual{
  display:grid;gap:12px;padding:24px;
  border-radius:24px;background:linear-gradient(135deg,#0a1628,#1a2744);
  color:#fff;position:relative;overflow:hidden;
}
.about-visual::before{
  content:"";position:absolute;inset:auto -60px -60px auto;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(226,55,68,.25),transparent 70%);
}
.about-stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;position:relative;z-index:1}
.about-stat-item{padding:16px;border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1)}
.about-stat-item .num{font-family:var(--font-display);font-size:2rem;font-weight:800;letter-spacing:-.05em;color:#fff}
.about-stat-item .desc{font-size:.82rem;color:rgba(255,255,255,.6);margin-top:2px}

/* ─── Lead text ─────────────────────────────────────────── */
.lead{font-size:1.1rem;color:var(--muted);line-height:1.75;max-width:60ch}
.small{font-size:.875rem}

/* ─── Misc ──────────────────────────────────────────────── */
.text-center{text-align:center}
.text-primary{color:var(--primary)}
.text-muted{color:var(--muted)}

/* ─── Responsive ────────────────────────────────────────── */
@media(max-width:1024px){
  .hero,.section-highlight{grid-template-columns:1fr}
  .benefit-grid,.feature-list,.blog-grid,.pricing-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr}
  .footer-nav-grid{grid-template-columns:repeat(2,1fr)}
  .section-highlight{padding:36px 32px}
  .banner-inner{padding:28px 32px}
}
@media(max-width:768px){
  .hero-copy h1,.section-title{font-size:2.2rem}
  .hero,.admin-shell,.grid-2,.grid-3,.grid-4,.feature-list,.stat-grid,.form-grid{grid-template-columns:1fr}
  .benefit-grid,.blog-grid,.faq-grid,.pricing-grid,.footer-nav-grid{grid-template-columns:1fr}
  .top-nav{display:none}
  .menu-hero-summary{grid-template-columns:1fr}
  .section-highlight{padding:28px 22px}
  .pricing-card.featured{transform:none}
  .banner-inner{padding:24px 20px;flex-direction:column;align-items:flex-start;gap:20px}
  .admin-shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;padding:16px}
}
@media(max-width:480px){
  .hero-copy h1,.section-title{font-size:1.85rem}
  .price{font-size:2.2rem}
  .phone{font-size:1.8rem}
}

/* ─── Motion refinements ────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .bg-orb{animation:none}
}

/* ─── Focus visible ─────────────────────────────────────── */
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}

/* ─── Scrollbar styling ─────────────────────────────────── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:var(--muted-light)}

