/* ============================================================================
   Jay-I MVP — abraham.com brand system (dark, editorial, luxury-advisory)
   Cormorant Garamond (display) + Source Serif 4 (body/UI). See source/brand-abraham.md
   ============================================================================ */
:root{
  --bg:#0D0D0D;            /* warm near-black page */
  --panel:#2A2520;         /* warm dark panel / raised surface */
  --panel-2:#1A1714;       /* deeper panel / inputs */
  --cream:#F5F0E8;         /* primary text / headings */
  --cream-soft:rgba(245,240,232,.82);
  --cream-faint:rgba(245,240,232,.55);
  --gold:#C9A84C;          /* signature accent */
  --gold-deep:#A8893B;     /* hover/pressed gold */
  --taupe:#8A8070;         /* muted labels / captions */
  --line:rgba(245,240,232,.10);
  --line-strong:rgba(245,240,232,.18);
  --shadow:0 24px 60px rgba(0,0,0,.55);
  --shadow-soft:0 16px 40px rgba(0,0,0,.40);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg)}
body{
  font-family:"Source Serif 4",Georgia,serif;color:var(--cream);
  background:
    radial-gradient(1100px 600px at 50% -10%, rgba(201,168,76,.06), transparent 70%),
    radial-gradient(800px 500px at 90% 110%, rgba(201,168,76,.04), transparent 70%),
    var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
.screen{min-height:100vh;display:flex;flex-direction:column}
.hidden{display:none!important}
h1,h2,h3,.brand-mark,.chat-title,.display{
  font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;letter-spacing:.2px;
}
.gilt{color:var(--gold);font-style:italic}
a{color:var(--gold)}

/* ---- kicker label (small uppercase letter-spaced gold) ---- */
.kicker{
  font-family:"Source Serif 4",serif;font-size:11.5px;font-weight:600;
  letter-spacing:3px;text-transform:uppercase;color:var(--gold);
}
.rule{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.6;border:0;margin:18px 0}
.rule.short{max-width:64px;margin:14px 0;background:var(--gold);opacity:.85}

/* ---- brand mark ---- */
.brand-mark{
  width:60px;height:60px;border-radius:50%;background:var(--panel-2);
  border:1px solid var(--gold);color:var(--gold);display:grid;place-items:center;
  font-size:26px;font-weight:600;letter-spacing:0;margin:0 auto 20px;
  box-shadow:inset 0 0 0 1px rgba(201,168,76,.18),0 8px 24px rgba(0,0,0,.4);
}
.brand-mark span{color:var(--cream);opacity:.85}
.brand-mark.sm{width:34px;height:34px;font-size:15px;margin:0;border-radius:50%}

/* ---- buttons ---- */
button{
  font-family:"Source Serif 4",serif;font-weight:600;font-size:15px;
  padding:13px 22px;border:1px solid var(--gold);border-radius:2px;
  background:var(--gold);color:#1A1409;cursor:pointer;
  transition:background .2s,transform .06s,opacity .2s,border-color .2s;
  letter-spacing:.3px;
}
button:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
button:active{transform:translateY(1px)}
button:disabled{opacity:.45;cursor:default}
.ghost{
  background:transparent;color:var(--cream-soft);border:1px solid var(--line-strong);
  padding:10px 16px;font-size:14px;border-radius:2px;
}
.ghost:hover{background:transparent;color:var(--cream);border-color:var(--gold)}
.linklike{
  background:none;border:none;color:var(--taupe);padding:6px 4px;font-size:13px;
  letter-spacing:.4px;text-decoration:underline;text-underline-offset:3px;cursor:pointer;
}
.linklike:hover{color:var(--gold);background:none}

/* ---- forms ---- */
form{display:flex;flex-direction:column;gap:12px}
label{font-size:11.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--taupe)}
input,textarea{
  font-family:"Source Serif 4",serif;font-size:16px;padding:14px 16px;
  border:1px solid var(--line-strong);border-radius:2px;background:var(--panel-2);
  color:var(--cream);outline:none;transition:border-color .2s,box-shadow .2s;
}
input::placeholder,textarea::placeholder{color:var(--cream-faint)}
input:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.12)}

/* ---- login ---- */
#login{align-items:center;justify-content:center;gap:18px;padding:24px}
.card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line-strong);border-radius:6px;padding:48px 42px;width:100%;
  max-width:440px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.7}
.brand{text-align:center;margin-bottom:30px}
.brand h1{font-size:52px;line-height:1;letter-spacing:1px}
.tag{color:var(--cream-soft);font-size:15px;margin-top:12px;line-height:1.55;font-style:italic}
.msg{margin-top:16px;font-size:14px;line-height:1.6;color:var(--cream-soft);min-height:20px}
.msg a{color:var(--gold);font-weight:600}
.footnote{color:var(--taupe);font-size:12.5px;letter-spacing:.3px}

/* ---- topbar ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 26px;
  border-bottom:1px solid var(--line);background:rgba(13,13,13,.85);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:5}
.topbar-brand{display:flex;align-items:center;gap:11px;font-family:"Cormorant Garamond",serif;
  font-size:24px;font-weight:600;letter-spacing:.5px}
.topbar-right{display:flex;align-items:center;gap:16px}
.who{font-size:13px;color:var(--taupe);letter-spacing:.3px}

/* ---- picker ---- */
.picker{max-width:960px;margin:0 auto;padding:56px 24px}
.picker .kicker{display:block;margin-bottom:14px}
.picker h2{font-size:44px;line-height:1.05;letter-spacing:.3px}
.picker-sub{color:var(--cream-soft);margin:14px 0 34px;font-size:16px;max-width:640px;line-height:1.65}
.track{margin-bottom:46px}
.track:last-child{margin-bottom:0}
.track-title{font-family:"Cormorant Garamond",serif;font-size:26px;font-weight:600;color:var(--cream);
  margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.day-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:20px}
.day-card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:5px;padding:26px;cursor:pointer;
  transition:transform .14s ease,box-shadow .25s ease,border-color .25s;
  display:flex;flex-direction:column;gap:11px;min-height:180px;position:relative;
}
.day-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--gold)}
.day-num{font-size:11.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold)}
.day-card h3{font-size:25px;font-weight:600;line-height:1.12;color:var(--cream)}
.day-card p{color:var(--cream-soft);font-size:14.5px;line-height:1.55}
.day-card .start{margin-top:auto;font-size:13px;font-weight:600;letter-spacing:.4px;color:var(--gold)}

/* ---- chat ---- */
.chat{max-width:820px;margin:0 auto;width:100%;display:flex;flex-direction:column;height:calc(100vh - 65px)}
.chat-head{display:flex;align-items:center;gap:16px;padding:18px 24px;border-bottom:1px solid var(--line)}
.chat-title{font-size:24px;color:var(--cream)}
.messages{flex:1;overflow-y:auto;padding:30px 24px;display:flex;flex-direction:column;gap:20px}
.bubble{max-width:80%;padding:16px 19px;border-radius:6px;font-size:15.5px;line-height:1.65;
  white-space:pre-wrap;word-wrap:break-word}
.bubble.jay{background:var(--panel);border:1px solid var(--line);border-bottom-left-radius:2px;
  align-self:flex-start;color:var(--cream)}
.bubble.me{background:var(--gold);color:#1A1409;border-bottom-right-radius:2px;align-self:flex-end}
.bubble .name{display:block;font-size:10.5px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;opacity:.65;margin-bottom:6px}
.typing{display:inline-flex;gap:5px;align-items:center}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:1}}
.composer{display:flex;gap:12px;padding:18px 24px;border-top:1px solid var(--line);background:rgba(13,13,13,.6)}
.composer textarea{flex:1;resize:none;max-height:160px}
.composer button{align-self:flex-end}

/* ============================================================================
   ONBOARDING
   ============================================================================ */
#onboarding{padding:0}
.ob-wrap{max-width:760px;margin:0 auto;width:100%;padding:64px 24px 96px;min-height:calc(100vh - 65px)}

/* progress rail */
.ob-progress{display:flex;align-items:center;gap:10px;margin-bottom:40px}
.ob-pip{flex:1;height:3px;background:var(--line-strong);border-radius:2px;overflow:hidden;position:relative}
.ob-pip span{position:absolute;inset:0;width:0;background:var(--gold);transition:width .45s ease}
.ob-pip.done span{width:100%}
.ob-pip.active span{width:100%;background:linear-gradient(90deg,var(--gold),var(--gold-deep))}
.ob-step{font-size:11.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--taupe);white-space:nowrap}

/* intro / completion screens */
.ob-hero{text-align:center;padding-top:24px}
.ob-hero .kicker{display:block;margin-bottom:18px}
.ob-hero h1{font-size:54px;line-height:1.05;letter-spacing:.4px;margin-bottom:6px}
.ob-hero p.lead{font-size:18px;line-height:1.7;color:var(--cream-soft);max-width:560px;
  margin:18px auto 0;font-style:italic}
.ob-hero .actions{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:40px}
.ob-meta{font-size:13px;color:var(--taupe);letter-spacing:.3px}

/* chapter screen */
.ob-chapter .kicker{display:block;margin-bottom:14px}
.ob-chapter h2{font-size:40px;line-height:1.08;letter-spacing:.3px}
.ob-chapter .ob-intro{color:var(--cream-soft);font-size:16px;line-height:1.65;margin-top:12px;
  font-style:italic;max-width:580px}
.ob-q{margin-top:38px}
.ob-q:first-of-type{margin-top:34px}
.ob-q .q-label{font-family:"Cormorant Garamond",serif;font-size:25px;font-weight:600;
  line-height:1.25;color:var(--cream);display:block;margin-bottom:6px}
.ob-q .q-helper{font-size:13.5px;color:var(--taupe);line-height:1.5;margin-bottom:12px;display:block}
.ob-q textarea{width:100%;min-height:96px;resize:vertical}
.ob-q input{width:100%}
.ob-q .saved{font-size:12px;color:var(--gold);letter-spacing:.4px;opacity:0;transition:opacity .3s;margin-top:8px;display:block}
.ob-q .saved.show{opacity:.8}

.ob-nav{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:48px;
  padding-top:26px;border-top:1px solid var(--line)}
.ob-nav .spacer{flex:1}
.ob-autosave{font-size:12px;color:var(--taupe);letter-spacing:.3px}

/* page-load reveal (staggered) */
.reveal{opacity:0;transform:translateY(14px);animation:revealIn .7s cubic-bezier(.2,.7,.2,1) forwards}
.reveal.d1{animation-delay:.05s}.reveal.d2{animation-delay:.16s}.reveal.d3{animation-delay:.28s}
.reveal.d4{animation-delay:.4s}.reveal.d5{animation-delay:.52s}.reveal.d6{animation-delay:.64s}
@keyframes revealIn{to{opacity:1;transform:none}}

@media(max-width:600px){
  .card{padding:36px 26px}
  .brand h1{font-size:44px}
  .bubble{max-width:90%}
  .picker h2{font-size:36px}
  .ob-hero h1{font-size:42px}
  .ob-chapter h2{font-size:32px}
  .ob-q .q-label{font-size:22px}
  .ob-step{display:none}
}
