Pollenflug Vorhersage von DWD auslesen

Vielen Dank für das tolle Skript und die super Optik!

Auf einem IPS Light Skin sieht das ganze dann so aus:

vielleicht färbe ich den hellgrauen Hintergrund noch auf anthrazit. aber ansonsten SUPER!

Hallo Heiko,

vielen Dank für dein tolles Skript, welches ich in IPSView integriert habe. Eine genauso tolle Arbeit wie das DWD Skript, die Meldungsanzeige und das Log Message Skript :slight_smile:

Wenn man sowohl das Bundesland als auch die Region in IPSView mittels Association Buttons implementiert wird man feststellen, dass nach Änderung des Bundeslandes die Region in IPSView nicht geändert wird, obwohl dies im WebFront der Fall ist.

Ich habe dieses Problem hier IPSView synchronisiert nicht die Assoziationen bei Profiländerungen Andreas gemeldet.

Gruß
Hans

Hallo Hans, jetzt wo Du so einiges aufzählst - vielen herzlichen Danke - die Sammlung wächst :smiley:

Dann hoffe ich mal das dafür auch noch eine Lösung gefunden wird. Zum Glück muss man diese Einstellung nicht so oft vornehmen!

Viele Grüße
Heiko

Moin,

da sich IPSView leider bezüglich der Synchronisation von Assoziationen nicht exakt so verhält wie das WF, stelle ich hier in Absprache mit Heiko eine Version zur Verfügung, die auch eine Änderung der Region unter IPSView berücksichtigt. Wer Region und Bundesland fest verdrahtet hat braucht diese Version natürlich nicht :wink:

Näheres hatte ich bei Andreas hier IPSView synchronisiert nicht die Assoziationen bei Profiländerungen nachgefragt. Sollte Andreas IPSView irgendwann doch mit dem WF kompatibel gestalten, dann kann natürlich zur Originalversion von pitti zurückgekehrt werden.

<? 
################################################################################ 
# Scriptbezeichnung: Online.Pollination.ips.php 
# Version:    1.1.20180826 
# Author:    Heiko Wilknitz (@pitti) 
# 
# Abruf des Pollenflug-Gefahrenindex von DWD (opendata.dwd.de). 
# 
# ------------------------------- Changelog  ----------------------------------- 
# 
# 1.0.20180825 
#     -- Initalversion 
# 1.1.20180826 
#     -- Letze und Nächste Aktualisierung jetzt mit Timestamp-Profil 
#     -- Zuordnung für geringe Belastung im Tageshinweis angepasst 
#     -- Fix function CreateProfileInteger für PHP 7 
#     -- Steuerung der darzustellende Tage über Variable 
# 1.1.20180829 
#     -- Version mit Unterstützung der Region unter IPSView durch eine weitere
#        Variable Region_IPSView mit Profil Pollen.IPSView PC Oldie (Hans)
#
# 
# ------------------------------- 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,Region und Tage über Dummy Modul (Einstellungen) 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'; 
# 
################################################################################ 
 
# Ablaufsteuerung  
switch ($_IPS['SENDER']) { 
    // INSTALL & INITIALIZE  
    case 'Execute': 
        Install($dataURL, $calURL); 
        UpdateData($dataURL); 
        break; 
    // AKTION VIA TIMER  
    case 'TimerEvent': 
        // Update Daten Speicher 
        UpdateData($dataURL); 
        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']); 

            //**************** IPSView Ergänzungen Start ***********************
            // IPSView Profil Assoziationen zunächst löschen
            $vpIPSView = IPS_GetVariableProfile("Pollen.IPSView");
            foreach ($vpIPSView['Associations'] as $asso) { 
                IPS_SetVariableProfileAssociation("Pollen.IPSView", $asso['Value'], "", "", -1);
            }
            // IPSView Profil aktualisieren und automatisch erstes auswählen
            foreach ($vp['Associations'] as $asso) { 
                IPS_SetVariableProfileAssociation("Pollen.IPSView", $asso['Value'], $asso['Name'], $asso['Icon'], $asso['Color']);
            }
            $vidIPSView = CreateVariableByName($_IPS['SELF'], "Region_IPSView", 1); 
            SetValue($vidIPSView, $vp['Associations'][0]['Value']); 
            //**************** IPSView Ergänzungen Ende ************************
        } 

        //**************** IPSView Ergänzungen Start ***************************
        // Region WebFront nach Region_IPSView
        if (IPS_GetName($_IPS['VARIABLE']) == 'Region') { 
            $vid = CreateVariableByName($_IPS['SELF'], "Region", 1); 
            $vidIPSView = CreateVariableByName($_IPS['SELF'], "Region_IPSView", 1); 
            SetValue($vidIPSView, GetValue($vid)); 
        } 

        // Region IPSView nach Region WebFront
        if (IPS_GetName($_IPS['VARIABLE']) == 'Region_IPSView') { 
            $vid = CreateVariableByName($_IPS['SELF'], "Region", 1); 
            $vidIPSView = CreateVariableByName($_IPS['SELF'], "Region_IPSView", 1); 
            SetValue($vid, GetValue($vidIPSView)); 
        } 
        //**************** IPSView Ergänzungen Ende ***************************

        // Immer machen! 
        UpdateData($dataURL); 
        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(($asso !== NULL) && (sizeof($asso) !== 0)){ 
        $minvalue = 0; 
        $maxvalue = 0; 
    }  
    IPS_SetVariableProfileValues($name, $minvalue, $maxvalue, $step); 
     
    if(($asso !== NULL) && (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_SetVariableCustomProfile($vid, '~UnixTimestamp'); 
    IPS_SetIcon($vid, 'Calendar'); 
    IPS_SetPosition($vid, $pos++); 
    $vid = CreateVariableByName($_IPS['SELF'], 'Nächste Aktualisierung', 1); 
    IPS_SetVariableCustomProfile($vid, '~UnixTimestamp'); 
    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++); 
    // Darzustellende Tage 
    $vid = CreateVariableByName($_IPS['SELF'], "Darzustellende Tage", 1); 
    $vpn = "Pollen.Tage"; 
    CreateProfileInteger($vpn, 'Calendar', '', '', 1, 3, 1, 0, NULL); 
    IPS_SetVariableCustomProfile($vid, $vpn); 
    IPS_SetVariableCustomAction($vid, $_IPS['SELF']); 
    IPS_SetPosition($vid, $pos++); 
    SetValue($vid, 2); 
    // 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%;\' \>'); 

    //**************** IPSView Ergänzungen Start *******************************
    // Variable Region_IPSView mit Profil Pollen.IPSView
    $vid = CreateVariableByName($_IPS['SELF'], "Region_IPSView", 1); 
    $vpn = "Pollen.IPSView"; 
    CreateProfileInteger($vpn, 'Macro', '', '', 0, 0, 0, 0, NULL); 
    IPS_SetVariableCustomProfile($vid, $vpn); 
    IPS_SetVariableCustomAction($vid, $_IPS['SELF']); 
    IPS_SetPosition($vid, $pos++); 
    //**************** IPSView Ergänzungen Ende *******************************
} 

// Holt täglich die Pollenfluginformationen und extrahiert für die  
// eingestellte Region die Daten! 
function UpdateData($url) { 
    // 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); 
            // Setze Tagesvorhersage 
            BuildText($pollination); 
            break; 
        }  
    }  
} 

function BuildHtml($pollination, $time) { 
    # 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 
    $vid = CreateVariableByName($_IPS['SELF'], "Darzustellende Tage", 1); 
    $days = GetValue($vid); 
    $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': 
            case '1': 
                $gb_text = $gb_text . $key.' '; 
                break; 
            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; 
} 

?>

Viel Spaß.

Hans

Hallo Heiko,

eine Kleinigkeit ist mir noch aufgefallen. Wenn ich die Anzahl der Tage der Vorhersage auf 3 setze, wird für den 3. Tag bei der Pollenbelastung für,alle,Pollenarten „nicht bekannt“ angegeben.

Kann das die Json Datei überhaupt ausgeben? Es steht heute z.b. drin

"dayafter_to":"-1"

In der DWD Beschreibung heißt es

Fehlende Werte werden mit einer -1 gekennzeichnet.

Sind dann zufällig nur an einzelnen Tagen keine Daten für den übernächsten Tag enthalten?

Hallo Heiko.

Im Namen meiner Mädels vielen Dank für das nützliche Skript. Hat auf Anhieb funktioniert und sieht wirklich gut aus.

Hallo Heiko,

auch von mir vielen Dank. :slight_smile:
Sehe zwar noch Fehler im Webfront (Popup: Fehler) bei Einstellungen, läuft aber.

Wenn ich zum suchen komme (Zeit finde), melde ich was los ist.

Thomas, lösch die Leerzeichen vom Kopieren vor und nach den <> :p.

Jupp Ralf,

und wieder mal reingefallen.:smiley:
Nur schnell kopiert und probiert, so ein blödes Leerzeichen springt mir nicht sofort ins Auge.:confused:

Eigentlich müsste @paresy die automatisch raus filtern. Das würde eine ganze Menge Fragen reduzieren :).

Ich würde empfehlen einfach das abschließende PHP-Symbol (?>) zu entfernen. Wir werden demnächst auch den initialen Skript-Inhalt anpassen und das Symbol entfernen.

Hi AKL,

das war der Grund für den Auswahlschalter der anzuzeigenden Tage. Für meine Gegend gibt es auch nur sinnvolle Werte für 2 Tage. Aber da ich nicht alle Gebiete ausprobiert habe wollte ich es auch nicht einfach auf 2 Tage begrenzen.

Wie genau die Datenerstellung bei DWD funktioniert kann ich Dir leider nicht sagen :frowning: Das JSON gibt halt die Möglichkeit für 3 Tage her!

Gruß Heiko

Hallo Pitti,

welchen Wert trägt man in die Region ein außerhalb von Inseln und Geest? 0 ist hier nicht erlaubt.

Grüße, Gerhard

Hi Gerhard,

kannst Du mal genau sagen was Du machen/haben möchtest. Ich nehme mal an Du wohnst in dem Gebiet/Bundesland „Schleswig-Holstein und Hamburg“.
Dannach kannst Du als Region „Inseln und Marschen“ oder „Geest, Schleswig-Holstein und Hamburg“ auswählen.
Oder anders ausgedrückt „Schleswig-Holstein und Hamburg“ ist nur in 2 Regionen unterteilt - mehr gibt es da nicht und Du musst Dich für eins entscheiden.

Oder habe ich da was falsch verstanden?

Gruß Heiko

Hallo Heiko,

ich wohne in Rheinland Pfalz. Das Bundesland kann ich einstellen. Damit sollte die Region keine Rolle spielen. Ich kann aber in der Region keine 0 eintragen, da dort nur 2 Werte erlaubt sind.

Grüße, Gerhard

Hi Gerhard,

habe das gleich mal ausgewählt (siehe Screen). Da kann man dann doch 3 Regionen auswählen? Irgendwie verstehe ich es nicht :frowning:

Ciao Heiko

Hallo Heiko,

ich hatte die Einstellungen im Objektbaum vorgenommen und da kam dann die Fehlermeldung. Nun habe ich die wichtigen Einstellungen in das Webfront gestellt und nochmals neu ausgewählt: alles ist gut.

Danke für das Programm, Gerhard

Hallo Gerhard,

ah, ja, jetzt, eine Insel :wink: Alles klar, freut mich!

Ciao Heiko

Hallo pitti,

ich habe die grandiose Darstellung der Pollenflugbelastung mit DWD-Daten hier gesehen. Ich möchte sie gern für meine Plattform ioBroker verwenden und im ioBroker-Forum auch veröffentlichen. Wenn ich das richtig sehe, kommen die SVG von dir. Daher frage ich dich als Urheber nach dem Nutzungsrecht.

Im Anhang liegt ein Screenshot. Etwa so wird es dann aussehen.

Viele Grüße
Pix

Hi Pix,

nee, so ein guter Designer bin ich nicht :rolleyes:

Die Icons waren „Free license“ von flaticon.com. Habe gerade nochmal geschaut. Man muss entweder ein Link zu freeicon.com setzen oder in den „credits/description page“ mit aufnehmen. Werde ich gleich auch mal in den Header mit aufnehmen :smiley:

Das sollte dann so aussehen: "Icon made by Freepik from Free vector icons - SVG, PSD, PNG, EPS & Icon Font - Thousands of free icons "

Ciao Heiko