/* ============================================================
   AVASAR CRM — component styles. Consume semantic tokens only.
   Works in light/dark + any theme because everything resolves
   from tokens.css.
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:var(--ff);color:var(--text);background:var(--bg);font-size:14px;line-height:1.5;transition:background .2s,color .2s}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:8px;border:2px solid var(--bg)}

/* ---------- App shell ---------- */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;height:100vh;grid-template-areas:"side top" "side main"}
.app[data-nav="right"]{grid-template-columns:1fr var(--sidebar-w);grid-template-areas:"top side" "main side"}
.app[data-nav="top"]{grid-template-columns:1fr;grid-template-rows:var(--topbar-h) auto 1fr;grid-template-areas:"top" "navbar" "main"}
.app[data-nav="bottom"]{grid-template-columns:1fr;grid-template-rows:var(--topbar-h) 1fr auto;grid-template-areas:"top" "main" "navbar"}
.sidebar{grid-area:side;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.app[data-nav="right"] .sidebar{border-right:0;border-left:1px solid var(--border)}
.app[data-nav="top"] .sidebar,.app[data-nav="bottom"] .sidebar{display:none}
.topbar{grid-area:top;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 20px}
.navbar{grid-area:navbar;display:none;background:var(--surface);align-items:center;gap:14px;padding:0 16px;min-height:52px;overflow:hidden}
.app[data-nav="top"] .navbar{display:flex;border-bottom:1px solid var(--border)}
.app[data-nav="bottom"] .navbar{display:flex;border-top:1px solid var(--border)}
.main{grid-area:main;overflow:hidden;position:relative}
.main iframe{width:100%;height:100%;border:0;display:block;background:var(--bg)}

.brand{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--border)}
.brand .logo{width:36px;height:36px;border-radius:9px;background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.05rem}
.brand .nm{font-weight:800;font-size:1.12rem;letter-spacing:.04em;color:var(--heading)}
.brand .nm small{display:block;font-size:.58rem;font-weight:600;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;margin-top:1px}

.nav{padding:10px 12px;flex:1}
.nav .grp{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:14px 12px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text);font-weight:500;font-size:.9rem;margin-bottom:2px;transition:.15s}
.nav a .ic{width:20px;text-align:center;flex:none;color:var(--text-muted);font-size:.95rem}
.nav a:hover{background:var(--surface-2)}
.nav a.active{background:var(--primary-50);color:var(--primary);font-weight:600}
.nav a.active .ic{color:var(--primary)}
.nav a .cnt{margin-left:auto;font-size:.7rem;font-weight:700;background:var(--surface-3);color:var(--text-muted);padding:1px 7px;border-radius:999px}
.nav a.alert .cnt{background:var(--crit-50);color:var(--crit)}

.search-top{flex:1;max-width:420px;position:relative}
.search-top input{width:100%;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:999px;padding:9px 14px 9px 38px;font-family:inherit;font-size:.88rem;outline:none}
.search-top input:focus{border-color:var(--primary);background:var(--surface)}
.search-top .si{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted)}
.topbar .spacer{flex:1}
.tb-ctl{display:flex;align-items:center;gap:7px}
.tb-ctl label{font-size:.72rem;color:var(--text-muted);font-weight:600}
.tb-ctl select{border:1px solid var(--border-2);border-radius:999px;padding:7px 11px;font-family:inherit;font-size:.8rem;font-weight:600;color:var(--text);background:var(--surface-2);cursor:pointer;outline:none}
.iconbtn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;font-size:1rem}
.iconbtn:hover{background:var(--surface-3)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem}

/* swatch in theme picker option not possible; show dot via JS list instead */

/* ---------- Screen scaffolding ---------- */
.screen{padding:24px 28px 60px;max-width:1320px}
.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px}
.page-head h1{font-size:1.5rem;font-weight:800;color:var(--heading);letter-spacing:-.01em}
.page-head .sub{color:var(--text-muted);font-size:.9rem;margin-top:3px}
.page-head .actions{margin-left:auto;display:flex;gap:9px}
.crumb{font-size:.8rem;color:var(--text-muted);margin-bottom:6px}
.crumb a{color:var(--primary);font-weight:600}

.btn{display:inline-flex;align-items:center;gap:7px;font-family:inherit;font-weight:600;font-size:.86rem;padding:9px 16px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:.15s}
.btn-primary{background:var(--primary);color:var(--on-primary)}
.btn-primary:hover{filter:brightness(.95)}
.btn-ghost{background:var(--surface);border-color:var(--border-2);color:var(--text)}
.btn-ghost:hover{background:var(--surface-2)}

.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card .card-h{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--border)}
.card .card-h h3{font-size:.98rem;font-weight:700;color:var(--heading)}
.card .card-h .actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.card .card-b{padding:18px}
.card .card-b.flush{padding:0}

/* Colorful, compact KPI tiles (filled gradient — matches dashboard look) */
.kpi{position:relative;border:0;border-radius:var(--radius);padding:13px 15px;box-shadow:var(--shadow-sm);overflow:hidden;
  color:#fff;background:linear-gradient(140deg,var(--c,var(--primary)),color-mix(in srgb,var(--c,var(--primary)) 70%,#000));
  cursor:pointer;transition:transform .16s,box-shadow .16s}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.kpi .lbl{font-size:.74rem;color:rgba(255,255,255,.9);font-weight:600;display:flex;align-items:center;gap:8px}
.kpi .lbl .i{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.2);color:#fff}
.kpi .v{font-size:1.5rem;font-weight:800;color:#fff!important;margin-top:7px;line-height:1}
.kpi .d{font-size:.72rem;margin-top:5px;font-weight:600;color:rgba(255,255,255,.9)!important}
.kpi .d.up,.kpi .d.down{color:rgba(255,255,255,.92)!important}
/* auto-rotate tile colors across a 4-up row — colorful with no per-screen markup */
.cols-4>.kpi:nth-child(4n+1){--c:var(--info)}
.cols-4>.kpi:nth-child(4n+2){--c:var(--ok)}
.cols-4>.kpi:nth-child(4n+3){--c:var(--warn)}
.cols-4>.kpi:nth-child(4n+4){--c:var(--purple)}

.badge{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;padding:3px 10px;border-radius:999px;white-space:nowrap}
.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.b-new{background:var(--info-50);color:var(--info)}
.b-contacted{background:var(--purple-50);color:var(--purple)}
.b-appt{background:var(--primary-50);color:var(--primary)}
.b-docs{background:var(--warn-50);color:var(--warn)}
.b-app{background:var(--ok-50);color:var(--ok)}
.b-approved{background:var(--ok-50);color:var(--ok)}
.b-enrolled{background:var(--ok-50);color:var(--ok)}
.b-rejected{background:var(--crit-50);color:var(--crit)}
.b-muted{background:var(--surface-3);color:var(--text-muted)}

.table{width:100%;border-collapse:collapse;font-size:.86rem}
.table th{text-align:left;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-weight:700;padding:11px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.table td{padding:12px 18px;border-bottom:1px solid var(--border);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tbody tr:hover{background:var(--surface-2)}
.table .who{display:flex;align-items:center;gap:10px}
.table .who .av{width:32px;height:32px;border-radius:50%;background:var(--surface-3);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.76rem;flex:none}
.table .who b{font-weight:600;color:var(--heading)}
.table .who span{display:block;font-size:.76rem;color:var(--text-muted)}
.linkish{color:var(--primary);font-weight:600;cursor:pointer}

.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px;align-items:center}
.filters input,.filters select{border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:9px 12px;font-family:inherit;font-size:.85rem;background:var(--surface);color:var(--text);outline:none}
.filters input{min-width:240px}
.filters input:focus,.filters select:focus{border-color:var(--primary)}
.chip{font-size:.78rem;font-weight:600;padding:6px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border-2);color:var(--text-muted);cursor:pointer}
.chip.on{background:var(--primary-50);border-color:transparent;color:var(--primary)}

/* kanban */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px}
.kcol{flex:0 0 264px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}
.kcol-h{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border)}
.kcol-h .swatch{width:9px;height:9px;border-radius:50%}
.kcol-h b{font-size:.84rem;font-weight:700;color:var(--heading)}
.kcol-h .n{margin-left:auto;font-size:.74rem;font-weight:700;color:var(--text-muted);background:var(--surface);padding:1px 8px;border-radius:999px;border:1px solid var(--border)}
.kcol-b{padding:10px;display:flex;flex-direction:column;gap:9px;min-height:120px}
.kcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 12px;box-shadow:var(--shadow-sm);cursor:pointer}
.kcard:hover{box-shadow:var(--shadow-md)}
.kcard .nm{font-weight:700;color:var(--heading);font-size:.86rem}
.kcard .meta{font-size:.76rem;color:var(--text-muted);margin-top:3px}
.kcard .row{display:flex;align-items:center;gap:7px;margin-top:9px}
.kcard .row .av{width:22px;height:22px;border-radius:50%;background:var(--surface-3);color:var(--text-muted);font-size:.64rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.kcard .row .tag{font-size:.68rem;color:var(--text-muted)}

/* timeline */
.timeline{position:relative;padding-left:26px}
.timeline::before{content:"";position:absolute;left:9px;top:4px;bottom:4px;width:2px;background:var(--border)}
.tl-item{position:relative;padding:0 0 18px}
.tl-item::before{content:"";position:absolute;left:-21px;top:2px;width:14px;height:14px;border-radius:50%;background:var(--surface);border:2px solid var(--primary)}
.tl-item.call::before{border-color:var(--info)} .tl-item.email::before{border-color:var(--purple)}
.tl-item.note::before{border-color:var(--text-muted)} .tl-item.status::before{border-color:var(--ok)}
.tl-item .t{font-weight:600;color:var(--heading);font-size:.86rem}
.tl-item .m{font-size:.82rem;color:var(--text-muted);margin-top:2px}
.tl-item .when{font-size:.72rem;color:var(--text-muted);margin-top:3px}

.info-list .r{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px dashed var(--border)}
.info-list .r:last-child{border-bottom:0}
.info-list .r .k{color:var(--text-muted);font-size:.84rem}
.info-list .r .val{font-weight:600;color:var(--heading);font-size:.86rem;text-align:right}

.doc{display:flex;align-items:center;gap:11px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px}
.doc .fi{width:34px;height:34px;border-radius:7px;background:var(--crit-50);color:var(--crit);display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:800;flex:none}
.doc b{font-weight:600;color:var(--heading);font-size:.84rem;display:block}
.doc span{font-size:.74rem;color:var(--text-muted)}
.doc .act{margin-left:auto;display:flex;gap:6px}

.lvl{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.74rem;padding:3px 10px;border-radius:6px}
.lvl-3{background:var(--warn-50);color:var(--warn)}
.lvl-7{background:var(--warn-50);color:var(--warn)}
.lvl-14{background:var(--crit-50);color:var(--crit)}

.muted{color:var(--text-muted)}
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}
.section-title{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0 0 12px}
@media(max-width:760px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:1fr}}
