:root{
  --brand:#0ea5b7; --bg:#eef2f6; --card:#fff; --line:#e2e8f0; --txt:#1e293b; --muted:#64748b;
  --navy:#0f2a43; --ok:#10b981; --warn:#f59e0b; --danger:#ef4444;
  --booking:#003580; --airbnb:#ff5a5f; --direct:#10b981; --expedia:#1c3f94;
  --shadow:0 1px 3px rgba(15,42,67,.08),0 1px 2px rgba(15,42,67,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:14px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.app{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:240px;background:var(--navy);color:#cbd5e1;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;flex-shrink:0}
.brand{padding:20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.07)}
.brand .logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--brand),#22d3ee);display:flex;align-items:center;justify-content:center;font-weight:800;color:#04222b;font-size:16px}
.brand b{color:#fff;font-size:15px;display:block;line-height:1.1}
.brand span{font-size:11px;color:#8aa3bd}
.brand.center{flex-direction:column;text-align:center;border:none;justify-content:center}
.brand .logo.big{width:52px;height:52px;font-size:22px}
.nav{padding:12px 10px;flex:1}
.nav .group{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#607d99;margin:16px 12px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:#cbd5e1;font-weight:500;margin-bottom:2px}
.nav a .ic{width:18px;text-align:center;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.active{background:var(--brand);color:#fff}
.sb-foot{padding:14px 18px;border-top:1px solid rgba(255,255,255,.07);font-size:12px;color:#8aa3bd}
.sb-foot .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ok);margin-right:6px}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:60px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:20}
.prop-select{display:flex;align-items:center;gap:10px;font-weight:600}
.prop-select .pin{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--brand),#22d3ee);display:flex;align-items:center;justify-content:center;color:#fff}
.prop-select small{font-weight:400;color:var(--muted);display:block;font-size:11px}
.top-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.host-chip{font-size:12px;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:6px 10px;border-radius:8px;font-family:ui-monospace,monospace}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:15px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.btn-newresv{padding:9px 15px;font-size:13px;white-space:nowrap}
.content{padding:24px;flex:1}

/* HEAD + BUTTONS */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.page-head h1{font-size:21px;font-weight:700}
.page-head p{color:var(--muted);font-size:13px;margin-top:3px}
.btn{border:none;border-radius:10px;padding:10px 16px;font-weight:600;font-size:13px;cursor:pointer;display:inline-block}
.btn.primary{background:var(--brand);color:#fff}
.btn.primary:disabled{background:#cbd5e1;cursor:not-allowed}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--txt)}
.btn.dark{background:var(--booking);color:#fff}
.btn.red{background:var(--airbnb);color:#fff}
.btn.full{width:100%;margin-top:8px;padding:12px}
.lnk{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px}
.note{font-size:12px;color:var(--muted);padding:14px 2px}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow)}
.kpi .l{color:var(--muted);font-size:12px;font-weight:600}
.kpi .v{font-size:25px;font-weight:800;margin-top:6px;letter-spacing:-.02em}
.kpi .c{font-size:12px;margin-top:4px;font-weight:600;color:var(--muted)}
.kpi .c.up{color:var(--ok)}

/* CARDS */
.grid2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.card .ch{padding:16px 18px;border-bottom:1px solid var(--line)}
.card .ch h3{font-size:15px;font-weight:700}
.card .cb{padding:18px}

/* occupancy */
.occ{display:flex;align-items:flex-end;gap:7px;height:160px;padding-top:18px}
.occ .bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.occ .bar .pctlabel{font-size:10px;color:var(--muted);font-weight:700}
.occ .bar .fill{width:100%;max-width:30px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--brand),#22d3ee)}
.occ .bar small{color:var(--muted);font-size:11px}

/* feed */
.feed .row{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--line)}
.feed .row:last-child{border-bottom:none}
.feed .dotc{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}
.feed .row .t{flex:1;font-size:13px}
.feed .row .t small{display:block;color:var(--muted);font-size:11.5px}
.feed .row .when{color:var(--muted);font-size:11px}

/* badges */
.ch-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;color:#fff;background:#64748b}
.ch-badge.booking{background:var(--booking)}.ch-badge.airbnb{background:var(--airbnb)}
.ch-badge.direct{background:var(--direct)}.ch-badge.expedia{background:var(--expedia)}
.status{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:#f1f5f9;color:#475569}
.status.conf{background:#dcfce7;color:#166534}.status.new{background:#dbeafe;color:#1e40af}.status.canc{background:#fee2e2;color:#991b1b}

/* LIST TABLE */
table.list{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden}
table.list th{text-align:left;padding:12px 16px;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--line);background:#f8fafc}
table.list td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:13px}
table.list tr:hover td{background:#f8fafc}
.guest{display:flex;align-items:center;gap:10px;font-weight:600}
.guest .av2{width:32px;height:32px;border-radius:50%;background:#e0e7ff;color:#3730a3;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}

/* CALENDAR */
.cal-wrap{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.cal-toolbar{padding:14px 18px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.legend{display:flex;gap:14px;margin-left:auto;font-size:12px;color:var(--muted);flex-wrap:wrap}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:12px;height:12px;border-radius:3px;display:inline-block}
.cal-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.btn.sm{padding:7px 11px;font-size:13px}
.month-jump{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;font-weight:600}
.cal-nav input[type=month]{padding:7px 10px;border:1px solid var(--line);border-radius:9px;font-size:13px;outline:none}
.cal-nav input[type=month]:focus{border-color:var(--brand)}
table.cal thead th.month-group{background:#f1f5f9;color:var(--txt);font-size:13px;font-weight:700;text-align:center;padding:8px;border-bottom:2px solid var(--brand);text-transform:capitalize}
table.cal thead th.is-today{background:var(--brand);color:#fff}
table.cal thead th.is-today b{color:#fff}

/* TIMELINE (planner) */
.tl-legend{display:flex;gap:14px;margin-left:auto;font-size:12px;color:var(--muted);flex-wrap:wrap}
.tl-legend span{display:inline-flex;align-items:center;gap:6px}
.tl-legend i{width:14px;height:14px;border-radius:3px;display:inline-block}
.tl-scroll{overflow-x:auto}
.tl{display:inline-block;min-width:100%;vertical-align:top}
.tl-row{display:flex;align-items:stretch;border-bottom:1px solid var(--line)}
.tl-name{width:190px;flex-shrink:0;padding:0 14px;display:flex;flex-direction:column;justify-content:center;font-weight:600;font-size:13px;background:#fff;position:sticky;left:0;z-index:6;border-right:1px solid var(--line);min-height:42px}
.tl-track{flex:1;display:flex;position:relative;min-height:42px}
.tl-d,.tl-cell,.tl-month{flex:1 1 0;min-width:34px;border-right:1px solid var(--line);box-sizing:border-box}
.tl-headrow .tl-name{background:#f8fafc;color:var(--muted)}
.tl-corner{min-height:0}
.tl-d{background:#f8fafc;text-align:center;font-size:11px;color:var(--muted);padding:5px 0;line-height:1.2}
.tl-d b{color:var(--txt);font-size:13px}
.tl-d.we{background:#eff6ff}
.tl-d.is-today{background:var(--brand);color:#fff}
.tl-d.is-today b{color:#fff}
.tl-month{background:#f1f5f9;text-align:center;font-weight:700;font-size:13px;padding:6px 0;border-bottom:2px solid var(--brand);text-transform:capitalize;color:var(--txt)}
.tl-cell{min-height:42px}
.tl-cell.we{background:#f8fbff}
.tl-cell.today{background:rgba(14,165,183,.08)}
.tl-freerow .tl-name{font-weight:600;color:var(--muted);font-size:12px}
.tl-freerow .tl-track,.tl-freerow .tl-name{min-height:30px}
.tl-freerow .tl-cell{display:flex;align-items:center;justify-content:center;min-height:30px}
.freenum{font-size:12px;font-weight:700;color:var(--ok)}
.freenum.zero{color:var(--danger)}
.tl-resv{position:absolute;top:5px;bottom:5px;border-radius:6px;color:#fff;font-size:11px;font-weight:600;padding:0 8px;display:flex;align-items:center;overflow:hidden;white-space:nowrap;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.22);z-index:3}
.tl-resv:hover{filter:brightness(1.08);z-index:5}
.tl-resv-l{overflow:hidden;text-overflow:ellipsis}
.rd-status{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.rd-line{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.rd-line span{color:var(--muted)}
.rd-line.total{font-size:16px;border-bottom:none;padding-top:14px}
.rd-line.total b{color:var(--brand)}
.tl-add{cursor:pointer}
.tl-add:hover{background:rgba(14,165,183,.12)!important;box-shadow:inset 0 0 0 1px var(--brand)}
.nerr{display:none;background:#fee2e2;color:#991b1b;padding:9px 12px;border-radius:9px;font-size:13px}

/* WIDGET (publiczny formularz rezerwacji) */
.wgt{max-width:460px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.bare .wgt{margin:24px auto}
.wgt-head{background:var(--brand);color:#fff;padding:18px 20px}
.wgt-title{font-size:18px;font-weight:800}
.wgt-sub{font-size:12px;opacity:.9;margin-top:2px}
.wgt-form{padding:18px 20px;display:flex;flex-direction:column;gap:12px}
.wgt-form label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted)}
.wgt-form input,.wgt-form select{padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;outline:none;color:var(--txt);background:#fff}
.wgt-form input:focus,.wgt-form select:focus{border-color:var(--brand)}
.wgt-row{display:flex;gap:12px}.wgt-row label{flex:1}
.wgt-hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0}
.wgt-btn{display:block;text-align:center;background:var(--brand);color:#fff;border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:700;cursor:pointer;text-decoration:none;margin-top:4px}
.wgt-foot{font-size:11px;color:var(--muted);text-align:center;margin-top:2px}
.wgt-err{margin:16px 20px 0;background:#fee2e2;color:#991b1b;padding:10px 12px;border-radius:10px;font-size:13px}
.wgt-ok{padding:28px 24px;text-align:center}
.wgt-ok-ic{width:60px;height:60px;border-radius:50%;background:var(--ok);color:#fff;font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.wgt-ok h3{font-size:16px;margin-bottom:16px}
.wgt-summary{text-align:left;border:1px solid var(--line);border-radius:12px;padding:8px 14px;margin-bottom:16px}
.wgt-summary div{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.wgt-summary div:last-child{border-bottom:none}
.wgt-summary span{color:var(--muted)}

/* WIDGET — pełny formularz 2-krokowy */
.wgt-wide{max-width:720px}
.wgt-book{padding:18px 20px}
.wgt-cols{display:flex;gap:18px;align-items:flex-start}
.wgt-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:14px}
.wgt-side{width:230px;flex-shrink:0;background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:14px;position:sticky;top:10px}
.wgt-sec{border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px}
.wgt-sec-t{font-weight:700;font-size:13px;color:var(--brand)}
.wgt-room{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:10px;cursor:pointer}
.wgt-room input{margin:0;width:auto}
.wgt-room-n{flex:1;font-weight:600;font-size:13px;color:var(--txt)}
.wgt-room-p{font-weight:700;color:var(--brand);font-size:13px}
.wgt-book label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted)}
.wgt-book input[type=text],.wgt-book input[type=email],.wgt-book input[type=tel],.wgt-book select,.wgt-book textarea{padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;color:var(--txt);font-family:inherit;background:#fff}
.wgt-book input:focus,.wgt-book select:focus,.wgt-book textarea:focus{border-color:var(--brand);outline:none}
.wgt-chk{flex-direction:row!important;align-items:center;gap:8px;font-weight:500!important;color:var(--txt)!important;font-size:13px!important}
.wgt-chk input{width:auto}
.wgt-terms{font-size:12px;color:var(--muted);line-height:1.5}
.wgt-sum-line{display:flex;justify-content:space-between;font-size:13px;padding:7px 0;border-bottom:1px solid var(--line);gap:8px}
.wgt-sum-line span{color:var(--muted)}.wgt-sum-line b{text-align:right}
.wgt-sum-total{display:flex;justify-content:space-between;font-size:16px;font-weight:800;padding:12px 0 14px}
.wgt-sum-total b{color:var(--brand)}
.wgt-back{display:block;text-align:center;font-size:12px;color:var(--muted);margin-top:10px}
@media(max-width:620px){.wgt-cols{flex-direction:column}.wgt-side{width:100%;position:static}}

/* USERS */
.rbadge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;background:#f1f5f9;color:#475569}
.rbadge.r-owner{background:#e0e7ff;color:#3730a3}
.rbadge.r-manager{background:#cffafe;color:#0e7490}
.rbadge.r-house{background:#fef3c7;color:#92400e}
.uform{display:flex;flex-direction:column;gap:12px}
.uform label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted)}
.uform input,.uform select{padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;color:var(--txt);background:#fff}
.uform input:focus,.uform select:focus{border-color:var(--brand);outline:none}

/* REPORTS */
.rep-filter{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:20px;box-shadow:var(--shadow)}
.rep-filter label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted)}
.rep-filter input,.rep-filter select{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-size:14px;color:var(--txt);background:#fff}
.rep-filter input:focus,.rep-filter select:focus{border-color:var(--brand);outline:none}
.rep-bar{height:6px;background:#eef2f6;border-radius:6px;margin-top:6px;overflow:hidden;max-width:220px}
.rep-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),#22d3ee);border-radius:6px}
.rep-ch{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.rep-ch:last-of-type{border-bottom:none}
.rep-ch-cnt{color:var(--muted);font-size:12px}
.rep-ch-rev{margin-left:auto;font-size:15px}

/* HOUSEKEEPING */
.hk-legend{display:flex;gap:16px;margin-bottom:16px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.hk-legend span{display:inline-flex;align-items:center;gap:6px}
.hk-legend i{width:13px;height:13px;border-radius:3px;display:inline-block}
.hk-legend i.dep{background:#3b82f6}.hk-legend i.arr{background:#16a34a}.hk-legend i.turn{background:#f59e0b}
.hk-day{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden}
.hk-date{padding:12px 18px;border-bottom:1px solid var(--line);font-size:14px;background:#f8fafc}
.hk-date b{text-transform:capitalize}
.hk-today{background:var(--brand);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;margin-left:8px}
.hk-cols{display:flex}
.hk-col{flex:1;padding:14px 18px}
.hk-col:first-child{border-right:1px solid var(--line)}
.hk-col-t{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.03em}
.hk-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;border-radius:9px;margin-bottom:6px;font-size:13px}
.hk-item.dep{background:#eff6ff}.hk-item.arr{background:#f0fdf4}.hk-item.turn{background:#fffbeb}
.hk-room{font-weight:600}
.hk-tag{font-size:11px;color:var(--muted)}
.hk-tag.turn{color:#92400e;font-weight:700}
.hk-guests{font-weight:700;color:#166534}
.hk-empty{color:var(--muted);font-size:13px;padding:6px 0}
@media(max-width:700px){.hk-cols{flex-direction:column}.hk-col:first-child{border-right:none;border-bottom:1px solid var(--line)}}

/* EMBED — generator iframe */
.muted2{color:var(--muted);font-size:13px}
.codebox{background:#0f2a43;color:#cbe7ee;padding:14px;border-radius:10px;font-family:ui-monospace,Menlo,monospace;font-size:12px;white-space:pre-wrap;word-break:break-all;margin-bottom:12px}
.embed-select{padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;margin-bottom:12px;width:100%;max-width:320px}

/* AVAILABILITY widget (kalendarz dostępności pokoju) */
.avw{max-width:520px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.bare .avw{margin:24px auto}
.avw-head{background:var(--brand);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between}
.avw-title{font-size:16px;font-weight:800}
.avw-sub{font-size:11px;opacity:.9}
.avw-nav{display:flex;gap:6px}
.avw-nav a{width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,.18);color:#fff;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:15px}
.avw-nav a:hover{background:rgba(255,255,255,.32)}
.avw-legend{display:flex;gap:16px;padding:10px 18px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--line)}
.avw-legend span{display:inline-flex;align-items:center;gap:6px}
.avw-legend i{width:13px;height:13px;border-radius:3px;display:inline-block}
.avw-legend i.free{background:#16a34a}.avw-legend i.booked{background:#ef4444}
.avw-months{display:flex;flex-wrap:wrap;gap:14px;padding:16px 18px}
.avw-month{flex:1 1 200px;min-width:190px}
.avw-mname{font-weight:700;font-size:13px;margin-bottom:8px;text-align:center;color:var(--txt)}
.avw-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.avw-dow{font-size:10px;color:var(--muted);text-align:center;font-weight:600;padding-bottom:2px}
.avw-blank{aspect-ratio:1}
.avw-d{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:11px;border-radius:5px;font-weight:600}
.avw-d.free{background:#dcfce7;color:#166534}
.avw-d.booked{background:#fecaca;color:#991b1b}
.avw-d.past{background:#f1f5f9;color:#cbd5e1}
.cal-scroll{overflow-x:auto}
table.cal{border-collapse:collapse;width:100%;min-width:900px}
table.cal th,table.cal td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:center}
table.cal thead th{background:#f8fafc;padding:8px 6px;font-size:11.5px;color:var(--muted);font-weight:600}
table.cal thead th.we{background:#eff6ff;color:#1d4ed8}
table.cal thead th b{color:var(--txt);font-size:14px}
.roomcol{text-align:left!important;padding:10px 14px!important;font-weight:600;background:#fff;position:sticky;left:0;z-index:5;min-width:200px;box-shadow:2px 0 4px rgba(0,0,0,.03)}
.roomcol small{display:block;color:var(--muted);font-weight:400;font-size:11px}
thead .roomcol{background:#f8fafc!important;color:var(--muted)}
td.cell{cursor:pointer;height:58px;min-width:62px}
td.cell:hover{background:#ecfeff!important;outline:2px solid var(--brand);outline-offset:-2px}
td.cell .av{font-weight:800;font-size:15px}
td.cell .pr{font-size:11px;color:var(--muted)}
td.cell.we{background:#f8fbff}
td.cell.low{background:#fffbeb}td.cell.low .av{color:var(--warn)}
td.cell.full{background:#f1f5f9}td.cell.full .av{color:var(--muted)}
td.cell.closed{background:#fef2f2}td.cell.closed .av{color:var(--danger);font-size:12px}

/* DRAWER */
.drawer-bg{position:fixed;inset:0;background:rgba(15,42,67,.4);opacity:0;pointer-events:none;transition:.2s;z-index:40}
.drawer-bg.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;width:380px;max-width:90vw;height:100vh;background:#fff;box-shadow:-8px 0 30px rgba(0,0,0,.15);transform:translateX(100%);transition:transform .25s;z-index:41;display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer .dh{padding:20px;border-bottom:1px solid var(--line)}
.drawer .dh h3{font-size:17px}.drawer .dh small{color:var(--muted)}
.drawer .db{padding:20px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:16px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:15px;outline:none}
.field input:focus{border-color:var(--brand)}
.row-2{display:flex;gap:12px}.row-2 .field{flex:1}
.chk{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:10px;font-size:13px}
.chk input{width:18px;height:18px}
.sync-note{background:#ecfeff;border:1px solid #a5f3fc;border-radius:10px;padding:12px;font-size:12px;color:#0e7490}
.sync-note b{display:block;margin-bottom:6px;color:#155e75}
.drawer .df{padding:16px 20px;border-top:1px solid var(--line);display:flex;gap:10px}
.drawer .df .btn{flex:1}

/* TOAST */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--navy);color:#fff;padding:13px 20px;border-radius:12px;font-weight:600;font-size:13px;box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:0;transition:.3s;z-index:60;display:flex;align-items:center;gap:10px}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast .ic{color:#22d3ee}

/* CHANNELS */
.ch-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.ch-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}
.ch-card .top{display:flex;align-items:center;gap:12px}
.ch-card .clogo{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;flex-shrink:0}
.ch-card h4{font-size:15px}.ch-card .meta{flex:1}.ch-card .top small{color:var(--muted)}
.ch-card .stats{display:flex;gap:18px;font-size:12px;color:var(--muted);align-items:center}
.ch-card .stats b{display:block;color:var(--txt);font-size:16px}
.conn{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}
.conn.on{background:#dcfce7;color:#166534}.conn.off{background:#f1f5f9;color:#64748b}
.toggle{margin-left:auto;width:42px;height:24px;border-radius:20px;background:var(--ok);position:relative;cursor:pointer;border:none;flex-shrink:0}
.toggle.off{background:#cbd5e1}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s}
.toggle.off::after{left:21px}

/* LOGIN */
.bare{background:linear-gradient(160deg,#0f2a43,#13344f 45%,#0e5566)}
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:400px;background:#fff;border-radius:18px;padding:30px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.auth-card h2{font-size:20px;margin:18px 0 4px}
.auth-card .muted{color:var(--muted);font-size:13px;margin-bottom:18px}
.auth-card label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin:12px 0 6px}
.auth-card input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:15px;outline:none}
.auth-card input:focus{border-color:var(--brand)}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:46px}
.pw-toggle{position:absolute;top:50%;right:6px;transform:translateY(-50%);background:none;border:0;cursor:pointer;font-size:17px;line-height:1;padding:6px;border-radius:8px}
.pw-toggle:hover{background:#f1f5f9}
.onb-guide{border:1px solid var(--brand);margin-bottom:18px}
.onb-guide .ch h3{color:var(--brand)}
.onb-steps{margin:0;padding-left:0;counter-reset:onb;list-style:none}
.onb-steps>li{position:relative;padding:10px 0 10px 44px;border-bottom:1px solid var(--line);line-height:1.6}
.onb-steps>li:last-child{border-bottom:0}
.onb-steps>li::before{counter-increment:onb;content:counter(onb);position:absolute;left:0;top:9px;width:28px;height:28px;border-radius:50%;background:var(--brand);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center}
.onb-copy{margin-top:6px}
.onb-copy code{display:inline-block;background:#eef2f6;padding:6px 10px;border-radius:7px;font-size:13px;color:var(--txt)}
.onb-copy a{display:inline-block;background:#eef2f6;padding:6px 10px;border-radius:7px;font-size:13px;color:var(--brand);font-weight:600;text-decoration:none}
.onb-copy a:hover{background:#e2e8f0;text-decoration:underline}
.pwa-banner{position:fixed;left:12px;right:12px;bottom:12px;z-index:9999;display:flex;align-items:center;gap:10px;background:#0f172a;color:#fff;padding:12px 14px;border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.pwa-banner[hidden]{display:none}
.pwa-banner .pwa-ic{font-size:22px;line-height:1}
.pwa-banner .pwa-tx{flex:1;font-size:13px;line-height:1.4}
.pwa-banner .btn{padding:8px 14px;font-size:13px;white-space:nowrap}
.pwa-banner .pwa-x{background:none;border:0;color:#94a3b8;font-size:16px;cursor:pointer;padding:4px 6px;border-radius:8px}
.pwa-banner .pwa-x:hover{background:rgba(255,255,255,.1);color:#fff}
.alert{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:14px}
.alert.ok{background:#dcfce7;color:#166534}
.demo-hint{margin-top:18px;padding:14px;background:#f8fafc;border:1px solid var(--line);border-radius:10px;font-size:12px;color:var(--muted);line-height:1.7}
.demo-hint code{background:#eef2f6;padding:2px 6px;border-radius:5px;color:var(--txt)}

/* WIZARD */
.wiz-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.wizard{width:100%;max-width:680px;background:#fff;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.25);overflow:hidden}
.wh{padding:22px 28px 0}
.stepper{display:flex;align-items:center;margin:18px 0 6px}
.step{display:flex;align-items:center;flex:1}
.step:last-child{flex:0}
.step .num{width:30px;height:30px;border-radius:50%;background:#e2e8f0;color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;transition:.3s}
.step .lab{font-size:12px;color:var(--muted);margin-left:8px;font-weight:600;white-space:nowrap}
.step .bar{height:3px;background:#e2e8f0;flex:1;margin:0 10px;border-radius:3px;transition:.3s}
.step.active .num{background:var(--brand);color:#fff}
.step.active .lab{color:var(--txt)}
.step.done .num{background:var(--ok);color:#fff}.step.done .bar{background:var(--ok)}
.wb{padding:28px}
.pane{display:none}.pane.active{display:block}
.wb h2{font-size:21px;margin-bottom:6px}
.sub{color:var(--muted);font-size:14px;margin-bottom:22px;line-height:1.5}
.conn-card{display:flex;align-items:center;gap:14px;border:1.5px solid var(--line);border-radius:14px;padding:16px;margin-bottom:12px}
.conn-card.done{border-color:#a7f3d0;background:#f0fdf4}
.conn-card .clogo{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:16px}
.conn-card .info{flex:1}.conn-card h4{font-size:15px}.conn-card small{color:var(--muted)}
.pill{font-size:12px;font-weight:700;color:var(--ok)}
.imp-head{text-align:center;margin-bottom:24px}
.imp-spin{width:54px;height:54px;border:4px solid #e2e8f0;border-top-color:var(--brand);border-radius:50%;margin:0 auto 16px;animation:spin 1s linear infinite}
.imp-done-ic{width:54px;height:54px;border-radius:50%;background:var(--ok);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.progress{height:8px;background:#e2e8f0;border-radius:8px;overflow:hidden;margin:20px 0}
.progress .fill{height:100%;width:0;background:linear-gradient(90deg,var(--brand),#22d3ee);transition:width .5s}
.imp-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.imp-list li{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;color:var(--muted);opacity:.45;transition:.3s}
.imp-list li.on{opacity:1;color:var(--txt);border-color:#a7f3d0;background:#f0fdf4}
.imp-list li .tick{width:22px;height:22px;border-radius:50%;border:2px solid #cbd5e1;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff}
.imp-list li.on .tick{background:var(--ok);border-color:var(--ok)}
.imp-list li b{margin-left:auto}
.map-note{background:#ecfeff;border:1px solid #a5f3fc;color:#0e7490;border-radius:10px;padding:12px 14px;font-size:13px;margin-bottom:18px}
.map-row{display:grid;grid-template-columns:1fr 28px 1fr;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px}
.map-row.warn{border-color:var(--warn);background:#fffbeb}
.src{font-weight:600;font-size:13px}.src small{display:block;color:var(--muted);font-weight:400}
.arrow{text-align:center;color:var(--muted);font-size:18px}
.map-row select{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fff}
.map-row.warn select{border-color:var(--warn)}
.automatch{font-size:10.5px;font-weight:700;color:var(--ok);margin-top:4px;display:inline-block}
.needs{font-size:10.5px;font-weight:700;color:var(--warn);margin-top:4px;display:inline-block}
.done-wrap{text-align:center}
.done-ic{width:74px;height:74px;border-radius:50%;background:var(--ok);color:#fff;font-size:40px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}
.summary .s{background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:14px 8px}
.summary .s b{font-size:22px;display:block;color:var(--brand)}
.summary .s small{font-size:11px;color:var(--muted)}
.wf{padding:18px 28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;background:#fafbfc}
.ov{position:fixed;inset:0;background:rgba(15,42,67,.55);display:none;align-items:center;justify-content:center;z-index:50}
.ov.show{display:flex}
.ov-card{background:#fff;border-radius:16px;padding:30px;text-align:center;width:320px}
.ov-card .sp{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:var(--brand);border-radius:50%;margin:0 auto 14px;animation:spin 1s linear infinite}
.ov-card h4{font-size:16px;margin-bottom:6px}.ov-card p{color:var(--muted);font-size:13px}

.hamburger{display:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:18px;line-height:1}
.sb-backdrop{display:none;position:fixed;inset:0;background:rgba(15,42,67,.45);z-index:45}
.sb-backdrop.open{display:block}
@media(max-width:900px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid2,.ch-grid{grid-template-columns:1fr}
  .hamburger{display:block}
  .host-chip{display:none}
  .sidebar{position:fixed;left:0;top:0;height:100vh;transform:translateX(-100%);transition:transform .25s;z-index:50}
  .sidebar.open{transform:none;box-shadow:8px 0 30px rgba(0,0,0,.3)}
}
@media(max-width:560px){.kpis{grid-template-columns:1fr}}
