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

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

/* ═══════════════════════════════════════════════════════════════════
   THEME VARIABLES
   ═══════════════════════════════════════════════════════════════════ */

[data-theme="dark"] {
    --bg:       #060608;
    --bg2:      rgba(10,10,12,0.82);
    --bg3:      rgba(5,5,7,0.88);
    --border:   #1a1a22;
    --border2:  #232330;
    --text:     #c4c4d0;
    --muted:    #48485a;
    --dim:      #333344;

    --accent:   #7eb8f7;          /* soft periwinkle-blue — replaces green dominance */
    --accent2:  #00e5ff;          /* cyan for commands */
    --accent3:  #ffce6e;          /* warm amber */
    --red:      #ff4f7a;
    --neon:     #7eb8f7;          /* bio border — this blue now */

    --name-first: #ffffff;
    --name-last:  #b0b0c8;
    --handle-col: #7eb8f7;
    --tag-active: #7eb8f7;
    --tag-glow:   rgba(126,184,247,0.2);
    --prompt-col: #7eb8f7;
    --ok-col:     #7eb8f7;
    --quote-border: #00e5ff;
    --quote-text: #e0e0f0;

    --dock-bg:    rgba(8,8,12,0.92);
    --dock-border:#1f1f2e;

    --scanline: rgba(0,0,0,0.06);
}

[data-theme="light"] {
    --bg:       #f2ede4;          /* warm parchment, not white */
    --bg2:      rgba(240,233,220,0.85);
    --bg3:      rgba(235,226,210,0.90);
    --border:   #d4c9b4;
    --border2:  #c8bc9e;
    --text:     #3a3020;
    --muted:    #8a7d60;
    --dim:      #6a5f44;

    --accent:   #7056c0;          /* warm indigo for light mode bio */
    --accent2:  #c05a20;          /* burnt orange for commands */
    --accent3:  #b07820;          /* deep amber */
    --red:      #c02040;
    --neon:     #7056c0;

    --name-first: #1a1508;
    --name-last:  #5a4e2e;
    --handle-col: #7056c0;
    --tag-active: #7056c0;
    --tag-glow:   rgba(112,86,192,0.15);
    --prompt-col: #7056c0;
    --ok-col:     #4a7a30;
    --quote-border:#c05a20;
    --quote-text: #2a2010;

    --dock-bg:    rgba(228,218,196,0.94);
    --dock-border:#c0b090;

    --scanline: rgba(180,160,120,0.04);
}

/* ═══════════════════════════════════════════════════════════════════
   BASE
   ═══════════════════════════════════════════════════════════════════ */

body {
    background: var(--bg);
    font-family: 'Share Tech Mono', monospace;
    color: var(--text);
    min-height: 100vh;
    overflow-x: hidden;
    cursor: crosshair;
    transition: background 0.7s ease, color 0.5s ease;
}

body::before {
    content: '';
    position: fixed; inset: 0;
    background: repeating-linear-gradient(
        0deg, transparent, transparent 2px,
        var(--scanline) 2px, var(--scanline) 4px
    );
    pointer-events: none;
    z-index: 9999;
}

#stars {
    position: fixed; inset: 0;
    z-index: 0;
    pointer-events: none;
    transition: opacity 0.7s ease;
}

/* ═══════════════════════════════════════════════════════════════════
   CELESTIAL BODIES
   ═══════════════════════════════════════════════════════════════════ */

.celestial {
    position: fixed;
    z-index: 1;
    pointer-events: none;
}

/* ── MOON — top-right in dark mode ── */
.moon {
    position: fixed;
    top: 48px;
    right: 80px;
    width: 80px;
    height: 80px;
    transition: opacity 0.6s ease, transform 0.7s ease;
}

[data-theme="dark"]  .moon { opacity: 1;  transform: scale(1); }
[data-theme="light"] .moon { opacity: 0;  transform: scale(0.6) translateY(-30px); pointer-events: none; }

.moon-halo {
    position: absolute;
    inset: -28px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(180,210,255,0.09) 0%, rgba(120,160,240,0.04) 50%, transparent 70%);
    animation: moonHalo 5s ease-in-out infinite alternate;
}

@keyframes moonHalo {
    from { transform: scale(1);    opacity: 0.7; }
    to   { transform: scale(1.08); opacity: 1;   }
}

.moon-body {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: radial-gradient(circle at 38% 38%, #e8eeff, #b8c8f0 40%, #8090c0 100%);
    box-shadow:
        inset -8px -6px 18px rgba(40,50,110,0.5),
        0 0 30px rgba(150,180,255,0.18),
        0 0 60px rgba(120,160,240,0.08);
}

.moon-crater {
    position: absolute;
    border-radius: 50%;
    background: rgba(60,70,120,0.22);
    border: 1px solid rgba(60,70,140,0.15);
}
.moon-crater.c1 { width: 14px; height: 14px; top: 22px; left: 28px; }
.moon-crater.c2 { width: 9px;  height: 9px;  top: 44px; left: 18px; }
.moon-crater.c3 { width: 6px;  height: 6px;  top: 30px; left: 50px; }

/* ── SUN — top-left in light mode ── */
.sun {
    position: fixed;
    top: -30px;
    left: -30px;
    width: 160px;
    height: 160px;
    transition: opacity 0.6s ease, transform 0.7s ease;
}

[data-theme="dark"]  .sun { opacity: 0;  transform: scale(0.6) translate(-20px, -20px); pointer-events: none; }
[data-theme="light"] .sun { opacity: 1;  transform: scale(1); }

/* Conic ray burst — the "raytracing" effect */
.sun-rays {
    position: absolute;
    inset: -120px;
    border-radius: 50%;
    /* 16 alternating transparent/warm rays from center */
    background: conic-gradient(
        from 0deg,
        rgba(255,200,80,0.0)   0deg,
        rgba(255,200,80,0.12)  5deg,
        rgba(255,200,80,0.0)  11deg,
        rgba(255,185,60,0.10) 16deg,
        rgba(255,200,80,0.0)  22deg,
        rgba(255,200,80,0.11) 27deg,
        rgba(255,200,80,0.0)  33deg,
        rgba(255,185,60,0.09) 38deg,
        rgba(255,200,80,0.0)  44deg,
        rgba(255,200,80,0.10) 49deg,
        rgba(255,200,80,0.0)  55deg,
        rgba(255,185,60,0.08) 60deg,
        rgba(255,200,80,0.0)  66deg,
        rgba(255,200,80,0.09) 71deg,
        rgba(255,200,80,0.0)  77deg,
        rgba(255,185,60,0.07) 82deg,
        rgba(255,200,80,0.0)  90deg,
        rgba(255,200,80,0.06) 100deg,
        rgba(255,200,80,0.0)  110deg,
        rgba(255,200,80,0.05) 120deg,
        rgba(255,200,80,0.0)  130deg,
        rgba(255,200,80,0.04) 145deg,
        rgba(255,200,80,0.0)  160deg,
        rgba(255,200,80,0.03) 175deg,
        rgba(255,200,80,0.0)  360deg
    );
    animation: rayRotate 24s linear infinite;
    mask-image: radial-gradient(circle at 158px 158px, transparent 70px, black 130px, transparent 100%);
    -webkit-mask-image: radial-gradient(circle at 158px 158px, transparent 70px, black 130px, transparent 100%);
}

@keyframes rayRotate {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* Outer warm glow */
.sun-body {
    position: absolute;
    top: 85px; left: 85px;
    width: 110px; height: 110px;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle,
        rgba(255,230,120,0.35) 0%,
        rgba(255,200,80,0.18)  45%,
        rgba(255,180,50,0.08)  70%,
        transparent 100%
    );
}

/* Inner sun disc */
.sun-core {
    position: absolute;
    top: 85px; left: 85px;
    width: 52px; height: 52px;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle at 42% 40%, #fff9d0, #ffd060 50%, #ffb030 100%);
    box-shadow:
        0 0 18px rgba(255,200,60,0.6),
        0 0 40px rgba(255,180,40,0.3),
        0 0 80px rgba(255,160,20,0.12);
    animation: sunPulse 4s ease-in-out infinite alternate;
}

@keyframes sunPulse {
    from { box-shadow: 0 0 16px rgba(255,200,60,0.5), 0 0 36px rgba(255,180,40,0.25), 0 0 70px rgba(255,160,20,0.10); }
    to   { box-shadow: 0 0 24px rgba(255,210,60,0.7), 0 0 54px rgba(255,190,40,0.38), 0 0 100px rgba(255,170,20,0.18); }
}

/* ═══════════════════════════════════════════════════════════════════
   WRAPPER
   ═══════════════════════════════════════════════════════════════════ */

.wrapper {
    max-width: 720px;
    margin: 0 auto;
    padding: 56px 24px 130px;
    position: relative;
    z-index: 2;
}

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

.hero { margin-bottom: 44px; }

.greeting-line {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 14px;
}

.prompt-sym {
    color: var(--accent);
    font-size: 14px;
    animation: blink 1s step-end infinite;
    text-shadow: 0 0 8px var(--accent);
    transition: color 0.5s, text-shadow 0.5s;
}

.greeting-txt {
    font-size: 11px; letter-spacing: 5px;
    text-transform: uppercase; color: var(--muted);
    transition: color 0.5s;
}

.name {
    font-family: 'Orbitron', monospace;
    font-size: clamp(44px, 11vw, 88px);
    font-weight: 900;
    line-height: 0.95;
    letter-spacing: -2px;
    margin-bottom: 18px;
    user-select: none;
}

.name-first {
    color: var(--name-first);
    text-shadow: 0 0 60px rgba(255,255,255,0.1);
    transition: color 0.5s;
}

.name-sep {
    color: var(--accent);
    text-shadow: 0 0 30px var(--accent);
    display: inline-block;
    animation: sepPulse 3s ease-in-out infinite alternate;
    transition: color 0.5s;
}

@keyframes sepPulse {
    from { opacity: 0.7; }
    to   { opacity: 1; text-shadow: 0 0 40px var(--accent), 0 0 70px color-mix(in srgb, var(--accent) 40%, transparent); }
}

.name-last {
    color: var(--name-last);
    transition: color 0.5s;
}

.name:hover .name-first {
    animation: glitch 0.25s steps(2) forwards;
}

@keyframes glitch {
    0%  { transform: translate(0); }
    20% { transform: translate(-3px,1px);  filter: hue-rotate(90deg);  }
    40% { transform: translate(3px,-1px);  filter: hue-rotate(-90deg); color: var(--accent2); }
    60% { transform: translate(-2px,2px);  color: var(--red); }
    80% { transform: translate(2px,-2px);  }
    100%{ transform: translate(0); filter: none; color: var(--name-first); }
}

.sub-row {
    display: flex; align-items: center; flex-wrap: wrap;
    gap: 10px; font-size: 12px; letter-spacing: 2px; color: var(--muted);
    transition: color 0.5s;
}

.handle { color: var(--handle-col); transition: color 0.5s; }
.sub-dot { color: var(--border2); }

/* ═══════════════════════════════════════════════════════════════════
   TAGS
   ═══════════════════════════════════════════════════════════════════ */

.tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 36px; }

.tag {
    font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
    padding: 4px 12px;
    border: 1px solid var(--border);
    color: var(--muted);
    transition: all 0.25s;
    clip-path: polygon(4px 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
}

.tag:hover, .tag.active {
    border-color: var(--tag-active);
    color: var(--tag-active);
    background: var(--tag-glow);
}

/* ═══════════════════════════════════════════════════════════════════
   TERMINAL
   ═══════════════════════════════════════════════════════════════════ */

.terminal {
    background: var(--bg3);
    border: 1px solid var(--border);
    margin-bottom: 32px;
    font-size: 13px; line-height: 2;
    backdrop-filter: blur(6px);
    transition: background 0.5s, border-color 0.5s;
}

.terminal-chrome {
    display: flex; align-items: center; gap: 6px;
    padding: 8px 14px;
    border-bottom: 1px solid var(--border);
    background: var(--bg2);
    transition: background 0.5s;
}

.tc-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.tc-red   { background: #ff5f57; }
.tc-amber { background: #febc2e; }
.tc-green { background: #28c840; }

.tc-title {
    font-size: 10px; color: var(--muted);
    letter-spacing: 3px; margin-left: 8px; text-transform: lowercase;
    transition: color 0.5s;
}

.terminal-body { padding: 14px 20px 18px; }
.terminal-line  { padding-top: 2px; }

.prompt { color: var(--prompt-col); transition: color 0.5s; }
.cmd    { color: var(--accent2);    transition: color 0.5s; }
.output { color: var(--dim); padding-left: 16px; transition: color 0.5s; }
.output.ok { color: var(--ok-col); transition: color 0.5s; }
.cursor-block { animation: blink 1s step-end infinite; color: var(--prompt-col); }

@keyframes blink { 50% { opacity: 0; } }

/* ═══════════════════════════════════════════════════════════════════
   BIO — soft blue accent, NOT green
   ═══════════════════════════════════════════════════════════════════ */

.bio-block {
    border-left: 2px solid var(--accent);   /* ← soft blue / indigo now */
    padding-left: 20px;
    margin-bottom: 32px;
    transition: border-color 0.5s;
}

.bio-label {
    font-size: 10px; color: var(--muted);
    letter-spacing: 2px; margin-bottom: 12px;
    transition: color 0.5s;
}

.bio-text {
    font-size: 14px; line-height: 1.85; color: var(--text);
    transition: color 0.5s;
}

.bio-text .hl  { color: var(--accent);  }   /* blue */
.bio-text .hl2 { color: var(--accent2); }   /* cyan / orange */
.bio-text .hl3 { color: var(--accent3); }   /* amber */
.bio-text .hl4 { color: var(--red);     }   /* red */

/* ═══════════════════════════════════════════════════════════════════
   QUOTE
   ═══════════════════════════════════════════════════════════════════ */

.quote-block {
    margin: 32px 0; padding: 18px 24px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-left: 2px solid var(--quote-border);
    clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
    backdrop-filter: blur(4px);
    transition: background 0.5s, border-color 0.5s;
}

.quote-text {
    font-family: 'VT323', monospace;
    font-size: 26px; color: var(--quote-text);
    letter-spacing: 2px; transition: color 0.5s;
}

.quote-attr {
    font-size: 10px; color: var(--muted);
    letter-spacing: 3px; margin-top: 6px;
    text-transform: uppercase; transition: color 0.5s;
}

/* ═══════════════════════════════════════════════════════════════════
   SECTION LABEL
   ═══════════════════════════════════════════════════════════════════ */

.section-label {
    font-size: 10px; color: var(--muted);
    letter-spacing: 4px; text-transform: uppercase;
    margin-bottom: 14px;
    display: flex; align-items: center; gap: 12px;
    transition: color 0.5s;
}
.section-label::after {
    content: ''; flex: 1; height: 1px; background: var(--border);
    transition: background 0.5s;
}

/* ═══════════════════════════════════════════════════════════════════
   SKILLS
   ═══════════════════════════════════════════════════════════════════ */

.skills-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 8px; margin-bottom: 32px;
}

.skill-item {
    padding: 10px 14px;
    background: var(--bg2);
    border: 1px solid var(--border);
    font-size: 12px; letter-spacing: 1px; color: var(--muted);
    position: relative; transition: all 0.22s; overflow: hidden;
    backdrop-filter: blur(4px);
}

.skill-item::before {
    content: ''; position: absolute;
    left: 0; top: 0; bottom: 0; width: 2px;
    background: var(--accent);
    transform: scaleY(0); transition: transform 0.2s;
    transform-origin: bottom;
}

.skill-item:hover { border-color: var(--border2); color: var(--text); background: var(--bg3); }
.skill-item:hover::before { transform: scaleY(1); }

.skill-dot {
    width: 4px; height: 4px; border-radius: 50%;
    background: var(--accent);
    display: inline-block; margin-right: 8px;
    box-shadow: 0 0 5px var(--accent);
    transition: background 0.5s, box-shadow 0.5s;
}
.skill-dot.red   { background: var(--red);    box-shadow: 0 0 5px var(--red); }
.skill-dot.cyan  { background: var(--accent2); box-shadow: 0 0 5px var(--accent2); }
.skill-dot.amber { background: var(--accent3); box-shadow: 0 0 5px var(--accent3); }

/* ═══════════════════════════════════════════════════════════════════
   PROJECTS
   ═══════════════════════════════════════════════════════════════════ */

.projects-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 10px; margin-bottom: 32px;
}

a { text-decoration: none; }

.project-card {
    padding: 16px;
    background: var(--bg2);
    border: 1px solid var(--border);
    transition: all 0.25s; cursor: pointer;
    position: relative; overflow: hidden;
    backdrop-filter: blur(4px);
}

.project-card::after {
    content: ''; position: absolute;
    bottom: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, var(--accent), var(--accent2));
    transform: scaleX(0); transition: transform 0.3s;
    transform-origin: left;
}

.project-card:hover { border-color: var(--border2); }
.project-card:hover::after { transform: scaleX(1); }

.project-name {
    font-size: 13px; color: var(--text);
    letter-spacing: 1px; margin-bottom: 6px;
    display: flex; align-items: center; gap: 8px;
    transition: color 0.5s;
}

.arrow { color: var(--accent); font-size: 10px; transition: color 0.5s; }

.project-desc { font-size: 11px; color: var(--muted); line-height: 1.6; transition: color 0.5s; }

.project-lang {
    margin-top: 10px; font-size: 10px;
    color: var(--accent2); letter-spacing: 2px;
    text-transform: uppercase; transition: color 0.5s;
}

/* ═══════════════════════════════════════════════════════════════════
   DOCK
   ═══════════════════════════════════════════════════════════════════ */

.dock {
    position: fixed; bottom: 24px; left: 50%;
    transform: translateX(-50%); z-index: 100;
    display: flex; align-items: center; gap: 2px;
    background: var(--dock-bg);
    border: 1px solid var(--dock-border);
    padding: 8px 12px;
    backdrop-filter: blur(16px);
    clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
    transition: background 0.5s, border-color 0.5s;
}

.dock-item {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 14px; color: var(--muted);
    font-size: 11px; letter-spacing: 2px;
    text-decoration: none; text-transform: uppercase;
    transition: color 0.2s;
    background: none; border: none; cursor: pointer;
    font-family: 'Share Tech Mono', monospace;
}

.dock-item svg {
    width: 14px; height: 14px;
    stroke: currentColor; fill: none;
    stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
    flex-shrink: 0;
}

.dock-item:hover { color: var(--accent); }
.dock-item:hover svg { filter: drop-shadow(0 0 4px var(--accent)); }

.dock-sep { width: 1px; height: 18px; background: var(--dock-border); margin: 0 2px; }

.theme-toggle { font-size: 12px; gap: 6px; }
.theme-toggle span:first-child { font-size: 14px; }

/* ═══════════════════════════════════════════════════════════════════
   FADE-IN
   ═══════════════════════════════════════════════════════════════════ */

.fade-in { animation: fadeIn 0.6s ease forwards; opacity: 0; }
.fade-in:nth-child(1) { animation-delay: 0.05s; }
.fade-in:nth-child(2) { animation-delay: 0.15s; }
.fade-in:nth-child(3) { animation-delay: 0.25s; }
.fade-in:nth-child(4) { animation-delay: 0.35s; }
.fade-in:nth-child(5) { animation-delay: 0.45s; }
.fade-in:nth-child(6) { animation-delay: 0.55s; }

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

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

@media (max-width: 560px) {
    .name { letter-spacing: -1px; }
    .skills-grid   { grid-template-columns: 1fr 1fr; }
    .projects-grid { grid-template-columns: 1fr; }
    .sub-row { gap: 8px; }
    .moon { right: 24px; top: 24px; width: 60px; height: 60px; }
}
