/* Universal branding for all coaches */
/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@600&family=Open+Sans:wght@400&family=Poppins:wght@700&display=swap');

/* Brand tokens */
:root{
  --brand-dark:#002f45;
  --brand-mid:#1a3d52;
  --brand-accent:#16c2c6;
  --bg:#f7fafc;
  --text:#1f2937;
  --muted:#4a5568;
  --white:#ffffff;
  --shadow:0 20px 40px rgba(0,0,0,0.1);
  --radius:20px;
}

/* Reset-ish */
*{margin:0;padding:0;box-sizing:border-box}

/* Base */
html,body{height:100%}
body{
  font-family:'Open Sans','Lato',sans-serif;
  background: linear-gradient(135deg, var(--brand-dark) 0%, var(--brand-mid) 100%);
  color: var(--white);
}

/* Card container (login + chat shell) */
.container, .chat-container{
  background: var(--white);
  color: var(--text);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  max-width: 900px;
  width: 92%;
  margin: 24px auto;
}

/* Header */
.header{
  background: linear-gradient(45deg, var(--brand-dark), var(--brand-accent));
  color: var(--white);
  padding: 20px;
  text-align:center;
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);
  position: relative;
}
.coach-info{
  display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:6px;
}
.header-avatar{
  width:60px;height:60px;border-radius:50%;object-fit:cover;
  border:3px solid rgba(255,255,255,.35);
}
.coach-name{
  font-family:'Poppins',sans-serif;font-weight:700;font-size:28px;
}
.tagline{opacity:.9}

/* Mini tags row under tagline */
.expertise-tags{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:10px
}
.tag{
  background: rgba(255,255,255,.2);
  padding:6px 12px;border-radius:14px;font-size:12px;font-weight:600;
}

/* Login card specifics */
.container{padding:32px}
.logo-section{margin-bottom:16px}
.expertise-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0;
}
.expertise-item{
  background:#f7fafc;padding:12px;border-radius:10px;color:var(--muted);font-size:14px;
}
.expertise-item strong{color:var(--text)}
.access-form{margin-top:12px}
.form-group{margin-bottom:16px;text-align:left}
label{display:block;margin-bottom:6px;font-weight:600;color:var(--text)}
input[type="text"], input[type="password"]{
  width:100%;padding:12px;border:2px solid #e2e8f0;border-radius:10px;font-size:16px;outline:none
}
input[type="text"]:focus, input[type="password"]:focus{border-color:var(--brand-accent)}
.submit-btn, .send-btn{
  width:100%;padding:12px;border:none;border-radius:12px;
  background: linear-gradient(135deg, var(--brand-accent) 0%, #00bcd4 100%);
  color:#fff;font-weight:700;cursor:pointer;transition:transform .2s
}
.submit-btn:hover, .send-btn:hover{transform:translateY(-1px)}
.submit-btn:disabled, .send-btn:disabled{opacity:.6;cursor:not-allowed}
.error-message{color:#e53e3e;margin-top:8px}
.loading{color:var(--brand-accent);margin-top:8px}

/* Chat layout */
.chat-container{display:flex;flex-direction:column;min-height:70vh}
.messages{flex:1;max-height:calc(100vh - 220px);overflow-y:auto;padding:20px}
.message{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}
.message-avatar{
  width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;flex-shrink:0;overflow:hidden;background:#e2e8f0;color:#2d3748
}
.avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}
.message-content{
  max-width:72%;padding:14px;border-radius:18px;line-height:1.5;border:1px solid #e2e8f0;background:#fff;color:#2d3748
}
.message.user{flex-direction:row-reverse}
.message.user .message-avatar{background:var(--brand-accent);color:#fff}
.message.user .message-content{
  background: var(--brand-accent);
  color:#fff;border-color: transparent;border-bottom-right-radius:6px
}
.message.assistant .message-content{border-bottom-left-radius:6px}

/* Input area */
.input-container{
  padding:16px;
  background:#fff;
  border-top:1px solid #e2e8f0;
}

/* Use flexbox for better mobile responsiveness */
.input-form{
  display:flex;
  gap:8px;
  align-items:center;
  max-width:900px;
  margin:0 auto;
  flex-wrap:wrap;
}

.input-field{
  flex:1;
  min-width:200px;
  min-height:44px;
  padding:12px 14px;
  border:2px solid #e2e8f0;
  border-radius:24px;
  font-size:16px;
  outline:none;
}
.input-field:focus{ border-color: var(--brand-accent); }

.send-btn{
  padding:12px 18px;
  border:none;
  border-radius:24px;
  font-weight:700;
  color:#fff;
  cursor:pointer;
  white-space:nowrap;
  flex-shrink:0;
}

.download-btn{ 
  background:#4CAF50; 
  padding:12px 16px;
}

/* Mobile responsive adjustments */
@media (max-width: 640px) {
  .input-form {
    gap:6px;
  }
  
  .send-btn, .download-btn {
    padding:12px 14px;
    font-size:14px;
  }
  
  .download-btn {
    padding:12px 10px;
  }
}

/* Very small screens - stack buttons below input */
@media (max-width: 480px) {
  .input-form {
    flex-direction:column;
    gap:10px;
  }
  
  .input-field {
    width:100%;
    min-width:unset;
  }
  
  .send-btn, .download-btn {
    width:100%;
    padding:12px;
  }
}



/* Typing indicator */
.typing-indicator{display:none;align-items:center;gap:10px;margin:8px 20px}
.typing-indicator.show{display:flex}
.typing-dot{width:8px;height:8px;background:#cbd5e0;border-radius:50%;animation:typing 1.5s infinite}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-8px)}}

/* Misc */
.logout-btn{
  position:absolute;top:16px;right:16px;background:rgba(255,255,255,.2);
  color:#fff;border:none;padding:8px 14px;border-radius:14px;font-size:14px;cursor:pointer
}
.logout-btn:hover{background:rgba(255,255,255,.3)}
.welcome-message{
  text-align:center;
  color:var(--muted);
  margin:24px 0;
  font-style:italic;
  white-space:normal;        /* allow wrapping */
  overflow-wrap:anywhere;    /* break long words if needed */
  max-width:100%;
}


/* Assistant response formatting */
.message.assistant .message-content h4{color:var(--brand-accent);margin-bottom:8px;font-weight:700}
.message.assistant .message-content ul{margin:10px 0 0 18px}
.message.assistant .message-content li{margin-bottom:6px}
/* --- Avatar sizing (header & chat) --- */
.header-avatar {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,0.3);
}

.avatar-image {
  width: 40px;
  height: 40px;
  object-fit: cover;
  border-radius: 50%;
}

/* Safety: never let any <img> blow up the layout */
img { max-width: 100%; height: auto; }

.header { text-align: center; }
.coach-info { display:flex; align-items:center; justify-content:center; gap:12px; }
.tagline { opacity:.9; }
.expertise-tags { display:flex; flex-wrap:wrap; justify-content:center; gap:8px; margin-top:10px; }
/* Access page button */
.access-btn { width: 100%; }                 /* always full width */
/* Or, if you want full width only on small screens: */
/*
@media (max-width: 640px) {
  .access-btn { width: 100%; }
}
*/
.starter-prompts{
  display:flex; flex-wrap:wrap; gap:8px; margin:12px auto 0; max-width:900px;
}
.starter-prompts button{
  padding:8px 12px; border-radius:20px; border:1px solid var(--brand-accent);
  background:rgba(22,194,198,0.12); color:#005e70; font-weight:600; cursor:pointer;
}
.starter-prompts button:hover{ filter:brightness(1.05); }

/* Pills + emoji (header tags) */
.expertise-tags { gap: 12px; }

.tag{
  background:#ffffff;
  color:#0b3a46;
  border:1px solid rgba(0,0,0,0.08);
  font-size:16px;
  padding:8px 14px;
  border-radius:16px;
}

.tag .emoji{
  font-size:1.35em;
  line-height:1;
  vertical-align:-2px;
  margin-right:6px;
}

.tag--specialty{
  background:#ffffff;
  color:#0b3a46;
  border-color:rgba(0,0,0,0.08);
}
