/* CoffeeMolka.MD — стиль кофейни-музея. Тёплая палитра эспрессо/крем, серифные заголовки.
   Mobile-first, нулевые внешние зависимости кроме Google Fonts. */
:root{
  --espresso:#2a1a10;
  --coffee:#5a3a25;
  --roast:#3b2417;
  --latte:#c8a27c;
  --crema:#e6c8a0;
  --cream:#f6efe4;
  --paper:#fbf7f0;
  --ink:#241812;
  --muted:#7c6452;
  --line:#e7dccb;
  --gold:#b9842f;
  --rad:16px;
  --rad-lg:24px;
  --shadow:0 18px 50px -20px rgba(42,26,16,.35);
  --wrap:1140px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--coffee);text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.narrow{max-width:680px}
.center{text-align:center}
.muted{color:var(--muted)}
.mt{margin-top:1.4rem}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--roast);margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.6rem)}
.sec-h{font-size:clamp(1.7rem,3.5vw,2.6rem);margin-bottom:.8em}
.lead{font-size:1.12rem;color:#43332a}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;background:var(--roast);color:#fff;border:none;border-radius:999px;padding:.7em 1.5em;font-family:var(--sans);font-weight:600;font-size:1rem;cursor:pointer;transition:.2s;white-space:nowrap}
.btn:hover{background:var(--coffee);transform:translateY(-2px)}
.btn-lg{padding:.9em 1.9em;font-size:1.05rem}
.btn-sm{padding:.5em 1.1em;font-size:.92rem}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.sec-menu .btn-ghost,.page-body .btn-ghost{color:var(--roast);border-color:var(--latte)}
.btn-block{width:100%}
.link-more{display:inline-block;margin-top:1rem;font-weight:600;color:var(--gold)}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:1.2rem;height:68px}
.brand{display:flex;align-items:center;gap:.5rem;font-family:var(--serif);font-weight:700;font-size:1.35rem;color:var(--roast)}
.brand-mark{font-size:1.4rem}
.nav{display:flex;gap:.3rem;margin-left:auto}
.nav a{padding:.5em .85em;border-radius:999px;font-weight:600;color:var(--coffee);font-size:.97rem}
.nav a:hover{background:var(--cream)}
.nav a.active{background:var(--roast);color:#fff}
.hdr-act{display:flex;align-items:center;gap:.6rem}
.lang{font-weight:700;color:var(--muted);padding:.4em .6em;border:1px solid var(--line);border-radius:999px;font-size:.85rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--roast);border-radius:2px;transition:.2s}

/* hero */
.hero{background:var(--espresso) center/cover no-repeat;color:#fff;text-align:center}
.hero-in{padding:clamp(4rem,11vw,8rem) 20px;max-width:880px}
.hero-kicker{text-transform:uppercase;letter-spacing:.22em;font-size:.82rem;font-weight:700;color:var(--crema);margin:0 0 1rem}
.hero h1{color:#fff;margin:0 0 .4em}
.hero-sub{font-size:1.2rem;color:#f0e3d2;max-width:640px;margin:0 auto 2rem}
.hero-act{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* sections */
.sec{padding:clamp(3rem,7vw,5.5rem) 0}
.sec-about{background:var(--paper)}
.two-col{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:center}
.about-stat{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:1.4rem;text-align:center;box-shadow:var(--shadow)}
.stat b{display:block;font-family:var(--serif);font-size:2.2rem;color:var(--gold);line-height:1}
.stat span{font-size:.9rem;color:var(--muted)}

/* menu cards */
.sec-menu{background:var(--cream)}
.mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem;margin-bottom:2rem}
.mcard{background:#fff;border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.mcard-img{aspect-ratio:16/10;background:var(--cream) center/cover no-repeat}
.mcard-b{padding:1.1rem 1.2rem 1.3rem;flex:1;display:flex;flex-direction:column}
.mcard-h{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}
.mcard-h h3{font-size:1.3rem;margin:0}
.mcard .muted{margin:.35rem 0 .8rem;font-size:.96rem;flex:1}
.mcard-price{font-family:var(--serif);font-size:1.3rem;font-weight:700;color:var(--gold)}
.badge{background:var(--gold);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25em .6em;border-radius:999px;font-family:var(--sans);white-space:nowrap}

/* loyalty */
.sec-loyalty{background:linear-gradient(135deg,var(--roast),var(--coffee));color:#fff}
.sec-loyalty .sec-h{color:#fff}
.loyalty-box{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr;gap:2.5rem;align-items:center;padding:0 20px}
.sec-loyalty .lead{color:#f3e7d6}
.sec-loyalty .lead b{color:var(--crema)}
.promo{margin-top:1.2rem;font-size:1rem;color:#f3e7d6}
.promo b{background:rgba(255,255,255,.14);padding:.2em .6em;border-radius:8px;letter-spacing:.08em}
.loyalty-badge{justify-self:center;width:190px;height:190px;border-radius:50%;background:#fff;color:var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--serif);font-size:3.4rem;font-weight:700;box-shadow:var(--shadow)}
.loyalty-badge span{font-family:var(--sans);font-size:1rem;color:var(--muted);font-weight:600;letter-spacing:.1em;text-transform:uppercase}

/* gallery */
.ggrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem}
.ggrid-lg{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.gitem{aspect-ratio:1/1;background:var(--cream) center/cover no-repeat;border-radius:var(--rad);display:block}
.ggrid-lg .gitem{aspect-ratio:4/3}
.gitem-fig{margin:0}
.gitem-fig figcaption{font-size:.9rem;color:var(--muted);margin-top:.4rem;text-align:center}
.ggrid-lg .gitem{cursor:zoom-in;transition:transform .2s ease,box-shadow .2s ease}
.ggrid-lg .gitem:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(28,18,12,.22)}
.ggrid-lg .gitem:focus-visible{outline:3px solid var(--sky,#1E88E5);outline-offset:2px}

/* lightbox */
.lbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:rgba(20,12,8,.92);padding:clamp(1rem,4vw,3rem);animation:lboxin .18s ease}
.lbox[hidden]{display:none}
@keyframes lboxin{from{opacity:0}to{opacity:1}}
.lbox-fig{margin:0;max-width:min(1100px,92vw);max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.lbox-fig img{max-width:100%;max-height:80vh;width:auto;height:auto;border-radius:12px;box-shadow:0 16px 60px rgba(0,0,0,.5);background:#000}
.lbox-fig figcaption{color:#f3ece6;font-size:1rem;text-align:center}
.lbox-x{position:absolute;top:14px;right:18px;background:none;border:0;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer;opacity:.85}
.lbox-x:hover{opacity:1}
.lbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:0;color:#fff;
  font-size:2.2rem;width:54px;height:54px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lbox-nav:hover{background:rgba(255,255,255,.25)}
.lbox-prev{left:max(10px,2vw)}.lbox-next{right:max(10px,2vw)}
@media(max-width:560px){.lbox-nav{width:44px;height:44px;font-size:1.8rem}}

/* location */
.sec-loc{background:var(--paper)}
.loc-grid{align-items:start}
.loc-map iframe{width:100%;min-height:380px;border:0;border-radius:var(--rad);box-shadow:var(--shadow)}
.loc-info p{margin:.3rem 0}

/* forms */
.rform{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}
.rrow{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.rform input,.rform textarea{font-family:var(--sans);font-size:1rem;padding:.8em 1em;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);width:100%}
.rform input:focus,.rform textarea:focus{outline:none;border-color:var(--latte);box-shadow:0 0 0 3px rgba(200,162,124,.25)}
.rform-ok{color:#2e7d32;font-weight:600;margin:.3rem 0 0}

/* page head + body */
.pagehead{background:var(--roast);color:#fff;padding:clamp(2.4rem,6vw,4rem) 0 clamp(2rem,5vw,3rem)}
.pagehead h1{color:#fff;margin:0}
.pagehead .muted{color:#e6d6c4}
.page-body{padding:clamp(2.5rem,6vw,4rem) 20px;max-width:820px;font-size:1.08rem}
.page-body h2{margin-top:1.6em}
.page-body img{border-radius:var(--rad);margin:1.2rem 0}
.menu-page,.gallery-page{padding:clamp(2.5rem,6vw,4rem) 20px}
.msec{margin-bottom:3rem}
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:2rem;align-items:start}

/* footer */
.ftr{background:var(--espresso);color:#e7d8c6;padding:3.5rem 0 1.5rem;margin-top:0}
.ftr-in{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
.ftr .brand{color:#fff;margin-bottom:.6rem}
.ftr h4{color:#fff;font-family:var(--sans);font-size:1rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .8rem}
.ftr p{margin:.3rem 0}
.ftr a{color:var(--crema)}
.ftr .soc{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap}
.ftr-nav{display:flex;flex-direction:column;gap:.3rem;margin-top:.6rem}
.ftr-bottom{margin-top:2.5rem;padding-top:1.3rem;border-top:1px solid rgba(255,255,255,.12);font-size:.88rem;color:#b59c85}

@media(max-width:860px){
  .nav{position:fixed;top:68px;left:0;right:0;background:var(--paper);flex-direction:column;padding:1rem 20px;gap:.3rem;border-bottom:1px solid var(--line);transform:translateY(-150%);transition:.25s;margin:0}
  .nav.open{transform:translateY(0)}
  .nav a{padding:.7em .9em}
  .burger{display:flex}
  .two-col,.loyalty-box,.contacts-grid,.loc-grid{grid-template-columns:1fr;gap:1.6rem}
  .ftr-in{grid-template-columns:1fr;gap:1.8rem}
  .loyalty-badge{width:150px;height:150px;font-size:2.6rem}
}
@media(max-width:480px){
  .rrow{grid-template-columns:1fr}
  .about-stat{grid-template-columns:1fr 1fr}
}
