/* IMC Capital — App/Admin UI (simple Oitila-inspired fintech, original) */
:root{
  --primary:#a855f7;
  --primary-bright:#e879f9;
  --highlight:#7c3aed;
  --accent:#2b0d63;
  --bg:#12032b;
  --text:#f8fafc;
  --muted:#94a3b8;
  --border:rgba(255,255,255,.08);
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --glow:0 0 36px rgba(168,85,247,.4);
  --font:"Plus Jakarta Sans","DM Sans",system-ui,sans-serif;
  --space-1:8px;
  --space-2:16px;
  --space-3:24px;
  --space-4:32px;
  --sidebar-w:272px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  font-size:15px;
  line-height:1.62;
  color:var(--text);
  background:linear-gradient(180deg,#42008f 0%, #23004f 45%, #12032b 100%);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--highlight);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary-bright);text-decoration:none}

.app{
  display:flex;
  min-height:100vh;
}

.sidebar{
  width:var(--sidebar-w);
  flex-shrink:0;
  background:linear-gradient(180deg,rgba(54,0,122,.92) 0%, rgba(26,4,61,.94) 100%);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  padding:var(--space-2) 0;
  position:fixed;
  top:0;bottom:0;left:0;
  height:100dvh;
  overflow:hidden;
  backdrop-filter:blur(14px);
}
.top-menu{flex:0 0 auto}

.sidebar .brand{
  padding:0 var(--space-2) var(--space-2);
  font-weight:900;
  font-size:1.28rem;
  color:var(--text);
  border-bottom:1px solid var(--border);
  margin-bottom:var(--space-1);
}
.sidebar .brand span{
  color:var(--primary-bright);
  text-shadow:0 0 20px rgba(167,139,250,.35);
}

.side-nav,.middle-content{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  padding:0 var(--space-1) var(--space-2);
}
.side-nav::-webkit-scrollbar,.middle-content::-webkit-scrollbar{
  width:8px;
}
.side-nav::-webkit-scrollbar-thumb,.middle-content::-webkit-scrollbar-thumb{
  background:rgba(232,121,249,.25);
  border-radius:999px;
}
.side-nav a{
  display:flex;align-items:center;gap:.65rem;
  padding:.8rem .9rem;
  border-radius:var(--radius-sm);
  color:var(--muted);
  font-weight:700;
  font-size:.91rem;
  margin-bottom:.35rem;
  border:1px solid transparent;
  transition:background .22s,color .22s,border-color .22s,transform .2s,box-shadow .22s;
}
.side-nav a svg{width:20px;height:20px;opacity:.9}
.side-nav a:hover{
  background:rgba(232,121,249,.09);
  color:#f3e8ff;
  border-color:rgba(232,121,249,.2);
}
.side-nav a.active{
  background:linear-gradient(135deg, rgba(217,70,239,.24), rgba(124,58,237,.24));
  color:var(--primary-bright);
  border-color:rgba(232,121,249,.32);
  box-shadow:0 8px 24px rgba(168,85,247,.2), inset 0 0 0 1px rgba(255,255,255,.04);
}

.side-foot{
  padding:var(--space-2);
  border-top:1px solid var(--border);
  background:rgba(10,4,25,.18);
  flex:0 0 auto;
}
.bottom-section{
  flex:0 0 auto;
  margin-top:auto;
  position:relative;
  z-index:2;
}
.uid{display:block;font-size:.78rem;color:var(--muted);margin-bottom:.55rem;word-break:break-all}
.logout{color:var(--highlight);font-weight:800}

.main-wrap{
  flex:1;
  margin-left:var(--sidebar-w);
  min-width:0;
  display:flex;
  flex-direction:column;
}

.topbar{
  display:flex;align-items:center;gap:1rem;
  padding:1rem var(--space-3);
  border-bottom:1px solid var(--border);
  background:rgba(28,7,54,.82);
  backdrop-filter:blur(14px);
  position:sticky;top:0;z-index:30;
}
.menu-btn{
  display:none;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  color:var(--text);
  padding:.45rem .65rem;
  border-radius:var(--radius-sm);
  cursor:pointer;
}
.topbar h1{flex:1;margin:0;font-size:1.22rem;font-weight:900;letter-spacing:.01em}

.topbar-user{
  display:flex;
  align-items:center;
  gap:.65rem;
  margin-left:auto;
  flex-shrink:0;
}
.topbar-user .meta{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}
.topbar-user .meta small{font-size:.72rem;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.topbar-user .meta span{font-weight:900;font-size:.92rem}
.avatar-img{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(232,121,249,.4);
  object-fit:cover;
  box-shadow:0 0 20px rgba(139,92,246,.2);
}

.content{
  flex:1;
  padding:var(--space-3);
  display:grid;
  gap:var(--space-3);
  align-content:start;
  grid-auto-rows:max-content;
}
.content > *{margin:0}
.content .alert{margin-bottom:0}
.content .card{margin-bottom:var(--space-2)}
.content .card:last-child{margin-bottom:0}

/* Alerts */
.alert{
  padding:.85rem 1rem;
  border-radius:var(--radius-sm);
  border:1px solid transparent;
  font-size:.92rem;
}
.alert.ok{background:rgba(232,121,249,.14);border-color:rgba(232,121,249,.35);color:#f5d0fe}
.alert.err{background:rgba(255,80,80,.10);border-color:rgba(255,100,100,.25);color:#ff9c9c}

/* Cards (glass) */
.card{
  background:linear-gradient(145deg, rgba(67,13,120,.56), rgba(22,4,53,.9));
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 16px 40px rgba(0,0,0,.32);
  position:relative;
  overflow:hidden;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.card::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(232,121,249,.28), rgba(168,85,247,.22), transparent);
  pointer-events:none;
  opacity:.7;
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 48px rgba(0,0,0,.4);
  border-color:rgba(232,121,249,.2);
}
.card-inner{position:relative;z-index:1;padding:1.1rem 1.25rem}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.7rem 1.3rem;
  border-radius:999px;
  font-weight:800;
  border:none;
  cursor:pointer;
  transition:transform .2s, box-shadow .25s, filter .22s, background .22s, color .22s, border-color .22s;
  font-family:inherit;
  text-decoration:none;
  user-select:none;
}
.btn:active{transform:scale(.98)}
.btn-sm{padding:.5rem 1rem;font-size:.83rem}
.btn-primary{
  background:linear-gradient(135deg, #f472b6 0%, #d946ef 35%, #a855f7 68%, #7c3aed 100%);
  color:#fff;
  box-shadow:0 10px 30px rgba(168,85,247,.4);
}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.06);box-shadow:0 14px 36px rgba(168,85,247,.52)}
.btn-ghost{
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  color:var(--text);
}
.btn-ghost:hover{border-color:rgba(232,121,249,.45);background:rgba(232,121,249,.10)}
.btn-soft{
  background:rgba(217,70,239,.12);
  color:#f5d0fe;
  border:1px solid rgba(217,70,239,.28);
}
.btn-soft:hover{
  background:rgba(217,70,239,.2);
  border-color:rgba(232,121,249,.45);
  transform:translateY(-1px);
}

.stat-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-bottom:1.5rem;
}
@media (max-width:1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.stat-grid{grid-template-columns:1fr}}

.stat-card .label{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.10em;
  color:var(--muted);
  margin-bottom:.35rem;
}
.stat-card .value{
  font-size:1.45rem;
  font-weight:950;
  color:var(--primary-bright);
  text-shadow:0 0 28px rgba(232,121,249,.2);
}
.stat-card.highlight .value{
  color:var(--highlight);
  text-shadow:0 0 28px rgba(168,85,247,.26);
}

.grid-2{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:1.25rem;
}
@media (max-width:960px){.grid-2{grid-template-columns:1fr}}

.section-title{
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--muted);
  margin:0 0 .85rem;
  font-weight:800;
}

/* Tables */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}
table.data{width:100%;border-collapse:collapse;font-size:.88rem}
table.data th,table.data td{padding:.75rem 1rem;border-bottom:1px solid var(--border);text-align:left}
table.data th{
  color:var(--muted);
  font-weight:800;
  text-transform:uppercase;
  font-size:.72rem;
  letter-spacing:.06em;
  background:rgba(0,0,0,.14);
}
table.data tbody tr:hover{background:rgba(96,165,250,.08)}
.table-tools{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.65rem;
  padding:.65rem .75rem;
  border-bottom:1px solid var(--border);
  background:rgba(0,0,0,.12);
}
.table-tools .left,.table-tools .right{display:flex;align-items:center;gap:.55rem}
.table-tools label{
  font-size:.74rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:800;
}
.table-tools input,.table-tools select{
  background:rgba(0,0,0,.22);
  border:1px solid var(--border);
  color:var(--text);
  border-radius:10px;
  padding:.45rem .6rem;
  font-size:.84rem;
}
.table-tools input{min-width:180px}
.table-pagination{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.45rem;
  padding:.65rem .75rem;
  border-top:1px solid var(--border);
  background:rgba(0,0,0,.12);
}
.table-page-btn{
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
  color:var(--text);
  border-radius:8px;
  padding:.32rem .52rem;
  cursor:pointer;
}
.table-page-btn[disabled]{opacity:.45;cursor:not-allowed}
.table-sort{cursor:pointer;user-select:none;position:relative;padding-right:14px}
.table-sort::after{content:"↕";position:absolute;right:0;opacity:.45;font-size:.72rem}
.table-sort.asc::after{content:"↑";opacity:.9}
.table-sort.desc::after{content:"↓";opacity:.9}

.muted{color:var(--muted)}

/* Badges */
.badge{
  display:inline-block;
  padding:.2rem .55rem;
  border-radius:999px;
  font-size:.72rem;
  font-weight:900;
}
.badge.ok{background:rgba(167,139,250,.14);color:var(--primary-bright)}
.badge.warn{background:rgba(96,165,250,.10);color:#93c5fd}
.badge.err{background:rgba(255,80,80,.12);color:#ff7a7a}

/* Forms + auth */
.auth-page{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:2rem;
  background:radial-gradient(ellipse at 50% 0%, rgba(167,139,250,.18), transparent 55%), linear-gradient(180deg, #1e1b4b 0%, #0f0a18 100%);
}
.auth-card{
  width:min(440px,100%);
  padding:2.25rem;
  border-radius:var(--radius);
  background:rgba(30,27,75,.35);
  border:1px solid var(--border);
  backdrop-filter:blur(20px);
  box-shadow:var(--shadow);
}
.auth-card h1{margin:0 0 .35rem;font-size:1.65rem;font-weight:950}
.auth-card .muted{color:var(--muted);margin:0 0 1.5rem;font-size:.95rem}
.form label{
  display:block;
  font-size:.82rem;
  font-weight:900;
  color:var(--muted);
  margin-bottom:.35rem;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.form input,.form select,.form textarea{
  width:100%;
  padding:.65rem .85rem;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:rgba(0,0,0,.18);
  color:var(--text);
  font-family:inherit;
  margin-bottom:1rem;
}
.form select{
  appearance:auto;
  color:#f8fafc;
  background-color:rgba(27,8,58,.95);
}
.form select option{
  color:#f8fafc;
  background:#2a0d52;
}
.form select option:checked{
  color:#ffffff;
  background:#2563eb;
}
.form select option:disabled{
  color:#94a3b8;
  background:#2a0d52;
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;
  border-color:rgba(167,139,250,.55);
  box-shadow:0 0 0 3px rgba(167,139,250,.18);
}
.form .btn{width:100%}

/* Tree nodes */
.tree-node{
  background:rgba(96,165,250,.06);
  border:1px solid rgba(139,92,246,.25);
  border-radius:10px;
  padding:.75rem;
}

/* Responsive sidebar */
@media (max-width:960px){
  .menu-btn{display:inline-flex}
  .sidebar{
    width:min(86vw,320px);
    box-shadow:0 24px 60px rgba(0,0,0,.45);
    transform:translateX(-110%);
    z-index:80;
  }
  .sidebar.is-open{transform:translateX(0)}
  .main-wrap{margin-left:0}
  .topbar{padding:.9rem 1rem}
  .content{padding:1rem}
  .side-nav,.middle-content{padding-bottom:1rem}
}

/* Chart container */
.chart-box{position:relative;height:280px}
.empty-state{text-align:center;padding:2rem;color:var(--muted);font-size:.95rem}

/* Referral block */
.ref-box{
  width:100%;
}
.ref-box input{
  width:100%;
  min-width:0;
  padding:.72rem .9rem;
  border-radius:12px;
  border:1px solid rgba(167,139,250,.35);
  background:rgba(12,8,30,.55);
  color:#e2e8f0;
  font-family:inherit;
  font-size:.92rem;
  box-sizing:border-box;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.ref-box input:focus{
  outline:none;
  border-color:rgba(167,139,250,.65);
  box-shadow:0 0 0 3px rgba(167,139,250,.2);
}
.copy-ref-btn{
  min-width:110px;
}
.ref-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.7rem;
}
.ref-item{
  padding:.7rem;
  border:1px solid rgba(167,139,250,.2);
  border-radius:12px;
  background:rgba(12,8,30,.35);
}
.ref-item input{
  width:100%;
  min-width:0;
  padding:.62rem .75rem;
  border-radius:10px;
  border:1px solid rgba(167,139,250,.3);
  background:rgba(8,6,20,.6);
  color:#e2e8f0;
  font-family:inherit;
  font-size:.84rem;
  box-sizing:border-box;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.ref-meta{
  margin:0 0 .45rem;
  color:var(--muted);
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:800;
}

/* Small devices */
@media (max-width:640px){
  .topbar{
    padding:.78rem .8rem;
    gap:.55rem;
  }
  .topbar h1{
    font-size:1rem;
  }
  .topbar-user .meta{
    display:none;
  }
  .avatar-img{
    width:34px;
    height:34px;
  }
  .content{
    padding:.85rem .75rem 1.2rem;
    gap:.85rem;
  }
  .card-inner{
    padding:.95rem;
  }
  .btn{
    padding:.6rem .95rem;
    font-size:.88rem;
  }
  table.data th,table.data td{
    padding:.6rem .65rem;
    font-size:.82rem;
    white-space:nowrap;
  }
  .table-tools{
    flex-direction:column;
    align-items:stretch;
  }
  .table-tools .left,.table-tools .right{
    justify-content:space-between;
  }
  .table-tools input{min-width:0;width:100%}
  .auth-page{
    padding:1rem;
  }
  .auth-card{
    padding:1.15rem;
  }
  .auth-card h1{
    font-size:1.35rem;
  }
  .chart-box{
    height:220px;
  }
  .ref-box input{
    font-size:.86rem;
    padding:.64rem .75rem;
  }
  .ref-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:420px){
  .topbar{
    padding:.72rem .68rem;
  }
  .menu-btn{
    padding:.32rem .5rem;
  }
  .content{
    padding:.72rem .55rem 1rem;
    gap:.7rem;
  }
  .card-inner{
    padding:.78rem;
  }
  .btn-sm{
    padding:.35rem .65rem;
    font-size:.78rem;
  }
  table.data{
    font-size:.78rem;
  }
}

/* Professional register page skin */
.register-modern-page{
  --reg-space-1:8px;
  --reg-space-2:16px;
  --reg-space-3:24px;
  --reg-space-4:32px;
  --reg-radius-md:12px;
  --reg-radius-lg:16px;
  --reg-text:#f6f2ff;
  --reg-text-muted:rgba(242,236,255,.82);
  --reg-line:rgba(255,255,255,.2);
  --reg-field-bg:rgba(255,255,255,.08);
  --reg-focus:#f472b6;
  background:
    radial-gradient(ellipse 72% 56% at 20% 15%, rgba(168,85,247,.25), transparent 62%),
    linear-gradient(160deg,#120028 0%, #0f0122 52%, #0c1026 100%);
  padding:0;
  color:var(--reg-text);
}
.register-layout{
  width:min(1180px, calc(100% - var(--reg-space-4)));
  margin:40px auto;
  display:grid;
  grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr);
  gap:28px;
  align-items:stretch;
  animation:registerEntry .5s ease;
}
.register-brand-panel{
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  background:linear-gradient(135deg, rgba(109,40,217,.26), rgba(79,70,229,.2));
  backdrop-filter:blur(12px);
  box-shadow:0 24px 60px rgba(12,4,34,.4);
  padding:28px;
  display:flex;
  flex-direction:column;
  height:100%;
}
.register-breadcrumb{
  margin:0;
  font-size:.82rem;
  font-weight:700;
  color:rgba(230,235,255,.85);
}
.register-breadcrumb span{margin:0 6px;opacity:.7}
.register-brand-title{
  margin:14px 0 10px;
  font-size:clamp(1.7rem,3vw,2.4rem);
  line-height:1.15;
  font-weight:900;
  letter-spacing:-.02em;
  color:#faf7ff;
}
.register-brand-lead{
  margin:0;
  color:rgba(236,230,255,.86);
  line-height:1.7;
  font-size:.95rem;
}
.register-brand-points{
  margin-top:20px;
  display:grid;
  gap:10px;
}
.register-brand-points div{
  position:relative;
  padding:10px 12px 10px 32px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;
  background:rgba(255,255,255,.06);
  color:#f4efff;
  font-size:.86rem;
  font-weight:700;
}
.register-brand-points div::before{
  content:"";
  position:absolute;
  left:12px;
  top:50%;
  width:10px;
  height:10px;
  border-radius:50%;
  transform:translateY(-50%);
  background:linear-gradient(135deg,#f472b6,#d946ef);
}
.register-top-home{
  margin:0 0 8px;
}
.register-top-home a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.8rem;
  font-weight:700;
  color:#ffe3fb;
  text-decoration:underline;
}
.register-top-home a:hover{
  color:#fff;
}

.register-shell{width:100%;margin:0}
.register-card{
  border-radius:var(--reg-radius-lg);
  border:1px solid var(--reg-line);
  background:linear-gradient(135deg,rgba(124,58,237,.94) 0%, rgba(109,40,217,.92) 38%, rgba(79,70,229,.9) 100%);
  box-shadow:0 30px 70px rgba(20,8,52,.52);
  padding:var(--reg-space-3);
  transition:transform .25s ease, box-shadow .25s ease;
  height:100%;
}
.register-card:hover{
  transform:translateY(-2px);
  box-shadow:0 34px 72px rgba(20,8,52,.52);
}
.register-alert{
  margin-bottom:var(--reg-space-2);
}

.register-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:var(--reg-space-2);
}
.register-grid > div{
  min-width:0;
}

.register-section-title{
  margin:0 0 10px;
  color:#fff;
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:.01em;
}
.register-form label{
  color:rgba(245,248,255,.9);
  font-size:.72rem;
  font-weight:700;
  margin-bottom:6px;
  letter-spacing:.05em;
}
.register-form input,
.register-form select{
  width:100%;
  min-height:42px;
  background:var(--reg-field-bg);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  border-radius:10px;
  margin-bottom:10px;
  padding:10px 12px;
  font-size:.86rem;
  line-height:1.25;
  transition:border-color .22s ease, box-shadow .22s ease, background-color .22s ease;
}
.register-form select option{
  color:#0f172a;
}
.register-form input::placeholder{
  color:rgba(255,255,255,.66);
}
.register-form input[readonly]{
  opacity:.9;
  cursor:default;
}
.register-form input:focus,
.register-form select:focus{
  outline:none;
  border-color:var(--reg-focus);
  box-shadow:0 0 0 3px rgba(244,114,182,.24);
  background:rgba(255,255,255,.11);
}

.register-inline{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.register-terms-title{
  margin-top:4px;
}
.register-terms-box{
  border:1px solid rgba(255,255,255,.24);
  border-radius:12px;
  padding:16px;
  color:var(--reg-text);
  background:rgba(255,255,255,.06);
}
.register-terms-box p{
  margin:0;
  line-height:1.72;
  font-size:.83rem;
  color:var(--reg-text-muted);
}
.register-terms-gap{
  margin-top:12px !important;
}

.register-check{
  margin-top:12px;
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:rgba(255,255,255,.96);
  font-weight:700;
  text-transform:none !important;
  letter-spacing:0 !important;
  font-size:.79rem !important;
  line-height:1.45;
}
.register-check input{
  margin-top:2px;
  width:16px;
  height:16px;
  accent-color:#f472b6;
}

.register-action{
  display:flex;
  justify-content:flex-end;
  margin-top:14px;
}
.register-action .btn{
  width:auto;
  min-width:170px;
  padding:11px 18px;
  font-size:.82rem;
  border-radius:999px;
  background:linear-gradient(135deg,#fb7185 0%, #f472b6 30%, #d946ef 65%, #a855f7 100%);
  box-shadow:0 14px 32px rgba(168,85,247,.45);
  transition:transform .22s ease, box-shadow .25s ease, filter .22s ease;
}
.register-action .btn:hover{
  transform:translateY(-1px);
  filter:brightness(1.06);
  box-shadow:0 18px 36px rgba(168,85,247,.55);
}
.register-foot-note{
  margin-top:14px !important;
  font-size:.82rem;
  color:var(--reg-text-muted) !important;
}
.register-foot-note a{
  color:#f5d0fe;
  text-decoration:underline;
}
.register-brand-panel img{
  width:min(100%, 493px);
  height:auto;
  display:block;
  margin-top:auto;
  border-radius:12px;
}

@keyframes registerEntry{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}
}

@media (max-width:1024px){
  .register-layout{
    grid-template-columns:1fr;
    gap:20px;
  }
  .register-grid{
    grid-template-columns:1fr;
  }
  .register-brand-panel{order:1}
  .register-shell{order:2}
  .register-brand-panel img{
    width:100%;
    margin-top:16px;
  }
}
@media (max-width:640px){
  .register-layout{
    width:calc(100% - 16px);
    margin:14px auto;
    gap:14px;
  }
  .register-brand-panel{padding:16px}
  .register-card{
    padding:14px 12px;
    border-radius:12px;
  }
  .register-inline{
    grid-template-columns:1fr;
  }
  .register-action{
    justify-content:stretch;
  }
  .register-action .btn{
    width:100%;
    min-width:0;
  }
}

/* Professional login page skin */
.login-modern-page{
  background:
    radial-gradient(ellipse 70% 55% at 20% 10%, rgba(124,58,237,.2), transparent 65%),
    linear-gradient(165deg,#130028 0%, #100124 50%, #0c102b 100%);
  align-items:center;
  justify-content:center;
  padding:0;
}
.login-shell{
  width:min(560px, calc(100% - 1.5rem));
  margin:1rem auto;
}
.login-panel{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(135deg,rgba(124,58,237,.95) 0%, rgba(109,40,217,.92) 40%, rgba(79,70,229,.9) 100%);
  display:block;
  min-height:0;
  box-shadow:0 30px 70px rgba(20,8,52,.45);
}
.login-panel-left{
  padding:1.5rem 1.4rem;
}
.login-panel-single{
  max-width:100%;
}
.login-panel-left h2{
  margin:0;
  font-size:1.65rem;
  font-weight:900;
  color:#fff;
}
.login-panel-left .lead{
  margin:.35rem 0 1rem;
  color:rgba(250,247,255,.92);
  font-size:.9rem;
  line-height:1.6;
}
.login-form-modern label{color:rgba(255,255,255,.98)}
.login-form-modern input{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.38);
  color:#ffffff;
  min-height:42px;
  border-radius:10px;
}
.login-form-modern input::placeholder{
  color:rgba(242,238,255,.82);
}
.login-form-modern input:focus{
  border-color:#f472b6;
  box-shadow:0 0 0 3px rgba(244,114,182,.22);
  background:rgba(255,255,255,.14);
}
.login-form-modern .btn{
  width:100%;
  margin-top:.85rem;
  background:linear-gradient(135deg,#fb7185 0%, #f472b6 30%, #d946ef 65%, #a855f7 100%);
  box-shadow:0 14px 34px rgba(168,85,247,.46);
}
.login-row-inline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-top:.55rem;
}
.login-check{
  display:flex;
  align-items:center;
  gap:.45rem;
  color:rgba(255,255,255,.98);
  font-size:.8rem;
  font-weight:700;
  text-transform:none !important;
  letter-spacing:0 !important;
}
.login-check input{
  width:15px;height:15px;margin:0;
  accent-color:#f472b6;
}
.forgot{
  color:#ffe3fb;
  font-size:.8rem;
  font-weight:700;
  text-decoration:underline;
}
.login-foot-note{
  margin-top:.9rem !important;
  color:rgba(250,246,255,.92) !important;
  font-size:.82rem;
}
.login-foot-note a{
  color:#ffe3fb;
}

@media (max-width:900px){
  .login-shell{
    width:min(560px, calc(100% - 1rem));
  }
}
@media (max-width:640px){
  .login-shell{
    width:calc(100% - .9rem);
  }
  .login-panel-left{padding:1rem .85rem}
  .login-row-inline{gap:.7rem}
}
