/* flexitarier.org — content + light tools */

.fx-hero-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1rem; margin: 1.5rem 0; }
.fx-cat-card { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1.4rem; text-decoration: none; color: inherit;
  transition: box-shadow .15s, border-color .15s; display: block; }
.fx-cat-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,.08); border-color: var(--accent); text-decoration: none; }
.fx-cat-card-icon { font-size: 2rem; margin-bottom: .3rem; }
.fx-cat-card h3 { margin: 0 0 .2rem; color: var(--accent); font-size: 1.05rem; }
.fx-cat-card p  { color: #555; font-size: .85rem; margin: 0; line-height: 1.45; }
.fx-cat-card .ct { color: #888; font-size: .8rem; margin-top: .3rem; }

.fx-articles { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem; margin: 1rem 0; }
.fx-art-card { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1.15rem 1.3rem; text-decoration: none; color: inherit;
  transition: box-shadow .15s, border-color .15s; }
.fx-art-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,.08); border-color: var(--accent); }
.fx-art-card .cat { color: #888; font-size: .75rem; text-transform: uppercase; letter-spacing: .04em; }
.fx-art-card h3 { margin: .3rem 0 .35rem; color: var(--accent); font-size: 1.05rem; line-height: 1.3; }
.fx-art-card p { color: #555; font-size: .9rem; margin: 0; line-height: 1.5; }

.fx-article { max-width: 720px; margin: 0 auto; }
.fx-article-cat { color: var(--accent); font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; margin-bottom: .3rem; }
.fx-article h1 { margin: .2rem 0 1rem; font-size: 1.9rem; line-height: 1.25; }
.fx-article .meta { color: #999; font-size: .85rem; margin-bottom: 2rem; }
.fx-article h2 { margin: 2rem 0 .8rem; font-size: 1.3rem; color: var(--accent); }
.fx-article p, .fx-article li { line-height: 1.65; color: #333; }
.fx-article p { margin: .8rem 0; }
.fx-article ul, .fx-article ol { padding-left: 1.5em; }
.fx-article li { margin: .35rem 0; }

.fx-article-related { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1.2rem 1.4rem; margin-top: 2rem; }
.fx-article-related h3 { margin-top: 0; }

/* Tool: Flexitarier-Score */
.fx-tool { background: linear-gradient(135deg, #f0fdf4, #fff); border: 2px solid #86efac;
  border-radius: 12px; padding: 1.5rem; margin: 0 0 2rem; }
.fx-tool h2 { margin-top: 0; }
.fx-slider-row { margin: 1rem 0; }
.fx-slider-row label { display: flex; justify-content: space-between; font-size: .9rem; color: #555; }
.fx-slider-row input[type=range] { width: 100%; }
.fx-result { background: #fff; border: 2px solid #2e9e4d; border-radius: 12px;
  padding: 1.5rem; margin: 1.2rem 0; text-align: center; }
.fx-result .badge { font-size: 1.4rem; font-weight: 800; color: #2e9e4d; }
.fx-result .lbl { color: #666; font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; margin-bottom: .5rem; }
.fx-result.r-karnivor   { border-color: #d4504e; } .fx-result.r-karnivor .badge   { color: #d4504e; }
.fx-result.r-reduzierer { border-color: #b07b00; } .fx-result.r-reduzierer .badge { color: #b07b00; }
.fx-result.r-flexi      { border-color: #2e9e4d; } .fx-result.r-flexi .badge      { color: #2e9e4d; }
.fx-result.r-wochenend  { border-color: #2e9e4d; } .fx-result.r-wochenend .badge  { color: #2e9e4d; }
.fx-result.r-vegetarier { border-color: #1a56d6; } .fx-result.r-vegetarier .badge { color: #1a56d6; }
.fx-result.r-vegan      { border-color: #6a4f1f; } .fx-result.r-vegan .badge      { color: #6a4f1f; }

/* Tool: Klima-Sparrechner */
.fx-co2-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .8rem; margin: 1rem 0; }
.fx-co2-card { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: .8rem 1rem; text-align: center; }
.fx-co2-card .icon { font-size: 1.8rem; }
.fx-co2-card .num { font-weight: 700; font-size: 1.2rem; color: var(--accent); font-family: monospace; }
.fx-co2-card .lbl { color: #555; font-size: .8rem; margin-top: .25rem; }

.fx-co2-savings { background: linear-gradient(135deg, #e8f0fe, #fff);
  border: 2px solid #2e9e4d; border-radius: 12px; padding: 2rem; margin: 1rem 0; text-align: center; }
.fx-co2-savings .num { font-size: 3.5rem; font-weight: 800; color: #2e9e4d;
  font-family: monospace; font-variant-numeric: tabular-nums; line-height: 1; }
.fx-co2-savings .lbl { color: #555; font-size: .9rem; margin-top: .5rem; }

/* Tool: Wochenplan */
.fx-week { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .8rem; margin: 1rem 0; }
.fx-day-card { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1rem 1.2rem; }
.fx-day-card .day { color: var(--accent); font-weight: 700; font-size: 1.05rem; }
.fx-day-card .meal { margin-top: .8rem; }
.fx-day-card .meal-label { color: #888; font-size: .75rem; text-transform: uppercase; letter-spacing: .04em; }
.fx-day-card .meal-name { color: #333; font-weight: 600; font-size: .95rem; margin-top: .1rem; }
.fx-day-card .meal-blurb { color: #666; font-size: .82rem; margin-top: .15rem; line-height: 1.4; }
