@charset "UTF-8";
/* =====================================================
   yoi-tesou.com — Main Stylesheet v2.1
   Typography scale, components, layout
   ===================================================== */

/* =====================================================
   1. CSS VARIABLES
   ===================================================== */
:root{
  /* Colors */
  --black:#0E0E0E;--black-mid:#161616;--black-light:#1E1E1E;--black-card:#242424;
  --white:#FAF7F0;--cream:#F0EAD6;
  --vermillion:#C9362A;--verm-h:#E04235;
  --gold:#C8A84B;--gold-l:#DFC46E;
  --border:rgba(200,168,75,.25);--border-d:rgba(200,168,75,.10);
  --text-main:#FAF7F0;--text-sub:#C8B89A;--text-muted:#8A7A6A;
  /* Typography */
  --f-serif:'Noto Serif JP','Times New Roman',serif;
  --f-sans:'Noto Sans JP','Helvetica Neue',sans-serif;
  /* Effects */
  --ease:.3s ease;
  --shadow:0 4px 24px rgba(0,0,0,.45);
  --glow:0 0 24px rgba(200,168,75,.18);
}

/* =====================================================
   2. RESET & BASE
   ===================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{background:var(--black);color:var(--text-main);font-family:var(--f-serif);font-size:1rem;line-height:1.8;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;transition:var(--ease);}
ul{list-style:none;}
button{font-family:inherit;}

/* =====================================================
   3. TYPOGRAPHY SCALE
   ===================================================== */
h1{font-size:clamp(1.75rem,5vw,3rem);line-height:1.3;letter-spacing:.05em;}
h2{font-size:clamp(1.375rem,3vw,2rem);line-height:1.4;}
h3{font-size:clamp(1.125rem,2.5vw,1.5rem);line-height:1.5;}
h4{font-size:clamp(1rem,2vw,1.25rem);line-height:1.55;}
p{font-size:1rem;line-height:1.9;}

/* Body text variants */
.text-lead{font-size:1.0625rem;color:var(--text-sub);line-height:1.95;}
.text-body{font-size:.9375rem;color:var(--text-sub);line-height:1.9;}
.text-small{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.text-label{font-size:.875rem;color:var(--gold);letter-spacing:.35em;font-family:var(--f-sans);}
.text-muted{color:var(--text-muted);}
.text-gold{color:var(--gold);}
.text-white{color:var(--white);}

/* =====================================================
   4. LAYOUT
   ===================================================== */
.container{max-width:1100px;margin:0 auto;padding:0 24px;}
.container-sm{max-width:760px;margin:0 auto;padding:0 24px;}
.container-md{max-width:900px;margin:0 auto;padding:0 24px;}
.section{padding:80px 0;}
.section-label{font-size:.875rem;color:var(--gold);letter-spacing:.35em;font-family:var(--f-sans);text-align:center;margin-bottom:10px;}
.section-title{text-align:center;margin-bottom:12px;}
.section-title h2{color:var(--white);display:inline-block;padding-bottom:16px;position:relative;}
.section-title h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:48px;height:2px;background:var(--gold);}
.section-sub{text-align:center;color:var(--text-muted);font-size:.9375rem;margin-bottom:52px;font-family:var(--f-sans);line-height:1.7;}
.divider{width:48px;height:1px;background:var(--gold);margin:0 auto 32px;}
.label-tag{font-size:.875rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:16px;padding-left:12px;border-left:2px solid var(--gold);display:block;}
.en-label{font-size:.875rem;color:var(--gold);letter-spacing:.4em;font-family:var(--f-sans);margin-bottom:16px;}

/* =====================================================
   5. BUTTONS
   ===================================================== */
.btn{display:inline-block;padding:14px 36px;border-radius:2px;font-size:1rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.08em;cursor:pointer;transition:var(--ease);border:none;text-align:center;}
.btn-primary{background:var(--vermillion);color:var(--white);}
.btn-primary:hover{background:var(--verm-h);transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,54,42,.4);}
.btn-secondary{background:transparent;color:var(--gold);border:1px solid var(--gold);}
.btn-secondary:hover{background:var(--gold);color:var(--black);transform:translateY(-2px);}
.btn-sm{padding:10px 24px;font-size:.9375rem;}
.btn-star-detail{background:transparent;padding:14px 28px;border-radius:2px;font-size:.9375rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.08em;text-align:center;cursor:pointer;text-decoration:none;transition:var(--ease);display:inline-block;}
.btn-star-detail:hover{opacity:.75;transform:translateY(-2px);}
.btn-buy{background:var(--vermillion);color:var(--white);}
.btn-buy:hover{background:var(--verm-h);}
.btn-detail{background:transparent;border:1px solid var(--gold);color:var(--gold);}
.btn-detail:hover{background:var(--gold);color:var(--black);}
.btn-disabled{background:var(--black-light);color:var(--text-muted);cursor:default;border:1px solid var(--border-d);}

/* =====================================================
   6. HEADER
   ===================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(14,14,14,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);}
/* トップページのみ: JS で .scrolled を付与 */
.site-header.transparent{background:transparent;backdrop-filter:none;border-bottom-color:transparent;}
.site-header.transparent.scrolled,
.site-header.scrolled{background:rgba(14,14,14,.96);backdrop-filter:blur(12px);border-bottom-color:var(--border);}

.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 32px;max-width:1200px;margin:0 auto;}
.site-logo{display:flex;align-items:center;gap:12px;}
.logo-mark{width:40px;height:40px;border-radius:50%;border:1px solid var(--gold);object-fit:cover;flex-shrink:0;}
.logo-text{display:flex;flex-direction:column;line-height:1.25;}
.logo-name{font-size:1.375rem;font-weight:700;color:var(--white);letter-spacing:.15em;}
.logo-en{font-size:.875rem;color:var(--text-muted);letter-spacing:.18em;font-family:var(--f-sans);font-weight:400;}

/* Desktop nav (index.html pattern) */
.desktop-nav{display:flex;align-items:center;}
.desktop-nav a{display:block;padding:8px 12px;font-size:.875rem;color:var(--text-sub);letter-spacing:.04em;font-family:var(--f-sans);white-space:nowrap;}
.desktop-nav a:hover{color:var(--gold);}
/* Simple nav (inner pages pattern) */
.header-nav{display:flex;align-items:center;gap:6px;}
.header-nav a{padding:8px 12px;font-size:.875rem;color:var(--text-sub);font-family:var(--f-sans);}
.header-nav a:hover{color:var(--gold);}

.nav-cta,.nav-cta.desktop-nav a{margin-left:6px;padding:8px 18px !important;background:var(--vermillion);color:var(--white) !important;border-radius:2px;}
.nav-cta:hover{background:var(--verm-h) !important;}
.nav-cart{display:flex;align-items:center;gap:5px;padding:8px 10px;font-size:.875rem;color:var(--text-sub);font-family:var(--f-sans);}
.nav-cart:hover{color:var(--gold);}
.cart-svg{width:20px;height:20px;}
.cart-icon-wrap{position:relative;display:inline-flex;align-items:center;}
.cart-count{position:absolute;top:-7px;right:-9px;background:var(--vermillion);color:var(--white);font-size:10px;font-weight:700;line-height:1;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;font-family:var(--f-sans);}

/* Hamburger / Mobile nav */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:6px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:4px;z-index:1001;}
.hamburger span{display:block;width:100%;height:1.5px;background:var(--white);transition:all .3s ease;transform-origin:center;}
.hamburger.active span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
.mobile-nav{display:none;position:fixed;top:72px;left:0;right:0;bottom:0;background:rgba(10,10,10,.98);backdrop-filter:blur(16px);z-index:999;padding:40px 32px;flex-direction:column;gap:4px;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
.mobile-nav.open{transform:translateX(0);}
.mobile-nav a{display:block;padding:15px 0;font-size:1.125rem;color:var(--text-sub);letter-spacing:.1em;border-bottom:1px solid var(--border-d);transition:var(--ease);}
.mobile-nav a:hover{color:var(--gold);padding-left:8px;}
.mob-cta{margin-top:24px;text-align:center;padding:16px !important;background:var(--vermillion);color:var(--white) !important;border-radius:2px;font-size:1.125rem;letter-spacing:.12em;border:none;}
.mob-cta:hover{background:var(--verm-h);padding-left:0 !important;}

/* =====================================================
   7. PAGE HEADER (inner pages)
   ===================================================== */
.page-header{padding:120px 0 60px;text-align:center;background:radial-gradient(ellipse at 50% 0%,rgba(200,168,75,.07) 0%,transparent 60%),var(--black);}
.page-header h1{color:var(--white);margin-bottom:12px;letter-spacing:.1em;}
.page-header p{color:var(--text-sub);max-width:520px;margin:0 auto;font-size:.9375rem;line-height:1.9;}
.breadcrumb{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-bottom:32px;}
.breadcrumb a{color:var(--text-muted);}
.breadcrumb a:hover{color:var(--gold);}
.breadcrumb span{margin:0 8px;}

/* =====================================================
   8. FOOTER
   ===================================================== */
/* Full footer (index.html) */
.site-footer{background:#080808;border-top:1px solid var(--border);padding:52px 0 28px;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:40px;}
.footer-logo{font-size:1.25rem;color:var(--white);letter-spacing:.2em;margin-bottom:4px;}
.footer-logo-en{font-size:.875rem;color:var(--text-muted);letter-spacing:.18em;font-family:var(--f-sans);margin-bottom:12px;}
.footer-tagline{font-size:.9375rem;color:var(--text-muted);line-height:1.7;margin-bottom:20px;}
.footer-social{display:flex;gap:8px;flex-wrap:wrap;}
.social-btn{padding:6px 14px;border:1px solid var(--border-d);display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.875rem;transition:var(--ease);font-family:var(--f-sans);font-weight:400;white-space:nowrap;}
.social-btn:hover{border-color:var(--gold);color:var(--gold);}
.footer-nav-head{font-size:.875rem;color:var(--gold);letter-spacing:.2em;margin-bottom:16px;font-family:var(--f-sans);}
.footer-nav-list{display:flex;flex-direction:column;gap:10px;}
.footer-nav-list a{font-size:.9375rem;color:var(--text-muted);transition:var(--ease);}
.footer-nav-list a:hover{color:var(--white);padding-left:4px;}
.footer-bottom{border-top:1px solid var(--border-d);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-copy{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.footer-legal{display:flex;gap:20px;}
.footer-legal a{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);transition:var(--ease);}
.footer-legal a:hover{color:var(--white);}
/* Slim footer (inner pages) */
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;}
.footer-nav{display:flex;gap:20px;flex-wrap:wrap;}
.footer-nav a{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.footer-nav a:hover{color:var(--white);}

/* =====================================================
   9. SCROLL / ANIMATION
   ===================================================== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(7px);}}
/* お知らせバナー */
.site-notice{width:100%;padding:12px 16px;font-family:var(--f-sans);font-size:.875rem;position:relative;z-index:1000;}
.site-notice.notice-gold{background:rgba(200,168,75,.15);border-bottom:1px solid var(--gold);color:var(--gold);}
.site-notice.notice-vermillion{background:rgba(201,54,42,.15);border-bottom:1px solid var(--vermillion);color:#e07070;}
.site-notice.notice-dark{background:var(--black-card);border-bottom:1px solid var(--border-d);color:var(--text-sub);}
.notice-inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.notice-text{line-height:1.6;flex:1;}
.notice-close{background:none;border:none;cursor:pointer;font-size:1.125rem;opacity:.6;padding:4px 8px;color:inherit;transition:opacity .2s;}
.notice-close:hover{opacity:1;}
.site-notice.is-hidden{display:none;}

.scroll-top{position:fixed;bottom:28px;right:24px;width:44px;height:44px;background:var(--black-card);border:1px solid var(--border);color:var(--gold);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(16px);transition:opacity .3s ease,transform .3s ease,background .2s ease;z-index:900;font-family:var(--f-sans);font-size:.875rem;text-decoration:none;}
.scroll-top.show{opacity:1;pointer-events:auto;transform:translateY(0);}
.scroll-top:hover{background:var(--gold);color:var(--black);border-color:var(--gold);}

/* =====================================================
   10. INDEX — HERO
   ===================================================== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:72px;}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0;}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,.6) 0%,rgba(10,10,10,.38) 48%,rgba(10,10,10,.82) 100%);}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 68% 28%,rgba(200,168,75,.07) 0%,transparent 55%),radial-gradient(ellipse at 22% 78%,rgba(201,54,42,.05) 0%,transparent 48%),#0A0A0A;z-index:0;}
.hero-inner{position:relative;z-index:1;text-align:center;max-width:820px;padding:60px 24px;}
.hero-badge{display:inline-block;font-size:.875rem;color:var(--gold);letter-spacing:.3em;font-family:var(--f-sans);padding:6px 24px;border:1px solid var(--border);margin-bottom:28px;text-shadow:0 1px 6px rgba(0,0,0,.7);}
.hero-title{color:var(--white);margin-bottom:20px;font-weight:700;text-shadow:0 2px 16px rgba(0,0,0,.8);}
.hero-title .gold{color:var(--gold);}
.hero-concept{font-size:clamp(1.125rem,2.5vw,1.4375rem);color:var(--white);margin-bottom:36px;letter-spacing:.12em;text-shadow:0 1px 10px rgba(0,0,0,.75);}
.hero-desc{font-size:1rem;color:var(--white);margin-bottom:48px;line-height:1.9;max-width:560px;margin-left:auto;margin-right:auto;text-shadow:0 1px 8px rgba(0,0,0,.8);}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:.875rem;letter-spacing:.25em;font-family:var(--f-sans);animation:scrollBounce 2s infinite;}
.hero-scroll::after{content:'';display:block;width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);}

/* =====================================================
   11. INDEX — PILLARS / PROFILE / SIMULATOR
   ===================================================== */
.pillars{background:var(--black-mid);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:52px 0;}
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center;}
.pillar-item{display:flex;flex-direction:column;align-items:center;gap:10px;}
.pillar-num{font-size:2rem;color:var(--gold);font-weight:700;line-height:1;}
.pillar-label{font-size:1rem;color:var(--white);letter-spacing:.1em;}
.pillar-desc{font-size:.875rem;color:var(--text-muted);line-height:1.65;}

.profile{background:var(--black-mid);border-top:1px solid var(--border);}
.profile-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:center;}
.profile-img-wrap{width:100%;aspect-ratio:3/4;background:var(--black-light);border:1px solid var(--border);position:relative;overflow:hidden;}
.profile-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:top;}
.profile-img-wrap::before{content:'';position:absolute;top:-1px;left:-1px;width:48px;height:48px;border-top:2px solid var(--gold);border-left:2px solid var(--gold);z-index:1;}
.profile-img-wrap::after{content:'';position:absolute;bottom:-1px;right:-1px;width:48px;height:48px;border-bottom:2px solid var(--gold);border-right:2px solid var(--gold);z-index:1;}
.profile-label{font-size:.875rem;color:var(--gold);letter-spacing:.3em;font-family:var(--f-sans);margin-bottom:8px;}
.profile-name{font-size:clamp(1.75rem,4vw,2.5rem);color:var(--white);letter-spacing:.2em;margin-bottom:4px;}
.profile-en{font-size:.875rem;color:var(--text-muted);letter-spacing:.18em;font-family:var(--f-sans);margin-bottom:20px;}
.profile-text{color:var(--text-sub);line-height:1.9;margin-bottom:16px;}
.profile-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;}
.ptag{font-size:.875rem;color:var(--gold);border:1px solid var(--border);padding:4px 14px;border-radius:2px;font-family:var(--f-sans);letter-spacing:.05em;}
.profile-stats{display:flex;gap:28px;padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:28px;}
.stat-num{font-size:1.75rem;color:var(--gold);font-weight:700;line-height:1;}
.stat-label{font-size:.875rem;color:var(--text-muted);margin-top:4px;font-family:var(--f-sans);}
.stat-item{text-align:center;padding:16px;background:var(--black-card);border:1px solid var(--border-d);}

.simulator{background:var(--black);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.sim-card{background:var(--black-card);border:1px solid var(--border);padding:48px;position:relative;max-width:820px;margin:0 auto;}
.sim-card::before{content:'';position:absolute;top:-1px;left:48px;right:48px;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.sim-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:16px;align-items:end;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group label{font-size:.875rem;color:var(--text-sub);letter-spacing:.05em;font-family:var(--f-sans);}
.form-group input,.form-group select{background:var(--black-light);border:1px solid var(--border-d);color:var(--white);padding:12px 16px;font-size:1rem;font-family:var(--f-sans);border-radius:2px;transition:border-color var(--ease);-webkit-appearance:none;appearance:none;}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--gold);}
.form-group select option{background:var(--black-light);color:var(--white);}
.sel-wrap{position:relative;}
.sel-wrap::after{content:'▾';position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--gold);pointer-events:none;font-size:.875rem;}
.sim-btn{height:48px;padding:0 28px;background:var(--vermillion);color:var(--white);border:none;border-radius:2px;font-size:.9375rem;font-family:var(--f-sans);font-weight:600;cursor:pointer;transition:var(--ease);white-space:nowrap;letter-spacing:.05em;}
.sim-btn:hover{background:var(--verm-h);}
.sim-result{display:none;margin-top:40px;padding-top:40px;border-top:1px solid var(--border);}
.sim-result.show{display:block;animation:fadeUp .5s ease;}
.result-stars{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;}
.star-card{background:var(--black-light);border:1px solid var(--border-d);padding:18px 12px;text-align:center;}
.star-card.main{border-color:var(--gold);}
.star-type{font-size:.875rem;color:var(--text-muted);letter-spacing:.08em;font-family:var(--f-sans);margin-bottom:8px;}
.star-name{font-size:1rem;color:var(--gold);letter-spacing:.08em;}
.star-elem{font-size:.875rem;color:var(--text-muted);margin-top:4px;font-family:var(--f-sans);}
.result-reading{background:var(--black-light);border-left:2px solid var(--gold);padding:24px 28px;margin-bottom:18px;}
.result-reading h4{color:var(--gold);margin-bottom:12px;font-size:1rem;letter-spacing:.1em;}
.result-reading p{color:var(--text-sub);line-height:1.9;font-size:.9375rem;}
.result-extras{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px;}
.extra-box{background:var(--black-light);border:1px solid var(--border-d);padding:20px;}
.extra-box h5{font-size:.875rem;color:var(--gold);margin-bottom:10px;letter-spacing:.1em;font-family:var(--f-sans);}
.extra-box p{font-size:.9375rem;color:var(--text-sub);line-height:1.7;}
.lucky-colors{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px;}
.color-chip{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--text-sub);font-family:var(--f-sans);}
.color-dot{width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.2);flex-shrink:0;}
.sim-border-warn{font-size:.875rem;color:var(--gold);background:rgba(200,168,75,.08);border:1px solid var(--border);padding:10px 16px;margin-bottom:16px;font-family:var(--f-sans);display:none;}
.result-ctas p{font-size:.9375rem;color:var(--text-muted);margin-bottom:14px;}
.result-ctas .btns{display:flex;gap:14px;flex-wrap:wrap;}

/* =====================================================
   12. INDEX — TESTIMONIALS / SERVICES
   ===================================================== */
.testimonials{background:var(--black-mid);border-top:1px solid var(--border);}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.testi-card{background:var(--black-card);border:1px solid var(--border-d);padding:28px 24px;}
.testi-quote{font-size:2.5rem;color:var(--gold);opacity:.3;line-height:1;margin-bottom:10px;font-family:Georgia,serif;}
.testi-stars{color:var(--gold);font-size:.9375rem;margin-bottom:10px;}
.testi-text{font-size:.9375rem;color:var(--text-sub);line-height:1.85;margin-bottom:20px;}
.testi-meta{display:flex;align-items:center;gap:12px;}
.testi-avatar{width:38px;height:38px;border-radius:50%;background:var(--black-light);border:1px solid var(--border-d);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.875rem;flex-shrink:0;font-family:var(--f-sans);}
.testi-name{font-size:.9375rem;color:var(--white);}
.testi-tag{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-top:2px;}
.coconala-badge{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-bottom:20px;}
.coconala-badge::before{content:'✓';color:var(--gold);}

.services{background:var(--black);border-top:1px solid var(--border);}
.svc-grid-top{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;}
.svc-grid-bottom{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.svc-card{background:var(--black-card);border:1px solid var(--border-d);padding:32px 28px;transition:all var(--ease);position:relative;overflow:hidden;}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform var(--ease);}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--glow);border-color:var(--border);}
.svc-card:hover::before{transform:scaleX(1);}
.svc-card.featured{border-color:var(--gold);}
.svc-card.featured::before{transform:scaleX(1);}
.svc-badge{display:inline-block;font-size:.875rem;padding:3px 10px;background:var(--vermillion);color:var(--white);border-radius:2px;letter-spacing:.04em;font-family:var(--f-sans);margin-bottom:10px;}
.svc-type{font-size:.875rem;color:var(--text-muted);letter-spacing:.15em;font-family:var(--f-sans);margin-bottom:8px;}
.svc-name{font-size:1.25rem;color:var(--white);letter-spacing:.04em;margin-bottom:12px;line-height:1.4;}
.svc-price{font-size:1.5rem;color:var(--gold);font-weight:700;margin-bottom:14px;}
.svc-price span{font-size:.9375rem;font-weight:400;}
.svc-desc{font-size:.9375rem;color:var(--text-sub);line-height:1.75;margin-bottom:22px;}
.svc-link{font-size:.875rem;color:var(--gold);letter-spacing:.04em;font-family:var(--f-sans);display:inline-flex;align-items:center;gap:6px;transition:gap var(--ease);}
.svc-link:hover{gap:10px;}
.svc-link::after{content:'→';}

/* =====================================================
   13. INDEX — 本命星 / 月運 / 手相コラム
   ===================================================== */
.kyusei-personal{background:var(--black-mid);border-top:1px solid var(--border);}
.kp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.kp-card{background:var(--black-card);border:1px solid var(--border-d);padding:24px 20px;text-align:center;transition:var(--ease);position:relative;overflow:hidden;}
.kp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;transform:scaleX(0);transition:transform var(--ease);}
.kp-card:hover{border-color:var(--border);transform:translateY(-4px);box-shadow:var(--glow);}
.kp-card:hover::before{transform:scaleX(1);}
.kp-num{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-bottom:6px;}
.kp-name{font-size:1.125rem;color:var(--white);letter-spacing:.1em;margin-bottom:8px;}
.kp-elem{font-size:.875rem;font-family:var(--f-sans);margin-bottom:12px;}
.kp-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:14px;}
.kp-tag{font-size:.875rem;padding:2px 10px;border-radius:2px;font-family:var(--f-sans);}
.kp-link{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);display:inline-flex;align-items:center;gap:4px;transition:gap var(--ease);}
.kp-link:hover{gap:8px;}
.kp-link::after{content:'→';}

.monthly{background:var(--black);border-top:1px solid var(--border);}
.monthly-articles{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;}
.article-card{background:var(--black-card);border:1px solid var(--border-d);transition:var(--ease);overflow:hidden;}
.article-card:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:var(--glow);}
.article-thumb{aspect-ratio:16/9;background:var(--black-light);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9375rem;position:relative;overflow:hidden;}
.article-thumb::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform var(--ease);}
.article-card:hover .article-thumb::after{transform:scaleX(1);}
.article-body{padding:20px 18px;}
.article-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.article-date{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.article-cat{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);border:1px solid var(--border);padding:2px 10px;border-radius:2px;}
.article-title{font-size:1rem;color:var(--white);line-height:1.55;margin-bottom:10px;}
.article-excerpt{font-size:.9375rem;color:var(--text-sub);line-height:1.7;}
.monthly-stars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:32px;}
.mstar{background:var(--black-card);border:1px solid var(--border-d);padding:12px;text-align:center;transition:var(--ease);}
.mstar:hover{border-color:var(--gold);}
.mstar span{font-size:.9375rem;color:var(--text-sub);transition:var(--ease);}
.mstar:hover span{color:var(--gold);}

.tesou-column{background:var(--black-mid);border-top:1px solid var(--border);}
.tcolumn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;}
.tcolumn-card{background:var(--black-card);border:1px solid var(--border-d);transition:var(--ease);overflow:hidden;}
.tcolumn-card:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:var(--glow);}
.tcolumn-thumb{aspect-ratio:16/9;background:var(--black-light);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9375rem;position:relative;overflow:hidden;}
.tcolumn-thumb::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform var(--ease);}
.tcolumn-card:hover .tcolumn-thumb::after{transform:scaleX(1);}
.tcolumn-body{padding:20px 18px;}
.tcolumn-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.tcolumn-date{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.tcolumn-cat{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);border:1px solid var(--border);padding:2px 10px;border-radius:2px;}
.tcolumn-title{font-size:1rem;color:var(--white);line-height:1.55;margin-bottom:10px;}
.tcolumn-excerpt{font-size:.9375rem;color:var(--text-sub);line-height:1.7;}

/* =====================================================
   14. INDEX — SHOP / CALENDAR / FAQ / CTA / NEWS
   ===================================================== */
.shop-sec{background:var(--black-mid);border-top:1px solid var(--border);}
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.shop-card{background:var(--black-card);border:1px solid var(--border-d);overflow:hidden;transition:var(--ease);}
.shop-card:hover{border-color:var(--border);transform:translateY(-4px);box-shadow:var(--glow);}
.shop-thumb{aspect-ratio:1/1;background:var(--black-light);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9375rem;letter-spacing:.05em;overflow:hidden;position:relative;}
.shop-thumb img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block;}
.shop-thumb span{position:relative;z-index:1;}
.shop-body{padding:16px;}
.shop-cat{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);margin-bottom:6px;}
.shop-name{font-size:.9375rem;color:var(--white);line-height:1.4;margin-bottom:8px;}
.shop-price{font-size:1.125rem;color:var(--gold);font-weight:700;margin-bottom:12px;}
.shop-btn{display:block;text-align:center;padding:9px;background:var(--vermillion);color:var(--white);font-size:.875rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.05em;border-radius:2px;transition:var(--ease);}
.shop-btn:hover{background:var(--verm-h);}

.calendar-sec{background:var(--black);border-top:1px solid var(--border);}
.cal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.cal-card{background:var(--black-card);border:1px solid var(--border-d);padding:32px 28px;text-align:center;transition:var(--ease);position:relative;}
.cal-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--glow);}
.cal-label{font-size:.875rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:8px;}
.cal-title{font-size:1.125rem;color:var(--white);margin-bottom:12px;letter-spacing:.05em;}
.cal-desc{font-size:.9375rem;color:var(--text-sub);line-height:1.75;margin-bottom:20px;}
.cal-price{font-size:1.25rem;color:var(--gold);font-weight:700;margin-bottom:20px;}
.cal-badge-limit{font-size:.875rem;color:var(--vermillion);font-family:var(--f-sans);margin-bottom:8px;}

.faq{background:var(--black-mid);border-top:1px solid var(--border);}
.faq-list{max-width:800px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--border-d);}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:22px 0;cursor:pointer;gap:24px;}
.faq-q h3{font-size:1rem;color:var(--white);letter-spacing:.03em;line-height:1.55;}
.faq-icon{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.125rem;transition:transform var(--ease);}
.faq-item.active .faq-icon{transform:rotate(45deg);}
.faq-a{display:none;padding:0 0 22px;color:var(--text-sub);line-height:1.9;font-size:.9375rem;}
.faq-item.active .faq-a{display:block;animation:fadeIn .3s ease;}

.final-cta{background:var(--black);text-align:center;padding:100px 0;}
.final-cta h2{color:var(--white);margin-bottom:14px;}
.final-cta .cta-lead{color:var(--text-sub);margin-bottom:40px;line-height:1.9;}
.final-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

.news-sec{background:var(--black);border-top:1px solid var(--border-d);}
.news-inner{max-width:800px;margin:0 auto;}
.news-list{display:flex;flex-direction:column;gap:0;}
.news-item{display:flex;align-items:flex-start;gap:20px;padding:16px 0;border-bottom:1px solid var(--border-d);}
.news-item:last-child{border-bottom:none;}
.news-meta{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.news-date{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);white-space:nowrap;}
.news-tag{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);border:1px solid var(--border);padding:2px 10px;border-radius:2px;white-space:nowrap;}
.news-title{font-size:.9375rem;color:var(--text-sub);line-height:1.65;}
.news-title a{color:var(--text-sub);transition:var(--ease);}
.news-title a:hover{color:var(--white);}
.news-more{text-align:right;margin-top:16px;}
.news-more a{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);display:inline-flex;align-items:center;gap:6px;transition:gap var(--ease);}
.news-more a:hover{gap:10px;}
.news-more a::after{content:'→';}

/* =====================================================
   15. ABOUT PAGE
   ===================================================== */
.about-hero{padding:120px 0 80px;background:radial-gradient(ellipse at 70% 0%,rgba(200,168,75,.07) 0%,transparent 55%),var(--black);}
.about-hero-inner{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:center;}
.about-photo-wrap{width:100%;aspect-ratio:3/4;background:var(--black-card);border:1px solid var(--border);position:relative;overflow:hidden;}
.about-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:top;}
.about-photo-wrap::before{content:'';position:absolute;top:-1px;left:-1px;width:48px;height:48px;border-top:2px solid var(--gold);border-left:2px solid var(--gold);z-index:1;}
.about-photo-wrap::after{content:'';position:absolute;bottom:-1px;right:-1px;width:48px;height:48px;border-bottom:2px solid var(--gold);border-right:2px solid var(--gold);z-index:1;}
.about-en{font-size:.875rem;color:var(--gold);letter-spacing:.4em;font-family:var(--f-sans);margin-bottom:12px;}
.about-name{font-size:clamp(2rem,5vw,3rem);color:var(--white);letter-spacing:.2em;line-height:1.2;margin-bottom:6px;}
.about-name-en{font-size:1rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.15em;margin-bottom:28px;}
.about-tagline{font-size:clamp(1rem,2.5vw,1.25rem);color:var(--text-sub);line-height:1.85;margin-bottom:28px;border-left:2px solid var(--gold);padding-left:16px;}
.about-lead{color:var(--text-sub);line-height:1.9;margin-bottom:20px;font-size:.9375rem;}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;}
.atag{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);border:1px solid var(--border-d);padding:4px 14px;letter-spacing:.06em;}

.philosophy{background:var(--black-mid);border-top:1px solid var(--border);}
.philosophy-inner{max-width:800px;margin:0 auto;text-align:center;}
.philosophy-en{font-size:.875rem;color:var(--gold);letter-spacing:.4em;font-family:var(--f-sans);margin-bottom:20px;}
.philosophy-quote{font-size:clamp(1.125rem,2.5vw,1.5rem);color:var(--white);line-height:1.7;margin-bottom:20px;}
.philosophy-desc{color:var(--text-sub);line-height:1.9;font-size:.9375rem;}
.philosophy-keyword{display:inline-block;margin-top:28px;padding:12px 36px;border:1px solid var(--border);font-size:.9375rem;color:var(--gold);letter-spacing:.2em;}

.elements{background:var(--black);border-top:1px solid var(--border);}
.elements-label{font-size:.875rem;color:var(--gold);letter-spacing:.35em;font-family:var(--f-sans);text-align:center;margin-bottom:10px;}
.elements-title{font-size:clamp(1.25rem,2.5vw,1.625rem);color:var(--white);text-align:center;margin-bottom:12px;letter-spacing:.08em;}
.elements-sub{text-align:center;color:var(--text-muted);font-size:.9375rem;font-family:var(--f-sans);margin-bottom:40px;}
.elements-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:860px;margin:0 auto 64px;}
.element-card{background:var(--black-card);border:1px solid var(--border-d);padding:28px 20px;text-align:center;position:relative;overflow:hidden;}
.element-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.element-num{font-size:1.75rem;color:rgba(200,168,75,.2);font-weight:700;font-family:var(--f-sans);margin-bottom:12px;}
.element-name{font-size:1rem;color:var(--white);margin-bottom:10px;letter-spacing:.08em;}
.element-desc{font-size:.875rem;color:var(--text-muted);line-height:1.85;}
.elements-article{max-width:760px;margin:0 auto;}
.elem-block{margin-bottom:52px;padding-bottom:52px;border-bottom:1px solid var(--border-d);}
.elem-block-last{margin-bottom:52px;}
.elem-heading{font-size:1.0625rem;color:var(--gold);margin-bottom:20px;letter-spacing:.04em;line-height:1.65;}
.elem-p{color:var(--text-sub);line-height:2;margin-bottom:16px;font-size:.9375rem;}
.elem-p:last-child{margin-bottom:0;}
.elem-closing{background:var(--black-card);border:1px solid var(--border-d);padding:36px 32px;margin-bottom:52px;position:relative;}
.elem-closing::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.elem-closing-label{font-size:.875rem;color:var(--gold);letter-spacing:.25em;font-family:var(--f-sans);margin-bottom:16px;}
.elem-video{text-align:center;}
.elem-video-label{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.12em;margin-bottom:20px;}
.elem-video-wrap{position:relative;width:100%;padding-top:56.25%;background:var(--black-card);border:1px solid var(--border-d);}
.elem-video-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;}

.values{background:var(--black-mid);border-top:1px solid var(--border);}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.value-card{background:var(--black-card);border:1px solid var(--border-d);padding:28px 24px;position:relative;overflow:hidden;}
.value-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--gold),transparent);}
.value-num{font-size:2rem;color:rgba(200,168,75,.12);font-family:var(--f-sans);font-weight:700;margin-bottom:12px;}
.value-title{font-size:1rem;color:var(--white);margin-bottom:10px;}
.value-desc{font-size:.9375rem;color:var(--text-sub);line-height:1.85;}

.story{background:var(--black-mid);border-top:1px solid var(--border);}
.story-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:60px;}
.story-timeline{display:flex;flex-direction:column;gap:0;}
.timeline-item{display:flex;gap:20px;padding:20px 0;border-bottom:1px solid var(--border-d);}
.timeline-item:last-child{border-bottom:none;}
.timeline-year{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);letter-spacing:.05em;flex-shrink:0;width:60px;margin-top:.2em;}
.timeline-body h4{font-size:.9375rem;color:var(--white);margin-bottom:4px;}
.timeline-body p{font-size:.9375rem;color:var(--text-muted);line-height:1.75;}
.story-section-title{font-size:.875rem;color:var(--gold);letter-spacing:.25em;font-family:var(--f-sans);padding-left:12px;border-left:2px solid var(--gold);margin-bottom:20px;}
.story-p{color:var(--text-sub);line-height:2;margin-bottom:20px;font-size:.9375rem;}

.skills{background:var(--black);border-top:1px solid var(--border-d);}
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.skill-card{background:var(--black-card);border:1px solid var(--border-d);padding:24px;text-align:center;}
.skill-icon{font-size:2rem;color:var(--gold);margin-bottom:12px;}
.skill-name{font-size:.9375rem;color:var(--white);margin-bottom:6px;}
.skill-year{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);}

.mission{background:radial-gradient(ellipse at 50% 50%,rgba(200,168,75,.06) 0%,transparent 65%),var(--black-mid);border-top:1px solid var(--border);text-align:center;}
.mission-inner{max-width:720px;margin:0 auto;}
.mission-en{font-size:.875rem;color:var(--gold);letter-spacing:.4em;font-family:var(--f-sans);margin-bottom:20px;}
.mission-text{font-size:clamp(1.125rem,2.5vw,1.375rem);color:var(--white);line-height:1.8;margin-bottom:20px;}
.mission-sub{color:var(--text-sub);line-height:2;font-size:.9375rem;margin-bottom:36px;}
.btn-cta-large{display:inline-block;padding:16px 48px;background:var(--vermillion);color:var(--white);font-size:1rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.1em;border-radius:2px;transition:var(--ease);}
.btn-cta-large:hover{background:var(--verm-h);transform:translateY(-2px);}

/* =====================================================
   16. KYUSEI PAGES
   ===================================================== */
.star-hero{padding:96px 0 60px;text-align:center;background:radial-gradient(ellipse at 50% 0%,var(--star-bg,rgba(200,168,75,.12)) 0%,transparent 65%),radial-gradient(ellipse at 50% 100%,rgba(200,168,75,.06) 0%,transparent 60%),var(--black);}
.star-hero-num{font-size:.875rem;color:var(--star,var(--gold));letter-spacing:.4em;font-family:var(--f-sans);margin-bottom:20px;}
.star-crown{font-size:.875rem;color:var(--star,var(--gold));letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:12px;background:var(--star-bg,rgba(200,168,75,.12));border:1px solid var(--star-border,rgba(200,168,75,.35));display:inline-block;padding:4px 18px;border-radius:2px;}
.star-hero .star-name{font-size:clamp(2rem,6vw,4rem);color:var(--white);letter-spacing:.2em;margin-bottom:8px;}
.star-ruby{font-size:1rem;color:var(--star,var(--gold));letter-spacing:.3em;font-family:var(--f-sans);margin-bottom:28px;}
.star-tags{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:32px;}
.star-tag{font-size:.875rem;color:var(--star,var(--gold));border:1px solid var(--star-border,rgba(200,168,75,.35));padding:5px 16px;border-radius:2px;font-family:var(--f-sans);}
.star-intro{font-size:1.0625rem;color:var(--text-sub);max-width:620px;margin:0 auto;line-height:1.9;}
.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px;}
.info-box{background:var(--black-card);border:1px solid var(--border-d);padding:20px 16px;text-align:center;}
.info-box .label{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-bottom:8px;}
.info-box .value{font-size:1.125rem;color:var(--star,var(--gold));}
.content-section{padding:60px 0;border-top:1px solid var(--border-d);}
.section-head{margin-bottom:36px;}
.section-head .en{font-size:.875rem;color:var(--star,var(--gold));letter-spacing:.3em;font-family:var(--f-sans);margin-bottom:8px;}
.section-head h2{color:var(--white);}
.section-head p{color:var(--text-sub);margin-top:12px;line-height:1.9;}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;}
.feature-col h3{font-size:1rem;color:var(--star,var(--gold));letter-spacing:.15em;font-family:var(--f-sans);margin-bottom:20px;padding-left:12px;border-left:2px solid var(--star,var(--gold));}
.feature-list{display:flex;flex-direction:column;gap:12px;}
.feature-item{background:var(--black-card);border:1px solid var(--border-d);padding:16px 20px;display:flex;gap:14px;align-items:flex-start;}
.feature-icon{width:28px;height:28px;border-radius:50%;background:var(--star-bg,rgba(200,168,75,.12));border:1px solid var(--star-border,rgba(200,168,75,.35));display:flex;align-items:center;justify-content:center;color:var(--star,var(--gold));font-size:.875rem;flex-shrink:0;margin-top:2px;font-family:var(--f-sans);}
.feature-item p{font-size:.9375rem;color:var(--text-sub);line-height:1.75;}
.feature-item strong{color:var(--white);display:block;margin-bottom:4px;font-size:.9375rem;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.topic-card{background:var(--black-card);border:1px solid var(--border-d);padding:28px 24px;position:relative;overflow:hidden;}
.topic-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--star,var(--gold)),var(--gold-l));}
.topic-card .topic-label{font-size:.875rem;color:var(--star,var(--gold));letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:12px;}
.topic-card h3{font-size:1.125rem;color:var(--white);margin-bottom:14px;}
.topic-card p{font-size:.9375rem;color:var(--text-sub);line-height:1.85;}
.compat-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.compat-card{background:var(--black-card);border:1px solid var(--border-d);padding:24px;}
.compat-card h4{font-size:.875rem;letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:16px;}
.compat-card.good h4{color:var(--gold);}
.compat-card.challenge h4{color:var(--text-muted);}
.compat-stars{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.compat-star{font-size:.875rem;padding:4px 12px;border-radius:2px;font-family:var(--f-sans);}
.compat-card.good .compat-star{background:rgba(200,168,75,.12);color:var(--gold);border:1px solid rgba(200,168,75,.3);}
.compat-card.challenge .compat-star{background:rgba(138,122,106,.1);color:var(--text-muted);border:1px solid var(--border-d);}
.compat-card p{font-size:.9375rem;color:var(--text-sub);line-height:1.75;}
.kaiun-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.kaiun-item{background:var(--black-card);border:1px solid var(--border-d);padding:20px 18px;text-align:center;}
.kaiun-item .ki{font-size:1.5rem;margin-bottom:10px;}
.kaiun-item h4{font-size:.875rem;color:var(--star,var(--gold));font-family:var(--f-sans);letter-spacing:.1em;margin-bottom:8px;}
.kaiun-item p{font-size:.875rem;color:var(--text-sub);line-height:1.65;}
.star-cta{background:var(--black-mid);border-top:1px solid var(--border);padding:72px 0;text-align:center;}
.star-cta h2{color:var(--white);margin-bottom:14px;}
.star-cta p{color:var(--text-sub);margin-bottom:36px;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.9;}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.star-nav{display:flex;justify-content:space-between;padding:32px 0 0;margin-top:32px;border-top:1px solid var(--border-d);}
.star-nav a{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);transition:var(--ease);}
.star-nav a:hover{color:var(--gold);}
.glow-box{border-color:var(--star-border,rgba(200,168,75,.35)) !important;box-shadow:0 0 28px rgba(200,168,75,.1);}

/* =====================================================
   17. SHOP PAGES
   ===================================================== */
.cat-nav{padding:40px 0 0;background:var(--black-mid);border-top:1px solid var(--border);}
.cat-nav-inner{display:flex;gap:12px;flex-wrap:wrap;}
.cat-btn{display:inline-block;padding:8px 22px;font-size:.875rem;font-family:var(--f-sans);letter-spacing:.08em;border:1px solid var(--border);color:var(--text-muted);border-radius:2px;cursor:pointer;transition:var(--ease);}
.cat-btn:hover,.cat-btn.active{border-color:var(--gold);color:var(--gold);}
.cat-btn.active{background:rgba(200,168,75,.06);}
.shop-section{padding:48px 0 100px;background:var(--black-mid);}
.section-head h2{font-size:1rem;color:var(--gold);letter-spacing:.25em;font-family:var(--f-sans);padding-left:12px;border-left:2px solid var(--gold);}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.product-card{background:var(--black-card);border:1px solid var(--border-d);position:relative;transition:border-color var(--ease),transform var(--ease);}
.product-card:hover{border-color:rgba(200,168,75,.4);transform:translateY(-3px);}
.product-badge{position:absolute;top:12px;left:12px;z-index:1;font-size:.8125rem;font-family:var(--f-sans);padding:3px 12px;border-radius:2px;letter-spacing:.06em;}
.badge-popular{background:var(--vermillion);color:var(--white);}
.badge-new{background:rgba(200,168,75,.15);color:var(--gold);border:1px solid var(--border);}
.badge-limited{background:rgba(200,168,75,.08);color:var(--gold-l);border:1px solid rgba(200,168,75,.3);}
.badge-coming{background:rgba(100,100,100,.3);color:var(--text-muted);}
.product-thumb{width:100%;aspect-ratio:4/3;background:var(--black-light);display:flex;align-items:center;justify-content:center;font-size:2rem;color:rgba(200,168,75,.3);border-bottom:1px solid var(--border-d);}
.product-body{padding:20px;}
.product-cat{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.1em;margin-bottom:8px;}
.product-name{font-size:1rem;color:var(--white);line-height:1.55;margin-bottom:10px;}
.product-desc{font-size:.875rem;color:var(--text-sub);line-height:1.75;margin-bottom:16px;}
.product-price{font-size:1.375rem;color:var(--gold);font-weight:700;margin-bottom:16px;font-family:var(--f-sans);}
.product-price small{font-size:.875rem;font-weight:400;color:var(--text-muted);}
.product-btn{display:block;width:100%;padding:12px;text-align:center;font-size:.9375rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.06em;border-radius:2px;cursor:pointer;transition:var(--ease);}
.category-section{margin-bottom:60px;}
.divider-line{height:1px;background:var(--border-d);margin:48px 0;}
/* Single product pages */
.product-page-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:start;}
.product-img-main{background:var(--black-card);border:1px solid var(--border-d);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--gold);opacity:.3;}
.product-img-placeholder{text-align:center;font-size:1.5rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.1em;}
.product-title{font-size:clamp(1.5rem,3.5vw,2rem);color:var(--white);line-height:1.4;margin-bottom:12px;}
.product-short-desc{color:var(--text-sub);line-height:1.9;margin-bottom:24px;font-size:.9375rem;}
.product-price-block{margin-bottom:20px;}
.price-main{font-size:2rem;color:var(--gold);font-weight:700;font-family:var(--f-sans);}
.price-note{font-size:.875rem;color:var(--text-muted);margin-top:4px;font-family:var(--f-sans);}
.includes-list{background:var(--black-card);border:1px solid var(--border-d);padding:24px;margin-bottom:24px;}
.includes-head{font-size:.875rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:12px;}
.includes-item{font-size:.9375rem;color:var(--text-sub);padding:8px 0;border-bottom:1px solid var(--border-d);padding-left:16px;position:relative;}
.includes-item::before{content:'◆';color:var(--gold);font-size:.65rem;position:absolute;left:0;top:12px;}
.includes-item:last-child{border-bottom:none;}
.purchase-block{margin-top:24px;}
.purchase-note{font-size:.875rem;color:var(--text-muted);margin-top:10px;font-family:var(--f-sans);line-height:1.7;}
.status-badge{display:inline-block;font-size:.875rem;padding:4px 14px;background:rgba(200,168,75,.1);color:var(--gold);border:1px solid var(--border);border-radius:2px;font-family:var(--f-sans);margin-bottom:16px;}
.status-badge-coming{display:inline-block;font-size:.875rem;padding:4px 14px;background:rgba(100,100,100,.2);color:var(--text-muted);border:1px solid var(--border-d);border-radius:2px;font-family:var(--f-sans);margin-bottom:16px;}
.notify-block{background:var(--black-card);border:1px solid var(--border-d);padding:28px;margin-top:24px;}
.notify-label{font-size:.875rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:10px;}
.notify-desc{font-size:.9375rem;color:var(--text-sub);line-height:1.85;margin-bottom:16px;}
.btn-notify{display:inline-block;padding:12px 28px;border:1px solid var(--gold);color:var(--gold);font-size:.9375rem;font-family:var(--f-sans);letter-spacing:.06em;transition:var(--ease);}
.btn-notify:hover{background:var(--gold);color:var(--black);}

/* =====================================================
   18. POSTS / ARTICLE PAGES
   ===================================================== */
.cat-tabs{background:var(--black-mid);border-top:1px solid var(--border);border-bottom:1px solid var(--border-d);}
.cat-tabs-inner{display:flex;gap:0;overflow-x:auto;}
.cat-tab{display:block;padding:16px 24px;font-size:.875rem;font-family:var(--f-sans);color:var(--text-muted);letter-spacing:.08em;border-bottom:2px solid transparent;white-space:nowrap;cursor:pointer;transition:var(--ease);}
.cat-tab:hover,.cat-tab.active{color:var(--gold);border-bottom-color:var(--gold);}
.posts-section{padding:60px 0 100px;}
.posts-layout{display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:start;}
.posts-list{display:flex;flex-direction:column;gap:0;}
.post-card{display:flex;gap:24px;padding:28px 0;border-bottom:1px solid var(--border-d);transition:var(--ease);}
.post-card:first-child{padding-top:0;}
.post-card:hover .post-title{color:var(--gold);}
.post-thumb{width:160px;min-width:160px;height:120px;background:var(--black-card);border:1px solid var(--border-d);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:rgba(200,168,75,.2);flex-shrink:0;overflow:hidden;}
.post-thumb img{width:100%;height:100%;object-fit:cover;}
.post-body{flex:1;}
.post-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.post-date{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);}
.post-cat{font-size:.8125rem;color:var(--gold);font-family:var(--f-sans);border:1px solid var(--border);padding:2px 10px;border-radius:2px;}
.post-title{font-size:1rem;color:var(--white);line-height:1.55;margin-bottom:8px;transition:var(--ease);}
.post-excerpt{font-size:.875rem;color:var(--text-muted);line-height:1.75;}
.post-more{font-size:.875rem;color:var(--gold);font-family:var(--f-sans);margin-top:8px;display:inline-flex;align-items:center;gap:4px;}
.post-more::after{content:'→';}
/* Article body */
.article-hero{padding:120px 0 60px;background:radial-gradient(ellipse at 70% 0%,rgba(200,168,75,.06) 0%,transparent 55%),var(--black);}
.article-hero-title{font-size:clamp(1.5rem,4vw,2.25rem);color:var(--white);line-height:1.5;letter-spacing:.05em;margin-bottom:20px;}
.article-lead{font-size:1rem;color:var(--text-sub);line-height:1.9;max-width:720px;border-left:2px solid var(--gold);padding-left:16px;}
.article-body-wrap{padding:60px 0 100px;}
.article-layout{display:grid;grid-template-columns:1fr 280px;gap:60px;align-items:start;}
.article-content h2{font-size:1.25rem;color:var(--white);margin:48px 0 16px;padding-left:14px;border-left:3px solid var(--gold);letter-spacing:.06em;}
.article-content h2:first-child{margin-top:0;}
.article-content h3{font-size:1.0625rem;color:var(--text-sub);margin:32px 0 12px;letter-spacing:.04em;}
.article-content p{color:var(--text-sub);line-height:2;margin-bottom:20px;font-size:.9375rem;}
.article-content ul,.article-content ol{color:var(--text-sub);font-size:.9375rem;line-height:1.9;margin-bottom:20px;padding-left:0;}
.article-content ul li,.article-content ol li{padding:6px 0 6px 20px;position:relative;}
.article-content ul li::before{content:'◆';color:var(--gold);font-size:.65rem;position:absolute;left:0;top:10px;}
.article-content ol{counter-reset:ol-cnt;}
.article-content ol li::before{counter-increment:ol-cnt;content:counter(ol-cnt)'.';color:var(--gold);position:absolute;left:0;}
.article-content strong{color:var(--white);font-weight:700;}
.article-content blockquote{border-left:2px solid var(--gold);padding:16px 20px;background:var(--black-card);margin:28px 0;color:var(--text-sub);font-size:.9375rem;line-height:1.9;}
.article-content .note{background:var(--black-card);border:1px solid var(--border-d);padding:20px 24px;margin:28px 0;font-size:.875rem;color:var(--text-muted);line-height:1.8;}
.cta-block{background:var(--black-card);border:1px solid var(--border-d);padding:32px;margin:48px 0;text-align:center;position:relative;}
.cta-block::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.cta-block p{color:var(--text-sub);margin-bottom:20px;font-size:.9375rem;line-height:1.85;}
.btn-cta{display:inline-block;padding:14px 40px;background:var(--vermillion);color:var(--white);font-size:.9375rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.08em;border-radius:2px;transition:var(--ease);}
.btn-cta:hover{background:var(--verm-h);transform:translateY(-2px);}
/* Sidebar */
.sidebar-block{background:var(--black-card);border:1px solid var(--border-d);padding:24px;margin-bottom:24px;}
.sidebar-title{font-size:.8125rem;color:var(--gold);letter-spacing:.25em;font-family:var(--f-sans);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border-d);}
.sidebar-list li{padding:10px 0;border-bottom:1px solid var(--border-d);font-size:.875rem;}
.sidebar-list li:last-child{border-bottom:none;}
.sidebar-list a{color:var(--text-sub);line-height:1.65;}
.sidebar-list a:hover{color:var(--gold);}
.sidebar-cats{display:flex;flex-wrap:wrap;gap:8px;}
.sidebar-cat{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);border:1px solid var(--border-d);padding:4px 12px;}
.sidebar-cat:hover{border-color:var(--gold);color:var(--gold);}

/* =====================================================
   19. CONTACT / FORM
   ===================================================== */
.contact-form-wrap{max-width:720px;margin:0 auto;}
.form-field{margin-bottom:24px;}
.form-field label{display:block;font-size:.875rem;color:var(--text-sub);font-family:var(--f-sans);margin-bottom:8px;letter-spacing:.04em;}
.form-field input,.form-field select,.form-field textarea{width:100%;background:var(--black-light);border:1px solid var(--border-d);color:var(--white);padding:14px 16px;font-size:1rem;font-family:var(--f-serif);border-radius:2px;transition:border-color var(--ease);}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--gold);}
.form-field textarea{min-height:160px;resize:vertical;line-height:1.8;}
.privacy-check{display:flex;align-items:flex-start;gap:12px;font-size:.875rem;color:var(--text-sub);}
.privacy-check input{width:18px;height:18px;margin-top:2px;flex-shrink:0;accent-color:var(--gold);}
.submit-btn{display:block;width:100%;padding:16px;background:var(--vermillion);color:var(--white);font-size:1rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.1em;border:none;border-radius:2px;cursor:pointer;transition:var(--ease);}
.submit-btn:hover{background:var(--verm-h);}

/* =====================================================
   20. MISSING COMPONENTS
   — page-hero / product detail / tabs / contact / send-photo / sidebar widgets
   ===================================================== */

/* ---- page-hero (breadcrumb-only header, shop + send-photo) ---- */
.page-hero{padding:88px 0 0;background:radial-gradient(ellipse at 50% 0%,rgba(200,168,75,.07) 0%,transparent 60%),var(--black);}
.page-hero .breadcrumb{padding:20px 0 28px;}
.page-title{font-size:clamp(1.5rem,4vw,2.25rem);color:var(--white);letter-spacing:.1em;margin-bottom:12px;}
.page-lead{font-size:1rem;color:var(--text-sub);line-height:1.9;max-width:560px;}

/* ---- Product detail page ---- */
.product-main{padding:0 0 80px;}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.product-cat-label{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.15em;margin-bottom:8px;}
.product-sku{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-bottom:12px;}
.product-rating{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-family:var(--f-sans);}
.stars{color:var(--gold);letter-spacing:.08em;}
.rating-count{font-size:.875rem;color:var(--text-muted);}
.product-img-main{width:100%;aspect-ratio:1;background:var(--black-card);border:1px solid var(--border-d);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.product-img-main::before{content:'';position:absolute;top:-1px;left:-1px;width:40px;height:40px;border-top:2px solid var(--gold);border-left:2px solid var(--gold);z-index:1;}
.product-img-main::after{content:'';position:absolute;bottom:-1px;right:-1px;width:40px;height:40px;border-bottom:2px solid var(--gold);border-right:2px solid var(--gold);z-index:1;}
/* アイキャッチ画像がコンテナを正しく埋めるように */
.product-img-main img,.product-img-thumb{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;}
/* ショップ一覧カードのアイキャッチ */
.product-thumb-wrap{width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--black-light);border-bottom:1px solid var(--border-d);position:relative;}
.product-thumb-wrap .product-card-img{width:100%;height:100%;object-fit:cover;display:block;}
.product-thumb-wrap .product-thumb{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;color:rgba(200,168,75,.3);}
.btn-contact{display:block;width:100%;padding:12px;text-align:center;border:1px solid var(--border);color:var(--text-sub);font-size:.9375rem;font-family:var(--f-sans);letter-spacing:.05em;border-radius:2px;transition:var(--ease);margin-top:10px;}
.btn-contact:hover{border-color:var(--gold);color:var(--gold);}

/* ---- Product tabs ---- */
.product-tabs{background:var(--black-mid);border-top:1px solid var(--border);padding:60px 0;}
.tab-nav{display:flex;gap:0;border-bottom:1px solid var(--border-d);margin-bottom:40px;overflow-x:auto;}
.tab-btn{padding:14px 24px;font-size:.9375rem;font-family:var(--f-sans);color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:var(--ease);letter-spacing:.04em;white-space:nowrap;}
.tab-btn:hover,.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold);}
.tab-content{display:none;}
.tab-content.active{display:block;animation:fadeUp .3s ease;}
.tab-content h3{font-size:1rem;color:var(--white);margin:28px 0 12px;padding-left:12px;border-left:2px solid var(--gold);letter-spacing:.04em;}
.tab-content h3:first-child{margin-top:0;}
.tab-content p{color:var(--text-sub);line-height:1.9;font-size:.9375rem;margin-bottom:16px;}
.tab-content ul{color:var(--text-sub);font-size:.9375rem;line-height:1.9;margin-bottom:16px;padding-left:0;}
.tab-content ul li{padding:6px 0 6px 20px;position:relative;}
.tab-content ul li::before{content:'◆';color:var(--gold);font-size:.65rem;position:absolute;left:0;top:10px;}
/* Flow steps (inside tabs) */
.flow-steps{display:flex;flex-direction:column;gap:0;}
.flow-step{display:flex;gap:24px;padding:24px 0;border-bottom:1px solid var(--border-d);align-items:flex-start;}
.flow-step:last-child{border-bottom:none;}
.step-num{width:44px;height:44px;border-radius:50%;background:var(--gold);color:var(--black);display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:700;font-family:var(--f-sans);flex-shrink:0;}
.step-body{flex:1;}
.step-body h4{color:var(--white);margin-bottom:8px;font-size:1rem;}
.step-body p{color:var(--text-sub);font-size:.9375rem;line-height:1.75;}

/* ---- Contact page ---- */
.contact-section{padding:60px 0 100px;background:var(--black);}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start;}
.cinfo-block{margin-bottom:36px;}
.cinfo-label{font-size:.875rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border-d);}
.cinfo-items{display:flex;flex-direction:column;gap:0;}
.cinfo-item{padding:14px 0;border-bottom:1px solid var(--border-d);}
.cinfo-item:last-child{border-bottom:none;}
.cinfo-item-label{font-size:.875rem;color:var(--white);margin-bottom:4px;}
.cinfo-item-val{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.cinfo-note{background:var(--black-card);border:1px solid var(--border-d);padding:24px;font-size:.9375rem;color:var(--text-sub);line-height:1.8;margin-top:8px;}
.cinfo-note strong{color:var(--white);display:block;margin-bottom:10px;}
.form-title{font-size:.9375rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border-d);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.req{font-size:.75rem;color:var(--vermillion);font-family:var(--f-sans);margin-left:8px;padding:2px 8px;border:1px solid rgba(201,54,42,.4);border-radius:2px;}

/* ---- send-photo page ---- */
.info-strip{background:var(--black-mid);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 0;}
.info-list{display:flex;gap:32px;flex-wrap:wrap;}
.info-item{font-size:.875rem;color:var(--text-sub);font-family:var(--f-sans);padding-left:14px;border-left:2px solid var(--gold);}
.form-section{padding:60px 0 100px;}
.form-card{background:var(--black-card);border:1px solid var(--border-d);padding:40px;max-width:720px;margin:0 auto;position:relative;}
.form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.form-desc{color:var(--text-sub);line-height:1.9;margin-bottom:28px;font-size:.9375rem;}
.file-upload-area{border:2px dashed var(--border);padding:48px 24px;text-align:center;border-radius:4px;transition:border-color var(--ease);cursor:pointer;}
.file-upload-area:hover{border-color:var(--gold);}
.upload-icon{font-size:2.5rem;color:var(--gold);opacity:.4;margin-bottom:12px;}
.upload-label{font-size:.9375rem;color:var(--text-sub);margin-bottom:8px;}
.upload-note{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);}
.upload-preview{margin-top:16px;display:flex;gap:8px;flex-wrap:wrap;}
.upload-preview-thumb{position:relative;width:80px;height:80px;border-radius:4px;overflow:hidden;border:1px solid var(--border-d);}
.upload-preview-thumb img{width:100%;height:100%;object-fit:cover;}
.upload-preview-thumb .thumb-remove{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.7);color:var(--white);border:none;border-radius:50%;width:20px;height:20px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;}
.upload-preview-active{border-color:var(--gold);background:rgba(200,168,75,.05);}
.file-note{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);margin-top:8px;}
.form-field-label{display:block;font-size:.875rem;color:var(--text-sub);font-family:var(--f-sans);margin-bottom:8px;letter-spacing:.04em;}
.opt{margin-left:8px;font-size:.75rem;color:var(--text-muted);border:1px solid var(--border-d);padding:1px 6px;border-radius:2px;font-family:var(--f-sans);}
.form-note{font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);line-height:1.75;margin-top:24px;padding:16px;background:var(--black-light);border:1px solid var(--border-d);}
.form-sent{display:none;text-align:center;padding:60px 0;}
.form-sent.show{display:block;}
.sent-mark{font-size:3rem;color:var(--gold);margin-bottom:20px;}
.sent-title{font-size:1.25rem;color:var(--white);margin-bottom:12px;}
.sent-text{color:var(--text-sub);line-height:1.9;margin-bottom:28px;}
.sent-link{color:var(--gold);font-family:var(--f-sans);}
.photo-guide{background:var(--black-mid);border-top:1px solid var(--border);padding:60px 0;}
.photo-guide-title{font-size:.875rem;color:var(--gold);letter-spacing:.2em;font-family:var(--f-sans);margin-bottom:20px;}
.photo-guide-list{display:flex;flex-direction:column;gap:12px;}

/* ---- Posts / sidebar widgets ---- */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:40px;flex-wrap:wrap;}
.page-num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border-d);color:var(--text-muted);font-family:var(--f-sans);font-size:.875rem;transition:var(--ease);}
.page-num:hover,.page-num.active{border-color:var(--gold);color:var(--gold);}
.sidebar-widget{margin-bottom:24px;}
.widget-title{font-size:.8125rem;color:var(--gold);letter-spacing:.25em;font-family:var(--f-sans);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border-d);}
.sidebar-cat-count{font-size:.75rem;color:var(--text-muted);font-family:var(--f-sans);margin-left:6px;}
.recent-posts{display:flex;flex-direction:column;gap:0;}
.recent-post{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-d);}
.recent-post:last-child{border-bottom:none;}
.recent-thumb{width:60px;height:60px;background:var(--black-light);border:1px solid var(--border-d);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.75rem;overflow:hidden;}
.recent-thumb img{width:100%;height:100%;object-fit:cover;}
.recent-body{flex:1;}
.recent-title{font-size:.875rem;color:var(--text-sub);line-height:1.55;margin-bottom:4px;}
.recent-title a:hover{color:var(--gold);}
.recent-date{font-size:.75rem;color:var(--text-muted);font-family:var(--f-sans);}
.cta-widget{background:var(--black-card);border:1px solid var(--border);padding:24px;text-align:center;}
.cta-widget-title{font-size:.875rem;color:var(--gold);letter-spacing:.15em;font-family:var(--f-sans);margin-bottom:10px;}
.cta-widget-desc{font-size:.9375rem;color:var(--text-sub);line-height:1.8;margin-bottom:20px;}
.btn-widget{display:block;width:100%;padding:12px;text-align:center;background:var(--vermillion);color:var(--white);font-size:.875rem;font-family:var(--f-sans);font-weight:600;border-radius:2px;transition:var(--ease);}
.btn-widget:hover{background:var(--verm-h);}

/* ---- Related products section ---- */
.related-section{background:var(--black-mid);border-top:1px solid var(--border);padding:60px 0;}
.related-head{margin-bottom:32px;}
.related-head h2{font-size:.875rem;color:var(--gold);letter-spacing:.3em;font-family:var(--f-sans);padding-left:12px;border-left:2px solid var(--gold);}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.related-card{background:var(--black-card);border:1px solid var(--border-d);padding:24px;transition:var(--ease);}
.related-card:hover{border-color:var(--gold);transform:translateY(-3px);}
.related-cat{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.1em;margin-bottom:8px;}
.related-name{font-size:.9375rem;color:var(--white);line-height:1.5;margin-bottom:12px;}
.related-price{font-size:1.125rem;color:var(--gold);font-weight:700;font-family:var(--f-sans);margin-bottom:16px;}
.related-btn{display:block;text-align:center;padding:10px;background:transparent;border:1px solid var(--border);color:var(--text-sub);font-size:.875rem;font-family:var(--f-sans);border-radius:2px;transition:var(--ease);}
.related-btn:hover{border-color:var(--gold);color:var(--gold);}

/* ---- FAQ mini (contact page) ---- */
.faq-mini{background:var(--black-mid);border-top:1px solid var(--border);padding:60px 0;}
.faq-mini-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:0;}
.faq-mini-item{border-bottom:1px solid var(--border-d);padding:18px 0;}
.faq-mini-item:last-child{border-bottom:none;}
.faq-mini-q{font-size:.9375rem;color:var(--white);margin-bottom:8px;padding-left:18px;position:relative;}
.faq-mini-q::before{content:'Q';position:absolute;left:0;color:var(--gold);font-family:var(--f-sans);font-weight:700;font-size:.875rem;}
.faq-mini-a{font-size:.9375rem;color:var(--text-sub);line-height:1.85;padding-left:18px;position:relative;}
.faq-mini-a::before{content:'A';position:absolute;left:0;color:var(--text-muted);font-family:var(--f-sans);font-size:.875rem;}

/* ---- Kyusei utility ---- */
.star-hero-inner{max-width:820px;margin:0 auto;}
.hide-sp{/* hidden on sp via media query */}

/* =====================================================
   21. RESPONSIVE
   ===================================================== */
@media(max-width:1024px){
  .header-inner{padding:0 20px;}
  .desktop-nav{display:none;}
  .hamburger{display:flex;}
  .mobile-nav{display:flex;}
  .product-layout{grid-template-columns:1fr;gap:40px;}
  .contact-grid{grid-template-columns:1fr;gap:40px;}
  .form-row{grid-template-columns:1fr;}
  .about-hero-inner{grid-template-columns:1fr;gap:40px;}
  .about-photo-wrap{max-width:300px;margin:0 auto;}
  .profile-grid{grid-template-columns:1fr;gap:40px;}
  .profile-img-wrap{max-width:300px;margin:0 auto;}
  .pillars-grid{grid-template-columns:repeat(2,1fr);}
  .svc-grid-top,.svc-grid-bottom{grid-template-columns:1fr;}
  .monthly-articles,.tcolumn-grid{grid-template-columns:1fr 1fr;}
  .shop-grid{grid-template-columns:repeat(2,1fr);}
  .cal-grid{grid-template-columns:1fr 1fr;}
  .kp-grid{grid-template-columns:repeat(3,1fr);}
  .values-grid{grid-template-columns:1fr 1fr;}
  .skills-grid{grid-template-columns:1fr 1fr;}
  .story-grid{grid-template-columns:1fr;}
  .elements-grid{grid-template-columns:1fr 1fr;}
  .feature-grid{grid-template-columns:1fr;}
  .two-col,.compat-grid{grid-template-columns:1fr;}
  .product-grid{grid-template-columns:repeat(2,1fr);}
  .product-page-grid{grid-template-columns:1fr;}
  .posts-layout{grid-template-columns:1fr;}
  .article-layout{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .contact-cta-grid{grid-template-columns:1fr !important;gap:40px !important;}
  .section{padding:60px 0;}
  .header-nav{display:none;}
  .hide-sp{display:none;}
  .info-list{flex-direction:column;gap:16px;}
  .tab-btn{padding:12px 16px;font-size:.875rem;}
  .sim-form{grid-template-columns:1fr 1fr;}
  .sim-form .sim-btn{grid-column:1/-1;width:100%;height:52px;}
  .result-stars{grid-template-columns:repeat(2,1fr);}
  .result-extras{grid-template-columns:1fr;}
  .pillars-grid{grid-template-columns:1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .monthly-articles,.tcolumn-grid{grid-template-columns:1fr;}
  .shop-grid{grid-template-columns:1fr 1fr;}
  .cal-grid{grid-template-columns:1fr;}
  .kp-grid{grid-template-columns:repeat(3,1fr);}
  .values-grid{grid-template-columns:1fr;}
  .skills-grid{grid-template-columns:1fr 1fr;}
  .elements-grid{grid-template-columns:1fr;}
  .info-grid{grid-template-columns:repeat(2,1fr);}
  .kaiun-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .sim-card{padding:28px 20px;}
  .news-item{flex-wrap:wrap;}
  .news-meta{flex-wrap:wrap;}
  .about-stats{grid-template-columns:repeat(3,1fr);gap:12px;}
  .sidebar{display:none;}
  .elem-closing{padding:28px 20px;}
}
@media(max-width:480px){
  .kp-grid{grid-template-columns:repeat(3,1fr);}
  .shop-grid{grid-template-columns:1fr;}
  .kaiun-grid{grid-template-columns:1fr;}
  .about-stats{gap:8px;}
  .skills-grid{grid-template-columns:1fr 1fr;}
}

/* =====================================================
   22. LP FEATURE SECTION
   ===================================================== */
.lp-feature{background:var(--black);border-top:1px solid var(--border);position:relative;}
.lp-feature-hook{background:var(--vermillion);padding:13px 0;text-align:center;}
.lp-feature-hook p{font-size:.9375rem;color:rgba(255,255,255,.92);letter-spacing:.2em;font-family:var(--f-sans);}
.lp-feature-body{padding:72px 0 80px;}
.lp-feature-label{text-align:center;font-size:.8125rem;color:var(--gold);letter-spacing:.5em;font-family:var(--f-sans);margin-bottom:20px;}
.lp-feature-lead{text-align:center;font-size:clamp(1.25rem,2.8vw,1.75rem);color:var(--white);letter-spacing:.06em;line-height:1.55;margin-bottom:12px;}
.lp-feature-sub{text-align:center;font-size:.9375rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.12em;margin-bottom:52px;}
.lp-cards{display:grid;grid-template-columns:1fr 60px 1fr;align-items:stretch;}
.lp-card{background:var(--black-card);border:1px solid var(--border-d);padding:40px 36px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:border-color .4s ease,box-shadow .4s ease;}
.lp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;transition:opacity .4s ease;}
.lp-card-honkaku{border-right:none;}
.lp-card-honkaku::before{background:linear-gradient(90deg,transparent,var(--vermillion),transparent);opacity:.5;}
.lp-card-honkaku:hover{border-color:rgba(201,54,42,.45);box-shadow:0 0 48px rgba(201,54,42,.1);}
.lp-card-honkaku:hover::before{opacity:1;}
.lp-card-business::before{background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.5;}
.lp-card-business:hover{border-color:var(--border);box-shadow:0 0 48px rgba(200,168,75,.1);}
.lp-card-business:hover::before{opacity:1;}
.lp-card-badge{display:inline-block;font-size:.75rem;letter-spacing:.12em;font-family:var(--f-sans);padding:3px 12px;border-radius:2px;margin-bottom:20px;align-self:flex-start;}
.lp-badge-red{color:var(--vermillion);border:1px solid rgba(201,54,42,.4);}
.lp-badge-gold{color:var(--gold);border:1px solid var(--border);}
.lp-card-type{font-size:.8125rem;color:var(--text-muted);letter-spacing:.3em;font-family:var(--f-sans);margin-bottom:8px;}
.lp-card-name{font-size:clamp(1.25rem,2.5vw,1.625rem);color:var(--white);line-height:1.45;letter-spacing:.04em;margin-bottom:20px;}
.lp-card-price{font-size:2.5rem;font-weight:700;font-family:var(--f-sans);line-height:1;margin-bottom:8px;}
.lp-price-red{color:var(--vermillion);}
.lp-price-gold{color:var(--gold);}
.lp-card-price span{font-size:.875rem;font-weight:400;color:var(--text-muted);margin-left:4px;}
.lp-card-tagline{font-size:.9375rem;color:var(--text-muted);font-family:var(--f-sans);margin-bottom:28px;}
.lp-hooks{display:flex;flex-direction:column;gap:10px;margin-bottom:36px;flex:1;}
.lp-hook{font-size:.9375rem;color:var(--text-sub);padding-left:18px;position:relative;line-height:1.7;}
.lp-hook::before{content:'◆';position:absolute;left:0;top:.35em;color:var(--gold);font-size:.55rem;}
.lp-cta-btn{display:block;padding:15px;text-align:center;font-size:.9375rem;font-family:var(--f-sans);font-weight:600;letter-spacing:.06em;border-radius:2px;transition:all .3s ease;margin-top:auto;}
.lp-cta-red{background:var(--vermillion);color:var(--white);}
.lp-cta-red:hover{background:var(--verm-h);transform:translateY(-2px);box-shadow:0 6px 24px rgba(201,54,42,.35);}
.lp-cta-gold{background:transparent;color:var(--gold);border:1px solid var(--gold);}
.lp-cta-gold:hover{background:var(--gold);color:var(--black);transform:translateY(-2px);}
.lp-or{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;}
.lp-or::before{content:'';position:absolute;top:0;bottom:0;left:50%;width:1px;background:var(--border-d);}
.lp-or span{background:var(--black);color:var(--text-muted);font-size:.75rem;font-family:var(--f-sans);letter-spacing:.1em;padding:8px 0;position:relative;z-index:1;}
@media(max-width:768px){
  .lp-cards{grid-template-columns:1fr;}
  .lp-card-honkaku{border-right:1px solid var(--border-d);border-bottom:none;}
  .lp-or{flex-direction:row;padding:20px 0;}
  .lp-or::before{top:50%;bottom:auto;left:0;right:0;width:100%;height:1px;}
  .lp-card-price{font-size:2rem;}
}

/* =====================================================
   23. AUTHOR BOX
   ===================================================== */
.author-box{background:var(--black-card);border:1px solid var(--border-d);padding:32px;margin:56px 0 0;position:relative;}
.author-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.author-box-inner{display:flex;gap:24px;align-items:flex-start;}
.author-thumb{width:72px;height:72px;border-radius:50%;border:1px solid var(--border);object-fit:cover;flex-shrink:0;}
.author-info{flex:1;}
.author-label{font-size:.8125rem;color:var(--text-muted);font-family:var(--f-sans);letter-spacing:.15em;margin-bottom:6px;}
.author-name{font-size:1.0625rem;color:var(--white);letter-spacing:.1em;margin-bottom:10px;}
.author-bio{font-size:.875rem;color:var(--text-sub);line-height:1.8;margin-bottom:18px;}
.author-lp-links{display:flex;flex-direction:column;gap:8px;}
.author-lp-btn{display:block;padding:10px 16px;font-size:.875rem;font-family:var(--f-sans);border-radius:2px;text-align:center;transition:var(--ease);}
.author-lp-main{background:var(--vermillion);color:var(--white);}
.author-lp-main:hover{background:var(--verm-h);}
.author-lp-sub{border:1px solid var(--border-d);color:var(--text-muted);}
.author-lp-sub:hover{border-color:var(--gold);color:var(--gold);}
@media(max-width:600px){
  .author-box-inner{flex-direction:column;}
  .author-thumb{width:56px;height:56px;}
}

/* =====================================================
   24. SNS SHARE BOX
   ===================================================== */
.share-box{background:var(--black-card);border:1px solid var(--border-d);padding:24px 28px;margin:48px 0 0;position:relative;}
.share-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.share-box-label{font-size:.75rem;color:var(--gold);letter-spacing:.3em;font-family:var(--f-sans);margin-bottom:6px;}
.share-box-text{font-size:.9375rem;color:var(--text-sub);margin-bottom:16px;line-height:1.75;}
.share-btns{display:flex;flex-wrap:wrap;gap:8px;}
.share-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;font-size:.875rem;font-family:var(--f-sans);letter-spacing:.02em;border-radius:2px;transition:var(--ease);text-decoration:none;cursor:pointer;}
.share-btn-x{background:#000;color:#fff;border:1px solid rgba(255,255,255,.15);}
.share-btn-x:hover{background:#333;color:#fff;}
.share-btn-line{background:#06C755;color:#fff;}
.share-btn-line:hover{background:#05a84a;color:#fff;}
.share-btn-instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;}
.share-btn-instagram:hover{opacity:.85;color:#fff;}
.share-btn-facebook{background:#1877F2;color:#fff;}
.share-btn-facebook:hover{background:#1060cc;color:#fff;}
.share-btn-threads{background:#1a1a1a;color:#fff;border:1px solid rgba(255,255,255,.15);}
.share-btn-threads:hover{background:#333;color:#fff;}
.share-btn-print{background:transparent;color:var(--text-muted);border:1px solid var(--border-d);}
.share-btn-print:hover{border-color:var(--gold);color:var(--gold);}
@media(max-width:600px){
  .share-btns{gap:6px;}
  .share-btn{padding:8px 12px;font-size:.8125rem;}
}

/* =====================================================
   25. RELATED ARTICLES (3×2)
   ===================================================== */
.related-articles-sec{background:var(--black-mid);border-top:1px solid var(--border);padding:60px 0 80px;}
.related-articles-label{font-size:.875rem;color:var(--gold);letter-spacing:.3em;font-family:var(--f-sans);padding-left:12px;border-left:2px solid var(--gold);margin-bottom:32px;}
.related-articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.rel-article-card{background:var(--black-card);border:1px solid var(--border-d);overflow:hidden;transition:var(--ease);}
.rel-article-card:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:var(--glow);}
.rel-article-thumb{aspect-ratio:16/9;background:var(--black-light);display:flex;align-items:center;justify-content:center;color:rgba(200,168,75,.2);font-size:2rem;position:relative;overflow:hidden;}
.rel-article-thumb img{width:100%;height:100%;object-fit:cover;}
.rel-article-body{padding:16px;}
.rel-article-cat{font-size:.8125rem;color:var(--gold);font-family:var(--f-sans);margin-bottom:6px;}
.rel-article-title{font-size:.9375rem;color:var(--white);line-height:1.55;transition:color var(--ease);}
.rel-article-card:hover .rel-article-title{color:var(--gold);}
@media(max-width:768px){
  .related-articles-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .related-articles-grid{grid-template-columns:1fr;}
}

/* =====================================================
   26. ARTICLE EYECATCH
   ===================================================== */
.article-eyecatch{width:100%;overflow:hidden;background:var(--black-card);border-bottom:1px solid var(--border-d);}
.article-eyecatch img{width:100%;max-height:480px;object-fit:cover;display:block;}
.article-eyecatch-ph{width:100%;height:200px;display:flex;align-items:center;justify-content:center;color:rgba(200,168,75,.12);font-size:3rem;}
/* タイトル直下インラインアイキャッチ（標準サイズ・全幅なし） */
.article-eyecatch--inline{width:100%;max-width:720px;margin:20px auto 28px;border:1px solid var(--border-d);border-radius:3px;background:var(--black-card);border-bottom:none;}
.article-eyecatch--inline img{width:100%;max-height:420px;object-fit:cover;display:block;border-radius:3px;}

/* =====================================================
   28. TABLE OF CONTENTS
   ===================================================== */
.toc{background:var(--black-card);border:1px solid var(--border);padding:28px 32px;margin-bottom:48px;position:relative;}
.toc::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(to bottom,var(--gold),transparent);}
.toc-label{font-size:.75rem;color:var(--gold);letter-spacing:.4em;font-family:var(--f-sans);margin-bottom:14px;display:block;}
.toc-title{font-size:1rem;color:var(--white);font-family:var(--f-sans);font-weight:600;letter-spacing:.05em;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border-d);}
.toc-list{list-style:none;display:flex;flex-direction:column;gap:2px;}
.toc-list li{display:flex;align-items:baseline;gap:14px;padding:6px 0;border-bottom:1px solid var(--border-d);}
.toc-list li:last-child{border-bottom:none;}
.toc-num{font-size:.75rem;color:var(--gold);font-family:var(--f-sans);letter-spacing:.1em;flex-shrink:0;min-width:24px;}
.toc-list a{font-size:.9375rem;color:var(--text-sub);font-family:var(--f-sans);line-height:1.6;transition:var(--ease);}
.toc-list a:hover{color:var(--white);}
@media(max-width:768px){
  .toc{padding:22px 20px;}
  .toc-list a{font-size:.875rem;}
}

/* =====================================================
   27. INDEX — 整える 3STEP SECTION
   ===================================================== */
.setonoeru-sec{background:var(--black);border-top:1px solid var(--border);}
.step-flow{display:grid;grid-template-columns:1fr 40px 1fr 40px 1fr;align-items:center;gap:0;max-width:860px;margin:0 auto;}
.step-block{background:var(--black-card);border:1px solid var(--border-d);padding:32px 24px;text-align:center;position:relative;}
.step-block::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
/* .step-label: 既存 .step-num (flow-steps用 gold circle) と競合するため別名で定義 */
.step-label{font-size:.75rem;color:var(--gold);letter-spacing:.3em;font-family:var(--f-sans);margin-bottom:12px;display:block;}
.step-icon{font-size:1.75rem;margin-bottom:12px;display:block;}
.step-title{font-size:1rem;color:var(--white);letter-spacing:.08em;margin-bottom:10px;display:block;}
.step-desc{font-size:.875rem;color:var(--text-muted);line-height:1.75;}
.step-arrow{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.25rem;opacity:.6;}
@media(max-width:768px){
  .step-flow{grid-template-columns:1fr;gap:16px;}
  .step-arrow{transform:rotate(90deg);}
}

/* =====================================================
   28. WOOCOMMERCE CHECKOUT
   ===================================================== */

/* ページ全体（padding は #primary 側で管理するためbodyへの付加は最小限） */
.woocommerce-checkout,
.woocommerce-cart{
  background:var(--black);
  color:var(--text-main);
  min-height:60vh;
}
.woocommerce-checkout #primary,
.woocommerce-cart #primary{
  max-width:1000px;
  margin:0 auto;
  padding:88px 24px 60px; /* 88px = fixed header(72px) + gap(16px) */
}

/* 見出し */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout #ship-to-different-address label,
.woocommerce-checkout #order_review_heading{
  font-family:var(--f-serif);
  font-size:1.125rem;
  color:var(--gold);
  letter-spacing:.15em;
  border-bottom:1px solid var(--border);
  padding-bottom:12px;
  margin-bottom:24px;
}

/* フォームレイアウト */
.woocommerce form .form-row{
  margin-bottom:20px;
}
.woocommerce form .form-row label{
  display:block;
  font-size:.875rem;
  color:var(--text-sub);
  letter-spacing:.06em;
  margin-bottom:8px;
}
.woocommerce form .form-row .required{
  color:var(--vermillion);
}

/* 入力フィールド */
.woocommerce form .form-row input[type="text"],
.woocommerce form .form-row input[type="email"],
.woocommerce form .form-row input[type="tel"],
.woocommerce form .form-row select,
.woocommerce form .form-row textarea{
  width:100%;
  background:var(--black-card);
  border:1px solid var(--border-d);
  color:var(--text-main);
  padding:14px 16px;
  font-family:var(--f-sans);
  font-size:.9375rem;
  border-radius:0;
  outline:none;
  transition:border-color .2s ease;
  -webkit-appearance:none;
  appearance:none;
}
.woocommerce form .form-row input:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus{
  border-color:var(--gold);
  background:var(--black-light);
}

/* セレクトボックス */
.woocommerce form .form-row select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C8A84B' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 16px center;
  padding-right:44px;
}

/* 手相写真アップロードフィールド */
.woocommerce .palm-photo-section{
  margin:32px 0;
  padding:28px 24px;
  background:var(--black-card);
  border:1px solid var(--border);
  position:relative;
}
.woocommerce .palm-photo-section::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(to right,transparent,var(--gold),transparent);
}
.woocommerce .palm-photo-section h3{
  border-bottom:none;
  margin-bottom:8px;
}
.woocommerce .palm-photo-section .palm-note{
  font-size:.8125rem;
  color:var(--text-muted);
  margin-bottom:20px;
  line-height:1.8;
}
.woocommerce .palm-photo-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.woocommerce .palm-photo-item label{
  font-size:.8125rem;
  color:var(--text-sub);
  margin-bottom:8px;
  display:block;
}
.woocommerce .palm-photo-item input[type="file"]{
  width:100%;
  background:var(--black-light);
  border:1px dashed var(--border);
  color:var(--text-muted);
  padding:12px 14px;
  font-size:.8125rem;
  cursor:pointer;
  transition:border-color .2s;
}
.woocommerce .palm-photo-item input[type="file"]:hover{
  border-color:var(--gold);
}

/* 注文サマリー */
.woocommerce-checkout-review-order-table,
.shop_table{
  width:100%;
  border-collapse:collapse;
  background:var(--black-card);
  margin-bottom:24px;
}
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td,
.shop_table th,
.shop_table td{
  padding:16px 20px;
  border-bottom:1px solid var(--border-d);
  font-size:.9375rem;
  vertical-align:top;
}
.woocommerce-checkout-review-order-table thead th,
.shop_table thead th{
  color:var(--gold);
  font-family:var(--f-sans);
  font-weight:500;
  letter-spacing:.08em;
  font-size:.8125rem;
  text-transform:uppercase;
}
.woocommerce-checkout-review-order-table .order-total td,
.shop_table .order-total td{
  color:var(--gold);
  font-size:1.125rem;
  font-weight:700;
}

/* 決済ボタン */
#place_order,
.woocommerce-cart .checkout-button{
  display:block;
  width:100%;
  background:var(--vermillion);
  color:var(--white);
  border:none;
  padding:18px 32px;
  font-family:var(--f-serif);
  font-size:1.0625rem;
  letter-spacing:.12em;
  cursor:pointer;
  transition:background .2s ease,transform .15s ease;
  text-align:center;
  text-decoration:none;
  margin-top:8px;
}
#place_order:hover,
.woocommerce-cart .checkout-button:hover{
  background:var(--verm-h);
  transform:translateY(-2px);
}

/* エラー・通知 */
.woocommerce-error,
.woocommerce-message,
.woocommerce-info{
  background:var(--black-card);
  border-left:3px solid var(--gold);
  color:var(--text-main);
  padding:16px 20px;
  margin-bottom:24px;
  font-size:.9375rem;
  list-style:none;
}
.woocommerce-error{
  border-left-color:var(--vermillion);
}

/* 2カラムレイアウト（ビリング＋オーダーサマリー） */
@media(min-width:769px){
  .woocommerce-checkout #customer_details{
    float:left;
    width:55%;
  }
  .woocommerce-checkout #order_review{
    float:right;
    width:40%;
  }
  .woocommerce-checkout::after{
    content:'';display:table;clear:both;
  }
}
@media(max-width:768px){
  .woocommerce .palm-photo-grid{
    grid-template-columns:1fr;
  }
}

/* =====================================================
   29. ARTICLE-THUMB 内アイキャッチ画像フィックス
   ===================================================== */
/* .article-thumb は position:relative;aspect-ratio:16/9;overflow:hidden 済み
   → 内部の img を absolute で塗りつぶす */
.article-thumb img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
}
/* 関連記事サムネイル（single.php 等）も同様 */
.rel-article-thumb img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
}
/* 手相コラムサムネイル（tcolumn-thumbも同じ構造）*/
.tcolumn-thumb img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
}

/* =====================================================
   30. WOOCOMMERCE SINGLE PRODUCT PAGE
   ===================================================== */

/* --- ラッパー（woocommerce.php の <div class="woocommerce"><div id="primary"> 構造用） --- */
/* 商品詳細ページ（body.single-product）のみ対象 */
body.single-product .woocommerce #primary{
  max-width:1100px;
  margin:0 auto;
  padding:88px 24px 60px; /* 88px = fixed header(72px) + gap(16px)  */
  min-height:60vh;
  background:var(--black);
}
/* ショップアーカイブ等の汎用 */
body.woocommerce-page:not(.woocommerce-checkout):not(.woocommerce-cart) .woocommerce #primary{
  max-width:1100px;
  margin:0 auto;
  padding:88px 24px 60px;
  min-height:60vh;
  background:var(--black);
}
/* page-hero グラデーション（静的HTMLの .page-hero と同等） */
body.single-product .woocommerce{
  background:radial-gradient(ellipse at 50% 0%,rgba(200,168,75,.07) 0%,transparent 60%),var(--black);
}
/* 旧カスタムラッパー互換 */
.woo-main{padding:60px 0;min-height:60vh;background:var(--black);}

/* --- パンくず --- */
.woocommerce .woocommerce-breadcrumb,
.woocommerce-page .woocommerce-breadcrumb{
  font-size:.8125rem;color:var(--text-muted);
  font-family:var(--f-sans);margin-bottom:36px;
}
.woocommerce .woocommerce-breadcrumb a{color:var(--text-muted);}
.woocommerce .woocommerce-breadcrumb a:hover{color:var(--gold);}
.woocommerce .woocommerce-breadcrumb .breadcrumb_last{color:var(--text-sub);}

/* --- 商品メインレイアウト --- */
.woocommerce div.product{
  display:flex !important;flex-wrap:wrap !important;
  gap:48px !important;align-items:flex-start !important;
  margin-bottom:60px !important;
}
.woocommerce div.product div.images{
  flex:1 1 40% !important;max-width:460px !important;
}
.woocommerce div.product div.summary{
  flex:1 1 46% !important;min-width:280px !important;
}

/* --- 商品ギャラリー --- */
.woocommerce-product-gallery{position:relative;}
.woocommerce-product-gallery__image img,
.woocommerce-product-gallery img{
  width:100%;height:auto;display:block;
  border:1px solid var(--border-d);
}
.woocommerce-product-gallery__image--placeholder{
  background:var(--black-light);aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border-d);
  color:var(--text-muted);font-size:.875rem;
}

/* --- タイトル・評価・価格 --- */
.woocommerce div.product .product_title{
  font-family:var(--f-serif);
  font-size:clamp(1.25rem,3vw,1.75rem);
  color:var(--white);line-height:1.45;
  letter-spacing:.04em;margin-bottom:16px;
}
.woocommerce div.product .woocommerce-product-rating{
  display:flex;align-items:center;gap:10px;margin-bottom:20px;
  font-size:.875rem;color:var(--text-muted);font-family:var(--f-sans);
}
.woocommerce div.product p.price,
.woocommerce div.product span.price{
  display:block;
  font-family:var(--f-sans);font-size:1.75rem;
  font-weight:700;color:var(--gold);
  letter-spacing:.04em;margin-bottom:20px;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del{
  color:var(--text-muted);font-size:1.125rem;margin-right:8px;
}
.woocommerce div.product .woocommerce-product-details__short-description{
  color:var(--text-sub);font-size:.9375rem;line-height:1.9;
  margin-bottom:28px;
  border-top:1px solid var(--border-d);padding-top:20px;
}

/* --- カートフォーム・購入ボタン --- */
.woocommerce div.product form.cart{margin-bottom:24px;}
.woocommerce div.product form.cart div.quantity{
  display:inline-flex;align-items:center;
  border:1px solid var(--border-d);
  margin-right:12px;margin-bottom:12px;
}
.woocommerce div.product form.cart div.quantity .qty{
  background:var(--black-card);border:none;
  color:var(--text-main);font-size:1rem;
  padding:10px 16px;width:60px;text-align:center;
  font-family:var(--f-sans);
}
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button{
  background:var(--vermillion) !important;
  color:var(--white) !important;
  border:none !important;
  padding:16px 36px !important;
  font-family:var(--f-serif) !important;
  font-size:1rem !important;
  letter-spacing:.1em !important;
  cursor:pointer !important;
  transition:background .2s,transform .15s !important;
  border-radius:0 !important;
  text-decoration:none;display:inline-block;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover{
  background:var(--verm-h) !important;
  transform:translateY(-2px) !important;
}

/* --- メタ情報（SKU） --- */
.woocommerce div.product .product_meta{
  font-size:.8125rem;color:var(--text-muted);
  font-family:var(--f-sans);
  border-top:1px solid var(--border-d);
  padding-top:16px;margin-top:16px;
}
.woocommerce div.product .product_meta span.sku{color:var(--text-sub);}

/* --- タブ（説明・詳細・レビュー） --- */
.woocommerce-tabs{
  margin-top:60px;
  border-top:1px solid var(--border-d);
  padding-top:40px;
}
.woocommerce-tabs ul.tabs{
  display:flex;gap:0;
  border-bottom:1px solid var(--border-d);
  margin-bottom:32px;padding:0;list-style:none;
}
.woocommerce-tabs ul.tabs li{
  border:none;background:transparent;margin:0;
  border-radius:0;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after{display:none;}
.woocommerce-tabs ul.tabs li a{
  display:block;padding:12px 24px;
  font-family:var(--f-sans);font-size:.9375rem;
  color:var(--text-muted);letter-spacing:.06em;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:color .2s,border-color .2s;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover{
  color:var(--gold);border-bottom-color:var(--gold);
}
.woocommerce-tabs .panel{
  color:var(--text-sub);font-size:.9375rem;line-height:1.9;
}
.woocommerce-tabs .panel h2{
  font-size:1.25rem;color:var(--white);
  margin-bottom:16px;padding-bottom:12px;
  border-bottom:1px solid var(--border-d);
}
.woocommerce-tabs .panel p{color:var(--text-sub);}
.woocommerce-tabs .panel ul{
  list-style:disc;padding-left:20px;color:var(--text-sub);
}

/* --- 関連商品・アップセル --- */
.related.products,
.upsells.products{
  margin-top:60px;
  border-top:1px solid var(--border-d);
  padding-top:40px;
}
.related.products > h2,
.upsells.products > h2{
  font-size:1rem;color:var(--gold);
  letter-spacing:.25em;font-family:var(--f-sans);
  margin-bottom:28px;text-align:center;
}
.woocommerce ul.products{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;list-style:none;padding:0;
}
.woocommerce ul.products li.product{
  background:var(--black-card);
  border:1px solid var(--border-d);
  transition:var(--ease);overflow:hidden;
}
.woocommerce ul.products li.product:hover{
  border-color:var(--border);
  transform:translateY(-3px);
  box-shadow:var(--glow);
}
.woocommerce ul.products li.product a img{
  width:100%;height:200px;
  object-fit:cover;display:block;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-size:.9375rem;color:var(--white);
  padding:14px 14px 4px;line-height:1.5;
}
.woocommerce ul.products li.product .price{
  display:block;padding:0 14px 8px;
  color:var(--gold);font-family:var(--f-sans);font-weight:700;
}
.woocommerce ul.products li.product .button{
  display:block;
  width:calc(100% - 28px);
  margin:0 14px 14px;
  padding:10px;text-align:center;
  background:var(--vermillion);
  color:var(--white);
  font-family:var(--f-sans);font-size:.875rem;
  transition:background .2s;
  border-radius:0 !important;
}
.woocommerce ul.products li.product .button:hover{
  background:var(--verm-h);
}

/* --- 商品詳細ページ レスポンシブ --- */
@media(max-width:768px){
  .woocommerce div.product{
    flex-direction:column;gap:28px;
  }
  .woocommerce div.product div.images,
  .woocommerce div.product div.summary{
    max-width:100%;flex:1 1 100%;
  }
  .woocommerce ul.products{
    grid-template-columns:repeat(2,1fr);
  }
  .woo-main{padding:40px 0;}
}
@media(max-width:480px){
  .woocommerce ul.products{
    grid-template-columns:1fr;
  }
}

/* =====================================================
   31. 特定商取引法ページ
   ===================================================== */
.tokushoho-table{
  border:1px solid var(--border-d);
  overflow:hidden;
}
.tokushoho-row{
  display:grid;
  grid-template-columns:200px 1fr;
  border-bottom:1px solid var(--border-d);
}
.tokushoho-row:last-child{border-bottom:none;}
.tokushoho-row dt{
  background:var(--black-light);
  padding:20px 24px;
  font-family:var(--f-sans);
  font-size:.875rem;
  color:var(--gold);
  letter-spacing:.06em;
  border-right:1px solid var(--border-d);
  display:flex;align-items:flex-start;
}
.tokushoho-row dd{
  padding:20px 24px;
  font-size:.9375rem;
  color:var(--text-sub);
  line-height:1.85;
  margin:0;
}
@media(max-width:640px){
  .tokushoho-row{grid-template-columns:1fr;}
  .tokushoho-row dt{
    border-right:none;
    border-bottom:1px solid var(--border-d);
    padding:14px 18px;
  }
  .tokushoho-row dd{padding:14px 18px;}
}

/* =====================================================
   32. WOOCOMMERCE CHECKOUT — フォームレイアウト完全修正
   ===================================================== */

/* input-wrapper を block で幅100%保証（!important でWC標準に優先） */
.woocommerce .woocommerce-input-wrapper,
.woocommerce-page .woocommerce-input-wrapper{
  display:block !important;
  width:100% !important;
}

/* field-wrapper を flexbox で並べる */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:0 20px !important;
  align-items:flex-start !important;
}
.woocommerce form .form-row-wide{
  width:100% !important;
  float:none !important;
  margin-right:0 !important;
}
.woocommerce form .form-row-first,
.woocommerce form .form-row-last{
  float:none !important;
  clear:none !important;
  overflow:visible !important;
  width:calc(50% - 10px) !important;
  margin-right:0 !important;
}

/* WooCommerceの .input-text クラスも確実にスタイル適用 */
.woocommerce form .form-row .input-text,
.woocommerce-page form .form-row .input-text{
  width:100% !important;
  box-sizing:border-box !important;
  background:var(--black-card) !important;
  border:1px solid var(--border-d) !important;
  color:var(--text-main) !important;
  padding:14px 16px !important;
  font-family:var(--f-sans) !important;
  font-size:.9375rem !important;
  border-radius:0 !important;
  outline:none !important;
  transition:border-color .2s ease !important;
  -webkit-appearance:none !important;
  appearance:none !important;
}
.woocommerce form .form-row .input-text:focus,
.woocommerce-page form .form-row .input-text:focus{
  border-color:var(--gold) !important;
  background:var(--black-light) !important;
}

/* select も同様 */
.woocommerce form .form-row select,
.woocommerce-page form .form-row select{
  width:100% !important;
  box-sizing:border-box !important;
  background:var(--black-card) !important;
  border:1px solid var(--border-d) !important;
  color:var(--text-main) !important;
  padding:14px 44px 14px 16px !important;
  font-family:var(--f-sans) !important;
  font-size:.9375rem !important;
  border-radius:0 !important;
  outline:none !important;
  -webkit-appearance:none !important;
  appearance:none !important;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C8A84B' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 16px center !important;
}

/* textarea */
.woocommerce form .form-row textarea,
.woocommerce-page form .form-row textarea{
  width:100% !important;
  box-sizing:border-box !important;
  background:var(--black-card) !important;
  border:1px solid var(--border-d) !important;
  color:var(--text-main) !important;
  padding:14px 16px !important;
  font-family:var(--f-sans) !important;
  font-size:.9375rem !important;
  border-radius:0 !important;
  outline:none !important;
  resize:vertical !important;
  min-height:100px !important;
}
.woocommerce form .form-row textarea:focus,
.woocommerce-page form .form-row textarea:focus{
  border-color:var(--gold) !important;
  background:var(--black-light) !important;
}

/* モバイル: 全フィールドを1カラム */
@media(max-width:600px){
  .woocommerce form .form-row-first,
  .woocommerce form .form-row-last{
    width:100% !important;
  }
}

/* ===== アイコン除去 ===== */

/* woocommerce-info（クーポン・注意バナー）のアイコン除去 */
.woocommerce .woocommerce-info::before,
.woocommerce-page .woocommerce-info::before{
  display:none !important;
  content:none !important;
}
.woocommerce .woocommerce-info,
.woocommerce-page .woocommerce-info{
  padding-left:1.25em !important;
}

/* 注文テーブル 商品名のアイコン除去 */
.woocommerce-checkout-review-order-table .product-name::before,
.woocommerce-checkout-review-order-table .product-name::after,
.shop_table .product-name::before,
.shop_table .product-name::after{
  display:none !important;
  content:none !important;
}

/* クーポンラベルアイコン除去 */
.woocommerce .coupon label::before,
.woocommerce .coupon label::after,
.woocommerce-form-coupon-toggle a::before,
.woocommerce-form-coupon-toggle a::after{
  display:none !important;
  content:none !important;
}

/* =====================================================
   33. WOOCOMMERCE CHECKOUT — 2カラムレイアウト改善
   ===================================================== */

/* clearfix */
.woocommerce-checkout #customer_details::after,
.woocommerce-checkout #order_review::after{
  content:'';display:table;clear:both;
}
.woocommerce-checkout #order_review_heading{
  margin-top:0;
}

/* =====================================================
   34. SHOP LIST — フィルター＆ソート
   ===================================================== */
.shop-filter-bar{
  background:var(--black-mid);
  border-bottom:1px solid var(--border-d);
  padding:16px 0;
  position:sticky;
  top:72px;
  z-index:100;
}
.shop-filter-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
}
.filter-cats{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.filter-btn{
  padding:8px 18px;
  font-size:.875rem;
  font-family:var(--f-sans);
  color:var(--text-muted);
  background:transparent;
  border:1px solid var(--border-d);
  border-radius:2px;
  cursor:pointer;
  transition:var(--ease);
  letter-spacing:.04em;
  white-space:nowrap;
}
.filter-btn:hover,
.filter-btn.active{
  color:var(--gold);
  border-color:var(--gold);
  background:rgba(200,168,75,.06);
}
.filter-sort{
  display:flex;
  gap:6px;
  align-items:center;
}
.filter-sort-label{
  font-size:.8125rem;
  color:var(--text-muted);
  font-family:var(--f-sans);
  margin-right:4px;
}
.sort-btn{
  padding:6px 14px;
  font-size:.8125rem;
  font-family:var(--f-sans);
  color:var(--text-muted);
  background:transparent;
  border:1px solid var(--border-d);
  border-radius:2px;
  cursor:pointer;
  transition:var(--ease);
  white-space:nowrap;
}
.sort-btn:hover,
.sort-btn.active{
  color:var(--gold);
  border-color:var(--gold);
}
/* 非表示カード（フィルター用） */
.product-card.hidden{
  display:none;
}
@media(max-width:640px){
  .shop-filter-inner{flex-direction:column;align-items:flex-start;}
  .filter-sort{flex-wrap:wrap;}
}

/* =====================================================
   35. ARCHIVE — カードグリッド
   ===================================================== */
.posts-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
}
.post-card-v{
  background:var(--black-card);
  border:1px solid var(--border-d);
  display:flex;
  flex-direction:column;
  transition:var(--ease);
  text-decoration:none;
  color:inherit;
}
.post-card-v:hover{
  border-color:var(--border);
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.post-card-v:hover .post-card-title{
  color:var(--gold);
}
.post-card-thumb{
  width:100%;
  aspect-ratio:16/9;
  background:var(--black-light);
  border-bottom:1px solid var(--border-d);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:2rem;
  color:rgba(200,168,75,.2);
  flex-shrink:0;
  position:relative;
}
.post-card-thumb img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.post-card-body{
  padding:20px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.post-card-meta{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
}
.post-card-date{
  font-size:.8125rem;
  color:var(--text-muted);
  font-family:var(--f-sans);
}
.post-card-cat{
  font-size:.75rem;
  color:var(--gold);
  font-family:var(--f-sans);
  border:1px solid var(--border);
  padding:2px 8px;
  border-radius:2px;
}
.post-card-title{
  font-size:.9375rem;
  color:var(--white);
  line-height:1.6;
  margin-bottom:10px;
  transition:color var(--ease);
  font-weight:400;
}
.post-card-excerpt{
  font-size:.8125rem;
  color:var(--text-muted);
  line-height:1.75;
  flex:1;
  margin-bottom:14px;
}
.post-card-more{
  font-size:.8125rem;
  color:var(--gold);
  font-family:var(--f-sans);
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-top:auto;
}
.post-card-more::after{content:'→';}
@media(max-width:640px){
  .posts-grid{grid-template-columns:1fr;}
}

/* =====================================================
   36. WOOCOMMERCE — CSS 無効化後の完全置き換えスタイル
   WooCommerce標準CSSを functions.php で無効化しているため
   必要なスタイルをここで定義する
   ===================================================== */

/* ----- 基本ページ構造 ----- */
.woocommerce,
.woocommerce-page{
  background:var(--black);
  color:var(--text-main);
}
.woocommerce ul.products,
.woocommerce-page ul.products{
  list-style:none;
  margin:0;padding:0;
}

/* ----- 通知・エラー ----- */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info{
  background:var(--black-card);
  border-left:3px solid var(--gold);
  color:var(--text-main);
  padding:14px 20px;
  margin-bottom:20px;
  font-size:.9375rem;
  list-style:none;
}
.woocommerce-error{ border-left-color:var(--vermillion); }
.woocommerce-message a,
.woocommerce-error a,
.woocommerce-info a{ color:var(--gold); text-decoration:underline; }
.woocommerce-message::before,
.woocommerce-error li::before,
.woocommerce-info::before{ display:none !important; content:none !important; }

/* ----- ブレッドクラム ----- */
.woocommerce .woocommerce-breadcrumb{
  font-size:.875rem;
  color:var(--text-muted);
  margin-bottom:24px;
}
.woocommerce .woocommerce-breadcrumb a{ color:var(--text-muted); }
.woocommerce .woocommerce-breadcrumb a:hover{ color:var(--gold); }

/* ----- チェックアウト ページ全体 ----- */
.woocommerce-checkout,
.woocommerce-cart{
  min-height:60vh;
  padding:60px 0;
}
.woocommerce-checkout #primary,
.woocommerce-cart #primary{
  max-width:1100px;
  margin:0 auto;
  padding:0 24px 80px;
}

/* ----- チェックアウト 見出し ----- */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout #ship-to-different-address label,
.woocommerce-checkout #order_review_heading{
  font-family:var(--f-serif);
  font-size:1.0625rem;
  color:var(--gold);
  letter-spacing:.12em;
  border-bottom:1px solid var(--border-d);
  padding-bottom:12px;
  margin-bottom:20px;
  margin-top:32px;
}

/* ----- チェックアウト 2カラム ----- */
@media(min-width:769px){
  .woocommerce-checkout #customer_details{
    float:left;
    width:56%;
  }
  .woocommerce-checkout #order_review{
    float:right;
    width:40%;
  }
  .woocommerce-checkout form.checkout::after{
    content:'';display:table;clear:both;
  }
}

/* ----- フォーム ラベル ----- */
.woocommerce form p.form-row{
  margin-bottom:16px;
  padding:0;
}
.woocommerce form p.form-row label,
.woocommerce form .form-row label{
  display:block;
  font-size:.875rem;
  color:var(--text-sub);
  letter-spacing:.05em;
  margin-bottom:6px;
  font-family:var(--f-sans);
}
.woocommerce form .form-row abbr.required,
.woocommerce form p.form-row abbr.required{
  color:var(--vermillion);
  text-decoration:none;
}

/* ----- フォーム 入力フィールド（最高優先度） ----- */
.woocommerce form p.form-row input.input-text,
.woocommerce form .form-row input.input-text,
.woocommerce form p.form-row input[type="text"],
.woocommerce form p.form-row input[type="email"],
.woocommerce form p.form-row input[type="tel"],
.woocommerce form p.form-row input[type="password"],
.woocommerce form p.form-row input[type="number"],
.woocommerce form p.form-row select,
.woocommerce form p.form-row textarea,
.woocommerce-checkout #billing_first_name,
.woocommerce-checkout #billing_last_name,
.woocommerce-checkout #billing_email,
.woocommerce-checkout #billing_phone,
.woocommerce-checkout #billing_address_1,
.woocommerce-checkout #billing_address_2,
.woocommerce-checkout #billing_city,
.woocommerce-checkout #billing_postcode,
.woocommerce-checkout #billing_state,
.woocommerce-checkout #order_comments,
.woocommerce-checkout #coupon_code{
  display:block !important;
  width:100% !important;
  box-sizing:border-box !important;
  background:#242424 !important;
  border:1px solid rgba(200,168,75,.15) !important;
  color:#FAF7F0 !important;
  padding:12px 14px !important;
  font-family:'Noto Sans JP','Helvetica Neue',sans-serif !important;
  font-size:.9375rem !important;
  border-radius:0 !important;
  outline:none !important;
  line-height:1.5 !important;
  -webkit-appearance:none !important;
  appearance:none !important;
  transition:border-color .2s !important;
  margin:0 !important;
  height:auto !important;
}
.woocommerce form p.form-row input.input-text:focus,
.woocommerce form .form-row input.input-text:focus,
.woocommerce-checkout input:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus{
  border-color:var(--gold) !important;
  background:#1E1E1E !important;
}
.woocommerce form p.form-row select,
.woocommerce-checkout select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C8A84B' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 14px center !important;
  padding-right:40px !important;
  cursor:pointer !important;
}
.woocommerce form p.form-row textarea,
.woocommerce-checkout textarea{
  min-height:100px !important;
  resize:vertical !important;
}

/* input-wrapper */
.woocommerce .woocommerce-input-wrapper{
  display:block !important;
  width:100% !important;
}

/* ----- form-row 横並び（first/last） ----- */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:0 16px !important;
}
.woocommerce form p.form-row-wide{
  width:100% !important;
  float:none !important;
  margin-right:0 !important;
}
.woocommerce form p.form-row-first,
.woocommerce form p.form-row-last{
  float:none !important;
  overflow:visible !important;
  width:calc(50% - 8px) !important;
  margin-right:0 !important;
}
@media(max-width:600px){
  .woocommerce form p.form-row-first,
  .woocommerce form p.form-row-last{
    width:100% !important;
  }
}

/* ----- 注文サマリー テーブル ----- */
.woocommerce-checkout-review-order-table,
.shop_table{
  width:100%;
  border-collapse:collapse;
  background:var(--black-card);
  margin-bottom:20px;
}
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td,
.shop_table th,
.shop_table td{
  padding:14px 18px;
  border-bottom:1px solid rgba(200,168,75,.1);
  font-size:.9375rem;
  color:var(--text-main);
  vertical-align:top;
  text-align:left;
}
.woocommerce-checkout-review-order-table thead th,
.shop_table thead th{
  color:var(--gold);
  font-family:var(--f-sans);
  font-size:.8125rem;
  letter-spacing:.08em;
  font-weight:500;
}
.woocommerce-checkout-review-order-table .order-total td,
.shop_table .order-total td{
  color:var(--gold);
  font-size:1.125rem;
  font-weight:700;
}
/* 商品名アイコン除去 */
.woocommerce-checkout-review-order-table .product-name::before,
.woocommerce-checkout-review-order-table .product-name::after,
.shop_table .product-name::before,
.shop_table .product-name::after{
  display:none !important;
  content:none !important;
}

/* ----- クーポン ----- */
.woocommerce-form-coupon-toggle,
.woocommerce .checkout_coupon{
  background:var(--black-card);
  border:1px solid var(--border-d);
  padding:20px 24px;
  margin-bottom:24px;
}
.woocommerce-form-coupon-toggle .woocommerce-info{
  background:none;
  border:none;
  padding:0;
  margin:0;
  font-size:.9375rem;
  color:var(--text-sub);
}
.woocommerce-form-coupon-toggle a,
.woocommerce .showcoupon{
  color:var(--gold);
  cursor:pointer;
}
/* クーポンアイコン除去 */
.woocommerce .woocommerce-info::before,
.woocommerce-page .woocommerce-info::before,
.woocommerce .coupon label::before,
.woocommerce .coupon label::after,
.woocommerce-form-coupon-toggle a::before,
.woocommerce-form-coupon-toggle a::after{
  display:none !important;
  content:none !important;
}
.woocommerce .checkout_coupon .form-row{
  display:flex;
  gap:10px;
  align-items:flex-end;
  margin-bottom:0;
}
.woocommerce .checkout_coupon .form-row input{
  flex:1;
}
.woocommerce .checkout_coupon .form-row button{
  flex-shrink:0;
}

/* ----- 決済 ボタン ----- */
#place_order,
.woocommerce-cart .checkout-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{
  display:block;
  width:100%;
  background:var(--vermillion);
  color:var(--white);
  border:none;
  padding:16px 24px;
  font-family:var(--f-serif);
  font-size:1rem;
  letter-spacing:.1em;
  cursor:pointer;
  text-align:center;
  text-decoration:none;
  transition:background .2s,transform .15s;
  box-sizing:border-box;
  border-radius:0;
  -webkit-appearance:none;
}
#place_order:hover,
.woocommerce-cart .checkout-button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover{
  background:var(--verm-h);
  transform:translateY(-2px);
  color:var(--white);
}
/* 二次ボタン（カートに戻る等） */
.woocommerce a.button.alt,
.woocommerce button.button.alt{
  background:var(--gold);
  color:var(--black);
}

/* ----- 支払い方法ラジオ ----- */
.woocommerce-checkout #payment{
  background:var(--black-card);
  border:1px solid var(--border-d);
  padding:20px 24px;
  margin-bottom:20px;
}
.woocommerce-checkout #payment ul.payment_methods{
  list-style:none;
  padding:0;margin:0 0 16px;
  border-bottom:1px solid var(--border-d);
}
.woocommerce-checkout #payment ul.payment_methods li{
  padding:10px 0;
  color:var(--text-sub);
  font-size:.9375rem;
}
.woocommerce-checkout #payment .payment_box{
  background:var(--black-light);
  padding:12px 14px;
  margin-top:8px;
  font-size:.875rem;
  color:var(--text-muted);
}
.woocommerce-checkout #payment .woocommerce-terms-and-conditions-wrapper{
  font-size:.875rem;
  color:var(--text-muted);
  margin-bottom:16px;
}

/* ----- カート テーブル ----- */
.woocommerce-cart-form .cart_item td{
  vertical-align:middle;
}
.woocommerce-cart-form .product-thumbnail img{
  width:80px;height:80px;object-fit:cover;
}
.woocommerce-cart-form a.remove{
  color:var(--vermillion) !important;
  font-size:1.25rem;
  line-height:1;
}
.woocommerce-cart .cart-collaterals .cart_totals{
  float:right;
  width:48%;
}
@media(max-width:768px){
  .woocommerce-cart .cart-collaterals .cart_totals{
    float:none;
    width:100%;
  }
}

/* ===== Section 37: チェックアウト追加フィールド ===== */
.yoi-extra-fields{
  margin-top:28px;
  padding-top:24px;
  border-top:1px solid var(--border-d);
}
.yoi-extra-fields h3{
  font-family:var(--f-serif);
  font-size:1rem;
  color:var(--gold);
  margin-bottom:20px;
  letter-spacing:.05em;
}
.yoi-field-section{
  margin-bottom:20px;
}
.yoi-field-section label{
  display:block;
  font-size:.875rem;
  color:var(--text-sub);
  margin-bottom:6px;
}
.yoi-field-section textarea{
  width:100% !important;
  background:var(--black-card) !important;
  border:1px solid var(--border-d) !important;
  color:var(--text-main) !important;
  padding:12px 14px !important;
  font-size:.9375rem !important;
  font-family:var(--f-sans) !important;
  border-radius:0 !important;
  box-sizing:border-box !important;
  resize:vertical;
  min-height:120px;
}
.yoi-field-section textarea:focus{
  outline:none !important;
  border-color:var(--gold) !important;
}
.yoi-field-note,
.palm-note{
  font-size:.8125rem;
  color:var(--text-muted);
  margin-top:0;
  margin-bottom:12px;
  line-height:1.6;
}
.palm-photo-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
.palm-photo-item label{
  font-size:.8125rem;
  color:var(--text-muted);
  display:block;
  margin-bottom:4px;
}
.palm-photo-item input[type="file"]{
  width:100%;
  background:var(--black-card);
  border:1px solid var(--border-d);
  color:var(--text-sub);
  padding:8px 10px;
  font-size:.8125rem;
  box-sizing:border-box;
}
@media(max-width:600px){
  .palm-photo-grid{
    grid-template-columns:1fr;
  }
}
