/* ==========================================================================
 MODERN EMERALD DARK THEME - CORE VARIABLES
========================================================================== */
:root {
 --bg-body: #030712;
 --bg-surface: #0a0f1e;
 --bg-glass: rgba(11, 17, 32, 0.7);
 --emerald-main: #10b981;
 --emerald-glow: rgba(16, 185, 129, 0.4);
 --emerald-dark: #047857;
 --text-bright: #f1f5f9;
 --text-muted: #64748b;
 --border-color: rgba(255, 255, 255, 0.08);
 --font-sans: 'Inter', sans-serif;
 --font-display: 'Space Grotesk', sans-serif;
 --sidebar-width: 320px;
 --transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);

 /* Legacy variables used by older sections (kept for backwards compatibility) */
 --emerald: var(--emerald-main);
 --emerald-2: #34d399;
 --cyan: #06b6d4;
 --border: var(--border-color);
 --border-em: rgba(16, 185, 129, 0.2);
 --bg-card: var(--bg-surface);
 --text-soft: var(--text-muted);
 --font-head: var(--font-display);
 --radius-lg: 20px;
 --ease: cubic-bezier(0.4, 0, 0.2, 1);
 --t: 0.25s;
 --sidebar-w: var(--sidebar-width);
 --shadow-card: 0 16px 40px rgba(0,0,0,0.2);
 --shadow-glow: 0 0 24px rgba(16, 185, 129, 0.15);
}

/* LIGHT MODE VARIABLES */
body.light-mode {
  --bg-body: #f8fafc;
  --bg-surface: #ffffff;
  --bg-glass: rgba(255, 255, 255, 0.8);
  --emerald-main: #059669;
  --emerald-glow: rgba(5, 150, 105, 0.3);
  --text-bright: #0f172a;
  --text-muted: #475569;
  --border-color: rgba(0, 0, 0, 0.08);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--bg-body);
  color: var(--text-bright);
  font-family: var(--font-sans);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  transition: background-color 0.5s ease, color 0.5s ease;
}

a {
  text-decoration: none;
  color: var(--emerald-main);
  transition: var(--transition);
}

a:hover {
  color: var(--text-bright);
}

ul {
  list-style: none;
}

::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-body);
}

::-webkit-scrollbar-thumb {
  background: var(--text-muted);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--emerald-main);
}

/* ========================================================================== PAGE LOADER ========================================================================== */
#page-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-body);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.5s ease, visibility 0.5s;
}

.spinner {
  width: 50px;
  height: 50px;
  border: 4px solid var(--border-color);
  border-top-color: var(--emerald-main);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}

/* ========================================================================== LAYOUT ARCHITECTURE & PREMIUM SIDEBAR ========================================================================== */
.app-container { display: flex; min-height: 100vh; width: 100%; } .sidebar-cv { width: var(--sidebar-width); min-width: var(--sidebar-width); background: var(--bg-surface); border-right: 1px solid var(--border-color); box-shadow: 5px 0 30px rgba(0,0,0,0.1); position: fixed; height: 100vh; overflow-y: auto; display: flex; flex-direction: column; z-index: 100; transition: var(--transition); } .profile-header { position: relative; width: 100%; height: 280px; padding: 0; overflow: hidden; } .profile-header-bg { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1); } .sidebar-cv:hover .profile-header-bg { transform: scale(1.05); } .profile-overlay { position: absolute; bottom: 0; left: 0; width: 100%; padding: 2.5rem 2rem 1.5rem; background: linear-gradient(to top, var(--bg-surface) 0%, rgba(11, 17, 32, 0.8) 50%, transparent 100%); z-index: 2; display: flex; flex-direction: column; } body.light-mode .profile-overlay { background: linear-gradient(to top, var(--bg-surface) 0%, rgba(255, 255, 255, 0.8) 50%, transparent 100%); } .profile-name { font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--text-bright); margin-bottom: 0.3rem; line-height: 1.1; letter-spacing: -0.5px; } .profile-role { font-size: 0.85rem; color: var(--text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 2px; display: flex; align-items: center; justify-content: center; gap: 10px; } .profile-role::before { content: ''; display: block; width: 6px; height: 6px; background: var(--emerald-main); border-radius: 50%; box-shadow: 0 0 10px var(--emerald-main); animation: pulseDot 2s infinite; } .nav-menu { padding: 1.5rem 0; flex-grow: 1; } .nav-menu ul { display: flex; flex-direction: column; gap: 6px; } .nav-menu ul li a { display: flex; align-items: center; padding: 14px 1.5rem; margin: 0 1.5rem; border-radius: 12px; color: var(--text-muted); font-weight: 500; font-size: 0.95rem; transition: var(--transition); position: relative; overflow: hidden; } .nav-menu ul li a i { width: 24px; margin-right: 15px; font-size: 1.1rem; opacity: 0.6; transition: var(--transition); } .nav-menu ul li a:hover, .nav-menu ul li a.active { color: var(--text-bright); background: rgba(16, 185, 129, 0.1); transform: translateX(6px); box-shadow: inset 3px 0 0 var(--emerald-main); } .nav-menu ul li a:hover i, .nav-menu ul li a.active i { color: var(--emerald-main); opacity: 1; transform: scale(1.1); } .sidebar-footer { padding: 2rem 1.5rem; display: flex; gap: 10px; flex-direction: column; } .sidebar-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 15px; background: linear-gradient(135deg, rgba(16,185,129,0.05), rgba(4,120,87,0.1)); color: var(--emerald-main); border: 1px solid rgba(16, 185, 129, 0.2); border-radius: 12px; font-weight: 600; font-size: 0.95rem; transition: var(--transition); cursor: pointer; } .sidebar-btn:hover { background: var(--emerald-main); color: #fff; border-color: var(--emerald-main); box-shadow: 0 10px 25px -5px var(--emerald-glow); transform: translateY(-3px); } /* ========================================================================== MAIN CONTENT & HEADERS ========================================================================== */ .main-content { flex: 1; margin-left: var(--sidebar-width); width: calc(100% - var(--sidebar-width)); position: relative; display: flex; flex-direction: column; } .mobile-header { display: none; height: 70px; background: var(--bg-glass); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border-color); padding: 0 1.5rem; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 90; } .mobile-toggle, .mobile-theme-toggle { font-size: 1.5rem; color: var(--text-bright); cursor: pointer; } .header-icons { display: flex; gap: 20px; align-items: center; } .page-header { padding: 4rem 4rem 0; max-width: 1400px; margin: 0 auto; width: 100%; } .page-header h1 { font-family: var(--font-display); font-size: 3.5rem; color: var(--emerald-main); margin-bottom: 0.5rem; line-height: 1.1; } .page-header p { color: var(--text-muted); font-size: 1.2rem; } /* ========================================================================== HOME HERO CV ========================================================================== */ .hero-section { position: relative; padding: 6rem 4rem; border-bottom: 1px solid var(--border-color); overflow: hidden; display: flex; align-items: center; min-height: 80vh; background: var(--bg-body); } #particles-js { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; } .hero-content-wrapper { position: relative; z-index: 2; width: 100%; max-width: 1300px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 4rem; } .hero-text-column { flex: 1; max-width: 750px; } .hero-greeting { color: var(--emerald-main); font-family: var(--font-sans); font-weight: 600; font-size: 0.95rem; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 1.5rem; display: inline-flex; align-items: center; gap: 8px; background: rgba(16, 185, 129, 0.1); padding: 8px 16px; border-radius: 30px; border: 1px solid var(--emerald-glow); } .hero-name { font-family: var(--font-display); font-size: 5.5rem; font-weight: 800; line-height: 1.1; margin-bottom: 0.5rem; letter-spacing: -2px; background: linear-gradient(to right, var(--text-bright), var(--emerald-main)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; } /* TYPING TEXT EFFECT */ .hero-roles { font-family: var(--font-display); font-size: 2rem; color: var(--text-muted); margin-bottom: 1.5rem; font-weight: 300; } .hero-roles .typed-text { color: var(--emerald-main); font-weight: 600; } .hero-roles .cursor { display: inline-block; width: 3px; background-color: var(--emerald-main); margin-left: 2px; animation: blink 1s infinite; } .hero-roles .cursor.typing { animation: none; } @keyframes blink { 0%, 49% { background-color: var(--emerald-main); } 50%, 99% { background-color: transparent; } 100% { background-color: var(--emerald-main); } } .hero-bio { font-size: 1.15rem; color: var(--text-muted); line-height: 1.8; margin-bottom: 1.5rem; max-width: 90%; } .hero-socials { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 2.5rem; } .hero-social-btn { width: 42px; height: 42px; border-radius: 50%; background: var(--bg-surface); border: 1px solid var(--border-color); display: flex; align-items: center; justify-content: center; color: var(--text-bright); font-size: 1.1rem; transition: var(--transition); } .hero-social-btn:hover { background: var(--emerald-main); color: #fff; border-color: var(--emerald-main); transform: translateY(-4px) rotate(8deg); box-shadow: 0 5px 15px var(--emerald-glow); } .hero-buttons { display: flex; gap: 15px; margin-bottom: 3.5rem; } .btn-primary, .btn-secondary { padding: 14px 32px; border-radius: 8px; font-weight: 600; font-size: 1rem; display: flex; align-items: center; gap: 10px; transition: var(--transition); cursor: pointer; } .btn-primary { background: var(--emerald-main); color: #fff; border: 1px solid var(--emerald-main); box-shadow: 0 0 20px var(--emerald-glow); } .btn-primary:hover { background: transparent; color: var(--emerald-main); transform: translateY(-3px); } .btn-secondary { background: var(--bg-surface); color: var(--text-bright); border: 1px solid var(--border-color); } .btn-secondary:hover { background: rgba(16,185,129,0.1); border-color: var(--emerald-main); color: var(--emerald-main); transform: translateY(-3px); } .hero-skills { display: flex; flex-wrap: wrap; align-items: center; gap: 15px; } .skills-label { font-weight: 700; color: var(--emerald-main); text-transform: uppercase; font-size: 0.85rem; letter-spacing: 1px; } .hero-skills > span:first-child { font-size: 0.85rem; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; margin-right: 5px; color: var(--text-bright); } .project-stat { background: rgba(255, 255, 255, 0.05); padding: 4px 12px; border-radius: 20px; font-size: 0.95rem; display: flex; align-items: center; gap: 8px; border: 1px solid var(--border-color); } .project-stat i { color: var(--emerald-main); font-size: 1rem; } .project-stat:hover { background: var(--emerald-main); color: #fff; transform: translateY(-3px); box-shadow: 0 5px 15px var(--emerald-glow); } .project-stat:hover i { color: #fff; } .hero-image-column { flex: 0 0 450px; display: flex; justify-content: center; position: relative; } .hero-image-frame { width: 100%; height: 500px; border-radius: 20px; overflow: hidden; position: relative; border: 2px solid var(--border-color); box-shadow: 0 20px 40px rgba(0,0,0,0.3); background: var(--bg-surface); } .slide-wrapper { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; visibility: hidden; transition: opacity 1.5s ease-in-out, visibility 1.5s; z-index: 1; } .slide-wrapper.active { opacity: 1; visibility: visible; z-index: 5; } .slide-wrapper img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.6); transform: scale(1.0); } .slide-wrapper.active img { filter: brightness(1); animation: kenBurnsZoom 6s ease-out forwards; } @keyframes kenBurnsZoom { 0% { transform: scale(1.0); } 100% { transform: scale(1.15); } } .slide-caption { position: absolute; bottom: 20px; left: 20px; right: 20px; background: rgba(5, 8, 15, 0.85); backdrop-filter: blur(10px); padding: 15px; border-radius: 12px; border-left: 3px solid var(--emerald-main); transform: translateY(20px); opacity: 0; transition: all 0.6s ease 0.3s; z-index: 10; } .slide-wrapper.active .slide-caption { transform: translateY(0); opacity: 1; } .slide-caption p { margin: 0 0 5px 0; font-size: 0.75rem; color: var(--emerald-main); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; } .slide-caption h4 { margin: 0; font-size: 1.15rem; font-family: var(--font-display); line-height: 1.3; } .slide-caption h4 a { color: #fff; } .slide-caption h4 a:hover { color: var(--emerald-main); } /* ========================================================================== TECH MARQUEE ========================================================================== */ .tech-marquee-wrapper { width: 100%; background: var(--bg-surface); padding: 1.5rem 0; overflow: hidden; border-bottom: 1px solid var(--border-color); display: flex; align-items: center; position: relative; } .tech-marquee { display: flex; width: max-content; animation: scrollMarquee 25s linear infinite; align-items: center; white-space: nowrap; } .tech-item { display: inline-flex; align-items: center; gap: 10px; margin: 0 2.5rem; font-family: var(--font-display); font-weight: 600; color: var(--text-muted); font-size: 1.1rem; transition: var(--transition); flex-shrink: 0; } .tech-item i { font-size: 1.5rem; color: var(--emerald-main); } .tech-item:hover { color: var(--text-bright); transform: scale(1.1); } @keyframes scrollMarquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } } /* ========================================================================== SERVICES SECTION ========================================================================== */ .services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; margin-top: 3rem; } .service-card { background: linear-gradient(145deg, var(--bg-surface) 0%, rgba(11, 17, 32, 0.4) 100%); border: 1px solid var(--border-color); padding: 2.5rem; border-radius: 20px; transition: var(--transition); text-align: left; position: relative; overflow: hidden; } .service-card::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: var(--emerald-main); transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease; } .service-card:hover { transform: translateY(-10px); box-shadow: 0 15px 30px rgba(0,0,0,0.2), 0 0 20px rgba(16,185,129,0.1); border-color: rgba(16, 185, 129, 0.3); } .service-card:hover::before { transform: scaleX(1); } .service-icon { width: 60px; height: 60px; border-radius: 12px; background: rgba(16,185,129,0.1); display: flex; align-items: center; justify-content: center; font-size: 1.8rem; color: var(--emerald-main); margin-bottom: 1.5rem; transition: var(--transition); } .service-card:hover .service-icon { background: var(--emerald-main); color: #fff; box-shadow: 0 5px 15px var(--emerald-glow); transform: rotate(-5deg); } .service-card h3 { font-family: var(--font-display); font-size: 1.4rem; color: var(--text-bright); margin-bottom: 1rem; } .service-card p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; } /* ========================================================================== VIDEO/VLOG SECTION ========================================================================== */ .video-container { background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: 20px; padding: 1.5rem; box-shadow: 0 10px 30px rgba(0,0,0,0.2); position: relative; } .video-wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; border-radius: 12px; } .video-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; } .video-label { position: absolute; top: 2.5rem; right: 2.5rem; background: rgba(220, 38, 38, 0.9); color: white; padding: 8px 16px; border-radius: 30px; font-weight: bold; font-size: 0.85rem; display: flex; align-items: center; gap: 8px; z-index: 10; backdrop-filter: blur(5px); pointer-events: none; } /* ========================================================================== SKILLS & TESTIMONIALS ========================================================================== */ .skills-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 1rem; } .skill-item { margin-bottom: 1.5rem; } .skill-info { display: flex; justify-content: space-between; margin-bottom: 0.5rem; font-weight: 600; font-size: 0.95rem; } .skill-bar-bg { width: 100%; height: 8px; background: var(--border-color); border-radius: 4px; overflow: hidden; } .skill-bar-fill { height: 100%; background: var(--emerald-main); width: 0; transition: width 1.5s cubic-bezier(0.4, 0, 0.2, 1); border-radius: 4px; box-shadow: 0 0 10px var(--emerald-glow); } .testimonials-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 2rem; margin-top: 1rem; } .testimonial-card { background: var(--bg-surface); border: 1px solid var(--border-color); padding: 2rem; border-radius: 16px; transition: var(--transition); position: relative; } .testimonial-card:hover { transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0,0,0,0.1); border-color: var(--emerald-main); } .testimonial-card i.fa-quote-left { font-size: 2rem; color: var(--emerald-glow); position: absolute; top: 1.5rem; right: 2rem; } .testimonial-text { font-style: italic; color: var(--text-muted); margin-bottom: 1.5rem; font-size: 1rem; line-height: 1.7; position: relative; z-index: 2; } .testimonial-author { display: flex; align-items: center; gap: 15px; } .testimonial-avatar { width: 50px; height: 50px; border-radius: 50%; object-fit: cover; border: 2px solid var(--emerald-main); } .author-info h4 { margin: 0; color: var(--text-bright); font-family: var(--font-display); font-size: 1.1rem; } .author-info p { margin: 0; font-size: 0.8rem; color: var(--emerald-main); } /* ========================================================================== PROJECT FILTERS & GRID ========================================================================== */ .filter-container { display: flex; gap: 10px; margin-bottom: 2rem; flex-wrap: wrap; } .filter-btn { background: var(--bg-surface); border: 1px solid var(--border-color); color: var(--text-muted); padding: 8px 20px; border-radius: 30px; cursor: pointer; font-family: var(--font-sans); font-weight: 600; font-size: 0.9rem; transition: var(--transition); } .filter-btn.active, .filter-btn:hover { background: var(--emerald-main); color: #fff; border-color: var(--emerald-main); box-shadow: 0 4px 15px var(--emerald-glow); transform: translateY(-2px); } .content-inner { padding: 4rem; max-width: 1600px; margin: 0 auto; width: 100%; flex-grow: 1; position: relative; z-index: 2; } .section-title { font-family: var(--font-display); font-size: 2.2rem; margin-bottom: 2.5rem; display: flex; align-items: center; gap: 15px; color: var(--text-bright); letter-spacing: -0.5px; } .section-title::after { content: ''; height: 2px; flex-grow: 1; background: linear-gradient(90deg, var(--emerald-main), transparent); opacity: 0.3; } .portfolio-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)); gap: 2.5rem; } .post-card { position: relative; height: 420px; border-radius: 16px; overflow: hidden; transition: var(--transition); box-shadow: 0 10px 30px rgba(0,0,0,0.1); border-left: 4px solid var(--emerald-main); background: var(--bg-surface); display: flex; flex-direction: column; justify-content: flex-end; } .post-card:hover { transform: translateY(-8px); box-shadow: 0 15px 35px rgba(0,0,0,0.2), 0 0 25px rgba(16, 185, 129, 0.1); } .post-thumb-wrap { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; } .post-thumb-wrap a { display: block; width: 100%; height: 100%; } .post-thumb-wrap::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to top, rgba(5, 8, 15, 0.95) 0%, rgba(5, 8, 15, 0.4) 50%, transparent 100%); z-index: 2; pointer-events: none; transition: var(--transition); } body.light-mode .post-thumb-wrap::after { background: linear-gradient(to top, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.6) 50%, transparent 100%); } .post-card:hover .post-thumb-wrap::after { background: linear-gradient(to top, rgba(5, 8, 15, 0.98) 0%, rgba(5, 8, 15, 0.6) 50%, rgba(5, 8, 15, 0.1) 100%); } body.light-mode .post-card:hover .post-thumb-wrap::after { background: linear-gradient(to top, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.8) 50%, rgba(255, 255, 255, 0.3) 100%); } .post-thumb-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1); } .post-card:hover .post-thumb-wrap img { transform: scale(1.1); } .post-category-badge { position: absolute; top: 20px; left: 20px; background: rgba(16, 185, 129, 0.9); color: #fff; padding: 6px 14px; border-radius: 30px; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; backdrop-filter: blur(4px); z-index: 4; } .post-info { position: relative; z-index: 3; padding: 2rem; display: flex; flex-direction: column; background: transparent; border: none; height: 100%; justify-content: flex-end; } .post-title { order: 1; font-family: var(--font-display); font-size: 1.4rem; margin-bottom: 10px; line-height: 1.3; letter-spacing: -0.5px; } .post-title a { color: #fff; text-shadow: 0 2px 5px rgba(0,0,0,0.8); transition: var(--transition); } body.light-mode .post-title a { color: #000; text-shadow: none; } .post-title a:hover { color: var(--emerald-main); } .post-snippet { order: 2; color: #e2e8f0; font-size: 0.95rem; margin-bottom: 1.5rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; line-height: 1.6; text-shadow: 0 1px 3px rgba(0,0,0,0.8); } body.light-mode .post-snippet { color: #334155; text-shadow: none; } .read-more-link { order: 3; display: inline-flex; align-items: center; gap: 8px; color: var(--emerald-main); font-weight: 600; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 1px; transition: var(--transition); } .read-more-link i { transition: transform 0.3s ease; } .post-card:hover .read-more-link { color: #fff; } body.light-mode .post-card:hover .read-more-link { color: #000; } .post-card:hover .read-more-link i { transform: translateX(6px); color: var(--emerald-main); } .post-meta { order: 4; display: flex; justify-content: flex-start; gap: 15px; font-size: 0.75rem; color: rgba(255, 255, 255, 0.6); margin-top: 15px; padding-top: 15px; border-top: 1px solid rgba(255, 255, 255, 0.1); font-weight: 500; text-transform: uppercase; letter-spacing: 1px; } body.light-mode .post-meta { color: rgba(0, 0, 0, 0.6); border-color: rgba(0, 0, 0, 0.1); } .post-meta span i { color: var(--emerald-main); margin-right: 5px; } /* ========================================================================== TIMELINE & EDUCATION ========================================================================== */ .timeline-container { position: relative; max-width: 800px; margin: 0 auto; padding: 20px 0; } .timeline-container::after { content: ''; position: absolute; width: 2px; background: var(--border-color); top: 0; bottom: 0; left: 20px; margin-left: -1px; } .timeline-item { padding: 10px 40px 40px; position: relative; background-color: inherit; width: 100%; } .timeline-dot { position: absolute; width: 16px; height: 16px; left: 12px; top: 15px; background: var(--emerald-main); border-radius: 50%; z-index: 1; box-shadow: 0 0 10px var(--emerald-glow); border: 3px solid var(--bg-surface); } .timeline-content { padding: 20px; background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: 12px; transition: var(--transition); } .timeline-content:hover { transform: translateY(-5px); border-color: var(--emerald-main); box-shadow: 0 10px 30px rgba(0,0,0,0.1); } .timeline-date { color: var(--emerald-main); font-weight: 600; font-size: 0.85rem; text-transform: uppercase; margin-bottom: 10px; display: block; } .timeline-content h3 { color: var(--text-bright); font-family: var(--font-display); margin-bottom: 10px; } .timeline-content p { color: var(--text-muted); font-size: 0.95rem; } .education-card { background: var(--bg-surface); border: 1px solid var(--border-color); padding: 2.5rem; border-radius: 16px; display: flex; gap: 25px; align-items: flex-start; transition: var(--transition); position: relative; overflow: hidden; } .education-card:hover { transform: translateY(-5px); border-color: var(--emerald-main); box-shadow: 0 10px 30px rgba(0,0,0,0.1); } .education-card::before { content: ''; position: absolute; left: 0; top: 0; width: 4px; height: 100%; background: var(--emerald-main); } .edu-icon { width: 70px; height: 70px; min-width: 70px; background: rgba(16, 185, 129, 0.1); border-radius: 16px; display: flex; align-items: center; justify-content: center; color: var(--emerald-main); font-size: 2rem; border: 1px solid var(--emerald-glow); transition: var(--transition); } .education-card:hover .edu-icon { background: var(--emerald-main); color: #fff; transform: rotate(10deg); box-shadow: 0 5px 15px var(--emerald-glow); } .edu-details h3 { font-family: var(--font-display); color: var(--text-bright); font-size: 1.4rem; margin-bottom: 5px; line-height: 1.3; } .edu-school { color: var(--emerald-main); font-weight: 600; font-size: 0.9rem; display: block; margin-bottom: 15px; letter-spacing: 0.5px; text-transform: uppercase; } .edu-details p { color: var(--text-muted); font-size: 1rem; margin: 0; line-height: 1.7; } /* ========================================================================== PREMIUM SINGLE POST / PAGE VIEW ========================================================================== */ .single-post-container { background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: 16px; padding: 3rem; } .single-header { margin-bottom: 2.5rem; border-bottom: 1px solid var(--border-color); padding-bottom: 2rem; text-align: left; } .single-category { display: inline-block; background: rgba(16, 185, 129, 0.1); color: var(--emerald-main); padding: 6px 14px; border-radius: 30px; font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 1rem; transition: var(--transition); border: 1px solid var(--emerald-glow); } .single-category:hover { background: var(--emerald-main); color: #fff; } .single-title { font-family: var(--font-display); font-size: 2.8rem; color: var(--text-bright); margin-bottom: 1.5rem; line-height: 1.2; letter-spacing: -0.5px; } .single-meta { display: flex; flex-wrap: wrap; gap: 20px; align-items: center; color: var(--text-muted); font-size: 0.95rem; font-weight: 500; } .single-meta .meta-item { display: flex; align-items: center; gap: 8px; } .single-meta .meta-item a { color: var(--text-muted); } .single-meta .meta-item a:hover { color: var(--emerald-main); } .meta-avatar { width: 35px; height: 35px; border-radius: 50%; object-fit: cover; border: 2px solid var(--emerald-main); padding: 2px; } .single-meta i { color: var(--emerald-main); } .single-body { font-size: 1.15rem; color: var(--text-muted); line-height: 1.8; } .single-body h2, .single-body h3 { font-family: var(--font-display); color: var(--text-bright); margin: 2.5rem 0 1rem; } .single-body img { max-width: 100%; height: auto; border-radius: 12px; margin: 2rem 0; border: 1px solid var(--border-color); box-shadow: 0 10px 30px rgba(0,0,0,0.2); } .single-body pre, .single-body code { background: var(--bg-body); padding: 1rem; border-radius: 8px; border: 1px solid var(--border-color); color: var(--emerald-main); overflow-x: auto; font-family: monospace; } pre[class*="language-"] { border-radius: 12px !important; border: 1px solid var(--border-color) !important; background: var(--bg-surface) !important; } .single-tags { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border-color); } .single-tags span { color: var(--text-bright); font-weight: 600; margin-right: 5px; } .single-tags i { color: var(--emerald-main); } .tag-link { background: var(--bg-body); border: 1px solid var(--border-color); color: var(--text-muted); padding: 6px 15px; border-radius: 8px; font-size: 0.9rem; transition: var(--transition); } .tag-link:hover { background: rgba(16, 185, 129, 0.1); color: var(--emerald-main); border-color: var(--emerald-main); transform: translateY(-2px); } .single-footer-share { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.5rem; margin-top: 2rem; background: rgba(16, 185, 129, 0.03); padding: 1.5rem 2rem; border-radius: 12px; border: 1px solid var(--border-color); } .single-footer-share h4 { margin: 0; font-family: var(--font-display); font-size: 1.2rem; color: var(--text-bright); display: flex; align-items: center; gap: 10px; } .single-footer-share h4 i { color: var(--emerald-main); } .share-buttons { display: flex; gap: 12px; } .share-btn { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; background: var(--bg-surface); border: 1px solid var(--border-color); color: var(--text-muted); font-size: 1.1rem; transition: var(--transition); } .share-btn:hover { background: var(--emerald-main); color: #fff; border-color: var(--emerald-main); transform: translateY(-4px) rotate(8deg); box-shadow: 0 5px 15px var(--emerald-glow); } .single-author-box { display: flex; align-items: center; gap: 1.5rem; margin-top: 2.5rem; padding: 2.5rem; background: var(--bg-body); border: 1px solid var(--border-color); border-radius: 16px; position: relative; overflow: hidden; } .single-author-box::before { content: ''; position: absolute; left: 0; top: 0; height: 100%; width: 4px; background: var(--emerald-main); } .author-box-img { width: 90px; height: 90px; min-width: 90px; border-radius: 50%; object-fit: cover; border: 2px solid var(--emerald-main); padding: 3px; } .author-box-info span { display: block; color: var(--emerald-main); font-size: 0.8rem; text-transform: uppercase; font-weight: 700; letter-spacing: 1px; margin-bottom: 5px; } .author-box-info h3 { margin: 0 0 10px 0; color: var(--text-bright); font-family: var(--font-display); font-size: 1.4rem; } .author-box-info p { margin: 0; color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; } .single-comments-wrapper { margin-top: 3rem; } .comments { margin: 0; } .comments h3.title { font-family: var(--font-display); font-size: 1.5rem; color: var(--text-bright); margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border-color); display: flex; align-items: center; gap: 10px; } .comments h3.title::before { content: '\f086'; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--emerald-main); } .comments .comment-block, .comments .comment-replybox-single { background: transparent !important; } .comments .comment-thread.inline-thread { background: rgba(16, 185, 129, 0.02) !important; border: 1px solid var(--border-color); border-radius: 12px; padding: 1.5rem; margin-top: 1rem; } body.light-mode .comments .comment-thread.inline-thread { background: rgba(0,0,0,0.02) !important; } @media (max-width: 768px) { .single-title { font-size: 2rem; } .single-meta { gap: 15px; } .single-footer-share { flex-direction: column; align-items: flex-start; } .single-author-box { flex-direction: column; text-align: center; } .single-author-box::before { width: 100%; height: 4px; top: 0; left: 0; } } /* ========================================================================== PREMIUM FOOTER ========================================================================== */ .site-footer { position: relative; margin-top: 5rem; background: linear-gradient(to bottom, var(--bg-surface), var(--bg-body)); border-top: 1px solid rgba(16, 185, 129, 0.1); overflow: hidden; } .footer-top-glow { position: absolute; top: 0; left: 0; width: 100%; height: 2px; background: linear-gradient(90deg, transparent, var(--emerald-main), transparent); opacity: 0.5; } .footer-inner { padding: 5rem 4rem; max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 3rem; position: relative; z-index: 2; } .footer-col h4 { font-family: var(--font-display); color: var(--text-bright); margin-bottom: 1.5rem; font-size: 1.1rem; position: relative; display: inline-block; } .footer-col h4::after { content: ''; position: absolute; bottom: -8px; left: 0; width: 30px; height: 2px; background: var(--emerald-main); border-radius: 2px; } .footer-brand h3 { font-family: var(--font-display); font-size: 1.8rem; color: var(--text-bright); margin-bottom: 1.2rem; display: flex; align-items: center; gap: 10px; } .footer-brand p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.7; max-width: 380px; margin-bottom: 1.5rem; } .availability-badge { display: inline-flex; align-items: center; gap: 10px; padding: 8px 16px; background: rgba(16, 185, 129, 0.05); border: 1px solid rgba(16, 185, 129, 0.2); border-radius: 30px; font-size: 0.85rem; color: var(--text-bright); font-weight: 500; } .pulse-dot { display: block; width: 8px; height: 8px; background: var(--emerald-main); border-radius: 50%; box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7); animation: pulseDot 2s infinite; } @keyframes pulseDot { 0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7); } 70% { transform: scale(1); box-shadow: 0 0 0 10px rgba(16, 185, 129, 0); } 100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(16, 185, 129, 0); } } .footer-links ul { display: flex; flex-direction: column; gap: 12px; } .footer-links a { color: var(--text-muted); font-size: 0.95rem; display: inline-flex; align-items: center; gap: 10px; transition: var(--transition); } .footer-links a i { font-size: 0.85rem; color: var(--emerald-main); transition: transform 0.3s ease; opacity: 0.7; } .footer-links a:hover { color: var(--text-bright); padding-left: 5px; } .footer-links a:hover i { transform: translateX(3px); opacity: 1; } .footer-social p { color: var(--text-muted); font-size: 0.9rem; margin-bottom: 1.5rem; line-height: 1.6; } .footer-social-icons { display: flex; gap: 12px; margin-bottom: 1.5rem; flex-wrap: wrap; } .footer-social-icons a { width: 42px; height: 42px; border-radius: 10px; background: rgba(255, 255, 255, 0.03); border: 1px solid var(--border-color); display: flex; align-items: center; justify-content: center; color: var(--text-muted); transition: var(--transition); font-size: 1.1rem; } body.light-mode .footer-social-icons a { background: rgba(0, 0, 0, 0.02); } .footer-social-icons a:hover { background: var(--emerald-main); color: #fff; border-color: var(--emerald-main); transform: translateY(-5px); box-shadow: 0 8px 20px rgba(16, 185, 129, 0.3); } .footer-mail-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 12px; background: transparent; border: 1px solid var(--emerald-main); color: var(--emerald-main); border-radius: 8px; font-weight: 600; font-size: 0.95rem; transition: var(--transition); } .footer-mail-btn:hover { background: var(--emerald-main); color: #fff; box-shadow: 0 5px 15px var(--emerald-glow); } .footer-bottom { border-top: 1px solid var(--border-color); background: rgba(0, 0, 0, 0.2); } body.light-mode .footer-bottom { background: rgba(0, 0, 0, 0.02); } .footer-bottom-content { max-width: 1400px; margin: 0 auto; padding: 1.5rem 4rem; display: flex; justify-content: space-between; align-items: center; color: var(--text-muted); font-size: 0.9rem; } .footer-made-with i { color: var(--emerald-main); margin: 0 4px; } /* ========================================================================== UTILITIES (CURSOR, PROGRESS, BACK TO TOP) ========================================================================== */ #back-to-top { position: fixed; bottom: 30px; right: 30px; width: 50px; height: 50px; background: var(--emerald-main); color: #fff; border-radius: 50%; border: none; font-size: 1.2rem; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 15px var(--emerald-glow); opacity: 0; visibility: hidden; transform: translateY(20px); transition: var(--transition); z-index: 99; } #back-to-top.show { opacity: 1; visibility: visible; transform: translateY(0); } #back-to-top:hover { background: var(--text-bright); color: var(--emerald-main); transform: translateY(-5px); } .progress-container { position: fixed; top: 0; z-index: 9999; width: 100%; height: 4px; background: transparent; } .progress-bar { height: 4px; background: var(--emerald-main); width: 0%; box-shadow: 0 0 10px var(--emerald-glow); } @media (min-width: 1025px) { body, a, button, .filter-btn { cursor: none; } .cursor-dot, .cursor-outline { opacity: 0; position: fixed; top: 0; left: 0; transform: translate(-50%, -50%); border-radius: 50%; z-index: 10000; pointer-events: none; transition: opacity 0.3s ease, width 0.2s, height 0.2s, background-color 0.2s; } .cursor-dot { width: 8px; height: 8px; background-color: var(--emerald-main); } .cursor-outline { width: 40px; height: 40px; border: 2px solid rgba(16, 185, 129, 0.5); } a:hover ~ .cursor-outline, button:hover ~ .cursor-outline { width: 60px; height: 60px; background-color: rgba(16, 185, 129, 0.1); } } /* ========================================================================== RESPONSIVE DESIGN ========================================================================== */ @media (max-width: 1300px) { .hero-name { font-size: 4rem; } .hero-roles { font-size: 1.6rem; } .hero-image-column { flex: 0 0 360px; } .hero-image-frame { height: 420px; } } @media (max-width: 1024px) { .sidebar-cv { transform: translateX(-100%); } .sidebar-cv.active { transform: translateX(0); box-shadow: 10px 0 30px rgba(0,0,0,0.5); } .main-content { margin-left: 0; width: 100%; } .mobile-header { display: flex; } .hero-section { padding: 4rem 2rem; } .hero-content-wrapper { flex-direction: column-reverse; text-align: center; gap: 3rem; } .hero-text-column { display: flex; flex-direction: column; align-items: center; } .hero-socials, .hero-buttons, .hero-skills { justify-content: center; } .page-header { padding: 2rem 2rem 0; } .content-inner { padding: 2rem; } .skills-grid { grid-template-columns: 1fr; } .footer-inner { grid-template-columns: 1fr 1fr; padding: 4rem 2rem; } .footer-bottom-content { flex-direction: column; gap: 10px; text-align: center; padding: 1.5rem 2rem; } } @media (max-width: 768px) { .portfolio-grid { grid-template-columns: 1fr; } .hero-name { font-size: 3.2rem; } .hero-buttons { flex-direction: column; gap: 10px; width: 100%; max-width: 300px; } .btn-primary, .btn-secondary { justify-content: center; width: 100%; } .hero-skills { flex-wrap: wrap; } .project-stat { padding: 6px 12px; font-size: 0.85rem; } .hero-image-column { flex: 0 0 300px; width: 100%; } .hero-image-frame { height: 350px; } .single-post-container { padding: 1.5rem; } .single-title, .page-header h1 { font-size: 2rem; } .footer-inner { grid-template-columns: 1fr; gap: 2.5rem; } .footer-brand p { max-width: 100%; } .education-card { flex-direction: column; gap: 15px; padding: 1.5rem; } .edu-icon { width: 50px; height: 50px; min-width: 50px; font-size: 1.5rem; } }
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg-body);color:var(--text-bright);font-family:var(--font-sans);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .5s,color .5s}
a{text-decoration:none;color:var(--emerald);transition:color var(--t) var(--ease)}
a:hover{color:var(--emerald-2)}
ul{list-style:none}
img{display:block;max-width:100%}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-body)}
::-webkit-scrollbar-thumb{background:var(--emerald-dark);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--emerald)}

/* ANIMATED BG GRID */
body::before{
    content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
    background-image:linear-gradient(rgba(16,185,129,0.03) 1px,transparent 1px),
                     linear-gradient(90deg,rgba(16,185,129,0.03) 1px,transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 40%,transparent 100%);
}

/* PAGE LOADER */
#page-loader{position:fixed;inset:0;background:var(--bg-body);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;transition:opacity .6s,visibility .6s}
.loader-logo{font-family:var(--font-head);font-size:2rem;font-weight:800;background:linear-gradient(135deg,#fff,var(--emerald));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:loaderPulse 1.5s ease-in-out infinite}
@keyframes loaderPulse{0%,100%{opacity:.6}50%{opacity:1}}
.spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--emerald);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{100%{transform:rotate(360deg)}}

/* PROGRESS BAR */
.progress-container{position:fixed;top:0;left:0;width:100%;height:3px;z-index:9998;background:transparent}
.progress-bar{height:3px;background:linear-gradient(90deg,var(--emerald),var(--cyan));width:0%;box-shadow:0 0 12px var(--emerald-glow)}

/* CURSOR */
@media(min-width:1025px){
    /* Keep native cursor but show custom accent cursor for better visibility */
    .cursor-dot,.cursor-outline{position:fixed;top:0;left:0;transform:translate(-50%,-50%);border-radius:50%;z-index:10000;pointer-events:none;opacity:0;transition:opacity .15s,transform .08s}
    .cursor-dot{width:10px;height:10px;background:var(--emerald);box-shadow:0 0 18px var(--emerald-glow);border:2px solid rgba(255,255,255,0.06)}
    .cursor-outline{width:48px;height:48px;border:2px solid rgba(16,185,129,0.6);background:transparent;box-shadow:0 8px 30px rgba(16,185,129,0.08);transition:width .12s,height .12s,background .12s}
}

/* Hide custom cursor on touch devices to avoid overlay issues */
@media(max-width:1024px){
    .cursor-dot,.cursor-outline{display:none}
}

/* LAYOUT */
.app-container{display:flex;min-height:100vh;position:relative;z-index:1}

/* ── SIDEBAR ── */
.sidebar-cv{
    width:var(--sidebar-w);min-width:var(--sidebar-w);
    background:rgba(3,7,18,0.75);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-right:1px solid rgba(255,255,255,0.05);
    position:fixed;height:100vh;left:0;top:0;
    display:flex;flex-direction:column;z-index:100;
    transition:transform .4s cubic-bezier(0.4,0,0.2,1);
    box-shadow:5px 0 30px rgba(0,0,0,0.5);
    overflow-y:auto;
    scrollbar-width:none; /* Firefox */
}
.sidebar-cv::-webkit-scrollbar { display:none; /* Chrome/Safari */ }
body.light-mode .sidebar-cv{
    background:rgba(255,255,255,0.85);
    border-right:1px solid rgba(0,0,0,0.05);
    box-shadow:5px 0 30px rgba(0,0,0,0.05);
}
.sidebar-cv::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--emerald),transparent);
    opacity:.5;
}

.profile-header {
    position:relative;width:100%;height:260px;overflow:hidden;flex-shrink:0;
}
.profile-img-wrapper {
    position:absolute;inset:0;width:100%;height:100%;
}
.profile-header-bg {
    width:100%;height:100%;object-fit:cover;object-position:center 30%;
    transition:transform .9s ease;
}
.sidebar-cv:hover .profile-header-bg{transform:scale(1.06)}

.profile-overlay {
    position:absolute;bottom:0;left:0;right:0;padding:2.5rem 1.5rem 1.5rem;
    background:linear-gradient(to top, rgba(3,7,18,1) 0%, rgba(3,7,18,0.8) 40%, transparent 100%);
    display:flex;flex-direction:column;align-items:center;z-index:2;
}
body.light-mode .profile-overlay{background:linear-gradient(to top, rgba(255,255,255,1) 0%, rgba(255,255,255,0.8) 40%, transparent 100%);}

.profile-name{font-family:var(--font-head);font-size:1.6rem;font-weight:800;color:var(--text-bright);line-height:1.1;margin-bottom:.5rem;}
.profile-role{font-size:.72rem;color:var(--text-soft);font-weight:600;text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;}

.sidebar-status-badge {
    display:inline-flex;align-items:center;gap:6px;
    padding:4px 12px;background:rgba(16,185,129,0.1);
    border:1px solid rgba(16,185,129,0.2);border-radius:20px;
    font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;
}
.pulse-dot {width:6px;height:6px;border-radius:50%;animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{opacity:.6}50%{opacity:1}}

.nav-menu{padding:1.5rem 0;flex:1}
.nav-menu li a{
    display:flex;align-items:center;gap:14px;padding:12px 1.5rem;margin:4px 1.2rem;
    border-radius:12px;color:var(--text-muted);font-weight:600;font-size:0.92rem;
    transition:all 0.3s cubic-bezier(0.4,0,0.2,1);position:relative;overflow:hidden;
}
.nav-menu li a::before{
    content:'';position:absolute;left:0;top:0;width:100%;height:100%;
    background:linear-gradient(90deg, rgba(16,185,129,0.1) 0%, transparent 100%);
    opacity:0;transition:opacity 0.3s ease;z-index:0;
}
.nav-menu li a::after{
    content:'';position:absolute;left:0;top:10%;height:80%;width:4px;
    background:var(--emerald);border-radius:4px;
    box-shadow:0 0 10px var(--emerald);
    transform:scaleY(0);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);
}
.nav-menu li a i{font-size:1.1rem;opacity:0.6;transition:all 0.3s ease;width:22px;text-align:center;position:relative;z-index:1;}
.nav-menu li a span.link-text { position:relative;z-index:1; }

.nav-menu li a:hover, .nav-menu li a.active{
    color:var(--text-bright);
    background:rgba(255,255,255,0.03);
    transform:translateX(5px);
}
.nav-menu li a:hover::before, .nav-menu li a.active::before{opacity:1;}
.nav-menu li a:hover::after, .nav-menu li a.active::after{transform:scaleY(1);}
.nav-menu li a:hover i, .nav-menu li a.active i{
    opacity:1;color:var(--emerald);
    filter:drop-shadow(0 0 8px rgba(16,185,129,0.6));
}

.sidebar-footer{padding:1.5rem;display:flex;flex-direction:column;gap:12px;border-top:1px solid rgba(255,255,255,0.05)}
body.light-mode .sidebar-footer{border-top:1px solid rgba(0,0,0,0.05)}
.sidebar-btn{
    display:flex;align-items:center;justify-content:center;gap:8px;
    padding:14px;border-radius:12px;font-weight:600;font-size:.9rem;
    border:1px solid rgba(16,185,129,0.3);color:var(--emerald);
    background:rgba(16,185,129,.05);cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
    position:relative;overflow:hidden;
}
.sidebar-btn::before {
    content:'';position:absolute;inset:0;background:var(--emerald);opacity:0;transition:opacity 0.3s ease;z-index:0;
}
.sidebar-btn i, .sidebar-btn span { position:relative;z-index:1;transition:color 0.3s ease; }
.sidebar-btn:hover::before { opacity:1; }
.sidebar-btn:hover i, .sidebar-btn:hover span, .sidebar-btn:hover { color:#000;border-color:var(--emerald);box-shadow:0 0 20px rgba(16,185,129,0.4);transform:translateY(-2px); }
.sidebar-btn-cv { background: linear-gradient(135deg, rgba(16,185,129,.15), rgba(16,185,129,.06)); border-color: rgba(16,185,129,0.4); font-weight: 700; }
.sidebar-btn-cv:hover { background: linear-gradient(135deg, var(--emerald), var(--emerald-dark)) !important; color: #fff !important; }
.sidebar-btn-cv:hover i, .sidebar-btn-cv:hover span { color: #fff !important; }

/* ── MAIN CONTENT ── */
.main-content{flex:1;margin-left:var(--sidebar-w);width:calc(100% - var(--sidebar-w));display:flex;flex-direction:column;min-height:100vh;position:relative}

.mobile-header{display:none;height:65px;background:rgba(3,7,18,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,0.05);padding:0 1.5rem;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:90}
body.light-mode .mobile-header{background:rgba(255,255,255,0.85);border-bottom:1px solid rgba(0,0,0,0.05);}
.mobile-header .profile-name{font-size:1.2rem;margin:0;font-weight:800;background:linear-gradient(90deg,#fff,var(--emerald));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
body.light-mode .mobile-header .profile-name{background:linear-gradient(90deg,#111,var(--emerald));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.header-icons{display:flex;gap:20px;align-items:center}
.mobile-toggle,.mobile-theme-toggle{font-size:1.4rem;color:var(--text-bright);cursor:pointer;transition:color .3s ease}
.mobile-toggle:hover,.mobile-theme-toggle:hover{color:var(--emerald);text-shadow:0 0 10px rgba(16,185,129,0.5);}

/* ── HERO ── */
.hero-section{
    position:relative;padding:5rem 4rem 6rem;
    overflow:hidden;display:flex;align-items:center;min-height:92vh;
    background:
        radial-gradient(ellipse 80% 50% at 60% 50%, rgba(16,185,129,.06) 0%, transparent 55%),
        radial-gradient(ellipse 50% 80% at 20% 20%, rgba(6,182,212,.04) 0%, transparent 50%),
        var(--bg-body);
    border-bottom:1px solid var(--border);
}
.hero-section::before{
    content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
    background-image:linear-gradient(rgba(16,185,129,0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(16,185,129,0.02) 1px, transparent 1px);
    background-size:64px 64px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, #000 20%, transparent 70%);
}
#particles-js{position:absolute;inset:0;z-index:1}
.hero-content-wrapper{position:relative;z-index:2;width:100%;max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:5rem}
.hero-text-column{flex:1;max-width:700px}

.hero-greeting{
    display:inline-flex;align-items:center;gap:10px;
    background:rgba(16,185,129,.07);border:1px solid var(--border-em);
    color:var(--emerald);padding:7px 18px;border-radius:40px;
    font-size:.82rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
    margin-bottom:1.5rem;backdrop-filter:blur(6px);
}
.hero-greeting .pulse-dot{display:inline-block;position:static}

.hero-name{
    font-family:var(--font-head);font-size:5.5rem;font-weight:800;
    line-height:1.05;letter-spacing:-3px;margin-bottom:.4rem;
    background:linear-gradient(120deg,var(--text-bright) 20%,var(--emerald) 55%,var(--cyan) 80%);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    animation:shimmer 4s linear infinite;background-size:200% auto;
}
@keyframes shimmer{0%{background-position:0% center}100%{background-position:200% center}}

.hero-roles{font-family:var(--font-head);font-size:1.9rem;color:var(--text-muted);margin-bottom:1.5rem;font-weight:300;min-height:2.5rem}
.hero-roles .typed-text{color:var(--emerald);font-weight:700}
.hero-roles .cursor{display:inline-block;width:2px;height:1.5rem;background:var(--emerald);margin-left:3px;vertical-align:middle;animation:blink 1s infinite}
.hero-roles .cursor.typing{animation:none}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}

.hero-bio{font-size:1.05rem;color:var(--text-soft);line-height:1.85;margin-bottom:1.75rem;max-width:95%}

/* ==========================
   Premium Login Page Styles
   ========================== */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:4rem 1.5rem;background:radial-gradient(circle at 10% 10%, rgba(16,185,129,0.02), transparent 20%), var(--bg-body);}
.login-box{display:flex;gap:2rem;max-width:960px;width:100%;align-items:stretch}
.login-box{margin:0 auto}
.login-panel{flex:1;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-card);display:flex;flex-direction:column}
.login-left{background:linear-gradient(180deg, rgba(7,10,18,0.6), rgba(7,10,18,0.45)); padding:2.5rem; color:var(--text-bright); min-width:360px; display:flex; flex-direction:column; justify-content:center; gap:1rem}
.login-left h1{font-family:var(--font-head);font-size:2rem;margin:0 0 0.25rem}
.login-left p{color:var(--text-soft);max-width:360px}
.login-right{background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,0.95)); color:#06202b; padding:2rem; min-width:320px}
.login-right .form-group{margin-bottom:1rem}
.login-right label{display:block;font-weight:700;margin-bottom:6px;color:rgba(0,0,0,0.65)}
.form-control{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(2,6,23,0.06);box-shadow:0 6px 20px rgba(2,6,23,0.04);font-size:1rem}
.btn-primary{background:linear-gradient(90deg,var(--emerald),var(--emerald-2));color:#fff;border:none;padding:12px 18px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-weight:800}
.alert{padding:10px 12px;border-radius:10px;background:rgba(255,230,230,0.04);color:#ffdddd;border:1px solid rgba(255,0,0,0.08);margin-bottom:1rem}

/* compact footer for login page */
.site-footer-mini{max-width:960px;margin:2.5rem auto 0;padding:1.5rem 1.5rem;color:var(--text-muted);display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,0.03);gap:1rem}
.site-footer-mini .left{display:flex;align-items:center;gap:12px}
.site-footer-mini .left .brand{font-weight:800;color:var(--text-bright)}
.site-footer-mini .right{color:var(--text-soft)}

@media (max-width:900px){
    .login-box{flex-direction:column;gap:1.25rem}
    .login-left{order:2;padding:1.5rem}
    .login-right{order:1;padding:1.25rem}
    .login-left, .login-right{min-width:100%;border-radius:12px}
    .site-footer-mini{flex-direction:column;gap:8px;text-align:center}
}

/* ==========================
   Footer: Mobile Improvements
   ========================== */
.footer-bottom { gap:1rem; }
.footer-theme-btn, .footer-login-link {
    border:1px solid rgba(255,255,255,0.06);
    background:transparent;
    color:var(--text-muted);
    padding:10px 12px;
    border-radius:12px;
    display:inline-flex;
    gap:10px;
    align-items:center;
    font-weight:700;
    font-size:0.95rem;
    transition:all .25s var(--ease);
}
.footer-theme-btn i{ font-size:1rem; color:var(--text-bright); }
.footer-theme-btn:hover, .footer-login-link:hover{ transform:translateY(-4px); box-shadow:0 8px 20px rgba(16,185,129,0.08); color:var(--text-bright); border-color:var(--border-em); }
.footer-login-link{ text-align:center; }

@media (max-width: 900px) {
    .footer-bottom{ flex-direction:column; text-align:center; align-items:center; gap:1rem; }
    .footer-bottom > div{ width:100%; display:flex; justify-content:center; gap:12px; flex-wrap:wrap; align-items:center; }
    .footer-theme-btn, .footer-login-link{ width:46%; max-width:240px; padding:12px 16px; }
    .footer-bottom p { width:100%; order:3; margin-top:6px; }
    .footer-bottom .crafted { order:2; }
}

.hero-socials{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:2rem}
.hero-social-btn{
    width:40px;height:40px;border-radius:50%;background:var(--bg-card);
    border:1px solid var(--border);display:flex;align-items:center;justify-content:center;
    color:var(--text-soft);font-size:1rem;transition:all .3s var(--ease);
}
.hero-social-btn:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);transform:translateY(-5px) rotate(10deg);box-shadow:0 8px 20px var(--emerald-glow)}

.hero-buttons{display:flex;gap:14px;margin-bottom:2.5rem;flex-wrap:wrap}
.btn-primary{
    padding:13px 32px;border-radius:10px;font-weight:700;font-size:.95rem;
    display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none;
    background:linear-gradient(135deg,var(--emerald),var(--emerald-dark));
    color:#fff;box-shadow:0 4px 20px var(--emerald-glow);
    transition:all .3s var(--ease);position:relative;overflow:hidden;
}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:opacity .3s}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px var(--emerald-glow);color:#fff}
.btn-primary:hover::after{opacity:1}
.btn-secondary{
    padding:13px 32px;border-radius:10px;font-weight:600;font-size:.95rem;
    display:inline-flex;align-items:center;gap:10px;cursor:pointer;
    background:transparent;color:var(--text-bright);border:1px solid var(--border);
    backdrop-filter:blur(6px);transition:all .3s var(--ease);
}
.btn-secondary:hover{border-color:var(--emerald);color:var(--emerald);background:rgba(16,185,129,.07);transform:translateY(-3px)}

.hero-stats{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.stat-chip{
    display:inline-flex;align-items:center;gap:7px;
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    padding:6px 14px;border-radius:30px;font-size:.82rem;color:var(--text-soft);
    transition:all .3s;
}
.stat-chip i{color:var(--emerald);font-size:.9rem}
.stat-chip:hover{border-color:var(--emerald);color:var(--text-bright);background:rgba(16,185,129,.08);transform:translateY(-2px)}
.stat-chip.counter-chip .count{font-weight:800;color:var(--emerald);font-size:1rem}

/* HERO IMAGE / SLIDER */
.hero-image-column{flex:0 0 430px;position:relative;display:flex;flex-direction:column;gap:1rem}
.hero-image-frame{
    width:100%;height:480px;border-radius:24px;overflow:hidden;position:relative;
    border:1px solid var(--border-em);
    box-shadow:0 0 60px rgba(16,185,129,.12),0 30px 60px rgba(0,0,0,.4);
    background:var(--bg-card);
}
.hero-image-frame::before{
    content:'';position:absolute;inset:0;z-index:6;border-radius:24px;
    background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,transparent 50%);
    pointer-events:none;
}
.slide-wrapper{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1.4s ease-in-out,visibility 1.4s;z-index:1}
.slide-wrapper.active{opacity:1;visibility:visible;z-index:5}
.slide-wrapper img{width:100%;height:100%;object-fit:cover}
.slide-wrapper.active img{animation:kenBurns 7s ease-out forwards}
@keyframes kenBurns{0%{transform:scale(1)}100%{transform:scale(1.12)}}
.slide-caption{
    position:absolute;bottom:1.2rem;left:1.2rem;right:1.2rem;
    background:rgba(3,7,18,.82);backdrop-filter:blur(12px);
    padding:14px 16px;border-radius:14px;border-left:3px solid var(--emerald);
    z-index:10;transform:translateY(10px);opacity:0;transition:all .5s ease .2s;
}
.slide-wrapper.active .slide-caption{transform:translateY(0);opacity:1}
.slide-caption p{font-size:.7rem;color:var(--emerald);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:4px}
.slide-caption h4{font-family:var(--font-head);color:#fff;font-size:1.05rem;line-height:1.3}
.slide-caption h4 a{color:inherit}
.slide-caption h4 a:hover{color:var(--emerald)}

/* Slider nav dots */
.slider-dots{display:flex;gap:6px;justify-content:center}
.slider-dot{width:6px;height:6px;border-radius:3px;background:var(--border);cursor:pointer;transition:all .3s}
.slider-dot.active{width:22px;background:var(--emerald);box-shadow:0 0 8px var(--emerald)}

/* TECH MARQUEE */
.tech-marquee-wrapper{
    position:relative;overflow:hidden;padding:1.2rem 0;
    background:linear-gradient(180deg,var(--bg-surface),rgba(10,15,30,.8));
    border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.tech-marquee-wrapper::before,.tech-marquee-wrapper::after{
    content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.tech-marquee-wrapper::before{left:0;background:linear-gradient(90deg,var(--bg-body),transparent)}
.tech-marquee-wrapper::after{right:0;background:linear-gradient(-90deg,var(--bg-body),transparent)}
.tech-marquee{display:flex;width:max-content;animation:scrollMarquee 28s linear infinite;white-space:nowrap;align-items:center}
.tech-marquee-wrapper:hover .tech-marquee{animation-play-state:paused}
.tech-item{
    display:inline-flex;align-items:center;gap:10px;margin:0 2.5rem;
    font-family:var(--font-head);font-weight:600;color:var(--text-muted);font-size:1rem;
    transition:color .3s;flex-shrink:0;cursor:default;
}
.tech-item i{font-size:1.4rem;color:var(--emerald);transition:transform .3s}
.tech-item:hover{color:var(--text-bright)}
.tech-item:hover i{transform:scale(1.3) rotate(-10deg);color:var(--emerald-2)}
@keyframes scrollMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* SECTIONS */
.content-inner{padding:4rem;max-width:1600px;margin:0 auto;width:100%;position:relative;z-index:2}
.page-header{padding:4rem 4rem 0;max-width:1600px;margin:0 auto;width:100%}
.page-header h1{font-family:var(--font-head);font-size:3rem;color:var(--emerald);margin-bottom:.5rem;line-height:1.1}
.page-header p{color:var(--text-soft);font-size:1.1rem}

.section-title{
    font-family:var(--font-head);font-size:2rem;margin-bottom:2.5rem;
    display:flex;align-items:center;gap:14px;color:var(--text-bright);
    letter-spacing:-.6px;
}
.section-title i{color:var(--emerald);font-size:1.6rem}
.section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border-em),transparent)}

/* FILTER BUTTONS */
.filter-container{display:flex;gap:8px;margin-bottom:2rem;flex-wrap:wrap}
.filter-btn{
    background:var(--bg-card);border:1px solid var(--border);
    color:var(--text-muted);padding:7px 18px;border-radius:30px;cursor:pointer;
    font-family:var(--font-sans);font-weight:600;font-size:.83rem;
    transition:all .3s var(--ease);
}
.filter-btn.active,.filter-btn:hover{
    background:var(--emerald);color:#fff;border-color:var(--emerald);
    box-shadow:0 4px 16px var(--emerald-glow);transform:translateY(-2px);
}

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

.post-card{
    position:relative;height:400px;border-radius:var(--radius-lg);overflow:hidden;
    transition:all .4s var(--ease);
    background:var(--bg-card);display:flex;flex-direction:column;justify-content:flex-end;
    border:1px solid var(--border);
    box-shadow:0 8px 24px rgba(0,0,0,0.15);
}
.post-card::after{
    content:'';position:absolute;inset:0;border-radius:18px;
    background:linear-gradient(to top,rgba(3,7,18,.97) 0%,rgba(3,7,18,.4) 55%,rgba(3,7,18,.05) 100%);
    z-index:2;pointer-events:none;transition:background .4s;
}
.post-card:hover{transform:translateY(-10px);border-color:var(--border-em);box-shadow:0 25px 50px -10px rgba(0,0,0,.5),0 0 30px rgba(16,185,129,.08)}
.post-card:hover::after{background:linear-gradient(to top,rgba(3,7,18,.98) 0%,rgba(3,7,18,.5) 50%,rgba(3,7,18,.1) 100%)}
body.light-mode .post-card::after{background:linear-gradient(to top,rgba(255,255,255,.97) 0%,rgba(255,255,255,.5) 55%,rgba(255,255,255,.05) 100%)}

.post-thumb-wrap{position:absolute;inset:0;z-index:1}
.post-thumb-wrap a{display:block;width:100%;height:100%}
.post-thumb-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.post-card:hover .post-thumb-wrap img{transform:scale(1.08)}
.post-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-surface),var(--bg-body));font-size:3.5rem;color:var(--emerald)}

.post-category-badge{
    position:absolute;top:16px;left:16px;z-index:4;
    background:linear-gradient(135deg,var(--emerald),var(--emerald-dark));color:#fff;
    padding:5px 13px;border-radius:30px;font-size:.7rem;font-weight:800;
    text-transform:uppercase;letter-spacing:1.2px;backdrop-filter:blur(4px);
    box-shadow:0 4px 12px var(--emerald-glow);
}

.post-info{position:relative;z-index:3;padding:1.4rem 1.6rem;display:flex;flex-direction:column;justify-content:flex-end;height:100%}
.post-title{font-family:var(--font-head);font-size:1.25rem;margin-bottom:8px;line-height:1.3;letter-spacing:-.3px}
.post-title a{color:#fff;transition:color .3s}
body.light-mode .post-title a{color:var(--text-bright)}
.post-title a:hover{color:var(--emerald-2)}
.post-snippet{color:rgba(255,255,255,.65);font-size:.88rem;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.6}
body.light-mode .post-snippet{color:var(--text-soft)}
.read-more-link{display:inline-flex;align-items:center;gap:7px;color:var(--emerald);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:1.2px}
.read-more-link i{transition:transform .3s}
.post-card:hover .read-more-link i{transform:translateX(6px)}
.post-meta{display:flex;gap:14px;font-size:.72rem;color:rgba(255,255,255,.45);margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.8px}
body.light-mode .post-meta{color:var(--text-muted);border-color:var(--border)}
.post-meta i{color:var(--emerald);margin-right:4px}

/* SINGLE POST */
.single-post-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:3rem}
.single-header{margin-bottom:2.5rem;border-bottom:1px solid var(--border);padding-bottom:2rem}
.single-category{display:inline-flex;align-items:center;gap:6px;background:rgba(16,185,129,.1);color:var(--emerald);padding:6px 14px;border-radius:30px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:1rem;border:1px solid var(--border-em);transition:all .3s}
.single-category:hover{background:var(--emerald);color:#fff}
.single-title{font-family:var(--font-head);font-size:2.6rem;color:var(--text-bright);margin-bottom:1.5rem;line-height:1.2;letter-spacing:-.5px}
.single-meta{display:flex;flex-wrap:wrap;gap:18px;color:var(--text-soft);font-size:.9rem;font-weight:500}
.meta-item{display:flex;align-items:center;gap:8px}
.meta-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid var(--emerald)}
.single-meta i{color:var(--emerald)}
.single-body{font-size:1.05rem;color:var(--text-soft);line-height:1.9}
.single-body h2,.single-body h3{font-family:var(--font-head);color:var(--text-bright);margin:2.5rem 0 1rem}
.single-body img{max-width:100%;border-radius:12px;margin:2rem 0;border:1px solid var(--border)}
.single-body p{margin-bottom:1.2rem}
.single-body ul,.single-body ol{padding-left:1.5rem;margin-bottom:1.2rem}
.single-body li{margin-bottom:.5rem;list-style:disc}
.single-body ol li{list-style:decimal}
.single-body code{background:var(--bg-body);padding:2px 7px;border-radius:4px;color:var(--emerald);font-family:monospace;font-size:.9em;border:1px solid var(--border)}
.single-body pre{background:var(--bg-body);padding:1.5rem;border-radius:10px;border:1px solid var(--border);overflow-x:auto;margin-bottom:1.2rem}
.single-tags{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.tag-link{background:var(--bg-body);border:1px solid var(--border);color:var(--text-soft);padding:5px 14px;border-radius:8px;font-size:.85rem;transition:all .3s}
.tag-link:hover{border-color:var(--emerald);color:var(--emerald);background:rgba(16,185,129,.07);transform:translateY(-2px)}
.single-footer-share{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-top:2rem;background:rgba(16,185,129,.04);padding:1.4rem 1.8rem;border-radius:14px;border:1px solid var(--border-em)}
.single-footer-share h4{margin:0;font-family:var(--font-head);display:flex;align-items:center;gap:10px;color:var(--text-bright)}
.single-footer-share h4 i{color:var(--emerald)}
.share-buttons{display:flex;gap:10px}
.share-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);font-size:1rem;transition:all .3s}
.share-btn:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);transform:translateY(-4px) rotate(10deg);box-shadow:0 6px 16px var(--emerald-glow)}
.single-author-box{display:flex;align-items:center;gap:1.5rem;margin-top:2.5rem;padding:2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;position:relative;overflow:hidden}
.single-author-box::before{content:'';position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(180deg,var(--emerald),var(--cyan))}
.author-box-img{width:80px;height:80px;min-width:80px;border-radius:50%;object-fit:cover;border:2px solid var(--emerald);padding:2px}
.author-box-info span{display:block;color:var(--emerald);font-size:.72rem;text-transform:uppercase;font-weight:800;letter-spacing:1.5px;margin-bottom:4px}
.author-box-info h3{margin:0 0 8px;color:var(--text-bright);font-family:var(--font-head);font-size:1.3rem}
.author-box-info p{margin:0;color:var(--text-soft);font-size:.9rem;line-height:1.6}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.service-card{
    background:var(--bg-card);border:1px solid var(--border);
    padding:2rem;border-radius:var(--radius-lg);transition:all .4s var(--ease);
    position:relative;overflow:hidden;
    box-shadow:0 4px 20px rgba(0,0,0,0.12);
}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--emerald),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.service-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(16,185,129,.06),transparent 60%);opacity:0;transition:opacity .4s}
.service-card:hover{transform:translateY(-8px);border-color:var(--border-em);box-shadow:var(--shadow-card), var(--shadow-glow)}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover::after{opacity:1}
.service-icon{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg, rgba(16,185,129,.12), rgba(6,182,212,.06));display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--emerald);margin-bottom:1.25rem;transition:all .4s var(--ease);border:1px solid var(--border-em);box-shadow:0 0 0 0 rgba(16,185,129,.2)}
.service-card:hover .service-icon{background:linear-gradient(135deg,var(--emerald),var(--emerald-dark));color:#fff;box-shadow:0 8px 24px var(--emerald-glow);transform:rotate(-5deg) scale(1.05);border-color:transparent}
.service-card h3{font-family:var(--font-head);font-size:1.25rem;color:var(--text-bright);margin-bottom:.75rem}
.service-card p{color:var(--text-soft);font-size:.9rem;line-height:1.7}

/* VIDEO */
.video-container{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem;position:relative;box-shadow:0 20px 40px rgba(0,0,0,.3)}
.video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:12px;border:1px solid var(--border)}
.video-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-label{position:absolute;top:2rem;right:2rem;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;padding:7px 16px;border-radius:30px;font-weight:800;font-size:.78rem;display:flex;align-items:center;gap:7px;z-index:10;box-shadow:0 4px 12px rgba(220,38,38,.4)}

/* SKILLS */
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 3rem}
.skill-item{margin-bottom:.75rem}
.skill-info{display:flex;justify-content:space-between;margin-bottom:.6rem;font-weight:600;font-size:.88rem;color:var(--text-soft)}
.skill-info span:last-child{color:var(--emerald);font-weight:700}
.skill-bar-bg{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden;position:relative}
.skill-bar-fill{height:100%;background:linear-gradient(90deg,var(--emerald),var(--cyan));width:0;transition:width 1.6s cubic-bezier(.4,0,.2,1);border-radius:3px;box-shadow:0 0 12px var(--emerald-glow)}

/* COUNTER STATS STRIP — Professional CV-style */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:3rem}
.stats-strip-item{
    background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);
    padding:2rem 1.5rem;text-align:center;position:relative;overflow:hidden;transition:all .4s var(--ease);
    box-shadow:0 4px 20px rgba(0,0,0,0.15);
}
.stats-strip-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center top,rgba(16,185,129,.1),transparent 65%);opacity:0;transition:opacity .4s}
.stats-strip-item:hover{border-color:var(--border-em);transform:translateY(-6px);box-shadow:var(--shadow-card), var(--shadow-glow)}
.stats-strip-item:hover::before{opacity:1}
.stats-strip-item .stats-icon-wrap{
    width:52px;height:52px;margin:0 auto 1rem;border-radius:50%;
    background:linear-gradient(135deg, rgba(16,185,129,.15), rgba(6,182,212,.08));
    border:1px solid var(--border-em);display:flex;align-items:center;justify-content:center;
    color:var(--emerald);font-size:1.35rem;transition:all .4s;
}
.stats-strip-item:hover .stats-icon-wrap{background:linear-gradient(135deg, var(--emerald), var(--emerald-dark));color:#fff;border-color:transparent;transform:scale(1.08)}
.stats-number{font-family:var(--font-head);font-size:2.75rem;font-weight:800;color:var(--emerald);line-height:1;display:block;margin-bottom:.35rem;letter-spacing:-1px}
.stats-label{font-size:.8rem;text-transform:uppercase;letter-spacing:1.8px;color:var(--text-muted);font-weight:600}

/* TIMELINE — Refined CV-style */
.timeline-container{position:relative;max-width:780px;margin:0 auto;padding:10px 0}
.timeline-container::before{content:'';position:absolute;left:20px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--emerald),var(--cyan),transparent);border-radius:2px;opacity:.8}
.timeline-item{padding:8px 8px 36px 52px;position:relative}
.timeline-dot{position:absolute;width:14px;height:14px;left:13px;top:12px;background:var(--emerald);border-radius:50%;z-index:1;box-shadow:0 0 0 4px rgba(16,185,129,.2), 0 0 12px rgba(16,185,129,.3);border:2px solid var(--bg-body);animation:pulseDot 2.5s infinite}
.timeline-content{padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .35s var(--ease);box-shadow:0 4px 20px rgba(0,0,0,0.1)}
.timeline-content:hover{border-color:var(--border-em);transform:translateX(6px);box-shadow:var(--shadow-card)}
.timeline-date{color:var(--emerald);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem;display:block}
.timeline-content h3{color:var(--text-bright);font-family:var(--font-head);font-size:1.2rem;margin-bottom:.5rem}
.timeline-content p{color:var(--text-soft);font-size:.9rem;line-height:1.7;margin:0}

/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.testimonial-card{background:var(--bg-card);border:1px solid var(--border);padding:2rem;border-radius:18px;transition:all .4s;position:relative;overflow:hidden}
.testimonial-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at bottom left,rgba(16,185,129,.05),transparent 60%);opacity:0;transition:opacity .4s}
.testimonial-card:hover{transform:translateY(-6px);border-color:var(--border-em);box-shadow:0 20px 40px rgba(0,0,0,.2)}
.testimonial-card:hover::before{opacity:1}
.testimonial-card i.fa-quote-left{font-size:2.5rem;color:rgba(16,185,129,.15);position:absolute;top:1.5rem;right:1.5rem}
.testimonial-stars{display:flex;gap:4px;margin-bottom:1rem}
.testimonial-stars i{color:#f59e0b;font-size:.85rem}
.testimonial-text{font-style:italic;color:var(--text-soft);margin-bottom:1.5rem;font-size:.92rem;line-height:1.8;position:relative;z-index:2}
.testimonial-author{display:flex;align-items:center;gap:14px}
.testimonial-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--emerald)}
.author-info h4{margin:0 0 2px;color:var(--text-bright);font-family:var(--font-head);font-size:1rem}
.author-info p{margin:0;font-size:.75rem;color:var(--emerald);font-weight:600;text-transform:uppercase;letter-spacing:.5px}

/* EDUCATION */
.education-card{background:var(--bg-card);border:1px solid var(--border);padding:2rem;border-radius:18px;display:flex;gap:1.5rem;align-items:flex-start;transition:all .4s;position:relative;overflow:hidden;margin-bottom:1.25rem}
.education-card::before{content:'';position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(180deg,var(--emerald),var(--cyan));border-radius:3px}
.education-card:hover{border-color:var(--border-em);transform:translateX(6px);box-shadow:0 12px 30px rgba(0,0,0,.2)}
.edu-icon{width:60px;height:60px;min-width:60px;background:rgba(16,185,129,.1);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--emerald);font-size:1.7rem;border:1px solid var(--border-em);transition:all .4s;flex-shrink:0}
.education-card:hover .edu-icon{background:linear-gradient(135deg,var(--emerald),var(--emerald-dark));color:#fff;transform:rotate(10deg)}
.edu-details h3{font-family:var(--font-head);color:var(--text-bright);font-size:1.25rem;margin-bottom:4px}
.edu-school{color:var(--emerald);font-weight:700;font-size:.8rem;display:block;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}
.edu-details p{color:var(--text-soft);font-size:.9rem;line-height:1.7;margin:0}

/* CONTACT FORM — Professional layout */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:2.5rem;align-items:start}
.contact-info,.contact-form-wrap{
    background:var(--bg-card);border:1px solid var(--border);padding:2rem;
    border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(0,0,0,0.12);
    transition: border-color .3s, box-shadow .3s;
}
.contact-info:hover,.contact-form-wrap:hover{border-color:var(--border-em);box-shadow:0 12px 40px rgba(0,0,0,0.18)}
.contact-info h3{font-family:var(--font-head);font-size:1.7rem;color:var(--text-bright);margin-bottom:.75rem}
.contact-info p{color:var(--text-soft);line-height:1.8;margin-bottom:1.5rem}
.contact-item{display:flex;align-items:center;gap:14px;margin-bottom:1.25rem}
.contact-item i{width:42px;height:42px;background:rgba(16,185,129,.1);border:1px solid var(--border-em);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--emerald);font-size:1.05rem;flex-shrink:0}
.contact-item span{color:var(--text-soft);font-size:.95rem}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;margin-bottom:.45rem;color:var(--text-bright);font-weight:600;font-size:.83rem;text-transform:uppercase;letter-spacing:.5px}
.form-control{width:100%;padding:12px 16px;background:var(--bg-body);border:1px solid var(--border);border-radius:10px;color:var(--text-bright);font-family:var(--font-sans);font-size:.95rem;transition:all .3s}
.form-control:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(16,185,129,.15), 0 0 20px rgba(16,185,129,.1)}
.form-control::placeholder{color:var(--text-muted);opacity:0.8}
.form-control:focus-visible{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(16,185,129,.2)}
textarea.form-control{resize:vertical;min-height:130px}
select.form-control option{background:var(--bg-body)}

/* ALERTS */
.alert{padding:.9rem 1.25rem;border-radius:10px;margin-bottom:1.25rem;font-weight:500;display:flex;align-items:center;gap:10px;font-size:.92rem}
.alert-success{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.3);color:var(--emerald)}
.alert-danger{background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.3);color:#f87171}
.alert-info{background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.3);color:#93c5fd}

/* FOOTER */
.site-footer{position:relative;margin-top:auto;background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-body) 100%);border-top:1px solid var(--border);overflow:hidden}
.footer-top-glow{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--emerald),var(--cyan),transparent);opacity:.5}
.footer-inner{padding:4rem 4rem;max-width:1600px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;position:relative;z-index:2}
.footer-col h4{font-family:var(--font-head);color:var(--text-bright);margin-bottom:1.25rem;font-size:1rem;position:relative;padding-bottom:10px}
.footer-col h4::after{content:'';position:absolute;bottom:0;left:0;width:28px;height:2px;background:linear-gradient(90deg,var(--emerald),var(--cyan));border-radius:2px}
.footer-brand h3{font-family:var(--font-head);font-size:1.6rem;color:var(--text-bright);margin-bottom:1rem;display:flex;align-items:center;gap:10px}
.footer-brand p{color:var(--text-muted);font-size:.88rem;line-height:1.7;max-width:360px;margin-bottom:1.25rem}
.availability-badge{display:inline-flex;align-items:center;gap:10px;padding:7px 16px;background:rgba(16,185,129,.06);border:1px solid var(--border-em);border-radius:30px;font-size:.8rem;color:var(--text-soft);font-weight:500}
.footer-links ul{display:flex;flex-direction:column;gap:10px}
.footer-links a{color:var(--text-muted);font-size:.88rem;display:inline-flex;align-items:center;gap:8px;transition:all .3s}
.footer-links a i{font-size:.75rem;color:var(--emerald);opacity:.6}
.footer-links a:hover{color:var(--text-bright);padding-left:5px}
.footer-social-icons{display:flex;gap:10px;margin-bottom:1.25rem;flex-wrap:wrap}
.footer-social-icons a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .3s;font-size:1rem}
.footer-social-icons a:hover{background:var(--emerald);color:#fff;border-color:var(--emerald);transform:translateY(-5px);box-shadow:0 8px 20px var(--emerald-glow)}
.footer-mail-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px;background:transparent;border:1px solid var(--border-em);color:var(--emerald);border-radius:10px;font-weight:700;font-size:.88rem;transition:all .3s}
.footer-mail-btn:hover{background:var(--emerald);color:#fff;box-shadow:0 8px 20px var(--emerald-glow)}
.footer-bottom{border-top:1px solid var(--border);background:rgba(0,0,0,.2)}
.footer-bottom-content{max-width:1600px;margin:0 auto;padding:1.25rem 4rem;display:flex;justify-content:space-between;align-items:center;color:var(--text-muted);font-size:.82rem}
.footer-made-with i{color:var(--emerald);margin:0 3px;animation:pulse-heart .9s ease-in-out infinite}
@keyframes pulse-heart{0%,100%{transform:scale(1)}50%{transform:scale(1.3)}}

/* LOGIN PAGE */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-body);padding:2rem;position:relative}
.login-page::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(16,185,129,.06),transparent 70%)}
.login-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:22px;padding:2.5rem;width:100%;max-width:420px;position:relative;z-index:2;box-shadow:0 25px 60px rgba(0,0,0,.4)}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo h1{font-family:var(--font-head);font-size:1.8rem;color:var(--text-bright)}
.login-logo p{color:var(--text-muted);margin-top:.4rem;font-size:.9rem}

/* UTILITIES */
.pulse-dot{display:inline-block;width:7px;height:7px;background:var(--emerald);border-radius:50%;box-shadow:0 0 0 0 rgba(16,185,129,.7);animation:pulseDot 2s infinite;flex-shrink:0}
@keyframes pulseDot{0%{transform:scale(.95);box-shadow:0 0 0 0 rgba(16,185,129,.7)}70%{transform:scale(1);box-shadow:0 0 0 8px rgba(16,185,129,0)}100%{transform:scale(.95);box-shadow:0 0 0 0 rgba(16,185,129,0)}}

/* Back to top — modern pill */
#back-to-top{
    position:fixed;bottom:28px;right:28px;width:52px;height:52px;
    background:linear-gradient(135deg, var(--emerald), var(--emerald-dark));
    color:#fff;border-radius:50%;border:none;font-size:1.15rem;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 8px 24px var(--emerald-glow);opacity:0;visibility:hidden;
    transform:translateY(20px) scale(0.9);transition:all .4s var(--ease-out);z-index:99;
}
#back-to-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
#back-to-top:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 32px var(--emerald-glow)}
#back-to-top:focus-visible{outline:2px solid var(--emerald);outline-offset:3px}

/* CV CTA STRIP — Professional résumé call-to-action */
.cv-cta-strip{
    display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;
    background:linear-gradient(135deg, rgba(16,185,129,.08) 0%, rgba(6,182,212,.04) 100%);
    border:1px solid var(--border-em);border-radius:var(--radius-lg);
    padding:1.5rem 2rem;box-shadow:0 8px 32px rgba(0,0,0,0.2);
}
.cv-cta-content{display:flex;align-items:center;gap:1.25rem;}
.cv-cta-content i{font-size:2rem;color:var(--emerald);opacity:.9;}
.cv-cta-content strong{display:block;font-family:var(--font-head);color:var(--text-bright);font-size:1.1rem;margin-bottom:2px;}
.cv-cta-content span{font-size:.88rem;color:var(--text-muted);}
.cv-cta-btn{flex-shrink:0;}
@media(max-width:600px){.cv-cta-strip{flex-direction:column;text-align:center;}.cv-cta-content{flex-direction:column;}}

/* CURRENT WORK CARD */
.current-work-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-wrap:wrap;gap:2rem;align-items:center;position:relative;overflow:hidden;transition:all .3s}
.current-work-card::before{content:'';position:absolute;top:0;right:0;width:200px;height:200px;background:radial-gradient(circle,rgba(16,185,129,.06),transparent 70%);pointer-events:none}
.current-work-card:hover{border-color:var(--border-em);box-shadow:0 15px 40px rgba(0,0,0,.2)}

/* ACTIVE LABEL */
.active-label{color:var(--emerald);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;display:flex;align-items:center;gap:8px}

/* GLOWING SECTION DIVIDER */
.section-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--border-em),transparent);margin:0;opacity:.6}

/* RESPONSIVE */
@media(max-width:1300px){
    .hero-name{font-size:4.5rem}
    .hero-image-column{flex:0 0 360px}
    .hero-image-frame{height:420px}
    .stats-strip{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1024px){
    .sidebar-cv{transform:translateX(-100%)}
    .sidebar-cv.active{transform:translateX(0);box-shadow:10px 0 40px rgba(0,0,0,.6)}
    .main-content{margin-left:0;width:100%}
    .mobile-header{display:flex}
    .hero-section{padding:3.5rem 2rem 5rem}
    .hero-content-wrapper{flex-direction:column-reverse;text-align:center;gap:3rem}
    .hero-text-column{display:flex;flex-direction:column;align-items:center;max-width:100%}
    .hero-socials,.hero-buttons,.hero-stats{justify-content:center}
    .hero-bio{text-align:center}
    .page-header,.content-inner{padding:2.5rem 2rem}
    .page-header{padding-bottom:0}
    .skills-grid{grid-template-columns:1fr}
    .footer-inner{grid-template-columns:1fr 1fr;padding:3rem 2rem}
    .footer-bottom-content{flex-direction:column;gap:8px;text-align:center;padding:1.25rem 2rem}
    .contact-grid{grid-template-columns:1fr}
    .stats-strip{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .portfolio-grid{grid-template-columns:1fr}
    .hero-name{font-size:3rem;letter-spacing:-2px}
    .hero-image-column{flex:0 0 280px;width:100%}
    .hero-image-frame{height:320px}
    .hero-buttons{flex-direction:column;width:100%;max-width:280px}
    .btn-primary,.btn-secondary{justify-content:center;width:100%}
    .single-post-container{padding:1.5rem}
    .single-title{font-size:1.9rem}
    .footer-inner{grid-template-columns:1fr;gap:2rem}
    .education-card{flex-direction:column;gap:1rem;padding:1.5rem}
    .single-author-box{flex-direction:column;text-align:center}
    .single-footer-share{flex-direction:column;align-items:flex-start}
    .stats-strip{grid-template-columns:1fr 1fr}
}

/* ============================================================
   GLOBAL STANDARDIZED HEADERS & SECTION TITLES
============================================================ */
.page-header {
    padding: 6rem 4rem 3rem;
    border-bottom: 1px solid var(--border);
    background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(16,185,129,.06) 0%, transparent 100%);
    text-align: left;
    position: relative;
}
.page-header::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 4rem;
    right: 4rem;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--emerald), var(--cyan), transparent);
    opacity: 0.5;
    border-radius: 2px;
}
.page-header h1 {
    font-family: var(--font-head);
    font-size: 3.2rem;
    font-weight: 800;
    margin-bottom: 1rem;
    color: var(--text-bright);
    letter-spacing: -1px;
    line-height: 1.2;
}
.page-header h1 span {
    background: linear-gradient(90deg, var(--emerald), var(--cyan));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.page-header p {
    color: var(--text-muted);
    font-size: 1.15rem;
    max-width: 650px;
    line-height: 1.6;
}

.section-title {
    font-family: var(--font-head);
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-bright);
    margin-bottom: 2rem;
    display: flex;
    align-items: center;
    gap: 12px;
    letter-spacing: -0.02em;
}
.section-title i {
    color: var(--emerald-main);
    font-size: 1.8rem;
    width: 2rem;
    text-align: center;
}
.section-title::after {
    content: '';
    flex: 1;
    max-width: 200px;
    height: 1px;
    background: linear-gradient(90deg, var(--border-em), transparent);
    border-radius: 1px;
}

@media(max-width: 768px) {
    .page-header {
        padding: 4rem 1.5rem 2rem;
        background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(16,185,129,.05) 0%, transparent 100%);
    }
    .page-header::after { left: 1.5rem; right: 1.5rem; }
    .page-header h1 { font-size: 2.5rem; }
}
