:root{
  --bg:#f6f3ec;
  --card:rgba(255,255,255,.92);
  --text:#102038;
  --muted:#58677d;
  --line:rgba(16,32,56,.12);
  --accent:#1793e8;
  --accent-weak:rgba(23,147,232,.14);
  --radius:18px;
  --control-height:42px;
  --control-radius:14px;
  --shadow:0 16px 42px rgba(16,32,56,.10);
}

*{ box-sizing:border-box; }
html, body{ height:100%; }
body{
  margin:0;
  font-family: "Avenir Next", "Segoe UI", sans-serif;
  background:
    radial-gradient(900px 380px at right top, rgba(23,147,232,.08), transparent 60%),
    radial-gradient(820px 340px at left 8%, rgba(238,92,77,.08), transparent 55%),
    var(--bg);
  color:var(--text);
}

a{ color:inherit; text-decoration:none; }

.wrap{ max-width:1100px; margin:0 auto; padding:18px; }

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:18px 0 22px 0;
}

.brand{
  font-weight:900;
  letter-spacing:.2px;
}
.brand-app{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  color:var(--text);
}

.brand-app-logo{
  height:44px;
  width:auto;
  display:block;
}

.brand-app-text{
  font-weight:900;
  font-size:20px;
  letter-spacing:.2px;
}

.nav{ display:flex; gap:8px; flex-wrap:wrap; }
.nav-toggle{
  display:none;
  position:relative;
  min-height:40px;
  min-width:44px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  color:var(--text);
  font-size:20px;
  line-height:1;
  cursor:pointer;
}
.nav-toggle.has-alert{
  border-color:rgba(239,68,68,.35);
}
.nav-toggle-badge{
  position:absolute;
  top:-6px;
  right:-6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:800;
  line-height:1;
  box-shadow:0 4px 12px rgba(220,38,38,.28);
}

.pill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  justify-content:center;
  min-height:var(--control-height);
  padding:0 18px;
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--muted);
  background:rgba(255,255,255,.88);
  font-size:13px;
  line-height:1;
  white-space:nowrap;
  font:inherit;
  appearance:none;
  -webkit-appearance:none;
  cursor:pointer;
}
.pill[data-active="1"]{
  border-color: rgba(0,153,230,.55);
  box-shadow: 0 0 0 4px var(--accent-weak);
  color: var(--text);
}

.menu-dropdown{
  position:relative;
}
.settings-trigger{
  gap:10px;
  min-width:var(--control-height);
  padding-inline:14px;
}
.locale-trigger{
  min-width:var(--control-height);
  padding-inline:12px;
}
.locale-flag,
.locale-menu-flag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  line-height:1;
}
.locale-menu .menu-item{
  gap:10px;
}
.settings-trigger.has-unread{
  border-color:rgba(239,68,68,.35);
  background:rgba(239,68,68,.08);
  color:#991b1b;
}
.settings-trigger.has-unread:hover{
  background:rgba(239,68,68,.12);
}
.pill-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:800;
  line-height:1;
}
.settings-trigger .gear-icon{
  font-size:24px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.settings-trigger .settings-label{
  display:none;
}
.menu-dropdown-panel{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  min-width:190px;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(255,255,255,.97);
  box-shadow:var(--shadow);
  padding:6px;
  display:none;
  z-index:30;
}
.menu-dropdown-panel.is-open{
  display:block;
}
.command-palette{
  position:fixed;
  inset:0;
  z-index:60;
}
.command-palette-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.42);
}
.command-palette-panel{
  position:relative;
  max-width:760px;
  margin:10vh auto 0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:16px;
}
.command-palette-list{
  display:grid;
  gap:8px;
  margin-top:12px;
  max-height:52vh;
  overflow:auto;
}
.command-palette-item{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
}
.command-palette-item:hover,
.command-palette-item.is-active{
  border-color:rgba(0,153,230,.55);
  box-shadow:0 0 0 4px var(--accent-weak);
}
.command-palette-item span{
  color:var(--muted);
  font-size:13px;
}
.menu-item{
  display:flex;
  align-items:center;
  width:100%;
  padding:9px 10px;
  border:0;
  border-radius:8px;
  color:var(--text);
  background:transparent;
  text-align:left;
  font:inherit;
  cursor:pointer;
}
.menu-item:hover{
  background:rgba(15,23,42,.05);
}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  backdrop-filter:blur(8px);
  box-shadow: var(--shadow);
}

.h1{ font-size:22px; margin:0 0 10px; letter-spacing:-.03em; }
.row{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; justify-content:space-between; }

.small{ color:var(--muted); font-size:13px; }
.err{ color:#b91c1c; font-size:13px; margin-top:4px; }
.flash-banner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}
.flash-banner.is-success{
  border-color:rgba(0,160,120,.35);
  background:rgba(0,160,120,.08);
}
.flash-banner.is-error{
  border-color:rgba(185,28,28,.18);
  background:rgba(185,28,28,.06);
}
.flash-banner-copy{
  font-weight:700;
  line-height:1.45;
}
.flash-banner-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}
.flash-banner.is-success .flash-banner-copy{
  color:var(--text);
}
.flash-banner.is-error .flash-banner-copy{
  color:#991b1b;
}
.flash-banner-close{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:36px;
  min-height:36px;
  border:1px solid rgba(16,32,56,.10);
  border-radius:12px;
  background:rgba(255,255,255,.82);
  color:var(--muted);
  font:inherit;
  font-size:22px;
  line-height:1;
  cursor:pointer;
}
  .flash-banner-close:hover{
  background:#fff;
  color:var(--text);
}
.mfa-setup-card{
  max-width:560px;
}
.mfa-setup-grid{
  display:grid;
  grid-template-columns:168px minmax(0, 1fr);
  gap:14px;
  align-items:start;
}
.mfa-qr-panel{
  display:grid;
  gap:8px;
}
.mfa-qr-frame{
  display:flex;
  align-items:center;
  justify-content:center;
  width:168px;
  min-height:168px;
  padding:8px;
  border:1px solid rgba(16,32,56,.12);
  border-radius:16px;
  background:#fff;
  box-shadow:0 10px 28px rgba(16,32,56,.08);
}
.mfa-qr-canvas{
  display:flex;
  align-items:center;
  justify-content:center;
  width:148px;
  height:148px;
}
.mfa-qr-canvas img,
.mfa-qr-canvas canvas{
  display:block;
  width:148px;
  height:148px;
}
.mfa-setup-fields{
  min-width:0;
}
.live-timer{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:112px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(0,153,230,.10);
  border:1px solid rgba(0,153,230,.28);
  color:var(--text);
  font-weight:900;
  letter-spacing:.08em;
  font-variant-numeric:tabular-nums;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 18px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.92);
  color:var(--text);
  font-weight:700;
  font-size:14px;
  line-height:1;
  cursor:pointer;
  transition:all .18s ease;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(2,8,23,.10);
}
.btn:active{ transform:translateY(0); }

/* Primary */
.btn.primary{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  box-shadow:0 12px 30px rgba(23,147,232,.22);
}
.btn.primary:hover{ filter:brightness(1.02); }

.btn.is-active-filter{
  background:#fff;
  color:var(--accent);
  border-color:rgba(0,153,230,.55);
  box-shadow:0 0 0 4px var(--accent-weak);
}

.btn.small{
  padding:6px 10px;
  font-size:13px;
  min-width:72px;
}

.btn.danger{
  border-color: rgba(239,68,68,.5);
  color:#b91c1c;
  background:#fff;
}
.btn.danger:hover{
  box-shadow:0 10px 22px rgba(239,68,68,.10);
}

/* Forms */
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
label{ color:var(--muted); font-size:13px; }

input, textarea, select{
  padding:10px 12px;
  border-radius:var(--control-radius);
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  outline:none;
  font:inherit;
}
input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
select{
  min-height:var(--control-height);
  height:var(--control-height);
  line-height:1.2;
}
select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  padding-right:38px;
  border-radius:var(--control-radius);
  background-color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:14px 14px;
}
input:focus, textarea:focus, select:focus{
  border-color: rgba(0,153,230,.80);
  box-shadow:0 0 0 4px var(--accent-weak);
}

.availability-rule-row{
  display:grid;
  grid-template-columns:90px 120px 120px 95px;
  gap:8px;
  align-items:end;
  justify-content:start;
}
.availability-rule-row .field{
  margin:0;
}

/* Support */
.support-hero{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.support-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:12px;
}
.support-card{
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:10px 12px;
}
.support-card summary{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  cursor:pointer;
  list-style:none;
}
.support-card summary::-webkit-details-marker{
  display:none;
}
.support-card[open] summary{
  margin-bottom:8px;
}
.support-card ol{
  margin:0 0 0 18px;
  padding:0;
}
.support-card li{
  margin:0 0 6px;
}
.support-link-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.support-link{
  min-width:140px;
}
.support-link.is-available{
  color:var(--accent);
  border-color:rgba(23,147,232,.45);
  background:rgba(255,255,255,.96);
  box-shadow:0 0 0 3px rgba(23,147,232,.08);
}
.support-link.is-available:hover{
  box-shadow:0 10px 22px rgba(23,147,232,.12);
}
.support-link.is-upgrade{
  color:var(--text);
  border-color:var(--line);
  background:rgba(255,255,255,.92);
}
.support-upgrade-note{
  margin-top:10px;
  color:var(--muted);
}

/* Table */
.table{ width:100%; border-collapse:collapse; }
.table th,.table td{
  text-align:left;
  padding:10px;
  border-bottom:1px solid var(--line);
  vertical-align:top;
}
.table th{ color:var(--muted); font-weight:800; }
.table tr[data-row-link]{ cursor:pointer; }
.table tr[data-row-link]:hover td{ background:rgba(0,153,230,.04); }
.desktop-only{ display:block; }
.mobile-only{ display:none; }
.entity-card-list{
  display:grid;
  gap:10px;
}
.entity-card{
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  background:rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}
.entity-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.entity-card-title{ font-weight:900; }
.entity-card-meta{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 12px;
  margin-top:12px;
}
.entity-card-meta .k{ color:var(--muted); font-size:12px; }
.entity-card-meta .v{ font-weight:700; margin-top:2px; }
.entity-card-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.split-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.form-section-title{
  margin:0 0 6px;
  font-size:18px;
  font-weight:900;
  letter-spacing:-.02em;
}
.step-chip{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(23,147,232,.10);
  border:1px solid rgba(23,147,232,.18);
  color:var(--text);
  font-weight:800;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.appointments-admin-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.appointments-admin-card{
  min-width:0;
}
.appointments-inline-fields{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.appointments-inline-fields.two{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.time-card{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  background:#fff;
  box-shadow:var(--shadow);
}
.time-card + .time-card{ margin-top:10px; }
.time-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.time-card-title{ font-weight:900; }
.time-card-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 12px;
  margin-top:10px;
}
.time-card-grid .k{ color:var(--muted); font-size:12px; }
.time-card-grid .v{ font-weight:700; margin-top:2px; }
.time-card-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}

/* Pipeline board */
.pipeline{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(260px, 1fr);
  gap:14px;
  overflow:auto;
  padding-bottom:10px;
}
.pipe-col{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  min-height:220px;
  box-shadow: var(--shadow);
}
.pipe-head{
  padding:12px 12px 10px;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
}
.pipe-list{
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.pipe-card{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  background:#fff;
}
.pipe-empty{
  padding:10px;
  border:1px dashed rgba(15,23,42,.18);
  border-radius:14px;
}
.pipe-card select{ width:100%; margin-top:6px; }

@media (max-width:820px){
  .topbar{
    align-items:flex-start;
  }
  .nav-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .nav{
    display:none;
    width:100%;
    margin-top:10px;
    padding-top:10px;
    border-top:1px solid var(--line);
    flex-direction:column;
    align-items:stretch;
  }
  .nav.is-open{
    display:flex;
  }
  .nav .pill{
    width:100%;
    justify-content:flex-start;
  }
  .menu-dropdown{
    width:100%;
  }
  .menu-dropdown .pill{
    width:100%;
  }
  .settings-trigger{
    justify-content:flex-start;
    min-height:44px;
    font-size:15px;
  }
  .settings-trigger.has-unread{
    background:rgba(239,68,68,.08);
  }
  .settings-trigger .gear-icon{
    font-size:22px;
  }
  .settings-trigger .settings-label{
    display:inline;
  }
  .menu-dropdown-panel{
    position:static;
    margin-top:6px;
    width:100%;
  }
  .nav-toggle-badge{
    top:-4px;
    right:-4px;
  }
  .pipeline{
    grid-auto-flow:row;
    grid-auto-columns:unset;
    grid-template-columns:1fr;
    overflow:visible;
    padding-bottom:0;
  }
  .pipe-col{ min-height:auto; }
  .pipe-list{ padding:10px; }
  .appointments-admin-grid{
    grid-template-columns:1fr;
  }
  .split-form{
    grid-template-columns:1fr;
  }
}
@media (min-width:821px){
  .pipeline{ scroll-snap-type:x mandatory; }
  .pipe-col{ scroll-snap-align:start; }
}
.pipe-card.is-dragging{ opacity:.55; }
.pipe-list.is-over{
  outline:2px dashed rgba(0,153,230,.55);
  outline-offset:6px;
  border-radius:14px;
}

/* ==========================
   Quote (customer-facing)
========================== */
.quote-doc{
  max-width:980px;
  margin:0 auto;
  padding:18px;
}

.quote-toolbar{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.quote-toolbar .btn{ min-width:130px; }

.quote-header{
  display:flex;
  justify-content:space-between;
  gap:18px;
  padding:18px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:#fff;
  box-shadow: var(--shadow);
}

.quote-brand{
  display:flex;
  gap:14px;
  align-items:flex-start;
}

.quote-logo-badge{
  width:64px;
  height:64px;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.quote-logo-img{
  max-height:54px;
  max-width:54px;
  width:auto;
  height:auto;
  display:block;
}
.quote-logo-fallback{
  font-weight:900;
  font-size:20px;
  color:var(--text);
}

.quote-brand-text{ min-width:260px; }
.quote-brand-name{ font-weight:900; font-size:18px; line-height:1.1; }
.quote-brand-line{
  margin-top:3px;
  line-height:1.25;
  color:var(--muted);
  font-size:12.5px;
}

.quote-meta{ text-align:right; min-width:220px; }
.quote-number{ font-size:18px; font-weight:900; }
.quote-meta-row{ margin-bottom:6px; color:var(--muted); }
.quote-meta-row .quote-number,
.quote-meta-row .quote-date{ color:var(--text); }

.quote-badge{
  display:inline-flex;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  margin-top:10px;
  color:var(--text);
}

.quote-badge[data-status="draft"]{
  background:#fff;
  border-color: rgba(15,23,42,.16);
}

.quote-badge[data-status="accepted"]{
  background:#16a34a;
  color:#fff;
  border:none;
}

.quote-badge[data-status="rejected"]{
  background:#dc2626;
  color:#fff;
  border:none;
}

.quote-panels{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:14px;
}
@media (max-width:820px){
  .quote-panels{ grid-template-columns:1fr; }
}

.quote-panel{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  box-shadow: var(--shadow);
}
.quote-panel-title{
  padding:12px 12px 10px;
  border-bottom:1px solid var(--line);
  font-weight:900;
}
.quote-panel-body{ padding:12px; }
.quote-strong{ font-weight:900; margin-bottom:6px; }

.quote-subject{ margin:12px 2px 0; color:var(--muted); }

.quote-text{
  margin-top:12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  padding:12px;
  box-shadow: var(--shadow);
}
.quote-text p{ margin:0; color:var(--text); }

.quote-table{ margin-top:14px; }
.quote-sum-row td{ border-bottom:none; }
.quote-total td{
  padding-top:14px;
  border-top:1px solid var(--line);
  font-size:16px;
}

.quote-footer{
  margin-top:14px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  box-shadow: var(--shadow);
}

@media (max-width:700px){
  .desktop-only{ display:none !important; }
  .mobile-only{ display:block; }
  .entity-card-meta,
  .time-card-grid,
  .appointments-inline-fields,
  .appointments-inline-fields.two{
    grid-template-columns:1fr;
  }
  .availability-rule-row{
    grid-template-columns:1fr 1fr;
  }
  .topbar{
    gap:12px;
  }
  .flash-banner{
    flex-direction:column;
    align-items:stretch;
  }
  .mfa-setup-card{
    max-width:none;
  }
  .mfa-setup-grid{
    grid-template-columns:1fr;
  }
  .mfa-qr-frame{
    width:100%;
    max-width:168px;
  }
  .flash-banner-actions{
    justify-content:flex-start;
  }
  .wrap{
    padding:14px;
  }
  .brand-app-text{
    font-size:18px;
  }
}

.platform-dashboard{
  max-width:1100px;
  margin:0 auto;
}
.platform-dashboard-section{
  margin-top:16px;
}
.platform-kpi-grid,
.platform-chart-grid,
.platform-ops-grid{
  display:grid;
  gap:12px;
}
.platform-kpi-grid{
  grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));
}
.platform-chart-grid{
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
}
.platform-ops-grid{
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
}
.platform-kpi-card{
  padding:18px;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow);
}
.platform-kpi-value{
  margin-top:8px;
  font-size:30px;
  font-weight:900;
  letter-spacing:-.04em;
}
.platform-bars{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(72px, 1fr));
  gap:10px;
  align-items:end;
}
.platform-bars-double{
  grid-template-columns:repeat(auto-fit, minmax(82px, 1fr));
}
.platform-bar-group{
  display:grid;
  gap:8px;
  align-items:end;
}
.platform-bar-double{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  align-items:end;
}
.platform-bar-stack{
  display:grid;
  gap:6px;
}
.platform-bar-value{
  min-height:32px;
  color:var(--muted);
  font-size:12px;
  line-height:1.3;
}
.platform-bar-track{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  border-radius:16px;
  background:rgba(16,32,56,.06);
  padding:8px;
}
.platform-bar-track-tall{
  min-height:172px;
}
.platform-bar-track-medium{
  min-height:148px;
}
.platform-bar{
  width:100%;
  border-radius:12px;
}
.platform-bar-accent{
  background:linear-gradient(180deg, #5bb9f7 0%, #1793e8 100%);
}
.platform-bar-secondary{
  background:linear-gradient(180deg, #1cc6a3 0%, #0f9f8a 100%);
}
.platform-bar-positive{
  background:linear-gradient(180deg, #49c98a 0%, #199f63 100%);
}
.platform-bar-negative{
  background:linear-gradient(180deg, #f39886 0%, #ee5c4d 100%);
}
.platform-bar-label{
  color:var(--muted);
  font-size:12px;
}
.platform-metric-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.platform-metric-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:10px 0;
  border-bottom:1px solid rgba(16,32,56,.08);
}
.platform-metric-row:last-child{
  border-bottom:0;
  padding-bottom:0;
}
.platform-metric-row span{
  color:var(--muted);
}
@media (max-width:760px){
  .platform-chart-grid,
  .platform-ops-grid,
  .platform-kpi-grid{
    grid-template-columns:1fr;
  }
}

/* Print: maak altijd wit */
@media print{
  .noprint{ display:none !important; }
  body{ background:#fff !important; color:#000 !important; }
  .card, .quote-header, .quote-panel, .quote-text, .quote-footer{
    box-shadow:none !important;
  }
  .quote-doc{ max-width:none; padding:0; }
}
