*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#0D0600;--roast:#1E0B00;--dark:#2A1000;--brown:#5C2800;
  --terra:#8B4513;--copper:#B5651D;--gold:#C8920A;--amber:#E8A820;
  --honey:#F0C040;--cream:#F7EDD8;--sand:#EDD8B0;--white:#FFFEF8;
}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--cream);font-family:'Jost',sans-serif;font-weight:300;overflow-x:hidden;cursor:none;margin:0}
#cur{position:fixed;width:10px;height:10px;background:var(--amber);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:exclusion;transition:transform .15s}
#cur-trail{position:fixed;width:40px;height:40px;border:1px solid rgba(200,146,10,.35);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .08s linear}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.055'/%3E%3C/svg%3E");pointer-events:none;z-index:9997;opacity:.5}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.8rem 5vw;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(180deg,rgba(13,6,0,.92) 0%,transparent 100%);transition:background .4s,padding .3s}
nav.scrolled{background:rgba(13,6,0,.97);padding:1.2rem 5vw}
.logo{font-family:'Playfair Display',serif;font-size:1.55rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);text-decoration:none}
.logo span{color:var(--cream);opacity:.45;font-style:italic;font-size:.8em}
.nav-links{display:flex;gap:2.8rem;list-style:none;align-items:center}
.nav-links a{color:var(--cream);text-decoration:none;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;opacity:.55;transition:opacity .3s,color .3s}
.nav-links a:hover{opacity:1;color:var(--amber)}
.nav-btn{border:1px solid rgba(200,146,10,.5);padding:.55rem 1.5rem;opacity:.9 !important;transition:all .3s !important}
.nav-btn:hover{background:var(--amber) !important;color:var(--ink) !important;border-color:var(--amber) !important;opacity:1 !important}

/* HERO */
.hero{min-height:100vh;display:grid;place-items:center;position:relative;overflow:hidden;padding:10rem 5vw 6rem}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 55% 70% at 75% 45%,rgba(92,40,0,.55) 0%,transparent 65%),radial-gradient(ellipse 35% 45% at 15% 75%,rgba(30,11,0,.8) 0%,transparent 55%),linear-gradient(160deg,#0D0600 0%,#1E0B00 35%,#2A1000 65%,#0D0600 100%)}
.hero-ring{position:absolute;right:12vw;top:50%;transform:translateY(-50%);width:min(45vw,520px);height:min(45vw,520px);pointer-events:none}
.ring-svg{width:100%;height:100%;animation:spin-slow 60s linear infinite}
@keyframes spin-slow{to{transform:rotate(360deg)}}
.hero-dot{position:absolute;border-radius:50%;background:var(--amber);opacity:0;animation:rise var(--d,8s) var(--delay,0s) infinite ease-in}
@keyframes rise{0%{opacity:0;transform:translateY(0) scale(.5)}15%{opacity:.7}90%{opacity:.1}100%{opacity:0;transform:translateY(-180px) scale(.2)}}
.hero-content{position:relative;z-index:2;max-width:680px}
.hero-tag{display:inline-flex;align-items:center;gap:.8rem;font-size:.68rem;letter-spacing:.38em;text-transform:uppercase;color:var(--amber);margin-bottom:2.5rem;opacity:0;animation:fade-rise .9s .2s forwards}
.hero-tag::before,.hero-tag::after{content:'';height:1px;background:linear-gradient(90deg,transparent,var(--gold));width:30px}
.hero-tag::after{background:linear-gradient(90deg,var(--gold),transparent)}
.hero-h1{font-family:'Playfair Display',serif;font-size:clamp(3.2rem,7.5vw,7rem);font-weight:400;line-height:.95;color:var(--cream);margin-bottom:1.4rem;opacity:0;animation:fade-rise .9s .45s forwards}
.hero-h1 em{font-style:italic;color:var(--amber);display:block;font-size:1.08em}
.hero-slogan{font-family:'Playfair Display',serif;font-size:clamp(1rem,2vw,1.35rem);font-style:italic;font-weight:400;color:rgba(247,237,216,.7);margin-bottom:2rem;letter-spacing:.03em;opacity:0;animation:fade-rise .9s .65s forwards;border-left:2px solid var(--gold);padding-left:1.2rem}
.hero-desc{font-size:.92rem;line-height:1.9;color:rgba(247,237,216,.5);max-width:480px;margin-bottom:3.2rem;opacity:0;animation:fade-rise .9s .85s forwards}
.hero-ctas{display:flex;gap:1.5rem;align-items:center;opacity:0;animation:fade-rise .9s 1.05s forwards;flex-wrap:wrap}
.btn{display:inline-block;text-decoration:none;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:400;transition:all .3s}
.btn-fill{padding:1rem 2.6rem;background:var(--amber);color:var(--ink);position:relative;overflow:hidden}
.btn-fill::before{content:'';position:absolute;inset:0;background:var(--honey);transform:scaleX(0);transform-origin:right;transition:transform .35s ease}
.btn-fill:hover::before{transform:scaleX(1);transform-origin:left}
.btn-fill span{position:relative;z-index:1}
.btn-ghost{color:rgba(247,237,216,.7);display:inline-flex;align-items:center;gap:.5rem}
.btn-ghost:hover{color:var(--amber);gap:.9rem}
.btn-ghost::after{content:'↓'}
.scroll-indicator{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;opacity:0;animation:fade-rise .9s 1.6s forwards}
.scroll-indicator span{font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;opacity:.35}
.scroll-bar{width:1px;height:55px;overflow:hidden;background:rgba(200,146,10,.15)}
.scroll-bar::after{content:'';display:block;width:1px;height:100%;background:var(--amber);animation:scroll-anim 1.8s 1.8s ease-in-out infinite}
@keyframes scroll-anim{0%{transform:translateY(-100%)}50%{transform:translateY(0)}100%{transform:translateY(100%)}}
@keyframes fade-rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* MARQUEE */
.marquee-wrap{overflow:hidden;padding:1.8rem 0;background:var(--gold);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.marquee-track{display:flex;white-space:nowrap;width:max-content;animation:marquee 28s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:1.5rem;padding:0 2rem;font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;color:var(--ink);font-weight:500}
.marquee-dot{width:4px;height:4px;background:var(--ink);border-radius:50%;opacity:.4}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* MANIFESTO */
.manifesto{padding:clamp(5rem,10vw,10rem) 5vw;position:relative;overflow:hidden;background:var(--roast);text-align:center}
.manifesto::before{content:'\201C';position:absolute;top:-4rem;left:50%;transform:translateX(-50%);font-family:'Playfair Display',serif;font-size:28rem;color:rgba(200,146,10,.05);line-height:1;pointer-events:none;user-select:none;font-style:italic}
.manifesto blockquote{position:relative;z-index:1;font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3.2vw,2.6rem);font-style:italic;font-weight:400;line-height:1.55;color:var(--cream);max-width:820px;margin:0 auto 2.5rem}
.manifesto blockquote strong{color:var(--amber);font-style:normal;font-weight:500}
.manifesto-line{width:50px;height:1px;background:var(--gold);margin:0 auto 1.5rem;opacity:.5}
.manifesto cite{font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;color:var(--copper);font-style:normal}

/* SECTION BASE */
.section{padding:clamp(5rem,10vw,9rem) 5vw}
.section-label{font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:var(--amber);margin-bottom:1rem}
.section-h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.4rem);font-weight:400;color:var(--cream);margin-bottom:1rem;line-height:1.15}
.section-h2 em{color:var(--amber);font-style:italic}
.section-sub{font-size:.88rem;line-height:1.85;color:rgba(247,237,216,.45);max-width:500px}
.section-header{text-align:center;margin-bottom:5rem}
.section-header .section-sub{margin:0 auto}

/* ORIGINS */
.origins{background:var(--ink)}
.origins-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;background:rgba(200,146,10,.08);max-width:1300px;margin:0 auto;border:1px solid rgba(200,146,10,.08)}
.origin-card{background:var(--roast);padding:3rem 2.5rem 2.8rem;position:relative;overflow:hidden;transition:background .4s,transform .3s;cursor:pointer}
.origin-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;transform:scaleX(0);transition:transform .5s cubic-bezier(.16,1,.3,1);transform-origin:left}
.origin-card.tz::before{background:linear-gradient(90deg,#1B5E20,#4CAF50)}
.origin-card.ug::before{background:linear-gradient(90deg,#0D47A1,#1976D2)}
.origin-card.ao::before{background:linear-gradient(90deg,#8B0000,#C62828)}
.origin-card.et::before{background:linear-gradient(90deg,#E65100,#FF8F00)}
.origin-card.ke::before{background:linear-gradient(90deg,#1B5E20,#B71C1C)}
.origin-card:hover{background:var(--dark);transform:translateY(-3px)}
.origin-card:hover::before{transform:scaleX(1)}
.origin-card:hover .origin-num{color:var(--amber);opacity:.9}
.origin-num{font-family:'Playfair Display',serif;font-size:4.5rem;font-weight:400;color:var(--cream);opacity:.05;line-height:1;margin-bottom:1rem;transition:opacity .4s,color .4s}
.origin-flag{font-size:1.8rem;margin-bottom:.8rem;display:block}
.origin-name{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:400;color:var(--cream);margin-bottom:.3rem}
.origin-role{font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--copper);margin-bottom:1.8rem}
.origin-divider{width:24px;height:1px;background:var(--gold);margin-bottom:1.5rem;opacity:.5}
.origin-text{font-size:.85rem;line-height:1.85;color:rgba(247,237,216,.55);margin-bottom:2rem}
.origin-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.tag{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;padding:.28rem .75rem;border:1px solid rgba(200,146,10,.25);color:rgba(200,146,10,.7)}

/* LIFESTYLE */
.lifestyle{background:linear-gradient(160deg,var(--dark) 0%,var(--brown) 50%,var(--dark) 100%);position:relative;overflow:hidden}
.lifestyle::before{content:'';position:absolute;top:50%;left:50%;width:700px;height:700px;background:radial-gradient(ellipse,rgba(200,146,10,.07) 0%,transparent 70%);transform:translate(-50%,-50%);pointer-events:none}
.lifestyle-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:center}
.coffee-art{position:relative;height:500px;display:flex;align-items:center;justify-content:center}
.c-rings{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.c-ring{position:absolute;border-radius:50%;border:1px solid rgba(200,146,10,.1);animation:pulse-ring 4s ease-out infinite}
.c-ring:nth-child(1){width:200px;height:200px}
.c-ring:nth-child(2){width:320px;height:320px;animation-delay:1s}
.c-ring:nth-child(3){width:440px;height:440px;animation-delay:2s}
.c-ring:nth-child(4){width:560px;height:560px;animation-delay:3s}
@keyframes pulse-ring{0%{opacity:.3;transform:scale(.97)}50%{opacity:.1}100%{opacity:.3;transform:scale(1.02)}}
.cup-wrap{position:relative;z-index:2}
.cup{width:140px;height:110px;background:linear-gradient(150deg,#F7EDD8,#EDD8B0);border-radius:6px 6px 28px 28px;position:relative;box-shadow:inset -6px -8px 16px rgba(0,0,0,.12),inset 4px 4px 10px rgba(255,255,255,.35),0 25px 60px rgba(0,0,0,.55)}
.cup-inner{position:absolute;top:14px;left:12px;right:12px;height:62px;background:radial-gradient(ellipse at 38% 28%,#B5651D,#5C2800 60%,#2A1000);border-radius:3px 3px 18px 18px;overflow:hidden}
.cup-inner::after{content:'';position:absolute;top:6px;left:10px;width:28px;height:16px;background:rgba(255,255,255,.07);border-radius:50%;transform:rotate(-18deg)}
.cup-handle{position:absolute;right:-32px;top:20px;width:30px;height:52px;border:10px solid #EDD8B0;border-left:none;border-radius:0 25px 25px 0}
.saucer{width:175px;height:14px;margin:-2px 0 0 -18px;background:linear-gradient(to bottom,#F0E0C0,#EDD8B0);border-radius:50%;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.steam-wrap{position:absolute;top:-55px;left:0;right:0;display:flex;justify-content:center;gap:14px}
.steam{width:2px;border-radius:2px;background:linear-gradient(to top,rgba(247,237,216,.45),transparent);animation:steam 2.8s ease-in-out infinite}
.steam:nth-child(1){height:38px}.steam:nth-child(2){height:52px;animation-delay:.5s}.steam:nth-child(3){height:42px;animation-delay:1s}
@keyframes steam{0%{opacity:0;transform:translateY(0) scaleX(1)}25%{opacity:.8}100%{opacity:0;transform:translateY(-36px) scaleX(1.8)}}
.lifestyle-h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.8vw,3rem);font-weight:400;line-height:1.2;color:var(--cream);margin-bottom:2rem}
.lifestyle-h2 em{color:var(--amber);font-style:italic;display:block}
.lifestyle-body{font-size:.9rem;line-height:1.95;color:rgba(247,237,216,.55);margin-bottom:3rem}
.lifestyle-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding-top:2.5rem;border-top:1px solid rgba(200,146,10,.18)}
.stat-n{font-family:'Playfair Display',serif;font-size:3rem;font-weight:400;color:var(--amber);line-height:1;margin-bottom:.3rem}
.stat-l{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(247,237,216,.38)}

/* PROCESS */
.process{background:var(--ink)}
.process-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);gap:0;position:relative}
.process-grid::before{content:'';position:absolute;top:26px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,rgba(200,146,10,.3),transparent)}
.p-step{text-align:center;padding:0 .8rem;position:relative}
.p-step:hover .p-num{background:var(--amber);color:var(--ink);border-color:var(--amber)}
.p-num{width:52px;height:52px;border-radius:50%;border:1px solid rgba(200,146,10,.35);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--amber);background:var(--ink);position:relative;z-index:1;transition:all .3s}
.p-title{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);margin-bottom:.6rem;font-weight:400}
.p-desc{font-size:.78rem;line-height:1.7;color:rgba(247,237,216,.38)}

/* CTA BAND */
.cta-band{padding:clamp(5rem,10vw,9rem) 5vw;background:var(--roast);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'CAFRICANO';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Playfair Display',serif;font-size:clamp(6rem,15vw,16rem);font-weight:700;color:transparent;-webkit-text-stroke:1px rgba(200,146,10,.05);white-space:nowrap;pointer-events:none;user-select:none;letter-spacing:.08em}
.cta-h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,4rem);font-weight:400;color:var(--cream);line-height:1.15;margin-bottom:1.5rem}
.cta-h2 em{color:var(--amber);font-style:italic}
.cta-p{font-size:.9rem;line-height:1.85;color:rgba(247,237,216,.45);max-width:480px;margin:0 auto 3.5rem}
.cta-btns{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}

/* CONTACT */
.contact{background:var(--dark)}
.contact-inner{max-width:1150px;margin:0 auto;display:grid;grid-template-columns:5fr 7fr;gap:8rem;align-items:start}
.contact-h3{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:400;color:var(--cream);margin-bottom:1rem;line-height:1.15}
.contact-p{font-size:.88rem;line-height:1.85;color:rgba(247,237,216,.45);margin-bottom:3rem}
.contact-details{display:flex;flex-direction:column;gap:1.8rem}
.c-label{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--amber);margin-bottom:.25rem}
.c-val{font-size:.9rem;color:var(--sand)}
.form{display:flex;flex-direction:column;gap:1.4rem}
.f-group{display:flex;flex-direction:column;gap:.5rem}
.f-label{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--copper)}
.f-input,.f-select,.f-textarea{background:rgba(255,255,255,.03);border:none;border-bottom:1px solid rgba(200,146,10,.2);color:var(--cream);padding:.8rem 0;font-family:'Jost',sans-serif;font-size:.9rem;font-weight:300;outline:none;appearance:none;transition:border-color .3s;width:100%}
.f-input:focus,.f-select:focus,.f-textarea:focus{border-color:rgba(200,146,10,.7)}
.f-input::placeholder,.f-textarea::placeholder{color:rgba(247,237,216,.2)}
.f-select option{background:var(--dark)}
.f-textarea{resize:vertical;min-height:110px;border:1px solid rgba(200,146,10,.2);padding:.8rem}
.f-textarea:focus{border-color:rgba(200,146,10,.7)}
.f-submit{margin-top:.5rem;padding:1rem 0;background:var(--amber);color:var(--ink);border:none;font-family:'Jost',sans-serif;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;cursor:pointer;transition:background .3s;width:100%}
.f-submit:hover{background:var(--honey)}

/* FOOTER */
footer{padding:3rem 5vw;border-top:1px solid rgba(200,146,10,.1);background:var(--ink);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--amber)}
.footer-slogan{font-family:'Playfair Display',serif;font-style:italic;font-size:.95rem;color:rgba(247,237,216,.28)}
.footer-copy{font-size:.65rem;letter-spacing:.12em;color:rgba(247,237,216,.2)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}

/* RESPONSIVE */
@media(max-width:960px){
  .nav-links{display:none}
  .lifestyle-inner,.contact-inner{grid-template-columns:1fr;gap:4rem}
  .coffee-art{height:280px}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:3rem}
  .process-grid::before{display:none}
  footer{flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .origins-grid{grid-template-columns:1fr}
  .hero-ring{display:none}
  .lifestyle-stats{grid-template-columns:repeat(3,1fr);gap:1rem}
}
