/*
Theme Name: Ringusu
Theme URI: https://ringusu.com/
Author: Stone Sharp
Description: 就労継続支援B型事業所 りんぐす オリジナルテーマ。オレンジ × 生成りベージュ、Noto Sans JP。トップページ・スタッフ・工賃シミュレーターは管理画面から編集できます。
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: ringusu
*/

/* ============================================================
   TOKENS
============================================================ */
:root{
  --bg:#f5f0ea;
  --surface:#ffffff;
  --surface-soft:#fffdf9;
  --cream:#faf8f5;
  --warm:#fff8f2;
  --peach-bg:#fff3e8;
  --peach:#fde5cf;
  --orange:#f97316;
  --orange-deep:#ea6a0c;
  --amber:#fbbf24;
  --ink:#1a1a1a;
  --muted:#888;
  --muted-2:#bbb;
  --line:#f0e8e0;
  --line-2:#f5f0ea;
  --footer:#1a1a1a;
  --sh-sm:0 2px 12px rgba(0,0,0,.06);
  --sh-md:0 4px 20px rgba(0,0,0,.10);
  --sh-lg:0 8px 40px rgba(0,0,0,.12);
  --sh-orange:0 4px 16px rgba(249,115,22,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:var(--bg);color:var(--ink);line-height:1.85;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:.72rem;font-weight:700;color:var(--orange);letter-spacing:.18em;margin-bottom:8px;display:block}
.sec-title{font-size:clamp(1.5rem,3.4vw,2.1rem);font-weight:900;color:var(--ink);line-height:1.4}
.sec-head{text-align:center;margin-bottom:36px}
.sec-head .desc{font-size:.9rem;color:var(--muted-2);margin-top:8px}

/* buttons */
.btn-fill{background:var(--orange);color:#fff;padding:15px 32px;border-radius:99px;font-weight:700;box-shadow:var(--sh-orange);transition:.3s;display:inline-flex;align-items:center;gap:8px}
.btn-fill:hover{background:var(--orange-deep);transform:translateY(-2px);color:#fff}
.btn-line{border:2px solid var(--orange);color:var(--orange);padding:13px 30px;border-radius:99px;font-weight:700;transition:.3s;display:inline-flex;align-items:center;gap:8px;background:#fff}
.btn-line:hover{background:var(--peach-bg)}
.btn-white{background:#fff;color:var(--orange);padding:16px 44px;border-radius:99px;font-weight:700;box-shadow:var(--sh-md);transition:.3s;display:inline-flex;align-items:center;gap:8px}
.btn-white:hover{transform:translateY(-2px);color:var(--orange)}

/* ============================================================
   HEADER
============================================================ */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 0}
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand .clover{width:38px;height:38px;border-radius:50%;background:var(--orange);display:grid;place-items:center;font-size:19px;flex:none}
.brand img.custom-logo{max-height:46px;width:auto}
.brand b{font-size:1.15rem;font-weight:900;color:var(--ink);line-height:1;display:block}
.brand small{font-size:.6rem;color:var(--muted-2);letter-spacing:.08em}
.nav-right{display:flex;align-items:center;gap:22px}
.menu{display:flex;align-items:center;gap:22px;list-style:none}
.menu a{font-size:.88rem;font-weight:700;color:var(--ink);transition:.3s;display:inline-block}
.menu a:hover,.menu .current-menu-item>a{color:var(--orange)}
.menu .sub-menu{position:absolute;background:#fff;border-radius:14px;box-shadow:var(--sh-md);padding:10px;min-width:190px;list-style:none;display:grid;gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.3s;z-index:20}
.menu li{position:relative}
.menu li:hover>.sub-menu{opacity:1;visibility:visible;transform:none}
.menu .sub-menu a{padding:8px 14px;border-radius:8px;font-weight:500;font-size:.84rem}
.menu .sub-menu a:hover{background:var(--peach-bg)}
.header-cta{background:var(--orange);color:#fff;padding:11px 22px;border-radius:99px;font-weight:700;font-size:.86rem;box-shadow:var(--sh-orange);transition:.3s;flex:none;white-space:nowrap}
.header-cta:hover{background:var(--orange-deep);transform:translateY(-2px);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:60}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:1px;transition:.3s}
.burger span:nth-child(3){width:15px;align-self:flex-start}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){width:22px;transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
============================================================ */
.hero{position:relative;background:linear-gradient(135deg,#ede8e0 0%,#ddd8ce 100%);overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:70px 0 80px}
.hero h1{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:900;line-height:1.4;color:var(--ink);margin-bottom:18px}
.hero h1 .hl{color:var(--orange)}
.hero p.lead{font-size:1rem;color:#6b6258;max-width:440px;margin-bottom:30px;line-height:1.9}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-visual .ph{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/3.6;box-shadow:var(--sh-lg)}
.hero-visual .ph img{width:100%;height:100%;object-fit:cover}
.hero-visual .badge-top{position:absolute;top:16px;right:16px;background:var(--orange);color:#fff;font-size:.74rem;font-weight:700;padding:7px 16px;border-radius:99px;z-index:2;box-shadow:var(--sh-orange)}
.hero-visual .badge-bot{position:absolute;bottom:-18px;left:-14px;background:#fff;border-radius:16px;padding:14px 20px;box-shadow:var(--sh-lg);display:flex;align-items:center;gap:12px;z-index:2}
.hero-visual .badge-bot .ic{width:42px;height:42px;border-radius:50%;background:var(--peach-bg);display:grid;place-items:center;font-size:20px;flex:none}
.hero-visual .badge-bot b{font-size:.92rem;font-weight:900;color:var(--ink);display:block;line-height:1.3}
.hero-visual .badge-bot span{font-size:.72rem;color:var(--muted-2)}

/* ============================================================
   FREE SPACE (ウィジェットエリア)
============================================================ */
.freespace{padding:44px 0 0}
.fs-inner > *{margin-bottom:0}
.fs-placeholder{border:2px dashed var(--peach);border-radius:18px;padding:30px 24px;background:var(--surface-soft);text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.fs-placeholder .ic{font-size:24px}
.fs-placeholder b{font-size:.92rem;font-weight:700;color:var(--muted-2)}
.fs-placeholder p{font-size:.82rem;color:var(--muted-2);line-height:1.7}

/* ============================================================
   FEATURES
============================================================ */
.features{padding:70px 0}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feat{background:#fff;border-radius:18px;padding:30px 26px;box-shadow:var(--sh-sm);transition:.3s}
.feat:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.feat .ic{width:60px;height:60px;border-radius:50%;background:var(--peach-bg);display:grid;place-items:center;font-size:28px;margin-bottom:16px}
.feat h3{font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.feat p{font-size:.86rem;color:var(--muted);line-height:1.8}

/* ============================================================
   PHILOSOPHY
============================================================ */
.philo{padding:70px 0;background:var(--warm)}
.philo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pcard{background:#fff;border-radius:18px;padding:32px 28px;box-shadow:var(--sh-sm);transition:.3s}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.pcard .no{font-size:1.6rem;font-weight:900;color:var(--peach);line-height:1;margin-bottom:10px}
.pcard .label{font-size:.7rem;font-weight:700;color:var(--orange);letter-spacing:.12em;margin-bottom:6px}
.pcard h3{font-size:1.12rem;font-weight:900;color:var(--ink);margin-bottom:12px;line-height:1.5}
.pcard p{font-size:.86rem;color:var(--muted);line-height:1.9}

/* ============================================================
   WORK
============================================================ */
.work{padding:70px 0}
.work-intro{text-align:center;max-width:600px;margin:-16px auto 40px;color:var(--muted);font-size:.92rem}
.work-card{background:#fff;border-radius:22px;overflow:hidden;box-shadow:var(--sh-sm);display:grid;grid-template-columns:300px 1fr;margin-bottom:22px;transition:.3s}
.work-card:hover{box-shadow:var(--sh-md)}
.work-card .img{position:relative;min-height:240px}
.work-card .img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.work-card .img .tag{position:absolute;top:14px;left:14px;background:#fff;color:var(--ink);font-size:.72rem;font-weight:700;padding:6px 14px;border-radius:99px;z-index:2;box-shadow:var(--sh-sm)}
.work-card .body{padding:30px 32px}
.work-card .chip{display:inline-block;background:var(--peach-bg);color:var(--orange);font-size:.72rem;font-weight:700;padding:5px 14px;border-radius:99px;margin-bottom:12px}
.work-card h3{font-size:1.35rem;font-weight:900;color:var(--ink);margin-bottom:8px}
.work-card .lead{font-size:.88rem;color:var(--muted);margin-bottom:18px;line-height:1.8}
.tasks{display:grid;gap:10px}
.task{display:flex;gap:12px;align-items:flex-start}
.task .n{width:26px;height:26px;border-radius:50%;background:var(--orange);color:#fff;font-size:.78rem;font-weight:700;display:grid;place-items:center;flex:none;margin-top:2px}
.task b{font-size:.92rem;font-weight:700;color:var(--ink);display:block}
.task span{font-size:.82rem;color:var(--muted-2)}

/* ============================================================
   STAFF
============================================================ */
.staff{padding:70px 0;background:var(--warm)}
.staff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.scard{background:#fff;border-radius:20px;padding:26px 18px;text-align:center;border:1.5px solid var(--peach);box-shadow:var(--sh-sm);transition:.3s}
.scard:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.scard .avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 14px;overflow:hidden;border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.1);background:linear-gradient(135deg,var(--peach),var(--amber));display:grid;place-items:center;font-size:38px}
.scard .avatar img{width:100%;height:100%;object-fit:cover}
.scard .role{font-size:.68rem;font-weight:700;color:var(--orange);letter-spacing:.1em;margin-bottom:5px}
.scard .name{font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:5px}
.scard .job{font-size:.78rem;color:var(--muted-2);line-height:1.6}

/* ============================================================
   TIMELINE 一日の流れ
============================================================ */
.schedule{padding:70px 0}
.tl{max-width:560px;margin:0 auto}
.tl-row{display:flex;gap:16px;align-items:stretch}
.tl-time{display:flex;flex-direction:column;align-items:center;width:44px;flex:none}
.tl-time .dot{width:44px;height:44px;border-radius:50%;color:#fff;display:grid;place-items:center;font-size:.74rem;font-weight:700;flex:none}
.tl-time .dot.o{background:var(--orange)}
.tl-time .dot.a{background:var(--amber);color:var(--ink)}
.tl-time .bar{width:2px;flex:1;background:var(--peach);min-height:24px;margin:4px 0}
.tl-row:last-child .bar{display:none}
.tl-body{padding:8px 0 22px}
.tl-body b{font-size:1rem;font-weight:700;color:var(--ink);display:block}
.tl-body span{font-size:.82rem;color:var(--muted-2)}

/* ============================================================
   STEPS ご利用の流れ
============================================================ */
.steps{padding:70px 0;background:var(--warm)}
.steps-wrap{max-width:620px;margin:0 auto;position:relative}
.steps-line{position:absolute;left:27px;top:30px;bottom:30px;width:2px;background:linear-gradient(to bottom,var(--orange),var(--amber),var(--orange));border-radius:1px}
.step{display:flex;gap:18px;align-items:flex-start;margin-bottom:22px;position:relative}
.step:last-child{margin-bottom:0}
.step .num{width:56px;height:56px;border-radius:50%;color:#fff;font-size:1.3rem;font-weight:900;display:grid;place-items:center;flex:none;border:3px solid #fff;box-shadow:var(--sh-md)}
.step .num.o{background:var(--orange)}
.step .num.a{background:var(--amber);color:var(--ink)}
.step .card{background:#fff;border:1.5px solid var(--peach);border-radius:14px;padding:18px 22px;flex:1}
.step .card.final{background:var(--peach-bg);border:2px solid var(--orange)}
.step .card b{font-size:1rem;font-weight:700;color:var(--ink);display:block;margin-bottom:4px}
.step .card.final b{color:var(--orange)}
.step .card p{font-size:.84rem;color:var(--muted-2);line-height:1.8}

/* ============================================================
   WAGE SIMULATOR
============================================================ */
.sim{padding:70px 0}
.sim-card{display:grid;grid-template-columns:1.1fr .9fr;background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--sh-md)}
.sim-form{padding:38px 36px}
.field{margin-bottom:24px}
.field:last-child{margin-bottom:0}
.field>label{display:flex;justify-content:space-between;align-items:center;font-size:.92rem;font-weight:700;color:var(--ink);margin-bottom:12px}
.field .val{font-weight:500;color:var(--muted-2);font-size:.85rem}
.field .val b{color:var(--orange);font-size:1.2rem;font-weight:900}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:0;border:2px solid var(--line);background:#fff;border-radius:14px;padding:12px 10px;font-family:inherit;font-weight:700;font-size:.86rem;color:var(--muted);cursor:pointer;transition:.25s;display:flex;flex-direction:column;gap:2px;align-items:center}
.seg button em{font-style:normal;font-size:.72rem;font-weight:500;color:var(--muted-2)}
.seg button.active{border-color:var(--orange);background:var(--peach-bg);color:var(--orange)}
.seg button.active em{color:var(--orange)}
.seg-sm button{flex-direction:row;padding:11px 8px;font-size:.82rem}
.field input[type=range]{width:100%;accent-color:var(--orange);height:6px;cursor:pointer}
.scale{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted-2);margin-top:6px}
.check{display:flex!important;align-items:center;gap:10px;font-size:.86rem;font-weight:500!important;color:var(--ink);cursor:pointer;background:var(--warm);padding:14px 16px;border-radius:12px;border:1.5px solid var(--line);margin-bottom:0}
.check input{width:18px;height:18px;accent-color:var(--orange);flex:none}
.sim-out{background:linear-gradient(160deg,#f97316,#ea6a0c);color:#fff;padding:38px 34px;display:flex;align-items:center}
.sim-out-inner{width:100%}
.ro{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.22);font-size:.9rem}
.ro span{color:rgba(255,255,255,.85)}
.ro b{font-weight:700;font-size:1.05rem}
.rtotal{margin-top:18px;text-align:center}
.rtotal>span{font-size:.85rem;color:rgba(255,255,255,.9);font-weight:700;letter-spacing:.05em}
.rtotal .big{font-weight:900;line-height:1.05;margin-top:6px;display:flex;align-items:baseline;justify-content:center;gap:2px}
.rtotal .big .yen{font-size:1.7rem}
.rtotal .big #rTotal{font-size:3rem}
.rcalc{text-align:center;margin-top:16px;font-size:.78rem;color:#fff;background:rgba(255,255,255,.16);padding:9px 14px;border-radius:99px;line-height:1.5}
.sim-cta{text-align:center;margin-top:22px}
.sim-note{text-align:center;font-size:.78rem;color:var(--muted-2);margin-top:16px;line-height:1.7}

/* ============================================================
   INFO TABLES + ACCESS
============================================================ */
.info{padding:70px 0;background:var(--warm)}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.info-card{background:#fff;border-radius:20px;padding:34px;box-shadow:var(--sh-sm)}
.info-card h3{font-size:1.2rem;font-weight:900;color:var(--ink);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.info-card h3 .ic{width:40px;height:40px;border-radius:12px;background:var(--peach-bg);display:grid;place-items:center;font-size:18px}
.trow{display:flex;padding:13px 0;border-bottom:1px solid var(--line-2);font-size:.9rem}
.trow:last-child{border:0}
.trow .k{width:110px;flex:none;color:var(--muted-2);font-weight:700}
.trow .v{flex:1;color:var(--ink)}
.trow .v strong{color:var(--orange)}
.svc{margin-top:22px;background:#fff;border-radius:20px;padding:34px;box-shadow:var(--sh-sm)}
.svc h3{font-size:1.2rem;font-weight:900;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.svc h3 .ic{width:40px;height:40px;border-radius:12px;background:var(--peach-bg);display:grid;place-items:center;font-size:18px}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.map-embed{border-radius:16px;overflow:hidden;min-height:240px;border:1px solid var(--line)}
.map-embed iframe{width:100%;height:100%;min-height:240px;border:0;display:block}
.map-ph{height:100%;min-height:240px;border-radius:16px;background:linear-gradient(135deg,#e8e4dc,#d8d4cc);display:grid;place-items:center;border:1.5px dashed #ccc;color:#aaa;text-align:center;font-size:.85rem}
.map-ph .pin{font-size:30px;margin-bottom:6px}

/* ============================================================
   BLOG (front teaser = news list)
============================================================ */
.blog{padding:70px 0}
.blog-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.blog-head h2{font-size:1.5rem;font-weight:900}
.blog-head a{font-size:.82rem;color:var(--orange);font-weight:700;background:var(--peach-bg);padding:7px 16px;border-radius:99px}
.news{background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--sh-sm)}
.news a{display:flex;gap:14px;align-items:flex-start;padding:18px 24px;border-bottom:1px solid var(--line-2);transition:.3s}
.news a:last-child{border:0}
.news a:hover{background:var(--warm)}
.news .badge{font-size:.7rem;font-weight:700;padding:4px 11px;border-radius:99px;flex:none;margin-top:3px;white-space:nowrap}
.news .badge.new{background:var(--peach-bg);color:var(--orange)}
.news .badge.cat{background:#f5f5f5;color:#999}
.news .ttl{font-size:.95rem;color:var(--ink);line-height:1.6;font-weight:500}
.news .date{font-size:.76rem;color:var(--muted-2);margin-top:3px}

/* ============================================================
   BIG CTA
============================================================ */
.bigcta{background:var(--orange);text-align:center;padding:72px 24px;position:relative;overflow:hidden}
.bigcta::before,.bigcta::after{content:"";position:absolute;border-radius:50%;border:2px solid rgba(255,255,255,.18)}
.bigcta::before{width:320px;height:320px;top:-120px;left:-80px}
.bigcta::after{width:200px;height:200px;bottom:-90px;right:6%}
.bigcta .eyebrow{color:rgba(255,255,255,.8);letter-spacing:.22em}
.bigcta h2{font-size:clamp(1.7rem,3.6vw,2.4rem);font-weight:900;color:#fff;line-height:1.4;margin-bottom:14px;position:relative}
.bigcta p{color:rgba(255,255,255,.88);margin-bottom:30px;position:relative}
.bigcta .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}
.bigcta .btn-out{border:2px solid rgba(255,255,255,.55);color:#fff;padding:15px 32px;border-radius:99px;font-weight:700;transition:.3s}
.bigcta .btn-out:hover{background:rgba(255,255,255,.12)}

/* ============================================================
   PAGE HERO (固定ページ/投稿/アーカイブ共通)
============================================================ */
.page-hero{position:relative;background:linear-gradient(135deg,#ede8e0,#ddd8ce);padding:120px 0 48px;text-align:center;overflow:hidden}
.page-hero .ring{position:absolute;border-radius:50%;border:2px solid var(--peach);opacity:.7;pointer-events:none}
.page-hero .pr1{width:160px;height:160px;top:-40px;left:-40px}
.page-hero .pr2{width:100px;height:100px;bottom:-30px;right:8%;border-color:rgba(249,115,22,.3)}
.page-hero .crumb{font-size:.78rem;color:var(--muted);margin-bottom:12px}
.page-hero .crumb a{color:var(--orange);font-weight:700}
.page-hero h1{font-size:clamp(1.7rem,4vw,2.5rem);font-weight:900;color:var(--ink);line-height:1.4}
.page-hero .sub{font-size:.72rem;font-weight:700;color:var(--orange);letter-spacing:.18em;margin-bottom:8px}

/* ============================================================
   CONTENT (固定ページ・投稿本文)
============================================================ */
.content-area{padding:56px 0 90px}
.content-narrow{max-width:800px;margin:0 auto}
.entry-content{font-size:1.02rem;color:var(--ink);line-height:2}
.entry-content > *{margin-bottom:1.4em}
.entry-content > *:last-child{margin-bottom:0}
.entry-content h2{font-size:1.5rem;font-weight:900;color:var(--ink);margin:1.8em 0 .7em;padding:0 0 .4em;border-bottom:3px solid var(--peach);position:relative}
.entry-content h2::after{content:"";position:absolute;left:0;bottom:-3px;width:70px;height:3px;background:var(--orange)}
.entry-content h3{font-size:1.25rem;font-weight:700;color:var(--ink);margin:1.6em 0 .6em;padding-left:14px;border-left:5px solid var(--orange)}
.entry-content h4{font-size:1.1rem;font-weight:700;color:var(--orange);margin:1.4em 0 .5em}
.entry-content a{color:var(--orange-deep);text-decoration:underline;text-underline-offset:3px}
.entry-content a:hover{color:var(--orange)}
.entry-content ul,.entry-content ol{padding-left:1.4em}
.entry-content li{margin-bottom:.5em}
.entry-content ul li::marker{color:var(--orange)}
.entry-content img,.entry-content .wp-block-image img{border-radius:16px;box-shadow:var(--sh-sm)}
.entry-content blockquote{background:var(--warm);border-left:5px solid var(--orange);border-radius:0 14px 14px 0;padding:18px 24px;color:var(--muted)}
.entry-content blockquote p:last-child{margin-bottom:0}
.entry-content figcaption{text-align:center;font-size:.82rem;color:var(--muted-2);margin-top:8px}
.entry-content table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--sh-sm)}
.entry-content table th{background:var(--orange);color:#fff;font-weight:700;padding:13px 16px;text-align:left}
.entry-content table td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:.94rem}
.entry-content table tr:last-child td{border-bottom:0}
.entry-content .wp-block-button__link{background:var(--orange);color:#fff;font-weight:700;padding:14px 30px;border-radius:99px;text-decoration:none;display:inline-block;box-shadow:var(--sh-orange)}
.entry-content hr{border:0;height:1px;background:var(--line);margin:2.2em 0}
.alignwide{width:min(1040px,100%);margin-left:auto;margin-right:auto}
.alignfull{width:100vw;margin-left:calc(50% - 50vw);max-width:100vw}
.aligncenter{margin-left:auto;margin-right:auto;text-align:center}
.alignleft{float:left;margin:0 1.4em 1em 0}
.alignright{float:right;margin:0 0 1em 1.4em}
.page-cta{margin-top:50px;background:var(--peach-bg);border-radius:20px;padding:40px;text-align:center}
.page-cta h3{font-size:1.3rem;font-weight:900;color:var(--ink);margin-bottom:16px}

/* ============================================================
   BLOG ARCHIVE / LISTING
============================================================ */
.archive-wrap{padding:56px 0 90px}
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:46px;align-items:start}
.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.pcard-blog{background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--sh-sm);transition:.35s;display:flex;flex-direction:column}
.pcard-blog:hover{transform:translateY(-6px);box-shadow:var(--sh-md)}
.pcard-blog .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--peach-bg)}
.pcard-blog .thumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.pcard-blog:hover .thumb img{transform:scale(1.05)}
.pcard-blog .thumb.no-img{display:grid;place-items:center;color:var(--orange);font-size:30px}
.pcard-blog .body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.pcard-blog .cat{font-size:.72rem;font-weight:700;color:var(--orange);margin-bottom:8px;display:flex;gap:8px;align-items:center}
.pcard-blog .cat .date{color:var(--muted-2)}
.pcard-blog h2{font-size:1.08rem;font-weight:700;line-height:1.6;color:var(--ink);margin-bottom:12px}
.pcard-blog .excerpt{font-size:.86rem;color:var(--muted);line-height:1.8;flex:1}
.pcard-blog .readmore{margin-top:14px;font-weight:700;font-size:.84rem;color:var(--orange)}

/* sidebar (ウィジェット) */
.sidebar .widget{background:#fff;border-radius:18px;padding:24px;margin-bottom:22px;box-shadow:var(--sh-sm)}
.sidebar .widget:last-child{margin-bottom:0}
.sidebar .widget-title,.sidebar h2,.sidebar h3{font-size:1.02rem;font-weight:900;color:var(--ink);margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--peach)}
.sidebar ul{list-style:none}
.sidebar li{padding:8px 0;border-bottom:1px dashed var(--line);font-size:.86rem}
.sidebar li:last-child{border:0}
.sidebar a:hover{color:var(--orange)}
.sidebar .search-field{width:100%;border:1.5px solid var(--line);border-radius:99px;padding:10px 18px;font-family:inherit;font-size:.9rem}
.sidebar .search-submit{margin-top:10px;background:var(--orange);color:#fff;border:0;border-radius:99px;padding:10px 22px;font-weight:700;cursor:pointer;font-family:inherit}

/* single */
.single-hero{padding:120px 0 0;background:linear-gradient(135deg,#ede8e0,#ddd8ce)}
.single-hero .wrap{max-width:820px}
.single-meta{display:flex;gap:12px;align-items:center;font-weight:700;font-size:.8rem;color:var(--orange);margin-bottom:14px}
.single-meta .cat{background:var(--peach-bg);padding:4px 12px;border-radius:99px}
.single-meta .date{color:var(--muted)}
.single-hero h1{font-size:clamp(1.5rem,3.4vw,2.2rem);font-weight:900;color:var(--ink);line-height:1.5;padding-bottom:36px}
.single-thumb{max-width:880px;margin:0 auto;border-radius:20px;overflow:hidden;box-shadow:var(--sh-md);transform:translateY(0)}
.single-thumb img{width:100%}
.post-nav{display:flex;justify-content:space-between;gap:14px;margin-top:46px;flex-wrap:wrap}
.post-nav a{background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:14px 20px;font-weight:700;font-size:.84rem;color:var(--ink);transition:.3s;max-width:47%}
.post-nav a:hover{border-color:var(--orange);color:var(--orange)}
.post-nav .nxt{margin-left:auto;text-align:right}

/* pagination */
.pagination{display:flex;justify-content:center;gap:9px;margin-top:46px;flex-wrap:wrap}
.pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 12px;border-radius:99px;background:#fff;border:1.5px solid var(--line);font-weight:700;color:var(--ink);transition:.3s}
.pagination .page-numbers.current{background:var(--orange);color:#fff;border-color:var(--orange)}
.pagination a.page-numbers:hover{border-color:var(--orange);color:var(--orange)}

/* 404 / empty */
.notfound{text-align:center;padding:140px 0 110px}
.notfound .big{font-size:5rem;font-weight:900;color:var(--peach);line-height:1}
.notfound h1{font-size:1.5rem;font-weight:900;color:var(--ink);margin:8px 0 18px}
.notfound p{color:var(--muted);margin-bottom:28px}

/* ============================================================
   FOOTER
============================================================ */
.site-footer{background:var(--footer);padding:58px 0 26px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px;margin-bottom:40px}
.foot-brand .b{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.foot-brand .clover{width:36px;height:36px;border-radius:50%;background:var(--orange);display:grid;place-items:center;font-size:18px}
.foot-brand .b b{color:#fff;font-size:1.05rem;font-weight:900;display:block;line-height:1.2}
.foot-brand .b small{color:#666;font-size:.62rem}
.foot-brand p{font-size:.82rem;color:#777;line-height:2.1}
.fcol h4{font-size:.72rem;font-weight:700;color:var(--orange);letter-spacing:.08em;margin-bottom:16px}
.fcol .foot-menu{list-style:none;display:grid;gap:11px}
.fcol .foot-menu a{font-size:.84rem;color:#999;transition:.3s}
.fcol .foot-menu a:hover{color:#fff}
.foot-bottom{border-top:1px solid #333;padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-bottom span{font-size:.76rem;color:#666}

/* ============================================================
   REVEAL
============================================================ */
.rv{opacity:0;transform:translateY(24px);transition:.7s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:980px){
  .blog-layout{grid-template-columns:1fr}
}
@media(max-width:960px){
  .feat-grid,.philo-grid{grid-template-columns:1fr 1fr}
  .info-grid,.access-grid{grid-template-columns:1fr}
  .staff-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .hero-inner{grid-template-columns:1fr;padding:48px 0 64px}
  .hero-visual{max-width:440px;margin:8px auto 0}
  .work-card{grid-template-columns:1fr}
  .work-card .img{min-height:220px}
  .sim-card{grid-template-columns:1fr}
  .sim-out{padding:32px 28px}
  .sim-form{padding:32px 26px}
}
@media(max-width:680px){
  .feat-grid,.philo-grid{grid-template-columns:1fr}
  .post-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:768px){
  .nav-right .menu{position:fixed;inset:0 0 0 auto;width:76%;max-width:300px;height:100vh;background:#fff;flex-direction:column;justify-content:center;gap:22px;transform:translateX(100%);transition:.4s;box-shadow:-8px 0 40px rgba(0,0,0,.15);padding:40px;overflow-y:auto}
  .nav-right .menu.open{transform:translateX(0)}
  .menu a{font-size:1.05rem}
  .menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding:6px 0 0 14px}
  .burger{display:flex}
  .header-cta{padding:9px 16px;font-size:.8rem}
  .post-nav a{max-width:100%}
  .foot-bottom{justify-content:center;text-align:center}
  .overlay{position:fixed;inset:0;background:rgba(26,26,26,.4);opacity:0;visibility:hidden;transition:.3s;z-index:45}
  .overlay.open{opacity:1;visibility:visible}
}
@media(max-width:520px){
  .staff-grid{grid-template-columns:1fr 1fr}
}
