/* ═══════════════ 1. TOKENS ═══════════════ */
:root{
  --primary:#0F766E; --primary-dark:#115E59; --primary-tint:#CCFBF1;
  --sidebar:#134E4A;
  --ink:#0F172A; --ink2:#475569; --ink3:#94A3B8;
  --line:#E2E8F0; --bg:#F8FAFC; --card:#FFFFFF;
  --success:#15803D; --success-tint:#DCFCE7;
  --warning:#B45309; --warning-tint:#FEF3C7;
  --danger:#B91C1C;  --danger-tint:#FEE2E2;
  --info:#1D4ED8;    --info-tint:#DBEAFE;
  --chart2:#0EA5E9;
  --r:12px; --shadow:0 1px 3px rgba(15,23,42,.08);
  --shadow-lg:0 10px 30px rgba(15,23,42,.16);
  --font:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;
}

/* ═══════════════ 2. BASE ═══════════════ */
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;min-height:100vh}
h1{font-size:24px;font-weight:800;margin:0 0 4px} h2{font-size:18px;font-weight:600;margin:0 0 8px}
h3{font-size:15px;font-weight:600;margin:0 0 6px}
p{margin:0 0 10px} a{color:var(--primary)} small,.small{font-size:13px;color:var(--ink2)}
.muted{color:var(--ink2)} .muted3{color:var(--ink3)}
.money{font-variant-numeric:tabular-nums;white-space:nowrap}
.icon{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.75;
  stroke-linecap:round;stroke-linejoin:round;vertical-align:-4px;flex:none}
.icon.sm{width:16px;height:16px;vertical-align:-3px} .icon.lg{width:26px;height:26px}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
.right{text-align:right}.center{text-align:center}
.row{display:flex;gap:10px;align-items:center}.row.wrap{flex-wrap:wrap}
.between{display:flex;justify-content:space-between;align-items:center;gap:10px}
.grow{flex:1}.mt{margin-top:14px}.mb{margin-bottom:14px}.hidden{display:none!important}

/* ═══════════════ 3. LAYOUT ═══════════════ */
.boot-splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:90vh}
.boot-logo{width:64px;height:64px;border-radius:18px;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg)}

.shell{display:flex;min-height:100vh}
.sidebar{width:236px;background:var(--sidebar);color:#fff;flex:none;display:flex;flex-direction:column;
  position:fixed;top:0;bottom:0;left:0;z-index:40;transition:transform .2s ease-out}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:18px 16px;font-weight:800;font-size:17px}
.sidebar .brand .logo{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;font-weight:800;overflow:hidden}
.sidebar .brand .logo img{width:100%;height:100%;object-fit:cover}
.sidebar nav{flex:1;overflow-y:auto;padding:6px 10px}
.snav{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:0;background:none;
  color:rgba(255,255,255,.82);padding:10px 12px;border-radius:9px;font:inherit;font-size:14.5px;
  cursor:pointer;margin:1px 0;position:relative}
.snav:hover{background:rgba(255,255,255,.08);color:#fff}
.snav.on{background:rgba(255,255,255,.14);color:#fff;font-weight:600}
.snav .nbadge{margin-left:auto;background:var(--danger);color:#fff;font-size:11px;font-weight:700;
  border-radius:999px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.sidebar .sep{height:1px;background:rgba(255,255,255,.12);margin:8px 12px}
.sidebar .foot{padding:12px 16px;font-size:12px;color:rgba(255,255,255,.5)}

.main{flex:1;margin-left:236px;display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:12px;padding:14px 22px;background:var(--card);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.topbar .hamb{display:none}
.content{padding:22px;max-width:1180px;width:100%;margin:0 auto;flex:1}
.scrim{position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:39;display:none}

/* Portal del inquilino: app centrada, bottom-nav */
.tshell{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);display:flex;flex-direction:column;
  box-shadow:0 0 40px rgba(15,23,42,.06)}
.thead{display:flex;align-items:center;gap:10px;padding:16px 18px 8px}
.thead .tlogo{width:36px;height:36px;border-radius:10px;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;overflow:hidden}
.thead .tlogo img{width:100%;height:100%;object-fit:cover}
.tcontent{flex:1;padding:10px 16px 86px}
.bottomnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;
  background:var(--card);border-top:1px solid var(--line);display:flex;z-index:35;
  padding-bottom:env(safe-area-inset-bottom)}
.bnav{flex:1;border:0;background:none;font:inherit;font-size:11.5px;color:var(--ink3);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 0 7px;min-height:56px;position:relative}
.bnav.on{color:var(--primary);font-weight:600}
.bnav .nbadge{position:absolute;top:5px;right:calc(50% - 20px);background:var(--danger);color:#fff;
  font-size:10px;font-weight:700;border-radius:999px;min-width:16px;height:16px;
  display:flex;align-items:center;justify-content:center}

@media (max-width:1023px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:none}
  .scrim.open{display:block}
  .main{margin-left:0}
  .topbar .hamb{display:inline-flex}
  .content{padding:16px}
}

/* ═══════════════ 4. COMPONENTES ═══════════════ */
/* Botones */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;
  font:inherit;font-weight:600;font-size:14.5px;border-radius:10px;padding:10px 18px;
  background:var(--primary);color:#fff;transition:background .15s;min-height:42px;text-decoration:none}
.btn:hover{background:var(--primary-dark)} .btn:disabled{opacity:.55;cursor:default}
.btn.big{width:100%;min-height:54px;font-size:16px}
.btn.sec{background:var(--card);color:var(--ink);border:1px solid var(--line)}
.btn.sec:hover{background:var(--bg)}
.btn.ghost{background:none;color:var(--primary);padding:8px 10px;min-height:36px}
.btn.danger{background:var(--danger)} .btn.danger:hover{background:#991B1B}
.btn.sm{padding:7px 12px;min-height:34px;font-size:13px;border-radius:8px}
.btn .spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:0;
  background:none;border-radius:9px;cursor:pointer;color:var(--ink2)}
.iconbtn:hover{background:var(--bg);color:var(--ink)}

/* Cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);
  padding:18px;margin-bottom:14px}
.card.click{cursor:pointer;transition:box-shadow .15s,transform .15s}
@media(hover:hover){.card.click:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}}
.card .card-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;margin-bottom:10px}

/* Badges de estado */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;
  border-radius:999px;padding:3px 10px;white-space:nowrap}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}
.b-success{background:var(--success-tint);color:var(--success)}
.b-warning{background:var(--warning-tint);color:var(--warning)}
.b-danger{background:var(--danger-tint);color:var(--danger)}
.b-info{background:var(--info-tint);color:var(--info)}
.b-neutral{background:#F1F5F9;color:var(--ink2)}
.b-primary{background:var(--primary-tint);color:var(--primary-dark)}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:12px;margin-bottom:16px}
@media(max-width:760px){.kpis{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
  .kpis .kpi{min-width:170px;scroll-snap-align:start}}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;box-shadow:var(--shadow)}
.kpi .klabel{font-size:12.5px;color:var(--ink2);display:flex;align-items:center;gap:6px;margin-bottom:6px}
.kpi .kval{font-size:24px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1.15}
.kpi .ksub{font-size:12px;color:var(--ink3);margin-top:3px}
.kpi.alert .kval{color:var(--danger)}
.kpi.click{cursor:pointer;transition:box-shadow .15s,transform .15s}
@media(hover:hover){.kpi.click:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}}
.chart.clickable .bar-hit:hover~.bar,.chart.clickable .bar{transition:opacity .15s}
.balance-tot{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:6px 0 4px}
.balance-tot .bt-cell{border:1px solid var(--line);border-radius:var(--r);padding:13px 15px;background:var(--card)}
.balance-tot .bt-cell .bl{font-size:12.5px;color:var(--ink2)}
.balance-tot .bt-cell .bv{font-size:21px;font-weight:800;font-variant-numeric:tabular-nums;margin-top:3px}
.bt-util .bv{color:var(--success)} .bt-util.neg .bv{color:var(--danger)}
.kbar{height:6px;background:var(--line);border-radius:99px;margin-top:8px;overflow:hidden}
.kbar>div{height:100%;background:var(--primary);border-radius:99px;transition:width .6s ease-out}

/* Tablas → cards en móvil */
.tablewrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;background:var(--card);border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow)}
.tbl th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--ink2);text-align:left;
  padding:11px 14px;border-bottom:1px solid var(--line);background:#FBFCFE;white-space:nowrap}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
@media(hover:hover){.tbl tbody tr:hover{background:#FBFCFE}}
@media(max-width:760px){
  .tbl thead{display:none}
  .tbl,.tbl tbody,.tbl tr,.tbl td{display:block;width:100%}
  .tbl tr{border-bottom:8px solid var(--bg);padding:6px 0}
  .tbl td{border:0;padding:5px 14px;display:flex;justify-content:space-between;gap:10px;align-items:center}
  .tbl td::before{content:attr(data-l);font-size:12px;color:var(--ink2);font-weight:600;flex:none}
  .tbl td:not([data-l])::before{display:none}
}

/* Formularios */
.frm label{display:block;font-size:13.5px;font-weight:600;margin:13px 0 5px}
.frm label .opt{font-weight:400;color:var(--ink3)}
.frm input[type=text],.frm input[type=number],.frm input[type=email],.frm input[type=date],
.frm input[type=tel],.frm input[type=password],.frm select,.frm textarea{
  width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font:inherit;
  font-size:16px;background:var(--card);color:var(--ink)}
.frm input:focus,.frm select:focus,.frm textarea:focus{border-color:var(--primary);outline:none}
.frm textarea{min-height:88px;resize:vertical}
.frm .help{font-size:12.5px;color:var(--ink3);margin-top:4px}
.frm .err{font-size:13px;color:var(--danger);margin-top:4px}
.frm .grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
@media(max-width:560px){.frm .grid2{grid-template-columns:1fr}}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{border:1.5px solid var(--line);background:var(--card);border-radius:999px;padding:8px 15px;
  font:inherit;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.chip.on{border-color:var(--primary);background:var(--primary-tint);color:var(--primary-dark);font-weight:600}
.switch{position:relative;display:inline-block;width:44px;height:25px;flex:none}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:#CBD5E1;border-radius:99px;transition:.18s;cursor:pointer}
.switch .sl::before{content:'';position:absolute;width:19px;height:19px;border-radius:50%;background:#fff;
  top:3px;left:3px;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.switch input:checked+.sl{background:var(--primary)}
.switch input:checked+.sl::before{transform:translateX(19px)}
.segmented{display:flex;background:#F1F5F9;border-radius:10px;padding:3px;gap:3px}
.segmented button{flex:1;border:0;background:none;font:inherit;font-size:13.5px;font-weight:600;
  color:var(--ink2);padding:8px 6px;border-radius:8px;cursor:pointer;white-space:nowrap}
.segmented button.on{background:var(--card);color:var(--ink);box-shadow:var(--shadow)}

/* Modales y bottom-sheets */
#modal-root .overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:60;
  display:flex;align-items:center;justify-content:center;animation:fadein .15s ease-out}
.modal{background:var(--card);border-radius:16px;max-width:520px;width:calc(100% - 36px);
  max-height:86vh;overflow-y:auto;padding:22px;box-shadow:var(--shadow-lg);animation:up .18s ease-out}
@keyframes fadein{from{opacity:0}} @keyframes up{from{transform:translateY(14px);opacity:0}}
@media(max-width:640px){
  #modal-root .overlay{align-items:flex-end}
  .modal{width:100%;max-width:480px;border-radius:18px 18px 0 0;max-height:92vh;
    padding-bottom:calc(22px + env(safe-area-inset-bottom));animation:sheet .22s ease-out}
  .modal::before{content:'';display:block;width:42px;height:4px;border-radius:99px;background:var(--line);margin:0 auto 14px}
  @keyframes sheet{from{transform:translateY(100%)}}
}
.modal .mhead{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}

/* Toasts */
#toasts{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:80;display:flex;
  flex-direction:column;gap:8px;align-items:center;width:max-content;max-width:calc(100vw - 30px)}
.toast{background:var(--ink);color:#fff;border-radius:11px;padding:11px 18px;font-size:14px;
  display:flex;align-items:center;gap:9px;box-shadow:var(--shadow-lg);animation:up .2s ease-out;max-width:100%}
.toast.ok .icon{color:#4ADE80}.toast.err .icon{color:#FCA5A5}.toast.warn .icon{color:#FCD34D}

/* Skeletons */
.skl{background:linear-gradient(90deg,#EDF1F6 25%,#F6F8FB 50%,#EDF1F6 75%);background-size:200% 100%;
  animation:shimmer 1.3s infinite;border-radius:8px;height:14px}
@keyframes shimmer{to{background-position:-200% 0}}
.skl-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px;margin-bottom:14px}

/* Estados vacíos */
.empty{text-align:center;padding:46px 22px;color:var(--ink2)}
.empty .eicon{width:74px;height:74px;border-radius:22px;background:var(--primary-tint);color:var(--primary);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.empty h2{color:var(--ink)} .empty p{max-width:420px;margin:0 auto 16px}

/* Listas */
.litem{display:flex;align-items:center;gap:12px;padding:13px 4px;border-bottom:1px solid var(--line)}
.litem:last-child{border-bottom:0}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-tint);color:var(--primary-dark);
  display:flex;align-items:center;justify-content:center;font-weight:700;flex:none;font-size:15px}
.litem .lmain{flex:1;min-width:0}.litem .lmain .t{font-weight:600}
.litem .lmain .s{font-size:12.5px;color:var(--ink2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Tabs */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--line);margin-bottom:16px;overflow-x:auto}
.tab{border:0;background:none;font:inherit;font-size:14.5px;font-weight:600;color:var(--ink2);
  padding:10px 15px;cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;white-space:nowrap;
  display:inline-flex;align-items:center;gap:7px}
.tab.on{color:var(--primary);border-bottom-color:var(--primary)}
.tab .nbadge{background:var(--danger);color:#fff;font-size:11px;font-weight:700;border-radius:999px;
  min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}

/* Kanban */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:start}
@media(max-width:1000px){.kanban{display:block}}
.kcol{background:#F1F5F9;border-radius:var(--r);padding:10px;min-height:60px;margin-bottom:10px}
.kcol .khead{font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--ink2);padding:4px 6px 10px;display:flex;justify-content:space-between}
.kcard{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:9px;
  box-shadow:var(--shadow);cursor:pointer}
.kcard .kt{font-weight:600;font-size:14px;margin:4px 0}
.kcard.dragging{opacity:.5}
.kcol.dragover{outline:2px dashed var(--primary);outline-offset:-4px}
.pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--danger);
  animation:pulse 1.2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 5px rgba(185,28,28,.15)}}

/* Chat */
.chatlog{display:flex;flex-direction:column;gap:8px;padding:6px 0}
.bub{max-width:78%;border-radius:14px;padding:9px 13px;font-size:14.5px;position:relative}
.bub .bt{font-size:11px;color:var(--ink3);margin-top:3px}
.bub.me{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:4px}
.bub.me .bt{color:rgba(255,255,255,.7)}
.bub.them{align-self:flex-start;background:var(--card);border:1px solid var(--line);border-bottom-left-radius:4px}
.bub.anuncio{align-self:stretch;max-width:100%;background:var(--info-tint);border:1px solid #BFDBFE;color:var(--ink)}
.chatbox{display:flex;gap:8px;position:sticky;bottom:70px;background:var(--bg);padding:8px 0}
.chatbox input{flex:1;border:1.5px solid var(--line);border-radius:99px;padding:11px 16px;font:inherit;font-size:16px}

/* Hero del inquilino */
.hero{border-radius:18px;padding:26px 22px;margin-bottom:16px;color:var(--ink)}
.hero.aldia{background:linear-gradient(135deg,#ECFDF5,#D1FAE5)}
.hero.pendiente{background:linear-gradient(135deg,#FFFBEB,#FEF3C7)}
.hero.mora{background:linear-gradient(135deg,#FEF2F2,#FEE2E2)}
.hero .hbig{font-size:31px;font-weight:800;font-variant-numeric:tabular-nums;margin:5px 0 2px}
.hero .hstate{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px}
.hero.aldia .hstate{color:var(--success)}.hero.pendiente .hstate{color:var(--warning)}.hero.mora .hstate{color:var(--danger)}
.paybox{background:rgba(255,255,255,.75);border-radius:12px;padding:12px 14px;margin-top:12px;font-size:14px}

/* Charts SVG */
.chart{width:100%}
.chart .bar{transition:opacity .15s}
.chart .bar:hover{opacity:.75}
.ring{transform:rotate(-90deg)}
.legend{display:flex;gap:14px;font-size:12.5px;color:var(--ink2);margin-top:6px}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px}

/* Login / PIN */
.authwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.authcard{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);
  max-width:420px;width:100%;padding:34px 28px;text-align:center}
.authcard .alogo{width:62px;height:62px;border-radius:17px;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.pinrow{display:flex;gap:8px;justify-content:center;margin:18px 0}
.pinrow input{width:46px;height:56px;text-align:center;font-size:24px;font-weight:700;
  border:1.5px solid var(--line);border-radius:11px;font-variant-numeric:tabular-nums}
.pinrow input:focus{border-color:var(--primary);outline:none}

/* Wizard */
.wizwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.wizcard{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);
  max-width:560px;width:100%;padding:30px}
.dots{display:flex;gap:7px;justify-content:center;margin-bottom:22px}
.dots i{width:8px;height:8px;border-radius:50%;background:var(--line);transition:.2s}
.dots i.on{background:var(--primary);width:22px;border-radius:99px}
.checklist{list-style:none;padding:0;margin:14px 0}
.checklist li{display:flex;align-items:center;gap:11px;padding:8px 0;color:var(--ink2)}
.checklist li.done{color:var(--ink)}
.checklist li .ic{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none}
.checklist li.done .ic{background:var(--success-tint);color:var(--success)}
.checklist li.doing .ic{border:2.5px solid var(--line);border-top-color:var(--primary);animation:spin .8s linear infinite}
.checklist li.todo .ic{border:2px solid var(--line)}

/* Zona de peligro y misc */
.danger-zone{border:1.5px solid #FECACA;background:#FEF2F2;border-radius:var(--r);padding:18px}
.copyable{display:inline-flex;align-items:center;gap:7px;background:#F1F5F9;border-radius:8px;
  padding:6px 11px;font-size:14px;cursor:pointer;border:1px dashed var(--line);font-variant-numeric:tabular-nums}
.copyable:hover{border-color:var(--primary)}
.fotos-grid{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.fotos-grid .ph{width:74px;height:74px;border-radius:10px;object-fit:cover;border:1px solid var(--line);cursor:pointer}
.banner{display:flex;gap:10px;border-radius:11px;padding:12px 14px;font-size:13.5px;margin:10px 0;align-items:flex-start}
.banner.info{background:var(--info-tint);color:#1E3A8A}
.banner.warn{background:var(--warning-tint);color:#78350F}
.banner .icon{margin-top:1px}
.fab{position:fixed;bottom:84px;right:calc(50% - 240px + 18px);width:56px;height:56px;border-radius:50%;
  background:var(--primary);color:#fff;border:0;box-shadow:var(--shadow-lg);cursor:pointer;z-index:34;
  display:flex;align-items:center;justify-content:center}
@media(max-width:520px){.fab{right:18px}}
.searchbox{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--line);
  border-radius:10px;padding:0 12px;max-width:340px;flex:1}
.searchbox input{border:0;outline:none;font:inherit;font-size:15px;padding:9px 0;width:100%;background:none}
.view-anim{animation:viewin .18s ease-out}
@keyframes viewin{from{opacity:0;transform:translateY(8px)}}
code{background:#F1F5F9;border-radius:5px;padding:1px 6px;font-size:12.5px;font-family:ui-monospace,Consolas,monospace}

/* Dropdown buscable / multiselección (componente propio) */
.dd{position:relative;width:100%}
.dd-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;
  border:1.5px solid var(--line);border-radius:10px;background:var(--card);color:var(--ink);
  font:inherit;font-size:15px;padding:10px 13px;cursor:pointer;min-height:44px;text-align:left}
.dd-trigger:hover{border-color:var(--ink3)}
.dd-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-ph{color:var(--ink3)}
.dd-caret{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;
  border-top:6px solid var(--ink3);flex:none}
.dd-panel{position:absolute;z-index:70;top:calc(100% + 4px);left:0;right:0;background:var(--card);
  border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow-lg);padding:6px;
  max-height:300px;display:flex;flex-direction:column}
/* El atributo [hidden] debe ganarle al display:flex de arriba (regla de autor vs UA) */
.dd-panel[hidden]{display:none}
.dd-srch{padding:4px 4px 6px}
.dd-srch input{width:100%;border:1.5px solid var(--line);border-radius:8px;padding:8px 11px;font:inherit;font-size:15px;outline:none}
.dd-srch input:focus{border-color:var(--primary)}
.dd-list{overflow-y:auto;display:flex;flex-direction:column}
.dd-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:14.5px}
.dd-item:hover{background:var(--bg)}
.dd-item.on{background:var(--primary-tint);color:var(--primary-dark)}
.dd-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--line);display:flex;
  align-items:center;justify-content:center;font-size:12px;color:var(--primary);flex:none;background:var(--card);font-weight:700}
.dd-item.on .dd-check{border-color:var(--primary)}
.dd-it-main{flex:1;min-width:0;display:flex;flex-direction:column}
.dd-it-sub{font-size:12px;color:var(--ink3);font-weight:400}
.dd-vacio{padding:12px;text-align:center;color:var(--ink3);font-size:13.5px}

/* Filtros colapsables (dashboard, propiedades, inquilinos) */
.filtros-tog{display:inline-flex;align-items:center;gap:6px;border:0;background:none;cursor:pointer;
  color:var(--ink3);font:inherit;font-size:13px;font-weight:600;padding:4px 2px}
.filtros-tog:hover{color:var(--ink2)}
.filtros-tog .fch{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;transition:transform .18s}
.filtros-tog.open .fch{transform:rotate(180deg)}
.filtros{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);
  padding:14px 16px;margin-bottom:14px;animation:viewin .18s ease-out}
.filtros .fgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;align-items:end}
.filtros .fld>label{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin-bottom:5px}
.filtros .fld.fld-range{grid-column:span 2}
@media(max-width:760px){.filtros .fld.fld-range{grid-column:auto}}
.filtros .frange{display:flex;align-items:center;gap:6px}
.filtros .frange input{width:100%;min-width:0;border:1.5px solid var(--line);border-radius:9px;padding:9px 11px;font:inherit;font-size:14px;background:var(--card)}
.filtros .frange input:focus{border-color:var(--primary);outline:none}
.filtros .factions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}

/* Barra de exportación */
.exp-bar{justify-content:flex-end;gap:8px;margin-top:12px;flex-wrap:wrap}

/* Modal ancho (tablas) y pestañas dentro de modal */
.modal.wide{max-width:880px}
@media(max-width:920px){.modal.wide{max-width:calc(100% - 36px)}}
.modal .tabs{margin-top:8px}
.modal .tablewrap{margin-top:4px}
.tbl.compact th{padding:8px 11px}.tbl.compact td{padding:8px 11px}
.tfoot-total{font-weight:800;background:#FBFCFE}

/* Bloc de notas (detalle de propiedad) */
.notepad{background:#FFFDF5;border:1px solid #EFE7C8;border-radius:var(--r);padding:13px 15px;
  font-size:14px;line-height:1.6;white-space:pre-wrap;min-height:54px;color:var(--ink)}
.notepad.empty-note{color:var(--ink3);font-style:italic}

/* Botón sutil de subir (estudio registral) */
.upload-sutil{display:inline-flex;align-items:center;gap:7px;border:1.5px dashed var(--line);
  background:var(--bg);color:var(--ink2);border-radius:10px;padding:9px 13px;font:inherit;font-size:13.5px;
  font-weight:600;cursor:pointer;width:100%;justify-content:center}
.upload-sutil:hover{border-color:var(--primary);color:var(--primary)}
.field-auto{border-color:var(--primary)!important;background:var(--primary-tint)!important;transition:background .4s}

/* Galería de propiedad */
.galeria{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:8px}
.galeria img{width:100%;height:96px;object-fit:cover;border-radius:10px;border:1px solid var(--line);cursor:pointer}

/* ═══════════════ Editor de plantillas de contrato (tipo Word) ═══════════════ */
.ce-toolbar{display:flex;flex-wrap:wrap;gap:3px;align-items:center;position:sticky;top:0;z-index:3;
  background:var(--card);border:1.5px solid var(--line);border-radius:10px;padding:6px;margin:6px 0 10px}
.ce-tool{min-width:34px;height:34px;padding:0 9px;border:1px solid transparent;border-radius:8px;background:transparent;
  color:var(--ink);font:inherit;font-size:14px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:5px}
.ce-tool:hover{background:var(--bg)}
.ce-tool.on{background:var(--primary-tint);color:var(--primary-dark)}
.ce-tool b{font-weight:800}.ce-tool i{font-style:italic;font-family:Georgia,serif}.ce-tool u{text-decoration:underline}
.ce-tool .icon{width:17px;height:17px}
.ce-sep{width:1px;height:22px;background:var(--line);margin:0 5px;flex:none}
.ce-tool.campo{margin-left:auto;background:var(--primary);color:#fff;font-weight:600;padding:0 13px}
.ce-tool.campo:hover{background:var(--primary-dark)}
.ce-tool.campo .icon{width:15px;height:15px}
.ce-nombre{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font:inherit;font-size:16px;margin-top:4px}
.ce-nombre:focus{outline:none;border-color:var(--primary)}
.ce-page{background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:28px 32px;min-height:340px;
  max-height:46vh;overflow-y:auto;font-size:15px;line-height:1.65;color:var(--ink);outline:none}
.ce-page:focus{border-color:var(--primary)}
.ce-page>:first-child{margin-top:0}
.ce-page h1{font-size:22px;margin:0 0 10px}.ce-page h2{font-size:18px;margin:14px 0 8px}.ce-page h3{font-size:16px;margin:12px 0 6px}
.ce-page p{margin:0 0 10px}.ce-page ul,.ce-page ol{margin:0 0 10px;padding-left:24px}
.field-token{display:inline-block;background:var(--primary-tint);color:var(--primary-dark);border-radius:6px;
  padding:0 6px;font-weight:600;font-size:.93em;white-space:nowrap;user-select:all}
.ce-campo-panel{display:none;gap:8px;align-items:center;flex-wrap:wrap;background:var(--bg);
  border:1.5px solid var(--line);border-radius:10px;padding:10px;margin-bottom:10px}
.ce-campo-panel.open{display:flex}
.ce-campo-panel input{flex:1;min-width:170px;border:1.5px solid var(--line);border-radius:8px;padding:9px 11px;font:inherit;font-size:16px}
.ce-campo-panel input:focus{outline:none;border-color:var(--primary)}
.ce-sugs{flex-basis:100%;display:flex;flex-wrap:wrap;gap:6px}
.ce-sugs .muted{align-self:center}
.ce-chip{border:1.5px solid var(--line);background:var(--card);border-radius:999px;padding:5px 11px;font-size:12.5px;cursor:pointer;color:var(--ink2)}
.ce-chip:hover{border-color:var(--primary);color:var(--primary-dark)}

/* ═══════════════ 5. PRINT (recibos / estados de cuenta) ═══════════════ */
@media print{
  body{background:#fff}
  .sidebar,.topbar,.bottomnav,.fab,#toasts,.no-print,.btn{display:none!important}
  .main{margin:0}.content{padding:0;max-width:none}
  .card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}
}
