
:root{
  --green-900:#07251a;--green-800:#0c3526;--green-700:#13503a;--green-600:#1a6b4d;
  --green-500:#1e7d5a;--green-400:#2fa177;--green-300:#4fc99a;--mint:#aef0d2;
  --bg:#04100b;--bg-2:#08180f;--ink:#04100b;--paper:#eef7f1;--paper-dim:#9fbdaf;
  --amber:#f0a830;--crema:#caa46a;--coffee:#3a2417;--coffee-2:#5b3a24;
  --line:rgba(79,201,154,.13);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Vazirmatn',sans-serif;background:var(--bg);color:var(--paper);overflow-x:hidden;line-height:1.8;-webkit-font-smoothing:antialiased;cursor:none}
::selection{background:var(--green-400);color:var(--ink)}
.mono{font-family:'JetBrains Mono',monospace;direction:ltr;unicode-bidi:plaintext}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.cur,.cur-d{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;mix-blend-mode:difference}
.cur{width:8px;height:8px;background:var(--mint);transform:translate(-50%,-50%)}
.cur-d{width:34px;height:34px;border:1.5px solid var(--green-300);transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s}
.cur-d.big{width:60px;height:60px;background:rgba(79,201,154,.12)}
@media(hover:none),(max-width:900px){body{cursor:auto}.cur,.cur-d{display:none}}
#matrix{position:fixed;inset:0;z-index:0;opacity:.10;pointer-events:none}
.glow{position:fixed;width:55vw;height:55vw;border-radius:50%;z-index:0;pointer-events:none;filter:blur(60px)}
.glow.g1{top:-18vw;right:-12vw;background:radial-gradient(circle,rgba(47,161,119,.22),transparent 60%)}
.glow.g2{bottom:0;left:-18vw;background:radial-gradient(circle,rgba(240,168,48,.07),transparent 60%)}
#prog{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:linear-gradient(90deg,var(--green-400),var(--mint));box-shadow:0 0 14px var(--green-400)}
nav{position:fixed;top:0;left:0;right:0;z-index:150;display:flex;align-items:center;justify-content:space-between;padding:16px 5vw;transition:.35s;border-bottom:1px solid transparent}
nav.scrolled{padding:10px 5vw;background:rgba(4,16,11,.72);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
nav .brand{display:flex;align-items:center;gap:12px;font-weight:800}
nav .brand img{width:46px;height:46px;border-radius:50%;transition:transform .6s}
nav .brand:hover img{transform:rotate(360deg)}
nav .brand .nm{display:flex;flex-direction:column;line-height:1.2}
nav .brand .nm b{font-size:1rem}
nav .brand .nm span{font-size:.62rem;color:var(--green-300);letter-spacing:2px}
nav .links{display:flex;gap:26px;align-items:center}
nav .links a{font-size:.9rem;color:var(--paper-dim);transition:color .2s;position:relative}
nav .links a:hover{color:var(--mint)}
nav .links a::after{content:"";position:absolute;bottom:-6px;right:0;width:0;height:2px;background:var(--green-400);transition:width .3s}
nav .links a:hover::after{width:100%}
nav .cta{background:var(--green-400);color:var(--ink);padding:9px 20px;border-radius:999px;font-weight:700;font-size:.85rem;transition:.25s}
nav .cta:hover{background:var(--mint);transform:translateY(-2px);box-shadow:0 10px 26px rgba(79,201,154,.35)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer}
.burger span{width:26px;height:2px;background:var(--paper);border-radius:2px;transition:.3s}
header{position:relative;z-index:2;min-height:100vh;display:grid;grid-template-columns:1.15fr .85fr;align-items:center;gap:40px;padding:130px 5vw 60px}
.hero-left .tag{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:999px;padding:7px 16px;font-size:.76rem;color:var(--green-300);margin-bottom:26px;background:rgba(19,80,58,.22)}
.hero-left .tag .dot{width:8px;height:8px;border-radius:50%;background:var(--green-300);box-shadow:0 0 10px var(--green-300);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.hero-left h1{font-size:clamp(2.6rem,7vw,5.6rem);font-weight:900;line-height:1.04;letter-spacing:-1.5px;margin-bottom:22px}
.hero-left h1 .hl{color:transparent;background:linear-gradient(120deg,var(--green-300),var(--mint),var(--amber));-webkit-background-clip:text;background-clip:text;background-size:200%;animation:flow 6s linear infinite}
@keyframes flow{to{background-position:200%}}
.hero-left h1 .cursor{display:inline-block;width:.5ch;height:.85em;background:var(--amber);margin-right:4px;vertical-align:-2px;animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.hero-left p.lead{font-size:clamp(1rem,2.2vw,1.25rem);color:var(--paper-dim);max-width:46ch;margin-bottom:36px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-primary{background:var(--green-400);color:var(--ink);padding:15px 32px;border-radius:999px;font-weight:700;transition:.25s;position:relative;overflow:hidden}
.btn-primary span{position:relative;z-index:1}
.btn-primary::before{content:"";position:absolute;inset:0;background:var(--mint);transform:translateY(101%);transition:transform .3s}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(79,201,154,.35)}
.btn-ghost{border:1px solid var(--green-600);padding:15px 28px;border-radius:999px;color:var(--green-300);transition:.25s}
.btn-ghost:hover{background:var(--green-800);border-color:var(--green-400);color:var(--mint)}
.brew{position:relative;display:flex;flex-direction:column;align-items:center;gap:18px}
.terminal{width:100%;max-width:430px;background:linear-gradient(160deg,#06231a,#04140d);border:1px solid var(--line);border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.6);overflow:hidden}
.terminal .bar{display:flex;gap:7px;align-items:center;padding:11px 14px;border-bottom:1px solid var(--line);background:rgba(0,0,0,.2)}
.terminal .bar i{width:11px;height:11px;border-radius:50%}
.terminal .bar .t{margin-right:auto;font-family:'JetBrains Mono',monospace;font-size:.66rem;color:var(--paper-dim);direction:ltr}
.terminal .body{font-family:'JetBrains Mono',monospace;direction:ltr;font-size:.72rem;line-height:1.85;padding:16px;min-height:170px;color:var(--paper-dim);white-space:pre-wrap}
.terminal .body .k{color:var(--green-300)}
.terminal .body .s{color:var(--amber)}
.terminal .body .c{color:#4d6f5f}
.terminal .body .f{color:var(--mint)}
.terminal .body .ok{color:var(--green-400)}
.tcursor{display:inline-block;width:7px;height:1em;background:var(--mint);vertical-align:-2px;animation:blink 1s steps(2) infinite}
.cup-stage{position:relative;width:170px;height:200px;display:flex;align-items:flex-end;justify-content:center}
.steam{position:absolute;top:-6px;left:50%;transform:translateX(-50%);display:flex;gap:12px;opacity:0;transition:opacity .8s}
.steam.on{opacity:.7}
.steam i{width:7px;height:46px;background:linear-gradient(to top,rgba(174,240,210,.5),transparent);border-radius:50%;filter:blur(3px);animation:steam 3s ease-in infinite}
.steam i:nth-child(2){animation-delay:.7s;height:58px}
.steam i:nth-child(3){animation-delay:1.4s}
@keyframes steam{0%{transform:translateY(10px) scaleX(1);opacity:0}30%{opacity:.8}100%{transform:translateY(-34px) scaleX(1.7);opacity:0}}
.cup{position:relative;width:130px;height:120px;background:linear-gradient(170deg,#f3faf6,#cfe2d8);border-radius:10px 10px 60px 60px/10px 10px 70px 70px;box-shadow:inset 0 -10px 20px rgba(0,0,0,.12),0 18px 40px rgba(0,0,0,.45);overflow:hidden;border:2px solid #e4efe9}
.cup .liquid{position:absolute;left:6px;right:6px;bottom:6px;height:0;background:linear-gradient(to bottom,var(--coffee-2),var(--coffee));border-radius:0 0 52px 52px;transition:height 2.4s cubic-bezier(.4,0,.2,1)}
.cup .liquid.full{height:88px}
.cup .crema{position:absolute;left:8px;right:8px;height:10px;background:radial-gradient(circle,var(--crema),#b9914f);border-radius:50%;opacity:0;transition:opacity .8s;bottom:88px;filter:blur(.4px)}
.cup .crema.on{opacity:1}
.handle{position:absolute;right:-26px;top:34px;width:34px;height:46px;border:9px solid #e4efe9;border-radius:0 40px 40px 0;border-left:0}
.pour{position:absolute;top:0;left:50%;transform:translateX(-50%);width:4px;height:0;background:linear-gradient(var(--coffee-2),var(--coffee));border-radius:3px;opacity:0}
.pour.on{opacity:1;height:64px;animation:jitter .15s linear infinite}
@keyframes jitter{50%{transform:translateX(-50%) scaleX(1.4)}}
.saucer{position:absolute;bottom:-2px;width:160px;height:14px;background:linear-gradient(#e4efe9,#bcd1c6);border-radius:50%;box-shadow:0 10px 26px rgba(0,0,0,.4)}
.brew-status{font-family:'JetBrains Mono',monospace;direction:ltr;font-size:.74rem;color:var(--green-300);min-height:1.2em}
.brew-again{font-size:.78rem;color:var(--paper-dim);border:1px solid var(--line);padding:7px 16px;border-radius:999px;transition:.25s;cursor:none}
.brew-again:hover{border-color:var(--green-400);color:var(--mint)}
section{position:relative;z-index:2;padding:110px 5vw}
.sec-head{margin-bottom:60px;max-width:62ch}
.sec-kicker{font-family:'JetBrains Mono',monospace;direction:ltr;color:var(--green-400);font-size:.85rem;letter-spacing:2px;margin-bottom:14px;text-align:right}
.sec-title{font-size:clamp(2rem,5vw,3.4rem);font-weight:800;line-height:1.1;letter-spacing:-.5px}
.sec-sub{color:var(--paper-dim);margin-top:18px;font-size:1.05rem}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;background:rgba(8,24,15,.5)}
.marquee .track{display:flex;gap:60px;width:max-content;animation:scrollx 26s linear infinite;font-family:'JetBrains Mono',monospace;direction:ltr;color:var(--green-300);font-size:1.05rem;align-items:center}
.marquee .track span{display:flex;align-items:center;gap:60px}
.marquee .track b{color:var(--amber)}
@keyframes scrollx{to{transform:translateX(-50%)}}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-text p{color:var(--paper-dim);margin-bottom:18px;font-size:1.05rem}
.about-text .chip{display:inline-block;font-family:'JetBrains Mono',monospace;direction:ltr;color:var(--green-400);font-size:.82rem;background:rgba(19,80,58,.25);border:1px solid var(--line);padding:6px 12px;border-radius:8px;margin-top:8px}
.about-photos{position:relative;height:460px}
.about-photos img{position:absolute;border-radius:16px;object-fit:cover;border:1px solid var(--line);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.about-photos .p1{width:62%;height:64%;top:0;right:0;z-index:2}
.about-photos .p2{width:54%;height:54%;bottom:0;left:0;z-index:3}
.about-photos .badge{position:absolute;z-index:4;bottom:24%;right:-10px;background:var(--green-400);color:var(--ink);font-weight:800;border-radius:14px;padding:14px 18px;text-align:center;box-shadow:0 16px 40px rgba(47,161,119,.4)}
.about-photos .badge b{font-family:'Space Grotesk';font-size:1.6rem;display:block}
.about-photos .badge small{font-size:.7rem}
/* MENU / QR band */
.menu-band{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;background:linear-gradient(150deg,var(--green-900),var(--bg-2));border:1px solid var(--line);border-radius:24px;padding:54px;position:relative;overflow:hidden}
.menu-band .rain{position:absolute;inset:0;font-family:'JetBrains Mono',monospace;font-size:1.1rem;line-height:1.5rem;color:var(--green-400);opacity:.05;word-break:break-all;padding:16px;pointer-events:none;direction:ltr;z-index:0}
.menu-band .mb-text{position:relative;z-index:1}
.menu-band h3{font-size:clamp(1.6rem,4vw,2.5rem);font-weight:800;margin-bottom:14px}
.menu-band p{color:var(--paper-dim);margin-bottom:26px;max-width:42ch}
/* new menu button: glass + sweeping shine + glowing border */
.menu-btn{display:inline-flex;align-items:center;gap:12px;position:relative;padding:16px 28px;border-radius:14px;font-family:'JetBrains Mono',monospace;direction:ltr;font-weight:700;font-size:1rem;color:var(--mint);background:rgba(19,80,58,.32);border:1px solid var(--green-500);overflow:hidden;transition:.3s;isolation:isolate}
.menu-btn .qr-ic{font-size:1.1rem}
.menu-btn::before{content:"";position:absolute;inset:-1px;border-radius:14px;padding:1px;background:linear-gradient(120deg,var(--green-300),transparent 30%,transparent 70%,var(--amber));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s;z-index:-1}
.menu-btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(174,240,210,.45),transparent);transform:skewX(-20deg);transition:left .6s}
.menu-btn:hover{background:rgba(30,125,90,.5);transform:translateY(-3px);box-shadow:0 14px 36px rgba(47,161,119,.35)}
.menu-btn:hover::before{opacity:1}
.menu-btn:hover::after{left:140%}
/* QR card: 3D tilt + animated glowing border + corner brackets */
.qr-wrap{position:relative;z-index:1;justify-self:center;width:100%;max-width:340px;perspective:900px}
.qr-card{position:relative;background:var(--paper);border-radius:22px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 24px 60px rgba(0,0,0,.5);transition:transform .15s ease-out,box-shadow .4s;transform-style:preserve-3d}
.qr-wrap::before,.qr-wrap::after{content:"";position:absolute;width:26px;height:26px;border:2px solid var(--green-300);z-index:3;opacity:.0;transition:opacity .35s,transform .35s}
.qr-wrap::before{top:-8px;right:-8px;border-left:0;border-bottom:0;border-radius:0 8px 0 0}
.qr-wrap::after{bottom:-8px;left:-8px;border-right:0;border-top:0;border-radius:0 0 0 8px}
.qr-wrap:hover::before{opacity:1;transform:translate(4px,-4px)}
.qr-wrap:hover::after{opacity:1;transform:translate(-4px,4px)}
.qr-card .qr-img{width:100%;max-width:300px;border-radius:12px;display:block;transform:translateZ(30px)}
.qr-card .scan{font-size:.9rem;color:var(--ink);font-weight:700;transform:translateZ(20px)}
.qr-card .cap{font-family:'JetBrains Mono',monospace;direction:ltr;font-size:.74rem;color:var(--green-700);font-weight:700;transform:translateZ(20px)}
.qr-card .glow-ring{position:absolute;inset:-2px;border-radius:24px;background:conic-gradient(from var(--a,0deg),var(--green-300),var(--amber),var(--mint),var(--green-300));filter:blur(10px);opacity:0;transition:opacity .4s;z-index:-1}
.qr-wrap:hover .glow-ring{opacity:.55;animation:spin 4s linear infinite}
@keyframes spin{to{--a:360deg}}
@property --a{syntax:'<angle>';inherits:false;initial-value:0deg}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gallery a{overflow:hidden;border-radius:14px;position:relative;border:1px solid var(--line)}
.gallery a img{width:100%;height:100%;object-fit:cover;transition:transform .7s,filter .7s;filter:saturate(.85)}
.gallery a:hover img{transform:scale(1.09);filter:saturate(1.15)}
.gallery a::after{content:attr(data-cap);position:absolute;inset:auto 0 0 0;padding:14px;font-size:.8rem;background:linear-gradient(transparent,rgba(4,16,11,.94));opacity:0;transition:.3s;color:var(--mint)}
.gallery a::before{content:attr(data-i);position:absolute;top:10px;left:10px;font-family:'JetBrains Mono',monospace;font-size:.66rem;color:var(--mint);background:rgba(4,16,11,.6);padding:3px 7px;border-radius:6px;opacity:0;transition:.3s;z-index:2}
.gallery a:hover::after,.gallery a:hover::before{opacity:1}
.g-wide{grid-column:span 2}.g-tall{grid-row:span 2}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{padding:30px;border:1px solid var(--line);border-radius:16px;background:rgba(8,24,15,.5);transition:.35s;position:relative;overflow:hidden}
.feat::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(47,161,119,.16),transparent 60%);opacity:0;transition:opacity .3s}
.feat:hover::before{opacity:1}
.feat:hover{border-color:var(--green-500);transform:translateY(-5px)}
.feat .n{font-family:'JetBrains Mono',monospace;color:var(--green-600);font-size:.8rem;direction:ltr}
.feat h4{font-size:1.2rem;margin:10px 0;font-weight:700;position:relative}
.feat p{color:var(--paper-dim);font-size:.95rem;position:relative}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.info-row{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.info-row .ic{width:46px;height:46px;border-radius:12px;background:var(--green-800);display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.info-row .lbl{font-size:.8rem;color:var(--green-400);margin-bottom:4px}
.info-row .v{font-size:1.05rem}
.map-card{border-radius:18px;overflow:hidden;border:1px solid var(--line);min-height:340px;background:var(--bg-2)}
.map-card iframe{width:100%;height:100%;min-height:340px;border:0;filter:invert(.92) hue-rotate(120deg) saturate(.6)}
.hours{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hours .day{border:1px solid var(--line);border-radius:10px;padding:10px 16px;font-size:.9rem}
.hours .day b{color:var(--green-300);margin-left:8px}
footer{position:relative;z-index:2;border-top:1px solid var(--line);padding:60px 5vw 40px;background:var(--bg-2)}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;margin-bottom:40px}
.foot-brand{max-width:36ch}
.foot-brand img{width:64px;height:64px;border-radius:50%;margin-bottom:16px}
.foot-brand p{color:var(--paper-dim);font-size:.95rem;margin-top:10px}
.foot-col h5{color:var(--green-300);font-size:.85rem;margin-bottom:16px}
.foot-col a{display:block;color:var(--paper-dim);font-size:.92rem;margin-bottom:10px;transition:.2s}
.foot-col a:hover{color:var(--mint);padding-right:5px}
.foot-bottom{text-align:center;color:var(--paper-dim);font-size:.82rem;border-top:1px solid var(--line);padding-top:24px}
.foot-bottom .mono{color:var(--green-400)}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;transition:.25s}
.socials a:hover{background:var(--green-700);border-color:var(--green-400);transform:translateY(-3px)}
@media(max-width:900px){
  nav .links{position:fixed;top:66px;left:0;right:0;flex-direction:column;background:rgba(4,16,11,.98);backdrop-filter:blur(16px);padding:30px;gap:20px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .4s}
  nav .links.open{transform:none}
  .burger{display:flex}
  header{grid-template-columns:1fr;text-align:center;padding-top:110px}
  .hero-left .tag,.hero-actions{justify-content:center}
  .hero-left p.lead{margin-inline:auto}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .menu-band{grid-template-columns:1fr;gap:30px;padding:30px}
  .feat-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .about-photos{position:static;height:auto;max-width:440px;margin-inline:auto;display:flex;flex-direction:column;gap:0}
  .about-photos img{position:static!important;width:100%!important;transform:none!important;border-radius:14px}
  .about-photos .p1{height:230px!important;z-index:2;box-shadow:0 18px 40px rgba(0,0,0,.55);animation:floatA 5s ease-in-out infinite}
  .about-photos .p2{height:200px!important;width:80%!important;align-self:flex-start;margin-top:-46px;margin-right:auto;z-index:3;border:2px solid var(--green-500);box-shadow:0 18px 44px rgba(47,161,119,.3);animation:floatB 5s ease-in-out infinite}
  @keyframes floatA{50%{transform:translateY(-8px)!important}}
  @keyframes floatB{50%{transform:translateY(8px)!important}}
  .about-photos .badge{position:static;align-self:flex-end;margin-top:-40px;margin-left:6px;z-index:4;display:inline-flex;flex-direction:column;align-items:center;width:max-content}
  .menu-btn{display:flex;justify-content:center;width:100%;text-align:center}
  .menu-band .mb-text{display:flex;flex-direction:column;align-items:center;text-align:center}
  .menu-band p{margin-inline:auto}
  .sec-head{margin-bottom:40px}
}
