:root {
    --bg-primary: #0d0b07; --bg-secondary: #1a1510; --bg-card: #1e1a13; --bg-card-hover: #2a2318;
    --green-accent: #4a7c59; --green-light: #6aad7a; --green-glow: rgba(74,124,89,0.3);
    --brown-dark: #3d2b1f; --brown-medium: #6b4226; --brown-light: #a67c52; --brown-warm: #c49a6c;
    --cream: #f5e6d3; --cream-dim: #d4c4b0; --text-primary: #f5e6d3; --text-secondary: #b8a898; --text-muted: #8a7b6b;
    --gold: #c8a96e;
    --font-display: 'Playfair Display', Georgia, serif;
    --font-body: 'Inter', -apple-system, sans-serif;
    --font-accent: 'Cormorant Garamond', Georgia, serif;
    --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
    --shadow-md: 0 8px 32px rgba(0,0,0,0.4); --shadow-lg: 0 16px 64px rgba(0,0,0,0.5);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;line-height:1.7}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}ul{list-style:none}
.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{padding:120px 0;position:relative}

/* CANVAS */
#coffee-beans-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}

/* NAV */
#main-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;background:transparent;transition:background var(--transition),padding var(--transition),backdrop-filter var(--transition)}
#main-nav.scrolled{background:rgba(13,11,7,0.85);backdrop-filter:blur(20px);padding:10px 0;border-bottom:1px solid rgba(74,124,89,0.15)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px;z-index:10}
.logo-icon{font-size:1.5rem}.logo-text{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--cream)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-link{font-size:.875rem;font-weight:500;color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase;transition:color var(--transition);position:relative}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--green-accent);transition:width var(--transition)}
.nav-link:hover,.nav-link.active{color:var(--green-light)}.nav-link:hover::after,.nav-link.active::after{width:100%}
.lang-switch{display:flex;gap:4px;margin-left:12px;padding:3px;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.lang-btn{padding:5px 12px;border-radius:6px;font-size:.75rem;font-weight:600;color:var(--text-muted);transition:all var(--transition);letter-spacing:.5px}
.lang-btn.active{background:var(--green-accent);color:#fff}
.lang-btn:hover:not(.active){color:var(--cream);background:rgba(255,255,255,.06)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:4px;z-index:10}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--cream);transition:var(--transition)}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:url('images/coffee-beans-hero.png') center/cover no-repeat}
.hero-grain{position:absolute;inset:0;opacity:.04;z-index:1;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)'/%3E%3C/svg%3E")}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,11,7,.82) 0%,rgba(13,11,7,.6) 40%,rgba(13,11,7,.92) 100%);z-index:1}
.steam-container{position:absolute;bottom:10%;left:50%;transform:translateX(-50%);z-index:1;pointer-events:none;width:200px;height:300px}
.steam{position:absolute;bottom:0;width:8px;height:8px;border-radius:50%;background:rgba(245,230,211,.08);filter:blur(6px);animation:steamRise 4s ease-out infinite}
.hero-content{position:relative;z-index:2;text-align:center;max-width:800px;padding:0 24px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 28px;border-radius:50px;background:rgba(13,11,7,.6);border:1px solid rgba(74,124,89,.35);color:var(--green-light);font-size:.78rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:32px;animation:fadeInDown .8s ease-out;backdrop-filter:blur(8px);text-shadow:0 1px 3px rgba(0,0,0,.5)}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--green-light);animation:pulse 2s ease-in-out infinite}
.hero-title{font-family:var(--font-display);line-height:1.1;margin-bottom:24px}
.hero-title-line{display:block;font-size:clamp(2.5rem,7vw,5rem);font-weight:800;color:var(--cream);animation:fadeInUp .8s ease-out both}
.hero-title-line.accent{color:transparent;background:linear-gradient(135deg,var(--green-light),var(--brown-warm));-webkit-background-clip:text;background-clip:text;font-style:italic;font-weight:600;animation-delay:.2s}
.hero-subtitle{font-family:var(--font-accent);font-size:clamp(1.05rem,2.5vw,1.4rem);color:var(--cream-dim);max-width:600px;margin:0 auto 40px;line-height:1.8;animation:fadeInUp .8s ease-out .4s both;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:60px;animation:fadeInUp .8s ease-out .6s both}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:50px;font-weight:600;font-size:.9rem;letter-spacing:.5px;cursor:pointer;transition:all var(--transition);border:2px solid transparent}
.btn-primary{background:var(--green-accent);color:#fff;border-color:var(--green-accent);box-shadow:0 4px 20px var(--green-glow)}
.btn-primary:hover{background:var(--green-light);border-color:var(--green-light);transform:translateY(-2px);box-shadow:0 8px 30px var(--green-glow)}
.btn-primary .btn-arrow{transition:transform var(--transition)}.btn-primary:hover .btn-arrow{transform:translateX(4px)}
.btn-outline{background:transparent;color:var(--cream);border-color:rgba(245,230,211,.3)}
.btn-outline:hover{border-color:var(--brown-warm);color:var(--brown-warm);transform:translateY(-2px)}
.hero-stats{display:flex;gap:40px;justify-content:center;align-items:center;animation:fadeInUp .8s ease-out .8s both}
.stat{text-align:center}
.stat-number{font-family:var(--font-display);font-size:2.5rem;font-weight:800;color:var(--brown-warm);display:inline}
.stat-suffix{font-family:var(--font-display);font-size:2rem;color:var(--green-light)}
.stat-label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.stat-divider{width:1px;height:40px;background:rgba(245,230,211,.1)}
.scroll-indicator{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;animation:fadeInUp 1s ease-out 1.2s both}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--green-accent),transparent);animation:scrollPulse 2s ease-in-out infinite}

/* MARQUEE */
.marquee-banner{padding:18px 0;background:var(--green-accent);overflow:hidden;white-space:nowrap;position:relative;z-index:2}
.marquee-track{display:inline-flex;gap:32px;animation:marquee 30s linear infinite;font-family:var(--font-display);font-size:.9rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:2px}
.marquee-dot{color:rgba(255,255,255,.4);font-size:.6rem;display:flex;align-items:center}

/* MUSIC PLAYER */
.music-section{padding:60px 0;background:var(--bg-primary);position:relative;overflow:hidden}
.music-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(74,124,89,.05) 0%,transparent 60%)}
.music-player{display:flex;align-items:center;gap:48px;max-width:700px;margin:0 auto;background:var(--bg-card);border-radius:24px;padding:40px 48px;border:1px solid rgba(74,124,89,.1);box-shadow:0 12px 40px rgba(0,0,0,.3);position:relative;overflow:hidden}
.music-player::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--green-accent),var(--brown-warm),transparent)}
.music-visual{flex-shrink:0}
.vinyl-disc{width:120px;height:120px;border-radius:50%;background:conic-gradient(from 0deg,#1a1510,#2a2318,#1a1510,#2a2318,#1a1510);border:3px solid rgba(74,124,89,.2);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.vinyl-disc::before{content:'';position:absolute;inset:8px;border-radius:50%;border:1px solid rgba(245,230,211,.05)}
.vinyl-disc::after{content:'';position:absolute;inset:16px;border-radius:50%;border:1px solid rgba(245,230,211,.03)}
.vinyl-disc.spinning{animation:spin 3s linear infinite}
.vinyl-inner{width:40px;height:40px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;border:2px solid rgba(74,124,89,.15);z-index:1}
.music-info{flex:1;min-width:0}
.music-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--green-light);margin-bottom:6px;display:block}
.music-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--cream);margin-bottom:8px}
.music-desc{font-size:.85rem;color:var(--text-muted);margin-bottom:20px;line-height:1.5}
.music-play-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 28px;border-radius:50px;background:var(--green-accent);color:#fff;border:none;cursor:pointer;font-family:var(--font-body);font-size:.85rem;font-weight:600;letter-spacing:.5px;transition:all var(--transition);box-shadow:0 4px 16px var(--green-glow)}
.music-play-btn:hover{background:var(--green-light);transform:translateY(-2px);box-shadow:0 6px 24px var(--green-glow)}
.music-play-btn.playing{background:rgba(74,124,89,.2);color:var(--green-light);border:1px solid rgba(74,124,89,.3);box-shadow:none}
.play-icon{font-size:1rem;transition:transform var(--transition)}
.music-progress-wrap{margin-top:16px;display:none}
.music-progress-wrap.visible{display:block}
.music-progress-bar{width:100%;height:4px;border-radius:4px;background:rgba(245,230,211,.08);overflow:hidden;cursor:pointer}
.music-progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--green-accent),var(--green-light));width:0%;transition:width .1s linear}
.music-time{display:flex;justify-content:space-between;margin-top:6px;font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}
.music-controls{display:flex;align-items:center;gap:10px}
.music-skip-btn{width:40px;height:40px;border-radius:50%;background:rgba(74,124,89,.12);border:1px solid rgba(74,124,89,.2);color:var(--green-light);font-size:1rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}
.music-skip-btn:hover{background:rgba(74,124,89,.25);transform:scale(1.1)}
.music-tracklist{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.track-btn{padding:6px 16px;border-radius:20px;font-size:.72rem;font-weight:500;font-family:var(--font-body);background:rgba(245,230,211,.04);border:1px solid rgba(245,230,211,.1);color:var(--text-muted);cursor:pointer;transition:all var(--transition);letter-spacing:.3px}
.track-btn.active{background:rgba(74,124,89,.15);border-color:rgba(74,124,89,.3);color:var(--green-light)}
.track-btn:hover:not(.active){color:var(--cream);border-color:rgba(245,230,211,.2)}

/* SECTION HEADERS */
.section-tag{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--green-light);margin-bottom:16px}
.section-tag.light{color:var(--green-light)}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.2;margin-bottom:16px;color:var(--cream)}
.section-title.light{color:#fff}
.section-desc{font-size:1.05rem;color:var(--text-secondary);max-width:560px;margin:0 auto 60px;line-height:1.7}
.section-header{text-align:center;margin-bottom:20px}

/* ABOUT */
.about{background:var(--bg-secondary)}
.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.about-image-wrapper{position:relative}
.about-image-frame{border-radius:16px;overflow:hidden;position:relative;box-shadow:var(--shadow-lg);border:1px solid rgba(74,124,89,.15)}
.about-image-frame img{width:100%;height:500px;object-fit:cover}
.about-image-accent{position:absolute;top:-20px;left:-20px;width:100%;height:100%;border-radius:16px;border:2px solid var(--green-accent);opacity:.2;z-index:-1}
.about-float-badge{position:absolute;bottom:-20px;right:-20px;background:var(--green-accent);border-radius:16px;padding:20px 24px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg);z-index:3}
.float-number{font-family:var(--font-display);font-size:2.2rem;font-weight:800;color:#fff}
.float-text{font-size:.75rem;color:rgba(255,255,255,.8);line-height:1.4;text-transform:uppercase;letter-spacing:1px}
.about-text{font-size:1rem;color:var(--text-secondary);margin-bottom:20px;line-height:1.8}
.about-text strong{color:var(--cream);font-weight:600}.about-text em{color:var(--brown-warm);font-style:italic}
.about-languages{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.lang-badge{padding:8px 18px;border-radius:50px;font-size:.8rem;font-weight:500;background:rgba(74,124,89,.1);border:1px solid rgba(74,124,89,.2);color:var(--green-light)}
.lang-badge small{color:var(--text-muted);font-weight:400}

/* PHILOSOPHY */
.philosophy{padding:100px 0;background:var(--bg-primary);position:relative;overflow:hidden}
.philosophy::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(74,124,89,.06) 0%,transparent 70%)}
.philosophy-quote{text-align:center;max-width:800px;margin:0 auto;position:relative}
.quote-mark{font-family:var(--font-display);font-size:8rem;color:var(--green-accent);opacity:.15;position:absolute;top:-60px;left:50%;transform:translateX(-50%);line-height:1}
.philosophy-quote p{font-family:var(--font-accent);font-size:clamp(1.3rem,3vw,1.8rem);color:var(--cream);line-height:1.8;font-weight:400;position:relative;z-index:1}
.philosophy-quote em{color:var(--green-light);font-weight:500}
.philosophy-quote footer{margin-top:24px;font-family:var(--font-body);font-size:.85rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}

/* PROCESS */
.process{background:var(--bg-secondary)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.process-step{background:var(--bg-card);border-radius:20px;padding:36px 28px;text-align:center;border:1px solid rgba(74,124,89,.06);transition:all .4s ease;position:relative;overflow:hidden}
.process-step::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green-accent),var(--brown-warm));transform:scaleX(0);transition:transform .4s ease}
.process-step:hover{transform:translateY(-6px);background:var(--bg-card-hover);box-shadow:var(--shadow-md);border-color:rgba(74,124,89,.2)}
.process-step:hover::after{transform:scaleX(1)}
.process-number{font-family:var(--font-display);font-size:3rem;font-weight:800;color:rgba(74,124,89,.1);position:absolute;top:12px;right:18px}
.process-icon-wrap{width:64px;height:64px;border-radius:50%;background:rgba(74,124,89,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:all var(--transition)}
.process-step:hover .process-icon-wrap{background:var(--green-accent);transform:scale(1.1)}
.process-icon{width:28px;height:28px;color:var(--green-light);transition:color var(--transition)}
.process-step:hover .process-icon{color:#fff}
.process-step h3{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:10px;color:var(--cream)}
.process-step p{font-size:.85rem;color:var(--text-muted);line-height:1.7}

/* GALLERY BENTO */
.gallery{background:var(--bg-primary)}
.gallery-bento{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:320px 280px;gap:16px}
.bento-item{position:relative;border-radius:16px;overflow:hidden;cursor:pointer}
.bento-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1),filter .4s ease}
.bento-item:hover img{transform:scale(1.06);filter:brightness(1.1)}
.bento-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(13,11,7,.95) 0%,rgba(13,11,7,.15) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:24px;opacity:0;transition:opacity var(--transition)}
.bento-item:hover .bento-overlay{opacity:1}
.bento-tag{display:inline-block;padding:4px 12px;border-radius:20px;background:var(--green-accent);color:#fff;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;width:fit-content}
.bento-overlay h3{font-family:var(--font-display);font-size:1.2rem;color:#fff;margin-bottom:4px}
.bento-overlay p{font-size:.8rem;color:var(--cream-dim);line-height:1.5}
.bento-hero{grid-column:span 2;grid-row:span 1}
.bento-tall{grid-row:span 2}
.bento-wide{grid-column:span 2}

/* TIMELINE */
.experience{background:var(--bg-secondary)}
.timeline{position:relative;max-width:750px;margin:0 auto 60px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--green-accent),var(--brown-warm),transparent)}
.timeline-item{padding-left:40px;margin-bottom:48px;position:relative}
.timeline-marker{position:absolute;left:-7px;top:8px;width:16px;height:16px;border-radius:50%;background:var(--bg-primary);border:3px solid var(--green-accent);z-index:2}
.timeline-content{background:var(--bg-card);border-radius:16px;padding:32px;border:1px solid rgba(74,124,89,.1);transition:all var(--transition)}
.timeline-content:hover{border-color:rgba(74,124,89,.25);box-shadow:var(--shadow-md)}
.timeline-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.timeline-date{font-size:.8rem;color:var(--text-muted);letter-spacing:1px}
.timeline-badge{padding:3px 12px;border-radius:20px;font-size:.7rem;font-weight:600;background:rgba(107,66,38,.2);color:var(--brown-warm);text-transform:uppercase}
.timeline-badge.current{background:rgba(74,124,89,.2);color:var(--green-light)}
.timeline-content h3{font-family:var(--font-display);font-size:1.3rem;color:var(--cream);margin-bottom:4px}
.timeline-content h4{font-size:.95rem;color:var(--brown-warm);font-weight:500;margin-bottom:8px}
.timeline-location{font-size:.85rem;color:var(--text-muted);margin-bottom:16px}
.timeline-content ul{display:flex;flex-direction:column;gap:8px}
.timeline-content li{font-size:.9rem;color:var(--text-secondary);padding-left:20px;position:relative;line-height:1.6}
.timeline-content li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--green-accent)}
.education-block{display:flex;align-items:center;gap:20px;max-width:750px;margin:0 auto;background:var(--bg-card);border-radius:16px;padding:28px 32px;border:1px solid rgba(74,124,89,.1)}
.edu-icon{font-size:2rem}
.edu-content h3{font-family:var(--font-display);font-size:1.1rem;color:var(--cream);margin-bottom:4px}
.edu-content p{font-size:.9rem;color:var(--text-secondary)}.edu-date{color:var(--text-muted);font-size:.8rem}

/* CONTACT */
.contact{background:var(--bg-primary)}
.contact-card{display:grid;grid-template-columns:1.2fr 1fr;gap:0;background:linear-gradient(135deg,var(--brown-dark),#1a1208);border-radius:24px;overflow:hidden;border:1px solid rgba(74,124,89,.15);box-shadow:var(--shadow-lg)}
.contact-content{padding:60px}
.contact-text{font-size:1rem;color:var(--cream-dim);margin-bottom:36px;line-height:1.8}
.contact-details{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:center;gap:16px;padding:14px 20px;border-radius:12px;background:rgba(255,255,255,.04);transition:all var(--transition)}
.contact-item:hover{background:rgba(74,124,89,.1);transform:translateX(4px)}
.contact-icon{font-size:1.4rem}
.contact-item small{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.contact-item span{font-size:.9rem;color:var(--cream)}
.contact-visual{position:relative}.contact-visual img{width:100%;height:100%;object-fit:cover}

/* FOOTER */
.footer{padding:48px 0;text-align:center;border-top:1px solid rgba(74,124,89,.1)}
.footer-content{display:flex;flex-direction:column;align-items:center;gap:12px}
.footer-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--cream)}
.footer p{font-size:.85rem;color:var(--text-muted)}
.footer-links{display:flex;gap:24px;margin:8px 0}
.footer-links a{font-size:.8rem;color:var(--text-secondary);transition:color var(--transition)}
.footer-links a:hover{color:var(--green-light)}.footer-copy{font-size:.75rem;color:var(--text-muted)}

/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes steamRise{0%{opacity:0;transform:translateY(0) scale(1)}30%{opacity:.6}100%{opacity:0;transform:translateY(-250px) scale(3) translateX(20px)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.reveal{opacity:0;transform:translateY(40px);transition:all .8s cubic-bezier(.4,0,.2,1)}.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1024px){.process-grid{grid-template-columns:repeat(2,1fr)}.about-grid{gap:48px}.contact-card{grid-template-columns:1fr}.contact-visual{height:300px}.gallery-bento{grid-template-columns:1fr 1fr;grid-template-rows:auto}.bento-hero,.bento-wide{grid-column:span 2}.bento-tall{grid-row:span 1}}
@media(max-width:768px){.section{padding:80px 0}.nav-links{position:fixed;inset:0;background:rgba(13,11,7,.97);flex-direction:column;justify-content:center;align-items:center;gap:28px;transform:translateX(100%);transition:transform var(--transition)}.nav-links.active{transform:translateX(0)}.nav-toggle{display:flex}.nav-link{font-size:1.2rem}.about-grid{grid-template-columns:1fr}.about-image-frame img{height:350px}.about-float-badge{bottom:-10px;right:10px;padding:14px 18px}.float-number{font-size:1.6rem}.process-grid{grid-template-columns:1fr}.gallery-bento{grid-template-columns:1fr;grid-template-rows:auto}.bento-hero,.bento-wide,.bento-tall{grid-column:span 1;grid-row:span 1}.hero-stats{flex-direction:column;gap:20px}.stat-divider{width:40px;height:1px}.contact-content{padding:36px}.timeline-item{padding-left:30px}.philosophy-quote p{font-size:1.1rem}.music-player{flex-direction:column;text-align:center;padding:32px 24px;gap:24px}.vinyl-disc{width:100px;height:100px}.music-play-btn{margin:0 auto}}
@media(max-width:480px){.hero-cta{flex-direction:column;align-items:center}.marquee-track{font-size:.75rem}}
