/* additional styles for sub-pages */

/* page header strip */
.page-hd{
  margin: clamp(20px,4vw,32px) 0 clamp(14px,3vw,22px);
}
.page-hd .crumb{
  font:11px/1 'JetBrains Mono',monospace;color:var(--muted);
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;
}
.page-hd h1{
  font-family:'Caveat',cursive;font-weight:700;
  font-size:clamp(38px,7vw,64px);line-height:.95;margin:0 0 6px;
  letter-spacing:-.5px;
}
.page-hd .accent{color:var(--accent)}
.page-hd p{
  font-size:clamp(14px,2.4vw,15.5px);line-height:1.5;margin:0;max-width:60ch;
  color:#333;
}
body.dark .page-hd p{color:#c9d1de}

/* ───── CHAT page ───── */
.chat-shell{
  display:grid;gap:clamp(14px,3vw,22px);
  grid-template-columns:1fr;
  margin-bottom: clamp(40px,8vw,72px);
}
@media (min-width:880px){
  .chat-shell{grid-template-columns: 280px 1fr}
}

.chat-side{
  display:flex;flex-direction:column;gap:14px;
}
.side-card{
  background:var(--paper);border:1.5px solid var(--ink);border-radius:8px;
  padding:14px 16px;
}
.side-card .lbl{
  font:10px/1 'JetBrains Mono',monospace;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px;
}
.side-card h3{
  font-family:'Caveat',cursive;font-weight:700;
  font-size:24px;margin:0 0 6px;line-height:1;
}
.side-card p{font-size:13px;line-height:1.45;margin:0 0 4px;color:#333}
body.dark .side-card p{color:#c9d1de}
.side-card ul{margin:6px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}
.side-card li{
  font:12px/1.3 'JetBrains Mono',monospace;color:var(--ink);
  padding:6px 8px;border:1px dashed rgba(0,0,0,.35);border-radius:6px;cursor:pointer;
  transition:background .15s;
}
body.dark .side-card li{border-color:rgba(240,236,224,.35)}
.side-card li:hover{background:rgba(177,57,43,.06)}
.side-card li::before{content:"› ";color:var(--accent)}

.chat-window{
  background:var(--paper);border:1.5px solid var(--ink);border-radius:8px;
  display:flex;flex-direction:column;
  height: clamp(520px, 70vh, 760px);
  overflow:hidden;
  position:relative;
}
.chat-hd{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-bottom:1.5px dashed rgba(0,0,0,.18);
}
body.dark .chat-hd{border-bottom-color:rgba(240,236,224,.25)}
.chat-hd .av{
  width:32px;height:32px;border-radius:50%;
  background:#f0e4d2;border:1.5px solid var(--ink);
  position:relative;overflow:hidden;flex:0 0 auto;
}
.chat-hd .av::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 50% 38%, #d6c9b8 0 22%, transparent 23%),
    radial-gradient(ellipse 60% 40% at 50% 88%, #d6c9b8 0 60%, transparent 61%);
}
.chat-hd .who{flex:1;min-width:0}
.chat-hd .who b{font-family:'Caveat',cursive;font-weight:700;font-size:18px;line-height:1;display:block}
.chat-hd .who small{font:10px/1.2 'JetBrains Mono',monospace;color:var(--muted);letter-spacing:.05em}
.chat-hd .live{
  display:inline-flex;align-items:center;gap:6px;
  font:10px/1 'JetBrains Mono',monospace;color:var(--muted);
}

.chat-stream{
  flex:1;overflow-y:auto;padding:18px clamp(14px,3vw,22px);
  display:flex;flex-direction:column;gap:14px;
  scroll-behavior:smooth;
}

.msg{
  display:flex;gap:10px;align-items:flex-start;max-width:90%;
}
.msg.user{align-self:flex-end;flex-direction:row-reverse}
.msg .bubble{
  border:1.5px solid var(--ink);border-radius:14px;
  padding:10px 14px;font-size:14px;line-height:1.45;
  background:var(--paper);
  box-shadow:2px 2px 0 var(--ink);
}
.msg.user .bubble{
  background:var(--ink);color:var(--paper);
  box-shadow:-2px 2px 0 var(--accent);
}
.msg .av{
  width:30px;height:30px;border-radius:50%;flex:0 0 auto;
  border:1.5px solid var(--ink);background:#f0e4d2;
  display:grid;place-items:center;font-family:Caveat,cursive;font-weight:700;font-size:14px;line-height:1;
}
.msg.user .av{background:var(--ink);color:var(--paper)}

.typing{display:inline-flex;gap:4px;padding:4px 0}
.typing span{
  width:6px;height:6px;border-radius:50%;background:var(--muted);
  animation:typeBlink 1.2s ease-in-out infinite;
}
.typing span:nth-child(2){animation-delay:.18s}
.typing span:nth-child(3){animation-delay:.36s}
@keyframes typeBlink{0%,80%,100%{opacity:.3}40%{opacity:1}}

.chat-foot{
  border-top:1.5px dashed rgba(0,0,0,.18);
  padding:10px 12px;display:flex;gap:8px;align-items:flex-end;
  background:var(--paper);
}
body.dark .chat-foot{border-top-color:rgba(240,236,224,.25)}
.chat-foot textarea{
  flex:1;border:1.5px solid var(--ink);border-radius:10px;
  padding:10px 12px;font:14px/1.45 'Kalam',cursive;color:var(--ink);
  background:var(--paper);resize:none;min-height:44px;max-height:120px;outline:none;
}
.chat-foot textarea:focus{box-shadow:2px 2px 0 var(--accent)}
.chat-foot button{
  appearance:none;background:var(--ink);color:var(--paper);
  border:1.5px solid var(--ink);border-radius:10px;
  padding:0 14px;height:44px;cursor:pointer;
  font:12px/1 'JetBrains Mono',monospace;letter-spacing:.06em;
}
.chat-foot button:hover{background:var(--accent);border-color:var(--accent)}
.chat-disclaim{
  font:10px/1.4 'JetBrains Mono',monospace;color:var(--muted);
  margin-top:8px;text-align:center;
}

/* ───── RESUME page ───── */
.resume-shell{
  display:grid;gap:clamp(14px,3vw,22px);
  grid-template-columns:1fr;
  margin-bottom: clamp(40px,8vw,72px);
}
@media (min-width:880px){
  .resume-shell{grid-template-columns: 1fr 280px}
}

.paper-sheet{
  background:#fffdf6;
  border:1.5px solid var(--ink);
  border-radius:4px;
  box-shadow: 6px 8px 0 var(--ink), 0 30px 80px -30px rgba(0,0,0,.3);
  position:relative;
  overflow:hidden;
  width:100%;
  /* US Letter ratio 8.5:11 */
  aspect-ratio: 8.5 / 11;
  color:#1a1a1a;
}
body.dark .paper-sheet{
  /* keep paper looking like paper even in dark mode */
  background:#fffdf6;color:#1a1a1a;
  border-color:#1a1a1a;
}
.paper-sheet .corner{
  position:absolute;top:0;right:0;width:38px;height:38px;
  background:linear-gradient(225deg, rgba(0,0,0,.12) 0 50%, transparent 50%);
}
.paper-pad{padding:clamp(20px,4vw,42px); height:100%; display:flex;flex-direction:column;gap:clamp(14px,2vw,18px); font-family:'Kalam',cursive}

/* PDF embed inside the paper-sheet */
.paper-pdf-canvas{
  display:block;
  width:100%;height:auto;
  background:#fffdf6;
}
.paper-fallback{
  position:absolute;inset:0;
  display:none;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;
  padding:32px;text-align:center;
  font:13px/1.5 'JetBrains Mono',monospace;color:#333;
  background:#fffdf6;
}
.paper-fallback.on{display:flex}
.paper-fallback .fb-stamp{
  font:11px/1 'JetBrains Mono',monospace;letter-spacing:.2em;
  border:1.5px solid #1a1a1a;border-radius:4px;padding:6px 10px;
  color:#1a1a1a;
}
.paper-sheet{aspect-ratio: 8.5 / 11}
/* Older selector — kept harmless in case of cached refs */
.paper-pdf{display:none}

/* glance list inside side-card */
.side-card .glance{
  margin:6px 0 0;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:6px;
  font:11.5px/1.4 'JetBrains Mono',monospace;color:var(--ink);
}
.side-card .glance li{
  padding:6px 0;border-bottom:1px dashed rgba(0,0,0,.15);
}
body.dark .side-card .glance li{border-bottom-color:rgba(240,236,224,.18);color:var(--ink)}
.side-card .glance li:last-child{border-bottom:0}
.side-card .glance b{font-family:'Kalam',cursive;font-weight:700;font-size:13px}

.resume-side{display:flex;flex-direction:column;gap:14px}
.dl-card{
  background:var(--ink);color:var(--paper);
  border:1.5px solid var(--ink);border-radius:8px;
  padding:18px;display:flex;flex-direction:column;gap:8px;
  text-decoration:none;
  transition:transform .15s, box-shadow .15s;
}
.dl-card:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--accent)}
.dl-card .lbl{font:10px/1 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;opacity:.7}
.dl-card .ttl{font-family:'Caveat',cursive;font-weight:700;font-size:32px;line-height:1}
.dl-card .meta{font:11px/1.3 'JetBrains Mono',monospace;opacity:.7;margin-top:auto}
.dl-card .arr{font:14px 'JetBrains Mono',monospace;align-self:flex-end}

.resume-meta{
  background:var(--paper);border:1.5px solid var(--ink);border-radius:8px;
  padding:14px 16px;
}
.resume-meta dl{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;margin:0;font:11px/1.4 'JetBrains Mono',monospace}
.resume-meta dt{color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.resume-meta dd{margin:0}

/* resume-content typography (within paper sheet) */
.r-name{font-family:'Caveat',cursive;font-weight:700;font-size:clamp(36px,5vw,52px);line-height:.95;margin:0}
.r-role{font:11px/1 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#666;margin-top:2px}
.r-line{height:1.5px;background:#1a1a1a;border-radius:1px;margin:6px 0 4px}
.r-section h3{font-family:'Architects Daughter',cursive;font-size:clamp(16px,2.4vw,20px);margin:0 0 6px;letter-spacing:.5px}
.r-row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-bottom:6px}
.r-row .when{font:11px/1.4 'JetBrains Mono',monospace;color:#666}
.r-row b{font-weight:700}
.r-row p{font-size:clamp(12px,2vw,13.5px);line-height:1.4;margin:2px 0 0;color:#333}
.r-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.r-tags span{font:10px/1.4 'JetBrains Mono',monospace;padding:2px 7px;border:1px solid #1a1a1a;border-radius:10px}

/* ───── CONTACT page ───── */
.contact-shell{
  display:grid;gap:clamp(14px,3vw,22px);
  grid-template-columns:1fr;
  margin-bottom: clamp(40px,8vw,72px);
}
@media (min-width:880px){
  .contact-shell{grid-template-columns: 1.2fr 1fr}
}

.form-card{
  background:var(--paper);border:1.5px solid var(--ink);border-radius:8px;
  padding:clamp(18px,4vw,28px);
}
.form-grid{display:grid;gap:14px;grid-template-columns:1fr;align-items:start}
@media (min-width:560px){
  .form-grid.two{grid-template-columns: 1fr 1fr}
}
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field label{
  font:10px/1 'JetBrains Mono',monospace;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);
  display:flex;justify-content:space-between;align-items:baseline;
  height:14px;
}
.field label .opt{color:var(--accent)}
.field input,.field textarea,.field select{
  appearance:none;border:1.5px solid var(--ink);border-radius:8px;
  background:var(--paper);color:var(--ink);
  padding:0 12px;font:14px/1.4 'Kalam',cursive;outline:none;
  height:42px;
  box-sizing:border-box;
}
.field textarea{min-height:120px;height:auto;padding:10px 12px;resize:vertical;font-family:'Kalam',cursive}
.field input:focus,.field textarea:focus,.field select:focus{
  box-shadow:2px 2px 0 var(--accent);
}
.field .help{
  font:10px/1.4 'JetBrains Mono',monospace;color:var(--muted);
  min-height:14px;
}

.purpose-row{display:flex;flex-wrap:wrap;gap:6px;align-items:stretch}
.purpose-row label{
  flex:1 1 auto;cursor:pointer;
  border:1.5px solid var(--ink);border-radius:8px;
  padding:0 10px;font:11px/1 'JetBrains Mono',monospace;
  letter-spacing:.04em;text-transform:uppercase;text-align:center;
  background:var(--paper);
  display:flex;justify-content:center;align-items:center;
  min-height:42px;
  height:42px;
  transition:background .15s;
}
.purpose-row input{position:absolute;opacity:0;pointer-events:none}
.purpose-row input:checked + label,
.purpose-row label.on{
  background:var(--ink);color:var(--paper);
}

.submit-row{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:6px;
}
.submit-btn{
  appearance:none;background:var(--accent);color:var(--paper);
  border:1.5px solid var(--ink);border-radius:10px;
  padding:12px 20px;cursor:pointer;
  font:12px/1 'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:3px 3px 0 var(--ink);transition:transform .15s, box-shadow .15s;
}
.submit-btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.submit-note{font:10px/1.4 'JetBrains Mono',monospace;color:var(--muted)}

.contact-side{display:flex;flex-direction:column;gap:14px}
.flow-card{
  background:var(--paper);border:1.5px solid var(--ink);border-radius:8px;
  padding:14px 16px;
}
.flow-card h3{font-family:'Caveat',cursive;font-weight:700;font-size:24px;margin:0 0 8px;line-height:1}
.flow-steps{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;font:12px/1.4 'JetBrains Mono',monospace}
.flow-steps li{display:flex;gap:10px;align-items:flex-start}
.flow-steps li .n{
  flex:0 0 auto;width:22px;height:22px;border:1.5px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;font-size:11px;font-weight:700;
}

.success{
  display:none;background:#d6e6cf;border:1.5px solid #1a1a1a;
  padding:18px 20px;border-radius:8px;color:#1a1a1a;
}
.success.on{display:block;animation:fadeIn .3s}
.success h3{font-family:'Caveat',cursive;font-weight:700;font-size:32px;margin:0 0 4px;line-height:1}
.success p{margin:0;font-size:13px}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
