/* VectaFinance — Design System */
:root{
  --teal-900:#0f3a38;
  --teal-800:#15514d;
  --teal-700:#1c6661;
  --teal-600:#247a73;
  --teal-50:#e8f1f0;
  --cream:#f7f3ea;
  --cream-2:#fbf8f1;
  --paper:#ffffff;
  --ink:#0e2a29;
  --ink-2:#1f3c3a;
  --muted:#6b7a78;
  --line:#e6e1d4;
  --gold:#f1c75b;
  --gold-2:#e7b840;
  --green:#2f9e6b;
  --red:#d94f4f;
  --blue:#3b6fb6;
  --radius:14px;
  --radius-lg:20px;
  --shadow-sm:0 1px 2px rgba(15,58,56,.06), 0 1px 1px rgba(15,58,56,.04);
  --shadow:0 8px 24px rgba(15,58,56,.08);
  --shadow-lg:0 20px 50px rgba(15,58,56,.12);
  --font:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Plus Jakarta Sans',var(--font);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  font-size:14.5px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);margin:0 0 .4em;letter-spacing:-.01em}
h1{font-size:2.4rem;line-height:1.1;font-weight:700}
h2{font-size:1.6rem;font-weight:700}
h3{font-size:1.15rem;font-weight:600}
p{color:var(--ink-2);margin:0 0 1em}
.muted{color:var(--muted)}
.container{max-width:1240px;margin:0 auto;padding:0 24px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:10px;border:1px solid transparent;font-weight:600;font-size:14px;cursor:pointer;transition:all .15s ease;font-family:var(--font)}
.btn-primary,a.btn-primary{background:var(--teal-800);color:#fff}
.btn-primary:hover,a.btn-primary:hover{background:var(--teal-900);color:#fff}
.btn-gold{background:var(--gold);color:var(--teal-900)}
.btn-gold:hover{background:var(--gold-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:#fff}
.btn-outline{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{border-color:var(--teal-700);color:var(--teal-800)}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:7px 12px;font-size:13px}

/* Cards / panels */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}
.card-pad-sm{padding:16px}
.divider{height:1px;background:var(--line);margin:16px 0}

/* Form */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:13px;font-weight:600;color:var(--ink-2)}
.field input,.field select,.field textarea{
  border:1px solid var(--line);background:#fff;border-radius:10px;padding:11px 13px;font-size:14px;color:var(--ink);font-family:var(--font);outline:none;transition:border .15s
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal-700);box-shadow:0 0 0 3px rgba(36,122,115,.12)}
.helper{font-size:12px;color:var(--muted)}
.error{color:var(--red);font-size:13px;margin-top:6px;min-height:18px}

/* ===================== Landing ===================== */
.nav{position:sticky;top:0;z-index:30;background:rgba(247,243,234,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;color:var(--teal-900);font-size:18px}
.brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--teal-800),var(--teal-600));display:grid;place-items:center;color:var(--gold);font-weight:800;box-shadow:var(--shadow-sm)}
.nav-links{display:flex;gap:28px}
.nav-links a{color:var(--ink-2);font-weight:500;font-size:14px}
.nav-links a:hover{color:var(--teal-800)}
.nav-cta{display:flex;gap:10px;align-items:center}

.hero{padding:80px 0 60px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:600;color:var(--teal-800);margin-bottom:20px}
.eyebrow .dot{width:7px;height:7px;background:var(--green);border-radius:50%}
.hero h1{font-size:3.2rem;color:var(--teal-900)}
.hero h1 em{font-style:normal;background:linear-gradient(120deg,var(--teal-700),var(--green));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:1.1rem;color:var(--ink-2);max-width:540px;margin-bottom:28px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-trust{margin-top:32px;display:flex;gap:24px;color:var(--muted);font-size:13px;flex-wrap:wrap}
.hero-trust span{display:flex;align-items:center;gap:6px}
.hero-art{position:relative}
.preview-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow-lg);transform:rotate(-1deg)}
.preview-card .pc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.preview-card .pc-title{font-weight:700;color:var(--teal-900)}
.kpi-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.kpi-mini{background:var(--cream-2);border-radius:12px;padding:12px}
.kpi-mini .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.kpi-mini .v{font-weight:700;color:var(--teal-900);font-size:18px;margin-top:2px}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding:10px 0;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line)}
.bar-chart .bar{flex:1;background:linear-gradient(180deg,var(--teal-700),var(--teal-600));border-radius:6px 6px 0 0;position:relative}
.bar-chart .bar.gold{background:linear-gradient(180deg,var(--gold),var(--gold-2))}

.section{padding:80px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 48px}
.section-head h2{color:var(--teal-900)}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;transition:transform .2s, box-shadow .2s}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.feature .ico{width:44px;height:44px;border-radius:12px;background:var(--teal-50);color:var(--teal-800);display:grid;place-items:center;margin-bottom:14px;font-size:20px}
.feature h3{color:var(--teal-900);margin-bottom:6px}
.feature p{font-size:14px;color:var(--muted);margin:0}

.modes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.mode{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden}
.mode .tag{display:inline-block;background:var(--cream-2);color:var(--teal-800);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-bottom:12px}
.mode h3{color:var(--teal-900)}
.mode ul{padding-left:18px;color:var(--ink-2);margin:10px 0 0;font-size:14px}
.mode ul li{margin:5px 0}

.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column}
.plan.featured{background:var(--teal-900);color:#fff;border-color:var(--teal-900)}
.plan.featured h3,.plan.featured .price{color:#fff}
.plan.featured p,.plan.featured li{color:#cfe3e1}
.plan h3{color:var(--teal-900)}
.plan .price{font-family:var(--display);font-size:2.2rem;font-weight:700;color:var(--teal-900);margin:8px 0}
.plan .price small{font-size:14px;font-weight:500;color:var(--muted)}
.plan ul{list-style:none;padding:0;margin:18px 0;flex:1}
.plan ul li{padding:7px 0;font-size:14px;border-bottom:1px dashed rgba(0,0,0,.05)}
.plan.featured ul li{border-color:rgba(255,255,255,.1)}

.footer{background:var(--teal-900);color:#cfe3e1;padding:50px 0 24px}
.footer .container{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.footer h4{color:#fff;font-size:14px;margin-bottom:14px;font-family:var(--font)}
.footer a{display:block;padding:5px 0;font-size:14px;color:#9fbab7}
.footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:30px;padding-top:18px;text-align:center;color:#7a9794;font-size:13px}

/* ===================== Auth ===================== */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.auth-art{background:linear-gradient(140deg,var(--teal-900),var(--teal-700));color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-art::after{content:"";position:absolute;right:-100px;bottom:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(241,199,91,.25),transparent 60%)}
.auth-art .brand{color:#fff}
.auth-art .brand-mark{background:var(--gold);color:var(--teal-900)}
.auth-art h2{color:#fff;font-size:2rem;max-width:420px}
.auth-art p{color:#cfe3e1;max-width:420px}
.auth-quote{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:20px;font-size:14px;color:#e3efed;backdrop-filter:blur(4px);position:relative;z-index:1}
.auth-form{display:flex;flex-direction:column;justify-content:center;padding:60px;max-width:520px;margin:0 auto;width:100%}
.auth-form h1{font-size:1.8rem;color:var(--teal-900);margin-bottom:6px}
.auth-form .sub{color:var(--muted);margin-bottom:28px}
.oauth-row{display:flex;gap:10px;margin-bottom:18px}
.oauth-btn{flex:1;background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:500;font-size:14px}
.oauth-btn:hover{border-color:var(--teal-700)}
.sep{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px;margin:18px 0}
.sep::before,.sep::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-foot{text-align:center;margin-top:18px;font-size:14px;color:var(--muted)}
.auth-foot a{color:var(--teal-800);font-weight:600}

/* ===================== App Shell ===================== */
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:var(--cream)}
.sidebar{background:var(--teal-900);color:#cfe3e1;padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sidebar .brand{color:#fff;padding:0 8px 22px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:18px}
.sidebar .brand-mark{background:var(--gold);color:var(--teal-900)}
.side-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.side-nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:#9fbab7;font-weight:500;font-size:14px;transition:all .15s}
.side-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.side-nav a.active{background:var(--gold);color:var(--teal-900);font-weight:600;box-shadow:0 4px 12px rgba(241,199,91,.25)}
.side-nav .ico{width:18px;height:18px;display:inline-flex}
.side-foot{border-top:1px solid rgba(255,255,255,.08);padding-top:14px;display:flex;flex-direction:column;gap:4px}

.topbar{background:transparent;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.topbar .search{flex:1;max-width:420px;position:relative}
.topbar .search input{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 14px 10px 38px;font-size:14px;outline:none}
.topbar .search::before{content:"⌕";position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}
.top-actions{display:flex;align-items:center;gap:14px}
.icon-btn{width:38px;height:38px;border-radius:10px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-2);cursor:pointer;position:relative}
.icon-btn .dot{position:absolute;top:7px;right:7px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid #fff}
.user-chip{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);padding:5px 12px 5px 5px;border-radius:999px;cursor:pointer}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--teal-700),var(--green));color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.user-chip .who{font-size:13px;line-height:1.15}
.user-chip .who b{color:var(--ink);font-weight:600}
.user-chip .who span{color:var(--green);font-size:11px}

.content{padding:8px 32px 40px}
.page-head{margin-bottom:22px}
.page-head h1{font-size:1.7rem;color:var(--teal-900);margin:0}
.breadcrumb{font-size:13px;color:var(--muted);margin-top:6px}
.breadcrumb a{color:var(--teal-800)}

/* Dashboard top row */
.dash-grid{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:18px;margin-bottom:18px}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px}
.stat-card .top{display:flex;justify-content:space-between;align-items:flex-start}
.stat-icon{width:38px;height:38px;border-radius:10px;background:var(--teal-50);color:var(--teal-800);display:grid;place-items:center}
.stat-card .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:14px}
.stat-card .value{font-family:var(--display);font-size:1.8rem;font-weight:700;color:var(--teal-900);margin-top:2px}
.trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:3px 8px;border-radius:999px;margin-top:6px}
.trend.up{background:#e3f5ec;color:var(--green)}
.trend.down{background:#fbe6e6;color:var(--red)}
.spark{height:40px;width:90px}

.cardvisual{background:linear-gradient(135deg,var(--teal-800),var(--teal-700));color:#fff;border-radius:var(--radius-lg);padding:22px;position:relative;overflow:hidden}
.cardvisual::after{content:"";position:absolute;right:-60px;top:-60px;width:200px;height:200px;border-radius:50%;background:rgba(241,199,91,.18)}
.cardvisual .bv{font-size:12px;color:#cfe3e1;text-transform:uppercase;letter-spacing:.06em}
.cardvisual .balance{font-family:var(--display);font-size:1.8rem;font-weight:700;margin:4px 0 18px}
.cardvisual .holder{font-size:11px;color:#cfe3e1;text-transform:uppercase;letter-spacing:.08em}
.cardvisual .name{font-weight:600;font-size:1.05rem}
.cardvisual .num{font-family:'JetBrains Mono',monospace;letter-spacing:2px;margin-top:14px;font-size:14px}
.cardvisual .exp{font-size:11px;color:#cfe3e1;margin-top:6px;display:flex;justify-content:space-between;position:relative;z-index:1}

.row2{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:18px}
.chart-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px}
.chart-card .ch-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.chart-card h3{margin:0;color:var(--teal-900)}
.legend{display:flex;gap:14px;font-size:12px;color:var(--muted)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}
.list-card .item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line)}
.list-card .item:last-child{border-bottom:0}
.list-card .item .lico{width:36px;height:36px;border-radius:10px;background:var(--cream-2);display:grid;place-items:center;color:var(--teal-700);font-weight:700}
.list-card .item .meta{flex:1}
.list-card .item .meta b{display:block;color:var(--ink);font-size:14px}
.list-card .item .meta span{font-size:12px;color:var(--muted)}
.list-card .item .pct{font-weight:700;color:var(--teal-800)}

/* Transactions table */
.tx-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px}
.tabs{display:flex;gap:18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.tabs button{background:none;border:0;padding:10px 2px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;font-size:14px;font-family:var(--font)}
.tabs button.active{color:var(--teal-900);border-color:var(--gold)}
table.tx{width:100%;border-collapse:collapse;font-size:13.5px}
table.tx th{text-align:left;padding:12px 10px;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}
table.tx td{padding:14px 10px;border-bottom:1px solid var(--line);color:var(--ink-2)}
table.tx tr:last-child td{border-bottom:0}
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.pill.green{background:#e3f5ec;color:var(--green)}
.pill.red{background:#fbe6e6;color:var(--red)}
.pill.gold{background:#fdf2d6;color:#8a6a14}

/* Upload */
.upload-zone{background:#fff;border:2px dashed var(--teal-700);border-radius:var(--radius-lg);padding:60px 30px;text-align:center;cursor:pointer;transition:all .2s}
.upload-zone:hover,.upload-zone.drag{background:var(--teal-50);border-color:var(--teal-800)}
.upload-zone .up-ico{width:64px;height:64px;border-radius:16px;background:var(--cream-2);color:var(--teal-800);display:grid;place-items:center;margin:0 auto 16px;font-size:28px}
.upload-zone h3{color:var(--teal-900)}
.mode-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.mode-pick label{cursor:pointer}
.mode-pick input{position:absolute;opacity:0}
.mode-pick .opt{background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:18px;transition:all .15s}
.mode-pick input:checked + .opt{border-color:var(--teal-800);background:var(--teal-50)}
.mode-pick .opt b{display:block;color:var(--teal-900);margin-bottom:4px;font-size:15px}
.mode-pick .opt span{font-size:12.5px;color:var(--muted)}

/* Report */
.report-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.narrative{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;line-height:1.7}
.narrative h2{color:var(--teal-900);margin-top:18px;font-size:1.3rem}
.narrative h2:first-child{margin-top:0}
.narrative ul{padding-left:20px}
.narrative .callout{background:var(--cream-2);border-left:3px solid var(--gold);padding:14px 18px;border-radius:8px;margin:14px 0}

/* Billing */
.invoice-table{width:100%;border-collapse:collapse;font-size:14px}
.invoice-table th{text-align:left;padding:10px;background:var(--cream-2);color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.invoice-table td{padding:14px 10px;border-bottom:1px solid var(--line)}

/* Settings */
.setting-grid{display:grid;grid-template-columns:240px 1fr;gap:24px}
.setting-nav{display:flex;flex-direction:column;gap:4px}
.setting-nav a{padding:10px 14px;border-radius:10px;color:var(--ink-2);font-weight:500;font-size:14px;cursor:pointer}
.setting-nav a.active{background:var(--teal-50);color:var(--teal-900);font-weight:600}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--teal-900);color:#fff;padding:12px 18px;border-radius:10px;box-shadow:var(--shadow-lg);font-size:14px;z-index:100;opacity:0;transform:translateY(10px);transition:all .2s}
.toast.show{opacity:1;transform:translateY(0)}

/* Mobile */
.menu-btn{display:none;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 10px;cursor:pointer;font-size:18px;line-height:1;color:var(--ink)}
.menu-btn[aria-expanded="true"]{background:var(--teal-50)}
@media (max-width: 980px){
  .hero-grid,.features,.modes,.pricing,.dash-grid,.row2,.report-grid,.setting-grid,.mode-pick,.auth-wrap{grid-template-columns:1fr}
  .auth-art{display:none}
  .footer .container{grid-template-columns:1fr 1fr}
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-280px;top:0;width:260px;z-index:50;transition:left .25s}
  .sidebar.open{left:0}
  .menu-btn{display:inline-flex}
  .nav{position:relative}
  .nav-row{flex-wrap:wrap}
  .nav-links,.nav-cta{display:none;width:100%}
  .nav.open .nav-links{display:flex;flex-direction:column;gap:6px;padding:14px 0 6px;border-top:1px solid var(--line);margin-top:12px;animation:navSlide .2s ease-out}
  .nav.open .nav-cta{display:flex;flex-direction:column;gap:8px;padding:6px 0 14px;animation:navSlide .25s ease-out}
  .nav.open .nav-links a{padding:10px 4px;font-size:15px}
  .nav.open .nav-cta .btn{width:100%;justify-content:center}
  .hero h1{font-size:2.2rem}
  .content,.topbar{padding-left:18px;padding-right:18px}
}
@keyframes navSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ===== Skeleton loader ===== */
@keyframes sk-shimmer { 0%{background-position:-400px 0} 100%{background-position:400px 0} }
.sk{
  background:linear-gradient(90deg,#eee 0%,#f6f6f6 40%,#eee 80%);
  background-size:800px 100%;
  animation:sk-shimmer 1.3s ease-in-out infinite;
  border-radius:8px;
}
.sk-card{
  background:#fff;border:1px solid var(--line, #ececec);
  border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px;
  box-shadow:0 1px 2px rgba(15,58,56,.04);
}
.sk-head{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.sk-title{height:24px;width:240px;max-width:60%}
.sk-sub{height:12px;width:160px;max-width:40%}
.sk-line{height:12px;width:100%}
.sk-line.w30{width:30%}.sk-line.w40{width:40%}.sk-line.w50{width:50%}.sk-line.w60{width:60%}
.sk-big{height:32px;width:70%}
.sk-row{height:34px;width:100%;border-radius:6px}
.sk-chart{height:200px;width:100%}

/* VectaFinance logo replacement for brand mark */
.brand-mark-img{width:28px;height:28px;border-radius:6px;object-fit:cover;display:inline-block;vertical-align:middle}
.brand{display:inline-flex;align-items:center;gap:8px}


/* === Pricing === */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
@media(max-width:880px){.pricing-grid{grid-template-columns:1fr}}
.price-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 24px;display:flex;flex-direction:column;gap:14px;position:relative;transition:transform .2s,box-shadow .2s}
.price-card:hover{transform:translateY(-3px);box-shadow:0 14px 40px -20px rgba(13,46,43,.18)}
.price-card-popular{border:2px solid var(--gold);box-shadow:0 14px 40px -20px rgba(212,160,23,.35)}
.price-tag{font-family:var(--display);font-size:18px;font-weight:700;color:var(--teal-900);display:flex;align-items:center;gap:10px}
.price-tag .badge{background:var(--gold);color:#3d2c00;font-size:10px;padding:3px 8px;border-radius:999px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.price{display:flex;align-items:baseline;gap:6px}
.price .amt{font-family:var(--display);font-size:46px;font-weight:800;color:var(--teal-900);line-height:1}
.price .per{font-size:14px;color:var(--muted)}
.price-sub{color:var(--muted);font-size:14px;margin:0}
.price-feat{list-style:none;padding:0;margin:8px 0 14px;font-size:14px}
.price-feat li{padding:6px 0;border-bottom:1px dashed var(--line);color:var(--ink2)}
.price-feat li:last-child{border-bottom:0}
.btn-block{display:block;width:100%;text-align:center}

/* === FAQ accordion === */
.faq-item{margin-bottom:10px;cursor:pointer}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:22px;color:var(--teal-800);line-height:1}
.faq-item[open] summary::after{content:"−"}
.faq-item p{margin:10px 0 0;color:var(--ink2);font-size:14.5px;line-height:1.6}

/* === Legal pages === */
.legal-wrap h1{font-family:var(--display);font-size:42px;margin:6px 0 6px}
.legal-wrap h2{font-family:var(--display);font-size:22px;margin:28px 0 8px;color:var(--teal-900)}
.legal-wrap p,.legal-wrap li{color:var(--ink2);line-height:1.7;font-size:15px}
.legal-wrap a{color:var(--teal-800);text-decoration:underline}
.breadcrumb{color:var(--muted);font-size:13px}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:18px}
@media(max-width:680px){.contact-grid{grid-template-columns:1fr}}
.contact-grid .card h3{margin:0 0 6px;font-size:15px}
.contact-grid .card p{margin:0 0 8px;font-size:13.5px}
.field{margin-bottom:14px;display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:600;color:var(--teal-900)}
.field input,.field textarea{padding:10px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fff}

/* === Notifications dropdown === */
.notif-wrap{position:relative}
.notif-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;background:#c0392b;color:#fff;font-size:10px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #fff}
.notif-panel{position:absolute;right:0;top:46px;width:340px;max-width:calc(100vw - 24px);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px -18px rgba(13,46,43,.25);overflow:hidden;z-index:50;display:none}
.notif-panel.open{display:block}
.notif-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}
.notif-head h4{margin:0;font-size:14px;color:var(--teal-900)}
.notif-head button{background:none;border:0;font-size:12px;color:var(--teal-800);cursor:pointer;font-weight:600}
.notif-list{max-height:380px;overflow-y:auto}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--line);font-size:13.5px;display:flex;gap:10px;align-items:flex-start;cursor:pointer}
.notif-item:hover{background:var(--cream-2)}
.notif-item:last-child{border-bottom:0}
.notif-item.unread{background:#fdf6e3}
.notif-item.unread::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);margin-top:6px;flex-shrink:0}
.notif-item .nt{font-weight:600;color:var(--teal-900)}
.notif-item .nm{color:var(--ink2);margin-top:2px}
.notif-item .nd{color:var(--muted);font-size:11.5px;margin-top:4px}
.notif-empty{padding:36px 16px;text-align:center;color:var(--muted);font-size:13px}

/* ===================== Report — Premium Redesign ===================== */
.vf-report{max-width:1120px;margin:0 auto}

/* Page head */
.vf-page-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-bottom:22px}
.vf-h1{font-family:var(--display);font-size:1.9rem;font-weight:800;color:var(--teal-900);margin:0;letter-spacing:-.02em}
.vf-crumb{margin-top:8px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.vf-crumb a{color:var(--teal-800);font-weight:500}
.vf-crumb .vf-sep{color:var(--line)}
.vf-head-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Mode pills */
.vf-mode-pill{display:inline-flex;align-items:center;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.vf-mode-founder{background:#fdf2d6;color:#8a6a14}
.vf-mode-investor{background:#e8f1f0;color:#15514d}
.vf-mode-accountant{background:#e8f0fb;color:#2d4a8a}

/* KPI strip */
.vf-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.vf-kpi{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 18px 16px;box-shadow:var(--shadow-sm)}
.vf-kpi-l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.vf-kpi-v{font-family:var(--display);font-weight:800;font-size:1.75rem;color:var(--teal-900);margin-top:6px;letter-spacing:-.01em}
.vf-kpi-s{font-size:12px;color:var(--muted);margin-top:4px}
.vf-pos{color:var(--green)}
.vf-neg{color:var(--red)}
.vf-up{color:var(--green)}

/* Cover card */
.vf-cover{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px 28px;display:grid;grid-template-columns:1.6fr 1fr;gap:28px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.vf-mode-badge{display:inline-flex;align-items:center;gap:7px;background:var(--teal-50);color:var(--teal-800);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:14px}
.vf-mode-badge .vf-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.vf-cover-title{font-family:var(--display);font-weight:800;color:var(--teal-900);font-size:1.6rem;line-height:1.15;margin:0 0 12px;letter-spacing:-.02em}
.vf-cover-sum{font-size:14.5px;color:var(--ink-2);margin:0;line-height:1.55;max-width:560px}
.vf-cover-r{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.vf-meta-l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.vf-meta-v{font-family:var(--display);font-weight:700;color:var(--teal-900);font-size:15px;margin-top:2px}
.vf-reviewed{display:inline-flex;align-items:center;gap:6px;background:#e3f5ec;color:var(--green);font-size:12px;font-weight:600;padding:5px 11px;border-radius:999px}
.vf-reviewed svg{width:13px;height:13px}

/* Narrative card overrides */
.vf-narrative{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 32px;box-shadow:var(--shadow-sm);line-height:1.65}
.vf-narrative > *:first-child{margin-top:0}

/* Section headings (narrative_html) */
.narrative .sec-h2{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:13px;color:var(--teal-900);text-transform:none;letter-spacing:.02em;border-bottom:1px solid var(--line);padding-bottom:10px;margin:24px 0 14px}
.narrative .sec-ico{width:28px;height:28px;border-radius:8px;background:var(--teal-50);color:var(--teal-700);display:inline-grid;place-items:center;font-size:14px;flex-shrink:0}
.narrative .sec-ico svg{width:15px;height:15px}

/* Inner KPI grid */
.narrative .kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0 18px}
.narrative .kpi-grid .cell{background:var(--cream-2);border:1px solid var(--line);border-radius:12px;padding:14px}
.narrative .kpi-grid .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.narrative .kpi-grid .v{font-family:var(--display);font-weight:800;font-size:1.4rem;color:var(--teal-900);margin-top:4px;letter-spacing:-.01em}
.narrative .kpi-grid .s{font-size:10.5px;color:var(--muted);margin-top:2px}
.narrative .kpi-grid .v.profit{color:var(--green)}
.narrative .kpi-grid .v.loss{color:var(--red)}

/* Expense bars */
.narrative .expense-bars{display:flex;flex-direction:column;gap:10px;margin:12px 0 4px}
.narrative .expense-bars .row{display:flex;align-items:center;gap:10px}
.narrative .expense-bars .lbl{width:120px;flex-shrink:0;font-size:13px;color:var(--ink-2);font-weight:500}
.narrative .expense-bars .track{flex:1;height:8px;background:var(--cream-2);border-radius:999px;overflow:hidden}
.narrative .expense-bars .fill{height:100%;border-radius:999px;width:0;animation:vf-bar .6s ease forwards;animation-delay:var(--d,0s);background:var(--teal-700)}
.narrative .expense-bars .fill.cogs{background:var(--teal-700)}
.narrative .expense-bars .fill.marketing{background:var(--gold-2)}
.narrative .expense-bars .fill.operations{background:var(--green)}
.narrative .expense-bars .fill.payroll{background:var(--blue)}
.narrative .expense-bars .fill.software{background:#6a9bd8}
.narrative .expense-bars .fill.other{background:var(--muted)}
.narrative .expense-bars .amt{font-family:var(--display);font-weight:700;font-size:13px;color:var(--ink);width:72px;text-align:right}
.narrative .expense-bars .pct{font-size:11px;color:var(--muted);width:30px;text-align:right}
@keyframes vf-bar{from{width:0}to{width:var(--w,0%)}}

/* Transaction mini list */
.narrative .tx-mini{display:flex;flex-direction:column;gap:8px;margin:12px 0}
.narrative .tx-mini .row{display:flex;align-items:center;gap:10px;background:var(--cream-2);border-radius:10px;padding:10px 14px}
.narrative .tx-mini .date{font-size:11px;color:var(--muted);width:80px;flex-shrink:0}
.narrative .tx-mini .desc{flex:1;font-size:13px;color:var(--ink-2);font-weight:500}
.narrative .tx-mini .cat{font-size:11px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:2px 8px}
.narrative .tx-mini .amt{font-family:var(--display);font-weight:700;font-size:13px;width:90px;text-align:right;color:var(--ink)}
.narrative .tx-mini .amt.pos{color:var(--green)}
.narrative .tx-mini .amt.neg{color:var(--red)}

/* Callouts */
.narrative .callout{background:var(--cream-2);border-left:3px solid var(--gold);border-radius:0 10px 10px 0;padding:14px 18px;font-size:14px;color:var(--ink-2);margin:14px 0}
.narrative .callout strong{display:block;color:var(--teal-900);font-size:14px;margin-bottom:2px;font-weight:700}
.narrative .callout-green{border-left-color:var(--green);background:#f0faf5}
.narrative .callout-red{border-left-color:var(--red);background:#fdf2f2}

/* Topic pills */
.narrative .topics{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0}
.narrative .topics .pill{display:flex;gap:10px;background:var(--cream-2);border:1px solid var(--line);border-radius:12px;padding:12px 16px;flex:1;min-width:240px;align-items:flex-start}
.narrative .topics .pill .pico{width:26px;height:26px;border-radius:7px;background:var(--teal-50);color:var(--teal-700);display:grid;place-items:center;font-size:12px;flex-shrink:0}
.narrative .topics .pill .pico svg{width:13px;height:13px}
.narrative .topics .pill b{display:block;font-family:var(--display);font-weight:700;font-size:13px;color:var(--teal-900);margin-bottom:3px}
.narrative .topics .pill span{font-size:12.5px;color:var(--ink-2);line-height:1.45}

/* Observations */
.narrative .obs-list{display:flex;flex-direction:column;gap:10px;margin:12px 0}
.narrative .obs-list .row{display:flex;gap:12px;background:var(--cream-2);border-radius:12px;padding:14px 16px;align-items:flex-start}
.narrative .obs-list .num{width:26px;height:26px;border-radius:8px;background:var(--teal-900);color:var(--gold);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:12px;flex-shrink:0}
.narrative .obs-list .txt{font-size:14px;color:var(--ink-2);line-height:1.55}
.narrative .obs-list .txt strong{color:var(--teal-900)}

/* Analyst notes */
.narrative .analyst-notes{background:var(--teal-900);border-radius:14px;padding:22px 26px;margin-top:28px;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.narrative .analyst-notes h3{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--display);font-weight:700;font-size:15px;margin:0 0 10px}
.narrative .analyst-notes h3 .ai{color:var(--gold);display:inline-flex}
.narrative .analyst-notes ul{margin:0;padding-left:18px;font-size:13px;color:#9fbab7;line-height:1.7}
.narrative .analyst-notes li{margin:3px 0}

/* Report footer */
.vf-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);margin-top:28px;padding-top:18px;flex-wrap:wrap;gap:10px}
.vf-foot-brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:14px;color:var(--teal-900)}
.vf-foot-meta{font-size:12px;color:var(--muted)}

/* Animations */
.vf-anim{opacity:0;transform:translateY(8px);animation:vf-in .3s ease forwards;animation-delay:var(--d,0s)}
@keyframes vf-in{to{opacity:1;transform:translateY(0)}}

/* Responsive */
@media (max-width:900px){
  .vf-kpis{grid-template-columns:repeat(2,1fr)}
  .vf-cover{grid-template-columns:1fr}
  .vf-cover-r{text-align:left;align-items:flex-start}
  .narrative .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .narrative .topics .pill{min-width:100%}
  .vf-narrative{padding:22px}
}
@media (max-width:560px){
  .vf-kpis{grid-template-columns:1fr 1fr}
  .vf-h1{font-size:1.5rem}
  .narrative .expense-bars .lbl{width:90px;font-size:12px}
}

/* Print */
@media print{
  body{background:#fff}
  .sidebar,.topbar,.vf-head-actions{display:none !important}
  .app{display:block !important}
  .content{padding:0 !important}
  .vf-kpi,.vf-cover,.vf-narrative{box-shadow:none !important;border-color:#ddd !important;page-break-inside:avoid}
  .narrative .sec-h2,.narrative .kpi-grid,.narrative .callout,.narrative .obs-list .row{page-break-inside:avoid}
  .narrative .analyst-notes{background:#0f3a38 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  @page{margin:18mm}
}

/* ============================================================
   VF Dashboard-style report layout (bento)
   ============================================================ */
.vf-dash{display:flex;flex-direction:column;gap:18px}
.vfd-row{display:grid;gap:18px;grid-auto-flow:dense}
.vfd-row-1{grid-template-columns:1fr 1fr 1fr 1.1fr}
.vfd-row-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.vfd-row-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}

.vfd-card,.vfd-kpi,.vfd-profile,.vfd-feature{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:20px;box-shadow:0 1px 2px rgba(15,58,56,.04)
}

/* KPI cards */
.vfd-kpi{display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
.vfd-kpi-ico{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-size:18px;margin-bottom:6px}
.vfd-kpi-ico svg{width:18px;height:18px}
.vfd-ico-rev{background:var(--teal-50);color:var(--teal-800)}
.vfd-ico-exp{background:#fdf3da;color:#9a7a16}
.vfd-ico-net{background:#eaf6f1;color:#1c6661}
.vfd-kpi-l{font-size:12.5px;color:var(--muted);font-weight:500}
.vfd-kpi-v{font-family:var(--display);font-weight:800;font-size:28px;color:var(--teal-900);letter-spacing:-.5px;line-height:1.1}
.vfd-kpi-v.vf-pos{color:#1c6661}
.vfd-kpi-v.vf-neg{color:#b3261e}
.vfd-kpi-s{font-size:12px;color:var(--muted)}
.vfd-kpi-s.vf-up{color:#1c6661;font-weight:600}

/* Profile card (right column row 1) */
.vfd-profile{display:flex;flex-direction:column;gap:14px;background:linear-gradient(180deg,#fff,#fbf8f1)}
.vfd-prof-top{display:flex;align-items:center;gap:12px}
.vfd-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--teal-800),var(--teal-600));color:var(--gold);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:17px}
.vfd-prof-name{font-family:var(--display);font-weight:700;color:var(--teal-900);font-size:15px;line-height:1.1}
.vfd-prof-role{font-size:12px;color:var(--muted)}
.vfd-bell{margin-left:auto;width:34px;height:34px;border-radius:10px;background:var(--cream-2);display:grid;place-items:center;color:var(--teal-800);position:relative}
.vfd-bell::after{content:"";position:absolute;top:8px;right:9px;width:7px;height:7px;background:var(--gold);border-radius:50%;border:2px solid #fff}
.vfd-prof-meta{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--ink-2)}
.vfd-prof-meta li{display:flex;gap:8px;align-items:center}
.vfd-prof-meta li span:first-child{width:18px;text-align:center;opacity:.7}
.vfd-prof-foot{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--muted);border-top:1px dashed var(--line);padding-top:10px;margin-top:auto}
.vfd-ver{font-family:var(--display);font-weight:700;color:var(--teal-900)}

/* Card head */
.vfd-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:10px}
.vfd-card-head h3{margin:0;font-family:var(--display);font-weight:700;font-size:15px;color:var(--teal-900)}
.vfd-pill-date{font-size:11.5px;background:var(--cream-2);border:1px solid var(--line);padding:4px 10px;border-radius:999px;color:var(--ink-2);white-space:nowrap}
.vfd-legend{display:flex;gap:14px;font-size:11.5px;color:var(--muted)}
.vfd-legend span{display:inline-flex;align-items:center;gap:6px}
.vfd-legend i{width:10px;height:10px;border-radius:2px;display:inline-block}

/* Compact table */
.vfd-table{width:100%;border-collapse:collapse;font-size:13px}
.vfd-table th{font-weight:600;color:var(--muted);text-align:left;padding:8px 4px;border-bottom:1px solid var(--line);font-size:11.5px;text-transform:uppercase;letter-spacing:.4px}
.vfd-table td{padding:11px 4px;border-bottom:1px solid var(--cream-2);color:var(--ink-2)}
.vfd-table tbody tr:last-child td{border-bottom:0}
.vfd-table td.vf-pos{color:#1c6661;font-weight:600}
.vfd-table td.vf-neg{color:#b3261e;font-weight:600}

/* Bar chart */
.vfd-chart{display:flex;align-items:flex-end;justify-content:space-around;height:190px;padding:8px 4px 4px}
.vfd-bargroup{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}
.vfd-bars{display:flex;align-items:flex-end;gap:4px;height:155px}
.vfd-bar{width:10px;border-radius:4px 4px 0 0;transition:height .4s ease}
.vfd-bar-inc{background:var(--teal-700)}
.vfd-bar-exp{background:var(--gold)}
.vfd-bargroup span{font-size:11px;color:var(--muted)}

/* Feature card */
.vfd-feature{background:linear-gradient(160deg,var(--teal-900),var(--teal-700));color:#fff;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}
.vfd-feature::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,var(--gold) 0%,transparent 70%);opacity:.35}
.vfd-feat-tag{align-self:flex-start;background:rgba(241,199,91,.18);color:var(--gold);font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.4px;text-transform:uppercase}
.vfd-feature h3{margin:6px 0 0;font-family:var(--display);font-size:18px;color:#fff;line-height:1.2}
.vfd-feature p{margin:0;font-size:13px;color:#cfe1df;line-height:1.5}
.vfd-feat-cta{margin-top:auto;align-self:flex-start;background:var(--gold);color:var(--teal-900);font-weight:700;font-size:13px;padding:9px 16px;border-radius:10px;text-decoration:none;z-index:1}
.vfd-feat-cta:hover{background:var(--gold-2)}
.vfd-feat-mark{font-size:11px;color:#9fbab7;font-family:var(--display);letter-spacing:.5px}

/* Donut */
.vfd-donut-wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.vfd-donut{width:150px;height:150px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;position:relative}
.vfd-donut-hole{width:96px;height:96px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 0 0 1px var(--line) inset}
.vfd-donut-l{font-size:11px;color:var(--muted)}
.vfd-donut-hole strong{font-family:var(--display);font-weight:800;font-size:16px;color:var(--teal-900)}
.vfd-donut-hole strong.vf-pos{color:#1c6661}
.vfd-donut-hole strong.vf-neg{color:#b3261e}
.vfd-donut-legend{list-style:none;padding:0;margin:0;flex:1;min-width:120px;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--ink-2)}
.vfd-donut-legend li{display:flex;align-items:center;gap:8px}
.vfd-donut-legend i{width:10px;height:10px;border-radius:50%}
.vfd-donut-legend b{margin-left:auto;font-family:var(--display);color:var(--teal-900)}

/* Channels */
.vfd-channels{display:flex;flex-direction:column;gap:12px}
.vfd-ch-row{display:grid;grid-template-columns:1.2fr 2fr 40px;align-items:center;gap:10px;font-size:12.5px}
.vfd-ch-l{display:flex;flex-direction:column;line-height:1.2}
.vfd-ch-l b{color:var(--teal-900);font-size:13px}
.vfd-ch-l span{font-size:11px;color:var(--muted)}
.vfd-ch-bar{height:8px;background:var(--cream-2);border-radius:999px;overflow:hidden}
.vfd-ch-bar > div{height:100%;background:linear-gradient(90deg,var(--teal-700),var(--teal-600));border-radius:999px}
.vfd-ch-pct{text-align:right;font-family:var(--display);font-weight:700;color:var(--teal-900);font-size:12.5px}

/* Notification toast (admin → user) */
.vf-notif-toast{position:fixed;top:74px;right:22px;z-index:9999;display:flex;align-items:flex-start;gap:12px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);box-shadow:0 12px 30px rgba(15,58,56,.18);padding:14px 16px;border-radius:14px;max-width:340px;animation:vf-toast-in .25s ease both}
.vf-notif-toast .ico{width:34px;height:34px;border-radius:10px;background:var(--teal-900);color:var(--gold);display:grid;place-items:center;flex-shrink:0;font-weight:800}
.vf-notif-toast b{display:block;color:var(--teal-900);font-family:var(--display);font-size:13.5px;margin-bottom:2px}
.vf-notif-toast p{margin:0;font-size:12.5px;color:var(--ink-2);line-height:1.4}
.vf-notif-toast button{background:none;border:0;color:var(--muted);font-size:18px;cursor:pointer;margin-left:6px}
@keyframes vf-toast-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* Responsive */
@media (max-width:1180px){
  .vfd-row-1{grid-template-columns:1fr 1fr;gap:14px}
  .vfd-row-1 .vfd-profile{grid-column:1/-1;order:-1}
  .vfd-row-2{grid-template-columns:1fr 1fr}
  .vfd-row-2 > .vfd-feature{grid-column:1/-1}
  .vfd-row-3{grid-template-columns:1fr 1fr}
  .vfd-row-3 > :last-child{grid-column:1/-1}
}
@media (max-width:680px){
  .vfd-row-1,.vfd-row-2,.vfd-row-3{grid-template-columns:1fr}
  .vfd-row-2 > .vfd-feature,.vfd-row-3 > :last-child{grid-column:auto}
}
