/* ============================================================
   D-LAB TOKYO — pikapika.co.jp clone style
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Noto Sans JP',sans-serif;color:#333;line-height:1.8;background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;vertical-align:middle;border:none;display:block}
a{color:inherit;text-decoration:none;transition:.3s}
a:hover{opacity:.7}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6,p,dl,dd,dt{margin:0;padding:0}
button{font:inherit;border:none;cursor:pointer;background:none}
.pc-only{display:block}
.sp-only{display:none}
@media(max-width:999px){.pc-only{display:none!important}.sp-only{display:block!important}}

/* ========== LAYOUT ========== */
.l-inner{max-width:1080px;margin:0 auto;padding:0 40px}
@media(max-width:999px){.l-inner{padding:0 5vw}}

/* ========== ANIMATION ========== */
/* Fade up (default) */
.anim-fade{opacity:0;transform:translateY(50px);transition:opacity .8s cubic-bezier(.23,1,.32,1),transform .8s cubic-bezier(.23,1,.32,1)}
.anim-fade.is-visible{opacity:1;transform:none}
/* Stagger delays for grid children */
.anim-fade.is-visible .svc-item:nth-child(1),.anim-fade.is-visible .campaign-card:nth-child(1),.anim-fade.is-visible .works-card:nth-child(1),.anim-fade.is-visible .sns-card:nth-child(1){animation:fadeUp .6s .05s both}
.anim-fade.is-visible .svc-item:nth-child(2),.anim-fade.is-visible .campaign-card:nth-child(2),.anim-fade.is-visible .works-card:nth-child(2),.anim-fade.is-visible .sns-card:nth-child(2){animation:fadeUp .6s .15s both}
.anim-fade.is-visible .svc-item:nth-child(3),.anim-fade.is-visible .campaign-card:nth-child(3),.anim-fade.is-visible .works-card:nth-child(3),.anim-fade.is-visible .sns-card:nth-child(3){animation:fadeUp .6s .25s both}
/* Fade from left */
.anim-left{opacity:0;transform:translateX(-40px);transition:opacity .8s cubic-bezier(.23,1,.32,1),transform .8s cubic-bezier(.23,1,.32,1)}
.anim-left.is-visible{opacity:1;transform:none}
/* Fade from right */
.anim-right{opacity:0;transform:translateX(40px);transition:opacity .8s cubic-bezier(.23,1,.32,1),transform .8s cubic-bezier(.23,1,.32,1)}
.anim-right.is-visible{opacity:1;transform:none}
/* Scale in */
.anim-scale{opacity:0;transform:scale(.92);transition:opacity .7s cubic-bezier(.23,1,.32,1),transform .7s cubic-bezier(.23,1,.32,1)}
.anim-scale.is-visible{opacity:1;transform:none}
/* Individual stagger items — for grids observed per-child */
.anim-stagger{opacity:0;transform:translateY(30px);transition:opacity .6s cubic-bezier(.23,1,.32,1),transform .6s cubic-bezier(.23,1,.32,1)}
.anim-stagger.is-visible{opacity:1;transform:none}
@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}100%{opacity:1;transform:none}}
/* Hero text entrance */
.mv-text-en{opacity:0;transform:translateY(20px);animation:heroTextIn .8s .5s cubic-bezier(.23,1,.32,1) forwards}
.mv-text-main{opacity:0;transform:translateY(30px);animation:heroTextIn .8s .8s cubic-bezier(.23,1,.32,1) forwards}
@keyframes heroTextIn{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:none}}
/* Section title entrance */
.sec-ttl.anim-fade .sec-ttl-svg{opacity:0;transform:translateY(16px);transition:opacity .6s .1s cubic-bezier(.23,1,.32,1),transform .6s .1s cubic-bezier(.23,1,.32,1)}
.sec-ttl.anim-fade .sec-ttl-ja{opacity:0;transform:translateY(12px);transition:opacity .6s .25s cubic-bezier(.23,1,.32,1),transform .6s .25s cubic-bezier(.23,1,.32,1)}
.sec-ttl.anim-fade.is-visible .sec-ttl-svg,.sec-ttl.anim-fade.is-visible .sec-ttl-ja{opacity:1;transform:none}
/* News slide in */
.sec-news .news-wrap{opacity:0;transform:translateY(16px);transition:opacity .7s .2s cubic-bezier(.23,1,.32,1),transform .7s .2s cubic-bezier(.23,1,.32,1)}
.sec-news.is-news-visible .news-wrap{opacity:1;transform:none}
/* Flow rows stagger */
.flow-row.anim-fade{transition-delay:0s}
.flow-row.anim-fade:nth-child(1){transition-delay:.05s}
.flow-row.anim-fade:nth-child(2){transition-delay:.1s}
.flow-row.anim-fade:nth-child(3){transition-delay:.15s}
.flow-row.anim-fade:nth-child(4){transition-delay:.2s}
.flow-row.anim-fade:nth-child(5){transition-delay:.25s}
.flow-row.anim-fade:nth-child(6){transition-delay:.3s}
/* FAQ items stagger */
.faq-item.anim-fade:nth-child(1){transition-delay:.05s}
.faq-item.anim-fade:nth-child(2){transition-delay:.1s}
.faq-item.anim-fade:nth-child(3){transition-delay:.15s}
.faq-item.anim-fade:nth-child(4){transition-delay:.2s}
.faq-item.anim-fade:nth-child(5){transition-delay:.25s}
/* About block — text left, image right with separate timing */
.about-block .about-text{opacity:0;transform:translateX(-30px);transition:opacity .8s .1s cubic-bezier(.23,1,.32,1),transform .8s .1s cubic-bezier(.23,1,.32,1)}
.about-block .about-img{opacity:0;transform:translateX(30px);transition:opacity .8s .25s cubic-bezier(.23,1,.32,1),transform .8s .25s cubic-bezier(.23,1,.32,1)}
.anim-fade.is-visible .about-text,.anim-fade.is-visible .about-img{opacity:1;transform:none}
/* Company table rows fade in */
.company-table tr{opacity:0;transform:translateY(12px);transition:opacity .5s cubic-bezier(.23,1,.32,1),transform .5s cubic-bezier(.23,1,.32,1)}
.anim-fade.is-visible .company-table tr:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
.anim-fade.is-visible .company-table tr:nth-child(2){opacity:1;transform:none;transition-delay:.1s}
.anim-fade.is-visible .company-table tr:nth-child(3){opacity:1;transform:none;transition-delay:.15s}
.anim-fade.is-visible .company-table tr:nth-child(4){opacity:1;transform:none;transition-delay:.2s}
.anim-fade.is-visible .company-table tr:nth-child(5){opacity:1;transform:none;transition-delay:.25s}
.anim-fade.is-visible .company-table tr:nth-child(6){opacity:1;transform:none;transition-delay:.3s}
/* Hero text re-animation on slide change */
.mv-text-animate .mv-text-en{animation:heroTextIn .6s .1s cubic-bezier(.23,1,.32,1) both}
.mv-text-animate .mv-text-main{animation:heroTextIn .6s .2s cubic-bezier(.23,1,.32,1) both}
/* Parallax-like subtle shift for images on scroll — handled via JS */
.about-img img,.company-photo img{will-change:transform;overflow:hidden}
.about-img,.company-photo{overflow:visible}
/* Reduce motion for accessibility */
@media(prefers-reduced-motion:reduce){.anim-fade,.anim-left,.anim-right,.anim-scale,.anim-stagger{opacity:1!important;transform:none!important;transition:none!important}.mv-slide.is-active{animation:none!important}.mv-text-en,.mv-text-main{animation:none!important;opacity:1!important;transform:none!important}}

/* ========== HEADER — pikapika exact ========== */
.g-header{position:fixed;top:0;left:0;width:100%;height:130px;z-index:1000;background:#fff;display:flex;align-items:center;transition:box-shadow .3s,transform .4s}
.g-header.is-scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.g-header.is-hidden{transform:translateY(-100%)}
.g-header-inner{max-width:1080px;margin:0 auto;padding:0 40px;width:100%;display:flex;align-items:center;justify-content:space-between}
.g-header-logo{display:flex;align-items:center;text-decoration:none}
.g-logo-img{height:120px;width:auto}
.logo-pika{position:relative;background:linear-gradient(90deg,#066aab 0%,#066aab 35%,#8edcff 48%,#fff 52%,#8edcff 56%,#066aab 70%,#066aab 100%);background-size:300% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:pikapika 3s ease-in-out infinite;font-weight:900}
.pika-particle{position:absolute;-webkit-text-fill-color:#5bc0ff;font-size:10px;opacity:0;pointer-events:none;animation:pika-float 2.4s ease-in-out infinite}
.pika-particle:nth-child(1){top:-10px;left:5%;animation-delay:0s;font-size:8px}
.pika-particle:nth-child(2){top:-6px;right:0%;animation-delay:.3s;font-size:11px}
.pika-particle:nth-child(3){bottom:-8px;left:25%;animation-delay:.6s;font-size:7px}
.pika-particle:nth-child(4){top:-12px;right:25%;animation-delay:.9s;font-size:9px}
.pika-particle:nth-child(5){bottom:-10px;right:10%;animation-delay:1.2s;font-size:8px}
.pika-particle:nth-child(6){top:-5px;left:45%;animation-delay:1.5s;font-size:10px}
.pika-particle:nth-child(7){bottom:-6px;left:60%;animation-delay:1.8s;font-size:7px}
.pika-particle:nth-child(8){top:-14px;left:70%;animation-delay:.2s;font-size:9px}
.pika-particle:nth-child(9){bottom:-12px;right:40%;animation-delay:.7s;font-size:6px}
.pika-particle:nth-child(10){top:-8px;left:85%;animation-delay:1.1s;font-size:10px}
@keyframes pikapika{0%,100%{background-position:100% 0}50%{background-position:-100% 0}}
@keyframes pika-float{0%{opacity:0;transform:translateY(4px) scale(.5)}25%{opacity:1;transform:translateY(-6px) scale(1)}50%{opacity:.8;transform:translateY(-10px) scale(.8)}75%{opacity:.4;transform:translateY(-14px) scale(.6)}100%{opacity:0;transform:translateY(-18px) scale(.3)}}
.g-logo-sub{font-family:'Montserrat',sans-serif;font-weight:600;font-size:14px;color:#333;letter-spacing:.04em}
.g-nav ul{display:flex;align-items:center;gap:28px;list-style:none}
.g-nav a{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;color:#333;letter-spacing:.12em;transition:color .3s}
.g-nav a:hover{color:#066aab;opacity:1}
.g-nav-contact{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:2px solid #066aab;border-radius:50%;transition:background .3s}
.g-nav-contact:hover{background:#066aab;opacity:1}
.g-nav-contact:hover img{filter:brightness(0) invert(1)}
.g-nav-contact img{width:18px;height:18px}
.g-nav-cta{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;color:#fff!important;font-size:12px!important;font-weight:700;letter-spacing:.08em;border-radius:3px;transition:background .3s,transform .3s}
.g-nav-cta:hover{transform:translateY(-1px);opacity:1}
.g-nav-cta--tel{background:#066aab}
.g-nav-cta--tel:hover{background:#055a95}
.g-nav-cta--line{background:#06c755}
.g-nav-cta--line:hover{background:#05a648}
/* Dropdown */
.g-nav-dropdown{position:relative}
.g-nav-dropdown>a{cursor:pointer}
.g-nav-dropdown>a::after{content:'▾';margin-left:3px;font-size:10px;opacity:.5}
.g-nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:160px;background:#fff;border-radius:3px;box-shadow:0 6px 20px rgba(0,0,0,.12);padding:8px 0;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:1200}
.g-nav-dropdown:hover .g-nav-dropdown-menu{opacity:1;visibility:visible}
.g-nav-dropdown-menu a{display:block;padding:10px 20px;font-size:13px;color:#333;font-weight:500;white-space:nowrap;transition:background .2s}
.g-nav-dropdown-menu a:hover{background:#f0f7fc;color:#066aab;opacity:1}
.g-hamburger{display:none;flex-direction:column;gap:6px;width:28px;padding:4px 0;z-index:1100}
.g-hamburger span{display:block;height:2px;background:#333;transition:.3s}
.g-hamburger.is-active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.g-hamburger.is-active span:nth-child(2){opacity:0}
.g-hamburger.is-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:999px){.g-header{height:64px}.g-header-inner{padding:0 4vw}.g-hamburger{display:flex}.g-logo-img{height:56px}}

/* ========== SP MENU ========== */
.g-sp-menu{position:fixed;inset:0;background:#fff;z-index:1050;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.g-sp-menu.is-active{opacity:1;pointer-events:auto}
.g-sp-menu ul{display:flex;flex-direction:column;align-items:center;gap:18px}
.g-sp-menu a{font-family:'Montserrat','Noto Sans JP',sans-serif;font-size:16px;font-weight:600;color:#333;letter-spacing:.1em}
.g-sp-menu-divider{width:40px;height:1px;background:#ddd;margin:4px 0}
.g-sp-tel{font-size:20px!important;color:#066aab!important;font-weight:700!important}
.g-sp-cta{background:#066aab!important;color:#fff!important;padding:12px 40px!important;border-radius:10px!important;font-size:14px!important;letter-spacing:.08em!important}

/* ========== HERO MV — pikapika slider ========== */
.mv{position:relative;width:100%;height:100vh;min-height:500px;max-height:920px;overflow:hidden;padding-top:130px}
.mv-slider{position:absolute;inset:0;z-index:1}
.mv-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease;animation:none}
.mv-slide.is-active{opacity:1;animation:kenBurns 8s ease forwards}
@keyframes kenBurns{0%{transform:scale(1)}100%{transform:scale(1.06)}}
.mv-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(0,0,0,.15) 0%,rgba(0,0,0,.35) 100%)}
.mv-text{position:absolute;bottom:15%;left:0;right:0;z-index:3;text-align:center;color:#fff;padding:0 40px}
.mv-text-en{font-family:'Montserrat',sans-serif;font-size:14px;font-weight:600;letter-spacing:.25em;margin-bottom:16px;opacity:.8;text-transform:uppercase}
.mv-text-main{font-family:'Noto Sans JP',sans-serif;font-size:46px;font-weight:900;line-height:1.5;letter-spacing:.08em;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.mv-dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:12px}
.mv-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.3);border:2px solid rgba(255,255,255,.5);cursor:pointer;transition:.3s;padding:0}
.mv-dot.is-active{background:#fff;border-color:#fff}
@media(max-width:999px){.mv{padding-top:64px;height:70vh;min-height:380px}.mv-text-main{font-size:28px}.mv-text-en{font-size:11px}.mv-text{bottom:20%;padding:0 6vw}}

/* old campaign banner — hidden */
.sec-campaign{display:none}

/* ========== NEWS — pikapika style ========== */
.sec-news{padding:40px 0;border-bottom:1px solid #eee}
.news-wrap{display:flex;align-items:center;gap:40px}
.news-ttl{flex-shrink:0}
.news-ttl .sec-ttl-svg{height:36px}
.news-list{flex:1;display:flex;flex-direction:column;gap:0}
.news-item{display:flex;align-items:center;gap:20px;padding:12px 0;border-bottom:1px solid #f0f0f0;transition:opacity .3s}
.news-item:last-child{border-bottom:none}
.news-item:hover{opacity:.6}
.news-item time{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:500;color:#999;letter-spacing:.04em;flex-shrink:0;white-space:nowrap}
.news-item span{font-size:14px;color:#333;line-height:1.6}
.news-more{flex-shrink:0}
.news-more a{display:inline-block;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;letter-spacing:.1em;color:#066aab;border:1px solid #066aab;padding:8px 24px;border-radius:3px;transition:.3s}
.news-more a:hover{background:#066aab;color:#fff;opacity:1}
@media(max-width:999px){.news-wrap{flex-direction:column;gap:16px;align-items:flex-start}.news-more{align-self:center}}

/* ========== SECTION COMMON ========== */
.sec{padding:100px 0}
.sec-gray{background:#f5f7fa}
.sec-blue{background:#066aab}

/* Section title — SVG image + Japanese subtitle like pikapika */
.sec-ttl{text-align:center;margin-bottom:60px}
.sec-ttl-svg{display:inline-block;height:42px;width:auto}
.sec-ttl-ja{font-size:14px;font-weight:500;color:#666;letter-spacing:.1em;margin-top:8px}
@media(max-width:999px){.sec{padding:64px 0}.sec-ttl{margin-bottom:40px}.sec-ttl-svg{height:32px}.sec-ttl-ja{font-size:12px}}


/* ========== ABOUT — pikapika layout ========== */
.about-block{display:flex;gap:48px;align-items:flex-start;max-width:1200px;margin:0 auto}
.about-text{flex:1;min-width:0}
.about-lead{font-size:18px;font-weight:700;color:#333;line-height:1.9;margin-bottom:24px}
.about-icon-deco{margin-bottom:20px}
.about-icon-deco img{width:48px;height:48px}
.about-text p{font-size:15px;color:#555;line-height:2;margin-bottom:16px}
.about-img{flex:0 0 620px}
.about-img img{width:100%;border-radius:3px;aspect-ratio:3/4;object-fit:cover}

/* 代表挨拶 */
.about-greeting{margin-top:80px;padding-top:60px;border-top:1px solid #eee}
.about-greeting-ttl{font-size:20px;font-weight:700;color:#333;margin-bottom:32px;text-align:center}
.about-greeting-wrap{display:flex;gap:40px;align-items:flex-start}
.about-greeting-photo{flex:0 0 200px}
.about-greeting-photo img{width:100%;border-radius:3px;aspect-ratio:3/4;object-fit:cover}
.about-greeting-body{flex:1;min-width:0}
.about-greeting-body p{font-size:15px;color:#555;line-height:2;margin-bottom:16px}
.about-sign{margin-top:24px;padding-top:20px;border-top:1px solid #e0e0e0}
.about-sign-role{display:block;font-size:12px;color:#999;letter-spacing:.06em}
.about-sign-name{display:block;font-size:24px;font-weight:700;color:#333;letter-spacing:.06em;margin-top:2px}
@media(max-width:999px){.about-block{flex-direction:column;gap:32px}.about-img{flex:none;text-align:center}.about-img img{max-width:280px;margin:0 auto}.about-greeting-wrap{flex-direction:column;gap:24px}.about-greeting-photo{flex:none;text-align:center}.about-greeting-photo img{max-width:180px;margin:0 auto}}

/* ========== SERVICE — pikapika style ========== */
.svc-intro{display:flex;align-items:center;gap:24px;justify-content:center;margin-bottom:48px}
.svc-intro-icon img{width:60px;height:60px}
.svc-intro-text p{font-size:14px;color:#666;line-height:1.8}
.svc-heading{font-size:20px;font-weight:700;color:#333;text-align:center;margin-bottom:32px;letter-spacing:.06em}
.svc-cat{font-size:15px;font-weight:700;color:#333;text-align:center;margin-bottom:20px;padding:10px 0;border-bottom:2px solid #066aab;letter-spacing:.06em}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:800px;margin:0 auto 48px;list-style:none}
.svc-note{text-align:center;font-size:14px;color:#888;margin-bottom:20px}
.svc-contact{text-align:center}
.btn-outline-blue{display:inline-block;font-family:'Montserrat','Noto Sans JP',sans-serif;font-size:14px;font-weight:600;color:#066aab;border:2px solid #066aab;padding:12px 40px;border-radius:3px;transition:.3s;letter-spacing:.06em}
.btn-outline-blue:hover{background:#066aab;color:#fff;opacity:1}
.svc-item{display:block;text-decoration:none;color:#333;border-radius:3px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.08);transition:transform .3s,box-shadow .3s}
.svc-item:hover{transform:translateY(-6px);box-shadow:0 8px 24px rgba(0,0,0,.14);opacity:1}
.svc-item-img{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden}
.svc-item-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.svc-item:hover .svc-item-img img{transform:scale(1.06)}
.svc-item-img--placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#066aab 0%,#044f80 100%);display:flex;align-items:center;justify-content:center}
.svc-item-img--placeholder span{color:rgba(255,255,255,.15);font-size:36px}
.svc-item-label{display:block;padding:14px 10px;font-size:14px;font-weight:700;text-align:center;color:#333;background:#fff;line-height:1.4}
@media(max-width:600px){.svc-grid{grid-template-columns:repeat(2,1fr);gap:14px}.svc-item-label{font-size:13px;padding:10px 8px}}

/* Buttons */
.btn-line{display:inline-flex;align-items:center;gap:8px;background:#06c755;color:#fff;padding:14px 36px;border-radius:10px;font-size:15px;font-weight:700;transition:.3s}
.btn-line:hover{background:#05b04c;opacity:1}
.btn-line svg{width:20px;height:20px}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#333;border:2px solid #333;padding:12px 32px;border-radius:10px;font-size:15px;font-weight:700;transition:.3s}
.btn-ghost:hover{background:#333;color:#fff;opacity:1}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#066aab;padding:14px 36px;border-radius:10px;font-size:15px;font-weight:700;transition:.3s}
.btn-white:hover{background:#f0f0f0;opacity:1}
.btn-white svg{width:20px;height:20px}
.btn-border-white{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5);padding:12px 32px;border-radius:10px;font-size:15px;font-weight:700;transition:.3s}
.btn-border-white:hover{background:rgba(255,255,255,.15);opacity:1}
.sec-cta{text-align:center;margin-top:48px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
@media(max-width:999px){.sec-cta{flex-direction:column;align-items:center}.btn-line,.btn-ghost,.btn-white,.btn-border-white{width:80%;max-width:300px;justify-content:center}}

/* MORE link — pikapika style */
.sec-more{text-align:center;margin-top:48px}
.sec-more a{display:inline-block;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:600;letter-spacing:.15em;color:#066aab;border:2px solid #066aab;padding:12px 40px;border-radius:3px;transition:.3s}
.sec-more a:hover{background:#066aab;color:#fff;opacity:1}

/* ========== WORKS ========== */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.works-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 6px 24px rgba(0,0,0,.06);transition:transform .3s}
.works-card:hover{transform:translateY(-6px)}
.works-ba{display:flex;align-items:stretch}
.works-ba-img{flex:1;position:relative;overflow:hidden}
.works-ba-img img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.works-ba-img span{position:absolute;top:8px;left:8px;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:.08em;color:#fff;background:rgba(0,0,0,.5);padding:3px 8px;border-radius:4px;z-index:2}
.works-ba-arrow{width:24px;flex-shrink:0;background:#066aab;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700}
.works-ba-arrow::after{content:'→'}
.works-info{padding:16px 20px}
.works-info h3{font-size:14px;font-weight:700;color:#333;margin-bottom:4px;line-height:1.5}
.works-info p{font-size:13px;color:#888;line-height:1.7}
@media(max-width:999px){.works-grid{grid-template-columns:1fr}}

/* ========== FLOW ========== */
.flow-list{max-width:720px;margin:0 auto}
.flow-row{display:flex;gap:20px;align-items:flex-start;padding:28px 0;border-bottom:1px solid #e8e8e8;position:relative}
.flow-row:last-child{border-bottom:none}
.flow-num{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:#066aab;color:#fff;font-family:'Montserrat',sans-serif;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}
.flow-body h3{font-size:17px;font-weight:700;color:#333;margin-bottom:6px}
.flow-body p{font-size:14px;color:#666;line-height:1.9}
@media(max-width:999px){.flow-row{gap:16px;padding:20px 0}.flow-num{width:40px;height:40px;font-size:14px}}

/* ========== FAQ ========== */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{margin-bottom:8px;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.faq-q{display:flex;align-items:center;gap:14px;padding:18px 24px;width:100%;text-align:left;font-size:15px;font-weight:600;color:#333;transition:color .3s}
.faq-q:hover{color:#066aab}
.faq-q-mark{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:#066aab;color:#fff;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center}
.faq-q span:nth-child(2){flex:1;line-height:1.6}
.faq-q-toggle{flex-shrink:0;font-size:20px;color:#aaa;transition:transform .3s;font-weight:300;line-height:1}
.faq-item.is-open .faq-q-toggle{transform:rotate(45deg)}
.faq-a{height:0;overflow:hidden;transition:height .35s ease}
.faq-a-inner{padding:0 24px 24px 70px;font-size:14px;line-height:2;color:#666}
@media(max-width:999px){.faq-q{padding:16px 18px}.faq-a-inner{padding:0 18px 18px 56px}}

/* ========== CAMPAIGN — pikapika 3-card layout ========== */
.campaign-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;max-width:900px;margin:0 auto}
.campaign-card{text-align:center;padding:0 16px}
.campaign-card-icon{margin-bottom:20px}
.campaign-card-icon img{width:64px;height:64px;margin:0 auto}
.campaign-card h4{font-size:18px;font-weight:700;color:#333;line-height:1.6;margin-bottom:12px}
.campaign-card p{font-size:14px;color:#666;line-height:1.9}
@media(max-width:999px){.campaign-grid{grid-template-columns:1fr;gap:40px;max-width:400px}}

/* ========== COMPANY — pikapika table layout ========== */
.company-block{max-width:800px;margin:0 auto}
.company-photo{margin-bottom:40px;border-radius:3px;overflow:hidden}
.company-photo img{width:100%;aspect-ratio:16/7;object-fit:cover}
.company-table{width:100%;border-collapse:collapse}
.company-table tr{border-bottom:1px solid #eee}
.company-table tr:last-child{border-bottom:none}
.company-table th{font-size:14px;font-weight:600;color:#555;padding:18px 20px;text-align:left;width:140px;vertical-align:top;white-space:nowrap}
.company-table td{font-size:14px;color:#666;padding:18px 20px;line-height:1.8}
.company-table td ul{list-style:none;padding:0}
.company-table td li{padding:2px 0}
.company-table td li::before{content:'・';color:#066aab}
@media(max-width:999px){.company-table th{display:block;padding:14px 0 4px;width:auto}.company-table td{display:block;padding:4px 0 14px}}

/* ========== SNS — pikapika style ========== */
.sns-grid{display:flex;justify-content:center;gap:40px}
.sns-card{display:flex;flex-direction:column;align-items:center;gap:12px;text-decoration:none;transition:transform .3s}
.sns-card:hover{transform:translateY(-4px);opacity:1}
.sns-card-icon{width:72px;height:72px;border-radius:50%;border:2px solid #066aab;display:flex;align-items:center;justify-content:center;transition:.3s}
.sns-card-icon svg{width:28px;height:28px;fill:#066aab;transition:.3s}
.sns-card:hover .sns-card-icon{background:#066aab;border-color:#066aab}
.sns-card:hover .sns-card-icon svg{fill:#fff}
.sns-card-icon--line svg{fill:#06c755}
.sns-card:hover .sns-card-icon--line{background:#06c755;border-color:#06c755}
.sns-card p{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;color:#555;letter-spacing:.06em}

/* ========== CONTACT ========== */
.contact-lead{font-size:16px;color:rgba(255,255,255,.85);margin-bottom:32px;line-height:1.9}
.contact-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.contact-area{font-size:13px;color:rgba(255,255,255,.5)}
@media(max-width:999px){.contact-btns{flex-direction:column;align-items:center}}

/* ========== FOOTER — pikapika style ========== */
.g-footer{background:#1a1a1a;color:#fff;text-align:center;padding:56px 20px 36px}
.g-footer-inner{max-width:800px;margin:0 auto}
.g-footer-logo{display:inline-block;font-family:'Montserrat',sans-serif;font-weight:900;font-size:24px;letter-spacing:.06em;color:#fff;margin-bottom:28px}
.g-footer-logo span{color:#fff}
.g-footer-nav{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:28px}
.g-footer-nav a{font-size:12px;color:rgba(255,255,255,.45);transition:color .3s}
.g-footer-nav a:hover{color:#fff;opacity:1}
.g-footer-sns{display:flex;justify-content:center;gap:16px;margin-bottom:24px}
.g-footer-sns a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);transition:.3s}
.g-footer-sns a:hover{background:rgba(255,255,255,.2);opacity:1}
.g-footer-sns a svg{width:16px;height:16px;fill:rgba(255,255,255,.6)}
.g-footer-privacy{display:inline-block;font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.35);margin-bottom:16px;transition:color .3s}
.g-footer-privacy:hover{color:#fff;opacity:1}
.g-footer-copy{font-size:11px;color:rgba(255,255,255,.25);letter-spacing:.02em}

/* ========== FIXED CTA ========== */
.g-fixed-cta{position:fixed;bottom:0;left:0;width:100%;z-index:900;display:flex;transform:translateY(100%);transition:transform .4s}
.g-fixed-cta.is-show{transform:translateY(0)}
.g-fixed-cta a{flex:1;display:flex;align-items:center;justify-content:center;padding:16px;font-size:14px;font-weight:700;letter-spacing:.06em;transition:.3s}
.g-fixed-line{background:#06c755;color:#fff;position:relative}
.g-fixed-line:hover{background:#05b04c;opacity:1}
.fixed-coupon-badge{position:absolute;top:-16px;left:50%;transform:translateX(-50%);color:#d63637;font-size:11px;font-weight:900;white-space:nowrap;letter-spacing:.04em;animation:coupon-pulse 1.5s ease-in-out infinite;background:#fff;padding:2px 10px;border-radius:4px;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.btn-line-coupon{position:relative;overflow:visible}
.line-coupon-badge{display:block;text-align:center;color:#d63637;font-size:18px;font-weight:900;letter-spacing:.08em;margin-bottom:10px;width:100%;animation:coupon-blink 1.2s ease-in-out infinite}
.sec-blue .line-coupon-badge,.sub-cta-section .line-coupon-badge{color:#ffde00;font-size:20px;text-shadow:0 2px 8px rgba(0,0,0,.3);-webkit-text-stroke:.5px rgba(255,255,255,.3)}
@keyframes coupon-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(1.03)}}
.sub-mid-cta.btn-line-coupon{display:flex;flex-direction:column;align-items:center}
.btn-line-coupon .line-coupon-badge{position:static;transform:none}
.contact-line-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}
@keyframes coupon-pulse{0%,100%{opacity:.85}50%{opacity:1}}
.g-fixed-tel{background:#066aab;color:#fff}
.g-fixed-tel:hover{background:#055a8f;opacity:1}

/* ============================================================
   BELOW: compatibility styles for sub pages
   (sub pages still use old class names)
   ============================================================ */

/* old header compat */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:#fff;height:80px;display:flex;align-items:center;transition:box-shadow .3s,transform .4s}
.site-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.site-header.hidden{transform:translateY(-100%)}
.hd-inner{max-width:1080px;margin:0 auto;padding:0 40px;width:100%;display:flex;align-items:center;justify-content:space-between}
.logo-mark{font-family:'Montserrat',sans-serif;font-weight:900;font-size:26px;letter-spacing:.06em;color:#066aab}
.min{font-family:'Montserrat','Noto Sans JP',sans-serif}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:13px;color:#555;font-weight:500;white-space:nowrap;transition:color .3s}
.nav-links a:hover{color:#066aab;opacity:1}
.hd-tel{display:flex;align-items:center;gap:5px;color:#555;font-size:13px;font-weight:500}
.hd-tel svg{width:14px;height:14px;fill:#999}
.hd-cta{display:flex;align-items:center;gap:6px;background:#066aab;color:#fff;padding:10px 24px;font-size:13px;border-radius:10px;font-weight:600;transition:.3s}
.hd-cta:hover{background:#055a8f;opacity:1}
.hd-cta svg{width:15px;height:15px;fill:#fff}
.hd-sns{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#f0f0f0;transition:.2s}
.hd-sns:hover{background:#e0e0e0;opacity:1}
.hd-sns svg{width:16px;height:16px;fill:#555}
.nav-links .nav-dropdown{position:relative}
.nav-links .nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.1);padding:8px 0;min-width:180px;opacity:0;pointer-events:none;transition:.2s}
.nav-links .nav-dropdown:hover .nav-dropdown-menu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-dropdown-menu a{display:block;padding:8px 20px;font-size:13px;color:#555!important;white-space:nowrap;transition:.2s}
.nav-dropdown-menu a:hover{background:#f5f7fa;color:#066aab!important}
.hamburger{display:none;flex-direction:column;gap:5px;width:24px;cursor:pointer;z-index:1100}
.hamburger span{display:block;height:2px;background:#333;border-radius:2px;transition:.3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:#fff;z-index:1050;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;opacity:0;pointer-events:none;transition:.3s}
.mobile-menu.active{opacity:1;pointer-events:auto}
.mobile-menu a{font-size:16px;font-weight:500;color:#333}
.mobile-menu a:last-child{background:#066aab;color:#fff;padding:12px 36px;border-radius:10px;font-size:14px}
.mobile-menu .mm-tel{display:flex;align-items:center;gap:6px;font-size:18px;color:#066aab;font-weight:700;background:none;padding:0;border-radius:0}
.mobile-menu .mm-tel svg{width:18px;height:18px;fill:#066aab}
@media(max-width:999px){.site-header{height:60px}.hd-inner{padding:0 4vw}.nav-links{display:none}.hamburger{display:flex}.hd-cta span{display:none}.hd-cta{padding:7px 10px}.hd-tel span{display:none}.hd-tel{width:32px;height:32px;justify-content:center}}

/* Sub Hero */
.sub-hero{padding-top:130px;background:#066aab;color:#fff;text-align:center;padding-bottom:48px}
.sub-hero .inner{position:relative;z-index:2}
.sub-hero h1{font-size:34px;font-weight:900;margin-bottom:12px;padding-top:40px;letter-spacing:.04em}
.sub-hero p{font-size:15px;color:rgba(255,255,255,.8);line-height:1.8}
@media(max-width:999px){.sub-hero{padding-top:60px}.sub-hero h1{font-size:24px;padding-top:28px}}

/* Shared .sec and .inner for sub pages */
.inner{max-width:1080px;margin:0 auto;padding:0 40px}
@media(max-width:999px){.inner{padding:0 5vw}}
.sec-alt{background:#f5f7fa}
.sec-pattern{background:#f5f7fa}
.sec-dark{background:#066aab;color:#fff}
.sec-hd{text-align:center;margin-bottom:40px}
.sec-hd .sec-en{display:block;font-family:'Montserrat',sans-serif;font-size:42px;font-weight:900;letter-spacing:.08em;color:#066aab;line-height:1.2;margin-bottom:6px}
.sec-hd h2{font-size:15px;font-weight:500;color:#666;letter-spacing:.08em}
.sec-hd p{font-size:14px;color:#999;margin-top:8px;line-height:1.9}
.sec-hd h2 .hl{color:#066aab}
.sec-dark .sec-hd .sec-en{color:rgba(255,255,255,.3)}
.sec-dark .sec-hd h2{color:#fff}
.sec-dark .sec-hd p{color:rgba(255,255,255,.6)}
@media(max-width:999px){.sec-hd .sec-en{font-size:30px}}

/* Breadcrumb */
.breadcrumb{padding:84px 0 0;font-size:13px;color:rgba(0,0,0,.5)}
.breadcrumb a{color:#066aab}
.breadcrumb span{margin:0 6px;color:#ddd}

/* ===== PRICING (sub pages) ===== */
.pricing-tabs{display:flex;justify-content:center;gap:6px;margin-bottom:32px}
.pricing-tab{padding:8px 24px;border-radius:10px;font-size:14px;font-weight:500;color:#888;background:#fff;border:1px solid #ddd;cursor:pointer;transition:.3s}
.pricing-tab.active{background:#066aab;color:#fff;border-color:#066aab}
.pricing-content{display:none}
.pricing-content.active{display:block}
.pricing-content h3{font-size:18px;font-weight:600;margin-bottom:18px;text-align:center;color:#333}
.price-category{font-size:18px;font-weight:700;color:#333;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.price-category::before{content:'●';color:#066aab;font-size:10px}
.price-item{display:flex;gap:0;margin-bottom:28px;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);min-height:200px}
.price-item.reverse{flex-direction:row-reverse}
.price-item-info{flex:1;min-width:0}
.price-item-type{background:#066aab;color:#fff;font-size:18px;font-weight:600;padding:12px 20px}
.price-item-table{padding:0}
.price-item-row{display:flex;align-items:center;border-bottom:1px solid #eee;padding:14px 20px}
.price-item-row:last-child{border-bottom:none}
.price-item-label{flex:0 0 72px;font-size:13px;font-weight:600;color:#066aab;border-left:3px solid #066aab;padding-left:10px}
.price-item-val{flex:1;font-size:15px;color:#555;line-height:1.6}
.price-item-val .price-main{font-size:34px;font-weight:900;color:#d63637}
.price-item-val .price-main .yen{font-size:16px}
.price-item-val .price-main .tax{font-size:11px;color:#999;font-weight:400;margin-left:2px}
.price-item-val .price-note{display:inline-block;margin-top:4px;font-size:12px;color:#d63637;background:#fef2f2;padding:3px 10px;border-radius:10px;font-weight:500}
.price-item-img{flex:0 0 44%;position:relative}
.price-item-img img{width:100%;height:100%;object-fit:cover;display:block}
.price-item-img-ph{width:100%;height:100%;min-height:200px;background:#e8ecef;display:flex;align-items:center;justify-content:center;color:#aaa;font-size:13px}
.price-discount-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.price-original{font-size:15px;color:#aaa;text-decoration:line-through}
.price-original .yen{font-size:12px}
.price-off{font-size:13px;font-weight:700;color:#d63637}
.price-item-cta{padding:12px 20px;border-top:1px solid #eee;text-align:center}
.price-item-cta a{display:inline-block;background:#066aab;color:#fff;padding:10px 36px;border-radius:10px;font-size:13px;font-weight:600;transition:.2s}
.price-item-cta a:hover{background:#055a8f;opacity:1}
@media(max-width:999px){.price-item,.price-item.reverse{flex-direction:column}.price-item-img{flex:none;height:200px}.price-item-val .price-main{font-size:26px}}

/* Set plan cards */
.set-plan-card{background:#fff;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.06);margin-bottom:24px;overflow:hidden}
.set-plan-header{background:#066aab;color:#fff;padding:16px 24px;display:flex;align-items:center;gap:12px}
.set-plan-header h3{font-size:18px;font-weight:600;margin:0}
.set-plan-badge{background:#d63637;color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:10px}
.set-plan-items{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;padding:20px 24px;background:#f9fbfc}
.set-plan-item{background:#fff;border:2px solid #066aab;color:#555;font-size:14px;font-weight:600;padding:8px 18px;border-radius:10px}
.set-plan-plus{color:#066aab;font-size:16px;font-weight:700}
.set-plan-price{padding:16px 24px;text-align:center;border-top:1px solid #eee}
.set-plan-price-label{display:block;font-size:12px;color:#999;margin-bottom:4px}
.set-plan-price-val{font-size:26px;font-weight:900;color:#d63637}
.set-plan-price-val .yen{font-size:15px}
.set-plan-price-val .tax{font-size:11px;color:#999;font-weight:400}
.set-plan-cta{padding:12px 24px 20px;text-align:center}
.set-plan-cta a{display:inline-block;background:#066aab;color:#fff;padding:10px 36px;border-radius:10px;font-size:13px;font-weight:600;transition:.2s}
.set-plan-cta a:hover{background:#055a8f}

/* Discount banners */
.service-card-original{display:block;font-size:14px;color:#aaa;text-decoration:line-through;margin-bottom:0}
.multi-discount-banner{margin-top:24px;background:#066aab;border-radius:10px;padding:18px 24px;text-align:center;color:#fff}
.multi-discount-banner .mdb-title{font-size:15px;font-weight:700;margin-bottom:4px}
.multi-discount-banner .mdb-title span{font-size:18px;color:#ffe066}
.multi-discount-banner .mdb-detail{font-size:13px;color:rgba(255,255,255,.8)}
.multi-discount-banner .mdb-detail strong{color:#ffe066;font-size:15px}
.price-2nd{display:block;margin-top:6px}
.price-2nd-label{font-size:14px;color:#d63637;font-weight:600}
.price-2nd-amount{font-size:28px;font-weight:900;color:#d63637}
.price-2nd-amount .yen{font-size:14px}
.price-2nd-amount .tax{font-size:11px;color:#999;font-weight:400}
.price-discount-tag{display:inline-block;margin-top:4px;background:#d63637;color:#fff;font-size:14px;font-weight:700;padding:4px 12px;border-radius:10px}
.price-section-spacer{height:20px}

/* Mid CTA / Section CTA */
.mid-cta{text-align:center;margin-top:36px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.mid-cta a{display:inline-flex;align-items:center;gap:7px;padding:13px 30px;border-radius:10px;font-size:15px;font-weight:600;transition:.3s}
.mid-cta .cta-line{background:#06c755;color:#fff}
.mid-cta .cta-line:hover{background:#05b04c;opacity:1}
.mid-cta .cta-dark{background:#333;color:#fff}
.mid-cta .cta-dark:hover{background:#444;opacity:1}
.cta-form{background:#e88732;color:#fff}
.cta-form:hover{background:#d47828;opacity:1}
.cta-form-badge{font-size:10px;background:rgba(255,255,255,.25);border-radius:10px;padding:2px 8px;margin-left:2px}
.final-cta-buttons .cta-form{background:#e88732;color:#fff}
.mid-cta a svg{width:16px;height:16px}
.section-cta{text-align:center;margin-top:40px;padding:32px 0 0}
.section-cta a{display:inline-flex;align-items:center;gap:7px;background:#066aab;color:#fff;padding:14px 32px;border-radius:10px;font-size:15px;font-weight:600;transition:.3s}
.section-cta a:hover{background:#055a8f;opacity:1}
.section-cta a svg{width:17px;height:17px}
.section-cta a.cta-line{background:#06c755}
.section-cta a.cta-line:hover{background:#05b04c}
.section-cta .line-coupon{background:#d63637}
.section-cta .cta-sub{display:block;margin-top:8px;font-size:11px;color:#aaa}
@media(max-width:999px){.mid-cta{flex-direction:column;align-items:center}.mid-cta a{width:100%;max-width:280px;justify-content:center}}

/* Line coupon compat */
.line-coupon-wrap{display:inline-block;margin-bottom:14px}
.line-coupon{display:inline-flex;align-items:center;gap:2px;background:#d63637;color:#fff;padding:10px 28px;border-radius:10px;font-size:13px;font-weight:600}
.line-coupon .coupon-top{font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px}
.line-coupon .coupon-top svg{width:14px;height:14px;fill:#fff}
.line-coupon .coupon-amount{font-size:16px;font-weight:900;color:#ffe066;margin-left:4px}
.coupon-ribbon-svg,.coupon-sparkle,.coupon-corner,.coupon-bow,.coupon-bow-center,.micro-copy,.line-coupon .coupon-bottom,.mega-burst,.hero,.hero-wrap,.coupon-banner{display:none}

/* Accordion */
.accordion{margin-bottom:8px}
.accordion-header{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:10px;cursor:pointer;font-size:15px;font-weight:500;color:#555;transition:.3s}
.accordion-header:hover{background:#eee}
.accordion-arrow{font-size:10px;transition:transform .3s;color:#aaa}
.accordion.open .accordion-arrow{transform:rotate(180deg)}
.accordion-body{height:0;overflow:hidden;padding:0 18px}
.accordion-body-inner{padding:14px 0;font-size:15px;line-height:1.9;color:#666}

/* Concerns compat */
.concerns-upper{background:#066aab;padding:56px 0 44px}
.concerns-cols{display:flex;gap:20px;max-width:700px;margin:0 auto}
.concerns-col{flex:1;display:flex;flex-direction:column;align-items:center}
.speech-bubble{background:rgba(255,255,255,.12);color:#fff;font-size:17px;font-weight:500;line-height:1.7;text-align:center;padding:18px 24px;border-radius:10px;margin-bottom:16px;position:relative;min-width:200px;border:1px solid rgba(255,255,255,.2)}
.speech-bubble::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid rgba(255,255,255,.12)}
.concerns-col-img{width:100%;aspect-ratio:1/1;border-radius:10px;overflow:hidden;background-size:cover;background-position:center}
.concerns-transition{background:#066aab;padding:0 0 48px;text-align:center}
.concerns-transition p{color:#fff;font-size:22px;line-height:1.8}
.concerns-transition strong{font-size:26px;font-weight:700}
.concerns-transition .hl-blue{color:#fff;text-decoration:underline;text-underline-offset:4px}
.concerns-arrow{position:relative;background:#066aab;height:0}
.concerns-arrow::before{content:'';display:block;width:0;height:0;border-left:50vw solid #066aab;border-right:50vw solid #066aab;border-bottom:28px solid #f5f7fa;position:absolute;bottom:0;left:50%;transform:translateX(-50%)}
.concerns-arrow::after{content:'';display:block;width:0;height:0;border-left:40px solid transparent;border-right:40px solid transparent;border-top:36px solid #066aab;position:absolute;top:0;left:50%;transform:translateX(-50%)}
.concerns-lower{background:#f5f7fa;padding:56px 0;text-align:center}
.concerns-lower-sub{font-size:17px;color:#888;margin-bottom:12px}
.concerns-lower-main{font-size:28px;font-weight:900;color:#333;line-height:1.6;margin-bottom:8px}
.concerns-lower-main .em-blue{color:#066aab}
.concerns-lower-main .sparkle::after{display:none}
.concerns-lower-img{max-width:520px;margin:24px auto 0;border-radius:10px;overflow:hidden}
@media(max-width:999px){.concerns-cols{flex-direction:column;gap:24px;padding:0 20px}.speech-bubble{font-size:15px;padding:14px 16px;min-width:auto}.concerns-transition strong{font-size:22px}.concerns-lower-main{font-size:22px}}

/* WM concerns */
.wm-concerns{padding:0;background:none}
.wm-concerns-banner{background:linear-gradient(135deg,#054a73 0%,#066aab 40%,#054a73 100%);padding:64px 48px}
.wm-concerns-center{text-align:center;max-width:800px;margin:0 auto}
.wm-concerns-lead{font-size:22px;color:rgba(255,255,255,.9);font-weight:500;margin-bottom:16px}
.wm-concerns-main{font-size:24px;color:#fff;font-weight:700;line-height:1.8;margin-bottom:28px}
.wm-em{color:#ffe066;font-size:34px;font-weight:900}
.wm-concerns-bubble{display:inline-block;background:#fff;border-radius:10px;padding:18px 32px;position:relative;box-shadow:0 4px 16px rgba(0,0,0,.1)}
.wm-concerns-bubble::after{content:'';position:absolute;top:-10px;left:50%;transform:translateX(-50%);border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:12px solid #fff}
.wm-concerns-bubble p{font-size:15px;font-weight:600;color:#555;line-height:1.7;text-align:center}

/* Zigzag / Compare / Process */
.block-c-wrapper{background:#fff;border-radius:10px;padding:36px;margin-bottom:40px;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.zigzag-block{display:flex;gap:36px;align-items:center}
.zigzag-img{flex:0 0 380px;border-radius:10px;overflow:hidden}
.zigzag-img-placeholder{width:100%;aspect-ratio:4/3;background-size:cover;background-position:center}
.zigzag-text .tag{display:inline-block;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:600;color:#fff;background:#066aab;padding:4px 14px;border-radius:10px;margin-bottom:12px;letter-spacing:.08em;text-transform:uppercase}
.zigzag-text h3{font-size:24px;font-weight:700;margin-bottom:14px;color:#333;line-height:1.55}
.zigzag-text p{font-size:15px;line-height:2;color:#666}
.compact-blocks{display:flex;gap:20px;margin-top:32px}
.compact-block{flex:1;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.compact-block-img .zigzag-img-placeholder{width:100%;aspect-ratio:16/9;background-size:cover;background-position:center;opacity:.75}
.compact-block-body{padding:18px 20px}
.compact-tag{display:inline-block;font-size:10px;font-weight:600;color:#fff;padding:2px 10px;border-radius:10px;margin-bottom:8px;text-transform:uppercase}
.compact-tag.problem{background:#999}
.compact-tag.risk{background:#d63637}
.compact-block h4{font-size:17px;font-weight:600;margin-bottom:6px;color:#333}
.compact-block p{font-size:14px;line-height:1.85;color:#666}
.compare-table-wrap{overflow-x:auto;margin-top:40px;border-radius:12px;box-shadow:0 6px 32px rgba(0,0,0,.08)}
.compare-table{width:100%;border-collapse:separate;border-spacing:0;min-width:960px}
.compare-table th,.compare-table td{padding:18px 20px;text-align:center;font-size:13px;line-height:1.7;border-bottom:1px solid #eaedf0}
.compare-table thead th{background:#f0f2f5;color:#555;font-weight:700;font-size:15px;padding:20px 16px;border-bottom:2px solid #dde0e4;letter-spacing:.04em}
.compare-table thead th:first-child{background:#e8eaed;color:#999;border-radius:12px 0 0 0}
.compare-table thead th:last-child{border-radius:0 12px 0 0}
.compare-table thead th.col-recommend{background:linear-gradient(135deg,#066aab,#0880c9);color:#fff;font-size:16px;position:relative;box-shadow:0 4px 16px rgba(6,106,171,.25)}
.compare-table thead th .th-sub{display:block;font-size:11px;opacity:.65;margin-top:3px;font-weight:400}
.compare-table thead th .recommend-label{display:inline-block;background:#fff;color:#066aab;font-size:10px;font-weight:800;padding:3px 12px;border-radius:20px;margin-top:6px;letter-spacing:.08em;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.compare-table tbody th{background:#f8f9fa;color:#444;font-weight:700;font-size:13px;text-align:left;padding:16px 20px;width:130px;letter-spacing:.03em}
.compare-table tbody td{background:#fff;color:#888;font-size:13px;white-space:nowrap}
.compare-table tbody td.col-recommend{background:#f6fbff;font-weight:700;color:#066aab;border-left:3px solid #066aab;border-right:3px solid #066aab;font-size:14px}
.compare-table tbody tr:first-child td.col-recommend{border-top:3px solid #066aab}
.compare-table tbody tr:last-child td.col-recommend{border-bottom:3px solid #066aab}
.compare-table tbody tr:last-child th{border-radius:0 0 0 12px}
.compare-table tbody tr:last-child td:last-child{border-radius:0 0 12px 0}
.compare-table tbody tr:hover td{background:#f9fafb}
.compare-table tbody tr:hover td.col-recommend{background:#eef6fc}
.compare-table .val-circle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:16px;font-weight:900;margin-bottom:6px}
.compare-table .circle-x{background:#f0f0f0;color:#ccc}
.compare-table .circle-tri{background:#fef2f2;color:#d63637}
.compare-table .circle-good{background:#e8f4f8;color:#066aab}
.compare-table td.col-recommend .circle-good{background:#066aab;color:#fff;box-shadow:0 2px 8px rgba(6,106,171,.3)}
@media(max-width:768px){
  .compare-table-wrap{overflow-x:hidden;border-radius:8px}
  .compare-table{min-width:0;table-layout:fixed;width:100%}
  .compare-table thead th{padding:8px 2px;font-size:10px;line-height:1.3;word-break:break-all}
  .compare-table thead th.col-recommend{font-size:10px}
  .compare-table thead th .th-sub{font-size:8px;margin-top:1px}
  .compare-table thead th .recommend-label{font-size:7px;padding:2px 6px;margin-top:3px}
  .compare-table tbody th{padding:8px 4px;font-size:10px;width:auto;text-align:center;word-break:break-all}
  .compare-table tbody td{padding:8px 3px;font-size:9px;line-height:1.4;white-space:normal;word-break:break-all}
  .compare-table tbody td.col-recommend{font-size:10px;border-left:2px solid #066aab;border-right:2px solid #066aab}
  .compare-table .val-circle{width:24px;height:24px;font-size:11px;margin-bottom:2px}
}
@media(max-width:999px){.zigzag-block{flex-direction:column;gap:24px}.zigzag-img{flex:none;width:100%}.block-c-wrapper{padding:24px 18px}.compact-blocks{flex-direction:column}}

/* Process grid */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.process-step{text-align:center}
.process-step-img{aspect-ratio:1;border-radius:10px;overflow:hidden;margin-bottom:12px;background-size:cover;background-position:center;background-color:#f0f0f0}
.step-num{display:inline-block;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:600;color:#fff;background:#066aab;padding:2px 12px;border-radius:10px;margin-bottom:4px}
.step-caption{font-size:14px;color:#666;font-weight:500}
@media(max-width:999px){.process-grid{grid-template-columns:repeat(2,1fr)}}

/* Flow steps (old) */
.flow-steps{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;position:relative}
.flow-progress-line{position:absolute;top:36px;left:40px;right:40px;height:2px;background:#e0e0e0}
.flow-progress-fill{height:100%;background:linear-gradient(90deg,#333,#066aab);transform-origin:left;transform:scaleX(0)}
.flow-step{text-align:center;position:relative}
.flow-step-icon{width:72px;height:72px;border-radius:50%;background:#fff;border:1.5px solid #ddd;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;position:relative;z-index:2;transition:.3s}
.flow-step-icon svg{width:24px;height:24px;fill:none;stroke:#066aab;stroke-width:1.6}
.flow-step.reached .flow-step-icon{background:#066aab;border-color:#066aab}
.flow-step.reached .flow-step-icon svg{stroke:#fff}
.flow-step h4{font-size:14px;font-weight:600;margin-bottom:5px;color:#333;line-height:1.5}
.flow-step p{font-size:13px;color:#888;line-height:1.65}
@media(max-width:999px){.flow-steps{grid-template-columns:1fr;gap:0;padding-left:44px}.flow-progress-line{top:0;bottom:0;left:18px;right:auto;width:2px;height:auto}.flow-progress-fill{transform-origin:top;transform:scaleY(0);width:100%}.flow-step{text-align:left;padding:16px 0 16px 20px}.flow-step-icon{position:absolute;left:-52px;top:16px;width:40px;height:40px;margin:0}.flow-step-icon svg{width:18px;height:18px}}

/* Cases */
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.case-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:.3s}
.case-card:hover{transform:translateY(-3px)}
.case-thumb{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:#f0f0f0}
.case-body{padding:16px 18px}
.case-tags{display:flex;gap:5px;margin-bottom:8px}
.case-tag{font-size:11px;font-weight:600;padding:2px 10px;border-radius:10px;background:#e8f4f8;color:#066aab}
.case-body h3{font-size:15px;font-weight:600;margin-bottom:5px;color:#333;line-height:1.5}
.case-body p{font-size:14px;color:#888;line-height:1.7}
a.case-card{display:block;text-decoration:none;color:inherit}
.cases-more{text-align:center;margin-top:32px}
.cases-more a{font-size:14px;color:#888;font-weight:500;display:inline-flex;align-items:center;gap:4px;border:2px solid #ddd;padding:8px 22px;border-radius:10px;transition:.3s}
.cases-more a:hover{color:#066aab;border-color:#066aab;opacity:1}
@media(max-width:999px){.cases-grid{grid-template-columns:1fr}}

/* Area checklist */
.area-checklist{padding:56px 0;background:#2c3e50;color:#fff}
.area-checklist h2{text-align:center;font-size:22px;font-weight:700}
.checklist-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:640px;margin:36px auto 0}
@media(max-width:999px){.checklist-grid{grid-template-columns:1fr}}
.checklist-item{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:16px 20px;font-size:14px;line-height:1.6}

/* Final CTA */
.final-cta{position:relative;padding:72px 0;overflow:hidden}
.final-cta-bg{position:absolute;inset:0}
.final-cta-overlay{position:absolute;inset:0;background:#066aab}
.final-cta-content{position:relative;z-index:2;text-align:center;color:#fff}
.final-cta-content h2{font-size:32px;font-weight:900;margin-bottom:12px;color:#fff}
.final-cta-content .sub-text{font-size:15px;color:rgba(255,255,255,.8);margin-bottom:32px;line-height:1.9}
.final-cta-buttons{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.final-cta-buttons a{display:inline-flex;align-items:center;gap:7px;padding:14px 32px;border-radius:10px;font-size:16px;font-weight:600;transition:.3s}
.final-cta-buttons a svg{width:17px;height:17px}
.final-cta-buttons .cta-line{background:#fff;color:#066aab}
.final-cta-buttons .cta-line:hover{background:#f0f0f0;opacity:1}
.final-cta-buttons .cta-dark{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.4)}
.final-cta-buttons .cta-dark:hover{background:rgba(255,255,255,.25);opacity:1}
.final-note{margin-top:22px;font-size:13px;color:rgba(255,255,255,.5)}
@media(max-width:999px){.final-cta{padding:48px 0}.final-cta-content h2{font-size:24px}.final-cta-buttons{flex-direction:column;align-items:center}.final-cta-buttons a{width:100%;max-width:280px;justify-content:center}}

/* Night card */
.night-sec{padding:56px 0}
.night-card{max-width:520px;margin:0 auto;background:#fff;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.06);text-align:center;overflow:hidden}
.night-card-visual{background:#1a2a3a;padding:40px 24px}
.night-icon{width:80px;height:80px;margin:0 auto;border-radius:50%;background:rgba(255,255,255,.08);border:2px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center}
.night-icon svg{width:40px;height:40px;stroke:#ffe066;fill:none;stroke-width:1.5}
.night-card-body{padding:28px 32px}
.night-card-body h3{font-size:19px;font-weight:700;color:#333;margin-bottom:12px}
.night-card-body p{font-size:14px;color:#666;line-height:1.9}

/* Notes */
.notes-sec{background:#f5f7fa;padding:48px 0}
.notes-sec .sec-hd h2{font-size:20px}
.notes-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.notes-list li{font-size:13px;color:#888;line-height:1.8;padding-left:1.2em;text-indent:-1.2em}
.notes-list li::before{content:'※';color:#bbb;margin-right:.2em}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:.3s}
.blog-card:hover{transform:translateY(-2px)}
.blog-card-img{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:#f0f5f7}
.blog-card-body{padding:18px 20px}
.blog-card-date{font-size:12px;color:#aaa;margin-bottom:6px}
.blog-card-tags{display:flex;gap:5px;margin-bottom:8px;flex-wrap:wrap}
.blog-card-tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;background:#e8f4f8;color:#066aab}
.blog-card-body h3{font-size:15px;font-weight:600;color:#333;line-height:1.55;margin-bottom:6px}
.blog-card-body h3 a:hover{color:#066aab;opacity:1}
.blog-card-excerpt{font-size:13px;color:#888;line-height:1.7}
@media(max-width:999px){.blog-grid{grid-template-columns:1fr}}

/* Article */
.article-content{max-width:760px;margin:0 auto}
.article-header{margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid #eee}
.article-content h2{font-size:22px;font-weight:700;color:#333;margin:40px 0 16px;padding-bottom:12px;border-bottom:2px solid #066aab}
.article-content h3{font-size:18px;font-weight:600;color:#333;margin:32px 0 12px;padding-left:14px;border-left:3px solid #066aab}
.article-content p{font-size:15px;color:#666;line-height:2;margin-bottom:20px}
.article-content img{border-radius:10px;margin:24px 0}
.article-content blockquote{margin:24px 0;padding:20px 24px;background:#f5f7fa;border-left:4px solid #066aab;border-radius:0 10px 10px 0;font-size:15px;color:#666;line-height:1.9}

/* About page */
.about-full-profile{display:flex;gap:48px;align-items:flex-start;margin-bottom:48px}
.about-full-photo{flex:0 0 280px}
.about-full-photo img{width:100%;border-radius:10px}
.about-full-text{flex:1}
.about-full-text h2{font-size:26px;font-weight:700;margin-bottom:20px;color:#333}
.about-full-text p{font-size:15px;color:#666;line-height:2;margin-bottom:16px}
.company-info{background:#fff;border-radius:10px;padding:32px;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.company-info h2{font-size:22px;font-weight:700;margin-bottom:24px;color:#333;text-align:center}
.company-info-table{width:100%}
.company-info-table tr{border-bottom:1px solid #eee}
.company-info-table tr:last-child{border-bottom:none}
.company-info-table th{font-size:14px;font-weight:600;color:#555;padding:16px 20px;text-align:left;width:160px;vertical-align:top}
.company-info-table td{font-size:14px;color:#666;padding:16px 20px;line-height:1.8}
@media(max-width:999px){.about-full-profile{flex-direction:column;gap:24px}.about-full-photo{flex:none;text-align:center}.about-full-photo img{max-width:240px}.company-info-table th{display:block;padding:12px 0 4px;width:auto}.company-info-table td{display:block;padding:4px 0 12px}}

/* Service cards compat */
.service-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:32px}
.service-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:.3s}
.service-card:hover{transform:translateY(-3px)}
.service-card-img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative}
.service-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(0,0,0,.3))}
.service-card-body{padding:24px}
.service-card-body h3{font-size:20px;font-weight:700;margin-bottom:8px;color:#333}
.service-card-body p{font-size:14px;color:#888;line-height:1.8;margin-bottom:16px}
.service-card-price{font-size:22px;font-weight:900;color:#d63637;margin-bottom:16px}
.service-card-price .yen{font-size:14px}
.service-card-price .tax{font-size:11px;color:#999;font-weight:400}
.service-card-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#066aab}
.service-card-link:hover{color:#055a8f;opacity:1}
.service-card-link svg{width:14px;height:14px}
@media(max-width:999px){.service-cards{grid-template-columns:1fr}}

/* Filter/BA compat */
.filter-tabs{display:flex;justify-content:center;gap:6px;margin-bottom:32px}
.filter-tab{padding:7px 20px;border-radius:10px;font-size:13px;font-weight:500;color:#888;background:#fff;border:1px solid #ddd;cursor:pointer;transition:.3s}
.filter-tab.active{background:#066aab;color:#fff;border-color:#066aab}
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:800px;margin:0 auto}
.ba-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:.3s}
.ba-card:hover{transform:translateY(-2px)}
.ba-images{display:grid;grid-template-columns:1fr 1fr;position:relative}
.ba-images::after{content:'→';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;background:#066aab;border-radius:50%;color:#fff;font-size:12px;line-height:28px;text-align:center;z-index:2}
.ba-img{aspect-ratio:1/1;position:relative;display:flex;background-size:cover;background-position:center;font-size:0;color:transparent}
.ba-img::after{content:attr(data-label);position:absolute;top:8px;left:8px;padding:3px 10px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.06em}
.ba-img.before::after{background:#555;color:#fff}
.ba-img.after::after{background:#066aab;color:#fff}
.ba-caption{padding:12px 16px;font-size:14px;color:#888;font-weight:500;border-top:1px solid #eee}
.ba-story{padding:0 16px 16px;display:flex;flex-direction:column;gap:10px}
.ba-story-item{padding:14px 16px;border-radius:10px;font-size:15px;line-height:1.95;color:#666}
.ba-story-item.concern{background:#faf7f4;border-left:3px solid #c9a68a}
.ba-story-item.result{background:#f0f6fa;border-left:3px solid #066aab}
.ba-story-badge{display:inline-block;font-size:12px;font-weight:700;padding:2px 10px;border-radius:10px;margin-bottom:8px}
.concern-badge{background:#c9a68a;color:#fff}
.result-badge{background:#066aab;color:#fff}
@media(max-width:999px){.ba-grid{grid-template-columns:1fr}}

/* Reasons grid compat */
.reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.reason-card{background:#fff;border-radius:10px;padding:28px 24px 24px;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:.3s}
.reason-card:hover{transform:translateY(-3px)}
.reason-num{font-weight:700;font-size:48px;color:rgba(0,0,0,.04);position:absolute;top:-4px;right:12px;line-height:1}
.reason-label{display:inline-block;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:600;color:#066aab;background:#e8f4f8;padding:3px 10px;border-radius:10px;margin-bottom:12px;letter-spacing:.06em;text-transform:uppercase}
.reason-icon{width:48px;height:48px;border-radius:50%;border:1.5px solid #ddd;background:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.reason-icon svg{width:20px;height:20px;fill:none;stroke:#066aab;stroke-width:1.6}
.reason-img{width:100%;height:140px;border-radius:10px;overflow:hidden;margin-bottom:14px}
.reason-img img{width:100%;height:100%;object-fit:cover;display:block}
.reason-img-bright img{filter:brightness(1.1)}
.reason-card h3{font-size:18px;font-weight:700;margin-bottom:8px;color:#333}
.reason-card p{font-size:14px;line-height:1.9;color:#666}
@media(max-width:999px){.reasons-grid{grid-template-columns:1fr}}

/* Old footer compat */
.site-footer{background:#1a1a1a;color:rgba(255,255,255,.8);text-align:center;padding:48px 20px 32px}
.ft-logo{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:900;letter-spacing:.06em;margin-bottom:14px;color:#fff}
.ft-desc{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:16px}
.ft-tel{display:flex;align-items:center;justify-content:center;gap:6px;font-size:16px;color:rgba(255,255,255,.8);margin-bottom:16px;font-weight:500}
.ft-tel svg{width:16px;height:16px;fill:rgba(255,255,255,.8)}
.ft-links{display:flex;justify-content:center;gap:16px;margin-bottom:14px;font-size:12px;flex-wrap:wrap}
.ft-links a{color:rgba(255,255,255,.5);transition:.3s}
.ft-links a:hover{color:#fff;opacity:1}
.ft-area{font-size:11px;color:rgba(255,255,255,.3);margin-bottom:14px;display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.ft-area a{color:rgba(255,255,255,.4);transition:.3s}
.ft-area a:hover{color:#fff}
.ft-sns{display:flex;justify-content:center;gap:14px;margin-bottom:16px}
.ft-sns a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);transition:.3s}
.ft-sns a:hover{background:rgba(255,255,255,.2);opacity:1}
.ft-sns a svg{width:16px;height:16px;fill:rgba(255,255,255,.7)}
.ft-copy{font-size:10px;color:rgba(255,255,255,.3)}

/* Old fixed CTA compat */
.fixed-cta{position:fixed;bottom:0;left:0;width:100%;z-index:900;display:flex;justify-content:center;gap:0;transform:translateY(100%);transition:.4s}
.fixed-cta.show{transform:translateY(0)}
.fixed-cta a{flex:1;max-width:300px;display:flex;align-items:center;justify-content:center;gap:7px;padding:14px;font-size:14px;font-weight:600;transition:.3s}
.fixed-cta a svg{width:15px;height:15px}
.fixed-cta .cta-line{background:#06c755;color:#fff}
.fixed-cta .cta-line:hover{background:#05b04c;opacity:1}
.fixed-cta .cta-dark{background:#066aab;color:#fff}
.fixed-cta .cta-dark:hover{background:#055a8f;opacity:1}
@media(max-width:999px){.fixed-cta a{max-width:none;padding:12px 8px;font-size:13px}}
.scroll-top{position:fixed;bottom:68px;right:20px;width:40px;height:40px;background:#066aab;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:899;opacity:0;pointer-events:none;transition:.3s;cursor:pointer;border:none}
.scroll-top.show{opacity:1;pointer-events:all}
.scroll-top:hover{background:#055a8f}
.scroll-top svg{width:16px;height:16px;fill:#fff}

/* .br helpers */
.br-sp{display:none}
@media(max-width:999px){.br-sp{display:inline}}
.br-pc{display:inline}
@media(max-width:999px){.br-pc{display:none}}
/* kill old .fade-in so anim-fade takes over */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.fade-in.v{opacity:1;transform:none}
.caution-text{color:#d63637;font-weight:500}

/* ============================================================
   SUB PAGE — pikapika clone v3
   ============================================================ */

/* ===== Sub MV ===== */
.sub-mv{position:relative;height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:130px;background:#066aab}
.sub-mv-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:kenBurns 20s ease forwards}
.sub-mv-overlay{position:absolute;inset:0;background:rgba(0,0,0,.35)}
.sub-mv.sub-mv--plain .sub-mv-bg,.sub-mv.sub-mv--plain .sub-mv-overlay{display:none}
.sub-mv.sub-mv--plain{background:linear-gradient(135deg,#066aab 0%,#044f80 100%)}
.sub-mv-content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 20px}
.sub-mv-en{font-family:'Montserrat',sans-serif;font-size:56px;font-weight:900;letter-spacing:.15em;line-height:1;margin-bottom:16px;text-transform:uppercase;opacity:0;transform:translateY(20px);animation:heroTextIn .8s .3s cubic-bezier(.23,1,.32,1) forwards}
.sub-mv-ttl{font-size:15px;font-weight:400;letter-spacing:.2em;opacity:0;transform:translateY(12px);animation:heroTextIn .8s .55s cubic-bezier(.23,1,.32,1) forwards}
.sub-mv-line{width:40px;height:1px;background:rgba(255,255,255,.5);margin:20px auto 0;opacity:0;animation:heroTextIn .8s .7s cubic-bezier(.23,1,.32,1) forwards}
@media(max-width:999px){.sub-mv{height:300px;margin-top:60px}.sub-mv-en{font-size:32px;letter-spacing:.08em}.sub-mv-ttl{font-size:13px}}

/* ===== Sub breadcrumb ===== */
.sub-breadcrumb{padding:14px 0;border-bottom:1px solid #eee}
.sub-breadcrumb ol{display:flex;align-items:center;gap:0;font-size:13px;color:#999;list-style:none}
.sub-breadcrumb a{color:#066aab}
.sub-breadcrumb li+li::before{content:'>';color:#ddd;margin:0 10px;font-size:11px}

/* ===== Section title — pikapika SVG-like ===== */
.sec-ttl-en{display:block;font-family:'Montserrat',sans-serif;font-size:36px;font-weight:900;letter-spacing:.08em;color:#066aab;line-height:1.1;margin-bottom:8px;text-transform:uppercase}
.sec-ttl-ja{font-size:14px;font-weight:500;color:#666;letter-spacing:.1em;margin-top:0}
.sec-ttl-line{display:none}
.sub-cta-section .sec-ttl-en{color:rgba(255,255,255,.2)}
.sub-cta-section .sec-ttl-ja{color:rgba(255,255,255,.7)}
@media(max-width:999px){.sec-ttl-en{font-size:26px}}
/* Animation */
.sec-ttl.anim-fade .sec-ttl-en{opacity:0;transform:translateY(16px);transition:opacity .6s .1s cubic-bezier(.23,1,.32,1),transform .6s .1s cubic-bezier(.23,1,.32,1)}
.sec-ttl.anim-fade.is-visible .sec-ttl-en{opacity:1;transform:none}

/* ===== Sub page lead ===== */
.sub-lead{text-align:center;max-width:560px;margin:0 auto;padding:80px 20px 0}
.sub-lead p{font-size:15px;color:rgba(0,0,0,.6);line-height:2.2}
.sub-lead-line{display:none}

/* ===== Sections — white base like pikapika ===== */
.sub-mv~.sec{padding:100px 0;background:#fff}
.sub-mv~.sec-gray,.sub-mv~.sec.sec-gray{background:#fff}
@media(max-width:999px){.sub-mv~.sec{padding:64px 0}}

/* ===== Price card — pikapika clean ===== */
.price-card{background:#fff;overflow:hidden;margin-bottom:32px;border-radius:3px;border:1px solid #eee;transition:box-shadow .3s}
.price-card:hover{box-shadow:0 8px 30px rgba(0,0,0,.07)}
.price-card-header{background:#066aab;color:#fff;font-size:11px;font-weight:600;padding:14px 24px;letter-spacing:.12em;text-transform:uppercase;font-family:'Montserrat','Noto Sans JP',sans-serif;display:flex;align-items:baseline;gap:12px}
.price-card-name{font-size:17px;font-weight:700;letter-spacing:.02em;font-family:'Noto Sans JP',sans-serif;text-transform:none}
.price-card-body{padding:0}
.price-card-main{display:flex;align-items:stretch}
.price-card-main.reverse{flex-direction:row-reverse}
.price-card-img{flex:0 0 40%;overflow:hidden}
.price-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.price-card:hover .price-card-img img{transform:scale(1.03)}
.price-card-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;padding:24px}
.price-card-table{width:100%;border-collapse:collapse}
.price-card-table th{font-size:13px;font-weight:600;color:rgba(0,0,0,.85);padding:12px 0;text-align:left;width:72px;vertical-align:top;border-bottom:1px solid #f0f0f0}
.price-card-table td{font-size:15px;color:rgba(0,0,0,.7);padding:12px 0 12px 8px;line-height:1.6;border-bottom:1px solid #f0f0f0}
.price-card-original{font-size:20px;font-family:'Montserrat',sans-serif;font-weight:700;color:#999;text-decoration:line-through;margin-right:10px}
.price-card-off{font-size:13px;font-weight:700;color:#fff;background:#d63637;padding:3px 10px;border-radius:2px;display:inline-block;vertical-align:middle}
.price-card-amount{font-size:32px;font-weight:900;color:rgba(0,0,0,.85);display:block;margin-top:4px;font-family:'Montserrat',sans-serif}
.price-card-amount .yen{font-size:16px}
.price-card-amount .tax{font-size:11px;color:#999;font-weight:400;margin-left:2px;font-family:'Noto Sans JP',sans-serif}
.price-card-cta{margin-top:16px}
.price-card-cta a{display:inline-block;background:#066aab;color:#fff;font-size:13px;font-weight:600;padding:10px 28px;border-radius:3px;transition:.3s}
.price-card-cta a:hover{background:#055a8f;opacity:1}
@media(max-width:999px){.price-card-main,.price-card-main.reverse{flex-direction:column}.price-card-img{flex:none;height:200px}.price-card-amount{font-size:26px}.price-card-info{padding:20px}.price-card-header{padding:12px 20px}}

/* ===== Discount banner ===== */
.discount-banner{background:#066aab;border-radius:3px;padding:20px 24px;text-align:center;color:#fff;margin-bottom:32px}
.discount-banner-ttl{font-size:15px;font-weight:700;margin-bottom:4px}
.discount-banner-ttl span{color:#ffe066;font-size:17px}
.discount-banner-detail{font-size:13px;color:rgba(255,255,255,.75)}
.discount-banner-detail strong{color:#ffe066}

/* ===== Sub page overrides — pikapika consistency ===== */
.sub-mv~*>.l-inner .process-step-img{border-radius:3px}
.sub-mv~*>.l-inner .step-num{border-radius:3px}
.sub-mv~*>.l-inner .faq-item{border-radius:3px;box-shadow:0 1px 8px rgba(0,0,0,.04)}
.sub-mv~*>.l-inner .ba-card{border-radius:3px;box-shadow:0 1px 8px rgba(0,0,0,.04)}
.sub-mv~*>.l-inner .ba-story-item{border-radius:3px}
.sub-mv~*>.l-inner .accordion{border-radius:3px}

/* ===== Sub page CTA ===== */
.sub-cta-section{padding:100px 0;background:#066aab;text-align:center;color:#fff}
.sub-cta-section .sec-ttl-ja{color:#fff;font-size:24px;font-weight:700}
.sub-cta-section .sub-cta-text{font-size:14px;color:rgba(255,255,255,.65);margin-bottom:36px;line-height:2}
.sub-cta-buttons{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.sub-cta-buttons a{display:inline-flex;align-items:center;gap:8px;padding:15px 36px;border-radius:3px;font-size:14px;font-weight:600;transition:.3s}
.sub-cta-buttons a svg{width:18px;height:18px}
.sub-cta-buttons .btn-cta-line{background:#fff;color:#066aab}
.sub-cta-buttons .btn-cta-line:hover{background:rgba(255,255,255,.85);opacity:1}
.sub-cta-buttons .btn-cta-tel{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.sub-cta-buttons .btn-cta-tel:hover{background:rgba(255,255,255,.1);opacity:1}
.sub-cta-buttons .btn-cta-form{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.sub-cta-buttons .btn-cta-form:hover{background:rgba(255,255,255,.1);opacity:1}
.sub-cta-area{font-size:12px;color:rgba(255,255,255,.35);margin-top:24px}
@media(max-width:999px){.sub-cta-section{padding:64px 0}.sub-cta-section .sec-ttl-ja{font-size:20px}.sub-cta-buttons{flex-direction:column;align-items:center}.sub-cta-buttons a{width:80%;max-width:280px;justify-content:center}}

/* ===== Campaign Banner — D-LAB style ===== */
.campaign-banner{max-width:1080px;margin:0 auto;border-radius:3px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.08)}
/* Header */
.campaign-header{background:linear-gradient(135deg,#e8f4fc 0%,#d0ebf7 100%);padding:48px 40px 32px;text-align:center;position:relative}
.campaign-header::before,.campaign-header::after{content:'✦';position:absolute;top:16px;color:#066aab;font-size:28px;opacity:.2}
.campaign-header::before{left:20px}
.campaign-header::after{right:20px}
.campaign-headline{font-size:26px;color:#333;font-weight:900;margin-bottom:10px;line-height:1.4}
.campaign-headline-price{font-size:76px;font-weight:900;color:#d63637;font-family:'Montserrat',sans-serif;text-shadow:0 3px 12px rgba(214,54,55,.2);letter-spacing:-.02em}
.campaign-headline-yen{font-size:42px;font-weight:900;color:#d63637}
.campaign-headline-sub{font-size:20px;color:#444;font-weight:700;margin-top:6px}
.campaign-headline-accent{color:#066aab;font-weight:900;font-size:20px}
/* Body */
.campaign-body{display:flex;flex-direction:column;background:#fff}
.campaign-left{padding:40px 48px;text-align:center}
.campaign-right{padding:32px 48px;background:#f9f9f9;display:flex;flex-direction:column;align-items:center}
/* Price compare */
.campaign-price-compare{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px;justify-content:center}
.campaign-price-badge{display:inline-block;background:#066aab;color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:3px}
.campaign-price-badge--red{background:#d63637}
.campaign-price-original{font-size:15px;color:#666;text-decoration:line-through}
.campaign-price-arrow{font-size:16px;color:#888}
.campaign-price-limited{font-size:20px;font-weight:900;color:#d63637;font-family:'Montserrat',sans-serif}
/* Big price */
.campaign-big-price{font-size:20px;font-weight:900;color:#333;margin-bottom:20px;padding:8px 0;border-bottom:3px solid #066aab;display:inline-block;white-space:nowrap}
.campaign-big-sparkle{color:#066aab;margin-right:4px}
.campaign-big-amount{font-size:64px;font-family:'Montserrat',sans-serif;color:#d63637;line-height:1;text-shadow:0 2px 8px rgba(214,54,55,.12)}
.campaign-big-yen{font-size:34px;color:#d63637;vertical-align:middle}
/* Checklist */
.campaign-checklist-wrap{background:#f7fafb;border-radius:3px;padding:20px 28px;margin:0 auto 20px;border:1px solid #e8f0f4;display:inline-block;text-align:left}
.campaign-checklist-header{display:inline-block;background:#066aab;color:#fff;font-size:13px;font-weight:700;padding:4px 12px;border-radius:3px;margin-bottom:12px}
.campaign-checklist-sparkle{color:#066aab}
.campaign-checklist{list-style:none;display:flex;flex-direction:column;gap:8px}
.campaign-checklist li{font-size:16px;color:#333;font-weight:500}
.campaign-check{display:inline-block;width:22px;height:22px;background:#066aab;color:#fff;font-size:13px;font-weight:900;text-align:center;line-height:22px;border-radius:3px;margin-right:8px}
.campaign-sparkle{font-size:14px}
/* Quick */
.campaign-quick{font-size:15px;color:#333;font-weight:700;margin-bottom:16px;text-align:center}
.campaign-quick-sparkle{color:#066aab}
/* CTA */
.campaign-cta{text-align:center}
.campaign-cta a{display:inline-block;padding:18px 48px;background:#06c755;color:#fff;font-size:18px;font-weight:900;border-radius:3px;transition:background .3s,transform .3s;box-shadow:0 4px 12px rgba(6,199,85,.2)}
.campaign-cta a:hover{background:#05a648;transform:translateY(-2px);opacity:1}
/* Right — BA photos */
.campaign-ba{display:flex;flex-direction:column;gap:16px;width:100%;max-width:720px}
/* BA Slider */
.ba-slider{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);cursor:ew-resize;-webkit-user-select:none;user-select:none}
.ba-slider img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba-slider .ba-after{clip-path:inset(0 0 0 50%)}
.ba-slider-handle{position:absolute;top:0;bottom:0;left:50%;width:4px;background:#fff;z-index:3;transform:translateX(-50%);box-shadow:0 0 8px rgba(0,0,0,.3);pointer-events:none}
.ba-slider-handle::before{content:"◀ ▶";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:#066aab;font-weight:900;box-shadow:0 2px 10px rgba(0,0,0,.25);letter-spacing:2px}
.ba-slider .ba-label{position:absolute;bottom:12px;font-size:13px;font-weight:800;color:#fff;background:rgba(0,0,0,.5);padding:4px 12px;border-radius:4px;z-index:2;pointer-events:none}
.ba-slider .ba-label-before{left:12px}
.ba-slider .ba-label-after{right:12px}
/* Legacy pair fallback */
.campaign-ba-pair{display:flex;align-items:center;gap:0;position:relative}
.campaign-ba-pair--vertical{flex-direction:column}
.campaign-ba-img{flex:1;min-width:0;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:6px;border:5px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,.22)}
.campaign-ba-arrow{z-index:2;flex-shrink:0;background:linear-gradient(135deg,#f5a623,#e8950a);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-size:22px;font-weight:900;box-shadow:0 3px 10px rgba(245,166,35,.4);margin:0 -12px;position:relative}
.campaign-ba-pair--vertical .campaign-ba-arrow{margin:-12px 0}
.campaign-ba-caption{font-size:18px;font-weight:900;color:#d63637;text-align:center;margin:4px auto;padding:6px 16px;background:#fff;border-radius:4px;display:inline-block;align-self:center;box-shadow:0 2px 8px rgba(0,0,0,.08);border:2px solid #d63637}
.campaign-ba-label{font-size:12px;font-weight:700;color:#066aab;text-align:center;letter-spacing:.1em}
/* Dual BA — 2x2 grid: before/after side by side, 2 rows */
.campaign-ba--dual{display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto auto;gap:4px 6px;align-items:center;width:100%;align-content:start}
.campaign-ba--dual .campaign-ba-col{display:contents}
.campaign-ba--dual .campaign-ba-col:nth-child(1) .campaign-ba-img:first-child{grid-column:1;grid-row:1}
.campaign-ba--dual .campaign-ba-col:nth-child(1) .campaign-ba-arrow{grid-column:2;grid-row:1}
.campaign-ba--dual .campaign-ba-col:nth-child(1) .campaign-ba-img:last-child{grid-column:3;grid-row:1}
.campaign-ba--dual .campaign-ba-col:nth-child(2) .campaign-ba-img:first-child{grid-column:1;grid-row:2}
.campaign-ba--dual .campaign-ba-col:nth-child(2) .campaign-ba-arrow{grid-column:2;grid-row:2}
.campaign-ba--dual .campaign-ba-col:nth-child(2) .campaign-ba-img:last-child{grid-column:3;grid-row:2}
.campaign-ba--dual .campaign-ba-img{width:100%;aspect-ratio:4/3;margin:0}
.campaign-ba--dual .campaign-ba-arrow{margin:0;width:36px;height:36px;font-size:16px}
.campaign-ba-placeholder{width:48%;aspect-ratio:4/3;background:linear-gradient(135deg,#e8f0f4,#d0dfe8);border-radius:8px;border:4px solid #fff;box-shadow:0 3px 12px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;color:#999;font-size:13px;font-weight:600}
@media(max-width:768px){
  .campaign-banner{margin:0 12px;border-radius:8px}
  .campaign-header{padding:28px 16px 20px}
  .campaign-headline{font-size:18px}
  .campaign-headline-price{font-size:48px}
  .campaign-headline-yen{font-size:28px}
  .campaign-headline-sub{font-size:15px}
  .campaign-headline-accent{font-size:15px}
  .campaign-left{padding:20px 16px}
  .campaign-right{padding:16px 12px}
  .campaign-price-compare{gap:6px}
  .campaign-price-limited{font-size:16px}
  .campaign-big-price{font-size:16px;white-space:normal;text-align:center}
  .campaign-big-amount{font-size:36px}
  .campaign-big-yen{font-size:24px}
  .campaign-checklist-wrap{padding:16px 16px;width:100%;box-sizing:border-box}
  .campaign-checklist li{font-size:14px}
  .campaign-cta a{padding:14px 24px;font-size:15px;width:100%;box-sizing:border-box}
  .campaign-ba{max-width:100%}
  .campaign-ba-pair{flex-direction:column}
  .campaign-ba-arrow{margin:-12px 0}
  .campaign-ba-img{width:100%;aspect-ratio:4/3}
  .campaign-ba-pair--vertical .campaign-ba-img{width:100%}
  .campaign-ba-caption{font-size:14px;padding:4px 12px}
  .campaign-ba--dual{grid-template-columns:1fr auto 1fr;gap:4px}
  .campaign-ba--dual .campaign-ba-arrow{width:28px;height:28px;font-size:14px}
  .campaign-quick{font-size:13px}
}

/* ===== Notes ===== */
.sub-notes{background:#fff;padding:56px 0;border-top:1px solid #eee}
.sub-notes-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.sub-notes-list li{font-size:13px;color:#999;line-height:1.9;padding-left:1.4em;text-indent:-1.4em}
.sub-notes-list li::before{content:'※';color:#ccc;margin-right:.3em}

/* ===== Mid CTA ===== */
.sub-mid-cta{text-align:center;margin-top:48px;position:relative}
.sub-mid-cta a{display:inline-flex;align-items:center;gap:10px;padding:18px 48px;font-size:18px;font-weight:800;transition:.3s;color:#fff;background:linear-gradient(135deg,#06c755,#05a648);border-radius:60px;box-shadow:0 6px 20px rgba(6,199,85,.35);letter-spacing:.04em}
.sub-mid-cta a:hover{background:linear-gradient(135deg,#05b04c,#049a40);transform:translateY(-2px);box-shadow:0 8px 28px rgba(6,199,85,.45);opacity:1}
.sub-mid-cta a svg{width:22px;height:22px;fill:#fff}

/* ===== Overlapping photo — pikapika style ===== */
.overlap-photo{position:relative;max-width:480px}
.overlap-photo::before{content:'';position:absolute;top:-28px;left:-28px;width:88%;height:90%;background:#066aab;z-index:0;border-radius:2px}
.overlap-photo img{position:relative;z-index:1;width:100%;display:block;border-radius:2px;box-shadow:0 8px 30px rgba(0,0,0,.1)}
.overlap-photo-deco{position:absolute;bottom:-16px;right:-16px;z-index:2;color:#066aab;font-size:24px;opacity:.18;line-height:1}
.overlap-photo.right .overlap-photo-deco{right:auto;left:-16px}
/* Reverse — blue on right */
.overlap-photo.right::before{left:auto;right:-28px}
.overlap-photo.right .overlap-photo-deco{right:auto;left:-12px}
/* No-image placeholder: blue rect + deco only */
.overlap-photo--noimg{aspect-ratio:4/3;max-width:420px}
.overlap-photo--noimg::before{width:100%;height:100%;top:0;left:0;border-radius:3px}
.overlap-photo--noimg .overlap-photo-deco{font-size:40px;opacity:.12;bottom:auto;top:50%;right:auto;left:50%;transform:translate(-50%,-50%)}
.overlap-photo--noimg.right::before{left:auto;right:0}
.overlap-photo--noimg.right .overlap-photo-deco{left:50%}
/* Layout: text + overlapping photo side by side */
.overlap-section{display:flex;gap:60px;align-items:center;max-width:960px;margin:0 auto}
.overlap-section-text{flex:1;min-width:0}
.overlap-section-text h3{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;letter-spacing:.2em;color:#066aab;text-transform:uppercase;margin-bottom:8px}
.overlap-section-text h2{font-size:24px;font-weight:700;color:rgba(0,0,0,.85);line-height:1.7;margin-bottom:16px}
.overlap-section-text p{font-size:14px;color:rgba(0,0,0,.6);line-height:2.1}
.overlap-section-img{flex:0 0 420px}
.overlap-section.reverse{flex-direction:row-reverse}
@media(max-width:999px){.overlap-section{flex-direction:column;gap:32px}.overlap-section.reverse{flex-direction:column}.overlap-section-img{flex:none;width:80%;max-width:360px;margin:0 auto}.overlap-photo::before{top:-16px;left:-16px}.overlap-photo.right::before{right:-16px}}

/* Hide old hero */
.sub-mv~.hero,.sub-mv~.breadcrumb{display:none}

/* About title override */
h2.sec-ttl-ja.about-ttl{font-family:"Montserrat","Noto Sans JP",sans-serif;font-size:clamp(28px,5vw,42px) !important;font-weight:900 !important;color:#066aab !important;letter-spacing:.08em !important}
