/* ===== Fonts ===== */

/* ==== Lokale Webfonts ==== */
/* Poppins (nur Regular vorhanden) */
@font-face{
  font-family: 'PoppinsLocal';
  src: url('/fonts/Poppins-Regular.woff2') format('woff2'),
       url('/fonts/Poppins-Regular.ttf')   format('truetype');
  font-weight: 400; font-style: normal; font-display: swap;
}
/* Faux-Semibold: mappe 600 auf dieselbe Datei, damit kein Fallback greift */
@font-face{
  font-family: 'PoppinsLocal';
  src: url('/fonts/Poppins-Regular.woff2') format('woff2'),
       url('/fonts/Poppins-Regular.ttf')   format('truetype');
  font-weight: 600; font-style: normal; font-display: swap;
}

/* The Seasons (Regular) */
@font-face{
  font-family: 'TheSeasons';
  src: url('/fonts/fonnts.com-The-Seasons-.woff2') format('woff2'),
       url('/fonts/fonnts.com-The-Seasons-.otf')   format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}

/* Globale Zuweisung */
:root{
  --font-body: 'PoppinsLocal', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-head: 'TheSeasons', serif;
}

/* Anwenden */
body{ font-family: var(--font-body); }
h1,h2,h3,h4,h5,h6{
  font-family: var(--font-head);
  /* falls nur Regular vorhanden → erlaub synthetisches Bold/Italic */
  font-synthesis: weight style;
}


/* ===== Design-Variablen ===== */
:root{
  --gold:      #BF9C67; /* Primary */
  --gold-2:    #96794E;
  --gold-3:    #6B5433; /* Dark */
  --gold-lite: #EAC989;
  --ivory:     #FDF7D0;

  --bg-deep:   #1B1611;
  --text:      var(--ivory);
  --muted:     rgba(253,247,208,.75);
  --card-bg:   rgba(20,16,12,.72);
  --card-bd:   rgba(191,156,103,.28);
  --focus:     rgba(191,156,103,.55);

  /* Fonts */
  --font-body: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-head: 'TheSeasons', serif;
}

/* ===== Reset / Base ===== */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  display:flex; justify-content:center; align-items:center;
  font-family: var(--font-body);
  color:var(--text);
  background: var(--bg-deep) url('/img/bg.jpg') center/cover no-repeat fixed;
}

/* ===== Typografie ===== */
h1,h2,h3,h4,h5,h6{
  font-family: var(--font-head);
  letter-spacing:.02em;
  color:var(--ivory);
  /* falls du nur Regular hast, synthetisches Bold erlauben: */
  font-synthesis: weight style;
}
h1{font-weight:700; font-size:2rem}
h2{font-weight:700; font-size:1.5rem}
h3{font-weight:400; font-size:1.2rem}
.muted{color:var(--muted)}

/* ===== Container ===== */
.wide-container,
.main-container{
  position:relative;
  background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.72)), var(--card-bg);
  border:1px solid var(--card-bd);
  border-radius:14px;
  backdrop-filter: blur(4px);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  padding:40px; width:90%; text-align:center;
}
.wide-container{max-width:1200px}
.main-container{max-width:500px}

/* Logout oben rechts im Container */
.btn.logout{
  position:absolute; top:14px; right:14px; margin-top:0;
}

/* ===== Inputs ===== */
input[type="email"],
input[type="password"],
input[type="text"],
textarea{
  width:100%; padding:12px 14px; margin:10px 0;
  border-radius:10px; border:1px solid var(--card-bd);
  background: rgba(255,255,255,.08);
  color:var(--ivory); font-size:1rem;
  outline:none; transition: box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
textarea{min-height:110px; resize:vertical}
input:focus, textarea:focus{
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--focus);
  background: rgba(255,255,255,.10);
}

/* ===== Links ===== */
a{color:var(--ivory); text-decoration:underline; display:block; margin-top:10px}
a.button, a.btn{display:inline-flex; text-decoration:none; margin-top:0}

/* ===== Buttons (einheitlich für <a> & <button>) ===== */
.button, .btn, button.button {
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;

  padding: .65rem 1rem;
  min-height: 44px;
  line-height: 1;
  white-space: nowrap;
  font: inherit;
  font-size: 1rem;
  font-weight: 600;

  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.18);
  cursor: pointer;
  text-decoration: none;
  margin: 0;

  transition: transform .12s ease, opacity .2s ease,
              box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
a.button, a.btn { display: inline-flex !important; text-decoration: none !important; margin: 0 !important; }

/* Primary */
.button.primary, .btn.primary, .btn-primary, button.button.primary, button.btn-primary {
  color: #1b1611;
  background: linear-gradient(180deg, var(--gold), var(--gold-2));
  border-color: rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 8px 18px rgba(191,156,103,.25);
}

/* Hover/Active */
.button.primary:hover, .btn.primary:hover, .btn-primary:hover,
button.button.primary:hover,
.button:hover, .btn:hover, button.button:hover {
  transform: translateY(-1px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.3), 0 12px 22px rgba(191,156,103,.3);
  opacity: .98;
}
.button.primary:active, .btn.primary:active, .btn-primary:active,
button.button.primary:active,
.button:active, .btn:active, button.button:active {
  transform: translateY(0);
  opacity: .92;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2), 0 6px 12px rgba(191,156,103,.22);
}

/* Secondary */
.btn-secondary, .button.secondary, button.button.secondary {
  color: var(--ivory);
  background: linear-gradient(180deg, #3a2e22, #2a2119);
  border-color: rgba(255,255,255,.16);
}
.btn-secondary:hover, .button.secondary:hover, button.button.secondary:hover {
  opacity: .95; transform: translateY(-1px);
}
	  
	  
	  .chat-actions .action-small{
  position: static;                 /* falls logout global absolut positioniert ist */
  top:auto; right:auto; bottom:auto; left:auto;
  padding: .35rem .7rem;
  min-height: 32px;
  font-size: .9rem;
  line-height: 1;
  border-radius: 10px;
  margin: 0;
}

/* Optional: gleiche Größe auch auf kleinen Screens */
@media (max-width: 600px){
  .chat-actions .action-small{
    padding: .3rem .6rem;
    min-height: 30px;
    font-size: .85rem;
  }
}
	  
	  /* Mic-Recording-State */
#mic-btn.recording{
  box-shadow: 0 0 0 2px rgba(191,156,103,.45) inset;
}
#mic-btn.recording::before{
  content:'●';
  margin-right:.4rem;
  color:#ff4d4d;
}

	  /* ===== Dashboard Grid + Cards ===== */
.app-grid{
  display:grid; gap:16px; margin-top:14px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.app-card{
  text-align:left;
  background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.65));
  border:1px solid var(--card-bd);
  border-radius:14px; padding:16px;
  box-shadow: 0 6px 16px rgba(0,0,0,.28);
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.app-card:hover{
  transform: translateY(-2px);
  border-color: rgba(191,156,103,.45);
  box-shadow: 0 12px 28px rgba(191,156,103,.15);
}
.app-card .muted{color:var(--muted)}
.app-card .button, .app-card .btn{margin-top:8px}

/* ===== Helpers ===== */
.row{display:flex; align-items:center; justify-content:space-between; gap:10px}
.divider{height:1px; background: rgba(253,247,208,.18); margin:14px 0}

/* ===== Jackie AI Chat ===== */
.antwort-box{
  background: rgba(253,247,208,.04);
  border:1px solid rgba(191,156,103,.28);
  border-left:4px solid var(--gold);
  padding:14px; border-radius:10px; margin-top:14px; text-align:left;
}
.antwort-box strong{
  display:block; margin-bottom:6px; font-family: var(--font-head);
}

.chips{display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin:12px 0}
.chip{
  background: rgba(255,255,255,.06);
  border:1px solid rgba(191,156,103,.35);
  color:var(--ivory); padding:6px 12px; border-radius:999px; cursor:pointer;
  transition: transform .12s ease, opacity .2s ease, box-shadow .2s ease;
}
.chip:hover{transform:translateY(-1px); box-shadow:0 6px 12px rgba(191,156,103,.2)}

.loading{display:none; gap:8px; align-items:center; margin-left:10px}
.dot{width:8px; height:8px; border-radius:50%; background: var(--ivory); opacity:.7; animation: blink 1s infinite alternate}
.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}
@keyframes blink{to{opacity:.2; transform: translateY(-2px)}}

/* ===== Responsive ===== */
@media (max-width: 600px){
  .main-container, .wide-container{padding:20px}
  .btn.logout{top:10px; right:10px}
  h1{font-size:1.6rem}
}

/* ———————————————————————————————
   Tipp für schnellere Webfont-Ladung (in HTML <head>):
   <link rel="preconnect" href="https://fonts.googleapis.com">
   <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
   ——————————————————————————————— */
