:root{
  --ink:#1C1B19; --ink2:#26241f; --gold:#C7A86B; --gold-d:#9A7B3C;
  --paper:#FBFAF7; --card:#F2F0EB; --grey:#5b574f; --greyl:#8d887e; --line:#E4E0D8;
  --serif-en:"Cormorant Garamond","Times New Roman",serif;
  --serif-jp:"Noto Serif JP",serif;
  --sans-jp:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans-jp);color:var(--ink);background:var(--paper);font-weight:300;line-height:1.85;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
.wrap.narrow{max-width:860px}
.eyebrow{font-family:var(--serif-en);font-style:italic;font-size:20px;color:var(--gold-d);letter-spacing:.04em}
.kicker{font-size:12px;letter-spacing:.34em;color:var(--gold-d);text-transform:uppercase;font-weight:500}
h2.title{font-family:var(--serif-jp);font-weight:500;font-size:clamp(26px,3.4vw,40px);line-height:1.45;letter-spacing:.04em;margin:.4em 0}
.lead{font-size:16px;color:var(--grey);line-height:2;max-width:46em}
.btn{display:inline-block;border:1px solid var(--gold-d);color:var(--ink);padding:14px 34px;font-size:13px;letter-spacing:.22em;background:transparent;transition:.35s;text-transform:uppercase;cursor:pointer}
.btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.light{border-color:var(--gold);color:#fff}
.btn.light:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
section{padding:120px 0}
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.4s;padding:24px 0}
header .wrap{display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--serif-en);font-weight:600;font-size:22px;letter-spacing:.42em;color:#fff;padding-left:.42em;transition:.4s}
nav.main{display:flex;gap:34px}
nav.main a{font-size:11.5px;letter-spacing:.18em;color:rgba(255,255,255,.85);text-transform:uppercase;transition:.3s}
nav.main a:hover{color:var(--gold)}
.navcta{font-size:11.5px;letter-spacing:.16em;color:#fff;border:1px solid rgba(255,255,255,.5);padding:9px 20px;text-transform:uppercase;transition:.3s}
.navcta:hover{background:#fff;color:var(--ink)}
header.solid{background:rgba(251,250,247,.96);padding:16px 0;box-shadow:0 1px 0 var(--line)}
header.solid .brand{color:var(--ink)}
header.solid nav.main a{color:var(--ink)}
header.solid .navcta{color:var(--ink);border-color:var(--gold-d)}
header.solid .navcta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.menu-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.menu-btn span{width:24px;height:1.5px;background:#fff;transition:.3s}
header.solid .menu-btn span{background:var(--ink)}

/* hero (TOP) */
.hero{height:100vh;min-height:620px;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff}
.hero .bg{position:absolute;inset:0;background:url('../img/hp04.jpg') center/cover no-repeat}
.hero .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,27,25,.55) 0%,rgba(28,27,25,.32) 38%,rgba(28,27,25,.62) 100%)}
.hero .inner{position:relative;z-index:2;padding:0 24px}
.hero h1{font-family:var(--serif-jp);font-weight:500;font-size:clamp(34px,6vw,72px);letter-spacing:.1em;line-height:1.3;text-indent:.1em;word-break:keep-all;overflow-wrap:break-word}
.hero .sub{font-family:var(--serif-en);font-style:italic;font-size:clamp(16px,2vw,22px);letter-spacing:.06em;margin-top:18px;color:rgba(255,255,255,.9)}
.hero .btn{margin-top:40px}
.hero .trust{position:absolute;bottom:38px;left:0;right:0;z-index:2;text-align:center;font-size:11px;letter-spacing:.26em;color:rgba(255,255,255,.82);text-transform:uppercase}
.scrolldown{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;width:1px;height:46px;background:linear-gradient(rgba(255,255,255,.7),transparent)}

/* page hero (inner pages) */
.page-hero{height:48vh;min-height:360px;position:relative;display:flex;align-items:flex-end;color:#fff;padding-bottom:56px}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,27,25,.45),rgba(28,27,25,.66))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-family:var(--serif-jp);font-weight:500;font-size:clamp(28px,4.2vw,48px);letter-spacing:.06em;line-height:1.35}
.page-hero .kicker{color:var(--gold)}
.crumbs{font-size:11px;letter-spacing:.14em;color:rgba(255,255,255,.78);text-transform:uppercase;margin-bottom:16px}
.crumbs a:hover{color:var(--gold)}
.crumbs span{opacity:.6;margin:0 8px}

/* concept */
.concept{text-align:center}
.concept .big{font-family:var(--serif-jp);font-weight:500;font-size:clamp(22px,3vw,34px);line-height:2;letter-spacing:.05em;max-width:20em;margin:18px auto 0}
.concept .big b{color:var(--gold-d);font-weight:600}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0}
.split.dark{background:var(--ink);color:#fff}
.split .media{min-height:560px;background-size:cover;background-position:center}
.split .body{padding:90px 8%}
.split.dark .lead{color:rgba(255,255,255,.78)}
.split .kicker{color:var(--gold)}
.split.dark h2.title{color:#fff}

/* section head + prose */
.section-head{text-align:center;max-width:48em;margin:0 auto 56px}
.section-head .lead{margin:18px auto 0}
.prose{max-width:42em;margin:0 auto;font-size:16px;color:#403c35}
.prose>*+*{margin-top:1.3em}
.prose h2{font-family:var(--serif-jp);font-weight:600;font-size:24px;letter-spacing:.03em;margin-top:1.8em}
.prose h3{font-family:var(--serif-jp);font-weight:600;font-size:18px;color:var(--ink);margin-top:1.5em}
.prose p{line-height:2}
.prose ul{padding-left:1.2em}
.prose li{margin:.5em 0;line-height:1.9}
.prose blockquote{border-left:2px solid var(--gold);padding:6px 0 6px 22px;color:var(--grey);font-style:italic}
.prose .summary{background:var(--card);border-radius:6px;padding:22px 26px;font-size:14.5px;color:var(--ink)}
.prose .summary b{color:var(--gold-d)}
.prose .byline{font-size:12px;color:var(--greyl);letter-spacing:.04em;border-bottom:1px solid var(--line);padding-bottom:16px;margin:0 0 1.6em}
.prose .sources{margin-top:2.6em;background:var(--card);border-radius:6px;padding:20px 26px;font-size:12.5px}
.prose .sources h3{font-family:var(--sans-jp);font-weight:500;font-size:11.5px;letter-spacing:.12em;color:var(--gold-d);margin:0 0 10px;text-transform:uppercase}
.prose .sources ul{padding-left:1.1em;margin:0}
.prose .sources li{margin:.35em 0;color:var(--grey);line-height:1.7}
.prose .sources a{text-decoration:underline}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cards.col2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:32px 30px;box-shadow:0 10px 30px rgba(0,0,0,.04)}
.card .kicker{margin-bottom:10px}
.card h3{font-family:var(--serif-jp);font-weight:600;font-size:18px;margin-bottom:10px}
.card p{font-size:13.5px;color:var(--grey);line-height:1.9}
.card .num{font-family:var(--serif-en);font-size:30px;color:var(--gold-d);line-height:1;margin-bottom:14px}

/* feature rows */
.rows{max-width:60em;margin:0 auto}
.frow{display:grid;grid-template-columns:200px 1fr;gap:30px;padding:28px 0;border-bottom:1px solid var(--line)}
.frow h3{font-family:var(--serif-jp);font-weight:600;font-size:17px}
.frow p{font-size:14px;color:var(--grey);line-height:1.9}

/* table */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th,.table td{text-align:left;padding:16px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.table th{width:30%;color:var(--ink);font-weight:500;background:var(--card)}
.table td{color:var(--grey)}

/* faq / qa */
.qa{max-width:54em;margin:0 auto}
.qa details{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;padding:24px 40px 24px 0;position:relative;font-size:16px;color:var(--ink);font-weight:400}
.qa summary::-webkit-details-marker{display:none}
.qa summary .q{font-family:var(--serif-jp);color:var(--gold-d);margin-right:12px;font-weight:600}
.qa summary:after{content:"+";position:absolute;right:6px;top:22px;font-size:22px;color:var(--gold-d);transition:.3s}
.qa details[open] summary:after{transform:rotate(45deg)}
.qa .a{padding:0 40px 26px 0;color:var(--grey);font-size:14.5px;line-height:1.95}

/* colours */
.colours{background:var(--card)}
.swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:22px;margin-top:54px}
.sw{text-align:center}
.sw .chip{aspect-ratio:1/1.35;border-radius:3px;box-shadow:0 8px 22px rgba(0,0,0,.10);transition:.4s}
.sw:hover .chip{transform:translateY(-6px)}
.sw .nm{font-family:var(--serif-en);font-size:14px;letter-spacing:.04em;margin-top:14px;color:var(--ink)}
.sw .jp{font-size:10.5px;color:var(--greyl);letter-spacing:.06em}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:230px;gap:14px;margin-top:54px}
.gal figure{position:relative;overflow:hidden;background-size:cover;background-position:center}
.gal figure figcaption{position:absolute;left:0;bottom:0;right:0;padding:18px 20px;color:#fff;font-size:12px;letter-spacing:.14em;background:linear-gradient(transparent,rgba(0,0,0,.55));text-transform:uppercase}
.g1{grid-column:span 7;grid-row:span 2}
.g2{grid-column:span 5}
.g3{grid-column:span 5}
.g4{grid-column:span 4}
.g5{grid-column:span 4}
.g6{grid-column:span 4}

/* journal cards */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.post{background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:.4s;display:block}
.post:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,0,0,.08)}
.post .ph{height:200px;background-size:cover;background-position:center}
.post .bd{padding:24px 24px 28px}
.post .tag{font-size:10.5px;letter-spacing:.16em;color:var(--gold-d);text-transform:uppercase}
.post h3{font-family:var(--serif-jp);font-weight:600;font-size:17px;line-height:1.5;margin:10px 0}
.post p{font-size:13px;color:var(--grey);line-height:1.8}

/* trust */
.trustsec{background:var(--ink);color:#fff;text-align:center}
.badge{display:inline-flex;align-items:center;gap:14px;border:1px solid rgba(199,168,107,.5);border-radius:999px;padding:14px 30px;margin-bottom:30px}
.badge b{font-family:var(--serif-en);letter-spacing:.18em;color:var(--gold);font-size:18px}
.badge span{font-size:12px;color:rgba(255,255,255,.78);letter-spacing:.08em}
.media-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;margin-top:48px;opacity:.9}
.media-row span{font-family:var(--serif-en);font-size:18px;letter-spacing:.08em;color:rgba(255,255,255,.85)}
.trustsec .lead{margin:0 auto;color:rgba(255,255,255,.8)}

/* contact + form */
.contact{background:url('../img/forest.jpg') center/cover fixed;position:relative;text-align:center;color:#fff}
.contact:before{content:"";position:absolute;inset:0;background:rgba(28,27,25,.6)}
.contact .wrap{position:relative;z-index:2}
.contact h2.title{color:#fff}
.contact .ways{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;margin-top:34px;font-size:13px;letter-spacing:.1em;color:rgba(255,255,255,.9)}
.contact .ways b{color:var(--gold);font-family:var(--serif-en);letter-spacing:.12em}
.form{max-width:620px;margin:0 auto;text-align:left}
.form .field{margin-bottom:22px}
.form label{display:block;font-size:12.5px;letter-spacing:.08em;color:var(--ink);margin-bottom:8px}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--line);background:#fff;padding:14px 16px;font-family:inherit;font-size:15px;color:var(--ink);border-radius:4px}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--gold-d)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--gold-d);outline-offset:2px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* cta band */
.cta-band{background:var(--ink);color:#fff;text-align:center}
.cta-band h2.title{color:#fff}
.cta-band .lead{margin:0 auto;color:rgba(255,255,255,.8)}

/* footer */
footer{background:#141312;color:rgba(255,255,255,.62);font-size:12.5px;padding:70px 0 36px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px}
footer .brand2{font-family:var(--serif-en);font-size:20px;letter-spacing:.4em;color:#fff;margin-bottom:14px}
footer h4{font-size:11px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:16px;font-weight:500}
footer a{display:block;color:rgba(255,255,255,.62);padding:5px 0;transition:.3s}
footer a:hover{color:#fff}
footer .note{border:1px solid rgba(255,255,255,.16);padding:14px 18px;border-radius:4px;color:rgba(255,255,255,.7);line-height:1.7}
footer .bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:rgba(255,255,255,.4);letter-spacing:.06em}
.proto-flag{position:fixed;bottom:14px;right:14px;z-index:99;background:rgba(28,27,25,.86);color:var(--gold);font-size:10.5px;letter-spacing:.12em;padding:7px 12px;border-radius:4px}

@media(max-width:880px){
  section{padding:78px 0}
  nav.main,.navcta{display:none}
  .menu-btn{display:flex}
  .hero h1{font-size:31px;letter-spacing:.05em;line-height:1.55}
  .hero .sub{font-size:15px}
  .concept .big{font-size:22px;line-height:1.9}
  .wrap{padding:0 24px}
  .split{grid-template-columns:1fr}
  .split .media{min-height:300px;order:-1}
  .split .body{padding:54px 28px}
  .swatches{grid-template-columns:repeat(3,1fr);gap:16px}
  .gal{grid-auto-rows:160px}
  .g1,.g2,.g3,.g4,.g5,.g6{grid-column:span 12;grid-row:span 1}
  .cards,.cards.col2,.posts{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr;gap:8px}
  .form .row2{grid-template-columns:1fr}
  footer .cols{grid-template-columns:1fr 1fr}
}
