:root{
  --bg:#f5efe2; --paper:#fffdf7; --ink:#1c1a17; --pink:#ff5d8f;
  --blue:#2d6cdf; --lime:#8bd44f; --orange:#ff7a2f; --muted:#5a5446;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:"Shantell Sans",cursive; font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.frame{
  max-width:760px; margin:28px auto; background:var(--paper);
  border:3px solid var(--ink); box-shadow:10px 10px 0 var(--ink);
  padding:32px 34px 48px;
}

/* header */
header{
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:10px; border-bottom:3px dashed var(--ink);
  padding-bottom:18px; margin-bottom:30px;
}
.logo{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:22px;
  background:var(--lime); padding:2px 10px; border:2px solid var(--ink);
  transform:rotate(-2deg); text-decoration:none; color:var(--ink);
}
nav a{
  text-decoration:none; color:var(--ink); font-weight:600; margin-left:10px;
  padding:3px 9px; border:2px solid var(--ink); background:#fff; white-space:nowrap;
}
nav a:hover{background:var(--pink); color:#fff}

/* headings + text */
main h1{font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:44px; line-height:1.02; margin:6px 0 18px}
.hero{font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:48px; line-height:1.0; margin:6px 0 20px}
.hero .hl{background:var(--orange); padding:0 6px; box-decoration-break:clone; -webkit-box-decoration-break:clone}
p{margin:0 0 18px}
a{color:var(--blue); text-decoration:underline}
a:hover{color:var(--pink)}

.badge{
  display:inline-block; background:var(--pink); color:#fff; font-weight:700;
  padding:4px 12px; border:2px solid var(--ink); transform:rotate(1.5deg); margin-bottom:18px;
}
.blurb{background:#fff; border:2px solid var(--ink); padding:14px 16px; margin:26px 0; box-shadow:5px 5px 0 var(--blue)}
.sec{font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:26px; margin:38px 0 16px; text-decoration:underline wavy var(--pink)}

/* sticker tags (home featured) */
.tags{display:flex; flex-wrap:wrap; gap:14px}
.tag{display:block; text-decoration:none; color:var(--ink); background:#fff; border:2px solid var(--ink); padding:12px 14px; font-weight:600; box-shadow:4px 4px 0 var(--ink)}
.tag:nth-child(odd){transform:rotate(-1.3deg)}
.tag:nth-child(even){transform:rotate(1.2deg)}
.tag:hover{box-shadow:4px 4px 0 var(--pink); background:#fffaf0}
.tag small{display:block; font-weight:400; color:var(--muted); margin-top:4px; font-family:"Newsreader",serif; font-size:15px}

/* full project cards (projects page) */
.project-card{background:#fff; border:2px solid var(--ink); box-shadow:6px 6px 0 var(--ink); padding:4px 24px 20px; margin:0 0 28px}
.project-card:nth-of-type(odd){transform:rotate(-.6deg)}
.project-card:nth-of-type(even){transform:rotate(.5deg)}
.project-card h2{font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:24px; margin:18px 0 8px}
.project-card p{font-family:"Newsreader",serif; font-size:18px; line-height:1.6; color:#2c2620; margin:0 0 10px}
.project-card h2 a{color:var(--ink); text-decoration:none}
.project-card h2 a:hover{color:var(--pink)}

/* prose pages: writing, about, essays */
.prose p, .prose li{font-family:"Newsreader",serif; font-size:19px; line-height:1.75}
.prose h2{font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:25px; margin:34px 0 12px}
.prose blockquote{border-left:4px solid var(--pink); margin:0 0 18px; padding:2px 0 2px 18px; color:var(--muted); font-style:italic}
.essay-date{font-family:"Shantell Sans",cursive; color:var(--muted); font-size:15px; margin:-6px 0 26px}

/* contact list */
.contact{list-style:none; padding:0; margin:8px 0 0}
.contact li{font-family:"Shantell Sans",cursive; padding:8px 0; border-bottom:2px dotted #d8cdb4}

/* essay list */
.essay-list{list-style:none; padding:0; margin:20px 0 0}
.essay-list li{padding:14px 0; border-bottom:2px dotted #d8cdb4; display:flex; justify-content:space-between; align-items:baseline; gap:12px; flex-wrap:wrap}
.essay-list a{font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:20px; text-decoration:none; color:var(--ink)}
.essay-list a:hover{color:var(--pink)}
.essay-list .meta{font-family:"Shantell Sans",cursive; color:var(--muted); font-size:14px}

/* say-hi contact form */
.say-hi-form{display:flex; flex-direction:column; gap:12px; margin:10px 0 8px; max-width:460px}
.say-hi-form input[type=text], .say-hi-form input[type=email], .say-hi-form textarea{
  font-family:"Shantell Sans",cursive; font-size:16px; padding:10px 12px;
  border:2px solid var(--ink); background:#fff; box-shadow:3px 3px 0 var(--ink); border-radius:0;
}
.say-hi-form textarea{resize:vertical}
.say-hi-form .hp{display:none !important}
.say-hi-form button{
  align-self:flex-start; font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:16px;
  background:var(--lime); color:var(--ink); border:2px solid var(--ink); box-shadow:4px 4px 0 var(--ink);
  padding:9px 18px; cursor:pointer; transform:rotate(-1deg);
}
.say-hi-form button:hover{background:var(--pink); color:#fff; box-shadow:4px 4px 0 var(--pink)}

/* project detail pages */
.backlink{display:inline-block; font-family:"Shantell Sans",cursive; font-size:15px; margin-bottom:8px}
.summary{font-family:"Shantell Sans",cursive; color:var(--muted); font-size:17px; margin:-4px 0 22px}
figure.shot{margin:26px 0}
figure.shot img{display:block; width:100%; height:auto; border:2px solid var(--ink); box-shadow:6px 6px 0 var(--ink)}
figure.shot figcaption{font-family:"Shantell Sans",cursive; color:var(--muted); font-size:14px; margin-top:8px}
.shot-placeholder{border:2px dashed var(--ink); background:#fff; padding:44px 18px; text-align:center; font-family:"Shantell Sans",cursive; color:var(--muted); box-shadow:5px 5px 0 #e8dcc4}
.muted-note{color:var(--muted); font-size:16px}

/* code blocks (zine box) + inline code */
/* dark "titled window" terminal */
.prose pre{position:relative; background:#1c1a17; color:#f5efe2; border:2px solid var(--ink); border-radius:10px; padding:42px 18px 16px; overflow-x:auto; margin:22px 0}
/* title bar: three traffic-light dots */
.prose pre::before{content:""; position:absolute; top:15px; left:16px; width:11px; height:11px; border-radius:50%; background:#ff5f56; box-shadow:18px 0 0 #ffbd2e, 36px 0 0 #27c93f; z-index:1}
/* centered window title + hairline */
.prose pre::after{content:"breadcrumb — zsh"; position:absolute; top:13px; left:0; right:0; text-align:center; font-size:12px; color:#9b9489; font-family:"JetBrains Mono",ui-monospace,monospace; border-bottom:2px solid rgba(245,239,226,.12); padding-bottom:11px}
.prose pre code{font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace; font-size:13.5px; line-height:1.6; white-space:pre; background:none; padding:0; color:#f5efe2}
.prose code{font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace; font-size:.88em; background:#efe7d4; padding:1px 5px}
/* copy button */
.copy-btn{position:absolute; top:10px; right:12px; z-index:2; font-family:"JetBrains Mono",ui-monospace,monospace; font-size:11px; padding:3px 9px; border:1.5px solid currentColor; background:transparent; color:inherit; opacity:.5; cursor:pointer}
.copy-btn:hover{opacity:1}
.copy-btn.copied{opacity:1; color:#46d369; border-color:#46d369; animation:pop .32s ease}
@keyframes pop{0%{transform:scale(1)}45%{transform:scale(1.15)}100%{transform:scale(1)}}

/* footer */
footer{margin-top:44px; border-top:3px dashed var(--ink); padding-top:16px; font-weight:600}
.footnote{font-size:14px; color:var(--muted); font-weight:400; margin-top:6px}

@media(max-width:640px){
  .frame{margin:14px; padding:24px 20px 36px; box-shadow:6px 6px 0 var(--ink)}
  .hero{font-size:34px} main h1{font-size:32px}
  nav{display:flex; flex-wrap:wrap}
  nav a{margin:4px 6px 0 0}
}
