/* ============================================================
   SplitFire UI — design tokens + component library
   v1.0 · applies across www / sentinel / corp
   Design language: near-black canvas, hairline borders,
   Shocking Orange signature accent, General Sans typography.
   ============================================================ */

/* ---------- 1. Tokens ---------- */
:root{
  /* canvas + surfaces */
  --sf-bg:        #060607;
  --sf-bg-2:      #0B0C0E;
  --sf-panel:     #101114;
  --sf-panel-2:   #15161A;
  --sf-inset:     #0A0B0D;
  --sf-line:      rgba(255,255,255,.07);
  --sf-line-2:    rgba(255,255,255,.12);

  /* text */
  --sf-txt:       #F2F3F5;
  --sf-txt-2:     #C9CBD1;
  --sf-muted:     #96979C;   /* sporty grey */
  --sf-dim:       #5E6065;

  /* brand accents */
  --sf-orange:    #FF8127;   /* shocking orange — signature */
  --sf-orange-2:  #FFA45C;
  --sf-orange-dim:rgba(255,129,39,.14);
  --sf-blue:      #5163FF;   /* laser blue */
  --sf-blue-dim:  rgba(81,99,255,.16);
  --sf-green:     #3EB75E;   /* chateau green */
  --sf-green-dim: rgba(62,183,94,.15);
  --sf-red:       #F0524D;
  --sf-red-dim:   rgba(240,82,77,.15);
  --sf-amber:     #FFCF5C;
  --sf-amber-dim: rgba(255,207,92,.14);

  /* effects */
  --sf-glow-orange: 0 0 24px rgba(255,129,39,.35);
  --sf-glow-soft:   0 24px 60px -28px rgba(0,0,0,.75);
  --sf-ring:        0 0 0 3px rgba(255,129,39,.25);

  /* shape + rhythm */
  --sf-r-sm: 8px;
  --sf-r:    12px;
  --sf-r-lg: 16px;
  --sf-r-xl: 24px;
  --sf-gap:  16px;
  --sf-maxw: 1160px;

  /* type */
  --sf-font: 'General Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --sf-mono: 'SF Mono', ui-monospace, Menlo, Consolas, monospace;
}

/* ---------- 2. Base ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body.sf{
  background:var(--sf-bg);
  color:var(--sf-txt);
  font-family:var(--sf-font);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
.sf a{color:inherit;text-decoration:none}
.sf ::selection{background:var(--sf-orange-dim);color:var(--sf-orange-2)}
.sf-wrap{max-width:var(--sf-maxw);margin:0 auto;padding:0 24px}
.sf-mono{font-family:var(--sf-mono)}

/* type scale — mirrors the reference (H1 bold, H2/H3 semibold, H4 medium) */
.sf h1,.sf-h1{font-size:clamp(34px,5.4vw,58px);font-weight:700;letter-spacing:-.02em;line-height:1.08}
.sf h2,.sf-h2{font-size:clamp(24px,3.2vw,34px);font-weight:600;letter-spacing:-.015em;line-height:1.15}
.sf h3,.sf-h3{font-size:19px;font-weight:600;line-height:1.3}
.sf h4,.sf-h4{font-size:16px;font-weight:500;line-height:1.35}
.sf-lead{font-size:clamp(15px,1.8vw,18px);color:var(--sf-muted);max-width:640px}
.sf-small{font-size:12.5px;color:var(--sf-muted)}
.sf-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--sf-dim);font-weight:500}
.sf-grad{background:linear-gradient(120deg,#FFFFFF 20%,var(--sf-orange-2) 65%,var(--sf-orange));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* section marker — orange radial dot + label (reference signature) */
.sf-marker{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--sf-txt-2)}
.sf-marker::before{content:"";width:9px;height:9px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, var(--sf-orange-2), var(--sf-orange) 60%, rgba(255,129,39,.2));
  box-shadow:0 0 12px rgba(255,129,39,.8)}

/* ---------- 3. Nav ---------- */
.sf-nav{position:sticky;top:0;z-index:50;background:rgba(6,6,7,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--sf-line)}
.sf-nav-in{max-width:var(--sf-maxw);margin:0 auto;display:flex;align-items:center;gap:24px;padding:0 24px;height:62px}
.sf-brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15.5px;letter-spacing:.01em}
.sf-brand .sf-logo{width:26px;height:26px;border-radius:7px;flex:0 0 auto;position:relative;
  background:conic-gradient(from 210deg,var(--sf-orange),#B34A0E 40%,var(--sf-orange-2) 80%,var(--sf-orange));
  box-shadow:0 0 18px rgba(255,129,39,.45)}
.sf-brand .sf-logo::after{content:"";position:absolute;inset:5px;border-radius:4px;background:var(--sf-bg);
  clip-path:polygon(50% 8%,92% 92%,8% 92%)}
.sf-nav-links{display:flex;gap:22px;align-items:center;margin-left:8px}
.sf-nav-links a{color:var(--sf-muted);font-size:13.5px;font-weight:500;transition:color .18s}
.sf-nav-links a:hover,.sf-nav-links a.on{color:var(--sf-txt)}
.sf-nav-cta{margin-left:auto;display:flex;gap:10px;align-items:center}
@media(max-width:760px){.sf-nav-links .sf-hide-sm{display:none}}

/* ---------- 4. Buttons ---------- */
.sf-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:10px;padding:10px 18px;font-size:13.5px;font-weight:600;font-family:var(--sf-font);
  border:1px solid transparent;cursor:pointer;transition:transform .16s,box-shadow .16s,background .16s,border-color .16s;
  white-space:nowrap;line-height:1.2}
.sf-btn:focus-visible{outline:none;box-shadow:var(--sf-ring)}
.sf-btn-primary{background:linear-gradient(135deg,var(--sf-orange),#E96A12);color:#160A02;
  box-shadow:0 8px 26px -10px rgba(255,129,39,.55)}
.sf-btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 32px -12px rgba(255,129,39,.7)}
.sf-btn-ghost{background:rgba(255,255,255,.03);border-color:var(--sf-line-2);color:var(--sf-txt)}
.sf-btn-ghost:hover{border-color:var(--sf-orange);background:var(--sf-orange-dim)}
.sf-btn-danger{background:var(--sf-red-dim);border-color:rgba(240,82,77,.35);color:var(--sf-red)}
.sf-btn-danger:hover{background:rgba(240,82,77,.24)}
.sf-btn-lg{padding:13px 26px;font-size:14.5px;border-radius:12px}
.sf-btn-sm{padding:6px 12px;font-size:12px;border-radius:8px}
.sf-btn[disabled]{opacity:.45;cursor:not-allowed;transform:none}

/* segmented control (Day / Monthly / Yearly) */
.sf-seg{display:inline-flex;background:var(--sf-inset);border:1px solid var(--sf-line);border-radius:10px;padding:3px;gap:2px}
.sf-seg button,.sf-seg a{border:none;background:transparent;color:var(--sf-muted);font-family:var(--sf-font);
  font-size:12.5px;font-weight:500;padding:6px 14px;border-radius:8px;cursor:pointer;transition:all .15s}
.sf-seg .on{background:var(--sf-panel-2);color:var(--sf-txt);box-shadow:inset 0 0 0 1px var(--sf-line-2)}

/* ---------- 5. Chips / tags / deltas ---------- */
.sf-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:6px;
  font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;line-height:1.5}
.sf-chip-orange{background:var(--sf-orange-dim);color:var(--sf-orange-2)}
.sf-chip-blue{background:var(--sf-blue-dim);color:#8B97FF}
.sf-chip-green{background:var(--sf-green-dim);color:#5ED07E}
.sf-chip-red{background:var(--sf-red-dim);color:#FF7B76}
.sf-chip-amber{background:var(--sf-amber-dim);color:var(--sf-amber)}
.sf-chip-grey{background:rgba(255,255,255,.06);color:var(--sf-muted)}
/* semantic aliases used by app pages */
.sf-chip-active{background:var(--sf-green-dim);color:#5ED07E}
.sf-chip-pending{background:var(--sf-amber-dim);color:var(--sf-amber)}
.sf-chip-revoked,.sf-chip-cancelled,.sf-chip-halted,.sf-chip-past_due{background:var(--sf-red-dim);color:#FF7B76}
.sf-chip-completed{background:rgba(255,255,255,.06);color:var(--sf-muted)}
.sf-chip-free{background:var(--sf-blue-dim);color:#8B97FF}
.sf-chip-dev{background:var(--sf-green-dim);color:#5ED07E}
.sf-chip-startup{background:var(--sf-orange-dim);color:var(--sf-orange-2)}
.sf-chip-enterprise{background:rgba(231,121,249,.14);color:#E879F9}
.sf-chip-admin{background:var(--sf-red-dim);color:#FF7B76}
.sf-chip-customer{background:var(--sf-green-dim);color:#5ED07E}
.sf-chip-razorpay{background:var(--sf-blue-dim);color:#8B97FF}
.sf-chip-system{background:rgba(255,255,255,.06);color:var(--sf-muted)}
/* delta chip: ▲ / ▼ percentage */
.sf-delta{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;
  padding:2px 7px;border-radius:5px}
.sf-delta.up{background:var(--sf-green-dim);color:#5ED07E}
.sf-delta.down{background:var(--sf-red-dim);color:#FF7B76}

/* ---------- 6. Cards & panels ---------- */
.sf-card{background:var(--sf-panel);border:1px solid var(--sf-line);border-radius:var(--sf-r-lg);padding:22px}
.sf-card-hover{transition:border-color .2s,transform .2s}
.sf-card-hover:hover{border-color:rgba(255,129,39,.35);transform:translateY(-2px)}
.sf-card h2.sf-card-title,.sf-card-title{font-size:12px;font-weight:600;letter-spacing:.07em;
  text-transform:uppercase;color:var(--sf-muted);margin-bottom:14px}
.sf-inset{background:var(--sf-inset);border:1px solid var(--sf-line);border-radius:var(--sf-r)}
/* framed hero panel — the "device frame" look */
.sf-frame{background:var(--sf-bg-2);border:1px solid var(--sf-line-2);border-radius:var(--sf-r-xl);
  box-shadow:var(--sf-glow-soft),0 0 80px -30px rgba(255,129,39,.25);overflow:hidden}

/* stat tile: icon ring + number + delta */
.sf-stat{display:flex;align-items:center;gap:14px;padding:14px 4px;border-bottom:1px solid var(--sf-line)}
.sf-stat:last-child{border-bottom:none}
.sf-stat .ic{width:38px;height:38px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--sf-line-2);background:var(--sf-inset);font-size:15px}
.sf-stat .num{font-size:20px;font-weight:700;letter-spacing:-.01em;line-height:1.15}
.sf-stat .lbl{font-size:12px;color:var(--sf-muted)}
/* big stat cards (grids) */
.sf-bignum{font-size:clamp(22px,3vw,30px);font-weight:700;letter-spacing:-.015em}
.sf-bignum.orange{color:var(--sf-orange)}
.sf-bignum.green{color:#5ED07E}
.sf-bignum.blue{color:#8B97FF}
.sf-bignum.red{color:#FF7B76}

/* key-value rows */
.sf-kv{display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:9px 0;border-bottom:1px solid var(--sf-line);font-size:13px}
.sf-kv:last-child{border-bottom:none}
.sf-kv .k{color:var(--sf-muted)}
.sf-kv .v{color:var(--sf-txt-2);font-weight:500;text-align:right}

/* ---------- 7. Tables ---------- */
.sf-table{width:100%;border-collapse:collapse;font-size:13px}
.sf-table th{text-align:left;padding:10px 12px;color:var(--sf-dim);font-size:10.5px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--sf-line);background:var(--sf-inset)}
.sf-table td{padding:11px 12px;border-bottom:1px solid var(--sf-line);vertical-align:middle;color:var(--sf-txt-2)}
.sf-table tr:last-child td{border-bottom:none}
.sf-table tbody tr{transition:background .12s}
.sf-table tbody tr:hover td{background:rgba(255,129,39,.04)}
.sf-table .rowlink{cursor:pointer}

/* ---------- 8. Forms ---------- */
.sf-input,.sf-select{width:100%;padding:12px 14px;background:var(--sf-inset);border:1px solid var(--sf-line-2);
  border-radius:10px;color:var(--sf-txt);font-size:13.5px;font-family:var(--sf-font);transition:border-color .15s,box-shadow .15s}
.sf-input:focus,.sf-select:focus{outline:none;border-color:var(--sf-orange);box-shadow:var(--sf-ring)}
.sf-input::placeholder{color:var(--sf-dim)}
.sf-input.mono{font-family:var(--sf-mono);font-size:12.5px}
.sf-field{margin-bottom:14px}
.sf-field label{display:block;font-size:11px;letter-spacing:.07em;text-transform:uppercase;
  color:var(--sf-muted);font-weight:500;margin-bottom:7px}
.sf-search{max-width:260px;padding:9px 13px}

/* ---------- 9. Meters / bars ---------- */
.sf-meter{height:9px;background:var(--sf-inset);border-radius:5px;overflow:hidden;border:1px solid var(--sf-line)}
.sf-meter .fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--sf-orange),var(--sf-orange-2));
  box-shadow:0 0 10px rgba(255,129,39,.5);transition:width .4s}
.sf-meter.warn .fill{background:linear-gradient(90deg,var(--sf-amber),#FFDF8C)}
.sf-meter.crit .fill{background:linear-gradient(90deg,var(--sf-red),#FF8A86)}
/* horizontal bar rows (behavioral-patterns style) */
.sf-bar-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:12.5px}
.sf-bar-row .lbl{width:150px;color:var(--sf-txt-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sf-bar-row .track{flex:1;height:9px;background:var(--sf-inset);border-radius:5px;overflow:hidden}
.sf-bar-row .fill{height:100%;display:block;border-radius:5px;
  background:linear-gradient(90deg,var(--sf-orange),var(--sf-orange-2));box-shadow:0 0 8px rgba(255,129,39,.4)}
.sf-bar-row .val{width:72px;text-align:right;color:var(--sf-muted);font-variant-numeric:tabular-nums}

/* ---------- 10. Overlays ---------- */
.sf-modal-back{display:none;position:fixed;inset:0;background:rgba(4,4,5,.86);backdrop-filter:blur(6px);
  z-index:100;overflow-y:auto;padding:34px 16px}
.sf-modal-back.show{display:block}
.sf-modal{background:var(--sf-panel);border:1px solid var(--sf-line-2);border-radius:var(--sf-r-lg);
  max-width:920px;margin:0 auto;padding:26px;box-shadow:var(--sf-glow-soft)}
.sf-toast{position:fixed;bottom:22px;right:22px;background:var(--sf-panel-2);border:1px solid var(--sf-line-2);
  border-radius:10px;padding:12px 20px;font-size:13px;display:none;z-index:1000;box-shadow:var(--sf-glow-soft)}
.sf-toast.ok{display:block;border-color:rgba(62,183,94,.4);color:#5ED07E}
.sf-toast.err{display:block;border-color:rgba(240,82,77,.4);color:#FF7B76}

/* ---------- 11. Charts (SVG hooks) ---------- */
.sf-chart-line{stroke:var(--sf-orange);stroke-width:2;fill:none;filter:drop-shadow(0 0 6px rgba(255,129,39,.55))}
.sf-chart-line.blue{stroke:var(--sf-blue);filter:drop-shadow(0 0 6px rgba(81,99,255,.5))}
.sf-chart-dot{fill:var(--sf-orange-2)}
.sf-chart-axis{stroke:var(--sf-line-2)}
.sf-chart-text{fill:var(--sf-dim);font-size:10px;font-family:var(--sf-font)}
.sf-chart-area{fill:url(#sfAreaGrad)}

/* ---------- 12. Misc ---------- */
.sf-grid{display:grid;gap:var(--sf-gap)}
.sf-grid-2{grid-template-columns:1fr 1fr}
.sf-grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.sf-grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.sf-cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
@media(max-width:820px){.sf-grid-2{grid-template-columns:1fr}}
.sf-divider{height:1px;background:var(--sf-line);border:none;margin:26px 0}
.sf-empty{text-align:center;padding:28px;color:var(--sf-dim);font-size:13px}
.sf-err{color:#FF7B76;font-size:12px;margin-top:8px}
.sf-footer{border-top:1px solid var(--sf-line);padding:34px 0;margin-top:60px}
.sf-footer-in{max-width:var(--sf-maxw);margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:16px;font-size:12.5px;color:var(--sf-dim)}
.sf-footer-in a{color:var(--sf-muted)}
.sf-footer-in a:hover{color:var(--sf-txt)}
.sf-code{background:var(--sf-inset);border:1px solid var(--sf-line);border-radius:10px;padding:14px;
  font-family:var(--sf-mono);font-size:12.5px;color:var(--sf-orange-2);overflow-x:auto;word-break:break-all;display:block}
.sf-glow-orb{position:fixed;border-radius:50%;filter:blur(130px);opacity:.35;z-index:0;pointer-events:none}
.sf-glow-orb.a{width:480px;height:480px;background:rgba(255,129,39,.5);top:-180px;right:-120px}
.sf-glow-orb.b{width:420px;height:420px;background:rgba(81,99,255,.35);bottom:-200px;left:-140px;opacity:.22}
.sf-z{position:relative;z-index:1}
/* pill link list (linkrow) */
.sf-links{display:flex;gap:16px;flex-wrap:wrap;font-size:13px}
.sf-links a{color:var(--sf-orange-2);font-weight:500}
.sf-links a:hover{color:var(--sf-orange)}
/* login card */
.sf-auth{max-width:440px;margin:72px auto;padding:32px}
/* tabs (admin) */
.sf-tabs{display:flex;gap:6px;margin:14px 0 20px;flex-wrap:wrap}
.sf-tabs button{background:var(--sf-panel);border:1px solid var(--sf-line);color:var(--sf-muted);
  padding:9px 18px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--sf-font);transition:all .15s}
.sf-tabs button.on{background:var(--sf-orange-dim);color:var(--sf-orange-2);border-color:rgba(255,129,39,.4)}
