
:root{
  --sans: "Hiragino Sans","Yu Gothic","Meiryo",sans-serif;
  --Quicksand: "Hiragino Sans","Yu Gothic","Meiryo",sans-serif;
  --water:#69c9ec;
  --water-deep:#1f86b7;
  --water-soft:#edf9ff;
  --navy:#20455c;
  --text:#37596b;
  --sub:#648092;
  --mint:#eaf7ef;
  --yellow:#fff2bf;
  --pink:#ffe1ea;
  --line:#d8eaf2;
  --white:#fff;
  --shadow:0 18px 42px rgba(29,83,112,.10);
  --shadow-soft:0 10px 24px rgba(29,83,112,.08);
  --radius-xl:34px;
  --radius-lg:26px;
  --radius-md:18px;
  --radius-sm:14px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:
    radial-gradient(circle at 10% 12%, rgba(255,242,191,.60) 0, rgba(255,242,191,0) 16%),
    radial-gradient(circle at 85% 20%, rgba(255,225,234,.52) 0, rgba(255,225,234,0) 16%),
    linear-gradient(180deg,#fffdf7 0%, #f8fdff 36%, #f2fbff 100%);
  overflow-x:hidden;
  line-height:1.8;
  letter-spacing:.02em;
}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
.premium-shell{position:relative;overflow:hidden}
.premium-shell::before,
.premium-shell::after{
  content:"";position:absolute;inset:auto;pointer-events:none;border-radius:50%;filter:blur(3px);opacity:.65;z-index:0;
}
.premium-shell::before{width:280px;height:280px;left:-110px;top:180px;background:rgba(105,201,236,.12)}
.premium-shell::after{width:240px;height:240px;right:-90px;top:420px;background:rgba(255,225,234,.34)}
.container{position:relative;z-index:1;width:min(calc(100% - 32px),var(--max));margin-inline:auto}

.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-bottom:1px solid rgba(32,69,92,.08)}
.site-header__bar{background:linear-gradient(90deg,#eaf7ff,#fffaf0,#eef8f1);text-align:center;padding:8px 14px;font-size:12px;font-weight:800;color:var(--water-deep);letter-spacing:.05em}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:80px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand__logo{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(180deg,#7ed4f1,#2998c7);color:#fff;font-size:20px;font-weight:900;box-shadow:var(--shadow-soft)}
.brand__name{display:block;font-size:17px;line-height:1.2;color:var(--navy);font-weight:900}
.brand__sub{display:block;font-size:11px;color:var(--sub);margin-top:2px}
.global-nav{display:none;align-items:center;gap:18px;flex-wrap:wrap}
.global-nav a{font-size:13px;font-weight:800;color:var(--navy);opacity:.88}
.header-cta{display:none;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:999px;font-weight:900;font-size:14px;border:1px solid transparent;transition:transform .24s ease, box-shadow .24s ease, background .24s ease;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn--line{background:#fff;border-color:#d8eaf2;color:var(--navy);box-shadow:var(--shadow-soft)}
.btn--primary{background:linear-gradient(180deg,#41b9e9,#1b8cbc);color:#fff;box-shadow:0 12px 24px rgba(27,140,188,.22)}
.btn--tel{background:linear-gradient(180deg,#86d9cf,#57bfae);color:#fff;box-shadow:0 12px 24px rgba(87,191,174,.20)}

.hero{position:relative;padding:38px 0 22px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 14% 16%, rgba(255,255,255,.72) 0, rgba(255,255,255,0) 18%),
  radial-gradient(circle at 84% 14%, rgba(255,255,255,.46) 0, rgba(255,255,255,0) 16%),
  linear-gradient(180deg, rgba(255,247,220,.92) 0%, rgba(255,248,244,.92) 24%, rgba(240,250,255,.96) 70%, rgba(232,247,255,.98) 100%);
  z-index:0}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:86px;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.78) 52%, #fff 100%);z-index:0}
.hero-bubbles,.hero-bubbles::before,.hero-bubbles::after{position:absolute;inset:0;pointer-events:none}
.hero-bubbles span{position:absolute;display:block;border-radius:50%;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.9), rgba(255,255,255,.18) 58%, rgba(255,255,255,.04) 100%);border:1px solid rgba(255,255,255,.72);box-shadow:inset 0 0 12px rgba(255,255,255,.42);animation:floatBubble 8s ease-in-out infinite}
.hero-bubbles span:nth-child(1){width:26px;height:26px;left:8%;top:18%}
.hero-bubbles span:nth-child(2){width:14px;height:14px;left:18%;top:42%;animation-delay:.8s}
.hero-bubbles span:nth-child(3){width:34px;height:34px;right:9%;top:18%;animation-delay:1.4s}
.hero-bubbles span:nth-child(4){width:16px;height:16px;right:19%;top:46%;animation-delay:2.3s}
.hero-bubbles span:nth-child(5){width:20px;height:20px;left:14%;bottom:16%;animation-delay:1.6s}
.hero-bubbles span:nth-child(6){width:12px;height:12px;right:12%;bottom:18%;animation-delay:2.8s}
.hero-wave{position:absolute;left:-8%;right:-8%;bottom:42px;height:120px;background:radial-gradient(120% 100% at 50% 100%, rgba(105,201,236,.22) 0, rgba(105,201,236,.12) 42%, rgba(105,201,236,0) 72%);filter:blur(6px);animation:waveDrift 8s ease-in-out infinite;pointer-events:none;z-index:0}
.hero__inner{position:relative;z-index:1;display:grid;gap:22px;align-items:center}
.hero-copy{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.82);border-radius:32px;padding:22px 18px 20px;box-shadow:var(--shadow);backdrop-filter:blur(8px)}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:linear-gradient(90deg,#fff3d0,#eefaff);color:var(--water-deep);font-size:12px;font-weight:900;letter-spacing:.05em}
.hero-copy h1{margin:16px 0 0;font-size:clamp(34px,7vw,64px);line-height:1.14;color:var(--navy);font-weight:900;letter-spacing:.01em}
.hero-copy h1 small{display:block;margin-bottom:8px;font-size:clamp(14px,2.9vw,20px);line-height:1.6;color:var(--water-deep);font-weight:800}
.hero-copy p{margin:16px 0 0;font-size:15px;color:var(--text)}
.hero-copy p strong{color:var(--water-deep);background:linear-gradient(transparent 56%, rgba(105,201,236,.20) 56%)}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-meta__item{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid #d8eaf2;color:var(--water-deep);font-size:13px;font-weight:900;box-shadow:var(--shadow-soft)}
.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-note{margin-top:12px;font-size:12px;color:var(--sub)}

.hero-visual-wrap{position:relative}
.hero-visual-card{position:relative;background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.82));border:1px solid rgba(255,255,255,.82);border-radius:34px;padding:12px;box-shadow:var(--shadow);overflow:hidden}
.hero-visual-card::before{content:"";position:absolute;inset:-18% auto auto -10%;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.42);filter:blur(3px)}
.hero-visual-card img{position:relative;z-index:1;width:100%;border-radius:24px;border:1px solid #d7ecf5;background:#f4fbff}
.hero-visual-caption{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.visual-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;font-size:12px;font-weight:900;box-shadow:var(--shadow-soft)}
.visual-chip--blue{background:#eef9ff;color:#2f8cb7}
.visual-chip--pink{background:#fff0f5;color:#d66b91}
.visual-chip--mint{background:#eef8f1;color:#4b9c88}

.highlights{position:relative;z-index:1;margin-top:8px;padding-bottom:22px}
.highlights-grid{display:grid;gap:14px}
.highlight-card{background:#fff;border:1px solid #ddebf2;border-radius:24px;padding:18px 16px;box-shadow:var(--shadow-soft);display:grid;grid-template-columns:58px 1fr;gap:14px;align-items:center}
.highlight-card__icon{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-size:22px;font-weight:900;color:#fff}
.highlight-card:nth-child(1) .highlight-card__icon{background:linear-gradient(180deg,#75d1f1,#2a99c9)}
.highlight-card:nth-child(2) .highlight-card__icon{background:linear-gradient(180deg,#8bdbcf,#54bfae)}
.highlight-card:nth-child(3) .highlight-card__icon{background:linear-gradient(180deg,#f2dca8,#d5b46a)}
.highlight-card h2{margin:0;font-size:24px;line-height:1.3;color:var(--navy)}
.highlight-card p{margin:4px 0 0;font-size:13px;color:var(--sub);line-height:1.75}

.illustration-strip{padding:14px 0 34px}
.illustration-panel{background:linear-gradient(180deg,#ffffff,#f7fcff);border:1px solid #dcecf3;border-radius:30px;padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.illustration-panel::after{content:"";position:absolute;right:-26px;bottom:-26px;width:140px;height:140px;border-radius:50%;background:rgba(105,201,236,.10)}
.panel-head{position:relative;z-index:1;display:grid;gap:8px;margin-bottom:18px}
.panel-head__eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:#eef9ff;color:var(--water-deep);font-size:12px;font-weight:900;width:max-content}
.panel-head h2{margin:0;font-size:clamp(24px,4vw,36px);line-height:1.45;color:var(--navy)}
.panel-head p{margin:0;font-size:14px;color:var(--sub)}
.illustration-grid{position:relative;z-index:1;display:grid;gap:14px}
.illustration-card{background:linear-gradient(180deg,#ffffff,#f7fbfe);border:1px solid #dcebf2;border-radius:24px;padding:16px;box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:center;min-height:132px}
.illustration-card > img{display:block;width:min(100%,220px);height:auto}
.illustration-card h3{margin:14px 0 0;font-size:18px;line-height:1.45;color:var(--navy)}
.illustration-card p{margin:6px 0 0;font-size:13px;color:var(--sub)}

.compare-section{padding:12px 0 48px}
.compare-board{background:linear-gradient(180deg,#eef9ff,#ffffff);border:1px solid #dcecf3;border-radius:32px;padding:22px;box-shadow:var(--shadow)}
.compare-top{display:grid;gap:14px}
.plan-card{border-radius:28px;padding:22px;position:relative;overflow:hidden}
.plan-card::after{content:"";position:absolute;right:-22px;bottom:-26px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.22)}
.plan-card--standard{background:linear-gradient(180deg,#7c8c98,#677985);color:#fff}
.plan-card--premium{background:linear-gradient(180deg,#eefbff,#cceefe 72%,#a8dcf2);color:#1c5974;border:1px solid #bfe4f4}
.plan-card__label{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.30);font-size:12px;font-weight:900;position:relative;z-index:1}
.plan-card h3{position:relative;z-index:1;margin:12px 0 6px;font-size:32px;line-height:1.15}
.plan-card p{position:relative;z-index:1;margin:0;font-size:14px;line-height:1.75}
.plan-card__price{position:relative;z-index:1;margin-top:14px;font-size:15px;font-weight:900}
.plan-card__price strong{display:block;font-size:34px;line-height:1.15}
.plan-card__subbox{position:relative;z-index:1;margin-top:14px;background:rgba(255,255,255,.54);border-radius:18px;padding:14px 16px}
.plan-card__subbox h4{margin:0;font-size:24px;line-height:1.4;color:#1d5973}
.plan-card__subbox p{margin-top:6px;font-size:13px;color:#436a7c}
.compare-table-wrap{margin-top:18px;overflow-x:auto}
.compare-table{width:100%;min-width:720px;border-collapse:separate;border-spacing:0;border-radius:26px;overflow:hidden}
.compare-table th,.compare-table td{padding:15px 14px;border-bottom:1px solid #e2ecf3;font-size:14px;vertical-align:middle}
.compare-table thead th{color:#fff;text-align:center;border-bottom:none}
.compare-table thead th:first-child{background:#8cb4c7;width:24%}
.compare-table thead th:nth-child(2){background:#8293a0}
.compare-table thead th:nth-child(3){background:linear-gradient(180deg,#caeefe,#97d7ee);color:#1b5972}
.compare-table tbody th{background:#f4fbff;text-align:left;color:var(--navy);font-weight:900}
.compare-table tbody td{background:#fff}
.compare-table strong{font-size:18px;line-height:1.35}
.compare-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}

.join-footer{margin-top:10px}

@keyframes floatBubble{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes waveDrift{0%,100%{transform:translateX(0)}50%{transform:translateX(24px)}}

@media (min-width: 900px){
  .global-nav{display:flex}
  .header-cta{display:flex}
  .hero{padding:46px 0 30px}
  .hero__inner{grid-template-columns:1.02fr .98fr;gap:28px}
  .highlights-grid{grid-template-columns:repeat(3,1fr)}
  .highlight-card{grid-template-columns:1fr;align-items:start}
  .highlight-card__icon{margin-bottom:2px}
  .illustration-grid{grid-template-columns:repeat(3,1fr)}
  .compare-top{grid-template-columns:1fr 1fr}
}

@media (max-width: 899px){
  .site-header__inner{padding:10px 0}
  .hero-copy h1 br{display:none}
}

@media (max-width: 640px){
  .container{width:min(calc(100% - 24px),var(--max))}
  .site-header__bar{font-size:11px;padding:7px 10px}
  .brand__name{font-size:15px}
  .brand__sub{font-size:10px}
  .btn{min-height:44px;padding:0 16px;font-size:13px}
  .hero{padding-top:24px}
  .hero-copy{padding:18px 16px 18px;border-radius:26px}
  .hero-copy p{font-size:14px}
  .hero-meta__item{font-size:12px;padding:9px 12px}
  .highlight-card h2{font-size:22px}
  .compare-board,.illustration-panel{padding:18px}
}

/* exact theme header/footer + campaign top integration */
.l-main--campaign{display:block;}
.premium-campaign-top{position:relative;z-index:1;}


/* 2026-05-08 update: hero poster slot + summary cards */
.hero-summary{margin-top:18px;display:grid;gap:10px}
.hero-summary__lead{margin:0;font-size:12px;font-weight:900;letter-spacing:.08em;color:var(--water-deep)}
.hero-summary__grid{display:grid;gap:10px}
.hero-summary__card{display:grid;grid-template-columns:40px 1fr;gap:12px;align-items:start;padding:14px 14px 13px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid #dcebf3;box-shadow:var(--shadow-soft)}
.hero-summary__no{display:grid;place-items:center;width:40px;height:40px;border-radius:14px;background:linear-gradient(180deg,#e9f7ff,#cfeefe);color:#1f86b7;font-size:12px;font-weight:900;letter-spacing:.08em}
.hero-summary__body strong{display:block;font-size:14px;line-height:1.5;color:var(--navy)}
.hero-summary__body p{margin:4px 0 0;font-size:12px;line-height:1.75;color:var(--sub)}
.hero-poster-wrap{position:relative}
.hero-poster-slot{position:relative;min-height:520px;border-radius:34px;border:2px dashed #cfe3ee;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(241,250,255,.95));box-shadow:var(--shadow);overflow:hidden;display:grid;place-items:center;padding:18px}
.hero-poster-slot::before,.hero-poster-slot::after{content:"";position:absolute;border-radius:50%;pointer-events:none}
.hero-poster-slot::before{width:170px;height:170px;left:-38px;top:-34px;background:rgba(105,201,236,.12)}
.hero-poster-slot::after{width:140px;height:140px;right:-24px;bottom:-24px;background:rgba(255,225,234,.35)}
.hero-poster-slot__inner{position:relative;z-index:1;display:grid;gap:12px;justify-items:center;text-align:center;max-width:360px;padding:26px 18px;border-radius:28px;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.92)}
.hero-poster-slot__eyebrow{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;background:#eef9ff;color:#1f86b7;font-size:12px;font-weight:900;letter-spacing:.08em}
.hero-poster-slot__inner strong{font-size:clamp(28px,4vw,42px);line-height:1.35;color:var(--navy)}
.hero-poster-slot__inner p{margin:0;font-size:14px;color:var(--sub)}
.hero-poster-slot__meta{display:inline-flex;align-items:center;justify-content:center;padding:9px 14px;border-radius:999px;background:#fff7df;color:#7a6331;font-size:12px;font-weight:800;line-height:1.6}

@media (min-width: 900px){
  .hero-summary__grid{grid-template-columns:repeat(3,1fr)}
  .hero-summary__card{grid-template-columns:1fr;gap:10px}
  .hero-summary__no{margin-bottom:2px}
}

@media (max-width: 640px){
  .hero-summary__card{padding:13px 13px 12px}
  .hero-poster-slot{min-height:380px;padding:14px}
  .hero-poster-slot__inner{padding:22px 14px}
  .hero-poster-slot__inner strong{font-size:24px}
}


/* 2026-05-08 update: dummy images for all editable visual slots */
.hero-poster-top{padding:18px 0 0;position:relative;z-index:1}
.hero-poster-top__frame{background:linear-gradient(180deg,#ffffff,#f5fbff);border:1px solid #dcecf3;border-radius:34px;padding:14px;box-shadow:var(--shadow);overflow:hidden}
.hero-poster-top__frame picture{display:block}.hero-poster-top__frame img{display:block;width:100%;height:auto;border-radius:24px;border:1px solid #dbeaf2;background:#f4fbff}@media (min-width: 641px){.hero-poster-top__frame{margin-top:135px}}
.hero-visual-card--poster img{width:100%;aspect-ratio:4 / 5;object-fit:cover}
.hero-poster-caption{margin:12px 4px 0;font-size:12px;line-height:1.7;color:var(--sub)}

@media (max-width: 640px){
  .hero-poster-top{padding-top:12px}
  .hero-poster-top__frame{padding:10px;border-radius:24px}
  .hero-poster-top__frame img{border-radius:18px}
}


/* 2026-05-08 update: align more closely to official web colors */
:root{
  --water:#71cdef;
  --water-deep:#1f4999;
  --navy:#1f536c;
  --text:#37566c;
  --sub:#64839a;
  --mint:#edf8f3;
  --yellow:#f5df97;
  --pink:#ffe7ef;
  --line:#d7e8f2;
}
body{
  background:
    radial-gradient(circle at 10% 12%, rgba(248,239,217,.58) 0, rgba(248,239,217,0) 16%),
    radial-gradient(circle at 85% 20%, rgba(113,205,239,.13) 0, rgba(113,205,239,0) 18%),
    linear-gradient(180deg,#fffdfa 0%, #f9fcff 34%, #f3f9fd 100%);
}
.panel-head__eyebrow,.hero-badge{background:linear-gradient(90deg,#eef8ff,#f8efd9);color:var(--water-deep)}
.btn--primary{background:linear-gradient(180deg,#3cb5e8,#1f95cc);box-shadow:0 12px 24px rgba(31,149,204,.22)}
.btn--line{border-color:#cfe0eb;color:#1f536c}
.hero__inner--single{grid-template-columns:1fr !important}
.hero__inner--single .hero-copy{max-width:100%;width:100%}
.hero__inner--single .hero-summary{margin-top:20px}
.hero__inner--single .hero-summary__lead{text-align:center}
.highlights{position:relative;z-index:1;margin-top:10px;padding-bottom:22px}
.highlights-grid{display:grid;gap:16px}
.highlight-card{position:relative;background:#fff;border:1px solid #d9e7ef;border-radius:26px;padding:16px;box-shadow:var(--shadow-soft);display:grid;grid-template-columns:1fr;gap:14px;align-items:stretch}
.highlight-card > img{display:block;width:min(240px,100%);height:auto;margin:0 auto;padding:20px 16px 16px;border-radius:22px;border:1px solid #edf4f8;background:linear-gradient(180deg,#f8fcff,#edf6fb);box-sizing:border-box}
.highlight-card__icon{position:absolute;left:30px;top:30px;z-index:1;width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-size:22px;font-weight:900;color:#fff;box-shadow:0 10px 18px rgba(31,83,108,.10)}
.highlight-card:nth-child(1) .highlight-card__icon{background:linear-gradient(180deg,#57bce9,#2698cb)}
.highlight-card:nth-child(2) .highlight-card__icon{background:linear-gradient(180deg,#7dd8cf,#59c3b7)}
.highlight-card:nth-child(3) .highlight-card__icon{background:linear-gradient(180deg,#efd78d,#d7b866)}
.highlight-card__body h2{margin:0;font-size:24px;line-height:1.3;color:var(--navy)}
.highlight-card__body p{margin:6px 0 0;font-size:13px;color:var(--sub);line-height:1.75}
.compare-board{background:linear-gradient(180deg,#f4fbff,#ffffff);border:1px solid #d9e8f1}
.compare-top{display:grid;gap:16px;align-items:stretch}
.plan-card{border-radius:30px;padding:24px;position:relative;overflow:hidden;min-height:100%}
.plan-card::after{content:"";position:absolute;right:-18px;bottom:-24px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.26)}
.plan-card--standard{background:linear-gradient(180deg,#f3f7fa,#dee7ee);color:#2b5064;border:1px solid #d4e0e8}
.plan-card--premium{background:linear-gradient(180deg,#fbf8ea,#f3e7bd);color:#6c5927;border:2px solid #e8d8a1;box-shadow:0 18px 36px rgba(31,149,204,.16);transform:translateY(-4px)}
.plan-card__label{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.56);font-size:12px;font-weight:900;position:relative;z-index:1;color:inherit}
.plan-card h3{position:relative;z-index:1;margin:12px 0 8px;font-size:32px;line-height:1.18}
.plan-card p{position:relative;z-index:1;margin:0;font-size:14px;line-height:1.8}
.plan-card__price{position:relative;z-index:1;margin-top:14px;font-size:15px;font-weight:900}
.plan-card__price strong{display:block;font-size:38px;line-height:1.1}
.plan-card__subbox{position:relative;z-index:1;margin-top:14px;background:rgba(255,255,255,.64);border-radius:18px;padding:14px 16px}
.plan-card__subbox h4{margin:0;font-size:22px;line-height:1.45;color:#1f536c}
.plan-card__subbox p{margin-top:6px;font-size:13px;color:#4d7285}
.plan-card__points{position:relative;z-index:1;list-style:none;padding:0;margin:14px 0 0;display:grid;gap:8px}
.plan-card__points li{display:flex;align-items:flex-start;gap:8px;font-size:13px;line-height:1.7;color:inherit}
.plan-card__points li::before{content:"•";color:#1f95cc;font-weight:900}
.compare-table thead th:first-child{background:#7fb7d5}
.compare-table thead th:nth-child(2){background:#7d93a4}
.compare-table thead th:nth-child(3){background:linear-gradient(180deg,#7fd2f1,#4bb7e5);color:#fff}
.compare-extra{margin-top:18px;padding:20px;border-radius:24px;background:linear-gradient(180deg,#ffffff,#f8fbfe);border:1px solid #d9e8f1;box-shadow:var(--shadow-soft)}
.compare-extra__eyebrow{margin:0;font-size:12px;font-weight:900;letter-spacing:.08em;color:#1f4999}
.compare-extra h3{margin:8px 0 14px;font-size:24px;line-height:1.45;color:#1f536c}
.compare-extra__image{border-radius:18px;overflow:hidden;border:1px solid #dce7ef;background:#fff}
.compare-extra__image img{display:block;width:100%;height:auto}

@media (min-width:900px){
  .hero__inner--single .hero-copy{padding:28px 28px 26px}
  .highlights-grid{grid-template-columns:repeat(3,1fr)}
  .compare-top{grid-template-columns:1fr 1.08fr}
}

@media (max-width:640px){
  .highlight-card > img{width:min(200px,100%);padding:16px 14px 14px}
  .highlight-card__icon{left:26px;top:26px;width:52px;height:52px;font-size:20px}
  .compare-extra{padding:16px}
  .compare-extra h3{font-size:20px}
  .plan-card--premium{transform:none}
}


/* 2026-05-08 update: replace compare image with HTML table */
.compare-subtable-wrap{overflow-x:auto}
.compare-subtable{width:100%;min-width:760px;border-collapse:collapse;background:#fff;border:2px solid #1f536c}
.compare-subtable th,.compare-subtable td{border:2px solid #1f536c;padding:12px 10px;text-align:center;vertical-align:middle;font-size:14px;line-height:1.6;color:#2f4f63}
.compare-subtable thead th{font-weight:900}
.compare-subtable__recommend th{background:#ffffff;font-size:24px;line-height:1.35;color:#111;padding:14px 10px}
.compare-subtable__recommend small{display:block;font-size:14px;font-weight:500;color:#222;margin-top:4px}
.compare-subtable__plan th{font-size:20px;line-height:1.35;padding:12px 10px;color:#203f52}
.compare-subtable__plan--support{background:#dcebf6}
.compare-subtable__plan--light{background:#e6f2dc}
.compare-subtable__category th{background:#f8fbfd;font-size:14px}
.compare-subtable tbody strong{font-size:18px;line-height:1.4;color:#1f536c}
.compare-subtable tbody small{display:block;font-size:12px;line-height:1.5;color:#4f7286;margin-top:2px}
.compare-subtable tbody td[colspan="2"]{font-size:16px}

@media (max-width:640px){
  .compare-subtable th,.compare-subtable td{padding:10px 8px;font-size:12px}
  .compare-subtable__recommend th{font-size:18px}
  .compare-subtable__recommend small{font-size:12px}
  .compare-subtable__plan th{font-size:16px}
  .compare-subtable tbody strong{font-size:16px}
}


/* 2026-05-08 update: deadline emphasis + three-plan layout */
.hero-deadline{display:inline-flex;align-items:center;justify-content:center;margin:14px 0 0;padding:12px 18px;border-radius:999px;background:linear-gradient(90deg,#1f95cc,#1f4999);color:#fff;font-size:16px;font-weight:900;letter-spacing:.08em;box-shadow:0 14px 28px rgba(31,73,153,.18)}
.compare-head .panel-head__eyebrow{background:linear-gradient(90deg,#eef8ff,#dff2ff)}
.compare-top--triple{grid-template-columns:1.18fr 1fr 1fr;align-items:stretch}
.plan-card__catch{position:relative;z-index:1;display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.7);font-size:12px;font-weight:900;letter-spacing:.04em;margin:4px 0 10px;color:inherit}
.plan-card--main{transform:translateY(-6px) scale(1.01)}
.plan-card--support{background:linear-gradient(180deg,#f1f9ff,#d8ecf8);color:#23506b;border:1px solid #c6dfee}
.plan-card--light{background:linear-gradient(180deg,#eff9ff,#d7f0fc 62%,#a9daf3);color:#1d5973;border:1px solid #8fceeb}
.plan-card--support .plan-card__subbox{background:rgba(255,255,255,.68)}
.plan-card--light .plan-card__subbox{background:rgba(255,255,255,.55)}
.compare-table--three{min-width:880px}
.compare-table--three thead th:nth-child(2){background:#d8bf73;color:#4f3f16}
.compare-table--three thead th:nth-child(3){background:#8cb9d6;color:#fff}
.compare-table--three thead th:nth-child(4){background:linear-gradient(180deg,#7fd2f1,#4bb7e5);color:#fff}
.compare-subtable--three{min-width:900px}
.compare-subtable--three .compare-subtable__recommend th{font-size:22px}
.compare-subtable--three .compare-subtable__plan--premium{background:#f2e6b9;color:#6c5927}
.compare-subtable--three .compare-subtable__plan--support{background:#dcebf6}
.compare-subtable--three .compare-subtable__plan--light{background:#a8daf3}
.compare-subtable--three tbody th{background:#f7fbfe;font-weight:900;white-space:nowrap}
.compare-subtable--three tbody td{background:#fff}

@media (min-width:900px){
  .compare-top--triple{grid-template-columns:1.18fr 1fr 1fr}
}

@media (max-width:899px){
  .compare-top--triple{grid-template-columns:1fr}
  .plan-card--main{transform:none}
}

@media (max-width:640px){
  .hero-deadline{font-size:13px;padding:10px 14px}
  .compare-subtable--three .compare-subtable__recommend th{font-size:16px}
}


/* 2026-05-08 cleanup: remove duplicated detail table and adjust premium badge */
.highlight-card:first-child .highlight-card__icon{font-size:18px;letter-spacing:.02em}
@media (max-width:640px){
  .highlight-card:first-child .highlight-card__icon{font-size:15px}
}
