/* ============================================================
   BoxAds Online — Advertiser Portal Stylesheet (Light theme)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --bg:        #f5f6f8;
  --bg-2:      #ffffff;
  --bg-3:      #eef0f4;
  --cyan:      #0099b8;
  --cyan-dim:  #007a94;
  --cyan-lt:   #e0f7fb;
  --text:      #1a1f2e;
  --text-2:    #3d4558;
  --grey:      #6b7280;
  --grey-lt:   #9ca3af;
  --border:    #dde1e9;
  --red:       #e03452;
  --green:     #0a9e72;
  --yellow:    #c47d00;
  --portal-w:  220px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'DM Sans', sans-serif; background: var(--bg); color: var(--text); font-size: 15px; line-height: 1.6; min-height: 100vh; }
a { color: var(--cyan); text-decoration: none; }
h1, h2, h3, h4 { font-family: 'Syne', sans-serif; font-weight: 700; color: var(--text); }
img { max-width: 100%; }

.portal-layout { display: flex; min-height: 100vh; }

.portal-sidebar {
  width: var(--portal-w); background: var(--bg-2); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; position: fixed; top: 0; left: 0;
  height: 100vh; overflow-y: auto; z-index: 50;
}
.portal-sidebar-logo { padding: 18px 18px 14px; border-bottom: 1px solid var(--border); }
.portal-sidebar-logo .logo-box { font-family: 'Syne',sans-serif; font-weight:800; font-size:1.15rem; color:var(--cyan); }
.portal-sidebar-logo .logo-ads { font-family: 'Syne',sans-serif; font-weight:800; font-size:1.15rem; color:var(--text); }
.portal-sidebar-logo .logo-dot { font-family: 'Syne',sans-serif; font-weight:800; font-size:1.15rem; color:var(--cyan); }
.portal-tag { font-size:0.6rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--cyan-dim); background:var(--cyan-lt); padding:2px 7px; border-radius:100px; display:inline-block; margin-top:4px; }

.portal-nav { flex:1; padding:10px 0; }
.portal-nav a { display:flex; align-items:center; gap:9px; padding:9px 18px; font-size:0.86rem; font-weight:500; color:var(--text-2); transition:all 0.18s; border-left:2px solid transparent; }
.portal-nav a:hover { color:var(--cyan); background:var(--cyan-lt); }
.portal-nav a.active { color:var(--cyan); background:var(--cyan-lt); border-left-color:var(--cyan); }

.portal-sidebar-footer { padding:14px 18px; border-top:1px solid var(--border); font-size:0.78rem; color:var(--grey); }
.portal-sidebar-footer a { color:var(--red); font-weight:600; }

.portal-main { margin-left: var(--portal-w); flex:1; display:flex; flex-direction:column; }
.portal-topbar { height:60px; background:var(--bg-2); border-bottom:1px solid var(--border); display:flex; align-items:center; padding:0 24px; gap:14px; position:sticky; top:0; z-index:40; }
.portal-topbar-title { font-family:'Syne',sans-serif; font-weight:700; font-size:0.95rem; color:var(--text); }
.portal-topbar-spacer { flex:1; }
.portal-topbar-user { display:flex; align-items:center; gap:8px; font-size:0.82rem; color:var(--text-2); }
.portal-avatar { width:30px; height:30px; background:var(--cyan); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Syne',sans-serif; font-weight:800; font-size:0.72rem; color:#fff; }

.portal-content { padding:24px; flex:1; }

.portal-card { background:var(--bg-2); border:1px solid var(--border); border-radius:10px; margin-bottom:20px; overflow:hidden; }
.portal-card-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--border); }
.portal-card-header h3 { font-size:0.95rem; color:var(--text); }
.portal-card-body { padding:20px; }

.portal-stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:20px; }
.portal-stat { background:var(--bg-2); border:1px solid var(--border); border-radius:10px; padding:18px; }
.portal-stat-label { font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--grey); margin-bottom:7px; }
.portal-stat-value { font-family:'Syne',sans-serif; font-size:1.7rem; font-weight:800; color:var(--text); }
.portal-stat.cyan .portal-stat-value { color:var(--cyan); }
.portal-stat.green .portal-stat-value { color:var(--green); }

.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:0.85rem; }
thead th { background:var(--bg-3); color:var(--grey); font-size:0.66rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; padding:11px 13px; text-align:left; white-space:nowrap; }
tbody td { padding:11px 13px; border-bottom:1px solid var(--border); color:var(--text-2); background:var(--bg-2); }
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover td { background:var(--bg-3); }

.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:0.75rem; font-weight:600; color:var(--text-2); margin-bottom:5px; text-transform:uppercase; letter-spacing:0.06em; }
.form-control { width:100%; background:var(--bg-2); border:1px solid var(--border); border-radius:6px; color:var(--text); font-family:'DM Sans',sans-serif; font-size:0.9rem; padding:10px 12px; transition:border-color 0.18s; outline:none; }
.form-control:focus { border-color:var(--cyan); box-shadow:0 0 0 3px rgba(0,153,184,0.1); }
.form-control::placeholder { color:var(--grey-lt); }
select.form-control { appearance:none; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

.btn-portal { display:inline-block; background:var(--cyan); color:#fff; font-family:'Syne',sans-serif; font-weight:700; font-size:0.78rem; letter-spacing:0.06em; text-transform:uppercase; padding:10px 22px; border-radius:6px; border:none; cursor:pointer; transition:all 0.18s; text-decoration:none; }
.btn-portal:hover { background:var(--cyan-dim); color:#fff; }
.btn-portal-sm { display:inline-block; background:none; color:var(--text-2); font-family:'Syne',sans-serif; font-weight:700; font-size:0.68rem; letter-spacing:0.06em; text-transform:uppercase; padding:4px 10px; border-radius:4px; border:1px solid var(--border); cursor:pointer; transition:all 0.18s; text-decoration:none; }
.btn-portal-sm:hover { border-color:var(--cyan); color:var(--cyan); background:var(--cyan-lt); }

.alert { padding:11px 15px; border-radius:6px; font-size:0.86rem; margin-bottom:16px; border-left:3px solid; }
.alert-success { background:#d1fae5; border-color:#059669; color:#065f46; }
.alert-danger   { background:#fee2e2; border-color:#dc2626; color:#991b1b; }
.alert-info     { background:var(--cyan-lt); border-color:var(--cyan); color:var(--cyan-dim); }
.badge { display:inline-block; font-size:0.66rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:2px 7px; border-radius:100px; }
.badge-success  { background:#d1fae5; color:#065f46; }
.badge-warning  { background:#fef3c7; color:#92400e; }
.badge-danger   { background:#fee2e2; color:#991b1b; }
.badge-info     { background:var(--cyan-lt); color:var(--cyan-dim); }
.badge-secondary{ background:var(--bg-3); color:var(--grey); }

.portal-group-banner { line-height:0; }
.portal-group-banner a { display:block; }
.portal-group-banner img { width:100%; height:auto; display:block; }

@media (max-width:700px) { .portal-sidebar { transform:translateX(-100%); } .portal-main { margin-left:0; } .form-row { grid-template-columns:1fr; } }
