*{
    margin: 0;
    font-family: 'Noto Sans', sans-serif;
}
h1,h2,h3,h4,h5,h6{
    font-weight: 700;
}
p{
    line-height: 35px;
}
:root{
    --brand:#0b4aa1;
    --text:#1f2a37;
    --muted:#6b7280;
    --bg:#ffffff;
    --shadow: 0 10px 30px rgba(0,0,0,.06);
    --radius: 14px;
    --grad: linear-gradient(90deg,#a6e1ff 0%, #bde6ff 20%, #9fd2ff 55%, #b1c9ff 85%, #e4f2ff 100%);
}
/*---------------------*/
/*
ヘッダー
*/
/*---------------------*/
*,*::before,*::after{box-sizing:border-box}
    body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,"Noto Sans JP",sans-serif;color:var(--text);background:#fff}
    a{color:inherit;text-decoration:none}
    img{max-width:100%;display:block}
    button{font:inherit;color:inherit}

    .lux-header{position:sticky;top:0;z-index:1000;background:var(--bg)}
    .lux-header{display: flex;align-items: center;justify-content: space-between;}
    .lux-header::after{content:"";position:absolute;inset:auto 0 0 0;height:2px;background:var(--grad);opacity:.9;}
    .lux-header.is-scrolled{backdrop-filter:saturate(160%) blur(4px);box-shadow:var(--shadow)}

    .lux-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:68px;padding-inline:clamp(16px,4vw,36px);}

    .lux-brand{display:flex;align-items:center;gap:12px}
    .lux-logo{width:40px;height:40px;object-fit:contain;border-radius:10px;box-shadow:0 2px 8px rgba(16,79,161,.15)}
    .lux-brand__name{font-weight:700;letter-spacing:.02em}
    .lux-brand__name span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

    .lux-nav{position:absolute;left:0;right:0;top:100%;
            background:var(--bg);box-shadow:var(--shadow);
            transform-origin:top;transform:scaleY(0.96) translateY(-8px);
            opacity:0;pointer-events:none;transition:transform .28s ease,opacity .28s ease;
            border-bottom-left-radius:16px;border-bottom-right-radius:16px;}
    .lux-nav__list{list-style:none;margin:0;padding:12px clamp(16px,4vw,36px);display:grid;gap:6px;margin-right: 30px;}
    .lux-nav__item{display:block}
    .lux-nav__link{display:block;padding:14px 10px;border-radius:10px;position:relative;isolation:isolate}
    .lux-nav__link::after{content:"";position:absolute;left:10px;right:10px;bottom:10px;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .28s ease}
    .lux-nav__link:hover::after,.lux-nav__link:focus-visible::after{transform:scaleX(1)}
    .lux-nav__link[aria-current="page"]{background:linear-gradient(#fff,#fff) padding-box, var(--grad) border-box;border:1px solid transparent}

    .lux-cta > a{display:inline-flex;align-items:center;gap:.6em;padding:12px 16px;border-radius:999px;border:1px solid transparent;
        background:linear-gradient(#fff,#fff) padding-box, var(--grad) border-box;transition:filter .25s ease, background .25s ease}
    .lux-cta > a:hover{filter:saturate(130%)}

    .lux-burger{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:12px;border:1px solid rgba(0,0,0,.06);background:#fff;position:relative}
    .lux-burger span{width:22px;height:2px;background:var(--text);border-radius:1px;display:block;transition:transform .28s ease, opacity .2s ease;}
    .lux-burger span:nth-child(1){transform:translateY(-6px)}
    .lux-burger span:nth-child(3){transform:translateY(6px)}
    .menu-open .lux-burger span:nth-child(1){transform:translateY(0) rotate(45deg)}
    .menu-open .lux-burger span:nth-child(2){opacity:0}
    .menu-open .lux-burger span:nth-child(3){transform:translateY(0) rotate(-45deg)}

    .menu-open .lux-nav{opacity:1;pointer-events:auto;transform:scaleY(1) translateY(0)}
    body.menu-open{overflow:hidden}

    @media (min-width:1000px){
        .lux-burger{display:none}
        .lux-nav{all:unset}
        .lux-nav{display:block}
        .lux-nav__list{display:flex;align-items:center;gap:6px;padding:0}
        .lux-nav__link{padding:12px 14px}
        .lux-cta > a{margin-left:8px}
        .lux-brand__name br{display: none;}
    }

    :focus-visible{outline:2px solid #86c9ff;outline-offset:2px;border-radius:10px}

    @media (prefers-reduced-motion: reduce){
        .lux-nav,.lux-burger span{transition:none}
    }
    @media(max-width:768px){
    .lux-burger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 12px;
    border: 1px solid rgba(0,0,0,.06);
    background: #fff;
    position: relative;
    cursor: pointer;
    }

    .lux-burger span {
    position: absolute;
    left: 50%;
    width: 26px;
    height: 2.5px;
    background: var(--text);
    border-radius: 2px;
    transform: translateX(-50%);
    transition: transform .3s ease, top .3s ease, opacity .2s ease;
    }
    .lux-burger span:nth-child(1) { top: 12px; }
    .lux-burger span:nth-child(2) { top: 21px; }
    .lux-burger span:nth-child(3) { top: 30px; }
    .menu-open .lux-burger span:nth-child(1) {
    top: 21px;
    transform: translateX(-50%) rotate(45deg);
    }
    .menu-open .lux-burger span:nth-child(2) {
    opacity: 0;
    }
    .menu-open .lux-burger span:nth-child(3) {
    top: 21px;
    transform: translateX(-50%) rotate(-45deg);
    }
    .lux-bar{
        width: 100%;
    }

    }

/*---------------------*/
/*
ヘッディングからアンダーヘッディング
*/
/*---------------------*/

.heading_container {
    position: relative;
background-image:
  linear-gradient(rgba(0,0,0,.35), rgba(0,0,0,.35)),
  url('image/iStock-81075659.jpg');
    background-position: center;
    background-size: cover;
    background-attachment: fixed;
    display: flex;
    align-items: center;
    justify-content: center;
    background-blend-mode: multiply;
    height: 80vh;
    overflow: hidden;
}
.heading_container::after {
    content: "";
    position: absolute;
    inset: 0;
    box-shadow: inset 0 0 120px rgba(0, 0, 0, 0.6);
    pointer-events: none;
}
.heading_content{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    height: 100%;
    text-align: center;
}
.heading_content img{
    width: 320px;
}
.heading_content h1 {
    font-family: 'Playfair Display', serif;
    font-size: 52px;
    color: #ffffff;
    letter-spacing: 2px;
    margin-top: 5px;
    text-transform: uppercase;
    text-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.heading_content h1 span {
    font-size: 32px;
    font-weight: 400;
    letter-spacing: 4px;
    color: rgba(255,255,255,0.85);
}

.under_heading_container {
    position: relative;
    background: url(image/1.png) center/cover no-repeat, #fafafa;
    padding: 80px 20px;
}

.under_heading_wrapper {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.under_heading_content {
    position: relative;
    text-align: center;
    padding: 60px 40px;
    background: rgba(255, 255, 255, 0.75);
    border-radius: 20px;
    box-shadow: 0 12px 35px rgba(0,0,0,0.08);
    backdrop-filter: blur(6px);
}

.under_heading_content h2 {
    font-family: 'Poppins', sans-serif;
    font-size: 42px;
    font-weight: 700;
    color: #222;
    margin-bottom: 20px;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.under_heading_content h2 span {
    display: inline-block;
    font-size: 48px;
    background: linear-gradient(90deg, #008cff, #00d4ff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.under_heading_content p {
    font-size: 20px;
    line-height: 1.8;
    color: #333;
}
.slider_cpntainer {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

.hero-slider .swiper-slide img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
}

/* 矢印とドットをブランドカラーに */
.swiper-button-prev,
.swiper-button-next {
    color: #008cff;
}

.swiper-pagination-bullet {
    background: #ccc;
    opacity: 0.6;
    transition: all 0.3s;
}

.swiper-pagination-bullet-active {
    background: #008cff;
    opacity: 1;
}

.hero-slider{
    --swiper-navigation-color: #fff;
    --swiper-theme-color: #fff;
    position: relative; 
}
.hero-slider{ width:80vw;max-width: 1200px; height:50vh; }
.swiper-slide{ display:flex; align-items:center; justify-content:center; background:#000; }
.swiper-slide img{ width:100%; height:100%; object-fit:cover; display:block; }
@media(min-width:769px){
    .hero-slider {
        aspect-ratio: 16 / 9;
        height: auto;
    }
}
.hero-slider .swiper-button-prev,
.hero-slider .swiper-button-next{
    position: absolute;
    top: 60%;
    transform: translateY(-50%);
    width: 44px; height: 44px;
    border-radius: 999px;
    background: rgba(20,20,20,.28);
    backdrop-filter: blur(6px);
    z-index: 20;
    pointer-events: auto;
}
.hero-slider .swiper-button-prev:hover,
.hero-slider .swiper-button-next:hover{
    background: rgba(20,20,20,.45);
}
.hero-slider .swiper-button-prev::after,
.hero-slider .swiper-button-next::after{
    font-size: 16px;
    color: #fff;
}
.slide-overlay{ pointer-events: none; z-index: 10; }

@media (max-width: 768px) {
    .heading_container {
        height: 60vh;
        background-attachment: scroll;
    }
    .heading_content img {
        width: 200px;
    }
    .heading_content h1 {
        font-size: 28px;
        letter-spacing: 1px;
    }
    .heading_content h1 span {
        font-size: 18px;
        letter-spacing: 2px;
    }

    .under_heading_container {
        padding: 40px 16px;
    }
    .under_heading_content {
        padding: 30px 20px;
        border-radius: 12px;
    }
    .under_heading_content h2 {
        font-size: 24px;
    }
    .under_heading_content h2 span {
        font-size: 28px;
    }
    .under_heading_content p {
        font-size: 14px;
        line-height: 1.6;
    }

    .slider_cpntainer {
        border-radius: 12px;
    }
    .hero-slider {
        width: 100%;
        height: 240px;
    }
    .hero-slider .swiper-button-prev,
    .hero-slider .swiper-button-next {
        width: 32px;
        height: 32px;
    }
    .hero-slider .swiper-button-prev::after,
    .hero-slider .swiper-button-next::after {
        font-size: 12px;
    }
}
/*---------------------*/
/*
サービス
*/
/*---------------------*/

.service_container{
    background: linear-gradient(180deg,#f7fbff 0%, #eef6ff 100%);
    padding: clamp(48px, 8vw, 96px) 4vw;
}
.service_wrapper{
    max-width: 1200px;
    margin: 0 auto;
}
.service_heading{
    text-align: center;
    margin-bottom: clamp(28px, 4vw, 48px);
}
.service_heading p{
    font-size: clamp(18px, 2.6vw, 28px);
    letter-spacing: .18em;
    color: #008cff;
}

.service_content{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(16px, 3vw, 28px);
}

.service_flex{
    position: relative;
    display: grid;
    grid-template-rows: auto auto 1fr auto;
    gap: 14px;
    text-align: center;
    padding: clamp(20px, 3vw, 28px);
    background: #fff;
    border-radius: 24px;
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
    transition: transform .3s ease, box-shadow .3s ease;
}
.service_flex:hover{
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(0,0,0,.12);
}

.service_flex img{
    width: clamp(120px, 10vw, 160px);
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    object-fit: cover;
    margin: 0 auto 6px;
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    outline: 4px solid #fff;
    background:
        radial-gradient(120% 120% at 50% 0%, rgba(0,140,255,.25), rgba(0,0,0,0)) border-box;
    border: 2px solid rgba(0,140,255,.35);
}

.service_flex h2{
    font-size: clamp(18px, 2.2vw, 22px);
    font-weight: 700;
    color: #0f1b2d;
    letter-spacing: .04em;
}
.service_flex p{
    font-size: clamp(14px, 1.6vw, 16px);
    line-height: 1.9;
    color: #3a485e;
}

.service_button{
    margin-top: 8px;
}
.service_button a{
    display: inline-block;
    padding: 12px 28px;
    border-radius: 999px;
    background: linear-gradient(90deg, #008cff, #00d4ff);
    color: #fff;
    font-weight: 700;
    letter-spacing: .08em;
    text-decoration: none;
    box-shadow: 0 8px 20px rgba(0, 140, 255, .28);
    transition: transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}
.service_button a:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(0, 140, 255, .35);
    opacity: .95;
}

@media (max-width: 1024px){
    .service_content{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 768px){
    .service_content{ grid-template-columns: 1fr; }
    .service_flex{ border-radius: 20px; }
    .service_flex img{ width: 128px; }
}

/*---------------------*/
/*
アバウト
*/
/*---------------------*/

.about_container {
    background: #fdfdfd;
    padding: clamp(60px, 8vw, 100px) 5vw;
}

.about_wrapper {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: clamp(32px, 5vw, 56px);
}

.about_heading {
    text-align: center;
    max-width: 880px;
    margin: 0 auto;
}
.about_heading h3 {
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-size: clamp(22px, 3vw, 28px);
    font-weight: 700;
    color: #222;
    margin-bottom: 18px;
    letter-spacing: 0.05em;
}
.about_heading p {
    font-size: clamp(14px, 1.6vw, 16px);
    line-height: 1.9;
    color: #555;
}

.about_content {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: start;
    gap: 32px;
}

.about_flex01 {
    padding: clamp(22px, 4vw, 34px);
    background: #ffffff;
    border: 1px solid #e5e5e5;
    border-radius: 14px;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.05);
}
.about_flex01 p {
    font-size: clamp(14px, 1.6vw, 16px);
    line-height: 1.9;
    color: #333;
}

.more_button_black {
    align-self: start;
}
.more_button_black a {
    display: inline-block;
    padding: 12px 28px;
    border-radius: 999px;
    background: #008cff;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-decoration: none;
    transition: background 0.25s ease, transform 0.25s ease;
}
.more_button_black a:hover {
    background: #006fd6;
    transform: translateY(-2px);
}

/* タブレット以下 */
@media (max-width: 1024px) {
    .about_content {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 24px;
    }
    .more_button_black {
        justify-self: center;
    }
}

.about_content {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 32px;
}

.more_button_black {
    align-self: center;
    justify-self: end;
}

.more_button_black a {
    display: inline-block;
    padding: 12px 28px;
    border-radius: 999px;
    background: #008cff;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-decoration: none;
    transition: background 0.25s ease, transform 0.25s ease;
}
.more_button_black a:hover {
    background: #006fd6;
    transform: translateY(-2px);
}

/* タブレット以下は中央寄せで下配置 */
@media (max-width: 1024px) {
    .about_content {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 24px;
    }
    .more_button_black {
        justify-self: center;
        margin-top: 12px;
    }
}

.more_button_black a {
    display: inline-block;
    padding: 12px 36px;
    border-radius: 999px;
    background: linear-gradient(90deg, #008cff, #00d4ff);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-decoration: none;
    box-shadow: 0 6px 18px rgba(0,140,255,0.25);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}
.more_button_black a::after {
    content: "";
    position: absolute;
    top: 0; left: -40%;
    width: 40%; height: 100%;
    background: rgba(255,255,255,0.3);
    transform: skewX(-25deg);
    transition: left 0.6s ease;
}
.more_button_black a:hover::after {
    left: 120%;
}
.more_button_black a:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(0,140,255,0.35);
}


/*---------------------*/
/*
予約
*/
/*---------------------*/

.reservation_container {
    background: linear-gradient(135deg, #ebebeb 0%, #f5f7fa 100%);
    padding: clamp(60px, 8vw, 100px) 4vw;
}

.reservation_wrapper {
    max-width: 1000px;
    margin: 0 auto;
}

.reservation_content {
    text-align: center;
    background: #ffffff;
    border-radius: 20px;
    padding: clamp(40px, 6vw, 60px);
    box-shadow: 0 18px 40px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.05);
}

.reservation_content p {
    font-family: 'Playfair Display', serif;
    font-size: clamp(22px, 3vw, 32px);
    font-weight: 700;
    letter-spacing: 0.12em;
    color: #111;
    margin-bottom: 28px;
    position: relative;
}
.reservation_content p::after {
    content: "";
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 3px;
    border-radius: 2px;
    background: linear-gradient(90deg, #bfa15a, #e6d28c);
}

.reservation_content ul {
    text-align: left;
    margin: 0 auto 40px;
    max-width: 760px;
    color: #333;
    font-size: clamp(14px, 1.6vw, 16px);
    line-height: 1.9;
    list-style: disc;
    padding-left: 20px;
}

.button_flex {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.tel_button a,
.line_button a {
    display: inline-block;
    min-width: 180px;
    padding: 14px 32px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
    letter-spacing: 0.08em;
    box-shadow: 0 10px 25px rgba(0,0,0,0.12);
    transition: all 0.3s ease;
}
.tel_button a {
    background: linear-gradient(135deg, #c5a84b, #f0e08a);
    color: #fff;
}
.tel_button a:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(197,168,75,0.45);
}
.line_button a {
    background: linear-gradient(135deg, #1e9c4b, #2ecc71);
    color: #fff;
}
.line_button a:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(30,156,75,0.45);
}

/* スマホ時調整 */
@media (max-width: 768px) {
    .reservation_content {
        padding: 32px 20px;
    }
    .reservation_content ul {
        font-size: 14px;
        line-height: 1.7;
        padding-left: 18px;
    }
    .button_flex {
        gap: 14px;
    }
    .tel_button a,
    .line_button a {
        min-width: 140px;
        font-size: 14px;
        padding: 12px 24px;
    }
}

/*---------------------*/
/*
フッター
*/
/*---------------------*/

footer {
    background: linear-gradient(180deg, #111 0%, #1a1a1a 100%);
    color: #eee;
    padding: 60px 4vw 30px;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.footer_container {
    max-width: 1200px;
    margin: 0 auto;
}

.footer_content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 32px;
    border-bottom: 1px solid rgba(255,255,255,0.12);
    padding-bottom: 28px;
}

.footer_flex01 {
    display: flex;
    align-items: center;
    gap: 14px;
}
.footer_flex01 img {
    width: 60px;
    height: auto;
    object-fit: contain;
}
.footer_flex01 h5 {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: #fff;
}

.footer_flex02 ul {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 28px;
    justify-content: flex-end;
}
.footer_flex02 ul li a {
    font-size: 14px;
    letter-spacing: 0.05em;
    color: #bbb;
    text-decoration: none;
    transition: color 0.25s ease;
}
.footer_flex02 ul li a:hover {
    color: #fff;
}

footer .footer_bottom {
    text-align: center;
    font-size: 12px;
    color: #777;
    margin-top: 24px;
    letter-spacing: 0.05em;
}
@media (max-width: 1024px) {
    .footer_content {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 24px;
    }
    .footer_flex02 ul {
        justify-content: center;
    }
}
@media (max-width: 600px) {
    footer {
        padding: 40px 6vw 20px;
    }
    .footer_flex01 img {
        width: 48px;
    }
    .footer_flex01 h5 {
        font-size: 15px;
    }
    .footer_flex02 ul {
        gap: 14px 20px;
    }
    .footer_flex02 ul li a {
        font-size: 13px;
    }
    footer .footer_bottom {
        font-size: 11px;
        margin-top: 18px;
    }
}



/* Base */
.ss_container{max-width:1200px;margin:0 auto;padding:0 4vw}
.ss_btn{display:inline-block;padding:12px 28px;border-radius:999px;font-weight:700;letter-spacing:.08em;text-decoration:none;transition:.25s ease;}

/* Hero */
.ss_hero{
  position:relative; height:52vh; min-height:360px;
  background: linear-gradient(rgba(0,0,0,.35),rgba(0,0,0,.35)), url(image/iStock-1354965105_011.jpg) center/cover no-repeat;
  display:flex; align-items:center; justify-content:center; text-align:center; color:#fff; overflow:hidden;
}
.ss_hero::after{content:""; position:absolute; inset:0; box-shadow: inset 0 0 120px rgba(0,0,0,.55); pointer-events:none;}
.ss_hero_inner{position:relative; padding:0 4vw}
.ss_hero h1{font-family:'Playfair Display',serif; font-size:clamp(28px,5vw,56px); letter-spacing:.12em; text-transform:uppercase}
.ss_hero p{font-family:'Poppins',sans-serif; font-size:clamp(14px,2.2vw,18px); opacity:.9; margin-top:.6em; letter-spacing:.12em}

/* Intro */
.ss_intro{background:#fafcff; padding: clamp(48px,8vw,96px) 0;}
.ss_intro h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(22px,3.2vw,32px); letter-spacing:.06em; color:#0f1b2d; text-align:center; margin-bottom:16px}
.ss_intro p{max-width:980px;margin:0 auto; font-size:clamp(14px,1.6vw,16px); line-height:1.9; color:#354155; text-align:center}
.ss_intro .ss_note{color:#008cff}

/* Services */
.ss_services{padding: clamp(56px,8vw,100px) 0; background: linear-gradient(180deg,#f7fbff 0%, #eef6ff 100%)}
.ss_services h2{text-align:center; font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(22px,3vw,28px); letter-spacing:.18em; color:#008cff; margin-bottom:28px}
.ss_service_grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(16px,3vw,28px)}
.ss_card{
  text-align:center; padding: clamp(20px,3vw,28px); background:#fff; border-radius:24px;
  box-shadow:0 10px 30px rgba(0,0,0,.08); transition:.3s ease transform, .3s ease box-shadow;
  display:grid; grid-template-rows:auto auto 1fr auto; gap:10px
}
.ss_card:hover{transform:translateY(-6px); box-shadow:0 16px 40px rgba(0,0,0,.12)}
.ss_card img{width:160px; max-width:46%; aspect-ratio:1/1; border-radius:50%; object-fit:cover; margin:0 auto 6px; box-shadow:0 8px 24px rgba(0,0,0,.18); outline:4px solid #fff; border:2px solid rgba(0,140,255,.28)}
.ss_card h3{font-size:clamp(16px,2.2vw,20px); font-weight:700; color:#0f1b2d}
.ss_card p{font-size:clamp(13px,1.6vw,15px); color:#3a485e; line-height:1.8}
.ss_price{font-weight:700; color:#0f1b2d}
.ss_price span{font-weight:400; color:#5c6b82}

/* Corporate CTA */
.ss_corporate{background:#fff; padding: clamp(56px,8vw,100px) 0;}
.ss_corporate_inner{display:grid; grid-template-columns: 1.1fr .9fr; gap:32px; align-items:center}
.ss_corp_text h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(22px,3.2vw,30px); letter-spacing:.06em; color:#0f1b2d; margin-bottom:10px}
.ss_corp_text p{font-size:clamp(14px,1.6vw,16px); line-height:1.9; color:#354155; margin-bottom:18px}
.ss_btn_row{display:flex; gap:14px; flex-wrap:wrap}
.ss_btn_gold{background: linear-gradient(135deg,#c5a84b,#f0e08a); color:#fff; box-shadow:0 10px 25px rgba(197,168,75,.35)}
.ss_btn_gold:hover{transform:translateY(-2px)}
.ss_btn_line{background: linear-gradient(135deg,#1e9c4b,#2ecc71); color:#fff; box-shadow:0 10px 25px rgba(30,156,75,.35)}
.ss_btn_line:hover{transform:translateY(-2px)}
.ss_corp_visual img{width:100%; height:auto; border-radius:18px; box-shadow:0 18px 40px rgba(0,0,0,.1); object-fit:cover}

/* Reserve Notes */
.ss_reserve_notes{background:#fafafa; padding: clamp(48px,7vw,88px) 0;}
.ss_reserve_notes h2{text-align:center; font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(20px,3vw,26px); letter-spacing:.06em; color:#0f1b2d; margin-bottom:16px}
.ss_reserve_notes ul{max-width:600px;margin:0 auto; padding-left:1.2em; line-height:1.9; color:#354155; font-size:clamp(14px,1.6vw,16px)}

/* Concept */
.ss_about_concept{background:#fff; padding: clamp(56px,8vw,100px) 0;}
.ss_concept_inner{display:grid; grid-template-columns: 1.1fr .9fr; gap:32px; align-items:center}
.ss_concept_text h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(22px,3.2vw,30px); letter-spacing:.06em; color:#0f1b2d; margin-bottom:10px}
.ss_concept_text p{font-size:clamp(14px,1.6vw,16px); line-height:1.9; color:#354155; margin-bottom:18px}
.ss_btn_outline{border:1px solid #cfd6e2; color:#0f1b2d; background:#fff}
.ss_btn_outline:hover{background:#0f1b2d; color:#fff; transform:translateY(-1px)}
.ss_concept_visual img{width:100%; height:auto; border-radius:18px; box-shadow:0 18px 40px rgba(0,0,0,.1); object-fit:cover}

/* Steps */
.ss_steps{background: linear-gradient(180deg,#f7fbff 0%, #eef6ff 100%); padding: clamp(56px,8vw,100px) 0;}
.ss_steps h2{text-align:center; font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(20px,3vw,26px); letter-spacing:.06em; color:#0f1b2d; margin-bottom:24px}
.ss_steps_grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(16px,3vw,28px)}
.ss_step{background:#fff; border-radius:18px; box-shadow:0 10px 28px rgba(0,0,0,.08); padding:20px; text-align:center; display:grid; grid-template-rows:auto auto 1fr; gap:8px}
.ss_step img{width:100%; height:220px; object-fit:cover; border-radius:12px}
.ss_step h3{font-size:clamp(16px,2.2vw,18px); font-weight:700; color:#0f1b2d; margin-top:6px}
.ss_step p{font-size:clamp(13px,1.6vw,15px); color:#3a485e; line-height:1.8}

/* Responsive */
@media (max-width: 1100px){
  .ss_corporate_inner, .ss_concept_inner{grid-template-columns:1fr}
}
@media (max-width: 1024px){
  .ss_service_grid, .ss_steps_grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 768px){
  .ss_hero{height:42vh; min-height:280px; background-attachment:scroll}
  .ss_card img{max-width:56%}
  .ss_service_grid, .ss_steps_grid{grid-template-columns:1fr}
}
/* Container */
.ss_container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 4vw;
}

/* ABOUT message */
.ss_about_msg {
  background: #fafcff;
  padding: clamp(48px, 8vw, 88px) 0;
  text-align: center;
}

.ss_about_msg h2 {
  font-weight: 700;
  font-size: clamp(22px, 3vw, 28px);
  letter-spacing: 0.12em;
  color: #008cff;
  margin-bottom: 12px;
}

.ss_about_msg .ss_lead {
  font-size: clamp(15px, 1.9vw, 18px);
  color: #0f1b2d;
  line-height: 1.9;
  margin: 0 auto 10px;
  max-width: 900px;
}

.ss_about_msg .ss_body {
  font-size: clamp(14px, 1.6vw, 16px);
  color: #354155;
  line-height: 1.9;
  max-width: 900px;
  margin: 0 auto;
}

/* ABOUT info */
.ss_about_info {
  background: #ffffff;
  padding: clamp(56px, 8vw, 100px) 0;
}

.ss_info_title {
  font-weight: 700;
  font-size: clamp(18px, 2.6vw, 22px);
  color: #0f1b2d;
  letter-spacing: 0.04em;
  margin-bottom: 14px;
}

.ss_list {
  margin: 6px 0 20px;
}

.ss_list > div {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 12px;
  padding: 12px 0;
  border-top: 1px solid #eef2f7;
}

.ss_list > div:first-child {
  border-top: 0;
}

.ss_list dt {
  color: #5a6b80;
  font-size: 14px;
  letter-spacing: 0.04em;
}

.ss_list dd {
    color: #223049;
    font-size: 14px;
    line-height: 1.9;
    margin: 0;
}

.ss_info_body p {
    font-size: 14px;
    line-height: 1.9;
    color: #354155;
    margin: 0 0 10px;
}
@media (max-width: 768px) {
    .ss_list > div {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .ss_list dt {
        font-weight: 700;
        color: #2b3c54;
    }
}


.ss_fv {
    position: relative;
    min-height: 70vh;
    background: linear-gradient(rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0.45)),
                url(image/iStock-1427908555kk.jpg) center/cover no-repeat;
    color: #fff;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.ss_fv_overlay {
    position: absolute;
    inset: 0;
    box-shadow: inset 0 0 140px rgba(0, 0, 0, 0.55);
}

.ss_fv_inner {
    position: relative;
    z-index: 2;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0 4vw;
}

.ss_fv_copy h1 {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: clamp(28px, 5vw, 52px);
  line-height: 1.2;
  letter-spacing: 0.08em;
  margin-bottom: 18px;
}

.ss_fv_copy h1 span {
  display: block;
  font-size: clamp(18px, 3vw, 28px);
  font-weight: 600;
  letter-spacing: 0.12em;
  margin-top: 6px;
}

.ss_fv_copy p {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.9;
  max-width: 720px;
  margin: 0 auto 20px;
  opacity: 0.95;
}

.ss_btn_row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}

/* ボタン */
.ss_btn {
  display: inline-block;
  padding: 12px 28px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: none;
  transition: 0.25s ease;
}

.ss_btn_gold {
  background: linear-gradient(135deg, #c5a84b, #f0e08a);
  color: #fff;
  box-shadow: 0 10px 25px rgba(197, 168, 75, 0.35);
}

.ss_btn_gold:hover {
  transform: translateY(-2px);
}

.ss_btn_line {
  background: linear-gradient(135deg, #1e9c4b, #2ecc71);
  color: #fff;
  box-shadow: 0 10px 25px rgba(30, 156, 75, 0.35);
}

.ss_btn_line:hover {
  transform: translateY(-2px);
}

/* ===== レスポンシブ ===== */
@media (max-width: 768px) {
  .ss_fv {
    min-height: 60vh;
    background-attachment: scroll;
  }
  .ss_fv_copy h1 {
    font-size: clamp(24px, 6vw, 36px);
  }
  .ss_fv_copy h1 span {
    font-size: clamp(16px, 4vw, 20px);
  }
}

/* ===== ABOUT Section ===== */
.ss_about_msg {
  position: relative;
  background: url(image/iStock-1249482470kk.jpg) center/cover no-repeat;
  padding: clamp(60px, 8vw, 120px) 0;
  color: #fff;
  text-align: center;
  overflow: hidden;
}

/* 背景を暗く＋ぼかすオーバーレイ */
.ss_about_overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px); /* ← 強めのぼかし */
  -webkit-backdrop-filter: blur(10px);
  z-index: 0;
}

/* さらにもう1段階ぼかし（奥行き感アップ用） */
.ss_about_msg::before {
  content: "";
  position: absolute;
  inset: -20px; /* 少し広げてぼかしの境界を隠す */
  background: inherit;
  filter: blur(15px); /* ← 背景そのものをぼかす */
  transform: scale(1.1); /* 少し拡大してズレ防止 */
  z-index: -1;
}

.ss_about_msg .ss_container {
  position: relative;
  z-index: 1;
  max-width: 980px;
  margin: 0 auto;
  padding: 0 5vw;
  color: #ffffff;
}
.ss_about_msg .ss_container p{
  color: #ffffff;
}
/* 見出し */
.ss_about_msg h2 {
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 28px;
  position: relative;
  display: inline-block;
  color: #fff;
}

.ss_about_msg h2::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, #00c6ff, #0072ff);
  margin: 10px auto 0;
  border-radius: 2px;
}

/* リード文 */
.ss_lead {
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 500;
  line-height: 1.9;
  margin-bottom: 24px;
  background: rgba(255,255,255,0.08); /* より透け感を強調 */
  padding: 20px 26px;
  border-radius: 16px;
  display: inline-block;
  box-shadow: 0 8px 32px rgba(0,0,0,0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* 本文 */
.ss_body {
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 2;
  max-width: 800px;
  margin: 0 auto;
  color: rgba(255,255,255,0.92);
}

/* ハイライト */
.ss_about_msg span {
  background: linear-gradient(
    180deg, 
    rgba(255,255,255,0) 60%, 
    rgba(0,140,255,0.35) 60%
  );
  padding: 0 2px;
}

/* レスポンシブ */
@media (max-width: 768px) {
  .ss_lead {
    font-size: 15px;
    padding: 16px 18px;
  }
  .ss_body {
    font-size: 14px;
  }
}