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
Tag: Reverted
Undo revision 342 by Eloise Zomia (talk)
Tag: Undo
 
Line 1: Line 1:
/* =========================================
/* Header styles */
  Main Page — TemplateStyles-safe CSS
.main-header-logo {
  (kept single-source, no external splits)
    text-align: center;
  ========================================= */
    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;
}


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


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


.mw-parser-output .main-tagline{
.home-card__foreground {
  font-size:1.1rem; color:#2d5016; font-weight:600;
    position: absolute;
  margin:1rem 0 .5rem 0; text-transform:uppercase; letter-spacing:1px;
    top: 0;
    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; }


/* Helper bits */
/* Content cards */
.mw-parser-output .main-intro{ max-width:980px; margin:0 auto 18px auto; font-size:1.05rem; line-height:1.55; }
.home-card {
.mw-parser-output .lw-recent{ font-weight:700; }
    position: relative;
    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 grid ---------- */
.home-card--col2 {
.mw-parser-output .home-grid{
    grid-column: span 2;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin-top:2rem;
}
}


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


/* ---------- Content cards ---------- */
.home-card__links {
.mw-parser-output .home-card{
    font-size: 0.8125rem;
  position:relative; padding:16px; background:#f8f9fa; border-radius:10px;
    color: #6c757d;
  border:1px solid #dee2e6; box-shadow:0 1px 2px rgba(0,0,0,.04);
    border-top: 1px solid #dee2e6;
  font-size:.95rem; transition:box-shadow .2s ease; min-height:120px;
    padding-top: 0.75rem;
}
}
.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{
.home-card__links a {
  color:#6c757d; font-size:.82rem; letter-spacing:.75px; text-transform:uppercase;
    color: #2d5016;
  font-weight:500; margin:0 0 .4rem 0;
    text-decoration: none;
    font-weight: 500;
}
}
.mw-parser-output .home-card__header{
 
  margin:0 0 .8rem 0; font-size:1.1rem; color:#2d5016; font-weight:600;
.home-card__links a:hover {
    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; }


.mw-parser-output .home-card__body{ color:#495057; line-height:1.6; margin:0 0 .9rem 0; }
/* Special styling for the research card with logo */
.mw-parser-output .home-card__links{
#home-card-research {
  font-size:.82rem; color:#6c757d; border-top:1px solid #dee2e6; padding-top:.6rem;
    background: linear-gradient(135deg, #2d5016 0%, #3d6b1f 100%);
    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; }


/* ---------- Special: research card ---------- */
#home-card-research a {
.mw-parser-output #home-card-research{
    color: white;
  background:linear-gradient(135deg,#2d5016 0%,#3d6b1f 100%);
    text-decoration: none;
  color:#fff; text-align:center; padding:24px 18px; border-radius:10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}
}
.mw-parser-output #home-card-research a{
 
  color:#fff; text-decoration:none; display:flex; flex-direction:column; align-items:center; gap:1rem;
#home-card-research img {
    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 123: Line 226:
}
}
.mw-parser-output .lw-cons-title{
.mw-parser-output .lw-cons-title{
   font-family:Georgia,"Times New Roman",serif;
   font-family:Georgia,"Times New Roman",serif; font-size:1.6rem; line-height:1.2; margin:4px 2px 14px;
  font-size:1.6rem; line-height:1.2; margin:4px 2px 14px;
}
}


/* KPIs */
/* KPIs - responsive 3-column to 1-column */
.mw-parser-output .lw-kpis{ display:flex; gap:12px; flex-wrap:wrap; margin:4px 0 10px; }
.mw-parser-output .lw-kpis{
  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{ font-size:1.6rem; font-weight:700; line-height:1; color:#111827; }
.mw-parser-output .lw-kpi__num{
.mw-parser-output .lw-kpi__label{ font-size:.9rem; color:#44613a; margin-top:6px; word-wrap:break-word; hyphens:auto; }
  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;
}


/* Proportional status bar (matches markup: .lw-seg + .lw-s-*) */
/* Status bar - maintains proportions, readable labels */
.mw-parser-output .lw-statusbar{
.mw-parser-output .lw-statusbar{
   display:flex; height:14px; border-radius:999px; overflow:hidden;
   display:flex; height:28px; 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-seg{ height:100%; min-width:2px; } /* ensures thin segments still visible */
.mw-parser-output .lw-statusbar .seg{
.mw-parser-output .lw-s-stable{     background:#2ecc71; }
  display:flex; align-items:center; justify-content:center;
.mw-parser-output .lw-s-vulnerable{ background:#f1c40f; }
  font-size:.85rem; font-weight:600; color:#17320f;
.mw-parser-output .lw-s-endangered{ background:#f39c12; }
  border-right:1px solid rgba(0,0,0,.06); min-width:24px;
.mw-parser-output .lw-s-critical{   background:#e74c3c; }
}
.mw-parser-output .lw-s-extinct{   background:#9ca3af; }
.mw-parser-output .lw-statusbar .seg:last-child{border-right:none}
.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 (matches markup: dot--stable, dot--vuln, dot--end, dot--crit, dot--ext) */
/* Legend - responsive wrapping with better touch targets */
.mw-parser-output .lw-legend{
.mw-parser-output .lw-legend{
   display:flex; flex-wrap:wrap; gap:12px 16px; list-style:none; padding:8px 2px 2px; margin:0;
   display:flex; flex-wrap:wrap; gap:14px 18px; list-style:none;  
  padding:10px 4px 4px; margin:0;
}
}
.mw-parser-output .lw-legend__item{
.mw-parser-output .lw-legend li{
   display:inline-flex; align-items:center; gap:6px; font-size:.92rem; color:#35522b; min-height:26px;
   display:flex; align-items:center; gap:8px; font-size:.92rem;  
  color:#35522b; min-height:28px; /* Better touch target */
}
}
.mw-parser-output .lw-legend .dot{
.mw-parser-output .dot{
   width:10px; height:10px; border-radius:50%; display:inline-block; border:1px solid rgba(0,0,0,.08);
   width:10px; height:10px; border-radius:50%; display:inline-block;  
  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--vuln{   background:#f1c40f; }
.mw-parser-output .dot--vulnerable{background:#f1c40f}
.mw-parser-output .dot--end{   background:#f39c12; }
.mw-parser-output .dot--endangered{background:#f39c12}
.mw-parser-output .dot--crit{   background:#e74c3c; }
.mw-parser-output .dot--critical{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 ---------- */
/* Mobile breakpoints */
@media (max-width: 720px){
@media (max-width: 480px) {
   .mw-parser-output .site-title{ font-size:3.2rem; }
  .mw-parser-output .lw-cons-panel {
   .mw-parser-output .home-grid{ grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
    padding:16px 14px; margin:16px 0; border-radius:12px;
   .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; }


   .mw-parser-output .lw-cons-panel{ padding:16px 14px; margin:16px 0; border-radius:12px; }
@media (max-width: 360px) {
   .mw-parser-output .lw-cons-title{ font-size:1.4rem; margin:2px 0 12px; }
   .mw-parser-output .lw-cons-panel {
   .mw-parser-output .lw-kpis{ gap:8px; margin:2px 0 12px; }
    padding:14px 12px; margin:12px 0;
   .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; }
   /* Force single column for KPIs */
   .mw-parser-output .lw-statusbar{ height:12px; margin:6px 0; }
   .mw-parser-output .lw-kpi{
}
    flex-basis:100%; margin-bottom: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; }
  /* Hide numbers in status bar if too cramped, keep colors visible */
   .mw-parser-output .lw-legend__item{ font-size:.86rem; }
   .mw-parser-output .lw-statusbar .seg{
    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;
  }
}
}

Latest revision as of 09:11, 26 August 2025

/* Header styles */
.main-header-logo {
    text-align: center;
    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 */
.home-card--button {
    overflow: hidden;
    padding: 0;
    background: #242a31;
    position: relative;
    border-radius: 8px;
    min-height: 120px;
}

.home-card__background {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #242a31;
    border-radius: 8px;
}

.home-card__background img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.2s ease;
}

.home-card--button:hover .home-card__background img {
    transform: scale(1.1);
}

.home-card__foreground {
    position: absolute;
    top: 0;
    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);
}

/* Content cards */
.home-card {
    position: relative;
    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 {
    grid-column: span 2;
}

.home-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08), 0 6px 12px rgba(0, 0, 0, 0.115);
}

.home-card__label {
    color: #6c757d;
    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;
}

.home-card__header a:hover {
    color: #3d6b1f;
}

.home-card__body {
    color: #495057;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.home-card__links {
    font-size: 0.8125rem;
    color: #6c757d;
    border-top: 1px solid #dee2e6;
    padding-top: 0.75rem;
}

.home-card__links a {
    color: #2d5016;
    text-decoration: none;
    font-weight: 500;
}

.home-card__links a:hover {
    text-decoration: underline;
}

/* Special styling for the research card with logo */
#home-card-research {
    background: linear-gradient(135deg, #2d5016 0%, #3d6b1f 100%);
    color: white;
    text-align: center;
    padding: 30px 20px;
}

#home-card-research a {
    color: white;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#home-card-research img {
    max-width: 120px;
    height: auto;
}

/* Conservation Panel - Mobile-Optimized TemplateStyles */

/* 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 - responsive 3-column to 1-column */
.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;
}
.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 */
.mw-parser-output .lw-statusbar{
  display:flex; height:28px; border-radius:999px; overflow:hidden; 
  border:1px solid #e6ebea; background:#f4f7f4; margin:8px 0;
}
.mw-parser-output .lw-statusbar .seg{
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; font-weight:600; color:#17320f; 
  border-right:1px solid rgba(0,0,0,.06); min-width:24px;
}
.mw-parser-output .lw-statusbar .seg:last-child{border-right:none}
.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 */
.mw-parser-output .lw-legend{
  display:flex; flex-wrap:wrap; gap:14px 18px; list-style:none; 
  padding:10px 4px 4px; margin:0;
}
.mw-parser-output .lw-legend li{
  display:flex; align-items:center; gap:8px; font-size:.92rem; 
  color:#35522b; min-height:28px; /* Better touch target */
}
.mw-parser-output .dot{
  width:10px; height:10px; border-radius:50%; display:inline-block; 
  border:1px solid rgba(0,0,0,.1); flex-shrink:0;
}
.mw-parser-output .dot--stable{background:#2ecc71}
.mw-parser-output .dot--vulnerable{background:#f1c40f}
.mw-parser-output .dot--endangered{background:#f39c12}
.mw-parser-output .dot--critical{background:#e74c3c}

/* Mobile breakpoints */
@media (max-width: 480px) {
  .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;
  }
  
  /* 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: 360px) {
  .mw-parser-output .lw-cons-panel {
    padding:14px 12px; margin:12px 0;
  }
  
  /* Force single column for KPIs */
  .mw-parser-output .lw-kpi{
    flex-basis:100%; margin-bottom:0;
  }
  
  /* Hide numbers in status bar if too cramped, keep colors visible */
  .mw-parser-output .lw-statusbar .seg{
    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;
  }
}