| |
| |
| |
| @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap'); |
|
|
| :root { |
| --pfizer-deep: #0d009d; |
| --pfizer-blue: #0051a5; |
| --pfizer-light: #00a3e0; |
| --pfizer-sky: #54c8e8; |
|
|
| --seg-a: #6B7280; |
| --seg-b: #1A6FD4; |
| --seg-c: #D4720A; |
| --seg-unlabeled: #7C3AED; |
|
|
| --bg-body: #f0f2f5; |
| --bg-card: #ffffff; |
| --bg-active: #eef6fc; |
|
|
| --text-primary: #1e293b; |
| --text-secondary: #64748b; |
| --text-muted: #94a3b8; |
|
|
| --border-subtle: #e2e8f0; |
| --border-card: #e5e7eb; |
|
|
| --accent-green: #0D9E6E; |
| --accent-amber: #d97706; |
| --accent-coral: #DC3545; |
|
|
| --shadow-card: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04); |
| --shadow-card-hover: 0 8px 24px rgba(0,0,0,0.08); |
| --shadow-header: 0 1px 8px rgba(0,0,0,0.04); |
| --radius-sm: 8px; |
| --radius-md: 12px; |
| --radius-lg: 16px; |
| --radius-xl: 20px; |
| --transition-base: 0.25s cubic-bezier(0.4,0,0.2,1); |
| } |
|
|
| *,*::before,*::after{box-sizing:border-box;margin:0;padding:0} |
| html{scroll-behavior:smooth} |
| body{font-family:'Inter',sans-serif;background:var(--bg-body);color:var(--text-primary);line-height:1.6;min-height:100vh} |
|
|
| |
| .top-header{background:var(--bg-card);border-bottom:1px solid var(--border-subtle);padding:14px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-header)} |
| .top-header-left{display:flex;align-items:center;gap:20px} |
| .top-header-left img{height:32px;width:auto} |
| .top-header-left h1{font-size:18px;font-weight:700;color:var(--pfizer-deep);border-left:1px solid var(--border-subtle);padding-left:20px} |
| .top-header-left span{font-size:13px;color:var(--text-secondary);margin-left:8px} |
| .header-badge{padding:6px 16px;border-radius:20px;font-size:12px;font-weight:600;background:#ecfdf5;color:var(--accent-green);border:1px solid #a7f3d0} |
|
|
| |
| .tab-nav{background:var(--bg-card);border-bottom:1px solid var(--border-subtle);padding:0 32px;display:flex;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch} |
| .tab-nav::-webkit-scrollbar{height:0} |
| .tab-btn{padding:14px 20px;font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:var(--transition-base);white-space:nowrap;display:flex;align-items:center;gap:8px} |
| .tab-btn:hover{color:var(--pfizer-blue);background:var(--bg-active)} |
| .tab-btn.active{color:var(--pfizer-blue);border-bottom-color:var(--pfizer-blue);background:var(--bg-active)} |
|
|
| |
| .tab-content{display:none;padding:32px;max-width:1440px;margin:0 auto;animation:fadeIn 0.35s ease} |
| .tab-content.active{display:block} |
| @keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}} |
|
|
| |
| .section-header{display:flex;align-items:center;gap:16px;margin-bottom:24px} |
| .section-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;background:rgba(0,81,165,0.08);color:var(--pfizer-blue)} |
| .section-title{font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-0.3px} |
| .section-subtitle{font-size:14px;color:var(--text-secondary);margin-top:2px} |
|
|
| |
| .grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px} |
| .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px} |
| .grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px} |
| .grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:20px} |
| .grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:24px} |
|
|
| |
| .card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);transition:var(--transition-base)} |
| .card:hover{box-shadow:var(--shadow-card-hover)} |
|
|
| |
| .kpi-card{display:flex;flex-direction:column;gap:8px} |
| .kpi-top{display:flex;align-items:center;justify-content:space-between} |
| .kpi-label{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:0.5px} |
| .kpi-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:14px} |
| .kpi-value{font-size:32px;font-weight:800;letter-spacing:-1px;color:var(--pfizer-deep);line-height:1.2} |
| .kpi-sub{font-size:13px;color:var(--text-muted);font-weight:500} |
|
|
| |
| .segment-card{position:relative;overflow:hidden} |
| .segment-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;border-radius:4px 0 0 4px} |
| .seg-a .segment-card::before,.seg-a.segment-card::before{background:var(--seg-a)} |
| .seg-b .segment-card::before,.seg-b.segment-card::before{background:var(--seg-b)} |
| .seg-c .segment-card::before,.seg-c.segment-card::before{background:var(--seg-c)} |
| .segment-name{font-size:18px;font-weight:700;margin-bottom:6px} |
| .segment-desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:20px;min-height:66px} |
| .segment-stats{display:flex;flex-direction:column;gap:12px} |
| .segment-stat{display:flex;justify-content:space-between;align-items:center} |
| .segment-stat-label{font-size:13px;color:var(--text-secondary);font-weight:500} |
| .segment-stat-value{font-size:14px;font-weight:700} |
| .segment-meter{width:100%;height:6px;background:#f1f5f9;border-radius:3px;margin-top:4px;overflow:hidden} |
| .segment-meter-fill{height:100%;border-radius:3px;transition:width 1s ease} |
|
|
| |
| .plotly-chart{width:100%;min-height:340px;border-radius:var(--radius-md);overflow:hidden} |
| .plotly-chart-sm{width:100%;min-height:280px} |
| .chart-title{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text-primary);letter-spacing:-0.2px} |
| .chart-container{position:relative;width:100%} |
| .chart-container canvas{width:100%!important} |
|
|
| |
| .persona-card{padding:32px} |
| .persona-header{display:flex;align-items:center;gap:20px;margin-bottom:24px} |
| .persona-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0} |
| .persona-name{font-size:20px;font-weight:700;color:var(--text-primary)} |
| .persona-role{font-size:14px;color:var(--text-secondary);margin-top:2px} |
| .persona-seg{font-size:13px;font-weight:600;margin-top:4px} |
| .persona-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px} |
| .persona-metric{background:#f8fafc;padding:16px;border-radius:var(--radius-md);border:1px solid #f1f5f9} |
| .persona-metric-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;font-weight:600;letter-spacing:0.5px} |
| .persona-metric-value{font-size:22px;font-weight:800;color:var(--pfizer-deep);margin-top:4px;letter-spacing:-0.5px} |
|
|
| |
| .badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600} |
| .badge-green{background:#ecfdf5;color:var(--accent-green)} |
| .badge-amber{background:#fffbeb;color:var(--accent-amber)} |
| .badge-red{background:#fef2f2;color:var(--accent-coral)} |
| .badge-blue{background:#eff6ff;color:var(--pfizer-blue)} |
| .badge-sky{background:#f0f9ff;color:var(--pfizer-light)} |
| .badge-purple{background:#f5f3ff;color:var(--seg-unlabeled)} |
|
|
| |
| .alert-box{padding:16px 20px;border-radius:var(--radius-md);font-size:14px;line-height:1.6;display:flex;align-items:flex-start;gap:12px;margin-top:20px} |
| .alert-box i{margin-top:3px;font-size:16px} |
| .alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:var(--pfizer-blue)} |
| .alert-warning{background:#fffbeb;border:1px solid #fde68a;color:var(--accent-amber)} |
| .alert-success{background:#ecfdf5;border:1px solid #a7f3d0;color:var(--accent-green)} |
|
|
| |
| .insight-card{border-left:4px solid var(--pfizer-light)} |
| .insight-number{font-size:40px;font-weight:900;color:var(--pfizer-sky);opacity:0.25;line-height:1;margin-bottom:8px} |
| .insight-title{font-size:16px;font-weight:700;margin-bottom:8px;color:var(--text-primary)} |
| .insight-text{font-size:14px;color:var(--text-secondary);line-height:1.6} |
|
|
| |
| .tier-card{border-left:4px solid transparent;padding:20px 24px} |
| .tier-card.tier-1{border-left-color:var(--accent-green)} |
| .tier-card.tier-2{border-left-color:var(--accent-amber)} |
| .tier-card.tier-3{border-left-color:var(--text-muted)} |
| .tier-value{font-size:28px;font-weight:800;letter-spacing:-0.5px;line-height:1.2} |
| .tier-label{font-size:13px;color:var(--text-secondary);font-weight:600;margin-top:2px} |
| .tier-desc{font-size:12px;color:var(--text-muted);margin-top:6px} |
|
|
| |
| .metric-highlight{text-align:center;padding:20px;background:#f8fafc;border-radius:var(--radius-md);border:1px solid #f1f5f9} |
| .metric-highlight-value{font-size:28px;font-weight:800;color:var(--pfizer-deep);letter-spacing:-0.5px} |
| .metric-highlight-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-top:4px} |
|
|
| |
| .sub-tabs{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap} |
| .sub-tab{padding:10px 24px;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--border-card);background:var(--bg-card);color:var(--text-secondary);transition:var(--transition-base)} |
| .sub-tab:hover{border-color:var(--pfizer-blue);color:var(--pfizer-blue)} |
| .sub-tab.active{background:var(--pfizer-deep);color:#fff;border-color:var(--pfizer-deep)} |
| .sub-panel{display:none} |
| .sub-panel.active{display:block;animation:fadeIn 0.3s ease} |
|
|
| |
| .data-table{width:100%;border-collapse:collapse;font-size:14px} |
| .data-table thead th{text-align:left;padding:12px 16px;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:0.5px;border-bottom:2px solid var(--border-subtle);background:#f8fafc} |
| .data-table tbody td{padding:12px 16px;border-bottom:1px solid var(--border-subtle)} |
| .data-table tbody tr:hover{background:#f8fafc} |
|
|
| |
| .coverage-gap{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;background:#fef2f2;color:var(--accent-coral);border:1px solid #fecaca} |
|
|
| |
| @media(max-width:1200px){.grid-5{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}} |
| @media(max-width:900px){.grid-3,.grid-2,.grid-2-1{grid-template-columns:1fr}} |
| @media(max-width:600px){.grid-5,.grid-4{grid-template-columns:1fr}.tab-btn{padding:12px 14px;font-size:12px}} |
|
|