:root{
  --bg:#07101a;
  --bg-2:#091523;
  --bg-3:#0d1d2d;
  --panel:rgba(10,22,36,.88);
  --panel-2:rgba(14,29,45,.94);
  --panel-3:rgba(17,35,54,.98);
  --line:rgba(70,221,255,.14);
  --line-strong:rgba(70,221,255,.28);
  --text:#edf8ff;
  --muted:#8faabd;
  --muted-2:#6f8798;
  --teal:#33e7ff;
  --teal-2:#13b7d5;
  --green:#7cff9c;
  --danger:#ff6d87;
  --warn:#ffd76c;
  --shadow:0 22px 60px rgba(0,0,0,.34);
  --shadow-soft:0 12px 30px rgba(0,0,0,.24);
  --radius:22px;
  --radius-lg:28px;
  --max:1260px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,Arial,Helvetica,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 8% 12%, rgba(51,231,255,.09), transparent 20%),
    radial-gradient(circle at 88% 10%, rgba(51,231,255,.07), transparent 18%),
    radial-gradient(circle at 70% 75%, rgba(124,255,156,.05), transparent 18%),
    linear-gradient(180deg,#06111b 0%, #08131f 35%, #07101a 100%);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(calc(100% - 34px), var(--max));margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(4,10,18,.72);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.nav-wrap{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.brand-mark{
  width:44px;
  height:44px;
  border-radius:15px;
  display:grid;
  place-items:center;
  font-size:20px;
  font-weight:900;
  color:var(--teal);
  border:1px solid rgba(51,231,255,.23);
  background:linear-gradient(145deg,rgba(51,231,255,.18),rgba(51,231,255,.04));
  box-shadow:inset 0 0 25px rgba(51,231,255,.08), 0 8px 24px rgba(0,0,0,.22);
}
.brand-text strong{display:block;font-size:16px}
.brand-text small{
  display:block;
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#78adc0;
}

.nav{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.nav a{
  color:#c4d6e4;
  font-size:14px;
}
.nav a:hover{color:#fff}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:none;
  cursor:pointer;
  border-radius:14px;
  font-weight:700;
  padding:12px 18px;
  transition:.18s ease;
}
.btn:hover{transform:translateY(-1px)}
.small-btn{padding:10px 14px}
.btn-primary{
  color:#001018;
  background:linear-gradient(180deg,var(--teal),var(--teal-2));
  box-shadow:0 10px 24px rgba(51,231,255,.18);
}
.btn-outline{
  color:var(--text);
  border:1px solid rgba(51,231,255,.20);
  background:rgba(255,255,255,.02);
}
.btn-soft{
  color:#a8efff;
  border:1px solid rgba(51,231,255,.14);
  background:rgba(51,231,255,.06);
}
.btn-full{width:100%}

.hero{
  padding:86px 0 42px;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:28px;
  align-items:center;
}
.hero-card,
.card,
.form-card,
.stats-card,
.table-card,
.kpi-card,
.sidebar-card,
.portal-card,
.feature-card,
.case-panel,
.widget-card{
  background:linear-gradient(180deg, rgba(10,22,36,.94), rgba(11,23,38,.90));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:var(--radius-lg);
}
.hero-copy{padding:46px}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#84d7e8;
  border:1px solid rgba(51,231,255,.16);
  background:rgba(51,231,255,.05);
  margin-bottom:16px;
}
.hero h1{
  margin:0 0 18px;
  font-size:54px;
  line-height:1.02;
  max-width:740px;
}
.hero p{
  margin:0;
  color:var(--muted);
  font-size:17px;
  line-height:1.75;
  max-width:700px;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:26px;
}
.hero-visual{
  padding:26px;
  min-height:430px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.visual-shell{
  width:100%;
  height:380px;
  position:relative;
  border-radius:26px;
  overflow:hidden;
  border:1px solid rgba(51,231,255,.18);
  background:
    radial-gradient(circle at 50% 50%, rgba(51,231,255,.16), transparent 28%),
    linear-gradient(135deg, rgba(51,231,255,.08), rgba(255,255,255,.01));
}
.visual-shell:before{
  content:"";
  position:absolute;
  width:170px;
  height:170px;
  right:14%;
  top:20%;
  border-radius:30px;
  border:1px solid rgba(51,231,255,.25);
  background:linear-gradient(145deg,rgba(51,231,255,.12),rgba(51,231,255,.03));
  box-shadow:0 0 50px rgba(51,231,255,.10), inset 0 0 22px rgba(51,231,255,.10);
}
.visual-shell:after{
  content:"";
  position:absolute;
  inset:18% 22%;
  border-radius:28px;
  border:1px solid rgba(51,231,255,.20);
  box-shadow:inset 0 0 30px rgba(51,231,255,.08);
}
.orb{
  position:absolute;
  width:20px;
  height:20px;
  border-radius:50%;
  background:rgba(51,231,255,.35);
  box-shadow:0 0 20px rgba(51,231,255,.30);
}
.orb.o1{left:16%;top:28%}
.orb.o2{left:25%;top:58%}
.orb.o3{left:45%;top:23%}
.orb.o4{left:61%;top:64%}
.orb.o5{left:80%;top:38%}
.line{
  position:absolute;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(51,231,255,.35), transparent);
  transform-origin:left center;
}
.line.l1{left:18%;top:30%;width:160px;transform:rotate(18deg)}
.line.l2{left:26%;top:55%;width:180px;transform:rotate(-12deg)}
.line.l3{left:44%;top:25%;width:220px;transform:rotate(10deg)}
.line.l4{left:50%;top:60%;width:180px;transform:rotate(-20deg)}

.section{padding:26px 0 56px}
.section-title{
  margin:0 0 18px;
  font-size:32px;
}
.section-sub{
  margin:0 0 24px;
  color:var(--muted);
  max-width:780px;
  line-height:1.75;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.feature-card{
  padding:24px;
}
.feature-icon{
  width:52px;
  height:52px;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:var(--teal);
  border:1px solid rgba(51,231,255,.18);
  background:rgba(51,231,255,.05);
  font-weight:900;
  margin-bottom:16px;
}
.feature-card h3{margin:0 0 10px}
.feature-card p{margin:0;color:var(--muted);line-height:1.75}

.portal-grid,
.profile-grid,
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.portal-card,
.form-card,
.table-card,
.stats-card,
.kpi-card,
.sidebar-card,
.widget-card{
  padding:24px;
}
.portal-card h3{margin:0 0 10px}
.portal-card p{margin:0;color:var(--muted);line-height:1.75}
.portal-mini{
  margin-top:18px;
  display:grid;
  gap:12px;
}
.portal-row,
.stat-pair{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:13px 15px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
}

.form-card h2{margin-top:0}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.form-stack{display:grid;gap:14px}
.input,.textarea,.select{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--text);
  padding:14px 15px;
  outline:none;
}
.input:focus,.textarea:focus,.select:focus{
  border-color:rgba(51,231,255,.34);
  box-shadow:0 0 0 3px rgba(51,231,255,.08);
}
.textarea{min-height:148px;resize:vertical}
.upload-note{
  font-size:13px;
  color:var(--muted);
}

.auth-wrap{
  min-height:calc(100vh - 160px);
  display:grid;
  place-items:center;
  padding:42px 0;
}
.auth-card{
  width:min(100%, 470px);
  padding:30px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(10,22,36,.94),rgba(11,23,38,.90));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.auth-card h1{margin-top:0;margin-bottom:10px}
.auth-card p{color:var(--muted)}

.dashboard{
  padding:38px 0 60px;
}
.dashboard-top{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
}
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin:22px 0;
}
.kpi-card h3,.widget-card h3{
  margin:0 0 8px;
  font-size:13px;
  color:#9bbbcf;
  font-weight:600;
}
.kpi-card strong,.widget-card strong{
  display:block;
  font-size:34px;
  line-height:1;
}
.kpi-card small{
  display:block;
  margin-top:8px;
  color:var(--muted);
}

.widget-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-bottom:22px;
}

.badge{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  background:rgba(51,231,255,.10);
  color:#8cefff;
  border:1px solid rgba(51,231,255,.18);
}
.badge.warn{
  background:rgba(255,215,108,.10);
  color:#ffe79a;
  border-color:rgba(255,215,108,.16);
}
.badge.green{
  background:rgba(124,255,156,.10);
  color:#acffc1;
  border-color:rgba(124,255,156,.16);
}

.priority-low{color:#b6d4e4}
.priority-normal{color:#9df3ff}
.priority-high{color:#ffe79a}
.priority-urgent{color:#ffafbe}

.progress-wrap{margin-top:18px}
.progress-bar{
  width:100%;
  height:12px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.06);
}
.progress-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, #33e7ff, #7cff9c);
}

.case-list,
.evidence-list,
.message-list,
.timeline-list,
.audit-list{
  display:grid;
  gap:14px;
}
.case-item,
.evidence-item,
.message-item,
.timeline-item,
.audit-item,
.note-box,
.case-upload-box{
  padding:16px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
}
.case-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.case-item-left{
  display:grid;
  gap:6px;
}
.case-item-right{
  display:grid;
  gap:8px;
  justify-items:end;
}
.meta{
  color:var(--muted);
  font-size:13px;
}
.meta-strong{
  color:#d9eef9;
  font-size:13px;
}

.table{
  width:100%;
  border-collapse:collapse;
}
.table th,.table td{
  text-align:left;
  padding:14px 10px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.table th{
  font-size:13px;
  color:#a8c2d3;
}
.table td{
  color:#edf8ff;
}

.admin-layout{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:22px;
  padding:34px 0 60px;
}
.sidebar-menu{
  display:grid;
  gap:10px;
}
.sidebar-menu a{
  display:block;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.04);
  color:#cddbe6;
}
.sidebar-menu a:hover{
  border-color:rgba(51,231,255,.22);
  color:#fff;
}
.case-shell{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:22px;
}
.message-item.admin{
  border-color:rgba(51,231,255,.16);
}
.message-item.client{
  border-color:rgba(124,255,156,.14);
}

.notice-bar{
  margin:18px 0 0;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(51,231,255,.06);
  border:1px solid rgba(51,231,255,.12);
  color:#b6f3ff;
}

.step-track{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;
  margin-top:18px;
}
.step-node{
  text-align:center;
}
.step-dot{
  width:34px;
  height:34px;
  margin:0 auto 8px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-weight:800;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#b5cad6;
}
.step-node.active .step-dot{
  background:rgba(51,231,255,.14);
  border-color:rgba(51,231,255,.24);
  color:#9bf2ff;
}
.step-node.done .step-dot{
  background:rgba(124,255,156,.14);
  border-color:rgba(124,255,156,.22);
  color:#b9ffcb;
}
.step-label{
  font-size:12px;
  color:var(--muted);
  line-height:1.4;
}

.filters-bar{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr auto;
  gap:12px;
  margin-bottom:18px;
}
.bulk-bar,
.inline-actions,
.pager{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.pager{
  margin-top:18px;
}
.pager a,
.pager span{
  padding:10px 14px;
  border-radius:12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  color:#dcebf5;
}
.pager .active{
  border-color:rgba(51,231,255,.20);
  background:rgba(51,231,255,.08);
  color:#9df3ff;
}
.check-col{width:40px}

.stat-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  color:#d7e7f3;
  font-size:13px;
}
.danger-link{color:#ffafbe}

.alert{
  margin-bottom:16px;
  padding:14px 16px;
  border-radius:14px;
  font-weight:600;
}
.alert-success{
  background:rgba(124,255,156,.10);
  color:#acffc1;
  border:1px solid rgba(124,255,156,.16);
}
.alert-error{
  background:rgba(255,109,135,.10);
  color:#ffafbe;
  border:1px solid rgba(255,109,135,.16);
}

.site-footer{
  margin-top:42px;
  border-top:1px solid rgba(255,255,255,.05);
  background:rgba(4,10,18,.72);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:24px;
  padding:36px 0 18px;
}
.footer-grid h4{margin:0 0 10px}
.footer-grid p,.footer-grid li,.footer-grid a{
  color:var(--muted);
  line-height:1.7;
}
.footer-grid ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}
.footer-bottom{
  padding:16px 0 28px;
  color:#7392a4;
  font-size:14px;
}

@media (max-width: 1100px){
  .hero-grid,
  .split,
  .portal-grid,
  .dashboard-top,
  .grid-3,
  .footer-grid,
  .form-row,
  .kpi-grid,
  .admin-layout,
  .case-shell,
  .step-track,
  .profile-grid,
  .widget-grid,
  .filters-bar{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .nav-wrap{padding:12px 0}
  .nav{gap:12px}
  .hero{padding:44px 0 28px}
  .hero-copy{padding:28px}
  .hero h1{font-size:34px}
  .section-title{font-size:26px}
  .case-item{
    flex-direction:column;
    align-items:flex-start;
  }
  .case-item-right{
    justify-items:start;
  }
}