
.page-hero h1 { font-size: 3rem; }

.intro-section { padding: var(--section-padding); background-color: var(--bg-white); }
.intro-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 4rem; align-items: center; }
.intro-grid h2 { font-size: 2.2rem; margin-bottom: 1.5rem; }
.intro-grid p { font-size: 1.1rem; color: var(--text-muted); margin-bottom: 1.2rem; }
.facts { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.fact { background: var(--bg-light); border-radius: var(--border-radius); padding: 1.8rem 1.5rem; text-align: center; position: relative; overflow: hidden; }
.fact::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--cg-green); }
.fact:nth-child(even)::before { background: var(--rp-orange); }
.fact .num { font-family: var(--font-logo); font-size: 2.4rem; font-weight: 800; color: var(--primary-blue); line-height: 1; }
.fact .lbl { font-size: 0.9rem; color: var(--text-muted); margin-top: 0.4rem; font-weight: 500; }

.timeline-section { padding: var(--section-padding); background-color: var(--bg-light); }
.timeline { position: relative; max-width: 940px; margin: 3rem auto 0; }
.timeline::before {
    content: ''; position: absolute; top: 6px; bottom: 6px; left: 50%; transform: translateX(-50%);
    width: 3px; border-radius: 3px;
    background: linear-gradient(to bottom, var(--cg-green) 0%, var(--primary-blue) 50%, var(--rp-orange) 100%);
}
.tl-item { position: relative; width: 50%; padding: 0 2.8rem 2.6rem; box-sizing: border-box; }
.tl-item:nth-child(odd) { left: 0; text-align: right; }
.tl-item:nth-child(even) { left: 50%; text-align: left; }
.tl-item::after {
    content: ''; position: absolute; top: 4px;
    width: 18px; height: 18px; border-radius: 50%;
    background: #fff; border: 4px solid var(--cg-green);
    box-shadow: 0 0 0 4px rgba(120,184,44,0.15); z-index: 2;
}
.tl-item:nth-child(odd)::after { right: -9px; }
.tl-item:nth-child(even)::after { left: -9px; }
.tl-card {
    background: var(--bg-white); border-radius: var(--border-radius);
    padding: 1.6rem 1.8rem; box-shadow: var(--box-shadow);
    transition: transform var(--transition-speed), box-shadow var(--transition-speed);
}
.tl-card:hover { transform: translateY(-5px); box-shadow: 0 20px 40px rgba(0,0,0,0.08); }
.tl-year { font-family: var(--font-logo); font-size: 1.5rem; font-weight: 800; color: var(--primary-blue); margin-bottom: 0.2rem; }
.tl-card h3 { font-size: 1.15rem; color: var(--text-dark); margin-bottom: 0.6rem; }
.tl-card p { color: var(--text-muted); font-size: 0.97rem; }
.tl-card p a { color: var(--rp-orange); font-weight: 600; }
.tl-card p a:hover { text-decoration: underline; }
.tl-item.is-green::after { border-color: var(--cg-green); box-shadow: 0 0 0 4px rgba(120,184,44,0.18); }
.tl-item.is-orange::after { border-color: var(--rp-orange); box-shadow: 0 0 0 4px rgba(238,117,1,0.18); }
.tl-card.feat-green { border-left: 4px solid var(--cg-green); }
.tl-card.feat-orange { background: linear-gradient(135deg, var(--rp-orange), var(--rp-orange-hover)); }
.tl-card.feat-orange .tl-year,
.tl-card.feat-orange h3 { color: #fff; }
.tl-card.feat-orange p { color: rgba(255,255,255,0.92); }
.tl-logo { display: inline-block; height: 34px; width: auto; margin-bottom: 0.9rem; }

.gen-section { padding: var(--section-padding); background-color: var(--bg-white); }
.gen-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: 3rem; }
.gen-card { background: var(--bg-light); border-radius: var(--border-radius); padding: 2.5rem 2rem; text-align: center; position: relative; overflow: hidden; transition: transform var(--transition-speed), box-shadow var(--transition-speed); }
.gen-card:hover { transform: translateY(-8px); box-shadow: var(--box-shadow); }
.gen-badge {
    width: 70px; height: 70px; border-radius: 50%; margin: 0 auto 1.4rem;
    display: grid; place-items: center; color: #fff;
    font-family: var(--font-logo); font-size: 1.5rem; font-weight: 800;
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-dark));
}
.gen-card:nth-child(2) .gen-badge { background: linear-gradient(135deg, var(--cg-green), var(--cg-green-hover)); }
.gen-card:nth-child(3) .gen-badge { background: linear-gradient(135deg, var(--rp-orange), var(--rp-orange-hover)); }
.gen-card .gen-era { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--rp-orange); margin-bottom: 0.4rem; }
.gen-card h3 { font-size: 1.3rem; margin-bottom: 0.6rem; }
.gen-card p { color: var(--text-muted); font-size: 0.96rem; }

.today-section { padding: var(--section-padding); background-color: var(--bg-light); }
.today-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 3rem; }
.today-card {
    background: var(--bg-white); border-radius: var(--border-radius);
    padding: 2.5rem; box-shadow: var(--box-shadow);
    display: flex; flex-direction: column; align-items: flex-start;
    position: relative; overflow: hidden;
    transition: transform var(--transition-speed), box-shadow var(--transition-speed);
}
.today-card:hover { transform: translateY(-8px); box-shadow: 0 20px 45px rgba(0,0,0,0.1); }
.today-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 5px; }
.today-card.t-cg::before { background: var(--cg-green); }
.today-card.t-rp::before { background: var(--rp-orange); }
.today-logo { height: 54px; width: auto; margin-bottom: 1.5rem; }
.today-card p { color: var(--text-muted); margin-bottom: 1.6rem; flex-grow: 1; }
.today-card .btn { margin-top: auto; }

@media (max-width: 992px) {
    .page-hero h1 { font-size: 2.4rem; }
    .intro-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .gen-grid { grid-template-columns: 1fr; gap: 1.5rem; }
    .today-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}
@media (max-width: 768px) {
    .page-hero h1 { font-size: 2rem; }
    .facts { grid-template-columns: 1fr 1fr; }
    .timeline { margin-top: 2rem; }
    .timeline::before { left: 18px; transform: none; }
    .tl-item { width: 100%; left: 0 !important; text-align: left !important; padding: 0 0 2.2rem 3.2rem; }
    .tl-item::after { left: 9px !important; right: auto !important; }
    .tl-card.feat-green { border-left-width: 4px; }
}
