
.eqai-wrapper{
  max-width: 1040px;
  margin: 28px auto;
  padding: 0 14px;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.45;
}
.eqai-hero{
  border-radius: 18px;
  padding: 18px 18px;
  background: rgba(0,0,0,0.04);
  border: 1px solid rgba(0,0,0,0.08);
}
.eqai-hero-title{
  font-size: 26px;
  font-weight: 800;
  letter-spacing: .2px;
}
.eqai-hero-sub{
  margin-top: 6px;
  opacity: .85;
}
.eqai-grid{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  margin-top: 14px;
}
@media (max-width: 860px){
  .eqai-grid{ grid-template-columns: 1fr; }
}
.eqai-card{
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,0.65);
  border: 1px solid rgba(0,0,0,0.10);
  backdrop-filter: blur(8px);
}
.eqai-card h3{
  margin: 0 0 10px 0;
  font-size: 16px;
  font-weight: 800;
}
.eqai-steps{
  margin: 0 0 14px 18px;
  opacity: .9;
}
.eqai-startbar{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  align-items: end;
}
@media (max-width: 860px){
  .eqai-startbar{ grid-template-columns: 1fr 1fr; }
  .eqai-startbar .eqai-btn{ grid-column: 1 / -1; }
}

.eqai-seg{
  display: flex;
  gap: 6px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.18);
  background: rgba(255,255,255,0.65);
}
.eqai-seg-item{
  flex: 1;
  position: relative;
}
.eqai-seg-item input{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.eqai-seg-item span{
  display: block;
  padding: 9px 10px;
  border-radius: 999px;
  text-align: center;
  font-weight: 800;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
  transition: background .15s ease, color .15s ease, transform .08s ease;
}
.eqai-seg-item input:checked + span{
  background: rgba(0,0,0,0.85);
  color: #fff;
}
.eqai-seg-item span:hover{ transform: translateY(-1px); }
.eqai-field label{
  display:block;
  font-size: 12px;
  opacity: .75;
  margin-bottom: 6px;
}
.eqai-field input, .eqai-field select, .eqai-field textarea{
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.18);
  padding: 10px 10px;
  background: rgba(255,255,255,0.7);
  color: inherit;
  outline: none;
}
.eqai-field textarea{ resize: vertical; }
.eqai-btn{
  border: 1px solid rgba(0,0,0,0.22);
  background: rgba(255,255,255,0.7);
  color: inherit;
  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 700;
  transition: transform .08s ease, opacity .15s ease;
  user-select: none;
}
.eqai-btn:hover{ transform: translateY(-1px); }
.eqai-btn:disabled{ opacity: .5; cursor: not-allowed; transform: none; }
.eqai-primary{
  background: rgba(0,0,0,0.85);
  color: #fff;
  border-color: rgba(0,0,0,0.6);
}
.eqai-danger{
  background: rgba(170,0,0,0.12);
  border-color: rgba(170,0,0,0.35);
}
.eqai-link{
  background: transparent;
  border-color: transparent;
  padding: 6px 10px;
  text-decoration: underline;
  opacity: .85;
}
.eqai-mini{
  font-size: 12px;
  opacity: .75;
  margin-top: 10px;
}
.eqai-muted{ opacity: .75; }
.eqai-box{
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(255,255,255,0.7);
}
.eqai-warning{
  border-color: rgba(180,120,0,0.35);
  background: rgba(180,120,0,0.08);
}
.eqai-status{
  font-size: 14px;
}
.eqai-actions{
  display:flex;
  gap:10px;
  margin-top: 12px;
}
.eqai-game{
  margin-top: 14px;
}
.eqai-roundbar{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(255,255,255,0.7);
}
.eqai-roundinfo{ display:flex; gap: 8px; flex-wrap: wrap; }
.eqai-badge{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.14);
  background: rgba(0,0,0,0.04);
}
.eqai-badge-soft{
  opacity: .85;
}
.eqai-points{
  font-size: 20px;
  font-weight: 900;
}
.eqai-board{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 12px;
  margin-top: 12px;
}
@media (max-width: 980px){
  .eqai-board{ grid-template-columns: 1fr; }
}

.eqai-map{ position: relative; }

.eqai-map-toolbar{
  position:absolute;
  top: 12px;
  left: 12px;
  z-index: 600;
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}

.eqai-btn-ghost{
  background: rgba(255,255,255,0.86);
  border: 1px solid rgba(0,0,0,0.14);
}
.eqai-media{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(255,255,255,0.7);
  overflow:hidden;
}
.eqai-imagewrap{
  height: 260px;
  position: relative;
  background: rgba(0,0,0,0.05);
}
.eqai-imagewrap img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.eqai-imageplaceholder{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.7;
}
.eqai-hint{
  padding: 12px 14px;
  border-top: 1px solid rgba(0,0,0,0.08);
}
.eqai-hint-title{
  font-weight: 900;
  margin-bottom: 6px;
}

.eqai-desc{
  padding: 10px 14px;
  border-top: 1px solid rgba(0,0,0,0.08);
}
.eqai-desc summary{
  cursor: pointer;
  font-weight: 800;
  user-select: none;
}
.eqai-desc summary::-webkit-details-marker{
  display:none;
}
.eqai-desc summary:before{
  content: '+';
  display: inline-block;
  width: 16px;
  opacity: .75;
}
.eqai-desc[open] summary:before{
  content: '–';
}
.eqai-desc-body{
  margin-top: 8px;
  white-space: pre-line;
  opacity: .92;
}
.eqai-guessbar{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 12px 14px;
  border-top: 1px solid rgba(0,0,0,0.08);
}
@media (max-width: 520px){
  .eqai-guessbar{ flex-direction: column; align-items: stretch; }
}
.eqai-result{
  padding: 12px 14px;
  border-top: 1px solid rgba(0,0,0,0.08);
}
.eqai-map{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,0.10);
  overflow:hidden;
  background: rgba(0,0,0,0.04);
}
.eqai-map-canvas{
  height: 520px;
}
@media (max-width: 980px){
  .eqai-map-canvas{ height: 420px; }
}
.eqai-footer{
  display:flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.eqai-challenge-box{
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px dashed rgba(0,0,0,0.22);
  background: rgba(0,0,0,0.03);
}
.eqai-modal{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index: 9999;
  padding: 14px;
}
.eqai-modal-inner{
  width: min(760px, 100%);
  border-radius: 18px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.20);
  overflow:hidden;
}
.eqai-modal-head{
  display:flex;
  justify-content: space-between;
  align-items:center;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(0,0,0,0.10);
}
.eqai-modal-title{
  font-weight: 900;
}
.eqai-x{
  background: transparent;
  border: 0;
  font-size: 22px;
  cursor: pointer;
  padding: 2px 8px;
}
.eqai-modal-body{
  padding: 14px;
}
.eqai-modal-actions{
  display:flex;
  justify-content:flex-end;
  margin-top: 10px;
}
.eqai-grid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
@media (max-width: 640px){
  .eqai-grid2{ grid-template-columns: 1fr; }
}

.eqai-place-map{
  height: 220px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.16);
  overflow: hidden;
  background: rgba(0,0,0,0.03);
}

.eqai-bottombar{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9998;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  padding-bottom: calc(10px + env(safe-area-inset-bottom));
  border-top: 1px solid rgba(0,0,0,0.16);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
}

.eqai-bottombar-msg{
  flex: 1;
  min-width: 0;
  font-size: 13px;
  opacity: .85;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.eqai-bottombar-actions{
  display:flex;
  align-items:center;
  gap: 8px;
}

.eqai-has-bottombar{
  padding-bottom: 92px;
}

@media (max-width: 640px){
  /* avoid duplicate buttons on mobile */
  #eqaiSubmitGuessBtn{ display:none; }
  .eqai-map-canvas{ height: clamp(300px, 52vh, 520px); }
  .eqai-imagewrap{ height: 200px; }
}

@media (max-width: 420px){
  .eqai-map-canvas{ height: clamp(260px, 48vh, 460px); }
}

/* Toast (Reisekasse Punkte) */
.eqai-toast{
  position: fixed;
  left: 50%;
  bottom: calc(92px + 16px + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 999999;
  background: rgba(0,0,0,0.86);
  color: #fff;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 13px;
  max-width: min(92vw, 520px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
  opacity: 0;
  transition: opacity .18s ease;
}
.eqai-toast.show{ opacity: 1; }

@media (max-width: 520px){
  .eqai-toast{ bottom: calc(92px + 10px + env(safe-area-inset-bottom)); }
}


/* --- Community Places Manager --- */
.eqai-tabs{display:flex;gap:8px;flex-wrap:wrap}
.eqai-tab{appearance:none;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:inherit;padding:8px 10px;border-radius:10px;cursor:pointer;font-weight:600}
.eqai-tab:hover{background:rgba(255,255,255,.10)}
.eqai-tab-active{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28)}
.eqai-places-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.eqai-place-row{border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18);border-radius:14px;padding:10px 12px}
.eqai-place-row h4{margin:0 0 6px 0;font-size:14px;line-height:1.2}
.eqai-place-meta{font-size:12px;opacity:.85;margin-bottom:8px}
.eqai-place-actions{display:flex;gap:8px;flex-wrap:wrap}
.eqai-place-actions .eqai-btn{padding:7px 10px;border-radius:10px}
.eqai-place-row.is-inactive{opacity:.6}
