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

:root {
    --bg:          #0D0A14;
    --bg-card:     #1A1025;
    --bg-elevated: #221633;
    --border:      rgba(59,31,94,0.7);
    --border-hi:   rgba(147,51,234,0.55);
    --accent:      #9333EA;
    --accent-lt:   #D257E6;   /* lightened from #C026D3 → WCAG AA (>=4.5:1) as text on dark bg */
    --accent-2:        #9333EA;
    --accent-2-lt:     #D257E6;
    --text:        #F1E8FF;
    --text-muted:  #C4B0E0;
    --text-dim:    #C4B0E0;
    --gradient:    linear-gradient(135deg,#9333EA,#C026D3);
    --glow:        rgba(147,51,234,0.3);
}

html { scroll-behavior: smooth; }

:focus-visible { outline: 2px solid #9333EA; outline-offset: 3px; }

#hero, #about, #skills, #experience, #education, #publication, #achievements, #projects, #contact {
    scroll-margin-top: 80px;
}

body {
    background: var(--bg);
    color: var(--text);
    font-family: 'DM Sans',sans-serif;
    line-height: 1.6;
    overflow-x: hidden;
}

h1, h2, h3, .nav-logo, .section-title, .hero-name, .pub-title, .tl-role, .hero-title, .block-label { font-family: 'Oxanium', sans-serif; }

::selection { background: rgba(147,51,234,0.3); color: #F1E8FF; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 3px; }

/* ── UTILITIES ── */
.container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

.section-label {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .72rem; font-weight: 600; letter-spacing: .15em;
    text-transform: uppercase; color: #C026D3; margin-bottom: 12px;
}
.section-label::before {
    content:''; display:inline-block; width:24px; height:2px; background:#C026D3;
}
.section-title {
    font-size: clamp(1.75rem,4vw,2.5rem); font-weight: 700;
    line-height: 1.15; margin-bottom: 8px;
}
.section-sub {
    color: var(--text-muted); font-size: 1rem;
    margin-bottom: 48px; max-width: 70ch;
}

section { padding: 100px 0; }

.fade-in {
    opacity: 0; transform: translateY(28px);
    transition: opacity .65s ease, transform .65s ease;
}
.fade-in.visible { opacity: 1; transform: none; }

/* ── NAV ── */
nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 200;
    padding: 18px 0; transition: all .3s;
}
nav.scrolled {
    background: rgba(26,16,37,.94); backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--border); padding: 12px 0;
}
.nav-inner {
    max-width: 1100px; margin: 0 auto; padding: 0 24px;
    display: flex; align-items: center; justify-content: space-between;
}
.nav-logo {
    font-weight: 700; font-size: 1.15rem;
    background: var(--gradient); -webkit-background-clip: text;
    -webkit-text-fill-color: transparent; background-clip: text;
    text-decoration: none;
}
.nav-links { display: flex; gap: 32px; list-style: none; }
.nav-links a {
    color: var(--text-muted); text-decoration: none;
    font-size: .88rem; font-weight: 500; transition: color .2s;
}
.nav-links a:hover { color: var(--text); }
.nav-cta {
    color: var(--accent-lt) !important;
    border: 1px solid var(--accent); padding: 7px 18px;
    border-radius: 6px; transition: all .2s !important;
}
.nav-cta:hover { background: var(--accent); color: #fff !important; }

.hamburger {
    display: none; flex-direction: column; gap: 5px;
    cursor: pointer; background: none; border: none; padding: 4px;
}
.hamburger span {
    display: block; width: 24px; height: 2px;
    background: var(--text); border-radius: 2px; transition: all .3s;
}

/* ── HERO ── */
#hero {
    min-height: 100vh; display: flex; align-items: center;
    position: relative; overflow: hidden; padding-top: 80px;
}
.hero-bg {
    position: absolute; inset: 0; pointer-events: none;
    background:
        radial-gradient(ellipse 80% 50% at 50% -10%, rgba(107,33,168,.28), transparent),
        radial-gradient(ellipse 50% 50% at 85% 85%, rgba(147,51,234,.15), transparent);
}
.hero-grid {
    position: absolute; inset: 0; pointer-events: none;
    background-image:
        linear-gradient(rgba(147,51,234,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(147,51,234,.03) 1px, transparent 1px);
    background-size: 60px 60px;
}
.hero-content { position: relative; z-index: 1; }

.hero-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.3);
    border-radius: 100px; padding: 6px 18px; margin-bottom: 28px;
    font-size: .78rem; color: var(--accent-lt); font-weight: 500; letter-spacing: .05em;
}
.hero-badge::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--accent-2); animation: blink 2s infinite;
}
@keyframes blink {
    0%,100% { opacity:1; transform:scale(1); }
    50%      { opacity:.4; transform:scale(.8); }
}

.hero-name {
    font-size: clamp(3rem,9vw,6rem); font-weight: 700;
    line-height: 1.02; margin-bottom: 18px;
}
.grad { background: var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

.hero-role {
    font-size: clamp(1rem,2.5vw,1.35rem);
    color: #EDE0FF; font-weight: 400; margin-bottom: 22px;
    text-shadow: 0 1px 6px rgba(13,10,20,.7);
}
.hero-desc {
    font-size: 1rem; color: #EDE0FF;
    max-width: 70ch; margin-bottom: 40px; line-height: 1.75;
    text-shadow: 0 1px 6px rgba(13,10,20,.7);
}
.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }

.btn-p {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--gradient); color: #fff; text-decoration: none;
    padding: 14px 28px; border-radius: 8px; font-weight: 600;
    font-size: .95rem; transition: opacity .2s, transform .2s, box-shadow .2s;
}
.btn-p:hover { opacity: .88; transform: translateY(-2px); box-shadow: 0 0 20px var(--glow); }

.btn-s {
    display: inline-flex; align-items: center; gap: 8px;
    background: transparent; color: var(--text); text-decoration: none;
    padding: 14px 28px; border-radius: 8px; font-weight: 600;
    font-size: .95rem; border: 1px solid var(--border-hi); transition: all .2s;
}
.btn-s:hover { border-color: var(--accent); color: var(--accent-lt); transform: translateY(-2px); }

.scroll-hint {
    position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%);
    display: flex; flex-direction: column; align-items: center; gap: 8px;
    color: var(--text-dim); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
}
.scroll-line {
    width: 1px; height: 40px;
    background: linear-gradient(to bottom, var(--accent), transparent);
    transform-origin: top;          /* constant origin keeps the animation GPU-composited */
    will-change: transform, opacity;
    animation: drip 1.6s ease-in-out infinite;
}
@keyframes drip {
    0%   { opacity:0; transform:scaleY(0); }
    50%  { opacity:1; transform:scaleY(1); }
    100% { opacity:0; transform:scaleY(1); }
}

/* ── ABOUT ── */
#about { background: var(--bg-card); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }

.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.about-text p { color: var(--text-muted); margin-bottom: 16px; line-height: 1.8; max-width: 70ch; }

.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; }
.stat {
    background: var(--bg); border: 1px solid var(--border);
    padding: 28px 22px; text-align: center; transition: border-color .2s, box-shadow .2s;
    border-right: none;
}
.stat:first-child { border-radius: 12px 0 0 12px; }
.stat:last-child  { border-radius: 0 12px 12px 0; border-right: 1px solid var(--border); }
.stat:hover { border-color: var(--accent); box-shadow: 0 0 14px var(--glow); z-index: 1; }
.stat-n {
    display: block; font-size: 2.5rem; font-weight: 800; margin-bottom: 6px;
    color: var(--accent);
}
.stat-l { font-size: .85rem; color: #C4B0E0; text-transform: uppercase; letter-spacing: .05em; }
@media (max-width: 640px) {
    .stats { grid-template-columns: 1fr 1fr; }
    .stat { border-right: none; border-bottom: none; border-radius: 0 !important; }
    .stat:nth-child(2n) { border-right: 1px solid var(--border); }
    .stat:nth-last-child(-n+2) { border-bottom: 1px solid var(--border); }
    .stat:first-child { border-radius: 12px 0 0 0 !important; }
    .stat:nth-child(2) { border-radius: 0 12px 0 0 !important; }
    .stat:nth-last-child(2) { border-radius: 0 0 0 12px !important; }
    .stat:last-child { border-radius: 0 0 12px 0 !important; border-right: 1px solid var(--border); }
}

/* ── SKILLS ── */
.skills-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(265px,1fr)); gap: 22px; }

.skill-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 16px; padding: 26px; transition: border-color .3s, transform .25s;
}
.skill-card:hover { border-color: var(--accent); transform: translateY(-5px); box-shadow: 0 0 18px var(--glow); }

.sk-icon { font-size: 1.7rem; display: block; margin-bottom: 10px; }
.sk-title { font-size: .95rem; font-weight: 600; margin-bottom: 14px; }

.tags { display: flex; flex-wrap: wrap; gap: 8px; }
.tag {
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.2);
    color: var(--accent-lt); padding: 5px 12px; border-radius: 100px;
    font-size: .78rem; font-weight: 500; transition: all .2s;
}
.tag:hover { background: rgba(147,51,234,.22); border-color: var(--accent); }
.tag.c {
    background: rgba(147,51,234,.1); border-color: rgba(147,51,234,.2); color: var(--accent-2-lt);
}
.tag.c:hover { background: rgba(147,51,234,.22); border-color: var(--accent-2); }

/* ── EXPERIENCE ── */
#experience { background: var(--bg-card); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }

.timeline { position: relative; padding-left: 32px; }
.timeline::before {
    content:''; position:absolute; left:0; top:8px; bottom:8px; width:2px;
    background: linear-gradient(to bottom, var(--accent), var(--accent-2), transparent);
}
.tl-item { position: relative; padding-bottom: 44px; }
.tl-item:last-child { padding-bottom: 0; }
.tl-dot {
    position: absolute; left: -39px; top: 8px;
    width: 14px; height: 14px; border-radius: 50%;
    background: var(--accent); border: 2px solid var(--bg-card);
    box-shadow: 0 0 0 3px var(--glow);
}
.tl-card {
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 14px; padding: 22px 26px; transition: border-color .3s;
}
.tl-card:hover { border-color: var(--accent); }
.tl-head { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.tl-role { font-size: 1rem; font-weight: 600; color: #F1E8FF; }
.tl-date {
    font-size: .75rem; color: #C4B0E0;
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.2);
    padding: 4px 12px; border-radius: 100px; white-space: nowrap;
}
.tl-org { font-size: .88rem; color: #C026D3; margin-bottom: 10px; font-weight: 500; }
.tl-pts { list-style: none; }
.tl-pts li {
    color: #D4C4F0; font-size: .88rem; padding-left: 16px;
    position: relative; margin-bottom: 5px; line-height: 1.6;
}
.tl-pts li::before { content:'▹'; position:absolute; left:0; color:var(--accent); }

/* Other experience — collapsible */
.other-exp-toggle {
    display: flex; align-items: center; gap: 10px; cursor: pointer;
    list-style: none; padding: 10px 0; margin-top: 28px;
    color: var(--text-dim); font-size: .82rem; font-weight: 600;
    letter-spacing: .06em; text-transform: uppercase;
}
.other-exp-toggle::marker, .other-exp-toggle::-webkit-details-marker { display: none; }
.other-exp-toggle::before { content:''; flex: 1; height: 1px; background: var(--border); }
.other-exp-toggle::after  { content:''; flex: 1; height: 1px; background: var(--border); }
.other-exp-details[open] .other-exp-toggle { color: var(--text-muted); }
.other-exp-details .tl-item { margin-top: 20px; }
.other-exp-details .tl-card { opacity: .7; font-size: .9em; }
.other-exp-details[open] .tl-card { opacity: 1; }

/* ── EDUCATION ── */
.edu-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(290px,1fr)); gap: 22px; }
.edu-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 16px; padding: 26px; transition: all .3s; position: relative; overflow: hidden;
}
.edu-card::before {
    content:''; position:absolute; top:0; left:0; right:0; height:3px;
    background: var(--gradient); opacity: 0; transition: opacity .3s;
}
.edu-card:hover { border-color: var(--accent); transform: translateY(-5px); }
.edu-card:hover::before { opacity: 1; }
.edu-yr { font-size: .73rem; color: var(--accent-2); text-transform: uppercase; letter-spacing: .1em; font-weight: 600; margin-bottom: 8px; }
.edu-deg { font-size: .98rem; font-weight: 600; margin-bottom: 4px; }
.edu-school { font-size: .87rem; color: var(--text-muted); margin-bottom: 14px; }
.edu-detail { font-size: .83rem; color: var(--text-dim); line-height: 1.6; }

/* ── PUBLICATION ── */
#publication { background: var(--bg-card); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }

.pub-card {
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 20px; padding: 40px; max-width: 800px; transition: border-color .3s;
}
.pub-card:hover { border-color: var(--accent); }
.pub-badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.3);
    color: var(--accent-lt); padding: 5px 14px; border-radius: 100px;
    font-size: .75rem; font-weight: 600; letter-spacing: .05em; margin-bottom: 18px;
}
.pub-title { font-size: 1.15rem; font-weight: 600; margin-bottom: 12px; line-height: 1.4; }
.pub-desc { color: var(--text-muted); font-size: .9rem; line-height: 1.75; margin-bottom: 24px; max-width: 70ch; }
.pub-link {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--accent-2); text-decoration: none; font-weight: 600;
    font-size: .9rem; transition: gap .2s;
}
.pub-link:hover { gap: 14px; }

/* ── PROJECTS ── */
.proj-tabs { display: flex; gap: 10px; margin-bottom: 40px; }
.tab {
    background: transparent; border: 1px solid var(--border);
    color: var(--text-muted); padding: 9px 22px; border-radius: 8px;
    font-family: 'DM Sans',sans-serif; font-size: .88rem;
    font-weight: 500; cursor: pointer; transition: all .2s;
}
.tab.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.tab:hover:not(.on) { border-color: var(--accent); color: var(--accent-lt); background: var(--bg-elevated); }

.proj-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 22px; }
.proj-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 16px; padding: 26px; transition: all .3s;
}
.proj-card:hover { border-color: var(--accent); transform: translateY(-5px); box-shadow: 0 0 20px var(--glow); }
.proj-card.ph { border-style: dashed; opacity: .6; }
.proj-card.ph:hover { opacity: .85; transform: translateY(-3px); }

.ph-inner {
    display: flex; flex-direction: column; align-items: center;
    justify-content: center; text-align: center; min-height: 160px; gap: 12px;
}
.ph-icon { font-size: 2rem; opacity: .4; }
.ph-title { font-size: 1rem; font-weight: 600; }
.ph-text { color: var(--text-dim); font-size: .83rem; }

.proj-engine {
    display: inline-block; background: rgba(147,51,234,.1);
    border: 1px solid rgba(147,51,234,.2); color: var(--accent-2-lt);
    padding: 3px 10px; border-radius: 4px; font-size: .7rem;
    font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin-bottom: 12px;
}
.proj-title { font-size: 1.02rem; font-weight: 600; margin-bottom: 8px; }
.proj-desc { color: var(--text-muted); font-size: .83rem; line-height: 1.6; margin-bottom: 18px; }
.proj-stack { display: flex; flex-wrap: wrap; gap: 6px; }
.st { background: rgba(147,51,234,.08); color: var(--text-dim); padding: 3px 10px; border-radius: 4px; font-size: .73rem; }

/* ── CONTACT ── */
#contact { background: var(--bg-card); border-top: 1px solid var(--border); }

.contact-wrap { max-width: 600px; }
.contact-text { color: var(--text-muted); font-size: 1rem; line-height: 1.75; margin-bottom: 36px; }

.contact-links { display: flex; flex-direction: column; gap: 14px; }
.cl {
    display: flex; align-items: center; gap: 16px;
    color: var(--text); text-decoration: none;
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 16px 20px; transition: all .2s;
}
.cl:hover { border-color: var(--accent); transform: translateX(6px); }
.cl-icon {
    width: 40px; height: 40px; border-radius: 8px;
    background: rgba(147,51,234,.1); display: flex;
    align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0;
}
.cl-body { flex: 1; }
.cl-label { font-size: .72rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: .05em; }
.cl-val { font-size: .93rem; font-weight: 500; }
.cl-arr { color: var(--text-dim); transition: color .2s; }
.cl:hover .cl-arr { color: var(--accent); }

/* ── SOCIAL ICONS ── */
.cl-svg { width: 20px; height: 20px; display: block; }
.cl-icon.github-ic  { background: rgba(147,51,234,.1); }
.cl-icon.github-ic  svg { fill: var(--accent-2); }
.cl-icon.insta-ic   { background: rgba(147,51,234,.1); }
.cl-icon.insta-ic   svg { fill: var(--accent-2); }
.cl-icon.discord-ic { background: rgba(147,51,234,.1); }
.cl-icon.discord-ic svg { fill: var(--accent-2); }
.cl-icon.gmail-ic   { background: rgba(147,51,234,.1); }
.cl-icon.gmail-ic   svg { fill: var(--accent-2); }
.cl-icon.li-ic      { background: rgba(147,51,234,.1); }
.cl-icon.li-ic      svg { fill: var(--accent-2); }
.cl-icon.cv-ic      { background: rgba(147,51,234,.1); }
.cl-icon.cv-ic      svg { fill: var(--accent-2); }

/* ── FOOTER ── */
footer { padding: 36px 0; border-top: 1px solid #3B1F5E; }
.foot-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.foot-text { font-size: .83rem; color: var(--text-dim); }
.foot-text span { color: var(--accent-lt); }
.foot-socials { display: flex; gap: 12px; align-items: center; }
.foot-soc {
    width: 36px; height: 36px; border-radius: 8px;
    background: var(--bg-card); border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    transition: all .2s; text-decoration: none;
}
.foot-soc:hover { border-color: var(--border-hi); transform: translateY(-2px); }
.foot-soc svg { width: 16px; height: 16px; display: block; }
.foot-soc.gh  svg { fill: var(--accent-2); }
.foot-soc.li  svg { fill: var(--accent-lt); }
.foot-soc.ig  svg { fill: var(--accent-2); }
.foot-soc.dc  svg { fill: var(--accent-2); }

/* ── ACHIEVEMENTS ── */
.ach-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
}
.ach-card {
    background: var(--bg-card); border-radius: 16px; padding: 24px;
    border: 1px solid var(--border); display: flex; gap: 18px;
    align-items: flex-start; transition: all .3s;
}
.ach-card:hover { transform: translateY(-4px); border-color: var(--ach-color, var(--accent)); box-shadow: 0 0 16px var(--glow); }

.ach-card.award  { --ach-color: #fbbf24; --ach-bg: rgba(251,191,36,.12); --ach-border: rgba(251,191,36,.25); }
.ach-card.pub    { --ach-color: #a78bfa; --ach-bg: rgba(167,139,250,.12); --ach-border: rgba(167,139,250,.25); }
.ach-card.press  { --ach-color: #C026D3; --ach-bg: rgba(192,38,211,.12);  --ach-border: rgba(192,38,211,.25); }
.ach-card.rank   { --ach-color: #fb923c; --ach-bg: rgba(251,146,60,.12);  --ach-border: rgba(251,146,60,.25); }

.ach-icon-wrap {
    width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
    background: var(--ach-bg); border: 1px solid var(--ach-border);
    display: flex; align-items: center; justify-content: center; font-size: 1.4rem;
}
.ach-body { flex: 1; min-width: 0; }
.ach-title { font-size: .97rem; font-weight: 600; color: var(--text); margin-bottom: 4px; line-height: 1.3; }
.ach-context { font-size: .82rem; color: var(--text-muted); margin-bottom: 8px; }
.ach-date {
    display: inline-block; font-size: .7rem; font-weight: 600;
    color: var(--ach-color); background: var(--ach-bg);
    border: 1px solid var(--ach-border); padding: 2px 10px; border-radius: 100px;
    letter-spacing: .04em; text-transform: uppercase;
}

/* ── VIEW PROJECT BUTTON ── */
.proj-view-btn {
    display: block; text-align: center; margin-top: 16px;
    padding: 10px 18px; border-radius: 8px; text-decoration: none;
    background: transparent; border: 1px solid var(--border-hi);
    color: var(--text-muted); font-size: .85rem; font-weight: 600;
    transition: all .25s; font-family: 'DM Sans', sans-serif;
}
.proj-view-btn:hover {
    background: var(--gradient); color: #fff;
    border-color: transparent; transform: translateY(-2px);
}
.proj-cover-link { display: block; }
.proj-cover-link:hover .proj-cover { border-color: var(--accent); }

/* ── PROJ FILTERS ── */
.proj-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; min-height: 38px; }
.filter-chip {
    background: transparent; border: 1px solid var(--border);
    color: var(--text-muted); padding: 7px 18px; border-radius: 100px;
    font-family: 'DM Sans',sans-serif; font-size: .8rem;
    font-weight: 500; cursor: pointer; transition: all .2s;
}
.filter-chip.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.filter-chip:hover:not(.on) { border-color: var(--accent-2); color: var(--accent-2-lt); background: var(--bg-elevated); }

/* ── PROJ CARD (dynamic) ── */
.proj-cover {
    width: 100%; aspect-ratio: 16/9; object-fit: cover;
    border-radius: 10px; margin-bottom: 18px; display: block;
    border: 1px solid var(--border);
}
.proj-card-body { display: flex; flex-direction: column; flex: 1; }
.proj-meta-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
.proj-degree-badge {
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.2);
    color: var(--accent-lt); padding: 3px 10px; border-radius: 4px;
    font-size: .68rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
}
.proj-links { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; padding-top: 16px; }
.proj-link-btn {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.2);
    color: var(--accent-lt); text-decoration: none; padding: 6px 14px;
    border-radius: 6px; font-size: .78rem; font-weight: 500; transition: all .2s;
}
.proj-link-btn:hover { background: rgba(147,51,234,.22); border-color: var(--accent); }
.proj-link-dl { background: rgba(147,51,234,.1); border-color: rgba(147,51,234,.2); color: var(--accent-2-lt); }
.proj-link-dl:hover { background: rgba(147,51,234,.22); border-color: var(--accent-2); }
.proj-empty {
    grid-column: 1/-1; text-align: center; padding: 60px 20px;
    color: var(--text-dim); font-size: .9rem;
}
.proj-empty-icon { font-size: 2.5rem; display: block; margin-bottom: 12px; opacity: .3; }

/* ── EVENT BADGE ── */
.proj-event-badge {
    background: rgba(250,204,21,.1); border: 1px solid rgba(250,204,21,.3);
    color: #fde68a; padding: 3px 10px; border-radius: 4px;
    font-size: .68rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
}

/* ── AWARDS ── */
.proj-awards { display: flex; flex-direction: column; gap: 6px; margin-top: 14px; }
.proj-award {
    display: flex; align-items: center; gap: 8px;
    background: rgba(250,204,21,.07); border: 1px solid rgba(250,204,21,.2);
    border-radius: 8px; padding: 7px 12px; font-size: .8rem; color: #fde68a;
}
.proj-award-icon { font-size: 1rem; flex-shrink: 0; }

/* ── DATE ── */
.proj-date {
    font-size: .75rem; color: var(--text-dim);
    display: flex; align-items: center; gap: 5px; margin-bottom: 10px;
}

/* ── GENRE ── */
.proj-genre {
    background: rgba(168,85,247,.1); border: 1px solid rgba(168,85,247,.25);
    color: #d8b4fe; padding: 3px 10px; border-radius: 4px;
    font-size: .68rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
}

/* ── ARTICLES ── */
.proj-articles { margin-top: 14px; border-top: 1px solid var(--border); padding-top: 14px; }
.proj-articles-label {
    font-size: .7rem; color: var(--text-dim); text-transform: uppercase;
    letter-spacing: .08em; font-weight: 600; margin-bottom: 8px;
}
.proj-article-link {
    display: flex; align-items: center; gap: 8px;
    color: var(--text-muted); text-decoration: none; font-size: .82rem;
    padding: 6px 0; border-bottom: 1px solid var(--border); transition: color .2s;
}
.proj-article-link:last-child { border-bottom: none; }
.proj-article-link:hover { color: var(--accent-2); }
.proj-article-source {
    font-size: .72rem; color: var(--text-dim); margin-left: auto;
    white-space: nowrap; padding-left: 8px;
}

/* ── PHOTO GALLERY ── */
.proj-gallery {
    display: flex; gap: 8px; overflow-x: auto; margin-bottom: 16px;
    padding-bottom: 4px; scrollbar-width: thin; scrollbar-color: var(--accent) transparent;
}
.proj-gallery::-webkit-scrollbar { height: 4px; }
.proj-gallery::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 2px; }
.proj-thumb {
    height: 80px; min-width: 130px; max-width: 200px; width: auto;
    object-fit: cover; border-radius: 6px; border: 1px solid var(--border);
    flex-shrink: 0; cursor: pointer; transition: border-color .2s;
}
.proj-thumb:hover { border-color: var(--accent); }

/* ── TAGS ── */
.proj-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.proj-tag-chip {
    background: rgba(147,51,234,.08); border: 1px solid rgba(147,51,234,.15);
    color: var(--text-dim); padding: 3px 10px; border-radius: 100px; font-size: .72rem; font-weight: 500;
}

/* ── ITCH WIDGET ── */
.proj-itch-wrap { margin-top: 16px; border-radius: 8px; overflow: hidden; }
.proj-itch-wrap iframe { display: block; width: 100%; border: none; }

/* ── HERO PHOTO ── */
.hero-layout { display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; }
.hero-photo-wrap {
    width: 300px; height: 300px; border-radius: 50%; flex-shrink: 0;
    background: var(--gradient); padding: 3px;
    box-shadow: 0 0 32px var(--glow), 0 0 64px rgba(147,51,234,.15);
}
.hero-photo-inner {
    width: 100%; height: 100%; border-radius: 50%; overflow: hidden;
    background: var(--bg-elevated); display: flex; align-items: center;
    justify-content: center;
}
.hero-photo-inner img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-photo-placeholder {
    width: 100%; height: 100%; display: flex; align-items: center;
    justify-content: center; font-size: 4rem; opacity: .3;
}

/* ── RELOCATING BADGE ── */
.reloc-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(147,51,234,.12); border: 1px solid rgba(147,51,234,.45);
    border-radius: 100px; padding: 7px 20px; margin-bottom: 20px;
    font-size: .82rem; color: #C4B0E0; font-weight: 600; letter-spacing: .04em;
    box-shadow: 0 0 12px rgba(147,51,234,.2);
}

/* ── CONTACT FORM ── */
.contact-form { margin-top: 40px; }
.contact-form h3 { font-family: 'Oxanium',sans-serif; font-size: 1.1rem; margin-bottom: 20px; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: .82rem; color: #C4B0E0; margin-bottom: 6px; font-weight: 500; }
.form-input, .form-textarea {
    width: 100%; background: #1A1025; border: 1px solid #3B1F5E;
    color: #F1E8FF; padding: 12px 16px; border-radius: 8px;
    font-family: 'DM Sans',sans-serif; font-size: .95rem;
    transition: border-color .2s, box-shadow .2s; outline: none;
}
.form-input::placeholder, .form-textarea::placeholder { color: #6B5A8A; }
.form-input:focus, .form-textarea:focus {
    border-color: #9333EA; box-shadow: 0 0 0 3px rgba(147,51,234,.2);
}
.form-textarea { resize: vertical; min-height: 130px; }
.form-submit {
    background: #9333EA; color: #fff; border: none; padding: 13px 32px;
    border-radius: 6px; font-family: 'DM Sans',sans-serif; font-size: .95rem;
    font-weight: 600; cursor: pointer; transition: background .2s, transform .15s;
    width: 100%;
}
.form-submit:hover { background: #6B21A8; transform: translateY(-1px); }

/* ── FORMSPREE STATUS ── */
.fs-success {
    background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.3);
    color: #86efac; padding: 14px 18px; border-radius: 8px;
    font-size: .9rem; margin-bottom: 16px; display: none;
}
.fs-error-global {
    background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.3);
    color: #fca5a5; padding: 14px 18px; border-radius: 8px;
    font-size: .9rem; margin-bottom: 16px; display: none;
}
.fs-field-error {
    color: #fca5a5; font-size: .78rem; margin-top: 4px; display: none;
}

/* ── PROJECT DETAIL NAV ── */
.proj-nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 200;
    background: rgba(13,10,20,.9); backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border); height: 60px;
    display: flex; align-items: center; padding: 0 24px;
    justify-content: space-between;
}
.back-btn {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--text-muted); text-decoration: none;
    font-size: .88rem; font-weight: 500; transition: all .2s;
    border: 1px solid var(--border); padding: 7px 16px; border-radius: 8px;
}
.back-btn:hover { color: var(--text); border-color: var(--border-hi); }
.back-arrow { display: inline-block; transition: transform .2s; }
.back-btn:hover .back-arrow { transform: translateX(-3px); }

/* ── PROJECT DETAIL HERO ── */
.proj-hero {
    position: relative; min-height: 72vh;
    display: flex; flex-direction: column; justify-content: flex-end;
    overflow: hidden; padding-top: 60px;
}
.proj-hero .hero-bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center top;
    transition: opacity .6s;
    background: none;
}
.hero-glow {
    position: absolute; inset: 0; pointer-events: none;
    background:
        radial-gradient(ellipse 80% 60% at 50% -10%, rgba(107,33,168,.30), transparent),
        radial-gradient(ellipse 50% 50% at 80% 80%, rgba(147,51,234,.18), transparent);
}
.hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(13,10,20,.05) 0%,
        rgba(13,10,20,.40) 35%,
        rgba(13,10,20,.88) 70%,
        #0D0A14 100%
    );
}
.proj-hero .hero-content {
    position: relative; z-index: 1;
    max-width: 920px; width: 100%; margin: 0 auto;
    padding: 60px 24px 56px;
}
.hero-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.badge {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 12px; border-radius: 5px;
    font-size: .68rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
}
.b-type   { background:rgba(147,51,234,.15); border:1px solid rgba(147,51,234,.3); color:var(--accent-lt); }
.b-degree { background:rgba(147,51,234,.1);  border:1px solid rgba(147,51,234,.2); color:var(--accent-lt); }
.b-genre  { background:rgba(168,85,247,.12); border:1px solid rgba(168,85,247,.28); color:#d8b4fe; }
.b-event  { background:rgba(250,204,21,.1);  border:1px solid rgba(250,204,21,.3); color:#fde68a; }
.hero-date { font-size: .85rem; color: var(--text-muted); }

/* ── PROJECT DETAIL CONTENT ── */
.proj-content {
    max-width: 920px; margin: 0 auto; padding: 8px 24px 80px;
}
.content-block { margin-bottom: 52px; }
.block-label {
    font-size: .72rem; font-weight: 600; color: var(--accent-2);
    text-transform: uppercase; letter-spacing: .12em;
    display: flex; align-items: center; gap: 8px; margin-bottom: 18px;
}
.block-label::before { content:''; width:20px; height:2px; background:var(--accent-2); flex-shrink:0; }
hr.divider { border:none; border-top:1px solid var(--border); margin: 48px 0; }

/* ── PROJECT DETAIL AWARDS ── */
.awards-list { display: flex; flex-direction: column; gap: 10px; }
.award-row {
    display: flex; align-items: center; gap: 14px;
    background: rgba(251,191,36,.07); border: 1px solid rgba(251,191,36,.2);
    border-radius: 10px; padding: 14px 20px; transition: border-color .2s;
}
.award-row:hover { border-color: rgba(251,191,36,.45); }
.award-icon { font-size: 1.4rem; flex-shrink: 0; }
.award-text { font-size: .95rem; font-weight: 500; color: #fde68a; }

/* ── SUMMARY ── */
.summary-text { color: var(--text-muted); font-size: 1rem; line-height: 1.85; max-width: 70ch; }

/* ── ITCH WIDGET (detail) ── */
.itch-wrap {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 14px; padding: 24px; overflow: hidden;
}
.itch-wrap iframe { display: block; width: 100%; height: 171px; border: none; border-radius: 8px; }

/* ── GALLERY ── */
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 12px;
}
.gal-item {
    position: relative; aspect-ratio: 16/9; overflow: hidden;
    border-radius: 10px; border: 1px solid var(--border);
    cursor: pointer; transition: border-color .25s, transform .25s;
}
.gal-item:hover { border-color: var(--accent); transform: scale(1.02); box-shadow: 0 0 14px var(--glow); }
.gal-item img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .35s; }
.gal-item:hover img { transform: scale(1.06); }
.gal-zoom {
    position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    background:rgba(13,10,20,.45); opacity:0; transition:opacity .25s; font-size:1.6rem;
}
.gal-item:hover .gal-zoom { opacity:1; }

/* ── LIGHTBOX ── */
.lightbox {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(13,10,20,.95);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .3s;
}
.lightbox.open { opacity: 1; pointer-events: all; }
.lb-img-wrap { max-width: min(92vw, 1280px); max-height: 90vh; display:flex; align-items:center; justify-content:center; }
.lb-img-wrap img { max-width:100%; max-height:90vh; object-fit:contain; border-radius:8px; display:block; }
.lb-btn {
    position:fixed; background:rgba(13,10,20,.85); border:1px solid var(--border);
    border-radius:50%; color:var(--text); cursor:pointer; width:50px; height:50px;
    display:flex; align-items:center; justify-content:center;
    font-size:1.3rem; transition:all .2s; z-index:1001; line-height:1;
}
.lb-btn:hover { background:var(--accent); border-color:var(--accent); }
#lb-close { top:18px; right:18px; font-size:1.5rem; }
#lb-prev  { left:18px; top:50%; transform:translateY(-50%); }
#lb-next  { right:18px; top:50%; transform:translateY(-50%); }
.lb-counter {
    position:fixed; bottom:22px; left:50%; transform:translateX(-50%);
    background:rgba(13,10,20,.85); border:1px solid var(--border);
    color:var(--text-muted); padding:5px 18px; border-radius:100px; font-size:.8rem;
}

/* ── STACK / TAGS (detail) ── */
.pill-row { display:flex; flex-wrap:wrap; gap:8px; }
.pill { background:rgba(147,51,234,.1); border:1px solid rgba(147,51,234,.2); color:var(--accent-lt); padding:6px 16px; border-radius:100px; font-size:.82rem; }
.tag-pill { background:rgba(147,51,234,.08); border:1px solid rgba(147,51,234,.15); color:var(--text-dim); padding:6px 16px; border-radius:100px; font-size:.82rem; }

/* ── PDF VIEWER ── */
.pdf-box {
    background: var(--bg-card); border:1px solid var(--border); border-radius:14px; overflow:hidden;
}
.pdf-toolbar {
    display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
    padding:14px 20px; border-bottom:1px solid var(--border);
}
.pdf-name { font-size:.85rem; color:var(--text-muted); font-weight:500; word-break:break-all; }
.pdf-actions { display:flex; gap:10px; flex-shrink:0; }
.pdf-btn {
    display:inline-flex; align-items:center; gap:5px;
    background:rgba(147,51,234,.1); border:1px solid rgba(147,51,234,.2);
    color:var(--accent-lt); padding:6px 14px; border-radius:6px;
    font-size:.78rem; font-weight:500; text-decoration:none; transition:all .2s;
}
.pdf-btn:hover { background:rgba(147,51,234,.22); border-color:var(--accent); }
.pdf-frame { width:100%; height:80vh; border:none; display:block; }
.pdf-fallback {
    padding:40px 24px; text-align:center; color:var(--text-muted); display:none;
}
.pdf-fallback a { color:var(--accent-lt); }

/* ── ARTICLES (detail) ── */
.article-list { display:flex; flex-direction:column; gap:4px; }
.article-row {
    display:flex; align-items:center; gap:12px; color:var(--text-muted);
    text-decoration:none; padding:12px 16px; border-radius:10px;
    border:1px solid transparent; transition:all .2s; font-size:.88rem;
}
.article-row:hover { background:var(--bg-elevated); border-color:var(--border); color:var(--text); }
.art-arrow { color:var(--accent-2); flex-shrink:0; font-size:1rem; }
.art-title { flex:1; min-width:0; }
.art-source {
    font-size:.72rem; color:var(--text-dim);
    background:rgba(147,51,234,.08); border:1px solid var(--border);
    padding:2px 10px; border-radius:4px; white-space:nowrap; flex-shrink:0;
}

/* ── PROJECT DETAIL FOOTER ── */
.proj-footer {
    border-top:1px solid var(--border); padding:36px 24px; text-align:center;
}
.footer-back {
    display:inline-flex; align-items:center; gap:8px; color:var(--text-muted);
    text-decoration:none; font-size:.9rem; font-weight:500; transition:color .2s;
}
.footer-back:hover { color:var(--accent-lt); }

/* ── LOADING / NOT FOUND ── */
.loading-state, .notfound-state {
    min-height:100vh; display:flex; flex-direction:column;
    align-items:center; justify-content:center; text-align:center; padding:24px;
}
.loading-spinner {
    width:40px; height:40px; border:3px solid var(--border);
    border-top-color:var(--accent); border-radius:50%;
    animation:spin .8s linear infinite; margin-bottom:16px;
}
@keyframes spin { to { transform:rotate(360deg); } }
.notfound-state h1 { font-size:2rem; margin-bottom:12px; }
.notfound-state p { color:var(--text-muted); margin-bottom:28px; }

/* ── FADE UP (project detail) ── */
.fade-up {
    opacity:0; transform:translateY(24px);
    transition:opacity .6s ease, transform .6s ease;
}
.fade-up.in { opacity:1; transform:none; }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
    padding: 120px 0 60px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
    position: relative;
    overflow: hidden;
}
.page-hero-grid {
    position: absolute; inset: 0; pointer-events: none;
    background-image:
        linear-gradient(rgba(147,51,234,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(147,51,234,.03) 1px, transparent 1px);
    background-size: 60px 60px;
}
.page-hero-glow {
    position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(ellipse 60% 60% at 30% 50%, rgba(107,33,168,.18), transparent);
}
.page-hero-content { position: relative; z-index: 1; }
.page-hero-sub { color: var(--text-muted); font-size: 1rem; max-width: 60ch; margin-top: 12px; }

/* ── NAV ACTIVE STATE ── */
.nav-links a.active { color: var(--text) !important; }

/* ── FEATURED CARDS (index.html hardcoded) ── */
.featured-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 22px; }
.featured-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 16px; overflow: hidden; transition: all .3s;
    display: flex; flex-direction: column;
}
.featured-card:hover { border-color: var(--accent); transform: translateY(-5px); box-shadow: 0 0 20px var(--glow); }
.featured-cover { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; border-bottom: 1px solid var(--border); }
.featured-body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.featured-title { font-family: 'Oxanium', sans-serif; font-size: 1rem; font-weight: 600; margin-bottom: 8px; }
.featured-desc { color: var(--text-muted); font-size: .83rem; line-height: 1.6; margin-bottom: 14px; flex: 1; }
.featured-link {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--accent-lt); font-size: .82rem; font-weight: 600;
    text-decoration: none; transition: gap .2s;
}
.featured-link:hover { gap: 10px; }
.featured-award {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(250,204,21,.07); border: 1px solid rgba(250,204,21,.2);
    color: #fde68a; padding: 4px 10px; border-radius: 6px;
    font-size: .72rem; font-weight: 600; margin-bottom: 12px;
}

/* ── STATS STRIP (index.html slim) ── */
.stats-strip {
    background: var(--bg-card); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
    padding: 28px 0;
}
.stats-strip-inner {
    display: flex; align-items: center; justify-content: center;
    gap: 0; flex-wrap: wrap;
}
.strip-stat {
    display: flex; flex-direction: column; align-items: center;
    padding: 0 40px; border-right: 1px solid var(--border);
}
.strip-stat:last-child { border-right: none; }
.strip-n { font-family: 'Oxanium', sans-serif; font-size: 1.9rem; font-weight: 800; color: var(--accent); line-height: 1; }
.strip-l { font-size: .78rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; margin-top: 4px; }

/* ── QUICK LINKS (index.html) ── */
.quick-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.quick-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 14px; padding: 24px; display: flex; align-items: center;
    gap: 16px; text-decoration: none; color: var(--text);
    transition: all .2s;
}
.quick-card:hover { border-color: var(--accent); transform: translateX(4px); }
.quick-icon { color: var(--accent); flex-shrink: 0; display: flex; align-items: center; }
.quick-icon svg { display: block; }
.quick-info { flex: 1; }
.quick-label { font-weight: 600; font-size: .95rem; margin-bottom: 3px; }
.quick-desc { color: var(--text-muted); font-size: .78rem; }
.quick-arrow { color: var(--accent); display: flex; align-items: center; flex-shrink: 0; }
.quick-arrow svg { display: block; }
.reloc-pin { display: inline-flex; line-height: 0; }
.reloc-pin svg { display: block; }

/* ── ABOUT SUMMARY (index.html) ── */
.about-summary-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.about-summary-text p { color: var(--text-muted); line-height: 1.8; margin-bottom: 16px; }
.about-summary-link { color: var(--accent-lt); text-decoration: none; font-weight: 600; font-size: .9rem; transition: gap .2s; display: inline-flex; align-items: center; gap: 6px; }
.about-summary-link:hover { gap: 10px; }

/* ── CONTACT CTA (index.html) ── */
.contact-cta { text-align: center; }
.contact-cta p { color: var(--text-muted); font-size: 1rem; margin-bottom: 20px; max-width: 50ch; margin-left: auto; margin-right: auto; }
.contact-cta-links { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ── AVAILABILITY BADGE ── */
.avail-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(147,51,234,.1); border: 1px solid rgba(147,51,234,.35);
    border-radius: 100px; padding: 10px 24px; font-size: .88rem;
    color: var(--text-muted); font-weight: 500;
}

/* ── PRESS LIST (achievements.html) ── */
.press-list { display: flex; flex-direction: column; gap: 4px; }

/* ── CONTACT TWO-COL ── */
.contact-page-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: start; }

/* ── MOBILE ── */
@media (max-width: 768px) {
    .hamburger { display: flex; }
    .nav-links {
        display: none; position: fixed; top: 60px; left: 0; right: 0;
        background: rgba(13,10,20,.97); backdrop-filter: blur(14px);
        flex-direction: column; padding: 24px; gap: 22px;
        border-bottom: 1px solid var(--border);
    }
    .nav-links.open { display: flex; }
    .about-grid { grid-template-columns: 1fr; gap: 40px; }
    .scroll-hint { display: none; }
    section { padding: 72px 0; }
    .pub-card { padding: 26px; }
    .proj-tabs { flex-wrap: wrap; }
    .timeline { padding-left: 24px; }
    .tl-dot { left: -31px; }
    .ach-grid { grid-template-columns: 1fr; }
    .foot-inner { flex-direction: column; text-align: center; }
    .contact-link:hover { transform: none; }
    .hero-layout { grid-template-columns: 1fr; gap: 32px; }
    .hero-photo-wrap { width: 200px; height: 200px; margin: 0 auto; }
    .quick-grid { grid-template-columns: 1fr; }
    .about-summary-grid { grid-template-columns: 1fr; gap: 32px; }
    .contact-page-grid { grid-template-columns: 1fr; }
    .strip-stat { padding: 12px 24px; border-right: none; border-bottom: 1px solid var(--border); width: 100%; text-align: center; }
    .strip-stat:last-child { border-bottom: none; }
    .proj-hero { min-height: 60vh; }
    .proj-hero .hero-content { padding: 40px 18px 40px; }
    .hero-title { font-size: 1.85rem; }
    .gallery-grid { grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); }
    .pdf-frame { height: 60vh; }
    .art-source { display: none; }
    #lb-prev { left: 8px; }
    #lb-next { right: 8px; }
    .lb-btn { width:42px; height:42px; }
    .proj-content { padding: 8px 18px 60px; }
    .lang-chips { display: flex; flex-wrap: wrap; gap: 6px; padding: 12px 0 4px; border-top: 1px solid var(--border); margin-top: 8px; }
}
@media (max-width: 480px) {
    .hero-btns { flex-direction: column; }
    .btn-p, .btn-s { justify-content: center; }
    .proj-tabs .tab { flex: 1; text-align: center; }
    .skills-grid { grid-template-columns: 1fr; }
    .edu-grid { grid-template-columns: 1fr; }
    .gallery-grid { grid-template-columns: 1fr 1fr; }
    .hero-title { font-size: 1.6rem; }
    .itch-wrap { padding: 14px; }
}

/* ---- LANGUAGE SWITCHER ---- */
.lang-switcher { position: relative; }

.lang-btn {
    display: flex; align-items: center; gap: 6px;
    background: transparent; border: 1px solid var(--border);
    color: var(--text-muted); padding: 7px 14px; border-radius: 6px;
    font-family: 'DM Sans', sans-serif; font-size: .82rem;
    font-weight: 500; cursor: pointer; transition: all .2s;
}
.lang-btn:hover { border-color: var(--border-hi); color: var(--text); }

.lang-dropdown {
    position: absolute; top: calc(100% + 8px); right: 0;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 12px; padding: 8px; min-width: 200px;
    box-shadow: 0 8px 32px rgba(0,0,0,.4); z-index: 300;
    display: none;
}
.lang-dropdown.open { display: block; }

.lang-option {
    display: flex; align-items: center; justify-content: space-between;
    padding: 9px 14px; border-radius: 8px; cursor: pointer;
    font-size: .85rem; color: var(--text-muted); transition: all .15s;
    border: none; background: none; width: 100%; text-align: left;
    font-family: 'DM Sans', sans-serif;
}
.lang-option:hover { background: var(--bg-elevated); color: var(--text); }
.lang-option.active { color: var(--accent-lt); }
.lang-option .lang-native { font-weight: 500; }
.lang-option .lang-english { font-size: .75rem; color: var(--text-dim); }

/* ---- LANGUAGE NOTICE BANNER ---- */
.lang-notice {
    width: 100%; background: rgba(147,51,234,.08);
    border-bottom: 1px solid rgba(147,51,234,.3);
    padding: 12px 24px; display: flex; align-items: flex-start;
    gap: 12px; font-size: .85rem; color: var(--text-muted);
    position: relative; z-index: 190; line-height: 1.6;
    margin-top: 60px;
}
.lang-notice strong { color: var(--text); }
.lang-notice-dismiss {
    margin-left: auto; flex-shrink: 0; background: none; border: none;
    color: var(--text-dim); cursor: pointer; font-size: 1rem;
    padding: 0 4px; line-height: 1; transition: color .2s; align-self: center;
}
.lang-notice-dismiss:hover { color: var(--text); }
.lang-notice.hidden { display: none; }

/* ---- MOBILE LANGUAGE CHIPS ---- */
.lang-chips {
    display: none; /* shown only inside mobile nav via media query below */
}
.lang-chip {
    background: var(--bg-elevated); border: 1px solid var(--border);
    color: var(--text-muted); padding: 5px 12px; border-radius: 100px;
    font-size: .75rem; cursor: pointer; transition: all .2s;
    font-family: 'DM Sans', sans-serif;
}
.lang-chip:hover { border-color: var(--accent); color: var(--text); }
.lang-chip.active {
    background: rgba(147,51,234,.15); border-color: var(--accent); color: var(--accent-lt);
}
.lang-chip:focus-visible {
    outline: 2px solid var(--accent); outline-offset: 2px;
}
.lang-option:focus-visible {
    outline: 2px solid var(--accent); outline-offset: -2px;
}

/* ---- FILE SYSTEM SAVE MODAL ---- */
.fs-modal-overlay {
    position: fixed; inset: 0; z-index: 2000;
    background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .2s;
}
.fs-modal-overlay.open { opacity: 1; pointer-events: all; }
.fs-modal {
    background: var(--bg-card); border: 1px solid rgba(59,31,94,.7);
    border-radius: 16px; padding: 28px 32px; max-width: 400px; width: 90%;
    box-shadow: 0 24px 80px rgba(0,0,0,.6);
}
.fs-modal-title {
    font-family: 'Oxanium', sans-serif; font-weight: 700; font-size: 1.1rem;
    color: var(--text); margin: 0 0 12px;
}
.fs-modal-body {
    color: var(--text-muted); font-size: .88rem; line-height: 1.6; margin: 0 0 24px;
}
.fs-modal-btns { display: flex; gap: 10px; justify-content: flex-end; flex-wrap: wrap; }
.fs-modal-no {
    background: transparent; border: 1px solid var(--border); color: var(--text-muted);
    padding: 9px 18px; border-radius: 8px; font-family: 'DM Sans', sans-serif;
    font-size: .88rem; font-weight: 500; cursor: pointer; transition: all .2s;
}
.fs-modal-no:hover { border-color: var(--border-hi); color: var(--text); }
.fs-modal-save {
    background: linear-gradient(135deg, var(--accent), var(--accent-lt));
    border: none; color: #fff; padding: 9px 18px; border-radius: 8px;
    font-family: 'DM Sans', sans-serif; font-size: .88rem; font-weight: 600;
    cursor: pointer; transition: opacity .2s;
}
.fs-modal-save:hover { opacity: .85; }

/* ---- RTL LAYOUT ADJUSTMENTS (Arabic) ---- */
[dir="rtl"] .section-label::before { margin-left: 8px; margin-right: 0; }
[dir="rtl"] .timeline { padding-left: 0; padding-right: 32px; }
[dir="rtl"] .timeline::before { left: auto; right: 0; }
[dir="rtl"] .tl-dot { left: auto; right: -39px; }
[dir="rtl"] .cl:hover { transform: translateX(-6px); }
[dir="rtl"] .back-btn .back-arrow { transform: scaleX(-1); }
[dir="rtl"] .lang-dropdown { right: auto; left: 0; }
[dir="rtl"] .nav-inner { flex-direction: row-reverse; }
[dir="rtl"] .foot-inner { flex-direction: row-reverse; }
[dir="rtl"] .hero-layout { direction: rtl; }
[dir="rtl"] .tl-head { flex-direction: row-reverse; }

/* ============================================================= */
/* Design System Update - June 2026                              */
/* ============================================================= */

/* Achievement cards */
.achievement-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.achievement-card { display: flex; align-items: center; gap: 16px; background: var(--bg-card); border: 1px solid rgba(59,31,94,.7); border-radius: 14px; padding: 20px 24px; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.achievement-card:hover { border-color: var(--accent); transform: translateY(-3px); box-shadow: 0 0 18px var(--glow); }
.achievement-icon-well { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.achievement-year { display: inline-block; background: rgba(147,51,234,.2); border: 1px solid rgba(147,51,234,.4); color: var(--accent-lt); font-size: 12px; border-radius: 4px; padding: 2px 8px; margin-top: 6px; }

/* Achievement card text (supporting rules for the new layout) */
.achievement-body { min-width: 0; }
.achievement-title { font-family: 'Oxanium', sans-serif; font-size: 15px; font-weight: 700; color: var(--text); line-height: 1.3; }
.achievement-sub { font-size: 13px; color: var(--text-muted); margin-top: 4px; line-height: 1.4; }
.achievement-sub a { color: var(--accent-lt); }

/* Skills grid */
.skills-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.skill-card { background: var(--bg-card); border: 1px solid rgba(59,31,94,.7); border-radius: 14px; padding: 24px; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.skill-card:hover { border-color: var(--accent); transform: translateY(-4px); box-shadow: 0 0 18px var(--glow); }
.skill-card-icon { color: var(--accent); margin-bottom: 14px; line-height: 0; }
.skill-card h3 { font-family: 'Oxanium', sans-serif; font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 14px; }
.skill-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.skill-tag { background: rgba(147,51,234,.15); border: 1px solid rgba(147,51,234,.3); color: var(--text-muted); border-radius: 100px; padding: 4px 12px; font-size: 13px; }

/* Category badge on project cards */
.featured-cover-wrap, .proj-cover-wrap { position: relative; }
.project-category-badge { position: absolute; top: 10px; left: 10px; background: rgba(147,51,234,.25); border: 1px solid rgba(147,51,234,.5); color: #C4B0E0; font-size: 10px; font-family: 'DM Sans', sans-serif; text-transform: uppercase; letter-spacing: .05em; padding: 3px 8px; border-radius: 4px; z-index: 2; }

/* Cover icon fallback (shown via onerror when an image fails, or as the cover for image-less projects) */
.cover-icon-fallback { aspect-ratio: 16/9; background: var(--bg-elevated); }
.cover-icon-fallback svg { width: 40px; height: 40px; }
.featured-cover-wrap .cover-icon-fallback { border-bottom: 1px solid var(--border); }
.proj-cover-wrap .cover-icon-fallback { border-radius: 10px; margin-bottom: 18px; border: 1px solid var(--border); }

/* Relocation pill */
.relocation-pill { display: inline-flex; align-items: center; gap: 8px; background: rgba(147,51,234,.15); border: 1px solid rgba(147,51,234,.35); border-radius: 100px; padding: 10px 20px; color: var(--text-muted); font-size: 14px; }
.relocation-pill svg { color: var(--accent); }

/* Footer 3-column */
.footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-location { color: var(--text-muted); font-size: 14px; }

/* Responsive */
@media (max-width: 768px) {
  .achievement-grid { grid-template-columns: repeat(2, 1fr); }
  .skills-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { flex-direction: column; text-align: center; }
}
@media (max-width: 480px) {
  .achievement-grid { grid-template-columns: 1fr; }
  .skills-grid { grid-template-columns: 1fr; }
}
