/* ================================================================
   AKID'S CYBERSECURITY — PROFESSIONAL DARK THEME v3
   ================================================================ */

/* ── Variables ──────────────────────────────────────────────────── */
:root {
    --bg:          #07090d;
    --bg-2:        #0c1118;
    --bg-3:        #131a23;
    --bg-4:        #1a2230;
    --green:       #00ff88;
    --green-dim:   #00cc66;
    --green-dark:  #007740;
    --green-glow:  rgba(0,255,136,.12);
    --green-faint: rgba(0,255,136,.05);
    --cyan:        #00d4ff;
    --red:         #ff3355;
    --amber:       #ffb347;
    --text:        #b0bec5;
    --text-2:      #6b7a87;
    --text-bright: #e8f0f8;
    --border:      rgba(0,255,136,.10);
    --border-2:    rgba(0,255,136,.22);
    --border-3:    rgba(0,255,136,.45);
    --mono:        'Share Tech Mono', 'Courier New', monospace;
    --ui:          'Rajdhani', sans-serif;
    --title:       'Orbitron', sans-serif;
    --shadow-sm:   0 4px 16px rgba(0,0,0,.5);
    --shadow-md:   0 8px 40px rgba(0,0,0,.6);
    --shadow-lg:   0 20px 70px rgba(0,0,0,.7);
    --glow-sm:     0 0 14px rgba(0,255,136,.22);
    --glow-md:     0 0 32px rgba(0,255,136,.28);
    --glow-lg:     0 0 64px rgba(0,255,136,.2);
    --ease:        cubic-bezier(.4,0,.2,1);
    --ease-spring: cubic-bezier(.34,1.56,.64,1);
    --t:           .24s;
    --r:           5px;
}

/* ── Keyframes ──────────────────────────────────────────────────── */
@keyframes fadeUp    { from { opacity:0; transform:translateY(28px) } to { opacity:1; transform:none } }
@keyframes fadeIn    { from { opacity:0 } to { opacity:1 } }
@keyframes blink     { 0%,100% { opacity:1 } 50% { opacity:0 } }
@keyframes pulse     { 0%,100% { opacity:1; transform:scale(1) } 50% { opacity:.4; transform:scale(.75) } }
@keyframes scanlines { 0% { background-position:0 0 } 100% { background-position:0 60px } }
@keyframes border-flow {
    0%   { background-position: 0% 50% }
    50%  { background-position: 100% 50% }
    100% { background-position: 0% 50% }
}
@keyframes float {
    0%,100% { transform: translateY(0) }
    50%      { transform: translateY(-10px) }
}
@keyframes float-slow {
    0%,100% { transform: translateY(0) rotate(0deg) }
    33%      { transform: translateY(-14px) rotate(5deg) }
    66%      { transform: translateY(-6px) rotate(-3deg) }
}
@keyframes glitch-clip {
    0%  { clip-path: inset(38% 0 60% 0); transform: translate(-3px, 0) }
    20% { clip-path: inset(90% 0 2% 0);  transform: translate(3px, 0) }
    40% { clip-path: inset(42% 0 2% 0);  transform: translate(-2px, 0) }
    60% { clip-path: inset(22% 0 56% 0); transform: translate(2px, 0) }
    80% { clip-path: inset(52% 0 6% 0);  transform: translate(-3px, 0) }
    100% { clip-path: inset(56% 0 41% 0); transform: translate(0) }
}
@keyframes flicker {
    0%,93%,100% { opacity:1 }
    94%  { opacity:.82 }
    96%  { opacity:1 }
    97%  { opacity:.6 }
    99%  { opacity:1 }
}
@keyframes scroll-drop {
    0%   { opacity:0; transform:scaleY(0); transform-origin:top }
    40%  { opacity:1; transform:scaleY(1); transform-origin:top }
    60%  { opacity:1; transform:scaleY(1); transform-origin:bottom }
    100% { opacity:0; transform:scaleY(0); transform-origin:bottom }
}
@keyframes ring-pulse {
    0%,100% { transform:translate(-50%,-50%) scale(1); opacity:.2 }
    50%      { transform:translate(-50%,-50%) scale(1.08); opacity:.08 }
}
@keyframes drift {
    0%   { transform: translateY(0) translateX(0) }
    25%  { transform: translateY(-20px) translateX(10px) }
    50%  { transform: translateY(-8px) translateX(-8px) }
    75%  { transform: translateY(-16px) translateX(6px) }
    100% { transform: translateY(0) translateX(0) }
}
@keyframes morph {
    0%,100% { border-radius: 6px 20px 6px 20px }
    50%      { border-radius: 20px 6px 20px 6px }
}
@keyframes shimmer {
    0%   { transform: translateX(-120%) skewX(-12deg) }
    100% { transform: translateX(220%) skewX(-12deg) }
}
@keyframes spin { to { transform: rotate(360deg) } }
@keyframes spin-slow { to { transform: rotate(360deg) } }
@keyframes hex-drift {
    0%,100% { transform: translateY(0) rotate(0deg); opacity:.12 }
    50%      { transform: translateY(-30px) rotate(15deg); opacity:.06 }
}

/* ── Reset ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px }
body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--ui);
    font-size: 1rem;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    max-width:100vw;
}
a { color: var(--green); text-decoration: none; transition: color var(--t) var(--ease) }
a:hover { color: var(--cyan) }
img { max-width:100%; height:auto; display:block }

/* ── Scrollbar ──────────────────────────────────────────────────── */
::-webkit-scrollbar { width:4px; height:4px }
::-webkit-scrollbar-track { background: var(--bg-2) }
::-webkit-scrollbar-thumb { background: var(--green-dark); border-radius:2px }
::-webkit-scrollbar-thumb:hover { background: var(--green-dim) }
::selection { background: rgba(0,255,136,.22); color: var(--text-bright) }

/* ── Utilities ──────────────────────────────────────────────────── */
.container        { max-width:1180px; margin:0 auto; padding:0 28px }
.container-sm     { max-width:780px; margin:0 auto; padding:0 28px }
.container-narrow { max-width:760px; margin:0 auto; padding:0 28px }
.section          { padding:100px 0; position:relative }
.text-green       { color: var(--green) }
.text-dim         { color: var(--text-2) }
.text-bright      { color: var(--text-bright) }
.text-center      { text-align:center }
.text-muted       { color: var(--text-2) }
.text-truncate    { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:180px }
.no-data          { color: var(--text-2); font-style:italic; text-align:center; padding:40px 0; grid-column:1/-1 }
.mt-2  { margin-top:.5rem }
.mt-4  { margin-top:1.5rem }
.mb-4  { margin-bottom:1.5rem }
.separator { color: var(--border-3) }

/* ── Matrix canvas ──────────────────────────────────────────────── */
.matrix-bg { position:fixed; inset:0; z-index:0; opacity:.04; pointer-events:none }
main#main  { position:relative; z-index:1 }

/* ================================================================
   NAVIGATION
   ================================================================ */
.cyber-nav {
    position:fixed; top:0; left:0; right:0; z-index:900;
    transition: all var(--t) var(--ease);
}
.cyber-nav::before {
    content:''; position:absolute; inset:0;
    background:transparent; backdrop-filter:blur(0);
    border-bottom:1px solid transparent;
    transition: background .4s var(--ease), backdrop-filter .4s var(--ease), border-color .4s var(--ease);
}
.cyber-nav.scrolled::before {
    background: rgba(7,9,13,.96);
    backdrop-filter: blur(32px) saturate(200%);
    border-bottom-color: var(--border);
    box-shadow: 0 1px 0 rgba(0,255,136,.06), 0 4px 32px rgba(0,0,0,.5);
}

.nav-container {
    max-width:1180px; margin:0 auto; padding:0 28px;
    display:flex; align-items:center; justify-content:space-between;
    height:72px; position:relative; z-index:1;
}

/* Brand */
.nav-brand {
    font-family: var(--title); font-size:.9rem; font-weight:700;
    letter-spacing:.16em; color:var(--text-bright);
    display:flex; align-items:center; gap:1px;
    transition: all var(--t); flex-shrink:0;
}
.nav-brand:hover { color:var(--text-bright); filter:drop-shadow(0 0 12px rgba(0,255,136,.4)) }
.brand-bracket { color:var(--green); font-size:1.2em; line-height:1 }
.brand-text    { color:var(--text-bright) }
.brand-sep     { color:var(--green-dim); margin:0 3px }
.brand-sub     { color:var(--green) }

/* Nav links */
.nav-links { display:flex; align-items:center; gap:2px; list-style:none; order:2 }
.nav-link {
    font-family: var(--mono); font-size:.75rem; color:var(--text-2);
    padding:8px 14px; border:1px solid transparent; border-radius:var(--r);
    transition: all var(--t) var(--ease); letter-spacing:.04em; white-space:nowrap;
    position:relative;
}
.nav-link::before {
    content:''; position:absolute; bottom:0; left:50%; right:50%;
    height:1px; background:var(--green); transition:all var(--t) var(--ease);
}
.nav-link:hover::before, .nav-link.active::before { left:14px; right:14px }
.nav-link:hover, .nav-link.active {
    color:var(--green); border-color:var(--border); background:var(--green-faint);
}
/* CTA button style */
.nav-cta {
    border-color:var(--border-2) !important; color:var(--green) !important;
    background:var(--green-faint) !important;
}
.nav-cta:hover {
    background:var(--green) !important; color:var(--bg) !important;
    box-shadow:var(--glow-sm); border-color:var(--green) !important;
}
.nav-cta::before { display:none }
/* Admin link */
.nav-admin { color:var(--cyan) !important }
.nav-admin:hover { border-color:rgba(0,212,255,.3) !important; background:rgba(0,212,255,.06) !important; color:var(--cyan) !important }
.nav-admin::before { display:none }

/* Hidden checkbox for CSS-only mobile toggle */
.nav-check { display:none !important }

/* Hamburger toggle (label for checkbox) */
.nav-toggle {
    display:none; flex-direction:column; justify-content:center; gap:5px;
    width:40px; height:40px; background:rgba(0,255,136,.06);
    border:1px solid var(--border); border-radius:var(--r);
    cursor:pointer; padding:0; align-items:center;
    transition: all var(--t) var(--ease); flex-shrink:0;
    order:3;
}
.nav-toggle:hover { background:rgba(0,255,136,.12); border-color:var(--green) }
.nav-toggle .bar {
    display:block; width:18px; height:2px; background:var(--green);
    transition: all var(--t) var(--ease); border-radius:1px;
}
/* X animation when checked */
.nav-check:checked ~ .nav-toggle .bar:nth-child(1) { transform:rotate(45deg) translateY(7px) }
.nav-check:checked ~ .nav-toggle .bar:nth-child(2) { opacity:0; transform:scaleX(0) }
.nav-check:checked ~ .nav-toggle .bar:nth-child(3) { transform:rotate(-45deg) translateY(-7px) }
.nav-check:checked ~ .nav-toggle { background:rgba(0,255,136,.12); border-color:var(--green) }

/* ================================================================
   BUTTONS
   ================================================================ */
.btn {
    display:inline-flex; align-items:center; gap:8px;
    padding:11px 26px; font-family:var(--mono); font-size:.8rem;
    font-weight:600; letter-spacing:.07em; border-radius:var(--r);
    border:1px solid transparent; cursor:pointer;
    transition: all var(--t) var(--ease);
    text-decoration:none; position:relative; overflow:hidden; white-space:nowrap;
}
.btn::after {
    content:''; position:absolute; top:0; left:-100%; width:50%; height:100%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.1), transparent);
    transform:skewX(-20deg); transition:left .5s var(--ease);
}
.btn:hover::after { left:160% }
.btn-primary {
    background:var(--green); color:var(--bg);
    border-color:var(--green); font-weight:700;
    text-shadow:0 1px 0 rgba(0,0,0,.15);
}
.btn-primary:hover {
    background:transparent; color:var(--green); box-shadow:var(--glow-md);
    text-shadow:none;
}
.btn-primary:focus-visible, .btn-outline:focus-visible {
    outline:2px solid var(--green); outline-offset:2px;
}
.btn-outline {
    background:transparent; color:var(--green); border-color:var(--border-2);
}
.btn-outline:hover {
    background:var(--green-glow); border-color:var(--green);
    box-shadow:var(--glow-sm); color:var(--green);
}
.btn-ghost { background:transparent; color:var(--text-2); border-color:var(--border) }
.btn-ghost:hover { color:var(--text-bright); border-color:var(--border-2) }
.btn-danger { background:var(--red); color:#fff; border-color:var(--red) }
.btn-danger:hover { background:transparent; color:var(--red); box-shadow:0 0 14px rgba(255,51,85,.3) }
.btn-sm  { padding:6px 14px; font-size:.72rem }
.btn-lg  { padding:13px 32px; font-size:.86rem }
.btn-xl  { padding:16px 40px; font-size:.92rem }
.btn-block { width:100%; justify-content:center }
.btn-hero { padding:13px 30px; font-size:.84rem }

/* ================================================================
   HERO
   ================================================================ */
.hero {
    min-height:100vh; display:flex; align-items:center; justify-content:center;
    position:relative; overflow:hidden; padding:80px 28px 80px;
}

/* Layered glow backgrounds */
.hero::before {
    content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
    background:
        radial-gradient(ellipse 90% 60% at 50% -5%, rgba(0,255,136,.08) 0%, transparent 55%),
        radial-gradient(ellipse 50% 45% at 10% 80%, rgba(0,212,255,.04) 0%, transparent 50%),
        radial-gradient(ellipse 40% 40% at 90% 85%, rgba(0,255,136,.03) 0%, transparent 50%);
}

/* Scanlines */
.hero-scanlines {
    position:absolute; inset:0; z-index:2; pointer-events:none;
    background:repeating-linear-gradient(
        0deg, transparent, transparent 3px,
        rgba(0,0,0,.05) 3px, rgba(0,0,0,.05) 4px
    );
    animation: scanlines 8s linear infinite;
}

.hero-overlay {
    position:absolute; inset:0; z-index:1; pointer-events:none;
    background:radial-gradient(ellipse at center bottom, rgba(0,255,136,.025) 0%, transparent 65%);
}

/* Grid pattern */
.hero-grid-bg {
    position:absolute; inset:0; z-index:1; pointer-events:none;
    background-image:
        linear-gradient(rgba(0,255,136,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,255,136,.04) 1px, transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black, transparent);
}

/* Main content */
.hero-content {
    position:relative; z-index:3;
    text-align:center; max-width:920px; width:100%;
    animation: fadeIn 1s var(--ease) both;
}

/* Badge pill */
.hero-badge {
    display:inline-flex; align-items:center; gap:10px;
    background:rgba(0,255,136,.06); border:1px solid var(--border-2);
    border-radius:30px; padding:6px 20px;
    font-family:var(--mono); font-size:.68rem;
    letter-spacing:.18em; color:var(--green); text-transform:uppercase;
    margin-bottom:36px; animation:float 4s ease-in-out infinite;
}
.badge-dot {
    width:7px; height:7px; border-radius:50%;
    background:var(--green); box-shadow:0 0 8px var(--green);
    animation:pulse 2s infinite; flex-shrink:0;
}
.badge-separator { color:var(--border-3); font-size:.6em }
.badge-status { color:var(--cyan); letter-spacing:.12em }

/* Terminal greeting */
.hero-greeting {
    font-family:var(--mono); font-size:.9rem; margin-bottom:16px;
    display:flex; justify-content:center; align-items:center; gap:3px; flex-wrap:wrap;
    animation: fadeIn .6s var(--ease) .2s both;
}
.greeting-prompt { color:var(--green) }
.greeting-sep    { color:var(--text-2) }
.greeting-path   { color:var(--cyan) }
.greeting-dollar { color:var(--text-2); margin:0 6px }
.greeting-cmd    { color:var(--text-bright); font-style:italic }

/* Name heading */
.hero-title {
    font-family:var(--title);
    font-size:clamp(4rem, 11vw, 8rem);
    font-weight:900; letter-spacing:.07em; line-height:1;
    margin-bottom:24px;
}
.hero-name {
    color:var(--text-bright); position:relative; display:inline-block;
    text-shadow:0 0 100px rgba(0,255,136,.15), 0 0 40px rgba(0,255,136,.08);
    animation:flicker 7s infinite;
}
.hero-name::before,
.hero-name::after {
    content:attr(data-text); position:absolute; top:0; left:0;
    width:100%; height:100%;
    font-family:inherit; font-size:inherit; font-weight:inherit; letter-spacing:inherit;
}
.hero-name::before {
    color:#00ffff; text-shadow:-2px 0 #00ffff;
    animation:glitch-clip 5s infinite linear; opacity:.45;
}
.hero-name::after {
    color:#ff0040; text-shadow:2px 0 #ff0040;
    animation:glitch-clip 5s infinite linear reverse;
    animation-delay:.65s; opacity:.3;
}

/* Code-style tagline row */
.hero-tagline-row {
    font-family:var(--mono);
    font-size:clamp(.85rem, 2vw, 1.18rem);
    color:var(--text-2); min-height:2.8em;
    margin-bottom:28px; letter-spacing:.02em;
    display:flex; justify-content:center; align-items:center; gap:4px; flex-wrap:wrap;
    background:rgba(12,17,24,.5); border:1px solid var(--border);
    border-radius:var(--r); padding:10px 20px; max-width:680px; margin-inline:auto;
    backdrop-filter:blur(8px);
}
.hero-tag-bracket { color:var(--green-dim) }
.hero-tag-label   { color:var(--text-2) }
.hero-tag-eq      { color:var(--text-2); margin:0 2px }
.hero-tag-quote   { color:var(--amber) }
.hero-tagline-row #typed-roles { color:var(--cyan); min-width:2ch }
.typed-cursor { animation:blink 1s step-end infinite; color:var(--cyan) }

/* Subtitle */
.hero-subtitle {
    font-size:1.08rem; color:var(--text-2);
    max-width:580px; margin:0 auto 44px; line-height:1.9;
    letter-spacing:.01em;
}

/* Stats bar */
.hero-stats {
    display:flex; justify-content:center; align-items:center; flex-wrap:wrap;
    margin:0 auto 44px;
    border:1px solid var(--border); border-radius:var(--r);
    background:rgba(12,17,24,.72); backdrop-filter:blur(12px);
    overflow:hidden; max-width:580px;
}
.stat-item {
    flex:1; min-width:130px; padding:22px 16px; text-align:center;
}
.stat-divider { width:1px; height:44px; background:var(--border); flex-shrink:0 }
.stat-number {
    display:block; font-family:var(--title); font-size:2rem; font-weight:700;
    color:var(--green); text-shadow:0 0 24px rgba(0,255,136,.4);
    line-height:1; margin-bottom:5px;
}
.stat-label {
    font-family:var(--mono); font-size:.63rem;
    color:var(--text-2); letter-spacing:.14em; text-transform:uppercase;
}

/* Action buttons */
.hero-actions {
    display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:48px;
}

/* Terminal bottom line */
.hero-terminal-line {
    font-family:var(--mono); font-size:.82rem; color:var(--text-2); opacity:.6;
    display:flex; justify-content:center; align-items:center; gap:2px;
}
.terminal-prompt { color:var(--green-dim) }
.terminal-blink  { animation:blink 1.1s step-end infinite; color:var(--green) }

/* Decorative elements */
.hero-deco { position:absolute; inset:0; z-index:2; pointer-events:none }
.deco-ring {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    border-radius:50%; border:1px solid var(--green); pointer-events:none;
}
.deco-ring-1 { width:700px; height:700px; opacity:.04; animation:ring-pulse 6s ease-in-out infinite }
.deco-ring-2 { width:900px; height:900px; opacity:.025; animation:ring-pulse 6s ease-in-out 2s infinite }
.deco-ring-3 { width:1100px; height:1100px; opacity:.015; animation:ring-pulse 6s ease-in-out 4s infinite }

.deco-hex {
    position:absolute; font-size:4rem; color:var(--green); opacity:.06;
    font-family:monospace; line-height:1; user-select:none;
}
.deco-hex-1 { top:15%; right:8%; animation:hex-drift 8s ease-in-out infinite }
.deco-hex-2 { bottom:20%; left:5%; font-size:3rem; animation:hex-drift 10s ease-in-out 3s infinite }
.deco-hex-3 { top:60%; right:3%; font-size:2.5rem; animation:hex-drift 7s ease-in-out 1.5s infinite }

.deco-dot {
    position:absolute; border-radius:50%; background:var(--green);
    animation:drift 8s ease-in-out infinite;
}
.deco-dot-1 { width:4px; height:4px; top:20%; left:12%; opacity:.5; animation-delay:0s }
.deco-dot-2 { width:3px; height:3px; top:70%; right:15%; opacity:.4; animation-delay:2s }
.deco-dot-3 { width:5px; height:5px; bottom:25%; left:20%; opacity:.35; animation-delay:4s }
.deco-dot-4 { width:3px; height:3px; top:40%; right:8%; opacity:.45; animation-delay:6s }

/* Scroll indicator */
.hero-scroll-indicator {
    position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
    display:flex; flex-direction:column; align-items:center; gap:8px;
    font-family:var(--mono); font-size:.6rem; letter-spacing:.22em;
    color:var(--text-2); text-transform:uppercase; z-index:3;
}
.scroll-line {
    width:1px; height:48px;
    background:linear-gradient(to bottom, var(--green), transparent);
    animation:scroll-drop 2.2s ease-in-out infinite;
}

/* ================================================================
   SHARED SECTION HEADERS
   ================================================================ */
.section-header { text-align:center; margin-bottom:68px }
.section-tag {
    font-family:var(--mono); font-size:.7rem; color:var(--green);
    letter-spacing:.24em; text-transform:uppercase; display:block; margin-bottom:14px;
}
.section-title {
    font-family:var(--title); font-size:clamp(1.7rem, 3.5vw, 2.6rem);
    color:var(--text-bright); margin-bottom:18px; letter-spacing:.04em; line-height:1.2;
}
.section-line {
    width:64px; height:2px; margin:0 auto;
    background:linear-gradient(90deg, transparent, var(--green), var(--cyan), transparent);
    border-radius:1px;
}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
[data-reveal] { transition:opacity .65s var(--ease), transform .65s var(--ease) }
[data-reveal].reveal-ready { opacity:0; transform:translateY(24px) }
[data-reveal].is-visible   { opacity:1; transform:none }

/* ================================================================
   ABOUT
   ================================================================ */
.about-section {
    background:linear-gradient(180deg, transparent, rgba(0,255,136,.012) 50%, transparent);
}

.about-grid {
    display:grid; grid-template-columns:1fr 1.65fr; gap:80px; align-items:start;
}

.about-image-area { position:relative }

.about-image-frame {
    position:relative; padding:3px;
    background:linear-gradient(135deg, var(--green), var(--cyan), var(--green-dark), var(--green));
    background-size:300% 300%;
    animation:border-flow 6s ease infinite;
    border-radius:12px;
}
.about-image-frame::after {
    content:''; position:absolute; inset:-1px; border-radius:12px;
    background:inherit; filter:blur(20px); opacity:.35; z-index:-1;
}
.about-image {
    width:100%; aspect-ratio:1/1; object-fit:cover;
    display:block; border-radius:10px;
    transition:transform .5s var(--ease);
    background:var(--bg-2);
}
.about-image-svg {
    background:var(--bg-2); padding:0;
}
.about-image-frame:hover .about-image { transform:scale(1.03) }

.about-image-placeholder {
    width:100%; aspect-ratio:1/1;
    display:flex; align-items:center; justify-content:center;
    background:var(--bg-3); font-size:5rem; color:var(--green-dark); border-radius:10px;
}

/* Corner decorations */
.image-corner {
    position:absolute; width:18px; height:18px; border-color:var(--green); border-style:solid;
}
.image-corner.tl { top:-6px; left:-6px; border-width:2px 0 0 2px }
.image-corner.tr { top:-6px; right:-6px; border-width:2px 2px 0 0 }
.image-corner.bl { bottom:-6px; left:-6px; border-width:0 0 2px 2px }
.image-corner.br { bottom:-6px; right:-6px; border-width:0 2px 2px 0 }

/* Certs */
.about-badges { display:flex; flex-wrap:wrap; gap:8px; margin-top:20px }
.cert-badge {
    font-family:var(--mono); font-size:.68rem; color:var(--green);
    border:1px solid var(--border-2); padding:4px 12px; border-radius:20px;
    background:var(--green-faint); transition:all var(--t) var(--ease);
}
.cert-badge:hover { border-color:var(--green); box-shadow:var(--glow-sm) }

/* Content */
.about-content { display:flex; flex-direction:column }
.about-text p { color:var(--text); margin-bottom:18px; line-height:1.95; letter-spacing:.01em }
.about-text p:first-child { font-size:1.08rem; color:var(--text-bright); font-weight:500 }

/* Services */
.about-services { display:grid; grid-template-columns:1fr 1fr; gap:9px; margin:28px 0 }
.service-item {
    display:flex; align-items:center; gap:11px;
    background:var(--bg-2); border:1px solid var(--border);
    border-radius:var(--r); padding:10px 14px;
    font-family:var(--mono); font-size:.77rem; color:var(--text-2);
    transition:all var(--t) var(--ease);
}
.service-item:hover { border-color:var(--green); color:var(--text-bright); background:var(--bg-3) }
.service-item i { color:var(--green); width:16px; text-align:center; flex-shrink:0 }

/* ================================================================
   SKILLS
   ================================================================ */
.skills-section { background:var(--bg-2); position:relative }
.skills-section::before,
.skills-section::after {
    content:''; display:block; height:1px;
    background:linear-gradient(90deg, transparent, var(--border-2), transparent);
}

.tab-buttons {
    display:flex; flex-wrap:wrap; gap:8px; margin-bottom:48px; justify-content:center;
}
.tab-btn {
    font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; padding:8px 22px;
    background:transparent; border:1px solid var(--border); color:var(--text-2);
    cursor:pointer; border-radius:var(--r);
    transition:all var(--t) var(--ease); position:relative; overflow:hidden;
}
.tab-btn::before {
    content:''; position:absolute; inset:0; background:var(--green);
    transform:scaleX(0); transform-origin:left; transition:transform var(--t) var(--ease);
}
.tab-btn span { position:relative; z-index:1; pointer-events:none }
.tab-btn:hover { border-color:var(--border-2); color:var(--text-bright) }
.tab-btn.active { border-color:var(--green); color:var(--bg) }
.tab-btn.active::before { transform:scaleX(1) }
.tab-btn::before { z-index:0 }

.tab-panel { display:none }
.tab-panel.active { display:block; animation:fadeIn .3s var(--ease) }

.skills-grid {
    display:grid; grid-template-columns:repeat(auto-fill, minmax(255px, 1fr)); gap:16px;
}

.skill-card {
    background:var(--bg-3); border:1px solid var(--border);
    border-radius:var(--r); padding:20px;
    transition:all var(--t) var(--ease); position:relative; overflow:hidden;
}
/* Left accent stripe by level */
.skill-card::after {
    content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
    background:var(--green-dark); border-radius:var(--r) 0 0 var(--r);
    transition:background var(--t), box-shadow var(--t);
}
.skill-card[data-skill-level="advanced"]::after { background:var(--green-dim) }
.skill-card[data-skill-level="expert"]::after   { background:var(--green); box-shadow:0 0 10px rgba(0,255,136,.4) }
.skill-card::before {
    content:''; position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(0,255,136,.04), transparent 55%);
    opacity:0; transition:opacity var(--t) var(--ease);
}
.skill-card:hover { border-color:var(--border-2); transform:translateY(-3px); box-shadow:var(--shadow-sm), 0 0 20px rgba(0,255,136,.05) }
.skill-card:hover::before { opacity:1 }

.skill-header {
    display:flex; align-items:center; gap:11px; margin-bottom:14px; position:relative; z-index:1;
}
.skill-icon-wrap {
    width:32px; height:32px; border-radius:var(--r); flex-shrink:0;
    background:rgba(0,255,136,.07); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--green); font-size:.88rem;
    transition:all var(--t) var(--ease);
}
.skill-card:hover .skill-icon-wrap {
    background:rgba(0,255,136,.14); border-color:var(--border-2);
    box-shadow:0 0 12px rgba(0,255,136,.18);
}
.skill-name {
    font-family:var(--mono); font-size:.82rem; color:var(--text-bright);
    flex:1; line-height:1.3;
}
.skill-percent {
    font-family:var(--title); font-size:.88rem; color:var(--green);
    font-weight:700; flex-shrink:0; letter-spacing:.02em;
}
.skill-percent em { font-style:normal; font-size:.62rem; color:var(--green-dim) }

.skill-bar-track {
    height:5px; background:rgba(255,255,255,.06); border-radius:3px;
    overflow:hidden; position:relative; z-index:1; margin-bottom:10px;
}
.skill-bar-fill {
    height:100%; border-radius:3px; width:0%;
    transition:width 1.4s cubic-bezier(.25,.46,.45,.94);
    background:linear-gradient(90deg, var(--green-dark), var(--skill-color, var(--green)));
    position:relative; overflow:visible;
}
.skill-bar-glow {
    position:absolute; right:-2px; top:-4px; width:8px; height:13px;
    background:var(--skill-color, var(--green));
    filter:blur(5px); opacity:.75; border-radius:50%; pointer-events:none;
}

.skill-footer { position:relative; z-index:1 }
.skill-level {
    font-family:var(--mono); font-size:.6rem; letter-spacing:.12em;
    text-transform:uppercase; padding:2px 9px; border-radius:20px; border:1px solid;
    display:inline-block;
}
.skill-level-intermediate { color:var(--text-2); border-color:var(--border) }
.skill-level-advanced     { color:var(--green-dim); border-color:rgba(0,204,102,.3); background:rgba(0,204,102,.06) }
.skill-level-expert       {
    color:var(--green); border-color:rgba(0,255,136,.35); background:rgba(0,255,136,.07);
    box-shadow:0 0 6px rgba(0,255,136,.15);
}

.skills-empty { text-align:center; padding:72px 20px; color:var(--text-2) }
.skills-empty i { font-size:2.5rem; color:var(--green-dark); margin-bottom:16px; display:block }
.skills-empty p { margin-bottom:20px }

/* ================================================================
   PROJECTS
   ================================================================ */
.projects-grid {
    display:grid; grid-template-columns:repeat(auto-fill, minmax(350px, 1fr)); gap:24px;
}
.project-card {
    background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r);
    overflow:hidden; display:flex; flex-direction:column;
    transition:all .3s var(--ease); position:relative;
}
.project-card::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, var(--green), var(--cyan));
    transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); z-index:1;
}
.project-card:hover { border-color:var(--border-2); transform:translateY(-5px); box-shadow:var(--shadow-md), 0 0 30px rgba(0,255,136,.06) }
.project-card:hover::before { transform:scaleX(1) }

.project-card-header { position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--bg-3) }
.project-img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease) }
.project-card:hover .project-img { transform:scale(1.06) }
.project-img-placeholder {
    width:100%; height:100%; display:flex; align-items:center; justify-content:center;
    font-size:2.8rem; color:var(--green-dark);
    background:linear-gradient(135deg, var(--bg-3), var(--bg-4));
}

.project-status {
    position:absolute; top:12px; right:12px;
    display:flex; align-items:center; gap:5px;
    background:rgba(7,9,13,.88); backdrop-filter:blur(8px);
    border:1px solid var(--border-2); border-radius:20px;
    font-family:var(--mono); font-size:.62rem; color:var(--green); padding:4px 10px;
}
.project-status .status-dot { width:6px; height:6px; flex-shrink:0 }

.project-card-body { padding:22px; flex:1; display:flex; flex-direction:column; gap:12px }
.project-title { font-family:var(--title); font-size:1rem; font-weight:600; color:var(--text-bright); letter-spacing:.04em }
.project-desc  { color:var(--text-2); font-size:.88rem; line-height:1.68; flex:1 }

.project-techs { display:flex; flex-wrap:wrap; gap:6px }
.tech-tag {
    font-family:var(--mono); font-size:.66rem; color:var(--green-dim);
    background:var(--green-faint); border:1px solid var(--border);
    padding:2px 9px; border-radius:3px; transition:all var(--t) var(--ease);
}
.tech-tag:hover { color:var(--green); border-color:var(--green) }

.project-card-footer { padding:14px 22px; border-top:1px solid var(--border); display:flex; gap:18px; align-items:center; background:rgba(0,0,0,.15) }
.project-link { font-family:var(--mono); font-size:.76rem; color:var(--text-2); display:flex; align-items:center; gap:5px; transition:all var(--t) var(--ease) }
.project-link:hover { color:var(--green) }
.project-link i { font-size:.82rem }

.section-cta { text-align:center; margin-top:48px; display:flex; flex-direction:column; align-items:center; gap:16px }
.section-cta p { color:var(--text-2); font-family:var(--mono); font-size:.8rem }

/* ================================================================
   BLOG (home cards)
   ================================================================ */
.blog-section { background:var(--bg-2) }
.blog-section::before, .blog-section::after {
    content:''; display:block; height:1px;
    background:linear-gradient(90deg, transparent, var(--border-2), transparent);
}
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:24px }

.blog-card {
    background:var(--bg-3); border:1px solid var(--border); border-radius:var(--r);
    padding:28px; transition:all .3s var(--ease);
    display:flex; flex-direction:column; gap:14px; position:relative; overflow:hidden;
}
.blog-card::after {
    content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, var(--green), var(--cyan));
    transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease);
}
.blog-card:hover { border-color:var(--border-2); transform:translateY(-3px); box-shadow:var(--shadow-sm) }
.blog-card:hover::after { transform:scaleX(1) }

.blog-card-meta { display:flex; align-items:center; gap:14px; flex-wrap:wrap; font-family:var(--mono); font-size:.7rem; color:var(--text-2) }
.blog-date i, .blog-reading-time i { color:var(--green); margin-right:4px }
.blog-title { font-family:var(--title); font-size:1.05rem; line-height:1.4 }
.blog-title a { color:var(--text-bright); transition:color var(--t) }
.blog-title a:hover { color:var(--green) }
.blog-excerpt { color:var(--text-2); font-size:.88rem; line-height:1.75; flex:1 }
.blog-tags { display:flex; flex-wrap:wrap; gap:5px }
.tag {
    font-family:var(--mono); font-size:.66rem; color:var(--green-dark);
    border:1px solid rgba(0,255,136,.14); padding:2px 9px; border-radius:20px;
    transition:all var(--t) var(--ease); background:var(--green-faint);
}
.tag:hover { color:var(--green); border-color:var(--green) }
.blog-read-more {
    font-family:var(--mono); font-size:.76rem; color:var(--green-dim);
    display:inline-flex; align-items:center; gap:6px;
    transition:all var(--t) var(--ease); margin-top:auto;
}
.blog-read-more:hover { color:var(--green); gap:10px }

/* ================================================================
   CONTACT CTA (home)
   ================================================================ */
.contact-cta-section { padding:80px 0 }
.cta-box {
    background:var(--bg-2); border:1px solid var(--border);
    border-radius:14px; padding:80px 48px; text-align:center;
    position:relative; overflow:hidden;
    box-shadow:0 12px 60px rgba(0,0,0,.4);
}
.cta-box::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, transparent, var(--green), var(--cyan), var(--green-dark), transparent);
    background-size:300% auto; animation:border-flow 5s ease infinite;
}
.cta-box::after {
    content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:600px; height:600px;
    background:radial-gradient(circle, rgba(0,255,136,.04), transparent 70%);
    pointer-events:none;
}
.cta-content { position:relative; z-index:1 }
.cta-content .section-tag { display:block; margin-bottom:12px }
.cta-content h2 { font-family:var(--title); font-size:clamp(1.7rem,3.5vw,2.5rem); margin:16px 0; color:var(--text-bright) }
.cta-content p { color:var(--text-2); max-width:500px; margin:0 auto 36px; font-size:1rem; line-height:1.8 }
.cta-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap }

/* ================================================================
   FOOTER
   ================================================================ */
.cyber-footer {
    background:linear-gradient(180deg, var(--bg-3), var(--bg-2) 40px);
    border-top:1px solid var(--border); padding:64px 0 28px; position:relative; z-index:1;
}
.footer-container { max-width:1180px; margin:0 auto; padding:0 28px }
.footer-grid { display:grid; grid-template-columns:1.8fr 1fr 1fr; gap:52px; margin-bottom:48px }
.footer-logo {
    font-family:var(--title); font-size:1rem; font-weight:700;
    color:var(--text-bright); margin-bottom:14px;
    text-shadow:0 0 24px rgba(0,255,136,.3); letter-spacing:.1em;
}
.footer-tagline { color:var(--text-2); font-size:.88rem; line-height:1.8; margin-bottom:16px }
.footer-secure-badge {
    display:inline-flex; align-items:center; gap:6px;
    font-family:var(--mono); font-size:.68rem; color:var(--green-dim);
    letter-spacing:.1em; border:1px solid var(--border); padding:4px 12px;
    border-radius:20px; background:var(--green-faint);
}
.footer-secure-badge i { font-size:.7rem }
.footer-heading { font-family:var(--mono); font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--green); margin-bottom:16px }
.footer-links ul { list-style:none; display:flex; flex-direction:column; gap:8px }
.footer-links a { color:var(--text-2); font-size:.88rem; transition:all var(--t) }
.footer-links a:hover { color:var(--green); padding-left:4px }
.footer-contact p { color:var(--text-2); font-size:.88rem; margin-bottom:18px; display:flex; align-items:center; gap:7px }
.footer-contact i { color:var(--green) }
.social-links { display:flex; gap:10px }
.social-link {
    width:34px; height:34px; border:1px solid var(--border); border-radius:var(--r);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-2); font-size:.88rem; transition:all var(--t) var(--ease);
}
.social-link:hover { color:var(--green); border-color:var(--green); background:var(--green-faint) }
.footer-bottom { }
.footer-line { width:100%; height:1px; background:var(--border); margin-bottom:20px }
.footer-bottom-row { display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:12px }
.footer-bottom-row p { color:var(--text-2); font-size:.78rem; font-family:var(--mono) }
.footer-status { display:flex; align-items:center; gap:6px }
.status-dot {
    width:7px; height:7px; border-radius:50%; background:var(--green);
    box-shadow:0 0 6px var(--green); animation:pulse 2s infinite; flex-shrink:0;
}

/* ================================================================
   FLASH MESSAGES
   ================================================================ */
.flash {
    display:flex; align-items:center; gap:10px;
    padding:13px 18px; margin:16px auto; max-width:820px;
    border-radius:var(--r); font-family:var(--mono); font-size:.83rem;
    border:1px solid; animation:fadeUp .35s var(--ease) both; position:relative; z-index:800;
}
.flash-success { background:rgba(0,255,136,.06); border-color:rgba(0,255,136,.3); color:var(--green) }
.flash-error   { background:rgba(255,51,85,.06); border-color:rgba(255,51,85,.3); color:var(--red) }
.flash-info    { background:rgba(0,212,255,.06); border-color:rgba(0,212,255,.3); color:var(--cyan) }
.flash-icon    { flex-shrink:0 }
.flash-message { flex:1 }
.flash-close   { background:none; border:none; color:inherit; cursor:pointer; opacity:.6; font-size:.9rem }
.flash-close:hover { opacity:1 }

/* ================================================================
   PAGE HERO (inner pages)
   ================================================================ */
.page-hero {
    padding:120px 0 64px;
    background:linear-gradient(180deg, rgba(0,255,136,.02), transparent);
    border-bottom:1px solid var(--border); text-align:center;
    position:relative; overflow:hidden;
}
.page-hero::before {
    content:''; position:absolute; inset:0;
    background:repeating-linear-gradient(
        0deg, transparent, transparent 3px, rgba(0,0,0,.05) 3px, rgba(0,0,0,.05) 4px
    );
    pointer-events:none;
}
.page-hero-small { padding:100px 0 52px }
.page-hero-content { position:relative }
.page-hero-title { font-family:var(--title); font-size:clamp(2rem,5vw,3.4rem); margin:14px 0 10px; color:var(--text-bright) }
.page-hero p { color:var(--text-2); position:relative; font-size:.95rem }

/* ================================================================
   BLOG LIST PAGE
   ================================================================ */
.blog-list { display:flex; flex-direction:column }
.blog-list-item {
    padding:40px 0; border-bottom:1px solid var(--border); transition:all var(--t) var(--ease);
}
.blog-list-item:hover { padding-left:8px }
.blog-list-meta { font-family:var(--mono); font-size:.72rem; color:var(--text-2); display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:12px }
.blog-list-title { font-family:var(--title); font-size:1.45rem; margin-bottom:12px; line-height:1.3 }
.blog-list-title a { color:var(--text-bright); transition:color var(--t) }
.blog-list-title a:hover { color:var(--green) }
.blog-list-excerpt { color:var(--text-2); max-width:720px; margin-bottom:18px; line-height:1.8 }
.blog-list-footer { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px }
.read-more-link { font-family:var(--mono); font-size:.76rem; color:var(--green-dim); display:inline-flex; align-items:center; gap:6px; transition:all var(--t) var(--ease) }
.read-more-link:hover { color:var(--green); gap:10px }
.pagination-wrapper { margin-top:52px; display:flex; justify-content:center }
.pagination { display:flex; gap:6px; list-style:none; align-items:center }
.pagination li a,
.pagination li span {
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px; font-family:var(--mono); font-size:.78rem;
    border:1px solid var(--border); border-radius:var(--r);
    color:var(--text-2); transition:all var(--t) var(--ease);
}
.pagination li a:hover { border-color:var(--green); color:var(--green); background:var(--green-faint) }
.pagination li.active span { background:var(--green); color:var(--bg); border-color:var(--green) }

/* ================================================================
   BLOG ARTICLE (show page)
   ================================================================ */
.blog-article { padding-top:70px }
.article-header { padding:56px 0 48px; background:linear-gradient(180deg, rgba(0,255,136,.02), transparent); border-bottom:1px solid var(--border); margin-bottom:56px }
.article-featured-img { margin-bottom:36px; border-radius:var(--r); overflow:hidden; border:1px solid var(--border); max-height:440px }
.article-featured-img img { width:100%; object-fit:cover; max-height:440px }
.article-meta-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; flex-wrap:wrap; gap:12px; font-family:var(--mono); font-size:.76rem; color:var(--text-2) }
.back-link { display:inline-flex; align-items:center; gap:6px; color:var(--text-2); transition:all var(--t) }
.back-link:hover { color:var(--green) }
.article-title { font-family:var(--title); font-size:clamp(1.8rem,4.5vw,3rem); margin-bottom:24px; line-height:1.2; color:var(--text-bright) }
.article-meta { display:flex; flex-wrap:wrap; gap:20px; font-family:var(--mono); font-size:.76rem; color:var(--text-2); margin-bottom:20px }
.article-meta i { color:var(--green); margin-right:4px }
.meta-author,.meta-time,.meta-date { display:inline-flex; align-items:center; gap:5px }
.article-tags { display:flex; flex-wrap:wrap; gap:6px }
.article-body { padding-bottom:80px }

/* Prose */
.prose { color:var(--text); line-height:1.95; font-size:1.05rem }
.prose h1,.prose h2,.prose h3,.prose h4 { font-family:var(--title); color:var(--text-bright); margin:2.4rem 0 1rem; letter-spacing:.04em }
.prose h2 { font-size:1.5rem; color:var(--green); border-bottom:1px solid var(--border); padding-bottom:10px }
.prose h3 { font-size:1.2rem; color:var(--cyan) }
.prose p  { margin-bottom:1.25rem }
.prose a  { color:var(--green); text-decoration:underline }
.prose strong { color:var(--text-bright) }
.prose code { font-family:var(--mono); background:var(--bg-3); color:var(--green); padding:2px 7px; border-radius:3px; font-size:.86em; border:1px solid var(--border) }
.prose pre { background:var(--bg-2); border:1px solid var(--border); border-left:3px solid var(--green); border-radius:var(--r); padding:24px; overflow-x:auto; margin:1.8rem 0 }
.prose pre code { background:none; border:none; padding:0; color:var(--green); font-size:.86rem }
.prose blockquote { border-left:3px solid var(--green); padding:14px 22px; color:var(--text-2); font-style:italic; margin:1.8rem 0; background:var(--bg-2); border-radius:0 var(--r) var(--r) 0 }
.prose ul,.prose ol { padding-left:24px; margin-bottom:1.25rem }
.prose li { margin-bottom:6px }
.prose table { width:100%; border-collapse:collapse; margin:1.8rem 0; font-size:.9rem }
.prose th,.prose td { padding:10px 16px; border:1px solid var(--border); text-align:left }
.prose th { background:var(--bg-3); color:var(--green); font-family:var(--mono); font-size:.75rem; letter-spacing:.08em }
.prose hr { border:none; border-top:1px solid var(--border); margin:2.4rem 0 }
.prose img { border-radius:var(--r); border:1px solid var(--border); margin:1rem 0 }

.article-footer { display:flex; justify-content:space-between; align-items:center; padding:28px 0; border-top:1px solid var(--border); flex-wrap:wrap; gap:16px; margin-top:52px }
.share-section { display:flex; align-items:center; gap:10px; font-family:var(--mono); font-size:.78rem; color:var(--text-2) }
.share-btn { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border:1px solid var(--border); border-radius:var(--r); font-size:.9rem; transition:all var(--t) var(--ease) }
.share-btn.twitter { color:#1da1f2 }
.share-btn.twitter:hover { border-color:#1da1f2; background:rgba(29,161,242,.1) }
.share-btn.linkedin { color:#0a66c2 }
.share-btn.linkedin:hover { border-color:#0a66c2; background:rgba(10,102,194,.1) }

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-grid { display:grid; grid-template-columns:1fr 1.35fr; gap:68px; align-items:start }
.contact-info-title { font-family:var(--title); font-size:1.65rem; color:var(--text-bright); margin-bottom:14px; letter-spacing:.04em }
.contact-info > p { color:var(--text-2); margin-bottom:32px; font-size:.95rem; line-height:1.8 }

.contact-details { display:flex; flex-direction:column; gap:10px; margin-bottom:32px }

.contact-detail-item {
    display:flex; gap:16px; align-items:center;
    background:var(--bg-2); border:1px solid var(--border);
    border-radius:8px; padding:16px 18px;
    transition:all var(--t) var(--ease);
}
.contact-detail-link { text-decoration:none; cursor:pointer }
.contact-detail-item:hover { border-color:var(--border-2); transform:translateX(5px); background:var(--bg-3) }

/* Icon box — colour variants */
.detail-icon {
    width:44px; height:44px; border-radius:8px; flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    font-size:1.1rem; border:1px solid;
    transition:all var(--t) var(--ease);
}
.detail-icon            { background:rgba(0,255,136,.08); border-color:rgba(0,255,136,.2); color:var(--green) }
.detail-icon-cyan       { background:rgba(0,212,255,.08); border-color:rgba(0,212,255,.2); color:var(--cyan) }
.detail-icon-amber      { background:rgba(255,179,71,.08); border-color:rgba(255,179,71,.2); color:var(--amber) }
.detail-icon-purple     { background:rgba(167,139,250,.08); border-color:rgba(167,139,250,.2); color:#a78bfa }
.contact-detail-item:hover .detail-icon     { box-shadow:0 0 14px rgba(0,255,136,.25) }
.contact-detail-item:hover .detail-icon-cyan  { box-shadow:0 0 14px rgba(0,212,255,.25) }
.contact-detail-item:hover .detail-icon-amber { box-shadow:0 0 14px rgba(255,179,71,.25) }
.contact-detail-item:hover .detail-icon-purple{ box-shadow:0 0 14px rgba(167,139,250,.25) }

.detail-text { flex:1; min-width:0 }
.detail-text strong { display:block; color:var(--text-bright); font-size:.88rem; margin-bottom:2px; font-weight:600 }
.detail-text span { color:var(--text-2); font-size:.82rem; font-family:var(--mono) }
.detail-arrow { color:var(--text-2); font-size:.75rem; flex-shrink:0; transition:all var(--t) }
.contact-detail-link:hover .detail-arrow { color:var(--green); transform:translateX(3px) }

/* Services list */
.contact-services { margin-bottom:28px }
.contact-services h3 {
    font-size:.88rem; color:var(--text-bright); margin-bottom:16px;
    display:flex; align-items:center; gap:9px; font-family:var(--mono);
    letter-spacing:.06em; text-transform:uppercase;
}
.contact-services h3 i { color:var(--green) }
.contact-services ul { list-style:none; display:flex; flex-direction:column; gap:8px }
.contact-services li {
    font-size:.88rem; color:var(--text-2);
    display:flex; align-items:center; gap:11px;
    padding:6px 0; border-bottom:1px solid rgba(255,255,255,.03);
    transition:color var(--t), padding-left var(--t);
}
.contact-services li:hover { color:var(--text-bright); padding-left:4px }
.service-bullet {
    width:6px; height:6px; border-radius:50%; background:var(--green-dark);
    flex-shrink:0; transition:background var(--t), box-shadow var(--t);
}
.contact-services li:hover .service-bullet { background:var(--green); box-shadow:0 0 6px var(--green) }

/* Social links on contact page */
.contact-socials { }
.contact-socials-label { font-family:var(--mono); font-size:.66rem; letter-spacing:.2em; color:var(--text-2); display:block; margin-bottom:12px; text-transform:uppercase }
.contact-social-links { display:flex; gap:10px }
.contact-social-btn {
    width:42px; height:42px; border:1px solid var(--border); border-radius:8px;
    display:flex; align-items:center; justify-content:center;
    color:var(--text-2); font-size:1rem; transition:all var(--t) var(--ease);
}
.contact-social-btn:hover { color:var(--green); border-color:var(--green); background:var(--green-faint); box-shadow:var(--glow-sm) }

/* Cyber panel */
.cyber-panel {
    background:var(--bg-2); border:1px solid var(--border);
    border-radius:10px; overflow:hidden;
    box-shadow:var(--shadow-md); transition:box-shadow var(--t) var(--ease);
}
.cyber-panel:hover { box-shadow:var(--shadow-md), var(--glow-sm) }
.panel-header {
    background:var(--bg-3); border-bottom:1px solid var(--border);
    padding:13px 20px; display:flex; align-items:center; gap:10px;
    font-family:var(--mono); font-size:.72rem; color:var(--text-2);
}
.panel-title { font-size:.72rem; letter-spacing:.06em }
.panel-indicator { width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); animation:pulse 2s infinite; flex-shrink:0 }
.panel-badge { margin-left:auto; font-size:.6rem; color:var(--green); background:var(--green-faint); border:1px solid var(--border); padding:2px 10px; border-radius:20px; letter-spacing:.1em; display:flex; align-items:center; gap:5px }
.panel-body { padding:28px }

/* ================================================================
   FORMS
   ================================================================ */
.form-group { margin-bottom:18px }
.form-group label { display:block; font-family:var(--mono); font-size:.7rem; color:var(--text-2); margin-bottom:7px; letter-spacing:.12em; text-transform:uppercase }
.form-control {
    width:100%; background:var(--bg-3); border:1px solid var(--border);
    color:var(--text-bright); padding:11px 15px;
    font-family:var(--mono); font-size:.86rem;
    border-radius:var(--r); transition:all var(--t) var(--ease);
    -webkit-appearance:none; appearance:none;
}
.form-control:focus { outline:none; border-color:var(--green-dim); background:rgba(0,255,136,.025); box-shadow:0 0 0 3px rgba(0,255,136,.07) }
.form-control::placeholder { color:rgba(176,190,197,.22) }
textarea.form-control { resize:vertical; min-height:130px; line-height:1.65 }
select.form-control  { cursor:pointer }
.form-control-lg { font-size:1rem; padding:13px 16px }
.form-control-file { color:var(--text-2); font-family:var(--mono); font-size:.8rem; cursor:pointer }
.form-control-file::file-selector-button {
    font-family:var(--mono); font-size:.75rem; padding:6px 14px;
    background:var(--bg-3); color:var(--green); border:1px solid var(--border);
    border-radius:var(--r); cursor:pointer; margin-right:10px;
    transition:all var(--t);
}
.form-control-file::file-selector-button:hover { border-color:var(--green); background:var(--green-faint) }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.form-hint { font-size:.7rem; color:var(--text-2); margin-top:5px; font-style:italic }
.form-footer { padding-top:8px }
.form-note { font-family:var(--mono); font-size:.7rem; color:var(--text-2); display:flex; align-items:center; gap:6px; margin-bottom:14px }
.form-note i { color:var(--green) }
.form-check { display:flex; align-items:center; gap:8px; margin-bottom:16px }
.form-check label { font-size:.85rem; color:var(--text-2); cursor:pointer; text-transform:none; font-family:var(--ui) }
.form-check-inline { display:flex; flex-direction:row; align-items:center; gap:8px; margin-bottom:16px }
.form-check-inline label { text-transform:none; font-family:var(--ui); font-size:.9rem; margin-bottom:0 }
input[type="checkbox"] { width:14px; height:14px; accent-color:var(--green); cursor:pointer }
.form-error, ul.form-error { list-style:none; padding:0 }
li.form-error, .form-error li { color:var(--red); font-size:.73rem; font-family:var(--mono); margin-top:4px }

.range-wrapper { display:flex; align-items:center; gap:12px }
.form-range { width:100%; accent-color:var(--green) }
output { font-family:var(--mono); color:var(--green); font-size:.9rem; min-width:4ch }

/* ================================================================
   EMPTY STATE
   ================================================================ */
.empty-state { text-align:center; padding:80px 20px; color:var(--text-2) }
.empty-state i { font-size:2.6rem; color:var(--green-dark); margin-bottom:16px; display:block }
.empty-state h3 { font-size:1.3rem; margin-bottom:8px; color:var(--text) }
.empty-state p { margin-bottom:20px }

/* ================================================================
   LOGIN
   ================================================================ */
.login-body    { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg); padding:24px }
.login-wrapper { position:relative; z-index:10; width:100%; max-width:440px }
.login-panel {
    background:var(--bg-2); border:1px solid var(--border); border-radius:12px; padding:48px;
    box-shadow:var(--shadow-lg), 0 0 60px rgba(0,255,136,.08); position:relative; overflow:hidden;
}
.login-panel::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, transparent, var(--green), var(--cyan), var(--green), transparent);
    background-size:200% auto; animation:border-flow 4s ease infinite;
}
.login-panel::after {
    content:''; position:absolute; inset:0; pointer-events:none;
    background:radial-gradient(ellipse 80% 50% at 50% -10%, rgba(0,255,136,.06), transparent);
}
.login-header   { text-align:center; margin-bottom:36px; position:relative; z-index:1 }
.login-logo     { font-family:var(--title); font-size:1.35rem; font-weight:700; color:var(--text-bright); text-shadow:0 0 28px rgba(0,255,136,.45); margin-bottom:14px; letter-spacing:.15em }
.login-subtitle { font-family:var(--mono); font-size:.75rem; color:var(--text-2); display:flex; align-items:center; justify-content:center; gap:4px; flex-wrap:wrap }
.login-prompt   { color:var(--green-dim) }
.login-cmd      { color:var(--cyan) }
.login-form     { position:relative; z-index:1 }
.login-error    { background:rgba(255,51,85,.08); border:1px solid rgba(255,51,85,.28); color:var(--red); padding:12px 16px; border-radius:var(--r); font-family:var(--mono); font-size:.8rem; margin-bottom:20px; display:flex; align-items:center; gap:9px }
.login-footer   { display:flex; justify-content:space-between; align-items:center; margin-top:24px; font-family:var(--mono); font-size:.72rem; color:var(--text-2); position:relative; z-index:1 }
.login-footer a { color:var(--text-2); transition:color var(--t); display:flex; align-items:center; gap:5px }
.login-footer a:hover { color:var(--green) }
.login-security-note { display:flex; align-items:center; gap:5px; color:var(--green-dim) }
.login-security-note i { color:var(--green) }

/* ================================================================
   ADMIN LAYOUT
   ================================================================ */
.admin-body   { background:#050810 }
.admin-layout { display:flex; min-height:100vh }

/* Sidebar */
.admin-sidebar {
    width:256px; flex-shrink:0;
    background:var(--bg-2); border-right:1px solid var(--border);
    display:flex; flex-direction:column;
    position:sticky; top:0; height:100vh; overflow-y:auto; z-index:100;
    transition:left var(--t) var(--ease);
}
.sidebar-header {
    padding:18px 20px; border-bottom:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between;
}
.sidebar-logo {
    font-family:var(--title); font-size:.86rem; font-weight:700;
    color:var(--text-bright); text-shadow:0 0 18px rgba(0,255,136,.3);
    letter-spacing:.1em;
}
.sidebar-logo:hover { color:var(--green) }
.sidebar-toggle {
    width:28px; height:28px; background:none; border:1px solid var(--border);
    border-radius:var(--r); color:var(--text-2); cursor:pointer;
    display:flex; align-items:center; justify-content:center; font-size:.8rem;
    transition:all var(--t);
}
.sidebar-toggle:hover { color:var(--green); border-color:var(--green) }

.sidebar-user {
    display:flex; align-items:center; gap:12px;
    padding:14px 20px; border-bottom:1px solid var(--border);
}
.user-avatar {
    width:36px; height:36px; border-radius:50%;
    background:var(--green-faint); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--green); flex-shrink:0; font-size:.9rem;
}
.user-info strong { font-size:.88rem; color:var(--text-bright); display:block }
.user-info span   { font-size:.7rem; color:var(--text-2); font-family:var(--mono) }

.sidebar-nav { flex:1; padding:12px 0 }
.nav-section { margin-bottom:4px }
.nav-section-label {
    font-family:var(--mono); font-size:.62rem; letter-spacing:.22em;
    color:var(--text-2); padding:10px 20px 4px; display:block; text-transform:uppercase;
}
.sidebar-link {
    display:flex; align-items:center; gap:10px; padding:9px 20px;
    font-family:var(--mono); font-size:.8rem; color:var(--text-2);
    transition:all var(--t) var(--ease); border-left:2px solid transparent;
}
.sidebar-link i { width:16px; text-align:center; flex-shrink:0 }
.sidebar-link:hover, .sidebar-link.active {
    color:var(--green); background:var(--green-faint); border-left-color:var(--green);
}
.sidebar-link-danger { color:rgba(255,51,85,.7) }
.sidebar-link-danger:hover { color:var(--red); border-left-color:var(--red); background:rgba(255,51,85,.05) }
.badge-count {
    margin-left:auto; background:var(--green); color:var(--bg);
    font-size:.62rem; padding:2px 7px; border-radius:10px; font-family:var(--mono);
    font-weight:700;
}

/* Admin main */
.admin-main { flex:1; display:flex; flex-direction:column; min-width:0 }

.admin-topbar {
    display:flex; align-items:center; justify-content:space-between;
    padding:0 24px; height:52px;
    background:var(--bg-2); border-bottom:1px solid var(--border);
    position:sticky; top:0; z-index:50;
}
.topbar-left  { display:flex; align-items:center; gap:14px }
.topbar-right { display:flex; align-items:center; gap:10px }
.topbar-toggle {
    width:30px; height:30px; background:none; border:1px solid var(--border);
    border-radius:var(--r); color:var(--text-2); cursor:pointer;
    display:flex; align-items:center; justify-content:center; font-size:.8rem;
    transition:all var(--t);
}
.topbar-toggle:hover { color:var(--green); border-color:var(--green) }
.breadcrumbs { font-family:var(--mono); font-size:.74rem; color:var(--text-2); display:flex; align-items:center; gap:8px }
.breadcrumbs a { color:var(--green-dim) }
.breadcrumbs a:hover { color:var(--green) }
.topbar-time { font-family:var(--mono); font-size:.74rem; color:var(--text-2) }
.topbar-btn {
    width:30px; height:30px; border:1px solid var(--border); border-radius:var(--r);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-2); font-size:.76rem; transition:all var(--t);
}
.topbar-btn:hover { color:var(--green); border-color:var(--green) }

.admin-content { flex:1; padding:28px }

/* Admin page header */
.admin-page-header {
    display:flex; align-items:center; justify-content:space-between;
    margin-bottom:28px; flex-wrap:wrap; gap:16px;
}
.admin-page-header h1 {
    font-family:var(--title); font-size:1.35rem; color:var(--text-bright);
    display:flex; align-items:center; gap:10px; letter-spacing:.04em;
}
.admin-page-header h1 i { color:var(--green) }
.admin-time-note { font-family:var(--mono); font-size:.7rem; color:var(--text-2) }

/* Stats grid */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:14px; margin-bottom:24px }
.stat-card {
    background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r);
    padding:20px 22px; transition:all var(--t) var(--ease); position:relative; overflow:hidden;
    display:flex; flex-direction:column; gap:4px;
}
.stat-card::before {
    content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, var(--green), transparent);
    transform:scaleX(0); transform-origin:left; transition:transform var(--t) var(--ease);
}
.stat-card:hover { border-color:var(--border-2); transform:translateY(-2px) }
.stat-card:hover::before { transform:scaleX(1) }
.stat-card-alert { border-color:rgba(255,51,85,.28) !important }
.stat-card-alert::before { background:linear-gradient(90deg, var(--red), transparent) !important }
.stat-card-icon { font-size:1.4rem; color:var(--green); margin-bottom:6px }
.stat-card-data { display:flex; flex-direction:column }
.stat-card-number { font-family:var(--title); font-size:2rem; color:var(--text-bright); line-height:1 }
.stat-card-label  { font-family:var(--mono); font-size:.68rem; color:var(--text-2); letter-spacing:.08em; margin-top:4px }
.stat-card-sub    { font-size:.76rem; color:var(--text-2) }
.stat-card-link { display:inline-flex; align-items:center; gap:4px; font-family:var(--mono); font-size:.72rem; color:var(--green-dim); margin-top:8px }
.stat-card-link:hover { color:var(--green) }

/* Admin grid */
.admin-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px }

/* Admin panels */
.admin-panel {
    background:var(--bg-2); border:1px solid var(--border);
    border-radius:var(--r); overflow:hidden; margin-bottom:14px;
}
.admin-panel-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:13px 18px; border-bottom:1px solid var(--border); background:var(--bg-3);
}
.admin-panel-header h3 { font-size:.9rem; color:var(--text-bright); display:flex; align-items:center; gap:8px }
.admin-panel-header h3 i { color:var(--green) }
.admin-panel-body { padding:20px }

/* Admin table */
.admin-table { width:100%; border-collapse:collapse }
.admin-table thead tr { border-bottom:1px solid var(--border) }
.admin-table th { font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; color:var(--text-2); text-transform:uppercase; padding:10px 14px; text-align:left }
.admin-table td { padding:12px 14px; color:var(--text); font-size:.87rem; border-bottom:1px solid rgba(255,255,255,.03) }
.admin-table tr:hover td { background:rgba(0,255,136,.02) }
.admin-table-sm td { padding:8px 14px }
.table-link { color:var(--text-bright); font-size:.88rem; transition:color var(--t) }
.table-link:hover { color:var(--green) }
.table-ext-link { color:var(--text-2); font-size:.72rem; margin-left:5px; transition:color var(--t) }
.table-ext-link:hover { color:var(--green) }
.empty-cell { text-align:center; color:var(--text-2); padding:44px; font-style:italic }
.empty-note { color:var(--text-2); font-style:italic; font-size:.88rem; padding:12px 0 }
.empty-note a { color:var(--green) }
.row-unread td { border-left:2px solid var(--green) }

/* Status badges */
.status-badge {
    display:inline-block; font-family:var(--mono); font-size:.65rem;
    padding:2px 9px; border-radius:20px; border:1px solid;
    color:var(--text-2); border-color:var(--border); background:rgba(255,255,255,.02);
    letter-spacing:.06em;
}
.status-published { color:var(--green); border-color:rgba(0,255,136,.3); background:rgba(0,255,136,.05) }
.status-draft     { color:var(--text-2); border-color:var(--border) }

/* Actions */
.actions-cell { white-space:nowrap }
.action-btn {
    display:inline-flex; align-items:center; justify-content:center;
    width:28px; height:28px; border:1px solid var(--border); border-radius:3px;
    background:none; color:var(--text-2); cursor:pointer; font-size:.76rem;
    transition:all var(--t) var(--ease); text-decoration:none; margin-right:2px;
}
.action-btn:hover { border-color:var(--green); color:var(--green); background:var(--green-faint) }
.action-btn-danger:hover { border-color:var(--red); color:var(--red); background:rgba(255,51,85,.07) }
.inline-form { display:inline }

/* Badges */
.badge-yes { color:var(--green); font-size:.9rem }
.badge-no  { color:var(--text-2) }

/* Tech/tag minis */
.tag-mini, .tech-tag-mini {
    font-family:var(--mono); font-size:.63rem; padding:1px 6px;
    border-radius:3px; border:1px solid var(--border); color:var(--text-2); margin:1px;
    display:inline-block;
}

/* Skill mini bar */
.skill-mini-bar { display:inline-block; width:80px; height:4px; background:rgba(255,255,255,.05); border-radius:2px; vertical-align:middle; margin-right:8px; overflow:hidden }
.skill-mini-fill { height:100%; border-radius:2px }

/* Unread indicator */
.unread-indicator {
    display:inline-block; width:7px; height:7px;
    background:var(--green); border-radius:50%; margin-right:7px; animation:pulse 2s infinite;
}

/* Admin form layout */
.admin-form-layout { display:grid; grid-template-columns:1fr 276px; gap:20px; align-items:start }
.admin-form-main   { display:flex; flex-direction:column; gap:14px }
.admin-form-sidebar { display:flex; flex-direction:column; gap:14px }

/* Current image preview */
.current-image { margin-bottom:10px }
.current-image img { width:100%; max-height:160px; object-fit:cover; border:1px solid var(--border); border-radius:var(--r) }
.current-image small { color:var(--text-2); font-size:.7rem; display:block; margin-top:4px }

/* Quick actions */
.quick-actions-panel { }
.quick-actions { display:flex; gap:14px; flex-wrap:wrap; padding:4px }
.quick-action {
    display:flex; flex-direction:column; align-items:center; gap:7px;
    padding:18px 24px; border:1px solid var(--border); border-radius:var(--r);
    color:var(--text-2); transition:all var(--t) var(--ease); text-align:center;
    flex:1; min-width:100px;
}
.quick-action i { font-size:1.3rem; color:var(--green-dark) }
.quick-action span { font-family:var(--mono); font-size:.73rem }
.quick-action:hover { border-color:var(--green); color:var(--green); background:var(--green-faint) }
.quick-action:hover i { color:var(--green) }

/* Contact detail list */
.contact-detail-list { display:grid; grid-template-columns:100px 1fr; gap:6px 14px; margin-bottom:20px; font-size:.88rem }
.contact-detail-list dt { font-family:var(--mono); font-size:.74rem; color:var(--text-2); padding:3px 0 }
.contact-detail-list dd { color:var(--text); padding:3px 0 }
.contact-detail-list a { color:var(--green) }
.message-body {
    background:var(--bg-3); border:1px solid var(--border); border-left:3px solid var(--green);
    padding:18px; border-radius:var(--r); color:var(--text); font-size:.92rem; line-height:1.85; white-space:pre-wrap;
}

/* Form actions */
.form-actions { padding-top:20px; display:flex; gap:12px; align-items:center; flex-wrap:wrap }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1100px) {
    .admin-form-layout { grid-template-columns:1fr 250px }
}

@media (max-width:960px) {
    .admin-grid-2 { grid-template-columns:1fr }
    .about-grid   { grid-template-columns:1fr; gap:52px }
    .contact-grid { grid-template-columns:1fr; gap:44px }
    .about-image-area { max-width:360px; margin:0 auto }
}

@media (max-width:768px) {
    .section { padding:72px 0 }

    /* Mobile nav — pure CSS toggle via checkbox */
    .nav-toggle { display:flex }
    .nav-links {
        display:none;
        position:absolute; top:72px; left:0; right:0;
        flex-direction:column; align-items:stretch;
        background:rgba(7,9,13,.98); backdrop-filter:blur(28px) saturate(180%);
        border-top:1px solid var(--border);
        border-bottom:1px solid var(--border);
        padding:8px 12px 14px; gap:2px;
        z-index:999;
        box-shadow:0 12px 40px rgba(0,0,0,.7);
        order:4;
    }
    /* Show menu when checkbox is checked — NO JavaScript needed */
    .nav-check:checked ~ .nav-links { display:flex }
    /* Also support JS .open class as fallback */
    .nav-links.open { display:flex }
    .nav-link {
        text-align:left; padding:11px 16px; border-radius:var(--r);
        border-color:transparent !important;
    }
    .nav-link:hover, .nav-link.active {
        background:var(--green-faint) !important;
        border-color:var(--border) !important;
        padding-left:22px;
    }
    .nav-link::before { display:none }
    .nav-cta { margin-top:6px }

    /* Layout */
    .footer-grid { grid-template-columns:1fr; gap:28px }
    .admin-form-layout { grid-template-columns:1fr }
    .admin-sidebar { position:fixed; left:-256px; z-index:200; height:100vh }
    .admin-sidebar.open { left:0; box-shadow:4px 0 40px rgba(0,0,0,.85) }
    .stats-grid { grid-template-columns:repeat(2, 1fr) }
    .blog-grid { grid-template-columns:1fr }
    .projects-grid { grid-template-columns:1fr }
    .about-services { grid-template-columns:1fr }
    .hero-stats { max-width:100%; flex-wrap:wrap }
    .stat-divider { display:none }
    .hero-stats .stat-item { min-width:100px; border-top:1px solid var(--border) }
    .hero-stats .stat-item:first-child { border-top:none }
    .hero-tagline-row { font-size:.82rem; padding:8px 14px }
    .cta-box { padding:52px 24px }
    .form-row { grid-template-columns:1fr }
    .deco-ring-1, .deco-ring-2, .deco-ring-3 { display:none }
    .deco-hex { display:none }
}

@media (max-width:480px) {
    .section { padding:56px 0 }
    .container { padding:0 18px }
    .hero { padding:80px 18px 60px }
    .hero-title { font-size:clamp(2.8rem, 15vw, 4.5rem) }
    .hero-badge { font-size:.6rem; padding:5px 14px; gap:6px }
    .badge-status { display:none }
    .badge-separator { display:none }
    .btn-hero { padding:11px 20px; font-size:.78rem }
    .footer-grid { grid-template-columns:1fr; gap:20px }
    .stats-grid { grid-template-columns:1fr 1fr }
    .admin-page-header h1 { font-size:1.1rem }
    .login-panel { padding:32px 24px }
    .hero-tagline-row { max-width:100% }
}

/* ================================================================
   PROFESSIONAL EXTRAS — Convincing UI polish
   ================================================================ */

/* Symfony form error styling */
.form-error { list-style:none; padding:0; margin:0 }
.form-error li,
li.form-error,
.form-error  { color:var(--red); font-size:.72rem; font-family:var(--mono); margin-top:5px; display:flex; align-items:center; gap:5px }
.form-error li::before { content:'\26A0'; font-size:.65rem }
/* Also target Symfony's default rendered errors */
.form-group .text-danger,
.invalid-feedback { color:var(--red); font-size:.72rem; font-family:var(--mono); margin-top:4px }

/* Input invalid state */
.form-control.is-invalid,
.form-control:invalid:not(:placeholder-shown) { border-color:rgba(255,51,85,.5); background:rgba(255,51,85,.03) }

/* Tooltip-style label for form controls */
.form-group:focus-within label { color:var(--green-dim) }

/* Blog read-more arrow animation */
.blog-read-more i,
.read-more-link i { transition:transform var(--t) var(--ease) }
.blog-read-more:hover i,
.read-more-link:hover i { transform:translateX(4px) }

/* Cert badges — refinement */
.cert-badge {
    display:inline-block; font-family:var(--mono); font-size:.65rem;
    padding:4px 12px; border:1px solid var(--border-2); border-radius:20px;
    color:var(--green); background:var(--green-faint); letter-spacing:.1em;
    text-transform:uppercase; margin:3px 2px;
    transition:all var(--t) var(--ease);
}
.cert-badge:hover { border-color:var(--green); box-shadow:var(--glow-sm); transform:translateY(-1px) }

/* About image frame corners */
.about-image-frame { position:relative; border-radius:var(--r); overflow:hidden }
.image-corner {
    position:absolute; width:16px; height:16px; z-index:2;
    border-color:var(--green); border-style:solid; border-width:0;
}
.image-corner.tl { top:8px; left:8px;  border-top-width:2px; border-left-width:2px; border-radius:2px 0 0 0 }
.image-corner.tr { top:8px; right:8px; border-top-width:2px; border-right-width:2px; border-radius:0 2px 0 0 }
.image-corner.bl { bottom:8px; left:8px;  border-bottom-width:2px; border-left-width:2px; border-radius:0 0 0 2px }
.image-corner.br { bottom:8px; right:8px; border-bottom-width:2px; border-right-width:2px; border-radius:0 0 2px 0 }

/* Range slider polish */
input[type="range"] {
    -webkit-appearance:none; appearance:none;
    width:100%; height:4px; border-radius:2px;
    background:var(--bg-3); outline:none; cursor:pointer;
    border:1px solid var(--border);
}
input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance:none; width:16px; height:16px; border-radius:50%;
    background:var(--green); cursor:pointer;
    box-shadow:0 0 8px rgba(0,255,136,.5); border:2px solid var(--bg);
    transition:box-shadow var(--t);
}
input[type="range"]:hover::-webkit-slider-thumb { box-shadow:0 0 14px rgba(0,255,136,.7) }

/* Section CTA */
.section-cta { text-align:center; margin-top:52px }
.section-cta p { font-family:var(--mono); font-size:.78rem; color:var(--text-2); margin-bottom:20px }

/* contact info title */
.contact-info-title { font-family:var(--title); font-size:1.5rem; color:var(--text-bright); margin-bottom:14px; line-height:1.3 }
.contact-info > div:first-child > p { color:var(--text-2); line-height:1.85; margin-bottom:0 }

/* Scrolled nav border glow */
.cyber-nav.scrolled { filter:drop-shadow(0 1px 0 rgba(0,255,136,.08)) }

/* Improve hero stat numbers with counter animation feel */
.stat-number { font-variant-numeric:tabular-nums }

/* Code tag in admin */
code { font-family:var(--mono); font-size:.82em; background:var(--bg-3); color:var(--cyan); padding:1px 6px; border-radius:3px; border:1px solid var(--border) }

/* mt-2 utility used in contact show */
.mt-2 { margin-top:.5rem }

/* Section cta text */
.no-data { color:var(--text-2); font-style:italic; text-align:center; padding:40px 0; grid-column:1/-1 }
.no-data a { color:var(--green) }

/* ================================================================
   USER MANAGEMENT
   ================================================================ */
.user-cell { display:flex; align-items:center; gap:10px }
.user-avatar-sm {
    width:32px; height:32px; border-radius:50%;
    background:var(--green-faint); border:1px solid var(--border-2);
    display:flex; align-items:center; justify-content:center;
    font-size:.8rem; color:var(--green); flex-shrink:0;
}
.badge-you {
    font-family:var(--mono); font-size:.6rem; color:var(--cyan);
    border:1px solid rgba(0,212,255,.35); border-radius:20px;
    padding:1px 7px; letter-spacing:.06em; background:rgba(0,212,255,.06);
}
.role-badge {
    font-family:var(--mono); font-size:.66rem; letter-spacing:.06em;
    padding:3px 10px; border-radius:20px; display:inline-flex; align-items:center; gap:5px;
}
.role-admin { color:var(--green); background:var(--green-faint); border:1px solid var(--border-2) }
.role-user  { color:var(--text-2); background:var(--bg-3); border:1px solid var(--border) }

/* Profile page */
.profile-info-row {
    display:flex; align-items:center; gap:14px;
    padding:10px 0; border-bottom:1px solid var(--border);
}
.profile-info-row:last-of-type { border-bottom:none }
.profile-label {
    font-family:var(--mono); font-size:.72rem; color:var(--text-2);
    min-width:70px; flex-shrink:0;
}
.profile-value { color:var(--text-bright); font-size:.9rem }

/* Form checkbox group (roles) */
.check-group { display:flex; flex-direction:column; gap:8px; padding:6px 0 }
.check-group label { display:flex; align-items:center; gap:8px; cursor:pointer; color:var(--text); font-size:.88rem }
.check-group input[type="checkbox"] {
    width:16px; height:16px; accent-color:var(--green);
    border:1px solid var(--border-2); border-radius:3px; cursor:pointer;
}

/* Form divider */
.form-divider {
    display:flex; align-items:center; gap:12px;
    margin:20px 0 14px; color:var(--text-2);
    font-family:var(--mono); font-size:.72rem; letter-spacing:.1em;
}
.form-divider::before, .form-divider::after {
    content:''; flex:1; height:1px; background:var(--border);
}

/* ================================================================
   MOBILE TOUCH IMPROVEMENTS
   ================================================================ */

/* Ensure touch targets are large enough (44px min) */
@media (max-width:768px) {
    .nav-toggle { width:44px; height:44px }
    .btn { min-height:44px }
    .nav-link { min-height:44px; display:flex; align-items:center }

    /* Prevent text selection on rapid taps */
    .nav-toggle, .sidebar-toggle, .topbar-toggle { -webkit-tap-highlight-color:transparent; user-select:none }

    /* Full-width project/blog cards on small screens */
    .project-card, .blog-card { width:100% }

    /* Stack hero buttons vertically on small screens */
    .hero-cta { flex-direction:column; align-items:center }

    /* Better mobile table wrapping */
    .admin-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch }

    /* Admin panels full-width */
    .admin-panel { border-radius:0; border-left:none; border-right:none }

    /* Improve form usability on mobile */
    .form-control { font-size:16px !important } /* prevent iOS zoom on focus */

    /* Stack form actions */
    .form-actions { flex-direction:column }
    .form-actions .btn { width:100%; justify-content:center }

    /* Improve skills grid */
    .skills-grid { grid-template-columns:1fr }

    /* Better contact form on mobile */
    .contact-grid { gap:32px }

    /* Footer improvements */
    .footer-bottom-row { text-align:center; justify-content:center }
    .footer-contact .social-links { justify-content:center }
}

@media (max-width:480px) {
    /* Hero stat items side by side */
    .hero-stats { gap:0 }
    .stat-item { padding:14px 12px }

    /* Reduce section heading size */
    .section-header h2 { font-size:clamp(1.6rem, 8vw, 2.5rem) }

    /* Blog post content */
    .post-content { font-size:.93rem }

    /* Admin topbar responsive */
    .breadcrumbs { font-size:.72rem }
    .topbar-time  { display:none }

    /* Settings panels */
    .admin-panel { padding:0 }
    .admin-panel-body { padding:16px }
}

/* Improve tap response — remove delay on all interactive elements */
a, button, input, select, textarea, label {
    touch-action: manipulation;
}

/* ================================================================
   PRINT / ACCESSIBILITY
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    .matrix-bg { display:none }
}

/* ================================================================
   SCROLL TO TOP
   ================================================================ */
.scroll-top {
    display:none;
    position:fixed; bottom:28px; right:28px; z-index:9999;
    width:44px; height:44px;
    align-items:center; justify-content:center;
    background:#0c1118;
    border:1px solid rgba(0,255,136,.4);
    border-radius:50%;
    color:#00ff88;
    font-size:.9rem;
    cursor:pointer;
    box-shadow:0 4px 20px rgba(0,0,0,.6);
    transition:background .2s, border-color .2s, box-shadow .2s;
    -webkit-tap-highlight-color:transparent;
}
.scroll-top.visible {
    display:flex;
}
.scroll-top:hover {
    background:#00ff88;
    color:#050810;
    border-color:#00ff88;
    box-shadow:0 4px 24px rgba(0,0,0,.5), 0 0 12px rgba(0,255,136,.4);
}
.scroll-top:active { transform:scale(.92) }

@media (max-width:768px) {
    .scroll-top { bottom:18px; right:16px; width:40px; height:40px; font-size:.8rem }
}

/* Mobile footer-bottom stack */
@media (max-width:600px) {
    .footer-bottom-row { flex-direction:column; text-align:center; gap:8px }
}
