/* ============================================================
   Matcha Kobo — main.css
   Palette: washi paper, sumi ink, ceremonial matcha, gold.
   ============================================================ */

:root{
  --mk-primary:#6c8a4e;        /* matcha */
  --mk-primary-d:#4a6334;
  --mk-primary-l:#a8be86;      /* usucha */
  --mk-accent:#b68d40;         /* gold */
  --mk-washi:#f6f2e9;          /* warm paper */
  --mk-washi-2:#efe9dc;
  --mk-cream:#fbf9f3;
  --mk-sumi:#1a1d17;           /* ink */
  --mk-sumi-2:#262b22;
  --mk-ink-soft:#4b5043;
  --mk-line:rgba(26,29,23,.12);
  --mk-shadow:0 24px 60px -28px rgba(26,29,23,.45);
  --mk-shadow-sm:0 10px 30px -16px rgba(26,29,23,.4);
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --jp:"Noto Serif JP",var(--serif);
  --wrap:1240px;
  --pad:clamp(24px,6vw,120px);
  --sec:clamp(64px,9vw,128px);
  --r:18px;
  --mk-headerh:88px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--mk-sumi);
  background:var(--mk-washi);line-height:1.65;font-size:17px;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
body.mk-has-action-bar{padding-bottom:0}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--mk-primary);color:var(--mk-cream)}

.mk-skip{position:absolute;left:-9999px;top:0;background:var(--mk-sumi);color:#fff;padding:12px 18px;z-index:9999}
.mk-skip:focus{left:12px;top:12px;border-radius:8px}

/* ---------- Typography helpers ---------- */
.mk-eyebrow{
  font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.28em;
  text-transform:uppercase;color:var(--mk-primary-d);margin:0 0 1.1rem;
}
.mk-eyebrow--light{color:var(--mk-primary-l)}
.mk-h2{
  font-family:var(--serif);font-weight:400;font-size:clamp(2rem,4.4vw,3.5rem);
  line-height:1.06;letter-spacing:-.015em;margin:0 0 1.1rem;color:var(--mk-sumi);
}
.mk-h2 em{font-style:italic;color:var(--mk-primary-d)}
.mk-lede,.mk-lede p{font-size:clamp(1.05rem,1.7vw,1.3rem);color:var(--mk-ink-soft);line-height:1.6;max-width:42ch}
.mk-section{padding:var(--sec) var(--pad)}
.mk-link{display:inline-flex;align-items:center;gap:.5em;color:var(--mk-primary-d);font-weight:600;border-bottom:1px solid var(--mk-primary-l);padding-bottom:2px;transition:.3s}
.mk-link:hover{gap:.85em;border-color:var(--mk-primary-d)}

/* ---------- Buttons ---------- */
.mk-btn{
  --bg:var(--mk-primary);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.02em;
  padding:.95em 1.6em;border-radius:100px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;transition:transform .3s,box-shadow .3s,background .3s,color .3s;
  min-height:48px;white-space:nowrap;
}
.mk-btn:hover{transform:translateY(-2px)}
.mk-btn--solid{background:var(--mk-primary);color:#fff;box-shadow:var(--mk-shadow-sm)}
.mk-btn--solid:hover{background:var(--mk-primary-d)}
.mk-btn--outline{background:transparent;border-color:currentColor;color:var(--mk-cream)}
.mk-btn--outline:hover{background:var(--mk-cream);color:var(--mk-sumi)}
.mk-btn--ghost{background:transparent;color:var(--mk-sumi);border-color:var(--mk-line)}
.mk-btn--ghost:hover{border-color:var(--mk-sumi)}
.mk-btn--lg{padding:1.1em 2em;font-size:1rem}

/* ============================================================
   HEADER
   ============================================================ */
.mk-header{position:fixed;inset:0 0 auto 0;z-index:900;transition:background .4s,box-shadow .4s,padding .4s;padding:18px 0}
.mk-header__inner{max-width:var(--wrap);margin:0 auto;padding:0 var(--pad);display:flex;align-items:center;gap:2rem}
.mk-brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.mk-brand__mark{width:40px;height:40px}
.mk-brand__text{display:flex;flex-direction:column;line-height:1}
.mk-brand__name{font-family:var(--serif);font-size:1.25rem;font-weight:500;color:var(--mk-cream);letter-spacing:.01em;transition:color .4s}
.mk-brand__kanji{font-family:var(--jp);font-size:.72rem;letter-spacing:.3em;color:var(--mk-primary-l);margin-top:3px;transition:color .4s}
.mk-nav__list{display:flex;gap:1.8rem;list-style:none;margin:0;padding:0}
.mk-nav__list a{font-size:.86rem;font-weight:500;letter-spacing:.04em;color:rgba(251,249,243,.86);position:relative;padding:4px 0;transition:color .3s}
.mk-nav__list a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--mk-primary-l);transition:width .3s}
.mk-nav__list a:hover{color:#fff}
.mk-nav__list a:hover::after{width:100%}
.mk-header__cta{display:flex;align-items:center;gap:.6rem}
.mk-header__cta .mk-btn--ghost{color:var(--mk-cream);border-color:rgba(251,249,243,.3)}
.mk-header__cta .mk-btn--ghost:hover{border-color:var(--mk-cream)}

/* scrolled / solid */
.mk-header.is-solid{background:var(--mk-washi);box-shadow:0 1px 0 var(--mk-line),0 12px 30px -22px rgba(26,29,23,.5);padding:12px 0}
.mk-header.is-solid .mk-brand__name{color:var(--mk-sumi)}
.mk-header.is-solid .mk-brand__kanji{color:var(--mk-primary-d)}
.mk-header.is-solid .mk-nav__list a{color:var(--mk-ink-soft)}
.mk-header.is-solid .mk-nav__list a:hover{color:var(--mk-sumi)}
.mk-header.is-solid .mk-header__cta .mk-btn--ghost{color:var(--mk-sumi);border-color:var(--mk-line)}
.mk-header.is-solid .mk-burger span{background:var(--mk-sumi)}
/* non-front pages start solid-styled because hero is dark anyway via pagehero */
.mk-header[data-transparent="false"]:not(.is-solid){background:transparent}

/* burger */
.mk-burger{display:none;flex-direction:column;gap:5px;width:48px;height:48px;align-items:center;justify-content:center;background:none;border:0;cursor:pointer;margin-left:auto}
.mk-burger span{width:24px;height:2px;background:var(--mk-cream);transition:.3s}

/* overlay menu */
.mk-overlay{position:fixed;inset:0;z-index:950;background:var(--mk-sumi);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;display:flex;align-items:center;justify-content:center}
.mk-overlay.is-open{opacity:1;visibility:visible}
.mk-overlay__inner{text-align:center;padding:2rem}
.mk-overlay__list{list-style:none;margin:0 0 2.5rem;padding:0;display:flex;flex-direction:column;gap:1.2rem}
.mk-overlay__list a{font-family:var(--serif);font-size:2rem;color:var(--mk-cream);transition:color .3s}
.mk-overlay__list a:hover{color:var(--mk-primary-l)}
.mk-overlay__meta{display:flex;flex-direction:column;gap:.6rem;color:rgba(251,249,243,.7);font-size:.95rem}
.mk-overlay__meta a{color:var(--mk-primary-l)}
.mk-body-lock{overflow:hidden}

/* ============================================================
   HERO
   ============================================================ */
.mk-hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:var(--mk-cream)}
.mk-hero__media{position:absolute;inset:0;background-image:var(--hero);background-size:cover;background-position:center;transform:scale(1.05);animation:mk-zoom 18s ease-out forwards}
@keyframes mk-zoom{to{transform:scale(1)}}
.mk-hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,24,16,.55) 0%,rgba(20,24,16,.22) 32%,rgba(16,20,12,.82) 100%)}
/* padding-top reserves the fixed-header height (plus breathing room) so content never collides; bottom padding sits clear of the scroll cue */
.mk-hero__inner{position:relative;max-width:var(--wrap);margin:0 auto;width:100%;padding:calc(var(--mk-headerh) + clamp(48px,7vh,96px)) var(--pad) clamp(96px,13vh,150px);}
.mk-hero__title{font-family:var(--serif);font-weight:400;font-size:clamp(2.6rem,8vw,6rem);line-height:1.02;letter-spacing:-.02em;margin:.4rem 0 1.2rem;max-width:16ch}
.mk-hero__title em{font-style:italic;color:var(--mk-primary-l)}
.mk-hero__lead{font-size:clamp(1.05rem,1.8vw,1.32rem);max-width:54ch;color:rgba(251,249,243,.9);margin:0 0 2rem}
.mk-hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.6rem}
.mk-hero__meta{font-size:.85rem;letter-spacing:.06em;color:rgba(251,249,243,.72);text-transform:uppercase}
.mk-hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);width:26px;height:42px;border:1.5px solid rgba(251,249,243,.5);border-radius:14px}
.mk-hero__scroll span{position:absolute;left:50%;top:8px;width:3px;height:8px;background:var(--mk-cream);border-radius:2px;transform:translateX(-50%);animation:mk-scroll 1.8s infinite}
@keyframes mk-scroll{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:22px}}

/* ============================================================
   SOCIAL PROOF
   ============================================================ */
.mk-proof{background:var(--mk-sumi);color:var(--mk-cream);padding:clamp(40px,6vw,64px) var(--pad)}
.mk-proof__inner{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.mk-proof__item{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0;position:relative}
.mk-proof__item:not(:last-child)::after{content:"";position:absolute;right:-.75rem;top:15%;height:70%;width:1px;background:rgba(251,249,243,.14)}
.mk-proof__item strong{font-family:var(--serif);font-size:clamp(1.8rem,3.4vw,2.7rem);font-weight:500;color:var(--mk-primary-l);line-height:1}
.mk-proof__item strong small{font-size:.42em;color:rgba(251,249,243,.65);margin-left:2px}
.mk-proof__item span{font-size:.84rem;color:rgba(251,249,243,.72);letter-spacing:.02em}
.mk-proof__press{text-align:center;color:rgba(251,249,243,.55);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin:2.4rem 0 0}
.mk-proof__press em{font-style:normal;color:var(--mk-primary-l)}

/* ============================================================
   CRAFT
   ============================================================ */
.mk-craft__head{max-width:var(--wrap);margin:0 auto 3.5rem;text-align:center;display:flex;flex-direction:column;align-items:center}
.mk-craft__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.mk-craft__card{background:var(--mk-cream);border:1px solid var(--mk-line);border-radius:var(--r);padding:2.4rem 2rem;transition:transform .3s,box-shadow .3s,border-color .3s}
.mk-craft__card:hover{transform:translateY(-6px);box-shadow:var(--mk-shadow);border-color:transparent}
.mk-craft__num{font-family:var(--serif);font-size:.95rem;color:var(--mk-accent);letter-spacing:.1em}
.mk-craft__card h3{font-family:var(--serif);font-weight:500;font-size:1.4rem;margin:1rem 0 .7rem;color:var(--mk-sumi)}
.mk-craft__card p{margin:0;color:var(--mk-ink-soft);font-size:.98rem}

/* ============================================================
   ABOUT
   ============================================================ */
.mk-about{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:calc(var(--wrap) + 80px);margin:0 auto}
.mk-about__media{position:relative}
.mk-about__media img{border-radius:var(--r);box-shadow:var(--mk-shadow);width:100%;object-fit:cover;aspect-ratio:4/5}
.mk-about__badge{position:absolute;right:-18px;bottom:28px;background:var(--mk-primary-d);color:var(--mk-cream);border-radius:14px;padding:1rem 1.2rem;text-align:center;box-shadow:var(--mk-shadow-sm)}
.mk-about__badge span{font-family:var(--jp);font-size:1.5rem;display:block}
.mk-about__badge small{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mk-primary-l)}
.mk-about__body p{color:var(--mk-ink-soft);margin:0 0 1.1rem;max-width:54ch}

/* ============================================================
   MENU (home preview + page)
   ============================================================ */
.mk-menu{background:var(--mk-washi-2)}
.mk-menu__head{max-width:var(--wrap);margin:0 auto 2.6rem;text-align:center;display:flex;flex-direction:column;align-items:center}
.mk-menu__cols{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.mk-menu__cat{font-family:var(--sans);font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--mk-primary-d);padding-bottom:1rem;border-bottom:1px solid var(--mk-line);margin:0 0 1.2rem}
.mk-menu__item{display:flex;flex-direction:column;gap:.25rem;padding:.85rem 0;border-bottom:1px dashed var(--mk-line)}
.mk-menu__item:last-child{border-bottom:0}
.mk-menu__name{font-family:var(--serif);font-size:1.18rem;color:var(--mk-sumi)}
.mk-menu__desc{font-size:.92rem;color:var(--mk-ink-soft)}
.mk-menu__foot{max-width:var(--wrap);margin:3rem auto 0;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.9rem}
.mk-menu__note{font-size:.85rem;color:var(--mk-ink-soft);font-style:italic}

.mk-menupage__inner{max-width:880px;margin:0 auto}
.mk-menupage__block{margin-bottom:3rem}
.mk-menupage__cat{font-family:var(--serif);font-weight:400;font-size:clamp(1.5rem,3vw,2.1rem);color:var(--mk-sumi);margin:0 0 1.2rem;padding-bottom:.8rem;border-bottom:2px solid var(--mk-primary-l)}
.mk-menupage__foot{max-width:880px;margin:1rem auto 0;text-align:center;color:var(--mk-ink-soft);font-style:italic;font-size:.95rem}

/* ============================================================
   GALLERY
   ============================================================ */
.mk-gallery__head{max-width:var(--wrap);margin:0 auto 3rem;text-align:center;display:flex;flex-direction:column;align-items:center}
.mk-gallery__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:300px;gap:14px}
.mk-gallery__item{position:relative;overflow:hidden;border-radius:14px;margin:0}
.mk-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.mk-gallery__item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1rem .9rem;color:#fff;font-size:.85rem;letter-spacing:.02em;background:linear-gradient(transparent,rgba(16,18,12,.78));opacity:0;transform:translateY(8px);transition:.4s}
.mk-gallery__item:hover img{transform:scale(1.07)}
.mk-gallery__item:hover figcaption{opacity:1;transform:translateY(0)}
.mk-gallery__item--tall{grid-row:span 2}
.mk-gallery__item--wide{grid-column:span 2}
.mk-gallery__credit{text-align:center;margin:2.4rem auto 0;color:var(--mk-ink-soft)}
.mk-gallery__credit a{color:var(--mk-primary-d);border-bottom:1px solid var(--mk-primary-l)}

/* ============================================================
   QUOTES
   ============================================================ */
.mk-quotes{background:var(--mk-sumi);color:var(--mk-cream)}
.mk-quotes__head{max-width:var(--wrap);margin:0 auto 3rem;text-align:center;display:flex;flex-direction:column;align-items:center}
.mk-quotes__head .mk-h2{color:var(--mk-cream)}
.mk-quotes__head .mk-eyebrow{color:var(--mk-primary-l)}
.mk-quotes__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.mk-quote{margin:0;background:rgba(251,249,243,.04);border:1px solid rgba(251,249,243,.1);border-radius:var(--r);padding:2rem 2.1rem;transition:transform .3s,border-color .3s}
.mk-quote:hover{transform:translateY(-4px);border-color:rgba(168,190,134,.4)}
.mk-quote__stars{color:var(--mk-accent);letter-spacing:.15em;font-size:.9rem;margin-bottom:1rem}
.mk-quote blockquote{margin:0 0 1.3rem;font-family:var(--serif);font-size:1.22rem;line-height:1.5;color:var(--mk-cream)}
.mk-quote figcaption{display:flex;flex-direction:column}
.mk-quote figcaption span{font-weight:600;color:var(--mk-primary-l)}
.mk-quote figcaption small{color:rgba(251,249,243,.55);font-size:.8rem;letter-spacing:.05em}

/* ============================================================
   FAQ
   ============================================================ */
.mk-faq__head{max-width:760px;margin:0 auto 3rem;text-align:center;display:flex;flex-direction:column;align-items:center}
.mk-faq__list{max-width:760px;margin:0 auto}
.mk-faq__item{border-bottom:1px solid var(--mk-line)}
.mk-faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.5rem 0;font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.35rem);color:var(--mk-sumi)}
.mk-faq__item summary::-webkit-details-marker{display:none}
.mk-faq__plus{position:relative;flex:0 0 22px;width:22px;height:22px}
.mk-faq__plus::before,.mk-faq__plus::after{content:"";position:absolute;background:var(--mk-primary-d);transition:.3s}
.mk-faq__plus::before{left:0;top:10px;width:22px;height:2px}
.mk-faq__plus::after{left:10px;top:0;width:2px;height:22px}
.mk-faq__item[open] .mk-faq__plus::after{transform:rotate(90deg);opacity:0}
.mk-faq__a{padding:0 0 1.6rem;max-width:62ch}
.mk-faq__a p{margin:0;color:var(--mk-ink-soft)}
.mk-faq--page{background:var(--mk-cream)}

/* ============================================================
   LOCATION
   ============================================================ */
.mk-location{display:grid;grid-template-columns:1fr 1.1fr;gap:0;align-items:stretch;padding:0;background:var(--mk-washi-2)}
.mk-location__body{padding:var(--sec) var(--pad)}
.mk-location__addr{font-family:var(--serif);font-size:1.3rem;color:var(--mk-sumi);margin:0 0 1.6rem;line-height:1.5}
.mk-location__meta{display:flex;flex-direction:column;gap:1rem;margin:0 0 2rem}
.mk-location__meta div{display:flex;flex-direction:column;gap:.2rem}
.mk-location__meta dt{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mk-primary-d);font-weight:600}
.mk-location__meta dd{margin:0;font-size:1.05rem;color:var(--mk-sumi)}
.mk-location__meta a{border-bottom:1px solid var(--mk-primary-l)}
.mk-location__actions{display:flex;flex-wrap:wrap;gap:.8rem}
.mk-location__map{min-height:420px;position:relative}
.mk-location__map iframe{position:absolute;inset:0;width:100%;height:100%;filter:grayscale(.2) contrast(1.02)}

/* ============================================================
   FINAL CTA
   ============================================================ */
.mk-cta{position:relative;background:var(--mk-primary-d);color:var(--mk-cream);text-align:center;padding:clamp(72px,11vw,140px) var(--pad);overflow:hidden}
.mk-cta::before{content:"抹茶";position:absolute;font-family:var(--jp);font-size:clamp(12rem,34vw,30rem);color:rgba(251,249,243,.05);right:-2vw;top:50%;transform:translateY(-50%);line-height:1;pointer-events:none}
.mk-cta__inner{position:relative;max-width:760px;margin:0 auto}
.mk-cta__title{font-family:var(--serif);font-weight:400;font-size:clamp(2.1rem,5vw,3.6rem);line-height:1.05;margin:.6rem 0 1rem}
.mk-cta__lead{font-size:1.1rem;color:rgba(251,249,243,.85);margin:0 auto 2rem;max-width:48ch}
.mk-cta__actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}

/* ============================================================
   PAGE HERO / PROSE
   ============================================================ */
.mk-pagehero{position:relative;background:var(--mk-sumi);color:var(--mk-cream);padding:clamp(140px,20vh,220px) var(--pad) clamp(60px,9vw,100px);overflow:hidden}
.mk-pagehero--img::before{content:"";position:absolute;inset:0;background-image:var(--hero);background-size:cover;background-position:center;opacity:.32}
.mk-pagehero--img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,20,12,.6),rgba(16,20,12,.86))}
.mk-pagehero__inner{position:relative;max-width:var(--wrap);margin:0 auto}
.mk-pagehero__title{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,6.5vw,4.6rem);line-height:1.04;margin:.3rem 0 0;letter-spacing:-.015em}
.mk-pagehero__lead{font-size:1.15rem;color:rgba(251,249,243,.85);margin:1.2rem 0 0;max-width:52ch}

.mk-prose__inner{max-width:760px;margin:0 auto}
.mk-prose__inner h2{font-family:var(--serif);font-weight:500;font-size:1.7rem;margin:2.2rem 0 1rem;color:var(--mk-sumi)}
.mk-prose__inner h3{font-family:var(--serif);font-weight:500;font-size:1.3rem;margin:1.8rem 0 .8rem}
.mk-prose__inner p,.mk-prose__inner li{color:var(--mk-ink-soft)}
.mk-prose__inner a{color:var(--mk-primary-d);border-bottom:1px solid var(--mk-primary-l)}
.mk-prose__inner ul{padding-left:1.2rem}

/* postlist */
.mk-postlist{display:grid;gap:2rem}
.mk-postcard{border-bottom:1px solid var(--mk-line);padding-bottom:1.6rem}
.mk-postcard h2{font-family:var(--serif);font-weight:500;font-size:1.5rem;margin:.8rem 0 .5rem}
.mk-postcard__img img{border-radius:12px}

/* ============================================================
   CONTACT
   ============================================================ */
.mk-contact__grid{max-width:var(--wrap);margin:0 auto 3rem;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem)}
.mk-contact__info .mk-h2,.mk-contact__form .mk-h2{font-size:1.7rem;margin-bottom:1.4rem}
.mk-contact__dl{display:flex;flex-direction:column;gap:1.1rem;margin:0 0 1.8rem}
.mk-contact__dl div{display:flex;flex-direction:column;gap:.2rem}
.mk-contact__dl dt{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mk-primary-d);font-weight:600}
.mk-contact__dl dd{margin:0;color:var(--mk-sumi);font-size:1.05rem}
.mk-contact__dl a{border-bottom:1px solid var(--mk-primary-l)}
.mk-form{display:flex;flex-direction:column;gap:1.1rem}
.mk-form label{display:flex;flex-direction:column;gap:.45rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mk-primary-d);font-weight:600}
.mk-form input,.mk-form textarea{font-family:var(--sans);font-size:1rem;color:var(--mk-sumi);background:var(--mk-cream);border:1px solid var(--mk-line);border-radius:12px;padding:.9rem 1rem;transition:border-color .3s,box-shadow .3s}
.mk-form input:focus,.mk-form textarea:focus{outline:none;border-color:var(--mk-primary);box-shadow:0 0 0 3px rgba(108,138,78,.15)}
.mk-form button{align-self:flex-start;margin-top:.4rem}
.mk-form__ok{background:rgba(108,138,78,.12);border:1px solid var(--mk-primary-l);color:var(--mk-primary-d);padding:1rem 1.2rem;border-radius:12px}
.mk-form__err{background:rgba(180,60,40,.1);border:1px solid #c0563c;color:#a13b25;padding:1rem 1.2rem;border-radius:12px}
.mk-contact__map{max-width:var(--wrap);margin:0 auto;height:440px;border-radius:var(--r);overflow:hidden;box-shadow:var(--mk-shadow-sm)}
.mk-contact__map iframe{width:100%;height:100%;border:0;filter:grayscale(.2)}

/* ============================================================
   FOOTER
   ============================================================ */
.mk-footer{background:var(--mk-sumi);color:rgba(251,249,243,.78);padding:clamp(56px,8vw,90px) var(--pad) 2rem}
.mk-footer__top{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem}
.mk-footer__brand img{width:56px;height:56px;margin-bottom:1rem}
.mk-footer__name{font-family:var(--serif);font-size:1.4rem;color:var(--mk-cream);margin:0 0 .6rem}
.mk-footer__name span{font-family:var(--jp);font-size:.85rem;color:var(--mk-primary-l);margin-left:.4rem}
.mk-footer__tag{font-size:.92rem;max-width:36ch;margin:0 0 1.2rem}
.mk-footer__social{display:flex;gap:1.2rem}
.mk-footer__social a{font-size:.85rem;color:var(--mk-primary-l);border-bottom:1px solid transparent;transition:.3s}
.mk-footer__social a:hover{border-color:var(--mk-primary-l)}
.mk-footer__col h3{font-family:var(--sans);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mk-cream);margin:0 0 1rem}
.mk-footer__col p{margin:0 0 .6rem;font-size:.95rem}
.mk-footer__col a:hover{color:var(--mk-primary-l)}
.mk-footer__note{font-size:.82rem;color:rgba(251,249,243,.5)}
.mk-footer__menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.mk-footer__menu a{font-size:.95rem}
.mk-footer__bottom{max-width:var(--wrap);margin:2.5rem auto 0;padding-top:1.6rem;border-top:1px solid rgba(251,249,243,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:rgba(251,249,243,.5)}
.mk-footer__legal{display:flex;gap:1.4rem}
.mk-footer__legal a:hover{color:var(--mk-primary-l)}

/* ============================================================
   MOBILE ACTION BAR
   ============================================================ */
.mk-actionbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:920;height:64px;background:var(--mk-primary-d);box-shadow:0 -8px 24px -12px rgba(0,0,0,.4)}
.mk-actionbar__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:rgba(251,249,243,.92);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-right:1px solid rgba(255,255,255,.12)}
.mk-actionbar__item:last-child{border-right:0}
.mk-actionbar__ico{font-size:22px;line-height:1}
.mk-actionbar__item--cta{background:var(--mk-accent);color:#fff}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .mk-nav,.mk-header__cta{display:none}
  .mk-burger{display:flex}
  .mk-craft__grid{grid-template-columns:1fr 1fr}
  .mk-footer__top{grid-template-columns:1fr 1fr}
  .mk-about__badge{right:12px}
}
@media(max-width:760px){
  body.mk-has-action-bar{padding-bottom:64px}
  .mk-actionbar{display:flex}
  .mk-craft__grid,.mk-menu__cols,.mk-quotes__grid,.mk-contact__grid{grid-template-columns:1fr}
  .mk-about{grid-template-columns:1fr}
  .mk-about__media{max-width:440px;margin:0 auto}
  .mk-about__badge{right:18px}
  .mk-location{grid-template-columns:1fr}
  .mk-location__map{min-height:320px;order:-1}
  .mk-proof__inner{grid-template-columns:1fr 1fr;gap:2rem 1rem}
  .mk-proof__item:not(:last-child)::after{display:none}
  .mk-proof__item:nth-child(2)::after{display:none}
  .mk-gallery__grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .mk-gallery__item--wide{grid-column:span 2}
  .mk-gallery__item--tall{grid-row:span 1}
  .mk-footer__top{grid-template-columns:1fr 1fr;gap:2rem 1.5rem}
  .mk-footer__brand{grid-column:1/-1}
  .mk-footer__bottom{flex-direction:column;text-align:center;align-items:center}
  .mk-hero{min-height:92svh}
}
@media(max-width:760px){
  /* keep hero clear of the fixed mobile action bar; drop the scroll cue it would sit behind */
  .mk-hero__inner{padding-bottom:calc(64px + clamp(40px,9vh,90px))}
  .mk-hero__scroll{display:none}
}
@media(max-width:420px){
  .mk-footer__top{grid-template-columns:1fr}
  .mk-gallery__grid{grid-template-columns:1fr;grid-auto-rows:240px}
  .mk-gallery__item--wide{grid-column:span 1}
}
/* short viewports (laptops, landscape phones): let the hero breathe instead of cramming */
@media(max-height:720px){
  .mk-hero{min-height:auto;padding-block:0}
  .mk-hero__inner{padding-top:calc(var(--mk-headerh) + 40px);padding-bottom:clamp(48px,8vh,80px)}
  .mk-hero__scroll{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
