﻿/*
Theme Name: Ryugaku YYC
Theme URI: https://ryugakuyyc.com/
Author: Ryugaku YYC
Description: カルガリー留学センター リュウガクYYC のカスタムテーマ。カルガリー特化・現地密着の留学エージェントとして、信頼感と読みやすさを重視した、自由に編集できる軽量テーマです。
Version: 1.0.3
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ryugakuyyc
*/

/* =========================================================
   デザインシステム（変数）
   ========================================================= */
:root{
  --yyc-red:#a31515;        /* ブランドの赤（ロゴ・アクセント） */
  --yyc-red-dark:#780000;   /* 濃い赤（ホバー等） */
  --yyc-ink:#222222;        /* 本文の黒 */
  --yyc-ink-soft:#555555;   /* やや薄い文字 */
  --yyc-muted:#777777;      /* キャプション */
  --yyc-line:#e8e8e8;       /* 罫線 */
  --yyc-bg:#ffffff;         /* 背景 */
  --yyc-bg-soft:#faf7f7;    /* ほんのり赤みのある背景 */
  --yyc-bg-tint:#fbf3f3;    /* バッジ等の薄赤 */
  --yyc-radius:14px;
  --yyc-radius-sm:8px;
  --yyc-shadow:0 8px 26px rgba(0,0,0,.06);
  --yyc-shadow-hover:0 14px 34px rgba(0,0,0,.10);
  --yyc-max:1100px;
  --yyc-gap:24px;
  --yyc-font: "Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic",Meiryo,sans-serif;
}

/* =========================================================
   ベース / リセット
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--yyc-font);
  color:var(--yyc-ink);
  background:var(--yyc-bg);
  line-height:1.85;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--yyc-red);text-decoration:none;transition:color .2s,opacity .2s;}
a:hover{color:var(--yyc-red-dark);}
h1,h2,h3,h4{line-height:1.45;margin:0 0 .6em;font-weight:700;color:var(--yyc-ink);}
p{margin:0 0 1.2em;}
ul{margin:0 0 1.2em;padding-left:1.3em;}

/* =========================================================
   レイアウト
   ========================================================= */
.yyc-container{max-width:var(--yyc-max);margin:0 auto;padding:0 20px;}
.yyc-section{padding:72px 0;}
.yyc-section--tint{background:var(--yyc-bg-soft);}
.yyc-section__head{text-align:center;max-width:720px;margin:0 auto 44px;}
.yyc-section__head::before{content:"";display:block;width:56px;height:31px;margin:0 auto 14px;background:url('assets/bear.png') center/contain no-repeat;}
.yyc-eyebrow{display:block;color:var(--yyc-red);letter-spacing:.22em;font-size:13px;font-weight:700;margin-bottom:10px;text-transform:uppercase;}
.yyc-title{font-size:30px;margin:0 0 14px;}
.yyc-lead{color:var(--yyc-ink-soft);font-size:16px;margin:0;}

/* =========================================================
   ボタン
   ========================================================= */
.yyc-btn{
  display:inline-block;background:var(--yyc-red);color:#fff;font-weight:700;
  padding:16px 40px;border-radius:var(--yyc-radius-sm);font-size:16px;border:2px solid var(--yyc-red);
}
.yyc-btn:hover{background:var(--yyc-red-dark);border-color:var(--yyc-red-dark);color:#fff;}
.yyc-btn--ghost{background:transparent;color:var(--yyc-red);}
.yyc-btn--ghost:hover{background:var(--yyc-red);color:#fff;}
.yyc-btn--lg{padding:18px 52px;font-size:17px;}

/* =========================================================
   ヘッダー
   ========================================================= */
.yyc-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-bottom:1px solid var(--yyc-line);}
.yyc-header__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:74px;}
.yyc-logo{font-weight:800;font-size:20px;color:var(--yyc-red);letter-spacing:.02em;}
.yyc-logo img{height:42px;width:auto;}
.yyc-nav{display:flex;align-items:center;gap:22px;}
.yyc-nav ul{display:flex;gap:22px;list-style:none;margin:0;padding:0;}
.yyc-nav a{color:var(--yyc-ink);font-weight:600;font-size:15px;}
.yyc-nav a:hover{color:var(--yyc-red);}
.yyc-nav > ul{align-items:center;}
.yyc-nav li{position:relative;}
.yyc-nav .menu-item-has-children > a::after{content:"▾";font-size:11px;margin-left:5px;color:var(--yyc-muted);}
.yyc-nav .sub-menu{list-style:none;position:absolute;top:calc(100% + 6px);left:0;min-width:210px;background:#fff;border:1px solid var(--yyc-line);border-radius:10px;box-shadow:var(--yyc-shadow);padding:8px 0;margin:0;display:none;z-index:60;}
/* 親項目とサブメニューの隙間を透明なブリッジで埋め、カーソル移動中も hover を維持 */
.yyc-nav .menu-item-has-children > a{padding-bottom:10px;margin-bottom:-10px;}
.yyc-nav .sub-menu::before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px;}
.yyc-nav li:hover > .sub-menu{display:block;}
.yyc-nav .sub-menu li{display:block;}
.yyc-nav .sub-menu a{display:block;padding:9px 18px;white-space:nowrap;font-weight:500;font-size:14px;}
.yyc-nav .sub-menu a:hover{background:var(--yyc-bg-soft);color:var(--yyc-red);}
.yyc-header__cta{display:inline-block;background:var(--yyc-red);color:#fff;font-weight:700;padding:11px 22px;border-radius:999px;font-size:14px;}
.yyc-header__cta:hover{background:var(--yyc-red-dark);color:#fff;}
.yyc-burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;}
.yyc-burger span{display:block;width:24px;height:2px;background:var(--yyc-ink);margin:5px auto;transition:.3s;}

/* =========================================================
   ヒーロー
   ========================================================= */
.yyc-hero{position:relative;background:#1a1a1a;color:#fff;overflow:hidden;}
.yyc-hero__media{position:absolute;inset:0;background-size:cover;background-position:center;}
.yyc-hero__bg{position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,16,38,.84) 0%,rgba(12,18,34,.70) 100%);}
.yyc-hero__inner{position:relative;z-index:2;max-width:var(--yyc-max);margin:0 auto;padding:110px 20px;text-align:center;}
.yyc-hero__eyebrow{color:#ffd9d9;letter-spacing:.2em;font-size:13px;font-weight:700;}
.yyc-hero__title{color:#fff;font-size:42px;line-height:1.5;margin:14px 0 18px;}
.yyc-hero__desc{color:#f0e6e6;max-width:720px;margin:0 auto 30px;font-size:17px;}
.yyc-hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.yyc-hero__note{margin-top:22px;color:#e7c9c9;font-size:13px;letter-spacing:.04em;}
.yyc-hero .yyc-btn--ghost{color:#fff;border-color:#fff;}
.yyc-hero .yyc-btn--ghost:hover{background:#fff;color:var(--yyc-red);}

/* =========================================================
   信頼ストリップ
   ========================================================= */
.yyc-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 16px;}
.yyc-trust span{display:inline-flex;align-items:center;gap:7px;background:var(--yyc-bg-tint);color:#7a1414;border:1px solid #f0dada;border-radius:999px;padding:9px 18px;font-size:14px;font-weight:600;}
.yyc-trust span::before{content:"\2714";color:var(--yyc-red);font-size:12px;}

/* =========================================================
   カードグリッド（選ばれる理由 / プログラム）
   ========================================================= */
.yyc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--yyc-gap);}
.yyc-card{background:#fff;border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);padding:30px 26px;box-shadow:var(--yyc-shadow);transition:transform .2s,box-shadow .2s;}
.yyc-card:hover{transform:translateY(-3px);box-shadow:var(--yyc-shadow-hover);}
.yyc-card__num{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:var(--yyc-red);color:#fff;font-weight:700;font-size:18px;margin-bottom:16px;}
.yyc-card h3{font-size:18px;margin:0 0 10px;}
.yyc-card p{font-size:14.5px;line-height:1.9;color:var(--yyc-ink-soft);margin:0;}
.yyc-card__link{display:inline-block;margin-top:14px;font-weight:700;font-size:14px;}
.yyc-card__link::after{content:" →";}

/* 代表メッセージ＋動画 */
.yyc-founder{display:grid;grid-template-columns:1.1fr 1fr;gap:38px;align-items:center;margin-top:54px;padding-top:48px;border-top:1px solid var(--yyc-line);}
.yyc-video{position:relative;padding-top:56.25%;border-radius:var(--yyc-radius);overflow:hidden;box-shadow:var(--yyc-shadow);background:#000;}
.yyc-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.yyc-founder__text .yyc-eyebrow{text-align:left;}
.yyc-founder__text h3{font-size:22px;margin:8px 0 14px;line-height:1.5;}
.yyc-founder__text p{color:var(--yyc-ink-soft);font-size:15px;line-height:1.95;margin:0 0 12px;}
.yyc-founder__name{font-weight:700;color:var(--yyc-ink);font-size:16px;margin-top:18px;}
.yyc-founder__name span{font-weight:500;color:var(--yyc-muted);font-size:13px;margin-left:8px;}
@media(max-width:880px){.yyc-founder{grid-template-columns:1fr;gap:24px;}}

/* コミュニティ カルーセル */
.yyc-carousel{position:relative;}
.yyc-carousel__viewport{position:relative;overflow:hidden;border-radius:var(--yyc-radius);box-shadow:var(--yyc-shadow);border:1px solid var(--yyc-line);}
.yyc-carousel__track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1);}
.yyc-slide{min-width:100%;display:grid;grid-template-columns:1.15fr 1fr;background:#fff;}
.yyc-slide__img{min-height:400px;background:center/cover no-repeat var(--yyc-bg-soft);}
.yyc-slide__body{padding:44px 40px;display:flex;flex-direction:column;justify-content:center;}
.yyc-slide__body h3{font-size:22px;margin:0 0 14px;line-height:1.5;}
.yyc-slide__body p{color:var(--yyc-ink-soft);font-size:15px;line-height:2;margin:0;}
.yyc-carousel__nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:var(--yyc-red);font-size:26px;line-height:44px;text-align:center;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.15);z-index:5;transition:background .2s;}
.yyc-carousel__nav:hover{background:#fff;}
.yyc-carousel__prev{left:14px;}
.yyc-carousel__next{right:14px;}
.yyc-carousel__dots{display:flex;justify-content:center;gap:9px;margin-top:20px;}
.yyc-carousel__dots button{width:9px;height:9px;border-radius:50%;border:0;background:#d8c4c4;cursor:pointer;padding:0;transition:all .2s;}
.yyc-carousel__dots button.is-active{background:var(--yyc-red);width:24px;border-radius:5px;}
@media(max-width:780px){
  .yyc-slide{grid-template-columns:1fr;}
  .yyc-slide__img{min-height:240px;}
  .yyc-slide__body{padding:26px 22px;}
  .yyc-carousel__nav{width:40px;height:40px;line-height:38px;font-size:22px;}
}

/* =========================================================
   なぜカルガリー（事実リスト）
   ========================================================= */
.yyc-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--yyc-gap);}
.yyc-fact{display:flex;gap:16px;background:#fff;border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);padding:24px;}
.yyc-fact__icon{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--yyc-bg-tint);color:var(--yyc-red);display:flex;align-items:center;justify-content:center;font-size:22px;}
.yyc-fact h3{font-size:16px;margin:0 0 6px;}
.yyc-fact p{font-size:14px;line-height:1.8;color:var(--yyc-ink-soft);margin:0;}

/* =========================================================
   サポートの流れ（ステップ）
   ========================================================= */
.yyc-steps{counter-reset:step;display:grid;grid-template-columns:repeat(7,1fr);gap:14px;}
.yyc-step{position:relative;background:#fff;border:1px solid var(--yyc-line);border-radius:var(--yyc-radius-sm);padding:22px 14px 18px;text-align:center;}
.yyc-step__n{counter-increment:step;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--yyc-red);color:#fff;font-weight:700;font-size:15px;margin-bottom:10px;}
.yyc-step__n::before{content:counter(step);}
.yyc-step p{font-size:13.5px;margin:0;line-height:1.6;color:var(--yyc-ink);}

/* =========================================================
   投稿カード（最新記事）
   ========================================================= */
.yyc-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--yyc-gap);}
.yyc-post{background:#fff;border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);overflow:hidden;transition:transform .2s,box-shadow .2s;}
.yyc-post:hover{transform:translateY(-3px);box-shadow:var(--yyc-shadow-hover);}
.yyc-post__thumb{aspect-ratio:16/10;background:var(--yyc-bg-soft) center/cover no-repeat;}
.yyc-post__body{padding:20px 22px;}
.yyc-post__cat{display:inline-block;background:var(--yyc-bg-tint);color:var(--yyc-red);font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;margin-bottom:10px;}
.yyc-post__title{font-size:16px;line-height:1.6;margin:0;}
.yyc-post__title a{color:var(--yyc-ink);}
.yyc-post__title a:hover{color:var(--yyc-red);}

/* =========================================================
   サマーキャンプ特集バナー
   ========================================================= */
.yyc-camp{display:grid;grid-template-columns:1.05fr 1fr;gap:0;align-items:stretch;background:var(--yyc-bg-tint);border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);overflow:hidden;box-shadow:var(--yyc-shadow);}
.yyc-camp__media{min-height:320px;}
.yyc-camp__media img{display:block;width:100%;height:100%;object-fit:cover;}
.yyc-camp__body{padding:38px 40px;display:flex;flex-direction:column;justify-content:center;}
.yyc-camp__body .yyc-eyebrow{color:var(--yyc-red);}
.yyc-camp__body .yyc-title{margin:8px 0 14px;}
.yyc-camp__body .yyc-lead{margin:0 0 22px;}
.yyc-camp__actions{display:flex;flex-wrap:wrap;gap:12px;}
@media(max-width:760px){
  .yyc-camp{grid-template-columns:1fr;}
  .yyc-camp__media{min-height:220px;}
  .yyc-camp__body{padding:26px 24px;}
}

/* =========================================================
   最終CTA
   ========================================================= */
.yyc-cta-final{background:linear-gradient(120deg,var(--yyc-red-dark),var(--yyc-red));color:#fff;text-align:center;}
.yyc-cta-final .yyc-title{color:#fff;}
.yyc-cta-final p{color:#ffe7e7;max-width:680px;margin:0 auto 26px;}
.yyc-cta-final .yyc-btn{background:#fff;color:var(--yyc-red);border-color:#fff;}
.yyc-cta-final .yyc-btn:hover{background:#ffe9e9;color:var(--yyc-red-dark);}

/* =========================================================
   フッター
   ========================================================= */
.yyc-footer{background:#1c1c1c;color:#cfcfcf;padding:56px 0 28px;font-size:14px;}
.yyc-footer a{color:#e6e6e6;}
.yyc-footer a:hover{color:#fff;}
.yyc-footer__cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:36px;}
.yyc-footer h4{color:#fff;font-size:15px;margin:0 0 14px;}
.yyc-footer ul{list-style:none;margin:0;padding:0;}
.yyc-footer li{margin-bottom:8px;}
.yyc-footer__brand p{color:#a9a9a9;font-size:13.5px;line-height:1.8;}
.yyc-footer__logo{display:inline-block;margin-bottom:16px;}
.yyc-footer__logo img{height:38px;width:auto;}
.yyc-footer__contact{margin-bottom:14px;}
.yyc-footer__ig{display:inline-flex;align-items:center;gap:8px;color:#e6e6e6;font-weight:600;}
.yyc-footer__ig svg{flex:0 0 auto;}
.yyc-footer__ig:hover{color:#fff;}
.yyc-footer__bottom{border-top:1px solid #333;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#9a9a9a;font-size:13px;}
.yyc-footer__legal{display:inline-flex;flex-wrap:wrap;gap:18px;}

/* =========================================================
   固定ページ・記事ヘッダー
   ========================================================= */
.yyc-page-head{background:var(--yyc-bg-tint);border-bottom:1px solid var(--yyc-line);padding:46px 0;text-align:center;}
.yyc-page-head .yyc-eyebrow{color:var(--yyc-red);}
.yyc-page-head h1{font-size:30px;line-height:1.4;margin:6px 0 0;color:var(--yyc-ink);}
.yyc-page-head p{margin:12px auto 0;max-width:680px;color:var(--yyc-ink-soft);}
.yyc-breadcrumb{font-size:13px;color:var(--yyc-ink-soft);margin-bottom:8px;}
.yyc-breadcrumb a{color:var(--yyc-ink-soft);}
.yyc-breadcrumb a:hover{color:var(--yyc-red);}

/* =========================================================
   本文タイポグラフィ（固定ページ・記事共通）
   ========================================================= */
.yyc-entry{font-size:16px;line-height:1.95;color:var(--yyc-ink);}
.yyc-entry > *:first-child{margin-top:0;}
.yyc-entry p{margin:0 0 1.5em;}
.yyc-entry h2{font-size:24px;line-height:1.5;margin:2em 0 .7em;padding-bottom:.4em;border-bottom:2px solid var(--yyc-line);}
.yyc-entry h3{font-size:20px;line-height:1.5;margin:1.8em 0 .6em;padding-left:14px;border-left:4px solid var(--yyc-red);}
.yyc-entry h4{font-size:17px;margin:1.6em 0 .5em;}
.yyc-entry a{color:var(--yyc-red);text-decoration:underline;text-underline-offset:2px;}
.yyc-entry a:hover{color:var(--yyc-red-dark);}
.yyc-entry strong{font-weight:700;}
.yyc-entry ul,.yyc-entry ol{margin:0 0 1.5em;padding-left:1.4em;}
.yyc-entry li{margin-bottom:.5em;}
.yyc-entry ul li::marker{color:var(--yyc-red);}
.yyc-entry img{max-width:100%;height:auto;border-radius:var(--yyc-radius);}
.yyc-entry figure{margin:1.8em 0;}
.yyc-entry figcaption{font-size:13px;color:var(--yyc-ink-soft);text-align:center;margin-top:8px;}
.yyc-entry blockquote{margin:1.8em 0;padding:18px 22px;background:var(--yyc-bg-soft);border-left:4px solid var(--yyc-red);border-radius:0 var(--yyc-radius) var(--yyc-radius) 0;color:var(--yyc-ink-soft);}
.yyc-entry blockquote p:last-child{margin-bottom:0;}
.yyc-entry hr{border:0;border-top:1px solid var(--yyc-line);margin:2.4em 0;}
.yyc-entry table{width:100%;border-collapse:collapse;margin:1.8em 0;font-size:15px;}
.yyc-entry th,.yyc-entry td{border:1px solid var(--yyc-line);padding:12px 14px;text-align:left;}
.yyc-entry th{background:var(--yyc-bg-tint);font-weight:700;}
.yyc-entry tr:nth-child(even) td{background:var(--yyc-bg-soft);}
.yyc-entry code{background:var(--yyc-bg-soft);padding:2px 6px;border-radius:4px;font-size:.92em;}
.yyc-entry .wp-block-button__link,.yyc-entry .yyc-btn{text-decoration:none;}
.yyc-entry > *{max-width:100%;}

/* FAQ アコーディオン */
.yyc-entry .yyc-faq{border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);margin:0 0 12px;overflow:hidden;background:#fff;}
.yyc-entry .yyc-faq > summary{list-style:none;cursor:pointer;padding:18px 52px 18px 22px;font-weight:700;font-size:16px;position:relative;color:var(--yyc-ink);}
.yyc-entry .yyc-faq > summary::-webkit-details-marker{display:none;}
.yyc-entry .yyc-faq > summary::before{content:"Q";color:var(--yyc-red);font-weight:800;margin-right:10px;}
.yyc-entry .yyc-faq > summary::after{content:"";position:absolute;right:22px;top:50%;width:10px;height:10px;border-right:2px solid var(--yyc-red);border-bottom:2px solid var(--yyc-red);transform:translateY(-70%) rotate(45deg);transition:transform .25s;}
.yyc-entry .yyc-faq[open] > summary::after{transform:translateY(-30%) rotate(-135deg);}
.yyc-entry .yyc-faq[open] > summary{border-bottom:1px solid var(--yyc-line);}
.yyc-entry .yyc-faq > summary:hover{color:var(--yyc-red);}
.yyc-entry .yyc-faq > p{margin:0;padding:18px 22px;background:var(--yyc-bg-soft);}

/* 既存記事の黄色マーカー（q_underline）をブランド統一 */
.yyc-entry .q_underline{background:linear-gradient(transparent 58%, #ffe9a8 58%);padding:0 2px;border-bottom:0 !important;font-weight:600;}

/* 吹き出し（TCD互換 speech_balloon） */
.yyc-balloon{display:flex;align-items:flex-start;gap:14px;margin:1.8em 0;}
.yyc-balloon--right{flex-direction:row-reverse;}
.yyc-balloon__avatar{flex:0 0 auto;width:74px;text-align:center;}
.yyc-balloon__avatar img{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--yyc-line);display:block;margin:0 auto;}
.yyc-balloon__name{display:block;font-size:12px;color:var(--yyc-ink-soft);margin-top:4px;line-height:1.3;}
.yyc-balloon__body{position:relative;flex:1 1 auto;background:var(--yyc-bg-tint);border:1px solid var(--yyc-line);border-radius:14px;padding:14px 18px;}
.yyc-balloon__body > *:first-child{margin-top:0;}
.yyc-balloon__body > *:last-child{margin-bottom:0;}
.yyc-balloon__body p{font-size:15px;line-height:1.85;margin:0 0 .8em;}
.yyc-balloon__body::before{content:"";position:absolute;top:22px;width:0;height:0;border:8px solid transparent;}
.yyc-balloon--left .yyc-balloon__body::before{left:-16px;border-right-color:var(--yyc-line);}
.yyc-balloon--right .yyc-balloon__body::before{right:-16px;border-left-color:var(--yyc-line);}

/* 囲み枠（TCD互換 well2） */
.yyc-entry .well2{background:var(--yyc-bg-soft);border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);padding:18px 22px;margin:1.6em 0;}
.yyc-entry .well2 > *:first-child{margin-top:0;}
.yyc-entry .well2 > *:last-child{margin-bottom:0;}
.yyc-entry .well2 ul{margin:0;}

/* ボタン（TCD互換 q_custom_button / q_button_wrap） */
.yyc-entry .q_button_wrap{text-align:center;margin:1.8em 0;}
.yyc-entry .q_custom_button{display:inline-flex;align-items:center;justify-content:center;background:#a31515 !important;color:#fff !important;font-weight:700;text-decoration:none !important;padding:14px 30px;border-radius:999px;min-width:200px;max-width:100%;transition:background .2s;border:0 !important;box-shadow:none !important;}
.yyc-entry .q_custom_button:hover{background:#780000 !important;color:#fff !important;}

/* 内部リンクカード（TCD互換 [clink]） */
.yyc-entry .yyc-clink{display:flex;align-items:center;gap:16px;margin:1.6em 0;padding:14px 18px;border:1px solid var(--yyc-line);border-radius:var(--yyc-radius);background:#fff;box-shadow:var(--yyc-shadow);transition:box-shadow .2s,transform .2s;text-decoration:none !important;}
.yyc-entry .yyc-clink:hover{box-shadow:var(--yyc-shadow-hover);transform:translateY(-2px);}
.yyc-entry .yyc-clink__thumb{flex:0 0 auto;width:88px;height:64px;border-radius:8px;background:var(--yyc-bg-soft) center/cover no-repeat;}
.yyc-entry .yyc-clink__body{display:flex;flex-direction:column;gap:3px;min-width:0;}
.yyc-entry .yyc-clink__title{color:var(--yyc-ink);font-weight:700;font-size:16px;line-height:1.5;}
.yyc-entry .yyc-clink__more{color:var(--yyc-red);font-size:13px;font-weight:600;}

/* TCD互換：装飾付き番号リスト */
.yyc-entry .q_styled_ol{list-style:decimal;padding-left:1.5em;}
.yyc-entry .q_styled_ol li{margin-bottom:.5em;}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media(max-width:980px){
  .yyc-grid,.yyc-posts{grid-template-columns:repeat(2,1fr);}
  .yyc-facts{grid-template-columns:1fr;}
  .yyc-steps{grid-template-columns:repeat(2,1fr);}
  .yyc-footer__cols{grid-template-columns:1fr 1fr;}
}
@media(max-width:680px){
  .yyc-section{padding:52px 0;}
  .yyc-title{font-size:24px;}
  .yyc-hero__title{font-size:30px;}
  .yyc-hero__inner{padding:80px 20px;}
  .yyc-grid,.yyc-posts,.yyc-steps{grid-template-columns:1fr;}
  .yyc-footer__cols{grid-template-columns:1fr;}
  /* モバイルメニュー */
  .yyc-nav{position:fixed;inset:74px 0 auto 0;background:#fff;border-bottom:1px solid var(--yyc-line);flex-direction:column;align-items:stretch;padding:10px 20px 20px;gap:0;transform:translateY(-120%);transition:transform .3s;box-shadow:var(--yyc-shadow);}
  .yyc-nav.is-open{transform:translateY(0);}
  .yyc-nav ul{flex-direction:column;gap:0;}
  .yyc-nav li{border-bottom:1px solid var(--yyc-line);}
  .yyc-nav a{display:block;padding:14px 4px;}
  .yyc-nav .sub-menu{position:static;display:block;box-shadow:none;border:0;padding:0 0 6px 16px;min-width:0;}
  .yyc-nav .sub-menu li{border:0;}
  .yyc-nav .sub-menu a{padding:9px 4px;color:var(--yyc-ink-soft);}
  .yyc-nav .menu-item-has-children > a::after{display:none;}
  .yyc-header__cta{display:none;}
  .yyc-burger{display:block;}
}
