Toggle menu
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Template:Main Page - styles/styles.css: Difference between revisions

Template page
No edit summary
No edit summary
Tag: Reverted
Line 1: Line 1:
/* Header styles */
/* =========================================
.main-header-logo {
  Main Page — TemplateStyles-safe CSS
    text-align: center;
  (kept single-source, no external splits)
    padding: 3rem 1rem 2rem 1rem;
  ========================================= */
    margin-bottom: 2rem;
    background-color: #ffffff;
}
 
.logo-container {
    text-align: center;
    margin-bottom: 1.5rem;
}
 
.logo-container img {
    max-width: 150px;
    height: auto;
    display: block;
    margin: 0 auto;
}
 
.header-text {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}
 
.site-title {
    font-family: 'Georgia', 'Times New Roman', serif;
    font-size: 5rem;
    font-weight: 400;
    letter-spacing: -0.02em;
    color: #2d5016;
    margin: 1rem 0 1.5rem 0;
    line-height: 1.1;
    position: relative;
}
 
.site-title::after {
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    background-color: #2d5016;
    margin: 1rem auto 0;
}
 
.main-tagline {
    font-size: 1.25rem;
    color: #2d5016;
    font-weight: 600;
    margin-bottom: 0.75rem;
    margin-top: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    max-width: 100%;
}
 
.sub-tagline {
    font-size: 1rem;
    color: #6c757d;
    line-height: 1.5;
    margin-bottom: 1rem;
}
 
.call-to-action {
    font-size: 0.9rem;
    color: #495057;
    font-style: italic;
    margin-bottom: 0;
}
 
/* Navigation grid */
.home-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    grid-gap: 0.625rem;
    margin-top: 2.4rem;
}


/* Navigation button cards */
/* ---------- Header ---------- */
.home-card--button {
.mw-parser-output .main-header-logo {
    overflow: hidden;
  text-align:center;
    padding: 0;
  padding:3rem 1rem 2rem 1rem;
    background: #242a31;
  margin-bottom:2rem;
    position: relative;
  background:#fff;
    border-radius: 8px;
    min-height: 120px;
}
}
 
.mw-parser-output .logo-container { text-align:center; margin-bottom:1.25rem; }
.home-card__background {
.mw-parser-output .logo-container img {
    position: absolute;
  max-width:150px; height:auto; display:block; margin:0 auto;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #242a31;
    border-radius: 8px;
}
}
.mw-parser-output .header-text { max-width:800px; margin:0 auto; text-align:center; }


.home-card__background img {
.mw-parser-output .site-title {
    width: 100%;
  font-family:Georgia,"Times New Roman",serif;
    height: 100%;
  font-size:4rem; /* slightly reduced for balance */
    object-fit: cover;
  font-weight:400;
    transition: transform 0.2s ease;
  letter-spacing:-0.02em;
  color:#2d5016;
  margin:0.75rem 0 1.25rem 0;
  line-height:1.1;
  position:relative;
}
}
 
.mw-parser-output .site-title::after {
.home-card--button:hover .home-card__background img {
  content:"";
    transform: scale(1.1);
  display:block;
  width:100%;
  height:2px;
  background:#2d5016;
  margin:1rem auto 0;
}
}


.home-card__foreground {
.mw-parser-output .main-tagline{
    position: absolute;
  font-size:1.1rem; color:#2d5016; font-weight:600;
    top: 0;
  margin:1rem 0 .5rem 0; text-transform:uppercase; letter-spacing:1px;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    padding: 0 15px;
    color: #fff;
    font-weight: 700;
    font-size: 1.1rem;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.8);
    background: linear-gradient(to right, rgba(0,0,0,0.7), transparent);
}
}
.mw-parser-output .sub-tagline{ font-size:1rem; color:#6c757d; line-height:1.55; margin-bottom:1rem; }
.mw-parser-output .call-to-action{ font-size:.95rem; color:#495057; font-style:italic; margin:0; }


/* Content cards */
/* Helper bits */
.home-card {
.mw-parser-output .main-intro{ max-width:980px; margin:0 auto 18px auto; font-size:1.05rem; line-height:1.55; }
    position: relative;
.mw-parser-output .lw-recent{ font-weight:700; }
    padding: 20px;
    background: #f8f9fa;
    border-radius: 8px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.04), 0 3px 6px rgba(0, 0, 0, 0.0575);
    font-size: 0.875rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: 1px solid #dee2e6;
    min-height: 120px;
}


.home-card--col2 {
/* ---------- Home grid ---------- */
    grid-column: span 2;
.mw-parser-output .home-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin-top:2rem;
}
}


.home-card:hover {
/* ---------- Nav "button" cards ---------- */
    transform: translateY(-2px);
.mw-parser-output .home-card--button{
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08), 0 6px 12px rgba(0, 0, 0, 0.115);
  overflow:hidden; padding:0; background:#242a31; position:relative;
  border-radius:10px; min-height:120px; border:1px solid #1f2329;
}
}
 
.mw-parser-output .home-card__background{
.home-card__label {
  position:absolute; top:0; right:0; bottom:0; left:0;
    color: #6c757d;
  background:#242a31; border-radius:10px;
    font-size: 0.8125rem;
    letter-spacing: 0.75px;
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: 0.5rem;
}
 
.home-card__header {
    margin: 0 0 1rem 0;
    font-size: 1.1rem;
    color: #2d5016;
    font-weight: 600;
}
 
.home-card__header a {
    color: inherit;
    text-decoration: none;
}
}
 
.mw-parser-output .home-card__background img{
.home-card__header a:hover {
  width:100%; height:100%; object-fit:cover; transition:transform .2s ease;
    color: #3d6b1f;
}
}
 
.mw-parser-output .home-card--button:hover .home-card__background img{ transform:scale(1.04); }
.home-card__body {
.mw-parser-output .home-card__foreground{
    color: #495057;
  position:absolute; top:0; right:0; bottom:0; left:0;
    line-height: 1.6;
  display:flex; align-items:center; padding:0 14px;
    margin-bottom: 1rem;
  color:#fff; font-weight:700; font-size:1.05rem;
  text-shadow:2px 2px 4px rgba(0,0,0,.6);
  background:linear-gradient(to right,rgba(0,0,0,.55),transparent);
}
}


.home-card__links {
/* ---------- Content cards ---------- */
    font-size: 0.8125rem;
.mw-parser-output .home-card{
    color: #6c757d;
  position:relative; padding:16px; background:#f8f9fa; border-radius:10px;
    border-top: 1px solid #dee2e6;
  border:1px solid #dee2e6; box-shadow:0 1px 2px rgba(0,0,0,.04);
    padding-top: 0.75rem;
  font-size:.95rem; transition:box-shadow .2s ease; min-height:120px;
}
}
.mw-parser-output .home-card:hover{ box-shadow:0 6px 14px rgba(0,0,0,.08); }
.mw-parser-output .home-card--col2{ grid-column:span 2; }


.home-card__links a {
.mw-parser-output .home-card__label{
    color: #2d5016;
  color:#6c757d; font-size:.82rem; letter-spacing:.75px; text-transform:uppercase;
    text-decoration: none;
  font-weight:500; margin:0 0 .4rem 0;
    font-weight: 500;
}
}
 
.mw-parser-output .home-card__header{
.home-card__links a:hover {
  margin:0 0 .8rem 0; font-size:1.1rem; color:#2d5016; font-weight:600;
    text-decoration: underline;
}
}
.mw-parser-output .home-card__header a{ color:inherit; text-decoration:none; }
.mw-parser-output .home-card__header a:hover{ color:#3d6b1f; }


/* Special styling for the research card with logo */
.mw-parser-output .home-card__body{ color:#495057; line-height:1.6; margin:0 0 .9rem 0; }
#home-card-research {
.mw-parser-output .home-card__links{
    background: linear-gradient(135deg, #2d5016 0%, #3d6b1f 100%);
  font-size:.82rem; color:#6c757d; border-top:1px solid #dee2e6; padding-top:.6rem;
    color: white;
    text-align: center;
    padding: 30px 20px;
}
}
.mw-parser-output .home-card__links a{ color:#2d5016; text-decoration:none; font-weight:500; }
.mw-parser-output .home-card__links a:hover{ text-decoration:underline; }


#home-card-research a {
/* ---------- Special: research card ---------- */
    color: white;
.mw-parser-output #home-card-research{
    text-decoration: none;
  background:linear-gradient(135deg,#2d5016 0%,#3d6b1f 100%);
    display: flex;
  color:#fff; text-align:center; padding:24px 18px; border-radius:10px;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}
}
 
.mw-parser-output #home-card-research a{
#home-card-research img {
  color:#fff; text-decoration:none; display:flex; flex-direction:column; align-items:center; gap:1rem;
    max-width: 120px;
    height: auto;
}
}
.mw-parser-output #home-card-research img{ max-width:120px; height:auto; }


/* Conservation Panel - Mobile-Optimized TemplateStyles */
/* =========================================================
  Conservation Panel — kept here (class names aligned)
  ========================================================= */


/* Panel shell */
/* Panel shell */
.mw-parser-output .lw-cons-panel {
.mw-parser-output .lw-cons-panel{
   background:#fff; border:1px solid #e6ebea; border-radius:14px;
   background:#fff; border:1px solid #e6ebea; border-radius:14px;
   padding:18px 18px 16px; margin:24px 0; box-shadow:0 1px 2px rgba(0,0,0,.03);
   padding:18px 18px 16px; margin:24px 0; box-shadow:0 1px 2px rgba(0,0,0,.03);
Line 226: Line 123:
}
}
.mw-parser-output .lw-cons-title{
.mw-parser-output .lw-cons-title{
   font-family:Georgia,"Times New Roman",serif; font-size:1.6rem; line-height:1.2; margin:4px 2px 14px;
   font-family:Georgia,"Times New Roman",serif;
  font-size:1.6rem; line-height:1.2; margin:4px 2px 14px;
}
}


/* KPIs - responsive 3-column to 1-column */
/* KPIs */
.mw-parser-output .lw-kpis{
.mw-parser-output .lw-kpis{ display:flex; gap:12px; flex-wrap:wrap; margin:4px 0 10px; }
  display:flex; gap:12px; flex-wrap:wrap; margin:4px 0 10px;
}
.mw-parser-output .lw-kpi{
.mw-parser-output .lw-kpi{
   flex:1 1 180px; background:#f8fbf7; border:1px solid #e6ebea;  
   flex:1 1 180px; background:#f8fbf7; border:1px solid #e6ebea;
   border-radius:10px; padding:12px 14px; min-width:0;
   border-radius:10px; padding:12px 14px; min-width:0;
}
}
.mw-parser-output .lw-kpi__num{
.mw-parser-output .lw-kpi__num{ font-size:1.6rem; font-weight:700; line-height:1; color:#111827; }
  font-size:1.6rem; font-weight:700; line-height:1;
.mw-parser-output .lw-kpi__label{ font-size:.9rem; color:#44613a; margin-top:6px; word-wrap:break-word; hyphens:auto; }
}
.mw-parser-output .lw-kpi__label{
  font-size:.9rem; color:#44613a; margin-top:6px;  
  word-wrap:break-word; hyphens:auto;
}


/* Status bar - maintains proportions, readable labels */
/* Proportional status bar (matches markup: .lw-seg + .lw-s-*) */
.mw-parser-output .lw-statusbar{
.mw-parser-output .lw-statusbar{
   display:flex; height:28px; border-radius:999px; overflow:hidden;  
   display:flex; height:14px; border-radius:999px; overflow:hidden;
   border:1px solid #e6ebea; background:#f4f7f4; margin:8px 0;
   border:1px solid #e6ebea; background:#f4f7f4; margin:8px 0;
}
}
.mw-parser-output .lw-statusbar .seg{
.mw-parser-output .lw-seg{ height:100%; min-width:2px; } /* ensures thin segments still visible */
  display:flex; align-items:center; justify-content:center;
.mw-parser-output .lw-s-stable{     background:#2ecc71; }
  font-size:.85rem; font-weight:600; color:#17320f;
.mw-parser-output .lw-s-vulnerable{ background:#f1c40f; }
  border-right:1px solid rgba(0,0,0,.06); min-width:24px;
.mw-parser-output .lw-s-endangered{ background:#f39c12; }
}
.mw-parser-output .lw-s-critical{   background:#e74c3c; }
.mw-parser-output .lw-statusbar .seg:last-child{border-right:none}
.mw-parser-output .lw-s-extinct{   background:#9ca3af; }
.mw-parser-output .seg--stable{background:#e9f7ee}
.mw-parser-output .seg--vulnerable{background:#fff6df}
.mw-parser-output .seg--endangered{background:#ffeade}
.mw-parser-output .seg--critical{background:#ffe3e3}


/* Legend - responsive wrapping with better touch targets */
/* Legend (matches markup: dot--stable, dot--vuln, dot--end, dot--crit, dot--ext) */
.mw-parser-output .lw-legend{
.mw-parser-output .lw-legend{
   display:flex; flex-wrap:wrap; gap:14px 18px; list-style:none;  
   display:flex; flex-wrap:wrap; gap:12px 16px; list-style:none; padding:8px 2px 2px; margin:0;
  padding:10px 4px 4px; margin:0;
}
}
.mw-parser-output .lw-legend li{
.mw-parser-output .lw-legend__item{
   display:flex; align-items:center; gap:8px; font-size:.92rem;  
   display:inline-flex; align-items:center; gap:6px; font-size:.92rem; color:#35522b; min-height:26px;
  color:#35522b; min-height:28px; /* Better touch target */
}
}
.mw-parser-output .dot{
.mw-parser-output .lw-legend .dot{
   width:10px; height:10px; border-radius:50%; display:inline-block;  
   width:10px; height:10px; border-radius:50%; display:inline-block; border:1px solid rgba(0,0,0,.08);
  border:1px solid rgba(0,0,0,.1); flex-shrink:0;
}
}
.mw-parser-output .dot--stable{background:#2ecc71}
.mw-parser-output .dot--stable{ background:#2ecc71; }
.mw-parser-output .dot--vulnerable{background:#f1c40f}
.mw-parser-output .dot--vuln{   background:#f1c40f; }
.mw-parser-output .dot--endangered{background:#f39c12}
.mw-parser-output .dot--end{   background:#f39c12; }
.mw-parser-output .dot--critical{background:#e74c3c}
.mw-parser-output .dot--crit{   background:#e74c3c; }
.mw-parser-output .dot--ext{    background:#9ca3af; }
.mw-parser-output .lw-legend .lbl{ color:#2e4631; }
.mw-parser-output .lw-legend .count{ margin-left:4px; color:#6b7280; font-variant-numeric:tabular-nums; }


/* Mobile breakpoints */
/* ---------- Responsive ---------- */
@media (max-width: 480px) {
@media (max-width: 720px){
  .mw-parser-output .lw-cons-panel {
   .mw-parser-output .site-title{ font-size:3.2rem; }
    padding:16px 14px; margin:16px 0; border-radius:12px;
   .mw-parser-output .home-grid{ grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
  }
   .mw-parser-output .home-card--col2{ grid-column:auto; }
 
  .mw-parser-output .lw-cons-title{
    font-size:1.4rem; margin:2px 0 12px;
  }
 
  /* Stack KPIs on very small screens */
  .mw-parser-output .lw-kpis{
    gap:8px; margin:2px 0 12px;
  }
  .mw-parser-output .lw-kpi{
    flex:1 1 100%; padding:10px 12px;
  }
  .mw-parser-output .lw-kpi__num{font-size:1.4rem}
   .mw-parser-output .lw-kpi__label{font-size:.85rem; margin-top:4px}
 
  /* Adjust status bar for small screens */
   .mw-parser-output .lw-statusbar{
    height:24px; margin:6px 0;
  }
  .mw-parser-output .lw-statusbar .seg{
    font-size:.8rem; min-width:20px;
  }
 
  /* Legend adjustments */
   .mw-parser-output .lw-legend{
    gap:10px 14px; padding:8px 2px 2px;
  }
  .mw-parser-output .lw-legend li{
    font-size:.88rem; gap:6px;
  }
}
}
@media (max-width: 480px){
  .mw-parser-output .site-title{ font-size:2.5rem; }
  .mw-parser-output .logo-container img{ max-width:120px; }
  .mw-parser-output .home-grid{ grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:8px; }
  .mw-parser-output .home-card{ padding:14px; }


@media (max-width: 360px) {
   .mw-parser-output .lw-cons-panel{ padding:16px 14px; margin:16px 0; border-radius:12px; }
   .mw-parser-output .lw-cons-panel {
   .mw-parser-output .lw-cons-title{ font-size:1.4rem; margin:2px 0 12px; }
    padding:14px 12px; margin:12px 0;
   .mw-parser-output .lw-kpis{ gap:8px; margin:2px 0 12px; }
   }
   .mw-parser-output .lw-kpi{ flex:1 1 100%; padding:10px 12px; }
    
   .mw-parser-output .lw-kpi__num{ font-size:1.4rem; }
  /* Force single column for KPIs */
   .mw-parser-output .lw-kpi__label{ font-size:.85rem; margin-top:4px; }
   .mw-parser-output .lw-kpi{
   .mw-parser-output .lw-statusbar{ height:12px; margin:6px 0; }
    flex-basis:100%; margin-bottom:0;
}
   }
@media (max-width: 360px){
    
   .mw-parser-output .lw-cons-panel{ padding:14px 12px; margin:12px 0; }
  /* Hide numbers in status bar if too cramped, keep colors visible */
   .mw-parser-output .lw-legend{ gap:8px 12px; }
   .mw-parser-output .lw-statusbar .seg{
   .mw-parser-output .lw-legend__item{ font-size:.86rem; }
    font-size:0; /* Hide text but keep color bars */
  }
 
   /* Compact legend */
   .mw-parser-output .lw-legend{
    gap:8px 12px;
  }
   .mw-parser-output .lw-legend li{
    font-size:.82rem;
  }
}
}

Revision as of 09:10, 26 August 2025

/* =========================================
   Main Page — TemplateStyles-safe CSS
   (kept single-source, no external splits)
   ========================================= */

/* ---------- Header ---------- */
.mw-parser-output .main-header-logo {
  text-align:center;
  padding:3rem 1rem 2rem 1rem;
  margin-bottom:2rem;
  background:#fff;
}
.mw-parser-output .logo-container { text-align:center; margin-bottom:1.25rem; }
.mw-parser-output .logo-container img {
  max-width:150px; height:auto; display:block; margin:0 auto;
}
.mw-parser-output .header-text { max-width:800px; margin:0 auto; text-align:center; }

.mw-parser-output .site-title {
  font-family:Georgia,"Times New Roman",serif;
  font-size:4rem; /* slightly reduced for balance */
  font-weight:400;
  letter-spacing:-0.02em;
  color:#2d5016;
  margin:0.75rem 0 1.25rem 0;
  line-height:1.1;
  position:relative;
}
.mw-parser-output .site-title::after {
  content:"";
  display:block;
  width:100%;
  height:2px;
  background:#2d5016;
  margin:1rem auto 0;
}

.mw-parser-output .main-tagline{
  font-size:1.1rem; color:#2d5016; font-weight:600;
  margin:1rem 0 .5rem 0; text-transform:uppercase; letter-spacing:1px;
}
.mw-parser-output .sub-tagline{ font-size:1rem; color:#6c757d; line-height:1.55; margin-bottom:1rem; }
.mw-parser-output .call-to-action{ font-size:.95rem; color:#495057; font-style:italic; margin:0; }

/* Helper bits */
.mw-parser-output .main-intro{ max-width:980px; margin:0 auto 18px auto; font-size:1.05rem; line-height:1.55; }
.mw-parser-output .lw-recent{ font-weight:700; }

/* ---------- Home grid ---------- */
.mw-parser-output .home-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin-top:2rem;
}

/* ---------- Nav "button" cards ---------- */
.mw-parser-output .home-card--button{
  overflow:hidden; padding:0; background:#242a31; position:relative;
  border-radius:10px; min-height:120px; border:1px solid #1f2329;
}
.mw-parser-output .home-card__background{
  position:absolute; top:0; right:0; bottom:0; left:0;
  background:#242a31; border-radius:10px;
}
.mw-parser-output .home-card__background img{
  width:100%; height:100%; object-fit:cover; transition:transform .2s ease;
}
.mw-parser-output .home-card--button:hover .home-card__background img{ transform:scale(1.04); }
.mw-parser-output .home-card__foreground{
  position:absolute; top:0; right:0; bottom:0; left:0;
  display:flex; align-items:center; padding:0 14px;
  color:#fff; font-weight:700; font-size:1.05rem;
  text-shadow:2px 2px 4px rgba(0,0,0,.6);
  background:linear-gradient(to right,rgba(0,0,0,.55),transparent);
}

/* ---------- Content cards ---------- */
.mw-parser-output .home-card{
  position:relative; padding:16px; background:#f8f9fa; border-radius:10px;
  border:1px solid #dee2e6; box-shadow:0 1px 2px rgba(0,0,0,.04);
  font-size:.95rem; transition:box-shadow .2s ease; min-height:120px;
}
.mw-parser-output .home-card:hover{ box-shadow:0 6px 14px rgba(0,0,0,.08); }
.mw-parser-output .home-card--col2{ grid-column:span 2; }

.mw-parser-output .home-card__label{
  color:#6c757d; font-size:.82rem; letter-spacing:.75px; text-transform:uppercase;
  font-weight:500; margin:0 0 .4rem 0;
}
.mw-parser-output .home-card__header{
  margin:0 0 .8rem 0; font-size:1.1rem; color:#2d5016; font-weight:600;
}
.mw-parser-output .home-card__header a{ color:inherit; text-decoration:none; }
.mw-parser-output .home-card__header a:hover{ color:#3d6b1f; }

.mw-parser-output .home-card__body{ color:#495057; line-height:1.6; margin:0 0 .9rem 0; }
.mw-parser-output .home-card__links{
  font-size:.82rem; color:#6c757d; border-top:1px solid #dee2e6; padding-top:.6rem;
}
.mw-parser-output .home-card__links a{ color:#2d5016; text-decoration:none; font-weight:500; }
.mw-parser-output .home-card__links a:hover{ text-decoration:underline; }

/* ---------- Special: research card ---------- */
.mw-parser-output #home-card-research{
  background:linear-gradient(135deg,#2d5016 0%,#3d6b1f 100%);
  color:#fff; text-align:center; padding:24px 18px; border-radius:10px;
}
.mw-parser-output #home-card-research a{
  color:#fff; text-decoration:none; display:flex; flex-direction:column; align-items:center; gap:1rem;
}
.mw-parser-output #home-card-research img{ max-width:120px; height:auto; }

/* =========================================================
   Conservation Panel — kept here (class names aligned)
   ========================================================= */

/* Panel shell */
.mw-parser-output .lw-cons-panel{
  background:#fff; border:1px solid #e6ebea; border-radius:14px;
  padding:18px 18px 16px; margin:24px 0; box-shadow:0 1px 2px rgba(0,0,0,.03);
  color:#26421a;
}
.mw-parser-output .lw-cons-title{
  font-family:Georgia,"Times New Roman",serif;
  font-size:1.6rem; line-height:1.2; margin:4px 2px 14px;
}

/* KPIs */
.mw-parser-output .lw-kpis{ display:flex; gap:12px; flex-wrap:wrap; margin:4px 0 10px; }
.mw-parser-output .lw-kpi{
  flex:1 1 180px; background:#f8fbf7; border:1px solid #e6ebea;
  border-radius:10px; padding:12px 14px; min-width:0;
}
.mw-parser-output .lw-kpi__num{ font-size:1.6rem; font-weight:700; line-height:1; color:#111827; }
.mw-parser-output .lw-kpi__label{ font-size:.9rem; color:#44613a; margin-top:6px; word-wrap:break-word; hyphens:auto; }

/* Proportional status bar (matches markup: .lw-seg + .lw-s-*) */
.mw-parser-output .lw-statusbar{
  display:flex; height:14px; border-radius:999px; overflow:hidden;
  border:1px solid #e6ebea; background:#f4f7f4; margin:8px 0;
}
.mw-parser-output .lw-seg{ height:100%; min-width:2px; } /* ensures thin segments still visible */
.mw-parser-output .lw-s-stable{     background:#2ecc71; }
.mw-parser-output .lw-s-vulnerable{ background:#f1c40f; }
.mw-parser-output .lw-s-endangered{ background:#f39c12; }
.mw-parser-output .lw-s-critical{   background:#e74c3c; }
.mw-parser-output .lw-s-extinct{    background:#9ca3af; }

/* Legend (matches markup: dot--stable, dot--vuln, dot--end, dot--crit, dot--ext) */
.mw-parser-output .lw-legend{
  display:flex; flex-wrap:wrap; gap:12px 16px; list-style:none; padding:8px 2px 2px; margin:0;
}
.mw-parser-output .lw-legend__item{
  display:inline-flex; align-items:center; gap:6px; font-size:.92rem; color:#35522b; min-height:26px;
}
.mw-parser-output .lw-legend .dot{
  width:10px; height:10px; border-radius:50%; display:inline-block; border:1px solid rgba(0,0,0,.08);
}
.mw-parser-output .dot--stable{ background:#2ecc71; }
.mw-parser-output .dot--vuln{   background:#f1c40f; }
.mw-parser-output .dot--end{    background:#f39c12; }
.mw-parser-output .dot--crit{   background:#e74c3c; }
.mw-parser-output .dot--ext{    background:#9ca3af; }
.mw-parser-output .lw-legend .lbl{ color:#2e4631; }
.mw-parser-output .lw-legend .count{ margin-left:4px; color:#6b7280; font-variant-numeric:tabular-nums; }

/* ---------- Responsive ---------- */
@media (max-width: 720px){
  .mw-parser-output .site-title{ font-size:3.2rem; }
  .mw-parser-output .home-grid{ grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
  .mw-parser-output .home-card--col2{ grid-column:auto; }
}
@media (max-width: 480px){
  .mw-parser-output .site-title{ font-size:2.5rem; }
  .mw-parser-output .logo-container img{ max-width:120px; }
  .mw-parser-output .home-grid{ grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:8px; }
  .mw-parser-output .home-card{ padding:14px; }

  .mw-parser-output .lw-cons-panel{ padding:16px 14px; margin:16px 0; border-radius:12px; }
  .mw-parser-output .lw-cons-title{ font-size:1.4rem; margin:2px 0 12px; }
  .mw-parser-output .lw-kpis{ gap:8px; margin:2px 0 12px; }
  .mw-parser-output .lw-kpi{ flex:1 1 100%; padding:10px 12px; }
  .mw-parser-output .lw-kpi__num{ font-size:1.4rem; }
  .mw-parser-output .lw-kpi__label{ font-size:.85rem; margin-top:4px; }
  .mw-parser-output .lw-statusbar{ height:12px; margin:6px 0; }
}
@media (max-width: 360px){
  .mw-parser-output .lw-cons-panel{ padding:14px 12px; margin:12px 0; }
  .mw-parser-output .lw-legend{ gap:8px 12px; }
  .mw-parser-output .lw-legend__item{ font-size:.86rem; }
}