/* manji.ai — shared styles. Brand kit sourced from /amia/agency/GUIde/theme/tokens.json
   and /amia/agency/GUIde/assets/. Colors + fonts match the Manji brand exactly. */

/* ───────── brand fonts ───────── */
@font-face {
  font-family: "Alte DIN 1451 Mittelschrift";
  src: url("/assets/fonts/din1451alt.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("/assets/fonts/EBGaramond12-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("/assets/fonts/EBGaramond12-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ───────── brand tokens (mirror of GUIde/theme/tokens.json palette.dark + accent) ───────── */
:root {
  /* dark palette */
  --base:     #0E0E10;
  --raised:   #161618;
  --elevated: #1E1E22;
  --ink:      #F5EDE8;
  --ink-70:   #F5EDE8B3;
  --ink-50:   #F5EDE880;
  --ink-30:   #F5EDE84D;
  --ink-10:   #F5EDE81A;
  --line:     #FFFFFF14;

  /* accent palette */
  --indigo:   #3D4AAA;
  --green:    #00bf63;
  --saffron:  #E55936;
  --yellow:   #FFCC03;
  --danger:   #FF4444;

  /* aliases used below */
  --bg:       var(--base);
  --fg:       var(--ink);
  --muted:    var(--ink-70);
  --dim:      var(--ink-50);
  --card:     var(--raised);
  --field:    var(--base);
  --accent:        var(--indigo);
  --accent-hover:  #4A58C7;
  --error:    var(--danger);
  --success:  var(--green);
}

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

html, body { height: 100%; }
body {
  font-family: "EB Garamond", Georgia, serif;
  background: var(--bg);
  color: var(--fg);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

.page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
}

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 40px 32px;
  width: 100%;
  max-width: 460px;
}

.dash-card { max-width: 720px; }

.brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 32px;
}
.brand img { width: 44px; height: 44px; }
.brand .name {
  font-family: "Alte DIN 1451 Mittelschrift", "EB Garamond", sans-serif;
  font-size: 1.5rem;
  letter-spacing: 0.04em;
  color: var(--ink);
  text-transform: uppercase;
}

h1 {
  font-family: "Alte DIN 1451 Mittelschrift", "EB Garamond", sans-serif;
  font-size: 1.85rem;
  font-weight: normal;
  margin-bottom: 8px;
  letter-spacing: 0.01em;
  line-height: 1.15;
}
.sub {
  color: var(--muted);
  font-size: 1rem;
  margin-bottom: 24px;
}

label {
  display: block;
  font-family: "Alte DIN 1451 Mittelschrift", sans-serif;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-70);
  margin-bottom: 6px;
  margin-top: 18px;
}
input[type="email"], input[type="password"], input[type="text"] {
  width: 100%;
  padding: 12px 14px;
  background: var(--field);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  font-size: 1rem;
  font-family: "EB Garamond", Georgia, serif;
}
input:focus {
  outline: none;
  border-color: var(--accent);
}
input:read-only {
  color: var(--ink-70);
  background: var(--base);
}

button.btn {
  width: 100%;
  margin-top: 24px;
  padding: 13px 16px;
  background: var(--accent);
  color: var(--ink);
  border: none;
  border-radius: 8px;
  font-family: "Alte DIN 1451 Mittelschrift", sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s;
}
button.btn:hover:not(:disabled) { background: var(--accent-hover); }
button.btn:disabled { background: var(--ink-30); cursor: wait; color: var(--ink-50); }

button.btn.ghost {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink);
}
button.btn.ghost:hover:not(:disabled) { border-color: var(--accent); background: transparent; }

.msg {
  margin-top: 16px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 0.95rem;
  display: none;
}
.msg.error   { background: #FF44441A; color: var(--danger); border: 1px solid #FF444466; display: block; }
.msg.success { background: #00BF631A; color: var(--green);  border: 1px solid #00BF6366; display: block; }

.foot {
  margin-top: 28px;
  text-align: center;
  color: var(--ink-50);
  font-size: 0.9rem;
}
.foot a { color: var(--ink-70); text-decoration: none; border-bottom: 1px solid var(--ink-30); }
.foot a:hover { color: var(--ink); border-color: var(--ink); }

/* dashboard */
.dash-row { display: flex; align-items: center; justify-content: space-between; padding: 18px 0; border-bottom: 1px solid var(--line); }
.dash-row:last-child { border-bottom: none; }
.dash-row .lbl {
  font-family: "Alte DIN 1451 Mittelschrift", sans-serif;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-70);
}
.dash-row .val { color: var(--ink); font-size: 1rem; }

.uuid-block {
  background: var(--base);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 24px 20px;
  margin: 16px 0 24px 0;
  text-align: center;
}
.uuid-block .uuid {
  font-family: ui-monospace, "SF Mono", Monaco, Consolas, monospace;
  font-size: 1.1rem;
  color: var(--accent);
  word-break: break-all;
  user-select: all;
  cursor: copy;
  letter-spacing: 0.02em;
}
.uuid-block .copy-hint {
  color: var(--ink-50);
  font-size: 0.8rem;
  margin-top: 10px;
  font-family: "Alte DIN 1451 Mittelschrift", sans-serif;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.actions { display: flex; gap: 12px; margin-top: 28px; }
.actions button { margin-top: 0; }

.status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-family: "Alte DIN 1451 Mittelschrift", sans-serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.status-pill.none     { background: var(--ink-10); color: var(--ink-70); }
.status-pill.active   { background: #00BF631F; color: var(--green); }
.status-pill.past_due { background: #FF44441F; color: var(--danger); }
.status-pill.canceled { background: var(--ink-10); color: var(--ink-50); }

.logout-link {
  color: var(--ink-70);
  text-decoration: none;
  font-family: "Alte DIN 1451 Mittelschrift", sans-serif;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.logout-link:hover { color: var(--ink); }
