/* ============================================================
   SALES BLUEPRINT — design tokens
   Concept: a technical/construction "blueprint" board. Data
   lives on pinned paper sheets over a deep blueprint-blue grid.
   ============================================================ */
:root{
  --bp-bg:#0E2A47;
  --bp-bg-soft:#123A5E;
  --grid-line:rgba(255,255,255,0.06);
  --grid-line-strong:rgba(255,255,255,0.13);

  --paper:#F6F9FA;
  --paper-alt:#EBF1F4;
  --paper-line:#D7E1E8;

  --ink:#0B2138;
  --ink-soft:#4C6478;
  --ink-faint:#8AA0B2;

  --on-blue:#EAF3FA;
  --on-blue-soft:rgba(234,243,250,0.7);
  --on-blue-faint:rgba(234,243,250,0.42);

  --amber:#FFB627;
  --amber-deep:#E0961A;
  --mint:#17C98D;
  --mint-deep:#0FA575;
  --coral:#FF6B5B;
  --sky:#5AA9E6;
  --violet:#9C86E0;
  --rose:#E07EA8;

  --radius-sm:6px;
  --radius-md:12px;
  --shadow-pin:0 12px 28px rgba(4,14,26,0.38);
  --shadow-soft:0 4px 14px rgba(4,14,26,0.22);

  --font-display:'Space Grotesk', 'Arial Narrow', sans-serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:'IBM Plex Mono', 'SFMono-Regular', Menlo, Consolas, monospace;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--on-blue);
  background-color:var(--bp-bg);
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
    linear-gradient(var(--grid-line-strong) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line-strong) 1px, transparent 1px);
  background-size:24px 24px, 24px 24px, 120px 120px, 120px 120px;
  min-height:100vh;
}

.container{
  max-width:1180px;
  margin:0 auto;
  padding:56px 24px 80px;
}

.hidden{display:none !important;}
.visually-hidden{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

:focus-visible{outline:2px solid var(--amber); outline-offset:2px;}

/* ============ HERO ============ */
.hero{text-align:center; margin-bottom:48px;}
.hero__mark{display:flex; justify-content:center; margin-bottom:14px;}
.hero__eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  color:var(--on-blue-faint);
  margin:0 0 10px;
  text-transform:uppercase;
}
.hero__title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2.2rem, 5vw, 3.4rem);
  letter-spacing:-0.01em;
  margin:0 0 12px;
  color:var(--on-blue);
}
.hero__tagline{
  max-width:560px;
  margin:0 auto 20px;
  color:var(--on-blue-soft);
  font-size:15px;
  line-height:1.6;
}
.hero__ruler{
  width:180px;
  height:8px;
  margin:0 auto 32px;
  background-image:repeating-linear-gradient(90deg, var(--on-blue-faint) 0 1px, transparent 1px 12px);
  background-position:bottom;
  background-repeat:repeat-x;
  background-size:auto 8px;
  opacity:0.6;
}

/* ============ PINNED SHEET (signature element) ============ */
.sheet{
  position:relative;
  background:var(--paper);
  color:var(--ink);
  border-radius:var(--radius-md);
  border:1px solid var(--paper-line);
  box-shadow:var(--shadow-pin);
}
.sheet::before,
.sheet::after{
  content:'+';
  position:absolute;
  font-family:var(--font-mono);
  font-size:14px;
  line-height:1;
  color:var(--ink-faint);
  opacity:0.55;
  pointer-events:none;
}
.sheet::before{top:-7px; left:-7px;}
.sheet::after{bottom:-7px; right:-7px;}

.sheet--tilt-l{transform:rotate(-0.55deg);}
.sheet--tilt-r{transform:rotate(0.45deg);}

.sheet__pin{
  position:absolute;
  top:-9px;
  left:50%;
  transform:translateX(-50%);
  width:14px;
  height:14px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #FFD98C, var(--amber-deep) 75%);
  box-shadow:0 3px 6px rgba(4,14,26,0.45);
}

/* ============ DROPZONE ============ */
.dropzone{
  max-width:520px;
  margin:0 auto;
  padding:40px 32px;
  text-align:center;
  cursor:pointer;
  border-style:dashed;
  border-width:2px;
  border-color:var(--paper-line);
  transition:border-color .15s ease, background-color .15s ease;
}
.dropzone.is-active{
  border-color:var(--amber);
  background:var(--paper-alt);
}
.dropzone__icon{margin-bottom:8px;}
.dropzone__text{margin:4px 0 2px; font-size:15px;}
.dropzone__sub{margin:0 0 18px; font-size:12.5px; color:var(--ink-soft);}

.filelist{
  max-width:560px;
  margin:20px auto 0;
  display:flex;
  flex-direction:column;
  gap:8px;
  text-align:left;
}
.fileitem{
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--bp-bg-soft);
  border:1px solid var(--grid-line-strong);
  border-radius:var(--radius-sm);
  padding:10px 12px;
  font-size:13px;
}
.fileitem__status{
  flex:none;
  width:18px; height:18px;
  display:flex; align-items:center; justify-content:center;
}
.fileitem__body{flex:1; min-width:0;}
.fileitem__name{
  font-family:var(--font-mono);
  font-size:12.5px;
  color:var(--on-blue);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.fileitem__msg{font-size:12px; color:var(--on-blue-faint); margin-top:2px;}
.fileitem--error .fileitem__msg{color:var(--coral);}
.fileitem__remove{
  flex:none;
  background:none; border:none; cursor:pointer;
  color:var(--on-blue-faint);
  font-size:16px; line-height:1;
  padding:4px;
}
.fileitem__remove:hover{color:var(--coral);}

.spinner{
  width:14px; height:14px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,0.25);
  border-top-color:var(--amber);
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ============ BUTTONS ============ */
.btn{
  font-family:var(--font-body);
  font-weight:600;
  font-size:13.5px;
  border-radius:999px;
  padding:10px 20px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .1s ease, filter .15s ease, background-color .15s ease;
}
.btn:active{transform:scale(0.97);}
.btn--primary{
  background:var(--amber);
  color:var(--ink);
}
.btn--primary:hover{filter:brightness(1.06);}
.btn--ghost{
  background:transparent;
  border-color:var(--on-blue-faint);
  color:var(--on-blue);
  font-size:12.5px;
  padding:8px 16px;
}
.btn--ghost:hover{border-color:var(--amber); color:var(--amber);}
.btn--danger-armed{
  border-color:var(--coral) !important;
  color:var(--coral) !important;
}

/* ============ DASHBOARD LAYOUT ============ */
.dashboard{display:flex; flex-direction:column; gap:28px;}

/* ============ FILTER BAR ============ */
.filterbar{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:20px 26px;
  padding:20px 24px;
  position:sticky;
  top:14px;
  z-index:30;
}
.filterbar__group{display:flex; flex-direction:column; gap:6px;}
.filterbar__group--rate{margin-left:auto;}
.filterbar__label{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.btn--addmore{
  color:var(--ink);
  border-color:var(--paper-line);
  align-self:flex-start;
}
.btn--addmore:hover{border-color:var(--amber-deep); color:var(--amber-deep);}
.btn--reset{
  color:var(--ink-soft);
  border-color:var(--paper-line);
  align-self:flex-end;
}
.btn--reset:hover{border-color:var(--coral); color:var(--coral);}

.chips{display:flex; flex-wrap:wrap; gap:6px; max-width:260px;}
.chip{
  font-family:var(--font-body);
  font-size:12.5px;
  font-weight:500;
  background:var(--paper-alt);
  border:1px solid var(--paper-line);
  color:var(--ink-faint);
  border-radius:999px;
  padding:6px 12px 6px 10px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:opacity .12s ease, border-color .12s ease, color .12s ease;
}
.chip__dot{width:8px; height:8px; border-radius:50%; flex:none;}
.chip.is-active{color:var(--chip-color, var(--ink)); border-color:var(--chip-color, var(--ink)); font-weight:600;}
.chip:not(.is-active){opacity:0.55;}
.chip:hover{opacity:1;}
.chips--presets{max-width:none; margin-top:2px;}
.chip--preset{padding:5px 10px; font-size:11.5px;}
.chip--preset.is-active{background:var(--ink); color:var(--paper); border-color:var(--ink);}

.daterange{display:flex; align-items:center; gap:6px;}
.daterange__sep{color:var(--ink-faint);}

.field-input{
  font-family:var(--font-mono);
  font-size:12.5px;
  background:var(--paper-alt);
  border:1px solid var(--paper-line);
  border-radius:var(--radius-sm);
  color:var(--ink);
  padding:7px 10px;
}
.field-input--date{width:132px;}
.rate-input{
  display:flex; align-items:center; gap:5px;
  font-family:var(--font-mono);
  font-size:12.5px;
  color:var(--ink-soft);
}
.field-input--rate{width:80px;}

/* ============ KPIs ============ */
.kpis{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(168px, 1fr));
  gap:16px;
}
.kpi{
  padding:18px 18px 16px;
}
.kpi:nth-child(odd){transform:rotate(-0.35deg);}
.kpi:nth-child(even){transform:rotate(0.3deg);}
.kpi__label{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin:0 0 8px;
}
.kpi__value{
  font-family:var(--font-mono);
  font-weight:600;
  font-size:clamp(1.35rem, 2.4vw, 1.7rem);
  margin:0;
  font-variant-numeric:tabular-nums;
}
.kpi__value--mint{color:var(--mint-deep);}
.kpi__value--amber{color:var(--amber-deep);}
.kpi__value--coral{color:var(--coral);}
.kpi__value--ink{color:var(--ink);}
.kpi__sub{font-size:11.5px; color:var(--ink-faint); margin:6px 0 0;}

/* ============ FIGURES ============ */
.figures-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.figure{padding:22px 24px 20px;}
.figure--wide{padding:22px 26px 18px;}
.figure__head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
}
.figure__eyebrow{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.09em;
  color:var(--ink-faint);
  margin:0 0 6px;
}
.figure__title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:17px;
  margin:0 0 14px;
  color:var(--ink);
}
.figure__canvas-wrap{position:relative; height:240px;}
.figure__canvas-wrap--tall{height:300px;}

.toggle{
  display:inline-flex;
  background:var(--paper-alt);
  border:1px solid var(--paper-line);
  border-radius:999px;
  padding:3px;
}
.toggle__btn{
  font-family:var(--font-body);
  font-size:12px;
  font-weight:600;
  border:none;
  background:transparent;
  color:var(--ink-soft);
  border-radius:999px;
  padding:6px 14px;
  cursor:pointer;
}
.toggle__btn.is-active{background:var(--ink); color:var(--paper);}

.empty-state{
  text-align:center;
  color:var(--ink-faint);
  font-size:13px;
  padding:30px 10px;
}

/* ============ EXPLORER ============ */
.explorer{padding:24px 26px 20px;}
.explorer__head{margin-bottom:16px;}
.explorer__toolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.explorer__field{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--ink-soft);
}
.explorer__field select.field-input{padding:7px 10px;}
.explorer__field--search{flex:1; min-width:180px;}
.explorer__field--search .field-input{width:100%;}

.table-wrap{overflow-x:auto; border:1px solid var(--paper-line); border-radius:var(--radius-sm);}
.data-table{width:100%; border-collapse:collapse; font-size:13px;}
.data-table thead th{
  position:sticky; top:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  text-align:left;
  padding:10px 12px;
  cursor:pointer;
  white-space:nowrap;
  user-select:none;
}
.data-table thead th.is-numeric{text-align:right;}
.data-table thead th .arrow{opacity:0.55; margin-left:4px; font-size:10px;}
.data-table tbody td{
  padding:9px 12px;
  border-top:1px solid var(--paper-line);
  white-space:nowrap;
}
.data-table tbody tr:nth-child(even){background:var(--paper-alt);}
.data-table tbody tr:hover{background:#E4EEF3;}
.data-table td.is-numeric{
  text-align:right;
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
}
.data-table td.is-label{max-width:280px; overflow:hidden; text-overflow:ellipsis;}
.bar-cell{position:relative;}
.bar-cell__fill{
  position:absolute; left:0; top:0; bottom:0;
  background:rgba(23,201,141,0.16);
  z-index:0;
}
.bar-cell__text{position:relative; z-index:1;}

.pagination{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-top:14px;
  font-size:12.5px;
  color:var(--ink-soft);
}
.pagination button{
  font-family:var(--font-mono);
  background:var(--paper-alt);
  border:1px solid var(--paper-line);
  border-radius:var(--radius-sm);
  padding:6px 12px;
  cursor:pointer;
  color:var(--ink);
}
.pagination button:disabled{opacity:0.35; cursor:not-allowed;}

.footer-note{
  max-width:760px;
  margin:8px auto 0;
  text-align:center;
  font-size:12px;
  line-height:1.6;
  color:var(--on-blue-faint);
}

/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .figures-grid{grid-template-columns:1fr;}
  .filterbar{position:static;}
  .filterbar__group--rate{margin-left:0;}
}
@media (max-width:560px){
  .container{padding:36px 14px 60px;}
  .dropzone{padding:28px 18px;}
  .kpis{grid-template-columns:repeat(2, 1fr);}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important;}
}