/*
Theme Name: DevFolio Pro
Theme URI: https://github.com/devfolio
Author: Custom Theme
Description: A bold, modern portfolio theme for web developers — Poppins edition.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: devfolio
Tags: portfolio, developer, blog, dark, poppins
*/

/* ═══════════════════════════════════════════════════════════
   TOKENS
═══════════════════════════════════════════════════════════ */
:root {
  --bg:          #080810;
  --bg-2:        #0f0f1a;
  --bg-card:     #13131f;
  --bg-card-2:   #18182a;
  --border:      rgba(255,255,255,0.06);
  --border-hi:   rgba(99,102,241,0.35);
  --accent:      #6366f1;
  --accent-2:    #a78bfa;
  --accent-3:    #38bdf8;
  --glow:        rgba(99,102,241,0.22);
  --success:     #34d399;
  --warn:        #fbbf24;
  --danger:      #f87171;
  --text:        #e2e2f0;
  --text-dim:    #9898b8;
  --text-muted:  #55556a;
  --white:       #ffffff;
  --font:        'Poppins', sans-serif;
  --font-mono:   'JetBrains Mono', 'Fira Code', monospace;
  --r:           10px;
  --r-lg:        18px;
  --r-xl:        28px;
  --ease:        cubic-bezier(0.4, 0, 0.2, 1);
  --t:           0.25s;
  --shadow:      0 8px 40px rgba(0,0,0,0.5);
  --shadow-glow: 0 0 50px rgba(99,102,241,0.18);
}

/* ═══════════════════════════════════════════════════════════
   RESET
═══════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Ambient glow blobs */
body::before, body::after {
  content: '';
  position: fixed;
  pointer-events: none;
  z-index: 0;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.35;
}
body::before {
  width: 700px; height: 700px;
  top: -200px; left: -150px;
  background: radial-gradient(circle, rgba(99,102,241,0.3), transparent 70%);
}
body::after {
  width: 500px; height: 500px;
  bottom: 10%; right: -100px;
  background: radial-gradient(circle, rgba(167,139,250,0.2), transparent 70%);
}

img  { max-width:100%; height:auto; display:block; }
a    { color: var(--accent); text-decoration: none; transition: color var(--t) var(--ease); }
a:hover { color: var(--accent-2); }
ul, ol { list-style: none; }

/* ═══════════════════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════════════════ */
h1,h2,h3,h4,h5,h6 { font-family: var(--font); font-weight: 700; line-height: 1.2; letter-spacing: -0.02em; color: var(--white); }
h1 { font-size: clamp(2.6rem, 6.5vw, 5rem);  font-weight: 800; }
h2 { font-size: clamp(1.9rem, 3.5vw, 2.8rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
h4 { font-size: 1.1rem; font-weight: 600; }
p  { color: var(--text-dim); margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }
strong { color: var(--text); font-weight: 600; }
.mono { font-family: var(--font-mono); font-size: 0.85em; }

/* Gradient text utility */
.grad {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 50%, var(--accent-3) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ═══════════════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════════════ */
.container         { max-width: 1160px; margin: 0 auto; padding: 0 2rem; }
.container--wide   { max-width: 1420px; margin: 0 auto; padding: 0 2rem; }
.container--narrow { max-width: 800px;  margin: 0 auto; padding: 0 2rem; }
section            { position: relative; z-index: 1; }

/* ═══════════════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════════════════ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 1.1rem 0;
  transition: background var(--t), backdrop-filter var(--t), box-shadow var(--t);
}
.site-header.scrolled {
  background: rgba(8,8,16,0.88);
  backdrop-filter: blur(24px);
  box-shadow: 0 1px 0 var(--border);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; }

.site-logo {
  font-size: 1.3rem; font-weight: 800;
  color: var(--white); letter-spacing: -0.04em;
}
.site-logo span { color: var(--accent); }

.nav-menu { display:flex; align-items:center; gap:0.25rem; }
.nav-menu a {
  font-size: 0.82rem; font-weight: 600;
  color: var(--text-dim); padding: 0.45rem 0.9rem;
  border-radius: 8px;
  text-transform: uppercase; letter-spacing: 0.06em;
  transition: color var(--t), background var(--t);
}
.nav-menu a:hover, .nav-menu a.current-menu-item { color: var(--white); background: rgba(255,255,255,0.05); }
.nav-menu a.nav-cta {
  background: var(--accent); color: var(--white) !important;
  padding: 0.5rem 1.15rem; margin-left: 0.5rem;
}
.nav-menu a.nav-cta:hover { background: var(--accent-2); }

.nav-toggle {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px; z-index:1001;
}
.nav-toggle span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all var(--t); }

/* ═══════════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding: 0.78rem 1.75rem;
  border-radius: var(--r); border:none;
  font-family: var(--font); font-weight: 600; font-size:0.9rem;
  cursor:pointer; transition: all var(--t) var(--ease);
  text-decoration:none;
}
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent-2); color:#fff; transform:translateY(-2px); box-shadow:0 10px 30px var(--glow); }
.btn-outline  { background:transparent; color:var(--text); border:1.5px solid var(--border-hi); }
.btn-outline:hover  { border-color:var(--accent); color:var(--accent); transform:translateY(-2px); }
.btn-ghost    { background:rgba(255,255,255,0.05); color:var(--text); }
.btn-ghost:hover { background:rgba(255,255,255,0.1); color:var(--white); }
.btn-sm { padding:0.55rem 1.2rem; font-size:0.82rem; }
.btn-lg { padding:0.95rem 2.2rem; font-size:1rem; }

/* ═══════════════════════════════════════════════════════════
   SECTION HEADER
═══════════════════════════════════════════════════════════ */
.section-header { text-align:center; margin-bottom:3.5rem; }
.section-tag {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-family:var(--font-mono); font-size:0.76rem; letter-spacing:0.12em;
  color:var(--accent); text-transform:uppercase; margin-bottom:0.75rem;
}
.section-tag::before, .section-tag::after { content:'//'; opacity:0.4; }
.section-title  { margin-bottom:0.75rem; }
.section-desc   { font-size:1.05rem; max-width:560px; margin:0 auto; }

/* ═══════════════════════════════════════════════════════════
   PAGE HERO (interior pages)
═══════════════════════════════════════════════════════════ */
.page-hero {
  padding: 11rem 0 5rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.page-hero::before {
  content:'';
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(99,102,241,0.12) 0%, transparent 70%);
  pointer-events:none;
}
.page-hero .eyebrow { color:var(--accent); font-size:0.8rem; font-weight:600; text-transform:uppercase; letter-spacing:0.14em; display:block; margin-bottom:0.8rem; }
.page-hero p { max-width:560px; margin:1.2rem auto 0; font-size:1.1rem; }

/* ═══════════════════════════════════════════════════════════
   CARDS  (shared)
═══════════════════════════════════════════════════════════ */
.card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
}
.card:hover { border-color:var(--border-hi); transform:translateY(-5px); box-shadow:var(--shadow), var(--shadow-glow); }

/* ═══════════════════════════════════════════════════════════
   ██████  HOME PAGE
═══════════════════════════════════════════════════════════ */

/* Hero */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding:8rem 0 5rem; overflow:hidden;
}
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }

.hero-status {
  display:inline-flex; align-items:center; gap:0.55rem;
  background:rgba(52,211,153,0.08); border:1px solid rgba(52,211,153,0.25);
  color:var(--success); padding:0.4rem 1rem; border-radius:100px;
  font-size:0.76rem; font-weight:600; letter-spacing:0.06em;
  margin-bottom:1.5rem; text-transform:uppercase;
}
.hero-status .pulse {
  width:7px; height:7px; border-radius:50%;
  background:var(--success); animation:pulse 2.2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.4)} }

.hero-title { margin-bottom:1.4rem; }
.hero-title .line { display:block; }
.hero-sub { font-size:1.1rem; max-width:480px; margin-bottom:2.2rem; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }

.hero-stats { display:flex; gap:2.5rem; padding-top:2rem; border-top:1px solid var(--border); }
.stat-num   { font-size:2rem; font-weight:800; color:var(--white); line-height:1; }
.stat-lbl   { font-size:0.72rem; font-weight:600; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.08em; margin-top:0.2rem; }

/* Floating code card */
.hero-visual { position:relative; display:flex; justify-content:center; align-items:center; }
.code-card {
  background:var(--bg-card-2); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:1.6rem;
  font-family:var(--font-mono); font-size:0.8rem; line-height:1.85;
  box-shadow:var(--shadow), var(--shadow-glow);
  width:100%; max-width:430px;
  animation:float 6s ease-in-out infinite;
}
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
.code-dots { display:flex; gap:6px; margin-bottom:1.2rem; padding-bottom:1rem; border-bottom:1px solid var(--border); }
.cd { width:12px;height:12px;border-radius:50%; }
.cd:nth-child(1){background:#ff5f57} .cd:nth-child(2){background:#febc2e} .cd:nth-child(3){background:#28c840}
.code-fname { margin-left:auto; font-size:0.68rem; color:var(--text-muted); }
.cl { display:flex; gap:0.5rem; }
.cp{color:#c792ea} .cb{color:#82aaff} .cg{color:#c3e88d} .co{color:#f78c6c} .cm{color:var(--text-muted)} .cw{color:#fff}

.float-badge {
  position:absolute; bottom:-1.5rem; right:-1rem;
  background:var(--bg-card-2); border:1px solid var(--border-hi);
  border-radius:var(--r); padding:0.9rem 1.1rem;
  display:flex; align-items:center; gap:0.7rem;
  box-shadow:var(--shadow);
}
.fb-icon { width:36px;height:36px; border-radius:9px; background:rgba(99,102,241,0.15); display:flex;align-items:center;justify-content:center;font-size:1.2rem; }
.fb-val  { font-size:0.88rem; font-weight:700; color:var(--white); }
.fb-lbl  { font-size:0.7rem; color:var(--text-muted); }

/* Home sections */
.home-section { padding:7rem 0; }
.home-section + .home-section { border-top:1px solid var(--border); }

/* Services strip */
.services-strip { padding:5rem 0; background:var(--bg-2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.services-grid  { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:1.5rem; }
.service-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:1.8rem;
  transition:all var(--t);
}
.service-card:hover { border-color:var(--border-hi); transform:translateY(-4px); box-shadow:0 12px 30px var(--glow); }
.service-icon { font-size:2rem; margin-bottom:1rem; }
.service-card h4 { margin-bottom:0.4rem; font-size:1rem; }
.service-card p  { font-size:0.85rem; }

/* Featured projects (home preview) */
.projects-preview { display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:1.5rem; }
.proj-card { border-radius:var(--r-lg); overflow:hidden; display:flex; flex-direction:column; }
.proj-card .card-img {
  aspect-ratio:16/9; overflow:hidden;
  background:linear-gradient(135deg,var(--bg-2),var(--bg-card));
  display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text-muted);
}
.proj-card .card-img img { width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease); }
.proj-card:hover .card-img img { transform:scale(1.04); }
.proj-card .card-body { padding:1.5rem; flex:1; display:flex;flex-direction:column; }
.proj-tags { display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem; }
.tag {
  font-family:var(--font-mono); font-size:0.7rem; padding:0.2rem 0.6rem;
  border-radius:100px; border:1px solid var(--border); color:var(--text-muted); letter-spacing:.04em;
}
.proj-title { font-size:1.2rem; margin-bottom:.5rem; }
.proj-desc  { font-size:.88rem; flex:1; }
.proj-links { display:flex;gap:.75rem;margin-top:1.2rem;padding-top:1rem;border-top:1px solid var(--border); }
.proj-links a {
  font-size:.8rem; font-weight:600; color:var(--text-muted);
  display:flex;align-items:center;gap:.3rem; transition:color var(--t);
}
.proj-links a:hover { color:var(--accent); }

/* Latest blog (home preview) */
.blog-preview { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:1.5rem; }

/* Testimonials */
.testimonials-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.testi-card { padding:1.8rem; }
.testi-stars { color:var(--warn); font-size:0.85rem; margin-bottom:0.8rem; }
.testi-text  { font-size:0.9rem; line-height:1.75; font-style:italic; margin-bottom:1.2rem; color:var(--text); }
.testi-author { display:flex;align-items:center;gap:.75rem; }
.testi-avatar { width:40px;height:40px;border-radius:50%;background:var(--bg-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem; }
.testi-name { font-size:.88rem;font-weight:700;color:var(--white); }
.testi-role { font-size:.74rem;color:var(--text-muted); }

/* CTA band */
.cta-band {
  padding:7rem 0;
  text-align:center;
}
.cta-inner {
  background:var(--bg-card);
  border:1px solid var(--border-hi);
  border-radius:var(--r-xl);
  padding:4.5rem 3rem;
  position:relative; overflow:hidden;
}
.cta-inner::before {
  content:''; position:absolute; top:-60%; left:50%; transform:translateX(-50%);
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(99,102,241,0.15),transparent 65%);
  pointer-events:none;
}
.cta-inner h2 { margin-bottom:1rem; }
.cta-inner p  { max-width:480px;margin:0 auto 2rem; font-size:1.05rem; }
.cta-actions  { display:flex;justify-content:center;gap:1rem;flex-wrap:wrap; }

/* ═══════════════════════════════════════════════════════════
   ██████  ABOUT PAGE
═══════════════════════════════════════════════════════════ */
.about-section { padding:5rem 0 7rem; }
.about-grid { display:grid; grid-template-columns:1fr 1.55fr; gap:5rem; align-items:start; }

.about-photo-wrap { position:relative; }
.about-photo {
  width:100%; aspect-ratio:4/5; border-radius:var(--r-xl);
  border:1px solid var(--border); overflow:hidden;
  background:var(--bg-card);
  display:flex;align-items:center;justify-content:center;font-size:5rem;
}
.about-photo img { width:100%;height:100%;object-fit:cover; }
.about-photo::before {
  content:''; position:absolute; inset:-1px; border-radius:var(--r-xl);
  background:linear-gradient(145deg,var(--accent),transparent 55%);
  z-index:-1; opacity:.4;
}
.exp-chip {
  position:absolute; bottom:-1.2rem; right:-1.2rem;
  background:var(--accent); color:#fff;
  padding:.9rem 1.2rem; border-radius:var(--r);
  font-weight:800; text-align:center;
}
.exp-chip .big { font-size:2rem; line-height:1; display:block; }
.exp-chip .sm  { font-size:.7rem; opacity:.85; }

.about-content h2  { margin-bottom:1.2rem; }
.about-content p   { font-size:1rem; margin-bottom:1rem; }
.about-actions     { display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem; }

/* Skill bars */
.skills-wrap { margin:2.5rem 0; }
.skill-row   { margin-bottom:1.1rem; }
.skill-meta  { display:flex;justify-content:space-between;margin-bottom:.35rem; }
.skill-name  { font-size:.85rem;font-weight:600;color:var(--text); }
.skill-pct   { font-family:var(--font-mono);font-size:.76rem;color:var(--accent); }
.skill-track { height:4px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden; }
.skill-fill  {
  height:100%; border-radius:4px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transform:scaleX(0); transform-origin:left;
  animation:barIn 1.3s var(--ease) forwards; animation-play-state:paused;
}
@keyframes barIn { to{transform:scaleX(1)} }

/* Values */
.values-section { padding:5rem 0; background:var(--bg-2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.values-grid    { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem; }
.value-card     { padding:1.8rem;text-align:center; }
.value-icon     { font-size:2.2rem;margin-bottom:.8rem; }
.value-card h4  { margin-bottom:.4rem;font-size:.98rem; }
.value-card p   { font-size:.83rem; }

/* Timeline */
.timeline-section { padding:6rem 0; }
.timeline         { max-width:700px; margin:0 auto; position:relative; }
.timeline::before { content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--accent),transparent); }
.tl-item          { padding:0 0 2.8rem 2.5rem; position:relative; }
.tl-item:last-child { padding-bottom:0; }
.tl-item::before  { content:'';position:absolute;left:-5px;top:8px;width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--glow); }
.tl-year          { font-family:var(--font-mono);font-size:.74rem;color:var(--accent);letter-spacing:.1em;margin-bottom:.2rem; }
.tl-role          { font-size:1.05rem;font-weight:700;color:var(--white);margin-bottom:.1rem; }
.tl-company       { font-size:.84rem;color:var(--text-muted);margin-bottom:.5rem; }
.tl-desc          { font-size:.88rem; }

/* Fun facts strip */
.facts-strip { padding:4rem 0;text-align:center; }
.facts-grid  { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:2rem; }
.fact-item .big { font-size:2.5rem;font-weight:800;color:var(--white);line-height:1; }
.fact-item .sm  { font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.3rem; }

/* ═══════════════════════════════════════════════════════════
   ██████  PORTFOLIO PAGE
═══════════════════════════════════════════════════════════ */
.portfolio-section { padding:3rem 0 7rem; }
.portfolio-filter  {
  display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:3rem;
}
.pf-btn {
  background:var(--bg-card);border:1px solid var(--border);
  color:var(--text-muted);padding:.45rem 1.1rem;border-radius:100px;
  font-family:var(--font);font-size:.8rem;font-weight:600;cursor:pointer;
  transition:all var(--t);
}
.pf-btn:hover, .pf-btn.active { background:var(--accent);border-color:var(--accent);color:#fff; }

.portfolio-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem; }

.portfolio-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r-xl); overflow:hidden;
  display:flex;flex-direction:column;
  transition:all var(--t);
}
.portfolio-card:hover { border-color:var(--border-hi);transform:translateY(-6px);box-shadow:var(--shadow),var(--shadow-glow); }
.portfolio-card .pcard-img {
  aspect-ratio:16/9;overflow:hidden;position:relative;
  background:linear-gradient(135deg,var(--bg-2),var(--bg-card));
  display:flex;align-items:center;justify-content:center;font-size:3.5rem;
}
.portfolio-card .pcard-img img { width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease); }
.portfolio-card:hover .pcard-img img { transform:scale(1.06); }
.pcard-overlay {
  position:absolute;inset:0;background:rgba(8,8,16,.8);
  display:flex;align-items:center;justify-content:center;gap:1rem;
  opacity:0;transition:opacity var(--t);
}
.portfolio-card:hover .pcard-overlay { opacity:1; }
.pcard-body  { padding:1.5rem;flex:1;display:flex;flex-direction:column; }
.pcard-cat   { font-family:var(--font-mono);font-size:.7rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem; }
.pcard-title { font-size:1.15rem;margin-bottom:.5rem; }
.pcard-desc  { font-size:.87rem;flex:1; }
.pcard-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:1.3rem;padding-top:1rem;border-top:1px solid var(--border);
}
.pcard-tech  { display:flex;gap:.4rem;flex-wrap:wrap; }

/* Case study section (single project page) */
.case-study  { padding:10rem 0 6rem; }

/* ═══════════════════════════════════════════════════════════
   ██████  BLOG PAGE
═══════════════════════════════════════════════════════════ */
.blog-section { padding:3rem 0 7rem; }
.blog-grid    { display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem; }

.post-card {
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  display:flex;flex-direction:column;
  transition:all var(--t);
}
.post-card:hover { border-color:var(--border-hi);transform:translateY(-5px);box-shadow:var(--shadow),var(--shadow-glow); }
.post-thumb { aspect-ratio:16/9;overflow:hidden;background:var(--bg-2);flex-shrink:0; }
.post-thumb img { width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease); }
.post-card:hover .post-thumb img { transform:scale(1.04); }
.post-body   { padding:1.5rem;flex:1;display:flex;flex-direction:column; }
.post-meta   { display:flex;align-items:center;gap:1rem;margin-bottom:.7rem; }
.post-cat    { font-family:var(--font-mono);font-size:.7rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em; }
.post-date   { font-size:.75rem;color:var(--text-muted); }
.post-title  { font-size:1.15rem;margin-bottom:.6rem;transition:color var(--t); }
.post-card:hover .post-title { color:var(--accent-2); }
.post-excerpt{ font-size:.88rem;flex:1; }
.post-footer { display:flex;align-items:center;justify-content:space-between;margin-top:1.3rem;padding-top:1rem;border-top:1px solid var(--border); }
.read-time   { font-size:.75rem;color:var(--text-muted); }
.read-more   { font-size:.82rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:.3rem;transition:gap var(--t); }
.read-more:hover { gap:.6rem;color:var(--accent-2); }

/* Single post */
.single-post     { padding:10rem 0 6rem; }
.post-header     { margin-bottom:3rem; text-align:center; }
.post-content    { font-size:1.05rem; line-height:1.9; }
.post-content h2,.post-content h3 { margin:2.5rem 0 1rem; }
.post-content p  { color:var(--text-dim);margin-bottom:1.4rem; }
.post-content ul,.post-content ol { padding-left:1.5rem;margin-bottom:1.4rem;color:var(--text-dim); }
.post-content li { list-style:disc;margin-bottom:.4rem; }
.post-content ol li { list-style:decimal; }
.post-content pre { background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;overflow-x:auto;margin-bottom:1.5rem; }
.post-content code { font-family:var(--font-mono);font-size:.84em;background:rgba(99,102,241,0.12);padding:.15em .4em;border-radius:4px;color:var(--accent-2); }
.post-content pre code { background:none;padding:0;color:var(--text); }
.post-content blockquote { border-left:3px solid var(--accent);padding-left:1.5rem;margin:2rem 0;font-style:italic;color:var(--text); }

/* ═══════════════════════════════════════════════════════════
   ██████  CONTACT PAGE
═══════════════════════════════════════════════════════════ */
.contact-section { padding:3rem 0 8rem; }
.contact-grid    { display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start; }

.contact-info h3 { margin-bottom:1rem; font-size:1.4rem; }
.contact-info p  { font-size:1rem; margin-bottom:2rem; }

.contact-list    { display:flex;flex-direction:column;gap:1rem;margin-bottom:2.5rem; }
.contact-item {
  display:flex;align-items:center;gap:1rem;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r);padding:1rem 1.2rem;
  transition:border-color var(--t);
}
.contact-item:hover { border-color:var(--border-hi); }
.ci-icon { width:40px;height:40px;border-radius:10px;background:rgba(99,102,241,0.12);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0; }
.ci-label { font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.15rem; }
.ci-val   { font-size:.9rem;font-weight:600;color:var(--white); }
.ci-val a { color:var(--white); }
.ci-val a:hover { color:var(--accent); }

.contact-socials { display:flex;gap:.75rem; }
.soc-btn {
  width:44px;height:44px;border-radius:var(--r);
  background:var(--bg-card);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:1rem;
  transition:all var(--t);
}
.soc-btn:hover { border-color:var(--accent);color:var(--accent);transform:translateY(-2px); }

/* Contact Form */
.contact-form-wrap {
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:2.5rem;
}
.contact-form-wrap h3 { margin-bottom:1.5rem; font-size:1.3rem; }

.form-row   { display:grid;grid-template-columns:1fr 1fr;gap:1rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label { display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:.45rem; }
.form-group input,
.form-group textarea,
.form-group select {
  width:100%;background:var(--bg-2);
  border:1.5px solid var(--border);border-radius:var(--r);
  padding:.8rem 1rem;color:var(--text);
  font-family:var(--font);font-size:.9rem;
  transition:border-color var(--t);
  outline:none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { border-color:var(--accent); }
.form-group textarea { min-height:150px;resize:vertical; }
.form-group select option { background:var(--bg-2); }

.wpcf7-spinner { display:none; }
.wpcf7 .btn   { width:100%;justify-content:center; }

/* Availability banner */
.avail-banner {
  background:rgba(52,211,153,0.07);border:1px solid rgba(52,211,153,0.2);
  border-radius:var(--r);padding:1rem 1.3rem;
  display:flex;align-items:center;gap:.75rem;margin-top:2rem;font-size:.85rem;color:var(--text);
}
.avail-dot { width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0;animation:pulse 2s infinite; }

/* Map/location block */
.location-section { padding:5rem 0;border-top:1px solid var(--border); }
.location-card {
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:2.5rem;display:flex;align-items:center;gap:3rem;flex-wrap:wrap;
}
.loc-icon { font-size:3rem; flex-shrink:0; }
.loc-info h3 { margin-bottom:.4rem; }
.loc-info p  { font-size:.9rem; }

/* FAQ */
.faq-section { padding:6rem 0;border-top:1px solid var(--border); }
.faq-list    { max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:1rem; }
.faq-item {
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);
  overflow:hidden;transition:border-color var(--t);
}
.faq-item.open { border-color:var(--border-hi); }
.faq-q {
  width:100%;background:none;border:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.2rem 1.5rem;cursor:pointer;text-align:left;
  font-family:var(--font);font-size:.95rem;font-weight:600;color:var(--white);
}
.faq-q svg { flex-shrink:0;transition:transform var(--t); }
.faq-item.open .faq-q svg { transform:rotate(180deg); }
.faq-a { max-height:0;overflow:hidden;transition:max-height .4s var(--ease); }
.faq-a-inner { padding:0 1.5rem 1.2rem;font-size:.9rem;color:var(--text-dim); }

/* ═══════════════════════════════════════════════════════════
   ██████  AFFILIATE LINKS PAGE
═══════════════════════════════════════════════════════════ */
.links-section { padding:3rem 0 7rem; }
.affiliate-disclosure {
  background:rgba(99,102,241,.07);border:1px solid rgba(99,102,241,.2);
  border-radius:var(--r);padding:1rem 1.5rem;text-align:center;
  margin-bottom:2.5rem;font-size:.84rem;color:var(--text-muted);
}
.affiliate-disclosure strong { color:var(--accent-2); }
.links-filter { display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:3rem; }
.lf-btn {
  background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);
  padding:.4rem 1rem;border-radius:100px;font-family:var(--font);font-size:.78rem;
  font-weight:600;cursor:pointer;transition:all var(--t);
}
.lf-btn:hover,.lf-btn.active { background:var(--accent);border-color:var(--accent);color:#fff; }
.links-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.2rem; }
.link-card {
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.5rem;display:flex;flex-direction:column;gap:1rem;
  position:relative;overflow:hidden;transition:all var(--t);
}
.link-card::before { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));opacity:0;transition:opacity var(--t); }
.link-card:hover { border-color:var(--border-hi);transform:translateY(-4px);box-shadow:var(--shadow),var(--shadow-glow); }
.link-card:hover::before { opacity:1; }
.lcard-header { display:flex;align-items:flex-start;gap:.9rem; }
.lcard-logo   { width:48px;height:48px;border-radius:12px;background:var(--bg-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;overflow:hidden; }
.lcard-logo img { width:100%;height:100%;object-fit:contain;padding:5px; }
.lcard-name   { font-size:1.02rem;font-weight:700;color:var(--white);margin-bottom:.1rem; }
.lcard-cat    { font-family:var(--font-mono);font-size:.68rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em; }
.lcard-badge  { font-family:var(--font-mono);font-size:.63rem;padding:.2rem .5rem;border-radius:4px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;flex-shrink:0; }
.lcard-badge.free { background:rgba(52,211,153,.12);color:var(--success);border:1px solid rgba(52,211,153,.25); }
.lcard-badge.deal { background:rgba(99,102,241,.12);color:var(--accent-2);border:1px solid rgba(99,102,241,.25); }
.lcard-badge.paid { background:rgba(248,113,113,.12);color:#f87171;border:1px solid rgba(248,113,113,.25); }
.lcard-desc  { font-size:.86rem;line-height:1.65; }
.lcard-cta   { display:flex;align-items:center;justify-content:space-between;margin-top:auto; }
.lcard-btn   { display:inline-flex;align-items:center;gap:.4rem;background:var(--accent);color:#fff;padding:.5rem 1.1rem;border-radius:8px;font-size:.8rem;font-weight:700;transition:all var(--t); }
.lcard-btn:hover { background:var(--accent-2);color:#fff;transform:translateX(2px); }
.lcard-disc  { font-size:.68rem;color:var(--text-muted);font-style:italic; }

/* ═══════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════ */
.site-footer { border-top:1px solid var(--border);padding:5rem 0 2rem; }
.footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem; }
.footer-brand .site-logo { display:block;margin-bottom:1rem; }
.footer-brand p { font-size:.87rem;max-width:250px; }
.footer-socials { display:flex;gap:.6rem;margin-top:1.5rem; }
.fsoc { width:36px;height:36px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem;transition:all var(--t); }
.fsoc:hover { border-color:var(--accent);color:var(--accent);transform:translateY(-2px); }
.footer-col h4 { font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1.1rem; }
.footer-col ul { display:flex;flex-direction:column;gap:.55rem; }
.footer-col a  { font-size:.88rem;color:var(--text-dim);transition:color var(--t); }
.footer-col a:hover { color:var(--accent); }
.footer-bottom { padding-top:2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--text-muted); }

/* ═══════════════════════════════════════════════════════════
   MISC
═══════════════════════════════════════════════════════════ */
.pagination { display:flex;justify-content:center;gap:.5rem;margin-top:4rem; }
.page-numbers { width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);color:var(--text-muted);font-size:.88rem;transition:all var(--t); }
.page-numbers:hover,.page-numbers.current { background:var(--accent);border-color:var(--accent);color:#fff; }

.page-404 { min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center; }
.err-code  { font-size:clamp(6rem,20vw,14rem);font-weight:900;line-height:1;background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.3;margin-bottom:-2rem; }

/* Scroll reveal */
.reveal { opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal.in { opacity:1;transform:none; }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }

/* Scrollbar */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--border);border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent); }
::selection { background:var(--accent);color:#fff; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media(max-width:1024px) {
  .hero-grid,.about-grid,.contact-grid { grid-template-columns:1fr; }
  .hero-visual { display:none; }
  .hero { min-height:auto;padding:8rem 0 4rem; }
  .about-photo { aspect-ratio:1/1;max-width:400px; }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .nav-menu { display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(8,8,16,.97);flex-direction:column;align-items:center;justify-content:center;gap:2rem;z-index:999; }
  .nav-menu.open { display:flex; }
  .nav-menu a { font-size:1.2rem;padding:.6rem 1rem; }
  .nav-toggle { display:flex; }
  .form-row { grid-template-columns:1fr; }
  .contact-grid { gap:3rem; }
  .footer-grid { grid-template-columns:1fr;gap:2rem; }
  .footer-bottom { flex-direction:column;gap:.5rem;text-align:center; }
  .cta-inner { padding:2.5rem 1.5rem; }
  .portfolio-grid,.blog-grid,.links-grid,.projects-preview,.blog-preview { grid-template-columns:1fr; }
  .facts-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:480px) {
  .container { padding:0 1.2rem; }
  h1 { font-size:2.3rem; }
  .hero-actions,.cta-actions { flex-direction:column; }
  .hero-stats { gap:1.5rem; }
}
