*{margin:0;padding:0;box-sizing:border-box;}
:root{--topbar-h:50px;--orange-nav-h:50px;--secondary-nav-h:48px;--sub-tabs-h:60px;}
body{font-family:'Inter',sans-serif;background:#f5f7fa;color:#1f2937;padding-top:calc(var(--topbar-h) + var(--orange-nav-h) + var(--secondary-nav-h) + var(--sub-tabs-h));padding-bottom:80px;}
.veeva-topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:white;padding:10px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb;z-index:1000;}
.topbar-left{display:flex;align-items:center;gap:12px;}
.back-btn{background:none;border:none;font-size:20px;color:#FF6B35;cursor:pointer;font-weight:700;}
.time{font-size:13px;color:#6b7280;font-weight:500;}
.topbar-title{font-size:18px;font-weight:700;}
.bell-icon{position:relative;font-size:18px;cursor:pointer;padding:6px;}
.bell-icon .badge{position:absolute;top:0;right:0;background:#ef4444;color:white;font-size:10px;font-weight:700;padding:2px 5px;border-radius:10px;}
.orange-nav{position:fixed;top:var(--topbar-h);left:0;right:0;height:var(--orange-nav-h);background:#D4711A;display:flex;gap:4px;padding:0 16px;z-index:999;}
.orange-nav a{display:flex;align-items:center;padding:0 20px;color:rgba(255,255,255,0.85);text-decoration:none;font-size:14px;font-weight:500;border-bottom:3px solid transparent;}
.orange-nav a:hover{color:white;background:rgba(255,255,255,0.1);}
.orange-nav a.active{color:white;border-bottom-color:white;font-weight:600;}
.secondary-nav{position:fixed;top:calc(var(--topbar-h) + var(--orange-nav-h));left:0;right:0;height:var(--secondary-nav-h);background:white;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;gap:40px;z-index:998;}
.sec-item{text-decoration:none;color:#6b7280;font-weight:600;font-size:14px;padding:12px 24px;border-bottom:3px solid transparent;}
.sec-item:hover{color:#374151;}
.sec-item.active{color:#FF6B35;border-bottom-color:#FF6B35;}
.sub-tabs{position:fixed;top:calc(var(--topbar-h) + var(--orange-nav-h) + var(--secondary-nav-h));left:0;right:0;height:var(--sub-tabs-h);background:white;border-bottom:1px solid #e5e7eb;padding:12px 24px;display:flex;align-items:center;gap:8px;z-index:997;}
.stab{padding:8px 16px;background:none;border:none;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-radius:6px;}
.stab:hover{background:#f9fafb;}
.stab.active{background:#fff7ed;color:#FF6B35;font-weight:600;}
.filter-btn{margin-left:auto;padding:8px 16px;background:white;border:1px solid #d1d5db;border-radius:8px;display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer;}
.create-btn{padding:8px 20px;background:#FF6B35;color:white;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;margin-left:12px;}
.main-grid{display:grid;grid-template-columns:1fr 320px;gap:0;}
.main-grid.no-filter{grid-template-columns:1fr;}
.charts-grid{padding:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-content:start;}
.chart-card{background:white;border-radius:12px;padding:18px;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid #e5e7eb;transition:all 0.3s;}
.chart-card:hover{box-shadow:0 8px 20px rgba(0,0,0,0.1);transform:translateY(-4px);border-color:#FF6B35;}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.rec{font-size:11px;font-weight:600;color:#FF6B35;}
.card-top>div{display:flex;gap:6px;}
.card-top button{background:none;border:none;font-size:14px;color:#9ca3af;cursor:pointer;}
.starred{color:#fbbf24 !important;}
.chart-card h4{font-size:15px;font-weight:600;margin-bottom:12px;color:#111827;line-height:1.4;}
.chart-box{height:200px;margin-bottom:10px;}
.insight-line{font-size:13px;color:#374151;line-height:1.5;margin-bottom:8px;padding:10px;background:#f9fafb;border-radius:6px;border-left:3px solid #FF6B35;}
.src{font-size:11px;color:#9ca3af;font-style:italic;}
.collections-grid{padding:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.coll-card{background:white;border-radius:12px;padding:20px;border:1px solid #e5e7eb;cursor:pointer;transition:all 0.3s;}
.coll-card:hover{box-shadow:0 8px 20px rgba(0,0,0,0.1);transform:translateY(-4px);border-color:#2563eb;}
.coll-insight{font-size:12px;color:#6b7280;line-height:1.4;margin:10px 0;}
.dots{text-align:center;color:#bfdbfe;font-size:12px;letter-spacing:4px;}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:white;border-top:1px solid #e5e7eb;padding:6px 4px;display:flex;justify-content:space-around;z-index:90;}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;padding:4px;}
.nav-btn span{font-size:10px;color:#6b7280;}
.nav-btn.active span{color:#FF6B35;font-weight:600;}







/* =========================
   FILTER PANEL (RIGHT ASIDE)
   ========================= */

/* Make sure the main grid can host the aside nicely */
.main-grid{
  align-items:start;
}

/* Aside container */
.filter-panel{
  position:sticky;                 /* stays visible while scrolling */
  top:calc(var(--topbar-h) + var(--orange-nav-h) + var(--secondary-nav-h) + var(--sub-tabs-h) + 16px);
  align-self:start;
  height:calc(100vh - (var(--topbar-h) + var(--orange-nav-h) + var(--secondary-nav-h) + var(--sub-tabs-h) + 32px));
  background:#ffffff;
  border-left:1px solid #e5e7eb;
  padding:16px;
  box-shadow:-6px 0 18px rgba(0,0,0,0.06);
  z-index:50;
  display:block;                   /* JS toggles this */
}

/* Optional show animation hook (your JS adds .show) */
.filter-panel.show{
  animation:filterSlideIn 180ms ease-out;
}

@keyframes filterSlideIn{
  from{transform:translateX(8px);opacity:0.5;}
  to{transform:translateX(0);opacity:1;}
}

/* Header */
.filter-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding-bottom:12px;
  border-bottom:1px solid #e5e7eb;
}

.filter-head h3{
  font-size:14px;
  font-weight:700;
  color:#111827;
}

.filter-head button{
  border:none;
  background:#f9fafb;
  width:32px;
  height:32px;
  border-radius:10px;
  cursor:pointer;
  color:#6b7280;
  font-size:14px;
}

.filter-head button:hover{
  background:#f3f4f6;
  color:#111827;
}

/* Body */
.filter-body{
  padding:14px 0;
  display:flex;
  flex-direction:column;
  gap:14px;
}

/* Field group */
.fg{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.fg label{
  font-size:12px;
  font-weight:700;
  color:#374151;
}

/* Select inputs */
.fg select{
  width:100%;
  padding:10px 12px;
  border:1px solid #d1d5db;
  border-radius:10px;
  background:#ffffff;
  color:#111827;
  font-size:13px;
  font-weight:600;
  outline:none;
  cursor:pointer;
}

.fg select:focus{
  border-color:#FF6B35;
  box-shadow:0 0 0 3px rgba(255,107,53,0.18);
}

/* Footer buttons */
.filter-foot{
  border-top:1px solid #e5e7eb;
  padding-top:12px;
  display:flex;
  gap:10px;
}

.filter-foot button{
  flex:1;
  padding:10px 12px;
  border-radius:10px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}

/* Cancel */
.filter-foot button:not(.apply){
  background:#ffffff;
  border:1px solid #d1d5db;
  color:#374151;
}

.filter-foot button:not(.apply):hover{
  background:#f9fafb;
}

/* Apply */
.filter-foot .apply{
  background:#FF6B35;
  border:none;
  color:#ffffff;
}

.filter-foot .apply:hover{
  filter:brightness(0.98);
}

/* When filter is hidden, let content use full width (you already toggle this class) */
.main-grid.no-filter .filter-panel{
  display:none !important;
}

/* Responsive: collapse to 2 columns then 1 column and make filter a drawer-ish panel */
@media (max-width: 1200px){
  .charts-grid{grid-template-columns:repeat(2,1fr);}
  .main-grid{grid-template-columns:1fr 300px;}
}

@media (max-width: 900px){
  .charts-grid{grid-template-columns:1fr;}
  .main-grid{grid-template-columns:1fr;}
  .filter-panel{
    position:fixed;
    right:0;
    top:calc(var(--topbar-h) + var(--orange-nav-h) + var(--secondary-nav-h) + var(--sub-tabs-h));
    height:calc(100vh - (var(--topbar-h) + var(--orange-nav-h) + var(--secondary-nav-h) + var(--sub-tabs-h)));
    width:min(360px, 92vw);
    border-left:1px solid #e5e7eb;
    box-shadow:-14px 0 28px rgba(0,0,0,0.12);
    display:none; /* default hidden; JS toggles to block */
  }
}
