:root {
 --ink: #0f172a;
 --ink-2: #1e293b;
 --muted: #64748b;
 --muted-2: #94a3b8;
 --line: #e2e8f0;
 --line-2: #cbd5e1;
 --paper: #ffffff;
 --paper-2: #f8fafc;
 --paper-3: #f1f5f9;
 --brand: #0ea5e9;
 --brand-deep: #0284c7;
 --brand-soft: #e0f2fe;
 --warm: #f59e0b;
 --warm-soft: #fef3c7;
 --max: 1180px;
 --gutter: clamp(20px, 4vw, 32px);
 }
 *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
 html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 80px; }
 body {
 font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", sans-serif;
 font-feature-settings: "palt";
 color: var(--ink);
 background: var(--paper);
 line-height: 1.75;
 -webkit-font-smoothing: antialiased;
 }
 img { display: block; max-width: 100%; height: auto; }
 a { color: var(--brand-deep); text-decoration: none; transition: color .15s; }
 a:hover { color: var(--brand); }
 ul { list-style: none; }
 h1, h2, h3, h4 { line-height: 1.4; letter-spacing: 0.01em; }

 .container { max-width: var(--max); margin-inline: auto; padding-inline: var(--gutter); }
 .skiplink { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
 .skiplink:focus { position: static; width: auto; height: auto; padding: 8px 12px; background: var(--ink); color: #fff; z-index: 999; }

 .site_header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.92); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
 .header_inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 0; }
 .brand { display: inline-flex; align-items: center; gap: 12px; }
 .brand img { height: 40px; width: auto; }
 .nav_menu { display: flex; gap: 28px; font-size: 14px; font-weight: 500; }
 .nav_menu a { color: var(--ink-2); }
 .nav_menu a:hover { color: var(--brand); }
 .header_actions { display: flex; gap: 10px; align-items: center; }
 .btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; border-radius: 8px; font-size: 14px; font-weight: 600; letter-spacing: 0.02em; transition: all .15s; white-space: nowrap; }
 .btn_primary { background: var(--ink); color: #fff; border: 1px solid var(--ink); }
 .btn_primary:hover { background: var(--ink-2); color: #fff; }
 .btn_outline { background: #fff; color: var(--ink); border: 1px solid var(--line-2); }
 .btn_outline:hover { border-color: var(--brand); color: var(--brand); }
 .btn_lg { padding: 14px 28px; font-size: 15px; border-radius: 10px; }
 .btn_brand { background: var(--brand); color: #fff; border: 1px solid var(--brand); }
 .btn_brand:hover { background: var(--brand-deep); color: #fff; border-color: var(--brand-deep); }
 .nav_toggle {
 display: none;
 background: transparent;
 border: 1px solid var(--line);
 border-radius: 8px;
 padding: 9px 10px;
 cursor: pointer;
 flex-direction: column;
 align-items: center;
 justify-content: center;
 gap: 4px;
 width: 42px;
 height: 42px;
 }
 .nav_toggle .bar { display: block; width: 22px; height: 2px; background: var(--ink); border-radius: 2px; }
 @media (max-width: 880px) {
 .nav_menu { display: none; }
 .nav_toggle { display: inline-flex; }
 .nav_menu.open { display: flex; position: absolute; top: 100%; right: var(--gutter); flex-direction: column; gap: 14px; padding: 20px; background: #fff; border: 1px solid var(--line); border-radius: 12px; box-shadow: 0 12px 40px rgba(0,0,0,.08); }
 .header_inner { gap: 10px; }
 .brand img { height: 34px; }
 .header_actions { gap: 8px; }
 .header_actions .btn { padding: 9px 14px; font-size: 13px; }
 }

 .hero { position: relative; padding: clamp(60px, 10vw, 110px) 0 clamp(50px, 8vw, 90px); background: radial-gradient(ellipse at top right, rgba(14,165,233,0.08) 0%, transparent 50%), linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); overflow: hidden; }
 .hero_inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(24px, 5vw, 64px); align-items: center; }
 .hero_text .pre { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: var(--brand-deep); background: var(--brand-soft); padding: 6px 14px; border-radius: 50px; letter-spacing: 0.06em; margin-bottom: 20px; }
 .hero_text .pre::before { content: ""; width: 6px; height: 6px; background: var(--brand); border-radius: 50%; }
 .hero_text h1 { font-size: clamp(28px, 4.5vw, 44px); font-weight: 800; line-height: 1.35; color: var(--ink); margin-bottom: 20px; letter-spacing: -0.01em; }
 .hero_text h1 .accent { color: var(--brand-deep); }
 .hero_text .lead { font-size: 15px; line-height: 1.85; color: var(--muted); margin-bottom: 28px; max-width: 540px; }
 .hero_cta { display: flex; gap: 12px; flex-wrap: wrap; }
 .hero_visual { position: relative; background: linear-gradient(135deg, var(--brand-soft) 0%, #f0f9ff 100%); border: 1px solid var(--brand-soft); border-radius: 20px; aspect-ratio: 4/3; padding: 36px; display: flex; flex-direction: column; justify-content: space-between; overflow: hidden; max-width: 100%; min-width: 0; box-sizing: border-box; }
 .hero_visual::before { content: ""; position: absolute; bottom: -50px; right: -50px; width: 280px; height: 280px; background: radial-gradient(circle, rgba(14,165,233,0.18) 0%, transparent 70%); border-radius: 50%; }
 .hv_label { font-size: 11px; font-weight: 700; color: var(--brand-deep); letter-spacing: 0.2em; text-transform: uppercase; position: relative; }
 .hv_features { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
 .hv_features li { background: rgba(255,255,255,0.85); backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,0.9); border-radius: 12px; padding: 14px 16px; font-size: 13px; font-weight: 600; color: var(--ink); }
 .hv_features li strong { display: block; color: var(--brand-deep); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; margin-bottom: 4px; }
 @media (max-width: 880px) {
 .hero_inner { grid-template-columns: 1fr; }
 .hero_visual { aspect-ratio: 16/10; padding: 24px; }
 }

 section { padding: clamp(60px, 9vw, 100px) 0; }
 .section_alt { background: var(--paper-2); }
 .section_dark { background: var(--ink); color: rgba(255,255,255,0.92); }
 .section_intro { margin-bottom: clamp(32px, 5vw, 56px); }
 .eyebrow { display: inline-block; font-size: 11px; font-weight: 700; color: var(--brand-deep); letter-spacing: 0.25em; text-transform: uppercase; margin-bottom: 14px; }
 .section_dark .eyebrow { color: var(--brand); }
 .headline { font-size: clamp(22px, 3vw, 30px); font-weight: 700; line-height: 1.4; color: var(--ink); margin-bottom: 14px; letter-spacing: -0.005em; }
 .section_dark .headline { color: #fff; }
 .section_lead { font-size: 15px; line-height: 1.85; color: var(--muted); max-width: 720px; }
 .section_dark .section_lead { color: rgba(255,255,255,0.75); }

 .ac_section { background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); }
 .ac_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
 .ac_card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 28px 24px; transition: all .2s; }
 .ac_card:hover { border-color: var(--brand); box-shadow: 0 8px 30px rgba(14,165,233,0.10); transform: translateY(-2px); }
 .ac_card .ico { width: 44px; height: 44px; border-radius: 10px; background: var(--brand-soft); color: var(--brand-deep); display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; margin-bottom: 18px; }
 .ac_card h3 { font-size: 16px; font-weight: 700; color: var(--ink); margin-bottom: 10px; }
 .ac_card p { font-size: 13.5px; line-height: 1.75; color: var(--muted); }
 .ac_card_more { margin-top: 14px; font-size: 13.5px; }
 .ac_card_more a { color: var(--brand-deep); font-weight: 700; text-decoration: none; border-bottom: 1px solid currentColor; padding-bottom: 1px; }
 .ac_card_more a:hover { color: var(--brand); }
 .ac_card.featured .ac_card_more a { color: #fff; }
 .ac_card_actions { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
 .ac_card_btn { display: inline-flex; align-items: center; padding: 10px 18px; border-radius: 8px; font-size: 13.5px; font-weight: 700; text-decoration: none; transition: all 0.15s; }
 .ac_card_btn.primary { background: var(--brand); color: #fff; }
 .ac_card_btn.primary:hover { background: var(--brand-deep); transform: translateY(-1px); }
 .ac_card_btn.ghost { color: rgba(255,255,255,0.95); border: 1px solid rgba(255,255,255,0.4); }
 .ac_card_btn.ghost:hover { background: rgba(255,255,255,0.12); }

 /* ===== Summer strip (top banner) ===== */
 .summer-strip {
 display: flex; align-items: center; justify-content: center; gap: 14px;
 padding: 12px 20px;
 background: linear-gradient(90deg, #0ea5e9 0%, #16a34a 50%, #f59e0b 100%);
 color: #fff; text-decoration: none; font-weight: 700; font-size: 14px;
 flex-wrap: wrap;
 }
 .summer-strip:hover { filter: brightness(1.08); color: #fff; }
 .summer-strip-tag {
 background: rgba(255,255,255,.22); padding: 4px 12px; border-radius: 50px;
 font-size: 11px; letter-spacing: .12em;
 }
 .summer-strip-msg { font-size: 14px; }
 .summer-strip-sub { font-weight: 500; opacity: .9; margin-left: 8px; font-size: 13px; }
 .summer-strip-arrow { font-size: 13px; font-weight: 600; opacity: .95; }
 @media (max-width:720px){
 .summer-strip { font-size: 13px; padding: 10px 14px; gap: 8px; }
 .summer-strip-sub { display: none; }
 .summer-strip-arrow { display: none; }
 }
 .nav-summer { color: #16a34a !important; font-weight: 700; }
 .nav-summer:hover { color: #15803d !important; }

 /* ===== Services Overview (TOP事業ポートフォリオ) ===== */
 .overview_grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
 .overview_card {
 background: #fff; border: 1.5px solid var(--line); border-radius: 16px;
 padding: 24px 22px; text-decoration: none; color: var(--ink);
 display: flex; flex-direction: column; gap: 8px; transition: all 0.15s;
 position: relative; overflow: hidden;
 }
 .overview_card:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(0,0,0,0.06); }
 .overview_card .ovr_badge {
 font-size: 10px; font-weight: 700; letter-spacing: 0.15em;
 text-transform: uppercase; color: var(--brand-deep);
 }
 .overview_card .ovr_num { font-family: "Inter", sans-serif; font-size: 34px; font-weight: 800; line-height: 1; letter-spacing: -0.02em; color: var(--line); margin: 4px 0; }
      .overview_card:hover .ovr_num { color: var(--brand); }
 .overview_card h3 { font-size: 18px; font-weight: 800; color: var(--ink); letter-spacing: 0.02em; }
 .overview_card p { font-size: 13px; color: var(--muted); line-height: 1.75; flex: 1; }
 .overview_card .ovr_more {
 font-size: 12px; font-weight: 700; color: var(--brand-deep);
 padding-top: 6px; border-top: 1px dashed var(--line);
 }
 .overview_card.aircon { border-color: #bae6fd; }
 .overview_card.aircon:hover { border-color: #0284c7; }
 .overview_card.aircon .ovr_badge, .overview_card.aircon .ovr_more { color: #0284c7; }
 .overview_card.grass { border-color: #bbf7d0; }
 .overview_card.grass:hover { border-color: #15803d; }
 .overview_card.grass .ovr_badge, .overview_card.grass .ovr_more { color: #15803d; }
 .overview_card.grave { border-color: #fed7aa; }
 .overview_card.grave:hover { border-color: #c2410c; }
 .overview_card.grave .ovr_badge, .overview_card.grave .ovr_more { color: #c2410c; }
 .overview_card.other { border-color: #e9d5ff; }
 .overview_card.other:hover { border-color: #7c3aed; }
 .overview_card.other .ovr_badge, .overview_card.other .ovr_more { color: #7c3aed; }
 @media (max-width: 880px) { .overview_grid { grid-template-columns: 1fr 1fr; } }
 @media (max-width: 520px) { .overview_grid { grid-template-columns: 1fr; } }

 /* ===== Embed availability calendar ===== */
 .embed-cal { background: #fff; border-radius: 14px; padding: 24px; max-width: 720px; margin: 0 auto 24px; box-shadow: 0 4px 18px rgba(0,0,0,0.05); border: 1px solid var(--line); width: 100%; box-sizing: border-box; overflow: hidden; }
 .embed-cal-loading { text-align: center; color: var(--muted); padding: 50px 0; font-size: 14px; }
 .embed-cal-month { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 8px; }
 .embed-cal-month .label { font-size: 17px; font-weight: 700; color: var(--ink); white-space: nowrap; }
 .embed-cal-month button { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 7px 16px; cursor: pointer; font-size: 13px; font-family: inherit; white-space: nowrap; flex-shrink: 0; }
 .embed-cal-month button:hover:not(:disabled) { background: var(--paper-3); border-color: var(--brand); }
 .embed-cal-month button:disabled { opacity: 0.3; cursor: not-allowed; }
 .embed-cal-week { display: grid; grid-template-columns: repeat(7,minmax(0,1fr)); gap: 4px; font-size: 11px; color: var(--muted); text-align: center; margin-bottom: 4px; font-weight: 600; }
 .embed-cal-week > * { min-width: 0; padding: 4px 0; }
 .embed-cal-week .sun { color: #dc2626; }
 .embed-cal-week .sat { color: #2563eb; }
 .embed-cal-grid { display: grid; grid-template-columns: repeat(7,minmax(0,1fr)); gap: 4px; }
 .embed-cell { aspect-ratio: 1/1.05; background: #fff; border: 1px solid var(--line); border-radius: 6px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 4px; transition: all 0.15s; min-width: 0; overflow: hidden; }
 .embed-cell.empty { visibility: hidden; }
 .embed-cell .num { font-size: 12px; font-weight: 600; color: var(--ink); }
 .embed-cell .mark { font-size: 18px; font-weight: 800; line-height: 1; margin-top: 2px; }
 .embed-cell.sun .num { color: #dc2626; }
 .embed-cell.sat .num { color: #2563eb; }
 .embed-cell.past { opacity: 0.35; }
 .embed-cell.open, .embed-cell.partial { background: #f0fdf4; border-color: #10b981; cursor: pointer; }
 .embed-cell.open .mark, .embed-cell.partial .mark { color: #10b981; }
 .embed-cell.open:hover, .embed-cell.partial:hover { background: #10b981; transform: translateY(-1px); }
 .embed-cell.open:hover .num, .embed-cell.open:hover .mark, .embed-cell.partial:hover .num, .embed-cell.partial:hover .mark { color: #fff; }
 .embed-cell.lead { background: #fef3c7; border-color: #fcd34d; cursor: pointer; }
 .embed-cell.lead .mark { color: #92400e; }
 .embed-cell.lead:hover { background: #fde68a; }
 .embed-cell.full, .embed-cell.holiday { background: #fee2e2; border-color: #fca5a5; }
 .embed-cell.full .mark, .embed-cell.holiday .mark { color: #991b1b; }
 .embed-legend { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; font-size: 12px; color: var(--muted); margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); }
 .embed-legend span { display: inline-flex; align-items: center; gap: 4px; }
 .embed-legend .lg { display: inline-block; width: 18px; height: 18px; border-radius: 4px; border: 1px solid; text-align: center; line-height: 16px; font-weight: 800; font-size: 11px; }
 .embed-legend .lg-open { background: #f0fdf4; border-color: #10b981; color: #10b981; }
 .embed-legend .lg-lead { background: #fef3c7; border-color: #fcd34d; color: #92400e; }
 .embed-legend .lg-full { background: #fee2e2; border-color: #fca5a5; color: #991b1b; }
 .embed-cal-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; max-width: 720px; margin: 0 auto; }
 .embed-banner { background: #fef3c7; border: 1px solid #fcd34d; padding: 12px 16px; border-radius: 8px; text-align: center; margin-bottom: 14px; color: #92400e; font-size: 13px; }
 @media (max-width:640px) {
 .embed-cal { padding: 16px 12px; }
 .embed-cal-month { gap: 6px; }
 .embed-cal-month .label { font-size: 14px; }
 .embed-cal-month button { padding: 6px 10px; font-size: 12px; }
 .embed-cal-week { gap: 3px; font-size: 10px; }
 .embed-cal-week > * { padding: 3px 0; }
 .embed-cal-grid { gap: 3px; }
 .embed-cell { padding: 2px 1px; border-radius: 5px; }
 .embed-cell .num { font-size: 11px; }
 .embed-cell .mark { font-size: 15px; line-height: 1; margin-top: 1px; }
 .embed-legend { gap: 10px; font-size: 11px; margin-top: 10px; padding-top: 10px; }
 .embed-legend .lg { width: 16px; height: 16px; line-height: 14px; font-size: 10px; }
 .embed-banner { padding: 10px 12px; font-size: 12.5px; }
 }
 @media (max-width:380px) {
 .embed-cal { padding: 14px 10px; }
 .embed-cell .num { font-size: 10px; }
 .embed-cell .mark { font-size: 13px; }
 }

 /* ===== Philosophy（あまてらすが大切にしていること） ===== */
 #philosophy { padding: clamp(60px, 9vw, 100px) 0; background: linear-gradient(180deg, var(--paper) 0%, var(--paper-3) 100%); position: relative; }
 #philosophy::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 80px; height: 4px; background: var(--brand); border-radius: 0 0 4px 4px; }
 #philosophy .section_intro { text-align: center; margin-bottom: clamp(28px, 4vw, 44px); }
 #philosophy .section_lead { margin: 0 auto; }
 .philo_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 1000px; margin: 0 auto; }
 .philo_card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 28px 24px 24px; position: relative; transition: all 0.2s; }
 .philo_card:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(0,0,0,0.06); border-color: var(--brand-soft); }
 .philo_num {
   position: absolute; top: 16px; right: 18px;
   font-size: 38px; font-weight: 800; color: var(--brand-soft);
   line-height: 1; letter-spacing: -0.02em; font-family: "Inter", sans-serif;
 }
 .philo_card h3 { font-size: 16px; font-weight: 800; color: var(--ink); margin-bottom: 10px; letter-spacing: 0.01em; padding-right: 50px; }
 .philo_card p { font-size: 13.5px; color: var(--muted); line-height: 1.85; }
 @media (max-width:880px) { .philo_grid { grid-template-columns: 1fr 1fr; gap: 14px; } }
 @media (max-width:560px) { .philo_grid { grid-template-columns: 1fr; gap: 12px; } .philo_card { padding: 22px 20px 20px; } .philo_num { font-size: 30px; top: 14px; right: 16px; } }
 .ac_card.featured { background: linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%); border-color: var(--ink); color: #fff; position: relative; }
 .ac_card.featured::after { content: "おすすめ"; position: absolute; top: 14px; right: 14px; background: var(--warm); color: #fff; font-size: 10px; font-weight: 700; padding: 3px 10px; border-radius: 50px; letter-spacing: 0.1em; }
 .ac_card.featured .ico { background: rgba(14,165,233,0.2); color: #fff; }
 .ac_card.featured h3 { color: #fff; }
 .ac_card.featured p { color: rgba(255,255,255,0.78); }
 .ac_promise { margin-top: 40px; background: var(--paper-3); border-radius: 16px; padding: 28px 32px; display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
 .ac_promise .pmark { font-size: 12px; font-weight: 700; color: var(--brand-deep); letter-spacing: 0.15em; }
 .ac_promise .pmsg { font-size: 14px; color: var(--ink-2); line-height: 1.8; flex: 1; min-width: 240px; }
 .ac_promise .pmsg strong { color: var(--ink); font-weight: 700; }
 @media (max-width: 880px) { .ac_grid { grid-template-columns: 1fr; } }

 /* ===== Personalized consultation ===== */
 .personal { background: linear-gradient(135deg, var(--brand) 0%, var(--brand-deep) 100%); color: #fff; }
 .personal .section_intro { margin-bottom: 40px; }
 .personal .eyebrow { color: rgba(255,255,255,0.85); }
 .personal .headline { color: #fff; }
 .personal .section_lead { color: rgba(255,255,255,0.92); }
 .personal_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
 .personal_card { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18); border-radius: 14px; padding: 28px 22px; backdrop-filter: blur(4px); }
 .personal_card .step { font-size: 11px; font-weight: 700; color: rgba(255,255,255,0.85); letter-spacing: 0.2em; margin-bottom: 12px; }
 .personal_card h3 { font-size: 17px; font-weight: 700; color: #fff; margin-bottom: 10px; }
 .personal_card p { font-size: 13.5px; line-height: 1.85; color: rgba(255,255,255,0.85); }
 .personal_msg { margin-top: 36px; text-align: center; font-size: 15px; line-height: 1.85; color: rgba(255,255,255,0.95); padding: 20px 24px; background: rgba(255,255,255,0.08); border-radius: 12px; border: 1px dashed rgba(255,255,255,0.3); }
 .personal_msg strong { color: #fff; font-weight: 700; }
 @media (max-width: 880px) { .personal_grid { grid-template-columns: 1fr; } }

 .pricing_grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 24px; margin-bottom: 24px; }
 .pricing_card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 32px 28px; }
 .pricing_card.featured { border-color: var(--brand); box-shadow: 0 12px 40px rgba(14,165,233,0.10); }
 .pricing_card .ptag { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.15em; color: var(--brand-deep); background: var(--brand-soft); padding: 6px 16px; border-radius: 50px; margin-bottom: 22px; }
 .pgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
 .pcell { text-align: center; padding: 22px 14px; border: 1px solid var(--line); border-radius: 12px; }
 .pcell.highlight { background: var(--ink); color: #fff; border-color: var(--ink); position: relative; }
 .pcell.highlight::before { content: "おすすめ"; position: absolute; top: -10px; right: 12px; background: var(--warm); color: #fff; font-size: 10px; font-weight: 700; padding: 3px 10px; border-radius: 50px; letter-spacing: 0.1em; }
 .plabel { font-size: 12px; font-weight: 700; color: var(--muted); margin-bottom: 8px; letter-spacing: 0.05em; }
 .pcell.highlight .plabel { color: rgba(255,255,255,0.75); }
 .pprice { font-size: 34px; font-weight: 800; line-height: 1; letter-spacing: -0.02em; color: var(--ink); }
 .pcell.highlight .pprice { color: #fff; }
 .pprice span { font-size: 16px; margin-left: 3px; font-weight: 700; }
 .pnote { font-size: 11px; color: var(--muted); margin-top: 8px; }
 .pcell.highlight .pnote { color: rgba(255,255,255,0.75); }
 .poptions, .psub { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 18px; border-top: 1px dashed var(--line); }
 .poptions span { font-size: 12px; color: var(--ink-2); background: var(--paper-3); padding: 6px 14px; border-radius: 50px; font-weight: 600; }
 .psub span { font-size: 12px; color: var(--brand-deep); background: var(--brand-soft); padding: 6px 14px; border-radius: 50px; font-weight: 600; }
 .pmsg .ptitle { font-size: 22px; font-weight: 700; color: var(--ink); margin-bottom: 12px; letter-spacing: 0.02em; }
 .pmsg .pdesc { font-size: 13.5px; line-height: 1.85; color: var(--muted); }
 .pnotice { font-size: 12.5px; color: var(--muted); text-align: center; line-height: 1.85; }
 @media (max-width: 880px) { .pricing_grid { grid-template-columns: 1fr; } }

 .other_grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
 .other_card { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 22px 20px; transition: all .15s; }
 .other_card:hover { border-color: var(--line-2); background: var(--paper-2); }
 .other_card h3 { font-size: 15px; font-weight: 700; color: var(--ink); margin-bottom: 8px; }
 .other_card p { font-size: 12.5px; line-height: 1.7; color: var(--muted); }
 @media (max-width: 880px) { .other_grid { grid-template-columns: repeat(2, 1fr); } }

 .why_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
 .why_item { padding: 0 4px; }
 .why_item .num { font-family: "Inter", sans-serif; font-size: 14px; font-weight: 700; color: var(--brand); letter-spacing: 0.2em; margin-bottom: 12px; }
 .why_item h3 { font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 12px; line-height: 1.5; }
 .why_item p { font-size: 13.5px; line-height: 1.85; color: rgba(255,255,255,0.78); }
 @media (max-width: 880px) { .why_grid { grid-template-columns: 1fr; gap: 30px; } }

 .estimate_inner { text-align: center; max-width: 700px; margin: 0 auto; }
 .estimate_inner .headline { margin-bottom: 16px; }
 .estimate_inner .lead { font-size: 15px; color: var(--muted); line-height: 1.85; margin-bottom: 32px; }
 .estimate_inner .lead strong { color: var(--ink); }
 .estimate_cta { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
 .estimate_note { margin-top: 20px; font-size: 12.5px; color: var(--muted-2); }

 .coverage_main { text-align: center; margin-bottom: 24px; }
 .coverage_main .core { display: inline-block; font-size: 22px; font-weight: 700; color: var(--ink); padding: 12px 28px; background: var(--brand-soft); border-radius: 50px; border: 1px solid var(--brand-soft); }
 .coverage_grid { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; max-width: 760px; margin: 0 auto; padding: 0; list-style: none; }
 .coverage_grid li { background: #fff; border: 1.5px solid var(--line); padding: 8px 18px; border-radius: 50px; font-size: 14px; color: var(--ink-2); font-weight: 600; transition: all .15s; }
 .coverage_grid li[data-slug] { cursor: pointer; }
 .coverage_grid li[data-slug]:hover { border-color: var(--brand); color: var(--brand-deep); }
 .coverage_grid li.is-active { background: var(--brand); color: #fff; border-color: var(--brand-deep); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(2,132,199,0.25); }
 .coverage_note { text-align: center; margin-top: 30px; font-size: 13px; color: var(--muted); line-height: 1.85; }

 /* ===== TOP用 対応エリアマップ ===== */
 .coverage_map_block { background:#fff; border:1px solid var(--line); border-radius:14px; padding:24px; margin:0 auto 28px; max-width:760px; }
 .coverage_map_block h3 { font-size:15px; font-weight:700; text-align:center; margin-bottom:14px; color:var(--ink); letter-spacing:0.02em; }
 .coverage_map_svg { position:relative; width:100%; max-width:480px; margin:0 auto; aspect-ratio: 424/552; background:#f8fafc; border-radius:10px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
 .coverage_map_svg svg { width:100%; height:100%; display:block; }
 .coverage_map_svg svg path { fill:#eef2f6; stroke:#fff; stroke-width:0.6; transition:fill 0.18s; cursor:default; }
 .coverage_map_svg svg path[data-tier="pref"] { fill:#f8fafc; stroke:#f1f5f9; }
 .coverage_map_svg svg path[data-tier="target"] { fill:#7dd3fc; cursor:pointer; }
 .coverage_map_svg svg path[data-tier="out"] { fill:#e5e7eb; cursor:pointer; }
 .coverage_map_svg svg path[data-tier="target"]:hover { fill:#38bdf8 !important; }
 .coverage_map_svg svg path[data-tier="out"]:hover { fill:#d1d5db !important; }
 .coverage_map_svg svg path[data-tier="target"].active { animation: covmap-pulse-target 1.2s ease-out; }
 .coverage_map_svg svg path[data-tier="out"].active { animation: covmap-pulse-out 1.2s ease-out; }
 @keyframes covmap-pulse-target {
   0%{fill:#7dd3fc} 30%{fill:#0ea5e9} 60%{fill:#0c4a6e} 100%{fill:#7dd3fc}
 }
 @keyframes covmap-pulse-out {
   0%{fill:#e5e7eb} 30%{fill:#9ca3af} 60%{fill:#475569} 100%{fill:#e5e7eb}
 }
 .coverage_map_legend { display:flex; gap:10px 18px; justify-content:center; flex-wrap:wrap; font-size:12px; color:var(--muted); margin-top:14px; padding-top:14px; border-top:1px solid var(--line); }
 .coverage_map_legend i { display:inline-block; width:14px; height:14px; border-radius:3px; border:1px solid rgba(0,0,0,0.08); margin-right:5px; vertical-align:middle; }
 .coverage_map_legend i.lg-target { background:#7dd3fc; }
 .coverage_map_legend i.lg-out { background:#e5e7eb; }
 .coverage_map_more { text-align:center; margin-top:12px; font-size:13.5px; font-weight:600; }
 .coverage_map_more a { color: var(--brand-deep); text-decoration: none; }
 .coverage_map_more a:hover { color: var(--brand); text-decoration: underline; }
 .coverage_map_credit { font-size:10.5px; color:#cbd5e1; text-align:center; margin-top:10px; line-height:1.5; }
 .coverage_map_credit a { color:#cbd5e1; text-decoration:none; }
 .coverage_map_credit a:hover { text-decoration:underline; }

 /* ===== 共通ポップアップ ===== */
 .map-popup {
   position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%);
   background: #fff; border: 1px solid var(--line); border-radius: 12px;
   box-shadow: 0 18px 50px rgba(0,0,0,0.18);
   padding: 14px 18px; max-width: calc(100vw - 24px);
   z-index: 100; display: flex; align-items: center; gap: 12px; flex-wrap: nowrap;
   opacity: 0; transition: opacity .25s, transform .25s;
   pointer-events: none;
 }
 .map-popup.show { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }
 .map-popup[hidden] { display: none; }
 .map-popup .map-popup-icon { font-size: 24px; line-height: 1; flex-shrink: 0; }
 .map-popup .map-popup-body { min-width: 0; flex: 1; }
 .map-popup .map-popup-name { font-weight: 700; font-size: 15px; color: var(--ink); line-height: 1.3; }
 .map-popup .map-popup-status { font-size: 12px; color: var(--muted); margin-top: 2px; line-height: 1.4; }
 .map-popup .map-popup-cta {
   background: var(--brand); color: #fff;
   padding: 8px 14px; border-radius: 8px;
   font-size: 13px; font-weight: 700; text-decoration: none; white-space: nowrap; flex-shrink: 0;
 }
 .map-popup .map-popup-cta:hover { background: var(--brand-deep); color: #fff; }
 .map-popup .map-popup-close {
   background: transparent; border: none; font-size: 20px; cursor: pointer;
   color: var(--muted); padding: 4px 6px; line-height: 1; flex-shrink: 0;
 }
 .map-popup.is-out .map-popup-name { color: #475569; }
 .map-popup.is-out .map-popup-cta { background: #64748b; }
 .map-popup.is-out .map-popup-cta:hover { background: #475569; }
 @media (max-width: 540px) {
   .map-popup { left: 12px; right: 12px; transform: none; width: auto; padding: 12px 14px; gap: 10px; }
   .map-popup.show { transform: translateY(0); }
   .map-popup .map-popup-icon { font-size: 20px; }
   .map-popup .map-popup-name { font-size: 14px; }
   .map-popup .map-popup-status { font-size: 11.5px; }
   .map-popup .map-popup-cta { padding: 7px 12px; font-size: 12px; }
 }

 .flow_steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; position: relative; }
 .flow_step { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 28px 22px; position: relative; }
 .flow_step .step_num { font-family: "Inter", sans-serif; font-size: 12px; font-weight: 700; color: var(--brand-deep); letter-spacing: 0.2em; margin-bottom: 10px; }
 .flow_step h3 { font-size: 15px; font-weight: 700; color: var(--ink); margin-bottom: 10px; }
 .flow_step p { font-size: 13px; line-height: 1.75; color: var(--muted); }
 @media (max-width: 880px) { .flow_steps { grid-template-columns: repeat(2, 1fr); } }

 .faq_list { max-width: 820px; margin: 0 auto; }
 .faq_list details { border-bottom: 1px solid var(--line); padding: 22px 4px; }
 .faq_list details:first-child { border-top: 1px solid var(--line); }
 .faq_list summary { list-style: none; cursor: pointer; font-size: 15px; font-weight: 600; color: var(--ink); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
 .faq_list summary::-webkit-details-marker { display: none; }
 .faq_list summary::after { content: "+"; font-size: 22px; color: var(--brand-deep); font-weight: 400; flex-shrink: 0; transition: transform .2s; }
 .faq_list details[open] summary::after { transform: rotate(45deg); }
 .faq_list details p { margin-top: 14px; font-size: 14px; line-height: 1.85; color: var(--muted); }

 .contact { background: linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%); color: #fff; }
 .contact_inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: 50px; align-items: center; }
 .contact_main h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 700; color: #fff; margin-bottom: 18px; line-height: 1.4; }
 .contact_main p { font-size: 15px; line-height: 1.85; color: rgba(255,255,255,0.78); margin-bottom: 32px; }
 .contact_actions { display: flex; gap: 12px; flex-wrap: wrap; }
 .contact_panel { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 32px; }
 .contact_panel .label { font-size: 11px; font-weight: 700; color: var(--brand); letter-spacing: 0.2em; margin-bottom: 14px; }
 .contact_panel .phone { font-family: "Inter", sans-serif; font-size: 28px; font-weight: 700; color: #fff; margin-bottom: 12px; letter-spacing: 0.01em; }
 .contact_panel .phone a { color: #fff; }
 .contact_panel .phone a:hover { color: var(--brand); }
 .contact_panel .hours { font-size: 13px; color: rgba(255,255,255,0.7); line-height: 1.7; padding-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,0.1); margin-bottom: 20px; }
 .contact_panel .meta { font-size: 13px; color: rgba(255,255,255,0.7); line-height: 1.9; }
 .contact_panel .meta strong { color: rgba(255,255,255,0.95); font-weight: 600; }
 @media (max-width: 880px) { .contact_inner { grid-template-columns: 1fr; gap: 30px; } .contact_panel { padding: 24px; } }

 .site_footer { background: var(--paper-3); padding: 40px 0 30px; border-top: 1px solid var(--line); }
 .footer_inner { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 40px; margin-bottom: 30px; }
 .footer_brand img { height: 28px; margin-bottom: 14px; }
 .footer_brand p { font-size: 12.5px; color: var(--muted); line-height: 1.85; }
 .footer_col h4 { font-size: 11px; font-weight: 700; color: var(--ink); letter-spacing: 0.2em; margin-bottom: 14px; }
 .footer_col ul li { font-size: 13px; color: var(--muted); line-height: 2; }
 .footer_col ul li a:hover { color: var(--brand-deep); }
 .footer_meta { border-top: 1px solid var(--line); padding-top: 20px; text-align: center; font-size: 11.5px; color: var(--muted-2); line-height: 1.7; }
 @media (max-width: 880px) { .footer_inner { grid-template-columns: 1fr; gap: 28px; } }

 .reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s, transform .6s; }
 .reveal.in { opacity: 1; transform: none; }
 @media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

 .to_top { position: fixed; right: 20px; bottom: 20px; width: 44px; height: 44px; border-radius: 50%; background: var(--ink); color: #fff; border: none; font-size: 16px; cursor: pointer; opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s; box-shadow: 0 8px 24px rgba(0,0,0,0.15); }
 .to_top.visible { opacity: 1; pointer-events: auto; }
 .to_top:hover { transform: translateY(-2px); }