/* ============================================================
   WEBWOLF — design tokens
   Palette:  --bg #14171A (slate night) · --bg-raised #1C2023
             --gold #F2B84B (fortune-cookie foil) · --gold-dim #C9924A
             --teal #3E8E7E (Gent canal / wolf-eye)
             --text #EDEAE4 · --text-dim #9CA0A0 · --line rgba(237,234,228,.10)
   Type:     display  = "Fraunces"      (playful ball-terminal serif)
             body     = "Space Grotesk" (clean geometric sans)
             utility  = "JetBrains Mono"(tags / labels / meta)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,500&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --bg:#14171A;
  --bg-raised:#1C2023;
  --gold:#F2B84B;
  --gold-dim:#C9924A;
  --teal:#3E8E7E;
  --text:#EDEAE4;
  --text-dim:#9CA0A0;
  --line:rgba(237,234,228,.10);
  --line-strong:rgba(237,234,228,.22);
  --radius:10px;
  --maxw:1120px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Space Grotesk',sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}

h1,h2,h3,h4{
  font-family:'Fraunces',serif;
  font-weight:600;
  line-height:1.08;
  margin:0 0 .4em;
  letter-spacing:-0.01em;
}
.eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(20,23,26,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;
  height:74px;
}
.logo{
  font-family:'Fraunces',serif;font-weight:700;font-size:1.35rem;
  display:flex;align-items:center;gap:.5em;
}
.logo .mark{color:var(--gold);}
.nav-links{display:flex;gap:2.1rem;font-size:.92rem;}
.nav-links a{
  position:relative;padding:.3em 0;color:var(--text-dim);
  transition:color .2s ease;
}
.nav-links a:hover,.nav-links a.active{color:var(--text);}
.nav-links a.active::after{
  content:'';position:absolute;left:0;right:0;bottom:-3px;height:2px;background:var(--gold);
}
.nav-cta{
  font-family:'JetBrains Mono',monospace;font-size:.8rem;
  border:1px solid var(--line-strong);border-radius:100px;
  padding:.55em 1.2em;color:var(--text);
  transition:border-color .2s ease, background .2s ease;
}
.nav-cta:hover{border-color:var(--gold);background:rgba(242,184,75,.08);}
.nav-toggle{display:none;}

@media (max-width:840px){
  .nav-links{display:none;}
  .nav-toggle{
    display:block;background:none;border:1px solid var(--line-strong);
    color:var(--text);border-radius:8px;padding:.5em .8em;font-family:'JetBrains Mono',monospace;
  }
}

/* ---------- hero ---------- */
.hero{padding:96px 0 80px;position:relative;overflow:hidden;}
.hero::before{
  content:'';position:absolute;inset:-40% -10% auto -10%;height:600px;
  background:radial-gradient(ellipse at 30% 0%, rgba(242,184,75,.14), transparent 60%),
             radial-gradient(ellipse at 80% 20%, rgba(62,142,126,.16), transparent 55%);
  pointer-events:none;
}
.hero .wrap{position:relative;}
.hero h1{font-size:clamp(2.4rem,5vw,4.1rem);max-width:16ch;}
.hero .lede{
  font-size:1.15rem;color:var(--text-dim);max-width:46ch;margin:1.1em 0 2em;
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;}

.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:'JetBrains Mono',monospace;font-size:.85rem;
  padding:.85em 1.5em;border-radius:100px;transition:all .2s ease;
}
.btn-primary{background:var(--gold);color:#1A1200;font-weight:500;}
.btn-primary:hover{background:#ffcf70;transform:translateY(-1px);}
.btn-ghost{border:1px solid var(--line-strong);color:var(--text);}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);}

/* ---------- fortune-cookie signature card ---------- */
/* folded corner (like a cracked fortune cookie) reveals a "fortune" strip on hover */
.fortune-grid{
  display:grid;gap:1.4rem;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin-top:2.2rem;
}
.fortune-card{
  position:relative;
  background:var(--bg-raised);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.9rem 1.7rem 2.3rem;
  overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% 100%,26px 100%,0 calc(100% - 26px));
  transition:transform .25s ease, border-color .25s ease;
}
.fortune-card:hover{transform:translateY(-4px);border-color:var(--line-strong);}
.fortune-card::after{
  /* the folded paper triangle */
  content:'';position:absolute;left:0;bottom:0;width:26px;height:26px;
  background:linear-gradient(135deg,transparent 49%,var(--bg) 50%);
}
.fortune-card .num{
  font-family:'JetBrains Mono',monospace;color:var(--gold-dim);font-size:.78rem;
}
.fortune-card h3{font-size:1.3rem;margin-top:.3em;}
.fortune-card p{color:var(--text-dim);font-size:.96rem;margin:.6em 0 0;}
.fortune-card .tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem;}
.fortune-card .tags span{
  font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--teal);
  border:1px solid rgba(62,142,126,.4);border-radius:100px;padding:.25em .7em;
}
.fortune-strip{
  position:absolute;left:0;right:0;bottom:-40px;
  background:var(--gold);color:#1A1200;
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:.86rem;padding:.6em 1.7rem;
  transition:bottom .28s ease;
}
.fortune-card:hover .fortune-strip{bottom:0;}

/* ---------- sections ---------- */
section{padding:88px 0;}
section.alt{background:var(--bg-raised);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-head{max-width:56ch;margin-bottom:2.4rem;}
.section-head h2{font-size:clamp(1.9rem,3.4vw,2.6rem);}
.section-head p{color:var(--text-dim);}

/* portfolio cards */
.portfolio-grid{
  display:grid;gap:1.6rem;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.pf-card{
  border:1px solid var(--line);border-radius:var(--radius);
  background:var(--bg-raised);overflow:hidden;
  transition:border-color .2s ease, transform .2s ease;
}
.pf-card:hover{border-color:var(--teal);transform:translateY(-3px);}
.pf-thumb{
  height:150px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(242,184,75,.10),rgba(62,142,126,.14));
  font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--text-dim);
  border-bottom:1px solid var(--line);
}
.pf-body{padding:1.4rem 1.5rem 1.6rem;}
.pf-body .eyebrow{display:block;margin-bottom:.5em;}
.pf-body h3{font-size:1.2rem;}
.pf-body p{color:var(--text-dim);font-size:.93rem;margin:.5em 0 0;}
.pf-link{
  display:inline-block;margin-top:1rem;font-family:'JetBrains Mono',monospace;
  font-size:.78rem;color:var(--gold);border-bottom:1px solid transparent;
}
.pf-link:hover{border-color:var(--gold);}

/* about / skills */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:start;}
@media (max-width:840px){.about-grid{grid-template-columns:1fr;}}
.skill-cloud{display:flex;flex-wrap:wrap;gap:.5rem;}
.skill-cloud span{
  font-family:'JetBrains Mono',monospace;font-size:.76rem;color:var(--text);
  border:1px solid var(--line-strong);border-radius:100px;padding:.4em 1em;
}

/* copywriting alphabet strip */
.az-strip{
  display:flex;flex-wrap:wrap;gap:.5em 1.3em;color:var(--text-dim);
  font-family:'Fraunces',serif;font-style:italic;font-size:1rem;
}
.az-strip strong{color:var(--gold);font-style:normal;}

/* contact */
.contact-panel{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;
}
@media (max-width:840px){.contact-panel{grid-template-columns:1fr;}}
.contact-info h2{font-size:2.1rem;}
.contact-info a.email{color:var(--gold);}
.contact-info .detail{color:var(--text-dim);margin-top:1.4rem;font-size:.94rem;}

form.contact-form{display:grid;gap:1.1rem;}
.field{display:grid;gap:.4rem;}
.field label{font-family:'JetBrains Mono',monospace;font-size:.74rem;color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase;}
.field input,.field textarea{
  background:var(--bg-raised);border:1px solid var(--line-strong);border-radius:8px;
  padding:.85em 1em;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:.95rem;
  resize:vertical;
}
.field input:focus,.field textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.form-msg{font-size:.9rem;padding:.8em 1em;border-radius:8px;display:none;}
.form-msg.show{display:block;}
.form-msg.ok{background:rgba(62,142,126,.15);color:var(--teal);border:1px solid rgba(62,142,126,.4);}
.form-msg.err{background:rgba(200,80,80,.12);color:#e08a8a;border:1px solid rgba(200,80,80,.4);}
.hp-field{position:absolute;left:-9999px;}

/* footer */
footer{border-top:1px solid var(--line);padding:48px 0 32px;}
.footer-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2rem;}
.footer-links{display:flex;gap:1.6rem;font-size:.85rem;color:var(--text-dim);}
.footer-links a:hover{color:var(--text);}
.footer-copy{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--text-dim);margin-top:1.6rem;}

/* legal pages */
.legal h2{font-size:2rem;}
.legal h4{font-family:'Space Grotesk',sans-serif;font-weight:600;color:var(--gold-dim);margin-top:2em;}
.legal p, .legal li{color:var(--text-dim);font-size:.95rem;}
.legal ul{list-style:disc;padding-left:1.4em;margin:.6em 0;}
.legal .updated{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--text-dim);margin-bottom:2em;display:block;}
