@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600;700&display=swap');

/* ====== [SECTION] LAYOUT ====== */
.shell{
  width:min(1180px, 92vw);
  margin: 18px auto 60px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

/* ====== [SECTION] AUTH LAYOUT ====== */
.auth-shell{
  min-height: 100vh;
  width: min(1180px, 92vw);
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 40px 12px;
}

.auth-frame{
  width: min(560px, 92vw);
  padding: 18px;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--p) 55%, transparent);
  box-shadow:
    0 0 26px color-mix(in srgb, var(--p) 30%, transparent),
    0 0 60px rgba(0,0,0,.55);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  position: relative;
  overflow: hidden;
}
.auth-frame::after{
  content:"";
  position:absolute; inset:-40%;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--p) 28%, transparent), transparent 55%),
    radial-gradient(circle at 70% 70%, color-mix(in srgb, var(--s) 22%, transparent), transparent 55%);
  filter: blur(24px);
  opacity:.7;
  animation: auth-glow 6s ease-in-out infinite;
  pointer-events:none;
}
.auth-card{
  position: relative;
  z-index: 1;
  animation: float-card 6s ease-in-out infinite;
}

@keyframes auth-glow{
  0%,100%{ transform: translateY(0); opacity:.55; }
  50%{ transform: translateY(-10px); opacity:.85; }
}
@keyframes float-card{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}

@media (max-width: 980px){
  .shell{ grid-template-columns: 1fr; }
}

.bg-grid{
  position:fixed; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(circle at 50% 25%, rgba(0,0,0,1), rgba(0,0,0,.35) 52%, transparent 76%);
  pointer-events:none;
}

.bg-glow{
  position:fixed; inset:-35%;
  background:
    radial-gradient(circle at 25% 20%, color-mix(in srgb, var(--s) 20%, transparent), transparent 55%),
    radial-gradient(circle at 75% 15%, color-mix(in srgb, var(--p) 20%, transparent), transparent 55%),
    radial-gradient(circle at 50% 70%, color-mix(in srgb, var(--g) 10%, transparent), transparent 60%);
  filter: blur(38px);
  pointer-events:none;
}

/* ====== [SECTION] THEME ENGINE (FX) ======
   Used by internal app UIs (admin/tech) and can be driven by per-company settings:
   --p --s --a --bg --text --glow --aura --pattern --scan + data-tpl + font/shape/anim classes.
*/
body.app-theme{
  background: var(--bg, #050012);
  color: var(--text, #f7f4ff);
  position: relative;
  isolation: isolate;
  overflow-x: hidden;
  font-family: var(--font-body, "Rajdhani", system-ui, -apple-system, Segoe UI, Roboto, Arial);
}

/* Wallpaper layer (only visible on pages that enable it) */
body.app-theme::before{
  content:"";
  position: fixed;
  inset: 0;
  background-image: var(--wallpaper-image, none);
  background-size: var(--wallpaper-size, cover);
  background-repeat: var(--wallpaper-repeat, no-repeat);
  background-position: center;
  opacity: 0;
  filter: blur(var(--wallpaper-blur, 0px));
  pointer-events: none;
  z-index: -1;
}
/* Wallpaper enabled for all pages (not only POS) */
body.has-wallpaper::before{
  opacity: var(--wallpaper-opacity, 0);
}
body.has-wallpaper{
  background: transparent !important;
}
body.pos-wallpaper-only::before{
  opacity: 1 !important;
}
body.pos-wallpaper-only .fx{
  display: none !important;
}
body.pos-page.pos-wallpaper-only .card::before{
  display: none !important;
}
body.pos-page.pos-wallpaper-only .card,
body.pos-page.pos-wallpaper-only .panel{
  background: transparent !important;
  box-shadow: none !important;
}
body.pos-page.pos-wallpaper-only .subnav,
body.pos-page.pos-wallpaper-only .pos-toolbar,
body.pos-page.pos-wallpaper-only .pos-catalog,
body.pos-page.pos-wallpaper-only .pos-cart{
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

/* FX toggles (per-tenant) */
body.fx-bg-off{
  background: var(--bg, #050012);
}
body.fx-grid-off .fx-grid{ display:none !important; }
body.fx-aura-off .fx-aura{ display:none !important; }
body.fx-beams-off .fx-beams{ display:none !important; }
body.fx-rings-off .fx-rings{ display:none !important; }
body.fx-noise-off .fx-noise{ display:none !important; }
body.fx-scan-off .fx-scan{ display:none !important; }
body.fx-hex-off .fx-hex{ display:none !important; }

body.app-theme{ --font-body: "Rajdhani", system-ui, -apple-system, Segoe UI, Roboto, Arial; }
body.app-theme.font-tech{ --font-body: "Rajdhani", system-ui, -apple-system, Segoe UI, Roboto, Arial; }
body.app-theme.font-orbit{ --font-body: "Orbitron", "Rajdhani", system-ui, -apple-system, Segoe UI, Roboto, Arial; }
body.app-theme.font-mono{ --font-body: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }
body.app-theme.font-soft{ --font-body: "Sora", system-ui, -apple-system, Segoe UI, Roboto, Arial; }
body.app-theme.font-pro{ --font-body: "Sora", system-ui, -apple-system, Segoe UI, Roboto, Arial; }
body.app-theme.font-scifi{ --font-body: "Rajdhani", system-ui, -apple-system, Segoe UI, Roboto, Arial; }

body.app-theme.font-scifi .h1,
body.app-theme.font-scifi .panel-title,
body.app-theme.font-scifi .landing-title,
body.app-theme.font-scifi .brand-main{
  font-family: "Orbitron", "Rajdhani", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  letter-spacing: 1px;
}

body.app-theme.shape-angular .topbar,
body.app-theme.shape-angular .panel,
body.app-theme.shape-angular .card,
body.app-theme.shape-angular .btn,
body.app-theme.shape-angular .field input,
body.app-theme.shape-angular .field select,
body.app-theme.shape-angular .field textarea{
  border-radius: 14px !important;
}

body.app-theme.shape-square .topbar,
body.app-theme.shape-square .panel,
body.app-theme.shape-square .card,
body.app-theme.shape-square .btn,
body.app-theme.shape-square .field input,
body.app-theme.shape-square .field select,
body.app-theme.shape-square .field textarea{
  border-radius: 10px !important;
}

.topbar,
.shell{
  position: relative;
  z-index: 1;
}

.fx{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.fx-aura{
  opacity: calc(var(--aura, .55) * 0.62);
  filter: blur(90px) saturate(1.12);
  background:
    radial-gradient(1200px 760px at 18% 8%, var(--p) 0%, transparent 62%),
    radial-gradient(1050px 720px at 88% 18%, var(--s) 0%, transparent 60%),
    radial-gradient(900px 720px at 50% 90%, var(--a) 0%, transparent 62%);
  animation: fx-aura-float 14s ease-in-out infinite alternate;
  transform: translateZ(0);
}

.fx-grid{
  background-image:
    linear-gradient(to right, rgba(255,255,255,.085) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.085) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: calc(var(--pattern, .35) * 0.22);
  mask-image: radial-gradient(circle at 50% 18%, rgba(0,0,0,1), rgba(0,0,0,.25) 55%, transparent 75%);
  animation: fx-grid-drift 64s linear infinite;
  transform: translateZ(0);
}

.fx-hex{
  background-image:
    radial-gradient(circle at 12px 10px, var(--s) 0 2px, transparent 2px),
    radial-gradient(circle at 32px 26px, var(--p) 0 2px, transparent 2px),
    radial-gradient(circle at 52px 10px, var(--a) 0 2px, transparent 2px);
  background-size: 64px 42px;
  opacity: calc(var(--pattern, .35) * 0.20);
  transform: skewY(-7deg);
  transform-origin: 50% 50%;
  animation: fx-hex-drift 56s linear infinite;
}

.fx-noise{
  opacity: 0.07;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"120\" height=\"120\"><filter id=\"n\"><feTurbulence type=\"fractalNoise\" baseFrequency=\"0.9\" numOctaves=\"3\" stitchTiles=\"stitch\"/></filter><rect width=\"120\" height=\"120\" filter=\"url(%23n)\" opacity=\"0.55\"/></svg>');
  background-size: 200px 200px;
  mix-blend-mode: overlay;
}

.fx-scan{
  background: repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,.10) 0px,
    rgba(255,255,255,.10) 1px,
    transparent 3px,
    transparent 7px
  );
  opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.14);
  mix-blend-mode: overlay;
  animation: fx-scan-drift 12s linear infinite;
}

.chart-scan{
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:16px;
  overflow:hidden;
}
.chart-scan::after{
  content:"";
  position:absolute;
  left:-20%;
  top:0;
  width:40%;
  height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  animation: chart-scan 4.8s linear infinite;
  mix-blend-mode: overlay;
}
@keyframes chart-scan{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(300%); }
}

.fx-beams{
  opacity: 0;
  filter: blur(80px) saturate(1.25);
  background:
    linear-gradient(115deg, transparent 0%, var(--p) 46%, transparent 72%),
    linear-gradient(65deg, transparent 0%, var(--s) 42%, transparent 70%),
    linear-gradient(140deg, transparent 10%, var(--a) 52%, transparent 78%);
  mix-blend-mode: screen;
  animation: fx-beams-move 22s ease-in-out infinite alternate;
  transform: translateZ(0);
}

.fx-rings{
  opacity: 0;
  background:
    repeating-radial-gradient(circle at 50% 55%,
      rgba(255,255,255,.12) 0 1px,
      transparent 1px 22px
    );
  mix-blend-mode: overlay;
  animation: fx-rings-pulse 14s ease-in-out infinite alternate;
}

.fx-vignette{
  background: radial-gradient(circle at 50% 40%,
    transparent 0%,
    rgba(0,0,0,.35) 55%,
    rgba(0,0,0,.72) 100%
  );
  opacity: 0.95;
}

@keyframes fx-grid-drift{
  from{ background-position: 0 0, 0 0; }
  to{ background-position: 640px 220px, 220px 640px; }
}
@keyframes fx-hex-drift{
  from{ transform: skewY(-7deg) translate3d(0,0,0); }
  to{ transform: skewY(-7deg) translate3d(-120px, 60px, 0); }
}
@keyframes fx-scan-drift{
  from{ background-position: 0 0; }
  to{ background-position: 0 80px; }
}
@keyframes fx-beams-move{
  from{ transform: translate3d(-6%, -4%, 0) rotate(-2deg); }
  to{ transform: translate3d(6%, 4%, 0) rotate(2deg); }
}
@keyframes fx-rings-pulse{
  from{ transform: scale(0.98); opacity: 0.55; }
  to{ transform: scale(1.03); opacity: 0.85; }
}
@keyframes fx-aura-float{
  from{ transform: translate3d(0,0,0) scale(1); }
  to{ transform: translate3d(0,-14px,0) scale(1.03); }
}

/* animations toggles */
body.anim-off .fx-aura,
body.anim-off .fx-grid,
body.anim-off .fx-hex,
body.anim-off .fx-beams,
body.anim-off .fx-rings,
body.anim-off .fx-scan{ animation: none !important; }

body.anim-subtle .fx-aura{ animation-duration: 18s; }
body.anim-active .fx-aura{ animation-duration: 10s; }
body.anim-subtle .fx-grid{ animation-duration: 80s; }
body.anim-active .fx-grid{ animation-duration: 42s; }
body.anim-subtle .fx-hex{ animation-duration: 70s; }
body.anim-active .fx-hex{ animation-duration: 38s; }
body.anim-subtle .fx-scan{ animation-duration: 18s; }
body.anim-active .fx-scan{ animation-duration: 8s; }
body.anim-subtle .fx-beams{ animation-duration: 26s; }
body.anim-active .fx-beams{ animation-duration: 14s; }
body.anim-subtle .fx-rings{ animation-duration: 18s; }
body.anim-active .fx-rings{ animation-duration: 10s; }

/* Extended animation modes (used by the Appearance editor) */
body.anim-pulse .fx-aura{ animation-duration: 10s; opacity: calc(var(--aura, .55) * 0.74); }
body.anim-pulse .fx-rings{ opacity: calc(var(--pattern, .35) * 0.16); animation-duration: 9s; }
body.anim-pulse .fx-beams{ opacity: calc(var(--aura, .55) * 0.18); animation-duration: 13s; }

body.anim-scan .fx-scan{ opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.28); animation-duration: 6s; }
body.anim-scan .fx-grid{ opacity: calc(var(--pattern, .35) * 0.28); }
body.anim-scan .fx-aura{ opacity: calc(var(--aura, .55) * 0.62); animation-duration: 12s; }

body.anim-matrix .fx-grid{ opacity: calc(var(--pattern, .35) * 0.38); background-size: 20px 20px; animation-duration: 42s; }
body.anim-matrix .fx-scan{ opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.26); animation-duration: 7s; }
body.anim-matrix .fx-aura{ opacity: calc(var(--aura, .55) * 0.52); }

body.anim-float .fx-aura{ animation-duration: 22s; opacity: calc(var(--aura, .55) * 0.58); }
body.anim-float .fx-grid{ animation-duration: 92s; }
body.anim-float .fx-hex{ animation-duration: 84s; }

body.anim-overdrive .fx-aura{ animation-duration: 8s; opacity: calc(var(--aura, .55) * 0.86); }
body.anim-overdrive .fx-beams{ opacity: calc(var(--aura, .55) * 0.26); animation-duration: 10s; }
body.anim-overdrive .fx-scan{ opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.30); animation-duration: 5s; }
body.anim-overdrive .fx-rings{ opacity: calc(var(--pattern, .35) * 0.20); animation-duration: 8s; }

/* ===== Templates (Core 4) =====
   Goal: few templates but visually VERY different (background, motion, vibe).
*/

/* Template: Titanium Glass (deep / calm / premium / "lens" reflections) */
body[data-tpl="titanium_glass"]{
  --ease: cubic-bezier(.22,.9,.2,1);
  background:
    radial-gradient(1100px 760px at 14% 10%, color-mix(in srgb, var(--p) 20%, transparent) 0%, transparent 65%),
    radial-gradient(980px 720px at 86% 14%, color-mix(in srgb, var(--s) 18%, transparent) 0%, transparent 66%),
    radial-gradient(980px 820px at 55% 92%, color-mix(in srgb, var(--a) 14%, transparent) 0%, transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, transparent 38%),
    var(--bg);
}
body[data-tpl="titanium_glass"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.14); background-size: 54px 54px; }
body[data-tpl="titanium_glass"] .fx-hex{ opacity: calc(var(--pattern, .35) * 0.04); }
body[data-tpl="titanium_glass"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.12); mix-blend-mode: overlay; filter: blur(90px) saturate(1.05); }
body[data-tpl="titanium_glass"] .fx-rings{ opacity: 0; }
body[data-tpl="titanium_glass"] .fx-aura{ opacity: calc(var(--aura, .55) * 0.52); filter: blur(105px) saturate(1.08); animation-duration: 18s; }

/* Template: Matrix Terminal (CRT / aggressive scan / compact grid) */
body[data-tpl="hud_matrix"]{
  --ease: cubic-bezier(.12,.9,.1,1);
  background:
    radial-gradient(1200px 880px at 50% 0%, color-mix(in srgb, var(--p) 18%, transparent) 0%, transparent 62%),
    radial-gradient(1100px 880px at 50% 100%, color-mix(in srgb, var(--s) 14%, transparent) 0%, transparent 64%),
    repeating-linear-gradient(to bottom, rgba(255,255,255,.05) 0 1px, transparent 1px 7px),
    var(--bg);
}
body[data-tpl="hud_matrix"] .fx-noise{ opacity: 0.12; mix-blend-mode: screen; filter: contrast(1.12) saturate(1.10); }
body[data-tpl="hud_matrix"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.52); background-size: 16px 16px; filter: contrast(1.08); }
body[data-tpl="hud_matrix"] .fx-hex{ opacity: 0; }
body[data-tpl="hud_matrix"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.06); filter: blur(120px) saturate(1.15); mix-blend-mode: screen; }
body[data-tpl="hud_matrix"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.22); }
body[data-tpl="hud_matrix"] .fx-scan{ opacity: calc(var(--scan, 1) * (0.26 + var(--pattern, .35) * 0.24)); mix-blend-mode: screen; animation-duration: 5.5s; }
body[data-tpl="hud_matrix"] .fx-aura{ opacity: calc(var(--aura, .55) * 0.32); filter: blur(140px) saturate(1.20) contrast(1.06); animation-duration: 11s; }
body[data-tpl="hud_matrix"] .fx-vignette{
  opacity: 0.62;
  background:
    radial-gradient(circle at 50% 35%, transparent 0%, rgba(0,0,0,.26) 58%, rgba(0,0,0,.66) 100%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.08) 0%, transparent 55%);
}

/* Template: Quartz Light (true light mode / blueprint lines / calm motion) */
body[data-tpl="quartz_light"]{
  --ease: cubic-bezier(.18,.8,.2,1);
  color-scheme: light;
  background:
    radial-gradient(900px 640px at 12% 6%, color-mix(in srgb, var(--p) 12%, white) 0%, transparent 66%),
    radial-gradient(860px 640px at 88% 12%, color-mix(in srgb, var(--s) 10%, white) 0%, transparent 68%),
    radial-gradient(860px 700px at 50% 100%, color-mix(in srgb, var(--a) 8%, white) 0%, transparent 72%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 55%, #ffffff 100%),
    var(--bg);
}
body[data-tpl="quartz_light"] .fx-noise{ opacity: 0.055; mix-blend-mode: multiply; }
body[data-tpl="quartz_light"] .fx-scan{ opacity: 0; }
body[data-tpl="quartz_light"] .fx-grid{
  opacity: calc(var(--pattern, .35) * 0.14);
  background-size: 32px 32px;
  background-image:
    linear-gradient(to right, rgba(15,23,42,.08) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,.08) 1px, transparent 1px),
    radial-gradient(circle at 1px 1px, rgba(15,23,42,.10) 0 1px, transparent 1px);
}
body[data-tpl="quartz_light"] .fx-hex{ opacity: 0; }
body[data-tpl="quartz_light"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.04); filter: blur(100px) saturate(1.02); mix-blend-mode: multiply; }
body[data-tpl="quartz_light"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.04); mix-blend-mode: multiply; }
body[data-tpl="quartz_light"] .fx-vignette{ opacity: 0.18; background: radial-gradient(circle at 50% 40%, transparent 0%, rgba(11,18,32,.10) 58%, rgba(11,18,32,.18) 100%); }
body[data-tpl="quartz_light"] .glass{ background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.70)); border: 1px solid rgba(15,23,42,.10); box-shadow: 0 16px 40px rgba(15,23,42,.10); }
body[data-tpl="quartz_light"] .field input,
body[data-tpl="quartz_light"] .field select,
body[data-tpl="quartz_light"] .field textarea{ background: rgba(255,255,255,.96); color: rgba(15,23,42,.92); border-color: rgba(15,23,42,.12); }
body[data-tpl="quartz_light"] .btn{ background: rgba(255,255,255,.96); color: rgba(15,23,42,.92); border-color: rgba(15,23,42,.12); }
body[data-tpl="quartz_light"] .badge{ color: rgba(15,23,42,.70); border-color: rgba(15,23,42,.12); box-shadow: none; }
body[data-tpl="quartz_light"] .kicker,
body[data-tpl="quartz_light"] .hint,
body[data-tpl="quartz_light"] .muted,
body[data-tpl="quartz_light"] .empty,
body[data-tpl="quartz_light"] .field span,
body[data-tpl="quartz_light"] .table th{
  color: rgba(15,23,42,.70);
}
body[data-tpl="quartz_light"] .table td{ color: #0f172a; }
body[data-tpl="quartz_light"] .tab-btn{
  color: rgba(15,23,42,.78);
  background: rgba(255,255,255,.78);
  border-color: rgba(15,23,42,.12);
}
body[data-tpl="quartz_light"] .tab-btn.is-active{
  color: #0f172a;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(240,244,255,.9));
  border-color: rgba(15,23,42,.22);
  box-shadow: 0 10px 24px rgba(15,23,42,.12);
}
body[data-tpl="quartz_light"] .brand-main{ color: #0f172a; text-shadow: none; }
body[data-tpl="quartz_light"] .brand-sub{ color: rgba(15,23,42,.60); text-shadow: none; }
body[data-tpl="quartz_light"] .statusline{
  background: rgba(255,255,255,.82);
  border-color: rgba(15,23,42,.12);
  color: rgba(15,23,42,.70);
}
body.pos-page[data-tpl="quartz_light"]{
  background:
    radial-gradient(1200px 720px at 15% 8%, color-mix(in srgb, var(--p) 10%, white) 0%, transparent 68%),
    radial-gradient(1200px 720px at 85% 10%, color-mix(in srgb, var(--s) 10%, white) 0%, transparent 70%),
    radial-gradient(1200px 800px at 50% 110%, color-mix(in srgb, var(--a) 8%, white) 0%, transparent 72%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 55%, #ffffff 100%);
}

/* Template: Neon Overdrive (super neon / aura radial / high energy motion) */
body[data-tpl="neon_overdrive"]{
  --ease: cubic-bezier(.16,1,.3,1);
  background:
    radial-gradient(1200px 900px at 18% 12%, color-mix(in srgb, var(--p) 32%, transparent) 0%, transparent 62%),
    radial-gradient(1100px 860px at 86% 18%, color-mix(in srgb, var(--s) 28%, transparent) 0%, transparent 64%),
    radial-gradient(980px 820px at 55% 92%, color-mix(in srgb, var(--a) 26%, transparent) 0%, transparent 66%),
    conic-gradient(from 210deg at 60% 40%, color-mix(in srgb, var(--p) 10%, transparent), transparent 35%, color-mix(in srgb, var(--s) 10%, transparent), transparent 70%, color-mix(in srgb, var(--a) 10%, transparent)),
    var(--bg);
}
body[data-tpl="neon_overdrive"] .fx-noise{ opacity: 0.10; mix-blend-mode: screen; }
body[data-tpl="neon_overdrive"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.12); background-size: 62px 62px; transform: rotate(-2deg); transform-origin: 50% 50%; }
body[data-tpl="neon_overdrive"] .fx-hex{ opacity: calc(var(--pattern, .35) * 0.22); }
body[data-tpl="neon_overdrive"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.32); filter: blur(110px) saturate(1.28); mix-blend-mode: screen; }
body[data-tpl="neon_overdrive"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.14); mix-blend-mode: screen; }
body[data-tpl="neon_overdrive"] .fx-scan{ opacity: calc(var(--scan, 1) * (0.22 + var(--pattern, .35) * 0.24)); }
body[data-tpl="neon_overdrive"] .fx-aura{
  opacity: calc(var(--aura, .55) * 0.92);
  filter: blur(140px) saturate(1.25);
  background:
    radial-gradient(1200px 820px at 20% 12%, var(--p) 0%, transparent 65%),
    radial-gradient(1100px 780px at 85% 18%, var(--s) 0%, transparent 66%),
    radial-gradient(1000px 820px at 55% 90%, var(--a) 0%, transparent 70%);
  animation-duration: 6.5s;
}

/* Template: MLTS (kawaii chibi / sakura / pastel) */
body[data-tpl="mlts"]{
  --ease: cubic-bezier(.2,.8,.2,1);
  background:
    radial-gradient(900px 700px at 18% 10%, color-mix(in srgb, var(--p) 35%, transparent) 0%, transparent 65%),
    radial-gradient(900px 700px at 85% 18%, color-mix(in srgb, var(--s) 30%, transparent) 0%, transparent 66%),
    radial-gradient(900px 800px at 50% 100%, color-mix(in srgb, var(--a) 25%, transparent) 0%, transparent 72%),
    linear-gradient(180deg, #fff1f7 0%, #ffd6ea 55%, #ffeaf3 100%);
}
body[data-tpl="mlts"] .fx-noise{ opacity: 0.05; mix-blend-mode: soft-light; }
body[data-tpl="mlts"] .fx-scan{ opacity: 0; }
body[data-tpl="mlts"] .fx-hex{ opacity: 0; }
body[data-tpl="mlts"] .fx-grid{
  opacity: calc(var(--pattern, .35) * 0.30);
  background-size: 46px 32px;
  background-image:
    radial-gradient(circle at 10px 10px, color-mix(in srgb, var(--p) 35%, transparent) 0 2px, transparent 3px),
    radial-gradient(circle at 28px 18px, color-mix(in srgb, var(--s) 30%, transparent) 0 2px, transparent 3px),
    radial-gradient(circle at 40px 6px, color-mix(in srgb, var(--a) 35%, transparent) 0 2px, transparent 3px);
}
body[data-tpl="mlts"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.18); filter: blur(120px) saturate(1.1); mix-blend-mode: screen; }
body[data-tpl="mlts"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.06); mix-blend-mode: screen; }
body[data-tpl="mlts"] .fx-aura{ opacity: calc(var(--aura, .55) * 0.70); filter: blur(120px) saturate(1.2); }
body[data-tpl="mlts"] .fx-vignette{
  opacity: .10;
  background: radial-gradient(circle at 50% 40%, transparent 0%, rgba(255,92,156,.08) 60%, rgba(60,20,40,.18) 100%);
}
body[data-tpl="mlts"] .glass{
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.58));
  border: 1px solid rgba(255, 105, 180,.28);
  box-shadow: 0 20px 50px rgba(255,105,180,.15);
}
body[data-tpl="mlts"] .btn{
  background: rgba(255,255,255,.90);
  color: rgba(60,20,40,.90);
  border-color: rgba(255, 105, 180,.35);
}
body[data-tpl="mlts"] .btn.btn-ghost{ background: rgba(255,255,255,.72); }
body[data-tpl="mlts"] .kicker,
body[data-tpl="mlts"] .hint,
body[data-tpl="mlts"] .muted,
body[data-tpl="mlts"] .empty,
body[data-tpl="mlts"] .field span,
body[data-tpl="mlts"] .table th{
  color: rgba(80,35,55,.65);
}
body[data-tpl="mlts"] .table td,
body[data-tpl="mlts"] .brand-main{
  color: #3b2230;
  text-shadow: none;
}
body[data-tpl="mlts"] .brand-sub{ color: rgba(80,35,55,.60); text-shadow: none; }
body[data-tpl="mlts"] .pill,
body[data-tpl="mlts"] .tab-btn{
  background: rgba(255,255,255,.78);
  border-color: rgba(255,105,180,.25);
  color: #4a2233;
}
body[data-tpl="mlts"] .tab-btn.is-active{
  background: linear-gradient(180deg, rgba(255,185,218,.92), rgba(255,210,232,.75));
  border-color: rgba(255,105,180,.45);
  box-shadow: 0 10px 24px rgba(255,105,180,.25);
}

/* Allow disabling template backgrounds entirely */
body.fx-bg-off{
  background: var(--bg, #050a14) !important;
}

/* ====== [SECTION] GLASS ====== */
.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
}
.panel.glass,
.card.glass{
  transition: transform .18s var(--ease, ease), box-shadow .18s var(--ease, ease);
}
.panel.glass:hover,
.card.glass:hover{
  transform: translateY(-2px);
  box-shadow: 0 28px 70px rgba(0,0,0,.6);
}

/* ====== [SECTION] TOPBAR ====== */
.topbar{
  width:min(1180px, 92vw);
  margin: 18px auto 0;
  border-radius: 18px;
  padding: 14px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
}

.topbar-left{
  display:flex;
  align-items:center;
  gap: 14px;
}
.topbar-right{
  display:flex;
  gap: 10px;
  align-items:center;
}

.kicker{
  font-size: 11px;
  letter-spacing: 3px;
  color: rgba(255,255,255,.55);
}

.h1{
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 2px;
}

.h2{
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 2px;
}

.accent{
  color: var(--p);
  text-shadow: 0 0 18px color-mix(in srgb, var(--p) 55%, transparent);
}

/* ====== [SECTION] LOGIN BRAND ====== */
.brand-marquee{
  position: relative;
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(90deg, rgba(6,6,14,.9), rgba(255,255,255,.05), rgba(6,6,14,.9));
  box-shadow:
    0 0 24px color-mix(in srgb, var(--p) 40%, transparent),
    0 0 60px rgba(0,0,0,.6);
  overflow: hidden;
  text-transform: uppercase;
  letter-spacing: 3px;
}

.brand-marquee::after{
  content:"";
  position:absolute;
  top:-10%;
  left:-50%;
  width:40%;
  height:120%;
  background: linear-gradient(120deg,
    transparent,
    color-mix(in srgb, var(--p) 45%, transparent),
    transparent
  );
  filter: blur(2px);
  opacity:.9;
  animation: marquee-scan 2.8s linear infinite;
}

.brand-main{
  font-size: clamp(30px, 5vw, 50px);
  font-weight: 800;
  color: #f6f7ff;
  text-shadow:
    0 0 12px color-mix(in srgb, var(--p) 60%, transparent),
    0 0 24px color-mix(in srgb, var(--s) 40%, transparent);
}

.brand-sub{
  font-size: 12px;
  letter-spacing: 4px;
  color: rgba(255,255,255,.72);
  text-shadow: 0 0 10px color-mix(in srgb, var(--s) 35%, transparent);
}

@keyframes marquee-scan{
  0%{ transform: translateX(0); opacity:.2; }
  40%{ opacity:.9; }
  100%{ transform: translateX(260%); opacity:.2; }
}

/* ====== [SECTION] LOGIN THEMES ====== */
body.login-theme--titanium,
.login-stage.login-theme--titanium{
  --bg0:#06060b;
  --bg1:#0f1220;
  --text:#f4f6ff;
  --muted:#b4bdd6;
}
body.login-theme--titanium .bg::before{
  background-size: 48px 48px;
  opacity:.28;
}
body.login-theme--titanium .brand-marquee{
  border-radius: 14px;
  box-shadow:
    0 0 25px color-mix(in srgb, var(--p) 60%, transparent),
    0 0 60px color-mix(in srgb, var(--s) 40%, transparent);
}

body.login-theme--robot,
.login-stage.login-theme--robot{
  --bg0:#0a0f12;
  --bg1:#111722;
  --text:#e7ecff;
  --muted:#b8bed6;
}
body.login-theme--robot .bg::before{
  background-size: 64px 64px;
  opacity:.2;
}
body.login-theme--robot .brand-marquee{
  border-radius: 8px;
  letter-spacing: 4px;
}

body.login-theme--neon,
.login-stage.login-theme--neon{
  --bg0:#05020f;
  --bg1:#0b0822;
}
body.login-theme--neon .bg::before{
  background-size: 40px 40px;
  opacity:.35;
}

body.login-theme--cyber,
.login-stage.login-theme--cyber{
  --bg0:#0b0a14;
  --bg1:#1a0f27;
}
body.login-theme--cyber .bg::before{
  background-size: 28px 28px;
  opacity:.45;
}
body.login-theme--cyber .brand-marquee{
  box-shadow:
    0 0 30px color-mix(in srgb, var(--s) 60%, transparent),
    0 0 80px rgba(0,0,0,.65);
}

body.login-theme--light,
.login-stage.login-theme--light{
  --bg0:#f7f8fc;
  --bg1:#ffffff;
  --text:#0f172a;
  --muted:#4b5563;
}
body.login-theme--light .bg::before{ opacity:.18; }
body.login-theme--light .scan{ opacity:.05; }

body.login-theme--mlts,
.login-stage.login-theme--mlts{
  --bg0:#fff1f7;
  --bg1:#ffe5f1;
  --text:#3b2230;
  --muted:#8a5b6d;
}
body.login-theme--mlts .bg::before{
  background-size: 32px 32px;
  opacity:.24;
}
body.login-theme--mlts .brand-marquee{
  border-radius: 16px;
  box-shadow:
    0 0 30px color-mix(in srgb, var(--p) 45%, transparent),
    0 0 80px rgba(255,105,180,.35);
}

body.login-theme--aurora,
.login-stage.login-theme--aurora{
  --bg0:#0b1026;
  --bg1:#1b1440;
  --text:#eef0ff;
  --muted:#c5c9e6;
}

body.login-theme--matrix,
.login-stage.login-theme--matrix{
  --bg0:#030b06;
  --bg1:#07110b;
  --text:#dfffee;
  --muted:#9bd3b9;
}
body.login-theme--matrix .bg::before{
  background-size: 30px 30px;
  opacity:.5;
}
body.login-theme--matrix .scan{ opacity:.18; }

body.login-theme--light .auth-frame,
.login-stage.login-theme--light .auth-frame{
  background: linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.02));
  border-color: color-mix(in srgb, var(--p) 40%, transparent);
}

/* ====== [SECTION] LOGIN PREVIEW ====== */
.login-preview-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
@media (max-width: 900px){
  .login-preview-grid{ grid-template-columns: 1fr; }
}
.login-preview{
  border-radius: 14px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  min-height: 96px;
  position: relative;
  overflow: hidden;
}
.login-preview.is-active{
  box-shadow: 0 0 18px color-mix(in srgb, var(--p) 55%, transparent);
  border-color: color-mix(in srgb, var(--p) 50%, rgba(255,255,255,.2));
}
.login-preview .preview-title{
  font-weight: 800;
  letter-spacing: 3px;
}
.login-preview .preview-chip{
  margin-top: 6px;
  font-size: 11px;
  color: rgba(255,255,255,.65);
  letter-spacing: 2px;
}
.login-preview--robot{
  background: linear-gradient(135deg, #10151a, #1b2430);
}
.login-preview--neon{
  background: linear-gradient(135deg, #0b0822, #140b2e);
}
.login-preview--cyber{
  background: linear-gradient(135deg, #0f0b1f, #231038);
}
.login-preview--light{
  background: linear-gradient(135deg, #f7f8fc, #e9edf5);
  color: #0f172a;
}
.login-preview--light .preview-title{ color:#0f172a; }
.login-preview--light .preview-chip{ color:#4b5563; }
.login-preview--aurora{
  background: linear-gradient(135deg, #15214b, #3b1b6a);
}
.login-preview--matrix{
  background: linear-gradient(135deg, #06110a, #0b2a18);
}

.login-live{
  padding: 14px;
  border-radius: 16px;
  display:flex;
  flex-direction: column;
  gap: 6px;
}

/* ====== [SECTION] LOGIN STAGE PREVIEW ====== */
.login-stage{
  position: relative;
  border-radius: 16px;
  padding: 16px;
  min-height: 260px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(1200px 800px at 10% 0%, color-mix(in srgb, var(--s) 22%, transparent), transparent 58%),
    radial-gradient(1100px 750px at 90% 10%, color-mix(in srgb, var(--p) 22%, transparent), transparent 55%),
    radial-gradient(900px 700px at 50% 110%, color-mix(in srgb, var(--a) 20%, transparent), transparent 55%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
}
.login-stage::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 44px 44px;
  opacity:.35;
  mask-image: radial-gradient(circle at 50% 18%, rgba(0,0,0,1), rgba(0,0,0,.25) 55%, transparent 75%);
  pointer-events:none;
}
.login-stage .auth-frame{
  transform: scale(.92);
  transform-origin: top left;
}

/* ====== [SECTION] LOGIN MINI PREVIEW ====== */
.auth-mini{
  margin-top: 10px;
  display:grid;
  gap: 8px;
}
.mini-field span{
  display:block;
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--muted);
  margin-bottom: 4px;
}
.mini-input{
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,10,20,.35);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.mini-btn{
  justify-content:center;
}

/* ====== [SECTION] LOADING ====== */
@keyframes shimmer{
  0%{ background-position: -200% 0; }
  100%{ background-position: 200% 0; }
}
@keyframes spin{
  to{ transform: rotate(360deg); }
}
.skeleton-card{
  height: 120px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.12), rgba(255,255,255,.04));
  background-size: 200% 100%;
  animation: shimmer 1.3s linear infinite;
}
.btn.loading{
  opacity: .7;
  pointer-events: none;
}
.btn.loading::after{
  content:"";
  position:absolute;
  right: 10px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.6);
  border-top-color: transparent;
  animation: spin .7s linear infinite;
}

/* ====== [SECTION] LANDING ====== */
body.landing-theme{
  min-height: 100vh;
}
body.landing-theme--neon,
.landing-preview-sandbox.landing-theme--neon{
  --bg0:#05020f;
  --bg1:#0b0822;
}
body.landing-theme--cyber,
.landing-preview-sandbox.landing-theme--cyber{
  --bg0:#0b0a14;
  --bg1:#180f26;
}
body.landing-theme--aurora,
.landing-preview-sandbox.landing-theme--aurora{
  --bg0:#0b1026;
  --bg1:#1b1440;
}
body.landing-theme--noir,
.landing-preview-sandbox.landing-theme--noir{
  --bg0:#040507;
  --bg1:#0a0c11;
}
body.landing-theme--light,
.landing-preview-sandbox.landing-theme--light{
  --bg0:#f7f8fc;
  --bg1:#ffffff;
  --text:#0f172a;
  --muted:#4b5563;
}
body.landing-theme--light .glass,
.landing-preview-sandbox.landing-theme--light .glass{
  background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.7));
  border-color: rgba(0,0,0,.08);
}
body.landing-theme--light .landing-card,
.landing-preview-sandbox.landing-theme--light .landing-card{
  background: rgba(255,255,255,.9);
}
body.landing-theme--cyber .landing-hero,
.landing-preview-sandbox.landing-theme--cyber .landing-hero{
  background:
    radial-gradient(circle at 10% 10%, rgba(0,255,204,.18), transparent 45%),
    radial-gradient(circle at 90% 30%, rgba(255,0,153,.16), transparent 55%),
    linear-gradient(135deg, rgba(10,8,24,.95), rgba(20,8,40,.85));
}
body.landing-theme--cyber .landing-chip,
.landing-preview-sandbox.landing-theme--cyber .landing-chip{
  box-shadow: 0 0 12px rgba(0,255,204,.18);
}

.landing-loader{
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 50% 30%, rgba(0,255,255,.12), transparent 50%), rgba(2,2,10,.95);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction: column;
  gap: 14px;
  z-index: 9999;
  opacity: 1;
  transition: opacity .6s ease;
}
.landing-loader-core{
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--p), rgba(0,0,0,.8));
  box-shadow: 0 0 20px color-mix(in srgb, var(--p) 70%, transparent);
  animation: pulse-core 1.6s ease-in-out infinite;
}
.landing-loader-ring{
  width: 84px;
  height: 84px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.2);
  border-top-color: var(--s);
  animation: spin 1s linear infinite;
}
.landing-loader-text{
  letter-spacing: 4px;
  font-size: 12px;
  color: rgba(255,255,255,.8);
}
body.is-loaded .landing-loader{
  opacity: 0;
  pointer-events: none;
}
body.landing-preview-mode .landing-loader{
  display: none;
}

.landing-top{
  width:min(1180px, 92vw);
  margin: 18px auto 0;
  border-radius: 18px;
  padding: 14px 16px;
  display:flex;
  align-items:center;
  gap: 14px;
}
.landing-sub{
  color: rgba(255,255,255,.6);
  font-size: 12px;
  letter-spacing: 2px;
}

.landing{
  width:min(1180px, 92vw);
  margin: 18px auto 60px;
  display:grid;
  gap: 20px;
}
.landing-hero{
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  padding: 26px;
  display:grid;
  gap: 18px;
  min-height: 320px;
  border: 1px solid color-mix(in srgb, var(--p) 40%, transparent);
  box-shadow: 0 0 30px color-mix(in srgb, var(--p) 20%, transparent);
}
.landing-hero-text{
  max-width: 620px;
  position: relative;
  z-index: 2;
}
.landing-title{
  font-size: clamp(36px, 6vw, 64px);
  letter-spacing: 3px;
  margin: 0 0 8px 0;
  text-transform: uppercase;
  text-shadow:
    0 0 16px color-mix(in srgb, var(--p) 70%, transparent),
    0 0 32px color-mix(in srgb, var(--s) 40%, transparent);
}
.glitch{
  position: relative;
}
.glitch::before,
.glitch::after{
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  overflow: hidden;
  color: color-mix(in srgb, var(--s) 70%, white);
  opacity: .6;
  pointer-events: none;
}
.glitch::before{
  clip-path: inset(0 0 60% 0);
  transform: translate(1px, -1px);
  animation: glitch-slice 2.6s infinite;
}
.glitch::after{
  clip-path: inset(45% 0 0 0);
  transform: translate(-1px, 1px);
  animation: glitch-slice 3.2s infinite reverse;
}
.landing-tagline{
  margin: 0 0 12px 0;
  color: color-mix(in srgb, var(--p) 65%, white);
  font-weight: 700;
  letter-spacing: 2px;
}
.landing-desc{
  margin: 0 0 18px 0;
  color: rgba(255,255,255,.7);
  font-size: 16px;
  max-width: 520px;
}
.landing-cta{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}
.landing-hero-orb{
  position:absolute;
  right:-10%;
  top:-30%;
  width: 420px;
  height: 420px;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--p) 35%, transparent), transparent 55%),
    radial-gradient(circle at 70% 60%, color-mix(in srgb, var(--s) 35%, transparent), transparent 55%);
  filter: blur(8px);
  opacity:.8;
  animation: float-card 8s ease-in-out infinite;
}
.landing-hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity:.25;
  mask-image: radial-gradient(circle at 30% 30%, rgba(0,0,0,1), rgba(0,0,0,.1) 60%, transparent 80%);
  animation: grid-drift 18s linear infinite;
}
.landing-hero-particles{
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.16) 1px, transparent 1px),
    radial-gradient(circle, rgba(255,255,255,.12) 1px, transparent 1px);
  background-size: 60px 60px, 90px 90px;
  background-position: 0 0, 20px 30px;
  opacity:.25;
  animation: particles-float 20s linear infinite;
}
.landing-hero::after{
  content:"";
  position:absolute; inset:-40%;
  background: conic-gradient(from 0deg,
    transparent,
    color-mix(in srgb, var(--p) 20%, transparent),
    transparent,
    color-mix(in srgb, var(--s) 16%, transparent),
    transparent);
  opacity:.4;
  filter: blur(22px);
  animation: glow-rotate 14s linear infinite;
  pointer-events:none;
}
.landing-hero::before{
  content:"";
  position:absolute;
  left:-10%;
  right:-10%;
  height: 2px;
  top: 14%;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--p) 65%, transparent), transparent);
  opacity:.5;
  animation: scanline 6s linear infinite;
  pointer-events:none;
}

.landing-cards{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}
.landing-card{
  border-radius: 20px;
  padding: 18px;
  position: relative;
  overflow: hidden;
  min-height: 210px;
  transition: transform .2s ease, box-shadow .2s ease;
  animation: card-rise .6s ease both;
}
.landing-card::before{
  content:"";
  position:absolute; inset:-40%;
  background: radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--p) 18%, transparent), transparent 55%);
  opacity:.8;
}
.landing-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--s) 30%, transparent);
  box-shadow: inset 0 0 16px color-mix(in srgb, var(--p) 18%, transparent);
  opacity:.6;
  pointer-events:none;
}
.landing-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
}
.landing-card-title{
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 2px;
  margin-bottom: 8px;
  text-shadow: 0 0 14px color-mix(in srgb, var(--p) 45%, transparent);
}
.landing-card-desc{
  color: rgba(255,255,255,.72);
  margin-bottom: 16px;
}
.landing-chip{
  display:inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.25);
  font-size: 11px;
  letter-spacing: 2px;
  margin-bottom: 10px;
}
.landing-footer{
  text-align:center;
  color: rgba(255,255,255,.55);
  letter-spacing: 2px;
  font-size: 12px;
}
.landing-preview{
  margin-top: 16px;
  padding: 14px;
  border-radius: 16px;
}
.landing-preview-sandbox{
  margin-top: 16px;
  border-radius: 16px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.2);
  position: relative;
  overflow: hidden;
}
.landing-preview-sandbox .landing-hero{
  min-height: 220px;
}
.landing-preview-title{
  font-weight: 800;
  letter-spacing: 2px;
  margin-bottom: 10px;
}
.landing-preview-cards{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}
.landing-preview-card{
  border-radius: 14px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.2);
}

/* ====== [SECTION] SUPER TABS ====== */
.app-tabs{
  display:flex;
  gap: 10px;
  padding: 10px;
  margin: 8px 0 16px;
  border-radius: 16px;
  flex-wrap: wrap;
}
.tab-btn{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.75);
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 800;
  letter-spacing: 1px;
  cursor: pointer;
  transition: .15s transform, .15s opacity, .15s box-shadow;
}
.tab-btn:hover{ transform: translateY(-1px); }
.tab-btn.is-active{
  color: white;
  background: linear-gradient(180deg, color-mix(in srgb, var(--p) 25%, transparent), color-mix(in srgb, var(--p) 10%, transparent));
  border-color: color-mix(in srgb, var(--p) 35%, transparent);
  box-shadow: 0 0 18px color-mix(in srgb, var(--p) 25%, transparent);
}
[data-app].is-hidden{
  display:none;
}

@media (max-width: 720px){
  .landing-hero{ padding: 18px; }
  .landing-top{ flex-direction: column; align-items:flex-start; }
  .landing-hero-orb{ right:-30%; top:-40%; }
  .landing-card{ min-height: 0; }
  .landing-cta{ flex-direction: column; }
  .landing-cta .btn{ width: 100%; justify-content: center; }
}

@media (max-width: 480px){
  .landing-top{ padding: 12px; }
  .landing-title{ font-size: clamp(28px, 10vw, 48px); }
  .landing-tagline{ letter-spacing: 1px; }
  .landing-desc{ font-size: 14px; }
}

@keyframes glow-rotate{
  0%{ transform: rotate(0deg); opacity:.25; }
  50%{ opacity:.6; }
  100%{ transform: rotate(360deg); opacity:.25; }
}
@keyframes grid-drift{
  0%{ background-position: 0 0; }
  100%{ background-position: 80px 120px; }
}
@keyframes card-rise{
  from{ transform: translateY(10px); opacity: 0; }
  to{ transform: translateY(0); opacity: 1; }
}
@keyframes particles-float{
  0%{ background-position: 0 0, 20px 30px; }
  100%{ background-position: 120px 160px, 60px 100px; }
}
@keyframes glitch-slice{
  0%{ transform: translate(0,0); opacity:.5; }
  20%{ transform: translate(2px,-1px); opacity:.8; }
  40%{ transform: translate(-2px,1px); opacity:.6; }
  60%{ transform: translate(1px,2px); opacity:.8; }
  80%{ transform: translate(-1px,-2px); opacity:.6; }
  100%{ transform: translate(0,0); opacity:.5; }
}
@keyframes pulse-core{
  0%,100%{ transform: scale(1); opacity:.9; }
  50%{ transform: scale(1.08); opacity:1; }
}
@keyframes scanline{
  0%{ transform: translateY(0); opacity:.15; }
  50%{ transform: translateY(220px); opacity:.6; }
  100%{ transform: translateY(420px); opacity:.15; }
}
/* ====== [SECTION] PDF PREVIEW ====== */
.pdf-preview{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,10,20,.35);
  padding: 10px;
  min-height: 360px;
}
.pdf-preview iframe{
  width: 100%;
  height: 560px;
  border: none;
  border-radius: 10px;
  background: #0b0f1a;
}

/* ====== [SECTION] APP THEMES ====== */
body.app-theme--neon{
  --bg0:#05020f;
  --bg1:#0b0822;
}

body.app-theme--tech{
  --bg0:#060b12;
  --bg1:#0e1522;
  --g:#20ffb0;
}
body.app-theme--tech .bg-grid{
  background-size: 36px 36px;
  opacity:.85;
}

body.app-theme--clean{
  --bg0:#0d111a;
  --bg1:#141c2c;
}

body.app-theme--noir{
  --bg0:#050607;
  --bg1:#0b0c0f;
  --text:#f2f5ff;
  --muted:#a1a8c3;
}

body.app-theme--light{
  --bg0:#f5f7fb;
  --bg1:#ffffff;
  --text:#0f172a;
  --muted:#4b5563;
}
body.app-theme--light .bg-grid{
  opacity:.25;
}
body.app-theme--light .bg-glow{
  opacity:.4;
  filter: blur(24px);
}
body.app-theme--light .glass{
  background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.6));
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 16px 40px rgba(0,0,0,.12);
}
body.app-theme--light .badge{
  color: #1f2a44;
  border-color: rgba(0,0,0,.12);
  box-shadow: none;
}
body.app-theme--light .field input,
body.app-theme--light .field select,
body.app-theme--light .field textarea{
  background: rgba(255,255,255,.9);
  color: #0f172a;
  border-color: rgba(0,0,0,.12);
}
body.app-theme--light .btn{
  background: rgba(255,255,255,.9);
  color: #0f172a;
  border-color: rgba(0,0,0,.12);
}
body.app-theme--light .empty{ color: rgba(0,0,0,.45); }

.logo{
  height: 96px;
  width: auto;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.22);
  padding: 4px 6px;
}
@media (max-width: 720px){
  .logo{ height: 60px; }
}

/* ====== [SECTION] MOBILE LAYOUT ====== */
@media (max-width: 720px){
  .topbar{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .topbar-left,
  .topbar-right{
    width: 100%;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
  .shell{
    width: min(980px, 94vw);
    margin: 12px auto 40px;
    gap: 12px;
  }
  .panel{
    padding: 12px;
  }
  .panel-head{
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .card-top{
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .card-actions{
    flex-wrap: wrap;
  }
  .card-actions .btn{
    flex: 1 1 100%;
    justify-content: center;
  }
  .inline{
    flex-direction: column;
    align-items: stretch;
  }
  .auth-shell{
    padding: 24px 10px;
  }
  .auth-frame{
    padding: 14px;
  }
  .brand-marquee{
    align-self: flex-start;
  }
  .modal{
    align-items: flex-start;
    padding: 12px;
  }
  .modal-card{
    max-height: 90vh;
    overflow: auto;
  }
  .pdf-preview iframe{
    height: 420px;
  }
}

@media (max-width: 520px){
  .topbar{
    padding: 12px;
  }
  .reactor{
    width: 36px;
    height: 36px;
  }
  .h1{ font-size: 16px; }
  .h2{ font-size: 14px; }
  .brand-main{
    font-size: clamp(24px, 7vw, 36px);
  }
  .card{
    padding: 12px;
  }
  .btn{
    padding: 10px 12px;
  }
  .photo-card img,
  .photo-thumb img{
    height: 150px;
  }
  .login-stage .auth-frame{
    transform: scale(.88);
  }
}

/* ====== [SECTION] REACTOR ICON ====== */
.reactor{
  width: 44px; height: 44px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.18);
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--p) 35%, transparent), transparent 55%),
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--s) 26%, transparent), transparent 62%),
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--g) 16%, transparent), transparent 68%);
  position: relative;
  overflow: hidden;
}
.reactor::after{
  content:"";
  position:absolute; inset:-70%;
  background: conic-gradient(from 0deg,
    transparent,
    color-mix(in srgb, var(--p) 55%, transparent),
    transparent,
    color-mix(in srgb, var(--g) 25%, transparent),
    transparent
  );
  animation: spin 2.2s linear infinite;
  opacity: .85;
}
@keyframes spin{ to{ transform: rotate(360deg);} }

/* ====== [SECTION] PANELS ====== */
.panel{
  border-radius: 18px;
  padding: 14px;
}

.panel-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom: 12px;
  gap: 10px;
}

.panel-title{
  font-weight: 900;
  letter-spacing: 3px;
  color: rgba(255,255,255,.92);
  font-size: 12px;
}

.panel-sub{
  font-size: 12px;
  color: rgba(255,255,255,.45);
}

/* ====== [SECTION] CARDS ====== */
.list{
  display:grid;
  gap: 12px;
}

.card{
  border-radius: 18px;
  padding: 14px;
  position: relative;
  overflow:hidden;
}
.card.allow-overflow{
  overflow: visible;
}
.card::before{
  content:"";
  position:absolute; inset:-80%;
  background: radial-gradient(circle at 20% 20%, rgba(0,243,255,.10), transparent 55%);
  transform: translateX(-15%);
  pointer-events:none;
}
.card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

.card-title{
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 1px;
}

.meta{
  margin-top: 10px;
  display:grid;
  gap: 6px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}

.meta-k{
  color: rgba(255,255,255,.45);
  letter-spacing: 1px;
  margin-right: 6px;
}

.card-actions{
  margin-top: 12px;
  display:flex;
  gap: 10px;
}

/* ====== [SECTION] CHECKLIST ====== */
.checklist{
  display:grid;
  gap: 10px;
}
.check-item{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
}
.check-item input{
  width: 18px;
  height: 18px;
  accent-color: var(--p);
}

/* ====== [SECTION] BADGES ====== */
.badge{
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 2px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.25);
}
.badge.ok{
  color: rgba(10,255,96,.95);
  border-color: rgba(10,255,96,.28);
  box-shadow: 0 0 18px rgba(10,255,96,.10);
}
.badge.warn{
  color: var(--p);
  border-color: color-mix(in srgb, var(--p) 28%, transparent);
  box-shadow: 0 0 18px color-mix(in srgb, var(--p) 10%, transparent);
}

/* ====== [SECTION] BUTTONS ====== */
.btn{
  position:relative;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
  color: var(--text);
  cursor: pointer;
  font-weight: 900;
  letter-spacing: 2px;
  overflow:hidden;
  user-select:none;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn[disabled]{
  opacity:.45;
  cursor:not-allowed;
}
.btn.btn-ghost{
  background: rgba(0,0,0,.10);
  border-color: rgba(255,255,255,.14);
  box-shadow: none;
}
.btn.btn-ghost:hover{
  border-color: color-mix(in srgb, var(--p) 35%, rgba(255,255,255,.15));
  box-shadow: 0 0 18px color-mix(in srgb, var(--p) 14%, transparent);
}

.btn.primary{
  border-color: color-mix(in srgb, var(--p) 35%, transparent);
  box-shadow: 0 0 22px color-mix(in srgb, var(--p) 8%, transparent);
}

.btn .shine{
  position:absolute; inset:-60%;
  background:
    radial-gradient(circle at 25% 35%, color-mix(in srgb, var(--p) 22%, transparent), transparent 55%),
    radial-gradient(circle at 70% 40%, color-mix(in srgb, var(--s) 16%, transparent), transparent 55%);
  transform: translateX(-18%);
  transition: transform .25s ease;
  pointer-events:none;
}
.btn:hover .shine{ transform: translateX(18%); }

/* ====== [SECTION] HINT ====== */
.hint{
  font-size: 12px;
  letter-spacing: 1px;
  color: rgba(255,255,255,.62);
}

/* ====== [SECTION] EMPTY + ALERT ====== */
.empty{
  padding: 16px;
  color: rgba(255,255,255,.40);
  letter-spacing: 2px;
}

.alert{
  border:1px solid rgba(255,80,80,.35);
  background: rgba(255,80,80,.10);
  padding: 12px 12px;
  border-radius: 14px;
  color:#ffbcbc;
  font-weight:800;
  letter-spacing: 1px;
}

/* Error color is fixed (not theme-driven) on purpose. */
.alert.err{
  border-color: rgba(255, 0, 51, 0.60) !important;
  background: rgba(255, 0, 51, 0.16) !important;
  color: #ffe3ea !important;
  box-shadow: 0 0 18px rgba(255, 0, 51, 0.35);
}
.alert.ok{
  border-color: rgba(34,197,94,.45);
  background: rgba(34,197,94,.10);
  color: rgba(224,255,240,.92);
}

/* Inline status line (POS + other pages). */
.statusline{
  min-height: 18px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
  color: rgba(255,255,255,.70);
  letter-spacing: .06em;
}
.statusline[data-kind="err"]{
  border-color: rgba(255, 0, 51, 0.75) !important;
  background: rgba(255, 0, 51, 0.14) !important;
  color: #ffe3ea !important;
  box-shadow: 0 0 18px rgba(255, 0, 51, 0.40);
}
.statusline[data-kind="ok"]{
  border-color: rgba(34,197,94,.55);
  background: rgba(34,197,94,.10);
  color: rgba(224,255,240,.92);
}
.statusline[data-kind="warn"]{
  border-color: rgba(255, 184, 0, 0.70);
  background: rgba(255, 184, 0, 0.14);
  color: #fff3cc;
  box-shadow: 0 0 16px rgba(255, 184, 0, 0.28);
}
.statusline[data-kind="info"]{
  border-color: rgba(255,255,255,.12);
  background: rgba(0,0,0,.10);
}

/* ====== [SECTION] MODAL ====== */
.modal{
  position:fixed; inset:0;
  background: rgba(0,0,0,.70);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 20px;
  z-index: 999;
}

.modal-card{
  width: min(720px, 94vw);
  border-radius: 18px;
  padding: 14px;
}

.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

.form-grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 720px){
  .form-grid{ grid-template-columns: 1fr; }
}

.field span{
  display:block;
  color: rgba(255,255,255,.55);
  font-size: 11px;
  letter-spacing: 2px;
  margin-bottom: 6px;
}

.inline{
  display:flex;
  gap: 8px;
  align-items:center;
}

.field input,
.field select,
.field textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,10,20,.35);
  color: var(--text);
  outline: none;
}

.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color: rgba(0,243,255,.55);
  box-shadow: 0 0 0 3px rgba(0,243,255,.12);
}

.field textarea{
  min-height: 90px;
  resize: vertical;
}

.wallpaper-preview{
  width: min(420px, 80vw);
  height: 120px;
  border-radius: 16px;
  border: 1px dashed rgba(255,255,255,.25);
  background: rgba(0,0,0,.08);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}

.modal-actions{
  margin-top: 12px;
  display:flex;
  justify-content:flex-end;
}

/* ====== [SECTION] CHECKLIST EDIT ====== */
.checklist-edit{
  display:grid;
  gap: 10px;
}
.check-edit-row{
  display:flex;
  align-items:center;
  gap: 10px;
}
.check-edit-row .check-item{
  flex:1;
}

.btn.mini{
  padding: 6px 10px;
  border-radius: 12px;
  font-size: 10px;
}

form.inline input,
form.inline select{
  min-width: 140px;
}

/* ====== [SECTION] PHOTOS ====== */
.photo-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
}
.photo-card{
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding: 8px;
  display:grid;
  gap: 8px;
}
.photo-card img{
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.12);
}
.photo-thumb{
  display:block;
  border-radius: 10px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
}
.photo-thumb img{
  width: 100%;
  height: 120px;
  object-fit: cover;
  display:block;
}

/* ====== [SECTION] Efi Delivery Restaurant Visual System (v2) ======
   Reemplaza el look neon-tech por una estética de software gastronómico:
   foco en legibilidad, ritmo visual y uso táctil.
*/
body.restaurant-suite{
  --surface-1: color-mix(in srgb, var(--bg) 90%, white 4%);
  --surface-2: color-mix(in srgb, var(--bg) 82%, white 6%);
  --surface-3: color-mix(in srgb, var(--bg) 76%, white 8%);
  --line-soft: color-mix(in srgb, var(--text) 10%, transparent);
  --line-strong: color-mix(in srgb, var(--text) 16%, transparent);
  --muted-2: color-mix(in srgb, var(--text) 62%, transparent);
  --card-shadow: 0 16px 36px rgba(0,0,0,.22);
  --card-shadow-lg: 0 24px 60px rgba(0,0,0,.28);
  --radius-xl: 18px;
  --radius-lg: 14px;
  --radius-md: 12px;
  --radius-sm: 10px;
  --tone-panel: color-mix(in srgb, var(--p) 7%, transparent);
  --tone-panel-2: color-mix(in srgb, var(--s) 6%, transparent);
}

body.restaurant-suite .fx-vignette{ opacity: .35; }
body.restaurant-suite .fx-grid{ opacity: calc(var(--pattern, .2) * 0.10); }
body.restaurant-suite .fx-hex{ opacity: 0 !important; }
body.restaurant-suite .fx-scan{ opacity: 0 !important; }
body.restaurant-suite .fx-beams{ opacity: calc(var(--aura, .15) * 0.08); filter: blur(120px) saturate(1.02); }
body.restaurant-suite .fx-rings{ opacity: 0; }

body.restaurant-suite .glass,
body.restaurant-suite .card{
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-2) 92%, var(--tone-panel) 8%), color-mix(in srgb, var(--surface-1) 94%, var(--tone-panel-2) 6%));
  border: 1px solid var(--line-soft);
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(8px);
}
body.restaurant-suite .card::before{
  background: linear-gradient(90deg, color-mix(in srgb, var(--a) 20%, transparent), transparent 55%);
  opacity: .12;
}
body.restaurant-suite .topbar{
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface-2) 96%, transparent), color-mix(in srgb, var(--surface-1) 98%, transparent));
  border: 1px solid var(--line-soft);
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(10px);
}
body.restaurant-suite .kicker{
  color: color-mix(in srgb, var(--text) 58%, transparent);
  letter-spacing: .18em;
}
body.restaurant-suite .h1{
  letter-spacing: .01em;
  font-weight: 800;
}
body.restaurant-suite .panel-title,
body.restaurant-suite .card-title{
  letter-spacing: .02em;
  font-weight: 800;
}
body.restaurant-suite .panel-sub,
body.restaurant-suite .muted,
body.restaurant-suite .hint{
  color: var(--muted-2);
}

body.restaurant-suite .pill,
body.restaurant-suite .badge,
body.restaurant-suite .tag,
body.restaurant-suite .chip{
  border-color: var(--line-soft);
  background: color-mix(in srgb, var(--surface-3) 92%, transparent);
  color: color-mix(in srgb, var(--text) 78%, transparent);
  box-shadow: none;
}
body.restaurant-suite .pill .dot{
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary, var(--p)) 16%, transparent);
}

body.restaurant-suite .field input,
body.restaurant-suite .field select,
body.restaurant-suite .field textarea{
  border-radius: var(--radius-md);
  border: 1px solid var(--line-soft);
  background: color-mix(in srgb, var(--surface-3) 94%, transparent);
  color: var(--text);
}
body.restaurant-suite .field input:focus,
body.restaurant-suite .field select:focus,
body.restaurant-suite .field textarea:focus{
  border-color: color-mix(in srgb, var(--p) 32%, transparent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--p) 10%, transparent);
}

body.restaurant-suite .btn{
  border-radius: var(--radius-md);
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface-3) 92%, transparent), color-mix(in srgb, var(--surface-2) 96%, transparent));
  color: var(--text);
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
}
body.restaurant-suite .btn .shine{ opacity: .35; }
body.restaurant-suite .btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(0,0,0,.16);
}
body.restaurant-suite .btn.btn-ghost{
  background: transparent;
  box-shadow: none;
}
body.restaurant-suite .btn.primary{
  background: linear-gradient(180deg, color-mix(in srgb, var(--p) 22%, transparent), color-mix(in srgb, var(--p) 12%, var(--surface-2) 88%));
  border-color: color-mix(in srgb, var(--p) 34%, transparent);
}

body.restaurant-suite .alert{
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,.12);
}
body.restaurant-suite .alert.err{
  background: color-mix(in srgb, var(--danger) 10%, var(--surface-2) 90%);
  border-color: color-mix(in srgb, var(--danger) 25%, transparent);
  color: color-mix(in srgb, var(--danger) 80%, white 20%);
}
body.restaurant-suite .alert.ok{
  background: color-mix(in srgb, var(--success) 10%, var(--surface-2) 90%);
  border-color: color-mix(in srgb, var(--success) 25%, transparent);
}

/* Auth screens (Owner/Mozo/KDS login) */
body.restaurant-suite .auth-frame{
  border: 1px solid var(--line-strong);
  border-radius: 20px;
  box-shadow: var(--card-shadow-lg);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-2) 95%, transparent), color-mix(in srgb, var(--surface-1) 96%, transparent));
}
body.restaurant-suite .auth-frame::after{
  opacity: .18;
  animation: none;
  filter: blur(32px);
}
body.restaurant-suite .auth-card{ animation: none; }
body.restaurant-suite .brand-main{
  font-family: "Sora", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-weight: 800;
  letter-spacing: .02em;
  text-shadow: none;
  color: var(--text);
}
body.restaurant-suite .brand-sub{
  font-family: "Sora", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: color-mix(in srgb, var(--text) 72%, transparent);
}

/* Waiter/KDS touch density */
body.restaurant-suite.page-waiter .btn,
body.restaurant-suite.page-kds .btn{
  min-height: 38px;
  font-weight: 700;
}
body.restaurant-suite.page-waiter .table-btn{
  border-radius: 12px;
  border: 1px solid var(--line-soft);
  background: color-mix(in srgb, var(--surface-2) 95%, transparent);
  box-shadow: none;
}
body.restaurant-suite.page-waiter .table-btn.active{
  border-color: color-mix(in srgb, var(--p) 28%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--p) 8%, transparent);
}
body.restaurant-suite.page-waiter .prod{
  border-color: var(--line-soft);
  background: color-mix(in srgb, var(--surface-2) 96%, transparent);
  box-shadow: none;
}
body.restaurant-suite.page-waiter .prod .ph{
  background: color-mix(in srgb, var(--surface-1) 94%, transparent);
}
body.restaurant-suite.page-waiter .order-row,
body.restaurant-suite.page-waiter .ticket-row,
body.restaurant-suite.page-waiter .sum-box{
  border-color: var(--line-soft);
  background: color-mix(in srgb, var(--surface-2) 96%, transparent);
}
body.restaurant-suite.page-waiter .input,
body.restaurant-suite.page-waiter .notes,
body.restaurant-suite.page-waiter .item-note,
body.restaurant-suite.page-waiter .modal-lite-card{
  border-color: var(--line-soft);
}

/* KDS readability */
body.restaurant-suite.page-kds .order{
  background: color-mix(in srgb, var(--surface-2) 97%, transparent);
  border-color: var(--line-soft);
  box-shadow: none;
}
body.restaurant-suite.page-kds .order.preparing{
  border-color: color-mix(in srgb, var(--info) 35%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--info) 10%, transparent);
}
body.restaurant-suite.page-kds .order.ready{
  border-color: color-mix(in srgb, var(--success) 35%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--success) 10%, transparent);
}
body.restaurant-suite.page-kds .kds-col-count{
  background: color-mix(in srgb, var(--surface-3) 96%, transparent);
  border-color: var(--line-soft);
}
body.restaurant-suite.page-kds .kds-badge.ok{ color: var(--success); border-color: color-mix(in srgb, var(--success) 35%, transparent); }
body.restaurant-suite.page-kds .kds-badge.warn{ color: var(--warn); border-color: color-mix(in srgb, var(--warn) 35%, transparent); }

/* Manager dashboard tables */
body.restaurant-suite.page-manager .tbl th,
body.restaurant-suite.page-manager .tbl td{
  border-bottom-color: var(--line-soft);
}
body.restaurant-suite.page-manager .kpi{
  border-color: var(--line-soft);
  background: color-mix(in srgb, var(--surface-2) 96%, transparent);
}

/* Light-friendly text for local white-based custom styles in waiter/kds/manager */
body.restaurant-suite[data-tpl="quartz_service"],
body.restaurant-suite[data-tpl="fast_casual"],
body.restaurant-suite[data-tpl="sakura_market"]{
  color-scheme: light;
}
body.restaurant-suite[data-tpl="quartz_service"] .mini,
body.restaurant-suite[data-tpl="quartz_service"] .muted,
body.restaurant-suite[data-tpl="quartz_service"] .panel-sub,
body.restaurant-suite[data-tpl="quartz_service"] .kds-col-count,
body.restaurant-suite[data-tpl="quartz_service"] .tbl th,
body.restaurant-suite[data-tpl="quartz_service"] .toolbar .field-mini span,
body.restaurant-suite[data-tpl="fast_casual"] .toolbar .field-mini span,
body.restaurant-suite[data-tpl="sakura_market"] .toolbar .field-mini span{
  color: color-mix(in srgb, var(--text) 62%, transparent);
}

/* ---------- Restaurant Templates (new) ---------- */
body[data-tpl="brasserie_slate"]{
  background:
    radial-gradient(960px 620px at 10% 8%, color-mix(in srgb, var(--p) 9%, transparent), transparent 70%),
    radial-gradient(1000px 760px at 90% 10%, color-mix(in srgb, var(--s) 8%, transparent), transparent 74%),
    linear-gradient(180deg, #1a2026 0%, #14191f 100%);
}
body[data-tpl="brasserie_slate"] .fx-grid{
  background-image:
    linear-gradient(to right, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 28px 28px;
}
body[data-tpl="brasserie_slate"] .fx-noise{ opacity:.035; mix-blend-mode: overlay; }

body[data-tpl="terra_bistro"]{
  background:
    radial-gradient(900px 650px at 8% 8%, color-mix(in srgb, var(--p) 11%, transparent), transparent 72%),
    radial-gradient(840px 620px at 92% 12%, color-mix(in srgb, var(--s) 10%, transparent), transparent 76%),
    linear-gradient(180deg, #2c1f1b 0%, #221814 100%);
}
body[data-tpl="terra_bistro"] .fx-grid{ opacity: calc(var(--pattern,.15) * .06); background-size: 36px 36px; }
body[data-tpl="terra_bistro"] .fx-noise{ opacity:.045; mix-blend-mode: soft-light; }

body[data-tpl="quartz_service"]{
  background:
    radial-gradient(900px 640px at 10% 8%, color-mix(in srgb, var(--p) 8%, white), transparent 72%),
    radial-gradient(900px 640px at 90% 10%, color-mix(in srgb, var(--s) 8%, white), transparent 72%),
    linear-gradient(180deg, #fbfaf7 0%, #f1eee7 100%);
}
body[data-tpl="quartz_service"] .fx-grid{
  opacity: calc(var(--pattern,.1) * .08);
  background-image:
    linear-gradient(to right, rgba(17,24,39,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(17,24,39,.045) 1px, transparent 1px);
  background-size: 32px 32px;
}
body[data-tpl="quartz_service"] .fx-aura{ opacity: calc(var(--aura,.05) * .10); filter: blur(120px); }
body[data-tpl="quartz_service"] .fx-noise{ opacity:.02; mix-blend-mode:multiply; }
body[data-tpl="quartz_service"] .fx-vignette{ opacity:.12; background: radial-gradient(circle at 50% 40%, transparent 0%, rgba(17,24,39,.06) 70%, rgba(17,24,39,.10) 100%); }

body[data-tpl="midnight_kitchen"]{
  background:
    radial-gradient(1200px 780px at 12% 4%, color-mix(in srgb, var(--s) 10%, transparent), transparent 74%),
    radial-gradient(900px 680px at 88% 12%, color-mix(in srgb, var(--p) 12%, transparent), transparent 72%),
    linear-gradient(180deg, #0f1216 0%, #090c10 100%);
}
body[data-tpl="midnight_kitchen"] .fx-grid{ opacity: calc(var(--pattern,.08) * .06); background-size: 20px 20px; }
body[data-tpl="midnight_kitchen"] .fx-noise{ opacity:.028; }
body[data-tpl="midnight_kitchen"] .fx-vignette{ opacity:.48; }
body[data-tpl="midnight_kitchen"] .glass,
body[data-tpl="midnight_kitchen"] .card{
  background: linear-gradient(180deg, rgba(20,24,30,.96), rgba(16,20,26,.96));
  border-color: rgba(255,255,255,.08);
}

body[data-tpl="fast_casual"]{
  background:
    radial-gradient(800px 540px at 12% 8%, color-mix(in srgb, var(--p) 10%, white), transparent 70%),
    radial-gradient(960px 680px at 88% 10%, color-mix(in srgb, var(--s) 10%, white), transparent 74%),
    linear-gradient(180deg, #f7fafc 0%, #eef3f8 100%);
}
body[data-tpl="fast_casual"] .fx-grid{
  opacity: calc(var(--pattern,.12) * .10);
  background-image:
    linear-gradient(to right, rgba(15,23,42,.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,.035) 1px, transparent 1px);
  background-size: 26px 26px;
}
body[data-tpl="fast_casual"] .fx-aura{ opacity: calc(var(--aura,.05) * .12); }
body[data-tpl="fast_casual"] .fx-noise{ opacity:.015; }
body[data-tpl="fast_casual"] .glass,
body[data-tpl="fast_casual"] .card{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.88));
  border-color: rgba(17,24,39,.08);
  box-shadow: 0 14px 30px rgba(15,23,42,.08);
}
body[data-tpl="fast_casual"] .btn{
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,250,252,.92));
  border-color: rgba(17,24,39,.12);
  color: #111827;
}
body[data-tpl="fast_casual"] .btn.primary{
  color: #fff;
  background: linear-gradient(180deg, color-mix(in srgb, var(--p) 88%, white 0%), color-mix(in srgb, var(--p) 75%, black 6%));
  border-color: color-mix(in srgb, var(--p) 65%, transparent);
}

body[data-tpl="sakura_market"]{
  background:
    radial-gradient(900px 640px at 12% 8%, color-mix(in srgb, var(--p) 14%, white), transparent 72%),
    radial-gradient(1000px 700px at 92% 10%, color-mix(in srgb, var(--s) 14%, white), transparent 72%),
    linear-gradient(180deg, #fff6fa 0%, #ffeef4 100%);
}
body[data-tpl="sakura_market"] .fx-grid{
  opacity: calc(var(--pattern,.16) * .12);
  background-image:
    radial-gradient(circle at 6px 6px, rgba(232,90,138,.14) 0 2px, transparent 2px),
    radial-gradient(circle at 18px 12px, rgba(216,69,94,.10) 0 2px, transparent 2px);
  background-size: 24px 18px;
}
body[data-tpl="sakura_market"] .fx-noise{ opacity:.014; }
body[data-tpl="sakura_market"] .glass,
body[data-tpl="sakura_market"] .card{
  background: linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,247,251,.82));
  border-color: rgba(232,90,138,.16);
  box-shadow: 0 14px 28px rgba(232,90,138,.09);
}
body[data-tpl="sakura_market"] .btn{
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,245,249,.90));
  border-color: rgba(232,90,138,.20);
  color: #432838;
}
body[data-tpl="sakura_market"] .btn.primary{
  color: #fff;
  background: linear-gradient(180deg, rgba(232,90,138,.96), rgba(216,69,94,.92));
  border-color: rgba(216,69,94,.42);
}

/* Legacy aliases in CSS (if body data-tpl arrives old key before normalization) */
body[data-tpl="quartz_light"]{ color-scheme: light; }
body[data-tpl="quartz_light"],
body[data-tpl="mlts"]{ /* keep selectors alive; appearance editor may still render previews with old ids */ }

/* ====== [SECTION] Restaurant Views Polish Pass (v2.1) ====== */

/* KDS should read like an operational screen, not decorative neon */
body.restaurant-suite.page-kds .fx-aura,
body.restaurant-suite.page-kds .fx-beams,
body.restaurant-suite.page-kds .fx-rings,
body.restaurant-suite.page-kds .fx-hex,
body.restaurant-suite.page-kds .fx-scan{
  opacity: 0 !important;
}
body.restaurant-suite.page-kds .fx-grid{
  opacity: .04 !important;
  background-size: 18px 18px !important;
}
body.restaurant-suite.page-kds .fx-vignette{
  opacity: .28 !important;
}

/* Light templates get stronger readable contrast by default */
body.restaurant-suite[data-tpl="quartz_service"],
body.restaurant-suite[data-tpl="fast_casual"],
body.restaurant-suite[data-tpl="sakura_market"]{
  --line-soft: rgba(17,24,39,.10);
  --line-strong: rgba(17,24,39,.14);
  --card-shadow: 0 10px 24px rgba(15,23,42,.06);
  --card-shadow-lg: 0 18px 38px rgba(15,23,42,.08);
}

/* Fast casual: flatter, high clarity panels */
body[data-tpl="fast_casual"] .pill,
body[data-tpl="fast_casual"] .chip,
body[data-tpl="fast_casual"] .tag,
body[data-tpl="fast_casual"] .badge{
  background: rgba(255,255,255,.86);
  border-color: rgba(15,23,42,.10);
  color: #334155;
}

/* Sakura variant: more paper-like subtle texture and softer UI */
body[data-tpl="sakura_market"] .fx-vignette{
  opacity: .06;
  background:
    radial-gradient(circle at 20% 15%, rgba(232,90,138,.08), transparent 45%),
    radial-gradient(circle at 80% 10%, rgba(216,69,94,.06), transparent 42%),
    radial-gradient(circle at 50% 100%, rgba(232,90,138,.07), transparent 55%);
}
body[data-tpl="sakura_market"] .fx-aura{
  opacity: calc(var(--aura,.10) * .08);
}
body[data-tpl="sakura_market"] .pill,
body[data-tpl="sakura_market"] .chip,
body[data-tpl="sakura_market"] .tag,
body[data-tpl="sakura_market"] .badge{
  background: rgba(255,255,255,.76);
  border-color: rgba(216,69,94,.18);
  color: #5b3143;
}

/* ====== [SECTION] Readability Pass (v2.2) ======
   Objective: avoid dark text over dark surfaces and keep high contrast in light templates.
*/
body.restaurant-suite{
  --ink-strong: var(--text);
  --ink-mid: color-mix(in srgb, var(--text) 88%, transparent);
  --ink-muted: color-mix(in srgb, var(--text) 68%, transparent);
  --control-bg: color-mix(in srgb, var(--surface-3, #1b2230) 94%, transparent);
  --control-border: color-mix(in srgb, var(--text) 14%, transparent);
}

body.restaurant-suite.theme-light-ui{
  --ink-strong: #0f172a;
  --ink-mid: rgba(15,23,42,.84);
  --ink-muted: rgba(15,23,42,.62);
  --control-bg: rgba(255,255,255,.90);
  --control-border: rgba(15,23,42,.18);
}

body.restaurant-suite.theme-dark-ui{
  --ink-strong: #f8fbff;
  --ink-mid: rgba(236,243,255,.90);
  --ink-muted: rgba(216,226,246,.76);
  --control-bg: rgba(255,255,255,.07);
  --control-border: rgba(255,255,255,.17);
}

body.restaurant-suite .brand-main,
body.restaurant-suite .brandTitle,
body.restaurant-suite .h1,
body.restaurant-suite .title h1,
body.restaurant-suite .card-title,
body.restaurant-suite .panel-title,
body.restaurant-suite .kpi .v,
body.restaurant-suite .tbl td,
body.restaurant-suite .who,
body.restaurant-suite .who strong{
  color: var(--ink-strong) !important;
}

body.restaurant-suite .kicker,
body.restaurant-suite .subtitle,
body.restaurant-suite .panel-sub,
body.restaurant-suite .muted,
body.restaurant-suite .hint,
body.restaurant-suite .empty,
body.restaurant-suite .mini,
body.restaurant-suite .field span,
body.restaurant-suite .toolbar .field-mini span,
body.restaurant-suite .tbl th,
body.restaurant-suite .kpi .k,
body.restaurant-suite .kpi .s,
body.restaurant-suite .badge,
body.restaurant-suite .pill,
body.restaurant-suite .chip,
body.restaurant-suite .tag{
  color: var(--ink-muted) !important;
}

body.restaurant-suite .field input,
body.restaurant-suite .field select,
body.restaurant-suite .field textarea,
body.restaurant-suite .input,
body.restaurant-suite .inputx,
body.restaurant-suite .notes,
body.restaurant-suite .item-note,
body.restaurant-suite .searchbar .input{
  background: var(--control-bg) !important;
  border-color: var(--control-border) !important;
  color: var(--ink-strong) !important;
}

body.restaurant-suite .field input::placeholder,
body.restaurant-suite .field textarea::placeholder,
body.restaurant-suite .input::placeholder,
body.restaurant-suite .inputx::placeholder,
body.restaurant-suite .notes::placeholder,
body.restaurant-suite .item-note::placeholder,
body.restaurant-suite .searchbar .input::placeholder{
  color: var(--ink-muted) !important;
  opacity: .9;
}

body.restaurant-suite .btn,
body.restaurant-suite .btnx,
body.restaurant-suite .tab-btn,
body.restaurant-suite .tabs .tab a{
  color: var(--ink-strong) !important;
  border-color: var(--control-border) !important;
}

body.restaurant-suite .btn.primary,
body.restaurant-suite .btnx.primary,
body.restaurant-suite .tab-btn.is-active,
body.restaurant-suite .tabs .tab a.active{
  color: var(--primary-ink, #fff) !important;
}

body.restaurant-suite .btn.danger,
body.restaurant-suite .btnx.danger{
  color: #fff !important;
}

/* ====== [SECTION] Tech Clean Overhaul (v3.0) ======
   Clean operational look across all Delivery views:
   owner / manager / waiter / kds / public menu / login.
*/
body.restaurant-suite{
  --bg: #f4f7fb;
  --surface-1: #ffffff;
  --surface-2: #eef3f8;
  --surface-3: #f8fafc;
  --text: #0f172a;
  --muted: #475569;
  --line-soft: #dce3ec;
  --line-strong: #cfd8e3;
  --card-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
  --card-shadow-lg: 0 16px 34px rgba(15, 23, 42, 0.09);
  --brand-primary: #0f766e;
  --brand-primary-hover: #0b5f59;
  --brand-link: #1d4ed8;
  --ok: #15803d;
  --warn: #b45309;
  --err: #b91c1c;
  font-family: "IBM Plex Sans", "Sora", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif !important;
  background: #f4f7fb !important;
  color: #0f172a !important;
}

body.restaurant-suite code,
body.restaurant-suite pre,
body.restaurant-suite .mono,
body.restaurant-suite .kicker,
body.restaurant-suite .tbl th,
body.restaurant-suite .chip,
body.restaurant-suite .badge,
body.restaurant-suite .pill{
  font-family: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !important;
}

body.restaurant-suite .fx-aura,
body.restaurant-suite .fx-hex,
body.restaurant-suite .fx-noise,
body.restaurant-suite .fx-scan,
body.restaurant-suite .fx-beams,
body.restaurant-suite .fx-rings{
  display: none !important;
}
body.restaurant-suite .fx-grid{
  opacity: .055 !important;
  background-image:
    linear-gradient(to right, rgba(15,23,42,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,.045) 1px, transparent 1px) !important;
  background-size: 28px 28px !important;
  mask-image: none !important;
}
body.restaurant-suite .fx-vignette{
  opacity: .10 !important;
  background: radial-gradient(circle at 50% 25%, transparent 0%, rgba(15,23,42,.05) 72%, rgba(15,23,42,.09) 100%) !important;
}

body.restaurant-suite .topbar{
  position: sticky !important;
  top: 12px !important;
  z-index: 40 !important;
  background: #ffffff !important;
  border: 1px solid #dce3ec !important;
  box-shadow: 0 8px 20px rgba(15,23,42,.06) !important;
  backdrop-filter: none !important;
}

body.restaurant-suite .glass,
body.restaurant-suite .card,
body.restaurant-suite .panel,
body.restaurant-suite .subpanel,
body.restaurant-suite .tabs-wrap,
body.restaurant-suite .kpi,
body.restaurant-suite .hero,
body.restaurant-suite .catCard,
body.restaurant-suite .prodCard,
body.restaurant-suite .cartbar,
body.restaurant-suite .auth-frame,
body.restaurant-suite .modal-lite-card,
body.restaurant-suite .order,
body.restaurant-suite .order-group,
body.restaurant-suite .sum-box,
body.restaurant-suite .ticket-row,
body.restaurant-suite .order-row{
  background: #ffffff !important;
  border-color: #dce3ec !important;
  box-shadow: 0 8px 20px rgba(15,23,42,.06) !important;
  color: #0f172a !important;
}

body.restaurant-suite .card::before,
body.restaurant-suite .hero::before,
body.restaurant-suite .hero::after,
body.restaurant-suite .auth-frame::after{
  opacity: 0 !important;
  display: none !important;
}

body.restaurant-suite .h1,
body.restaurant-suite .title h1,
body.restaurant-suite .brand-main,
body.restaurant-suite .brandTitle,
body.restaurant-suite .panel-title,
body.restaurant-suite .card-title,
body.restaurant-suite .sectionTitle,
body.restaurant-suite .kpi .v{
  color: #0f172a !important;
  text-shadow: none !important;
  font-weight: 700 !important;
}

body.restaurant-suite .subtitle,
body.restaurant-suite .panel-sub,
body.restaurant-suite .muted,
body.restaurant-suite .hint,
body.restaurant-suite .empty,
body.restaurant-suite .mini,
body.restaurant-suite .kpi .k,
body.restaurant-suite .kpi .s,
body.restaurant-suite .tbl th,
body.restaurant-suite .badge,
body.restaurant-suite .pill,
body.restaurant-suite .chip,
body.restaurant-suite .tag{
  color: #475569 !important;
}
body.restaurant-suite .tbl td,
body.restaurant-suite .who,
body.restaurant-suite .who strong{
  color: #0f172a !important;
}

body.restaurant-suite .field input,
body.restaurant-suite .field select,
body.restaurant-suite .field textarea,
body.restaurant-suite .input,
body.restaurant-suite .inputx,
body.restaurant-suite .notes,
body.restaurant-suite .item-note,
body.restaurant-suite .searchbar .input,
body.restaurant-suite .toolbar input,
body.restaurant-suite form.inline input,
body.restaurant-suite form.inline select{
  background: #ffffff !important;
  border: 1px solid #dce3ec !important;
  color: #0f172a !important;
  box-shadow: none !important;
}
body.restaurant-suite .field input::placeholder,
body.restaurant-suite .field textarea::placeholder,
body.restaurant-suite .input::placeholder,
body.restaurant-suite .inputx::placeholder,
body.restaurant-suite .notes::placeholder,
body.restaurant-suite .item-note::placeholder,
body.restaurant-suite .searchbar .input::placeholder,
body.restaurant-suite .toolbar input::placeholder{
  color: #64748b !important;
  opacity: 1 !important;
}
body.restaurant-suite .field input:focus,
body.restaurant-suite .field select:focus,
body.restaurant-suite .field textarea:focus,
body.restaurant-suite .input:focus,
body.restaurant-suite .inputx:focus,
body.restaurant-suite .notes:focus,
body.restaurant-suite .item-note:focus,
body.restaurant-suite .searchbar .input:focus,
body.restaurant-suite .toolbar input:focus{
  border-color: #0f766e !important;
  box-shadow: 0 0 0 3px rgba(15,118,110,.14) !important;
  outline: none !important;
}

body.restaurant-suite .btn,
body.restaurant-suite .btnx,
body.restaurant-suite .tab-btn,
body.restaurant-suite .tabs .tab a,
body.restaurant-suite .table-btn{
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid #dce3ec !important;
  box-shadow: 0 2px 8px rgba(15,23,42,.05) !important;
}
body.restaurant-suite .btn:hover,
body.restaurant-suite .btnx:hover,
body.restaurant-suite .tab-btn:hover,
body.restaurant-suite .tabs .tab a:hover{
  border-color: #c7d3e1 !important;
}
body.restaurant-suite .btn.primary,
body.restaurant-suite .btnx.primary,
body.restaurant-suite .tab-btn.is-active,
body.restaurant-suite .tabs .tab a.active{
  background: #0f766e !important;
  border-color: #0f766e !important;
  color: #ffffff !important;
}
body.restaurant-suite .btn.primary:hover,
body.restaurant-suite .btnx.primary:hover{
  background: #0b5f59 !important;
  border-color: #0b5f59 !important;
}
body.restaurant-suite .btn.btn-ghost,
body.restaurant-suite .btnx.ghost{
  background: transparent !important;
  box-shadow: none !important;
}
body.restaurant-suite .btn.danger,
body.restaurant-suite .btnx.danger{
  background: #b91c1c !important;
  border-color: #b91c1c !important;
  color: #fff !important;
}

body.restaurant-suite .tag.on,
body.restaurant-suite .badge-state.st-ready,
body.restaurant-suite .kds-badge.ok{
  color: #15803d !important;
  border-color: rgba(21,128,61,.35) !important;
}
body.restaurant-suite .badge-state.st-sent,
body.restaurant-suite .kds-badge.warn{
  color: #b45309 !important;
  border-color: rgba(180,83,9,.35) !important;
}
body.restaurant-suite .alert.err{
  color: #b91c1c !important;
  border-color: rgba(185,28,28,.28) !important;
  background: rgba(185,28,28,.08) !important;
}
body.restaurant-suite .alert.ok{
  color: #15803d !important;
  border-color: rgba(21,128,61,.28) !important;
  background: rgba(21,128,61,.08) !important;
}

/* ====== [SECTION] Mobile/PWA Stability Layer ====== */
body.restaurant-suite{
  --mobile-safe-top: env(safe-area-inset-top, 0px);
  --mobile-safe-right: env(safe-area-inset-right, 0px);
  --mobile-safe-bottom: env(safe-area-inset-bottom, 0px);
  --mobile-safe-left: env(safe-area-inset-left, 0px);
  --mobile-touch-target: 44px;
  --mobile-gap: 10px;
  --mobile-gap-lg: 14px;
}

html,
body{
  max-width: 100%;
}

body.restaurant-suite{
  overflow-x: clip;
}

body.restaurant-suite,
body.restaurant-suite *{
  box-sizing: border-box;
}

body.restaurant-suite .topbar,
body.restaurant-suite .card,
body.restaurant-suite .panel,
body.restaurant-suite .shell,
body.restaurant-suite .mgr-shell,
body.restaurant-suite .mozo-shell,
body.restaurant-suite .wrap{
  min-width: 0;
}

body.restaurant-suite .topbar-right,
body.restaurant-suite .card-actions,
body.restaurant-suite .actions,
body.restaurant-suite .toolbar,
body.restaurant-suite .catalog-tools,
body.restaurant-suite .owner-tab-panel,
body.restaurant-suite .owner-subtab-panel,
body.restaurant-suite .owner-menu-subtab-panel,
body.restaurant-suite .mgr-view-panel{
  min-width: 0;
}

body.restaurant-suite .btn,
body.restaurant-suite .btnx,
body.restaurant-suite .input,
body.restaurant-suite .inputx,
body.restaurant-suite select,
body.restaurant-suite input,
body.restaurant-suite textarea{
  min-height: var(--mobile-touch-target);
}

body.restaurant-suite .mobile-stack{
  display:flex;
  flex-wrap:wrap;
  gap: var(--mobile-gap);
  align-items:flex-start;
}

body.restaurant-suite .mobile-stack-lg{
  display:flex;
  flex-wrap:wrap;
  gap: var(--mobile-gap-lg);
  align-items:flex-start;
}

body.restaurant-suite .mobile-compact{
  gap: 8px !important;
}

@media (max-width: 980px){
  body.restaurant-suite{
    padding-left: max(10px, var(--mobile-safe-left));
    padding-right: max(10px, var(--mobile-safe-right));
    padding-bottom: calc(var(--mobile-safe-bottom) + 12px);
  }

  body.restaurant-suite .topbar{
    top: calc(var(--mobile-safe-top) + 6px) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  body.restaurant-suite .topbar-right .btn[data-pwa-install-btn],
  body.restaurant-suite .topbar-right .btnx[data-pwa-install-btn]{
    white-space: normal;
    line-height: 1.15;
  }

  body.restaurant-suite .table-scroll,
  body.restaurant-suite .channel-list,
  body.restaurant-suite .collection-items-box{
    overflow: auto;
  }

  body.restaurant-suite .mobile-stack,
  body.restaurant-suite .mobile-stack-lg{
    display:grid;
    grid-template-columns: 1fr;
    gap: var(--mobile-gap);
    width:100%;
  }

  body.restaurant-suite .mobile-stack .btn,
  body.restaurant-suite .mobile-stack .btnx,
  body.restaurant-suite .mobile-stack-lg .btn,
  body.restaurant-suite .mobile-stack-lg .btnx{
    width:100%;
    justify-content:center;
    text-align:center;
  }
}
