/* SEO-Werkstatt – Design
   Leitidee: hell, luftig, freundlich. Warmes Papierweiß, Petrol als Arbeitsfarbe,
   Bricolage Grotesque für Überschriften, Source Sans 3 für Text, Plex Mono für Daten. */

:root {
  --papier: #F7F6F2;
  --flaeche: #FFFFFF;
  --tinte: #23282D;
  --gedimmt: #6F7780;
  --linie: #E4E1D8;
  --petrol: #1F7A68;
  --petrol-tief: #15584B;
  --petrol-hauch: #E7F2EE;
  --sand: #EFE9DC;
  --bernstein: #B7791F;
  --rot: #B3403A;
  --radius: 14px;
  --schatten: 0 6px 24px rgba(35, 40, 45, .05);
  --schrift: "Source Sans 3", system-ui, sans-serif;
  --schrift-kopf: "Bricolage Grotesque", var(--schrift);
  --schrift-mono: "IBM Plex Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html { font-size: 16px; }
body { margin: 0; font-family: var(--schrift); background: var(--papier); color: var(--tinte); line-height: 1.55; }
a { color: var(--petrol); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3 { font-family: var(--schrift-kopf); letter-spacing: -.01em; }
h1 { font-size: 1.7rem; margin: 0; }
h2 { font-size: 1.05rem; margin: 0 0 .7rem; }
h3 { font-size: .92rem; margin: 0 0 .5rem; }
small, .klein { font-size: .85rem; color: var(--gedimmt); }
.mono { font-family: var(--schrift-mono); font-size: .85em; }
.rechts { text-align: right; }
.leer { color: var(--gedimmt); font-style: italic; }
:focus-visible { outline: 2px solid var(--petrol); outline-offset: 2px; }

/* ---------- Rahmen & Seitenleiste ---------- */
.rahmen { display: flex; min-height: 100vh; }
.seitenleiste {
  width: 232px; flex-shrink: 0; padding: 22px 14px;
  background: var(--flaeche); border-right: 1px solid var(--linie);
  display: flex; flex-direction: column; gap: 18px;
  position: sticky; top: 0; height: 100vh;
}
.marke { font-family: var(--schrift-kopf); font-weight: 700; font-size: 1.15rem; }
.marke span { color: var(--petrol); }
.marke.gross { font-size: 1.5rem; }
.mandant-wahl label { display: block; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--gedimmt); margin-bottom: 4px; }
.mandant-wahl select, .mandant-fest {
  width: 100%; padding: 8px 10px; border: 1px solid var(--linie); border-radius: 10px;
  background: var(--papier); font: inherit; font-weight: 600;
}
.seitenleiste nav { display: flex; flex-direction: column; gap: 2px; }
.seitenleiste nav a {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 10px; color: var(--tinte); font-weight: 600;
}
.seitenleiste nav a:hover { background: var(--papier); text-decoration: none; }
.seitenleiste nav a.aktiv { background: var(--petrol-hauch); color: var(--petrol-tief); }
.seitenleiste .ico { width: 1.2em; text-align: center; opacity: .75; }
.leiste-fuss { margin-top: auto; border-top: 1px solid var(--linie); padding-top: 14px; display: flex; justify-content: space-between; align-items: center; }
.leiste-fuss .wer { font-weight: 600; font-size: .9rem; }
.leiste-fuss small { display: block; font-weight: 400; }
.logout { font-size: .85rem; }

.inhalt { flex: 1; padding: 28px 32px 60px; max-width: 1280px; }
.kopf { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 22px; }
.unter { margin: 4px 0 0; color: var(--gedimmt); }

/* ---------- Karten & Raster ---------- */
.karte { background: var(--flaeche); border: 1px solid var(--linie); border-radius: var(--radius); padding: 20px; box-shadow: var(--schatten); margin-bottom: 18px; }
.kachel-raster { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 18px; }
.kachel-raster .karte { margin-bottom: 0; }
.kachel-raster .breit { grid-column: 1 / -1; }
.zwei-spalten { display: grid; grid-template-columns: minmax(280px, 380px) 1fr; gap: 18px; align-items: start; }
.zwei-spalten .karte { margin-bottom: 0; }

/* ---------- Formulare ---------- */
label { display: block; font-weight: 600; font-size: .85rem; margin: 12px 0 4px; }
input, select, textarea {
  width: 100%; padding: 9px 12px; border: 1px solid var(--linie); border-radius: 10px;
  font: inherit; background: #fff; color: var(--tinte);
}
textarea { resize: vertical; line-height: 1.6; }
input:focus, select:focus, textarea:focus { border-color: var(--petrol); outline: none; box-shadow: 0 0 0 3px var(--petrol-hauch); }
.formular .zeile, .zeile { display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap; }
.waechst { flex: 1; min-width: 160px; }
form.inline { display: inline; }
details summary { cursor: pointer; font-weight: 600; margin: 12px 0 6px; }

.knopf {
  display: inline-block; background: var(--petrol); color: #fff; border: 0;
  border-radius: 10px; padding: 10px 18px; font: inherit; font-weight: 600;
  cursor: pointer; margin-top: 14px; transition: background .15s;
}
.knopf:hover { background: var(--petrol-tief); text-decoration: none; }
.knopf.zart { background: var(--petrol-hauch); color: var(--petrol-tief); }
.knopf.zart:hover { background: #d9eae4; }
.knopf.gefahr { background: #FBEAE8; color: var(--rot); }
.knopf.gefahr:hover { background: #f5d9d6; }
.knopf.voll { width: 100%; text-align: center; }
.klein-knopf { padding: 6px 12px; font-size: .85rem; margin-top: 6px; }
.link-knopf { background: none; border: 0; padding: 0; font: inherit; cursor: pointer; color: var(--petrol); }
.gefahr-text { color: var(--rot); }
button:disabled { opacity: .45; cursor: not-allowed; }

/* ---------- Hinweise & Badges ---------- */
.hinweis { border-radius: 10px; padding: 10px 14px; margin-bottom: 16px; border: 1px solid; }
.hinweis.ok, .hinweis.info { background: var(--petrol-hauch); border-color: #BBDCD2; color: var(--petrol-tief); }
.hinweis.fehler { background: #FBEAE8; border-color: #E5B7B2; color: #8C2F28; }

.badge { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: .78rem; font-weight: 600; background: var(--sand); }
.b-idee { background: var(--sand); }
.b-entwurf, .b-geplant { background: #EAF0F7; color: #33567E; }
.b-review, .b-in_arbeit { background: #FBF1DD; color: var(--bernstein); }
.b-freigegeben, .b-rankt { background: var(--petrol-hauch); color: var(--petrol-tief); }
.b-veroeffentlicht { background: var(--petrol); color: #fff; }
.prio-hoch { background: #FBEAE8; color: var(--rot); }
.prio-niedrig { color: var(--gedimmt); }

/* ---------- Tabellen ---------- */
.tabelle { width: 100%; border-collapse: collapse; font-size: .92rem; }
.tabelle th { text-align: left; font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; color: var(--gedimmt); padding: 8px 10px; border-bottom: 1px solid var(--linie); }
.tabelle td { padding: 10px; border-bottom: 1px solid var(--linie); vertical-align: top; }
.tabelle tr:last-child td { border-bottom: 0; }
.zeile-ok { opacity: .65; }
.zelle-url { max-width: 320px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.status-wahl { width: auto; padding: 4px 8px; font-size: .85rem; }
.mini-aktion summary { list-style: none; cursor: pointer; }
.mini-aktion form { margin: 6px 0; }

/* ---------- Dashboard ---------- */
.grosse-zahl { font-family: var(--schrift-kopf); font-size: 2.6rem; font-weight: 700; }
.score-ring {
  width: 110px; height: 110px; border-radius: 50%; margin: 6px 0 10px;
  display: grid; place-items: center;
  background: conic-gradient(var(--ringfarbe, var(--petrol)) calc(var(--p) * 1%), var(--linie) 0);
}
.score-ring span {
  width: 84px; height: 84px; border-radius: 50%; background: var(--flaeche);
  display: grid; place-items: center; font-family: var(--schrift-mono); font-weight: 600; font-size: 1.7rem;
}
.score-ring.gut { --ringfarbe: var(--petrol); }
.score-ring.mittel { --ringfarbe: var(--bernstein); }
.score-ring.kritisch { --ringfarbe: var(--rot); }
.score-pille { font-family: var(--schrift-mono); font-weight: 600; padding: 2px 10px; border-radius: 999px; }
.score-pille.gut { background: var(--petrol-hauch); color: var(--petrol-tief); }
.score-pille.mittel { background: #FBF1DD; color: var(--bernstein); }
.score-pille.kritisch { background: #FBEAE8; color: var(--rot); }

.pipeline { display: flex; gap: 6px; flex-wrap: wrap; }
.pipeline-stufe { flex: 1; min-width: 70px; background: var(--papier); border-radius: 10px; padding: 8px 6px; text-align: center; }
.pipeline-stufe strong { display: block; font-family: var(--schrift-kopf); font-size: 1.3rem; }
.pipeline-stufe span { font-size: .72rem; color: var(--gedimmt); }

.schlichte-liste { list-style: none; margin: 0; padding: 0; }
.schlichte-liste li { padding: 7px 0; border-bottom: 1px solid var(--linie); display: flex; justify-content: space-between; gap: 8px; align-items: baseline; }
.schlichte-liste li:last-child { border-bottom: 0; }
.schlichte-liste li.aktiv a { font-weight: 700; }
.schlichte-liste small { white-space: nowrap; }

/* ---------- Audit ---------- */
.fortschritt { height: 12px; background: var(--linie); border-radius: 999px; overflow: hidden; }
.fortschritt-balken { height: 100%; background: var(--petrol); border-radius: 999px; transition: width .4s; }
.problem-liste { list-style: none; padding: 0; margin: 0; columns: 2; gap: 24px; }
.problem-liste li { padding: 5px 0; break-inside: avoid; }
.problem-liste .anzahl { font-family: var(--schrift-mono); font-weight: 600; color: var(--bernstein); margin-right: 6px; }

/* ---------- Keywords ---------- */
.ideen-liste { list-style: none; padding: 0; margin: 12px 0 0; display: flex; flex-wrap: wrap; gap: 8px; }
.ideen-liste li button {
  border: 1px solid var(--linie); background: var(--papier); border-radius: 999px;
  padding: 5px 13px; font: inherit; font-size: .88rem; cursor: pointer;
}
.ideen-liste li button:hover { border-color: var(--petrol); color: var(--petrol-tief); background: var(--petrol-hauch); }

/* ---------- Kanban ---------- */
.kanban { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; align-items: start; }
.kanban-spalte { background: var(--papier); border: 1px solid var(--linie); border-radius: var(--radius); padding: 12px; }
.kanban-spalte h3 { display: flex; justify-content: space-between; }
.zaehler { color: var(--gedimmt); font-weight: 400; }
.kanban-karte {
  display: block; background: var(--flaeche); border: 1px solid var(--linie); border-radius: 10px;
  padding: 10px 12px; margin-bottom: 8px; color: var(--tinte); box-shadow: var(--schatten);
}
.kanban-karte:hover { border-color: var(--petrol); text-decoration: none; }
.kanban-karte strong { display: block; font-size: .92rem; line-height: 1.35; }
.kanban-karte small { display: block; margin-top: 6px; }
.kw-chip { display: inline-block; margin-top: 6px; font-size: .76rem; background: var(--petrol-hauch); color: var(--petrol-tief); border-radius: 999px; padding: 1px 8px; }
.kanban-leer { text-align: center; color: var(--linie); }

/* ---------- Editor ---------- */
.editor-raster { display: grid; grid-template-columns: 1fr 320px; gap: 18px; align-items: start; }
.editor-seite .karte { margin-bottom: 14px; }
#text-editor { font-size: 1rem; }

/* ---------- Bilder ---------- */
.upload-zone {
  border: 2px dashed var(--linie); border-radius: var(--radius); padding: 22px;
  text-align: center; color: var(--gedimmt); cursor: pointer; transition: all .15s;
}
.upload-zone.gross { padding: 36px; font-size: 1.05rem; }
.upload-zone:hover, .upload-zone.dragover { border-color: var(--petrol); background: var(--petrol-hauch); color: var(--petrol-tief); }
.bild-reihe { display: flex; gap: 12px; flex-wrap: wrap; }
.bild-reihe figure { margin: 0; width: 130px; }
.bild-reihe.kompakt figure { width: 84px; }
.bild-reihe img { width: 100%; height: 90px; object-fit: cover; border-radius: 10px; border: 1px solid var(--linie); }
.bild-reihe.kompakt img { height: 62px; }
.bild-reihe figcaption { font-size: .75rem; color: var(--gedimmt); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bild-reihe figcaption small { display: block; }
.bild-galerie { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 16px; }
.bild-karte { display: flex; gap: 14px; margin-bottom: 0; }
.bild-karte img { width: 110px; height: 110px; object-fit: cover; border-radius: 10px; border: 1px solid var(--linie); flex-shrink: 0; }
.bild-meta { flex: 1; min-width: 0; }
.bild-meta strong { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.alt-form input { margin-top: 8px; font-size: .88rem; }

/* ---------- Strategie ---------- */
.strategie-raster { display: grid; grid-template-columns: 280px 1fr; gap: 18px; align-items: start; }
.strategie-liste li { flex-direction: column; align-items: flex-start; gap: 2px; }

/* ---------- Mindmap ---------- */
.mindmap-karte { padding: 0; overflow: hidden; position: relative; }
.mindmap-werkzeuge { display: flex; gap: 8px; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--linie); flex-wrap: wrap; }
.mindmap-werkzeuge .knopf { margin-top: 0; }
.mm-status { font-size: .85rem; color: var(--gedimmt); }
.mindmap-buehne { overflow: auto; height: 600px; background:
  radial-gradient(circle, #E9E6DD 1px, transparent 1px) 0 0 / 26px 26px var(--papier); cursor: default; }
#mm-svg { width: 2000px; height: 1400px; display: block; }
.mm-knoten { cursor: grab; }
.mm-knoten:active { cursor: grabbing; }
.mm-knoten rect { rx: 12; stroke-width: 1.5; filter: drop-shadow(0 2px 4px rgba(35,40,45,.10)); }
.mm-knoten.gewaehlt rect { stroke: var(--tinte); stroke-width: 2.5; }
.mm-knoten text { font-family: var(--schrift); font-size: 14px; font-weight: 600; fill: var(--tinte); pointer-events: none; }
.mm-knoten .mm-link-icon { font-size: 11px; fill: var(--petrol-tief); pointer-events: all; cursor: pointer; }
.mm-kante { stroke: var(--linie); stroke-width: 2; fill: none; marker-end: url(#pfeil); }
.mm-kante.gewaehlt { stroke: var(--tinte); }
.f-petrol rect { fill: #DFF0EA; stroke: #8FC3B4; }
.f-sand rect { fill: #F3EDE0; stroke: #D5C9AC; }
.f-rose rect { fill: #F8E9E7; stroke: #DEB4AE; }
.f-himmel rect { fill: #E7EFF8; stroke: #A9C3DE; }
.f-salbei rect { fill: #EBF1E4; stroke: #B7CBA3; }
.mm-panel {
  position: absolute; right: 16px; top: 66px; width: 260px;
  background: var(--flaeche); border: 1px solid var(--linie); border-radius: var(--radius);
  padding: 16px; box-shadow: var(--schatten);
}
.mm-farben { display: flex; gap: 8px; margin-top: 4px; }
.mm-farben button { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--linie); cursor: pointer; padding: 0; }
.mm-farben [data-farbe="petrol"] { background: #DFF0EA; }
.mm-farben [data-farbe="sand"] { background: #F3EDE0; }
.mm-farben [data-farbe="rose"] { background: #F8E9E7; }
.mm-farben [data-farbe="himmel"] { background: #E7EFF8; }
.mm-farben [data-farbe="salbei"] { background: #EBF1E4; }

/* ---------- Login ---------- */
.login-body { display: grid; place-items: center; min-height: 100vh; padding: 20px; }
.login-karte { background: var(--flaeche); border: 1px solid var(--linie); border-radius: 18px; padding: 36px; width: 100%; max-width: 380px; box-shadow: var(--schatten); }
.login-sub { color: var(--gedimmt); margin-top: 4px; }

/* ---------- Responsiv ---------- */
@media (max-width: 1020px) {
  .kanban { grid-template-columns: repeat(2, 1fr); }
  .editor-raster, .zwei-spalten, .strategie-raster { grid-template-columns: 1fr; }
}
@media (max-width: 780px) {
  .rahmen { flex-direction: column; }
  .seitenleiste { width: 100%; height: auto; position: static; flex-direction: row; flex-wrap: wrap; align-items: center; }
  .seitenleiste nav { flex-direction: row; flex-wrap: wrap; }
  .leiste-fuss { margin: 0 0 0 auto; border: 0; padding: 0; gap: 12px; }
  .inhalt { padding: 18px 14px 50px; }
  .kanban { grid-template-columns: 1fr; }
  .problem-liste { columns: 1; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}

/* ---------- Audit 1.1: Keyword-Checks & Empfehlungen ---------- */
.kw-checks { display: block; margin-top: 2px; font-family: var(--schrift-mono); font-size: .72rem; color: var(--gedimmt); }
.empfehlungs-liste { margin: 6px 0 0; padding-left: 18px; }
.empfehlungs-liste li { margin-bottom: 4px; }

/* ---------- Top-10-Analyse (1.2.0) ---------- */
.benchmark-raster { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.benchmark { background: var(--papier); border: 1px solid var(--linie); border-radius: var(--radius); padding: 16px; }
.benchmark .vergleich { border-top: 1px dashed var(--linie); padding-top: 8px; margin-top: 8px; }
.semantik-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.sem-chip { background: var(--petrol-hauch); color: var(--petrol-tief); border-radius: 999px; padding: 4px 13px; font-size: .9rem; font-weight: 600; }
.sem-chip small { font-family: var(--schrift-mono); font-weight: 400; margin-left: 6px; opacity: .7; }
.sem-chip.fehlt { background: #FBEAE8; color: var(--rot); }
.sem-chip.fehlt::before { content: "+ "; }
@media (max-width: 780px) { .benchmark-raster { grid-template-columns: 1fr; } }
