/*
Theme Name: 不動産売却コンシェルジュ
Theme URI: https://fudousan.adobekiki.com/
Description: 岡山特化 不動産売却コンシェルジュ LP テーマ
Author: iekin
Version: 3.0
*/

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP','Hiragino Sans',sans-serif;font-size:17px;color:var(--text);line-height:2;letter-spacing:.06em;background:var(--white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:opacity .2s ease-in-out}
ul{list-style:none}

/* ===== VARIABLES ===== */
:root{
  --primary:#053657;
  --primary-light:#065C96;
  --accent:#F0EB47;
  --accent-dark:#d8d33f;
  --bg-cream:#FAF6E2;
  --bg-light:#F0F1ED;
  --white:#fff;
  --text:#042d4a;
  --text-light:#2e5470;
  --text-muted:#6b7f8e;
  --border:rgba(5,54,87,.12);
  --border-md:rgba(5,54,87,.25);
  --green:#06c755;
  --shadow-sm:0 4px 8px rgba(0,0,0,.05);
  --shadow-md:0 7px 14px rgba(0,0,0,.08);
  --shadow-lg:0 10px 24px rgba(0,0,0,.10);
  --shadow-btn:0 10px 10px rgba(0,0,0,.1);
  --radius-pill:62.5rem;
  --radius-md:12px;
  --radius-lg:20px;
}

/* ===== TICKER ===== */
.ticker-section{background:var(--accent);padding:30px 0;white-space:nowrap;position:relative;z-index:100;overflow-x:clip;overflow-y:visible}
.ticker-label{position:absolute;left:50%;top:0;transform:translate(-50%,-50%);background:var(--primary);color:var(--accent);font-size:18px;font-weight:700;padding:4px 20px;border-radius:var(--radius-pill);z-index:9999;letter-spacing:.08em;box-shadow:var(--shadow-sm);border:5px solid var(--accent);animation:ticker-blink 1.5s ease-in-out infinite}
@keyframes ticker-blink{0%,100%{opacity:1}50%{opacity:0}}
.ticker-track{display:inline-flex;animation:ticker 30s linear infinite}
.ticker-item{display:inline-flex;align-items:center;gap:8px;margin-right:40px;font-size:14px;letter-spacing:.04em;background:var(--white);padding:4px 16px}
.ticker-area{color:var(--primary);font-weight:600}
.ticker-price{color:var(--primary);font-family:'Roboto',sans-serif;font-weight:700;font-size:15px}
.ticker-item::before{content:'';display:inline-block;width:6px;height:6px;background:var(--primary);border-radius:50%;flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== UTILITIES ===== */
.container{max-width:1140px;margin:0 auto;padding:0 2.5rem}

/* ===== SCROLL ANIMATIONS ===== */

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--primary);padding:0;transition:box-shadow .3s ease}
.site-header.scrolled{box-shadow:0 4px 20px rgba(5,54,87,.2)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 2.5rem;height:72px}
.site-logo{font-family:'Roboto','Noto Sans JP',sans-serif;font-size:16px;font-weight:700;color:var(--white);letter-spacing:.15em;display:flex;align-items:center;gap:10px}
.site-logo svg{width:32px;height:32px}
.header-nav{display:flex;align-items:center;gap:32px}
.header-nav a{color:rgba(255,255,255,.9);font-size:14px;font-weight:700;letter-spacing:.1em;transition:color .2s;position:relative;padding:4px 0}
.header-nav a:hover{color:var(--white)}
.header-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:width .3s ease}
.header-nav a:hover::after{width:100%}
.header-buttons{display:flex;align-items:center;gap:10px}
.header-guide{display:flex;align-items:center;margin-right:0;transition:all .2s ease-in-out}
.header-guide img{height:44px;width:auto;display:block}
.header-guide:hover{opacity:.85;transform:translateY(-1px)}
.header-cta{background:var(--accent);color:var(--primary);padding:10px 28px;border-radius:var(--radius-pill);font-size:14px;font-weight:700;letter-spacing:.08em;transition:all .2s ease-in-out;box-shadow:var(--shadow-btn)}
.header-cta:hover{opacity:.85;transform:translateY(-1px)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;position:relative;width:36px;height:36px}
.hamburger span,.hamburger span::before,.hamburger span::after{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;position:absolute;left:7px;transition:all .3s}
.hamburger span{top:17px}
.hamburger span::before{content:'';top:-7px}
.hamburger span::after{content:'';top:7px}
.hamburger.active span{background:transparent}
.hamburger.active span::before{top:0;transform:rotate(45deg)}
.hamburger.active span::after{top:0;transform:rotate(-45deg)}
.sp-menu{display:none;position:fixed;top:60px;left:0;right:0;background:var(--primary);padding:1.5rem;z-index:998;box-shadow:var(--shadow-lg);flex-direction:column;gap:0}
.sp-menu.open{display:flex}
.sp-menu a{color:var(--white);font-size:15px;font-weight:600;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);letter-spacing:.06em}
.sp-menu a:last-child{border-bottom:none}
.sp-menu .sp-menu-cta{background:var(--accent);color:var(--primary);text-align:center;padding:14px;border-radius:var(--radius-pill);font-weight:700;margin-top:12px;border-bottom:none}

/* ===== HERO ===== */
.hero{background:var(--primary);padding:160px 0 80px;color:var(--white);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(160deg,rgba(5,54,87,1) 0%,rgba(6,92,150,.6) 100%);pointer-events:none}
.hero::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('assets/img/16220_hero.svg') repeat;background-size:420px auto;opacity:.18;pointer-events:none;z-index:1}
.hero-content{position:relative;z-index:2;display:flex;align-items:center;gap:40px;max-width:1100px;margin:0 auto}
.hero-text{flex:1;text-align:center}
.hero-image{flex:1;display:flex;align-items:center;justify-content:center}
.hero-image img{width:100%;max-width:400px;height:auto}
.hero-tag{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);padding:8px 24px;border-radius:var(--radius-pill);font-size:14px;margin-bottom:32px;letter-spacing:.15em;font-weight:700}
.hero h1{font-size:2.625rem;font-weight:700;line-height:1.625;margin-bottom:16px;letter-spacing:.05em}
.hero h1 .highlight{background:var(--accent);color:var(--text);padding:2px 6px;display:inline-block;line-height:1.2}
.hero h2{font-size:1.25rem;font-weight:700;line-height:1.8;margin-bottom:20px;color:rgba(255,255,255,.9);letter-spacing:.05em}
.hero-brand{color:var(--accent)}
.hero-sub{font-size:15px;line-height:2;color:rgba(255,255,255,.75);margin-bottom:40px}
.hero-features{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;position:relative;z-index:10;margin-top:24px}
.hero-feature-item{display:flex;flex-direction:column;align-items:center;justify-content:center;width:130px;height:130px;background:var(--accent);border:12px solid var(--white);border-radius:50%;text-align:center;gap:2px;box-shadow:0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.1);position:relative}
.hero-feature-item span{color:var(--primary);font-size:16px;font-weight:900;letter-spacing:0;line-height:1.3;position:relative;z-index:1}
.hero-feature-item svg{position:relative;z-index:1}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:1.125rem 2.5rem;border-radius:var(--radius-pill);font-size:15px;font-weight:700;letter-spacing:.08em;transition:all .2s ease-in-out;border:none;cursor:pointer;position:relative;box-shadow:var(--shadow-btn)}
.btn:hover{opacity:.85;transform:translateY(-2px)}
.btn-phone{background:var(--accent);color:var(--primary)}
.btn-mail{background:var(--white);color:var(--primary)}
.btn-line{background:var(--green);color:var(--white)}
.btn-guide{background:var(--green);color:var(--white)}

/* ===== BADGES ===== */
.badges{padding:56px 0;background:var(--white)}
.badge-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.badge-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px 16px;text-align:center;transition:all .3s ease;box-shadow:var(--shadow-sm)}
.badge-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.badge-icon{font-size:32px;margin-bottom:12px;display:flex;align-items:center;justify-content:center}
.badge-icon svg{width:36px;height:36px;stroke:var(--primary);stroke-width:1.5;fill:none}
.badge-text{font-size:14px;font-weight:700;color:var(--text);line-height:1.6;letter-spacing:.06em}

/* ===== SECTION COMMON ===== */
.section{padding:5rem 0;position:relative}
.section-tag{display:inline-block;font-family:'Roboto',sans-serif;color:var(--primary-light);font-size:14px;font-weight:700;letter-spacing:.2em;margin-bottom:12px;text-transform:uppercase}
.section-title{font-size:2rem;font-weight:700;color:var(--text);line-height:1.6;letter-spacing:.05em}
.section-title .marker{background:linear-gradient(transparent 60%,var(--accent) 60%);padding:0 2px}
.section-subtitle{font-size:16px;color:var(--text-light);margin-bottom:3.5rem;line-height:2;letter-spacing:.06em}
.section-subtitle.accent-sub{font-size:18px;font-weight:700;color:var(--text)}
/* ===== BRIDGE ===== */
.bridge-section{text-align:center;background:var(--bg-cream);padding-bottom:0;overflow:visible;position:relative;z-index:1}
.bridge-text{font-size:2rem;font-weight:700;color:var(--text);line-height:1.7;letter-spacing:.05em;margin:0}
.bridge-question-card{display:inline-block;background:var(--bg-light);border-radius:10px;padding:2rem 2.5rem;position:relative;margin-bottom:1.5rem}
.bridge-question-card::before{content:'？';position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:32px;height:32px;background:var(--primary);color:#fff;border-radius:50%;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}
.bridge-question-card p{font-size:1.5rem;font-weight:700;color:var(--text);line-height:1.7;letter-spacing:.05em;margin:0}
.bridge-small{font-size:1.5rem;margin-bottom:10px}
.bridge-highlight{display:inline-block;background:var(--primary);color:var(--accent);font-size:2.2rem;padding:4px 20px;margin:0 4px;font-style:italic;letter-spacing:.08em}
.bridge-arrow{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;z-index:2;transform:translateY(50%)}
.sp-only{display:none}

.section-header{text-align:center;margin-bottom:3.5rem}
.bg-cream{background:var(--bg-cream)}
.bg-light{background:var(--bg-light)}

/* ===== SERVICE FLOW ===== */
.steps-flow{display:flex;align-items:flex-start;gap:0;margin-bottom:3.5rem;position:relative}
.step-item{flex:1;text-align:center;position:relative;padding:0 8px}
.step-num{width:52px;height:52px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:'Roboto',sans-serif;font-size:18px;font-weight:700;margin:0 auto 12px;box-shadow:var(--shadow-md);transition:all .3s ease}
.step-item:hover .step-num{background:var(--accent);color:var(--primary);transform:scale(1.08)}
.step-label{font-size:14px;font-weight:700;color:var(--text);line-height:1.5;letter-spacing:.04em;margin-bottom:8px}
.step-desc{font-size:12px;color:var(--text-light);line-height:1.7;letter-spacing:.02em;max-width:160px;margin:0 auto}
.step-arrow{color:var(--text-muted);font-size:20px;font-weight:400;display:flex;align-items:center;padding-top:12px;flex-shrink:0}
.step-arrow svg{width:20px;height:20px}

/* ===== FAILURE PATTERN ===== */
.failure-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.failure-card{background:var(--white);border-radius:var(--radius-md);padding:2.5rem 1.5rem 2rem;text-align:center;border:2px solid #e8e4da;position:relative;transition:all .3s ease;display:flex;flex-direction:column;align-items:center}
.failure-card:hover{transform:translateY(-4px);border-color:var(--primary)}
.failure-icon{width:100px;height:100px;margin:0 auto 16px;position:relative}
.failure-icon::before{content:'✕';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:260px;font-weight:900;color:rgba(0,0,0,.06);line-height:1;pointer-events:none;z-index:0}
.failure-icon img{width:100%;height:100%;object-fit:contain;position:relative;z-index:1}
.failure-title{font-size:17px;font-weight:700;color:var(--text);line-height:1.7;margin-bottom:14px;letter-spacing:.04em}
.failure-desc{font-size:14px;color:var(--text-light);line-height:1.9;letter-spacing:.03em;text-align:left;margin-bottom:16px}
.failure-cta{margin-top:auto;text-align:center}
.failure-arrow{display:block;color:var(--primary);font-size:18px;margin-bottom:8px}
.failure-btn{display:block;background:var(--primary);color:var(--white);font-size:13px;font-weight:700;padding:16px 40px;border-radius:var(--radius-pill);letter-spacing:.04em;line-height:1.3;transition:opacity .2s}
.failure-btn:hover{opacity:.85}
.failure-btn-line{background:var(--green)}

/* ===== MERIT CARDS ===== */
.merit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.merit-card{background:var(--white);border-radius:var(--radius-md);padding:2rem 1.5rem;box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid var(--border)}
.merit-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.merit-icon{width:56px;height:56px;border-radius:50%;background:var(--bg-cream);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.merit-icon svg{width:28px;height:28px;stroke:var(--primary);stroke-width:1.5;fill:none}
.merit-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:12px;letter-spacing:.04em}
.merit-desc{font-size:15px;color:var(--text-light);line-height:2;letter-spacing:.04em}

/* ===== COMPARISON TABLE ===== */
.compare-table{width:100%;border-collapse:separate;border-spacing:0;margin-bottom:3rem;font-size:15px;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md);table-layout:fixed}
.compare-table col.col-item{width:14%}
.compare-table col.col-ours{width:26%}
.compare-table col.col-rival{width:20%}
.compare-table th,.compare-table td{padding:16px 14px;border-bottom:1px solid var(--border);text-align:center;letter-spacing:.05em;vertical-align:middle}
.compare-table thead th{background:var(--primary);color:var(--white);font-weight:700;font-size:14px;border-bottom:none;letter-spacing:.08em}
.compare-table thead th:nth-child(2){background:var(--primary);position:relative}
.compare-table thead th:nth-child(2)::after{content:'';position:absolute;bottom:0;left:15%;right:15%;height:3px;background:var(--accent);border-radius:2px}
.compare-table thead th.rival{background:var(--text-light)}
.compare-table thead th.item{background:#3a5a72}
.compare-table tbody td:first-child{text-align:left;font-weight:700;background:var(--bg-cream)}
.compare-table tbody td:nth-child(2){background:rgba(240,235,71,.06)}
.compare-table .good{color:var(--primary);font-weight:700}
.compare-table .bad{color:var(--primary)}
.compare-table .mid{color:#b08c30}
.compare-table .td-mark{display:block;font-size:22px;line-height:1;margin-bottom:4px;text-align:center}
.compare-table tbody tr:hover td{background:rgba(5,54,87,.03)}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-summary{text-align:center;margin-top:2.5rem;padding:2.5rem 2rem;background:var(--primary);border-radius:var(--radius-lg);color:var(--white)}
.compare-summary-lead{font-size:1.1rem;font-weight:700;line-height:1.9;letter-spacing:.04em;margin-bottom:12px}
.compare-summary-lead strong{color:var(--accent);font-weight:700}
.compare-summary-big{font-size:1.6rem;font-weight:700;line-height:1.6;letter-spacing:.06em}
.compare-keyword{display:inline-block;background:var(--accent);color:var(--primary);font-weight:700;padding:2px 14px;border-radius:var(--radius-pill);margin:0 4px;font-size:1.5rem}

/* ===== PILLAR CARDS ===== */
.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pillar-card{background:var(--white);border-radius:var(--radius-md);padding:2rem 1.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .3s ease}
.pillar-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pillar-img{margin-bottom:20px;text-align:center}
.pillar-img img{width:160px;aspect-ratio:1/1;object-fit:contain;margin:0 auto}
.pillar-title{font-size:17px;font-weight:700;color:var(--primary);margin-bottom:14px;letter-spacing:.04em}
.pillar-desc{font-size:15px;color:var(--text-light);line-height:2;letter-spacing:.04em}

/* ===== REASON BLOCKS ===== */
.reason-block{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem 3rem;margin-bottom:2rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative;display:flex;align-items:center;gap:2.5rem}
.reason-body{flex:6;min-width:0}
.reason-img{flex:4;display:flex;align-items:center;justify-content:center}
.reason-img img{width:220px;aspect-ratio:1/1;object-fit:contain}
.reason-number{font-size:48px;font-weight:900;color:var(--accent);line-height:1;margin-bottom:.5rem;letter-spacing:-.02em}
.reason-title{font-size:22px;font-weight:700;color:var(--primary);line-height:1.6;margin-bottom:1.5rem;letter-spacing:.04em;background:linear-gradient(transparent 60%,var(--accent) 60%);background-position-y:-10px;display:inline;padding:0 4px 10px;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.reason-list{list-style:none;padding:0}
.reason-list li{position:relative;padding-left:2rem;margin-bottom:.8rem;font-size:16px;color:var(--text);line-height:1.9;letter-spacing:.04em}
.reason-list li::before{content:'✓';position:absolute;left:0;width:1.8em;height:1.8em;background:var(--primary);color:var(--white);font-weight:700;font-size:10px;border-radius:50%;display:flex;align-items:center;justify-content:center;top:.75em}
.reason-list li strong{color:var(--primary);font-weight:700}
.reason-lead{font-size:16px;color:var(--text);line-height:1.9;margin-bottom:1.2rem;letter-spacing:.04em}
.reason-lead strong{color:var(--primary);font-weight:700}
.reason-qa{background:var(--bg-cream);border-radius:var(--radius-md);padding:1.8rem 2rem}
.reason-q{font-size:16px;font-weight:700;color:var(--text);margin-bottom:1rem;line-height:1.8;letter-spacing:.04em}
.reason-q::before{content:'▶';margin-right:.5em;color:var(--primary-light)}
.reason-a{font-size:16px;color:var(--text-light);line-height:2;letter-spacing:.04em}
.reason-a::before{content:'⇒';margin-right:.5em;color:var(--primary);font-weight:700}
.reason-a strong{color:var(--primary);font-weight:700}

/* ===== CONCIERGE SECTION ===== */
.concierge-grid{display:flex;flex-direction:column;gap:2rem}
.concierge-card{display:flex;gap:2.5rem;background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.concierge-photo{flex:0 0 180px;text-align:center}
.concierge-photo img{width:180px;height:180px;border-radius:50%;object-fit:cover;object-position:40% 20%;border:4px solid var(--accent);box-shadow:var(--shadow-md)}
.concierge-info{flex:1;min-width:0}
.concierge-position{display:inline-block;background:var(--primary);color:var(--white);font-size:13px;font-weight:700;padding:3px 14px;border-radius:var(--radius-pill);margin-bottom:8px;letter-spacing:.06em}
.concierge-name{font-size:24px;font-weight:700;color:var(--primary);margin-bottom:10px;letter-spacing:.04em}
.concierge-kana{font-size:14px;font-weight:400;color:var(--text-muted);margin-left:.8em;letter-spacing:.08em}
.concierge-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.concierge-badge{display:inline-block;background:var(--bg-cream);color:var(--primary);font-size:13px;font-weight:700;padding:4px 12px;border-radius:var(--radius-pill);border:1px solid var(--border-md);letter-spacing:.04em}
.concierge-message{font-size:15px;color:var(--text-light);line-height:2;margin-bottom:16px;letter-spacing:.04em}
.concierge-stats{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:8px 24px}
.concierge-stats li{font-size:14px;color:var(--text);letter-spacing:.04em}
.concierge-stats li strong{color:var(--primary);margin-right:.5em}

/* ===== STORY SECTION (お悩み → サービス概要) ===== */
.story-section{background:#F0F1ED;padding:0rem 4rem;position:relative;overflow:hidden}
.story-question{text-align:center;font-size:2rem;font-weight:700;color:var(--text);margin:3rem;letter-spacing:.05em}
.story-question .dot{color:var(--primary);font-size:2.4rem;position:relative}
.story-question .dot::before{content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:7px;height:7px;background:var(--primary);border-radius:50%}
.worry-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;max-width:860px;margin:0 auto}
.worry-card{flex:0 1 calc(50% - 12px);max-width:300px;background:var(--bg-cream);border-radius:10px;padding:2rem 1.5rem;display:flex;align-items:center;justify-content:center;text-align:center;transition:all .3s ease;position:relative}
.worry-card::before{content:'？';position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:32px;height:32px;background:var(--primary);color:#fff;border-radius:50%;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}
.worry-card:hover{transform:translateY(-4px)}
.worry-text{font-size:16px;font-weight:700;color:var(--text);line-height:1.9;letter-spacing:.02em}
.worry-illust{display:flex;justify-content:center;align-items:flex-end;gap:1rem;margin-top:2rem}
.worry-illust img{width:100%;max-width:240px;object-fit:contain}
.story-arrow{text-align:center;padding:3.5rem 0 0;background:var(--accent);position:relative;margin-top:2rem;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);padding-left:calc(50vw - 50%);padding-right:calc(50vw - 50%)}
.story-arrow::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:30px;background:#F0F1ED;clip-path:polygon(0 0,100% 0,50% 100%)}
.story-arrow svg{display:none}
.story-solution-wrap{background:var(--accent);margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);padding:2.5rem calc(50vw - 50%)}
.story-solution{background:var(--white);border-radius:var(--radius-lg);padding:3rem 2.5rem;box-shadow:var(--shadow-md);border:2px solid var(--accent);text-align:center}
.story-solution-inner{display:flex;align-items:center;gap:2rem;margin-bottom:2rem}
.story-video{flex:1;aspect-ratio:16/9;border-radius:var(--radius-md);overflow:hidden}
.story-video iframe{width:100%;height:100%;display:block}
.yt-facade{position:relative;width:100%;height:100%;cursor:pointer;background:#000}
.yt-facade img{width:100%;height:100%;object-fit:cover}
.yt-facade-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:none;border:none;cursor:pointer;padding:0;opacity:.85;transition:opacity .2s}
.yt-facade:hover .yt-facade-btn{opacity:1}
.story-solution-right{flex:1}
.story-lead{font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:.06em;line-height:1.7}
.story-lead-big{font-size:1.875rem;letter-spacing:.08em;background:linear-gradient(transparent 60%,var(--white) 60%);padding:0 4px}
.story-lead-wrap{display:flex;align-items:center;justify-content:center;gap:.5rem}
.story-lead-deco{color:var(--primary);font-size:2.5rem;font-weight:900;line-height:1;flex-shrink:0}
.story-heading{font-size:1.5rem;font-weight:700;color:var(--primary);line-height:1.7;letter-spacing:.05em;margin-bottom:1.2rem}
.story-desc{font-size:15px;color:var(--text-light);line-height:2;letter-spacing:.04em;margin-bottom:.8rem;text-align:left}
.sp-only{display:none}
.catch-flow{display:flex;align-items:center;justify-content:center;gap:12px;padding:2rem 0 .5rem;border-top:1px solid var(--border)}
.catch-flow-item{text-align:center;flex:0 0 auto}
.catch-flow-icon{width:72px;height:72px;border-radius:50%;background:var(--bg-cream);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;border:2px solid var(--border);transition:all .3s ease}
.catch-flow-icon.accent{background:var(--accent);border-color:var(--accent-dark);width:80px;height:80px}
.catch-flow-icon svg{width:32px;height:32px}
.catch-flow-label{font-size:14px;font-weight:700;color:var(--text);line-height:1.6;letter-spacing:.04em}
.catch-flow-arrow{flex-shrink:0;display:flex;align-items:center;margin-bottom:24px}
.catch-flow-center .catch-flow-label{color:var(--primary)}

/* ===== PRICING ===== */
.price-hero{text-align:center;padding:0 0 3rem;background:transparent;border:none;border-radius:var(--radius-lg);position:relative;box-shadow:none}
.price-label{display:inline-block;font-size:16px;color:var(--text-light);margin-bottom:8px;letter-spacing:.08em;background:var(--white);border:2px solid var(--primary);border-radius:var(--radius-pill);padding:5px 50px}
.price-number{font-family:'Roboto',sans-serif;font-size:6rem;font-weight:700;color:var(--primary);line-height:1;letter-spacing:-.02em}
.price-unit{font-family:'Noto Sans JP',sans-serif;font-size:2rem;color:var(--primary);font-weight:700}
.price-plus{font-family:'Roboto','Noto Sans JP',sans-serif;font-size:2rem;font-weight:700;color:var(--primary);margin-left:4px}
.price-note{font-size:15px;color:var(--text-light);letter-spacing:.06em}
.price-sub{font-size:14px;color:var(--text-light);margin-top:6px;letter-spacing:.04em}
.why-free{background:var(--white);border-radius:var(--radius-md);padding:1.25rem 2rem;box-shadow:var(--shadow-sm);margin-bottom:1rem;border:1px solid var(--border);max-width:750px;margin-left:auto;margin-right:auto}
.why-free h3{font-size:1.125rem;font-weight:700;color:var(--text);margin-bottom:8px;text-align:center;letter-spacing:.05em;background:var(--accent);display:inline-block;padding:4px 16px;margin-left:auto;margin-right:auto;width:auto}
.why-free{text-align:center}
.why-free h3 svg{width:24px;height:24px;stroke:var(--primary);stroke-width:1.5;fill:none}
.why-free p{font-size:15px;color:var(--text-light);line-height:2;letter-spacing:.04em;text-align:left}
.free-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:750px;margin-left:auto;margin-right:auto}
.free-item{background:var(--bg-cream);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;font-size:15px;color:var(--text);display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:.05em;transition:all .2s}
.free-item:hover{border-color:var(--accent);background:rgba(240,235,71,.08)}
.free-item svg{width:20px;height:20px;stroke:var(--primary);stroke-width:2;fill:none;flex-shrink:0}

/* ===== RESULTS ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:3.5rem}
.kpi-card{text-align:center;padding:2.5rem 1.5rem;background:var(--white);border:2px solid var(--primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .3s ease}
.kpi-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.kpi-num{font-family:'Roboto',sans-serif;font-size:3.5rem;font-weight:700;color:var(--primary);line-height:1;letter-spacing:-.02em}
.kpi-num span{font-size:1.25rem;font-weight:700}
.kpi-label{font-size:14px;color:var(--text-light);margin-top:10px;letter-spacing:.08em;font-weight:600}
.case-slider{position:relative;overflow:hidden;padding:0 48px}
.case-slider-track{display:flex;gap:20px;transition:transform .4s ease}
.case-card{flex:0 0 calc(33.333% - 14px);background:var(--white);border-radius:var(--radius-md);padding:1.8rem;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.case-type{display:inline-block;background:var(--primary);color:var(--white);padding:4px 16px;border-radius:var(--radius-pill);font-size:13px;font-weight:700;margin-bottom:12px;letter-spacing:.1em}
.case-area{font-size:15px;color:var(--text);margin-bottom:12px;letter-spacing:.06em;font-weight:700}
.case-price{background:var(--bg-cream);border:none;border-radius:var(--radius-md);padding:5px;text-align:center;font-size:15px;letter-spacing:.05em}
.case-price strong{font-family:'Roboto',sans-serif;font-size:1.5rem;color:var(--primary);font-weight:700}
.case-detail{list-style:none;padding:0;margin-top:12px;display:flex;flex-wrap:wrap;gap:6px 16px}
.case-detail li{font-size:13px;color:var(--text-light);letter-spacing:.04em}
.case-detail li strong{color:var(--primary);margin-right:.4em}
.case-slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--primary);transition:all .2s}
.case-slider-btn:hover{background:var(--primary);color:var(--white)}
.case-slider-btn.prev{left:0}
.case-slider-btn.next{right:0}

/* ===== FAQ ===== */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:14px;overflow:hidden;transition:all .3s ease}
.faq-item:hover{box-shadow:var(--shadow-sm)}
.faq-item.open{border-color:var(--border-md)}
.faq-q{background:var(--white);padding:20px 56px 20px 22px;font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:14px;cursor:pointer;transition:background .2s;position:relative;letter-spacing:.05em}
.faq-q::after{content:'';position:absolute;right:22px;width:12px;height:12px;border-right:2px solid var(--primary);border-bottom:2px solid var(--primary);transform:rotate(45deg);transition:transform .3s cubic-bezier(.22,1,.36,1);top:calc(50% - 8px)}
.faq-item.open .faq-q::after{transform:rotate(-135deg);top:calc(50% - 4px)}
.faq-q:hover{background:var(--bg-cream)}
.faq-qi{width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:'Roboto',sans-serif;font-size:13px;font-weight:700;flex-shrink:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.22,1,.36,1),padding .3s;padding:0 22px 0 68px;font-size:15px;color:var(--text-light);line-height:2;letter-spacing:.05em}
.faq-item.open .faq-a{max-height:200px;padding:10px 22px 22px 68px}
.faq-a b{color:var(--primary);font-weight:700}

/* ===== CONTACT ===== */
.contact-section{background:var(--primary);padding:5rem 0;color:var(--white);position:relative;overflow:hidden}
.contact-section::before{content:'';position:absolute;top:-2px;left:0;right:0;height:80px;background:var(--white);clip-path:ellipse(55% 100% at 50% 0%);pointer-events:none;z-index:1}
.contact-section::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(160deg,rgba(5,54,87,1) 0%,rgba(6,92,150,.4) 100%);pointer-events:none}
.contact-header{text-align:center;margin-bottom:3.5rem;position:relative;z-index:2;padding-top:2rem}
.contact-header h2{font-size:2rem;font-weight:700;margin-bottom:12px;letter-spacing:.05em}
.contact-header p{font-size:16px;color:rgba(255,255,255,.8);letter-spacing:.08em}
.contact-methods{display:flex;gap:16px;justify-content:center;margin:0 auto 3rem;max-width:900px;position:relative;z-index:2}
.contact-card-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-pill);font-size:15px;font-weight:700;color:var(--white);transition:all .2s ease-in-out;letter-spacing:.05em;white-space:nowrap;box-shadow:var(--shadow-btn);flex:1;justify-content:center}
.contact-card-btn:hover{opacity:.85;transform:translateY(-2px)}
.contact-card-btn.phone{background:var(--accent);color:var(--primary)}
.contact-card-btn.mail{background:var(--white);color:var(--primary)}
.contact-card-btn.line{background:var(--green)}

/* ===== FORM ===== */
.contact-form{background:var(--white);border-radius:var(--radius-lg);padding:3rem;max-width:800px;margin:0 auto;box-shadow:var(--shadow-lg);position:relative;z-index:2}
.form-title{font-size:1.25rem;font-weight:700;color:var(--text);text-align:center;margin-bottom:8px;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;gap:10px}
.form-title svg{width:24px;height:24px;stroke:var(--primary);stroke-width:1.5;fill:none}
.form-subtitle{font-size:14px;color:var(--text-light);text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);letter-spacing:.08em}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-group{margin-bottom:0}
.form-group.full{grid-column:1/-1}
.form-label{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px;display:block;letter-spacing:.04em}
.wpcf7 .wpcf7-form-control-wrap{display:block;margin-top:0}
.wpcf7 .form-group label>br{display:none}
.form-label .req{color:var(--primary);font-size:12px;margin-left:4px;font-weight:700}
.form-input,.form-textarea{width:100%;padding:14px 16px;border:1px solid var(--border-md);border-radius:8px;font-size:15px;font-family:inherit;transition:all .2s;background:var(--white);letter-spacing:.05em;color:var(--text)}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(5,54,87,.3)}
.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(5,54,87,.08)}
.form-textarea{height:110px;resize:vertical}
.form-submit{width:100%;padding:1.125rem;background:var(--primary);color:var(--white);border:none;border-radius:var(--radius-pill);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease-in-out;margin-top:1.25rem;box-shadow:var(--shadow-btn);letter-spacing:.08em}
.form-submit:hover{opacity:.85;transform:translateY(-2px)}
.form-privacy{font-size:12px;color:var(--text-muted);text-align:center;margin-top:14px;letter-spacing:.05em}
.form-privacy a{color:var(--primary);text-decoration:underline}
/* CF7 overrides */
.wpcf7 .wpcf7-form{margin:0}
.wpcf7 .wpcf7-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.wpcf7 .wpcf7-form .form-group.full{grid-column:1/-1}
.wpcf7 .wpcf7-form .wpcf7-form-control.form-input,.wpcf7 .wpcf7-form .wpcf7-form-control.form-textarea{width:100%;padding:10px 16px;border:1px solid var(--border-md);border-radius:8px;font-size:15px;font-family:inherit;transition:all .2s;background:var(--white);letter-spacing:.05em;color:var(--text)}
.wpcf7 .wpcf7-form .wpcf7-form-control.form-input::placeholder,.wpcf7 .wpcf7-form .wpcf7-form-control.form-textarea::placeholder{color:rgba(5,54,87,.3)}
.wpcf7 .wpcf7-form .wpcf7-form-control.form-input:focus,.wpcf7 .wpcf7-form .wpcf7-form-control.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(5,54,87,.08)}
.wpcf7 .wpcf7-form .wpcf7-form-control.form-textarea{height:110px;resize:vertical}
.wpcf7 .wpcf7-form input[type="submit"].form-submit,.wpcf7 .wpcf7-form .wpcf7-submit.form-submit{width:100%;padding:1.125rem;background:var(--primary);color:var(--white);border:none;border-radius:var(--radius-pill);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease-in-out;margin-top:1.25rem;box-shadow:var(--shadow-btn);letter-spacing:.08em}
.wpcf7 .wpcf7-form input[type="submit"].form-submit:hover{opacity:.85;transform:translateY(-2px)}
.wpcf7 .wpcf7-response-output{text-align:center;font-size:14px;margin:16px 0 0!important;padding:12px!important;border-radius:8px!important}
.wpcf7 .wpcf7-not-valid-tip{font-size:12px;color:var(--primary);margin-top:4px}
.wpcf7 p{margin:0}

/* ===== STICKY CTA BAR ===== */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;background:var(--white);padding:14px 0;z-index:999;transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);box-shadow:0 -4px 20px rgba(5,54,87,.10);border-top:1px solid var(--border);display:none}
.sticky-cta.show{transform:translateY(0)}
.sticky-inner{display:flex;align-items:center;justify-content:space-between;max-width:1140px;margin:0 auto;padding:0 2.5rem}
.sticky-text{color:var(--text);font-size:15px;font-weight:700;letter-spacing:.08em}
.sticky-btns{display:flex;gap:6px;flex:1;align-items:center}
.sticky-btns .btn{padding:10px 22px;font-size:13px}
.btn-sticky-cta{flex:1;background:var(--accent);color:var(--primary);display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:var(--radius-pill);font-size:15px;font-weight:700;letter-spacing:.06em;height:44px}
.btn-sticky-guide{flex:none;display:flex;align-items:center;justify-content:center;padding:0;background:none;box-shadow:none;height:44px}
.sticky-guide-img{height:44px;width:auto}

/* ===== FOOTER ===== */
.site-footer{background:var(--primary);color:var(--white);padding:3.5rem 0 1.5rem}
.footer-inner{display:flex;justify-content:space-between;gap:40px;margin-bottom:2rem}
.footer-brand{flex:1}
.footer-logo{font-family:'Roboto','Noto Sans JP',sans-serif;font-size:16px;font-weight:700;color:var(--white);margin-bottom:10px;letter-spacing:.1em}
.footer-desc{font-size:14px;color:rgba(255,255,255,.6);line-height:2;margin-bottom:8px;letter-spacing:.05em}
.footer-license{font-size:12px;color:rgba(255,255,255,.45);letter-spacing:.05em}
.footer-nav{display:flex;gap:48px}
.footer-nav-group h4{font-size:14px;font-weight:700;color:rgba(255,255,255,.85);margin-bottom:14px;letter-spacing:.08em}
.footer-nav-group a{display:block;font-size:14px;color:rgba(255,255,255,.6);margin-bottom:10px;transition:color .2s;letter-spacing:.05em}
.footer-nav-group a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.25rem;display:flex;justify-content:space-between;font-size:13px;color:rgba(255,255,255,.45);letter-spacing:.05em}
.footer-bottom a{color:rgba(255,255,255,.6);transition:color .2s}
.footer-bottom a:hover{color:var(--white)}

/* ===== PAGE HERO & POLICY ===== */
.page-hero{background:var(--primary);padding:120px 0 3rem;text-align:center}
.page-hero-title{font-size:1.75rem;font-weight:700;color:var(--white);letter-spacing:.06em}
.policy-content{max-width:820px;margin:0 auto}
.policy-intro{font-size:16px;color:var(--text);line-height:2;margin-bottom:2.5rem;letter-spacing:.04em}
.policy-section{margin-bottom:2.5rem}
.policy-section h2{font-size:18px;font-weight:700;color:var(--primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent);letter-spacing:.04em}
.policy-section p{font-size:15px;color:var(--text-light);line-height:2;letter-spacing:.04em}
.policy-section ul{list-style:none;padding:0;margin-top:.8rem}
.policy-section ul li{position:relative;padding-left:1.5em;margin-bottom:.5rem;font-size:15px;color:var(--text-light);line-height:1.9;letter-spacing:.04em}
.policy-section ul li::before{content:'・';position:absolute;left:0;color:var(--primary)}
.policy-contact{background:var(--bg-cream);border-radius:var(--radius-md);padding:1.5rem 2rem;margin-top:1rem}
.policy-contact p{margin-bottom:.3rem}
.policy-contact a{color:var(--primary-light);font-weight:700}
.policy-date{font-size:14px;color:var(--text-muted);text-align:right;margin-top:2rem;letter-spacing:.04em}


/* ===== BLOG ===== */
.blog-layout{display:flex;flex-direction:row-reverse;gap:3rem;align-items:flex-start}
.blog-main{flex:1;min-width:0}
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.blog-card{background:var(--white);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;transition:all .3s ease;box-shadow:var(--shadow-sm)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-card-link{display:block;color:inherit}
.blog-card-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-light)}
.blog-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.blog-card:hover .blog-card-thumb img{transform:scale(1.05)}
.blog-card-nothumb{width:100%;height:100%;background:var(--bg-light)}
.blog-card-nothumb.small{width:100%;height:100%;background:var(--bg-light)}
.blog-card-body{padding:1.2rem 1.5rem}
.blog-card-cat{display:inline-block;background:var(--primary);color:var(--white);font-size:12px;font-weight:700;padding:2px 10px;border-radius:var(--radius-pill);margin-bottom:8px;letter-spacing:.06em}
.blog-card-title{font-size:16px;font-weight:700;color:var(--text);line-height:1.7;letter-spacing:.04em;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-date{font-size:13px;color:var(--text-muted);letter-spacing:.04em}

/* Blog Article */
.blog-article{background:var(--white);border-radius:var(--radius-lg);padding:3rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:2rem}
.blog-article-header{margin-bottom:2rem}
.blog-article-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.blog-article-date{font-size:14px;color:var(--text-muted);letter-spacing:.04em}
.blog-article-cat{display:inline-block;background:var(--primary);color:var(--white);font-size:12px;font-weight:700;padding:2px 10px;border-radius:var(--radius-pill);letter-spacing:.06em}
.blog-article-title{font-size:1.75rem;font-weight:700;color:var(--text);line-height:1.6;letter-spacing:.04em}
.blog-article-hero{margin-bottom:2rem;border-radius:var(--radius-md);overflow:hidden}
.blog-article-hero img{width:100%;height:auto;display:block}
.blog-article-content{font-size:16px;color:var(--text);line-height:2;letter-spacing:.04em}
.blog-article-content h2{font-size:1.5rem;font-weight:700;color:var(--primary);margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent)}
.blog-article-content h3{font-size:1.25rem;font-weight:700;color:var(--text);margin:2rem 0 .8rem}
.blog-article-content p{margin-bottom:1.5rem}
.blog-article-content img{border-radius:var(--radius-md);margin:1.5rem 0}
.blog-article-content ul,.blog-article-content ol{margin:1rem 0 1.5rem;padding-left:1.5em}
.blog-article-content ul{list-style:disc}
.blog-article-content ol{list-style:decimal}
.blog-article-content li{margin-bottom:.5rem;line-height:1.9}
.blog-article-content blockquote{border-left:4px solid var(--accent);padding:1rem 1.5rem;margin:1.5rem 0;background:var(--bg-cream);border-radius:0 var(--radius-md) var(--radius-md) 0}
.blog-article-content a{color:var(--primary-light);text-decoration:underline}

/* Blog Navigation */
.blog-nav{display:flex;justify-content:space-between;gap:1rem}
.blog-nav-link{flex:1;display:block;padding:1.2rem 1.5rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .2s;max-width:48%}
.blog-nav-link:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.blog-nav-prev{text-align:left}
.blog-nav-next{text-align:right;margin-left:auto}
.blog-nav-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:4px;letter-spacing:.04em}
.blog-nav-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.6;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}

/* Blog Pagination */
.blog-pagination{margin-top:2.5rem;text-align:center}
.blog-pagination .nav-links{display:flex;justify-content:center;gap:6px}
.blog-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;font-size:14px;font-weight:700;color:var(--text);background:var(--white);border:1px solid var(--border);transition:all .2s}
.blog-pagination .page-numbers.current{background:var(--primary);color:var(--white);border-color:var(--primary)}
.blog-pagination .page-numbers:hover{border-color:var(--primary)}
.blog-empty{text-align:center;font-size:16px;color:var(--text-muted);padding:3rem 0}

/* Sidebar */
.blog-sidebar{flex:0 0 280px}
.sidebar-widget{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}
.sidebar-title{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent);letter-spacing:.04em}
.sidebar-cat-list{list-style:none;padding:0}
.sidebar-cat-list li{margin-bottom:0}
.sidebar-cat-list li a{display:block;padding:8px 0;font-size:14px;color:var(--text);border-bottom:1px solid var(--border);transition:color .2s;letter-spacing:.04em}
.sidebar-cat-list li a:hover{color:var(--primary-light)}
.sidebar-cat-list li:last-child a{border-bottom:none}
.sidebar-recent{list-style:none;padding:0}
.sidebar-recent li{margin-bottom:12px}
.sidebar-recent li:last-child{margin-bottom:0}
.sidebar-recent-link{display:flex;gap:10px;align-items:center}
.sidebar-recent-thumb{flex:0 0 60px;height:45px;border-radius:6px;overflow:hidden;background:var(--bg-light)}
.sidebar-recent-thumb img{width:100%;height:100%;object-fit:cover}
.sidebar-recent-body{flex:1;min-width:0}
.sidebar-recent-title{display:block;font-size:13px;font-weight:700;color:var(--text);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sidebar-recent-date{font-size:12px;color:var(--text-muted)}
.sidebar-cta{background:var(--primary);text-align:center;padding:2rem 1.5rem}
.sidebar-cta-text{color:var(--white);font-size:15px;font-weight:700;line-height:1.7;margin-bottom:1rem;letter-spacing:.04em}
.sidebar-cta-btn{display:inline-block;background:var(--accent);color:var(--primary);padding:10px 24px;border-radius:var(--radius-pill);font-size:14px;font-weight:700;letter-spacing:.06em;transition:all .2s}
.sidebar-cta-btn:hover{opacity:.85;transform:translateY(-1px)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  body{line-height:1.8}
  .container{padding:0 1.25rem}
  .header-nav{display:none}
  .header-guide{display:none}
  .sp-only{display:inline}
  .bridge-text{font-size:1.3rem}
  .bridge-highlight{font-size:1.4rem;padding:3px 14px}
  .header-cta{display:none}
  .hamburger{display:block}
  .sticky-cta{display:block}
  .header-inner{padding:0 1.25rem;height:60px;max-width:360px}
  .hero{padding:110px 0 60px}
  .hero-content{flex-direction:column;gap:24px}
  .hero-image{order:1}
  .hero-image img{max-width:280px}
  .hero h1{font-size:1.5rem}
  .hero h2{font-size:.9rem}
  .hero-features{gap:16px;flex-wrap:nowrap}
  .hero-feature-item{width:100px;height:100px;border-width:8px}
  .hero-feature-item span{font-size:13px}
  .hero-feature-item svg{width:18px;height:18px}
  .hero::after{background-size:300px auto}
  .badge-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .badge-item{padding:16px 8px}
  .badge-text{font-size:12px}
  .section{padding:3.5rem 0}
  .steps-flow{flex-direction:column;gap:0}
  .step-arrow{display:none}
  .step-item{flex:none;display:flex;align-items:center;text-align:left;padding:16px 0;border-bottom:1px solid var(--border)}
  .step-item:last-child{border-bottom:none}
  .step-num{margin:0 16px 0 0;flex-shrink:0}
  .step-body{flex:1;min-width:0}
  .step-label{font-size:15px;margin-bottom:2px}
  .step-label br{display:none}
  .step-desc{font-size:12px;max-width:none;margin:0;text-align:left}
  .merit-grid,.pillar-grid,.free-list,.failure-grid{grid-template-columns:1fr}
  .failure-card{padding:1.5rem 1.2rem}
  .worry-grid{gap:12px}
  .worry-card{flex:0 1 calc(50% - 6px);padding:1.2rem 1rem}
  .worry-card::before{width:26px;height:26px;font-size:13px;top:-12px}
  .worry-text{font-size:12px;line-height:1.7}
  .worry-text br{display:none}
  .worry-illust{margin-top:1.2rem;gap:.5rem}
  .worry-illust img{max-width:160px}
  .contact-methods{flex-direction:column}
  .case-slider{padding:0 36px}
  .case-card{flex:0 0 calc(100% - 14px)}
  .kpi-grid{grid-template-columns:1fr}
  .compare-table{font-size:10px}
  .compare-table th,.compare-table td{padding:10px 8px}
  .reason-block{padding:1.8rem 1.5rem;flex-direction:column}
  .reason-img{flex:0 0 auto}
  .reason-img img{width:140px}
  .reason-title{font-size:20px}
  .reason-title br{display:none}
  .reason-qa{padding:1.2rem 1.25rem}
  .concierge-card{flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem}
  .concierge-badges{justify-content:center}
  .concierge-stats{justify-content:center;flex-direction:column;align-items:center}
  .form-grid{grid-template-columns:1fr}
  .wpcf7 .wpcf7-form .form-grid{grid-template-columns:1fr}
  .contact-form{padding:1.5rem}
  .wpcf7 .wpcf7-form input[type="submit"].form-submit,.wpcf7 .wpcf7-submit.form-submit{white-space:normal;word-break:break-all}
  .contact-section::before{height:40px}
  .footer-inner{flex-direction:column}
  .footer-nav{gap:32px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .sticky-inner{padding:0 1.25rem;justify-content:center}
  .section-title{font-size:1.5rem}
  .price-number{font-size:4rem}
  .kpi-num{font-size:2.5rem}
  .sp-only{display:inline}
  .story-section{padding:2.5rem 0 3.5rem}
  .story-question{font-size:1.375rem;margin:1.5rem}
  .story-question .dot{font-size:1.7rem}
  .story-question .dot::before{width:5px;height:5px;top:-5px}
  .story-lead{font-size:1rem;line-height:1.8}
  .story-lead-big{font-size:1.35rem}
  .story-solution{padding:2rem 1.25rem}
  .story-solution-inner{flex-direction:column}
  .story-main{font-size:1.25rem}
  .story-arrow{padding:3rem 0 1.5rem;margin-top:1.5rem}
  .story-arrow::before{height:30px}
  .catch-flow{flex-direction:column;gap:8px}
  .catch-flow-arrow{transform:rotate(90deg);margin-bottom:0}
  .catch-flow-icon{width:64px;height:64px}
  .catch-flow-icon.accent{width:72px;height:72px}
  .blog-layout{flex-direction:column}
  .blog-sidebar{flex:none;width:100%}
  .blog-grid{grid-template-columns:1fr}
  .blog-article{padding:1.5rem}
  .blog-article-title{font-size:1.3rem}
  .blog-nav{flex-direction:column}
  .blog-nav-link{max-width:100%}
  .bridge-question-card{padding:1.5rem 1.2rem}
  .bridge-question-card p{font-size:1.1rem}
}
