/* =====================
   File: static/style.css
   ===================== */

/* Base */
:root {
  --bg: #1e1e1e;
  --panel: #2e2e2e;
  --text: #f0f0f0;
  --muted: #dcdcdc;
  --blue: #61dafb;
  --orange: #ffa500;
  --shadow: rgba(0,0,0,0.3);
}

* { box-sizing: border-box; }

body {
  font-family: Arial, Helvetica, sans-serif;
  text-align: center;
  background-color: var(--bg);
  color: var(--text);
  margin: 0;
  padding: 20px 0 0 0;
  min-height: 100vh;
  line-height: 1.6;
}

h1 { font-size: 4rem; margin: 0; color: var(--blue); }
h3 { font-size: 2rem; margin: 2rem 0 1rem; color: var(--orange); }
p { font-size: 1.2rem; margin: 10px 0; color: var(--muted); }

a { text-decoration: none; color: var(--blue); font-size: 1.1rem; margin: 0 10px; transition: color .2s ease; }
a:hover { color: var(--orange); }

.links { margin: 20px 0; }

/* Media */
.logo {
  width: 100%;
  max-width: 600px;
  height: auto;
  padding: 0 20px;
}

.artist-photo {
  max-width: 300px;
  width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 15px auto;
  display: block;
}

.slogan { padding: 0 20px; }

/* Cards / lists */
.appearances {
  background-color: var(--panel);
  padding: 15px;
  border-radius: 10px;
  width: 90%;
  max-width: 700px;
  box-shadow: 0 4px 10px var(--shadow);
  margin: 0 auto 30px;
  text-align: left;
}

.subhead { margin: .5rem 0; color: var(--blue); font-size: 1.25rem; }
.list { margin: 0 0 1rem; padding-left: 1.2rem; }
.list li { margin: .25rem 0; }
.tag {
  display: inline-block; margin-left: 8px; padding: 2px 6px; border-radius: 6px;
  background: var(--bg); border: 1px solid #444; font-size: .8rem; color: var(--muted);
}

/* MailerLite overrides (kept minimal) */
#mlb2-21954646 .ml-form-embedBody .ml-form-horizontalRow button,
#mlb2-21954646 .ml-form-embedBody .ml-form-embedSubmit button { color: #1e1e1e !important; }

/* Make ZIP truly optional */
.ml-field-z_i_p.ml-validate-required { /* drop the required style effect */ }

/* Responsive tweaks */
@media (max-width: 480px) {
  h3 { font-size: 1.6rem; }
  .subhead { font-size: 1.1rem; }
}


/* ---- Booking toggle ---- */
#booking-content{
  display:none;
  padding:10px;
  border:1px solid #444;
  background:var(--bg);
  color:var(--muted);
  border-radius:5px;
  margin-top:5px;
}
#booking-content ol{
  list-style-type: decimal;
  padding-left:20px;
  text-align:left;
  font-size:1rem;
  color:var(--muted);
}
.toggle-button{
  cursor:pointer;
  font-weight:bold;
  color:var(--blue);
  background-color:var(--panel);
  padding:8px 12px;
  border-radius:5px;
  display:inline-block;
}
.toggle-button:hover{ color:var(--orange); }

/* ---- MailerLite: light-touch dark theme ---- */
/* Container look */
#mlb2-21954646 .ml-form-embedWrapper{
  background:#000;
  border-radius:4px;
}
/* Headings/text inside the form */
#mlb2-21954646 .ml-form-embedContent h4,
#mlb2-21954646 .ml-form-successContent h4{ color:var(--blue); }
#mlb2-21954646 .ml-form-embedContent p,
#mlb2-21954646 .ml-form-successContent p{ color:var(--muted); }

/* Inputs */
#mlb2-21954646 .ml-form-fieldRow input,
#mlb2-21954646 .ml-form-fieldRow textarea,
#mlb2-21954646 .ml-form-fieldRow select,
#mlb2-21954646 .ml-form-horizontalRow input{
  background:#000 !important;
  color:#8d8d8d !important;
  border:1px solid #ccc !important;
  border-radius:4px !important;
  font-size:14px !important;
  padding:10px !important;
}

/* Buttons */
#mlb2-21954646 .ml-form-embedBody .ml-form-horizontalRow button,
#mlb2-21954646 .ml-form-embedBody .ml-form-embedSubmit button{
  background:var(--orange) !important;
  border:1px solid var(--orange) !important;
  color:#1e1e1e !important; /* ensure readable text */
  font-weight:700 !important;
  border-radius:4px !important;
}
#mlb2-21954646 .ml-form-embedBody .ml-form-horizontalRow button:hover,
#mlb2-21954646 .ml-form-embedBody .ml-form-embedSubmit button:hover{
  background:#333 !important;
  border-color:#333 !important;
  color:#fff !important;
}

/* Make ZIP truly optional visually (already in your file, keep as-is) */
.ml-field-z_i_p.ml-validate-required{}

/* ==== MailerLite: tighten layout & colors ==== */
#subscribe { margin: 30px 0; }

/* center the widget and give it your card look */
#subscribe .ml-form-embedWrapper {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
  background: #000;          /* keep their black but within a card */
  border-radius: 10px;
  box-shadow: 0 4px 10px var(--shadow);
}

/* add padding like your .appearances card */
#subscribe .ml-form-embedBody,
#subscribe .ml-form-successBody { padding: 20px; }

#subscribe .ml-form-embedContent h4 { color: var(--blue); margin: 0 0 10px; }
#subscribe .ml-form-embedContent p,
#subscribe .ml-form-successContent p { color: var(--muted); }

/* inputs readable on dark background */
#subscribe .ml-form-fieldRow input,
#subscribe .ml-form-fieldRow textarea,
#subscribe .ml-form-horizontalRow input {
  background: #000 !important;
  color: #dcdcdc !important;
  border: 1px solid #555 !important;
  border-radius: 4px !important;
  padding: 10px !important;
}
#subscribe .ml-form-fieldRow input::placeholder { color: #8d8d8d; }
#subscribe .ml-form-fieldRow input:focus { outline: none; border-color: var(--blue) !important; }

/* buttons consistent with theme */
#subscribe .ml-form-embedSubmit button,
#subscribe .ml-form-horizontalRow button {
  background: var(--orange) !important;
  border: 1px solid var(--orange) !important;
  color: #1e1e1e !important;
  font-weight: 700 !important;
  border-radius: 4px !important;
}
#subscribe .ml-form-embedSubmit button:hover,
#subscribe .ml-form-horizontalRow button:hover {
  background: #333 !important;
  border-color: #333 !important;
  color: #fff !important;
}
