/*
Theme Name: 個人パソコンレッスン
Theme URI: https://nagoyapc.com/
Author: 大野 裕哉
Author URI: https://nagoyapc.com/
Description: オンライン個人パソコンレッスンの公式テーマ。トップ・ブログ一覧・記事ページを同一デザインで提供します。カテゴリ（パソコン豆知識 / ガジェット紹介 / AI活用 / お知らせ）に応じて記事末のCTAを自動で出し分けます。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
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: pclesson
*/

:root{
  --ink:#16202e;--muted:#5d6b7d;--line:#e7ecf2;--bg:#ffffff;--soft:#f5f8fc;
  --blue:#1d6fe0;--blue-d:#155bbd;--sky:#2ba8e0;--blue-tint:#eaf2fd;
  --grn:#1f8a52;--grn-tint:#e8f4ec;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Zen Kaku Gothic New",sans-serif;color:var(--ink);background:var(--bg);line-height:1.8;-webkit-font-smoothing:antialiased}
.en{font-family:"Outfit",sans-serif}
.wrap{max-width:1160px;margin:0 auto;padding:0 30px}
a{color:inherit;text-decoration:none}
img{max-width:100%}

.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15.5px;padding:14px 28px;border-radius:14px;transition:.15s;cursor:pointer;border:none}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 24px -12px rgba(29,111,224,.8)}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-2px)}
.btn-ghost{background:var(--soft);color:var(--ink)}
.btn-ghost:hover{background:var(--blue-tint);color:var(--blue)}

/* image holders + placeholders */
.hero-shot,.tshot,.lcard .ph,.post .ph,.cover,.inl,.byline .av,.bio .av,.art-head .av{background:linear-gradient(135deg,#eef4fb,#e3eef9);overflow:hidden}
.hero-shot>img,.tshot>img,.lcard .ph>img,.post .ph>img,.cover>img,.inl>img,.av>img{width:100%;height:100%;object-fit:cover;display:block}
.img-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9db4cf;font-size:13px;text-align:center;padding:18px;line-height:1.5}

/* header */
header.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.8);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
body.admin-bar header.nav{top:32px}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:11px}
.logo svg{width:36px;height:36px}
.logo b{font-size:17px;font-weight:900;letter-spacing:-.01em}
.menu{display:flex;align-items:center;gap:32px}
.menu .lnk{font-size:14px;font-weight:500;color:var(--muted);white-space:nowrap}
.menu .lnk:hover,.menu .lnk.on{color:var(--blue)}
.nav .btn{padding:10px 20px;font-size:14px}
@media(max-width:900px){.menu .lnk{display:none}}
@media(max-width:782px){body.admin-bar header.nav{top:46px}}

/* hero */
.hero{text-align:center;padding:80px 0 0;position:relative;overflow:hidden;background:radial-gradient(70% 60% at 50% 0%,rgba(43,168,224,.1),transparent 60%)}
.tagchip{display:inline-flex;align-items:center;gap:8px;background:var(--blue-tint);color:var(--blue);font-size:13px;font-weight:700;padding:8px 16px;border-radius:999px;margin-bottom:26px}
.hero h1{font-size:clamp(36px,5.6vw,64px);font-weight:900;line-height:1.22;letter-spacing:-.02em;margin-bottom:24px}
.hero h1 .grad{background:linear-gradient(120deg,var(--blue),var(--sky));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:18.5px;color:var(--muted);max-width:620px;margin:0 auto 34px}
.hero-cta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-bottom:18px}
.hero-meta{font-size:13.5px;color:var(--muted);display:flex;gap:22px;justify-content:center;flex-wrap:wrap}
.hero-meta span{display:inline-flex;align-items:center;gap:7px}
.hero-meta svg{width:16px;height:16px;color:var(--blue)}
.hero-stage{margin-top:56px;position:relative}
.browser{max-width:920px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:18px 18px 0 0;box-shadow:0 40px 80px -40px rgba(22,32,46,.4);overflow:hidden}
.bbar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line)}
.bbar i{width:11px;height:11px;border-radius:50%;display:block}
.bbar .u{margin-left:14px;background:var(--soft);border-radius:7px;height:22px;flex:1;max-width:300px}
.hero-shot{height:420px;width:100%;display:block}

/* section */
.section{padding:96px 0}
.head{text-align:center;max-width:680px;margin:0 auto 56px}
.kick{font-family:"Outfit";font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
h2{font-size:clamp(28px,3.6vw,42px);font-weight:900;line-height:1.32;letter-spacing:-.01em;margin-bottom:16px}
.head p{font-size:17px;color:var(--muted)}

/* bento */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:18px}
.cell{background:var(--soft);border:1px solid var(--line);border-radius:24px;padding:30px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;transition:.18s}
.cell:hover{border-color:#cfe0f5;transform:translateY(-4px)}
.cell h3{font-size:21px;font-weight:900;margin-bottom:8px;letter-spacing:-.01em}
.cell p{font-size:14px;color:var(--muted)}
.cell .ic{position:absolute;top:26px;left:30px;width:46px;height:46px;border-radius:13px;background:#fff;border:1px solid var(--line);display:grid;place-items:center}
.cell .ic svg{width:24px;height:24px;color:var(--blue)}
.c-wide{grid-column:span 2}
.c-tall{grid-row:span 2}
.cell.blue{background:linear-gradient(150deg,var(--blue),var(--sky));border:none;color:#fff}
.cell.blue p{color:rgba(255,255,255,.85)}
.cell.blue .ic{background:rgba(255,255,255,.18);border:none}
.cell.blue .ic svg{color:#fff}
.cell .big{font-family:"Outfit";font-weight:800;font-size:52px;line-height:1;margin-bottom:6px}

/* lessons */
.lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lcard{border:1px solid var(--line);border-radius:22px;overflow:hidden;transition:.18s;background:#fff}
.lcard:hover{box-shadow:0 26px 50px -30px rgba(22,32,46,.35);transform:translateY(-5px)}
.lcard .ph{height:180px}
.lcard .b{padding:22px 24px 26px}
.lcard .num{font-family:"Outfit";font-size:12px;font-weight:700;color:var(--blue);letter-spacing:.1em;margin-bottom:9px}
.lcard h3{font-size:19px;font-weight:900;margin-bottom:8px;display:flex;align-items:center;gap:9px}
.lcard p{font-size:14px;color:var(--muted)}
.pillnew{font-size:11px;font-weight:700;background:var(--blue);color:#fff;padding:3px 9px;border-radius:999px}

/* ai split */
.ai{background:var(--ink);color:#fff;border-radius:36px;overflow:hidden;margin:0 30px;max-width:1160px;margin-left:auto;margin-right:auto}
.ai-in{display:grid;grid-template-columns:1fr 1fr}
.ai-left{padding:70px 56px}
.ai-left .kick{color:var(--sky)}
.ai-left h2{color:#fff}
.ai-left p{color:rgba(255,255,255,.72);font-size:16px;margin-bottom:28px}
.ai-feat{display:grid;gap:14px;margin-bottom:32px}
.ai-feat .r{display:flex;gap:13px;align-items:center;font-size:15px}
.ai-feat .r span{width:30px;height:30px;border-radius:9px;background:rgba(43,168,224,.2);color:var(--sky);display:grid;place-items:center;flex:none}
.ai-feat .r svg{width:16px;height:16px}
.ai-right{background:linear-gradient(160deg,#1d6fe0,#2ba8e0);padding:56px 50px;display:flex;align-items:center}
.ai-panel{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:20px;padding:26px;width:100%;backdrop-filter:blur(6px)}
.ai-panel .ttl{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.ai-panel .ttl span{width:9px;height:9px;border-radius:50%;background:#7ef0b0}
.msg{background:rgba(255,255,255,.96);color:var(--ink);border-radius:14px;padding:14px 16px;font-size:14px;margin-bottom:12px}
.msg.me{background:rgba(255,255,255,.16);color:#fff}
.msg b{color:var(--blue)}

/* flow */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stp{padding:0 6px}
.stp .n{font-family:"Outfit";font-weight:800;font-size:14px;color:var(--blue);background:var(--blue-tint);width:40px;height:40px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px}
.stp h3{font-size:18px;font-weight:900;margin-bottom:8px}
.stp p{font-size:14px;color:var(--muted)}
.stp .bar{height:2px;background:var(--line);margin:24px 0 0;position:relative}
.stp .bar::before{content:"";position:absolute;left:0;top:0;height:2px;width:40%;background:var(--blue)}

/* pricing */
.pricing{background:var(--soft)}
.ptable{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ptable.two{grid-template-columns:repeat(2,1fr);max-width:720px;margin:0 auto}
.pcol{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px 30px;display:flex;flex-direction:column}
.pcol.feat{border:2px solid var(--blue);position:relative}
.pcol .badge{position:absolute;top:-13px;left:30px;background:var(--blue);color:#fff;font-size:12px;font-weight:700;padding:6px 16px;border-radius:999px}
.pcol .nm{font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.05em;margin-bottom:14px}
.pcol .amt{font-family:"Outfit";font-weight:800;font-size:44px;line-height:1;letter-spacing:-.02em;margin-bottom:4px}
.pcol .amt small{font-size:18px;font-weight:600}
.pcol .per{font-size:13.5px;color:var(--muted);margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.pcol ul{list-style:none;display:grid;gap:12px;margin-bottom:28px;flex:1}
.pcol li{display:flex;gap:10px;font-size:14.5px;align-items:flex-start}
.pcol li svg{width:18px;height:18px;color:var(--blue);flex:none;margin-top:3px}
.pcol .btn{justify-content:center}
.ptopics{max-width:720px;margin:34px auto 0;background:#fff;border:1px solid var(--line);border-radius:22px;padding:28px 30px}
.ptopics h4{font-size:14px;font-weight:700;margin-bottom:16px;color:var(--ink)}
.pchips{display:flex;flex-wrap:wrap;gap:10px}
.pchips span{display:inline-flex;align-items:center;gap:7px;font-size:14px;background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:9px 16px;color:var(--ink)}
.pchips span::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--blue);flex:none}

/* category pill */
.cat{font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:999px;white-space:nowrap;background:#eef1f5;color:#5d6b7d}
.cat.tips{background:var(--blue-tint);color:var(--blue)}
.cat.ai{background:#e3f5fb;color:#1496c8}
.cat.news{background:#fdefe4;color:#c9711f}
.cat.gadget{background:var(--grn-tint);color:var(--grn)}

/* blog cards */
.bloggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
.post:hover{box-shadow:0 26px 50px -30px rgba(22,32,46,.35);transform:translateY(-5px)}
.post .ph{height:190px}
.post .b{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.post .meta{display:flex;align-items:center;gap:10px;margin-bottom:13px}
.post .date{font-family:"Outfit";font-size:12.5px;color:var(--muted)}
.post h3{font-size:18px;font-weight:900;line-height:1.5;margin-bottom:10px;letter-spacing:-.01em}
.post .ex{font-size:14px;color:var(--muted);flex:1}
.post .more{margin-top:16px;font-size:13.5px;font-weight:700;color:var(--blue);display:inline-flex;align-items:center;gap:6px}
.post .more svg{width:15px;height:15px}
.blog-foot{text-align:center;margin-top:48px}
@media(max-width:900px){.bloggrid{grid-template-columns:1fr}}

/* teacher */
.tin{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
.tshot{height:520px;width:100%;max-width:380px;justify-self:start;border-radius:26px}
.tin .kick{color:var(--blue)}
.tin h2{margin-bottom:4px}
.tin .role{font-family:"Outfit";color:var(--sky);font-size:14px;letter-spacing:.08em;margin-bottom:22px;font-weight:600}
.tin p{font-size:16px;color:var(--muted);margin-bottom:16px}
.tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.tags span{font-size:13px;background:var(--blue-tint);color:var(--blue);padding:7px 14px;border-radius:999px;font-weight:600}

/* faq */
.faq{max-width:800px;margin:0 auto}
details{border-bottom:1px solid var(--line);padding:8px 0}
summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:14px;padding:18px 4px;font-size:17px;font-weight:700}
summary::-webkit-details-marker{display:none}
summary .pm{margin-left:auto;color:var(--blue);transition:.2s}
details[open] summary .pm{transform:rotate(45deg)}
summary .pm svg{width:22px;height:22px}
.ans{padding:0 4px 20px 0;font-size:15px;color:var(--muted)}

/* final cta */
.final{text-align:center;background:linear-gradient(150deg,var(--blue),var(--sky));color:#fff;border-radius:36px;margin:0 auto;max-width:1160px;padding:80px 30px}
.final h2{color:#fff;margin-bottom:14px}
.final p{font-size:17px;color:rgba(255,255,255,.88);margin-bottom:32px}
.final .btn{background:#fff;color:var(--blue);font-size:16px;padding:16px 34px}
.final .btn:hover{transform:translateY(-2px)}

/* ---- blog listing page ---- */
.phead{text-align:center;padding:72px 0 52px;background:radial-gradient(70% 90% at 50% 0%,rgba(43,168,224,.1),transparent 65%)}
.phead .kick{margin-bottom:14px}
.phead h1{font-size:clamp(32px,4.4vw,48px);font-weight:900;letter-spacing:-.02em;margin-bottom:16px}
.phead p{font-size:17px;color:var(--muted);max-width:600px;margin:0 auto}
.filter{display:flex;gap:11px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.fchip{font-size:14px;font-weight:700;padding:10px 22px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;transition:.15s}
.fchip:hover{border-color:#cfe0f5;color:var(--blue)}
.fchip.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.pagi{display:flex;gap:8px;justify-content:center;margin-top:56px;flex-wrap:wrap}
.pagi .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border-radius:12px;border:1px solid var(--line);font-family:"Outfit";font-weight:600;font-size:15px;color:var(--muted)}
.pagi .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}
.pagi a.page-numbers:hover{border-color:var(--blue);color:var(--blue)}
.emptynote{text-align:center;color:var(--muted);padding:60px 0;font-size:16px}

/* ---- single article ---- */
.art{max-width:760px;margin:0 auto;padding:0 30px}
.crumb{font-size:13px;color:var(--muted);padding:32px 0 0}
.crumb a:hover{color:var(--blue)}
.art-head{padding:26px 0 30px}
.art-head .meta{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.art-head .date{font-family:"Outfit";font-size:13px;color:var(--muted)}
.art-head h1{font-size:clamp(28px,4vw,40px);font-weight:900;line-height:1.4;letter-spacing:-.01em}
.byline{display:flex;align-items:center;gap:13px;margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.byline .av{width:46px;height:46px;border-radius:50%;flex:none}
.byline .nm{font-size:14.5px;font-weight:700}
.byline .rl{font-size:12.5px;color:var(--muted)}
.cover{height:420px;border-radius:24px;margin:8px auto 44px;max-width:900px}

.body{font-size:17px;color:#2c3a4c}
.body p{margin-bottom:26px}
.body h2{font-size:25px;font-weight:900;letter-spacing:-.01em;margin:46px 0 18px;line-height:1.5}
.body h2::before{content:"";display:block;width:46px;height:4px;border-radius:4px;background:linear-gradient(90deg,var(--blue),var(--sky));margin-bottom:16px}
.body h3{font-size:20px;font-weight:900;margin:34px 0 12px}
.body ul,.body ol{margin:0 0 26px;padding-left:6px;display:grid;gap:13px}
.body ul{list-style:none}
.body ul li{position:relative;padding-left:30px;font-size:16.5px}
.body ul li::before{content:"";position:absolute;left:3px;top:.72em;width:9px;height:9px;border-radius:50%;background:var(--blue)}
.body ol{padding-left:1.5em;font-size:16.5px}
.body ol li{padding-left:4px}
.body a{color:var(--blue);text-decoration:underline}
.body strong{font-weight:700}
.body img{max-width:100%;height:auto;border-radius:16px;display:block}
.body figure{margin:0 0 26px}
.body figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:8px}
/* WordPress 画像ブロックを「ふつうに」本文幅で表示 */
.body .wp-block-image:not(.inl){display:block;margin:0 0 26px}
.body .wp-block-image:not(.inl) img{width:100%;height:auto;border-radius:16px}
.body .wp-block-image.is-resized img,.body .wp-block-image.size-thumbnail img,.body .wp-block-image.size-medium img{width:auto;max-width:100%}
.body .wp-block-image.aligncenter{text-align:center}
.body .wp-block-image.aligncenter img{margin-left:auto;margin-right:auto}
.body .wp-block-image.alignleft{float:left;margin:4px 26px 18px 0;max-width:48%}
.body .wp-block-image.alignright{float:right;margin:4px 0 18px 26px;max-width:48%}
.body .wp-block-image.alignleft img,.body .wp-block-image.alignright img{width:100%}
.body .wp-block-image figcaption{margin-top:8px}
.body blockquote{border-left:4px solid var(--blue);background:var(--soft);border-radius:0 12px 12px 0;padding:16px 22px;margin:0 0 26px;color:var(--muted)}
.inl{height:340px;border-radius:18px;margin:8px 0 30px}
.cap{font-size:13px;color:var(--muted);text-align:center;margin:-18px 0 34px}

/* callout pattern */
.callout{background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:14px;padding:24px 28px;margin:0 0 30px}
.callout .lb{font-size:12.5px;font-weight:700;color:var(--blue);letter-spacing:.06em;margin-bottom:7px;display:flex;align-items:center;gap:7px}
.callout .lb svg{width:16px;height:16px}
.callout p{font-size:15.5px;margin:0;color:var(--muted)}

/* scorecard pattern */
.scorecard{border:1px solid var(--line);border-radius:18px;overflow:hidden;margin:0 0 34px}
.scorecard .sc-top{background:var(--grn-tint);padding:18px 24px;font-size:14px;font-weight:700;color:var(--grn);display:flex;align-items:center;gap:9px}
.scorecard .sc-top svg{width:18px;height:18px}
.scorecard .row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:15px 24px;border-top:1px solid var(--line);font-size:15px}
.scorecard .row b{font-weight:700}
.stars{color:var(--grn);font-size:15px;letter-spacing:2px;flex:none}

/* in-article CTAs */
.lessoncta{background:linear-gradient(150deg,var(--blue),var(--sky));color:#fff;border-radius:24px;padding:40px;margin:44px 0;text-align:center}
.lessoncta .pill{display:inline-block;font-size:12px;font-weight:700;background:rgba(255,255,255,.2);padding:5px 14px;border-radius:999px;margin-bottom:16px}
.lessoncta h3{font-size:23px;font-weight:900;margin-bottom:10px;line-height:1.5}
.lessoncta p{font-size:15px;color:rgba(255,255,255,.9);margin-bottom:24px}
.lessoncta .btn{background:#fff;color:var(--blue)}
.lessoncta .btn:hover{transform:translateY(-2px)}
.buycta{background:linear-gradient(150deg,#157a47,#2bb673);color:#fff;border-radius:24px;padding:42px 40px;margin:44px 0;text-align:center}
.buycta .pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;background:rgba(255,255,255,.2);padding:6px 15px;border-radius:999px;margin-bottom:16px}
.buycta .pill svg{width:14px;height:14px}
.buycta h3{font-size:24px;font-weight:900;margin-bottom:12px;line-height:1.5}
.buycta p{font-size:15px;color:rgba(255,255,255,.92);margin-bottom:24px;max-width:520px;margin-left:auto;margin-right:auto}
.buysteps{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.buysteps .s{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:12px 18px;font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:9px}
.buysteps .s .n{font-family:"Outfit";font-weight:800;font-size:13px;background:#fff;color:var(--grn);width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex:none}
.buycta .btn{background:#fff;color:var(--grn)}
.buycta .btn:hover{transform:translateY(-2px)}

/* author bio */
.bio{display:flex;gap:22px;align-items:flex-start;background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:30px;margin:48px 0 0}
.bio .av{width:84px;height:84px;border-radius:18px;flex:none}
.bio .role{font-family:"Outfit";color:var(--sky);font-size:12px;letter-spacing:.07em;font-weight:600;margin:2px 0 10px}
.bio h4{font-size:18px;font-weight:900;margin-bottom:2px}
.bio p{font-size:14px;color:var(--muted)}
.artnav{display:flex;justify-content:center;margin:56px 0 0}

/* footer */
footer.site{padding:64px 0 28px;border-top:1px solid var(--line);margin-top:96px}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:40px}
.fgrid .about{font-size:14px;color:var(--muted);margin-top:16px;max-width:300px}
.fgrid h4{font-size:13px;font-weight:700;margin-bottom:16px}
.fgrid ul{list-style:none;display:grid;gap:10px}
.fgrid li a{font-size:14px;color:var(--muted)}
.fgrid li a:hover{color:var(--blue)}
.finfo{font-size:14px;color:var(--muted);display:grid;gap:8px}
.fbot{border-top:1px solid var(--line);padding-top:22px;font-size:12.5px;color:var(--muted);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---- お問い合わせ（Contact Form 7 対応） ---- */
.cwrap{max-width:1000px;margin:0 auto;padding:0 30px 110px;display:grid;grid-template-columns:.85fr 1.15fr;gap:34px;align-items:start}
.cinfo{background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:34px 32px}
.cinfo h3{font-size:19px;font-weight:900;margin-bottom:18px}
.cinfo .pt{display:flex;gap:13px;align-items:flex-start;margin-bottom:18px}
.cinfo .pt span{width:34px;height:34px;border-radius:10px;background:var(--blue-tint);color:var(--blue);display:grid;place-items:center;flex:none}
.cinfo .pt span svg{width:18px;height:18px}
.cinfo .pt b{font-size:15px;font-weight:700;display:block;margin-bottom:2px}
.cinfo .pt p{font-size:13.5px;color:var(--muted)}
.cinfo .meta{border-top:1px solid var(--line);margin-top:8px;padding-top:20px;display:grid;gap:9px;font-size:14px;color:var(--muted)}
.cinfo .meta div b{color:var(--ink);font-weight:700}
.cform{background:#fff;border:1px solid var(--line);border-radius:22px;padding:36px 36px 40px;box-shadow:0 30px 60px -45px rgba(22,32,46,.4)}
.field{margin-bottom:22px}
.field label{display:block;font-size:14px;font-weight:700;margin-bottom:9px}
.field label .req{color:#d6492f;font-size:12px;margin-left:7px;font-weight:700}
.field label .opt{color:var(--muted);font-size:12px;margin-left:7px;font-weight:500}
.cform input[type=text],.cform input[type=email],.cform input[type=tel],.cform input[type=date],.cform textarea{
  width:100%;font-family:inherit;font-size:15.5px;color:var(--ink);background:var(--soft);
  border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;transition:.15s;line-height:1.6}
.cform input::placeholder,.cform textarea::placeholder{color:#9fadbd}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px var(--blue-tint)}
.cform textarea{resize:vertical;min-height:130px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips label,.chips .wpcf7-list-item label{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:500;background:var(--soft);border:1.5px solid var(--line);border-radius:999px;padding:9px 16px;cursor:pointer;transition:.15s;margin:0}
.chips input,.chips .wpcf7-list-item input{accent-color:var(--blue);width:16px;height:16px}
.chips label:hover,.chips .wpcf7-list-item label:hover{border-color:#cfe0f5}
.chips .wpcf7-checkbox{display:flex;flex-wrap:wrap;gap:10px}
.chips .wpcf7-list-item{margin:0}
.submit{margin-top:6px}
.submit .btn,.submit input[type=submit]{width:100%;justify-content:center;font-size:16px;padding:16px;border-radius:14px;font-weight:700;cursor:pointer}
.note{font-size:12.5px;color:var(--muted);text-align:center;margin-top:14px}
/* CF7 のメッセージ・エラー表示 */
.wpcf7-not-valid-tip{color:#d6492f;font-size:12.5px;margin-top:6px;display:block}
.wpcf7 form.invalid .wpcf7-response-output,.wpcf7 form.unaccepted .wpcf7-response-output{border:1px solid #f0c2b6;background:#fdeee9;color:#b23a1e}
.wpcf7 form.sent .wpcf7-response-output{border:1px solid #bfe3cf;background:#eaf7ef;color:var(--grn)}
.wpcf7-response-output{border-radius:12px;padding:13px 16px;font-size:14px;margin:18px 0 0!important}
.cform .wpcf7-spinner{margin:14px auto 0;display:block}

@media(max-width:880px){.cwrap{grid-template-columns:1fr}}

/* ---- レッスンページ（page-lessons.php） ---- */
.lindex{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:820px;margin:30px auto 0}
.lindex a{font-size:14px;font-weight:700;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 18px;color:var(--muted);transition:.15s}
.lindex a:hover{border-color:var(--blue);color:var(--blue)}
.lessons-page{max-width:1160px;margin:0 auto;padding:70px 30px 40px}
.lrow{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:46px 0;scroll-margin-top:96px}
.lrow + .lrow{border-top:1px solid var(--line)}
.lrow.flip .lmedia{order:2}
.lmedia{height:380px;border-radius:26px;overflow:hidden;box-shadow:0 30px 60px -42px rgba(22,32,46,.4)}
.lmedia img{width:100%;height:100%;object-fit:contain;display:block}
.lnum{font-family:"Outfit";font-size:13px;font-weight:700;color:var(--blue);letter-spacing:.12em;margin-bottom:12px}
.lbody h2{font-size:clamp(26px,3.2vw,36px);font-weight:900;letter-spacing:-.01em;margin-bottom:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.lbody .lead{font-size:17px;color:var(--muted);margin-bottom:22px}
.lbody ul{list-style:none;display:grid;gap:12px;margin-bottom:26px;padding:0}
.lbody li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px}
.lbody li::before{display:none}
.lbody li svg{width:20px;height:20px;color:var(--blue);flex:none;margin-top:3px}
@media(max-width:880px){
  .lrow{grid-template-columns:1fr;gap:26px;padding:38px 0}
  .lrow.flip .lmedia{order:0}
  .lmedia{height:280px}
}

@media(max-width:900px){
  .section{padding:64px 0}
  .bento{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .c-wide,.c-tall{grid-column:auto;grid-row:auto}
  .lgrid,.ptable{grid-template-columns:1fr}
  .ai-in{grid-template-columns:1fr}.ai-left{padding:48px 32px}.ai-right{padding:40px 32px}
  .steps{grid-template-columns:1fr 1fr}
  .tin{grid-template-columns:1fr;gap:32px}
  .fgrid{grid-template-columns:1fr}
  .bio{flex-direction:column}
}
