Pollenflug Vorhersage von DWD auslesen

Hallo,

ich möchte gerne die Seite

https://opendata.dwd.de/climate_environment/health/alerts/s31fg.json

auslesen und die Pollenflug Vorhersagen in Variablen speichern. Leider kenne ich mich viel zu wenig aus und versuche per copy & paste mein Ziel zu erreichen. Bin aber noch weit weg davon :frowning:

Mit diesem Skript bekomme ich die Daten von ganz Deutschland

<?
$url = "https://opendata.dwd.de/climate_environment/health/alerts/s31fg.json";


$region_name =  ("Baden-Württemberg");
$partregion_name = ("Hohenlohe/mittlerer Neckar/Oberschwaben");
$region_id = ("110");

$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt($ch, CURLOPT_URL, $url); 
$output = curl_exec($ch);
curl_close($ch);  
$content = json_decode($output, true);


echo $output;

?>

Frage 1: wie kann ich die Daten eingerenzen für meine Region Baden-Württemberg Hohenlohe/mittlerer Neckar/Oberschwaben?

Frage 2: wir bekomme ich die Werte in die einzelnen Variablen?

Über einen Schubs in die richtige Richtung würde ich mich sehr freuen.

Gruß
AKL

Hi AKL,

ich bin auch gerade dabei mir hinsichtlich Pollenflug etwas zu basteln. Ich wollte dafür das HTML von hier parsen.
Aber es gleich als Json zu bekommen ist natürlich erheblich einfacher;-) Ich schaue es mir mal an!

Gruß Pitti

falls du es noch nicht vorliegen hast … ich habe gerade mal gesucht, die API ist hier beschrieben: https://opendata.dwd.de/climate_environment/health/alerts/Beschreibung_pollen_s31fg.pdf

würd mich auch interessieren.

gruß
demel

@demel: Die Beschreibung habe ich gesehen. Mangels php Kenntnis hilft mir das aber leider nicht weiter :confused:

@Pitti: freue mich schon auf dein Ergebnis :slight_smile:

@demel: Danke für den Hinweis, hatte ich mir auch schon runtergeladen!.

Eigentlich will ich mich mit dem Thema nicht unter Druck setzen lassen, aber ich zeige schon mal den derzeitigen Arbeitsstand (Design).

Ist wie gesagt ein reiner Arbeitsstand und kann noch nicht versprechen wann es fertig ist!

Ciao Pitti

… vielleicht ist das nützlich.
@pitti: das sieht gut aus!

$partregion_id = "123"; // ermitteln aus https://opendata.dwd.de/climate_environment/health/alerts/s31fg.json

$ObjektID = @IPS_GetObjectIDByName("DWD Pollenflug JSON", $_IPS['SELF']); // meine relevanten Werte abspeichern

if ($ObjektID === false) {
    echo "Objekt nicht gefunden!";
    
    // Anlegen einer String-Variablen mit dem Namen "DWD Pollenflug JSON"
    
    $ObjektID = IPS_CreateVariable(3);
    IPS_SetName($ObjektID, "DWD Pollenflug JSON"); // Variable benennen
    IPS_SetParent($ObjektID, $_IPS['SELF']); // Variable einsortieren
    echo "Eine Varibale mit der ID " . $ObjektID . " wurde erstellt";
} else {
    //echo "
Eine Varibale  mit der ID " . $ObjektID . " ist bereits vorhanden
";
}

// Datenquelle
$json = file_get_contents("https://opendata.dwd.de/climate_environment/health/alerts/s31fg.json");

// falls die Daten nicht geladen werden koennen
if (empty($json) || $json == "") {
    IPS_LogMessage(IPS_GetName($_IPS['SELF']), "can't get url content");
    return;
}

$daten = json_decode($json, TRUE);

if (array_key_exists('last_update', $daten)) {
    if ($_IPS['SENDER'] == 'Execute') {
        Echo "Zeitstempel der DWD Info: " . $daten['last_update'] . "
";
        $last_update = $daten['last_update'];
    }
} else {
    if ($_IPS['SENDER'] == 'Execute') {
        echo "keine Zeitangabe  vorhanden! 
";
    }
}

if (array_key_exists('next_update', $daten)) {
    if ($_IPS['SENDER'] == 'Execute') {
        Echo "Zeitstempel der nächsten DWD Info: " . $daten['next_update'] . "
";
        $next_update = $daten['last_update'];
    }
} else {
    if ($_IPS['SENDER'] == 'Execute') {
        echo "keine Zeitangabe  vorhanden! 
";
    }
}


// Tabelle für Legende erstellen
$legend = $daten['legend'];
asort($legend);
$legendtbl = array();
foreach ($legend as $lkey => $value) {
    $len = strlen($lkey);
    if (strlen($lkey) < 4) {
        $legendtbl[$value] = $legend[$lkey . '_desc'];
    }
}
$legendtbl['-1'] = "Fehlender Wert";

// Daten meiner Region aus den DWD Daten filtern
foreach ($daten['content'] as $content) {
    if ($content['partregion_id'] == $partregion_id) {
        if ($_IPS['SENDER'] == 'Execute') {
            echo "
Partregion Name: " . $content['partregion_name'] . "

";
        }
        $pollen = $content['Pollen'];
        
        // Neues Array mit meinen Pollenflugdaten aufbauen	
        $pollenflug['last_update'] = $daten['last_update'];
		
        foreach ($pollen as $blueher => $value) {
            $pollenflug[$blueher] = array(
                'today' => $legendtbl[$value['today']],
                'tomorrow' => $legendtbl[$value['tomorrow']],
                'dayafter_to' => $legendtbl[$value['dayafter_to']]
            );
            if ($_IPS['SENDER'] == 'Execute') {
                echo $blueher . ": heute = " . $legendtbl[$value['today']] . "
";
                echo $blueher . ": morgen = " . $legendtbl[$value['tomorrow']] . "
";
                echo $blueher . ": übermorgen = " . $legendtbl[$value['dayafter_to']] . "
";
            }
        }
    }
}

SetValue($ObjektID, json_encode($pollenflug)); // Meine Pollenflugdaten als Array abspeichern 

das sieht ja schon toll aus. Schon mal vielen Dank an euch.

Kurzes Zwischenupdate - Design steht :wink:

Jetzt geht es langsam an die Daten, bin dran!

Gruß Heiko

Vom Feinsten, sieht klasse aus.

Hi, sieht klasse aus!

Bin da auch scharf drauf!

Hardlog

Allein anhand der einen Grafik geht der WAF nach oben. Unglaublich. :smiley:

Grüße
galleto

Hi zusammen,

dank des regnerischen Samstags konnte ich mich nun auch der Funktionalität widmen :slight_smile:

Ich habe noch nicht sehr viel getestet, aber ich glaube es tut schon was brauchbares :smiley:

Schaut mal ob ihr damit zurecht kommt und ob es stabil läuft - bin gespannt!


<?
################################################################################
# Scriptbezeichnung: Online.Pollination.ips.php
# Version:	20180825
# Author:	Heiko Wilknitz (@pitti)
#
# Abruf des Pollenflug-Gefahrenindex von DWD (opendata.dwd.de).
#
# ------------------------------- Changelog  -----------------------------------
#
# 2018-08-25 -- Initalversion
#
# ------------------------------- Installation ---------------------------------
#
# Dieses Skript richtet automatisch alle nötigen Objekte bei manueller
# Ausführung auf der Console ein.
# Dannach muss man die entsprechenden Variablen den eigenen Wünschen
# entsprechend in das Webfront einhängen.
# HINWEIS bzw. TIPP:
#  - Bundesland und Region über Dummy Modul (Gebiet) gruppieren.
#  - Jahreskalender in ein Popup Modul hängen sonst IMG-Html anpassen!
#
# ------------------------------- Konfiguration --------------------------------
#
# JSON Daten URL 
$dataURL = 'https://opendata.dwd.de/climate_environment/health/alerts/s31fg.json';
#
# Jahreskalender URL
$calURL = 'https://www.wetterdienst.de/imgs/pollenflugkalendar.jpg';
#
# Anzahl der darzustellenden Tage
# Das Json liefert Heute, Morgen und Übermorgen, aber Letzeres hat fast immer
# keine gültigen bzw. verwertbaren Informationen
$numDays = 2;
#
################################################################################

# Ablaufsteuerung 
switch ($_IPS['SENDER']) {
	// INSTALL & INITIALIZE 
	case 'Execute':
		Install($dataURL, $calURL);
		UpdateData($dataURL, $numDays);
		break;
	// AKTION VIA TIMER 
	case 'TimerEvent':
		// Update Daten Speicher
		UpdateData($dataURL, $numDays);
		break;
	// AKTION VIA WEBFRONT
	case 'WebFront':
		// Speichern
		SetValue($_IPS['VARIABLE'], $_IPS['VALUE']);
		// Profile austauschen?
		if (IPS_GetName($_IPS['VARIABLE']) == 'Bundesland') {
			$vid = CreateVariableByName($_IPS['SELF'], "Region", 1);
			$vpn = "Pollen.".$_IPS['VALUE'];
			IPS_SetVariableCustomProfile($vid, $vpn);
			// automatisch erstes auswählen
			$vp = IPS_GetVariableProfile($vpn);
			SetValue($vid, $vp['Associations'][0]['Value']);
		}
		// Immer machen!
		UpdateData($dataURL, $numDays);
		break;
}

# ------------------------------- Funktionen -----------------------------------

// Erzeugt eine Variable unterhalb {id} mit dem Namen {name} vom Typ [type}
// Existiert die Variable schon wird diese zurückgeliefert.
// Types: 0 = Boolean, 1 = Integer, 2 = Float, 3 = String
function CreateVariableByName($id, $name, $type) 
{ 
	$vid = @IPS_GetVariableIDByName($name, $id); 
	if($vid===false) { 
		$vid = IPS_CreateVariable($type); 
		IPS_SetParent($vid, $id); 
		IPS_SetName($vid, $name); 
	}
	return $vid; 
}

// Erzeugt ein zyklisches Event
// id: 		Int - Parent 
// name:		String - Event name
// type: 	0 => Legt ein “ausgelöstes” Ereignis an
//				1 => Legt ein “zyklisches” Ereignis an
//				2 => Legt ein “Wochenplan” Ereignis an
// time		Int - timestamp
function CreateEventByName($id, $name, $type, $time) 
{ 
	if($time < time()) {
		return -1;
	}
	
	$eid = @IPS_GetEventIDByName($name, $id); 
	if($eid===false) { 
		$eid = IPS_CreateEvent($type); 
		IPS_SetParent($eid, $id); 
		IPS_SetName($eid, $name); 
	} 
	
	// einmaliges Event
	IPS_SetEventCyclic($eid, 1, 0, 0, 0, 0, 0); 
	IPS_SetEventCyclicDateFrom($eid, (int)date('j',$time), (int)date('n', $time),  (int)date('Y', $time)); 
	IPS_SetEventCyclicDateTo($eid, 0, 0, 0); 
	IPS_SetEventCyclicTimeFrom($eid, (int)date("H", $time), (int)date("i", $time), (int)date("s", $time)); 
	IPS_SetEventCyclicTimeTo($eid, 0, 0, 0);
	IPS_SetEventActive($eid, true); 
	return $eid; 
}

// Erzeugt ein Variablenprofil vom Typ {type} mit Name n{name} 
function CreateProfile($name, $type)
{
	if(!IPS_VariableProfileExists($name)) {
		IPS_CreateVariableProfile($name, $type);
	} 
	else {
		$profile = IPS_GetVariableProfile($name);
		if($profile['ProfileType'] != $type)
			throw new Exception("Variable profile type does not match for profile ".$name);
	}
}

// Erzeugt ein Integer-Variablenprofil
function CreateProfileInteger($name, $icon, $prefix, $suffix, $minvalue, $maxvalue, $step, $digits, $asso = NULL)
{
	CreateProfile($name, 1);

	IPS_SetVariableProfileIcon($name, $icon);
	IPS_SetVariableProfileText($name, $prefix, $suffix);
	IPS_SetVariableProfileDigits($name, $digits);
	
	if(sizeof($asso) !== 0){
		$minvalue = 0;
		$maxvalue = 0;
	} 
	IPS_SetVariableProfileValues($name, $minvalue, $maxvalue, $step);
	
	if(sizeof($asso) !== 0){
		foreach($asso as $ass) {
			IPS_SetVariableProfileAssociation($name, $ass[0], $ass[1], $ass[2], $ass[3]);
		}
	}
}

// Installiert alle notwendigen Variablen und erzeugt die entsprechenden Profile
// dazu (Pollen.Region und Pollen.<id>).
function Install($dataURL, $calURL) {
	// Datenquelle 
	$json = file_get_contents($dataURL); 
	// falls die Daten nicht geladen werden koennen 
	if (empty($json) || $json == "") { 
		echo "Fehler beim Lesen von '$url'";
		return;
	}
	$data = json_decode($json, TRUE); 
	$regions = array();
	$parts = array();
	// Daten meiner Region aus den DWD Daten filtern 
	foreach ($data['content'] as $content) {
		if (!isset($parts[$content['region_id']])) {
			$regions[] = array($content['region_id'], $content['region_name'],	"", 0x800080);
			$parts[$content['region_id']] = array();
		}
		if ($content['partregion_id'] == -1) { 
			$parts[$content['region_id']][] = array($content['partregion_id'], $content['region_name'], "", -1); 
		}
		else {
			$parts[$content['region_id']][] = array($content['partregion_id'], $content['partregion_name'], "", -1); 
		}
	}
	$pos = 1;
	// Aktualisierungen
	$vid = CreateVariableByName($_IPS['SELF'], 'Letzte Aktualisierung', 1);
	IPS_SetIcon($vid, 'Calendar');
	IPS_SetPosition($vid, $pos++);
	$vid = CreateVariableByName($_IPS['SELF'], 'Nächste Aktualisierung', 1);
	IPS_SetIcon($vid, 'Calendar');
	IPS_SetPosition($vid, $pos++);
	// Region = Bundesland
	$vpn = "Pollen.Region";
	$vid = CreateVariableByName($_IPS['SELF'], "Bundesland", 1);
	CreateProfileInteger($vpn, 'Macro', '', '', 0, 0, 0, 0, $regions);
	IPS_SetVariableCustomProfile($vid, $vpn);
	IPS_SetVariableCustomAction($vid, $_IPS['SELF']);
	IPS_SetPosition($vid, $pos++);
	SetValue($vid, $regions[0][0]);	
	// Pro Bundesland ein Teilgebiets-Profil
	foreach ($parts as $key => $asso) {
		$vpn = "Pollen.".$key;
		CreateProfileInteger($vpn, 'Image', '', '', 0, 0, 0, 0, $asso);
	}
	$vid = CreateVariableByName($_IPS['SELF'], "Region", 1);
	$profil = "Pollen.".$regions[0][0];
	IPS_SetVariableCustomProfile($vid, $profil);
	IPS_SetVariableCustomAction($vid, $_IPS['SELF']);
	IPS_SetPosition($vid, $pos++);
	SetValue($vid, $parts[$regions[0][0]][0][0]);
	// Tageshinweis
	$vid = CreateVariableByName($_IPS['SELF'], "Tageshinweis", 3);
	IPS_SetVariableCustomProfile($vid, '~TextBox');
	IPS_SetIcon($vid, "Information");
	IPS_SetPosition($vid, $pos++);
	// Vorhersage
	$vid = CreateVariableByName($_IPS['SELF'], "Vorhersage", 3);
	IPS_SetVariableCustomProfile($vid, '~HTMLBox');
	IPS_SetIcon($vid, "Snow");
	IPS_SetPosition($vid, $pos++);
	// Jahreskalender
	$vid = CreateVariableByName($_IPS['SELF'], "Jahreskalender", 3);
	IPS_SetVariableCustomProfile($vid, '~HTMLBox');
	IPS_SetIcon($vid, "Information");
	IPS_SetPosition($vid, $pos++);
	SetValue($vid, '<img src=\''.$calURL.'\' style=\'max-height: 100%; max-width: 100%;\' \>');
}

// Holt täglich die Pollenfluginformationen und extrahiert für die 
// eingestellte Region die Daten!
function UpdateData($url, $days) {
	// Datenquelle 
	$json = file_get_contents($url); 
	// falls die Daten nicht geladen werden koennen 
	if (empty($json) || $json == "") { 
		IPS_LogMessage('POLLENFLUG', "Fehler beim Lesen von '$url'");
		return;
	}
	$data = json_decode($json, TRUE);
	// Last Update
	if (array_key_exists('last_update', $data)) {
		$vid = CreateVariableByName($_IPS['SELF'], 'Letzte Aktualisierung', 1);
		$update = str_replace(' Uhr', '', $data['last_update']);
		$last = strtotime($update);
		SetValue($vid, $last); 
	}
	else {
		IPS_LogMessage('POLLENFLUG', "Fehler beim Auslesen von 'last_update'");
		return;
	} 
	// Next Update
	if (array_key_exists('next_update', $data)) {
		$vid = CreateVariableByName($_IPS['SELF'], 'Nächste Aktualisierung', 1);
		$update = str_replace(' Uhr', '', $data['next_update']);
		$next = strtotime($update);
		SetValue($vid, $next);
		// Timer
		$next = $next+(15*60); // 15 Minuten safty puffer
	 	// Neuen Aktualisierungstimer erzeugen
		CreateEventByName($_IPS['SELF'], 'UpdateTimer', 1, $next); 
	}
	else {
		IPS_LogMessage('POLLENFLUG', "Fehler beim Auslesen von 'next_update'");
		return;
	}
	// Daten raussuchen
	$vid = CreateVariableByName($_IPS['SELF'], "Bundesland", 1);
	$region_id = GetValue($vid);
	$vid = CreateVariableByName($_IPS['SELF'], "Region", 1);
	$partregion_id = GetValue($vid);
	//echo $region_id.PHP_EOL;
	//echo $partregion_id.PHP_EOL;
	// Suchen
	foreach ($data['content'] as $content) {
		if (($content['region_id'] == $region_id) && ($content['partregion_id'] == $partregion_id)) { 
			$pollen = $content['Pollen']; 
			// Neues Array mit meinen Pollenflugdaten aufbauen
			$pollination = array();
			foreach ($pollen as $key => $value) {
				$pollination[$key] = array($value['today'], $value['tomorrow'],$value['dayafter_to']);
			}
			// Baue Html Tagestabelle
			BuildHtml($pollination, $last, $days);
			// Setze Tagesvorhersage
			BuildText($pollination);
			break;
		} 
	} 
}

function BuildHtml($pollination, $time, $days) {
	# Wochentage auf Deutsch
	$day = array("Sonntag", "Montag", "Dienstag", "Mittwoch", "Donnerstag", "Freitag","Samstag",);
	# Übersetzungstabelle
	$trans = array('January'=>'Januar','February'=>'Februar','March'=>'März','May'=>'Mai','June'=>'Juni','July'=>'Juli','October'=>'Oktober','December'=>'Dezember');
	# Styles
	$style = "";
	$style = $style.'<style type="text/css">';
	# Erle (Alder)
	$style = $style.'div.erle {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iQ2FwYV8xIiB4PSIwcHgiIHk9IjBweCIgdmlld0JveD0iMCAwIDUxMiA1MTIiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDUxMiA1MTI7IiB4bWw6c3BhY2U9InByZXNlcnZlIiB3aWR0aD0iMzJweCIgaGVpZ2h0PSIzMnB4Ij4KPGc+Cgk8Zz4KCQk8cGF0aCBkPSJNNDM3Ljg4MSwyNzkuNDZsLTUwLjI4LTE1Ni4yYy0wLjc1Ni0yLjM1LTIuMDgxLTQuNDc3LTMuODU2LTYuMTkxTDI2Ni45MzIsNC4yMTJDMjY0LjEzNSwxLjUxLDI2MC4zOTgsMCwyNTYuNTEsMGgtMS4wMTkgICAgYy0zLjg4OSwwLTcuNjI1LDEuNTEtMTAuNDIyLDQuMjEyTDEyOC4yNTUsMTE3LjA2OWMtMS43NzUsMS43MTUtMy4xLDMuODQyLTMuODU2LDYuMTkxbC01MC4yOCwxNTYuMiAgICBjLTEuMTQxLDMuNTQzLTAuOTIzLDcuMzg0LDAuNjEsMTAuNzc2bDU1LjE2MSwxMjJjMS41MzksMy40MDIsNC4yOTEsNi4xMDgsNy43MTgsNy41OUwyNDEsNDY0LjUwM1Y0OTdjMCw4LjI4NCw2LjcxNiwxNSwxNSwxNSAgICBjOC4yODQsMCwxNS02LjcxNiwxNS0xNXYtMzIuNDk3bDEwMy4zOTMtNDQuNjc3YzMuNDI3LTEuNDgxLDYuMTc5LTQuMTg4LDcuNzE4LTcuNTlsNTUuMTYxLTEyMiAgICBDNDM4LjgwNCwyODYuODQ1LDQzOS4wMjIsMjgzLjAwNCw0MzcuODgxLDI3OS40NnogTTM1Ny4xNjUsMzk0LjU4OUwyNzEsNDMxLjgyMnYtNDYuNzQ1bDg4LjY1Ny02OC41NjggICAgYzYuNTUzLTUuMDY4LDcuNzU3LTE0LjQ4OSwyLjY4OC0yMS4wNDJjLTUuMDY4LTYuNTUzLTE0LjQ4OS03Ljc1OC0yMS4wNDItMi42ODhMMjcxLDM0Ny4xNTF2LTQ4LjE3MyAgICBjMC4zOTctMC4yNTIsMC43ODktMC41MTksMS4xNjgtMC44MTNsNzcuNTc0LTU5Ljk5N2M2LjU1My01LjA2OCw3Ljc1Ny0xNC40ODksMi42ODgtMjEuMDQyICAgIGMtNS4wNjktNi41NTMtMTQuNDktNy43NTgtMjEuMDQyLTIuNjg4TDI3MSwyNjEuMTQ0di01Mi40NzFsNDguNC0zNy40MzNjNi41NTMtNS4wNjgsNy43NTctMTQuNDg5LDIuNjg4LTIxLjA0MiAgICBjLTUuMDY5LTYuNTUzLTE0LjQ5LTcuNzU4LTIxLjA0Mi0yLjY4OEwyNzEsMTcwLjc0OFY5Mi42NWMwLTguMjg0LTYuNzE2LTE1LTE1LTE1Yy04LjI4NCwwLTE1LDYuNzE2LTE1LDE1djc4LjA5N2wtMzAuMDQ3LTIzLjIzOCAgICBjLTYuNTUzLTUuMDY4LTE1Ljk3NC0zLjg2NS0yMS4wNDIsMi42ODhjLTUuMDY4LDYuNTUzLTMuODY1LDE1Ljk3NCwyLjY4OCwyMS4wNDJsNDguNCwzNy40MzN2NTIuNDcxbC02MC4zODktNDYuNzA1ICAgIGMtNi41NTQtNS4wNjctMTUuOTc1LTMuODY1LTIxLjA0MiwyLjY4OGMtNS4wNjgsNi41NTMtMy44NjUsMTUuOTc0LDIuNjg4LDIxLjA0Mmw3Ny41NzQsNTkuOTk3ICAgIGMwLjM4LDAuMjk0LDAuNzcxLDAuNTYxLDEuMTY4LDAuODEzdjQ4LjE3M2wtNzAuMzA0LTU0LjM3M2MtNi41NTMtNS4wNjgtMTUuOTc0LTMuODY0LTIxLjA0MiwyLjY4OCAgICBjLTUuMDY4LDYuNTUzLTMuODY1LDE1Ljk3NCwyLjY4OCwyMS4wNDJMMjQxLDM4NS4wNzd2NDYuNzQ1bC04Ni4xNjUtMzcuMjMzbC01MC4zODctMTExLjQ0Mmw0Ny4zNTUtMTQ3LjExNUwyNTYsMzUuMzY1ICAgIGwxMDQuMTk2LDEwMC42NjdsNDcuMzU2LDE0Ny4xMTVMMzU3LjE2NSwzOTQuNTg5eiIgZmlsbD0iI0ZGRkZGRiIvPgoJPC9nPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+Cjwvc3ZnPgo=)}';
	# Haselnuss (Hazelnut)
	$style = $style.'div.hasel {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iQ2FwYV8xIiB4PSIwcHgiIHk9IjBweCIgdmlld0JveD0iMCAwIDQ5Ni41NDQgNDk2LjU0NCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNDk2LjU0NCA0OTYuNTQ0OyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjMycHgiIGhlaWdodD0iMzJweCI+CjxnPgoJPGc+CgkJPGc+CgkJCTxwYXRoIGQ9Ik00MDguMjcyLDQ4aC0zOC41Nmw4LTQ4aC02Ni44ODhsOCw0OGgtMzguNTUyYy00OC41MiwwLTg4LDM5LjQ4LTg4LDg4djhoLTE0LjU2bDgtNDhoLTY2Ljg4OGw4LDQ4SDg4LjI3MiAgICAgYy00OC41MiwwLTg4LDM5LjQ4LTg4LDg4djMyYzAsMTAuNDE2LDYuNzA0LDE5LjIxNiwxNiwyMi41Mjh2NzUuODU2YzAsNDkuNzQ0LDMxLjI4OCw5NC44ODgsNzcuODU2LDExMi4zNmw1OC4xNDQsMjEuOCAgICAgbDU4LjE0NC0yMS44MDhjNDEuMjg4LTE1LjQ4OCw3MC41MTItNTIuNzQ0LDc2LjYyNC05NS42NjRsNTcuMjMyLDIxLjQ3Mmw1OC4xNDQtMjEuODA4ICAgICBjNDYuNTY4LTE3LjQ2NCw3Ny44NTYtNjIuNjE2LDc3Ljg1Ni0xMTIuMzZWMTkwLjUyYzkuMjg4LTMuMzEyLDE2LTEyLjExMiwxNi0yMi41Mjh2LTMyQzQ5Ni4yNzIsODcuNDcyLDQ1Ni43OTIsNDgsNDA4LjI3Miw0OHogICAgICBNMzU4LjgyNCwxNmwtNS4zMjgsMzJoLTE4LjQ0OGwtNS4zMjgtMzJIMzU4LjgyNHogTTE2Ni44MjQsMTEybC01LjMyOCwzMmgtMTguNDQ4bC01LjMyOC0zMkgxNjYuODI0eiBNMjcyLjI3MiwzNjIuMzc2ICAgICBjMCw0My4xMTItMjcuMTIsODIuMjQtNjcuNDg4LDk3LjM3NmwtNTIuNTEyLDE5LjY5NmwtNTIuNTItMTkuNjk2Yy00MC4zNi0xNS4xMjgtNjcuNDgtNTQuMjY0LTY3LjQ4LTk3LjM3NnYtNzQuMzg0aDI0MFYzNjIuMzc2ICAgICB6IE0yODAuMjcyLDI3MmgtMjU2Yy00LjQxNiwwLTgtMy41ODQtOC04di0zMmMwLTM5LjcwNCwzMi4yOTYtNzIsNzItNzJoMTI4YzM5LjcwNCwwLDcyLDMyLjI5Niw3Miw3MnYzMiAgICAgQzI4OC4yNzIsMjY4LjQwOCwyODQuNjg4LDI3MiwyODAuMjcyLDI3MnogTTQ4MC4yNzIsMTY4YzAsNC40MTYtMy41ODQsOC04LDhoLTI0djE2aDE2djc0LjM4NCAgICAgYzAsNDMuMTEyLTI3LjEyLDgyLjI0LTY3LjQ4OCw5Ny4zNzZsLTUyLjUxMiwxOS42ODhsLTUyLjUyLTE5LjY5NmMtMS4xODQtMC40NDgtMi4zMTItMC45ODQtMy40OC0xLjQ3MnYtNzUuNzYgICAgIGM5LjI4OC0zLjMxMiwxNi0xMi4xMTIsMTYtMjIuNTI4di0zMmMwLTE0LjQwOC0zLjU1Mi0yNy45ODQtOS43MTItNDBoMTM3LjcxMnYtMTZIMjg0LjEwNGMtNS4wNC02LjA4OC0xMC45MTItMTEuNDQ4LTE3LjM5Mi0xNiAgICAgaDUuNTZ2LTE2aC0xNnY5LjcxMmMtMTIuMDE2LTYuMTY4LTI1LjU5Mi05LjcxMi00MC05LjcxMmgtOHYtOGMwLTM5LjcwNCwzMi4yOTYtNzIsNzItNzJoMTI4YzM5LjcwNCwwLDcyLDMyLjI5Niw3Miw3MlYxNjh6IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjI1Ni4yNzIiIHk9IjgwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMjg4LjI3MiIgeT0iODAiIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgZmlsbD0iI0ZGRkZGRiIvPgoJCQk8cmVjdCB4PSIzMjAuMjcyIiB5PSI4MCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjM1Mi4yNzIiIHk9IjgwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMzg0LjI3MiIgeT0iODAiIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgZmlsbD0iI0ZGRkZGRiIvPgoJCQk8cmVjdCB4PSI0MTYuMjcyIiB5PSI4MCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjI4OC4yNzIiIHk9IjE0NCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjMyMC4yNzIiIHk9IjE0NCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjM1Mi4yNzIiIHk9IjE0NCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjM4NC4yNzIiIHk9IjE0NCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjQxNi4yNzIiIHk9IjE0NCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjQ0OC4yNzIiIHk9IjE0NCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjIyNC4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjI1Ni4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjI4OC4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjMyMC4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjM1Mi4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjM4NC4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjQxNi4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9IjQ0OC4yNzIiIHk9IjExMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxwYXRoIGQ9Ik0xMDUuMzc2LDQ0NC43NzZsNC4wNzIsMS41Mmw1LjYwOC0xNC45ODRsLTQuMDY0LTEuNTJjLTI3Ljk0NC0xMC40NzItNDYuNzItMzcuNTY4LTQ2LjcyLTY3LjQxNnYtMi4zODRoLTE2djIuMzg0ICAgICBDNDguMjcyLDM5OC44NTYsNzEuMjE2LDQzMS45NzYsMTA1LjM3Niw0NDQuNzc2eiIgZmlsbD0iI0ZGRkZGRiIvPgoJCQk8cmVjdCB4PSI2NC4yNzIiIHk9IjE3NiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9Ijk2LjI3MiIgeT0iMTc2IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTI4LjI3MiIgeT0iMTc2IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTYwLjI3MiIgeT0iMTc2IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTkyLjI3MiIgeT0iMTc2IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMjI0LjI3MiIgeT0iMTc2IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMzIuMjcyIiB5PSIyNDAiIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgZmlsbD0iI0ZGRkZGRiIvPgoJCQk8cmVjdCB4PSI2NC4yNzIiIHk9IjI0MCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9Ijk2LjI3MiIgeT0iMjQwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTI4LjI3MiIgeT0iMjQwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTYwLjI3MiIgeT0iMjQwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTkyLjI3MiIgeT0iMjQwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMjI0LjI3MiIgeT0iMjQwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMjU2LjI3MiIgeT0iMjQwIiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMzIuMjcyIiB5PSIyMDgiIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgZmlsbD0iI0ZGRkZGRiIvPgoJCQk8cmVjdCB4PSI2NC4yNzIiIHk9IjIwOCIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiBmaWxsPSIjRkZGRkZGIi8+CgkJCTxyZWN0IHg9Ijk2LjI3MiIgeT0iMjA4IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTI4LjI3MiIgeT0iMjA4IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTYwLjI3MiIgeT0iMjA4IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMTkyLjI3MiIgeT0iMjA4IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMjI0LjI3MiIgeT0iMjA4IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iMjU2LjI3MiIgeT0iMjA4IiB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIGZpbGw9IiNGRkZGRkYiLz4KCQkJPHJlY3QgeD0iNDguMjcyIiB5PSIzMjgiIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgZmlsbD0iI0ZGRkZGRiIvPgoJCTwvZz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K)}';
	# Esche (Ash)
	$style = $style.'div.esche {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTguMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iQ2FwYV8xIiB4PSIwcHgiIHk9IjBweCIgdmlld0JveD0iMCAwIDMzOSAzMzkiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDMzOSAzMzk7IiB4bWw6c3BhY2U9InByZXNlcnZlIiB3aWR0aD0iMzJweCIgaGVpZ2h0PSIzMnB4Ij4KPGc+Cgk8cGF0aCBkPSJNMTc2LjA5MywyMzEuNjNjMTcuNDEyLDAsMzQuMzIxLTYuNDk0LDQ3LjI3LTE4LjM0YzE0LjcyOS0xMy40NzcsMjMuMDEzLTMyLjY3MiwyMi43MjktNTIuNjY1ICAgYy0wLjA0My0zLjA0Mi0yLjM1Ni01LjU3LTUuMzgyLTUuODgzYy0xOS44OS0yLjA1OC0zOS43NDQsNC40OTMtNTQuNDczLDE3Ljk2OWMtNC4xLDMuNzUxLTcuNjgsNy45NTktMTAuNzM1LDEyLjQ5di0zNy4zNSAgIGMwLjE5OCwwLjAwMiwwLjM5NiwwLjAxNSwwLjU5NCwwLjAxNWMxNy40MSwwLDM0LjMyMS02LjQ5NSw0Ny4yNjktMTguMzRjMTQuNzI5LTEzLjQ3NiwyMy4wMTMtMzIuNjcxLDIyLjcyOS01Mi42NjUgICBjLTAuMDQzLTMuMDQyLTIuMzU2LTUuNTctNS4zODItNS44ODNjLTE5Ljg5LTIuMDU1LTM5Ljc0NCw0LjQ5My01NC40NzMsMTcuOTY5Yy00LjEsMy43NTEtNy42OCw3Ljk1OC0xMC43MzUsMTIuNDlWOTAuNjkyICAgYzE0LjU3NS05Ljc5MSwyMy40OTMtMjYuMzQ0LDIzLjQ5My00NC4wMDhjMC0xOC44NDMtMTAuMTQ5LTM2LjQyMy0yNi40ODgtNDUuODc3Yy0xLjg1OS0xLjA3Ni00LjE1MS0xLjA3Ni02LjAxMSwwICAgYy0xNi4zMzgsOS40NTUtMjYuNDg4LDI3LjAzNC0yNi40ODgsNDUuODc3YzAsMTcuNjY0LDguOTE4LDM0LjIxNywyMy40OTMsNDQuMDA4djEwLjc0NGMtMy4wNTUtNC41MzEtNi42MzUtOC43MzgtMTAuNzM1LTEyLjQ5ICAgYy0xNC43MjktMTMuNDc2LTM0LjU4LTIwLjAyNS01NC40NzMtMTcuOTY5Yy0zLjAyNiwwLjMxMy01LjMzOSwyLjg0MS01LjM4Miw1Ljg4M2MtMC4yODQsMTkuOTkzLDgsMzkuMTg4LDIyLjcyOSw1Mi42NjUgICBjMTIuOTQ5LDExLjg0NywyOS44NTcsMTguMzQsNDcuMjY5LDE4LjM0YzAuMTk4LDAsMC4zOTYtMC4wMTQsMC41OTQtMC4wMTV2MzcuMzVjLTMuMDU1LTQuNTMxLTYuNjM1LTguNzM5LTEwLjczNS0xMi40OSAgIGMtMTQuNzI5LTEzLjQ3Ni0zNC41OC0yMC4wMjUtNTQuNDczLTE3Ljk2OWMtMy4wMjYsMC4zMTMtNS4zMzksMi44NDEtNS4zODIsNS44ODNjLTAuMjg0LDE5Ljk5Myw4LDM5LjE4OCwyMi43MjksNTIuNjY1ICAgYzEyLjk0OSwxMS44NDcsMjkuODU2LDE4LjM0LDQ3LjI3LDE4LjM0YzAuMTk3LDAsMC4zOTYtMC4wMTQsMC41OTMtMC4wMTV2MzcuMzVjLTMuMDU1LTQuNTMxLTYuNjM1LTguNzM4LTEwLjczNS0xMi40OSAgIGMtMTQuNzI5LTEzLjQ3Ni0zNC41OC0yMC4wMjUtNTQuNDczLTE3Ljk2OWMtMy4wMjYsMC4zMTMtNS4zMzksMi44NDEtNS4zODIsNS44ODNjLTAuMjg0LDE5Ljk5Myw4LDM5LjE4OCwyMi43MjksNTIuNjY1ICAgYzEyLjk0OSwxMS44NDcsMjkuODU2LDE4LjM0LDQ3LjI3LDE4LjM0YzAuMTk3LDAsMC4zOTYtMC4wMTQsMC41OTMtMC4wMTVWMzMzYzAsMy4zMTMsMi42ODYsNiw2LDZzNi0yLjY4Nyw2LTZ2LTE3LjYyMiAgIGMwLjE5NywwLjAwMiwwLjM5NiwwLjAxNSwwLjU5MywwLjAxNWMxNy40MTIsMCwzNC4zMjEtNi40OTQsNDcuMjctMTguMzRjMTQuNzI5LTEzLjQ3NiwyMy4wMTMtMzIuNjcxLDIyLjcyOS01Mi42NjUgICBjLTAuMDQzLTMuMDQyLTIuMzU2LTUuNTctNS4zODItNS44ODNjLTE5Ljg5LTIuMDU3LTM5Ljc0NCw0LjQ5My01NC40NzMsMTcuOTY5Yy00LjEsMy43NTEtNy42OCw3Ljk1OC0xMC43MzUsMTIuNDl2LTM3LjM1ICAgQzE3NS42OTcsMjMxLjYxNiwxNzUuODk2LDIzMS42MywxNzYuMDkzLDIzMS42M3ogTTE5NC4zMzYsMTgxLjU2NGMxMC44MjYtOS45MDUsMjQuOTUzLTE1LjI3NywzOS41NjctMTUuMTkyICAgYy0xLjE5MiwxNC41MjItNy44MTUsMjguMTU5LTE4LjY0MiwzOC4wNjRjLTEwLjcyNyw5LjgxNC0yNC43MzcsMTUuMTk0LTM5LjE2NywxNS4xOTRjLTAuMTMzLDAtMC4yNjcsMC0wLjQtMC4wMDEgICBDMTc2Ljg4NiwyMDUuMTA2LDE4My41MSwxOTEuNDcsMTk0LjMzNiwxODEuNTY0eiBNMTk0LjMzNiw5Ny44YzEwLjgyNi05LjkwNSwyNC45NTMtMTUuMzAxLDM5LjU2Ny0xNS4xOTIgICBjLTEuMTkyLDE0LjUyMi03LjgxNSwyOC4xNTktMTguNjQyLDM4LjA2NGMtMTAuODI4LDkuOTA2LTI1LjAzNSwxNS4zMTEtMzkuNTY3LDE1LjE5MiAgIEMxNzYuODg2LDEyMS4zNDMsMTgzLjUxLDEwNy43MDYsMTk0LjMzNiw5Ny44eiBNMTIzLjczOCwxMjAuNjcyYy0xMC44MjYtOS45MDUtMTcuNDUtMjMuNTQyLTE4LjY0Mi0zOC4wNjQgICBjMTQuNjE4LTAuMTE3LDI4Ljc0Miw1LjI4OCwzOS41NjcsMTUuMTkyYzEwLjgyNiw5LjkwNSwxNy40NSwyMy41NDIsMTguNjQyLDM4LjA2NCAgIEMxNDguNzQxLDEzNS45NzIsMTM0LjU2NCwxMzAuNTc3LDEyMy43MzgsMTIwLjY3MnogTTE2Mi45MDUsMjE5LjYzYy0xNC40MjksMC0yOC40NC01LjM4LTM5LjE2Ny0xNS4xOTQgICBjLTEwLjgyNi05LjkwNi0xNy40NS0yMy41NDItMTguNjQyLTM4LjA2NGMxNC42MTgtMC4wOTgsMjguNzQyLDUuMjg4LDM5LjU2NywxNS4xOTJjMTAuODI2LDkuOTA2LDE3LjQ1LDIzLjU0MiwxOC42NDIsMzguMDY0ICAgQzE2My4xNzIsMjE5LjYyOSwxNjMuMDM4LDIxOS42MywxNjIuOTA1LDIxOS42M3ogTTE2Mi45MDUsMzAzLjM5NGMtMTQuNDI5LDAtMjguNDQtNS4zOC0zOS4xNjctMTUuMTk0ICAgYy0xMC44MjYtOS45MDUtMTcuNDUtMjMuNTQyLTE4LjY0Mi0zOC4wNjRjMC4xMzMtMC4wMDEsMC4yNjgtMC4wMDEsMC40MDEtMC4wMDFjMTQuNDI4LDAsMjguNDQsNS4zOCwzOS4xNjcsMTUuMTk0ICAgYzEwLjgyNiw5LjkwNSwxNy40NSwyMy41NDIsMTguNjQyLDM4LjA2NEMxNjMuMTcyLDMwMy4zOTMsMTYzLjAzOCwzMDMuMzk0LDE2Mi45MDUsMzAzLjM5NHogTTE5NC4zMzYsMjY1LjMyOCAgIGMxMC44MjYtOS45MDUsMjUuMDI3LTE1LjI4NiwzOS41NjctMTUuMTkyYy0xLjE5MiwxNC41MjItNy44MTUsMjguMTU5LTE4LjY0MiwzOC4wNjRjLTEwLjcyNyw5LjgxNC0yNC43MzcsMTUuMTk0LTM5LjE2NywxNS4xOTQgICBjLTAuMTMzLDAtMC4yNjcsMC0wLjQtMC4wMDFDMTc2Ljg4NiwyODguODcsMTgzLjUxLDI3NS4yMzMsMTk0LjMzNiwyNjUuMzI4eiBNMTUyLjAwNyw0Ni42ODVjMC0xMy4zODMsNi42MjItMjUuOTQzLDE3LjQ5My0zMy41NzIgICBjMTAuODcyLDcuNjI5LDE3LjQ5MywyMC4xODksMTcuNDkzLDMzLjU3MnMtNi42MjIsMjUuOTQzLTE3LjQ5MywzMy41NzJDMTU4LjYyOCw3Mi42MjcsMTUyLjAwNyw2MC4wNjcsMTUyLjAwNyw0Ni42ODV6IiBmaWxsPSIjRkZGRkZGIi8+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPC9zdmc+Cg==)}';
	# Birke (Birch)
	$style = $style.'div.birke {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iQ2FwYV8xIiB4PSIwcHgiIHk9IjBweCIgdmlld0JveD0iMCAwIDUxMi4wMDEgNTEyLjAwMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNTEyLjAwMSA1MTIuMDAxOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjMycHgiIGhlaWdodD0iMzJweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTI4Ni4yODcsNDc5Ljk2M2gtOS4zNTVjLTIuNzEzLDAtNC45MTQtMi4yMDEtNC45MTQtNC45MTR2LTQzLjE0N0gyMzkuOTh2NDcuOTY2YzAsMTcuNzQ2LDE0LjM4NiwzMi4xMzMsMzIuMTMzLDMyLjEzMyAgICBoMTQuMTc0YzguODQ3LDAsMTYuMDE5LTcuMTcyLDE2LjAxOS0xNi4wMTlDMzAyLjMwNiw0ODcuMTM1LDI5NS4xMzQsNDc5Ljk2MywyODYuMjg3LDQ3OS45NjN6IiBmaWxsPSIjRkZGRkZGIi8+Cgk8L2c+CjwvZz4KPGc+Cgk8Zz4KCQk8cGF0aCBkPSJNNDQ1Ljk5OCwyNjAuMzE3aC02Ljk1MWMtMi44NDUsMC01LjY4NC0wLjY2Mi04LjEyNy0yLjEyMWMtNS4xNjUtMy4wODQtNy45MjUtOC43MjgtNy40MzQtMTQuNDQ3bDQuNjg5LTU0LjUwMyAgICBjMC40NTUtNS4yOC01LjYwNS04LjYwMy05LjgyMy01LjMwN2MtMS42NDksMS4yODktMy40NzgsMi4zNjEtNS41MzEsMi43NjdjLTkuNzI5LDEuOTI2LTE3LjY0My00LjUxNS0xOC43ODgtMTIuODczICAgIGwtOC40MTItNjEuNDEyYy0wLjQxMi0zLjAxNC0yLjk4OC01LjI2LTYuMDI5LTUuMjZoLTE4LjU3NGMtNS40ODYsMC0xMC41NS0yLjk0NS0xMy4yNjQtNy43MTRsLTI0Ljc2Ny00My41MyAgICBjLTIuNTE2LTQuNDIxLTcuOTg4LTYuMTk1LTEyLjYxOS00LjA5Yy05LjEzMSw0LjE1MS0xOS45MTQsMC40OTYtMjQuNjM2LTguMzU0QzI3OS4xMjEsMzEuMDgyLDI3Mi4xNCwxNy45NjUsMjY1LjczLDUuODYgICAgYy00LjEzOC03LjgxMy0xNS4zMjMtNy44MTMtMTkuNDYxLDBjLTYuNDExLDEyLjEwNS0xMy4zOTIsMjUuMjIyLTIwLjAwNCwzNy42MTJjLTQuNzIyLDguODQ5LTE1LjUwNSwxMi41MDUtMjQuNjM2LDguMzU0ICAgIGMtNC42MzEtMi4xMDUtMTAuMTA0LTAuMzMxLTEyLjYxOSw0LjA5bC0yNC43NjcsNDMuNTMyYy0yLjcxMyw0Ljc2OS03Ljc3Nyw3LjcxMy0xMy4yNjQsNy43MTNoLTE4LjU3MyAgICBjLTMuMDQyLDAtNS42MTcsMi4yNDYtNi4wMjksNS4yNmwtOC4zNzEsNjEuMTA3Yy0wLjU2LDQuMDg0LTIuNjA5LDcuODc2LTUuODk2LDEwLjM2M2MtNS41NjgsNC4yMTItMTMuMDE1LDQuMDkxLTE4LjM2NCwwLjExOCAgICBsLTAuMjMtMC4xNzFjLTQuMjEtMy4xMy0xMC4xNDIsMC4xNzgtOS42OTIsNS40MDRsNC42ODksNTQuNTA1YzAuNDkyLDUuNzE5LTIuMjY4LDExLjM2My03LjQzNCwxNC40NDcgICAgYy0yLjQ0MywxLjQ1OS01LjI4MSwyLjEyMS04LjEyNywyLjEyMUg2NmMtNC4wMjUsMC02LjkzMywzLjgzMS01Ljg2NSw3LjcxMWM1LjEwNywxOC41NjMsMTQuMjk2LDQ1LjA2NSwyOS45MjYsNzEuMjQ4ICAgIGMzNC45MTksNTguNDk1LDg1LjMzMSw4OS41OTUsMTQ5LjkyLDkyLjYyNnYtNTMuMjU5Yy0yNy4wNTUtMjMuMTYxLTkzLjcwMy04MC4xOTktOTYuNzg5LTgyLjc2NiAgICBjLTYuNDg5LTUuMjgzLTcuNTE2LTE0LjgyMS0yLjI3OC0yMS4zNjZjNS4yNjUtNi41OCwxNC44NjktNy42NDcsMjEuNDQ4LTIuMzhjMS40MzEsMS4xNDUsNDUuMjk5LDM4LjY3Nyw3Ny42MTksNjYuMzM5di01Mi41MzkgICAgYy0yNy44OTgtMjMuODgxLTY4LjkzMy01OC45OTMtNzEuMjM5LTYwLjkxN2MtNi40NzEtNS4yODYtNy40OTEtMTQuODEtMi4yNi0yMS4zNDljNS4yNjUtNi41ODEsMTQuODY4LTcuNjQ5LDIxLjQ0OS0yLjM4MSAgICBjMS4wMDksMC44MDcsMjcuNjI4LDIzLjU3NSw1Mi4wNSw0NC40NzZ2LTQ0LjEwNWMtMTcuMjMzLTE0Ljc1Mi00Mi4yMjctMzYuMTM4LTQzLjkxOC0zNy41NTUgICAgYy02LjY5LTUuNDk1LTcuNTItMTUuNTMzLTEuNTk3LTIyLjA2NGM1LjU2Ny02LjEzNiwxNS4xMzMtNi40NiwyMS40NTctMS4xMDZjMS40MzksMS4yMTgsNi4zNTcsNS40MSwyNC4wNTcsMjAuNTU1Vjg2Ljg2NyAgICBjMC04LjYyNSw2LjYyOS0xNi4wNDcsMTUuMjQ1LTE2LjQ1M2M5LjE5OS0wLjQzNCwxNi43OTMsNi44OTcsMTYuNzkzLDE2LjAwMXY3NS4wNzFjMTcuNjk5LTE1LjE0NCwyMi42MTgtMTkuMzM3LDI0LjA1Ny0yMC41NTUgICAgYzYuMzIzLTUuMzUzLDE1Ljg5LTUuMDMxLDIxLjQ1NywxLjEwNWM1LjkyNCw2LjUzLDUuMDk0LDE2LjU3LTEuNTk2LDIyLjA2NGMtMS42OTEsMS40MTgtMjYuNjg1LDIyLjgwMy00My45MTgsMzcuNTU1djQ0LjEwNSAgICBjMjQuNDIyLTIwLjkwMSw1MS4wNC00My42Nyw1Mi4wNDktNDQuNDc3YzYuNTgxLTUuMjY2LDE2LjE4NC00LjIsMjEuNDQ5LDIuMzgxYzUuMjMyLDYuNTM5LDQuMjEyLDE2LjA2My0yLjI2LDIxLjM0OSAgICBjLTIuMzA2LDEuOTI1LTQzLjM0MiwzNy4wMzctNzEuMjM5LDYwLjkxOHY1Mi41MzljMzIuMzE5LTI3LjY2Myw3Ni4xODgtNjUuMTk1LDc3LjYxOS02Ni4zNGM2LjU4MS01LjI2NSwxNi4xODMtNC4yLDIxLjQ0OCwyLjM4ICAgIGM1LjIzOCw2LjU0Niw0LjIxMSwxNi4wODMtMi4yNzgsMjEuMzY2Yy0zLjA4NywyLjU2Ni02OS43MzQsNTkuNjA1LTk2Ljc4OSw4Mi43NjZWNDMxLjkgICAgYzY0LjU4OS0zLjAzMSwxMTUuMDAxLTM0LjEzMSwxNDkuOTItOTIuNjI2YzE1LjYyOS0yNi4xODEsMjQuODE4LTQ3LjY3NSwyOS45MjUtNjYuMjQyICAgIEM0NTIuOTMyLDI2OS4xNTMsNDUwLjAyMywyNjAuMzE3LDQ0NS45OTgsMjYwLjMxN3oiIGZpbGw9IiNGRkZGRkYiLz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K)}';
	# Grässer (Grasses)
	$style = $style.'div.graeser {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iQ2FwYV8xIiB4PSIwcHgiIHk9IjBweCIgdmlld0JveD0iMCAwIDQ1MyA0NTMiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDQ1MyA0NTM7IiB4bWw6c3BhY2U9InByZXNlcnZlIiB3aWR0aD0iMzJweCIgaGVpZ2h0PSIzMnB4Ij4KPGc+Cgk8Zz4KCQk8cGF0aCBkPSJNNDUxLjIsMTAwLjVjLTMuMi0zLjItNy4yLTMuMi0xMC40LTAuOGMtNCwzLjItNzcuNiw2NC44LTExNi44LDE2Ny4yYy03LjItMTguNC0xNS4yLTM2LjgtMjQtNTIuOCAgICBjMjAuOC02OCw0MS42LTExNS4yLDYzLjItMTQwYzIuNC0zLjIsMi40LTgtMC44LTExLjJjLTMuMi0zLjItOC0zLjItMTEuMiwwYy0xLjYsMS42LTQwLjgsNDAuOC04MCwxMDEuNiAgICBjLTguOC0xMy42LTE3LjYtMjUuNi0yNi40LTM2LjhjMTAuNC0yMy4yLDIxLjYtNDEuNiwzMi01NC40YzIuNC0zLjIsMi40LTgtMC44LTExLjJjLTMuMi0zLjItOC0zLjItMTEuMiwwICAgIGMtMC44LDAuOC0xNi44LDE2LjgtMzguNCw0Mi40Yy0yMC44LTI1LjYtMzYuOC00MC44LTM4LjQtNDIuNGMtMy4yLTMuMi04LTMuMi0xMS4yLDBjLTMuMiwzLjItMy4yLDgtMC44LDExLjIgICAgYzExLjIsMTMuNiwyMi40LDMyLDMyLDU0LjRjLTguOCwxMS4yLTE2LjgsMjMuMi0yNS42LDM2LjhjLTM4LjQtNjAuOC03Ny42LTEwMC04MC0xMDEuNmMtMy4yLTMuMi04LTMuMi0xMS4yLDAgICAgYy0zLjIsMy4yLTMuMiw4LTAuOCwxMS4yYzI0LjgsMjguOCw0Ni40LDg0LDYzLjIsMTQwYy05LjYsMTcuNi0xNy42LDM2LTI0LDUzLjZDODkuNiwxNjQuNSwxNiwxMDIuOSwxMi44LDk5LjcgICAgYy0zLjItMi40LTgtMi40LTEwLjQsMC44Yy0zLjIsMy4yLTMuMiw4LDAsMTEuMkM1NiwxNzQuOSw4Mi40LDMzNy4zLDg4LDM3Ny4zSDQwLjh2MGMtNC44LDAtOCwzLjItOCw4czMuMiw4LDgsOEg5NmgxNS4yaDM0LjQgICAgaDE1LjJoNDAuOGgwLjhoNDhoMC44SDI5MmgxNS4yaDM0LjRoMTUuMmg1OC40YzQuOCwwLDgtMy4yLDgtOHMtMy4yLTgtOC04aC00OS42YzUuNi00MCwzMi0yMDIuNCw4NS42LTI2NS42ICAgIEM0NTMuNiwxMDguNSw0NTMuNiwxMDMuNyw0NTEuMiwxMDAuNXogTTMwOS42LDEzNy4zYy03LjIsMTYuOC0xMy42LDM2LjgtMjAuOCw1OC40Yy0zLjItNC44LTUuNi05LjYtOC44LTE0LjQgICAgQzI4OS42LDE2NS4zLDMwMCwxNTAuMSwzMDkuNiwxMzcuM3ogTTI0MCwyMTcuM2MtNCwxMC40LTguOCwyMC44LTEzLjYsMzEuMmMtNC44LTExLjItOS42LTIxLjYtMTUuMi0zMiAgICBjNC44LTE2LDkuNi0zMC40LDE0LjQtNDMuMkMyMzEuMiwxODcuNywyMzYsMjAyLjEsMjQwLDIxNy4zeiBNMjE2LDE0Ni4xYzAuOCwxLjYsMS42LDMuMiwxLjYsNC44Yy01LjYsMTQuNC0xMS4yLDI5LjYtMTYuOCw0Ni40ICAgIGMtMy4yLTUuNi02LjQtMTEuMi05LjYtMTZDMjAwLDE2OC41LDIwOCwxNTYuNSwyMTYsMTQ2LjF6IE0xMDQsMzc3LjNoLTAuOGMtNC0yOC0yMC0xMzYtNTQuNC0yMTUuMmMyNC44LDMxLjIsNTMuNiw3NS4yLDcyLDEzMC40ICAgIEMxMTEuMiwzMjEuMywxMDYuNCwzNTAuMSwxMDQsMzc3LjN6IE0xNTMuNiwzNzcuM2gtOC44aC0yNS42YzMuMi00NC44LDE2LjgtOTIsNDAtMTQwYzUuNiwxOS4yLDEwLjQsMzcuNiwxNC40LDU0LjQgICAgQzE2My4yLDMzMS43LDE1Ni44LDM2NC41LDE1My42LDM3Ny4zeiBNMTcwLjQsMzc3LjNjMi40LTEwLjQsNS42LTI4LjgsMTEuMi01MS4yYzUuNiwyMy4yLDguOCw0MS42LDExLjIsNTEuMkgxNzAuNHogICAgIE0xOTkuMiwzMzMuM2MtMTEuMi01MS4yLTMwLjQtMTMyLTU2LjgtMTk1LjJjMjYuNCwzMy42LDU1LjIsNzkuMiw3NS4yLDEzMkMyMDkuNiwyOTEuNywyMDQsMzEyLjUsMTk5LjIsMzMzLjN6IE0yNDQsMzc2LjUgICAgaC0zNC4zMzFjMy4yOTYtNDMuNzYzLDE2LjA2Ni04OS44OSwzOC4zMzEtMTM3LjZjNS42LDE4LjQsMTAuNCwzNiwxNC40LDUyQzI1Mi44LDMzMC4xLDI0Ni40LDM2Mi45LDI0NCwzNzYuNXogTTI2MC44LDM3Ny4zICAgIGMxLjYtMTAuNCw1LjYtMjguOCwxMC40LTUxLjJjNC44LDIzLjIsOC44LDQxLjYsMTEuMiw1MS4ySDI2MC44eiBNMjk5LjIsMzc4LjFoLTAuOGMtNS42LTI4LjgtMjguOC0xNDAtNjMuMi0yMjcuMiAgICBjMC44LTEuNiwxLjYtMy4yLDEuNi00LjhjMjgsMzguNCw1OS4yLDg4LjgsNzguNCwxNDYuNEMzMDcuMiwzMTguOSwzMDEuNiwzNDYuOSwyOTkuMiwzNzguMXogTTM0OS42LDM3Ny4zaC04SDMxNiAgICBjNi40LTk0LjQsNTItMTY5LjYsODgtMjE1LjJDMzY5LjYsMjQyLjEsMzUzLjYsMzQ5LjMsMzQ5LjYsMzc3LjN6IiBmaWxsPSIjRkZGRkZGIi8+Cgk8L2c+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPC9zdmc+Cg==)}';
	#Roggen (Rye)
	$style = $style.'div.roggen {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,<?xml version="1.0" encoding="iso-8859-1"?>
<!-- Generator: Adobe Illustrator 17.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Capa_1" x="0px" y="0px" viewBox="0 0 416.973 416.973" style="enable-background:new 0 0 416.973 416.973;" xml:space="preserve" width="32px" height="32px">
<path id="XMLID_808_" d="M356.407,416.973c4.418,0,8-3.582,8-8s-3.582-8-8-8h-93.936l18.041-42.096  c0.896,0.088,1.797,0.146,2.704,0.146c1.106,0,2.219-0.066,3.333-0.199c5.033-0.6,9.705-2.524,13.631-5.55l38.903-28.236  c5.948-4.317,9.838-10.746,10.952-18.103c1.02-6.735-0.492-13.685-4.147-19.368l13.712-10.259  c11.777-8.814,14.578-25.227,6.713-37.403l13.71-10.257c5.94-4.445,9.797-10.957,10.86-18.337  c0.807-5.606-0.077-11.184-2.494-16.146l23.628-55.138c1.74-4.061-0.141-8.764-4.203-10.504s-8.764,0.141-10.504,4.203  L376.324,182.7c-2.778-1.456-5.818-2.446-9.022-2.907c-3.456-0.498-6.902-0.346-10.203,0.406l31.435-73.412  c1.739-4.062-0.144-8.764-4.205-10.503c-4.06-1.739-8.763,0.144-10.503,4.205l-31.446,73.437c-1.735-2.926-4.011-5.542-6.772-7.714  c-2.543-2.001-5.354-3.519-8.324-4.526l20.986-48.975c1.74-4.061-0.142-8.764-4.203-10.504c-4.062-1.74-8.764,0.141-10.504,4.203  l-23.627,55.14c-12.472,3.971-20.807,16.37-19.202,29.838l2.029,17c-14.241,2.704-24.194,16.053-22.452,30.659l2.029,17.002  c-14.241,2.704-24.193,16.052-22.451,30.658l5.699,47.756v-0.001c0.863,7.231,4.459,13.715,10.132,18.313l-20.656,48.199h-28.546  v-118.5c7.023-1.991,12.882-6.534,16.522-12.839l24.047-41.651c3.709-6.425,4.689-13.93,2.759-21.132  c-1.761-6.573-5.753-12.146-11.319-15.891l8.563-14.83c7.353-12.739,3.463-28.928-8.561-37.023l8.561-14.828  c6.78-11.746,4.002-26.424-5.895-34.986V29.301c0-4.418-3.582-8-8-8s-8,3.582-8,8v53.283c-3.127-0.244-6.309,0.044-9.436,0.881  c-3.383,0.906-6.499,2.409-9.241,4.407V8c0-4.418-3.582-8-8-8s-8,3.582-8,8v79.874c-5.388-3.93-12.043-5.81-18.678-5.287V29.301  c0-4.418-3.582-8-8-8s-8,3.582-8,8v59.993c-9.896,8.564-12.673,23.241-5.893,34.985l8.561,14.827  c-12.025,8.095-15.915,24.284-8.561,37.024l8.562,14.83c-5.598,3.784-9.724,9.577-11.44,16.169  c-1.874,7.2-0.832,14.642,2.935,20.954l24.603,41.218c2.418,4.355,5.968,7.984,10.377,10.529c1.771,1.023,3.626,1.825,5.532,2.43  v118.714h-28.609l-20.66-48.196c5.674-4.597,9.271-11.082,10.135-18.314v0l5.699-47.757c1.741-14.605-8.21-27.954-22.452-30.658  l2.029-17.002c1.742-14.606-8.209-27.955-22.451-30.659l2.029-17.001c1.606-13.468-6.73-25.865-19.201-29.837l-23.628-55.141  c-1.74-4.061-6.442-5.943-10.504-4.203c-4.061,1.74-5.943,6.443-4.203,10.504l20.986,48.977c-2.97,1.007-5.782,2.525-8.325,4.525  c-2.77,2.18-5.053,4.807-6.791,7.746l-31.424-73.466c-1.738-4.063-6.438-5.947-10.501-4.209c-4.063,1.738-5.947,6.439-4.209,10.501  l31.399,73.405c-3.288-0.743-6.721-0.893-10.166-0.396c-3.204,0.461-6.244,1.451-9.022,2.908l-20.986-48.976  c-1.74-4.061-6.442-5.942-10.504-4.203c-4.061,1.74-5.943,6.443-4.203,10.504l23.629,55.145  c-5.723,11.768-2.494,26.352,8.364,34.477l13.709,10.257c-7.864,12.175-5.063,28.588,6.714,37.403l13.712,10.258  c-3.655,5.684-5.167,12.634-4.146,19.369c1.114,7.357,5.003,13.785,10.951,18.102l38.902,28.235  c3.927,3.027,8.599,4.951,13.632,5.551c1.115,0.133,2.228,0.199,3.334,0.199c0.906,0,1.806-0.058,2.701-0.145l18.045,42.096H60.566  c-4.418,0-8,3.582-8,8s3.582,8,8,8H356.407z M208.837,200.125l-0.319,0.553l-0.319-0.553c-1.698-2.942-3.883-5.496-6.439-7.592  l20.935-36.261c1.573-2.724,4.132-4.678,7.207-5.501c3.074-0.824,6.268-0.412,8.99,1.161c5.663,3.27,7.61,10.537,4.342,16.198  l-10.438,18.078c-2.346,0.021-4.707,0.336-7.037,0.96C218.555,189.099,212.546,193.7,208.837,200.125z M173.805,168.132  c-3.269-5.663-1.321-12.93,4.34-16.199c5.663-3.268,12.93-1.321,16.199,4.34l4.937,8.553l-12.431,21.531  c-0.87-0.09-1.74-0.14-2.608-0.148L173.805,168.132z M229.9,98.92c3.073-0.824,6.267-0.412,8.992,1.162  c5.662,3.269,7.61,10.536,4.341,16.198l-10.437,18.077c-2.346,0.021-4.707,0.336-7.037,0.96c-7.203,1.93-13.212,6.531-16.921,12.956  l-0.319,0.552l-0.319-0.553c-1.723-2.984-3.921-5.525-6.441-7.59l20.935-36.261C224.267,101.698,226.826,99.744,229.9,98.92z   M194.347,104.427l4.939,8.538l-12.434,21.536c-0.866-0.088-1.736-0.136-2.61-0.143l-10.438-18.078  c-3.269-5.663-1.321-12.929,4.341-16.198C183.808,96.812,191.074,98.759,194.347,104.427z M172.555,211.159  c0.819-3.147,2.804-5.766,5.589-7.374c2.726-1.573,5.918-1.986,8.993-1.162c3.074,0.824,5.632,2.777,7.206,5.502l4.938,8.551  l-13.497,23.375l-12.039-20.169C172.191,217.28,171.768,214.182,172.555,211.159z M198.916,262.053l-0.127-0.212  c-0.567-0.946-1.011-1.975-1.306-3.074c-0.824-3.074-0.412-6.267,1.161-8.991l24.049-41.651c1.573-2.724,4.131-4.677,7.206-5.501  c1.035-0.277,2.083-0.415,3.123-0.415c2.048,0,4.062,0.533,5.869,1.576c2.724,1.573,4.678,4.132,5.502,7.207  c0.824,3.074,0.411,6.267-1.161,8.991l-24.047,41.651c-1.573,2.724-4.132,4.678-7.206,5.502c-1.136,0.304-2.289,0.438-3.428,0.408  c-0.011,0-0.021-0.002-0.031-0.002c-0.01,0-0.02,0.001-0.03,0.002c-1.921-0.06-3.803-0.589-5.502-1.57  C201.309,265.005,199.926,263.66,198.916,262.053z M130.772,237.151l-2.474,20.729c-8.76,3.833-15.328,12.067-16.54,22.227  l-0.076,0.634l-0.511-0.382c-2.72-2.035-5.735-3.522-8.91-4.441l4.96-41.575c0.775-6.493,6.69-11.142,13.18-10.371  C126.895,224.746,131.547,230.659,130.772,237.151z M91.257,178.786c2.501-1.968,5.596-2.849,8.723-2.474  c6.493,0.774,11.145,6.686,10.371,13.178l-2.474,20.729c-8.758,3.833-15.327,12.067-16.541,22.226l-0.076,0.634l-0.511-0.382  c-2.759-2.065-5.78-3.535-8.91-4.441l4.961-41.575C87.174,183.558,88.756,180.754,91.257,178.786z M44.145,200.238  c1.884-2.519,4.656-4.156,7.806-4.609c3.152-0.454,6.273,0.334,8.739,2.179l7.948,6.049l-2.934,24.589  c-0.831,0.26-1.65,0.559-2.455,0.897l-16.714-12.505C41.299,212.92,40.227,205.475,44.145,200.238z M64.567,247.898  c3.918-5.234,11.362-6.308,16.598-2.391l7.907,5.916l-2.946,24.687c-0.835,0.26-1.654,0.556-2.455,0.891l-16.713-12.503  C61.723,260.58,60.651,253.133,64.567,247.898z M82.756,304.54c-0.487-3.215,0.306-6.404,2.234-8.981  c1.884-2.519,4.657-4.156,7.807-4.609c3.149-0.455,6.272,0.334,8.792,2.219l7.906,5.915l-3.198,26.802l-19.011-13.798  C84.832,310.308,83.224,307.627,82.756,304.54z M127.031,340.935l-0.194-0.141c-0.895-0.647-1.71-1.418-2.414-2.314  c-1.968-2.501-2.847-5.599-2.474-8.722l5.699-47.756c0.717-6.017,5.849-10.453,11.766-10.453c0.466,0,0.938,0.028,1.412,0.084  c6.493,0.775,11.146,6.687,10.371,13.178l-5.699,47.756c-0.373,3.124-1.955,5.928-4.456,7.896c-0.927,0.729-1.937,1.307-2.999,1.728  c-0.01,0.004-0.02,0.007-0.029,0.011c-0.007,0.003-0.014,0.007-0.021,0.01c-1.79,0.701-3.727,0.955-5.674,0.723  C130.393,342.707,128.592,342.015,127.031,340.935z M316.993,176.313c3.12-0.375,6.221,0.505,8.722,2.474  c2.501,1.968,4.083,4.771,4.456,7.895l4.96,41.575c-3.175,0.919-6.19,2.406-8.91,4.441l-0.51,0.382l-0.076-0.634  c-1.213-10.158-7.782-18.392-16.539-22.225l-2.474-20.728C305.848,182.999,310.5,177.086,316.993,176.313z M296.57,223.972  c1.216-0.145,2.412-0.1,3.558,0.112c0.06,0.013,0.119,0.031,0.18,0.042c4.886,0.985,8.819,5.004,9.441,10.215l4.961,41.576  c-3.176,0.919-6.19,2.406-8.91,4.441l-0.51,0.382l-0.076-0.633c-1.211-10.16-7.78-18.396-16.541-22.228l-2.473-20.727  C285.426,230.659,290.078,224.746,296.57,223.972z M278.971,342.21c-0.005-0.002-0.01-0.005-0.016-0.008  c-0.004-0.002-0.009-0.003-0.013-0.005c-1.066-0.422-2.08-1.002-3.01-1.734c-2.501-1.968-4.083-4.772-4.456-7.896c0,0,0,0,0,0  l-5.699-47.756c-0.774-6.492,3.878-12.403,10.369-13.178c0.475-0.057,0.946-0.084,1.413-0.084c5.917,0,11.049,4.437,11.767,10.454  l5.698,47.757c0.373,3.123-0.506,6.22-2.474,8.721c-0.704,0.896-1.52,1.668-2.415,2.314l-0.193,0.14  c-1.561,1.08-3.363,1.772-5.288,2.002C282.703,343.169,280.762,342.914,278.971,342.21z M334.216,304.539  c-0.468,3.088-2.076,5.769-4.53,7.549l-19.01,13.798l-3.198-26.801l7.907-5.916c2.52-1.885,5.641-2.674,8.791-2.219  c3.15,0.454,5.922,2.091,7.807,4.61C333.91,298.135,334.703,301.324,334.216,304.539z M350.015,264.497l-16.714,12.505  c-0.801-0.335-1.62-0.631-2.455-0.891l-2.946-24.687l7.906-5.916c2.519-1.885,5.639-2.674,8.791-2.219  c3.15,0.454,5.922,2.09,7.807,4.609C356.322,253.134,355.25,260.58,350.015,264.497z M375.047,209.03  c-0.454,3.15-2.091,5.923-4.609,7.807l-16.713,12.504c-0.801-0.335-1.621-0.631-2.457-0.891l-2.941-24.647l7.903-5.956  c2.519-1.884,5.639-2.671,8.791-2.219c3.15,0.454,5.922,2.091,7.807,4.611C374.713,202.758,375.501,205.879,375.047,209.03z" fill="#FFFFFF"/>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
</svg>
)}';
	# Beifuss
	$style = $style.'div.beifuss {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,<?xml version="1.0" encoding="iso-8859-1"?>
<!-- Generator: Adobe Illustrator 17.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Capa_1" x="0px" y="0px" viewBox="0 0 471.898 471.898" style="enable-background:new 0 0 471.898 471.898;" xml:space="preserve" width="32px" height="32px">
<path id="XMLID_478_" d="M323.405,307.163c-0.397-1.88-1.107-3.6-2.125-5.14c-2.318-3.516-5.99-5.731-10.617-6.407  c-6.387-0.93-14.581,1.265-22.969,5.912c-1.752-6.199-4.86-11.496-9.148-15.408c-5.238-4.778-11.76-7.083-18.866-6.655  c-3.026,0.181-6.055,0.859-9.032,2.019c-3.095-0.798-6.182-1.11-9.212-0.929c-7.812,0.466-14.682,4.239-19.346,10.624  c-6.293,8.616-8.021,20.947-4.739,33.832c1.444,5.672,3.788,11.062,6.791,15.906l-18.922,15.463v-82.573  c0.031-0.282,0-2.225,0-2.225c1.251,0.102,2.512,0.158,3.781,0.158c15.32,0,31.653-7.19,42.869-15.845  c12.597-9.721,19.581-21.59,19.163-32.564c-0.105-2.77-1.956-5.168-4.609-5.973c-3.606-1.094-7.523-1.638-11.624-1.678  c0.634-4.767,0.713-9.621,0.134-13.55c-0.404-2.742-2.504-4.927-5.229-5.439c-8.972-1.689-18.756,1.597-28.289,9.503  c-6.085,5.046-11.619,11.561-16.196,18.723v-29.908c9.227-0.602,19.376-5.408,28.871-13.854  c13.749-12.231,26.688-33.202,24.603-52.482c-0.298-2.756-2.312-5.021-5.015-5.638c-10.471-2.391-22.631,1.671-34.252,11.435  c-5.386,4.525-10.188,9.861-14.207,15.596v-19.992c9.59-2.588,19.075-10.333,26.72-22.049  c10.006-15.334,16.986-38.757,10.025-56.521c-1.011-2.583-3.576-4.232-6.319-4.124c-4.949,0.204-9.864,1.818-14.578,4.711  c0.919-17.296-3.641-38.054-16.575-50.307c-2.013-1.906-5.015-2.329-7.473-1.046c-9.888,5.149-16.541,16.61-18.735,32.273  c-2.438,17.403,1.024,40.551,13.936,54.658v49.075c-8.072-11.279-18.72-19.627-30.479-20.418c-2.774-0.186-5.347,1.403-6.425,3.957  c-1.697,4.019-2.786,8.45-3.272,13.239c-4.517-1.173-9.075-1.743-13.567-1.559c-2.771,0.114-5.163,1.973-5.959,4.629  c-3.445,11.5,0.73,26.014,11.457,39.821c10.929,14.068,29.444,27.929,48.245,30.122v28.875c-3.462-4.788-7.488-9.037-11.942-12.437  c-7.043-5.376-14.682-8.261-22.16-8.494c-0.148-0.197-0.295-0.405-0.444-0.596c-7.647-9.878-17.586-16.051-26.586-16.513  c-5.505-0.276-10.486,1.616-14.036,5.34c-1.406,1.474-2.56,3.188-3.448,5.119c-1.886,0.98-3.542,2.213-4.946,3.687  c-3.551,3.727-5.206,8.798-4.66,14.279c0.895,8.967,7.538,18.598,17.773,25.764c0.214,0.15,0.44,0.294,0.658,0.442  c0.852,9.624,6.261,19.246,15.615,27.323c12.6,10.879,29.422,16.919,45.081,16.919c3.09,0,6.136-0.236,9.095-0.716v82.579  c-0.046,0.892,0,11.328,0,11.328l-3.943-4.653c0-0.57-0.011-1.142-0.047-1.717c-0.489-7.696-4.254-15.489-10.525-22.048  c1.604-2.423,3.042-4.989,4.282-7.676c5.569-12.073,6.112-24.513,1.489-34.13c-3.426-7.126-9.496-12.085-17.093-13.963  c-2.946-0.729-6.036-0.982-9.227-0.761c-2.716-1.682-5.571-2.898-8.515-3.626c-7.191-1.781-14.536-0.461-20.684,3.714  c-5.365,3.643-9.602,9.29-12.301,16.165c-7.769-6.674-15.807-10.579-22.648-10.779c-4.627-0.129-8.555,1.378-11.44,4.377  c-1.279,1.331-2.289,2.893-3.021,4.667c-1.747,0.802-3.269,1.872-4.546,3.202c-2.92,3.035-4.275,7.103-3.918,11.765  c0.493,6.437,4.434,13.948,10.812,21.11c-5.661,3.071-10.145,7.266-13.02,12.309c-3.511,6.16-4.323,13.029-2.35,19.865  c0.842,2.914,2.169,5.72,3.956,8.371c-0.099,3.198,0.275,6.28,1.117,9.192c2.172,7.518,7.362,13.391,14.616,16.537  c3.983,1.729,8.4,2.583,13.037,2.583c6.757,0,13.981-1.816,21.007-5.394c2.625-1.336,5.131-2.879,7.491-4.59  c6.802,6.021,14.741,9.487,22.457,9.677c0.222,0.005,0.443,0.008,0.664,0.008c0.352,0,0.702-0.012,1.052-0.026l13.085,10.243  c4.478,3.504,10.049,5.344,15.764,5.344c2.441,0,4.911-0.336,7.331-1.022c1.784-0.428,3.497-1.095,5.118-1.954v27.617  c-0.09,10.373,8.827,8.956,11.659,5.535l43.779-57.126c2.184-2.849,1.644-6.929-1.205-9.113c-2.85-2.184-6.93-1.643-9.113,1.206  l-32.12,41.913v-44.936c0.206,0.099,0.406,0.208,0.615,0.301c3.747,1.851,7.801,2.777,11.814,2.777  c4.053,0,8.064-0.944,11.678-2.832l25.854-13.506c3.274,4.632,7.319,8.887,12.003,12.474c8.285,6.346,17.469,9.722,26.063,9.721  c2.356,0,4.67-0.254,6.907-0.77c7.704-1.776,13.874-6.608,17.374-13.605c1.359-2.717,2.288-5.679,2.771-8.835  c2.237-2.281,4.052-4.799,5.407-7.512c3.502-6.999,3.67-14.835,0.473-22.067c-2.506-5.668-6.878-10.621-12.604-14.489  c8.208-6.11,13.779-13.089,15.476-19.715c1.142-4.458,0.534-8.649-1.757-12.123C326.277,309.595,324.975,308.267,323.405,307.163z   M162.656,400.946c-0.898,2.278-2.113,4.223-3.609,5.78c-2.583,2.685-5.789,3.992-9.521,3.907  c-4.313-0.106-8.908-2.074-13.128-5.527c4.195-4.837,7.448-10.247,9.451-15.811l2.751,2.647c1.593,1.532,4.125,1.484,5.656-0.109  c1.531-1.592,1.482-4.125-0.109-5.656l-3.987-3.836c6.829-2.002,13.427-5.945,19.112-11.303c3.583,4.069,5.71,8.562,5.982,12.847  c0.237,3.729-0.952,6.983-3.535,9.668c-1.492,1.551-3.388,2.839-5.634,3.828C164.516,398.072,163.285,399.352,162.656,400.946z   M83.37,331.214c0.301-0.313,0.947-0.59,1.772-0.759c2.637-0.542,4.667-2.653,5.104-5.309c0.137-0.831,0.39-1.488,0.69-1.801  c0.308-0.32,0.957-0.396,1.508-0.396c0.063,0,0.124,0.001,0.184,0.003c4.129,0.12,11.904,4.167,19.816,12.732  c-0.01,0.149,0.323,7.775,1.166,11.779l-5.6-3.934c-1.811-1.271-4.302-0.833-5.573,0.974c-1.27,1.808-0.834,4.303,0.974,5.572  l10.634,7.471l0.999,4.572c-4.763-1.042-10.085-3.321-15.452-7.416c-10.862-8.289-16.193-17.071-16.549-21.725  C82.998,332.375,83.016,331.582,83.37,331.214z M113.36,406.957c-8.259,4.205-16.848,5.126-22.973,2.47  c-3.737-1.622-6.193-4.387-7.301-8.221c-0.598-2.066-0.766-4.354-0.499-6.798c0.186-1.701-0.308-3.405-1.371-4.745  c-1.527-1.925-2.605-3.95-3.202-6.017c-0.991-3.433-0.604-6.738,1.154-9.822c2.236-3.923,6.55-7.166,12.068-9.16  c0.159,0.123,0.31,0.25,0.47,0.372c10.382,7.922,20.052,10.819,28.714,10.134c10.579-0.837,7.833-8.333,6.167-16.75  c-1.128-5.698-1.575-14.243-1.186-21.599c0.047-0.885,0.298-3.26,0.314-3.381c1.108-8.146,4.587-14.749,9.544-18.115  c3.142-2.134,6.592-2.758,10.26-1.85c2.091,0.517,4.154,1.515,6.133,2.965c1.381,1.013,3.104,1.438,4.801,1.187  c2.423-0.362,4.715-0.283,6.81,0.235c3.872,0.958,6.73,3.304,8.496,6.976c2.894,6.02,2.304,14.637-1.578,23.053  c-5.156,11.179-15.331,20.045-25.156,22.336l8.521-34.371c0.531-2.144-0.776-4.313-2.92-4.845c-2.146-0.532-4.313,0.776-4.846,2.92  l-10.092,40.712c-0.018,0.041-0.034,0.083-0.052,0.124l-31.957,19.708c-1.881,1.16-2.465,3.624-1.305,5.504  c0.756,1.226,2.066,1.901,3.408,1.901c0.716,0,1.441-0.192,2.096-0.596l25.529-15.744  C130.181,393.971,122.697,402.206,113.36,406.957z M191.576,417.398c-0.029,0.117-0.055,0.235-0.077,0.354  c-0.329,1.724-1.2,3.362-2.511,4.726l-0.363,0.377c-1.317,1.369-2.919,2.302-4.632,2.698c-0.117,0.027-0.233,0.058-0.349,0.091  c-4.067,1.182-8.521,0.405-11.626-2.026l-6.625-5.187c1.064-0.811,2.076-1.708,3.025-2.695c2.104-2.19,3.871-4.741,5.271-7.608  c2.815-1.512,5.297-3.375,7.399-5.562c0.948-0.986,1.807-2.029,2.575-3.123l5.438,6.418  C191.649,408.869,192.598,413.289,191.576,417.398z M257.303,228.784c-1.741,5.48-6.452,11.475-13.376,16.818  c-11.731,9.053-26.413,13.966-37.766,13.012c2.017-5.812,7.181-12.105,14.645-17.642  C232.453,232.333,246.392,227.792,257.303,228.784z M229.714,216.199c4.378-3.631,8.699-5.896,12.589-6.651  c-0.095,2.506-0.424,5.181-0.941,7.676c-6.866,1.585-13.87,4.362-20.535,8.213C223.584,221.949,226.579,218.798,229.714,216.199z   M227.788,144.421c6.265-5.264,12.571-8.364,17.999-8.952c-1.061,11.7-8.854,25.755-20.338,35.97  c-6.847,6.091-13.952,9.777-19.965,10.509C207.199,169.346,215.899,154.409,227.788,144.421z M231.277,61.448  c1.941,11.348-1.903,26.716-10.226,39.471c-4.823,7.392-10.423,12.745-15.833,15.345V88.611c3.992-2.934,7.33-7.038,9.907-12.135  C220.119,68.829,225.79,63.593,231.277,61.448z M191.157,34.812c1.2-8.565,4.004-15.38,7.919-19.508  c7.105,9.909,10.625,26.297,8.507,41.415c-0.734,5.235-2.069,9.812-3.889,13.527c-0.092,0.166-0.176,0.334-0.253,0.504  c-1.1,2.145-2.365,3.989-3.777,5.478C192.558,66.319,189.04,49.93,191.157,34.812z M165.682,130.403  c8.702,3.346,17.669,13.752,23.379,27.008c-6.825-7.622-15.242-14.342-24.29-18.968  C164.827,135.578,165.121,132.885,165.682,130.403z M154.24,168.435c-6.354-8.18-9.849-16.498-9.915-23.238  c3.494,0.454,7.043,1.468,10.55,2.912c0.574,0.363,1.203,0.643,1.874,0.813c16.899,7.734,32.396,25.276,35.469,39.849v4.612  C179.396,191.281,164.574,181.736,154.24,168.435z M192.219,272.343v9.072c-6.882-0.181-14.328-4.074-21.076-11.168  c-11.338-11.92-16.996-28.951-14.556-42.803c6.312-0.215,11.941,2.914,15.802,5.859  C183.557,241.829,191.613,257.769,192.219,272.343z M116.932,224.502c-0.229-2.296,0.538-3.395,1.135-4.021  c0.651-0.684,1.577-1.234,2.751-1.635c2.006-0.687,3.551-2.309,4.139-4.345c0.344-1.188,0.849-2.137,1.503-2.823  c0.597-0.627,1.646-1.442,3.961-1.328c3.446,0.177,9.171,2.671,14.837,8.942c-0.062,0.158-0.13,0.312-0.18,0.476  c-1.026,3.365-1.65,6.772-1.931,10.178l-8.631-8.571c-1.568-1.556-4.101-1.548-5.656,0.02c-1.557,1.568-1.548,4.101,0.02,5.657  l9.204,9.141c-3.893,0.439-7.61,1.27-11.04,2.5c-0.161,0.058-0.313,0.133-0.467,0.203  C120.043,233.537,117.274,227.936,116.932,224.502z M135.301,249.808c2.99-0.677,6.225-0.999,9.6-0.974  c2.972,11.462,9.069,21.931,16.083,29.571c-5.487-2.388-10.463-5.486-14.444-8.923C139.441,263.353,135.494,256.365,135.301,249.808  z M223.307,390.04c-3.495,1.825-8.016,1.78-11.798-0.119c-0.108-0.054-0.218-0.105-0.328-0.154c-1.611-0.7-3.017-1.908-4.066-3.5  l-0.279-0.421c-1.048-1.59-1.606-3.359-1.616-5.115v-2.093c0.237-3.607,1.884-7.011,4.52-9.165l22.491-18.378  c4.092,4.043,8.709,7.254,13.575,9.327c-0.034,5.342,1.073,10.859,3.174,16.207L223.307,390.04z M314.079,373.714  c-0.963,1.926-2.389,3.72-4.237,5.331c-1.292,1.125-2.087,2.715-2.213,4.423c-0.18,2.443-0.761,4.661-1.728,6.591  c-1.784,3.567-4.701,5.84-8.669,6.755c-6.51,1.501-14.786-0.968-22.145-6.604c-9.274-7.101-15.526-18.172-16.203-27.908  l32.678,14.407c0.524,0.231,1.072,0.341,1.611,0.341c1.536,0,3.002-0.891,3.662-2.387c0.892-2.021-0.025-4.383-2.047-5.274  l-36.072-15.904c-0.127-0.317-0.276-0.625-0.451-0.917l-5.679-36.649c0-2.209-1.791-4-4-4s-4,1.791-4,4l5.679,32.283  c-9.113-4.138-17.304-14.562-20.318-26.4c-2.287-8.981-1.301-17.563,2.64-22.956c2.402-3.29,5.641-5.078,9.623-5.316  c2.152-0.127,4.418,0.21,6.739,1.006c1.618,0.554,3.39,0.45,4.931-0.294c2.214-1.067,4.427-1.673,6.575-1.802  c3.552-0.21,6.706,0.892,9.329,3.284c3.335,3.042,5.552,7.964,6.284,13.786c-0.154,0.128-0.311,0.247-0.465,0.376  c-14.885,12.473-17.601,33.283-9.799,37.946c1.927,1.152,4.518,0.952,6.3-0.414c8.482-6.5,37.566,3.676,42.184,15.3  C315.793,366.505,315.866,370.143,314.079,373.714z M316.457,320.034c-1.025,4.002-6.681,10.698-16.775,16.535  c-0.128-0.037-1.655-0.473-1.655-0.473c-2.56-0.735-5.845-1.666-9.491-2.351l6.326-4.17c1.845-1.216,2.354-3.697,1.139-5.542  c-1.217-1.844-3.697-2.353-5.541-1.138l-15.471,10.198c-0.302,0.038-0.603,0.074-0.905,0.121c1.032-3.955,3.724-8.211,9.871-13.363  c10.472-8.775,20.224-12.051,24.829-11.372c0.598,0.087,1.367,0.28,1.647,0.705c0.239,0.363,0.367,1.052,0.351,1.891  c-0.053,2.695,1.563,5.144,4.062,6.155c0.777,0.314,1.362,0.704,1.602,1.067C316.717,318.709,316.601,319.469,316.457,320.034z   M406.031,211.334l-65.005,82.465c-1.282,1.627-3.187,2.477-5.108,2.477c-1.409,0-2.828-0.456-4.02-1.396  c-2.819-2.222-3.304-6.309-1.081-9.128l65.005-82.465c2.222-2.82,6.312-3.303,9.128-1.081  C407.769,204.428,408.254,208.514,406.031,211.334z M275.073,268.172c0-0.614,0.088-1.238,0.271-1.856l61.366-206.492  c1.023-3.441,4.595-5.233,8.082-4.379c5.169,1.266,4.563,7.464,4.379,8.082l-30.686,214.839c-0.452,3.252-3.237,5.607-6.431,5.607  c-0.298,0-0.599-0.021-0.901-0.063c-3.557-0.494-6.038-3.776-5.545-7.332l17.323-124.756l-35.126,118.197  c-0.839,2.823-3.426,4.65-6.228,4.65c-0.613,0-1.236-0.087-1.854-0.271C276.9,273.559,275.074,270.974,275.073,268.172z" fill="#FFFFFF"/>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
</svg>
)}';
	# Ambrosia
	$style = $style.'div.ambrosia {margin:8px;display: inline-block;width: 32px;height: 32px;background-image: url(data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iQ2FwYV8xIiB4PSIwcHgiIHk9IjBweCIgdmlld0JveD0iMCAwIDUxMi4wMDEgNTEyLjAwMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNTEyLjAwMSA1MTIuMDAxOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjMycHgiIGhlaWdodD0iMzJweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTQ5NS40NTUsMC4wOTRsLTI3LjE4NywyLjgxM2MtMzMuOTc0LDMuNTE1LTY0LjgwOSwyNC4wMTQtODMuOTY3LDUxLjk0NGMtNS40ODgtMTIuMjk2LTEzLjk3LTI1LjI5OC0yNi44NDctMzguMTc0ICAgIGMtNS44NTQtNS44NTQtMTUuMzU1LTUuODU3LTIxLjIxMiwwbC0yMS4yMTEsMjEuMjEyYy0zOS4yNTQsMzkuMjU0LTQwLjk2MSwxMDEuNzQyLTUuMTE4LDE0Mi45OTFsLTIyLjQ4OSwyMi40ODggICAgYzAuMDA5LTIwLjc5MS02LjQ0OC01MS4wNDktMzYuMDMtODAuNjMxYy01Ljg1OC01Ljg1OC0xNS4zNTQtNS44NTgtMjEuMjEyLDBsLTIxLjIxMiwyMS4yMTIgICAgYy0zOS4xNTIsMzkuMTUyLTQwLjg1NSwxMDEuNzg0LTUuMTE3LDE0Mi45ODRsLTIyLjQzMSwyMi40M2MwLjAyMy0yNi43MDktMTAuNjM3LTU1LjExNS0zNi4wODgtODAuNTY2ICAgIGMtNS44NTctNS44NTgtMTUuMzUzLTUuODU4LTIxLjIxMiwwbC0yMS4yMTIsMjEuMjEyYy0zOS4xNTEsMzkuMTUxLTQwLjg1NSwxMDEuNzgtNS4xMjEsMTQyLjk4MUw0LjM5Myw0ODYuMzgyICAgIGMtNS44NTgsNS44NTgtNS44NTgsMTUuMzU0LDAsMjEuMjEyYzUuODU4LDUuODU5LDE1LjM1NSw1Ljg1OCwyMS4yMTIsMC4wMDFsOTMuMzk4LTkzLjM5MSAgICBjNDEuMjM4LDM1Ljc4NSwxMDMuODcxLDM0LjAyNiwxNDIuOTk5LTUuMTAzbDIxLjIxMi0yMS4yMTJjNS44NTgtNS44NTgsNS44NTgtMTUuMzU0LDAtMjEuMjEyICAgIGMtMjkuNTkxLTI5LjU5MS01OS44NDctMzYuMDQyLTgwLjY1LTM2LjAyOWwyMi40OTktMjIuNDk3YzQxLjE4NSwzNS43OTQsMTAzLjY4NSwzNC4yMDUsMTQyLjk5OS01LjExbDIxLjIxMi0yMS4yMTIgICAgYzUuODU4LTUuODU4LDUuODU4LTE1LjM1NCwwLTIxLjIxMmMtMjUuNDU3LTI1LjQ1Ny01My44Ny0zNi4xMTYtODAuNTg0LTM2LjA4OGwyMi40MzctMjIuNDM1ICAgIGM0MS4xODMsMzUuNzg5LDEwMy42ODEsMzQuMjAxLDE0Mi45OTUtNS4xMTRsMjEuMjEyLTIxLjIxMmM1Ljg1OC01Ljg1OCw1Ljg1OC0xNS4zNTQsMC0yMS4yMTIgICAgYy0xMi4yMDUtMTIuMjA2LTI1LjA5Mi0yMS4wMS0zOC4xNDQtMjYuODY3YzI4LjA0OC0xOS4yNSw0OC40MTctNTAuMTI3LDUxLjkxNS04My45NDdsMi44MTMtMjcuMTg3ICAgIEM1MTIuODk3LDcuMDkxLDUwNC45MTEtMC44ODQsNDk1LjQ1NSwwLjA5NHogTTExOS4wNzYsMzcxLjcwN2MtMjQuMDgyLTI5LjQyOC0yMi40MDEtNzMuMDM2LDUuMDQ3LTEwMC40ODRsOS45MTgtOS45MTkgICAgYzI4LjEzNSwzNi44ODgsMTguNjYxLDc2LjQyMy00LjIxMSw5OS42NDlMMTE5LjA3NiwzNzEuNzA3eiBNMjUwLjcsMzc3Ljk3OWwtOS45MSw5LjkxMSAgICBjLTI3LjQ1MywyNy40NTItNzEuMDY1LDI5LjEyOS0xMDAuNDk1LDUuMDRjMTAuNzM5LTEwLjczOSwyOC4yMzUtMzEuNjMsNjAuOTYzLTMyLjI3ICAgIEMyMTguNDYyLDM2MC4zMjQsMjM1LjMxMSwzNjYuMjcsMjUwLjcsMzc3Ljk3OXogTTIyNS4xMzksMjY1LjY1MWMtMjQuMDg0LTI5LjQyOS0yMi40MDQtNzMuMDQsNS4wNDUtMTAwLjQ4OWw5LjkxLTkuOTEgICAgYzI2LjU5MSwzNC45NDYsMjAuNTA5LDc0Ljc1LTQuNDE2LDk5Ljg2MUwyMjUuMTM5LDI2NS42NTF6IE0zNTYuNzY5LDI3MS45MTFsLTkuOTE3LDkuOTE3ICAgIGMtMjcuOTYsMjcuOTU5LTcxLjU2NCwyOC43ODEtMTAwLjQ5OCw1LjA0M2wxMC4zNDUtMTAuMzQ1QzI3OS44NjgsMjUzLjM1OCwzMTkuNjYxLDI0My42MDcsMzU2Ljc2OSwyNzEuOTExeiBNMzMxLjIwMSwxNTkuNTk4ICAgIGMtMjMuNzUxLTI4Ljk0OS0yMi45MDItNzIuNTUxLDUuMDQ0LTEwMC40OTZsOS45MDktOS45MWMyNi42NSwzNS4wMjQsMjAuNDc3LDc0Ljk0NS00LjU3NiwxMDAuMDI5TDMzMS4yMDEsMTU5LjU5OHogICAgIE00NjIuODI5LDE2NS44NWwtOS45MTcsOS45MTdjLTI3Ljk1OCwyNy45NTgtNzEuNTYyLDI4Ljc4Mi0xMDAuNDk4LDUuMDQzbDEwLjM0NS0xMC4zNDUgICAgQzM4NS45MjgsMTQ3LjI5Nyw0MjUuNzIxLDEzNy41NDcsNDYyLjgyOSwxNjUuODV6IE00NzkuMjY3LDQwLjY1N2MtMy45NjEsMzguMjg3LTM4LjMzMSw3Mi42NTgtNzYuNjE5LDc2LjYxOWwtOC44MjMsMC45MTMgICAgbDAuOTEzLTguODI0YzMuOTYxLTM4LjI4NywzOC4zMzEtNzIuNjU4LDc2LjYxOS03Ni42MTlsOC44MjQtMC45MTNMNDc5LjI2Nyw0MC42NTd6IiBmaWxsPSIjRkZGRkZGIi8+Cgk8L2c+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPC9zdmc+Cg==)}';
	# TABLE
	$style = $style.'table  {border-collapse: collapse; font-size: 14px; width: 100%; }';
	$style = $style.'td.fst {vertical-align: middle; text-align: center; padding: 5px 15px 5px 5px; border-left: 1px solid rgba(255, 255, 255, 0.2); border-top: 1px solid rgba(255, 255, 255, 0.1); }';
	$style = $style.'td.mid {vertical-align: middle; text-align: center; padding: 5px; border-top: 1px solid rgba(255, 255, 255, 0.1); border-left: 1px solid rgba(255, 255, 255, 0.2); border-right: 1px solid rgba(255, 255, 255, 0.2); }';
	$style = $style.'td.lst {vertical-align: middle; text-align: center; padding: 5px; border-right: 1px solid rgba(255, 255, 255, 0.2); border-top: 1px solid rgba(255, 255, 255, 0.1); }';
	$style = $style.'tr:last-child {border-bottom: 1px solid rgba(255, 255, 255, 0.2); }';
	$style = $style.'tr:nth-child(even) {  background-color: rgba(0, 0, 0, 0.2); }';	  
	$style = $style.'.th { color: rgb(255, 255, 255); background-color: rgb(160, 160, 0); font-weight:bold; background-image: linear-gradient(top,rgba(0,0,0,0) 0,rgba(0,0,0,0.3) 50%,rgba(0,0,0,0.3) 100%); background-image: -o-linear-gradient(top,rgba(0,0,0,0) 0,rgba(0,0,0,0.3) 50%,rgba(0,0,0,0.3) 100%); background-image: -moz-linear-gradient(top,rgba(0,0,0,0) 0,rgba(0,0,0,0.3) 50%,rgba(0,0,0,0.3) 100%); background-image: -webkit-linear-gradient(top,rgba(0,0,0,0) 0,rgba(0,0,0,0.3) 50%,rgba(0,0,0,0.3) 100%); background-image: -ms-linear-gradient(top,rgba(0,0,0,0) 0,rgba(0,0,0,0.3) 50%,rgba(0,0,0,0.3) 100%); }';
	$style = $style.'.num { font-size: 48px;color: rgb(160,160,0)}';
	$style = $style.'.mon { text-transform: uppercase; }';
	# SCALE
	$style = $style.'.scale {clear:both;display: inline-block;width: 8px;height: 8px;margin-left: 2px; border: solid 1px rgba(255, 255, 255, 0.2)}';
	$style = $style.'.square1 { background-color: darkgreen;}';
	$style = $style.'.square2 { background-color: green;}';
	$style = $style.'.square3 { background-color: greenyellow;}';
	$style = $style.'.square4 { background-color: gold;}';
	$style = $style.'.square5 { background-color: tomato;}';
	$style = $style.'.square6 { background-color: red;}';
	$style = $style.'.square7 { background-color: crimson;}';
	$style = $style.'</style>';
	// Tabelle bauen
	$html = $style;
	$html = $html.'<table>';
	// Header
	$html = $html.'<tr>';
	$html = $html."<td class='fst th'>Tag</td>";
	$size = sizeof($pollination);
	$index = 0;
	foreach($pollination as $key => $value) {
		if($index == $size-1) {
			$html = $html."<td class='lst th'>$key</td>";
		}
		else {
			$html = $html."<td class='mid th'>$key</td>";
		}
		$index++; 
	}
	$html = $html.'</tr>';
	// Datenzeilen
	$st = $time;
	for($i = 0; $i < $days; $i++) {
		// zeit
		$wd = $day[date("w", $st)];
		$md = date("j", $st);
		$mo = date("F", $st);
		$mo = strtr($mo, $trans);
		$item_day ='<div class=\'day\'>'.$wd.'</div><div class=\'num\'>'.$md.'</div><div class=\'mon\'>'.$mo.'</div>';
		// pollen
		$html = $html.'<tr><td class=\'fst\'>'.$item_day.'</td>';
		$index = 0;
		foreach($pollination as $key => $value) {
			if($index == $size-1) {
				$html = $html."<td class='lst th'>$key</td>";
			}
			else {
				$html = $html."<td class='mid'>".GetScale($key, $value[$i])."</td>";
			}
		}
		$html = $html.'</tr>';
		// Plus ein Tag
		$st = $st+ 86400;
	}

	$html = $html.'</table>';
	// HTML ausgeben
	$vid = CreateVariableByName($_IPS['SELF'], "Vorhersage", 3);
	SetValue($vid, $html);
}

function BuildText($pollination) {
	// Vorhersage für geringe Belastung
	$gb_text = "";
	// Vorhersage für mittlere Belastung
	$mb_text = "";
	// Vorhersage für hohe Belastung
	$hb_text = "";
	// Belastung durch ???
	foreach($pollination as $key => $value) {
		switch ($value[0]) {
			case '0-1':
				$gb_text = $gb_text . $key.' ';
				break;
			case '1':
			case '1-2':
			case '2':
				$mb_text = $mb_text . $key.' ';
				break;
			case '2-3':
			case '3':
				$hb_text = $hb_text . $key.' ';
				break;
		}
	}
	// Ansagetext zusammen stellen
	if ($gb_text !== "") {$gb_text = "Geringe Belastung durch " . str_replace(" ", ", ", trim($gb_text) . ".");}
	if ($mb_text !== "") {$mb_text = "Mittlere Belastung durch " . str_replace(" ", ", ", trim($mb_text) . ".");}
	if ($hb_text !== "") {$hb_text = "Hohe Belastung durch " . str_replace(" ", ", ", trim($hb_text) . ".");}
	$text = "";
	if ($gb_text !== "") {$text = trim($gb_text) . " " ;}
	if ($mb_text !== "") {$text = $text . trim($mb_text) . " ";}
	if ($hb_text !== "") {$text = $text . trim($hb_text) . " ";}
	// Text ausgeben
	$vid = CreateVariableByName($_IPS['SELF'], "Tageshinweis", 3);
	SetValue($vid, $text);
}

function GetScale($type, $value) {
	# Level
	$asso = array('-1'=>0,'0'=>1,'0-1'=>2,'1'=>3,'1-2'=>4,'2'=>5,'2-3'=>6,'3'=>7);
	# Text
	$text = array('-1'=>'nicht bekannt','0'=>'keine','0-1'=>'keine bis gering','1'=>'gering','1-2'=>'gering bis mittel','2'=>'mittel','2-3'=>'mittel bis hoch','3'=>'hoch');
	# Style Klasse
	$class = strtolower($type);
	$level = $asso[$value];
	$div = '<div style=\'clear:both\'>'.$text[$value].'</div><div class=\''.$class.'\'></div><div>';
	for ($i = 1; $i <= 7; $i++) {
		if($i <= $level) {
			$div = $div.'<span class=\'scale square'.$i.'\'></span>';
		}
		else {
			$div = $div.'<span class="scale"></span>';
		}
	}
	$div = $div.'</div>';
	return $div;
}

?>

Sieht bei mir so aus …

Viel Spaß
Heiko

Cool,

läuft promt!

Danke

hardlog

Ganz herzlichen Dank, zum Glück bin ich selber nicht allergisch, kann ich dennoch sehr gut gebrauchen.

Wow, dickes Dankeschön läuft super.

Gruß Torsten

Gesendet von iPhone mit Tapatalk

Bitteschön, geht mir ähnlich, aber meine Mädl’s schauen drauf :wink:

Dafür installiere ich jetzt mal Dein Echo Remote, Danke zurück!

Gruß
Heiko

Klitze Kleinigkeit ;), vielleicht kannst Du Letzte und Nächste Aktualisierung auch gleich das Variablenprofile ~UnixTimestampTime zuweisen.

Ah - ja - Mist, hatte ich bei der Entwicklung schon per Hand gemacht und darum vergessen!

Kommt mit nächsten Update, Danke!

Ciao Heiko

Hallo Heiko,

der Dank meiner 3 Mädels wird Dir ewig nachschleichen. :smiley:

Installiert, Bundesland eingestellt und läuft sofort. Vielen, herzlichen Dank für Deine Arbeit, echt Klasse.

Anbei mal ein Bild, wie das Ganze in IPSStudio aussehen kann, ich bin echt begeistert:

Viele Grüße,

Burkhard

Super! Habe die Version aus #12 installiert und geht auf Anhieb. Vielen Dank!

Eine Kleinigkeit: Bei mir zeigt das Webfront jedesmal ein Pop-Up mit „Fehler“ wenn uch an den Gebietseinstellungen etwas ändere. Es scheint aber trotzdem zu funktionieren. Ist das nur bei mir so, oder wohnt ihr alle auf den Default-Inseln und habt es noch nicht bemerkt?