html, body{
max-width:100%;
overflow-x:hidden;
}
body{
padding:0 0 0 0 !important;
margin:0 !important;
position: relative;
background-repeat: repeat-y; 
background-size: 100% auto;
background-position: 0 50%;
}
.header {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 68px;
z-index: 1000;

/* ガラス効果 */
background: rgba(8, 20, 40, 0.48);               /* 黒×青のガラス色 */
backdrop-filter: blur(12px) saturate(140%);
-webkit-backdrop-filter: blur(12px) saturate(140%);

border-bottom: 1px solid rgba(255,255,255,0.06);
box-shadow: 0 4px 18px rgba(0,0,0,0.3);

display: flex;
align-items: center;
padding: 5px 8px;
}

.header-logo{
width:222px;
box-shadow:none;
margin:0 auto 0 8px;
}
.header-menu{
position:absolute;
left:50%;
top:50%;
transform:translate(-50%, -50%);
margin:0;
display:flex;
gap:32px;
align-items:center;
}
.header-menu span{
font-size:16px;
color:#e8e8ee;
margin-top:0 !important;
align-items: flex-end;
vertical-align: bottom; 
display: inline-block;

}
.header-menu span a{
color:#e8e8ee;
}
.header-inner{
display:flex;
align-items:center;
width:100%;
margin:0;
padding:0;
box-sizing:border-box;
justify-content:flex-start;
position:relative;
}
.header-actions{
display:flex;
margin-left:auto;
gap:6px;
align-items:center;
}
#menuBtn{
    display: none;
}
.drawer-body a {
border-radius: 0 !important;
color: #505059;
}
h1{
font-size:40px !important;
font-weight: 800 !important;
color:#333338;
margin-bottom:0;
}
h1 span{
    font-size:32px;
}
h2{
font-size:30px !important;
color:#0541DA;
}

.button{
padding:11px 12px;
color: white;
background-color: darkorange;
border-radius: 8px;
border: solid 1px #808080;
text-align: center;
width:200px;
font-weight: 700;
}
@media (max-width: 768px){
.act-section-text{
    text-align:left;
}
}
.content-main{
max-width:1200px;
padding:70px 20px 0 20px; 
margin:0 auto;
}
.act-footer{
font-size:14px !important;
color:#c0c0c0;
display:flex;
flex-wrap:wrap;
justify-content:center;
gap:6px 0;
margin:24px auto 0;
padding:0 16px;
}
.act-footer span{
white-space:nowrap;
display:inline-flex;
align-items:center;
}
.act-footer span + span::before{
content:"｜";
color:#5c5c5c;
margin:0 10px;
}
.footer-wrap{
text-align:center;
background-color:#292929;
padding:36px 0 5px;
padding-bottom: 50px;
}
.footer-logo img{
box-shadow:none !important;
width:120px;
margin:0 auto;
}

@media (max-width: 880px){
.content-main{
    max-width:1200px;
    padding:70px 20px 0 20px; 
    margin:0 auto;
}
.header{
    height:auto;
    padding:12px 24px 18px;
}
.header-inner{
    flex-wrap:wrap;
    justify-content:center;
    gap:12px 24px;
    padding:0;
}
.header-logo{
    margin:0 auto;
}
.header-menu{
    display: none;
}
.header-actions{
    display: none;
}
.header .button{
    margin-top:0 !important;
}
#menuBtn{
    display: block;
}
.contents-width{
    display: block;
}
.act-section.flex{
    flex-direction:column;
    align-items:center;
    gap:28px;
    padding:48px 5%;
}
.act-section.flex .section-contents{
    width:100%;
    max-width:680px;
    padding:20px 0;
}
.act-section.flex .section-contents img{
    width:100% !important;
    height:auto !important;
}
.act-section.flex div[style*="display:flex"]{
    width:100%;
    flex-wrap:wrap;
    justify-content:center;
    gap:12px;
}
.act-section.flex div[style*="display:flex"] .button{
    margin-left:0 !important;
}
.features-grid{
    flex-wrap:wrap !important;
    justify-content:center;
    gap:20px;
}
.features-grid > div{
    height:auto !important;
}
.features-grid img{
    width:100% !important;
    height:auto !important;
}
.ai-label-wrapper{
    justify-content:center;
}
.ai-label-wrapper div{
    margin-left:0;
}
.our-edge-section{
    padding:48px 6% !important;
}
.our-edge-section .edge-block{
    padding:0 12px !important;
}
.our-edge-section .edge-block h3{
    margin-left:0 !important;
}
.plan-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    height:auto;
}
.plan-card{
    height:auto;
}
}
@media (max-width: 768px){
body{
    background-size: cover;
    background-position: center top;
}
.content-main{
    max-width:1200px;
    padding:70px 12px 0 12px; 
    margin:0 auto;
}
.header{
    height:auto;
    padding:12px 0px 3px;
}
.header-inner{
    flex-direction: column;
    align-items: center;
    gap:12px;
    width:100%;
    padding:0;
}
.header-logo{
    width:220px;
    margin:0 auto 0 12px;
}
.header-menu{
    display:none;
}
.header-actions{
    display:none;
}
.header .button + .button{
    margin-top:8px !important;
    margin-left:0 !important;
}
#menuBtn{
    position: absolute;
    right:10px;
    top:4px;
    display: block;
}
}

/* ==== 背景動画 ==== */
#bgVideo{
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
object-fit: cover;
z-index: -2;
pointer-events: none;
filter: brightness(0.6);
}

/* ==== 青フィルター ==== */
.bg-filter{
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
background: rgba(1, 72, 225, 0.2); /* 青系フィルター（濃さ調整可） */
z-index: -1;
pointer-events: none;
opacity: 0;
visibility: hidden;
transition: opacity .4s ease;
}

/* body の背景設定は不要になるので消してOK */
body{
background: none !important;
}

/* ▼ 見出し：超細くて丸い未来系フォント */
h1, h2, h3 {
font-family: 'Nunito', 'Zen Maru Gothic', sans-serif;
font-weight: 400;
letter-spacing: 0.02em;
}
h2{
padding-bottom:10px;
border-bottom: solid 1px #606060 !important;
}
/* ▼ 本文：日本語丸ゴシック（細め） */
body, p, span {
font-family: 'Zen Maru Gothic', 'Nunito', sans-serif;
font-weight: 400;
line-height: 1.75;
color: #e0e0ee;
}

.icon-card {
width: 48px;
height: 48px;
border-radius: 18px;
background: linear-gradient(135deg, #ff8a3d 0%, #ff7ad1 50%, #b48bff 100%);
display: flex;
align-items: center;
justify-content: center;
box-shadow:
    0 4px 10px rgba(0, 0, 0, 0.15),
    0 1px 3px rgba(255, 255, 255, 0.3) inset;
}

.icon-card i {
width: 32px;
height: 32px;
color: #0b1820;               /* ダークネイビー */
}

/* lucide iconsをより太く見せる */
.icon-card svg {
stroke-width: 2.6;            /* 2.2〜3.0で調整可能 */
}

/* ================================
AI検索に、対応する セクション
================================ */
.ai-hero {
padding: 12px 5%;
position: relative;
overflow: hidden;
}

@keyframes aiTwinkle {
0% { transform: translateY(0); }
100% { transform: translateY(-40px); }
}

.ai-hero-inner {
display: flex;
align-items: center;
justify-content: space-between;
max-width: 1320px;
margin: 0 auto;
gap: 40px;
}

/* 左テキスト */
.ai-hero-title {
font-size: 54px;
font-weight: 400;
line-height: 1.35;
color: #ffffff;
margin-bottom: 0px;
}

.ai-hero-accent, .sp-ai-hero-accent {
background: linear-gradient(90deg, #ff7a00, #ff4e00);
-webkit-background-clip: text;
color: transparent;
font-weight: 600;
margin-bottom:0;
padding-bottom:0;
}

.ai-hero-desc {
color: #d0dae4;
font-size: 20px;
line-height: 1.8;
margin-bottom: 36px;
text-align: left;
}

.ai-hero-text p{
margin-top: 6px !important;
}

/* ボタン */
.ai-hero-buttons {
display: flex;
gap: 20px;
}

.ai-hero-buttons a svg {
margin-right: 6px;
}

/* 右画像 */
.ai-hero-image-wrap img {
width: 515px;
border-radius: 28px;
box-shadow: 0 16px 40px rgba(0,0,0,0.45);
margin-left:0px !important;
margin-top:26px;
}
.ai-hero-title-pc{
    display:block;
}
.ai-hero-title-sp{
    display:none;
}
.ai-hero-image-wrap-sp{
display: none;
}
.ai-hero-text p{
    margin-top:18px;
    padding-top:0;
    margin-bottom:18px;
    padding-bottom:0;
    max-width: 560px !important;
    padding-right:30px;
}
.act-point{
    display: flex;
}
.act-point div{
    font-size:18px;
    padding:8px 22px;
    border-radius: 30px;
    border: solid 2px #29d2f2;
    color: #29d2f2;
    margin-right:15px;
    text-align: center;
    margin-top:0px !important;
    margin-bottom:12px;
}
/* スマホ対応 */
@media (max-width: 880px) {
.pc-title{
    display:none;
}
.sp-title{
    display:block;
    margin-top:8px;font-family:'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif;
    font-weight: bold;
    font-size:68px;
    line-height:72px;
}
h2{
    font-size:26px !important;
}
.ai-hero-title-pc{
    display:none;
}
.ai-hero-title-sp{
    display:block;
}
.act-point{
    display: none;
}
.sp-act-point{
    display: block;
    margin:12px auto 20px auto;

}
.sp-act-point div{
    font-size:18px;
    padding:8px 22px;
    border-radius: 30px;
    border: solid 2px #29d2f2;
    color: #29d2f2;
    margin-right:15px;
    text-align: center;
    margin-top:0px !important;
    margin-bottom:12px;
}
.geo-title {
    margin-top:0px;
    margin-bottom: 0px;
}
.geo-subtitle {
    margin-top:0px;
}
.ai-hero-inner {
    flex-direction: column;
    text-align: center;
}
.ai-hero-title {
    font-size: 38px;
}
.ai-hero-buttons {
    flex-direction: column;
    align-items: center;
}
.ai-hero-text p{
    padding-right:0px;
}
.ai-hero-image-wrap-sp{
    display: block;
    width:98%;
}
.ai-hero-image-wrap-sp img{
    width:99%;
    border-radius: 26px;
}
.ai-hero-image-wrap{
    display: none;
}
.ai-hero-desc {
    text-align: left;
    margin:0 auto;
}
.sp-cta-inner{
    display:block;
}
.cta-inner{
    display:none;
}
.sp-ai-hero-accent{
    display:block;
}
.ai-hero-accent{
    display:none;
}
}
@media (min-width: 880px) {
.pc-title{
    display:block;
    font-family:'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif;
    font-weight: bold;
    font-size:68px;
}
.sp-title{
    display:none;
}
.act-point{
    display: flex;
}
.act-point div{
    font-size:18px;
    padding:8px 22px;
    border-radius: 30px;
    border: solid 2px #29d2f2;
    color: #29d2f2;
    margin-right:15px;
    text-align: center;
    margin-top:0px !important;
    margin-bottom:12px;
}
.sp-act-point{
    display: none;
}
.cta-inner{
    display:block;
}
.cta-inner{
    display:none;
}
.sp-ai-hero-accent{
    display:none;
}
.ai-hero-accent{
    display:block;
}
}

/* ==========================
    導入企業セクション
    ========================== */
.clients-section, .platforms-section {
padding: 50px 1% 30px;
text-align: center;
}

.clients-title, .platforms-title {
font-size: 32px;
color: #ffffff;
font-weight: 700;
margin-bottom: 40px;
border-bottom: 1px solid rgba(255,255,255,0.1);
display: inline-block;
padding-bottom: 10px;
}

h2{
font-size: 32px;
color: #ffffff;
font-weight: 700;
margin-bottom: 40px;
border-bottom: 1px solid rgba(255,255,255,0.1);
display: inline-block;
padding-bottom: 10px;
text-align: center;
}

/* グリッド：最大5列 → 幅に応じて自動で4・3・2に落ちる */
.clients-grid, .platforms-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(188px, 1fr));
gap: 26px;
max-width: 1100px;
margin: 0 auto;
}

.client-card, .platforms-card {
background: rgba(255,255,255);
border-radius: 18px;
padding: 18px 12px;
box-shadow: 0 10px 26px rgba(0,0,0,0.22);

display: flex;
flex-direction: column;
align-items: center;
justify-content: center;

transition: .25s ease;
height: 150px;

position: relative;
}

.platforms-card {
padding: 18px 22px;
height: 90px;
}

.client-card img, .platforms-card img {
max-width: 100%;
max-height:118px;
object-fit: contain;
margin-bottom: 6px;
}

/* ▼ カードの下固定に配置 */
.client-card div label {
position: absolute;
bottom: 18px;       /* ← カード下からの距離を調整 */
left: 50%;
transform: translateX(-50%);

font-size: 10px;
color: #333333;
text-align: center;
white-space: nowrap;
}

.client-card:hover {
transform: translateY(-4px);
box-shadow: 0 14px 34px rgba(0,0,0,0.28);
}

/* スマホ最適化 */
@media (max-width: 768px) {
.clients-title {
    font-size: 26px;
}
.client-card {
    height: 110px;
    padding: 8px 14px 14px 14px;
}
.client-card div label {
    bottom: 9px;
}
}

.platform-tags .tag{
color: orange;
border: solid 1px orange;
border-radius: 8px;
padding:3px 8px;
margin:3px 6px 13px 6px;
line-height: 43px;

}
.features-section {
    padding: 80px 8% 100px;
    color: #e6efff;
    position: relative;
    text-align: center;
}

.features-title {
    text-align: center;
    font-size: 32px;
    margin-bottom: 40px;
    font-weight: 700;
    color: #ffffff;
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 28px;
}

.feature-card {
    background: rgba(9, 22, 45, 0.45);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 26px 24px;
    backdrop-filter: blur(14px) saturate(160%);
    -webkit-backdrop-filter: blur(14px) saturate(160%);
    box-shadow: 0 6px 28px rgba(0,0,0,0.35);
    transition: .25s ease;
}

.feature-card:hover {
    transform: translateY(-4px);
    border-color: rgba(120,180,255,0.35);
    box-shadow: 0 12px 34px rgba(0,0,0,0.45);
}

.feature-icon {
    width: 56px;
    height: 56px;
    border-radius: 20px;
    margin-bottom: 16px;
    background: linear-gradient(135deg, #ff8a3d 0%, #ff7ad1 50%, #b48bff 100%);
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 14px rgba(0,0,0,0.25);
    margin:0 auto;
}

.feature-icon svg {
    width: 32px;
    height: 32px;
    stroke: #393933 !important;
    stroke-width: 2.6;
}

.feature-card h3 {
    font-size: 20px;
    margin-bottom: 12px;
    font-weight: 700;
    color: #ffffff;
}

.feature-card p {
    line-height: 1.7;
    font-size: 15px;
    color: #cfd8e7;
}

/* レスポンシブ */
@media (max-width: 768px) {
    .features-title {
    font-size: 26px;
    }
    .feature-card {
    padding: 22px;
    }
    .feature-card h3 {
    text-align: center;
    }
}

/* ================================
GEO セクション
================================ */
.geo-section {
padding: 10px 0;
position: relative;
overflow: hidden;
text-align: center;
}

@keyframes geo-twinkle {
0% { transform: translateY(0); }
100% { transform: translateY(-40px); }
}

.geo-container {
width: 92%;
max-width: 1200px;
margin: 0 auto;
}

/* タイトル */
.geo-title {
text-align: center;
color: #fff;
font-size: 38px;
font-weight: 500;
margin-bottom: 60px;
}

/* 2カラム */
.geo-content {
display: flex;
align-items: center;
gap: 60px;
}

/* 左画像 */
.geo-image-wrap img {
width: 100%;
width: 480px;
border-radius: 24px;
box-shadow: 0 12px 34px rgba(0, 0, 0, 0.4);
}

/* 右テキスト */
.geo-text {
margin-top:-18px !important;
color: #cfd9e6;
font-size: 18px;
line-height: 1.8;
}

        /* 右テキスト */
.geo-text p{
text-align: left;
line-height: 1.6;
}

.geo-subtitle {
color: #29d2f2;
font-size: 24px;
margin-bottom: 18px;
font-weight: 500;
}

/* レスポンシブ */
@media (max-width: 880px) {
    .geo-content {
        flex-direction: column;
        text-align: center;
    }

    .geo-text {
        max-width: 680px;
        margin: 0 auto;
    }

    .geo-image-wrap img {
        max-width: 420px;
    }
}

/* タイトル */
.plan-title {
    text-align: center;
    color: #fff;
    font-size: 38px;
    font-weight: 500;
    margin-bottom: 6px;
    margin-top:70px;
}
.alias-theme {
border-radius: 12px;
padding: 24px;
box-shadow: 0 4px 22px rgba(0,0,0,0.45);
color: #fff;
}

.plan-grid {
display: grid;
grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
gap: 20px;
}

.plan-card {
position: relative;
background: rgba(255,255,255,0.05);
border: 1px solid rgba(255,255,255,0.1);
border-radius: 12px;
padding: 18px 18px 3px 18px !important;
box-shadow: 0 6px 20px rgba(0,0,0,0.3);
display: flex;
flex-direction: column;
transition: 0.3s;
color: #e0e0ee;
}
.plan-card:hover {
border-color: #4b3f72;
transform: translateY(-3px);
box-shadow: 0 10px 30px rgba(0,0,0,0.45);
}
.featured {
background: linear-gradient(135deg,#4b3f72,#7253ff) !important;
border: none;
color: #e0e0ee;
}
.plan-ribbon {
position: absolute;
top: -10px;
right: -8px;
background: #ff2e72;
color: #fff;
padding: 5px 10px;
font-size: 12px;
font-weight: 700;
border-radius: 8px;
box-shadow: 0 6px 14px rgba(255,46,114,.4);
}

.plan-head {
display: flex;
justify-content: space-between;
align-items: flex-end;
margin-bottom: 10px;
color: #e0e0ee;
}
.plan-name {
font-size: 20px;
font-weight: 700;
color: #e0e0ee;
}
.plan-price {
font-size: 32px;
font-weight: 700;
color: #aee2ff;
}
.plan-currency { font-size: 14px; color: #9ac9ff; margin-right: 2px; }
.plan-term { font-size: 13px; color: white; margin-left: 3px; }

.plan-features {
list-style: none;
padding: 0;
margin-bottom:0 !important;
margin: 14px 0 18px;
flex-grow: 1;
color: #e0e0ee;
}
.plan-features li {
display: flex;
align-items: center;
gap: 8px;
margin: 8px 0;
font-size: 16px !important;
color: #e0e0ee !important;
}
.plan-features i {
color: #00e0ff;
font-size: 12px;
}

.plan-choose {
width: 100%;
border: none;
border-radius: 8px;
padding: 10px 0;
font-weight: 700;
cursor: pointer;
color: #fff;
background: linear-gradient(90deg,#4b3f72,#7253ff);
transition: 0.3s;
}
.plan-card.featured .plan-choose {
background: #ff2e72;
}
.plan-card[data-plan="enterprise"] .plan-choose {
background: linear-gradient(90deg,#0a3b91,#16a0b5);
}
.plan-choose:hover {
filter: brightness(1.1);
transform: translateY(-2px);
}
.plan-choose.is-current {
background: #555 !important;
color: #ccc !important;
cursor: default;
pointer-events: none;
}

.plan-actions {
margin-top: 20px;
display: flex;
justify-content: flex-end;
}
.plan-cancel {
background: rgba(255,255,255,0.1);
color: #ccc;
border: 1px solid rgba(255,255,255,0.15);
padding: 8px 16px;
border-radius: 8px;
font-size: 13px;
transition: 0.25s;
}
.plan-cancel:hover {
background: rgba(255,255,255,0.2);
color: #fff;
}
.contact-text {
font-size: 16px;
color: #aee2ff;
font-weight: 600;
letter-spacing: 0.4px;
background: linear-gradient(90deg,#00e0ff,#7b61ff);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}

/* -------------------------
CTA HERO SECTION
------------------------- */
.cta-hero {
padding: 130px 20px 70px;
text-align: center;
position: relative;
overflow: hidden;
}

@keyframes twinkle {
0% { transform: translateY(0px); }
100% { transform: translateY(-40px); }
}

.cta-title {
font-size: 48px;
line-height: 1.4;
margin-bottom: 22px;
font-weight: 400;
color: #ffffff;
}

.cta-gradient {
background: linear-gradient(90deg, #ff7a00, #ff4e00);
-webkit-background-clip: text;
color: transparent;
font-weight: 500;
}

.cta-text {
font-size: 20px;
color: #cfd9e6;
line-height: 1.8;
margin-bottom: 50px;
}

.cta-buttons {
display: flex;
justify-content: center;
gap: 24px;
margin-bottom: 36px;
}

/* Primary orange button */
.cta-btn-primary {
background: #ff6a00;
color: #fff;
padding: 14px 32px;
border-radius: 12px;
font-size: 18px;
font-weight: 600;
text-decoration: none;
box-shadow: 0 6px 20px rgba(255, 100, 0, 0.35);
transition: 0.25s;
width:220px;
}
.cta-btn-primary:hover {
transform: translateY(-3px);
box-shadow: 0 10px 26px rgba(255, 100, 0, 0.45);
}

/* Secondary outline button */
.cta-btn-secondary {
border: 1px solid #00bcd4;
padding: 14px 32px;
border-radius: 12px;
color: white;
font-size: 18px;
font-weight: 600;
text-decoration: none;
transition: 0.25s;
background: rgba(0, 200, 255, 0.5);
width:220px;
}
.cta-btn-secondary:hover {
background: rgba(0, 200, 255, 0.8);
transform: translateY(-3px);
}

.cta-sub {
margin-top: 20px;
font-size: 16px;
color: #c5d4e0;
letter-spacing: 0.5px;
}


/* レスポンシブ */
@media (max-width: 768px) {
.cta-title { font-size: 34px;margin-top:-100px !important }
.cta-text { font-size: 18px; }
.cta-buttons { flex-direction: column; }
}

.iziModal.isAttached {
    border-radius: 12px !important;
}
/* ── モーダル全体を少し背高に ───────────────────────── */
#upgrade-modal .iziModal-content{ min-height: 570px; }   /* ←ここで縦を稼ぐ */
@media (max-width: 880px){
    #upgrade-modal .iziModal-content{ min-height: 520px; }
}

/* ヘッダを黒やめ → ネイビー系グラデ */
#upgrade-modal .iziModal-header{
    background: linear-gradient(90deg,#233045 0%, #2b3f63 100%) !important;
    border-bottom: 1px solid rgba(255,255,255,.06);
}
#upgrade-modal .iziModal-header-title{ color:#f2f6ff !important; }

.upgrade-wrap{
    height:460px;
    padding:8px 18px 28px 18px;
}
/* ── モーダル内レイアウト ──────────────────────────── */
.plan-grid{
    display:grid; gap:22px;
    grid-template-columns: repeat(3, 1fr);
    align-items: stretch;
    height:460px;
}
.plan-card{
    position:relative;
    background:#f0f8ff;                 /* 深いフォレスト（黒じゃない） */
    color:#464846 !important;
    border:1px solid #a8aaa8;
    border-radius:12px;
    padding:10px 18px 16px 18px;
    box-shadow:0 10px 30px rgba(0,0,0,0.18);
    transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
    height:100%;
}
/* Business だけネイビー面（おすすめ感） */
.plan-card.featured{
    background:#e6e6fa;                 /* ネイビー */
    border:1px solid #a8aaa8;
    box-shadow:0 14px 34px rgba(45,75,140,.22);
}
.plan-card:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 36px rgba(0,0,0,0.28);
    border-color:#3c5a49;
}

.plan-ribbon{
    position:absolute; top:-20px; right:-8px;
    background:#ff2e72; color:#fff;
    padding:6px 10px; border-radius:8px;
    font-weight:800; font-size:12px; letter-spacing:.3px;
    box-shadow:0 6px 16px rgba(255,46,114,.3);
}

.plan-head{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:10px; }
.plan-name{ font-size:20px; font-weight:800; letter-spacing:.3px; }
.plan-price{ font-size:28px; font-weight:800; }
.plan-currency{ font-size:16px; opacity:.9; margin-right:2px; }
.plan-term{ font-size:12px; margin-left:4px; opacity:.75; }

.plan-features{ list-style:none; padding:0; margin:12px 0 18px; }
.plan-features li{ display:flex; align-items:center; gap:8px; margin:10px 0; font-size:14px; color:#464846;; }
.plan-features i{ font-size:12px; }

/* ボタン色：Starter=フォレスト、Business=アクセント、Enterprise=ティール */
.plan-choose{
    width:100%; border:none; border-radius:12px; padding:12px 0;
    font-weight:800; cursor:pointer;
}
.plan-card[data-plan="starter"] .plan-choose{ background:#2e4638; color:#eafff3; }
.plan-card[data-plan="starter"] .plan-choose:hover{ background:#365343; }

.plan-card.featured .plan-choose{ background:#ff2e72; color:#fff; }
.plan-card.featured .plan-choose:hover{ filter:brightness(1.06); }

.plan-card[data-plan="enterprise"] .plan-choose{ background:#1f5b5f; color:#e0ffff; }
.plan-card[data-plan="enterprise"] .plan-choose:hover{ background:#23666b; }

.plan-actions{ display:flex; justify-content:flex-end; margin-top:20px; }
.plan-cancel{
    border:1px solid #464946; background:#464946; color:#eee; padding:8px 16px;
    border-radius:10px; cursor:pointer;
    font-size: 13px;
    margin-top:6px;
}

@media (max-width: 880px){
    .upgrade-wrap{ height:auto; padding-bottom:36px; }
    .plan-grid{
    grid-template-columns: 1fr;
    height:auto;
    }
    .plan-card{ height:auto; }
}

/* 背面動画を最背面へ */
#bgVideo {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    object-fit: cover;
    z-index: -9999;
}

/* 料金セクション透明化 */
.pricing-section {
    background: transparent !important;
}

/* カードを上に置く */
.plan-card {
    position: relative;
    z-index: 10;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    backdrop-filter: blur(22px) saturate(160%);
    -webkit-backdrop-filter: blur(22px) saturate(160%);
    border-radius: 18px;
    box-shadow: 0 6px 26px rgba(0,0,0,0.3);
}

/* ▼ スマホでカードを2列に強制する（対象プラットフォーム／導入企業） */
@media (max-width: 768px) {

.platforms-grid,
.clients-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
    max-width: 100% !important;
}

.platforms-card{
    width: 77% !important;
    height: 50px !important;
}

.client-card {
    width: 88% !important;
    height: 94px !important;
}

.platforms-card img {
    max-height: 40px !important;
}

.platforms-card .gemini {
    max-height: 65px !important;
}

.platforms-card .grok {
    max-height: 48px !important;
}

.platforms-card .claude {
    max-height: 30px !important;
}

.client-card img{
    max-height: 80px !important;
}

/* ラベルが潰れないように調整 */
.client-card div label {
    font-size: 10px !important;
    bottom: 6px !important;
}
}

/* FAQ */
.faq-section {
  max-width: 840px;
  margin: 160px auto 0px;
  padding: 0 20px;
  font-family: 'Zen Maru Gothic', sans-serif;
}

.faq-title {
  font-size: 32px;
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 28px;
  text-align: center;
  display: inline-block;
  align-items: center;
}

.faq-left {
  display: flex;
  align-items: center;  /* 真ん中揃え */
  gap: 14px;
}

.faq-text {
  line-height: 40px;  /* 画像の高さと合わせる */
  display: flex;
  align-items: center;
}


.faq-item {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  margin-bottom: 14px;
  overflow: hidden;
}

.faq-question {
  width: 100%;
  text-align: left;
  padding: 16px 18px;
  font-size: 21px;
  background: none;
  border: none;
  color: #d5e0ed;
  cursor: pointer;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: space-between;
}

.faq-question:hover {
  color: #ffffff;
}

.faq-icon {
  font-size: 20px;
  transition: transform 0.25s ease;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  background: rgba(255, 170, 200, 0.14);
  transition: max-height 0.35s ease;
}

.faq-answer p {
  padding: 14px 18px 18px;
  line-height: 1.7;
  font-size: 16px;
  color: #c8d8e8;
  text-align: left;
}

.faq-img{
  width:72px !important;
  margin-top:-8px;
  opacity: 0.9;
}
/* 開いているときのアイコン回転 */
.faq-item.open .faq-icon {
  transform: rotate(45deg);
}
@media (max-width: 768px) {
  .faq-section {
    margin: 0px auto 50px;
    padding: 0 20px;
    font-family: 'Zen Maru Gothic', sans-serif;
  }
  .faq-img{
    width:50px !important;
    margin-top:-4px;
    opacity: 0.9;
  }
  .faq-text {
    font-size: 17px;
    line-height: 1.6; 
  }
}
