/* =============================== */
/* TONSTUDIO LEIPZIG – FULL PRO STYLE FINAL */
/* Voll responsive • barrierefrei • mobil perfekt */
/* =============================== */

/* 1) Global Schriften */
.fgsc-wrap,
.fgsc-card,
.fgsc-toolbar input,
.fgsc-toolbar select,
.fgsc-toolbar button,
.fgsc-cta-btn,
.fgsc-note,
.fgsc-block-item,
.fgsc-help,
.fgsc-hinweis-green,
.fgsc-hinweis-important {
  font-family: 'Hind', sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  color: #282834;
}

.fgsc-card h1,
.fc-toolbar-title,
.fgsc-help summary,
.fgsc-block-title,
.fgsc-toolbar label,
.fgsc-legend strong {
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
}

/* 2) Wrapper und Card */
.fgsc-wrap { max-width: 1100px; margin: 20px auto; padding: 14px; }
.fgsc-card { background: #fff; border-radius: 16px; padding: 20px; box-shadow: 0 6px 26px rgba(0,0,0,.08); }
.fgsc-card h1 { margin: 0 0 8px; font-size: 26px; }
.fgsc-sub { color: #6d6d6d; font-size: 15px; margin-bottom: 14px; }

/* 3) Legende */
.fgsc-legend { display: flex; gap: 10px; margin: 10px 0; font-size: 15px; align-items: center; flex-wrap: wrap; }
.dot { width: 12px; height: 12px; border-radius: 50%; display:inline-block; }
.dot.ok { background:#2ecc71; }
.dot.partial { background:#f1c40f; }
.dot.busy { background:#dc2751; }

/* 4) Kalender Wrapper */
#fgsc-calendar { background:#fff; border-radius:12px; padding:12px; border:1px solid #e6e6e6; margin-bottom: 20px; }

/* 5) Day cells */
.fc .fc-daygrid-day { background:#fff !important; color:#282834 !important; font-size:15px; position:relative; }
.fc-daygrid-day-number { color:#282834 !important; font-weight:600; }

/* 6) Statusfarben mit Icon */
.day-fit { 
  background: rgba(46,204,113,.08) !important;
  outline:2px solid #2ecc71 !important; 
  border-radius:6px; 
  position:relative;
}
.day-fit::after { 
  content:"✓"; 
  position:absolute; 
  bottom:4px; 
  right:6px; 
  font-size:15px; 
  font-weight:700; 
  color:#2ecc71; 
}

.day-partial { 
  background: rgba(241,196,15,.08) !important;
  outline:2px solid #f1c40f !important; 
  border-radius:6px; 
  position:relative; 
}
.day-partial::after { 
  content:"•"; 
  position:absolute; 
  bottom:4px; 
  right:8px; 
  font-size:18px; 
  font-weight:700; 
  color:#f1c40f; 
}

.day-full { 
  background: rgba(220,39,81,.08) !important;
  outline:2px solid #dc2751 !important; 
  border-radius:6px; 
  position:relative; 
}
.day-full::after { 
  content:"✕"; 
  position:absolute; 
  bottom:4px; 
  right:6px; 
  font-size:16px; 
  font-weight:700; 
  color:#dc2751; 
}

/* 7) Hover, Heute, Auswahl */
.fc-daygrid-day:hover { background:#f6f6f6 !important; cursor:pointer; }
.fc .fc-day-today { background:#fff1f4 !important; border:1px solid #dc2751 !important; }
.fc-daygrid-day.fc-day-selected { background:#ffe3ea !important; border:2px solid #dc2751 !important; }

/* 8) FullCalendar Toolbar */
.fc-toolbar-title { color:#282834; font-size:22px; }
.fc-button {
  background:#dc2751 !important;
  border:none !important;
  color:#fff !important;
  padding:6px 12px;
  border-radius:9999px !important;
  font-size:14px;
  font-family:'Poppins', sans-serif;
  font-weight:600;
}
.fc-button:hover { background:#c02247 !important; }

/* 9) Toolbar Grid – tt.mm.jjjj, Startzeit, Dauer, Jetzt prüfen */
.fgsc-toolbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 18px;
  margin-top: 18px;
  margin-bottom: 16px;
  align-items: end;
}

.fgsc-toolbar label {
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color:#282834;
  margin-bottom: 6px;
  display: block;
}

.fgsc-toolbar input,
.fgsc-toolbar select {
  width: 100%;
  height: 48px;
  min-height: 48px;
  background:#fff;
  border:1px solid #ccc;
  color:#282834;
  border-radius:14px;
  padding: 0 14px;
  font-size: 15px;
  display:flex;
  align-items:center;
}

.fgsc-toolbar input:focus,
.fgsc-toolbar select:focus {
  outline: 3px solid rgba(220,39,81,.3);
  border-color:#dc2751;
}

/* Jetzt prüfen Button im Shopstil */
.fgsc-toolbar button {
  height: 48px;
  min-height: 48px;
  line-height: 48px;
  padding: 0 26px;
  background:#dc2751;
  color:#fff;
  border:none;
  border-radius:9999px;
  cursor:pointer;
  font-size:15px;
  font-family:'Poppins', sans-serif;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition: all .18s ease;
}
.fgsc-toolbar button:hover { background:#dc2751; color:#ffffffcc; transform: translateY(-1px); }
.fgsc-toolbar button:focus { outline: 3px solid rgba(220,39,81,.4); }

/* 10) Notes */
.fgsc-note { font-size:14px; margin:12px 0; padding:12px; border-radius: 8px; line-height: 1.6; background:transparent;  }

/* 11) CTA Einzeilig */
.fgsc-cta { margin-top:20px; margin-bottom:20px; }

/* 12) CTA Grid drei Buttons */
.fgsc-cta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px;
  margin-top: 24px;
  margin-bottom: 24px;
}

/* Basis CTA Button */
.fgsc-cta-btn {
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:14px 26px;
  border-radius:9999px;
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:15px;
  text-decoration:none;
  transition: all .18s ease;
}

/* Online buchen */
.fgsc-cta-primary { background:#dc2751; color:#fff; }
.fgsc-cta-primary:hover { background:#dc2751; color:#ffffffcc; transform:translateY(-1px); }

/* Telefonische Buchung */
.fgsc-cta-phone { background:#f0f0f3; color:#282834; }
.fgsc-cta-phone:hover { background:#e3e3e6; color:#282834; transform:translateY(-1px); }

/* Erstgespräch */
.fgsc-cta-consult { background:#282834; color:#fff; }
.fgsc-cta-consult:hover { background:#1d1d24; color:#ffffffcc; transform:translateY(-1px); }

/* 13) Freie Blöcke Liste */
.fgsc-block-title { margin-top:16px; margin-bottom:10px; font-weight:700; font-size: 15px; }
.fgsc-block-item {
  display:inline-block;
  margin:6px 8px 6px 0;
  padding:8px 12px;
  border-radius:8px;
  background:#f7f7f7;
  border:1px solid #e5e5e5;
  transition: all 0.2s ease;
  font-size: 14px;
}
.fgsc-block-item:hover {
  background: #2ecc71;
  color: #fff;
  border-color: #2ecc71;
  cursor: pointer;
  transform: translateY(-1px);
}
.fgsc-none { margin:12px 0; padding:12px; background: #f9f9f9; border-radius: 8px; color:#666; line-height: 1.6; }
.fgsc-ok { color:#2ecc71; font-weight:600; }
.fgsc-bad { color:#dc2751; font-weight:600; }

/* 14) Hinweise */
.fgsc-hinweis-important {
  margin-top:24px;
  margin-bottom:16px;
  padding:16px 20px;
  background:rgba(220,39,81,.07);
  border-left:4px solid #dc2751;
  border-radius:10px;
  font-size:15px;
  line-height:1.6;
  display:flex;
  align-items:flex-start;
}
.fgsc-hinweis-green {
  margin-top:20px;
  margin-bottom:16px;
  padding:16px 20px;
  background:rgba(46,204,113,.10);
  border-left:4px solid #2ecc71;
  border-radius:10px;
  font-size:15px;
  color:#1d7f4c;
  line-height:1.6;
  display:flex;
  align-items:flex-start;
}

/* 15) Hilfe Bereich */
.fgsc-help { margin-top:24px; margin-bottom:16px; padding:16px 20px; background:#ffffff; border-radius:10px; border:1px solid #e0e0e0; } 
.fgsc-help summary { font-weight:600; font-size:15px; color:#282834; cursor:pointer; padding:4px 0; list-style: none; }
.fgsc-help ol { margin:16px 0 6px 0; padding-left: 20px; }
.fgsc-help li { margin:10px 0; line-height:1.6; color:#282834; }
.fgsc-help strong { color:#dc2751; }

/* 16) Loader */
.fgsc-loading { display:flex; align-items:center; justify-content:center; gap:10px; padding:20px; margin:12px 0; color:#6d6d6d; font-size:14px; }
.fgsc-spinner {
  width:18px; height:18px;
  border:3px solid #f3f3f3;
  border-top:3px solid #dc2751;
  border-radius:50%;
  animation: fgsc-spin 0.8s linear infinite;
}
@keyframes fgsc-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

/* 17) Mobile Fixes Date Input */
.fgsc-toolbar input[type="date"] {
  -webkit-appearance: none !important;
  appearance: none !important;
  position: relative;
  z-index: 2;
  border:1px solid #ccc !important;
  background:#fff !important;
}
.fgsc-toolbar input[type="date"]:invalid {
  border-color:#dc2751 !important;
  background:#fff5f7 !important;
  color:#dc2751 !important;
}

/* Android Placeholder Workaround */
@media (max-width: 600px) {
  .fgsc-toolbar input[type="date"]::before {
    content: attr(placeholder);
    color: #999;
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events:none;
  }
  .fgsc-toolbar input[type="date"]:focus::before,
  .fgsc-toolbar input[type="date"]:valid::before { content: ""; }
}

/* 18) Select Dauer Mobile Fix */
@media (max-width: 768px) {
  #fgsc-duration {
    height: 55px !important;
    min-height: 55px !important;
    line-height: 55px !important;
    font-size: 16px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    text-indent: 12px !important;
    border: 1px solid #ccc !important;
    border-radius: 10px !important;
    background-color: #fff !important;
    color: #282834 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23282834' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    padding-right: 40px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-sizing: border-box !important;
  }
  @supports (-webkit-touch-callout: none) {
    #fgsc-duration {
      height: 57px !important;
      min-height: 57px !important;
      line-height: 57px !important;
    }
  }
}

/* 19) Barrierefreiheit extras */
* { scroll-margin-top: 80px; }
.fgsc-cta-btn:focus,
.fgsc-toolbar input:focus,
.fgsc-toolbar select:focus,
.fgsc-toolbar button:focus {
  outline: 3px solid rgba(220,39,81,.4);
  outline-offset: 2px;
}

/* 20) Responsive Regeln */
@media (max-width: 900px) {
  .fgsc-toolbar { grid-template-columns: 1fr; }
  .fgsc-cta-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  #fgsc-calendar { padding: 14px !important; }
  .fc .fc-daygrid-day { min-height: 58px !important; font-size: 16px !important; }
  .fc-daygrid-day-number { font-size: 16px !important; }
  .fgsc-toolbar input,
  .fgsc-toolbar select,
  .fgsc-toolbar button {
    padding: 0 16px !important;
    font-size: 16px !important;
    min-height: 48px !important;
  }
}
@media (max-width: 480px) {
  .fgsc-card { padding: 16px; }
  .fgsc-cta-btn { font-size: 16px; padding: 14px 20px; }
}

.fgsc-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #d72852;
  color: #ffffff;
  font-size: 13px;
  font-weight: 600;
  margin-right: 8px;
  flex-shrink: 0;
  font-family: Arial, sans-serif;
  box-shadow: 0 1px 2px rgba(0,0,0,0.15);
}
.fgsc-info-icon::before {
  content: "i";
}

.fgsc-thanks {
  margin-top: 22px;
  margin-bottom: 4px;
  font-weight: 600;
  font-size: 15px;
  color: #282834;
  opacity: 0.9;
}

.fgsc-hint-small {
  font-size: 14px;
  color: #6d6d6d;
  margin: 6px 0 12px 0;
}

/* Wochentage im FullCalendar dauerhaft sichtbar erzwingen */
.fc .fc-col-header {
  height: 32px !important;
  min-height: 32px !important;
  background: #ffffff !important;
}

.fc .fc-col-header-cell {
  background: #ffffff !important;
  border: none !important;
}

.fc .fc-col-header-cell-cushion {
  color: #282834 !important;
  font-size: 15px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  padding: 4px 0 !important;
  display: block !important;
  overflow: visible !important;
  opacity: 1 !important;
}

/* FullCalendar Bug Fix: Header darf nicht abgeschnitten werden */
.fc .fc-scrollgrid-sync-table {
  overflow: visible !important;
}

.fc-day-header {
  display: block !important;
  visibility: visible !important;
  color: #282834;
  font-weight: 600;
}

/* Header leicht grau 5 Prozent */
.fc .fc-col-header,
.fc .fc-scrollgrid thead,
.fc-theme-standard th.fc-col-header-cell {
  background-color: rgba(0, 0, 0, 0.01) !important;
  background-image: none !important;
}

/* Textkissen sichtbar lassen */
.fc .fc-col-header-cell-cushion {
  display: block !important;
  background: transparent !important;
}

.fc .fc-col-header-cell-cushion {
  color: #ffffff !important;
}


/* nur für meine alte Studioseite wichtig Handyanpassung LEgende */


@media (max-width: 768px) {
  .fgsc-legend {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .fgsc-legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    text-align: center;
  }
}
