.wertstoffhof-container{max-width:700px;margin:0 auto;padding:clamp(1rem,3vw,2rem)var(--container-padding);contain:layout style}.wsh{color-scheme:light;background:#fff;color:#333;border:1px solid #e9ecef;border-radius:8px;padding:1rem;margin-bottom:20px;box-shadow:0 2px 4px rgba(0,0,0,.1);contain:layout style}.wsh h2,.wsh h3{color:var(--color-primary);margin-bottom:1rem}.wsh a{color:var(--color-primary)}.wsh a:hover{color:var(--color-primary-dark)}.wertstoffhof-header{text-align:center;margin-bottom:1.5rem;padding:1rem 0;border-bottom:2px solid #e9ecef}.wertstoffhof-header h1{font-size:clamp(1.4rem,2vw + .8rem,1.8rem);color:var(--color-text);margin-bottom:.5rem;font-weight:700}.location-info{font-size:1.05rem;color:#6c757d;font-weight:500}.location-info p{margin:0}.wertstoffhof-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,7%);margin-bottom:1.5rem;overflow:hidden;display:flex;flex-direction:column;height:100%;transition:var(--transition-standard)}.wertstoffhof-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px rgba(0,0,0,.12);border-color:var(--color-primary)}.card-header{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:1rem;margin:0;font-size:1.2rem;font-weight:600;border:none}.card-body{padding:1rem}.wertstoffhof-card.contact-card{padding:1.5rem;text-align:center}.wertstoffhof-card.contact-card h2{font-size:1.3rem;margin-bottom:1rem}.wertstoffhof-card.contact-card p{font-size:1.15rem;color:#2d3748;font-weight:500;margin-bottom:1.5rem;line-height:1.5}.wertstoffhof-card.contact-card .maps-link a{display:inline-block;padding:12px 24px;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:var(--transition-standard);box-shadow:0 2px 8px rgba(0,123,255,.3)}.wertstoffhof-card.contact-card .maps-link a:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,123,255,.4);color:#fff;text-decoration:none}.wertstoffhof-container .card,.wertstoffhof-container .wsh.contact-card{max-width:none;margin-left:auto;margin-right:auto}.status-banner{display:flex;align-items:center;padding:1rem;margin:1.5rem 0;border-radius:12px;border-left:5px solid;box-shadow:0 2px 4px rgba(0,0,0,.1)}.status-geschlossen{background-color:#fef2f2;border-left-color:#dc2626;color:#991b1b}.status-eingeschränkt{background-color:#fffbeb;border-left-color:#d97706;color:#92400e}.status-icon{font-size:1.5rem;margin-right:1rem;flex-shrink:0}.status-content{flex:1}.status-content h3{margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.status-content p{margin:.25rem 0;font-size:.95rem;line-height:1.4}.oeffnungszeiten-section{margin-bottom:2rem}.table-responsive-wrapper{overflow-x:auto}.opening-hours-table,.oeffnungszeiten-table{width:100%;margin-bottom:0;border-collapse:collapse}.opening-hours-table th,.oeffnungszeiten-table th{border:none;padding:12px 15px;font-weight:600;text-align:left;color:#495057;border-bottom:2px solid #dee2e6}.opening-hours-table td,.oeffnungszeiten-table td{border:none;padding:12px 15px;vertical-align:middle;border-bottom:1px solid #e9ecef}.opening-hours-table tbody tr:hover,.oeffnungszeiten-table tbody tr:hover{background:#f8f9fa}.opening-hours-table .geschlossen,.oeffnungszeiten-table .geschlossen{color:#adb5bd;font-style:italic}.opening-hours-table .geoeffnet,.oeffnungszeiten-table .geoeffnet{color:#28a745;font-weight:500}.opening-hours-table tr.heute,.opening-hours-table tr.current-day,.opening-hours-table tr.today,.opening-hours-table tr.heute-zeile,.oeffnungszeiten-table tr.heute,.oeffnungszeiten-table tr.current-day,.oeffnungszeiten-table tr.today,.oeffnungszeiten-table tr.heute-zeile{background:linear-gradient(90deg,rgba(255,193,7,.12) 0%,rgba(255,193,7,3%) 100%);border-left:4px solid #ffc107;box-shadow:0 1px 6px rgba(255,193,7,.15)}.opening-hours-table tr.heute td,.opening-hours-table tr.current-day td,.opening-hours-table tr.today td,.opening-hours-table tr.heute-zeile td,.oeffnungszeiten-table tr.heute td,.oeffnungszeiten-table tr.current-day td,.oeffnungszeiten-table tr.today td,.oeffnungszeiten-table tr.heute-zeile td{color:#e0a800;font-weight:600}.opening-hours-table tr.heute td:first-child,.opening-hours-table tr.current-day td:first-child,.opening-hours-table tr.today td:first-child,.opening-hours-table tr.heute-zeile td:first-child,.oeffnungszeiten-table tr.heute td:first-child,.oeffnungszeiten-table tr.current-day td:first-child,.oeffnungszeiten-table tr.today td:first-child,.oeffnungszeiten-table tr.heute-zeile td:first-child{font-weight:700}.opening-hours-table tr.heute td:first-child::after,.opening-hours-table tr.current-day td:first-child::after,.opening-hours-table tr.today td:first-child::after,.opening-hours-table tr.heute-zeile td:first-child::after,.oeffnungszeiten-table tr.heute td:first-child::after,.oeffnungszeiten-table tr.current-day td:first-child::after,.oeffnungszeiten-table tr.today td:first-child::after,.oeffnungszeiten-table tr.heute-zeile td:first-child::after{content:" \1F4CD";font-size:12px;margin-left:6px}.oeffnungszeit-zeile.heute{background-color:#e8f5e8;border-left:4px solid #28a745;font-weight:700}.current-day .tag-name{color:#28a745;font-weight:700}.heute-status{margin-top:15px;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #28a745;font-weight:700}.heute-status.geoeffnet{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;border-left:4px solid #28a745}.heute-status.geschlossen{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-left:4px solid #dc3545}.heute-info{font-size:1.1rem}.heute-info strong{color:#28a745}.zeiten-detail{color:#666;font-size:.9rem}.heute-status-special{background:#e3f2fd;border:1px solid #2196f3;border-radius:8px;padding:12px;margin:15px 0;font-weight:700;text-align:center}.oeffnungszeiten-tabelle tr.heute-geoeffnet{background-color:#d4edda}.oeffnungszeiten-tabelle tr.heute-geschlossen{background-color:#f8d7da}.naechste-oeffnung{margin-top:10px;padding:8px;background-color:#e2e3e5;border-radius:4px;font-style:italic}.saison-info,.season-info{background:#e3f2fd;border:1px solid #bee5eb;border-radius:6px;padding:.75rem 1rem;margin:10px 0;font-weight:700;color:#1976d2}.andere-saison-hinweis{margin-top:1.5rem}.andere-saison-hinweis details{border:1px solid #dee2e6;border-radius:6px;padding:1rem}.andere-saison-hinweis summary{cursor:pointer;font-weight:500;color:#007bff;margin-bottom:1rem}.andere-saison-hinweis summary:hover{color:#0056b3}.season-toggle summary{cursor:pointer;padding:10px;background:#f5f5f5;border-radius:4px;margin:15px 0 5px;color:#007bff;font-weight:500}.season-toggle summary:hover{background:#e9ecef;color:#0056b3}.season-toggle[open] summary{margin-bottom:10px;background:#e9ecef}.alternative-season{opacity:.8;border:1px dashed #ccc;margin-top:10px}.alternative-season thead{background:#f9f9f9}.oeffnungszeiten-hinweise{margin-top:15px}.oeffnungszeiten-hinweis{background:#d1ecf1;border:1px solid #bee5eb;border-radius:6px;padding:.75rem 1rem;margin:.5rem 0;color:#0c5460;font-size:.9rem;display:flex;align-items:center}.oeffnungszeiten-hinweis:first-child{margin-top:0}.oeffnungszeiten-hinweis:last-child{margin-bottom:0}.oeffnungszeiten-hinweis [class*=emoji],.oeffnungszeiten-hinweis span[title]{margin-right:.5rem}.special-rule{font-size:.9rem;color:#6c757d;font-style:italic}.regel-hinweis{background:#fff3cd;padding:2px 6px;border-radius:3px;color:#856404;font-weight:500}@media(max-width:768px){.oeffnungszeiten-table th:last-child,.oeffnungszeiten-table td:last-child{display:none}.oeffnungszeiten-hinweis{font-size:.85rem;padding:.6rem .8rem}}.angenommene-wertstoffe-section{margin-bottom:2rem}.wertstoff-liste{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.wertstoff-liste li{background:#f8f9fa;border:none;border-left:4px solid #28a745;border-radius:4px;padding:.5rem 1rem;transition:background-color .2s ease}.wertstoff-liste li:hover{background:#e9ecef}.wertstoff-liste li::before{content:none}.kostenpflichtige-section{margin-top:2rem}.wertstoffe-section.spezial{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin:1.5rem 0}.wertstoffe-section.spezial h3{color:#1e293b;margin-bottom:1rem}.wertstoff-item.spezial{background:#f1f5f9;border:1px solid #cbd5e1}.wertstoff-hinweis{font-size:.75rem;color:#dc2626;font-weight:500;margin-top:.25rem;text-align:center;background:#fef2f2;padding:.2rem .4rem;border-radius:4px}.wertstoffe-section.nicht-verfügbar{background:#fafafa;border:1px solid #e5e5e5;border-radius:8px;padding:1.5rem;margin:1.5rem 0}.nicht-verfügbar-grid{display:grid;gap:1rem;margin-top:1rem}.nicht-verfügbar-item{background:#fff;border:1px solid #e5e5e5;border-radius:6px;padding:1rem}.nicht-verfügbar-item .wertstoff-header{display:flex;align-items:center;margin-bottom:.5rem}.nicht-verfügbar-item .wertstoff-name{font-weight:600;color:#374151}.grund{color:#6b7280;font-size:.9rem;margin-bottom:.5rem}.standorte-liste{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.standort-tag{background:#f3f4f6;color:#374151;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;border:1px solid #d1d5db}.mehr-standorte{background:#f9fafb;color:#6b7280;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-style:italic;border:1px solid #e5e7eb}.abfall-abc-verweis{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:1rem;margin-top:1rem}.abfall-abc-verweis a{color:#1e40af;text-decoration:none;font-weight:600}.abfall-abc-verweis a:hover{text-decoration:underline}.alternative-standorte{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f3f4f6}.alternative-standorte strong{color:#374151;font-size:.9rem}.service-level-section{margin:2rem 0;padding:1.5rem;background:linear-gradient(135deg,#f8f9ff 0%,#f0f4ff 100%);border:2px solid #2196f3;border-radius:12px}.service-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;text-align:center}.stat-item{padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);border:2px solid #e3f2fd}.stat-item.total{border-color:#2196f3;background:linear-gradient(135deg,#e3f2fd 0%,#f0f8ff 100%)}.stat-number{display:block;font-size:clamp(1.4rem,2vw,2rem);font-weight:700;color:#1976d2;margin-bottom:.5rem}.stat-label{display:block;font-size:.9rem;color:#666;font-weight:500}.info-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:clamp(16px,3vw,20px);margin-top:20px}.info-card h2{color:#495057;margin-bottom:20px;font-size:1.25rem}.info-card h3{color:#6c757d;margin-bottom:12px;font-size:1.1rem}.hinweise-section{margin-bottom:20px}.hinweise-liste{list-style:none;padding:0;margin:0}.website-section{margin-top:20px}.website-link-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.1)}.website-link{display:flex;align-items:center;padding:clamp(12px,2vw,16px);text-decoration:none;color:inherit;transition:background-color .2s ease}.website-link:hover{background-color:#f8f9fa;text-decoration:none;color:inherit}.website-info{flex:1}.website-name{font-weight:600;color:var(--color-primary);margin-bottom:4px;font-size:1.05rem}.website-description{color:#6c757d;font-size:.9rem;line-height:1.4}.external-icon{color:#6c757d;margin-left:12px;flex-shrink:0}.website-link:hover .external-icon{color:var(--color-primary)}a.service-btn.primary{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;text-decoration:none}a.service-btn.primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff;text-decoration:none}a.service-btn.primary:visited{color:#fff}.wertstoffhof-overview-container{max-width:800px;margin:0 auto;padding:clamp(1rem,3vw,2rem)var(--container-padding)}.wertstoffhof-overview-container .alphabet-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:15px;margin-bottom:20px;background:#fff;border:1px solid #e9ecef;border-radius:6px;box-shadow:var(--box-shadow-small)}.wertstoffhof-overview-container .alphabet-tab{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:8px 12px;cursor:pointer;font-weight:600;color:#495057;transition:var(--transition-standard);font-size:14px;min-width:44px;height:40px}.wertstoffhof-overview-container .alphabet-tab:hover{background:#e9ecef;transform:translateY(-1px)}.wertstoffhof-overview-container .alphabet-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.wertstoffhof-overview-container .tab-count{font-weight:400;opacity:.8;font-size:12px;margin-left:4px}.wertstoffhof-overview-container .alphabet-info{color:#6c757d;font-size:.9rem;margin-bottom:1rem}.wertstoffhoefe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:1.25rem;margin-bottom:3rem}.wertstoffhof-card-header{padding:1.25rem 1.25rem .75rem}.wertstoffhof-card-header h3{margin:0;font-size:1.15rem;font-weight:600;line-height:1.4}.wertstoffhof-card-header h3 a{color:#2d3748;text-decoration:none;transition:color .2s ease}.wertstoffhof-card-header h3 a:hover{color:var(--color-primary)}.wertstoffhof-card-body{display:flex;flex-direction:column;flex:1;padding:1.25rem}.wertstoffhof-address{flex-grow:1;margin-bottom:1rem;font-size:.95rem;line-height:1.6}.wertstoffhof-address a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.wertstoffhof-address a:hover{color:var(--color-primary-dark);text-decoration:underline}.wertstoffhof-actions{margin-top:auto}.wertstoffhof-actions .btn{width:100%}@media(max-width:768px){.oeffnungszeiten-container{padding:2px;margin:16px 0;border-radius:10px}.oeffnungszeiten-container h3,.oeffnungszeiten-container h4{margin:-16px -16px 12px;padding:10px 12px;font-size:16px;border-radius:8px 8px 0 0}.oeffnungszeiten-table{font-size:14px;border-radius:6px}.oeffnungszeiten-table th{padding:10px 12px;font-size:14px}.oeffnungszeiten-table td{padding:10px 12px;font-size:14px;color:#495057;font-weight:400}.oeffnungszeiten-table td:first-child{width:25%;font-size:13px;font-weight:600}.oeffnungszeiten-table td:last-child{width:75%;font-size:13px;color:#495057;font-weight:400;text-align:center}.oeffnungszeiten-table td.closed{color:#dc3545;font-weight:600;font-style:italic}}@media(max-width:480px){.oeffnungszeiten-container{padding:2px;margin:12px 0;border-radius:8px}.oeffnungszeiten-container h3,.oeffnungszeiten-container h4{margin:-12px -12px 10px;padding:8px 10px;font-size:15px;border-radius:6px 6px 0 0}.oeffnungszeiten-table th,.oeffnungszeiten-table td{padding:8px 10px;font-size:13px}.oeffnungszeiten-table td:first-child{width:35%;font-weight:600}.oeffnungszeiten-table td:last-child{width:65%;font-size:12px;color:#495057;font-weight:400}.oeffnungszeiten-table tr.heute td:first-child::after,.oeffnungszeiten-table tr.heute-zeile td:first-child::after,.oeffnungszeiten-table tr.current-day td:first-child::after,.oeffnungszeiten-table tr.today td:first-child::after{font-size:11px;margin-left:4px}}.wsh a:hover,.wertstoff-link:hover{background-color:#28a745!important;color:#fff!important;border-color:#28a745!important;box-shadow:0 1px 1px rgba(0,0,0,.1),0 2px 2px rgba(0,0,0,.1),0 4px 4px rgba(0,0,0,.1),0 8px 8px rgba(0,0,0,.1),0 16px 16px rgba(0,0,0,.1)!important;transform:translateY(-2px)!important;text-decoration:none!important}.wsh a,.wertstoff-link{transition:all .2s ease!important}.wsh a::after,.wertstoff-link::after{content:"";display:block;position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border:1px solid rgba(255,0,0,.3);border-radius:10px;pointer-events:none;opacity:.5}@keyframes removeDebugBorder{0%{opacity:.5}100%{opacity:0;display:none}}.wsh a::after,.wertstoff-link::after{animation:removeDebugBorder 3s forwards .5s}