/* AstraBase shared design system — a VeloAstra product */
:root{
  --ink:#0d1a5e; --blue:#1a73e8; --teal:#1fb6a6; --teal-d:#0f8a7e;
  --ink-70:rgba(13,26,94,0.70); --ink-45:rgba(13,26,94,0.45); --ink-35:rgba(13,26,94,0.35);
  --ink-12:rgba(13,26,94,0.12); --ink-07:rgba(13,26,94,0.07); --ink-05:rgba(13,26,94,0.05);
  --bg:#f0f2f8; --line:rgba(13,26,94,0.08);
  --g:#22c55e; --amber:#fbbf24; --red:#ef4444; --purple:#7c3aed; --orange:#ea580c;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{max-width:100%;overflow-x:hidden}
body{font-family:'Inter',sans-serif;color:var(--ink);-webkit-font-smoothing:antialiased;background:#fff}
.sora{font-family:'Sora',sans-serif}

/* Brand logo lockup */
.brand{display:flex;align-items:center;gap:9px;text-decoration:none}
.brand img,.brand-top img,.crumb img{height:26px;width:auto;display:block;content:url("../assets/generated/veloastra_logoside_transparent.png")}
.brand.logo-light img,.side-logo img{content:url("../assets/generated/veloastra_logoside_white.png")}
.brand-name{font-family:'Sora',sans-serif;font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.3px}
.brand-name span{color:var(--blue)}
.brand-sub{font-size:10px;color:var(--ink-35);font-weight:500}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;font-family:'Inter',sans-serif;font-weight:600;font-size:13.5px;border-radius:8px;cursor:pointer;border:none;transition:all .15s;text-decoration:none}
.btn-ink{background:var(--ink);color:#fff;padding:8px 18px}
.btn-ink:hover{background:var(--blue)}
.btn-teal{background:var(--teal);color:#fff;padding:8px 18px}
.btn-teal:hover{background:var(--teal-d)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink-12);padding:8px 18px}
.btn-outline:hover{border-color:var(--ink)}
.btn-ghost{background:none;color:var(--ink-45);padding:8px 12px}
.btn-block{width:100%;justify-content:center;padding:11px}

/* Badges */
.bdg{font-size:10px;font-weight:600;border-radius:4px;padding:2px 7px;letter-spacing:.2px;text-transform:uppercase}
.bdg-g{background:#ecfdf5;color:#065f46}.bdg-o{background:#fff7ed;color:#9a3412}
.bdg-b{background:#eff6ff;color:#1e40af}.bdg-p{background:#f5f3ff;color:#5b21b6}
.bdg-t{background:#e6fbf7;color:#0f6e60}

/* Cards / inputs */
.card{background:#fff;border:1px solid var(--line);border-radius:16px}
.field{width:100%;height:46px;border:1.5px solid var(--ink-12);border-radius:10px;padding:0 14px;font-size:14px;font-family:'Inter',sans-serif;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}
.field:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(26,115,232,.1)}
.label{font-size:12.5px;font-weight:600;color:var(--ink-70);margin-bottom:6px;display:block}

/* Top nav (public) */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:60px}
.nav-links{display:flex;gap:26px}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--ink-45);text-decoration:none}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:10px}

/* Shared public top navigation */
.global-nav{
  position:sticky;
  top:0;
  z-index:200;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.global-nav-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  min-height:60px;
}
.global-nav-logo{
  display:flex;
  align-items:center;
  gap:9px;
  text-decoration:none;
  flex-shrink:0;
}
.global-nav-logo img{height:24px;width:auto;display:block}
.global-nav-name{font-family:'Sora',sans-serif;font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.3px}
.global-nav-name span{color:var(--blue)}
.global-nav-links{display:flex;align-items:center;gap:8px}
.global-nav-item{position:relative}
.global-nav-trigger,.global-nav-direct{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:9px 8px;
  border:0;
  background:transparent;
  color:var(--ink-45);
  font:500 13.5px 'Inter',sans-serif;
  text-decoration:none;
  cursor:pointer;
  transition:color .15s;
}
.global-nav-trigger:hover,.global-nav-direct:hover,.global-nav-item:hover .global-nav-trigger,.global-nav-item:focus-within .global-nav-trigger{color:var(--ink)}
.global-nav-trigger i{font-size:11px;opacity:.65}
.global-nav-menu{
  position:absolute;
  top:calc(100% + 10px);
  left:-10px;
  width:292px;
  background:#fff;
  border:1px solid rgba(13,26,94,.1);
  border-radius:14px;
  box-shadow:0 18px 48px rgba(13,26,94,.12);
  padding:8px;
  opacity:0;
  visibility:hidden;
  transform:translateY(6px);
  transition:opacity .14s,transform .14s,visibility .14s;
}
.global-nav-item:nth-child(n+3) .global-nav-menu{left:auto;right:-10px}
.global-nav-item:hover .global-nav-menu,.global-nav-item:focus-within .global-nav-menu{opacity:1;visibility:visible;transform:translateY(0)}
.global-nav-menu a{
  display:grid;
  grid-template-columns:34px minmax(0,1fr);
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:10px;
  color:var(--ink);
  text-decoration:none;
}
.global-nav-menu a:hover{background:#f5f8ff}
.global-nav-menu .gni{
  width:34px;
  height:34px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#eff6ff;
  color:var(--blue);
  font-size:17px;
}
.global-nav-menu .gni-blue{background:#eff6ff;color:var(--blue)}
.global-nav-menu .gni-purple{background:#eff6ff;color:var(--blue)}
.global-nav-menu .gni-amber{background:#eff6ff;color:var(--blue)}
.global-nav-menu .gni-teal{background:#eff6ff;color:var(--blue)}
.global-nav-menu .gni-green{background:#eff6ff;color:var(--blue)}
.global-nav-menu .gni-orange{background:#eff6ff;color:var(--blue)}
.global-nav-menu .gni-red{background:#eff6ff;color:var(--blue)}
.global-nav-menu strong{display:block;font-size:13px;font-weight:800}
.global-nav-menu span{display:block;margin-top:2px;font-size:11.5px;color:var(--ink-45);line-height:1.35}
.global-nav-note{
  margin:6px 8px 4px;
  padding:9px 10px;
  border-radius:9px;
  background:#fff7ed;
  color:#9a3412;
  font-size:11.5px;
  line-height:1.45;
}
.global-nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.global-nav-overlay{display:none}
.global-nav .global-nav-menu-btn{display:none}
body.has-global-nav > nav.nav:first-child,
body.has-global-nav > nav:not(.global-nav):first-child{display:none}
@media(max-width:920px){
  .global-nav-inner{padding:0 18px}
  .global-nav-links,.global-nav-actions{display:none}
  .global-nav .global-nav-menu-btn{display:inline-flex}
}

/* App shell (dashboards) */
.shell{display:flex;min-height:100vh;background:var(--bg)}
.side{width:236px;background:var(--ink);min-height:100vh;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;z-index:40;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin}
.side-logo{padding:18px 18px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:9px}
.side-logo img{height:24px;max-width:124px;object-fit:contain}
.side-logo .brand-name{color:#fff}.side-logo .brand-name span{color:#60a5fa}
.side-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:rgba(255,255,255,.22);padding:18px 20px 8px}
.side-nav{padding:0 10px}
.side-link{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;font-size:13.5px;font-weight:500;color:rgba(255,255,255,.45);cursor:pointer;text-decoration:none;margin-bottom:1px;transition:all .15s}
.side-link:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}
.side-link.active{background:rgba(26,115,232,.2);color:#fff}
.side-badge{margin-left:auto;background:var(--blue);color:#fff;font-size:10px;font-weight:700;border-radius:99px;padding:1px 7px}
.main{margin-left:236px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:#fff;border-bottom:1px solid var(--line);padding:0 32px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30}
.content{padding:28px 32px;flex:1}
.page-title{font-family:'Sora',sans-serif;font-size:22px;font-weight:800;letter-spacing:-.6px}
.page-sub{font-size:13.5px;color:var(--ink-45);margin-top:2px}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpi{background:#fff;border:1px solid var(--ink-07);border-radius:14px;padding:18px 20px}
.kpi-label{font-size:12px;font-weight:600;color:var(--ink-35);text-transform:uppercase;letter-spacing:.4px}
.kpi-num{font-family:'Sora',sans-serif;font-size:26px;font-weight:800;letter-spacing:-1px;margin:8px 0 6px}
.kpi-up{background:#ecfdf5;color:#065f46;font-size:12px;font-weight:600;border-radius:99px;padding:2px 8px;display:inline-flex;align-items:center;gap:3px}

/* Section helpers */
.eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--blue)}
.crumb{font-size:13px;color:var(--ink-35)}.crumb b{color:var(--ink);font-weight:600}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tag{font-size:12px;font-weight:500;padding:5px 14px;border-radius:99px;border:1px solid var(--ink-12);color:var(--ink-45);cursor:pointer;background:#fff;transition:all .15s}
.tag:hover,.tag.on{background:var(--ink);color:#fff;border-color:var(--ink)}

@media(max-width:768px){
  .side{position:static;width:100%;min-height:auto;height:auto}
  .main{margin-left:0;width:100%}
  .topbar{padding:0 16px}
  .content{padding:20px 16px}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .grid2,.grid3{grid-template-columns:1fr}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr}
}
