/* ═══════ BASE.KE — LANDLORD PORTAL ═══════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --teal:#0D9488;--teal-dark:#0F766E;--teal-light:#CCFBF1;
  --copper:#C4704E;--copper-light:#FDF2EC;
  --black:#0F172A;--white:#FFFFFF;
  --gray-50:#F8FAFC;--gray-100:#F1F5F9;--gray-200:#E2E8F0;
  --gray-300:#CBD5E1;--gray-400:#94A3B8;--gray-500:#64748B;
  --gray-600:#475569;--gray-700:#334155;
  --red:#EF4444;--amber:#F59E0B;--green:#10B981;
  --sidebar-w:240px;
  --font-display:'Clash Display',sans-serif;
  --font-body:'Sora',sans-serif;
  --radius:12px;--radius-sm:8px;
  --shadow:0 1px 3px rgba(15,23,42,0.04),0 1px 2px rgba(15,23,42,0.02);
  --shadow-md:0 4px 12px rgba(15,23,42,0.06);
}
body{font-family:var(--font-body);background:var(--gray-50);color:var(--black);min-height:100vh;font-size:14px;-webkit-font-smoothing:antialiased}

/* ═══════ AUTH ═══════ */
.auth{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,var(--gray-50) 0%,var(--teal-light) 100%)}
.auth-card{background:var(--white);border-radius:16px;padding:2.5rem;width:100%;max-width:380px;box-shadow:var(--shadow-md)}
.auth-brand{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--black);margin-bottom:1.5rem}
.auth-brand span{color:var(--teal)}
.auth-card h1{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin-bottom:0.25rem}
.auth-card>p{color:var(--gray-500);font-size:0.82rem;margin-bottom:2rem}
.auth-error{color:var(--red);font-size:0.78rem;margin-top:1rem;padding:0.6rem;background:#FEF2F2;border-radius:var(--radius-sm)}
.auth-links{display:flex;justify-content:space-between;margin-top:1rem}
.btn-link{border:none;background:none;font-family:var(--font-body);font-size:0.75rem;color:var(--teal);cursor:pointer;padding:0}
.btn-link:hover{text-decoration:underline}
.mfa-qr{display:flex;justify-content:center;margin:1.5rem 0}
.mfa-qr img{width:200px;height:200px;border-radius:var(--radius-sm)}
.mfa-secret{text-align:center;font-family:monospace;font-size:0.72rem;color:var(--gray-500);margin-bottom:1.5rem;word-break:break-all;padding:0.5rem;background:var(--gray-50);border-radius:var(--radius-sm)}
.account-section{background:var(--white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}
.account-section h3{font-family:var(--font-display);font-size:1rem;font-weight:600;margin-bottom:1rem}
.account-row{display:flex;align-items:center;justify-content:space-between;padding:0.8rem 0;border-bottom:1px solid var(--gray-100)}
.account-row:last-child{border-bottom:none}
.account-label{font-size:0.82rem;font-weight:500}
.account-value{font-size:0.82rem;color:var(--gray-500)}

/* ═══════ ONBOARD ═══════ */
.onboard{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,var(--gray-50) 0%,var(--teal-light) 100%)}
.onboard-card{background:var(--white);border-radius:16px;padding:2.5rem;width:100%;max-width:460px;box-shadow:var(--shadow-md)}
.onboard-card h1{font-family:var(--font-display);font-size:1.4rem;font-weight:600;margin-bottom:0.25rem}
.onboard-card>p{color:var(--gray-500);font-size:0.82rem;margin-bottom:2rem}

/* ═══════ FORMS ═══════ */
.field{margin-bottom:1.2rem}
.field label{display:block;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--gray-500);margin-bottom:0.4rem}
.field input,.field select,.field textarea{width:100%;padding:0.7rem 0.9rem;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.85rem;transition:border-color 0.2s,box-shadow 0.2s;background:var(--white)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,0.08)}
.field textarea{resize:vertical;min-height:80px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* ═══════ BUTTONS ═══════ */
.btn-primary{width:100%;padding:0.75rem;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.85rem;font-weight:600;cursor:pointer;background:var(--teal);color:var(--white);transition:all 0.2s}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.btn-ghost{width:100%;padding:0.65rem;border:none;background:none;font-family:var(--font-body);font-size:0.8rem;color:var(--gray-500);cursor:pointer;margin-top:0.5rem}
.btn-ghost:hover{color:var(--teal)}
.btn-sm{padding:0.5rem 1rem;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.78rem;font-weight:600;cursor:pointer;background:var(--teal);color:var(--white);transition:all 0.2s}
.btn-sm:hover{background:var(--teal-dark)}
.btn-sm.outline{background:none;border:1.5px solid var(--gray-200);color:var(--gray-600)}
.btn-sm.outline:hover{border-color:var(--teal);color:var(--teal)}
.btn-sm.copper{background:var(--copper);color:var(--white)}
.btn-sm.copper:hover{background:#B5623F}
.btn-sm.danger{background:var(--red);color:var(--white)}

/* ═══════ LAYOUT ═══════ */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.hidden{display:none!important}

/* ═══════ SIDEBAR ═══════ */
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--black);display:flex;flex-direction:column;z-index:100;padding:1.5rem 0}
.sidebar-brand{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--white);padding:0 1.5rem 1.5rem}
.sidebar-brand span{color:var(--teal)}
.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:0.7rem;padding:0.7rem 1.5rem;color:var(--gray-400);text-decoration:none;font-size:0.82rem;font-weight:500;transition:all 0.15s;border-left:3px solid transparent;cursor:pointer}
.nav-item:hover{color:var(--gray-200);background:rgba(255,255,255,0.03)}
.nav-item.active{color:var(--white);background:rgba(13,148,136,0.08);border-left-color:var(--teal)}
.nav-item svg{flex-shrink:0;opacity:0.7}
.nav-item.active svg{opacity:1}
.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,0.06)}
.sidebar-user{font-size:0.78rem;font-weight:500;color:var(--gray-300);margin-bottom:0.5rem}
.sidebar-logout{border:none;background:none;color:var(--gray-500);font-family:var(--font-body);font-size:0.72rem;cursor:pointer;padding:0}
.sidebar-logout:hover{color:var(--red)}

/* ═══════ MAIN ═══════ */
.main{margin-left:var(--sidebar-w);padding:2rem 2.5rem;min-height:100vh}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}
.topbar-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600}
.topbar-sub{font-size:0.78rem;color:var(--gray-500);margin-top:0.15rem}
.topbar-actions{display:flex;align-items:center;gap:0.8rem}
.prop-select{padding:0.5rem 1rem;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.8rem;background:var(--white);cursor:pointer}
.prop-select:focus{outline:none;border-color:var(--teal)}

/* ═══════ KPI CARDS ═══════ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}
.kpi{background:var(--white);border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:var(--shadow);transition:transform 0.2s,box-shadow 0.2s}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.kpi-label{font-size:0.68rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--gray-500)}
.kpi-value{font-family:var(--font-display);font-size:1.8rem;font-weight:700;margin-top:0.3rem;line-height:1}
.kpi-sub{font-size:0.7rem;color:var(--gray-400);margin-top:0.4rem}
.kpi-value.teal{color:var(--teal)}
.kpi-value.copper{color:var(--copper)}

/* ═══════ CARDS ═══════ */
.card{background:var(--white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.card-title{font-family:var(--font-display);font-size:1rem;font-weight:600}
.card-action{font-size:0.75rem;color:var(--teal);font-weight:600;cursor:pointer;text-decoration:none}
.card-action:hover{text-decoration:underline}

/* ═══════ CONTENT GRID ═══════ */
.content-2col{display:grid;grid-template-columns:1.6fr 1fr;gap:1.5rem}

/* ═══════ CHART ═══════ */
.chart-bars{display:flex;align-items:flex-end;gap:10px;height:140px;padding-top:0.5rem}
.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.chart-fill{width:100%;border-radius:6px 6px 2px 2px;background:linear-gradient(180deg,var(--teal),var(--teal-dark));transition:height 0.6s cubic-bezier(0.34,1.56,0.64,1);min-height:4px}
.chart-fill:hover{filter:brightness(1.1)}
.chart-lbl{font-size:0.6rem;color:var(--gray-400)}

/* ═══════ FEED ═══════ */
.feed-item{display:flex;align-items:center;gap:0.8rem;padding:0.65rem 0;border-bottom:1px solid var(--gray-100)}
.feed-item:last-child{border-bottom:none}
.feed-avatar{width:34px;height:34px;border-radius:50%;background:var(--teal);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:0.62rem;font-weight:700;flex-shrink:0}
.feed-info{flex:1;min-width:0}
.feed-name{font-size:0.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-sub{font-size:0.68rem;color:var(--gray-400)}
.feed-amount{font-size:0.82rem;font-weight:700;color:var(--teal);white-space:nowrap}

/* ═══════ TABLE ═══════ */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:0.8rem}
th{text-align:left;padding:0.65rem 0.8rem;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--gray-400);border-bottom:2px solid var(--gray-100)}
td{padding:0.7rem 0.8rem;border-bottom:1px solid var(--gray-50);vertical-align:middle}
tr:hover td{background:rgba(13,148,136,0.015)}
.table-actions{display:flex;gap:0.4rem}

/* ═══════ BADGES ═══════ */
.badge{display:inline-block;padding:0.18rem 0.55rem;border-radius:100px;font-size:0.64rem;font-weight:600;text-transform:uppercase;letter-spacing:0.02em}
.badge-green{background:#DCFCE7;color:#16A34A}
.badge-amber{background:#FEF9C3;color:#CA8A04}
.badge-red{background:#FEE2E2;color:#DC2626}
.badge-blue{background:#DBEAFE;color:#2563EB}
.badge-gray{background:var(--gray-100);color:var(--gray-500)}
.badge-teal{background:var(--teal-light);color:var(--teal-dark)}
.badge-copper{background:var(--copper-light);color:var(--copper)}

/* ═══════ EMPTY STATE ═══════ */
.empty{text-align:center;padding:3rem;color:var(--gray-400)}
.empty-icon{font-size:2.5rem;margin-bottom:0.8rem;opacity:0.5}
.empty p{font-size:0.85rem;margin-bottom:1rem}

/* ═══════ MODAL ═══════ */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,0.4);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:2rem}
.modal-backdrop.hidden{display:none}
.modal{background:var(--white);border-radius:16px;padding:2rem;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(15,23,42,0.15)}
.modal h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-bottom:1.2rem}
.modal-actions{display:flex;gap:0.8rem;margin-top:1.5rem}
.modal-actions .btn-primary,.modal-actions .btn-sm{flex:1}

/* ═══════ TOAST ═══════ */
.toast{position:fixed;bottom:2rem;right:2rem;padding:0.75rem 1.3rem;border-radius:var(--radius-sm);font-size:0.8rem;font-weight:600;color:var(--white);z-index:300;transform:translateY(20px);opacity:0;transition:all 0.3s;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:var(--teal)}
.toast.error{background:var(--red)}

/* ═══════ FILTERS ═══════ */
.filters{display:flex;gap:0.5rem;margin-bottom:1.2rem;flex-wrap:wrap}
.filter-btn{padding:0.35rem 0.9rem;border-radius:100px;border:1.5px solid var(--gray-200);background:var(--white);font-family:var(--font-body);font-size:0.72rem;font-weight:500;cursor:pointer;transition:all 0.15s}
.filter-btn.active{background:var(--teal);color:var(--white);border-color:var(--teal)}
.filter-btn:hover{border-color:var(--teal)}

/* ═══════ PROGRESS ═══════ */
.progress{height:5px;background:var(--gray-100);border-radius:3px;overflow:hidden;margin-top:0.4rem}
.progress-fill{height:100%;border-radius:3px;background:var(--teal);transition:width 0.6s ease}
.progress-fill.amber{background:var(--amber)}
.progress-fill.red{background:var(--red)}

/* ═══════ LOADING ═══════ */
.spinner{width:20px;height:20px;border:2.5px solid var(--gray-200);border-top-color:var(--teal);border-radius:50%;animation:spin 0.6s linear infinite;margin:2rem auto}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.view-enter{animation:fadeIn 0.25s ease}

/* ═══════ RESPONSIVE ═══════ */
@media(max-width:1024px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .content-2col{grid-template-columns:1fr}
}
@media(max-width:768px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .main{margin-left:0;padding:1.5rem}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:1fr}
}
