:root{
    --bg0:#070A12;
    --bg1:#0B1020;
    --text:rgba(255,255,255,.92);
    --muted:rgba(255,255,255,.68);
    --border:rgba(255,255,255,.14);
    --glow1:#7c5cff;
    --glow2:#37d3ff;
    --glow3:#ff3bd4;
    --shadow:0 20px 70px rgba(0,0,0,.45);
    --radius:22px;
    --max:1150px;
}

/* Themes */
html[data-theme="neon"]{
    --bg0:#070A12; --bg1:#0B1020;
    --glow1:#7c5cff; --glow2:#37d3ff; --glow3:#ff3bd4;
    --border:rgba(255,255,255,.14);
}
html[data-theme="cyber"]{
    --bg0:#03060b; --bg1:#06151a;
    --glow1:#00ffa8; --glow2:#00c8ff; --glow3:#b000ff;
    --border:rgba(0,255,168,.22);
}
html[data-theme="mono"]{
    --bg0:#070707; --bg1:#101010;
    --glow1:#ffffff; --glow2:#cfcfcf; --glow3:#9a9a9a;
    --border:rgba(255,255,255,.12);
    --muted:rgba(255,255,255,.62);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
    margin:0;
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial;
    color:var(--text);
    background:
            radial-gradient(1200px 800px at 10% 10%, color-mix(in oklab, var(--glow1) 28%, transparent), transparent 55%),
            radial-gradient(900px 650px at 85% 15%, color-mix(in oklab, var(--glow2) 22%, transparent), transparent 60%),
            radial-gradient(950px 700px at 35% 90%, color-mix(in oklab, var(--glow3) 16%, transparent), transparent 55%),
            linear-gradient(180deg, var(--bg0), var(--bg1));
    overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }

#fx{
    position:fixed; inset:0;
    z-index:0;
    opacity:.9;
}

.grain{
    position:fixed; inset:0;
    pointer-events:none;
    background: repeating-radial-gradient(circle at 50% 50%, rgba(255,255,255,.03), rgba(255,255,255,0) 2px);
    opacity:.08;
    z-index:1;
}

/* Page transition overlay */
.page-transition{
    position:fixed; inset:0;
    z-index:50;
    pointer-events:none;
    opacity:0;
    background:
            radial-gradient(800px 500px at 20% 20%, color-mix(in oklab, var(--glow1) 35%, transparent), transparent 60%),
            radial-gradient(800px 500px at 80% 25%, color-mix(in oklab, var(--glow2) 28%, transparent), transparent 60%),
            radial-gradient(800px 500px at 50% 85%, color-mix(in oklab, var(--glow3) 18%, transparent), transparent 60%),
            rgba(0,0,0,.55);
    transition: opacity .35s ease;
    backdrop-filter: blur(10px);
}
.page-transition.on{ opacity:1; }

.wrap{
    max-width:var(--max);
    margin:auto;
    padding:120px 18px 80px;
    position:relative;
    z-index:2;
}

/* NAV */
.nav{
    position:fixed;
    top:14px; left:50%;
    transform:translateX(-50%);
    width:calc(100% - 28px);
    max-width:var(--max);
    padding:14px 16px;

    border:1px solid var(--border);
    border-radius:999px;

    /* SOLID NAVBAR (no see-through) */
    background: linear-gradient(
            180deg,
            rgba(10, 12, 18, 0.98),
            rgba(8, 10, 16, 0.98)
    );

    /* remove blur/transparency look */
    backdrop-filter: none;
    -webkit-backdrop-filter: none;

    display:flex;
    justify-content:space-between;
    align-items:center;
    z-index:10;

    box-shadow: 0 18px 60px rgba(0,0,0,.55);
}


.brand{ display:flex; gap:10px; align-items:center; font-weight:800; }
.orb{
    width:14px; height:14px; border-radius:50%;
    background:linear-gradient(135deg,var(--glow1),var(--glow2),var(--glow3));
    box-shadow:0 0 22px color-mix(in oklab, var(--glow1) 55%, transparent);
}

.navlinks{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

/* hamburger button hidden on desktop */
.navToggle{ display:none; }

.pill{
    padding:10px 12px;
    border-radius:999px;
    color:var(--muted);
    border:1px solid transparent;
    user-select:none;
}
.iconBtn{
    width:40px;
    height:40px;
    display:inline-flex;
    align-items:center;
    justify-content:center;

    border-radius:999px;
    border:1px solid var(--border);
    background: rgba(255,255,255,.06);
    cursor:pointer;
    transition: transform .18s ease, background .18s ease, border-color .18s ease;
    user-select:none;
}

.iconBtn:hover{
    transform: translateY(-1px);
    background: rgba(255,255,255,.09);
    border-color: color-mix(in oklab, var(--glow2) 35%, var(--border));
}

.iconBtn svg{
    width:18px;
    height:18px;
    fill: rgba(255,255,255,.88);
}

.pill:hover{ color:var(--text); border-color:var(--border); background:rgba(255,255,255,.05); }
.pill.primary{
    background:linear-gradient(135deg,
    color-mix(in oklab, var(--glow1) 35%, transparent),
    color-mix(in oklab, var(--glow2) 24%, transparent));
    border-color:color-mix(in oklab, var(--glow2) 35%, var(--border));
    color:rgba(255,255,255,.95);
}

.themeWrap{ position:relative; }
.themeMenu{
    position:absolute;
    right:0;
    top:48px;
    min-width:140px;
    border:1px solid var(--border);
    border-radius:16px;

    /* more solid menu */
    background: rgba(10, 12, 18, 0.98);

    box-shadow: var(--shadow);
    padding:8px;
    display:none;
}

.themeMenu.open{ display:block; }
.themeMenu button{
    width:100%;
    text-align:left;
    padding:10px 10px;
    border-radius:12px;
    border:0;
    background:transparent;
    color:var(--text);
    cursor:pointer;
}
.themeMenu button:hover{
    background:rgba(255,255,255,.07);
}

/* SECTIONS */
section{ padding:60px 0; }
.hero{ padding-top:0; }

.card{
    border:1px solid var(--border);
    border-radius:var(--radius);
    background:rgba(255,255,255,.05);
    box-shadow:var(--shadow);
    overflow:hidden;
}

.inner{ padding:26px; }

h1{ font-size:clamp(32px,5vw,56px); margin:0 0 10px; }
h2{ margin:0 0 10px; }

.sub{ color:var(--muted); max-width:75ch; }

.metaRow{ display:flex; gap:10px; flex-wrap:wrap; margin:14px 0; }

.chip{
    padding:8px 10px;
    border-radius:999px;
    border:1px solid var(--border);
    font-size:13px;
}

.pulse{
    display:inline-block;
    width:8px; height:8px; border-radius:50%;
    background:var(--glow2);
    box-shadow:0 0 14px var(--glow2);
    margin-right:8px;
    animation:pulse 1.3s infinite;
}
@keyframes pulse{ 0%,100%{ transform:scale(1); opacity:.6 } 50%{ transform:scale(1.6); opacity:1 } }

/* Grids */
.grid4{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}
@media(max-width:560px){ .grid4{ grid-template-columns:1fr; } }

.grid3{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:12px;
}
@media(max-width:820px){ .grid3{ grid-template-columns:1fr; } }

.mini{
    border:1px solid var(--border);
    background:rgba(255,255,255,.035);
    border-radius:18px;
    padding:14px;
}
.miniT{ font-weight:800; margin-bottom:6px; }
.miniD{ color:var(--muted); font-size:13px; }

/* Buttons */
.btn{
    padding:16px;
    border-radius:18px;
    border:1px solid var(--border);
    background:rgba(255,255,255,.04);
    transition:.2s;
    position:relative;
    overflow:hidden;
}
.btn:hover{
    transform:translateY(-3px);
    background:rgba(255,255,255,.07);
    border-color:color-mix(in oklab, var(--glow2) 30%, var(--border));
}
.btn::before{
    content:"";
    position:absolute; inset:-2px;
    background: radial-gradient(420px 220px at var(--mx, 50%) var(--my, 50%),
    color-mix(in oklab, var(--glow1) 35%, transparent),
    color-mix(in oklab, var(--glow2) 18%, transparent),
    color-mix(in oklab, var(--glow3) 10%, transparent),
    transparent 60%);
    opacity:0;
    transition:.2s;
    pointer-events:none;
}
.btn:hover::before{ opacity:1; }
.btn .t{ font-weight:800; }
.btn .d{ font-size:13px; color:var(--muted); }

.footer{
    text-align:center;
    color:var(--muted);
    font-size:13px;
    margin-top:40px;
}
/* Contact form */
.contactForm{
    display:grid;
    gap:12px;
    max-width: 720px;
}
.contactForm label{
    display:grid;
    gap:6px;
    color: var(--muted);
    font-size: 13px;
}
.contactForm input,
.contactForm textarea{
    border-radius: 14px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,.04);
    color: var(--text);
    padding: 12px 12px;
    outline: none;
}
.contactForm input:focus,
.contactForm textarea:focus{
    border-color: color-mix(in oklab, var(--glow2) 40%, var(--border));
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--glow2) 22%, transparent);
}

/* CV embed */
.cvFrameWrap{
    border-radius: 18px;
    overflow:hidden;
    border: 1px solid var(--border);
    background: rgba(255,255,255,.03);
}
.cvFrame{
    width: 100%;
    height: min(78vh, 900px);
    border: 0;
    display:block;
}
#about-entry,
#work-entry{
    scroll-margin-top: 140px; /* prevents nav overlap when linked */
}

/* -----------------------------
   Mobile + iOS navbar fixes (single source of truth)
   ----------------------------- */

/* Brand name: full on desktop, short on mobile */
.brand-short{ display:none; }
.brand-full{ display:inline; }

/* Dropdown triggers: never white on iOS */
#langBtn, #cvLangBtn, .nav .pill{
    -webkit-tap-highlight-color: transparent;
    appearance: none;
    -webkit-appearance: none;
}
#langBtn, #cvLangBtn{
    background: rgba(255,255,255,.06);
    color: var(--muted);
    border: 1px solid var(--border);
    text-decoration: none;
    cursor: pointer;
}
#langBtn:focus, #langBtn:active,
#cvLangBtn:focus, #cvLangBtn:active,
.nav .pill:focus, .nav .pill:active{
    outline: none;
    background: rgba(255,255,255,.10);
    color: var(--text);
}


@media (max-width: 720px){

    html, body{ overflow-x:hidden; }

    /* Navbar becomes sticky + full width (override desktop centering) */
    .nav{
        position: sticky;
        top: 10px;
        left: auto !important;
        right: auto !important;
        transform: none !important;
        width: calc(100% - 16px);
        max-width: 100%;
        margin: 8px auto;
        padding: 10px 12px;
        border-radius: 18px;
        box-sizing: border-box;
        z-index: 10000;
    }

    /* Mobile brand settings */
    .brand{ gap:6px; }

    /* Show hamburger button on mobile */
    .navToggle{ display:inline-flex; }

    /* --- Dropdown panel (compact, right-aligned) --- */
    #navLinks{
        position: fixed;
        top: 86px;
        right: 14px;
        left: auto;

        width: max-content;
        max-width: calc(100vw - 28px);
        min-width: 220px;

        display: flex;
        flex-direction: column;
        gap: 10px;

        padding: 14px;
        border: 1px solid var(--border);
        border-radius: 18px;
        background: rgba(10, 12, 18, 0.98);
        box-shadow: var(--shadow);
        z-index: 10001;

        /* Hidden state (animatable) */
        opacity: 0;
        transform-origin: top right;
        transform: translateY(-10px) scale(.98);
        visibility: hidden;
        pointer-events: none;

        transition:
                opacity .25s ease,
                transform .25s ease,
                visibility 0s linear .25s;
    }

    /* Panel open */
    #siteNav.open #navLinks{
        opacity: 1;
        transform: translateY(0) scale(1);
        visibility: visible;
        pointer-events: auto;
        transition:
                opacity .25s ease,
                transform .25s ease,
                visibility 0s linear 0s;
    }

    /* Items: staggered entrance */
    #navLinks > a,
    #navLinks > .themeWrap{
        opacity: 0;
        transform: translateY(-10px);
        transition:
                transform .28s cubic-bezier(0,.5,.5,1.1),
                opacity .18s ease;
    }

    #siteNav.open #navLinks > a,
    #siteNav.open #navLinks > .themeWrap{
        opacity: 1;
        transform: translateY(0);
    }

    /* Stagger delays */
    #siteNav.open #navLinks > *:nth-child(1){ transition-delay: 60ms; }
    #siteNav.open #navLinks > *:nth-child(2){ transition-delay: 120ms; }
    #siteNav.open #navLinks > *:nth-child(3){ transition-delay: 180ms; }
    #siteNav.open #navLinks > *:nth-child(4){ transition-delay: 240ms; }
    #siteNav.open #navLinks > *:nth-child(5){ transition-delay: 300ms; }
    #siteNav.open #navLinks > *:nth-child(6){ transition-delay: 360ms; }
    #siteNav.open #navLinks > *:nth-child(7){ transition-delay: 420ms; }
    #siteNav.open #navLinks > *:nth-child(8){ transition-delay: 480ms; }

    /* Pills should NOT stretch panel width */
    #navLinks .pill{
        width: auto;
        text-align: left;
        white-space: nowrap;
    }

    /* Theme dropdown menus inside panel */
    #navLinks .themeWrap{ width: 100%; }
    #navLinks .themeMenu{
        position: static;
        width: 100%;
        margin-top: 8px;
        max-width: none;
    }

    /* Reduce content offset on mobile */
    .wrap{ padding-top: 26px; }

    /* anchor jumps should account for sticky nav height */
    #about-entry, #work-entry{ scroll-margin-top: 120px; }
}

@media (max-width: 420px){
    .nav .pill{ font-size: 12px; padding: 7px 9px; }
}


/* Ensure FX layers never block taps */
#fx, .grain, #pageTransition{ pointer-events:none; }

/* ===== MOBILE DROPDOWN SIZE + CENTER ALIGN OVERRIDE ===== */
/* ===== MOBILE DROPDOWN FINAL OVERRIDE (RIGHT + CLEAN LANG MENU) ===== */
@media (max-width: 720px) {

    /* Panel: narrow + aligned to the right (under hamburger) */
    #siteNav.open #navLinks {
        left: auto !important;
        right: 14px !important;
        top: 82px !important;

        width: 230px !important;
        max-width: calc(100vw - 28px) !important;

        /* keep your open animation translateY/scale from earlier rules */
        transform-origin: top right !important;

        /* cleaner inside alignment */
        align-items: center !important;
        padding: 14px 12px !important;
    }

    /* Center the menu items */
    #siteNav.open #navLinks > a,
    #siteNav.open #navLinks > .themeWrap {
        width: 100% !important;
        text-align: center !important;
    }

    /* Make pills actually centered */
    #siteNav.open #navLinks .pill {
        width: 100% !important;
        text-align: center !important;
        justify-content: center !important;
        white-space: normal !important;
    }

    /* ✅ IMPORTANT: Make Languages dropdown appear UNDER the Languages button
   (effects.js sets it to fixed; we override that here) */
    #siteNav.open #langMenu {
        position: static !important;
        left: auto !important;
        top: auto !important;

        width: 100% !important;
        margin-top: 8px !important;

        border-radius: 16px !important;
        z-index: 10002 !important;
    }

    /* Same for theme menu if you open it inside the dropdown */
    #siteNav.open #themeMenu {
        position: static !important;
        left: auto !important;
        top: auto !important;

        width: 100% !important;
        margin-top: 8px !important;

        z-index: 10002 !important;
    }

}
/* ===== Desktop dropdown style: match mobile panel look ===== */
@media (min-width: 721px){

    /* Language + theme dropdown containers */
    #langMenu,
    #themeMenu{
        /* keep effects.js positioning (fixed with left/top), just restyle */
        display: none; /* JS will set to block when open */
        width: 230px;
        padding: 10px;
        border-radius: 18px;

        background: rgba(10, 12, 18, 0.98);
        border: 1px solid var(--border);
        box-shadow: var(--shadow);

        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);

        overflow: hidden;
    }

    /* When JS adds .open, animate in */
    #langMenu.open,
    #themeMenu.open{
        display: block;
        animation: dropdownIn 180ms ease-out;
        transform-origin: top right;
    }

    /* Buttons inside the dropdown */
    #langMenu button,
    #themeMenu button{
        width: 100%;
        border-radius: 14px;
        padding: 10px 12px;

        background: rgba(255,255,255,0.03);
        border: 1px solid rgba(255,255,255,0.06);
        color: inherit;

        text-align: left;
        cursor: pointer;
        transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
    }

    #langMenu button:hover,
    #themeMenu button:hover{
        background: rgba(124, 58, 237, 0.10);
        border-color: rgba(124, 58, 237, 0.35);
        transform: translateY(-1px);
    }

    #langMenu button:active,
    #themeMenu button:active{
        transform: translateY(0);
    }

    @keyframes dropdownIn{
        from { opacity: 0; transform: translateY(-8px) scale(.98); }
        to   { opacity: 1; transform: translateY(0) scale(1); }
    }
}

/* ===== Desktop: hide hamburger + move Car/Links into Extra dropdown ===== */
@media (min-width: 721px){
    /* Force-hide hamburger on desktop */
    .navToggle{ display: none !important; }

    /* Hide the mobile-only Car/Links items in the main row */
    .navlinks a[data-extra-mobile="1"]{ display: none !important; }

    /* Extra dropdown visible on desktop */
    #extraWrap{ display: inline-flex !important; }

    /* Make links inside dropdown look like menu items (same as buttons) */
    #extraMenu a{
        display: block;
        width: 100%;
        border-radius: 14px;
        padding: 10px 12px;
        color: var(--text);
        background: rgba(255,255,255,0.03);
        border: 1px solid rgba(255,255,255,0.06);
        text-align: left;
        transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
    }
    #extraMenu a:hover{
        background: rgba(124, 58, 237, 0.10);
        border-color: rgba(124, 58, 237, 0.35);
        transform: translateY(-1px);
    }
}

/* Mobile: Extra dropdown hidden (use hamburger list instead) */
@media (max-width: 720px){
    #extraWrap{ display: none !important; }
}
/* ===== Fix Extras dropdown white background ===== */
#extraMenu.themeMenu{
    background: rgba(10, 12, 18, 0.98) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

#extraMenu a{
    color: var(--text) !important;
    text-decoration: none !important;
}
/* ===== FORCE: dropdown glass style (Languages / Extra / Theme) ===== */
.themeMenu,
#langMenu,
#extraMenu,
#themeMenu {
    background: rgba(10, 12, 18, 0.98) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow) !important;
    color: var(--text) !important;
    border-radius: 16px !important;
    padding: 10px !important;
    min-width: 200px !important;
    max-width: calc(100vw - 28px) !important;
    overflow: hidden !important;
}

/* make any <a> or <button> inside look consistent */
.themeMenu button,
.themeMenu a,
#langMenu button,
#langMenu a,
#extraMenu a,
#themeMenu button,
#themeMenu a {
    display: block !important;
    width: 100% !important;
    text-align: left !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    background: transparent !important;
    border: 1px solid rgba(255,255,255,0.03) !important;
    color: inherit !important;
    transition: background .12s ease, transform .12s ease, border-color .12s ease;
}

.themeMenu button:hover,
.themeMenu a:hover,
#langMenu button:hover,
#langMenu a:hover,
#extraMenu a:hover,
#themeMenu button:hover,
#themeMenu a:hover {
    background: rgba(124,58,237,0.08) !important;
    border-color: rgba(124,58,237,0.28) !important;
    transform: translateY(-1px);
}

/* ensure open menu is visible (JS toggles .open, but ensure no other rule hides it) */
.themeMenu { visibility: visible !important; opacity: 1 !important; }

/* Desktop: keep the dropdown anchored to the right edge of its button */
@media (min-width: 721px){
    #langMenu, #extraMenu, #themeMenu {
        transform-origin: top right !important;
    }
}

/* Mobile: menus inside the hamburger panel should be full-width of panel */
@media (max-width: 720px){
    #siteNav.open .themeMenu,
    #siteNav.open #langMenu,
    #siteNav.open #extraMenu {
        position: static !important;
        width: 100% !important;
        margin-top: 8px !important;
    }
}
/* ===== FORCE dropdown glass style (Languages / Extras / Theme) ===== */
.themeMenu,
#langMenu,
#extraMenu,
#themeMenu {
    background: rgba(10, 12, 18, 0.98) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow) !important;
    color: var(--text) !important;
}

.themeMenu button,
.themeMenu a {
    background: transparent !important;
    color: inherit !important;
}
/* ===== Fix: Extras button turns white when it keeps focus ===== */
#extraBtn,
#extraBtn:focus,
#extraBtn:focus-visible,
#extraBtn:active {
    background: rgba(255,255,255,0.04) !important;
    color: var(--text) !important;
    border: 1px solid var(--border) !important;
    outline: none !important;
}

/* optional: keep a subtle focus ring without turning white */
#extraBtn:focus-visible{
    box-shadow: 0 0 0 2px rgba(124,58,237,0.25) !important;
}
/* Stretch dark background behind mobile browser bars */
html,
body{
    background-color: #020617; /* your dark base color */
    min-height: 100%;
}

body{
    min-height: 100vh;
}
