/* ============================================================
   TerraPlant Partners · Portal Theme
   Professional teal / warm gray
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap');

:root {
  --bg:#f7f8fa; --bg2:#fff; --bg3:#f0f2f5;
  --card:#fff; --border:#e2e5ea;
  --text:#1a1d27; --text2:#5e6278; --text3:#a1a5b7;
  --accent:#0d9488; --accent2:#0891b2; --accent-light:rgba(13,148,136,.08);
  --red:#ef4444; --amber:#f59e0b; --green:#22c55e; --purple:#8b5cf6;
  --font:'DM Sans',system-ui,sans-serif;
  --radius:10px; --shadow:0 2px 12px rgba(0,0,0,.06);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;}
#app{display:flex;min-height:100vh;}

/* Sidebar */
.sidebar{width:230px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;}
.sidebar-brand{padding:20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);}
.brand-icon{font-size:22px;}
.brand-text{font-size:16px;font-weight:700;color:var(--accent);}
.sidebar-nav{flex:1;padding:12px 8px;}
.nav-item{display:block;padding:10px 16px;border-radius:8px;color:var(--text2);text-decoration:none;font-size:14px;font-weight:500;transition:all .15s;margin-bottom:2px;}
.nav-item:hover{background:var(--accent-light);color:var(--accent);}
.nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:600;}
.sidebar-footer{padding:16px;border-top:1px solid var(--border);}
.user-info{font-size:12px;color:var(--text3);margin-bottom:8px;line-height:1.5;}
.btn-logout{width:100%;padding:8px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text2);cursor:pointer;font-family:var(--font);font-size:13px;transition:all .15s;}
.btn-logout:hover{background:var(--red);color:#fff;border-color:var(--red);}

/* Main */
.main{flex:1;margin-left:230px;padding:24px 32px;min-height:100vh;}
.page-title{font-size:22px;font-weight:700;margin-bottom:4px;}
.page-subtitle{font-size:13px;color:var(--text3);margin-bottom:24px;}
.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:12px;}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:24px;}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);}
.kpi-card.clickable{cursor:pointer;transition:all .15s;}.kpi-card.clickable:hover{border-color:var(--accent);transform:translateY(-2px);}
.kpi-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;}
.kpi-val{font-size:26px;font-weight:700;color:var(--accent);}
.kpi-sub{font-size:11px;color:var(--text3);margin-top:4px;}

/* Tables */
.table-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow);}
.table-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:10px;}
.table-title{font-size:16px;font-weight:600;}
.table-search{padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;font-family:var(--font);width:200px;}
.table-search:focus{border-color:var(--accent);outline:none;}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text2);font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg3);}
tbody td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle;}
tbody tr:hover{background:var(--accent-light);}
tbody tr:last-child td{border-bottom:none;}

/* Badges */
.badge{display:inline-block;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;}
.badge-green{background:rgba(34,197,94,.1);color:var(--green);}
.badge-red{background:rgba(239,68,68,.1);color:var(--red);}
.badge-amber{background:rgba(245,158,11,.1);color:var(--amber);}
.badge-teal{background:rgba(13,148,136,.1);color:var(--accent);}
.badge-gray{background:rgba(161,165,183,.1);color:var(--text3);}
.badge-purple{background:rgba(139,92,246,.1);color:var(--purple);}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;border:none;transition:all .15s;}
.btn-sm{padding:5px 10px;font-size:12px;}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:4px;}
.btn-primary{background:var(--accent);color:#fff;}.btn-primary:hover{background:#0b7e73;}
.btn-success{background:var(--green);color:#fff;}
.btn-danger{background:var(--red);color:#fff;}.btn-danger:hover{background:#dc2626;}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text2);}.btn-ghost:hover{background:var(--bg3);color:var(--text);}
.td-actions{display:flex;gap:4px;flex-wrap:wrap;}

/* Forms / Modal */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:12px;color:var(--text2);margin-bottom:6px;font-weight:600;}
.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;font-family:var(--font);outline:none;}
.form-input:focus,.form-select:focus{border-color:var(--accent);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:5000;display:flex;align-items:center;justify-content:center;}
.modal-box{background:var(--card);border:1px solid var(--border);border-radius:14px;width:90%;max-width:560px;max-height:85vh;overflow-y:auto;padding:28px;box-shadow:0 8px 30px rgba(0,0,0,.12);}
.modal-title{font-size:18px;font-weight:700;margin-bottom:20px;}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:600;background:var(--accent);color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.15);opacity:0;transform:translateY(10px);transition:all .3s;z-index:9999;max-width:360px;}
.toast.show{opacity:1;transform:translateY(0);}
.toast.err{background:var(--red);}

/* Login */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f0fdfa 0%,#e0f2fe 100%);}
.login-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px 32px;text-align:center;box-shadow:0 8px 30px rgba(0,0,0,.08);}
.login-card h1{font-size:20px;margin-bottom:4px;color:var(--accent);}
.login-card .subtitle{font-size:13px;color:var(--text3);margin-bottom:28px;}
.login-error{color:var(--red);font-size:12px;min-height:18px;margin-bottom:8px;text-align:left;}
.login-btn{width:100%;padding:12px;border-radius:8px;font-size:15px;font-weight:600;}
.input-pass-wrap{position:relative;display:flex;align-items:center;}
.input-pass-wrap .form-input{padding-right:40px;}
.pass-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:16px;color:var(--text3);padding:4px;}

/* Invite URL box */
.invite-url-box{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:12px;margin:12px 0;word-break:break-all;font-size:12px;font-family:monospace;color:var(--accent);cursor:pointer;}
.invite-url-box:hover{background:var(--accent-light);}

/* Detail grid */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;}
.detail-item{padding:12px 16px;background:var(--bg3);border-radius:8px;}
.detail-label{font-size:11px;color:var(--text3);text-transform:uppercase;margin-bottom:4px;}
.detail-val{font-size:14px;font-weight:600;}

/* Responsive */
@media(max-width:768px){
  .sidebar{width:60px;}.brand-text{display:none;}.nav-item{font-size:0;padding:10px 12px;}
  .main{margin-left:60px;padding:16px;}
  .kpi-grid{grid-template-columns:1fr 1fr;}
  .form-row,.detail-grid{grid-template-columns:1fr;}
}
