/* Ramprt Glance app styles. Brand tokens + base reset live in tokens.css,
   which must be linked BEFORE this file. The shared marketing nav (site.css)
   is also loaded here for a seamless header; align its width to the app canvas. */
  body{background:var(--stone);color:var(--charcoal);font-family:var(--font);line-height:1.5;min-height:100vh}
  .wrap{max-width:1080px;margin:0 auto;padding:0 28px 80px}
  .site-nav .inner{max-width:1080px;padding:0 28px}

  /* ───────── Brand bar ───────── */
  .topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 0;border-bottom:1px solid var(--border)}
  .brand{display:flex;align-items:center;gap:11px}
  .glyph{width:30px;height:30px;flex:none}
  .brand .name{font-weight:800;font-size:18px;letter-spacing:-.01em;line-height:1}
  .brand .sub{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);margin-top:3px;font-weight:700}
  .live{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--slate);font-weight:600;
    background:var(--white);border:1px solid var(--border);padding:6px 11px;border-radius:100px}
  .live .dot{width:7px;height:7px;border-radius:50%;background:var(--sage);box-shadow:0 0 0 0 rgba(107,160,157,.5);animation:pulse 2.4s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(107,160,157,.45)}70%{box-shadow:0 0 0 7px rgba(107,160,157,0)}100%{box-shadow:0 0 0 0 rgba(107,160,157,0)}}

  /* ───────── Property + ranges ───────── */
  .head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin:30px 0 22px;flex-wrap:wrap}
  .eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);font-weight:700;margin-bottom:12px}
  .property{display:flex;align-items:center;gap:12px}
  .favicon{width:30px;height:30px;border-radius:6px;background:var(--teal);display:grid;place-items:center;
    color:var(--charcoal);font-weight:800;font-size:15px}
  .property h1{font-weight:800;font-size:30px;letter-spacing:-.02em;line-height:1}
  .ranges{display:flex;gap:3px;background:var(--white);border:1px solid var(--border);border-radius:100px;padding:4px}
  .ranges button{font-family:var(--font);font-weight:700;font-size:12px;color:var(--slate);
    border:0;background:transparent;padding:7px 14px;border-radius:100px;cursor:pointer;transition:.15s}
  .ranges button:hover{color:var(--charcoal)}
  .ranges button.on{background:var(--charcoal);color:var(--white)}

  /* ───────── Stat tiles ───────── */
  .tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
  .tile{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px;
    cursor:pointer;transition:transform .16s,box-shadow .16s,border-color .16s;position:relative;overflow:hidden}
  .tile:hover{transform:translateY(-2px);box-shadow:0 10px 24px -16px rgba(33,33,33,.4)}
  .tile.on{border-color:var(--charcoal)}
  .tile.on::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--teal)}
  .tile .lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);font-weight:700}
  .tile .val{font-weight:800;font-size:33px;letter-spacing:-.02em;margin:10px 0 7px;line-height:1}
  .tile .delta{font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:6px}
  .delta.up{color:var(--sage)} .delta.down{color:var(--slate)}
  .delta .arw{font-size:10px}
  .delta .vs{color:var(--grey-mid);font-weight:600}

  /* ───────── Chart ───────── */
  .chart-card{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:20px 20px 12px;margin-bottom:14px}
  .ctitle{display:flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);font-weight:700;margin-bottom:14px}
  .ctitle .sw{width:10px;height:10px;border-radius:2px;background:var(--charcoal)}
  .chart-svg{width:100%;height:210px;display:block}
  .xaxis{display:flex;justify-content:space-between;font-size:11px;color:var(--grey-mid);font-weight:600;
    padding:8px 2px 2px;border-top:1px solid var(--border);margin-top:4px}

  /* ───────── Panels ───────── */
  .panels{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
  .panel{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:18px 20px 10px}
  .ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
  .ph h3{font-weight:800;font-size:15px;letter-spacing:-.01em}
  .ph .phlabel{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-mid);font-weight:700}
  .row{position:relative;display:flex;align-items:center;justify-content:space-between;
    padding:9px 10px;margin:0 -10px;border-radius:4px;font-size:13.5px;transition:background .12s}
  .row:hover{background:var(--stone)}
  .row .bar{position:absolute;left:0;top:0;bottom:0;background:var(--teal-tint-soft);border-radius:4px;z-index:0}
  .row .rl{position:relative;z-index:1;color:var(--charcoal);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:74%}
  .row .rl .path{color:var(--grey-mid);font-weight:500}
  .row .rv{position:relative;z-index:1;font-size:12.5px;color:var(--slate);font-weight:700}
  .src{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:9px;vertical-align:middle}

  .legend{display:flex;gap:15px;font-size:12px;color:var(--slate);font-weight:600;flex-wrap:wrap;margin-bottom:7px}
  .legend i{width:9px;height:9px;border-radius:2px;display:inline-block;margin-right:6px;vertical-align:middle}
  .split{display:flex;height:8px;border-radius:4px;overflow:hidden;margin:2px 0 14px}
  .split span{display:block;height:100%}

  /* ───────── Email capture ───────── */
  .capture{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
    background:var(--white);border:1px dashed var(--grey-mid);border-radius:8px;padding:18px 22px;margin-bottom:14px}
  .capture .ct{max-width:58%}
  .capture h4{font-weight:800;font-size:16px;margin-bottom:3px;letter-spacing:-.01em}
  .capture p{font-size:13px;color:var(--slate)}
  .capture form{display:flex;gap:8px}
  .capture input{font-family:var(--font);font-size:13.5px;padding:10px 13px;border:1px solid var(--border);
    border-radius:8px;background:var(--stone);min-width:200px;color:var(--charcoal)}
  .capture input::placeholder{color:var(--grey-mid)}
  .btn{font-family:var(--font);font-weight:700;font-size:13.5px;border:0;border-radius:8px;cursor:pointer;
    padding:11px 18px;transition:.15s;white-space:nowrap}
  .btn-dark{background:var(--charcoal);color:var(--white)} .btn-dark:hover{background:#000}
  .btn-teal{background:var(--teal);color:var(--charcoal)} .btn-teal:hover{filter:brightness(.94)}

  /* ───────── Ramprt cross-sell ───────── */
  .crosssell{background:var(--charcoal);color:var(--white);border-radius:8px;padding:24px 26px;
    display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;position:relative;overflow:hidden}
  /* subtle horizon lines, no text over them */
  .crosssell .horizon{position:absolute;right:0;top:0;bottom:0;width:38%;opacity:.5;pointer-events:none}
  .crosssell .cs-l{position:relative;z-index:1;max-width:64%}
  .pill{display:inline-block;font-size:11px;padding:3px 9px;border-radius:100px;font-weight:700;letter-spacing:.04em}
  .pill.purple{background:var(--purple);color:var(--white)}
  .crosssell h4{font-weight:800;font-size:21px;line-height:1.25;letter-spacing:-.015em;margin:10px 0 8px}
  .crosssell p{font-size:13.5px;color:#C9C9C9}
  .crosssell .hot{color:var(--charcoal);background:var(--teal);padding:0 5px;font-weight:800}
  .crosssell .n{color:var(--white);font-weight:800}

  .footnote{text-align:center;font-size:11px;color:var(--grey-mid);margin-top:26px;font-weight:600;letter-spacing:.04em}

  .reveal{opacity:0;transform:translateY(10px);animation:rise .55s cubic-bezier(.2,.7,.2,1) forwards}
  @keyframes rise{to{opacity:1;transform:none}}
  .d1{animation-delay:.04s}.d2{animation-delay:.10s}.d3{animation-delay:.16s}.d4{animation-delay:.22s}
  .d5{animation-delay:.29s}.d6{animation-delay:.36s}.d7{animation-delay:.43s}.d8{animation-delay:.50s}

  @media(max-width:860px){
    .tiles{grid-template-columns:1fr 1fr}.panels{grid-template-columns:1fr}
    .crosssell .cs-l,.capture .ct{max-width:100%}.crosssell .horizon{display:none}
  }

/* ---- app additions (connect wizard, capture states) ---- */
.thanks{font-weight:700;color:var(--charcoal)}
.err{color:var(--clay,#B14A33);font-size:13px;margin-top:8px;font-weight:600}
.connect{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:28px 30px;margin-top:30px;max-width:680px}
.connect-h{font-weight:800;font-size:26px;letter-spacing:-.02em;margin-bottom:6px}
.connect-sub{color:var(--slate);font-size:14px;margin-bottom:22px}
.steps{list-style:none;counter-reset:s;padding:0}
.steps li{counter-increment:s;position:relative;padding:0 0 22px 40px;font-size:14px;line-height:1.65;color:var(--slate)}
.steps li::before{content:counter(s);position:absolute;left:0;top:-2px;width:26px;height:26px;border-radius:100px;background:var(--charcoal);color:var(--white);font-weight:800;font-size:13px;display:grid;place-items:center}
.steps li:last-child{padding-bottom:0}
.steps strong{color:var(--charcoal);display:block;margin-bottom:4px;font-size:14px}
.steps code{background:var(--stone);padding:3px 8px;border-radius:4px;font-size:12.5px;color:var(--charcoal);word-break:break-all}
.steps .field{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.steps input{font-family:var(--font);font-size:14px;padding:10px 13px;border:1px solid var(--border);border-radius:8px;min-width:200px}
.copybtn{margin-left:8px;padding:5px 12px;font-size:12px}


/* ===== Plausible-parity components ===== */
.head{align-items:center}
.controls{display:flex;align-items:center;gap:10px}
.range-select{font-family:var(--font);font-weight:700;font-size:13px;color:var(--charcoal);background:var(--white);
  border:1px solid var(--border);border-radius:8px;padding:8px 12px;cursor:pointer}
.compare-btn{font-family:var(--font);font-weight:700;font-size:13px;color:var(--slate);background:var(--white);
  border:1px solid var(--border);border-radius:8px;padding:8px 12px;cursor:pointer}
.compare-btn.on{background:var(--charcoal);color:var(--white);border-color:var(--charcoal)}

/* 6 KPI tiles */
.tiles{grid-template-columns:repeat(6,1fr)}
button.tile{font-family:var(--font);text-align:left;width:100%;display:block}
.tile .val{font-size:27px}
.delta.good{color:var(--sage)} .delta.bad{color:var(--clay,#B14A33)} .delta.flat{color:var(--grey-mid)}

/* filter chips */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--charcoal);color:var(--white);
  font-size:12.5px;font-weight:600;padding:5px 6px 5px 11px;border-radius:100px}
.chip button{background:rgba(255,255,255,.2);color:var(--white);border:0;width:17px;height:17px;border-radius:50%;
  cursor:pointer;font-size:12px;line-height:1;display:grid;place-items:center}
.chip-clear{background:none;border:0;color:var(--slate);font-weight:700;font-size:12.5px;cursor:pointer;text-decoration:underline}

/* panel tabs */
.ph{align-items:flex-start}
.ptabs{display:flex;flex-wrap:wrap;gap:2px}
.ptab{font-family:var(--font);font-weight:700;font-size:11.5px;letter-spacing:.04em;color:var(--grey-mid);
  background:none;border:0;padding:4px 8px;border-radius:6px;cursor:pointer;text-transform:uppercase}
.ptab:hover{color:var(--charcoal)}
.ptab.on{color:var(--charcoal);background:var(--stone)}
.details-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--slate);cursor:pointer;
  width:26px;height:26px;font-size:13px;line-height:1;flex:none}
.details-btn:hover{color:var(--charcoal);border-color:var(--grey-mid)}
.phlabel-row{display:flex;justify-content:space-between;margin:8px 0 4px;padding:0 10px}
.rows{min-height:40px}
button.row{font-family:var(--font);text-align:left;width:100%;display:flex;border:0;background:none;cursor:pointer}
.muted{color:var(--grey-mid);font-size:13px;padding:10px}

/* details modal */
#modal-root .modal-back{position:fixed;inset:0;background:rgba(33,33,33,.45);display:grid;place-items:center;z-index:50;padding:24px}
.modal{background:var(--white);border-radius:10px;width:min(720px,100%);max-height:82vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px -20px rgba(33,33,33,.5)}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}
.modal-h h3{font-weight:800;font-size:16px}
.modal-h button{background:none;border:0;font-size:22px;color:var(--slate);cursor:pointer;line-height:1}
#modal-search{margin:14px 20px 0;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-family:var(--font);font-size:13.5px}
#modal-body{overflow:auto;padding:12px 20px 20px}
.modal-table{width:100%;border-collapse:collapse;font-size:13.5px}
.modal-table th{text-align:left;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);font-weight:700;
  padding:8px 10px;border-bottom:2px solid var(--charcoal);cursor:pointer;white-space:nowrap}
.modal-table td{padding:8px 10px;border-bottom:1px solid var(--border)}
.modal-table .r{text-align:right}

@media(max-width:900px){ .tiles{grid-template-columns:repeat(3,1fr)} }
@media(max-width:560px){ .tiles{grid-template-columns:repeat(2,1fr)} .tile .val{font-size:23px} }

/* realtime modal */
.live{cursor:pointer}
.modal.rt{width:min(640px,100%)}
.rt-big{padding:20px 20px 4px;font-size:14px;color:var(--slate)}
.rt-big .num{font-size:40px;font-weight:800;color:var(--charcoal);font-variant-numeric:tabular-nums}
.rt-lbl{font-weight:600}
.rt-svg{width:100%;height:120px;display:block;padding:8px 20px 0}
.rt-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--grey-mid);font-weight:600;padding:6px 20px 20px}
.modal-h .dot{width:8px;height:8px;border-radius:50%;background:var(--sage);display:inline-block}

/* world map */
.wt-map{padding:8px 2px 12px;min-height:200px}
.wt-map-svg{width:100%;height:auto;display:block}
.wt-map-svg path:hover{stroke:#212121;stroke-width:.8}

/* chart hover */
.chart-card{position:relative}
#chart{cursor:crosshair}
.chart-tip{position:absolute;top:36px;pointer-events:none;background:var(--charcoal);color:#fff;border-radius:8px;padding:9px 11px;font-size:12px;z-index:6;min-width:130px;box-shadow:0 8px 20px -8px rgba(0,0,0,.45)}
.tip-date{font-weight:700;margin-bottom:6px;font-size:11px;color:#bdbdbd}
.tip-row{display:flex;align-items:center;gap:8px;font-size:12px;color:#e6e6e6;white-space:nowrap}
.tip-row b{margin-left:auto;font-variant-numeric:tabular-nums;color:#fff;padding-left:14px}
.tip-sw{width:9px;height:3px;border-radius:2px;background:#47FFCE;display:inline-block}
.tip-sw.prev{background:#9CA3AF}

/* realtime lists */
.rt-lists{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:16px 20px 22px;border-top:1px solid var(--border);margin-top:8px}
.rt-list-h{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-mid);font-weight:700;margin-bottom:8px}
.rt-row{position:relative;display:flex;align-items:center;gap:8px;padding:6px 8px;margin:0 -8px;font-size:13px}
.rt-row .bar{position:absolute;left:0;top:0;bottom:0;background:var(--teal-tint-soft);border-radius:4px;z-index:0}
.rt-rl{position:relative;z-index:1;color:var(--charcoal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rt-rv{position:relative;z-index:1;margin-left:auto;color:var(--slate);font-weight:700;font-size:12px}
@media(max-width:560px){ .rt-lists{grid-template-columns:1fr} }
