@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root{
  --primary:#0A8192;
  --accent:#2391D0;
  --bg:#F7F9FB;
  --card:#FFFFFF;
  --heading:#1A1A1A;
  --body:#6B7280;
  --light:#9CA3AF;
  --success:#22C55E;
  --warning:#F59E0B;
  --danger:#EF4444;
  --info:#3B82F6;
  --radius:16px;
}

*{box-sizing:border-box}
body{font-family:'Inter',Arial,sans-serif;background:var(--bg);margin:0;padding:24px;color:var(--heading)}
.container{max-width:1440px;margin:0 auto}
.auth-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#dff4f7 0%,#eef4f9 40%,#f8fbfd 100%)}
.auth-container{width:min(1120px,100%)}
h1{font-size:26px;margin:0 0 16px;font-weight:700}
h2{font-size:20px;margin:0 0 6px;font-weight:600}
h3{font-size:18px;margin:0 0 12px;font-weight:600}
p{color:var(--body);margin:0}

.card,.card-lite{background:var(--card);border-radius:var(--radius);box-shadow:0 10px 30px rgba(0,0,0,.05)}
.card{padding:20px;margin-bottom:16px}
.card-lite{padding:16px 20px;margin-bottom:16px}

.alert{padding:10px 12px;border-radius:8px;margin-bottom:10px}
.alert.error{background:#fee2e2;color:#991b1b}
.alert.success{background:#dcfce7;color:#166534}

label{display:block;font-size:14px;color:var(--heading);margin:8px 0 6px}
input,select,button{height:40px;padding:8px 12px;border:1px solid #d8dde5;border-radius:8px;width:100%;font:inherit}
button{background:var(--primary);color:#fff;border:none;cursor:pointer;transition:.2s ease}
button:hover{filter:brightness(0.95)}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 12px;background:#fff;border:1px solid #d8dde5;border-radius:8px;color:var(--heading);text-decoration:none;width:auto}

.password-wrap{position:relative}
.password-wrap input{padding-right:48px}
.password-eye{position:absolute;top:50%;right:8px;transform:translateY(-50%);width:32px;height:32px;padding:0;border-radius:8px;border:1px solid #d8dde5;background:#fff !important;color:#4b5563 !important;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:none !important}
.password-eye:hover{background:#f3f4f6 !important;filter:none}
.auth-card .password-eye{margin-top:0;height:32px;width:32px;padding:0;background:#fff !important;background-image:none !important}
.auth-card .password-eye svg{display:block}

.app-shell{display:grid;grid-template-columns:240px minmax(0,1fr) 320px;gap:16px;align-items:start}
.app-shell.no-right{grid-template-columns:240px minmax(0,1fr)}
.sidebar{position:sticky;top:24px;background:#fff;border-radius:16px;padding:20px;min-height:calc(100vh - 48px);display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.logo{font-weight:700;font-size:20px;margin-bottom:20px}
.brand-logo-wrap{display:flex;align-items:center;gap:10px}
.brand-logo{width:30px;height:30px;border-radius:8px;object-fit:cover}
.menu{display:grid;gap:8px}
.menu-item{text-decoration:none;color:var(--body);padding:10px 12px;border-radius:10px;transition:.2s ease}
.menu-item:hover{background:#eef5f8;color:var(--heading)}
.menu-item.active{background:rgba(10,129,146,.12);border-left:3px solid var(--primary);color:var(--primary);font-weight:600}
.upgrade-card{background:#f0f9ff;border:1px solid #d8eefc;border-radius:14px;padding:14px}
.upgrade-card h4{margin:0 0 8px}
.upgrade-card p{margin:0 0 10px;font-size:13px}

.main-content{min-width:0;padding-right:8px}
.top-header{display:flex;justify-content:space-between;align-items:center;gap:12px}
.header-actions{display:flex;gap:8px;align-items:center}
.kpi-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:16px}
.kpi-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.kpi-card span{font-size:13px;color:var(--light)}
.kpi-card strong{display:block;font-size:28px;margin:6px 0}
.kpi-card small.up{color:var(--success)}
.kpi-card small.down{color:var(--danger)}

.section-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:12px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;min-width:760px}
th,td{padding:10px;border-bottom:1px solid #eef2f7;text-align:left;vertical-align:top;font-size:14px}
.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.inline-form input,.inline-form select,.inline-form button{width:auto}

.reseller-actions{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;white-space:nowrap}
.reseller-actions form{margin:0}
.reseller-actions button{width:auto;height:36px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center}
.btn-danger{background:var(--danger)!important;color:#fff}
.btn-danger:hover{filter:brightness(0.95)}
.reseller-password-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.reseller-password-form .password-wrap{flex:1 1 280px;min-width:240px}
.reseller-password-form .password-wrap input{width:100%}
.reseller-password-form button{width:auto;flex:0 0 auto}
.plan-actions{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;white-space:nowrap}
.plan-actions form{margin:0}
.plan-actions button{width:auto;height:36px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.action-row{grid-column:1/-1}
.check-inline{display:flex;align-items:center;gap:8px;color:var(--body)}
.check-inline input{width:auto;height:auto}

.tag{display:inline-block;padding:4px 8px;border-radius:20px;font-size:12px}
.tag-info{background:#dbeafe;color:#1d4ed8}
.tag-success{background:#dcfce7;color:#166534}
.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize}
.status-pending{background:#fef3c7;color:#92400e}
.status-approved{background:#dbeafe;color:#1e40af}
.status-paid{background:#dcfce7;color:#166534}
.status-rejected{background:#fee2e2;color:#991b1b}

.plan-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.plan-list li{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:8px;padding:10px;border:1px solid #eef2f7;border-radius:10px}

.right-panel{display:grid;gap:16px;position:sticky;top:24px}
.profile-card{text-align:center}

.auth-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:22px;align-items:stretch}
.auth-brand,.auth-card{border:1px solid #e8edf4;box-shadow:0 20px 45px rgba(15,23,42,.08)}
.auth-brand{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;min-height:500px;padding:40px;background:linear-gradient(160deg,#ffffff 0%,#f5fbff 100%)}
.auth-brand::after{content:'';width:120px;height:6px;border-radius:99px;background:linear-gradient(90deg,var(--primary),var(--accent));margin-top:18px;opacity:.7}
.auth-logo{width:110px;height:110px;border-radius:20px;object-fit:cover;margin-bottom:14px;box-shadow:0 8px 20px rgba(2,132,199,.18)}
.auth-brand h2{font-size:34px;line-height:1.15;margin:8px 0;color:#0f172a}
.auth-brand p{font-size:16px;max-width:360px;color:#4b5563}
.auth-card{display:flex;flex-direction:column;justify-content:center;min-height:500px;padding:36px}
.auth-card h3{margin:0 0 12px;font-size:28px;color:#111827}
.auth-card label{font-weight:600;color:#374151}
.auth-card input{height:44px;border-color:#cfd8e3;background:#fbfdff}
.auth-card button{height:44px;font-weight:600;background:linear-gradient(90deg,var(--primary),var(--accent));margin-top:16px}
.auth-card p{margin-top:10px}
.avatar{width:64px;height:64px;border-radius:50%;margin:0 auto 10px;background:linear-gradient(145deg,var(--accent),var(--primary));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.tier-badge-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}
.tier-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#e0f2fe;color:#075985;font-size:12px;font-weight:600}
.tier-info-btn{width:26px;height:26px;padding:0;border-radius:999px;background:#fff;color:#0f172a;border:1px solid #d8dde5;display:inline-flex;align-items:center;justify-content:center;font-weight:700}
.tier-info-btn:hover{background:#f8fafc;filter:none}
.bubble{background:#f3f6fb;border-radius:12px;padding:10px 12px;margin-bottom:8px;font-size:13px}
.chat-input input{margin-bottom:10px}
.chat-icons{display:flex;gap:8px}
.chat-icons button{width:40px;padding:0}
.pager{margin-top:10px;font-size:13px;color:var(--light)}
.pager-links{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.pager-btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border:1px solid #d8dde5;border-radius:8px;text-decoration:none;color:var(--heading);background:#fff;font-size:13px}
.pager-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}

@media(max-width:1200px){
  .app-shell{grid-template-columns:88px minmax(0,1fr)}
  .right-panel{display:none}
  .logo{font-size:14px}
  .menu-item{font-size:0;padding:12px}
  .menu-item::before{content:'•';font-size:18px;color:var(--body)}
  .menu-item.active::before{color:var(--primary)}
  .upgrade-card{display:none}
}

.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);display:none;align-items:center;justify-content:center;padding:16px;z-index:999}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:16px;max-width:720px;width:100%;max-height:85vh;overflow:auto;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.15)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.modal-head button{width:auto;height:34px;padding:0 10px;background:#ef4444}

@media(max-width:900px){
  .auth-grid{grid-template-columns:1fr}
  .auth-brand,.auth-card{min-height:auto;padding:24px}
  .auth-brand h2{font-size:28px}
}

@media(max-width:768px){
  body{padding:12px}
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:relative;min-height:auto}
  .kpi-row,.form-grid,.auth-grid{grid-template-columns:1fr}
  .top-header,.section-head{flex-direction:column;align-items:stretch}
}
