/* ═══════════════════════════════════════
   DEVOPS ARG v3 — SYS.OVERRIDE
   Corrupted OS / Cyberpunk Terminal
   ═══════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Share+Tech+Mono&family=Silkscreen:wght@400;700&display=swap');

:root {
    --void:      #0a0a12;
    --void-up:   #11111d;
    --phosphor:  #39FF14;
    --plasma:    #FF2D6B;
    --cyber:     #00D4FF;
    --amber:     #FFB000;
    --ultra:     #BF40FF;
    --text:      #C8C8D0;
    --text-dim:  #5A5A6E;
    --border:    #2A2A3C;
    --font-d:    'Orbitron', sans-serif;
    --font-m:    'Share Tech Mono', monospace;
    --font-p:    'Silkscreen', cursive;
}

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

html { scroll-behavior: smooth; }

body {
    font-family: var(--font-m);
    background: var(--void);
    color: var(--text);
    overflow-x: hidden;
    line-height: 1.6;
}

::selection {
    background: var(--plasma);
    color: #000;
}

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--void); }
::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: var(--phosphor); }

/* ═══════ UTILITY COLORS ═══════ */

.c-green  { color: var(--phosphor); }
.c-pink   { color: var(--plasma); }
.c-cyan   { color: var(--cyber); }
.c-amber  { color: var(--amber); }
.c-ultra  { color: var(--ultra); }

/* ═══════ BACKGROUND LAYERS ═══════ */

#gridCanvas {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0.25;
}

.noise {
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: 0.035;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 256px 256px;
    animation: noiseShift 0.3s steps(3) infinite;
}

@keyframes noiseShift {
    0%   { transform: translate(0, 0); }
    33%  { transform: translate(-30px, -20px); }
    66%  { transform: translate(20px, 10px); }
    100% { transform: translate(-10px, 30px); }
}

.scanlines {
    position: fixed;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: repeating-linear-gradient(
        0deg,
        transparent 0px,
        rgba(0, 0, 0, 0.15) 1px,
        transparent 2px,
        transparent 4px
    );
    opacity: 0.4;
}

.vignette {
    position: fixed;
    inset: 0;
    z-index: 3;
    pointer-events: none;
    background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.7) 100%);
}

/* ═══════ BOOT OVERLAY ═══════ */

.boot {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: #000;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 2rem;
    transition: opacity 0.8s ease, visibility 0.8s ease;
}

.boot.done {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.boot__log {
    font-family: var(--font-m);
    font-size: clamp(0.7rem, 1.5vw, 0.95rem);
    color: var(--phosphor);
    max-width: 600px;
    width: 100%;
    line-height: 1.8;
    white-space: pre-wrap;
    text-shadow: 0 0 8px var(--phosphor);
    min-height: 200px;
}

.boot__bar-track {
    max-width: 400px;
    width: 100%;
    height: 6px;
    background: var(--border);
    border-radius: 3px;
    margin-top: 2rem;
    overflow: hidden;
}

.boot__bar-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--phosphor), var(--cyber));
    border-radius: 3px;
    transition: width 0.3s ease;
    box-shadow: 0 0 12px var(--phosphor);
}

.boot__skip {
    margin-top: 1.5rem;
    font-family: var(--font-p);
    font-size: 0.7rem;
    color: var(--text-dim);
    cursor: pointer;
    letter-spacing: 0.1em;
    transition: color 0.2s;
}

.boot__skip:hover { color: var(--phosphor); }

/* ═══════ DESKTOP / MAIN ═══════ */

.desktop {
    position: relative;
    z-index: 5;
    max-width: 1000px;
    margin: 0 auto;
    padding: 3rem 1.5rem 0;
    display: flex;
    flex-direction: column;
    gap: 4rem;
}

/* ═══════ WINDOW COMPONENT ═══════ */

.win {
    background: rgba(10, 10, 18, 0.85);
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    backdrop-filter: blur(8px);
    box-shadow:
        0 4px 30px rgba(0,0,0,0.5),
        0 0 1px var(--border);
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s ease, transform 0.8s ease, box-shadow 0.3s ease;
}

.win.visible {
    opacity: 1;
    transform: translateY(0);
}

.win:hover {
    box-shadow:
        0 4px 30px rgba(0,0,0,0.5),
        0 0 40px rgba(57,255,20,0.06),
        0 0 1px var(--phosphor);
}

.win__bar {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 1.2rem;
    background: var(--void-up);
    border-bottom: 1px solid var(--border);
}

.win__dots {
    display: flex;
    gap: 6px;
}

.dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: block;
}

.dot--r { background: #ff5f56; box-shadow: 0 0 6px #ff5f56; }
.dot--y { background: #ffbd2e; box-shadow: 0 0 6px #ffbd2e; }
.dot--g { background: var(--phosphor); box-shadow: 0 0 6px var(--phosphor); }

.win__title {
    font-family: var(--font-m);
    font-size: 0.85rem;
    color: var(--text-dim);
    letter-spacing: 0.05em;
}

.win__body {
    padding: 2rem;
}

/* ═══════ HERO ═══════ */

.hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 4rem 2rem;
    min-height: 70vh;
    justify-content: center;
}

.hero__logo {
    width: clamp(140px, 25vw, 220px);
    height: auto;
    margin-bottom: 2rem;
    filter:
        drop-shadow(0 0 30px rgba(57,255,20,0.4))
        drop-shadow(0 0 60px rgba(0,212,255,0.2));
    animation: logoFloat 6s ease-in-out infinite, logoHue 20s linear infinite;
    cursor: pointer;
    transition: transform 0.3s ease;
}

.hero__logo:hover {
    transform: scale(1.08) rotate(3deg);
}

@keyframes logoFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-15px); }
}

@keyframes logoHue {
    0%   { filter: hue-rotate(0deg) drop-shadow(0 0 30px rgba(57,255,20,0.4)); }
    50%  { filter: hue-rotate(40deg) drop-shadow(0 0 30px rgba(0,212,255,0.4)); }
    100% { filter: hue-rotate(0deg) drop-shadow(0 0 30px rgba(57,255,20,0.4)); }
}

.hero__name {
    font-family: var(--font-d);
    font-weight: 900;
    font-size: clamp(2.5rem, 8vw, 5rem);
    letter-spacing: 0.08em;
    line-height: 1.1;
    margin-bottom: 1.5rem;
}

.hero__d {
    background: linear-gradient(135deg, var(--phosphor), var(--cyber));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: none;
}

.hero__sep {
    color: var(--plasma);
    -webkit-text-fill-color: var(--plasma);
    animation: sepBlink 2s step-end infinite;
}

@keyframes sepBlink {
    0%, 49% { opacity: 1; }
    50%, 100% { opacity: 0; }
}

.hero__a {
    background: linear-gradient(135deg, var(--plasma), var(--amber));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: none;
}

.hero__tagline {
    font-family: var(--font-m);
    font-size: clamp(1rem, 2.5vw, 1.4rem);
    color: var(--amber);
    letter-spacing: 0.3em;
    text-shadow: 0 0 15px var(--amber);
    min-height: 2em;
}

.hero__scroll {
    margin-top: 3rem;
    font-family: var(--font-p);
    font-size: 0.7rem;
    color: var(--text-dim);
    letter-spacing: 0.15em;
    animation: scrollPulse 3s ease-in-out infinite;
}

@keyframes scrollPulse {
    0%, 100% { opacity: 0.5; transform: translateY(0); }
    50% { opacity: 1; transform: translateY(8px); }
}

.blink {
    animation: blinkCursor 1s step-end infinite;
}

@keyframes blinkCursor {
    0%, 49% { opacity: 1; }
    50%, 100% { opacity: 0; }
}

/* ═══════ MARQUEE ═══════ */

.marquee {
    overflow: hidden;
    padding: 1rem 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    background: rgba(10,10,18,0.6);
    position: relative;
}

.marquee::before,
.marquee::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 80px;
    z-index: 2;
    pointer-events: none;
}

.marquee::before {
    left: 0;
    background: linear-gradient(90deg, var(--void), transparent);
}

.marquee::after {
    right: 0;
    background: linear-gradient(-90deg, var(--void), transparent);
}

.marquee__track {
    display: flex;
    gap: 2rem;
    white-space: nowrap;
    animation: marqueeScroll 30s linear infinite;
    font-family: var(--font-d);
    font-size: clamp(0.8rem, 1.5vw, 1.1rem);
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--text-dim);
}

.marquee__track span {
    flex-shrink: 0;
}

.marquee__dot {
    color: var(--plasma);
    font-size: 0.6em;
}

@keyframes marqueeScroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

/* ═══════ SERVICES (ls -la) ═══════ */

.srv-head {
    display: grid;
    grid-template-columns: 100px 40px 70px 1fr;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    font-family: var(--font-p);
    font-size: 0.65rem;
    color: var(--text-dim);
    letter-spacing: 0.1em;
    border-bottom: 1px solid var(--border);
    margin-bottom: 0.5rem;
}

.srv {
    border-bottom: 1px solid rgba(42,42,60,0.5);
    transition: background 0.2s;
}

.srv:last-child { border-bottom: none; }

.srv summary {
    display: grid;
    grid-template-columns: 100px 40px 70px 1fr;
    gap: 0.5rem;
    padding: 0.8rem 1rem;
    cursor: pointer;
    list-style: none;
    font-size: 0.9rem;
    transition: background 0.2s, color 0.2s;
    align-items: center;
}

.srv summary::-webkit-details-marker { display: none; }

.srv summary:hover {
    background: rgba(57,255,20,0.04);
}

.srv[data-accent="1"] summary:hover { background: rgba(57,255,20,0.06); }
.srv[data-accent="2"] summary:hover { background: rgba(0,212,255,0.06); }
.srv[data-accent="3"] summary:hover { background: rgba(191,64,255,0.06); }
.srv[data-accent="4"] summary:hover { background: rgba(255,45,107,0.06); }
.srv[data-accent="5"] summary:hover { background: rgba(255,176,0,0.06); }
.srv[data-accent="6"] summary:hover { background: rgba(57,255,20,0.06); }
.srv[data-accent="7"] summary:hover { background: rgba(0,212,255,0.06); }
.srv[data-accent="8"] summary:hover { background: rgba(191,64,255,0.06); }

.srv__perm { color: var(--text-dim); font-size: 0.75rem; }
.srv__id   { color: var(--amber); font-weight: bold; }
.srv__own  { color: var(--cyber); }

.srv__name {
    color: var(--phosphor);
    font-weight: bold;
}

.srv__name i { font-style: normal; margin-left: 0.5rem; }

.srv[data-accent="1"] .srv__name { color: var(--phosphor); }
.srv[data-accent="2"] .srv__name { color: var(--cyber); }
.srv[data-accent="3"] .srv__name { color: var(--ultra); }
.srv[data-accent="4"] .srv__name { color: var(--plasma); }
.srv[data-accent="5"] .srv__name { color: var(--amber); }
.srv[data-accent="6"] .srv__name { color: var(--phosphor); }
.srv[data-accent="7"] .srv__name { color: var(--cyber); }
.srv[data-accent="8"] .srv__name { color: var(--ultra); }

.srv__detail {
    padding: 1rem 1rem 1.5rem;
    padding-left: calc(100px + 40px + 70px + 2.5rem);
    border-top: 1px dashed var(--border);
    animation: slideDown 0.3s ease;
}

@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to   { opacity: 1; transform: translateY(0); }
}

.srv__detail h4 {
    font-family: var(--font-d);
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: #fff;
}

.srv__detail p {
    color: var(--text);
    font-size: 0.9rem;
    margin-bottom: 1rem;
    line-height: 1.7;
}

.tags {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.tags span {
    font-family: var(--font-p);
    font-size: 0.6rem;
    padding: 0.35rem 0.8rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--text-dim);
    letter-spacing: 0.1em;
    transition: all 0.2s;
}

.tags span:hover {
    border-color: var(--phosphor);
    color: var(--phosphor);
    box-shadow: 0 0 10px rgba(57,255,20,0.2);
}

/* ═══════ ABOUT / NEOFETCH ═══════ */

.about {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 2rem;
    align-items: start;
}

.about__ascii {
    display: flex;
    align-items: center;
}

.about__ascii pre {
    font-family: var(--font-m);
    font-size: clamp(0.5rem, 1.2vw, 0.75rem);
    color: var(--cyber);
    text-shadow: 0 0 10px rgba(0,212,255,0.3);
    line-height: 1.3;
    animation: asciiGlow 4s ease-in-out infinite;
}

@keyframes asciiGlow {
    0%, 100% { text-shadow: 0 0 10px rgba(0,212,255,0.2); }
    50% { text-shadow: 0 0 20px rgba(0,212,255,0.5), 0 0 40px rgba(57,255,20,0.1); }
}

.about__info {
    font-size: 0.9rem;
    line-height: 1.8;
    overflow: hidden;
    min-width: 0;
}

.about__line {
    margin-bottom: 0.15rem;
    word-break: break-word;
    overflow-wrap: break-word;
}

.about__sep {
    color: var(--border);
    margin: 0.4rem 0;
}

.about__certs {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin: 0.5rem 0;
}

.cert {
    font-size: 0.8rem;
    padding: 0.3rem 0.6rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 6px;
    transition: all 0.2s;
}

.cert:hover {
    border-color: var(--amber);
    box-shadow: 0 0 12px rgba(255,176,0,0.2);
    transform: translateY(-2px);
}

.about__colors {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.about__colors span {
    width: 20px;
    height: 20px;
    border-radius: 4px;
    display: block;
}

/* ═══════ ABOUT PROSE ═══════ */

.about-prose {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 1rem;
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.about-prose.visible {
    opacity: 1;
    transform: translateY(0);
}

.about-prose p {
    font-size: clamp(1rem, 2vw, 1.2rem);
    line-height: 1.9;
    margin-bottom: 1.5rem;
    color: var(--text);
    padding-left: 1.5rem;
    border-left: 3px solid var(--border);
    transition: border-color 0.3s;
}

.about-prose p:nth-child(1) { border-left-color: var(--phosphor); }
.about-prose p:nth-child(2) { border-left-color: var(--cyber); }
.about-prose p:nth-child(3) { border-left-color: var(--plasma); }

.about-prose strong {
    color: var(--phosphor);
    text-shadow: 0 0 8px rgba(57,255,20,0.3);
}

/* ═══════ STATS / HTOP ═══════ */

.stats {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.stat {
    display: grid;
    grid-template-columns: 140px 1fr 60px;
    gap: 1rem;
    align-items: center;
}

.stat__label {
    font-family: var(--font-p);
    font-size: 0.6rem;
    color: var(--text-dim);
    letter-spacing: 0.1em;
    text-align: right;
}

.stat__bar {
    height: 18px;
    background: rgba(255,255,255,0.05);
    border-radius: 2px;
    overflow: hidden;
    border: 1px solid var(--border);
}

.stat__fill {
    height: 100%;
    width: 0%;
    border-radius: 1px;
    transition: width 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
}

.stat__fill::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15));
}

.stat__val {
    font-family: var(--font-d);
    font-size: 0.85rem;
    font-weight: 700;
    color: #fff;
    text-align: right;
}

/* ═══════ CONTACT ═══════ */

.contact__intro {
    margin-bottom: 2rem;
    font-size: 1rem;
    line-height: 2;
}

.contact__intro p {
    color: var(--text);
}

.field {
    margin-bottom: 1.2rem;
}

.field label {
    display: block;
    font-size: 0.9rem;
    margin-bottom: 0.4rem;
    color: var(--text);
}

.field input,
.field textarea {
    width: 100%;
    font-family: var(--font-m);
    font-size: 1rem;
    padding: 0.8rem 1rem;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--phosphor);
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s, background 0.3s;
}

.field input:focus,
.field textarea:focus {
    border-color: var(--phosphor);
    background: rgba(57,255,20,0.03);
    box-shadow: 0 0 20px rgba(57,255,20,0.1);
}

.field textarea { resize: vertical; }

.btn-submit {
    font-family: var(--font-m);
    font-size: 1rem;
    padding: 1rem 2rem;
    background: transparent;
    border: 2px solid var(--phosphor);
    border-radius: 6px;
    color: var(--phosphor);
    cursor: pointer;
    letter-spacing: 0.1em;
    transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    text-shadow: 0 0 8px rgba(57,255,20,0.3);
    width: 100%;
    margin-top: 0.5rem;
}

.btn-submit:hover {
    background: var(--phosphor);
    color: var(--void);
    box-shadow: 0 0 30px rgba(57,255,20,0.4);
    transform: scale(1.02);
    text-shadow: none;
}

.btn-submit:active {
    transform: scale(0.98);
}

/* ═══════ TASKBAR / FOOTER ═══════ */

.taskbar {
    margin-top: 2rem;
    padding: 2rem 0;
    border-top: 1px solid var(--border);
}

.taskbar__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.taskbar__brand {
    font-family: var(--font-d);
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--phosphor);
    text-shadow: 0 0 10px rgba(57,255,20,0.3);
}

.taskbar__links {
    display: flex;
    gap: 1.5rem;
}

.taskbar__links a {
    font-family: var(--font-p);
    font-size: 0.65rem;
    color: var(--text-dim);
    text-decoration: none;
    letter-spacing: 0.1em;
    transition: color 0.2s, text-shadow 0.2s;
    padding: 0.3rem;
}

.taskbar__links a:hover {
    color: var(--cyber);
    text-shadow: 0 0 10px rgba(0,212,255,0.4);
}

.taskbar__clock {
    font-family: var(--font-m);
    font-size: 0.85rem;
    color: var(--amber);
    text-shadow: 0 0 8px rgba(255,176,0,0.3);
}

.taskbar__bottom {
    text-align: center;
    color: var(--text-dim);
    font-size: 0.8rem;
}

.taskbar__quote {
    margin-top: 0.5rem;
    font-style: italic;
    color: var(--border);
    font-size: 0.75rem;
}

/* ═══════ GLITCH EFFECT (applied via JS) ═══════ */

.glitch-flash {
    animation: glitchFlash 0.15s linear;
}

@keyframes glitchFlash {
    0%   { filter: hue-rotate(0deg) brightness(1); transform: translate(0) skewX(0); }
    20%  { filter: hue-rotate(90deg) brightness(1.8); transform: translate(-4px, 3px) skewX(-2deg); }
    40%  { filter: hue-rotate(200deg) brightness(0.6) saturate(3); transform: translate(5px, -2px) skewX(3deg); }
    60%  { filter: hue-rotate(300deg) brightness(1.4) contrast(1.5); transform: translate(-2px, 1px) skewX(-1deg); }
    80%  { filter: hue-rotate(120deg) brightness(2); transform: translate(3px, -3px) skewX(2deg); }
    100% { filter: hue-rotate(0deg) brightness(1); transform: translate(0) skewX(0); }
}

/* ═══════ CHROMATIC ABERRATION ═══════ */

.chromatic-hit {
    animation: chromaSplit 0.3s ease-out;
}

@keyframes chromaSplit {
    0%   { text-shadow: 0 0 0 transparent; }
    30%  { text-shadow: -3px 0 var(--plasma), 3px 0 var(--cyber), 0 2px var(--phosphor); }
    60%  { text-shadow: 2px 0 var(--cyber), -2px 0 var(--plasma), 0 -1px var(--ultra); }
    100% { text-shadow: 0 0 0 transparent; }
}

/* ═══════ SCREEN TEAR ═══════ */

.screen-tear {
    position: fixed;
    left: 0;
    width: 100%;
    height: 3px;
    z-index: 9998;
    pointer-events: none;
    background: linear-gradient(90deg, var(--phosphor), var(--cyber), var(--plasma), var(--ultra));
    opacity: 0;
    animation: tearFlash 0.12s linear forwards;
}

@keyframes tearFlash {
    0%   { opacity: 0.9; }
    100% { opacity: 0; }
}

/* ═══════ CURSOR TRAIL ═══════ */

.cursor-particle {
    position: fixed;
    pointer-events: none;
    z-index: 9997;
    border-radius: 50%;
    mix-blend-mode: screen;
    animation: cursorFade 0.8s ease-out forwards;
}

@keyframes cursorFade {
    0%   { transform: scale(1); opacity: 0.8; }
    100% { transform: scale(0); opacity: 0; }
}

/* ═══════ CORRUPTED TEXT ═══════ */

.text-corrupt {
    animation: textCorrupt 0.15s steps(2) infinite;
}

@keyframes textCorrupt {
    0%   { clip-path: inset(0 0 85% 0); transform: translate(-2px, 0); }
    25%  { clip-path: inset(40% 0 30% 0); transform: translate(2px, 0); }
    50%  { clip-path: inset(80% 0 0 0); transform: translate(-1px, 0); }
    75%  { clip-path: inset(20% 0 60% 0); transform: translate(3px, 0); }
    100% { clip-path: inset(0); transform: translate(0); }
}

/* ═══════ RANDOM WOBBLE ═══════ */

.wobble {
    animation: wobbleDrunk 4s ease-in-out infinite;
}

@keyframes wobbleDrunk {
    0%, 100% { transform: rotate(0deg) scale(1); }
    25%  { transform: rotate(0.3deg) scale(1.002); }
    50%  { transform: rotate(-0.2deg) scale(0.998); }
    75%  { transform: rotate(0.15deg) scale(1.001); }
}

/* ═══════ ACID BACKGROUND PULSE ═══════ */

.acid-bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.5s;
    background: radial-gradient(ellipse at var(--mx, 50%) var(--my, 50%),
        rgba(191, 64, 255, 0.06) 0%,
        rgba(0, 212, 255, 0.03) 30%,
        transparent 70%);
}

/* ═══════ FLOATING SYMBOLS ═══════ */

.float-symbol {
    position: fixed;
    pointer-events: none;
    z-index: 4;
    font-family: var(--font-m);
    color: var(--phosphor);
    opacity: 0;
    animation: floatUp 8s linear forwards;
    text-shadow: 0 0 6px currentColor;
}

@keyframes floatUp {
    0%   { opacity: 0; transform: translateY(0) rotate(0deg); }
    10%  { opacity: 0.3; }
    90%  { opacity: 0.1; }
    100% { opacity: 0; transform: translateY(-100vh) rotate(180deg); }
}

/* ═══════ INTERACTIVE TERMINAL (inside hero) ═══════ */

.hero-term {
    width: 100%;
    max-width: 650px;
    margin: 2rem auto 0;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(6px);
    overflow: hidden;
    text-align: left;
}

.term__output {
    padding: 1rem 1.2rem;
    font-size: 0.85rem;
    line-height: 1.8;
    max-height: 260px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--phosphor) transparent;
}

.term__output::-webkit-scrollbar { width: 5px; }
.term__output::-webkit-scrollbar-track { background: transparent; }
.term__output::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

.term__line {
    margin-bottom: 0.3rem;
}

.term__prompt {
    color: var(--plasma);
    font-weight: bold;
    user-select: none;
}

.term__pulse {
    animation: termPulse 2s ease-in-out infinite;
    color: var(--phosphor);
}

@keyframes termPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

.term__input-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.8rem 1.5rem;
    border-top: 1px solid var(--border);
    background: rgba(0,0,0,0.3);
}

.term__input {
    flex: 1;
    font-family: var(--font-m);
    font-size: 0.95rem;
    background: transparent;
    border: none;
    color: var(--phosphor);
    outline: none;
    caret-color: var(--phosphor);
}

.term__input::placeholder {
    color: var(--text-dim);
    font-style: italic;
}

.term__cmd-output {
    margin: 0.3rem 0 0.8rem;
    padding-left: 2rem;
}

.term__cmd-output p {
    margin: 0.15rem 0;
}

/* ═══════ AI AGENTS SECTION ═══════ */

.ai {
    padding: 2rem !important;
}

.ai__header {
    text-align: center;
    margin-bottom: 2.5rem;
}

.ai__title {
    font-family: var(--font-d);
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    font-weight: 900;
    letter-spacing: 0.1em;
    background: linear-gradient(135deg, var(--cyber), var(--ultra), var(--plasma));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 0.5rem;
}

.ai__sub {
    color: var(--text-dim);
    font-size: 0.95rem;
    letter-spacing: 0.05em;
}

.ai__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}

.ai__card {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 1.5rem;
    position: relative;
    transition: all 0.3s ease;
    overflow: hidden;
}

.ai__card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 10px;
    padding: 1px;
    background: linear-gradient(135deg, transparent 40%, var(--cyber) 50%, transparent 60%);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: 0;
    transition: opacity 0.4s;
}

.ai__card:hover::before {
    opacity: 1;
}

.ai__card:hover {
    border-color: var(--cyber);
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 212, 255, 0.1);
}

.ai__card[data-agent="incident"]:hover { border-color: var(--plasma); box-shadow: 0 8px 30px rgba(255,45,107,0.1); }
.ai__card[data-agent="incident"]:hover::before { background: linear-gradient(135deg, transparent 40%, var(--plasma) 50%, transparent 60%); }

.ai__card[data-agent="cost"]:hover { border-color: var(--amber); box-shadow: 0 8px 30px rgba(255,176,0,0.1); }
.ai__card[data-agent="cost"]:hover::before { background: linear-gradient(135deg, transparent 40%, var(--amber) 50%, transparent 60%); }

.ai__card[data-agent="security"]:hover { border-color: var(--phosphor); box-shadow: 0 8px 30px rgba(57,255,20,0.1); }
.ai__card[data-agent="security"]:hover::before { background: linear-gradient(135deg, transparent 40%, var(--phosphor) 50%, transparent 60%); }

.ai__card[data-agent="deploy"]:hover { border-color: var(--ultra); box-shadow: 0 8px 30px rgba(191,64,255,0.1); }
.ai__card[data-agent="deploy"]:hover::before { background: linear-gradient(135deg, transparent 40%, var(--ultra) 50%, transparent 60%); }

.ai__card[data-agent="chat"]:hover { border-color: var(--amber); box-shadow: 0 8px 30px rgba(255,176,0,0.1); }
.ai__card[data-agent="chat"]:hover::before { background: linear-gradient(135deg, transparent 40%, var(--amber) 50%, transparent 60%); }

.ai__card-status {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    color: var(--phosphor);
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.ai__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    display: inline-block;
}

.ai__dot--live {
    background: var(--phosphor);
    box-shadow: 0 0 8px var(--phosphor);
    animation: aiPulse 2s ease-in-out infinite;
}

@keyframes aiPulse {
    0%, 100% { opacity: 1; box-shadow: 0 0 8px var(--phosphor); }
    50% { opacity: 0.4; box-shadow: 0 0 2px var(--phosphor); }
}

.ai__card-icon {
    font-size: 2.2rem;
    margin-bottom: 0.8rem;
    line-height: 1;
}

.ai__card-name {
    font-family: var(--font-d);
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.03em;
    margin-bottom: 0.6rem;
}

.ai__card-desc {
    font-size: 0.82rem;
    color: var(--text);
    line-height: 1.7;
    margin-bottom: 1rem;
}

.ai__card-stats {
    display: flex;
    gap: 1.2rem;
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-bottom: 0.8rem;
    flex-wrap: wrap;
}

.ai__card .tags {
    margin-top: auto;
}

.ai__footer {
    border-top: 1px solid var(--border);
    padding-top: 1.5rem;
    text-align: center;
}

.ai__footer-line {
    font-size: 0.85rem;
    color: var(--text-dim);
    margin-bottom: 0.4rem;
    line-height: 1.6;
}

/* ═══════ RESPONSIVE ═══════ */

@media (max-width: 768px) {
    .desktop {
        padding: 1.5rem 0.8rem 0;
        gap: 2.5rem;
    }

    .win { border-radius: 8px; }
    .win__body { padding: 1.2rem; }
    .win__bar { padding: 0.6rem 1rem; gap: 0.6rem; }
    .win__title { font-size: 0.75rem; }
    .dot { width: 10px; height: 10px; }

    /* Hero */
    .hero { min-height: auto; padding: 2rem 1rem; }
    .hero__logo { width: clamp(100px, 35vw, 160px); margin-bottom: 1.5rem; }
    .hero__name { font-size: clamp(1.8rem, 10vw, 3.5rem); margin-bottom: 1rem; }
    .hero__tagline { font-size: clamp(0.75rem, 2.5vw, 1rem); letter-spacing: 0.12em; }
    .hero__scroll { font-size: 0.65rem; margin-top: 1.5rem; }

    /* Terminal in hero */
    .hero-term { max-width: 100%; margin: 1.5rem auto 0; }
    .term__output { max-height: 180px; font-size: 0.75rem; padding: 0.8rem; line-height: 1.6; }
    .term__output pre { font-size: 0.65rem; overflow-x: auto; }
    .term__input-row { padding: 0.6rem 0.8rem; }
    .term__input { font-size: 16px; }
    .term__prompt { font-size: 0.8rem; }

    /* Marquee */
    .marquee__track { font-size: 0.75rem; }
    .marquee__dot { margin: 0 0.8rem; }

    /* Services */
    .srv-head { grid-template-columns: 30px 1fr; }
    .srv-head span:nth-child(1),
    .srv-head span:nth-child(3) { display: none; }
    .srv summary { grid-template-columns: 30px 1fr; font-size: 0.85rem; }
    .srv__perm, .srv__own { display: none; }
    .srv__id { font-size: 0.7rem; }
    .srv__detail { padding-left: 0.5rem; }
    .srv__detail h4 { font-size: 0.9rem; }
    .srv__detail p { font-size: 0.78rem; }

    /* Tags overflow */
    .tags { flex-wrap: wrap; gap: 0.3rem; }
    .tags span { font-size: 0.6rem; padding: 0.2rem 0.5rem; }

    /* AI Agents */
    .ai { padding: 1.2rem !important; }
    .ai__header { margin-bottom: 1.5rem; }
    .ai__title { font-size: clamp(1.4rem, 6vw, 2rem); }
    .ai__sub { font-size: 0.8rem; }
    .ai__grid { grid-template-columns: 1fr; gap: 1rem; }
    .ai__card { padding: 1.2rem; }
    .ai__card:hover { transform: none; }
    .ai__card-icon { font-size: 1.8rem; }
    .ai__card-name { font-size: 0.85rem; }
    .ai__card-desc { font-size: 0.78rem; line-height: 1.6; }
    .ai__card-stats { font-size: 0.7rem; gap: 0.8rem; }
    .ai__footer { padding-top: 1rem; }
    .ai__footer-line { font-size: 0.75rem; }

    /* About / Neofetch */
    .about { grid-template-columns: 1fr; gap: 1rem; }
    .about__ascii { display: none; }
    .about__info { font-size: 0.8rem; }
    .about__line { font-size: 0.78rem; line-height: 1.6; word-break: break-word; }
    .about__sep { font-size: 0.7rem; }
    .about__certs { gap: 0.4rem; }
    .cert { font-size: 0.65rem; padding: 0.25rem 0.5rem; }

    /* About prose */
    .about-prose { padding: 1.5rem 1rem; }
    .about-prose p { font-size: 0.85rem; line-height: 1.7; }

    /* Stats */
    .stat { grid-template-columns: 1fr 50px; }
    .stat__label { grid-column: 1 / -1; text-align: left; margin-bottom: -0.6rem; font-size: 0.7rem; }
    .stat__val { font-size: 0.7rem; }

    /* Contact */
    .contact-intro p { font-size: 0.85rem; }
    .field label { font-size: 0.8rem; }
    .field input, .field textarea { font-size: 16px; padding: 0.7rem; }
    .btn-submit { font-size: 0.85rem; padding: 0.8rem; }

    /* Taskbar */
    .taskbar { padding: 1rem; }
    .taskbar__row { flex-direction: column; text-align: center; gap: 0.8rem; }
    .taskbar__logo { font-size: 0.8rem; }
    .taskbar__links { gap: 0.8rem; font-size: 0.7rem; }
    .taskbar__clock { font-size: 0.7rem; }
    .taskbar__copy { font-size: 0.65rem; }
    .taskbar__quote { font-size: 0.6rem; }

    /* Reduce visual effects on mobile */
    .scanlines { opacity: 0.15; }
    .noise { opacity: 0.015; }
    .vignette { display: none; }
    .acid-bg { display: none; }
    .float-symbol { display: none; }
    .screen-tear { display: none; }
}

@media (max-width: 480px) {
    .desktop {
        padding: 0.8rem 0.4rem 0;
        gap: 1.8rem;
    }

    .win__body { padding: 1rem; }
    .win__bar { padding: 0.5rem 0.8rem; }
    .dot { width: 8px; height: 8px; }

    .hero { padding: 1.5rem 0.8rem; }
    .hero__logo { width: clamp(80px, 30vw, 120px); }
    .hero__name { font-size: clamp(1.5rem, 12vw, 2.5rem); letter-spacing: 0.04em; }
    .hero__tagline { font-size: 0.75rem; letter-spacing: 0.1em; }

    .term__output { max-height: 150px; font-size: 0.7rem; }
    .term__output pre { font-size: 0.6rem; }
    .term__cmd-output p { font-size: 0.7rem; }

    .marquee__track { font-size: 0.65rem; }

    .about__line { font-size: 0.72rem; }
    .about__info { font-size: 0.75rem; }
    .cert { font-size: 0.6rem; }

    .about-prose p { font-size: 0.8rem; }

    .ai__title { font-size: clamp(1.2rem, 7vw, 1.6rem); }
    .ai__card { padding: 1rem; }
    .ai__card-name { font-size: 0.8rem; }
    .ai__card-desc { font-size: 0.72rem; }
    .ai__card-stats { font-size: 0.65rem; }

    .stat__label { font-size: 0.65rem; }

    .field input, .field textarea { font-size: 16px; }
    .btn-submit { font-size: 0.8rem; }

    .taskbar__copy { font-size: 0.6rem; }
    .taskbar__quote { font-size: 0.55rem; }
}

@media (max-width: 360px) {
    .hero__name { font-size: 1.4rem; }
    .hero__tagline { font-size: 0.65rem; }
    .win__title { font-size: 0.65rem; }
    .term__output { max-height: 130px; }
    .ai__card-name { font-size: 0.75rem; }
    .about__line { font-size: 0.68rem; }
}

/* Touch devices */
@media (hover: none) and (pointer: coarse) {
    .win:hover { box-shadow: 0 4px 30px rgba(0,0,0,0.5), 0 0 1px var(--border); }
    .tags span:hover { border-color: var(--border); color: var(--text-dim); box-shadow: none; }
    .ai__card:hover { transform: none; box-shadow: none; border-color: var(--border); }
    .ai__card:hover::before { opacity: 0; }
    .cursor-particle { display: none; }
}
