/*
Theme Name:  Griffin Team
Theme URI:   https://griffin-team.com
Description: Griffin Team 公式 WordPress テーマ — Rugby Online Private Brand
Author:      Griffin Corporation / M&Y Planning Services
Version:     2.0.0
Text Domain: griffin-team
*/

/* =============================================
   DESIGN TOKENS
   ============================================= */
:root {
  /* Colors */
  --bg:          #0a0a0a;
  --bg-2:        #111111;
  --bg-3:        #181818;
  --white:       #ffffff;
  --accent:      #c8a96e;   /* ゴールド */
  --accent-dim:  rgba(200,169,110,.15);

  --g06:  rgba(255,255,255,.06);
  --g10:  rgba(255,255,255,.10);
  --g20:  rgba(255,255,255,.20);
  --g35:  rgba(255,255,255,.35);
  --g55:  rgba(255,255,255,.55);
  --g70:  rgba(255,255,255,.70);
  --g85:  rgba(255,255,255,.85);

  --border:   rgba(255,255,255,.08);
  --border-2: rgba(255,255,255,.14);

  /* Fonts */
  --f-head:  'Cormorant Garamond', 'Noto Serif JP', Georgia, serif;
  --f-body:  'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  --f-mono:  'Montserrat', sans-serif;

  /* Sizes */
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 14px;
  --r-xl: 24px;
  --nav:  72px;
  --wrap: 1160px;
  --ease: cubic-bezier(.4,0,.2,1);
}

/* =============================================
   RESET
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--white);
  font-family:var(--f-body);font-size:15px;line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:opacity .25s var(--ease)}
a:hover{opacity:.72}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}

/* =============================================
   LAYOUT
   ============================================= */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:40px}
@media(max-width:640px){.wrap{padding-inline:20px}}

section.band{
  padding:80px 40px;
  border-top:1px solid var(--border);
}
section.band--dark{background:var(--bg-2)}
@media(max-width:640px){section.band{padding:56px 20px}}

/* =============================================
   TYPOGRAPHY
   ============================================= */
h1,h2,h3,h4{font-family:var(--f-head);font-weight:600;letter-spacing:.04em;line-height:1.2}
.eyebrow{
  font-family:var(--f-mono);font-size:10px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--g55);
}
.eyebrow--accent{color:var(--accent)}

/* =============================================
   HEADER / NAV
   ============================================= */
#hd{
  position:fixed;inset:0 0 auto 0;z-index:200;
  height:var(--nav);
  background:rgba(10,10,10,.90);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;
}
#hd .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}

/* ロゴ */
.hd-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--f-head);font-size:20px;font-weight:600;letter-spacing:.08em;
}
.hd-logo img{height:44px;width:auto}
.hd-logo-text span{display:block;font-family:var(--f-mono);font-size:8px;letter-spacing:.2em;color:var(--g55);margin-top:1px}

/* ナビ */
.hd-nav{display:flex;align-items:center;gap:2px}
.hd-nav a{
  font-family:var(--f-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--g55);padding:7px 14px;border-radius:var(--r-sm);
  transition:color .2s,background .2s;
}
.hd-nav a:hover,.hd-nav a[aria-current="page"]{color:var(--white);background:var(--g06);opacity:1}
.hd-nav .nav-shop{
  background:var(--white);color:var(--bg) !important;
  font-weight:700;margin-left:6px;
}
.hd-nav .nav-shop:hover{background:var(--g85);opacity:1}

/* ハンバーガー */
.hd-burger{display:none;flex-direction:column;gap:5px;padding:8px}
.hd-burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:.25s var(--ease)}
.hd-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hd-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hd-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media(max-width:960px){
  .hd-burger{display:flex}
  .hd-nav{
    display:none;position:fixed;
    top:var(--nav);inset-inline:0;
    background:rgba(10,10,10,.97);
    flex-direction:column;align-items:stretch;
    padding:16px 20px 24px;gap:0;
    border-bottom:1px solid var(--border);
  }
  .hd-nav.open{display:flex}
  .hd-nav a{padding:13px 12px;font-size:12px;border-bottom:1px solid var(--border)}
  .hd-nav .nav-shop{margin:16px 0 0;border-radius:var(--r-sm);text-align:center;justify-content:center}
}

/* =============================================
   HERO
   ============================================= */
.hero{
  padding-top:calc(var(--nav) + 72px);
  padding-bottom:88px;
  padding-inline:40px;
  position:relative;overflow:hidden;
}
/* グロー背景 */
.hero::before{
  content:'';position:absolute;
  top:-160px;right:-160px;width:640px;height:640px;
  background:radial-gradient(circle,rgba(200,169,110,.07) 0%,transparent 68%);
  pointer-events:none;
}
.hero-inner{
  max-width:var(--wrap);margin-inline:auto;
  display:grid;grid-template-columns:1fr 420px;gap:64px;align-items:center;
}
.hero-eyebrow{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);margin-bottom:18px;
}
.hero h1{
  font-size:clamp(38px,5.5vw,66px);line-height:1.05;margin-bottom:8px;
  color:var(--accent);font-weight:700;font-style:normal;
}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero-tagline{
  font-family:var(--f-head);font-size:clamp(14px,2vw,18px);
  font-style:italic;color:var(--g55);margin-bottom:16px;letter-spacing:.05em;
}
.hero-body{font-size:13.5px;color:var(--g55);line-height:2;max-width:440px;margin-bottom:36px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}

/* ライトカラムの視覚要素 */
.hero-visual{display:flex;flex-direction:column;gap:14px}
.hero-vcard{
  background:var(--g06);border:1px solid var(--border-2);
  border-radius:var(--r-lg);padding:28px 28px 22px;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.hero-vcard::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(200,169,110,.06) 0%,transparent 60%);
}
.hero-vcard-label{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--g35);margin-bottom:6px}
.hero-vcard-name{font-family:var(--f-head);font-size:22px;color:var(--white)}
.hero-vcard-sub{font-size:12px;color:var(--g55);margin-top:4px;line-height:1.6}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero{padding-top:calc(var(--nav)+52px);padding-bottom:60px;padding-inline:20px}
}

/* =============================================
   BUTTONS
   ============================================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;border-radius:var(--r-sm);border:1px solid transparent;
  font-family:var(--f-mono);font-size:11.5px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  transition:all .25s var(--ease);
}
.btn-white{background:var(--white);color:var(--bg)}
.btn-white:hover{background:var(--g85);opacity:1}
.btn-outline{background:transparent;color:var(--white);border-color:var(--border-2)}
.btn-outline:hover{background:var(--g06);opacity:1}
.btn-gold{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.btn-gold:hover{opacity:.82}

/* =============================================
   SECTION HEADER
   ============================================= */
.sh{margin-bottom:48px}
.sh .eyebrow{display:block;margin-bottom:12px}
.sh h2{font-size:clamp(26px,3.5vw,40px)}
.sh p{margin-top:14px;font-size:13.5px;color:var(--g55);line-height:1.9;max-width:520px}

/* =============================================
   CARD
   ============================================= */
.card{
  background:var(--g06);border:1px solid var(--border-2);
  border-radius:var(--r-lg);overflow:hidden;
  transition:background .25s,border-color .25s,transform .25s;
}
.card:hover{background:rgba(255,255,255,.09);border-color:var(--g20);transform:translateY(-3px)}
.card-img{
  aspect-ratio:4/3;background:var(--bg-3);
  display:flex;align-items:center;justify-content:center;font-size:52px;
  overflow:hidden;
}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-body{padding:22px 24px 26px}
.card-tag{font-family:var(--f-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.card-title{font-size:16px;font-weight:700;margin-bottom:6px}
.card-desc{font-size:12.5px;color:var(--g55);line-height:1.8}

/* =============================================
   PAGE HERO
   ============================================= */
.page-hero{
  padding-top:calc(var(--nav)+56px);padding-bottom:52px;
  padding-inline:40px;
  border-bottom:1px solid var(--border);
}
.page-hero .eyebrow{display:block;margin-bottom:14px}
.page-hero h1{font-size:clamp(28px,5vw,54px)}
.page-hero p{margin-top:14px;font-size:13.5px;color:var(--g55);max-width:540px;line-height:1.9}
@media(max-width:640px){.page-hero{padding-inline:20px;padding-top:calc(var(--nav)+40px)}}

/* =============================================
   PRODUCTS
   ============================================= */
.prod-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
@media(max-width:1024px){.prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.prod-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* カテゴリ行 */
.cat-row{
  display:grid;grid-template-columns:240px 1fr;gap:44px;align-items:start;
}
@media(max-width:768px){.cat-row{grid-template-columns:1fr}}

/* 粘着カテゴリナビ */
.cat-nav{
  position:sticky;top:var(--nav);z-index:100;
  background:rgba(10,10,10,.95);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);padding:0 40px;
}
.cat-nav-inner{
  max-width:var(--wrap);margin-inline:auto;
  display:flex;gap:4px;overflow-x:auto;padding:10px 0;
  scrollbar-width:none;
}
.cat-nav-inner::-webkit-scrollbar{display:none}
.cat-nav a{
  flex-shrink:0;font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--g55);
  padding:6px 14px;border-radius:var(--r-sm);white-space:nowrap;
  transition:color .2s,background .2s;
}
.cat-nav a:hover{color:var(--white);background:var(--g06);opacity:1}

/* =============================================
   CATALOG
   ============================================= */
.cat-dl-card{
  display:flex;align-items:center;gap:24px;
  background:var(--g06);border:1px solid var(--border-2);
  border-radius:var(--r-lg);padding:28px 32px;
  transition:background .25s,border-color .25s;
  max-width:760px;
}
.cat-dl-card:hover{background:rgba(255,255,255,.09);border-color:var(--g20)}
.cat-dl-icon{
  width:68px;height:68px;flex-shrink:0;
  background:var(--bg);border:1px solid var(--border-2);
  border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:26px;
}
.cat-dl-info{flex:1}
.cat-dl-info h3{font-size:17px;margin-bottom:5px}
.cat-dl-info p{font-size:12.5px;color:var(--g55)}
@media(max-width:640px){
  .cat-dl-card{flex-direction:column;text-align:center}
  .cat-dl-card .btn{width:100%;justify-content:center}
}

/* =============================================
   COMPANY TABLE
   ============================================= */
.co-table{width:100%;border-collapse:collapse}
.co-table th,.co-table td{
  padding:15px 18px;border-bottom:1px solid var(--border);
  font-size:13.5px;text-align:left;vertical-align:top;line-height:1.8;
}
.co-table th{width:160px;color:var(--g55);white-space:nowrap;font-weight:500}
.co-table td{color:var(--g85)}
.co-table td a{color:var(--accent)}
@media(max-width:580px){
  .co-table th,.co-table td{display:block;width:auto}
  .co-table th{padding-bottom:2px;border-bottom:none;font-size:11px}
  .co-table td{padding-top:2px}
}

/* =============================================
   CONTACT FORM
   ============================================= */
.cf-wrap{max-width:660px}
.wpcf7-form .cf-row,
.cf-row{margin-bottom:22px}
.wpcf7-form label,.cf-label{
  display:block;font-size:11.5px;font-weight:600;
  letter-spacing:.06em;color:var(--g70);margin-bottom:7px;
}
.req{color:var(--accent);margin-left:4px;font-size:10px}

.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=tel],
.wpcf7-form select,
.wpcf7-form textarea,
.cf-input{
  width:100%;background:var(--g06);
  border:1px solid var(--border-2);border-radius:var(--r-sm);
  padding:11px 15px;color:var(--white);
  font-family:var(--f-body);font-size:14px;
  transition:border-color .2s;appearance:none;
}
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus,
.cf-input:focus{outline:none;border-color:var(--g35)}
.wpcf7-form textarea,.cf-input.cf-textarea{min-height:130px;resize:vertical}

.wpcf7-form input[type=submit],.cf-submit{
  background:var(--white);color:var(--bg);border:none;
  padding:14px 36px;border-radius:var(--r-sm);
  font-family:var(--f-mono);font-size:11.5px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  transition:background .25s;
}
.wpcf7-form input[type=submit]:hover,.cf-submit:hover{background:var(--g85)}

/* reCAPTCHA バッジ非表示（利用規約は明示している場合のみ） */
.grecaptcha-badge{visibility:hidden}

/* =============================================
   FOOTER
   ============================================= */
#ft{background:var(--bg-2);border-top:1px solid var(--border);padding:60px 40px 28px}
.ft-inner{
  max-width:var(--wrap);margin-inline:auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid var(--border);
}
.ft-brand .hd-logo{margin-bottom:14px}
.ft-brand p{font-size:12.5px;color:var(--g55);line-height:1.9}
.ft-col h4{
  font-family:var(--f-mono);font-size:9.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--g35);margin-bottom:16px;
}
.ft-col ul{display:flex;flex-direction:column;gap:9px}
.ft-col a{font-size:12.5px;color:var(--g55)}
.ft-col a:hover{color:var(--white);opacity:1}
.ft-bottom{
  max-width:var(--wrap);margin-inline:auto;padding-top:22px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:11.5px;color:var(--g35);
}
@media(max-width:760px){
  #ft{padding:44px 20px 20px}
  .ft-inner{grid-template-columns:1fr 1fr;gap:28px}
  .ft-bottom{flex-direction:column;gap:6px;text-align:center}
}
@media(max-width:440px){.ft-inner{grid-template-columns:1fr}}

/* =============================================
   UTILITY / ANIMATION
   ============================================= */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:640px){.g2,.g3{grid-template-columns:1fr}}

.divider{border:none;border-top:1px solid var(--border);margin:0}

@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.fu{animation:fadeUp .55s ease both}
.fu:nth-child(2){animation-delay:.08s}
.fu:nth-child(3){animation-delay:.16s}
.fu:nth-child(4){animation-delay:.24s}
