/* ==========================================================
   form-fields.css – Personal Data Form unified to view look
   Relies on tokens from style.css
   ========================================================== */

/* Visibility helpers */
.show { display:block; animation:fadeIn .25s ease; }
.hide { display:none!important; }

.compact-input.is-disabled { opacity: .6; }

.personal-data-form {
background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px 22px 26px;
  box-shadow: var(--shadow-sm);
  margin: 20px 14px;
  display: flex;
  position: relative;
  flex-wrap: wrap;
  align-items: baseline;
}

.personal-data-form .form-title {
  margin:0;
  font-size:1.35rem;
  font-weight:800;
  letter-spacing:.55px;
  text-align:center;
}

.personal-data-form .form-subtitle {
  margin:6px auto 4px;
  font-size:.75rem;
  text-align:center;
  max-width:560px;
  line-height:1.35;
}

.form-section {
  background:var(--card-alt);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:var(--shadow-xs);
  overflow:hidden;
  transition:background .25s,border-color .22s, box-shadow .22s;
  position:relative;
  width:100%;
  margin-bottom: 20px;
}

.form-section:hover {
  border-color:var(--accent);
  box-shadow:var(--shadow-md);
}

.form-section-title {
  margin:0;
  padding:14px 18px;
  font:700 .85rem var(--font-ui);
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--accent);
  display:flex;
  gap:10px;
  align-items:center;
  position:relative;
  cursor:pointer;
}

.form-section-title .section-toggle {
  margin-left:auto;
  font-size:.7rem;
  opacity:.6;
  transition:transform .3s;
}

.form-section.collapsed .section-toggle {
  transform:rotate(-90deg);
}

.form-section-content {
  display:flex;
  flex-direction:column;
  gap:18px;
  padding:18px 20px 20px;
}

.form-row {
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  align-items:flex-start;
}

.form-grid {
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  border-bottom: 1px solid var(--border);
  padding-bottom: 1em;
}

.form-field {
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
  flex:1;
}

.form-field > span,
.form-field > label > span,
.form-section-content span.form-label {
  font:600 .7rem/1.1 var(--font-ui);
  letter-spacing:.04em;
  color:var(--accent);
  text-transform:uppercase;
}

.personal-data-form input,
.personal-data-form select,
.personal-data-form textarea {
  font:500 .75rem/1.25 var(--font-ui);
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  background:#fff;
  color:var(--text);
  min-height:44px;
  transition:border-color .2s, box-shadow .2s, background .2s;
}

.personal-data-form textarea { resize:vertical; min-height:92px; }

.personal-data-form input:focus,
.personal-data-form select:focus,
.personal-data-form textarea:focus {
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 2px var(--accent-alt);
}

.preview-thumb {
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:12px;
}

/* Profile Image */
.profile-pic-container {
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:center;
  width:min(320px,100%);
}

.profile-pic-preview {
  width:120px;
  height:120px;
  border-radius:50%;
  object-fit:cover;
  background:#ccc;
  border:3px solid var(--accent);
  box-shadow:0 2px 10px #00000025;
  transition:transform .25s;
}
.profile-pic-preview:hover { transform:scale(1.05); }

/* Toggle Chips */
.toggle-group,
.option-toggles-container {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}

.toggle-input {
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.toggle-label,
.option-toggle,
.form-toggle {
  background:var(--accent-soft);
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  font:600 .65rem/1.1 var(--font-ui);
  padding:7px 14px;
  letter-spacing:.04em;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:6px;
  cursor:pointer;
  user-select:none;
  transition:background .2s,color .2s,border-color .2s,box-shadow .22s;
  position:relative;
}

.toggle-label:hover,
.option-toggle:hover {
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}

.toggle-input:checked + .toggle-label,
.option-toggle.selected {
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  box-shadow:0 0 0 1px #ffffff40 inset;
}

.option-toggle.selected.favorite:not(.no-go) {
  background:linear-gradient(90deg,#ffd54d,#ffb300);
  color:#332600;
  border-color:#ffb300;
}

.option-toggle.selected.no-go {
  background:#e53935;
  color:#fff;
  border-color:#e53935;
  text-decoration:line-through;
}

.togglegroup-wrap {
  padding-bottom:1em;
}

#top_roles_wrap, 
#other_roles_wrap, 
#bottom_roles_wrap,
#bdsm_exp_top,
#bdsm_exp_bottom,
.bdsm-exp-top,
.bdsm-exp-bottom {
  padding: 0 1em 0.5em 2em;

}

/* Relationship list styling */
.relationship-item {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px 16px 6px;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:10px;
  box-shadow:var(--shadow-xs);
}

.relationship-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}

.relationship-title {
  margin:0;
  font:700 .8rem/1 var(--font-ui);
  letter-spacing:.04em;
  color:var(--accent);
  text-transform:uppercase;
}

.remove-relationship-btn {
  background:var(--accent-soft);
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--danger);
  font-size:.85rem;
  line-height:1;
  padding:6px 10px;
  cursor:pointer;
  transition:background .2s,border-color .2s;
}
.remove-relationship-btn:hover {
  background:#ffe5e5;
  border-color:#ffc8c8;
}

/* Buttons */

#save-to-server-btn {
  position: fixed;
  right: 16px;
  bottom: 50px;
  z-index: 9999;
  margin: 0;
  width: 40px;
  height: 40px;
  border-radius:20px;      
}

.personal-data-form button,
.personal-data-form .form-button {
  background:var(--bg-alt);
  border:1px solid var(--border);
  color:var(--text);
  font:600 .7rem/1 var(--font-ui);
  letter-spacing:.04em;
  border-radius:12px;
  display:inline-flex;
  gap:6px;
  align-items:center;
  cursor:pointer;
  box-shadow:var(--shadow-xs);
  transition:background .2s, transform .15s;
}
.personal-data-form button:hover {
  background:var(--accent-alt);
}
.personal-data-form button:active {
  transform:translateY(1px);
}
.personal-data-form button:focus-visible {
  outline:var(--focus-ring);
  outline-offset:2px;
}

.btn-secondary {
  background:var(--accent-soft);
  color:var(--accent);
  border-color:var(--accent);
}
.btn-secondary:hover {
  background:var(--accent);
  color:#fff;
}

/* Shape Galleries (Breasts / Vulva) */
.breast-shape-gallery,
.vulva-shape-gallery {
  display:grid;
  gap:14px;
  grid-template-columns:repeat(auto-fill,minmax(92px,1fr));
  margin:6px 0 4px;
}

.breast-shape-item,
.vulva-shape-item {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:10px 6px 12px;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:center;
  cursor:pointer;
  position:relative;
  transition:border-color .22s, box-shadow .25s, transform .25s, background .25s;
  box-shadow:var(--shadow-xs);
}

.breast-shape-item:hover,
.vulva-shape-item:hover {
  border-color:var(--accent);
  box-shadow:var(--shadow-sm);
  transform:translateY(-3px);
}

.breast-shape-item.selected,
.vulva-shape-item.selected {
  border-color:var(--accent);
  box-shadow:0 0 0 2px var(--accent-alt);
  background:linear-gradient(120deg,var(--accent-soft),#fff);
}

.breast-shape-cell,
.vulva-shape-cell {
  width:62px;
  height:62px;
  border-radius:50%;
  background:#f0ecf8 center/cover no-repeat;
  border:2px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:border-color .25s, box-shadow .25s;
  position:relative;
  overflow:hidden;
}

.breast-shape-item.selected .breast-shape-cell,
.vulva-shape-item.selected .vulva-shape-cell {
  border-color:var(--accent);
  box-shadow:0 0 0 2px var(--accent-soft);
}

.breast-shape-label,
.vulva-shape-label {
  font:600 .58rem/1.15 var(--font-ui);
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--text-dim);
  text-align:center;
  max-width:80px;
  user-select:none;
}

/* Tooltips */
.breast-tooltip,
.vulva-tooltip {
  display:none;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  font:500 .6rem/1.25 var(--font-ui);
  color:var(--text);
  position:absolute;
  top:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  width:190px;
  box-shadow:var(--shadow-md);
  z-index:20;
  text-align:left;
}
.breast-shape-item:hover .breast-tooltip,
.vulva-shape-item:hover .vulva-tooltip {
  display:block;
}

@keyframes fadeIn {
  from { opacity:0; transform:translateY(-4px); }
  to { opacity:1; transform:translateY(0); }
}

/* Responsive */
@media (max-width:780px){
  .personal-data-form { padding:20px 16px 24px; }
  .form-section-content { padding:16px 18px 18px; }
  .breast-shape-gallery,
  .vulva-shape-gallery { grid-template-columns:repeat(auto-fill,minmax(80px,1fr)); }
  .breast-shape-cell,
  .vulva-shape-cell { width:56px; height:56px; }
}

@media (max-width:560px){
  .form-grid { gap:12px; }
  .personal-data-form { padding:18px 14px 22px; }
  .form-section-title { font-size:.78rem; }
  .breast-shape-gallery,
  .vulva-shape-gallery { grid-template-columns:repeat(auto-fill,minmax(70px,1fr)); }
}

/* Dark Mode refinement */
:root.dark-mode .form-section {
  background:#261f31;
  border-color:var(--border);
}
:root.dark-mode .option-toggle,
:root.dark-mode .toggle-label {
  background:#2a2331;
  border-color:var(--border);
  color:var(--text-dim);
}
:root.dark-mode .option-toggle:hover {
  background:var(--accent);
  color:#fff;
}
:root.dark-mode .relationship-item {
  background:#2a2331;
  border-color:var(--border);
}
:root.dark-mode .breast-shape-item,
:root.dark-mode .vulva-shape-item {
  background:#2a2331;
  border-color:var(--border);
}
:root.dark-mode .breast-tooltip,
:root.dark-mode .vulva-tooltip {
  background:#2f2838;
  border-color:#3b3247;
  color:var(--text);
}

/* === Arrangement Utilities (nicht-invasiv) ==================== */

/* Generische Auto-Grids */
.form-grid.grid-auto {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.form-grid.grid-2col {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr 1fr;
}

.form-grid.grid-3col {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr 1fr 1fr;
}

.form-grid.grid-tight {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}
.form-grid.mini-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  align-items: start;
}

.form-grid.grid-column {
  grid-template-columns: 1fr;
}

/* Volle Breite innerhalb eines Grids erzwingen */
.full-span {
  grid-column: 1 / -1 !important;
}

/* Kleinere numerische Felder */
.form-field.size-xs input[type="number"],
.form-field.size-xs input[type="text"] {
  max-width: 110px;
}
.form-field.size-s input[type="number"],
.form-field.size-s input[type="text"],
.form-field.size-s select {
  max-width: 160px;
}

/* Breitenklassen (werden nur max-width gesetzt, reagieren trotzdem responsiv) */
.w-xs { max-width: 120px; }
.w-s  { max-width: 180px; }
.w-m  { max-width: 260px; }
.w-l  { max-width: 360px; }

/* Inline Cluster */
.field-inline {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: flex-end;
}
.field-inline > .form-field {
  flex: 1 1 120px;
  min-width: 110px;
}

/* Kompakte Zeilen (reduziert vertikale Luft) */
.row-compact {
  gap: 10px !important;
}
.row-compact .form-field {
  gap: 4px;
}

/* Label-Höhe harmonisieren */
.form-field > span,
.form-field > label > span,
.form-section-content span.form-label {
  min-height: 14px;
  display: inline-flex;
  align-items: center;
}

/* Textareas in Grids glatter integrieren */
.form-field textarea.compact-input {
  padding-top: 8px;
  padding-bottom: 8px;
  line-height: 1.25;
}

/* Feldelemente mit Emoji im Label: ein kleines Padding teilen */
.form-field > span:has(emoji),
.form-field > span:has(svg) {
  padding-left: 0;
}

/* Abstände zwischen Hauptgruppen */
.form-section-content .form-grid + .form-grid {
  margin-top: 6px;
}
.form-section-content .form-grid + .form-row {
  margin-top: 8px;
}

/* Beziehungskarten im Zwei-Spalten-Modus ausrichten */
#relationships-container.relationships-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit,minmax(300px,1fr));
}

/* Mini-Hinweis unter Feldern (optional) */
.field-hint {
  font: 500 .55rem/1.2 var(--font-ui);
  color: var(--text-dim);
  margin-top: -2px;
}

/* Range + custom ticks */
.range-wrap {
  position: relative;
  gap: 8px;
  display: grid;
  grid-template-columns: 2fr 1fr; /* slider | live label */
  align-items: center;
}
.range-wrap input[type="range"] { width: 100%; }
.range-wrap .range-output { font-variant-numeric: tabular-nums; opacity: .85; }

.range-output {
  text-align: center;
}

/* Range output as color badge */
.range-output {
  --ro-bg: #e5e7eb;   /* default neutral bg */
  --ro-fg: #111827;   /* default text */
  --ro-br: rgba(17,24,39,.12);
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.1;
  background: var(--ro-bg);
  color: var(--ro-fg);
  border: 1px solid var(--ro-br);
  white-space: nowrap;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
  width: 50%;
  margin-left: 2em;
}

/* Color bands */
.range-output.ro-0 { --ro-bg:#e5e7eb; --ro-fg:#111827; --ro-br:rgba(17,24,39,.12); }   /* none */
.range-output.ro-1 { --ro-bg:#dcfce7; --ro-fg:#065f46; --ro-br:#a7f3d0; }               /* low (green) */
.range-output.ro-2 { --ro-bg:#fef9c3; --ro-fg:#854d0e; --ro-br:#fde68a; }               /* medium (amber) */
.range-output.ro-3 { --ro-bg:#ffedd5; --ro-fg:#7c2d12; --ro-br:#fed7aa; }               /* strong (orange) */
.range-output.ro-4 { --ro-bg:#fee2e2; --ro-fg:#7f1d1d; --ro-br:#fecaca; }               /* very strong (red) */
.range-output.ro-5 { --ro-bg:#fecaca; --ro-fg:#7f1d1d; --ro-br:#fca5a5; }               /* overwhelming (deep red) */

.hide, [hidden] { display: none !important; }

@media (prefers-color-scheme: dark) {
  .range-output {
    --ro-bg: #374151;
    --ro-fg: #e5e7eb;
    --ro-br: rgba(255,255,255,.1);
  }
}


/* Mobile Feintuning */
@media (max-width: 640px) {
  .form-grid.mini-grid { grid-template-columns: repeat(auto-fit, minmax(95px, 1fr)); }
  .field-inline { gap: 10px; }
  .form-field.size-xs input[type="number"] { max-width: 100%; }
  .range-wrap { grid-template-columns: 1fr; }
  .range-output { width: 100%; padding: 0; margin: 0; }
}

@media (max-width: 480px){
  .range-ticks .tick-label { font-size: 11px; }
}

/* Dark-Mode leichte Anpassung für Clusterränder */
:root.dark-mode .field-cluster {
  background:#2a2331;
}