/* ============================================
   Coobik Portfolio — coobik.dev
   Optimized Stylesheet v1.0
   ============================================ */

/* --- CSS Variables --- */
:root{--duck-yellow:#F5C518;--duck-orange:#E8751A;--duck-dark-orange:#C4580D;--bg-primary:#0A0A0F;--bg-secondary:#12121A;--bg-card:#16161F;--bg-card-hover:#1C1C28;--text-primary:#E8E6E3;--text-secondary:#8A8A9A;--text-muted:#55556A;--border-color:#222233;--border-glow:rgba(245,197,24,.15);--discord-blurple:#5865F2;--online-green:#23A55A;--idle-yellow:#F0B232;--dnd-red:#F23F43;--offline-gray:#80848E;--glow-yellow:rgba(245,197,24,.08);--glow-orange:rgba(232,117,26,.06);--youtube-red:#FF0000;--transition-fast:.2s ease;--transition-med:.35s ease;--radius-sm:6px;--radius-md:10px;--radius-lg:14px}

/* --- Reset --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--duck-yellow) var(--bg-secondary)}
body{font-family:'Outfit',sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* --- Noise Overlay --- */
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}

/* --- Ambient Background --- */
.ambient-bg{position:fixed;inset:0;z-index:-1;overflow:hidden}
.ambient-bg .orb{position:absolute;border-radius:50%;filter:blur(120px);animation:orbFloat 20s ease-in-out infinite}
.ambient-bg .orb:nth-child(1){width:500px;height:500px;background:var(--duck-yellow);top:-15%;left:-10%;opacity:.06;animation-duration:25s}
.ambient-bg .orb:nth-child(2){width:400px;height:400px;background:var(--duck-orange);bottom:-10%;right:-5%;opacity:.04;animation-duration:30s;animation-delay:-5s}
.ambient-bg .orb:nth-child(3){width:300px;height:300px;background:var(--discord-blurple);top:50%;left:50%;opacity:.03;animation-duration:22s;animation-delay:-10s}

/* --- Grid Pattern --- */
.grid-pattern{position:fixed;inset:0;z-index:-1;background-image:linear-gradient(rgba(245,197,24,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(245,197,24,.015) 1px,transparent 1px);background-size:60px 60px}

/* --- Scanline --- */
.scanline{position:fixed;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,transparent,var(--duck-yellow),transparent);opacity:.08;z-index:9998;animation:scanDown 8s linear infinite}

/* --- Animations --- */
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-40px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(40px,30px) scale(1.02)}}
@keyframes scanDown{0%{top:-4px}100%{top:100%}}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(35,165,90,.4)}50%{opacity:.8;box-shadow:0 0 0 6px rgba(35,165,90,0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes spinRing{to{transform:rotate(360deg)}}
@keyframes floatBadge{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* --- Nav --- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 2rem;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(10,10,15,.8);border-bottom:1px solid var(--border-color);transition:all .3s ease}
.nav.scrolled{padding:.7rem 2rem;background:rgba(10,10,15,.95)}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--text-primary)}
.nav-logo-icon{width:36px;height:36px;border-radius:8px;object-fit:cover;border:2px solid var(--duck-yellow);box-shadow:0 0 12px rgba(245,197,24,.2)}
.nav-logo-text{font-family:'Chakra Petch',sans-serif;font-weight:700;font-size:1.25rem;letter-spacing:.05em}
.nav-logo-text span{color:var(--duck-yellow)}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:.8rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;transition:color var(--transition-fast);font-family:'JetBrains Mono',monospace}
.nav-links a:hover{color:var(--duck-yellow)}
.nav-cta{background:var(--duck-yellow)!important;color:var(--bg-primary)!important;padding:.5rem 1.2rem;border-radius:var(--radius-sm);font-weight:600!important;transition:all var(--transition-fast)!important}
.nav-cta:hover{background:var(--duck-orange)!important;transform:translateY(-1px);box-shadow:0 4px 20px rgba(245,197,24,.3)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav-hamburger span{width:24px;height:2px;background:var(--text-primary);transition:all .3s;border-radius:2px;display:block}

/* --- Hero --- */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 4rem;position:relative}
.hero-content{max-width:1200px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-text{z-index:2}
.hero-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:var(--glow-yellow);border:1px solid rgba(245,197,24,.15);border-radius:100px;font-family:'JetBrains Mono',monospace;font-size:.75rem;color:var(--duck-yellow);margin-bottom:1.5rem;letter-spacing:.05em;animation:fadeInUp .6s ease both}
.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--online-green);animation:pulse 2s ease-in-out infinite}
.hero-name{font-family:'Chakra Petch',sans-serif;font-size:clamp(3rem,7vw,5.5rem);font-weight:700;line-height:1;letter-spacing:-.02em;margin-bottom:.5rem;animation:fadeInUp .6s ease .1s both}
.hero-name .accent{color:var(--duck-yellow);position:relative;display:inline-block}
.hero-name .accent::after{content:'';position:absolute;bottom:4px;left:0;width:100%;height:4px;background:var(--duck-yellow);opacity:.3;border-radius:2px}
.hero-subtitle{font-family:'JetBrains Mono',monospace;font-size:1rem;color:var(--text-secondary);margin-bottom:1.5rem;animation:fadeInUp .6s ease .2s both}
.hero-subtitle .typing-cursor{display:inline-block;width:2px;height:1.1em;background:var(--duck-yellow);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}
.hero-desc{font-size:1.05rem;color:var(--text-secondary);max-width:480px;line-height:1.7;margin-bottom:2rem;animation:fadeInUp .6s ease .3s both}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeInUp .6s ease .4s both}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:8px;font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .25s ease;white-space:nowrap}
.btn svg{flex-shrink:0}
.btn-primary{background:var(--duck-yellow);color:var(--bg-primary)}
.btn-primary:hover{background:var(--duck-orange);transform:translateY(-2px);box-shadow:0 8px 30px rgba(245,197,24,.25)}
.btn-discord{background:var(--discord-blurple);color:#fff}
.btn-discord:hover{background:#4752C4;transform:translateY(-2px);box-shadow:0 8px 30px rgba(88,101,242,.25)}
.btn-youtube{background:var(--youtube-red);color:#fff}
.btn-youtube:hover{background:#cc0000;transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,0,0,.2)}
.btn-ghost{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}
.btn-ghost:hover{border-color:var(--duck-yellow);color:var(--duck-yellow);background:var(--glow-yellow);transform:translateY(-2px)}

/* --- Hero Visual / Mascot --- */
.hero-visual{display:flex;justify-content:center;align-items:center;position:relative;animation:fadeInUp .8s ease .3s both}
.mascot-container{position:relative;width:380px;height:380px}
.mascot-ring{position:absolute;inset:-15px;border-radius:50%;border:2px solid transparent;border-top-color:var(--duck-yellow);border-right-color:var(--duck-orange);animation:spinRing 8s linear infinite;opacity:.4}
.mascot-ring:nth-child(2){inset:-30px;animation-duration:12s;animation-direction:reverse;border-top-color:var(--duck-orange);border-right-color:var(--duck-yellow);opacity:.2}
.mascot-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid var(--duck-yellow);box-shadow:0 0 40px rgba(245,197,24,.15),0 0 80px rgba(245,197,24,.05),inset 0 0 30px rgba(0,0,0,.3);position:relative;z-index:2}
.mascot-glow{position:absolute;inset:20%;border-radius:50%;background:radial-gradient(circle,var(--duck-yellow) 0%,transparent 70%);opacity:.06;filter:blur(40px);z-index:1}
.float-badge{position:absolute;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem .85rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--text-secondary);z-index:3;backdrop-filter:blur(10px);white-space:nowrap;display:flex;align-items:center;gap:.4rem;animation:floatBadge 4s ease-in-out infinite}
.float-badge .val{color:var(--duck-yellow);font-weight:600}
.float-badge:nth-child(4){top:10%;right:-20%;animation-delay:0s}
.float-badge:nth-child(5){bottom:15%;left:-25%;animation-delay:-1.5s}
.float-badge:nth-child(6){bottom:5%;right:-15%;animation-delay:-3s}

/* --- Discord Status Widget --- */
.discord-widget{animation:fadeInUp .6s ease .5s both;margin-top:2rem}
.discord-card{display:inline-flex;align-items:center;gap:.85rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:.75rem 1.25rem;transition:all .3s ease}
.discord-card:hover{border-color:var(--discord-blurple);box-shadow:0 4px 24px rgba(88,101,242,.1)}
.discord-avatar{width:38px;height:38px;border-radius:50%;position:relative}
.discord-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.discord-status-dot{position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-radius:50%;border:3px solid var(--bg-card);background:var(--offline-gray)}
.discord-status-dot.online{background:var(--online-green)}
.discord-status-dot.idle{background:var(--idle-yellow)}
.discord-status-dot.dnd{background:var(--dnd-red)}
.discord-info{display:flex;flex-direction:column}
.discord-name{font-weight:600;font-size:.85rem;color:var(--text-primary)}
.discord-status-text{font-size:.72rem;color:var(--text-muted);font-family:'JetBrains Mono',monospace}

/* --- Sections --- */
.section{padding:6rem 2rem;max-width:1200px;margin:0 auto}
.section-header{margin-bottom:3.5rem}
.section-label{font-family:'JetBrains Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.15em;color:var(--duck-yellow);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}
.section-label::before{content:'//';opacity:.5}
.section-title{font-family:'Chakra Petch',sans-serif;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;letter-spacing:-.01em;line-height:1.2}
.section-divider{width:60px;height:3px;background:linear-gradient(90deg,var(--duck-yellow),var(--duck-orange));border-radius:2px;margin-top:1rem}

/* --- About --- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.about-text p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:1rem;line-height:1.8}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--duck-yellow),transparent);opacity:0;transition:opacity .3s}
.stat-card:hover{border-color:rgba(245,197,24,.2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.stat-card:hover::before{opacity:1}
.stat-value{font-family:'Chakra Petch',sans-serif;font-size:2rem;font-weight:700;color:var(--duck-yellow);line-height:1;display:flex;align-items:center;gap:.4rem}
.stat-label{font-size:.78rem;color:var(--text-muted);margin-top:.4rem;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.05em}

/* --- Timeline --- */
.timeline{position:relative;padding-left:3rem}
.timeline::before{content:'';position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--duck-yellow),var(--duck-orange),transparent);border-radius:2px}
.timeline-item{position:relative;margin-bottom:2.5rem}
.timeline-item:last-child{margin-bottom:0}
.timeline-dot{position:absolute;left:-3rem;top:6px;width:16px;height:16px;border-radius:50%;background:var(--bg-primary);border:3px solid var(--duck-yellow);z-index:2}
.timeline-item:first-child .timeline-dot{background:var(--duck-yellow);box-shadow:0 0 12px rgba(245,197,24,.4)}
.timeline-date{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--duck-orange);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.35rem}
.timeline-title{font-family:'Chakra Petch',sans-serif;font-size:1.2rem;font-weight:600;margin-bottom:.2rem}
.timeline-company{font-size:.85rem;color:var(--duck-yellow);margin-bottom:.5rem}
.timeline-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.7}

/* --- Projects Grid --- */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}
.project-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.75rem;transition:all var(--transition-med);position:relative;overflow:hidden}
.project-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--glow-yellow),transparent 60%);opacity:0;transition:opacity var(--transition-med)}
.project-card:hover{border-color:rgba(245,197,24,.25);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.3)}
.project-card:hover::after{opacity:1}
.project-card>*{position:relative;z-index:2}
.project-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;background:var(--glow-yellow);border:1px solid rgba(245,197,24,.1);color:var(--duck-yellow)}
.project-name{font-family:'Chakra Petch',sans-serif;font-size:1.15rem;font-weight:600;margin-bottom:.4rem}
.project-type{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--duck-orange);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}
.project-desc{color:var(--text-secondary);font-size:.88rem;line-height:1.7;margin-bottom:1.25rem}
.project-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.project-tag{padding:.25rem .6rem;font-size:.68rem;font-family:'JetBrains Mono',monospace;border-radius:4px;background:rgba(245,197,24,.06);border:1px solid rgba(245,197,24,.08);color:var(--text-muted)}

/* --- Tech Stack --- */
.stack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}
.stack-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem;text-align:center;transition:all .3s ease}
.stack-item:hover{border-color:rgba(245,197,24,.2);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.stack-icon{margin-bottom:.6rem;display:flex;justify-content:center;align-items:center;color:var(--duck-yellow)}
.stack-name{font-size:.82rem;font-weight:600}
.stack-level{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--text-muted);margin-top:.25rem}

/* --- Communities --- */
.communities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.community-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1.25rem;transition:all .3s ease}
.community-card:hover{border-color:rgba(88,101,242,.3);transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,.25)}
.community-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.community-icon.ci-labs{background:linear-gradient(135deg,var(--duck-yellow),var(--duck-orange))}
.community-icon.ci-valley{background:linear-gradient(135deg,#06b6d4,#0891b2)}
.community-icon.ci-fivem{background:linear-gradient(135deg,var(--discord-blurple),#4752C4)}
.community-info{flex:1}
.community-name{font-family:'Chakra Petch',sans-serif;font-weight:600;font-size:1rem;margin-bottom:.2rem}
.community-role{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--duck-yellow);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem}
.community-members{font-size:.78rem;color:var(--text-muted)}

/* --- Contact / CTA --- */
.contact-section{text-align:center;padding:8rem 2rem;position:relative}
.contact-section::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--glow-yellow),transparent 70%);filter:blur(80px);opacity:.5;pointer-events:none}
.contact-inner{position:relative;z-index:2;max-width:600px;margin:0 auto}
.contact-title{font-family:'Chakra Petch',sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1rem}
.contact-title span{color:var(--duck-yellow)}
.contact-desc{color:var(--text-secondary);margin-bottom:2.5rem;font-size:1.05rem;line-height:1.7}
.contact-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}

/* --- Footer --- */
.footer{border-top:1px solid var(--border-color);padding:2.5rem 2rem}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-left{font-family:'JetBrains Mono',monospace;font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.4rem}
.footer-left span{color:var(--duck-yellow)}
.footer-links{display:flex;gap:1.5rem;align-items:center}
.footer-links a{color:var(--text-muted);text-decoration:none;font-size:.8rem;transition:color var(--transition-fast);display:inline-flex;align-items:center;gap:.35rem}
.footer-links a:hover{color:var(--duck-yellow)}

/* --- Scroll Reveal --- */
.reveal{opacity:0;transform:translateY(30px);transition:all .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* --- Hyperlinks --- */
.timeline-company a{color:var(--duck-yellow);text-decoration:none;transition:color var(--transition-fast)}
.timeline-company a:hover{color:var(--duck-orange)}

/* --- Responsive --- */
@media(max-width:900px){
    .hero-content{grid-template-columns:1fr;text-align:center}
    .hero-desc{margin-left:auto;margin-right:auto}
    .hero-actions{justify-content:center}
    .hero-visual{order:-1}
    .mascot-container{width:260px;height:260px}
    .float-badge{display:none}
    .about-grid{grid-template-columns:1fr}
    .projects-grid{grid-template-columns:1fr}
    .communities-grid{grid-template-columns:1fr}
    .nav-links{display:none}
    .nav-hamburger{display:flex}
    .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(10,10,15,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);gap:1.25rem}
    .discord-widget{display:flex;justify-content:center}
    .section{padding:4rem 1.25rem}
    .section-label{justify-content:center}
}
@media(max-width:500px){
    .hero{padding:5rem 1rem 3rem}
    .about-stats{grid-template-columns:1fr}
    .stack-grid{grid-template-columns:repeat(2,1fr)}
    .footer-inner{flex-direction:column;text-align:center}
    .contact-actions{flex-direction:column;align-items:center}
}