/* =============================================
   ☕ FAMYXLYE.ME — PRODUCTION LOFI THEME
   Warm · Muted · Cozy · Production-ready
   ============================================= */

/* ===== KEYFRAMES ===== */
@keyframes loaderFill { from{width:0} to{width:100%} }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
@keyframes vinylSpin { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes barPulse { 0%,100%{width:var(--lv)} 50%{width:calc(var(--lv) - 5%)} }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-4px)} }
@keyframes heartFloat { 0%{transform:translateY(0) scale(1);opacity:1} 100%{transform:translateY(-25px) scale(.5);opacity:0} }
@keyframes grainAnim { 0%{transform:translate(0,0)} 10%{transform:translate(-5%,-10%)} 20%{transform:translate(-15%,5%)} 30%{transform:translate(7%,-25%)} 40%{transform:translate(-5%,25%)} 50%{transform:translate(-15%,10%)} 60%{transform:translate(15%,0)} 70%{transform:translate(0,15%)} 80%{transform:translate(3%,35%)} 90%{transform:translate(-10%,10%)} 100%{transform:translate(0,0)} }
@keyframes pageIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes skillFill { from{width:0} to{width:var(--lv)} }
@keyframes revealUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes particleDrift { 0%{transform:translate(0,0);opacity:0} 10%{opacity:.6} 90%{opacity:.6} 100%{transform:translate(var(--dx),var(--dy));opacity:0} }
@keyframes slideDown { from{opacity:0;transform:translateY(-10px)} to{opacity:1;transform:translateY(0)} }
@keyframes shimmer { 0%{background-position:200% center} 100%{background-position:-200% center} }
@keyframes ringPulse { 0%,100%{box-shadow:0 0 0 0 rgba(196,149,106,.4)} 50%{box-shadow:0 0 8px 2px rgba(196,149,106,.15)} }
@keyframes tiltIn { from{opacity:0;transform:perspective(400px) rotateX(8deg)} to{opacity:1;transform:perspective(400px) rotateX(0)} }

/* ===== CUSTOM PROPERTIES ===== */
:root {
    --bg: #1c1814; --bg2: #241f1a; --card: #2a2420; --card-border: #3a3228;
    --text: #d4c8b8; --muted: #8a7e70; --accent: #c4956a;
    --accent2: #7a9e7e; --warm: #b8956a; --cool: #6a8a9e;
    --rose: #b07878; --cream: #e8dcc8; --f-mono: 'Space Mono', monospace;
    --f-sans: 'Inter', sans-serif; --f-serif: 'DM Serif Display', serif;
    --radius: 8px; --transition: .3s cubic-bezier(.4,0,.2,1);
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; }

body {
    font-family:var(--f-sans); font-size:15px; color:var(--text);
    background: var(--bg);
    min-height:100vh; overflow-x:hidden; line-height:1.6;
}

/* ===== SMOOTH SCROLL ===== */
#smoothWrap {
    position:fixed; inset:0; overflow:hidden;
    width:100%; height:100%;
}
#smoothContent {
    will-change:transform;
    backface-visibility:hidden;
}

/* ===== UTILITIES ===== */
.sr-only {
    position:absolute; width:1px; height:1px; padding:0; margin:-1px;
    overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ===== GRAIN OVERLAY ===== */
.grain-overlay {
    position:fixed; inset:-50%; width:200%; height:200%; z-index:9998; pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
    animation:grainAnim 8s steps(10) infinite;
    opacity:.4;
}

/* ===== PARTICLES ===== */
#particles {
    position:fixed; inset:0; pointer-events:none; z-index:9995; overflow:hidden;
}
.particle {
    position:absolute; width:3px; height:3px; border-radius:50%;
    background:var(--accent); opacity:0;
    animation:particleDrift var(--dur) linear infinite;
    animation-delay:var(--delay);
}

/* ===== LOADER ===== */
#loader {
    position:fixed; inset:0; z-index:99999; background:var(--bg);
    display:flex; align-items:center; justify-content:center;
    transition:opacity .8s, visibility .8s;
}
#loader.hidden { opacity:0; visibility:hidden; pointer-events:none; }
.loader-content { text-align:center; }
.loader-icon { font-size:32px; animation:float 2s ease-in-out infinite; margin-bottom:12px; }
.loader-text { font-family:var(--f-mono); font-size:12px; color:var(--muted); letter-spacing:2px; }
.loader-bar { width:160px; height:3px; background:var(--card); margin:14px auto 0; border-radius:2px; overflow:hidden; }
.loader-fill { height:100%; background:linear-gradient(90deg,var(--accent),var(--accent2)); animation:loaderFill 2s ease forwards; border-radius:2px; }

/* ===== CANVAS ===== */
#cursorCanvas { position:fixed; inset:0; pointer-events:none; z-index:9996; }

/* ===== LIGHTBOX ===== */
.lightbox {
    position:fixed; inset:0; z-index:10001; background:rgba(28,24,20,.92);
    display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s;
    backdrop-filter:blur(6px);
}
.lightbox.active { opacity:1; visibility:visible; }
.lb-close {
    position:absolute; top:20px; right:24px; font-size:28px;
    color:var(--cream); background:none; border:none; cursor:pointer;
    width:40px; height:40px; display:flex; align-items:center; justify-content:center;
    border-radius:50%; transition:background .2s;
}
.lb-close:hover { background:rgba(255,255,255,.1); }
.lb-content {
    max-width:90vw; max-height:85vh; display:flex;
    align-items:center; justify-content:center;
}
.lb-content img { max-width:100%; max-height:85vh; border-radius:var(--radius); border:2px solid var(--card-border); }

/* ===== BACK TO TOP ===== */
.back-to-top {
    position:fixed; bottom:24px; right:24px; z-index:10000;
    width:40px; height:40px; border-radius:50%;
    background:var(--card); border:1px solid var(--card-border);
    color:var(--accent); font-size:18px;
    cursor:pointer; display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transform:translateY(10px);
    transition:opacity .3s, visibility .3s, transform .3s, background .2s, border-color .2s;
    box-shadow:0 2px 12px rgba(0,0,0,.3);
}
.back-to-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.back-to-top:hover { background:var(--accent); color:var(--bg); border-color:var(--accent); }

/* ===== HEADER ===== */
.lo-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:16px 24px; border-bottom:1px solid var(--card-border);
    background:rgba(28,24,20,.92); backdrop-filter:blur(10px);
    position:relative; z-index:100;
}
.header-progress {
    position:absolute; bottom:0; left:0; height:2px;
    background:linear-gradient(90deg, var(--accent), var(--accent2));
    width:0; transition:width .1s linear; z-index:101;
}
.lo-brand { display:flex; align-items:center; gap:8px; }
.brand-icon { font-size:20px; }
.brand-name {
    font-family:var(--f-serif); font-size:22px;
    background:linear-gradient(90deg, var(--cream) 0%, var(--accent) 40%, var(--cream) 60%, var(--accent) 100%);
    background-size:200% auto;
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
    animation:shimmer 6s linear infinite;
}
.lo-nav { display:flex; gap:4px; }
.nav-link {
    font-family:var(--f-mono); font-size:12px; color:var(--muted);
    text-decoration:none; padding:6px 14px; border-radius:var(--radius);
    transition:all .25s; position:relative;
}
.nav-link::after {
    content:''; position:absolute; bottom:2px; left:14px; right:14px;
    height:1px; background:var(--accent); transform:scaleX(0);
    transition:transform .25s ease; transform-origin:center;
}
.nav-link:hover::after { transform:scaleX(1); }
.nav-link:hover { color:var(--text); background:var(--card); }
.nav-link.active { color:var(--accent); background:rgba(196,149,106,.1); }
.nav-link.active::after { transform:scaleX(1); }

/* MOBILE TOGGLE */
.mobile-toggle {
    display:none; flex-direction:column; gap:4px; padding:6px;
    background:none; border:1px solid var(--card-border); border-radius:var(--radius);
    cursor:pointer; z-index:101;
}
.mt-bar {
    display:block; width:20px; height:2px; background:var(--cream);
    border-radius:1px; transition:all .3s;
}
.mobile-toggle.active .mt-bar:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.mobile-toggle.active .mt-bar:nth-child(2) { opacity:0; transform:scaleX(0); }
.mobile-toggle.active .mt-bar:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

/* ===== LAYOUT ===== */
.lo-layout {
    display:flex; gap:16px; padding:16px 24px;
    max-width:1300px; margin:0 auto;
}
.lo-sidebar { width:220px; flex-shrink:0; display:flex; flex-direction:column; gap:12px; }
.lo-main { flex:1; min-width:0; display:flex; flex-direction:column; gap:12px; }
.lo-page { display:none; flex-direction:column; gap:12px; opacity:0; }
.lo-page.active { display:flex; animation:pageIn .5s ease forwards; }

/* ===== SCROLL REVEAL ===== */
.reveal {
    opacity:0; transform:translateY(20px);
    transition:opacity .6s ease, transform .6s ease;
}
.reveal.revealed { opacity:1; transform:translateY(0); }

/* ===== CARD ===== */
.lo-card {
    background:var(--card); border:1px solid var(--card-border);
    border-radius:var(--radius); padding:14px; position:relative;
    transition:border-color .3s, box-shadow .3s;
}
.lo-card:hover { border-color:rgba(196,149,106,.3); box-shadow:0 2px 16px rgba(0,0,0,.15); }
.main-card { padding:20px; }
.card-label {
    font-family:var(--f-mono); font-size:10px; color:var(--muted);
    text-transform:uppercase; letter-spacing:2px; margin-bottom:12px;
    padding-bottom:8px; border-bottom:1px solid rgba(58,50,40,.3);
}

/* ===== MINI PROFILE ===== */
.mini-profile { text-align:center; }
.mp-avatar-ring {
    width:52px; height:52px; border-radius:50%; margin:0 auto 6px;
    background:linear-gradient(135deg, var(--accent), var(--accent2), var(--rose));
    padding:2px; animation:ringPulse 3s ease-in-out infinite;
}
.mp-avatar {
    width:100%; height:100%; border-radius:50%; background:var(--card);
    display:flex; align-items:center; justify-content:center;
    font-size:20px; font-family:var(--f-serif); color:var(--cream);
}
.mp-name { font-family:var(--f-serif); font-size:18px; color:var(--cream); }
.mp-aka { font-size:12px; color:var(--muted); margin:2px 0; }
.mp-status { font-size:12px; color:var(--accent2); display:flex; align-items:center; justify-content:center; gap:4px; }
.pulse { animation:pulse 2s infinite; font-size:8px; }

/* ===== NOW PLAYING ===== */
.np-widget { display:flex; align-items:center; gap:12px; }
.np-vinyl {
    width:44px; height:44px; border-radius:50%; flex-shrink:0;
    background:conic-gradient(#2a2420,#3a3228,#2a2420,#3a3228,#2a2420);
    display:flex; align-items:center; justify-content:center;
    animation:vinylSpin 3s linear infinite;
    border:2px solid var(--card-border);
}
.vinyl-label { font-size:12px; color:var(--accent); }
.np-info { flex:1; min-width:0; }
.np-title { font-family:var(--f-mono); font-size:11px; color:var(--cream); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.np-artist { font-size:11px; color:var(--muted); }
.np-progress { height:2px; background:var(--bg); border-radius:1px; margin-top:6px; }
.np-bar { height:100%; background:var(--accent); border-radius:1px; width:35%; transition:width .3s; }

/* ===== BLINKIES & STAMPS ===== */
.blinkie-wall, .blinkie-showcase { display:flex; flex-wrap:wrap; gap:4px; justify-content:center; }
.lo-blinkie { border-radius:4px; overflow:hidden; transition:transform .2s; }
.lo-blinkie:hover { transform:scale(1.05); }
.lo-blinkie img { display:block; max-width:100%; height:auto; }
.stamp-wall, .stamp-showcase { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.lo-stamp { border-radius:4px; overflow:hidden; border:1px solid var(--card-border); transition:all .2s; }
.lo-stamp.lg { width:120px; height:120px; }
.lo-stamp img { display:block; width:100%; height:100%; object-fit:contain; }
.lo-stamp:hover { transform:rotate(-2deg) scale(1.05); border-color:var(--accent); }

/* ===== BUTTONS ===== */
.buttons-wall { display:flex; flex-wrap:wrap; gap:4px; justify-content:center; }
.lo-button { border-radius:4px; overflow:hidden; border:1px solid var(--card-border); transition:all .2s; }
.lo-button img { display:block; width:88px; height:31px; }
.lo-button:hover { transform:translateY(-2px); border-color:var(--accent); }

/* ===== WELCOME ===== */
.welcome-text { line-height:1.8; font-size:14px; }
.welcome-text p { margin-bottom:8px; }
.welcome-text strong { color:var(--accent); font-weight:600; }
.welcome-text em { color:var(--muted); font-style:italic; }

/* TEXT SCRAMBLE */
.scramble { cursor:default; }

/* ===== BIRTHDAY ===== */
.bday-section { display:flex; align-items:center; gap:14px; }
.bday-icon { font-size:24px; }
.bday-label { font-family:var(--f-mono); font-size:10px; color:var(--muted); letter-spacing:1px; }
.bday-timer { font-family:var(--f-mono); font-size:16px; color:var(--accent); margin:4px 0; }

/* ===== PROFILE ===== */
.profile-header { display:flex; align-items:center; gap:16px; margin-bottom:16px; flex-wrap:wrap; }
.ph-avatar-ring {
    width:56px; height:56px; border-radius:50%; flex-shrink:0;
    background:linear-gradient(135deg, var(--accent), var(--accent2), var(--rose));
    padding:2px;
}
.ph-avatar {
    width:100%; height:100%; border-radius:50%; background:var(--card);
    display:flex; align-items:center; justify-content:center;
    font-size:22px; font-family:var(--f-serif); color:var(--cream);
}
.ph-name { font-family:var(--f-serif); font-size:20px; color:var(--cream); }
.ph-tags { display:flex; flex-wrap:wrap; gap:4px; margin-top:4px; }
.tag {
    font-family:var(--f-mono); font-size:10px; color:var(--accent);
    padding:3px 8px; border:1px solid rgba(196,149,106,.3);
    border-radius:var(--radius); transition:all .2s;
}
.tag:hover { background:rgba(196,149,106,.1); border-color:var(--accent); }
.info-grid { display:flex; flex-direction:column; gap:2px; }
.info-row {
    display:flex; justify-content:space-between; padding:6px 0;
    border-bottom:1px solid rgba(58,50,40,.5); font-size:14px;
}
.info-key { font-family:var(--f-mono); font-size:11px; color:var(--muted); }
.info-val { color:var(--cream); }

/* ===== PERSONALITY ===== */
.personality-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px; }
.pcard {
    padding:14px; text-align:center; border:1px solid var(--card-border);
    border-radius:var(--radius); transition:all .2s;
    border-top:2px solid transparent;
}
.pcard:nth-child(1) { border-top-color:var(--accent); }
.pcard:nth-child(2) { border-top-color:var(--rose); }
.pcard:nth-child(3) { border-top-color:var(--accent2); }
.pcard:nth-child(4) { border-top-color:var(--cool); }
.pcard:nth-child(5) { border-top-color:var(--warm); }
.pcard:nth-child(6) { border-top-color:var(--muted); }
.pcard:hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:0 3px 12px rgba(0,0,0,.12); }
.pc-label { font-family:var(--f-mono); font-size:9px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.pc-val { font-family:var(--f-serif); font-size:16px; color:var(--accent); margin:4px 0; }
.pc-sub { font-size:11px; color:var(--muted); }

/* ===== SKILLS ===== */
.skills-list { display:flex; flex-direction:column; gap:10px; }
.skill-row { display:flex; align-items:center; gap:10px; }
.sk-name { font-family:var(--f-mono); font-size:10px; color:var(--muted); min-width:80px; text-transform:uppercase; letter-spacing:1px; }
.sk-track { flex:1; height:6px; background:var(--bg); border-radius:3px; overflow:hidden; }
.sk-fill { height:100%; background:linear-gradient(90deg,var(--accent),var(--accent2)); border-radius:3px; width:0; transition:width 1.5s ease; }
.sk-pct { font-family:var(--f-mono); font-size:10px; color:var(--muted); min-width:30px; text-align:right; }

/* ===== INTERESTS ===== */
.interests-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; }
.interest-card {
    padding:14px 16px; text-align:left; border:1px solid var(--card-border);
    border-left:2px solid var(--accent); border-radius:var(--radius); transition:all .25s;
}
.interest-card:nth-child(even) { border-left-color:var(--accent2); }
.interest-card:nth-child(3n) { border-left-color:var(--rose); }
.interest-card:hover { border-color:var(--accent); transform:translateY(-3px); box-shadow:0 3px 12px rgba(0,0,0,.12); }
.ic-name { font-family:var(--f-mono); font-size:11px; color:var(--cream); font-weight:700; }
.ic-sub { font-size:11px; color:var(--muted); margin-top:2px; }

/* ===== WAIFU ===== */
.waifu-section { display:flex; gap:16px; align-items:center; flex-wrap:wrap; justify-content:center; }
.waifu-frame {
    width:90px; height:90px; border-radius:var(--radius);
    border:1px solid var(--card-border); overflow:hidden; flex-shrink:0;
    cursor:pointer; transition:border-color .2s, transform .2s;
}
.waifu-frame:hover { border-color:var(--accent); transform:scale(1.05); }
.waifu-frame img { width:100%; height:100%; object-fit:cover; display:block; }
.waifu-info { flex:1; min-width:160px; }
.wi-name { font-family:var(--f-serif); font-size:16px; color:var(--accent); }
.wi-source { font-size:12px; color:var(--muted); }
.wi-desc { font-size:12px; color:var(--text); margin:6px 0; line-height:1.6; opacity:.85; }
.wi-hearts { color:var(--rose); letter-spacing:2px; margin:4px 0; }
.wi-score { font-family:var(--f-mono); font-size:11px; color:var(--accent2); }

/* ===== ANIME LIST ===== */
.anime-list { display:flex; flex-direction:column; gap:2px; }
.al-row { display:flex; align-items:center; gap:8px; padding:6px 4px; border-bottom:1px solid rgba(58,50,40,.5); font-size:13px; transition:background .2s; border-radius:4px; }
.al-row:hover { background:rgba(196,149,106,.04); }
.al-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.al-dot.watching { background:var(--accent2); }
.al-dot.done { background:var(--accent); }
.al-dot.plan { background:var(--muted); }
.al-title { flex:1; }
.al-ep { font-family:var(--f-mono); font-size:10px; color:var(--muted); }

/* ===== MUSIC LIST ===== */
.music-list { display:flex; flex-direction:column; gap:2px; }
.ml-row { display:flex; align-items:center; gap:10px; padding:7px 4px; border-bottom:1px solid rgba(58,50,40,.5); font-size:13px; transition:background .2s; border-radius:4px; }
.ml-row:hover { background:rgba(196,149,106,.04); }
.ml-icon { font-size:14px; flex-shrink:0; }
.ml-title { flex:1; color:var(--cream); font-size:13px; }
.ml-artist { font-family:var(--f-mono); font-size:10px; color:var(--muted); }

/* ===== GAMES ===== */
.games-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; }
.game-card {
    padding:12px 14px; text-align:left; border:1px solid var(--card-border);
    border-left:2px solid var(--accent2); border-radius:var(--radius); transition:all .25s;
}
.game-card:hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:0 3px 12px rgba(0,0,0,.15); }
.gc-name { font-family:var(--f-mono); font-size:11px; color:var(--cream); font-weight:700; }
.gc-note { font-size:10px; color:var(--muted); margin-top:2px; }

/* ===== GALLERY ===== */
.desc-muted { font-size:13px; color:var(--muted); margin-bottom:12px; }
.gallery-filters { display:flex; gap:6px; margin-bottom:14px; flex-wrap:wrap; }
.filter-btn {
    font-family:var(--f-mono); font-size:10px; color:var(--muted);
    padding:5px 12px; border:1px solid var(--card-border); border-radius:var(--radius);
    background:none; cursor:pointer; text-transform:uppercase; letter-spacing:1px;
    transition:all .2s;
}
.filter-btn:hover { color:var(--text); border-color:var(--muted); }
.filter-btn.active { color:var(--accent); background:rgba(196,149,106,.1); border-color:var(--accent); }
.lo-gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px; }
.gal-item {
    aspect-ratio:1; border-radius:var(--radius); display:flex;
    flex-direction:column; align-items:center; justify-content:center; gap:6px;
    cursor:pointer; transition:all .35s cubic-bezier(.4,0,.2,1); border:1px solid var(--card-border);
    position:relative; overflow:hidden;
}
.gal-item::before {
    content:''; position:absolute; inset:0; background:rgba(0,0,0,.15);
    opacity:0; transition:opacity .3s; border-radius:var(--radius);
}
.gal-item:hover::before { opacity:1; }
.gal-item.hidden { display:none; }
.gal-label { font-family:var(--f-mono); font-size:11px; color:rgba(255,255,255,.9); text-transform:uppercase; letter-spacing:2px; font-weight:700; position:relative; z-index:1; }
.gal-item:hover { transform:scale(1.05) translateY(-2px); border-color:var(--accent); box-shadow:0 4px 16px rgba(0,0,0,.2); }

/* ===== GUESTBOOK ===== */
.gb-form { display:flex; flex-direction:column; gap:12px; }
.gb-row { display:flex; flex-direction:column; gap:4px; }
.gb-label { font-family:var(--f-mono); font-size:10px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.gb-input {
    background:var(--bg); border:1px solid var(--card-border); color:var(--text);
    font-family:var(--f-sans); font-size:14px; padding:10px; border-radius:var(--radius);
    outline:none; transition:border-color .2s;
}
.gb-input:focus { border-color:var(--accent); }
.gb-textarea { min-height:80px; resize:vertical; }
.gb-icons { display:flex; gap:6px; }
.gb-icon-opt input { display:none; }
.gb-icon-opt span {
    display:block; width:34px; height:34px; line-height:34px; text-align:center;
    font-size:16px; border:1px solid var(--card-border); border-radius:var(--radius);
    cursor:pointer; transition:all .2s;
}
.gb-icon-opt input:checked + span { border-color:var(--accent); background:rgba(196,149,106,.1); }
.gb-submit {
    font-family:var(--f-mono); font-size:11px; padding:10px 20px;
    background:rgba(196,149,106,.15); border:1px solid var(--accent);
    color:var(--accent); border-radius:var(--radius); cursor:pointer;
    transition:all .25s; align-self:flex-start; text-transform:uppercase; letter-spacing:1px;
    position:relative; overflow:hidden;
}
.gb-submit::after {
    content:''; position:absolute; inset:0;
    background:linear-gradient(90deg, transparent, rgba(196,149,106,.1), transparent);
    transform:translateX(-100%); transition:transform .5s;
}
.gb-submit:hover { background:rgba(196,149,106,.25); }
.gb-submit:hover::after { transform:translateX(100%); }
.gb-entries { display:flex; flex-direction:column; gap:8px; }
.gb-entry {
    display:flex; gap:10px; padding:12px; border:1px solid var(--card-border);
    border-radius:var(--radius); animation:fadeIn .4s ease; transition:border-color .2s;
}
.gb-entry:hover { border-color:rgba(196,149,106,.25); }
.ge-icon { font-size:18px; flex-shrink:0; }
.ge-body { flex:1; }
.ge-header { display:flex; justify-content:space-between; margin-bottom:2px; flex-wrap:wrap; gap:4px; }
.ge-name { font-family:var(--f-mono); font-size:10px; color:var(--accent); }
.ge-date { font-size:11px; color:var(--muted); }
.ge-msg { font-size:13px; }
.gb-empty { text-align:center; color:var(--muted); font-style:italic; padding:20px; }
.gb-empty.hidden { display:none; }

/* ===== LINKS ===== */
.links-grid { display:flex; flex-direction:column; gap:4px; }
.link-item {
    display:flex; align-items:center; gap:10px; padding:8px 12px;
    border:1px solid var(--card-border); border-radius:var(--radius);
    transition:all .25s; text-decoration:none; color:inherit;
}
.link-item:hover { border-color:var(--accent); transform:translateX(4px); background:rgba(196,149,106,.04); }
.li-icon { font-size:16px; transition:transform .25s; }
.link-item:hover .li-icon { transform:translateX(3px); }
.li-label { font-family:var(--f-mono); font-size:10px; color:var(--muted); min-width:60px; text-transform:uppercase; }
.li-val { font-size:13px; color:var(--cream); }

/* ===== BYF ===== */
.byf-section { display:flex; gap:20px; flex-wrap:wrap; }
.byf-col { flex:1; min-width:140px; }
.byf-title { font-family:var(--f-mono); font-size:11px; margin-bottom:8px; }
.byf-title.green { color:var(--accent2); }
.byf-title.red { color:var(--rose); }
.byf-list { list-style:none; display:flex; flex-direction:column; gap:4px; }
.byf-list li { font-size:12px; color:var(--muted); padding:4px 0; border-bottom:1px solid rgba(58,50,40,.3); transition:color .2s; }
.byf-list li:hover { color:var(--text); }
.byf-list li:last-child { border-bottom:none; }

/* ===== CHANGELOG ===== */
.changelog { display:flex; flex-direction:column; gap:4px; }
.cl-entry { display:flex; align-items:baseline; gap:12px; padding:5px 0; border-bottom:1px solid rgba(58,50,40,.3); }
.cl-date { font-family:var(--f-mono); font-size:10px; color:var(--accent); min-width:65px; }
.cl-text { font-size:12px; color:var(--muted); }

/* ===== CLOCK ===== */
.lo-clock { font-family:var(--f-mono); font-size:18px; color:var(--accent); text-align:center; }
.lo-date { font-family:var(--f-mono); font-size:10px; color:var(--muted); text-align:center; margin-top:2px; }

/* ===== VISITORS ===== */
.visitor-counter { display:flex; justify-content:center; gap:4px; }
.vc-digit {
    font-family:var(--f-mono); font-size:16px; color:var(--accent);
    width:22px; height:28px; display:flex; align-items:center; justify-content:center;
    background:var(--bg); border:1px solid var(--card-border); border-radius:4px;
    transition:transform .3s, box-shadow .3s;
}
.visitor-counter:hover .vc-digit { transform:translateY(-1px); box-shadow:0 2px 8px rgba(196,149,106,.15); }

/* ===== MOOD ===== */
.mood-widget { text-align:center; display:flex; align-items:center; justify-content:center; gap:8px; }
.mood-icon { font-size:20px; animation:float 3s ease-in-out infinite; }
.mood-text { font-family:var(--f-mono); font-size:11px; color:var(--muted); }

/* ===== CHATBOX ===== */
.chatbox { font-size:12px; }
.cb-messages {
    height:90px; overflow-y:auto; background:var(--bg); border:1px solid var(--card-border);
    border-radius:var(--radius); padding:6px; margin-bottom:6px;
    display:flex; flex-direction:column; gap:3px;
}
.cb-messages::-webkit-scrollbar { width:3px; }
.cb-messages::-webkit-scrollbar-thumb { background:var(--accent); border-radius:2px; }
.sb-msg { font-size:11px; word-break:break-word; animation:fadeIn .3s; }
.sb-msg b { color:var(--accent); }
.cb-input-wrap { display:flex; gap:4px; }
.cb-input {
    flex:1; background:var(--bg); border:1px solid var(--card-border); color:var(--text);
    font-family:var(--f-mono); font-size:11px; padding:6px; border-radius:var(--radius); outline:none;
}
.cb-input:focus { border-color:var(--accent); }
.cb-send {
    background:rgba(196,149,106,.15); border:1px solid var(--accent);
    color:var(--accent); width:28px; border-radius:var(--radius);
    cursor:pointer; font-size:12px; transition:all .2s;
}
.cb-send:hover { background:rgba(196,149,106,.3); }

/* ===== QUOTE ===== */
.quote-widget { text-align:center; }
.quote-text { font-family:var(--f-serif); font-size:13px; color:var(--cream); font-style:italic; min-height:40px; transition:opacity .5s; }
.quote-author { font-family:var(--f-mono); font-size:9px; color:var(--muted); margin-top:4px; }

/* ===== TODO ===== */
.todo-list { display:flex; flex-direction:column; gap:4px; }
.todo { font-family:var(--f-mono); font-size:11px; color:var(--muted); padding:3px 0; }
.todo.done { color:var(--accent2); text-decoration:line-through; opacity:.6; }

/* ===== FOOTER ===== */
.lo-footer { text-align:center; padding:20px; border-top:1px solid var(--card-border); }
.footer-line { font-family:var(--f-mono); font-size:11px; color:var(--muted); }
.footer-sub { font-size:11px; color:rgba(138,126,112,.5); margin-top:2px; }
.footer-keys { font-family:var(--f-mono); font-size:9px; color:rgba(138,126,112,.3); margin-top:6px; letter-spacing:.5px; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--card-border); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent); }
::selection { background:rgba(196,149,106,.3); color:var(--cream); }

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
    .lo-layout { flex-direction:column; }
    .lo-sidebar { width:100%; flex-direction:row; flex-wrap:wrap; }
    .lo-sidebar .lo-card { flex:1 1 180px; min-width:160px; }
}

@media (max-width:768px) {
    .lo-header { padding:12px 16px; }
    .lo-nav {
        display:none; flex-direction:column; position:absolute;
        top:100%; left:0; right:0; background:rgba(28,24,20,.96);
        border-bottom:1px solid var(--card-border); padding:12px 16px;
        gap:2px; backdrop-filter:blur(10px);
        animation:slideDown .3s ease;
    }
    .lo-nav.open { display:flex; }
    .mobile-toggle { display:flex; }
    .lo-layout { padding:10px; gap:10px; }
    .main-card { padding:14px; }
    .interests-grid { grid-template-columns:repeat(2,1fr); }
    .personality-grid { grid-template-columns:repeat(2,1fr); }
    .lo-gallery { grid-template-columns:repeat(2,1fr); }
    .games-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:480px) {
    body { font-size:14px; }
    .brand-name { font-size:18px; }
    .lo-sidebar .lo-card { flex:1 1 100%; }
    .byf-section { flex-direction:column; }
    .waifu-section { flex-direction:column; text-align:center; }
    .profile-header { justify-content:center; text-align:center; }
    .bday-section { flex-direction:column; text-align:center; }
    .lo-gallery { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:480px) and (orientation:landscape) {
    .lo-layout { padding:8px; }
    .lo-sidebar { flex-direction:row; }
    .lo-sidebar .lo-card { flex:1 1 auto; min-width:140px; }
}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration:0.01ms!important; animation-iteration-count:1!important; transition-duration:0.01ms!important; scroll-behavior:auto!important; }
    .grain-overlay, #particles, #cursorCanvas { display:none!important; }
    .np-vinyl { animation:none!important; }
    .reveal { opacity:1!important; transform:none!important; }
}

/* ===== FOCUS VISIBLE ===== */
:focus-visible {
    outline:2px solid var(--accent);
    outline-offset:2px;
    border-radius:var(--radius);
}
:focus:not(:focus-visible) { outline:none; }

/* ===== PRINT ===== */
@media print {
    .grain-overlay, #cursorCanvas, #particles, #loader, .back-to-top,
    .lightbox, .mobile-toggle, .lo-sidebar.right, .chatbox,
    .gb-form, .copy-btn, .gallery-filters { display:none!important; }
    body { background:#fff; color:#000; font-size:12pt; }
    .lo-card { border:1px solid #ccc; break-inside:avoid; }
    .lo-header { position:static; background:#fff; border-bottom:1px solid #ccc; }
    .nav-link { color:#333; }
    .nav-link.active { color:#000; font-weight:bold; }
}
