/* ============================================================
   Muhanga TTC Enterprise — Main Stylesheet v1.0
   ============================================================ */
:root {
  --green-dark:  #0F2F24;
  --green-mid:   #1D5C3A;
  --green-light: #e8f5ee;
  --gold:        #C8A84B;
  --gold-light:  #fdf3d8;
  --white:       #ffffff;
  --bg:          #f8faf8;
  --border:      #e2e8e4;
  --text:        #1a2e23;
  --text-mid:    #4b5e54;
  --text-light:  #8a9e94;
  --red:         #dc2626;
  --red-light:   #fef2f2;
  --blue:        #2563eb;
  --blue-light:  #eff6ff;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08);
  --shadow:      0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:   0 12px 40px rgba(0,0,0,.14);
  --radius:      10px;
  --radius-lg:   16px;
  --transition:  all .2s ease;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'Segoe UI',system-ui,Arial,sans-serif; background:var(--bg); color:var(--text); line-height:1.6; }

/* ── Typography ── */
h1,h2,h3,h4,h5 { font-family:'EB Garamond',Georgia,serif; color:var(--green-dark); line-height:1.25; }
h1 { font-size:2.4rem; } h2 { font-size:1.9rem; } h3 { font-size:1.4rem; }
h4 { font-size:1.1rem; } h5 { font-size:.95rem; }
p { color:var(--text-mid); }
a { color:var(--green-mid); text-decoration:none; }
a:hover { color:var(--green-dark); }

/* ── Announce Bar ── */
.announce-bar { background:var(--green-dark); color:#fff; padding:.35rem 0; overflow:hidden; }
.announce-inner { display:flex; align-items:center; gap:1rem; }
.announce-tag { background:var(--gold); color:#000; font-size:.65rem; font-weight:800; padding:.15rem .5rem; border-radius:3px; text-transform:uppercase; letter-spacing:.08em; flex-shrink:0; }
.ticker-wrap { flex:1; overflow:hidden; }
.ticker-track { display:flex; width:max-content; animation:tickerScroll 45s linear infinite; }
.ticker-track:hover { animation-play-state:paused; }
.ticker-item { padding:0 2.5rem; white-space:nowrap; font-size:.8rem; color:rgba(255,255,255,.85); }
.ticker-item a { color:rgba(255,255,255,.9); }
@keyframes tickerScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── Navigation ── */
#main-nav { background:#fff; border-bottom:2px solid var(--border); position:sticky; top:0; z-index:900; box-shadow:var(--shadow-sm); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; padding:.6rem 0; }
.nav-logo { display:flex; align-items:center; gap:.75rem; text-decoration:none; }
.nav-logo-mark { width:42px; height:42px; background:var(--gold); border-radius:8px; display:flex; align-items:center; justify-content:center; font-weight:900; color:#fff; font-size:1.2rem; flex-shrink:0; }
.nav-logo-text strong { display:block; font-size:.88rem; font-weight:800; color:var(--green-dark); }
.nav-logo-text small { color:var(--text-light); font-size:.68rem; }
.nav-links { display:flex; align-items:center; gap:.15rem; }
.nav-links a { padding:.42rem .8rem; border-radius:6px; font-size:.84rem; font-weight:600; color:var(--text-mid); transition:var(--transition); white-space:nowrap; }
.nav-links a:hover,.nav-links a.active { background:var(--green-light); color:var(--green-dark); }
.nav-links .nav-btn { background:var(--green-dark); color:#fff !important; padding:.42rem 1rem; }
.nav-links .nav-btn:hover { background:var(--green-mid); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:.4rem; background:none; border:none; }
.hamburger span { display:block; width:22px; height:2px; background:var(--green-dark); border-radius:2px; transition:var(--transition); }

/* ── Container ── */
.container { max-width:1200px; margin:0 auto; padding:0 1.25rem; }
.container-sm { max-width:760px; margin:0 auto; padding:0 1.25rem; }

/* ── Hero ── */
.hero { position:relative; overflow:hidden; background:var(--green-dark); padding:5rem 0 4rem; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(15,47,36,.96) 40%,rgba(29,92,58,.8) 100%); z-index:0; }
.hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.15; z-index:0; }
.hero > .container { position:relative; z-index:1; }
.hero-badge { display:inline-block; background:rgba(200,168,75,.2); border:1px solid rgba(200,168,75,.4); color:var(--gold); font-size:.75rem; font-weight:700; padding:.3rem .9rem; border-radius:20px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:1rem; }
.hero h1 { color:#fff; font-size:2.6rem; line-height:1.2; margin-bottom:1rem; max-width:720px; }
.hero-sub { color:rgba(255,255,255,.75); font-size:1.05rem; max-width:600px; margin-bottom:2rem; }
.hero-btns { display:flex; gap:.75rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.hero-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; max-width:680px; }
.hero-stat-n { font-size:1.8rem; font-weight:800; color:var(--gold); font-family:'EB Garamond',Georgia,serif; }
.hero-stat-l { font-size:.75rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.05em; }

/* ── Page Header ── */
.page-header { background:var(--green-dark); padding:3rem 0 2.5rem; position:relative; overflow:hidden; }
.page-header .hero-bg { opacity:.12; }
.page-header > .container { position:relative; z-index:1; }
.page-header h1 { color:#fff; font-size:2rem; }
.breadcrumb { font-size:.78rem; color:rgba(255,255,255,.55); margin-bottom:.5rem; font-family:sans-serif; }
.breadcrumb a { color:rgba(255,255,255,.55); }

/* ── Sections ── */
.section { padding:4rem 0; }
.section-alt { background:#fff; padding:4rem 0; }
.section-dark { background:var(--green-dark); padding:4rem 0; }
.section-label { font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--green-mid); margin-bottom:.4rem; font-family:sans-serif; }
.text-center { text-align:center; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; gap:.4rem; padding:.6rem 1.35rem; border-radius:7px; font-size:.875rem; font-weight:700; border:2px solid transparent; cursor:pointer; transition:var(--transition); font-family:inherit; text-decoration:none; white-space:nowrap; }
.btn-primary   { background:var(--green-mid); color:#fff; border-color:var(--green-mid); }
.btn-primary:hover { background:var(--green-dark); border-color:var(--green-dark); color:#fff; }
.btn-gold      { background:var(--gold); color:#1a1a1a; border-color:var(--gold); }
.btn-gold:hover { background:#b8942e; }
.btn-outline   { border-color:var(--border); color:var(--text-mid); background:#fff; }
.btn-outline:hover { border-color:var(--green-mid); color:var(--green-dark); }
.btn-danger    { background:var(--red); color:#fff; border-color:var(--red); }
.btn-danger:hover { background:#b91c1c; }
.btn-ghost     { background:transparent; color:var(--text-mid); border-color:transparent; }
.btn-ghost:hover { background:var(--green-light); color:var(--green-dark); }
.btn-sm        { padding:.35rem .8rem; font-size:.78rem; }
.btn-lg        { padding:.8rem 2rem; font-size:1rem; }
.w-100         { width:100%; justify-content:center; }

/* ── Cards ── */
.card { background:#fff; border-radius:var(--radius); border:1px solid var(--border); box-shadow:var(--shadow-sm); overflow:hidden; transition:var(--transition); }
.card:hover { box-shadow:var(--shadow); }
.card-body { padding:1.5rem; }
.card-img { width:100%; height:200px; object-fit:cover; display:block; }
.card-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.card-grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; }
.card-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }

/* ── Forms ── */
.form-group { margin-bottom:1.1rem; }
.form-label { display:block; font-size:.82rem; font-weight:700; color:var(--text); margin-bottom:.35rem; font-family:sans-serif; }
.form-control { display:block; width:100%; padding:.55rem .85rem; border:1.5px solid var(--border); border-radius:7px; font-size:.9rem; font-family:inherit; color:var(--text); background:#fff; transition:var(--transition); }
.form-control:focus { outline:none; border-color:var(--green-mid); box-shadow:0 0 0 3px rgba(29,92,58,.12); }
.form-hint { font-size:.73rem; color:var(--text-light); margin-top:.3rem; font-family:sans-serif; }
.form-control.is-invalid { border-color:var(--red); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
select.form-control { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238a9e94' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .85rem center; padding-right:2.5rem; }
textarea.form-control { resize:vertical; min-height:120px; }
.captcha-box { background:var(--bg); border:1.5px solid var(--border); border-radius:7px; padding:.65rem 1rem; font-size:1rem; font-weight:700; color:var(--green-dark); font-family:monospace; text-align:center; margin-bottom:.4rem; }

/* ── Alerts ── */
.alert { padding:.85rem 1.1rem; border-radius:8px; font-size:.88rem; margin-bottom:1rem; border-left:4px solid transparent; font-family:sans-serif; }
.alert-success { background:#e8f5e9; border-color:#4caf50; color:#1b5e20; }
.alert-error   { background:var(--red-light); border-color:var(--red); color:#991b1b; }
.alert-info    { background:var(--blue-light); border-color:var(--blue); color:#1e3a8a; }
.alert-warning { background:var(--gold-light); border-color:var(--gold); color:#7a5a10; }

/* ── Badges ── */
.badge { display:inline-block; font-size:.68rem; font-weight:700; padding:.18rem .55rem; border-radius:12px; text-transform:uppercase; letter-spacing:.05em; font-family:sans-serif; }
.badge-success { background:#dcfce7; color:#166534; }
.badge-warning { background:#fef9c3; color:#854d0e; }
.badge-danger  { background:#fee2e2; color:#991b1b; }
.badge-info    { background:#dbeafe; color:#1e40af; }
.badge-gray    { background:#f3f4f6; color:#4b5563; }
.badge-gold    { background:var(--gold-light); color:#7a5a10; }
.badge-primary { background:var(--green-light); color:var(--green-dark); }

/* ── Tables ── */
.data-table { width:100%; border-collapse:collapse; font-size:.84rem; }
.data-table th { background:var(--green-dark); color:#fff; padding:.65rem 1rem; text-align:left; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; }
.data-table td { padding:.7rem 1rem; border-bottom:1px solid var(--border); vertical-align:middle; color:var(--text-mid); }
.data-table tr:hover td { background:var(--green-light); }
.data-table tr:last-child td { border-bottom:none; }
.table-wrap { overflow-x:auto; border-radius:var(--radius); border:1px solid var(--border); box-shadow:var(--shadow-sm); }

/* ── Stats ── */
.stat-card { background:#fff; border-radius:var(--radius); border:1px solid var(--border); padding:1.25rem; border-top:3px solid var(--green-mid); }
.stat-n { font-size:2rem; font-weight:800; color:var(--green-dark); font-family:Georgia,serif; line-height:1; }
.stat-l { font-size:.75rem; color:var(--text-light); text-transform:uppercase; letter-spacing:.06em; margin-top:.25rem; }

/* ── Modal ── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:5000; display:none; align-items:center; justify-content:center; padding:1rem; backdrop-filter:blur(2px); }
.modal-overlay.open { display:flex; }
.modal-box { background:#fff; border-radius:14px; padding:2rem; max-width:540px; width:100%; box-shadow:var(--shadow-lg); position:relative; max-height:90vh; overflow-y:auto; }
.modal-box-lg { max-width:760px; }
.modal-close { position:absolute; top:1rem; right:1rem; background:var(--bg); border:none; width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1.1rem; color:var(--text-mid); transition:var(--transition); }
.modal-close:hover { background:var(--border); }
.modal-header { margin-bottom:1.25rem; }
.modal-header h3 { font-size:1.2rem; }
.modal-header p { font-size:.85rem; color:var(--text-light); margin-top:.25rem; font-family:sans-serif; }

/* ── Tabs ── */
.tabs { display:flex; border-bottom:2px solid var(--border); margin-bottom:1.75rem; gap:0; overflow-x:auto; }
.tab-btn { padding:.65rem 1.25rem; font-size:.88rem; font-weight:600; color:var(--text-mid); background:none; border:none; border-bottom:3px solid transparent; margin-bottom:-2px; cursor:pointer; white-space:nowrap; transition:var(--transition); font-family:inherit; }
.tab-btn:hover { color:var(--green-dark); }
.tab-btn.active { color:var(--green-dark); border-bottom-color:var(--green-mid); }
.tab-pane { display:none; } .tab-pane.active { display:block; }

/* ── Gallery Slider ── */
.slider-wrap { position:relative; overflow:hidden; border-radius:var(--radius-lg); aspect-ratio:16/6; background:var(--green-dark); }
.slider-track { display:flex; height:100%; transition:transform .6s cubic-bezier(.4,0,.2,1); }
.slider-slide { flex-shrink:0; width:100%; position:relative; }
.slider-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.slider-caption { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(0,0,0,.6)); color:#fff; padding:2rem 1.5rem .8rem; font-size:.9rem; }
.slider-btn { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.15); backdrop-filter:blur(4px); border:1.5px solid rgba(255,255,255,.3); color:#fff; width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1.15rem; z-index:5; transition:var(--transition); }
.slider-btn:hover { background:rgba(255,255,255,.3); }
.slider-prev { left:1rem; } .slider-next { right:1rem; }
.slider-dots { position:absolute; bottom:.75rem; left:50%; transform:translateX(-50%); display:flex; gap:.35rem; z-index:5; }
.slider-dot { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.4); border:none; cursor:pointer; transition:var(--transition); }
.slider-dot.active { background:var(--gold); }

/* ── News cards ── */
.news-cat { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--green-mid); font-family:sans-serif; }
.news-date { font-size:.75rem; color:var(--text-light); font-family:sans-serif; margin:.1rem 0 .4rem; }
.news-title { font-size:1rem; font-weight:700; color:var(--green-dark); line-height:1.35; margin-bottom:.4rem; }
.news-excerpt { font-size:.83rem; color:var(--text-mid); line-height:1.55; }

/* ── Event ── */
.event-date-badge { background:var(--green-dark); color:#fff; border-radius:8px; padding:.45rem .7rem; text-align:center; min-width:52px; flex-shrink:0; }
.event-date-badge .eday { font-size:1.35rem; font-weight:800; line-height:1; }
.event-date-badge .emon { font-size:.6rem; text-transform:uppercase; letter-spacing:.08em; color:var(--gold); }

/* ── Partners strip ── */
.partner-pill { display:inline-flex; align-items:center; gap:.5rem; border:1.5px solid var(--border); border-radius:8px; padding:.45rem .9rem; font-size:.8rem; color:var(--text-mid); text-decoration:none; transition:var(--transition); background:#fff; }
.partner-pill:hover { border-color:var(--green-mid); color:var(--green-dark); }

/* ── Admin Layout ── */
.admin-layout { display:flex; min-height:100vh; }
.admin-sidebar { width:240px; background:var(--green-dark); flex-shrink:0; display:flex; flex-direction:column; position:sticky; top:0; height:100vh; overflow-y:auto; }
.admin-main { flex:1; min-width:0; }
.admin-topbar { background:#fff; border-bottom:1px solid var(--border); padding:.8rem 1.5rem; display:flex; align-items:center; justify-content:space-between; box-shadow:var(--shadow-sm); position:sticky; top:0; z-index:100; }
.admin-content { padding:1.5rem; }
.sidebar-logo { padding:1.25rem 1.1rem; border-bottom:1px solid rgba(255,255,255,.08); }
.sidebar-logo strong { color:#fff; font-size:.88rem; display:block; }
.sidebar-logo small { color:rgba(255,255,255,.4); font-size:.7rem; }
.sidebar-nav { flex:1; padding:.5rem 0; }
.sidebar-group { font-size:.62rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.3); padding:.85rem 1.1rem .25rem; margin-top:.15rem; }
.sidebar-link { display:flex; align-items:center; gap:.6rem; padding:.5rem 1.1rem; color:rgba(255,255,255,.65); font-size:.82rem; transition:var(--transition); border-right:3px solid transparent; }
.sidebar-link:hover,.sidebar-link.active { background:rgba(255,255,255,.09); color:#fff; border-right-color:var(--gold); }
.sidebar-link .icon { width:16px; flex-shrink:0; opacity:.7; }
.sidebar-link .badge-count { background:#c0392b; color:#fff; border-radius:20px; font-size:.62rem; padding:.1rem .4rem; margin-left:auto; }
.sidebar-footer { padding:1rem; border-top:1px solid rgba(255,255,255,.08); }

/* ── Dashboard widgets ── */
.dash-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:1.5rem; }
.dash-stat { background:#fff; border-radius:var(--radius); padding:1.25rem 1.5rem; border:1px solid var(--border); display:flex; align-items:flex-start; gap:1rem; border-left:4px solid var(--green-mid); }
.dash-stat-icon { width:42px; height:42px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.dash-stat-n { font-size:1.7rem; font-weight:800; color:var(--green-dark); line-height:1; font-family:Georgia,serif; }
.dash-stat-l { font-size:.72rem; color:var(--text-light); text-transform:uppercase; letter-spacing:.05em; }

/* ── Progress bar ── */
.progress { height:8px; background:var(--bg); border-radius:4px; overflow:hidden; }
.progress-bar { height:100%; background:var(--green-mid); border-radius:4px; transition:width .5s ease; }

/* ── Timeline ── */
.timeline { position:relative; padding-left:1.5rem; }
.timeline::before { content:''; position:absolute; left:.55rem; top:0; bottom:0; width:2px; background:var(--border); }
.timeline-item { position:relative; margin-bottom:1.5rem; }
.timeline-dot { position:absolute; left:-1.5rem; width:12px; height:12px; border-radius:50%; background:var(--green-mid); border:2px solid #fff; box-shadow:0 0 0 2px var(--green-mid); top:.25rem; }
.timeline-date { font-size:.72rem; color:var(--text-light); font-family:sans-serif; margin-bottom:.25rem; }
.timeline-body { background:#fff; border:1px solid var(--border); border-radius:8px; padding:.85rem 1rem; font-size:.85rem; }

/* ── CTA strip ── */
.cta-strip { background:var(--green-light); border-radius:12px; padding:1.75rem 2rem; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; border-left:5px solid var(--green-mid); }

/* ── Utility ── */
.flex { display:flex; } .flex-center { display:flex; align-items:center; } .flex-between { display:flex; align-items:center; justify-content:space-between; }
.gap-1 { gap:.5rem; } .gap-2 { gap:1rem; } .gap-3 { gap:1.5rem; }
.mt-1{margin-top:.5rem} .mt-2{margin-top:1rem} .mt-3{margin-top:1.5rem}
.mb-1{margin-bottom:.5rem} .mb-2{margin-bottom:1rem} .mb-3{margin-bottom:1.5rem}
.divider { border:none; border-top:1px solid var(--border); margin:1.5rem 0; }
.text-muted { color:var(--text-light); } .text-small { font-size:.8rem; }
img.lazy { opacity:0; transition:opacity .35s; } img.lazy.loaded { opacity:1; }

/* ── Footer ── */
#main-footer { background:var(--green-dark); color:rgba(255,255,255,.75); padding:3rem 0 1.5rem; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:2rem; margin-bottom:2rem; }
.footer-title { font-family:sans-serif; font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--gold); margin-bottom:.75rem; }
.footer-links { display:flex; flex-direction:column; gap:.35rem; }
.footer-links a { color:rgba(255,255,255,.6); font-size:.85rem; transition:var(--transition); }
.footer-links a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:1.25rem; display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.4); flex-wrap:wrap; gap:.5rem; }

/* ── Responsive ── */
@media(max-width:1024px) {
  .hero-stats { grid-template-columns:repeat(2,1fr); }
  .card-grid-4 { grid-template-columns:repeat(2,1fr); }
  .dash-stats { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  h1{font-size:1.75rem} h2{font-size:1.4rem}
  .nav-links { display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:#fff; border-top:1px solid var(--border); padding:1rem; gap:.25rem; box-shadow:var(--shadow); }
  .nav-links.open { display:flex; }
  .hamburger { display:flex; }
  .card-grid-3,.card-grid-2 { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .hero-stats { grid-template-columns:repeat(2,1fr); }
  .hero-btns { flex-direction:column; }
  .admin-sidebar { display:none; }
  .dash-stats { grid-template-columns:1fr 1fr; }
}
@media(max-width:480px) {
  .dash-stats { grid-template-columns:1fr; }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .tabs { flex-wrap:nowrap; overflow-x:auto; }
}
@media print {
  #main-nav,.announce-bar,#main-footer,.admin-sidebar,.admin-topbar { display:none !important; }
}

/* ── Captcha ── */
.captcha-group { margin-bottom:1rem; }
.captcha-box { background:linear-gradient(135deg,#e8f5ee,#d4edd9); border:2px solid #a7d5b5; border-radius:10px; padding:.8rem 1.25rem; text-align:center; font-size:1.4rem; font-weight:900; color:#0F2F24; font-family:Georgia,serif; margin-bottom:.45rem; letter-spacing:.04em; }

/* ── Nav logo improved ── */
.nav-logo { display:flex; align-items:center; text-decoration:none; gap:0; }

/* ── Timeline ── */
.timeline { position:relative; padding-left:2rem; }
.timeline::before { content:''; position:absolute; left:.65rem; top:.25rem; bottom:0; width:2px; background:var(--border); border-radius:2px; }
.timeline-item { position:relative; margin-bottom:1.5rem; }
.timeline-dot { position:absolute; left:-2rem; top:.3rem; width:13px; height:13px; border-radius:50%; background:var(--green-mid); border:2.5px solid #fff; box-shadow:0 0 0 2px var(--green-mid); }
.timeline-date { font-size:.72rem; color:var(--text-light); font-weight:700; text-transform:uppercase; letter-spacing:.06em; margin-bottom:.2rem; }
.timeline-body { background:#fff; border:1px solid var(--border); border-radius:8px; padding:.85rem 1rem; }
