:root{--bg: #FAFAF7;--accent: #B8834A;--cream: #EFE9DF;--ink: #1C1A15;--dark: #2A2520;--light-accent: #D4A574}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:"Noto Serif JP",Georgia,serif;color:var(--ink);background:var(--bg);font-size:16px;line-height:1.7}body{min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}.banner{background:var(--accent);color:#fff;text-align:center;padding:.5rem 1rem;font-size:.85rem;letter-spacing:.08em}nav{background:var(--bg);border-bottom:1px solid var(--cream);position:sticky;top:0;z-index:100}.nav-inner{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:400;letter-spacing:.12em;color:var(--ink)}.nav-logo svg{width:36px;height:36px}.nav-links{display:flex;gap:2.5rem;list-style:none;font-size:.85rem;letter-spacing:.1em}.nav-links a{position:relative;padding-bottom:2px;transition:color .2s}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width .3s}.nav-links a:hover{color:var(--accent)}.nav-links a:hover:after{width:100%}.hero{background:linear-gradient(135deg,var(--cream) 0%,#e8ddd0 50%,#d4c4ae 100%);min-height:85vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0;overflow:hidden;position:relative}.hero:before{content:"";position:absolute;top:-50px;right:-50px;width:400px;height:400px;border-radius:50%;background:#b8834a14;pointer-events:none}.hero-text{padding:4rem 3rem 4rem 8vw;display:flex;flex-direction:column;gap:2rem;z-index:1}.hero-vertical{writing-mode:vertical-rl;text-orientation:upright;font-size:clamp(2rem,4vw,3.5rem);line-height:1.4;letter-spacing:.3em;color:var(--ink);font-weight:400}.hero-sub{font-size:.9rem;letter-spacing:.2em;color:var(--accent);writing-mode:vertical-rl;text-orientation:mixed}.hero-cta{display:inline-block;background:var(--accent);color:#fff;padding:.9rem 2.5rem;font-size:.85rem;letter-spacing:.15em;border:none;cursor:pointer;transition:background .3s,transform .2s;align-self:flex-start;writing-mode:horizontal-tb}.hero-cta:hover{background:#9a6b38;transform:translateY(-2px)}.hero-illustration{display:flex;align-items:center;justify-content:center;padding:3rem;z-index:1}.hero-illustration svg{width:min(480px,90%);height:auto;filter:drop-shadow(4px 8px 20px rgba(28,26,21,.1))}.concept{max-width:1200px;margin:0 auto;padding:6rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}.concept-heading{font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.8;letter-spacing:.08em;font-weight:400}.concept-heading span{color:var(--accent)}.concept-body{font-size:.95rem;line-height:2;color:#4a4540;letter-spacing:.05em}.concept-body p+p{margin-top:1.2em}.products{background:var(--cream);padding:5rem 2rem}.products-inner{max-width:1200px;margin:0 auto}.section-header{text-align:center;margin-bottom:3rem}.section-label{font-size:.75rem;letter-spacing:.3em;color:var(--accent);text-transform:uppercase;margin-bottom:.5rem}.section-title{font-size:1.8rem;letter-spacing:.1em;font-weight:400}.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}.product-card{background:var(--bg);overflow:hidden;transition:transform .3s,box-shadow .3s}.product-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px #1c1a151f}.product-img{aspect-ratio:3/4;background:var(--cream);display:flex;align-items:center;justify-content:center;overflow:hidden}.product-img svg{width:60%;opacity:.6}.product-info{padding:1.2rem}.product-name{font-size:.9rem;letter-spacing:.08em;margin-bottom:.4rem;font-weight:400}.product-price{font-size:.85rem;color:var(--accent);letter-spacing:.05em}.product-tag{display:inline-block;font-size:.65rem;letter-spacing:.15em;color:#888;border:1px solid #ddd;padding:.15rem .5rem;margin-bottom:.6rem}.news{background:#fff;padding:5rem 2rem}.news-inner{max-width:1200px;margin:0 auto}.news-list{margin-top:2rem;border-top:1px solid var(--cream)}.news-item{display:grid;grid-template-columns:120px 80px 1fr;gap:2rem;align-items:center;padding:1.2rem 0;border-bottom:1px solid var(--cream);font-size:.88rem;letter-spacing:.05em}.news-date{color:#888}.news-cat{color:var(--accent);font-size:.75rem;letter-spacing:.15em}footer{background:var(--dark);color:#ffffffb3;padding:4rem 2rem 2rem}.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}.footer-brand{display:flex;align-items:center;gap:.75rem;font-size:1.1rem;letter-spacing:.12em;color:#fff;margin-bottom:1rem}.footer-brand svg{width:28px;height:28px;opacity:.9}.footer-desc{font-size:.8rem;line-height:1.9;letter-spacing:.05em}.footer-col-title{font-size:.75rem;letter-spacing:.2em;color:#fff6;text-transform:uppercase;margin-bottom:1rem}.footer-links{list-style:none;display:flex;flex-direction:column;gap:.7rem;font-size:.82rem}.footer-links a:hover{color:var(--light-accent)}.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;text-align:center;font-size:.75rem;letter-spacing:.1em;color:#ffffff4d}@media(max-width:900px){.hero{grid-template-columns:1fr;min-height:auto}.hero-illustration{order:-1;padding:3rem 2rem 1rem}.hero-text{padding:2rem;align-items:center;text-align:center}.hero-vertical,.hero-sub{writing-mode:horizontal-tb}.concept{grid-template-columns:1fr;gap:2rem}.products-grid{grid-template-columns:repeat(2,1fr)}.footer-inner{grid-template-columns:1fr 1fr}}@media(max-width:600px){.nav-links{display:none}.products-grid{grid-template-columns:1fr 1fr;gap:1rem}.news-item{grid-template-columns:1fr;gap:.3rem}.footer-inner{grid-template-columns:1fr}}
