/* ====== [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);
}

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; }

/* ===== Template: Titanium Glass ===== */
body[data-tpl="titanium_glass"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.12); }
body[data-tpl="titanium_glass"] .fx-rings{ opacity: 0; }

/* ===== Template: HUD Matrix ===== */
body[data-tpl="hud_matrix"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.34); background-size: 22px 22px; }
body[data-tpl="hud_matrix"] .fx-hex{ opacity: 0; }
body[data-tpl="hud_matrix"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.14); }
body[data-tpl="hud_matrix"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.16); }
body[data-tpl="hud_matrix"] .fx-scan{ opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.22); }

/* ===== Template: Solar HUD ===== */
body[data-tpl="solar_hud"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.26); background-size: 26px 26px; }
body[data-tpl="solar_hud"] .fx-hex{ opacity: 0; }
body[data-tpl="solar_hud"] .fx-scan{ opacity: 0; }
body[data-tpl="solar_hud"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.12); }
body[data-tpl="solar_hud"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.18); }

/* ===== Template: Hexa Blueprint ===== */
body[data-tpl="hexa_blueprint"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.20); background-size: 40px 40px; }
body[data-tpl="hexa_blueprint"] .fx-hex{ opacity: calc(var(--pattern, .35) * 0.30); }
body[data-tpl="hexa_blueprint"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.08); }
body[data-tpl="hexa_blueprint"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.08); }

/* ===== Template: Noir Minimal ===== */
body[data-tpl="noir_minimal"] .fx-grid,
body[data-tpl="noir_minimal"] .fx-hex,
body[data-tpl="noir_minimal"] .fx-scan,
body[data-tpl="noir_minimal"] .fx-beams,
body[data-tpl="noir_minimal"] .fx-rings{ opacity: 0; }
body[data-tpl="noir_minimal"] .fx-aura{ opacity: 0; }
body[data-tpl="noir_minimal"] .fx-vignette{ opacity: 0.75; }

/* ===== Template: Quartz Light ===== */
body[data-tpl="quartz_light"]{
  color-scheme: light;
}
body[data-tpl="quartz_light"] .fx-noise{ opacity: 0.04; 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.18);
  background-image:
    linear-gradient(to right, rgba(11,18,32,.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(11,18,32,.10) 1px, transparent 1px);
}
body[data-tpl="quartz_light"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.06); filter: blur(90px) saturate(1.05); mix-blend-mode: multiply; }
body[data-tpl="quartz_light"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.06); 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) 60%, rgba(11,18,32,.18) 100%); }
body[data-tpl="quartz_light"] .glass{
  background: linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.62));
  border: 1px solid rgba(11,18,32,.10);
  box-shadow: 0 16px 40px rgba(0,0,0,.12);
}
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,.92);
  color: rgba(11,18,32,.92);
  border-color: rgba(11,18,32,.12);
}
body[data-tpl="quartz_light"] .btn{
  background: rgba(255,255,255,.92);
  color: rgba(11,18,32,.92);
  border-color: rgba(11,18,32,.12);
}
body[data-tpl="quartz_light"] .badge{
  color: rgba(11,18,32,.75);
  border-color: rgba(11,18,32,.12);
  box-shadow: none;
}

/* ===== Template: Cyberpunk Pulse ===== */
body[data-tpl="cyberpunk_pulse"] .fx-hex{ opacity: 0; }
body[data-tpl="cyberpunk_pulse"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.22); background-size: 28px 28px; }
body[data-tpl="cyberpunk_pulse"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.18); }
body[data-tpl="cyberpunk_pulse"] .fx-scan{ opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.20); }

/* ===== Template: Neon Overdrive ===== */
body[data-tpl="neon_overdrive"] .fx-grid{ opacity: calc(var(--pattern, .35) * 0.16); background-size: 44px 44px; }
body[data-tpl="neon_overdrive"] .fx-hex{ opacity: calc(var(--pattern, .35) * 0.16); }
body[data-tpl="neon_overdrive"] .fx-beams{ opacity: calc(var(--aura, .55) * 0.24); }
body[data-tpl="neon_overdrive"] .fx-rings{ opacity: calc(var(--pattern, .35) * 0.10); }
body[data-tpl="neon_overdrive"] .fx-scan{ opacity: calc(var(--scan, 1) * var(--pattern, .35) * 0.22); }
body[data-tpl="neon_overdrive"] .fx-aura{
  opacity: calc(var(--aura, .55) * 0.78);
  filter: blur(110px) saturate(1.18);
  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: 8s;
}

/* ====== [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 ease, box-shadow .18s 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--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="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;
}

.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;
}
