*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root { --teal:#1F4D4C; --teal-mid:#2A6260; --teal-deep:#143635; --lime:#8DC21F; --lime-dark:#6EA018; --mist:#EAF0FB; --panel:#F7F9FE; --white:#fff; --ink:#1A2E2E; --mid:#445555; --muted:#718787; --border:#D5E0E0; --shadow:0 22px 60px rgba(31,77,76,.12); }
html { scroll-behavior: smooth; }
body { font-family: 'Rubik', sans-serif; background: var(--mist); color: var(--ink); line-height: 1.62; overflow-x: hidden; }
a { color: var(--teal); }
nav { position: fixed; top: 0; width: 100%; z-index: 100; background: rgba(255,255,255,.96); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
.nav-inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; height: 100px; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.logo-img { height: 80px; width: auto; }
.nav-links { display: flex; align-items: center; gap: .1rem; list-style: none; }
.nav-links a { text-decoration: none; color: var(--mid); font-size: .875rem; font-weight: 500; padding: .45rem .75rem; border-radius: 6px; }
.nav-links a:hover { color: var(--teal); background: rgba(31,77,76,.06); }
.nav-cta { background: var(--teal) !important; color: #fff !important; padding: .55rem 1.25rem !important; border-radius: 999px !important; font-weight: 600 !important; }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--teal); }
.research-hero { padding: 142px 0 4.5rem; background: linear-gradient(180deg,#f8fbff 0%, var(--mist) 100%); }
.hero-shell, .shell { max-width: 1180px; margin: 0 auto; padding: 0 2rem; }
.hero-shell { display: grid; grid-template-columns: 1.08fr .92fr; gap: 2.2rem; align-items: center; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: .72rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; color: var(--teal); margin-bottom: 1rem; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lime); }
h1 { font-size: clamp(2.2rem,4vw,3.75rem); line-height: 1.05; color: var(--teal); font-weight: 800; margin-bottom: 1rem; }
h1 .accent, .section-title .accent { color: var(--lime-dark); }
.lead { font-size: 1.02rem; color: var(--mid); max-width: 680px; margin-bottom: 1rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.6rem; }
.btn-primary, .btn-secondary { display: inline-flex; align-items: center; justify-content: center; padding: .9rem 1.25rem; border-radius: 999px; text-decoration: none; font-weight: 800; }
.btn-primary { background: var(--lime); color: var(--ink); }
.btn-secondary { background: #fff; color: var(--teal); border: 1px solid rgba(31,77,76,.15); }
.hero-visual { min-height: 430px; border-radius: 28px; overflow: hidden; box-shadow: var(--shadow); background: var(--teal); position: relative; }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .82; }
.data-badge { position: absolute; left: 1.2rem; right: 1.2rem; bottom: 1.2rem; background: rgba(255,255,255,.96); border-radius: 18px; padding: 1rem; }
.data-badge strong { display: block; color: var(--teal); margin-bottom: .25rem; }
.data-badge p { color: var(--mid); font-size: .88rem; }
.section { padding: 4.4rem 0; background: #fff; }
.section.alt { background: var(--panel); }
.section-title { font-size: clamp(1.7rem,3vw,2.55rem); line-height: 1.1; color: var(--teal); font-weight: 800; margin-bottom: .9rem; }
.section-copy { color: var(--mid); max-width: 760px; margin-bottom: 1.4rem; }
.asset-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 1.4rem; }
.asset-card, .quote-card, .source-card, .mini-card { background: #fff; border: 1px solid rgba(31,77,76,.1); border-radius: 16px; padding: 1.15rem; box-shadow: 0 12px 30px rgba(31,77,76,.05); }
.asset-card { text-decoration: none; color: inherit; min-height: 230px; display: flex; flex-direction: column; }
.asset-card:hover { transform: translateY(-2px); border-color: var(--lime); transition: .2s ease; }
.asset-card span, .mini-card span { display: block; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--lime-dark); font-weight: 800; margin-bottom: .55rem; }
.asset-card h2, .asset-card h3, .mini-card h3, .source-card h3 { color: var(--teal); line-height: 1.22; margin-bottom: .55rem; }
.asset-card p, .mini-card p, .source-card p { color: var(--mid); font-size: .9rem; }
.asset-card .read { margin-top: auto; color: var(--teal); font-weight: 800; font-size: .84rem; }
.stat-row { display: grid; grid-template-columns: repeat(4,1fr); gap: .9rem; margin: 1.4rem 0; }
.stat { background: var(--teal); color: #fff; border-radius: 18px; padding: 1.1rem; min-height: 130px; }
.stat b { display: block; font-size: clamp(1.55rem,3vw,2.2rem); line-height: 1; margin-bottom: .45rem; color: var(--lime); }
.stat span { font-size: .82rem; color: rgba(255,255,255,.84); }
.chart { background: #fff; border: 1px solid rgba(31,77,76,.1); border-radius: 20px; padding: 1.2rem; box-shadow: 0 12px 30px rgba(31,77,76,.05); margin-top: 1.3rem; }
.bar { display: grid; grid-template-columns: 170px 1fr 70px; gap: .8rem; align-items: center; margin: .85rem 0; color: var(--mid); font-size: .86rem; }
.bar-track { height: 14px; border-radius: 999px; background: var(--mist); overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg,var(--teal),var(--lime)); }
.data-table { width: 100%; border-collapse: separate; border-spacing: 0; overflow: hidden; border-radius: 18px; background: #fff; box-shadow: 0 12px 30px rgba(31,77,76,.05); margin-top: 1.2rem; }
.data-table th { background: var(--teal); color: #fff; text-align: left; padding: .86rem; font-size: .8rem; }
.data-table td { padding: .84rem .86rem; border-bottom: 1px solid var(--border); color: var(--mid); font-size: .9rem; vertical-align: top; }
.quote-card { border-left: 6px solid var(--lime); margin-top: 1.2rem; }
.quote-card p { color: var(--mid); font-size: 1rem; }
.source-grid, .mini-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 1.4rem; }
.source-card { display: block; text-decoration: none; color: inherit; }
.cta-band { background: linear-gradient(135deg,var(--teal),var(--teal-deep)); border-radius: 24px; padding: 2rem; color: #fff; display: grid; grid-template-columns: 1fr auto; gap: 1.4rem; align-items: center; }
.cta-band h2 { font-size: clamp(1.5rem,3vw,2.2rem); line-height: 1.1; margin-bottom: .6rem; }
.cta-band p { color: rgba(255,255,255,.8); max-width: 680px; }
footer { background: #102625; color: #fff; padding: 4rem 0 2rem; }
.foot-top { max-width: 1180px; margin: 0 auto; padding: 0 2rem 2rem; display: grid; grid-template-columns: minmax(220px,1.4fr) repeat(4,minmax(135px,1fr)); gap: 2rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.foot-logo { height: 70px; width: auto; margin-bottom: 1rem; }
.foot-copytext { color: rgba(255,255,255,.58); font-size: .9rem; line-height: 1.7; }
.f-heading { font-size: .67rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 1rem; }
.f-links { list-style: none; display: flex; flex-direction: column; gap: .55rem; }
.f-links a { text-decoration: none; color: rgba(255,255,255,.65); font-size: .85rem; }
.foot-bottom { text-align: center; padding: 1.4rem 2rem 0; color: rgba(255,255,255,.35); font-size: .78rem; }
@media (max-width: 980px) { .hero-shell, .cta-band, .foot-top { grid-template-columns: 1fr; } .asset-grid, .source-grid, .mini-grid { grid-template-columns: repeat(2,1fr); } .stat-row { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 720px) { .nav-links { display: none; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: #fff; padding: 1rem 2rem 1.5rem; } .nav-links.open { display: flex; } .hamburger { display: flex; } .hero-shell, .shell { padding: 0 1rem; } .research-hero { padding-top: 128px; } .asset-grid, .source-grid, .mini-grid, .stat-row { grid-template-columns: 1fr; } .bar { grid-template-columns: 1fr; gap: .35rem; } }
