/* ============================================================
   PALTI PORTFOLIO — Page-specific styles
   ============================================================ */

/* ── Homepage: Hero ───────────────────────────────────────── */
.hero { padding: 88px 0 64px; }
.hero-status {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--green-light); border: 1px solid #bbf7d0;
  color: var(--green); font-family: var(--mono); font-size: 11px;
  padding: 4px 10px; border-radius: 20px; margin-bottom: 20px;
}
.hero-status .dot { width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulse 2s ease-in-out infinite; }
.hero h1 { max-width: 600px; }
.hero-sub { margin-top:16px; font-size:17px; color:var(--text-2); max-width:520px; line-height:1.7; }
.hero-actions { display:flex; gap:10px; align-items:center; margin-top:28px; flex-wrap:wrap; }
.hero-meta { display:flex; gap:20px; align-items:center; margin-top:40px; flex-wrap:wrap; }
.hero-meta-item { display:flex; flex-direction:column; }
.hero-meta-item .num   { font-size:22px; font-weight:700; color:var(--text); font-family:var(--mono); }
.hero-meta-item .label { font-size:12px; color:var(--text-3); font-family:var(--mono); }
.meta-sep { width:1px; height:32px; background:var(--border); }

/* ── Homepage: Skills ─────────────────────────────────────── */
.skills-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:12px; margin-top:8px; }
.skill-card  { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px;
               transition:box-shadow .18s,border-color .18s,transform .18s; }
.skill-card:hover { box-shadow:var(--shadow-md); border-color:var(--border-dark); transform:translateY(-2px); }
.skill-icon  { font-size:22px; margin-bottom:10px; }
.skill-card h3 { font-size:14px; margin-bottom:6px; }
.skill-card p  { font-size:13px; color:var(--text-2); line-height:1.55; }

/* ── Homepage: Projects row ───────────────────────────────── */
.proj-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:8px; }
@media (max-width:640px) { .proj-row { grid-template-columns:1fr; } }

/* ── Project cards (shared) ───────────────────────────────── */
.proj-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; transition:box-shadow .18s,border-color .18s,transform .18s;
  display:block; color:inherit; cursor:pointer;
}
.proj-card:hover { box-shadow:var(--shadow-md); border-color:var(--border-dark); transform:translateY(-2px); }
.proj-thumb {
  height: 160px;
  display: flex; align-items: center; justify-content: center;
  font-size: 40px; border-bottom: 1px solid var(--border);
  overflow: hidden;
  position: relative;
}
/* Image fills the card thumbnail — responsive, centered, no stretch */
.proj-thumb-img {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .35s ease;
}
.proj-card:hover .proj-thumb-img {
  transform: scale(1.04);
}
.t-blue   { background:linear-gradient(135deg,#eff6ff,#dbeafe); }
.t-green  { background:linear-gradient(135deg,#f0fdf4,#dcfce7); }
.t-amber  { background:linear-gradient(135deg,#fffbeb,#fef3c7); }
.t-purple { background:linear-gradient(135deg,#faf5ff,#ede9fe); }
.t-rose   { background:linear-gradient(135deg,#fff1f2,#ffe4e6); }
.t-slate  { background:linear-gradient(135deg,#f8fafc,#f1f5f9); }
.proj-body { padding:18px; }
.proj-body h3  { font-size:14px; margin-bottom:6px; }
.proj-body p   { font-size:13px; color:var(--text-2); line-height:1.5; margin-bottom:12px; }
.proj-tags     { display:flex; flex-wrap:wrap; gap:5px; }
.proj-footer   { display:flex; align-items:center; justify-content:space-between; padding:12px 18px; border-top:1px solid var(--border); font-family:var(--mono); font-size:11px; color:var(--text-3); }
.proj-arrow    { transition:color .16s,transform .16s; }
.proj-card:hover .proj-arrow { color:var(--accent); transform:translateX(3px); }

/* ── Homepage: Toolbox ────────────────────────────────────── */
.tools-strip { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.tool-badge  { display:flex; align-items:center; gap:6px; background:var(--bg-card); border:1px solid var(--border);
               border-radius:6px; padding:6px 10px; font-size:12px; font-family:var(--mono); color:var(--text-2); }

/* ── Homepage: Contact ────────────────────────────────────── */
.contact-section { padding-bottom: 80px; }
.contact-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; margin-top: 8px;
}
@media (max-width:640px) { .contact-layout { grid-template-columns:1fr; } }
.contact-left h2 { font-size:22px; margin-bottom:8px; }
.contact-info-list { margin-top:20px; display:flex; flex-direction:column; gap:10px; }
.contact-info-item { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text-2); }
.info-icon { font-size:16px; flex-shrink:0; }
.contact-info-item a { color:var(--accent); }
.contact-info-item a:hover { text-decoration:underline; }

/* Contact form */
.contact-form .form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
@media (max-width:480px) { .contact-form .form-row { grid-template-columns:1fr; } }
.contact-form .form-group { margin-bottom:12px; }
.contact-form label { display:block; font-size:12px; font-weight:600; color:var(--text-2); margin-bottom:5px; font-family:var(--mono); }
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form textarea {
  width:100%; padding:10px 14px; border:1px solid var(--border-dark);
  border-radius:var(--radius); font-family:var(--sans); font-size:14px;
  background:var(--bg-card); color:var(--text); transition:border-color var(--transition); outline:none;
}
.contact-form input:focus,
.contact-form textarea:focus { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-muted); }
.contact-form textarea { resize:vertical; }

/* ── About page ───────────────────────────────────────────── */
.about-hero { padding:72px 0 48px; }
.profile-row { display:flex; gap:32px; align-items:flex-start; flex-wrap:wrap; }
.avatar { width:80px; height:80px; background:linear-gradient(135deg,#dbeafe,#c7d2fe);
          border-radius:50%; border:2px solid var(--border); display:flex; align-items:center;
          justify-content:center; font-size:32px; flex-shrink:0; }
.profile-info h1 { font-size:30px; }
.profile-info .role { font-size:15px; color:var(--text-2); margin-top:6px; }
.contact-row { display:flex; gap:8px; flex-wrap:wrap; margin-top:14px; }
.bio-block { max-width:640px; }
.bio-block p { font-size:15px; color:var(--text-2); line-height:1.75; margin-bottom:16px; }
.bio-block p strong { color:var(--text); font-weight:600; }
.resume-bar {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:18px 22px; display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px; margin-bottom:48px;
}
.resume-bar p { font-size:14px; color:var(--text-2); }

/* Timeline */
.timeline { position:relative; padding-left:20px; }
.timeline::before { content:''; position:absolute; left:0; top:6px; bottom:0; width:1px; background:var(--border); }
.tl-item { position:relative; padding:0 0 32px 24px; }
.tl-item::before { content:''; position:absolute; left:-4px; top:6px; width:9px; height:9px; border-radius:50%; background:var(--bg); border:2px solid var(--border-dark); }
.tl-item.current::before { border-color:var(--accent); background:var(--accent); }
.tl-meta { display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:4px; }
.tl-org { font-weight:600; font-size:15px; color:var(--text); }
.tl-title-wrap { margin-bottom:4px; }
.tl-title { font-size:13px; color:var(--accent); font-style:italic; }
.tl-date { font-family:var(--mono); font-size:11px; color:var(--text-3); display:block; margin-bottom:8px; }
.tl-bullets { list-style:none; padding:0; margin-top:10px; }
.tl-bullets li { position:relative; padding-left:14px; font-size:13.5px; color:var(--text-2); line-height:1.6; margin-bottom:7px; }
.tl-bullets li::before { content:'–'; position:absolute; left:0; color:var(--text-3); }

/* Education */
.edu-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px 24px; }
.edu-top { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:8px; }
.edu-top h3 { font-size:16px; }
.edu-gpa { font-family:var(--mono); font-size:13px; color:var(--green); font-weight:500; }
.edu-degree { font-size:13px; color:var(--text-2); margin-top:4px; }
.edu-courses { font-size:12.5px; color:var(--text-3); margin-top:10px; line-height:1.6; }

/* Certs */
.cert-item { display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-bottom:1px solid var(--border); }
.cert-item:last-child { border-bottom:none; }
.cert-icon { font-size:20px; flex-shrink:0; margin-top:2px; }
.cert-name { font-size:14px; font-weight:600; color:var(--text); }
.cert-issuer { font-size:13px; color:var(--text-2); margin-top:2px; }
.cert-date { font-family:var(--mono); font-size:11px; color:var(--text-3); margin-top:4px; }

/* Skills */
.skill-group { margin-bottom:20px; }
.skill-group-label { font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); margin-bottom:8px; }
.skill-tags { display:flex; flex-wrap:wrap; gap:6px; }

/* ── Projects archive ─────────────────────────────────────── */
.proj-header { padding:72px 0 40px; }
.filter-bar { display:flex; gap:6px; flex-wrap:wrap; margin:20px 0 32px; }
.filter-btn { font-family:var(--mono); font-size:11px; padding:5px 12px; border-radius:20px;
              border:1px solid var(--border); background:var(--bg); color:var(--text-2);
              cursor:pointer; transition:all .16s; }
.filter-btn.active, .filter-btn:hover { background:var(--text); color:#fff; border-color:var(--text); }
.projects-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.proj-thumbnail-img { width:100%; height:100%; object-fit:cover; object-position:center top; }

/* ── Single Project ───────────────────────────────────────── */
.back-link { display:inline-flex; align-items:center; gap:6px; font-size:13px; color:var(--text-3);
             font-family:var(--mono); margin:32px 0 20px; transition:color .16s; display:block; }
.back-link:hover { color:var(--text); }
.proj-eyebrow { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.proj-title { font-size:clamp(22px,4vw,36px); font-weight:700; letter-spacing:-.02em; line-height:1.2; max-width:640px; }
.proj-tagline { font-size:17px; color:var(--text-2); max-width:580px; margin-top:14px; line-height:1.7; }
.proj-meta-strip { display:flex; gap:0; border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; margin:32px 0 40px; flex-wrap:wrap; }
.meta-cell { flex:1; min-width:120px; padding:16px 20px; border-right:1px solid var(--border); background:var(--bg-card); }
.meta-cell:last-child { border-right:none; }
.meta-cell .label { font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.1em; color:var(--text-3); margin-bottom:6px; }
.meta-cell .val { font-size:14px; font-weight:600; color:var(--text); }
.proj-cover {
  border:1px solid var(--border); border-radius:var(--radius-lg); height:280px;
  display:flex; align-items:center; justify-content:center; flex-direction:column;
  gap:12px; margin-bottom:48px; position:relative; overflow:hidden;
}
.proj-cover::before { content:''; position:absolute; inset:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:40px 40px; opacity:.3; }
.proj-cover > * { position:relative; z-index:1; }
.proj-cover-img { width:100%; height:100%; object-fit:cover; }
.proj-cover-emoji { font-size:56px; }
.proj-cover-sub { font-family:var(--mono); font-size:11px; color:var(--text-3); letter-spacing:.08em; text-transform:uppercase; }
.impact-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; margin:16px 0 40px; }
.impact-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; text-align:center; }
.impact-num { font-family:var(--mono); font-size:26px; font-weight:700; color:var(--accent); display:block; }
.impact-label { font-size:12px; color:var(--text-3); margin-top:4px; }
.proj-nav { display:flex; gap:12px; justify-content:space-between; margin:56px 0 40px; flex-wrap:wrap; }
.proj-nav-btn { flex:1; min-width:180px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
                padding:16px 20px; display:flex; flex-direction:column; gap:4px; transition:box-shadow .16s,transform .16s; color:inherit; }
.proj-nav-btn:hover { box-shadow:var(--shadow-md); transform:translateY(-1px); }
.nav-dir   { font-family:var(--mono); font-size:11px; color:var(--text-3); }
.nav-title { font-size:14px; font-weight:600; color:var(--text); }

/* ── Prose (project content) ──────────────────────────────── */
.prose h2 { font-size:20px; margin:40px 0 14px; }
.prose h3 { font-size:17px; margin:28px 0 10px; }
.prose p  { font-size:15px; color:var(--text-2); line-height:1.75; margin-bottom:14px; }
.prose strong { color:var(--text); font-weight:600; }
.prose ul { padding-left:0; list-style:none; margin-bottom:16px; }
.prose ul li { position:relative; padding-left:18px; font-size:14.5px; color:var(--text-2); line-height:1.65; margin-bottom:8px; }
.prose ul li::before { content:'–'; position:absolute; left:0; color:var(--text-3); }
.prose ol { counter-reset:item; padding-left:0; list-style:none; }
.prose ol li { counter-increment:item; padding-left:24px; position:relative; font-size:14.5px; color:var(--text-2); margin-bottom:8px; }
.prose ol li::before { content:counter(item)'.'; position:absolute; left:0; color:var(--text-3); font-family:var(--mono); font-size:12px; }
.prose a { color:var(--accent); text-decoration:underline; }
.prose img { border-radius:var(--radius-lg); margin:24px 0; border:1px solid var(--border); }
.prose blockquote { border-left:3px solid var(--accent); padding:12px 18px; background:var(--accent-muted); border-radius:0 var(--radius) var(--radius) 0; margin:24px 0; }
.prose blockquote p { color:var(--text-2); font-style:italic; margin:0; }
.prose code { font-family:var(--mono); font-size:12px; background:var(--bg-tag); border:1px solid var(--border); padding:2px 6px; border-radius:4px; }


/* ---- Component ----- */
/* Reading Progress Bar */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%; /* Dimulai dari 0 */
  height: 4px;
  background: var(--accent); /* Menggunakan token biru Anda */
  z-index: 10000; /* Pastikan di atas nav bar */
  transition: width 0.1s ease;
  pointer-events: none; /* Agar tidak menghalangi klik */
}
