:root {
  --violet: #6c1195;
  --violet-2: #9b22d3;
  --violet-3: #c24de8;
  --dark: #241135;
  --muted: #73587f;
  --line: #dbcbe8;
  --soft: #fbf7ff;
  --soft-2: #f2e5fb;
  --white: #fff;
  --green: #0f9d58;
  --red: #be245b;
  --blue: #0b66d5;
  --shadow: 0 24px 55px rgba(82, 15, 110, 0.14);
  --font: Cochin, Georgia, 'Times New Roman', serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--dark);
  background: radial-gradient(circle at 70% 10%, #dfb4fb 0, #f7efff 32%, #fff 70%);
  background-size: 140% 140%;
  min-height: 100vh;
  font-size: 18px;
  overflow-x: hidden;
  animation: pageGlow 14s ease-in-out infinite alternate;
}
button, input, select, textarea { font-family: inherit; font-size: 16px; }
button { cursor: pointer; }
.hidden { display: none !important; }
.muted { color: var(--muted); }
.eyebrow { margin: 0 0 8px; color: var(--violet-2); text-transform: uppercase; letter-spacing: .06em; font-weight: 800; }
.mobile-menu {
  display: none;
  position: fixed;
  left: 16px;
  top: 16px;
  z-index: 90;
  width: 52px;
  height: 52px;
  border: 1px solid rgba(255,255,255,.35);
  border-radius: 18px;
  background: linear-gradient(135deg, var(--violet), var(--violet-3));
  color: #fff;
  font-size: 28px;
  font-weight: 900;
  box-shadow: 0 18px 40px rgba(109,17,149,.35);
}

.splash-screen, .login-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  position: fixed;
  inset: 0;
  z-index: 20;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 20%, rgba(74, 208, 139, .28), transparent 18%),
    radial-gradient(circle at 75% 30%, rgba(201, 141, 237, .78), transparent 34%),
    radial-gradient(circle at 50% 85%, rgba(33, 134, 255, .18), transparent 24%),
    linear-gradient(135deg, #fff 0%, #f4d8ff 100%);
  animation: splashGradient 10s ease-in-out infinite alternate;
}
.splash-screen::before,
.splash-screen::after,
.login-screen::before {
  content: "";
  position: absolute;
  inset: -20%;
  pointer-events: none;
}
.splash-screen::before {
  background-image:
    radial-gradient(circle, rgba(255,255,255,.95) 0 2px, transparent 3px),
    radial-gradient(circle, rgba(156,34,211,.35) 0 2px, transparent 3px),
    radial-gradient(circle, rgba(33,134,255,.24) 0 1px, transparent 2px);
  background-size: 88px 88px, 130px 130px, 64px 64px;
  animation: starDrift 18s linear infinite;
  opacity: .75;
}
.splash-screen::after {
  background: conic-gradient(from 120deg, transparent, rgba(156,34,211,.24), transparent, rgba(50,187,117,.22), transparent);
  filter: blur(30px);
  animation: slowSpin 22s linear infinite;
}
.login-screen::before {
  background-image: linear-gradient(115deg, transparent 0 44%, rgba(255,255,255,.35) 48%, transparent 52% 100%);
  animation: shineSweep 6s ease-in-out infinite;
  opacity: .75;
}
.splash-orb { position: absolute; border-radius: 50%; filter: blur(20px); opacity: .7; }
.orb-one { width: 360px; height: 360px; background: #d99bff; top: 18%; right: 15%; }
.orb-two { width: 240px; height: 240px; background: #fff; bottom: 18%; left: 18%; }
.splash-card, .login-card {
  position: relative;
  width: min(92vw, 620px);
  padding: 44px;
  border: 2px solid rgba(255,255,255,.8);
  border-radius: 38px;
  background: rgba(255,255,255,.62);
  box-shadow: var(--shadow);
  text-align: center;
  backdrop-filter: blur(14px);
  overflow: hidden;
}
.splash-card { animation: cardEntrance .9s ease both, floatCard 5.5s ease-in-out .9s infinite; }
.splash-card::before {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 42px;
  padding: 3px;
  background: conic-gradient(from var(--angle), rgba(108,17,149,.1), rgba(194,77,232,.65), rgba(17,157,88,.45), rgba(11,102,213,.42), rgba(108,17,149,.1));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: ringRotate 5s linear infinite;
  pointer-events: none;
}
.splash-logo { max-width: 260px; width: 70%; display: block; margin: 0 auto 14px; animation: logoPulse 3s ease-in-out infinite; filter: drop-shadow(0 14px 20px rgba(111, 14, 158, .18)); }
.login-logo { max-width: 290px; width: 76%; margin-bottom: 16px; }
.splash-card h1, .login-card h2 { margin: 0; font-size: clamp(46px, 7vw, 82px); color: var(--violet); line-height: 1; }
.splash-card h1 { background: linear-gradient(90deg, #5a0d82, #b72de0, #5a0d82); background-size: 220% 100%; -webkit-background-clip:text; background-clip:text; color: transparent; animation: textShimmer 3.8s ease-in-out infinite; }
.splash-kicker { color: var(--violet); letter-spacing: .35em; text-transform: uppercase; font-weight: 800; }
.login-options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 32px; text-align: left; }
.role-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 22px;
  color: var(--dark);
  min-height: 190px;
  box-shadow: 0 14px 28px rgba(90,17,115,.08);
}
.role-card span { color: var(--violet-2); font-weight: 900; display:block; margin-bottom: 18px; }
.role-card strong { display:block; font-size: 26px; margin-bottom: 12px; }
.role-card small { color: var(--muted); line-height: 1.5; }
.role-card:hover { border-color: var(--violet-2); transform: translateY(-2px); }
.primary, .ghost, .danger, .soft-btn, .logout-btn {
  border: 0;
  border-radius: 18px;
  padding: 14px 24px;
  font-weight: 800;
  transition: .2s ease;
}
.primary { background: linear-gradient(135deg, var(--violet), var(--violet-3)); color: #fff; box-shadow: 0 16px 32px rgba(139,34,194,.24); }
.ghost { background: #fff; color: var(--dark); border: 1px solid var(--line); }
.danger { background: #fff1f6; color: var(--red); border: 1px solid #ffd5e5; }
.soft-btn { background: var(--soft-2); color: var(--violet); }
.primary:hover, .ghost:hover, .danger:hover, .soft-btn:hover { transform: translateY(-1px); }
.large { padding: 16px 34px; margin-top: 20px; animation: buttonPulse 2.2s ease-in-out infinite; }
.small { padding: 10px 16px; border-radius: 14px; font-size: 15px; }
.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 300px;
  background: linear-gradient(180deg, #7d0eaf, #371147);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  z-index: 5;
  overflow-y: auto;
}
.sidebar-logo-card {
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 22px;
  padding: 22px;
  background: rgba(255,255,255,.10);
}
.sidebar-logo-card img { width: 100%; display: block; }
.sidebar nav { display: grid; gap: 8px; }
.sidebar a {
  color: #f8e8ff;
  text-decoration: none;
  padding: 14px 16px;
  border-radius: 16px;
  display: block;
  border: 1px solid transparent;
}
.sidebar a.active, .sidebar a:hover { background: rgba(255,255,255,.16); border-color: rgba(255,255,255,.3); }
.logout-btn { margin-top: auto; color: #fff; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.3); }
.app { margin-left: 300px; min-height: 100vh; padding: 34px; }
.topbar {
  background: rgba(255,255,255,.78);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 30px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
  box-shadow: var(--shadow);
  position: sticky;
  top: 18px;
  z-index: 3;
  backdrop-filter: blur(12px);
}
.topbar h2 { margin: 0; font-size: clamp(34px, 4vw, 58px); }
.top-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.section { margin-top: 30px; }
.card, .table-card, .hero-card, .stat-card, .sheet-panel, .modal-card {
  background: rgba(255,255,255,.82);
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--shadow);
}
.hero-card { padding: 32px; display: grid; grid-template-columns: 1.2fr .8fr; gap: 30px; align-items: center; }
.hero-card h3 { margin: 0 0 14px; font-size: clamp(32px, 5vw, 58px); line-height: 1.08; }
.hero-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.hero-stats div, .stat-card { background: #fff; border-radius: 24px; padding: 26px; }
.hero-stats strong, .stat-card strong { font-size: 42px; display:block; color: var(--dark); }
.stat-grid { display: grid; grid-template-columns: repeat(4, minmax(180px, 1fr)); gap: 20px; margin: 24px 0; }
.stat-card span { color: var(--muted); }
.section-title { display: flex; justify-content: space-between; align-items: center; gap: 18px; margin-bottom: 18px; }
.section-title h3 { margin: 0; font-size: 32px; }
.cards { display: grid; grid-template-columns: repeat(4, minmax(180px, 1fr)); gap: 18px; }
.card { padding: 26px; }
.card h4 { margin: 8px 0 10px; font-size: 24px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.sheet-buttons { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin: 20px 0; }
.sheet-btn {
  min-height: 112px;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--violet);
  font-size: 34px;
  font-weight: 900;
  box-shadow: 0 16px 30px rgba(112,18,150,.08);
}
.sheet-btn.active { background: var(--soft-2); border-color: var(--violet-2); }
.table-card, .sheet-panel { padding: 26px; margin-top: 20px; overflow: hidden; }
.table-scroll { overflow: auto; border: 1px solid #d8d8d8; border-radius: 6px; max-width: 100%; background: #fff; }
table { border-collapse: collapse; width: 100%; min-width: 960px; background: #fff; }
th, td { border: 1px solid #d6d6d6; padding: 12px 14px; text-align: left; vertical-align: middle; }
th { background: #f1f1f1; color: #51355c; font-weight: 900; position: relative; }
td input, td select, td textarea, .cell-input, .form-grid input, .form-grid select, .form-grid textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: #fff; color: var(--dark);
}
td textarea { min-height: 80px; resize: vertical; }
tr:nth-child(even) td { background: #fcf7ff; }
.sheet-toolbar { display:flex; justify-content:space-between; align-items:center; gap:14px; margin-bottom: 16px; }
.action-row { display:flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.filter-btn { padding: 8px 10px; border-radius: 10px; background:#fff; border:1px solid #bbb; margin-left:8px; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(220px, 1fr)); gap: 16px; }
.form-grid label { font-weight: 800; color: var(--dark); display: grid; gap: 8px; }
.vertical-entry { min-width: 720px; }
.vertical-entry td:first-child { width: 80px; text-align: center; color: var(--muted); font-weight: 800; }
.vertical-entry td:nth-child(2) { width: 260px; font-weight: 900; }
.message-group { margin-top: 26px; }
.message-group h4 { font-size: 28px; margin: 0 0 12px; }
.send-big { width: 100%; margin-top: 12px; font-size: 20px; padding: 18px; }
.badge { display:inline-block; border-radius: 999px; padding: 8px 12px; background: var(--soft-2); color: var(--violet); font-weight: 800; }
.badge.green { color: var(--green); background:#eaf8f0; }
.badge.red { color: var(--red); background:#fff0f5; }
.badge.blue { color: var(--blue); background:#eef5ff; }
.modal { position: fixed; inset: 0; z-index: 50; background: rgba(24,10,34,.45); display: grid; place-items: center; padding: 20px; }
.modal-card { width: min(92vw, 760px); padding: 28px; position: relative; max-height: 90vh; overflow:auto; }
.modal-close { position:absolute; top:14px; right:14px; width:36px; height:36px; border:0; border-radius:50%; background:var(--soft-2); color:var(--violet); font-weight:900; }
.package-list { display:grid; gap:10px; margin-top: 12px; }
.package-item { display:flex; justify-content:space-between; align-items:center; gap:12px; padding:12px; background:#fbf7ff; border:1px solid var(--line); border-radius:14px; }
.toast { position: fixed; right: 22px; bottom: 22px; z-index: 70; background: #2b123b; color: white; padding: 16px 20px; border-radius: 16px; box-shadow: var(--shadow); }
.rich-editor { min-height: 170px; border:1px solid var(--line); border-radius:18px; padding:16px; background:#fff; }
.toolbar-mini { display:flex; gap:8px; margin-bottom:10px; }
.permission-list li { margin: 8px 0; }
.warning { background:#fff8e9; border:1px solid #f5d99b; color:#754f00; padding:16px; border-radius:16px; }
.success { background:#eefaf2; border:1px solid #c6eed6; color:#086c35; padding:16px; border-radius:16px; }
.audit-line { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px; }

@property --angle { syntax: "<angle>"; initial-value: 0deg; inherits: false; }
@keyframes pageGlow { from { background-position: 0% 0%; } to { background-position: 100% 100%; } }
@keyframes splashGradient { from { filter: saturate(1); } to { filter: saturate(1.18); } }
@keyframes starDrift { from { transform: translate3d(0,0,0) rotate(0deg); } to { transform: translate3d(50px,60px,0) rotate(6deg); } }
@keyframes slowSpin { to { transform: rotate(360deg); } }
@keyframes shineSweep { 0%, 40% { transform: translateX(-40%); } 70%, 100% { transform: translateX(40%); } }
@keyframes cardEntrance { from { opacity: 0; transform: scale(.9) translateY(24px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@keyframes floatCard { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes ringRotate { to { --angle: 360deg; } }
@keyframes logoPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.045); } }
@keyframes textShimmer { 0%, 100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
@keyframes buttonPulse { 0%, 100% { box-shadow: 0 16px 32px rgba(139,34,194,.24); } 50% { box-shadow: 0 20px 48px rgba(139,34,194,.42); } }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; }
}

@media (max-width: 1050px) {
  body { font-size: 16px; }
  .mobile-menu:not(.hidden) { display: grid; place-items: center; }
  .sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(86vw, 330px);
    min-height: 100vh;
    transform: translateX(-105%);
    transition: transform .28s ease;
    z-index: 80;
  }
  .sidebar.mobile-open { transform: translateX(0); }
  body.sidebar-open::after {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(22, 6, 31, .38);
    z-index: 75;
  }
  .app { margin-left: 0; padding: 82px 14px 22px; }
  .topbar, .section-title, .hero-card { grid-template-columns: 1fr; display: grid; }
  .topbar { position: relative; top: 0; padding: 22px; border-radius: 24px; }
  .top-actions { width: 100%; }
  .top-actions button, .action-row button, .primary, .ghost, .danger, .soft-btn { width: 100%; }
  .login-options, .cards, .grid-2, .grid-3, .stat-grid, .sheet-buttons, .hero-stats { grid-template-columns: 1fr; }
  .sheet-btn { min-height: 86px; font-size: 28px; }
  .splash-card, .login-card { padding: 26px 20px; border-radius: 28px; }
  .splash-logo, .login-logo { width: 82%; max-width: 260px; }
  .splash-card h1, .login-card h2 { font-size: clamp(40px, 14vw, 66px); }
  .splash-kicker { letter-spacing: .18em; font-size: 14px; }
  .table-card, .sheet-panel, .card { padding: 18px; border-radius: 22px; }
  .table-scroll { border-radius: 10px; }
  th, td { padding: 10px 12px; }
  .form-grid { grid-template-columns: 1fr; }
  .modal-card { width: 96vw; padding: 22px; }
}
@media (max-width: 620px) {
  .app { padding-left: 10px; padding-right: 10px; }
  .hero-card h3 { font-size: 34px; }
  .hero-stats strong, .stat-card strong { font-size: 34px; }
  .section-title h3 { font-size: 26px; }
  table { min-width: 820px; font-size: 15px; }
  .vertical-entry { min-width: 680px; }
}
@media print {
  .sidebar, .topbar, .action-row, .splash-screen, .login-screen, .modal { display:none !important; }
  .app { margin: 0; padding: 0; }
  body { background:#fff; }
}

/* Premium animation and clean arrangement fixes */
.splash-screen {
  isolation: isolate;
  background:
    radial-gradient(circle at 50% 45%, rgba(255,255,255,.95) 0 0, rgba(255,255,255,.52) 12%, transparent 33%),
    radial-gradient(circle at 16% 24%, rgba(24,152,255,.32), transparent 20%),
    radial-gradient(circle at 88% 18%, rgba(194,77,232,.78), transparent 27%),
    radial-gradient(circle at 40% 100%, rgba(63,230,126,.26), transparent 28%),
    linear-gradient(135deg, #fff 0%, #f4d9ff 44%, #d99cff 100%);
  animation: premiumBgMove 7s ease-in-out infinite alternate !important;
}
.premium-particle-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.premium-particle-layer span {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--s);
  height: var(--s);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,255,255,.95), rgba(177,35,223,.35), transparent 72%);
  box-shadow: 0 0 28px rgba(167,40,220,.42);
  animation: particleFloat var(--d) ease-in-out var(--delay) infinite alternate !important;
}
.splash-card {
  z-index: 2;
  transform-style: preserve-3d;
  border: 1px solid rgba(255,255,255,.9);
  background: linear-gradient(145deg, rgba(255,255,255,.88), rgba(247,229,255,.72));
  box-shadow: 0 38px 100px rgba(79,8,112,.28), inset 0 1px 0 rgba(255,255,255,.88);
  animation: cinematicEntry 1s cubic-bezier(.18,.86,.26,1.1) both, floatCardStrong 4.2s ease-in-out 1s infinite !important;
}
.splash-card::after {
  content: "";
  position: absolute;
  inset: -60% -30%;
  background: linear-gradient(110deg, transparent 38%, rgba(255,255,255,.75) 48%, transparent 58%);
  transform: translateX(-70%) rotate(8deg);
  animation: premiumSweep 3.8s ease-in-out infinite !important;
  pointer-events: none;
}
.splash-logo {
  animation: logoPremium 2.4s ease-in-out infinite !important;
}
.splash-logo::after { content: none; }
.splash-card h1 {
  text-shadow: 0 12px 40px rgba(99,8,132,.18);
  animation: textShimmer 2.4s ease-in-out infinite !important;
}
.splash-kicker,
.splash-text {
  animation: fadeRise .9s ease both !important;
}
.splash-text { animation-delay: .24s !important; }
#enterPortalBtn {
  position: relative;
  overflow: hidden;
  border-radius: 999px;
  animation: buttonGlowHeavy 1.7s ease-in-out infinite !important;
}
#enterPortalBtn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.52), transparent);
  transform: translateX(-110%);
  animation: buttonShine 2s ease-in-out infinite !important;
}
.splash-exit {
  animation: splashExit .5s ease forwards !important;
}
.login-enter .login-card {
  animation: cinematicEntry .72s cubic-bezier(.18,.86,.26,1.1) both !important;
}

/* Clean page arrangement */
.sidebar {
  width: 292px;
  padding: 28px 22px;
}
.sidebar-logo-card {
  padding: 18px;
  margin-bottom: 22px;
}
.sidebar a {
  padding: 14px 16px;
  margin: 6px 0;
  border-radius: 14px;
}
.app {
  margin-left: 292px;
  width: calc(100% - 292px);
  padding: 28px;
}
.topbar {
  max-width: 1320px;
  margin: 0 auto;
  padding: 24px 26px;
  border-radius: 26px;
}
.section {
  max-width: 1320px;
  margin: 26px auto 0;
}
.hero-card {
  grid-template-columns: minmax(0,1.05fr) minmax(340px,.75fr);
}
.stat-grid,
.cards {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.sheet-buttons {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 16px;
}
.sheet-btn {
  min-height: 92px;
  font-size: clamp(26px, 3vw, 34px);
  border-radius: 22px;
}
.table-card, .sheet-panel, .card, .hero-card {
  border-radius: 24px;
}
.table-card, .sheet-panel {
  padding: 20px;
}
.sheet-toolbar {
  position: sticky;
  left: 0;
  z-index: 2;
  background: rgba(255,255,255,.9);
  padding-bottom: 12px;
  flex-wrap: wrap;
}
.table-scroll {
  border-radius: 12px;
  border-color: #d3d3d3;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.02);
}
table {
  font-size: 16px;
}
th {
  white-space: nowrap;
}
td {
  min-height: 54px;
}
.form-grid {
  align-items: start;
}

@keyframes premiumBgMove {
  0% { background-position: 0% 20%, 0 0, 100% 0, 50% 100%, 0% 50%; filter: saturate(1); }
  100% { background-position: 100% 80%, 8% 7%, 92% 12%, 42% 94%, 100% 50%; filter: saturate(1.2); }
}
@keyframes particleFloat {
  from { transform: translate3d(-18px, 22px, 0) scale(.65); opacity: .18; }
  to { transform: translate3d(24px, -34px, 0) scale(1.18); opacity: .85; }
}
@keyframes cinematicEntry {
  from { opacity: 0; transform: translateY(34px) scale(.88) rotateX(8deg); filter: blur(10px); }
  to { opacity: 1; transform: translateY(0) scale(1) rotateX(0); filter: blur(0); }
}
@keyframes floatCardStrong {
  0%,100% { transform: translateY(0) rotate(.0deg); }
  50% { transform: translateY(-16px) rotate(.4deg); }
}
@keyframes premiumSweep {
  0%, 36% { transform: translateX(-75%) rotate(8deg); opacity: 0; }
  48% { opacity: .9; }
  72%, 100% { transform: translateX(75%) rotate(8deg); opacity: 0; }
}
@keyframes logoPremium {
  0%,100% { transform: translateY(0) scale(1); filter: drop-shadow(0 14px 20px rgba(111, 14, 158, .18)); }
  50% { transform: translateY(-8px) scale(1.06); filter: drop-shadow(0 26px 34px rgba(111, 14, 158, .32)); }
}
@keyframes fadeRise {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes buttonGlowHeavy {
  0%,100% { box-shadow: 0 16px 34px rgba(139,34,194,.28), 0 0 0 rgba(178,49,226,0); }
  50% { box-shadow: 0 22px 56px rgba(139,34,194,.48), 0 0 0 9px rgba(178,49,226,.12); }
}
@keyframes buttonShine {
  0%, 35% { transform: translateX(-110%); }
  65%, 100% { transform: translateX(110%); }
}
@keyframes splashExit {
  to { opacity: 0; transform: scale(1.04); filter: blur(8px); }
}

@media (prefers-reduced-motion: reduce) {
  .splash-screen, .splash-card, .splash-card::after, .splash-logo, .splash-card h1, #enterPortalBtn, #enterPortalBtn::before, .premium-particle-layer span {
    animation-duration: inherit !important;
    animation-iteration-count: infinite !important;
  }
}
@media (max-width: 1050px) {
  .app {
    width: 100%;
    margin-left: 0;
    padding: 82px 14px 24px;
  }
  .topbar, .section { max-width: 100%; }
  .topbar {
    padding: 20px;
    gap: 16px;
  }
  .sidebar { width: min(86vw, 320px); }
  .splash-card, .login-card {
    width: min(92vw, 520px);
  }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .app { padding: 78px 10px 18px; }
  .topbar { border-radius: 22px; }
  .topbar h2 { font-size: 34px; }
  .section { margin-top: 18px; }
  .hero-card { grid-template-columns: 1fr; padding: 20px; }
  .hero-stats, .grid-2, .grid-3, .stat-grid, .cards, .sheet-buttons { grid-template-columns: 1fr; }
  .sheet-btn { min-height: 78px; font-size: 27px; }
  .table-card, .sheet-panel, .card { padding: 14px; border-radius: 20px; }
  .action-row { display: grid; grid-template-columns: 1fr; width: 100%; }
  .sheet-toolbar { display: grid; grid-template-columns: 1fr; }
  .splash-card { padding: 28px 20px; }
  .splash-logo { max-width: 220px; width: 74%; }
}

/* Final neat arrangement update - keeps opening animation, cleans login + inside pages */
.login-screen {
  position: fixed;
  inset: 0;
  overflow-y: auto;
  padding: 36px 18px;
  align-items: start;
  place-items: start center;
}
.login-card {
  width: min(92vw, 1180px) !important;
  margin: 54px auto 42px;
  padding: 54px 58px !important;
  border-radius: 30px !important;
  background: rgba(255,255,255,.88) !important;
  box-shadow: 0 34px 90px rgba(94, 15, 127, .18) !important;
  border-top: 7px solid transparent !important;
  border-image: linear-gradient(90deg, var(--violet), var(--violet-3)) 1 !important;
}
.login-logo {
  width: min(360px, 52vw) !important;
  max-width: 360px !important;
  margin: 0 auto 22px !important;
  display: block;
}
.login-card .eyebrow {
  text-align: center;
  color: var(--violet);
  font-size: 15px;
  letter-spacing: .08em;
  margin-bottom: 18px;
}
.login-card h2 {
  font-size: clamp(34px, 4vw, 50px) !important;
  line-height: 1.05 !important;
  color: var(--dark) !important;
  margin-bottom: 16px !important;
}
.login-card .muted {
  font-size: 20px;
  margin: 0 auto;
  max-width: 700px;
}
.login-options {
  margin-top: 38px !important;
  gap: 20px !important;
}
.role-card {
  min-height: 182px !important;
  border-radius: 22px !important;
  padding: 28px 28px !important;
  background: linear-gradient(180deg, #fff, #fffbff) !important;
  box-shadow: 0 18px 36px rgba(90, 17, 115, .08) !important;
}
.role-card span {
  width: 50px;
  height: 50px;
  display: grid !important;
  place-items: center;
  border-radius: 16px;
  background: var(--soft-2);
  margin-bottom: 20px !important;
}
.role-card strong {
  font-size: clamp(24px, 2vw, 30px) !important;
  line-height: 1.08;
}
.role-card small {
  font-size: 16px;
  line-height: 1.55;
}

body:has(.app:not(.hidden)) {
  background:
    linear-gradient(90deg, rgba(255,255,255,.86), rgba(247,233,255,.65)),
    radial-gradient(circle at 86% 18%, rgba(203,126,240,.52), transparent 30%),
    radial-gradient(circle at 20% 80%, rgba(67,201,136,.11), transparent 25%),
    #fbf8ff;
}
.sidebar {
  width: 292px !important;
  background: linear-gradient(180deg, #8d19c5 0%, #64108d 45%, #331144 100%) !important;
  padding: 24px 20px !important;
  box-shadow: 20px 0 50px rgba(62, 9, 84, .18);
}
.sidebar-logo-card {
  border-radius: 24px !important;
  padding: 20px !important;
  background: rgba(255,255,255,.13) !important;
  border: 1px solid rgba(255,255,255,.22) !important;
}
.sidebar a {
  font-size: 18px;
  padding: 15px 16px !important;
  border-radius: 15px !important;
  color: rgba(255,255,255,.92) !important;
}
.sidebar a.active,
.sidebar a:hover {
  background: rgba(255,255,255,.18) !important;
  box-shadow: inset 4px 0 0 #fff;
}
.logout-btn {
  width: 100%;
  border-radius: 16px !important;
}
.app {
  margin-left: 292px !important;
  width: calc(100% - 292px) !important;
  padding: 32px 34px 54px !important;
}
.topbar {
  max-width: 1180px !important;
  margin: 0 auto 28px !important;
  padding: 28px 32px !important;
  border-radius: 28px !important;
  background: rgba(255,255,255,.9) !important;
  border: 1px solid rgba(219,203,232,.95) !important;
  position: relative !important;
  top: auto !important;
}
.topbar h2 {
  font-size: clamp(36px, 4vw, 56px) !important;
  line-height: 1.02;
}
.section {
  max-width: 1180px !important;
  margin: 0 auto 28px !important;
}
.section > .hero-card:first-child,
.section > .table-card:first-child,
.section > .sheet-area:first-child,
.section > .grid-2:first-child,
.section > .grid-3:first-child,
.section > .cards:first-child {
  margin-top: 0 !important;
}
.hero-card,
.table-card,
.sheet-panel,
.card,
.stat-card {
  background: rgba(255,255,255,.9) !important;
  border: 1px solid rgba(219,203,232,.95) !important;
  border-radius: 28px !important;
  box-shadow: 0 24px 55px rgba(87, 18, 112, .10) !important;
}
.hero-card {
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .8fr) !important;
  padding: 36px !important;
  margin-bottom: 24px;
}
.hero-card h3 {
  font-size: clamp(34px, 4.2vw, 54px) !important;
}
.hero-stats div,
.stat-card {
  border: 1px solid rgba(219,203,232,.55);
  background: linear-gradient(180deg, #fff, #fdf8ff) !important;
}
.stat-grid {
  gap: 18px !important;
  margin: 22px 0 28px !important;
}
.sheet-area {
  margin-top: 22px;
}
.sheet-buttons {
  grid-template-columns: repeat(4, minmax(180px, 1fr)) !important;
  gap: 18px !important;
  margin: 18px 0 24px !important;
}
.sheet-btn {
  min-height: 112px !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, #fff, #fffbff) !important;
  border: 1px solid var(--line) !important;
  box-shadow: 0 22px 38px rgba(99, 16, 134, .08) !important;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.sheet-btn:hover,
.sheet-btn.active {
  transform: translateY(-2px);
  background: #f6e9ff !important;
  border-color: var(--violet-2) !important;
}
.table-card,
.sheet-panel {
  padding: 26px !important;
}
.table-scroll {
  border-radius: 14px !important;
  border: 1px solid #d2d2d2 !important;
  background: #fff;
}
table {
  font-size: 16px !important;
  min-width: 980px;
}
th {
  background: #f3f3f3 !important;
  color: #3d234e !important;
}
th, td {
  padding: 13px 15px !important;
  border-color: #d7d7d7 !important;
}
tr:nth-child(even) td {
  background: #fcf7ff !important;
}
.primary,
.ghost,
.danger,
.soft-btn {
  border-radius: 16px !important;
}
.top-actions,
.action-row {
  gap: 12px !important;
}
.modal-card {
  background: rgba(255,255,255,.96) !important;
}

@media (max-width: 1050px) {
  .login-card {
    width: min(94vw, 640px) !important;
    padding: 34px 22px !important;
    margin: 30px auto !important;
  }
  .login-options {
    grid-template-columns: 1fr !important;
  }
  .role-card {
    min-height: auto !important;
  }
  .app {
    margin-left: 0 !important;
    width: 100% !important;
    padding: 82px 14px 28px !important;
  }
  .topbar,
  .section {
    max-width: 100% !important;
  }
  .hero-card {
    grid-template-columns: 1fr !important;
  }
  .sheet-buttons {
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }
}
@media (max-width: 680px) {
  .login-screen { padding: 18px 10px; }
  .login-logo { width: min(280px, 82vw) !important; }
  .login-card h2 { font-size: 34px !important; }
  .login-card .muted { font-size: 17px; }
  .topbar { padding: 20px !important; }
  .topbar h2 { font-size: 34px !important; }
  .hero-card,
  .table-card,
  .sheet-panel,
  .card { padding: 18px !important; border-radius: 22px !important; }
  .stat-grid,
  .cards,
  .grid-2,
  .grid-3,
  .hero-stats,
  .sheet-buttons { grid-template-columns: 1fr !important; }
  .sheet-btn { min-height: 84px !important; font-size: 28px !important; }
  .section-title { display: grid !important; grid-template-columns: 1fr; align-items: start; }
  .action-row, .top-actions { display: grid !important; grid-template-columns: 1fr; width: 100%; }
  .action-row button, .top-actions button { width: 100%; }
}

/* Minimal premium animated interior refresh */
:root {
  --radius-xl: 34px;
  --radius-lg: 28px;
  --radius-md: 22px;
  --interior-shadow: 0 22px 60px rgba(91, 12, 126, .12);
}
body {
  font-size: 15.5px !important;
  line-height: 1.45;
}
body:has(.app:not(.hidden)) {
  background:
    radial-gradient(circle at 14% 14%, rgba(27, 175, 117, .16), transparent 24%),
    radial-gradient(circle at 84% 10%, rgba(191, 77, 232, .34), transparent 30%),
    radial-gradient(circle at 70% 86%, rgba(119, 35, 209, .22), transparent 30%),
    linear-gradient(135deg, #fff 0%, #fbf5ff 44%, #efd8ff 100%) !important;
  animation: premiumInteriorBg 8s ease-in-out infinite alternate !important;
}
body:has(.app:not(.hidden))::before,
body:has(.app:not(.hidden))::after {
  content: "";
  position: fixed;
  inset: auto;
  z-index: 0;
  pointer-events: none;
  border-radius: 999px;
  filter: blur(22px);
  opacity: .65;
}
body:has(.app:not(.hidden))::before {
  width: 340px;
  height: 340px;
  left: 310px;
  top: 70px;
  background: radial-gradient(circle, rgba(194, 77, 232, .45), rgba(194, 77, 232, .06), transparent 70%);
  animation: interiorBlobOne 7s ease-in-out infinite alternate !important;
}
body:has(.app:not(.hidden))::after {
  width: 290px;
  height: 290px;
  right: 5vw;
  bottom: 7vh;
  background: radial-gradient(circle, rgba(30, 198, 130, .24), rgba(63, 141, 255, .12), transparent 72%);
  animation: interiorBlobTwo 6.5s ease-in-out infinite alternate !important;
}
.app, .sidebar, .mobile-menu, .modal, .toast { position: relative; z-index: 1; }
.app::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.75) 0 1px, transparent 2px),
    radial-gradient(circle, rgba(154,34,211,.18) 0 1px, transparent 2px),
    linear-gradient(115deg, transparent 0 44%, rgba(255,255,255,.25) 48%, transparent 53% 100%);
  background-size: 72px 72px, 116px 116px, 160% 160%;
  animation: interiorParticleDrift 18s linear infinite, interiorSweep 5.5s ease-in-out infinite !important;
  opacity: .55;
}

/* Minimal typography */
.eyebrow { font-size: 13px !important; letter-spacing: .08em !important; }
.muted, p, li, small { font-size: 15px !important; }
.topbar h2 { font-size: clamp(26px, 2.8vw, 38px) !important; line-height: 1.05 !important; }
.hero-card h3 { font-size: clamp(24px, 3vw, 34px) !important; line-height: 1.15 !important; }
.section-title h3 { font-size: 24px !important; }
.card h4 { font-size: 19px !important; }
.hero-stats strong, .stat-card strong { font-size: 30px !important; }
.sheet-btn { font-size: clamp(21px, 2.2vw, 27px) !important; min-height: 78px !important; }
.message-group h4 { font-size: 21px !important; }
.role-card strong { font-size: 23px !important; }
.login-card h2 { font-size: clamp(30px, 3.2vw, 42px) !important; }
.splash-card h1 { font-size: clamp(44px, 6vw, 74px) !important; }

/* Curved premium components everywhere */
.topbar,
.hero-card,
.card,
.table-card,
.sheet-panel,
.stat-card,
.modal-card,
.login-card,
.splash-card,
.sidebar-logo-card,
.role-card,
.package-item,
.rich-editor,
.warning,
.success,
.table-scroll,
.hero-stats div {
  border-radius: var(--radius-xl) !important;
}
.primary,
.ghost,
.danger,
.soft-btn,
.logout-btn,
.filter-btn,
.modal-close,
.mobile-menu,
td input,
td select,
td textarea,
.cell-input,
.form-grid input,
.form-grid select,
.form-grid textarea,
input,
select,
textarea {
  border-radius: var(--radius-md) !important;
}
.badge { border-radius: 999px !important; }

/* Heavy animated page cards */
.topbar,
.hero-card,
.card,
.table-card,
.sheet-panel,
.stat-card,
.role-card {
  position: relative;
  overflow: hidden;
  box-shadow: var(--interior-shadow) !important;
  animation: panelRise .55s cubic-bezier(.18,.86,.26,1.08) both, panelFloat 5.8s ease-in-out infinite !important;
  transform-origin: center;
}
.topbar::before,
.hero-card::before,
.card::before,
.table-card::before,
.sheet-panel::before,
.stat-card::before,
.role-card::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  padding: 2px;
  background: conic-gradient(from var(--angle), rgba(108,17,149,.12), rgba(194,77,232,.38), rgba(36,199,126,.22), rgba(52,143,255,.22), rgba(108,17,149,.12));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  animation: ringRotate 7s linear infinite !important;
  opacity: .72;
}
.topbar::after,
.hero-card::after,
.card::after,
.table-card::after,
.sheet-panel::after,
.stat-card::after,
.role-card::after {
  content: "";
  position: absolute;
  inset: -70% -30%;
  background: linear-gradient(110deg, transparent 40%, rgba(255,255,255,.42) 50%, transparent 60%);
  transform: translateX(-78%) rotate(7deg);
  animation: panelShine 5s ease-in-out infinite !important;
  pointer-events: none;
}
.card:nth-child(2n), .stat-card:nth-child(2n), .sheet-btn:nth-child(2n) { animation-delay: .08s !important; }
.card:nth-child(3n), .stat-card:nth-child(3n), .sheet-btn:nth-child(3n) { animation-delay: .16s !important; }

.sidebar {
  border-top-right-radius: 34px !important;
  border-bottom-right-radius: 34px !important;
  background: linear-gradient(180deg, #901aca 0%, #671094 44%, #2e0d42 100%) !important;
  background-size: 120% 120% !important;
  animation: sidebarGlow 6s ease-in-out infinite alternate !important;
}
.sidebar a {
  border-radius: 22px !important;
  transition: transform .22s ease, background .22s ease, box-shadow .22s ease !important;
}
.sidebar a:hover, .sidebar a.active {
  transform: translateX(5px);
  box-shadow: inset 4px 0 0 #fff, 0 16px 34px rgba(255,255,255,.08) !important;
}
.sidebar-logo-card img { animation: logoPremium 3.4s ease-in-out infinite !important; }

.sheet-buttons { gap: 14px !important; }
.sheet-btn {
  position: relative;
  overflow: hidden;
  border-radius: 32px !important;
  animation: panelRise .5s cubic-bezier(.18,.86,.26,1.08) both, sheetBreath 3.6s ease-in-out infinite !important;
}
.sheet-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,.55), transparent);
  transform: translateX(-110%);
  animation: buttonShine 3.4s ease-in-out infinite !important;
}
.primary, .ghost, .danger, .soft-btn, .logout-btn {
  position: relative;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease !important;
}
.primary { animation: buttonGlowHeavy 2.4s ease-in-out infinite !important; }
.primary::after,
.ghost::after,
.danger::after,
.soft-btn::after,
.logout-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.38), transparent);
  transform: translateX(-110%);
  animation: buttonShine 3.6s ease-in-out infinite !important;
  pointer-events: none;
}
.primary:hover, .ghost:hover, .danger:hover, .soft-btn:hover, .logout-btn:hover, .sheet-btn:hover {
  transform: translateY(-2px) scale(1.01) !important;
}

/* Compact neat tables */
.table-card, .sheet-panel { padding: 18px !important; }
.table-scroll {
  border-radius: 24px !important;
  overflow: auto;
}
table { font-size: 14px !important; }
th, td { padding: 9px 11px !important; }
th { font-size: 13px !important; letter-spacing: .02em; }
td input, td select, td textarea, .cell-input { padding: 9px 10px !important; font-size: 14px !important; }
tr td { transition: background .2s ease, transform .2s ease; }
tr:hover td { background: #f8ecff !important; }

/* Login kept neat but animated */
.login-card { animation: panelRise .65s cubic-bezier(.18,.86,.26,1.08) both, panelFloat 6s ease-in-out infinite !important; }
.login-logo { animation: logoPremium 3.2s ease-in-out infinite !important; }
.role-card:hover { transform: translateY(-4px) scale(1.015) !important; }

@keyframes premiumInteriorBg {
  from { background-position: 0% 20%, 100% 10%, 50% 100%, 0% 50%; filter: saturate(1); }
  to { background-position: 10% 10%, 92% 18%, 60% 90%, 100% 50%; filter: saturate(1.16); }
}
@keyframes interiorBlobOne {
  from { transform: translate3d(-20px, 0, 0) scale(.95); opacity: .42; }
  to { transform: translate3d(80px, 80px, 0) scale(1.18); opacity: .78; }
}
@keyframes interiorBlobTwo {
  from { transform: translate3d(30px, 20px, 0) scale(.9); opacity: .35; }
  to { transform: translate3d(-70px, -50px, 0) scale(1.22); opacity: .72; }
}
@keyframes interiorParticleDrift {
  from { background-position: 0 0, 0 0, -30% 0; }
  to { background-position: 80px 100px, -90px 70px, 130% 0; }
}
@keyframes interiorSweep {
  0%, 38% { opacity: .40; }
  60% { opacity: .75; }
  100% { opacity: .50; }
}
@keyframes panelRise {
  from { opacity: 0; transform: translateY(18px) scale(.985); filter: blur(5px); }
  to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes panelFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -3px; }
}
@keyframes panelShine {
  0%, 45% { transform: translateX(-84%) rotate(7deg); opacity: 0; }
  56% { opacity: .75; }
  82%, 100% { transform: translateX(84%) rotate(7deg); opacity: 0; }
}
@keyframes sidebarGlow {
  from { background-position: 0% 0%; box-shadow: 18px 0 45px rgba(73,8,105,.18); }
  to { background-position: 100% 100%; box-shadow: 22px 0 60px rgba(145,29,199,.30); }
}
@keyframes sheetBreath {
  0%, 100% { box-shadow: 0 14px 34px rgba(99,16,134,.08), 0 0 0 rgba(184,54,234,0); }
  50% { box-shadow: 0 20px 48px rgba(99,16,134,.16), 0 0 0 6px rgba(184,54,234,.06); }
}

@media (max-width: 1050px) {
  body:has(.app:not(.hidden))::before { left: 8vw; top: 8vh; }
  .topbar, .section { max-width: 100% !important; }
  .topbar h2 { font-size: 28px !important; }
  .hero-card h3 { font-size: 26px !important; }
  .sheet-btn { min-height: 72px !important; font-size: 22px !important; }
  .sidebar { border-radius: 0 34px 34px 0 !important; }
}
@media (max-width: 680px) {
  body { font-size: 14.5px !important; }
  .muted, p, li, small { font-size: 14px !important; }
  .app { padding: 76px 10px 22px !important; }
  .topbar, .hero-card, .card, .table-card, .sheet-panel, .stat-card { border-radius: 26px !important; }
  .topbar h2 { font-size: 25px !important; }
  .hero-card h3 { font-size: 23px !important; }
  .hero-stats strong, .stat-card strong { font-size: 26px !important; }
  table { font-size: 13px !important; }
  th, td { padding: 8px 10px !important; }
}

/* =========================================================
   FINAL ACCURATE CLEAN + HEAVY ANIMATION LAYOUT OVERRIDE
   ========================================================= */
:root {
  --final-sidebar: 280px;
  --final-radius: 30px;
  --final-radius-sm: 18px;
  --final-border: rgba(121, 48, 158, .18);
  --final-purple: #7a16b6;
  --final-purple-2: #b936e6;
  --final-text: #241135;
  --final-muted: #755882;
}
html, body { min-height: 100%; }
body {
  position: relative !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
  color: var(--final-text) !important;
  overflow-x: hidden !important;
  background:
    radial-gradient(circle at 18% 20%, rgba(40, 210, 142, .18), transparent 22%),
    radial-gradient(circle at 82% 18%, rgba(187, 69, 232, .32), transparent 28%),
    linear-gradient(135deg, #ffffff 0%, #fbf6ff 46%, #efd7ff 100%) !important;
  background-size: 160% 160% !important;
  animation: finalAuroraBg 12s ease-in-out infinite alternate !important;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.95) 0 1px, transparent 2px),
    radial-gradient(circle, rgba(151,25,204,.25) 0 1px, transparent 2px),
    linear-gradient(115deg, transparent 0 42%, rgba(255,255,255,.42) 49%, transparent 57% 100%);
  background-size: 76px 76px, 132px 132px, 180% 180%;
  opacity: .65;
  animation: finalDotsMove 18s linear infinite, finalLightSweep 7s ease-in-out infinite !important;
}
body::after {
  content: "";
  position: fixed;
  width: 520px;
  height: 520px;
  right: -180px;
  top: 14vh;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(194,77,232,.26), transparent 66%);
  filter: blur(20px);
  z-index: 0;
  pointer-events: none;
  animation: finalOrbFloat 9s ease-in-out infinite alternate !important;
}
body > * { position: relative; z-index: 1; }

/* Splash/login keep premium but clean */
.splash-screen,
.login-screen {
  z-index: 50 !important;
}
.splash-card,
.login-card {
  border-radius: 36px !important;
  max-width: 880px !important;
  width: min(92vw, 880px) !important;
  padding: clamp(28px, 4vw, 46px) !important;
  background: rgba(255,255,255,.82) !important;
  border: 1px solid rgba(122,22,182,.20) !important;
}
.splash-logo,
.login-logo { max-width: 300px !important; width: 60% !important; }
.splash-card h1 { font-size: clamp(44px, 7vw, 78px) !important; }
.login-card h2 { font-size: clamp(30px, 4vw, 46px) !important; margin: 8px 0 !important; }
.login-options { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 18px !important; }
.role-card { min-height: 150px !important; border-radius: 24px !important; padding: 20px !important; }
.role-card strong { font-size: 22px !important; }
.role-card small { font-size: 14px !important; }

/* Fixed accurate app layout */
.sidebar {
  position: fixed !important;
  inset: 0 auto 0 0 !important;
  width: var(--final-sidebar) !important;
  height: 100vh !important;
  padding: 24px 18px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border-radius: 0 34px 34px 0 !important;
  background: linear-gradient(180deg, #9918d5 0%, #6e1298 42%, #2d0e40 100%) !important;
  box-shadow: 18px 0 45px rgba(89, 15, 126, .20) !important;
  animation: finalSidebarGlow 6s ease-in-out infinite alternate !important;
}
.sidebar-logo-card {
  margin: 0 0 18px !important;
  padding: 14px !important;
  border-radius: 28px !important;
  background: rgba(255,255,255,.13) !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.20) !important;
}
.sidebar-logo-card img { max-width: 100% !important; animation: finalLogoFloat 4s ease-in-out infinite !important; }
.sidebar nav { display: grid !important; gap: 6px !important; }
.sidebar a {
  min-height: 46px !important;
  display: flex !important;
  align-items: center !important;
  border-radius: 19px !important;
  padding: 11px 15px !important;
  color: rgba(255,255,255,.92) !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease !important;
}
.sidebar a.active,
.sidebar a:hover {
  background: rgba(255,255,255,.18) !important;
  border-color: rgba(255,255,255,.30) !important;
  box-shadow: inset 4px 0 0 #fff, 0 12px 24px rgba(33, 8, 46, .18) !important;
  transform: translateX(3px) !important;
}
.logout-btn {
  width: 100% !important;
  min-height: 46px !important;
  margin-top: 18px !important;
  border-radius: 19px !important;
  background: rgba(255,255,255,.13) !important;
  border: 1px solid rgba(255,255,255,.25) !important;
  color: #fff !important;
}
.app {
  margin-left: var(--final-sidebar) !important;
  width: calc(100% - var(--final-sidebar)) !important;
  min-height: 100vh !important;
  padding: 28px 34px 42px !important;
  max-width: none !important;
  overflow: visible !important;
}
.app::before { display: none !important; }
.topbar {
  position: relative !important;
  top: auto !important;
  width: min(1180px, 100%) !important;
  max-width: 1180px !important;
  margin: 0 auto 22px !important;
  padding: 22px 26px !important;
  border-radius: var(--final-radius) !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 20px !important;
  background: rgba(255,255,255,.88) !important;
  border: 1px solid var(--final-border) !important;
  backdrop-filter: blur(16px) !important;
  box-shadow: 0 22px 55px rgba(91, 17, 129, .10) !important;
  animation: finalPanelIn .55s ease both, finalPanelGlow 6s ease-in-out infinite alternate !important;
}
.topbar h2 {
  font-size: clamp(28px, 3vw, 40px) !important;
  line-height: 1.02 !important;
  margin: 0 !important;
}
.topbar .muted { margin: 6px 0 0 !important; }
.top-actions { display: flex !important; align-items: center !important; gap: 12px !important; flex-wrap: wrap !important; }
.section {
  width: min(1180px, 100%) !important;
  max-width: 1180px !important;
  margin: 0 auto 24px !important;
  padding: 0 !important;
}

/* Minimal text and neat components */
.eyebrow { font-size: 12px !important; letter-spacing: .11em !important; margin-bottom: 6px !important; }
.muted, p, li, small, label, input, select, textarea, button { font-size: 14px !important; }
h3, h4 { line-height: 1.15 !important; }
.hero-card,
.card,
.table-card,
.sheet-panel,
.stat-card,
.modal-card,
.hero-stats div,
.package-item,
.warning,
.success,
.rich-editor {
  border-radius: var(--final-radius) !important;
  background: rgba(255,255,255,.88) !important;
  border: 1px solid var(--final-border) !important;
  box-shadow: 0 22px 55px rgba(91, 17, 129, .09) !important;
}
.hero-card {
  padding: 26px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr) !important;
  gap: 24px !important;
  align-items: center !important;
  margin-bottom: 20px !important;
}
.hero-card h3 { font-size: clamp(26px, 3vw, 38px) !important; margin: 0 0 10px !important; }
.hero-stats { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 14px !important; }
.hero-stats div,
.stat-card { padding: 20px !important; min-height: 110px !important; }
.hero-stats strong,
.stat-card strong { font-size: clamp(26px, 3vw, 34px) !important; line-height: 1 !important; margin-bottom: 8px !important; }
.stat-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 14px !important; margin: 0 0 22px !important; }
.cards { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 14px !important; }
.card { padding: 20px !important; }
.card h4 { font-size: 19px !important; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 16px !important; }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 14px !important; }
.section-title { margin: 0 0 14px !important; }
.section-title h3 { font-size: 22px !important; }
.sheet-buttons { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 14px !important; margin: 14px 0 !important; }
.sheet-btn {
  min-height: 88px !important;
  border-radius: 26px !important;
  font-size: clamp(21px, 2.3vw, 28px) !important;
  background: rgba(255,255,255,.92) !important;
  border: 1px solid var(--final-border) !important;
  color: var(--final-purple) !important;
  box-shadow: 0 20px 45px rgba(91, 17, 129, .08) !important;
  animation: finalButtonBreathe 3.8s ease-in-out infinite !important;
}
.sheet-btn.active { background: linear-gradient(135deg, #fbf4ff, #f0dcff) !important; border-color: var(--final-purple-2) !important; }
.table-card,
.sheet-panel { padding: 20px !important; margin-top: 18px !important; }
.table-scroll {
  border-radius: 18px !important;
  border: 1px solid #d9d4dc !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.7) !important;
}
table { font-size: 13px !important; min-width: 980px !important; }
th, td { padding: 9px 10px !important; }
th { font-size: 12px !important; background: #f4f0f6 !important; color: #51355c !important; }
tr:nth-child(even) td { background: #fbf7ff !important; }
tr:hover td { background: #f4e8ff !important; }
.primary,
.ghost,
.danger,
.soft-btn,
.logout-btn,
.filter-btn,
.mobile-menu,
.modal-close,
input,
select,
textarea,
td input,
td select,
td textarea,
.cell-input,
.form-grid input,
.form-grid select,
.form-grid textarea {
  border-radius: var(--final-radius-sm) !important;
}
.primary,
.ghost,
.danger,
.soft-btn { padding: 11px 18px !important; min-height: 44px !important; }
.primary { background: linear-gradient(135deg, var(--final-purple), var(--final-purple-2)) !important; }

/* Heavy animation but controlled: no layout shifting */
.topbar,
.hero-card,
.card,
.table-card,
.sheet-panel,
.stat-card,
.role-card { animation: finalPanelIn .55s ease both, finalPanelGlow 7s ease-in-out infinite alternate !important; }
.topbar::before,
.hero-card::before,
.card::before,
.table-card::before,
.sheet-panel::before,
.stat-card::before,
.role-card::before { opacity: .45 !important; }
.topbar::after,
.hero-card::after,
.card::after,
.table-card::after,
.sheet-panel::after,
.stat-card::after,
.role-card::after { animation-duration: 7s !important; opacity: .38 !important; }
.primary::after,
.ghost::after,
.danger::after,
.soft-btn::after,
.logout-btn::after { animation-duration: 4.8s !important; }

@keyframes finalAuroraBg {
  0% { background-position: 0% 0%; filter: saturate(1); }
  100% { background-position: 100% 100%; filter: saturate(1.15); }
}
@keyframes finalDotsMove {
  0% { background-position: 0 0, 0 0, -40% 0; }
  100% { background-position: 90px 110px, -80px 70px, 140% 0; }
}
@keyframes finalLightSweep {
  0%, 40% { opacity: .42; }
  60% { opacity: .75; }
  100% { opacity: .55; }
}
@keyframes finalOrbFloat {
  from { transform: translate3d(0,0,0) scale(.95); }
  to { transform: translate3d(-80px,70px,0) scale(1.16); }
}
@keyframes finalSidebarGlow {
  from { background-position: 0 0; filter: saturate(1); }
  to { background-position: 0 100%; filter: saturate(1.18); }
}
@keyframes finalLogoFloat {
  0%, 100% { transform: translateY(0) scale(1); filter: drop-shadow(0 8px 18px rgba(255,255,255,.08)); }
  50% { transform: translateY(-4px) scale(1.025); filter: drop-shadow(0 12px 24px rgba(255,255,255,.18)); }
}
@keyframes finalPanelIn {
  from { opacity: 0; transform: translateY(14px) scale(.99); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes finalPanelGlow {
  from { box-shadow: 0 20px 48px rgba(91,17,129,.08); }
  to { box-shadow: 0 26px 68px rgba(154,34,211,.17); }
}
@keyframes finalButtonBreathe {
  0%, 100% { transform: translateY(0); box-shadow: 0 16px 38px rgba(91,17,129,.08); }
  50% { transform: translateY(-2px); box-shadow: 0 22px 54px rgba(154,34,211,.18); }
}

/* Mobile accuracy */
@media (max-width: 1050px) {
  .mobile-menu:not(.hidden) { display: grid !important; place-items: center !important; }
  .sidebar {
    width: min(86vw, 320px) !important;
    transform: translateX(-105%) !important;
    transition: transform .25s ease !important;
    z-index: 80 !important;
  }
  .sidebar.mobile-open { transform: translateX(0) !important; }
  .app { margin-left: 0 !important; width: 100% !important; padding: 82px 14px 26px !important; }
  .topbar { display: grid !important; grid-template-columns: 1fr !important; width: 100% !important; padding: 20px !important; }
  .top-actions { display: grid !important; grid-template-columns: 1fr 1fr !important; width: 100% !important; }
  .hero-card { grid-template-columns: 1fr !important; }
  .stat-grid, .cards, .grid-2, .grid-3, .sheet-buttons, .login-options { grid-template-columns: 1fr !important; }
  .sheet-btn { min-height: 72px !important; }
}
@media (max-width: 680px) {
  body { font-size: 14px !important; }
  .app { padding-left: 10px !important; padding-right: 10px !important; }
  .topbar, .hero-card, .card, .table-card, .sheet-panel, .stat-card { border-radius: 24px !important; }
  .topbar h2 { font-size: 25px !important; }
  .hero-card h3 { font-size: 24px !important; }
  .top-actions { grid-template-columns: 1fr !important; }
  .hero-stats { grid-template-columns: 1fr 1fr !important; }
  .hero-stats div, .stat-card { min-height: 92px !important; padding: 16px !important; }
  .hero-stats strong, .stat-card strong { font-size: 25px !important; }
  .splash-logo, .login-logo { width: 78% !important; }
  .splash-card, .login-card { padding: 24px 18px !important; border-radius: 28px !important; }
}
