/* ═══════════════════════════════════════════
   Components v3 — All sections & UI
   ═══════════════════════════════════════════ */

/* ═══ ABOUT ═══ */
.about-split{display:grid;grid-template-columns:55% 45%}

.about-main{background:#6b6762;padding:40px 36px;display:flex;flex-direction:column}

.about-tagline{
  font-family:var(--font-display);font-size:var(--fs-lg);font-weight:var(--fw-bold);
  font-style:italic;color:var(--text-white);line-height:1.35;max-width:500px;
}

.about-right{background:#c2bdb5;display:flex;flex-direction:column;border-left:1px solid rgba(0,0,0,0.08)}

.about-right-text{
  padding:20px 24px;font-size:var(--fs-sm);color:#2a2a2a;line-height:var(--lh-relaxed);flex-shrink:0;
}

/* ── Halftone ── */
.ht-wrap{
  flex:1;position:relative;overflow:hidden;background:var(--window-light);min-height:280px;
}
.ht-wrap canvas{width:100%;height:100%;display:block;position:relative;z-index:1}

.ht-blocks{
  position:absolute;inset:0;
  display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);
  gap:3px;padding:12px;pointer-events:none;z-index:2;
}
.hb{background:rgba(140,136,130,0.5);transition:opacity 1.5s ease}
.hb.clear{background:transparent}
.hb.solid{background:rgba(140,136,130,0.7)}

/* ── Contact Strip ── */
.contact-strip{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:16px 36px;border-top:1px solid rgba(0,0,0,0.1);
  background:rgba(0,0,0,0.03);font-size:var(--fs-sm);
}
.cs-group{display:flex;flex-direction:column;gap:2px}
.cs-label{font-size:var(--fs-2xs);color:var(--text-medium);font-weight:var(--fw-medium)}
.cs-val{color:var(--text-dark);font-weight:var(--fw-medium)}
.cs-val a{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;transition:color 0.2s}
.cs-val a:hover{color:var(--accent-copper)}

/* ── About Description ── */
.about-desc{
  font-family:var(--font-body);font-size:var(--fs-lg);font-weight:var(--fw-bold);
  color:#2a2a2a;line-height:1.3;padding:28px 36px 0;
}

/* ═══ BOOK COVER STRIPES ═══ */
.book-covers{
  width:100%;height:240px;position:relative;overflow:hidden;
  background:#b0aba5;display:flex;align-items:flex-end;
  padding:0 8px;gap:2px;
  border-top:1px solid rgba(0,0,0,0.06);border-bottom:1px solid rgba(0,0,0,0.06);
}
.book-spine{
  flex:1;background:rgba(185,180,174,0.7);
  border-left:1px solid rgba(0,0,0,0.06);border-right:1px solid rgba(255,255,255,0.08);
  position:relative;transition:height 0.5s var(--ease-expo),background 0.3s;
  box-shadow:inset 0 0 8px rgba(0,0,0,0.06);
}
.book-spine:nth-child(2n){background:rgba(175,170,162,0.6)}
.book-spine:nth-child(3n){background:rgba(165,160,152,0.65)}
.book-spine:nth-child(5n){background:rgba(155,150,142,0.7)}
.book-spine:hover{background:rgba(150,145,138,0.8)}

/* ═══ QUOTES PANEL ═══ */
.quotes-panel{
  background:var(--accent-copper);padding:28px 32px;position:relative;
}
/* Binder clip SVG */
.binder-clip{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);z-index:5;
}
.quotes-head{
  display:flex;justify-content:space-between;align-items:baseline;
  padding-bottom:12px;margin-bottom:16px;border-bottom:1px solid rgba(0,0,0,0.2);
}
.quotes-title{font-size:var(--fs-base);font-weight:var(--fw-semibold);color:var(--text-dark)}
.quotes-count{font-size:var(--fs-sm);color:rgba(0,0,0,0.4)}

.quote{
  padding:14px 0;border-bottom:1px solid rgba(0,0,0,0.12);
  display:grid;grid-template-columns:90px 1fr;gap:16px;
}
.quote:last-child{border-bottom:none}
.quote-author{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-dark)}
.quote-text{font-size:var(--fs-sm);line-height:var(--lh-relaxed);color:var(--text-dark);margin-bottom:6px}
.quote-src{
  font-size:var(--fs-2xs);font-weight:var(--fw-bold);text-transform:uppercase;
  letter-spacing:var(--ls-wider);color:var(--text-dark);
}

/* ═══ FEATURED PANEL ═══ */
.featured-panel{background:#6b6762}
.featured-head{display:flex;justify-content:space-between;align-items:baseline;padding:28px 32px 20px}
.featured-title{
  font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:var(--fw-bold);
  color:var(--text-white);line-height:1;
}
.featured-count{font-family:var(--font-display);font-size:var(--fs-lg);color:rgba(255,255,255,0.3)}

/* ═══ PROJECT ROWS ═══ */
.proj-row{
  display:grid;grid-template-columns:50px 1fr auto;align-items:center;
  padding:16px 32px;border-bottom:1px solid rgba(0,0,0,0.08);
  cursor:pointer;position:relative;
  transition:background 0.25s ease,padding-left 0.4s var(--ease-expo);
}
.proj-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--accent-copper);transform:scaleY(0);
  transition:transform 0.35s var(--ease-expo);transform-origin:bottom;
}
.proj-row:hover{background:rgba(255,255,255,0.05);padding-left:38px}
.proj-row:hover::before{transform:scaleY(1)}

.proj-num{
  font-family:var(--font-display);font-size:var(--fs-lg);font-weight:var(--fw-light);
  color:rgba(255,255,255,0.25);line-height:1;transition:color 0.25s;
}
.proj-row:hover .proj-num{color:var(--accent-copper)}

.proj-info{display:flex;flex-direction:column;gap:2px}
.proj-name{
  font-size:var(--fs-base);font-weight:var(--fw-semibold);color:var(--text-dark);
  transition:color 0.25s;
}
.proj-row:hover .proj-name{color:var(--text-white)}

.proj-sub{font-size:var(--fs-xs);color:var(--text-medium);transition:color 0.25s}
.proj-row:hover .proj-sub{color:rgba(255,255,255,0.5)}

.proj-tag{
  font-size:var(--fs-2xs);font-weight:var(--fw-medium);text-transform:uppercase;
  letter-spacing:var(--ls-wider);padding:3px 12px;
  border:1px solid rgba(0,0,0,0.15);color:var(--text-medium);
  transition:all 0.25s;white-space:nowrap;
}
.proj-row:hover .proj-tag{border-color:var(--accent-copper);color:var(--accent-copper);background:rgba(198,93,58,0.06)}

/* ═══ PROJECTS WINDOW ═══ */
.projects-head{padding:36px 36px 24px;border-bottom:1px solid rgba(0,0,0,0.08)}
.projects-title{
  font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:var(--fw-bold);
  color:var(--text-dark);line-height:var(--lh-tight);margin-bottom:12px;
}
.projects-desc{font-size:var(--fs-sm);color:var(--text-medium);max-width:440px;line-height:var(--lh-relaxed)}

/* ═══ EXPERIENCE (salmon bg) ═══ */
.exp-bg{background:var(--accent-salmon-bg)!important;min-height:100%}
.exp-grid{display:grid;grid-template-columns:1fr 1fr;min-height:100%}
.exp-col{padding:32px 36px}
.exp-col + .exp-col{border-left:1px solid rgba(0,0,0,0.08)}

.exp-section{margin-bottom:36px}
.exp-section-title{
  font-size:var(--fs-2xs);font-weight:var(--fw-bold);text-transform:uppercase;
  letter-spacing:var(--ls-wider);color:rgba(0,0,0,0.35);
  margin-bottom:18px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,0.1);
}
.exp-item{margin-bottom:20px}
.exp-role{font-size:var(--fs-base);font-weight:var(--fw-semibold);color:var(--text-dark)}
.exp-org{font-size:var(--fs-sm);color:rgba(0,0,0,0.5);margin-top:1px}
.exp-date{font-size:var(--fs-2xs);color:rgba(0,0,0,0.3);font-weight:var(--fw-medium);margin-top:2px}
.exp-desc{font-size:var(--fs-sm);color:rgba(0,0,0,0.55);line-height:var(--lh-relaxed);margin-top:6px}

/* ═══ CONTACT ═══ */
.contact-top{
  display:flex;justify-content:space-between;padding:20px 36px;
  border-bottom:1px solid rgba(0,0,0,0.08);
}
.contact-group{display:flex;flex-direction:column;gap:4px}
.contact-label{
  font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:var(--ls-wider);
  color:var(--text-medium);font-weight:var(--fw-medium);
}
.contact-val{
  font-size:var(--fs-sm);color:var(--text-dark);font-weight:var(--fw-medium);
  text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;
  transition:color 0.2s;
}
.contact-val:hover{color:var(--accent-copper)}

.contact-center{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:24px;padding:40px;
}
.contact-avail{display:flex;align-items:center;gap:10px;font-size:var(--fs-sm);color:var(--text-medium)}

.pulse-dot{
  width:8px;height:8px;border-radius:50%;background:#4ade80;animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.85)}}

.contact-ht{
  width:100%;max-width:500px;aspect-ratio:4/3;position:relative;
  overflow:hidden;background:var(--window-light);
}
.contact-ht canvas{width:100%;height:100%;display:block;position:relative;z-index:1}

.contact-big-name{
  font-family:var(--font-display);font-size:var(--fs-hero);font-weight:var(--fw-bold);
  color:var(--text-dark);line-height:var(--lh-tight);letter-spacing:var(--ls-tight);
  text-align:center;padding:40px 36px;border-top:1px solid rgba(0,0,0,0.08);
}

/* ═══ DETAIL WINDOW ═══ */
.detail-head{padding:36px;position:relative}
.detail-title{
  font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:var(--fw-bold);
  color:var(--text-dark);line-height:var(--lh-tight);margin-bottom:8px;
}
.detail-tag{
  display:inline-block;font-size:var(--fs-2xs);font-weight:var(--fw-medium);
  text-transform:uppercase;letter-spacing:var(--ls-wider);
  padding:3px 12px;border:1px solid rgba(0,0,0,0.2);color:var(--text-medium);
  position:absolute;top:36px;right:36px;
}
.detail-img{
  width:100%;aspect-ratio:16/9;background:var(--window-lighter);overflow:hidden;
}
.detail-img canvas{width:100%;height:100%;display:block}

.detail-subtitle{padding:16px 36px 0;font-size:var(--fs-xs);color:var(--text-medium);font-style:italic}
.detail-quote{
  padding:8px 36px 0;font-size:var(--fs-md);font-weight:var(--fw-semibold);
  color:var(--text-dark);line-height:1.3;font-style:italic;
}

.detail-body{padding:24px 36px;display:flex;flex-direction:column;gap:16px}
.detail-body p{font-size:var(--fs-base);line-height:var(--lh-relaxed);color:var(--text-medium)}

.detail-meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px 36px;
  border-top:1px solid rgba(0,0,0,0.08);border-bottom:1px solid rgba(0,0,0,0.08);
}
.detail-meta-item{display:flex;flex-direction:column;gap:2px}
.detail-meta-label{
  font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:var(--ls-wider);
  color:var(--text-muted);font-weight:var(--fw-medium);
}
.detail-meta-val{font-size:var(--fs-sm);color:var(--text-dark);font-weight:var(--fw-medium)}

.gh-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border:1px solid var(--text-dark);
  font-size:var(--fs-sm);font-weight:var(--fw-medium);
  transition:all 0.25s;width:fit-content;
}
.gh-btn:hover{background:var(--text-dark);color:var(--text-white)}
.gh-btn svg{transition:fill 0.25s}
.gh-btn:hover svg{fill:var(--text-white)}

/* ═══ SKILLS GRID ═══ */
.skills-section{padding:36px}
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.skill-card{
  aspect-ratio:3/4;overflow:hidden;cursor:pointer;
  transition:transform 0.4s var(--ease-expo);
}
.skill-card:hover{transform:scale(1.04)}
.skill-card canvas{width:100%;height:100%;display:block}

/* ═══ SCROLL ANIMATIONS ═══ */
.reveal{
  opacity:0;transform:translateY(30px);
  transition:opacity 0.7s var(--ease-expo),transform 0.7s var(--ease-expo);
}
.reveal.visible{opacity:1;transform:translateY(0)}

.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}
.reveal-delay-5{transition-delay:0.5s}
