/* ============================================================
   common.css - Taste of the Wild Japan
   共通スタイル：変数・リセット・ナビ・フッター・共通クラス
   ============================================================ */

/* リセット・基本 */
*{margin:0;padding:0;box-sizing:border-box}img{max-width:100%;height:auto}
:root{
  --primary:#121d27;--ac:#0f5167;--ac2:#0a3a4a;--ac3:#1a6a85;--acl:#e4f2f7;
  --gold:#A57C37;--gold2:#c09a52;--gold3:#d4b472;
  --be:#f5f0e8;--be2:#ede5d5;--be3:#d4c9b0;--cr:#faf8f4;--ww:#fdfcf9;
  --td:#1e1a14;--tm:#5a5347;--tl:#8a8078;
  --fs-xs:12px;--fs-base:16px;--fs-lg:24px;--fs-xl:32px;--fs-2xl:40px;--fs-3xl:48px;
  --sp-1:16px;--sp-2:32px;--sp-3:48px;--sp-4:64px;--sp-5:80px;--sp-7:112px;
}
html{scroll-behavior:smooth}
html{overflow-x:hidden}body{font-family:'DM Sans','Noto Sans JP',sans-serif;background:var(--ww);color:var(--td);overflow-x:hidden;width:100%;font-size:var(--fs-base);line-height:1.75}

/* カーソル */
.cursor-dot{position:fixed;width:8px;height:8px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
.cursor-paw{position:fixed;pointer-events:none;z-index:9998;width:44px;height:44px;transform:translate(-50%,-50%) rotate(-15deg);transition:width 0.3s,height 0.3s,opacity 0.3s;opacity:0.55}
.cursor-paw svg{width:100%;height:100%}
.cursor-paw.expand{width:68px;height:68px;opacity:0.85}
.progress-bar{position:fixed;top:0;left:0;height:2px;background:linear-gradient(to right,var(--gold),var(--ac3));z-index:200;width:0%;pointer-events:none}

/* アニメーション */
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown{to{opacity:1;transform:translateY(0)}}
@keyframes titleSlide{to{opacity:1;transform:translateY(0)}}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.85s cubic-bezier(0.16,1,0.3,1),transform 0.85s cubic-bezier(0.16,1,0.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-l{opacity:0;transform:translateX(-40px);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1)}
.reveal-l.visible{opacity:1;transform:translateX(0)}
.reveal-r{opacity:0;transform:translateX(40px);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1)}
.reveal-r.visible{opacity:1;transform:translateX(0)}

/* 共通クラス */
.sl{font-size:12px;letter-spacing:0.22em;color:var(--gold);font-weight:500;text-transform:uppercase;display:flex;align-items:center;gap:16px;margin-bottom:var(--sp-1)}
.sl::before{content:'';width:24px;height:1px;background:var(--gold);flex-shrink:0}
.st{font-family:'Playfair Display',serif;font-size:var(--fs-2xl);line-height:1.18;color:var(--primary);margin-bottom:var(--sp-1);font-weight:700}
.ss{color:var(--tm);font-size:var(--fs-base);line-height:1.875}
.arr{transition:transform 0.25s}
.btn-ac{display:inline-flex;align-items:center;gap:8px;background:var(--ac);color:#fff;padding:16px var(--sp-2);font-size:var(--fs-base);font-weight:500;letter-spacing:0.07em;text-decoration:none;transition:all 0.28s}
.btn-ac:hover{background:var(--ac2);transform:translateY(-2px)}
.btn-ac:hover .arr{transform:translateX(4px)}
.btn-gold{display:inline-block;background:var(--gold);color:#fff;padding:16px 40px;font-size:var(--fs-base);font-weight:500;letter-spacing:0.08em;text-decoration:none;transition:all 0.25s;position:relative;overflow:hidden}
.btn-gold::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.15);transform:translateX(-110%) skewX(-18deg);transition:transform 0.4s}
.btn-gold:hover::after{transform:translateX(110%) skewX(-18deg)}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-ghost{display:inline-block;border:1.5px solid rgba(255,255,255,0.5);color:#fff;padding:15px 36px;font-size:var(--fs-base);font-weight:400;letter-spacing:0.07em;text-decoration:none;transition:all 0.25s}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,0.08);transform:translateY(-2px)}
.btn-wh{display:inline-block;background:#fff;color:var(--gold);padding:16px 40px;font-size:var(--fs-base);font-weight:500;letter-spacing:0.08em;text-decoration:none;transition:all 0.25s;white-space:nowrap}
.btn-wh:hover{background:var(--be);transform:translateY(-2px)}
.btn-ow{display:inline-block;border:1.5px solid rgba(255,255,255,0.55);color:#fff;padding:15px 36px;font-size:var(--fs-base);font-weight:400;letter-spacing:0.07em;text-decoration:none;transition:all 0.25s;white-space:nowrap}
.btn-ow:hover{border-color:#fff;background:rgba(255,255,255,0.1);transform:translateY(-2px)}
.float-btn{position:fixed;bottom:32px;right:32px;background:var(--primary);border:1px solid rgba(165,124,55,0.35);color:rgba(255,255,255,0.7);width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--fs-base);opacity:0;transform:translateY(16px);transition:all 0.35s;z-index:90}
.float-btn.show{opacity:1;transform:translateY(0)}
.float-btn:hover{background:var(--gold);border-color:var(--gold);color:#fff}

/* ============================================================
   ナビゲーション
   ============================================================ */
.nav-hamburger{display:none}
.nav-drawer{display:none}
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 80px;display:flex;align-items:center;justify-content:space-between;height:64px;transition:background 0.5s,backdrop-filter 0.5s,box-shadow 0.5s}
nav.dark,nav.scrolled{background:rgba(18,29,39,0.97);backdrop-filter:blur(18px);box-shadow:0 1px 0 rgba(255,255,255,0.06)}
.nav-logo a{display:block}
.nav-logo img{height:40px}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{color:rgba(255,255,255,0.82);text-decoration:none;font-size:12px;letter-spacing:0.06em;font-weight:400;transition:color 0.2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:#d4b472;transition:width 0.3s cubic-bezier(0.16,1,0.3,1)}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-links li{position:relative}
.nav-links li:hover .nav-dropdown{opacity:1;pointer-events:auto}
.nav-has-dd{position:relative}
.nav-has-dd::after{content:'';position:absolute;top:100%;left:0;right:0;height:16px}
.nav-dropdown{position:absolute;top:100%;left:0;margin-top:8px;background:rgba(18,29,39,0.97);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-top:2px solid var(--gold);min-width:220px;opacity:0;pointer-events:none;transition:opacity 0.22s;z-index:200;white-space:nowrap}
.nav-dropdown::before{content:'';position:absolute;top:-7px;left:20px;width:10px;height:6px;background:var(--gold);clip-path:polygon(50% 0%,0% 100%,100% 100%)}
.nav-dropdown a{display:flex;align-items:center;gap:10px;padding:14px 20px;color:rgba(255,255,255,0.72);font-size:12px;text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.06);transition:background 0.18s,color 0.18s,padding-left 0.18s}
.nav-dropdown a::after{display:none}
.nav-dropdown a:last-child{border-bottom:none}
.nav-dropdown a:hover{background:rgba(255,255,255,0.05);color:#fff;padding-left:26px}
.nav-dropdown a .dd-arrow{margin-left:auto;color:var(--gold3);font-size:10px;transition:transform 0.18s}
.nav-dropdown a:hover .dd-arrow{transform:translateX(3px)}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-search{color:rgba(255,255,255,0.5);background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;transition:color 0.2s}
.nav-search:hover{color:#fff}
.nav-cta{background:var(--gold);color:#fff;padding:8px 24px;font-size:16px;font-weight:500;letter-spacing:0.08em;text-decoration:none;transition:all 0.25s;position:relative;overflow:hidden}
.nav-cta::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.15);transform:translateX(-110%) skewX(-20deg);transition:transform 0.4s}
.nav-cta:hover::after{transform:translateX(110%) skewX(-20deg)}
.nav-cta:hover{background:var(--gold2)}

/* ============================================================
   ページヒーロー（共通）
   ============================================================ */
.page-hero{position:relative;height:360px;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:64px;background:var(--primary)}
.page-hero-bg{position:absolute;inset:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:0.35}
.page-hero-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(18,29,39,0.92) 0%,rgba(18,29,39,0.55) 100%)}
.page-hero-noise{position:absolute;inset:0;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.page-hero-content{position:relative;z-index:2;text-align:center;color:#fff}
.page-hero-eyebrow{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:var(--sp-1);opacity:0;transform:translateY(16px);animation:fadeUp 0.7s 0.3s cubic-bezier(0.16,1,0.3,1) forwards}
.page-hero-line{height:1px;width:32px;background:var(--gold3)}
.page-hero-eyebrow-text{font-size:12px;letter-spacing:0.25em;color:var(--gold3);text-transform:uppercase}
.page-hero-title{font-family:'Playfair Display',serif;font-size:var(--fs-3xl);color:#fff;line-height:1.1;font-weight:700;opacity:0;transform:translateY(24px);animation:fadeUp 0.8s 0.5s cubic-bezier(0.16,1,0.3,1) forwards}
.page-hero-title em{font-style:italic;color:var(--gold3)}
.page-hero-sub{font-size:var(--fs-base);color:rgba(255,255,255,0.6);margin-top:16px;opacity:0;animation:fadeUp 0.7s 0.7s cubic-bezier(0.16,1,0.3,1) forwards}
.breadcrumb{position:absolute;bottom:var(--sp-1);left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,0.5);z-index:2;white-space:nowrap}
.breadcrumb a{color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.2s}
.breadcrumb a:hover{color:var(--gold3)}
.breadcrumb-sep{color:rgba(255,255,255,0.3)}

/* ============================================================
   フッター
   ============================================================ */
footer{background:var(--primary);padding:80px 64px 0;border-top:3px solid var(--gold)}
.footer-top{text-align:center;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:48px;display:flex;flex-direction:column;align-items:center;gap:16px}
.logo-img{height:44px;filter:brightness(0) invert(1);opacity:0.92}
.footer-catch{font-family:'Playfair Display',serif;font-size:16px;color:rgba(255,255,255,0.5);letter-spacing:0.1em;font-style:italic}
.footer-store-btn{display:inline-block;border:1.5px solid var(--gold);color:var(--gold3);padding:12px 36px;font-size:16px;font-weight:500;letter-spacing:0.1em;text-decoration:none;transition:all 0.25s;margin-top:8px}
.footer-store-btn:hover{background:var(--gold);color:#fff}
.ft{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.08)}
.fc h4{margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid rgba(165,124,55,0.4)}
.fc h4 a{color:#fff;text-decoration:none;font-size:16px;font-weight:500;letter-spacing:0.08em;display:flex;align-items:center;gap:8px;transition:color 0.2s}
.fc h4 a::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0}
.fc h4 a:hover{color:var(--gold3)}
.fc ul{list-style:none}
.fc li{margin-bottom:8px}
.fc a{color:rgba(255,255,255,0.55);text-decoration:none;font-size:16px;display:flex;align-items:center;gap:6px;transition:all 0.22s}
.fc a::before{content:'';width:4px;height:1px;background:rgba(255,255,255,0.25);flex-shrink:0;transition:width 0.22s,background 0.22s}
.fc a:hover{color:#fff;padding-left:4px}
.fc a:hover::before{width:8px;background:var(--gold)}
.fbot{display:flex;justify-content:space-between;align-items:center;padding:32px 0;font-size:12px;color:rgba(255,255,255,0.35);border-top:1px solid rgba(255,255,255,0.06)}
.fbot a{color:rgba(255,255,255,0.4);text-decoration:none;margin-left:16px;transition:color 0.2s}
.fbot a:hover{color:var(--gold3)}

/* ============================================================
   スマートフォン（768px以下）共通スタイル
   ============================================================ */
@media(max-width:768px){
  :root{--fs-base:12px;--fs-lg:18px;--fs-xl:24px;--fs-2xl:30px;--fs-3xl:36px;--sp-1:12px;--sp-2:24px;--sp-3:36px;--sp-4:48px;--sp-5:60px;--sp-7:72px}
  /* カーソル非表示 */
  .cursor-dot,.cursor-paw{display:none}
  /* ナビ */
  nav{padding:0 0 0 20px;height:56px}
  .nav-links{display:none}
  .nav-logo img{height:30px}
  .nav-right{gap:12px}
  .nav-cta{display:none}  /* SP時は購入CTAを非表示にしてハンバーガー表示領域を確保 */
  /* 検索ボタンSPで非表示 */
  .nav-search{display:none}
  /* ハンバーガーボタン */
  .nav-hamburger{
    display:flex !important;flex-direction:column;justify-content:center;align-items:center;
    gap:6px;width:44px;height:44px;
    background:none !important;border:none !important;cursor:pointer;padding:0;
    flex-shrink:0;visibility:visible !important;opacity:1 !important;
    padding-right:20px;margin-right:0;
  }
  .nav-hamburger span{
    display:block !important;width:24px;height:2px;
    background:#fff !important;border-radius:2px;
    transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
    transform-origin:center;
  }
  /* × アニメーション */
  .nav-hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
  .nav-hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .nav-drawer{display:block;position:fixed;top:56px;left:0;right:0;bottom:0;background:rgba(18,29,39,0.98);backdrop-filter:blur(16px);z-index:99;padding:36px 24px;transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.16,1,0.3,1);overflow-y:auto}
  .nav-drawer.open{transform:translateX(0)}
  .nav-drawer ul{list-style:none;display:flex;flex-direction:column}
  .nav-drawer li{border-bottom:1px solid rgba(255,255,255,0.07)}
  .nav-drawer a{display:block;padding:14px 0;color:rgba(255,255,255,0.8);text-decoration:none;font-size:14px;font-weight:400;transition:color 0.2s,padding-left 0.2s}
  .nav-drawer a:hover{color:var(--gold3);padding-left:8px}
  .nav-drawer-cta{display:block;margin-top:24px;background:var(--gold);color:#fff;text-align:center;padding:14px;font-size:13px;font-weight:500;text-decoration:none}
  /* ページヒーロー */
  .page-hero{height:240px;margin-top:56px}
  /* フッター */
  footer{padding:32px 20px 0}
  .footer-top{padding-bottom:20px;margin-bottom:20px}
  .footer-catch{font-size:12px}
  .footer-store-btn{font-size:12px;padding:10px 24px}
  .ft{grid-template-columns:1fr;gap:20px}
  .fc:last-child{grid-column:auto}
  .fc h4 a{font-size:12px}
  .fc a{font-size:11px}
  .fc li{margin-bottom:6px}
  .fbot{flex-direction:column;align-items:flex-start;gap:6px;font-size:10px}
  .fbot a{margin-left:0;margin-right:12px;font-size:10px}
  .float-btn{bottom:24px;right:16px;width:40px;height:40px}
}
