/* ========================================
   C JUICE — 可愛らしく大胆な、健康・長寿のシークヮーサーブランド
   ======================================== */

/* ---- Variables（可愛らしい・健康美容・長寿） ---- */
:root {
  --green: #3D7A35;
  --green-light: #5BA04F;
  --green-pale: #8BC67C;
  --green-mint: #B8E0B0;
  --green-dark: #2A5C24;
  --green-deep: #1A3D16;
  --gold: #E5B84A;
  --gold-light: #F0D078;
  --gold-soft: rgba(229,184,74,.18);
  --peach: #F5D5C8;
  --peach-deep: #E8B4A0;
  --cream: #FBF6F0;
  --cream-dark: #F0E8DE;
  --white: #FFFEFC;
  --black: #1A1A1A;
  --text: #2C2C2C;
  --text-sub: #5C5C5C;
  --text-muted: #8C8C8C;
  --border: rgba(0,0,0,.07);
  --font-serif: 'Noto Serif JP','Georgia',serif;
  --font-sans: 'Noto Sans JP','Helvetica Neue',Arial,sans-serif;
  --font-display: 'M PLUS Rounded 1c','Noto Sans JP',sans-serif;
  --font-cute: 'M PLUS Rounded 1c',sans-serif;
  --font-mono: 'Noto Sans JP',sans-serif;
  --radius: 20px;
  --radius-lg: 28px;
  --radius-xl: 40px;
  --radius-full: 9999px;
  --section-py: 160px;
  --max-w: 1280px;
  --px: 36px;
  --ease: cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --shadow-soft: 0 8px 40px rgba(61,122,53,.08);
  --shadow-cute: 0 12px 48px rgba(0,0,0,.06);
}

/* ---- Reset ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--text);background:var(--cream);line-height:1.8;overflow-x:hidden;cursor:none}
body.loading{overflow:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;cursor:none}
button{cursor:none;font-family:inherit}
ul{list-style:none}
::selection{background:var(--gold-soft);color:var(--green-dark)}
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--px)}
.hide-sp{display:inline}

/* ========== CURSOR ========== */
.cursor{pointer-events:none;position:fixed;top:0;left:0;z-index:10000;mix-blend-mode:difference}
.cursor-dot{position:fixed;width:10px;height:10px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease-spring),height .3s var(--ease-spring);z-index:10001}
.cursor-circle{position:fixed;width:44px;height:44px;border:1.5px solid rgba(255,255,255,.5);border-radius:50%;transform:translate(-50%,-50%);transition:width .4s var(--ease-spring),height .4s var(--ease-spring),border-color .3s,background .3s;z-index:10000}
body.cursor-hover .cursor-dot{width:5px;height:5px}
body.cursor-hover .cursor-circle{width:68px;height:68px;border-color:rgba(255,255,255,.8);background:rgba(255,255,255,.04)}

/* ========== LOADER ========== */
.loader{position:fixed;inset:0;z-index:9999;background:linear-gradient(160deg,var(--green-deep),var(--green-dark));display:flex;align-items:center;justify-content:center;transition:opacity .7s var(--ease),visibility .7s}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center}
.loader-logo{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:600;letter-spacing:.28em;color:#fff;margin-bottom:28px}
.loader-logo span{display:inline-block;opacity:0;transform:translateY(100%);animation:charUp .6s var(--ease) forwards}
.loader-logo span:nth-child(1){animation-delay:.1s}
.loader-logo span:nth-child(2){animation-delay:.15s}
.loader-logo span:nth-child(3){animation-delay:.2s}
.loader-logo span:nth-child(4){animation-delay:.25s}
.loader-logo span:nth-child(5){animation-delay:.3s}
.loader-logo span:nth-child(6){animation-delay:.35s}
.loader-logo span:nth-child(7){animation-delay:.4s}
@keyframes charUp{to{opacity:1;transform:translateY(0)}}
.loader-bar{width:200px;height:6px;background:rgba(255,255,255,.12);margin:0 auto 24px;border-radius:var(--radius-full);overflow:hidden}
.loader-bar-fill{width:0;height:100%;background:linear-gradient(90deg,var(--gold-light),var(--green-pale));border-radius:var(--radius-full);animation:barFill 2s cubic-bezier(.65,0,.35,1) .5s forwards}
@keyframes barFill{to{width:100%}}
.loader-tagline{font-family:var(--font-display);font-size:.8rem;letter-spacing:.15em;color:rgba(255,255,255,.4);opacity:0;animation:fadeIn .6s .8s forwards}
@keyframes fadeIn{to{opacity:1}}

/* ========== SECTION UTILITIES ========== */
.section-tag{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:24px;text-align:center;opacity:0;transform:translateY(20px);transition:all .8s var(--ease)}
.section-tag.revealed{opacity:1;transform:translateY(0)}
.section-tag span{color:var(--gold);font-weight:700}
.section-tag--light{color:rgba(255,255,255,.5)}
.section-tag--light span{color:var(--gold-light)}

.display-heading{font-family:var(--font-display);font-size:clamp(1.6rem,3.2vw,2.6rem);font-weight:700;letter-spacing:.03em;line-height:1.6;margin-bottom:48px;text-align:center;word-break:keep-all;overflow-wrap:break-word;opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.display-heading.revealed{opacity:1;transform:translateY(0)}
.display-heading--light{color:#fff}
.display-heading .char{display:inline;opacity:0;transition:opacity .6s var(--ease)}
.display-heading.revealed .char{opacity:1}

.section-lead{font-size:1rem;line-height:2.2;color:var(--text-sub);max-width:600px;margin-left:auto;margin-right:auto;margin-bottom:64px;text-align:center;opacity:0;transform:translateY(20px);transition:all .8s var(--ease)}
.section-lead.revealed{opacity:1;transform:translateY(0)}
.section-lead--light{color:rgba(255,255,255,.6)}

/* Left-align headings inside grid/content columns */
.shikuwasa-teaser-content .display-heading,
.shikuwasa-teaser-content .section-tag,
.shikuwasa-teaser-content .section-lead,
.story-section-text .display-heading,
.story-section-text .section-tag,
.nobiletin-text .display-heading,
.nobiletin-text .section-tag,
.nobiletin-text .section-lead{text-align:left}
.shikuwasa-teaser-content .section-lead,
.story-section-text .section-lead,
.nobiletin-text .section-lead{margin-left:0}

/* Big background text */
.big-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:clamp(5.5rem,16vw,14rem);font-weight:700;letter-spacing:.02em;color:rgba(0,0,0,.04);white-space:nowrap;pointer-events:none;user-select:none;z-index:0}
.big-text--light{color:rgba(255,255,255,.05)}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:18px 44px;font-family:var(--font-display);font-size:.92rem;font-weight:600;letter-spacing:.04em;border-radius:var(--radius-full);border:none;position:relative;overflow:hidden;isolation:isolate;transition:all .4s var(--ease)}
.btn::before{content:'';position:absolute;inset:0;border-radius:inherit;transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease);z-index:-1}
.btn:hover::before{transform:scaleX(1);transform-origin:left}
.btn-text{position:relative;z-index:1}
.btn-arrow{position:relative;z-index:1;display:flex;align-items:center;transition:transform .4s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

.btn-primary{background:var(--green);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary::before{background:var(--green-light)}
.btn-primary:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 48px rgba(61,122,53,.22)}

.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:2px solid rgba(255,255,255,.35)}
.btn-ghost::before{background:rgba(255,255,255,.15)}
.btn-ghost:hover{border-color:var(--gold-light);color:var(--gold-light);transform:translateY(-4px)}

.btn-outline{background:var(--white);color:var(--green);border:2px solid var(--green)}
.btn-outline::before{background:var(--green)}
.btn-outline:hover{color:#fff;transform:translateY(-4px);box-shadow:var(--shadow-soft)}

.btn-block{width:100%;justify-content:center}

/* ========== HEADER ========== */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px 0;transition:all .5s var(--ease)}
.header.scrolled{background:rgba(245,240,230,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:12px 0;box-shadow:0 1px 24px rgba(0,0,0,.06)}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--px);display:flex;align-items:center;justify-content:space-between}

.logo{display:flex;flex-direction:column}
.logo-main{font-family:var(--font-display);font-size:1.45rem;font-weight:700;letter-spacing:.2em;color:#fff;transition:color .5s var(--ease)}
.header.scrolled .logo-main{color:var(--green-dark)}
.logo-sub{font-size:.58rem;letter-spacing:.16em;color:rgba(255,255,255,.45);transition:color .5s var(--ease);margin-top:2px;font-weight:500}
.header.scrolled .logo-sub{color:var(--text-muted)}

/* Sub-page header (always scrolled style) */
.header--sub .logo-main{color:var(--green-dark)}
.header--sub .logo-sub{color:var(--text-muted)}

.nav-list{display:flex;align-items:center;gap:32px}
.nav-link{font-size:.78rem;font-weight:400;letter-spacing:.05em;color:rgba(255,255,255,.65);transition:color .3s;position:relative;padding:4px 0}
.header.scrolled .nav-link{color:var(--text-sub)}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--gold);transition:width .4s var(--ease)}
.nav-link:hover::after{width:100%}
.nav-link:hover{color:#fff}
.header.scrolled .nav-link:hover{color:var(--green)}

/* Active nav link */
.nav-link--active{color:var(--green)!important;font-weight:500}
.nav-link--active::after{width:100%!important;background:var(--gold)!important}

.nav-link--cta{padding:8px 24px;border:1px solid rgba(255,255,255,.2);border-radius:50px}
.nav-link--cta::after{display:none}
.nav-link--cta:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.4)}
.header.scrolled .nav-link--cta{border-color:var(--green);color:var(--green)}
.header.scrolled .nav-link--cta:hover{background:var(--green);color:#fff}

.header-actions{display:flex;align-items:center;gap:12px}
.cart-btn{position:relative;background:none;border:none;color:rgba(255,255,255,.7);padding:8px;transition:color .3s}
.header.scrolled .cart-btn{color:var(--text-sub)}
.cart-btn:hover{color:#fff}
.header.scrolled .cart-btn:hover{color:var(--green)}
.cart-count{position:absolute;top:0;right:0;width:16px;height:16px;border-radius:50%;background:var(--gold);color:var(--green-deep);font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}

.hamburger{display:none;flex-direction:column;gap:6px;background:none;border:none;padding:8px;z-index:1001}
.hamburger span{display:block;width:24px;height:1.5px;background:#fff;transition:all .4s var(--ease);transform-origin:center}
.header.scrolled .hamburger span{background:var(--text)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ========== HERO ========== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-gradient-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,61,24,.82) 0%,rgba(45,90,39,.65) 30%,rgba(61,122,53,.5) 55%,rgba(42,92,36,.7) 80%,rgba(26,61,24,.85) 100%);z-index:1}
.hero-grain{position:absolute;inset:0;z-index:2;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");background-size:256px}

.hero-content{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:920px}

.hero-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:40px;opacity:0;transform:translateY(16px);transition:all .8s var(--ease) .3s}
.hero-badges.revealed{opacity:1;transform:translateY(0)}
.hero-badge{display:inline-block;padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-display);font-size:clamp(.72rem,1vw,.85rem);font-weight:600;letter-spacing:.12em}
.hero-badge--main{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3)}
.hero-badge--sub{background:var(--gold-soft);color:var(--gold-light);border:1px solid rgba(229,184,74,.4)}

.hero-title{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,4.4rem);font-weight:700;line-height:1.35;color:#fff;margin-bottom:40px;letter-spacing:.02em;word-break:keep-all;text-shadow:0 2px 24px rgba(0,0,0,.15)}
.hero-title-row{display:block;overflow:hidden}
.hero-title-row .char{display:inline-block;transform:translateY(115%);transition:transform .9s var(--ease)}
.hero-title-row.revealed .char{transform:translateY(0)}
.hero-title--gold{color:var(--gold-light);font-weight:700}

.hero-lead{font-size:clamp(.9rem,1.3vw,1.05rem);line-height:2.2;color:rgba(255,255,255,.7);margin-bottom:48px;font-weight:500;letter-spacing:.03em;opacity:0;transform:translateY(24px);transition:all 1s var(--ease) .6s}
.hero-lead.revealed{opacity:1;transform:translateY(0)}
.hero-lead strong{color:var(--gold-light);font-weight:700}

.hero-actions{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;opacity:0;transform:translateY(24px);transition:all 1s var(--ease) .8s}
.hero-actions.revealed{opacity:1;transform:translateY(0)}

.hero-persona-nav{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:32px;opacity:0;transform:translateY(16px);transition:all .8s var(--ease) 1s}
.hero-persona-nav.revealed{opacity:1;transform:translateY(0)}
.hero-persona-link{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.08em;color:rgba(255,255,255,.6);text-decoration:none;padding:10px 20px;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-full);transition:all .3s var(--ease)}
.hero-persona-link:hover{color:var(--gold-light);border-color:var(--gold-light);background:rgba(255,255,255,.08);transform:translateY(-2px)}

/* Hero Scroll */
.hero-scroll{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:14px}
.hero-scroll span{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.25em;color:rgba(255,255,255,.3);text-transform:uppercase;writing-mode:vertical-rl}
.hero-scroll-track{width:1px;height:48px;background:rgba(255,255,255,.08);border-radius:1px;overflow:hidden}
.hero-scroll-thumb{width:100%;height:30%;background:var(--gold);border-radius:1px;animation:scrollThumb 2s ease-in-out infinite}
@keyframes scrollThumb{0%{transform:translateY(-100%)}50%{transform:translateY(233%)}100%{transform:translateY(-100%)}}

/* Hero Marquee */
.hero-marquee{position:absolute;bottom:0;left:0;right:0;z-index:3;padding:14px 0;border-top:1px solid rgba(255,255,255,.04);overflow:hidden}
.marquee-track{display:flex;width:max-content;animation:marquee 50s linear infinite}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee-item{font-family:var(--font-display);font-size:.7rem;letter-spacing:.3em;color:rgba(255,255,255,.12);text-transform:uppercase;padding:0 8px}
.marquee-dot{font-size:.3rem;color:rgba(255,255,255,.08);padding:0 12px;display:inline-flex;align-items:center}

/* ========== IMPACT ========== */
.impact{padding:100px 0;background:var(--white);position:relative}
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;text-align:center}
.impact-item{padding:20px;opacity:0;transform:translateY(40px);transition:all .8s var(--ease)}
.impact-item.revealed{opacity:1;transform:translateY(0)}
.impact-number{font-family:var(--font-display);font-size:clamp(3.8rem,7.5vw,6rem);font-weight:700;color:var(--green);line-height:1;letter-spacing:-.02em}
.impact-unit{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--green-pale);margin-left:6px}
.impact-label{margin-top:20px;font-size:.82rem;color:var(--text-muted);line-height:1.9;font-weight:500}

/* ========== PHILOSOPHY ========== */
.philosophy{padding:var(--section-py) 0;background:linear-gradient(180deg,var(--cream) 0%,var(--cream-dark) 100%);position:relative;overflow:hidden}
.philosophy-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.2;pointer-events:none}
.philosophy-blob--1{width:400px;height:400px;background:var(--green-mint);top:-100px;right:-100px}
.philosophy-blob--2{width:300px;height:300px;background:var(--peach);bottom:-80px;left:-80px}
.philosophy-tag{display:inline-block;margin-bottom:16px;padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.1em}
.philosophy-tag--organic{background:var(--gold-soft);color:var(--green-dark);border:1px solid rgba(61,122,53,.2)}
.philosophy-content{max-width:720px;margin:0 auto;text-align:center}
.philosophy-content .display-heading{text-align:center}
.philosophy-body p{margin-bottom:24px;font-size:.95rem;line-height:2.4;color:var(--text-sub);opacity:0;transform:translateY(20px);transition:all .8s var(--ease)}
.philosophy-body p.revealed{opacity:1;transform:translateY(0)}
.philosophy-body strong{color:var(--green);font-weight:700}
.philosophy-cta{margin-top:40px;opacity:0;transform:translateY(20px);transition:all .8s var(--ease)}
.philosophy-cta.revealed{opacity:1;transform:translateY(0)}

/* Photo Frame (shared) */
.photo-frame{position:relative}
.photo-frame-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius-lg);display:block;box-shadow:var(--shadow-cute)}
.photo-frame--rounded .photo-frame-img{border-radius:var(--radius-xl)}
.photo-frame-border{position:absolute;inset:-12px;border:2px solid var(--gold);border-radius:calc(var(--radius-lg) + 8px);opacity:.25;transition:opacity .5s}
.photo-frame--rounded .photo-frame-border{border-radius:calc(var(--radius-xl) + 8px)}
.photo-frame:hover .photo-frame-border{opacity:.5}


/* ========== SHIKUWASA TEASER ========== */
.shikuwasa-teaser{position:relative;padding:var(--section-py) 0;overflow:hidden;min-height:90vh;display:flex;align-items:center}
.shikuwasa-teaser-bg{position:absolute;inset:0}
.shikuwasa-teaser-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.shikuwasa-teaser-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,21,7,.88) 0%,rgba(21,46,12,.8) 40%,rgba(15,29,11,.85) 100%)}
.shikuwasa-teaser-content{position:relative;z-index:1;max-width:800px}
.shikuwasa-highlights{display:flex;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.shikuwasa-highlight-item{display:flex;flex-direction:column;gap:6px;padding:22px 28px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);min-width:160px;transition:all .4s var(--ease)}
.shikuwasa-highlight-item:hover{background:rgba(255,255,255,.14);border-color:var(--gold-light);transform:translateY(-6px) scale(1.02);box-shadow:0 12px 40px rgba(0,0,0,.2)}
.shikuwasa-highlight-num{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:#fff;letter-spacing:.03em}
.shikuwasa-highlight-label{font-size:.74rem;color:rgba(255,255,255,.5);letter-spacing:.04em;font-weight:500}

/* ========== PRODUCTS (EC) ========== */
.products{position:relative;padding:var(--section-py) 0;overflow:hidden}
.products-bg{position:absolute;inset:0;background:linear-gradient(160deg,#1B3B16,#0F1D0B 50%,#0A1507)}

.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;z-index:1}
.product-grid--two{grid-template-columns:repeat(2,1fr)}
.product-card{position:relative}
.product-card-link{position:absolute;inset:0;z-index:1}
.product-detail-link{font-size:.8rem;font-weight:600;color:var(--gold-light);text-decoration:none;letter-spacing:.04em;transition:color .3s;flex-shrink:0}
.product-detail-link:hover{color:var(--gold);text-decoration:underline}
.product-bottom .product-detail-link{margin-right:auto}

.product-card{background:rgba(255,255,255,.06);border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);overflow:hidden;transition:all .5s var(--ease);opacity:0;transform:translateY(40px);display:flex;flex-direction:column}
.product-card.revealed{opacity:1;transform:translateY(0)}
.product-card:hover{transform:translateY(-14px) scale(1.02);border-color:var(--gold-light);box-shadow:0 32px 80px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.1);background:rgba(255,255,255,.1)}

.product-img{aspect-ratio:1/1;overflow:hidden;position:relative;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.product-img-inner{width:100%;height:100%;background:linear-gradient(135deg,rgba(229,184,74,.12),rgba(91,160,79,.2));display:flex;align-items:center;justify-content:center;transition:transform .7s var(--ease);overflow:hidden}
.product-card:hover .product-img-inner{transform:scale(1.06)}
.product-photo{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.product-card:hover .product-photo{transform:scale(1.08)}
.product-badge{position:absolute;top:18px;left:18px;font-family:var(--font-display);font-size:.62rem;font-weight:700;letter-spacing:.12em;color:var(--gold-light);background:rgba(0,0,0,.45);backdrop-filter:blur(10px);padding:8px 16px;border-radius:var(--radius-full)}

.product-persona-tags{position:absolute;bottom:12px;left:12px;right:12px;display:flex;flex-wrap:wrap;gap:6px;list-style:none;margin:0;padding:0}
.product-persona-tag{font-size:.62rem;font-weight:600;letter-spacing:.06em;color:rgba(255,255,255,.95);background:rgba(42,92,36,.9);padding:6px 12px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.2)}

.product-detail{position:relative;z-index:2;padding:28px 28px 32px;flex:1;display:flex;flex-direction:column}
.product-benefits{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0 0 12px;padding:0}
.product-benefits li{font-family:var(--font-display);font-size:.65rem;font-weight:600;letter-spacing:.08em;color:var(--gold-light);background:rgba(229,184,74,.18);padding:6px 12px;border-radius:var(--radius-full)}
.product-benefits--gift li{color:rgba(255,255,255,.9);background:rgba(255,255,255,.12)}
.product-detail h3{font-family:var(--font-display);font-size:1.12rem;font-weight:700;color:#fff;margin-bottom:10px;letter-spacing:.03em}
.product-detail p{font-size:.85rem;line-height:1.95;color:rgba(255,255,255,.55);margin-bottom:auto;padding-bottom:20px}

.product-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.product-bottom .product-detail-link{order:-1;margin-right:auto}
.product-price{font-family:var(--font-display);font-size:1.3rem;font-weight:500;color:#fff;letter-spacing:.02em}
.product-price small{font-size:.7rem;color:rgba(255,255,255,.4);margin-left:2px;font-weight:400}

.add-cart-btn{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:var(--green-deep);border:none;padding:12px 22px;border-radius:var(--radius-full);font-size:.8rem;font-weight:700;font-family:var(--font-display);letter-spacing:.04em;transition:all .3s var(--ease)}
.add-cart-btn:hover{background:var(--gold-light);transform:translateY(-3px);box-shadow:0 8px 24px rgba(229,184,74,.4)}
.add-cart-btn svg{flex-shrink:0}

/* ========== CART DRAWER ========== */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;visibility:hidden;transition:all .4s var(--ease)}
.cart-overlay.active{opacity:1;visibility:visible}

.cart-drawer{position:fixed;top:0;right:-420px;width:400px;max-width:90vw;height:100vh;height:100dvh;background:var(--white);z-index:2001;display:flex;flex-direction:column;transition:right .5s var(--ease);box-shadow:-8px 0 40px rgba(0,0,0,.1)}
.cart-drawer.active{right:0}

.cart-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--border)}
.cart-header h3{font-family:var(--font-serif);font-size:1.1rem;font-weight:500;letter-spacing:.06em}
.cart-close{background:none;border:none;color:var(--text-sub);padding:4px;transition:color .3s}
.cart-close:hover{color:var(--text)}

.cart-body{flex:1;overflow-y:auto;padding:24px 28px}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:16px;text-align:center}
.cart-empty p{font-size:.9rem}

.cart-items{display:flex;flex-direction:column;gap:20px}
.cart-item{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding-bottom:20px;border-bottom:1px solid var(--border)}
.cart-item-img{width:56px;height:56px;background:var(--cream);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--text-muted);text-align:center;font-family:var(--font-serif)}
.cart-item-info h4{font-size:.85rem;font-weight:500;margin-bottom:4px}
.cart-item-info .cart-item-price{font-size:.8rem;color:var(--text-sub)}
.cart-item-actions{display:flex;align-items:center;gap:10px}
.cart-qty-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:none;font-size:.9rem;display:flex;align-items:center;justify-content:center;color:var(--text-sub);transition:all .3s}
.cart-qty-btn:hover{border-color:var(--green);color:var(--green)}
.cart-qty{font-size:.85rem;font-weight:500;min-width:20px;text-align:center}

.cart-footer{padding:24px 28px;border-top:1px solid var(--border);background:var(--white)}
.cart-total{display:flex;justify-content:space-between;margin-bottom:16px;font-size:.9rem}
.cart-total-price{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--green)}
.cart-stripe-note{display:flex;align-items:center;gap:6px;justify-content:center;margin-top:12px;font-size:.7rem;color:var(--text-muted)}

/* ========== VOICES / TESTIMONIALS ========== */
.voices{padding:var(--section-py) 0;background:var(--cream);position:relative;overflow:hidden}
.voices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.voice-card{background:var(--white);border:2px solid var(--border);border-radius:var(--radius-xl);padding:44px 36px;transition:all .5s var(--ease);opacity:0;transform:translateY(30px);box-shadow:var(--shadow-cute)}
.voice-card.revealed{opacity:1;transform:translateY(0)}
.voice-card:hover{transform:translateY(-10px);box-shadow:0 24px 64px rgba(0,0,0,.08);border-color:var(--gold-soft)}
.voice-stars{color:var(--gold);font-size:.9rem;margin-bottom:20px;letter-spacing:3px}
.voice-text{font-size:.92rem;line-height:2.2;color:var(--text-sub);margin-bottom:26px;font-style:italic}
.voice-author{display:flex;align-items:center;gap:14px}
.voice-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.85rem;font-weight:700;letter-spacing:.03em}
.voice-name{display:block;font-size:.88rem;font-weight:600;color:var(--text);font-family:var(--font-display)}
.voice-meta{display:block;font-size:.74rem;color:var(--text-muted);margin-top:2px}

/* ========== WHOLESALE ========== */
.wholesale{padding:100px 0;background:var(--cream)}
.cta-banner{position:relative;border-radius:var(--radius-xl);padding:80px 56px;text-align:center;overflow:hidden;background:linear-gradient(180deg,var(--white),var(--cream));border:2px solid var(--border);opacity:0;transform:translateY(40px);transition:all .8s var(--ease);box-shadow:var(--shadow-cute)}
.cta-banner.revealed{opacity:1;transform:translateY(0)}
.cta-banner:hover{box-shadow:0 20px 80px rgba(61,122,53,.1);transform:translateY(-6px)}
.cta-banner-deco{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:clamp(4rem,10vw,8rem);font-weight:700;color:rgba(0,0,0,.035);white-space:nowrap;pointer-events:none}
.cta-banner h2{font-family:var(--font-display);font-size:clamp(1.3rem,2.8vw,1.7rem);font-weight:700;letter-spacing:.04em;margin-bottom:20px;position:relative}
.cta-banner p{font-size:.95rem;line-height:2.2;color:var(--text-sub);margin-bottom:36px;position:relative}

/* ========== COMPANY ========== */
.company{padding:var(--section-py) 0;background:var(--white);position:relative;overflow:hidden}
.company-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.company-info{opacity:0;transform:translateY(30px);transition:all .8s var(--ease)}
.company-info.revealed{opacity:1;transform:translateY(0)}

.company-table{width:100%;border-collapse:collapse}
.company-table tr{border-bottom:1px solid var(--border);transition:background .3s}
.company-table tr:hover{background:rgba(200,162,78,.03)}
.company-table th,.company-table td{padding:20px 14px;text-align:left;vertical-align:top;font-size:.9rem}
.company-table th{font-family:var(--font-serif);font-weight:500;width:90px;letter-spacing:.05em;color:var(--text)}
.company-table td{color:var(--text-sub);line-height:1.9}
.company-table td a{color:var(--green);position:relative}
.company-table td a::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--green);transition:width .3s var(--ease)}
.company-table td a:hover::after{width:100%}
.company-table small{color:var(--text-muted);font-size:.75rem}

.company-map{opacity:0;transform:translateY(30px);transition:all .8s var(--ease) .15s}
.company-map.revealed{opacity:1;transform:translateY(0)}
.map-wrapper{border-radius:16px;overflow:hidden;box-shadow:0 6px 36px rgba(0,0,0,.07);border:1px solid var(--border)}
.map-wrapper iframe{display:block}
.map-link{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-size:.82rem;color:var(--green);transition:all .3s}
.map-link:hover{color:var(--green-light)}
.map-link:hover svg{transform:translateX(3px)}
.map-link svg{transition:transform .3s var(--ease)}

/* ========== CONTACT FORM ========== */
.contact{position:relative;padding:var(--section-py) 0;overflow:hidden}
.contact-bg{position:absolute;inset:0;background:linear-gradient(160deg,#2D5A27,#1B3B16 50%,#0F1D0B)}

.contact-layout{display:grid;grid-template-columns:1.3fr .7fr;gap:64px;position:relative;z-index:1;align-items:start}

.contact-form{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:48px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:0;transform:translateY(30px);transition:all .8s var(--ease)}
.contact-form.revealed{opacity:1;transform:translateY(0)}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{margin-bottom:24px}
.form-group label{display:block;font-size:.78rem;font-weight:500;letter-spacing:.04em;color:rgba(255,255,255,.65);margin-bottom:8px}
.form-group label em{color:var(--gold);font-style:normal}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px 18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-family:var(--font-sans);font-size:.88rem;transition:all .3s;outline:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.25)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);background:rgba(255,255,255,.09);box-shadow:0 0 0 3px rgba(200,162,78,.1)}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,.4)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;cursor:none}
.form-group select option{background:var(--green-deep);color:#fff}
.form-group textarea{resize:vertical;min-height:120px}
.form-error{display:none;font-size:.72rem;color:#E57373;margin-top:6px}
.form-group.error .form-error{display:block}
.form-group.error input,.form-group.error textarea{border-color:#E57373}

.form-group--check{margin-bottom:28px}
.checkbox-label{display:flex;align-items:center;gap:10px;font-size:.82rem;color:rgba(255,255,255,.6);cursor:none}
.checkbox-label input{display:none}
.checkbox-box{width:18px;height:18px;border:1.5px solid rgba(255,255,255,.2);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .3s}
.checkbox-label input:checked+.checkbox-box{background:var(--gold);border-color:var(--gold)}
.checkbox-label input:checked+.checkbox-box::after{content:'✓';font-size:.7rem;color:var(--green-deep);font-weight:700}
.checkbox-label em{color:var(--gold);font-style:normal}

.form-success{text-align:center;padding:40px;color:rgba(255,255,255,.8)}
.form-success svg{margin:0 auto 16px;color:var(--gold)}
.form-success p{font-size:.9rem;line-height:2}

.contact-aside{opacity:0;transform:translateY(30px);transition:all .8s var(--ease) .15s}
.contact-aside.revealed{opacity:1;transform:translateY(0)}
.contact-info-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:40px 32px;backdrop-filter:blur(12px)}
.contact-info-card h4{font-family:var(--font-serif);font-size:1rem;font-weight:500;color:#fff;margin-bottom:24px;letter-spacing:.06em}
.contact-info-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:rgba(255,255,255,.65);font-size:.9rem}
.contact-info-row svg{flex-shrink:0;color:var(--gold-light)}
.contact-info-row a{color:#fff;transition:color .3s}
.contact-info-row a:hover{color:var(--gold-light)}
.contact-info-note{font-size:.75rem;color:rgba(255,255,255,.35);margin-top:8px}

/* ========== FOOTER ========== */
.footer{background:#080E06;padding:68px 0 32px;color:rgba(255,255,255,.4)}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:32px}
.footer-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:500;color:#fff;letter-spacing:.22em;display:block;margin-bottom:8px}
.footer-tagline{font-size:.7rem;color:rgba(255,255,255,.25);letter-spacing:.12em}
.footer-nav{display:flex;gap:64px}
.footer-col h4{font-family:var(--font-display);font-size:.75rem;font-style:italic;color:var(--gold);margin-bottom:16px;letter-spacing:.12em;opacity:.6}
.footer-col li{margin-bottom:10px}
.footer-col a{font-size:.78rem;color:rgba(255,255,255,.35);transition:color .3s}
.footer-col a:hover{color:rgba(255,255,255,.8)}
.footer-bottom{text-align:center}
.footer-bottom p{font-size:.68rem;color:rgba(255,255,255,.15);letter-spacing:.05em}

/* ========== BACK TO TOP ========== */
.back-to-top{position:fixed;bottom:32px;right:32px;width:50px;height:50px;background:var(--green);color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(20px) scale(.8);transition:all .5s var(--ease);box-shadow:0 4px 24px rgba(45,90,39,.3);z-index:999}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.back-to-top:hover{background:var(--green-light);transform:translateY(-4px) scale(1.05)}
.back-to-top svg{width:20px;height:20px}

/* ========== REVEAL ========== */
[data-reveal]{opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].revealed{opacity:1;transform:translateY(0)}


/* ================================================================
   SUB-PAGE STYLES
   ================================================================ */

/* ========== PAGE HERO (Sub-pages) ========== */
.page-hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-hero-bg{position:absolute;inset:0}
.page-hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,21,7,.82) 0%,rgba(21,46,12,.7) 40%,rgba(15,29,11,.82) 100%)}
.page-hero-content{position:relative;z-index:2;text-align:center;padding:120px 24px 60px;max-width:800px}
.page-hero-tag{font-family:var(--font-display);font-size:clamp(.8rem,1.2vw,.95rem);font-style:italic;color:var(--gold-light);letter-spacing:.3em;margin-bottom:28px;opacity:0;transform:translateY(16px);transition:all .8s var(--ease) .2s}
.page-hero-tag.revealed{opacity:.7;transform:translateY(0)}
.page-hero-title{font-family:var(--font-serif);font-size:clamp(2rem,5vw,3.6rem);font-weight:200;line-height:1.4;color:#fff;margin-bottom:32px;letter-spacing:.04em;word-break:keep-all;overflow-wrap:break-word;opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.page-hero-title.revealed{opacity:1;transform:translateY(0)}
.page-hero-title .char{display:inline;opacity:0;transition:opacity .6s var(--ease)}
.page-hero-title.revealed .char{opacity:1}
.page-hero-lead{font-size:clamp(.82rem,1.1vw,.95rem);line-height:2.4;color:rgba(255,255,255,.5);font-weight:300;letter-spacing:.03em;opacity:0;transform:translateY(20px);transition:all 1s var(--ease) .5s}
.page-hero-lead.revealed{opacity:1;transform:translateY(0)}
.page-hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:14px}
.page-hero-scroll span{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.25em;color:rgba(255,255,255,.3);text-transform:uppercase;writing-mode:vertical-rl}

/* ========== STORY PAGE ========== */
.story-intro{padding:var(--section-py) 0;background:var(--cream)}

/* Story Sections */
.story-section{padding:var(--section-py) 0;background:var(--white);position:relative;overflow:hidden}
.story-section--alt{background:var(--cream)}
.story-section-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.story-section-grid--reverse{direction:rtl}
.story-section-grid--reverse > *{direction:ltr}
.story-section-text p{margin-bottom:24px;font-size:.93rem;line-height:2.4;color:var(--text-sub)}
.story-section-text p.revealed{opacity:1;transform:translateY(0)}
.story-section-text strong{color:var(--green);font-weight:600}
.story-section-num{display:block;font-family:var(--font-display);font-size:4rem;font-weight:300;color:var(--gold);opacity:.15;line-height:1;margin-bottom:20px}
.story-section-num.revealed{opacity:.15}

.story-section-photo{opacity:0;transform:scale(.95);transition:all 1s var(--ease)}
.story-section-photo.revealed{opacity:1;transform:scale(1)}

.story-section-text--centered{max-width:720px;margin:0 auto}
.story-section-text--centered .display-heading{text-align:left}
.story-section-text--centered .section-tag{text-align:left}
.story-section-text--centered p{margin-bottom:24px;font-size:.93rem;line-height:2.4;color:var(--text-sub)}
.story-section-text--centered p.revealed{opacity:1;transform:translateY(0)}
.story-section-text--centered strong{color:var(--green);font-weight:600}
.story-section-text--centered .story-section-num{display:block;font-family:var(--font-display);font-size:4rem;font-weight:300;color:var(--gold);opacity:.15;line-height:1;margin-bottom:20px}
.story-section-text--centered .nobiletin-list{margin-bottom:24px;padding-left:0}

/* Quote Band */
.quote-band{position:relative;padding:120px 0;overflow:hidden}
.quote-band-bg{position:absolute;inset:0}
.quote-band-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.quote-band-overlay{position:absolute;inset:0;background:rgba(15,29,11,.85)}
.quote-band-text{position:relative;z-index:1;text-align:center;max-width:800px;margin:0 auto;opacity:0;transform:translateY(30px);transition:all .8s var(--ease)}
.quote-band-text.revealed{opacity:1;transform:translateY(0)}
.quote-band-text p{font-family:var(--font-serif);font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:300;color:#fff;line-height:2;letter-spacing:.04em;margin-bottom:24px;word-break:keep-all}
.quote-band-text cite{font-family:var(--font-sans);font-size:.82rem;font-style:normal;color:var(--gold-light);letter-spacing:.1em;opacity:.6}

/* Story CTA */
.story-cta{padding:120px 0;background:var(--cream)}
.story-cta-inner{text-align:center;max-width:600px;margin:0 auto;opacity:0;transform:translateY(30px);transition:all .8s var(--ease)}
.story-cta-inner.revealed{opacity:1;transform:translateY(0)}
.story-cta-inner h2{font-family:var(--font-serif);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:400;letter-spacing:.04em;line-height:1.6;margin-bottom:20px;color:var(--text);word-break:keep-all}
.story-cta-inner p{font-size:.92rem;color:var(--text-sub);line-height:2;margin-bottom:40px}
.story-cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ========== SHIKUWASA PAGE ========== */
.shiku-intro{padding:var(--section-py) 0;background:var(--cream)}

/* Nutrients Section */
.nutrients{position:relative;padding:var(--section-py) 0;overflow:hidden}
.nutrients-bg{position:absolute;inset:0;background:linear-gradient(160deg,#1B3B16,#0F1D0B 50%,#0A1507)}
.nutrient-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;position:relative;z-index:1}
.nutrient-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:20px;padding:40px 32px;transition:all .5s var(--ease);opacity:0;transform:translateY(30px)}
.nutrient-card.revealed{opacity:1;transform:translateY(0)}
.nutrient-card:hover{background:rgba(255,255,255,.08);border-color:rgba(200,162,78,.2);transform:translateY(-6px)}
.nutrient-card-icon{width:56px;height:56px;color:var(--gold-light);margin-bottom:24px}
.nutrient-card h3{font-family:var(--font-serif);font-size:1.15rem;font-weight:500;color:#fff;margin-bottom:12px;letter-spacing:.06em}
.nutrient-card-highlight{font-family:var(--font-serif);font-size:.88rem;color:var(--gold-light);margin-bottom:16px}
.nutrient-card-highlight strong{font-weight:600}
.nutrient-card p{font-size:.84rem;line-height:2;color:rgba(255,255,255,.5)}

/* Nobiletin Section */
.nobiletin{padding:var(--section-py) 0;background:var(--white);position:relative;overflow:hidden}
.nobiletin-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.nobiletin-text p{margin-bottom:24px;font-size:.93rem;line-height:2.4;color:var(--text-sub)}
.nobiletin-text p.revealed{opacity:1;transform:translateY(0)}
.nobiletin-text strong{color:var(--green);font-weight:600}
.nobiletin-list{margin-bottom:24px;padding-left:0}
.nobiletin-list li{position:relative;padding-left:24px;margin-bottom:12px;font-size:.9rem;color:var(--text-sub);line-height:2}
.nobiletin-list li::before{content:'';position:absolute;left:0;top:12px;width:8px;height:8px;border-radius:50%;background:var(--gold);opacity:.5}
.nobiletin-list.revealed{opacity:1;transform:translateY(0)}

/* Comparison Chart */
.nobiletin-chart{background:var(--cream);border-radius:20px;padding:40px 36px;opacity:0;transform:translateY(30px);transition:all .8s var(--ease)}
.nobiletin-chart.revealed{opacity:1;transform:translateY(0)}
.nobiletin-chart-title{font-family:var(--font-serif);font-size:1rem;font-weight:500;margin-bottom:32px;letter-spacing:.04em;color:var(--text)}
.comparison-bars{display:flex;flex-direction:column;gap:20px}
.comparison-bar-item{display:grid;grid-template-columns:110px 1fr auto;gap:14px;align-items:center}
.comparison-label{font-size:.78rem;color:var(--text-sub);text-align:right}
.comparison-bar-track{height:24px;background:var(--cream-dark);border-radius:12px;overflow:hidden}
.comparison-bar-fill{height:100%;border-radius:12px;background:var(--green-pale);transition:width 1.5s var(--ease);width:0}
.comparison-bar-fill--hero{background:linear-gradient(90deg,var(--green),var(--gold))}
.comparison-value{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);min-width:90px}
.comparison-note{font-size:.7rem;color:var(--text-muted);margin-top:20px;text-align:center}

/* Enjoy Section */
.enjoy{position:relative;padding:var(--section-py) 0;overflow:hidden}
.enjoy-bg{position:absolute;inset:0}
.enjoy-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.enjoy-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,21,7,.88),rgba(21,46,12,.82) 50%,rgba(10,21,7,.9))}
.enjoy-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;position:relative;z-index:1}
.enjoy-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:36px 28px;transition:all .5s var(--ease);opacity:0;transform:translateY(30px)}
.enjoy-card.revealed{opacity:1;transform:translateY(0)}
.enjoy-card:hover{background:rgba(255,255,255,.09);border-color:rgba(200,162,78,.2);transform:translateY(-6px)}
.enjoy-card-num{display:block;font-family:var(--font-display);font-size:2.5rem;font-weight:300;color:var(--gold);opacity:.2;line-height:1;margin-bottom:16px}
.enjoy-card h3{font-family:var(--font-serif);font-size:1rem;font-weight:500;color:#fff;margin-bottom:12px;letter-spacing:.04em}
.enjoy-card p{font-size:.84rem;line-height:2;color:rgba(255,255,255,.5)}

/* ========== PRODUCT DETAIL PAGE ========== */
.product-page-intro{padding:var(--section-py) 0;background:var(--cream)}
.product-page-grid{display:grid;grid-template-columns:1fr 400px;gap:56px;align-items:start}
.product-page-main{position:sticky;top:120px}
.product-page-photo-wrap{background:var(--white);border-radius:var(--radius-xl);overflow:hidden;border:2px solid var(--border);box-shadow:var(--shadow-cute)}
.product-page-photo{width:100%;height:auto;display:block;aspect-ratio:1}
.product-page-side{display:flex;flex-direction:column;gap:32px}
.product-page-price-block{background:var(--white);border:2px solid var(--border);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-cute)}
.product-page-price{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--green);letter-spacing:.02em}
.product-page-price small{font-size:.85rem;color:var(--text-sub);font-weight:400;margin-left:4px}
.product-page-capacity{font-size:.9rem;color:var(--text-sub);margin:8px 0 20px}
.product-spec{border-top:1px solid var(--border);padding-top:24px}
.product-spec dt{font-size:.75rem;font-weight:700;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px}
.product-spec dd{font-size:.9rem;line-height:1.85;color:var(--text-sub);margin-bottom:20px;padding-left:0}
.product-spec dd:last-child{margin-bottom:0}


/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  :root{--section-py:120px}
  .cursor,.cursor-dot,.cursor-circle{display:none!important}
  body,a,button{cursor:auto}
  .nav-list{gap:20px}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .product-card:last-child{grid-column:1/-1;max-width:420px;margin:0 auto}
  .product-grid--two .product-card:last-child{grid-column:auto;max-width:none;margin:0}
  .philosophy-content{max-width:100%}
  .voices-grid{grid-template-columns:repeat(2,1fr)}
  .voice-card:last-child{grid-column:1/-1;max-width:440px;margin:0 auto}
  .nutrient-cards{grid-template-columns:repeat(2,1fr)}
  .nobiletin-grid{gap:60px}
  .story-section-grid{gap:60px}
  .product-page-grid{grid-template-columns:1fr;gap:40px}
  .product-page-main{position:static}
}

@media(max-width:768px){
  :root{--section-py:90px;--px:20px}
  .hide-sp{display:none}
  .hamburger{display:flex}
  .nav{position:fixed;top:0;right:-100%;width:85%;max-width:380px;height:100vh;height:100dvh;background:rgba(15,29,11,.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:100px 36px;transition:right .5s var(--ease);z-index:1000}
  .nav.active{right:0}
  .nav-list{flex-direction:column;gap:0}
  .nav-link{display:block;padding:16px 0;font-size:1rem;color:rgba(255,255,255,.7)!important;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-link--cta{margin-top:16px;text-align:center;border:1px solid rgba(255,255,255,.2)!important;border-radius:50px;padding:12px 24px}
  .nav-link::after{display:none}
  .hamburger.active span{background:#fff!important}

  .hero-lead br{display:none}
  .hero-actions{flex-direction:column;align-items:center}
  .hero-scroll{bottom:80px}
  .hero-marquee{display:none}

  .impact-grid{grid-template-columns:1fr;gap:28px}
  .photo-frame-img{aspect-ratio:16/10}
  .section-lead br{display:none}
  .display-heading{margin-bottom:36px}

  /* Shikuwasa teaser */
  .shikuwasa-highlights{flex-direction:column;gap:12px}
  .shikuwasa-highlight-item{min-width:auto}

  /* Products */
  .product-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .product-card:last-child{max-width:none}
  .product-grid--two{max-width:none}

  /* Voices */
  .voices-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}
  .voice-card:last-child{grid-column:auto;max-width:none}

  .company-grid{grid-template-columns:1fr;gap:36px}
  .contact-layout{grid-template-columns:1fr;gap:36px}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:32px 24px}

  .cta-banner{padding:48px 24px}
  .footer-top{flex-direction:column;gap:36px}
  .footer-nav{gap:36px;flex-wrap:wrap}

  .big-text{font-size:clamp(3rem,12vw,8rem)}

  /* Story page */
  .story-section-text--centered{max-width:100%}

  /* Shikuwasa page */
  .story-section-text--centered .display-heading{text-align:left}
  .nutrient-cards{grid-template-columns:1fr}
  .nobiletin-grid{grid-template-columns:1fr;gap:40px}
  .enjoy-grid{grid-template-columns:1fr}
  .comparison-bar-item{grid-template-columns:80px 1fr auto}

  .page-hero{min-height:60vh}
  .page-hero-content{padding:100px 20px 40px}

  .story-cta-actions{flex-direction:column;align-items:center}
  .product-page-grid{grid-template-columns:1fr;gap:32px}
  .product-page-price-block{padding:24px}
}

@media(max-width:480px){
  .hero-title{font-size:1.8rem}
  .hero-persona-nav{gap:10px;margin-top:24px}
  .hero-persona-link{font-size:.65rem;padding:6px 10px}
  .product-persona-tags{bottom:8px;left:8px;right:8px;gap:4px}
  .product-persona-tag{font-size:.55rem;padding:3px 8px}
  .product-benefits li{font-size:.55rem;padding:3px 8px}
  .display-heading{font-size:1.4rem}
  .btn{padding:14px 30px;font-size:.82rem}
  .impact-number{font-size:3rem}
  .cta-banner p br{display:none}
  .page-hero-title{font-size:1.6rem}
  .comparison-bar-item{grid-template-columns:70px 1fr;gap:8px}
  .comparison-value{grid-column:2;font-size:.65rem;margin-top:-8px}
}

@media print{
  .header,.hero-scroll,.back-to-top,.hamburger,.cursor,.loader,.tape,.hero-marquee,.cart-drawer,.cart-overlay,.page-hero-scroll{display:none!important}
  .hero,.page-hero{min-height:auto;padding:40px 0}
  body{color:#000;background:#fff;cursor:auto}
}
