/* ===== Calm site — shared styles ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600&family=Zen+Maru+Gothic:wght@400;500;700&family=Zen+Kaku+Gothic+New:wght@400;500;700;900&display=swap');

:root{
  --green:#1f4d34; --green-deep:#143524; --green-soft:#6f8a6a;
  --cream:#f6f1e7; --cream-deep:#ece4d3; --paper:#fdfbf6;
  --accent:#e07a3f; --accent-deep:#c4632c; --gold:#f4c453;
  --ink:#33352f; --muted:#7c7d72;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Zen Kaku Gothic New","Zen Maru Gothic",sans-serif;color:var(--ink);background:var(--paper);line-height:1.85;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.narrow{max-width:760px}
.en{font-family:"Cormorant Garamond",serif;letter-spacing:.06em}

/* mock banner */
.mockbar{background:var(--ink);color:#fff;font-size:12px;text-align:center;padding:7px;letter-spacing:.04em}

/* header */
header{position:sticky;top:0;z-index:50;background:var(--green);color:#fff}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:"Cormorant Garamond",serif;font-size:30px;font-weight:600;letter-spacing:.12em;color:var(--cream)}
.logo small{display:block;font-family:"Zen Kaku Gothic New";font-size:9px;letter-spacing:.5em;opacity:.8;margin-top:-6px}
nav ul{display:flex;gap:24px;list-style:none;font-size:13px;letter-spacing:.08em;align-items:center}
nav .nav-en{font-family:"Cormorant Garamond",serif;font-size:15px;transition:opacity .2s}
nav .nav-en:hover{opacity:.7}
nav .line-btn{background:var(--accent);color:#fff;padding:9px 18px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.06em}
nav .line-btn:hover{background:var(--accent-deep)}
@media(max-width:920px){nav ul{display:none}}

/* buttons */
.btn{display:inline-block;padding:14px 30px;border-radius:999px;font-weight:700;font-size:14px;letter-spacing:.04em;transition:.2s}
.btn-line{background:var(--accent);color:#fff}
.btn-line:hover{background:var(--accent-deep)}
.btn-gold{background:var(--gold);color:var(--green-deep)}
.btn-gold:hover{filter:brightness(.96)}
.btn-ghost{border:1.5px solid var(--green);color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}
.btn-ghost-w{border:1.5px solid #fff;color:#fff}
.btn-ghost-w:hover{background:#fff;color:var(--green)}

/* sections */
section{padding:90px 0}
.sec-head{text-align:center;margin-bottom:14px}
.sec-head .en{display:block;font-size:42px;color:var(--green);font-weight:600}
.sec-head .jp{font-size:14px;color:var(--accent);letter-spacing:.2em;font-weight:700}
.sec-sub{text-align:center;color:var(--muted);margin-bottom:48px}
.ph-note{font-size:10px;color:#b9a87f;letter-spacing:.05em}

/* page hero (lower pages) */
.page-hero{background:var(--green);color:#fff;text-align:center;padding:70px 0 64px}
.page-hero .en{display:block;font-size:48px;font-weight:600;color:var(--cream)}
.page-hero .jp{font-size:14px;letter-spacing:.2em;color:#cfe0c5;font-weight:700}
.crumb{font-size:12px;color:var(--muted);padding:16px 0}
.crumb a:hover{color:var(--accent)}

/* CSS salad bowl (placeholder) */
.bowl{border-radius:50%;
  background:conic-gradient(#e8743f 0 14%,#7ba05b 14% 30%,#d8b24a 30% 44%,#9d5fa0 44% 56%,#c94f4f 56% 68%,#6f8a6a 68% 82%,#e0a93f 82% 100%);
  box-shadow:0 24px 50px rgba(63,93,68,.18),inset 0 0 0 14px #c8a877;position:relative}
.bowl::after{content:"Calm";font-family:"Cormorant Garamond",serif;font-size:24px;color:var(--green);
  position:absolute;width:36%;height:36%;border-radius:50%;background:#fbf7ef;top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 2px #e4dcc9}

/* hero */
.hero{background:var(--paper);padding:70px 0 90px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:20px}
.hero h1{font-family:"Zen Maru Gothic";font-weight:700;font-size:56px;line-height:1.35;color:var(--green)}
.hero h1 .accent{color:var(--accent)}
.hero p.lead{margin-top:22px;font-size:16px;color:var(--muted);max-width:380px}
.hero .cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;height:440px;display:flex;align-items:center;justify-content:center}
.hero-art .bowl{width:340px;height:340px}
.seed{position:absolute;border-radius:50%}
.s1{width:54px;height:54px;background:#e8743f;top:30px;left:0}
.s2{width:42px;height:42px;background:#7ba05b;bottom:40px;left:30px}
.s3{width:48px;height:48px;background:#d8b24a;top:10px;right:40px}
.s4{width:38px;height:38px;background:#9d5fa0;bottom:20px;right:10px}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr}.hero h1{font-size:40px}.hero-art{height:320px}.hero-art .bowl{width:250px;height:250px}}

/* concept band */
.band{background:var(--cream)}
.band .wrap{max-width:720px;text-align:center}
.band h2{font-family:"Zen Maru Gothic";font-size:30px;color:var(--green);line-height:1.6;margin-bottom:20px}
.band p{color:#5c5d52}

/* menu grid */
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.menu-grid.g3{grid-template-columns:repeat(3,1fr)}
.card{text-align:center}
.card .ph{width:100%;aspect-ratio:1;border-radius:18px;margin-bottom:14px;
  background:linear-gradient(135deg,#eef0e6,#e3e8d6);
  box-shadow:0 10px 24px rgba(31,77,52,.12);position:relative}
.card .jp{font-size:12px;color:var(--muted)}
.card .nm{font-family:"Cormorant Garamond",serif;font-size:22px;font-weight:600;color:var(--ink);letter-spacing:.04em}
.card .dress{font-size:11px;color:var(--green);font-weight:700;letter-spacing:.03em;margin-top:6px}
.card .pr{color:var(--accent);font-weight:700;margin-top:6px}
.card .pr small{font-size:11px;color:var(--muted);font-weight:600}
@media(max-width:920px){.menu-grid,.menu-grid.g3{grid-template-columns:repeat(2,1fr)}}
/* menu board posters (full, uncropped) */
.board-row{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;align-items:flex-start}
.board-img{flex:1 1 360px;max-width:520px;border-radius:14px;overflow:hidden;box-shadow:0 10px 26px rgba(31,77,52,.14);background:#fff}
.board-img.single{max-width:1000px;margin:0 auto}
.board-img img{width:100%;height:auto;display:block}
@media(max-width:920px){.board-row{gap:18px}.board-img{flex:1 1 100%}}

/* subscription block */
.sub{background:var(--green);color:#fff;text-align:center}
.sub .pre{color:#cfe0c5;font-size:14px;letter-spacing:.1em;margin-bottom:18px}
.sub h2{font-family:"Zen Maru Gothic";font-size:40px;line-height:1.45;margin-bottom:10px}
.sub h2 .y{color:var(--gold)}
.plans{display:flex;gap:24px;justify-content:center;margin:40px 0;flex-wrap:wrap}
.plan{background:#fff;color:var(--ink);border-radius:18px;padding:28px 34px;width:300px;text-align:left}
.plan.std{outline:3px solid var(--gold);position:relative}
.plan.std .tag{position:absolute;top:-14px;left:24px;background:var(--gold);color:var(--green-deep);font-size:11px;font-weight:700;padding:4px 12px;border-radius:999px}
.plan .pname{font-weight:700;color:var(--green);font-size:18px}
.plan .price{font-family:"Cormorant Garamond",serif;font-size:40px;color:var(--accent);font-weight:600;margin:6px 0}
.plan .price small{font-size:14px;color:var(--muted)}
.plan ul{list-style:none;font-size:13px;color:#5c5d52;margin-top:10px}
.plan li{padding:4px 0 4px 20px;position:relative}
.plan li::before{content:"●";color:var(--green-soft);font-size:8px;position:absolute;left:0;top:7px}
.sub .note{font-size:12px;color:#cfe0c5;margin-bottom:26px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:900px;margin:0 auto}
.step{background:var(--cream);border-radius:16px;padding:30px 26px;text-align:center}
.step .no{font-family:"Cormorant Garamond",serif;font-size:34px;color:var(--accent);font-weight:600}
.step h4{font-family:"Zen Maru Gothic";color:var(--green);margin:6px 0 8px;font-size:18px}
.step p{font-size:13px;color:#5c5d52}
@media(max-width:920px){.steps{grid-template-columns:1fr}}

/* faq */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--cream-deep);padding:18px 0}
.faq summary{font-weight:700;color:var(--green);cursor:pointer;list-style:none}
.faq summary::before{content:"Q. ";color:var(--accent)}
.faq p{font-size:14px;color:#5c5d52;padding-top:10px}

/* two column */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.twocol.top{align-items:start}
.ph-box{aspect-ratio:4/3;border-radius:16px;background:repeating-linear-gradient(45deg,#e7e1d2,#e7e1d2 12px,#efe9da 12px,#efe9da 24px);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px}
.ph-box.green{background:linear-gradient(135deg,#7ba05b,#3f5d44);color:#fff}
.twocol h3{font-family:"Zen Maru Gothic";color:var(--green);font-size:24px;margin-bottom:14px}
.twocol p{color:#5c5d52}
@media(max-width:920px){.twocol{grid-template-columns:1fr;gap:24px}}

/* store dl */
.store dl{display:grid;grid-template-columns:100px 1fr;row-gap:12px;font-size:14px}
.store dt{color:var(--accent);font-weight:700}
.map{aspect-ratio:16/9;background:repeating-linear-gradient(45deg,#e7e1d2,#e7e1d2 12px,#efe9da 12px,#efe9da 24px);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;margin-top:30px}

/* news */
.news-list{max-width:760px;margin:0 auto}
.news-item{border-bottom:1px solid var(--cream-deep);padding:18px 0;display:flex;gap:18px;font-size:14px;align-items:center}
.news-item .date{color:var(--muted);font-family:"Cormorant Garamond",serif;white-space:nowrap}
.news-item .cat{background:var(--cream);color:var(--green);font-size:11px;padding:2px 10px;border-radius:999px;font-weight:700;white-space:nowrap}

/* feature cards */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feat .item{text-align:center;padding:10px}
.feat .icon{width:84px;height:84px;border-radius:50%;background:var(--cream);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-family:"Cormorant Garamond",serif;font-size:30px;color:var(--green)}
.feat h4{font-family:"Zen Maru Gothic";color:var(--green);font-size:18px;margin-bottom:8px}
.feat p{font-size:13px;color:#5c5d52}
@media(max-width:920px){.feat{grid-template-columns:1fr}}

/* cta band */
.cta-band{background:var(--cream);text-align:center}
.cta-band h2{font-family:"Zen Maru Gothic";color:var(--green);font-size:30px;margin-bottom:10px}
.cta-band p{color:var(--muted);margin-bottom:26px}

/* image slots (drop assets/img/*.jpg to replace placeholders; onerror keeps the placeholder) */
.imgslot{position:relative;overflow:hidden}
.imgslot>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.card .ph>img{border-radius:18px}
.bowl>img{border-radius:50%}
.hero-art .imgwrap{position:relative;width:380px;height:380px}
.hero-art .imgwrap .bowl{width:100%;height:100%}
.hero-art video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}

/* hero concept paragraph */
.hero .concept-lead{margin-top:18px;font-size:14px;color:#5c5d52;max-width:420px;line-height:2}

/* region tabs (menu) */
.tabs{display:flex;gap:10px;justify-content:center;margin:0 0 40px}
.tab{border:1.5px solid var(--green-soft);color:var(--green);border-radius:999px;padding:7px 22px;font-size:13px;font-weight:700}
.tab.on{background:var(--green);color:#fff;border-color:var(--green)}

/* topping / dressing quick list */
.tagwrap{max-width:860px;margin:40px auto 0}
.tagwrap h4{text-align:center;font-family:"Cormorant Garamond",serif;color:var(--green);font-size:22px;margin-bottom:14px}
.tagrow{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.tagrow span{background:var(--cream);color:#5c5d52;font-size:12px;padding:5px 14px;border-radius:999px}

/* media / SNS grid */
.sns-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.sns-grid .imgslot{aspect-ratio:1;border-radius:10px;background:linear-gradient(135deg,#7ba05b,#3f5d44)}
@media(max-width:920px){.sns-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== flowing salad hero (marquee) ===== */
.marquee{overflow:hidden;background:var(--cream);padding:22px 0}
.marquee-track{display:flex;gap:18px;width:max-content;animation:flowRight 45s linear infinite}
@keyframes flowRight{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.marquee:hover .marquee-track{animation-play-state:paused}
.msalad{flex:0 0 auto;width:330px;height:330px;border-radius:22px;overflow:hidden;position:relative;background:linear-gradient(135deg,#eef0e6,#dde5d0);box-shadow:0 12px 30px rgba(31,77,52,.12)}
.msalad img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.msalad .lbl{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9aa890;font-size:14px;font-weight:700;letter-spacing:.05em;text-align:center;gap:4px}
@media(max-width:920px){.msalad{width:230px;height:230px}}

/* empty image slot (to be specified) */
.slot{position:relative;overflow:hidden;background:linear-gradient(135deg,#eef0e6,#dde5d0);border-radius:16px}
.slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.slot .lbl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#9aa890;font-size:13px;font-weight:700;text-align:center;padding:10px}

/* menu sub-block */
.mblock{margin-top:18px}
.mblock-head{display:flex;align-items:baseline;gap:12px;justify-content:center;margin:50px 0 24px}
.mblock-head .en{font-family:"Cormorant Garamond",serif;font-size:30px;color:var(--green);font-weight:600}
.mblock-head .jp{font-size:13px;color:var(--accent);font-weight:700;letter-spacing:.15em}

/* clean photo hero */
.hero-photo{width:100%;max-width:460px;aspect-ratio:82/100;object-fit:cover;border-radius:22px;box-shadow:0 26px 60px rgba(20,53,36,.22);margin-left:auto}
@media(max-width:920px){.hero-photo{max-width:100%;aspect-ratio:4/3}}

/* pillars (3 product categories) */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pillar{text-align:center;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 10px 28px rgba(31,77,52,.10);transition:.2s}
.pillar:hover{transform:translateY(-4px)}
.pillar .pimg{aspect-ratio:4/3;background:linear-gradient(135deg,#7ba05b,#1f4d34);position:relative;overflow:hidden}
.pillar .pimg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pillar .pbody{padding:22px 20px 26px}
.pillar .en{display:block;font-size:24px;color:var(--green);font-weight:600}
.pillar .jp{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:.1em}
.pillar p{font-size:13px;color:#5c5d52;margin:10px 0 0}
@media(max-width:920px){.pillars{grid-template-columns:1fr}}

/* map embed */
.map-embed{border:0;width:100%;aspect-ratio:16/9;border-radius:14px;margin-top:10px;display:block}

/* feature row (image + text alternating) reuse .twocol */
.nutri{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:16px}
.nutri span{background:#fff;border:1px solid var(--cream-deep);border-radius:999px;padding:6px 16px;font-size:13px;color:var(--green);font-weight:700}

/* MOVIE section (vertical reel) */
.movie{background:var(--cream)}
.movie-wrap{display:flex;justify-content:center}
.movie video{width:300px;max-width:80vw;aspect-ratio:590/1280;border-radius:22px;box-shadow:0 24px 60px rgba(20,53,36,.25);background:#000;object-fit:cover}

/* Instagram section */
.ig-embeds{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.ig-embeds .instagram-media{margin:0!important;min-width:0!important;width:100%!important}
@media(max-width:920px){.ig-embeds{grid-template-columns:1fr;max-width:380px;margin:0 auto}}
.ig-note{max-width:760px;margin:30px auto 0;background:var(--cream);border-radius:14px;padding:22px 26px;font-size:13px;color:#5c5d52;line-height:1.9}
.ig-note b{color:var(--green)}

/* footer */
footer{background:var(--green-deep);color:#cfd8c8;padding:60px 0 30px;text-align:center}
footer .logo{color:var(--cream);margin-bottom:18px}
footer .fnav{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;font-size:13px;margin-bottom:24px}
footer .fnav a:hover{color:#fff}
footer .copy{font-size:11px;opacity:.6;font-family:"Cormorant Garamond",serif;letter-spacing:.1em}
