/* DESIGN-NEUERUNG: MODERNES "LIQUID GLASS" DESIGN SYSTEM */
:root {
  --col-left: 420px;
  --col-right: 500px;
  --col-gap: 30px;
  --page-max: calc(var(--col-left) + var(--col-right) + var(--col-gap)); /* 950px */
}

:root, html[data-theme='dark'] {
    --bg-color: #10102E;
    --primary: #6a63f5;
    --primary-light: #8a84ff;
    --secondary: rgba(44, 41, 102, 0.4);
    --secondary-light: rgba(44, 41, 102, 0.2);
    --accent: #00aaff;
    --accent-gradient: linear-gradient(45deg, #00aaff, #00ffc4);
    --text-primary: #f0f0f8;
    --text-secondary: #a8a4e4;
    --border-color: rgba(138, 132, 255, 0.2);
    --shadow-color: rgba(0, 0, 0, 0.3);
    --input-bg: rgba(0, 0, 0, 0.25);
    --thumb-bg: var(--text-primary);
    --map-bg: rgba(0,0,0,0.25);
    --review-bg: rgba(0,0,0,0.2);
}

html[data-theme='light'] {
    --bg-color: #f0f2f5;
    --primary: #5a52e1;
    --primary-light: #7972ff;
    --secondary: rgba(255, 255, 255, 0.5);
    --secondary-light: rgba(255, 255, 255, 0.6);
    --accent: #0077cc;
    --accent-gradient: linear-gradient(45deg, #0077cc, #00b894);
    --text-primary: #1c1c1e;
    --text-secondary: #5a5a5e;
    --border-color: rgba(0, 0, 0, 0.1);
    --shadow-color: rgba(0, 0, 0, 0.1);
    --input-bg: rgba(0, 0, 0, 0.05);
    --thumb-bg: var(--primary);
    --map-bg: #e9ecef;
    --review-bg: rgba(0, 0, 0, 0.04);
}

*, *::before, *::after { box-sizing: border-box; }

/* === Locked equal heights via CSS variable === */
:root { --locked-height: auto; }
.filters-container, .results-wrapper { height: var(--locked-height); flex: 0 0 auto; }
.results-wrapper { overflow: hidden; }
#result-container { display: flex; flex-direction: column; min-height: 0; }


@keyframes fadeIn {
    from { opacity: 0; transform: translateY(15px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes move-blob {
    0% { transform: translate(-50%, -50%) scale(1); border-radius: 50% 50% 30% 70% / 60% 40% 60% 40%; }
    25% { transform: translate(-45%, -55%) scale(1.1); border-radius: 70% 30% 50% 50% / 30% 30% 70% 70%; }
    50% { transform: translate(-50%, -50%) scale(1); border-radius: 40% 60% 70% 30% / 40% 70% 30% 60%; }
    75% { transform: translate(-55%, -45%) scale(1.1); border-radius: 30% 70% 40% 60% / 70% 40% 60% 30%; }
    100% { transform: translate(-50%, -50%) scale(1); border-radius: 50% 50% 30% 70% / 60% 40% 60% 40%; }
}

body {
    font-family: 'Poppins', sans-serif;
    margin: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 40px 20px;
    background-color: var(--bg-color);
    color: var(--text-primary);
    overflow-x: hidden;
    transition: background-color 0.3s ease, color 0.3s ease;
}

.background-blur {
    position: fixed; top: 50%; left: 50%;
    width: 60vw; height: 60vw;
    max-width: 800px; max-height: 800px;
    background: linear-gradient(160deg, var(--primary) 0%, var(--secondary) 100%);
    filter: blur(250px);
    opacity: 0.6;
    z-index: -1;
    animation: move-blob 25s ease-in-out infinite alternate;
}

.top-right-controls {
    position: fixed;
    top: 20px;
    right: 20px;
    display: flex;
    gap: 12px;
    align-items: center;
    z-index: 100;
}

.language-switcher {
    display: flex;
    gap: 8px;
    background-color: var(--secondary-light);
    padding: 6px;
    border-radius: 20px;
    border: 1px solid var(--border-color);
    backdrop-filter: blur(10px);
}
.language-switcher button {
    background: transparent; border: none;
    color: var(--text-secondary); font-family: 'Poppins', sans-serif; font-weight: 600;
    cursor: pointer; padding: 6px 12px; border-radius: 16px; transition: all 0.3s ease;
}
.language-switcher button.active {
    background-color: var(--primary); color: var(--text-primary);
    box-shadow: 0 2px 8px rgba(106, 99, 245, 0.4);
}
.language-switcher button:not(.active):hover { background-color: rgba(138, 132, 255, 0.2); }

.theme-toggle {
    background-color: var(--secondary-light);
    border: 1px solid var(--border-color);
    width: 42px; height: 42px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    backdrop-filter: blur(10px);
    transition: all 0.3s ease;
    overflow: hidden;
}
.theme-toggle:hover {
    background-color: rgba(138, 132, 255, 0.2);
}
.theme-toggle svg {
    color: var(--text-secondary);
    transition: transform 0.4s ease-in-out;
    position: absolute;
}
.theme-toggle .sun { display: block; transform: translateY(150%); }
.theme-toggle .moon { display: block; transform: translateY(0); }

html[data-theme='light'] .theme-toggle .sun { transform: translateY(0); }
html[data-theme='light'] .theme-toggle .moon { transform: translateY(-150%); }

.main-content {
  max-width: var(--page-max);
  display: grid;
  grid-template-columns: 420px 500px;
  gap: 30px;
  align-items: start;
  justify-content: center;
  margin: 0 auto;
}

.container {
    background: var(--secondary);
    backdrop-filter: blur(30px); -webkit-backdrop-filter: blur(30px);
    border-radius: 24px;
    text-align: center;
    animation: fadeIn 0.6s ease-out forwards;
    transition: all 0.3s ease;
    border: 1px solid var(--border-color);
    box-shadow: 0 8px 30px rgba(0,0,0,0.25), inset 0 1px rgba(255,255,255,0.08);
}
.container:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.3);
}

.filters-container {
    width: 100%;
    padding: 28px;
}

.results-wrapper {
    position: relative; 
    min-height: 400px; 
    width: 100%;
    padding: 28px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

header h1 { font-weight: 700; font-size: 2.2em; margin: 0; }
header p { color: var(--text-secondary); margin: 5px 0 30px 0; font-weight: 500; letter-spacing: .2px;}
.filters { display: flex; flex-direction: column; gap: 18px; }

input[type="text"], select {
    width: 100%; padding: 14px 20px; border-radius: 12px;
    border: 1px solid var(--border-color);
    background: var(--input-bg);
    color: var(--text-primary); font-family: 'Poppins', sans-serif;
    font-size: 16px; transition: all 0.3s ease;
}

input[type="text"]::placeholder { color: var(--text-secondary); opacity: 0.7; }
input[type="text"]:focus, select:focus {
    outline: none; border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(0, 170, 255, 0.3);
}
select {
    appearance: none; -webkit-appearance: none;
    background-repeat: no-repeat;
    background-position: right 20px center;
}

select option { background-color: var(--bg-color); color: var(--text-primary); }

.filter-group {
    text-align: left; color: var(--text-secondary);
    padding: 12px 15px; border-radius: 12px;
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}
.filter-group:focus-within { border-color: rgba(138, 132, 255, 0.5); }
.filter-group label { display: block; margin-bottom: 8px; font-size: 14px; padding: 0 5px; color: var(--text-primary);  font-weight: 600; letter-spacing: .2px; }

.segmented-control {
  display: flex;
  background-color: var(--input-bg);
  border-radius: 10px;
  border: 1px solid var(--border-color);
  padding: 4px;
  overflow: hidden;
  gap: 4px;
}

.price-options input[type="checkbox"] {
  display: none;
}

.price-options label {
  flex: 1; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  padding: 8px 10px;
  cursor: pointer;
  border-radius: 8px;
  font-weight: 600;
  color: var(--text-secondary);
  transition: all 0.2s ease-in-out;
  margin-bottom: 0;
}

.price-options label:hover {
  background-color: var(--secondary-light);
  color: var(--text-primary);
}

.price-options input[type="checkbox"]:checked + label {
  background-color: var(--accent); 
  color: white;
  box-shadow: none;
  transform: none;
}

.star-rating-input { display: flex; gap: 5px; cursor: pointer; }
.star-rating-input .star {
  width: 28px;
  height: 28px;
  fill: var(--border-color); 
  transition: all 0.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.star-rating-input:hover .star {
  fill: var(--accent); 
  opacity: 0.6;
  transform: scale(1.1);
}

.star-rating-input .star:hover ~ .star {
  fill: var(--border-color); 
  opacity: 1;
  transform: scale(1);
}

.star-rating-input .star.selected {
  fill: #FFC107;
  opacity: 1; 
}
.open-now-filter { display: flex; justify-content: space-between; align-items: center; padding: 12px 5px; border: none; background: transparent; }
.open-now-filter label { margin: 0; cursor: pointer;}
input[type="checkbox"]#open-now-checkbox {
    appearance: none; -webkit-appearance: none;
    width: 44px; height: 24px; border-radius: 12px;
    background: var(--input-bg); cursor: pointer;
    position: relative; transition: all 0.3s ease;
    border: 1px solid var(--border-color);
}
input[type="checkbox"]#open-now-checkbox::before {
    content: ''; position: absolute; width: 18px; height: 18px;
    border-radius: 50%; background: var(--text-secondary);
    top: 2px; left: 3px;
    transition: all 0.3s ease;
}
input[type="checkbox"]#open-now-checkbox:checked { background-color: var(--accent); border-color: var(--accent); }
input[type="checkbox"]#open-now-checkbox:checked::before {
    transform: translateX(19px); background-color: white;
}

.slider { -webkit-appearance: none; width: 100%; height: 6px; background: var(--input-bg); outline: none; border-radius: 3px; margin-top: 10px; }
.slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: var(--accent); 
  cursor: pointer;
  border-radius: 50%;
  transition: transform 0.2s ease;
  border: none;
  box-shadow: 0 0 8px rgba(0, 170, 255, 0.5); 
}

.slider::-moz-range-thumb {
  width: 20px;
  height: 20px;
  background: var(--accent); 
  cursor: pointer;
  border-radius: 50%;
  border: none;
  box-shadow: 0 0 8px rgba(0, 170, 255, 0.5);
}

.slider::-webkit-slider-thumb:hover {
  transform: scale(1.15);
}
.slider::-moz-range-thumb:hover {
  transform: scale(1.15);
}

#find-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 15px;
    border: none;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    background: linear-gradient(90deg, var(--accent), var(--primary-light));
    background-size: 200% 100%;
    color: white;
    transition: background-position 0.4s ease, box-shadow .2s ease;
    margin-top: 10px;
    box-shadow: 0 4px 15px rgba(0, 170, 255, 0.3);
}
#find-btn:hover { background-position: right center; box-shadow: 0 8px 24px rgba(0,170,255,0.30); }

.initial-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    height: 100%;
    color: var(--text-secondary);
    animation: fadeIn 0.8s ease-out;
}
.initial-state svg { width: 80px; height: 80px; opacity: 0.5; }
.initial-state h3 { font-size: 1.5em; margin: 0; color: var(--text-primary); }
.initial-state p { margin: 0; max-width: 300px; }

@keyframes pulse { 0% { transform: scale(0.9); box-shadow: 0 0 0 0 rgba(138, 132, 255, 0.7); } 70% { transform: scale(1); box-shadow: 0 0 0 20px rgba(138, 132, 255, 0); } 100% { transform: scale(0.9); box-shadow: 0 0 0 0 rgba(138, 132, 255, 0); } }

#loading-spinner {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  z-index: 5;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 150ms ease;
}

#loading-spinner:not(.hidden) {
  opacity: 1;
  visibility: visible;
}

/* From Uiverse.io by Nawsome */
.wheel-and-hamster {
  --dur: 1s;
  position: relative;
  width: 12em;
  height: 12em;
  font-size: 14px;
}

.wheel,
.hamster,
.hamster div,
.spoke {
  position: absolute;
}

.wheel,
.spoke {
  border-radius: 50%;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.wheel {
  background: radial-gradient(100% 100% at center,hsla(0,0%,60%,0) 47.8%,hsl(0,0%,60%) 48%);
  z-index: 2;
}

.hamster {
  animation: hamster var(--dur) ease-in-out infinite;
  top: 50%;
  left: calc(50% - 3.5em);
  width: 7em;
  height: 3.75em;
  transform: rotate(4deg) translate(-0.8em,1.85em);
  transform-origin: 50% 0;
  z-index: 1;
}

.hamster__head {
  animation: hamsterHead var(--dur) ease-in-out infinite;
  background: hsl(30,90%,55%);
  border-radius: 70% 30% 0 100% / 40% 25% 25% 60%;
  box-shadow: 0 -0.25em 0 hsl(30,90%,80%) inset,
		0.75em -1.55em 0 hsl(30,90%,90%) inset;
  top: 0;
  left: -2em;
  width: 2.75em;
  height: 2.5em;
  transform-origin: 100% 50%;
}

.hamster__ear {
  animation: hamsterEar var(--dur) ease-in-out infinite;
  background: hsl(0,90%,85%);
  border-radius: 50%;
  box-shadow: -0.25em 0 hsl(30,90%,55%) inset;
  top: -0.25em;
  right: -0.25em;
  width: 0.75em;
  height: 0.75em;
  transform-origin: 50% 75%;
}

.hamster__eye {
  animation: hamsterEye var(--dur) linear infinite;
  background-color: hsl(0,0%,0%);
  border-radius: 50%;
  top: 0.375em;
  left: 1.25em;
  width: 0.5em;
  height: 0.5em;
}

.hamster__nose {
  background: hsl(0,90%,75%);
  border-radius: 35% 65% 85% 15% / 70% 50% 50% 30%;
  top: 0.75em;
  left: 0;
  width: 0.2em;
  height: 0.25em;
}

.hamster__body {
  animation: hamsterBody var(--dur) ease-in-out infinite;
  background: hsl(30,90%,90%);
  border-radius: 50% 30% 50% 30% / 15% 60% 40% 40%;
  box-shadow: 0.1em 0.75em 0 hsl(30,90%,55%) inset,
		0.15em -0.5em 0 hsl(30,90%,80%) inset;
  top: 0.25em;
  left: 2em;
  width: 4.5em;
  height: 3em;
  transform-origin: 17% 50%;
  transform-style: preserve-3d;
}

.hamster__limb--fr,
.hamster__limb--fl {
  clip-path: polygon(0 0,100% 0,70% 80%,60% 100%,0% 100%,40% 80%);
  top: 2em;
  left: 0.5em;
  width: 1em;
  height: 1.5em;
  transform-origin: 50% 0;
}

.hamster__limb--fr {
  animation: hamsterFRLimb var(--dur) linear infinite;
  background: linear-gradient(hsl(30,90%,80%) 80%,hsl(0,90%,75%) 80%);
  transform: rotate(15deg) translateZ(-1px);
}

.hamster__limb--fl {
  animation: hamsterFLLimb var(--dur) linear infinite;
  background: linear-gradient(hsl(30,90%,90%) 80%,hsl(0,90%,85%) 80%);
  transform: rotate(15deg);
}

.hamster__limb--br,
.hamster__limb--bl {
  border-radius: 0.75em 0.75em 0 0;
  clip-path: polygon(0 0,100% 0,100% 30%,70% 90%,70% 100%,30% 100%,40% 90%,0% 30%);
  top: 1em;
  left: 2.8em;
  width: 1.5em;
  height: 2.5em;
  transform-origin: 50% 30%;
}

.hamster__limb--br {
  animation: hamsterBRLimb var(--dur) linear infinite;
  background: linear-gradient(hsl(30,90%,80%) 90%,hsl(0,90%,75%) 90%);
  transform: rotate(-25deg) translateZ(-1px);
}

.hamster__limb--bl {
  animation: hamsterBLLimb var(--dur) linear infinite;
  background: linear-gradient(hsl(30,90%,90%) 90%,hsl(0,90%,85%) 90%);
  transform: rotate(-25deg);
}

.hamster__tail {
  animation: hamsterTail var(--dur) linear infinite;
  background: hsl(0,90%,85%);
  border-radius: 0.25em 50% 50% 0.25em;
  box-shadow: 0 -0.2em 0 hsl(0,90%,75%) inset;
  top: 1.5em;
  right: -0.5em;
  width: 1em;
  height: 0.5em;
  transform: rotate(30deg) translateZ(-1px);
  transform-origin: 0.25em 0.25em;
}

.spoke {
  animation: spoke var(--dur) linear infinite;
  background: radial-gradient(100% 100% at center,hsl(0,0%,60%) 4.8%,hsla(0,0%,60%,0) 5%),
		linear-gradient(hsla(0,0%,55%,0) 46.9%,hsl(0,0%,65%) 47% 52.9%,hsla(0,0%,65%,0) 53%) 50% 50% / 99% 99% no-repeat;
}

@keyframes hamster { from, to { transform: rotate(4deg) translate(-0.8em,1.85em); } 50% { transform: rotate(0) translate(-0.8em,1.85em); } }
@keyframes hamsterHead { from, 25%, 50%, 75%, to { transform: rotate(0); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(8deg); } }
@keyframes hamsterEye { from, 90%, to { transform: scaleY(1); } 95% { transform: scaleY(0); } }
@keyframes hamsterEar { from, 25%, 50%, 75%, to { transform: rotate(0); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(12deg); } }
@keyframes hamsterBody { from, 25%, 50%, 75%, to { transform: rotate(0); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(-2deg); } }
@keyframes hamsterFRLimb { from, 25%, 50%, 75%, to { transform: rotate(50deg) translateZ(-1px); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(-30deg) translateZ(-1px); } }
@keyframes hamsterFLLimb { from, 25%, 50%, 75%, to { transform: rotate(-30deg); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(50deg); } }
@keyframes hamsterBRLimb { from, 25%, 50%, 75%, to { transform: rotate(-60deg) translateZ(-1px); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(20deg) translateZ(-1px); } }
@keyframes hamsterBLLimb { from, 25%, 50%, 75%, to { transform: rotate(20deg); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(-60deg); } }
@keyframes hamsterTail { from, 25%, 50%, 75%, to { transform: rotate(30deg) translateZ(-1px); } 12.5%, 37.5%, 62.5%, 87.5% { transform: rotate(10deg) translateZ(-1px); } }
@keyframes spoke { from { transform: rotate(0); } to { transform: rotate(-1turn); } }

.hidden { display: none !important; }

#message-container {
  color: var(--text-primary);
  padding: 30px 20px;
  min-height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1em;
  font-weight: 500;
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100%;
  text-align: center;
  box-sizing: border-box;
}
.message-plain { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; max-width: 480px; }
.message-plain .icon { color: var(--text-secondary); width: 40px; height: 40px; }
.message-plain h3 { margin: 0; font-weight: 700; color: var(--text-primary); }
.message-plain p { margin: 0; color: var(--text-secondary); line-height: 1.6; }

#result-container { animation: fadeIn 0.5s ease-out forwards; }
#map { width: 100%; height: 200px; border-radius: 12px; margin: 16px 0; background-color: var(--map-bg); border: 1px solid var(--border-color); flex-shrink: 0; }
#place-name { font-size: 1.6em; font-weight: 700; color: var(--text-primary); margin-bottom: 5px; }
#place-address, #place-rating { color: var(--text-secondary); margin: 5px 0;}
#place-rating { display: flex; align-items: center; justify-content: center; gap: 8px; }

/* === KORREKTUR: Abstand UNTER dem Review Snippet hinzugefügt === */
#review-snippet {
    margin-top: 20px;
    margin-bottom: 20px; /* Dieser Abstand sorgt für die Lücke zu den Buttons */
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); 
    border: 1px solid var(--border-color); 
    border-left: 4px solid var(--accent); 
    border-radius: 12px; 
    padding: 16px 18px; 
    text-align: left; 
    max-height: 220px; 
    overflow-y: auto;
}
#review-text { margin: 0; font-style: normal; color: var(--text-secondary); line-height: 1.6; position: relative; }
#review-text:before, #review-text:after { content: "“"; color: rgba(255,255,255,.35); font-size: 1.4em; line-height: 0; position: relative; top: .08em; }
#review-text:after { content: "”"; }
#review-author { display: block; margin-top: 10px; text-align: right; font-weight: 600; color: var(--text-primary); opacity: .9; }
#review-snippet::-webkit-scrollbar { width: 8px; }
#review-snippet::-webkit-scrollbar-thumb { background: rgba(255,255,255,.18); border-radius: 8px; }

:focus-visible { outline: 0; box-shadow: 0 0 0 3px rgba(0,170,255,.35); border-color: var(--accent); transition: box-shadow .2s ease; }

.result-actions {
    /* Der Margin hier wird von 'margin-top: auto' überschrieben, daher ist er unwirksam */
    display: grid;
    grid-template-areas:
        "details copy"
        "next next";
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: center;
}

.result-actions .action-btn {
    display: flex; 
    align-items: center;
    justify-content: center;
    text-decoration: none;
    padding: 15px;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: .2px;
    cursor: pointer;
    text-align: center;
    transition: all 0.2s ease;
}

#next-suggestion-btn {
    background: linear-gradient(90deg, var(--accent), var(--primary-light));
    background-size: 200% 100%;
    color: #fff;
    border: none;
    box-shadow: 0 6px 16px rgba(0, 170, 255, 0.25);
}

#details-link,
#copy-share-btn {
    background: color-mix(in oklab, var(--input-bg) 85%, white);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    box-shadow: 0 2px 6px rgba(0,0,0,.06);
}

#copy-share-btn svg { color: currentColor; } 

#next-suggestion-btn:hover {
    background-position: right center;
    box-shadow: 0 8px 24px rgba(0,170,255,0.30);
    transform: translateY(-2px);
}

#details-link:hover,
#copy-share-btn:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0,0,0,.1);
}

.icon-btn { width: 52px; padding: 12px 0; }

.faq-section {
  max-width: var(--page-max);
  width: 100%;
  margin: 40px auto 0 auto;
  padding: 0;
}
.faq-container { max-width: 100%; padding: 28px 40px; text-align: left; }
.faq-container h2 { text-align: center; font-size: 1.8em; font-weight: 700; color: var(--text-primary); margin-bottom: 30px; }
.faq-container details { background: var(--input-bg); border-radius: 12px; margin-bottom: 10px; border: 1px solid var(--border-color); transition: background-color 0.3s ease; }
.faq-container details:last-child { margin-bottom: 0; }
.faq-container details[open] { background: var(--secondary-light); }
.faq-container summary { display: flex; justify-content: space-between; align-items: center; padding: 16px 18px; cursor: pointer; font-weight: 600; color: var(--text-primary); list-style: none; }
.faq-container summary::-webkit-details-marker { display: none; }
.faq-container summary svg { color: var(--text-secondary); transition: transform 0.3s ease-in-out; flex-shrink: 0; }
.faq-container details[open] summary svg { transform: rotate(180deg); }
.faq-container details p { padding: 0 20px 20px 20px; margin: 0; color: var(--text-secondary); line-height: 1.7; }

.site-footer { padding: 40px 20px 20px 20px; text-align: center; color: var(--text-secondary); font-size: 14px; width: 100%; }
.site-footer a { color: var(--text-secondary); text-decoration: none; transition: color 0.3s ease; }
.site-footer a:hover { color: var(--primary-light); text-decoration: underline; }

.input-error { border-color: #ff6b6b !important; box-shadow: 0 0 0 3px rgba(255,107,107,.25) !important; }
@keyframes shake { 0%,100% { transform: translateX(0); } 25% { transform: translateX(-4px); } 50% { transform: translateX(4px); } 75% { transform: translateX(-2px); } }
.shake { animation: shake .28s linear; }

.input-group {
  display: flex;
  align-items: center;
  width: 100%;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  overflow: hidden;
  background: var(--input-bg);
  transition: box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.input-group:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(0,170,255,.25); background: color-mix(in oklab, var(--input-bg) 85%, white); }
.input-group input[type="text"] { flex: 1; border: none; background: transparent; box-shadow: none; }
.input-group .btn-inline { width: 44px; height: 44px; border: none; background: transparent; color: var(--text-secondary); cursor: pointer; }

.fab {
    display: none; 
    position: fixed;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid var(--border-color);
    background: var(--secondary-light);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: var(--text-secondary);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 22px rgba(0,0,0,.18);
    transition: transform .2s, background-color .2s, opacity .3s ease, visibility .3s ease;
    z-index: 200;
}
.fab:hover {
    background-color: rgba(138,132,255,.20);
    transform: translateY(-2px);
}
.fab svg {
    width: 20px;
    height: 20px;
}

#history-btn {
    bottom: calc(24px + env(safe-area-inset-bottom, 0px));
    right: 24px;
}

#scroll-to-top-btn {
    bottom: calc(24px + env(safe-area-inset-bottom, 0px));
    left: 24px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(15px);
}
#scroll-to-top-btn.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

#history-sidebar {
  position: fixed;
  top: 0;
  right: 0;
  width: 320px;
  max-width: 92vw;
  height: 100vh;
  background: var(--secondary);
  border-left: 1px solid var(--border-color);
  box-shadow: -4px 0 15px rgba(0,0,0,.3);
  padding: 20px;
  overflow-y: auto;
  transition: transform .3s ease;
  z-index: 300;
}
#history-sidebar.hidden { transform: translateX(100%); }
#history-sidebar .history-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
#history-sidebar h3 { margin: 0; }
#history-close {
  border: none; background: transparent; color: var(--text-secondary);
  font-size: 20px; cursor: pointer;
}
#history-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
#history-list .history-item { background: var(--input-bg); border: 1px solid var(--border-color); border-radius: 10px; padding: 10px; text-align: left; }
#history-list .history-item a { color: var(--text-primary); text-decoration: none; font-weight: 600; }
#history-list .history-item small { color: var(--text-secondary); display: block; margin-top: 4px; }

#details-link { grid-area: details; }
#copy-share-btn { grid-area: copy; width: 46px; padding: 0; display: grid; place-items: center; }
#next-suggestion-btn { grid-area: next; }

.filters-container { display: flex; flex-direction: column; }
.filters-container .filters { display: flex; flex-direction: column; flex: 1 1 auto; }
#find-btn { margin-top: auto; }

.results-wrapper .result-actions {
  display: grid !important;
  grid-template-areas:
    "details copy"
    "next next";
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
}
.results-wrapper #details-link { grid-area: details; }
.results-wrapper #copy-share-btn { grid-area: copy; width: 46px; padding: 0; display: grid; place-items: center; }
.results-wrapper #next-suggestion-btn { grid-area: next; }

.results-wrapper { display: flex; flex-direction: column;   position: relative;}
#result-container { display: flex; flex-direction: column; flex: 1 1 auto; }
.result-actions { margin-top: auto; }

.result-actions .action-btn { min-height: 52px; display: inline-flex; align-items: center; justify-content: center; }

.results-wrapper { overflow: hidden; }
#result-container { min-height: 0; } 
#review-snippet {
  height: 220px;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable both-edges;
}

#review-snippet::-webkit-scrollbar { width: 10px; }
#review-snippet::-webkit-scrollbar-track {
  background: color-mix(in oklab, var(--input-bg) 80%, transparent);
  border-radius: 10px;
}
#review-snippet::-webkit-scrollbar-thumb {
  background: color-mix(in oklab, var(--text-secondary) 40%, transparent);
  border-radius: 10px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
#review-snippet::-webkit-scrollbar-thumb:hover {
  background: color-mix(in oklab, var(--text-secondary) 55%, transparent);
}

#review-snippet {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in oklab, var(--text-secondary) 45%, transparent)
                   color-mix(in oklab, var(--input-bg) 85%, transparent);
}

.results-wrapper #message-container {
  display: grid;
  place-items: center;
  margin: 0;
  padding: 0 20px;
  flex: 1 1 auto;
}

.language-switcher {
  background-color: var(--secondary-light);
  border: 1px solid var(--border-color);
}
.language-switcher button {
  color: var(--text-secondary);
}
.language-switcher button.active {
  background: linear-gradient(90deg, var(--accent), var(--primary-light));
  color: #fff;
  box-shadow: 0 2px 10px rgba(0,0,0,.15);
}

#history-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.25);
  z-index: 250;
}
#history-backdrop.hidden { display: none; }

#history-sidebar {
  z-index: 300;
  background: color-mix(in oklab, var(--bg-color) 90%, white);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

#details-link::before,
#next-suggestion-btn::before { margin-right: 6px; }

#history-list .history-item {
  background: color-mix(in oklab, var(--bg-color) 85%, white);
}

.text-input{padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--input-bg);color:var(--text);}


/* === Responsive: stack columns on small screens === */
@media (max-width: 920px) {
  :root {
    --col-left: 1fr;
    --col-right: 1fr;
    --col-gap: 20px;
    --page-max: 100vw;
    --locked-height: auto;
  }

  body {
    padding: 20px 14px 120px 14px;
  }

  .top-right-controls {
    position: absolute;
    top: 14px;
    right: 14px;
    gap: 10px;
  }

  .main-content {
    grid-template-columns: 1fr;
    max-width: 500px; 
    gap: 20px;
    margin-top: 0;
  }
  
  .wheel-and-hamster {
  font-size: 12px; 
}

  .fab {
      display: inline-flex;
  }

  .filters-container,
  .results-wrapper {
    height: auto;
    padding: 22px 18px;
  }

  header h1 { font-size: 1.9em; }
  header p { margin-bottom: 24px; }

  #map { height: 180px; }

  .result-actions {
    grid-template-areas:
      "details copy"
      "next next";
    grid-template-columns: 1fr auto;
    gap: 10px;
  }
  
  #copy-share-btn {
    width: 50px;
    height: 50px;
    padding: 0;
  }

  .action-btn {
      padding: 14px;
      font-size: 15px;
      min-height: 50px;
  }

  .faq-container { padding: 22px; }
}

@media (max-width: 400px) {
  body { 
    padding: 15px 10px 110px 10px; 
  }
  .filters-container,
  .results-wrapper { padding: 18px 14px; }
  header h1 { font-size: 1.7em; }
  #map { height: 160px; }
  
  .top-right-controls {
    top: 12px;
    right: 12px;
    gap: 8px;
  }
  
  .language-switcher button { padding: 5px 10px; }
  .theme-toggle { width: 40px; height: 40px; }

  .action-btn { font-size: 15px; padding: 12px; min-height: 48px; }
  #copy-share-btn { width: 48px; height: 48px; }
}

/* Stabilität */
#map { width:100%; min-height:220px; border-radius:12px; overflow:hidden; }
#review-snippet { max-height:160px; overflow:auto; }

/* ----- Mobile: feste Bottom-Bar ----- */
@media (max-width: 720px) {
  :root { --actionbar-h: 84px; }

  /* Platz für die feste Leiste + Footer-Badge + Safe-Area */
  html, body { height: 100%; }
  body {
    padding-bottom: calc(var(--actionbar-h) + 64px + env(safe-area-inset-bottom));
  }
  .main-content,
  .results-wrapper,
  #result-container,
  #message-container { padding-bottom: 16px; }

  /* Alte Card-Buttons auf Mobile ausblenden */
  .result-actions { display: none !important; }
  #result-container { padding-bottom: 12px; }
}

/* Kleiner FAB für "Nächster Vorschlag" – nur auf Mobile sichtbar */
.fab-next {
  position: fixed;
  right: 16px;
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 1100;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid var(--border-color);
  background: linear-gradient(90deg, var(--accent), var(--primary-light));
  color: #fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
  display: none;           /* default: verborgen (Desktop) */
  align-items: center;
  justify-content: center;
  font-size: 22px;
}

@media (max-width: 720px) {
  .fab-next { display: flex; }
}