.flowless-page {
    background: transparent;
}

/* HERO */
.flowless-hero {
    position: relative;
    min-height: 100vh;
    padding: 10rem 8% 8rem;

    display: grid;
    grid-template-columns: 1fr 0.9fr;
    gap: 6rem;
    align-items: center;

    overflow: hidden;
}
.flowless-hero {
    position: relative;
    isolation: isolate;
}
.flowless-kicker {
    margin-bottom: 1.5rem;

    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.38em;
    color: var(--color-1);
}

.flowless-hero-title {
    margin-bottom: 2.5rem;

    font-size: clamp(3.4rem, 8vw, 8rem);
    line-height: 0.9;
    font-weight: 900;
    letter-spacing: -0.07em;
}

.flowless-hero-lead {
    margin-bottom: 2rem;

    font-family: 'Noto Serif JP', serif;
    font-size: clamp(1.8rem, 4vw, 3.8rem);
    line-height: 1.45;
    font-weight: 700;
}

.flowless-hero-text {
    max-width: 620px;

    font-size: clamp(1rem, 1.6vw, 1.25rem);
    line-height: 2;
    color: var(--text-soft);
    font-weight: 700;
}

.flowless-hero-visual {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 620px;
    isolation: isolate;
    overflow: visible;
}

.flowless-hero-image-wrap {
    position: relative;
    width: min(115%, 820px);
    display: grid;
    place-items: center;
    transform: translateX(4%);
    border-radius: 3rem;
    overflow: visible;
    cursor: pointer;
}

.flowless-hero-image-wrap::before {
    content: "";
    position: absolute;
    inset: -18%;
    background:
        radial-gradient(circle at 45% 45%, rgba(79,172,254,0.32), transparent 42%),
        radial-gradient(circle at 70% 65%, rgba(240,147,251,0.26), transparent 44%),
        radial-gradient(circle at 30% 70%, rgba(255,255,255,0.75), transparent 38%);
    filter: blur(70px);
    z-index: -2;
    opacity: 0.95;
}

.flowless-hero-image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;

    background:
        linear-gradient(
            135deg,
            rgba(2,6,18,0.22),
            rgba(2,6,18,0.04)
        );

    border-radius: inherit;

    pointer-events: none;

    opacity: 0.9;
    transition: opacity 0.5s ease;
}

.flowless-hero-image {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;

    mix-blend-mode: screen;

    opacity: 0.96;
    filter:
        brightness(0.92)
        contrast(1.08)
        saturate(0.92)
        drop-shadow(0 42px 90px rgba(15,23,42,0.28))
        drop-shadow(0 12px 36px rgba(79,172,254,0.16));

    transform:
        perspective(1000px)
        rotateY(-4deg)
        rotateX(2deg)
        scale(1.04);

    transition:
        transform 0.75s cubic-bezier(0.16, 1, 0.3, 1),
        filter 0.75s cubic-bezier(0.16, 1, 0.3, 1),
        opacity 0.45s ease;
}
.flowless-hero::before {
    backdrop-filter: blur(4px);
}
.flowless-hero-image-wrap:hover {
    z-index: 20;
}

.flowless-hero-image-wrap:hover::after {
    opacity: 0.12;
}

.flowless-hero-image-wrap:hover .flowless-hero-image {
    transform:
        perspective(1000px)
        rotateY(0deg)
        rotateX(0deg)
        scale(1.28);

    filter:
        drop-shadow(0 90px 180px rgba(15,23,42,0.34))
        drop-shadow(0 24px 70px rgba(79,172,254,0.34));
}

.flowless-hero-content {
    transition:
        opacity 0.55s ease,
        transform 0.75s cubic-bezier(0.16, 1, 0.3, 1);
}

.flowless-hero:has(.flowless-hero-image-wrap:hover) .flowless-hero-content {
    opacity: 0.42;
    transform: translateX(-1.5rem);
}
.flowless-hero::before {
    content: "";
    position: absolute;
    inset: 0;

    background:
        linear-gradient(
            135deg,
            rgba(4,10,24,0.92),
            rgba(6,12,32,0.86)
        ),
        url("./assets/images/hero/flowless-bg.png");

    background-size: cover;
    background-position: center;

    opacity: 0;
    transition:
        opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
        transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);

    transform: scale(1.08);

    z-index: -2;
    pointer-events: none;
}
.flowless-hero:has(.flowless-hero-image-wrap:hover)::before {
    opacity: 1;
    transform: scale(1);
}
.flowless-hero:has(.flowless-hero-image-wrap:hover) .flowless-hero-content {
    opacity: 0.72;
    transform: translateX(-12px);
}

.flowless-hero:has(.flowless-hero-image-wrap:hover) .flowless-hero-title,
.flowless-hero:has(.flowless-hero-image-wrap:hover) .flowless-hero-lead,
.flowless-hero:has(.flowless-hero-image-wrap:hover) .flowless-hero-text {
    color: rgba(255,255,255,0.92);
}
.flowless-hero-image {
    mask-image:
        radial-gradient(circle at center,
        rgba(0,0,0,1) 58%,
        rgba(0,0,0,0.82) 76%,
        transparent 100%);

    -webkit-mask-image:
        radial-gradient(circle at center,
        rgba(0,0,0,1) 58%,
        rgba(0,0,0,0.82) 76%,
        transparent 100%);
}
.flowless-hero-title {
    text-shadow:
        0 0 18px rgba(79,172,254,0.12),
        0 0 40px rgba(240,147,251,0.08);
}
.flowless-hero:has(.flowless-hero-image-wrap:hover) .header-cta {
    background:
        linear-gradient(
            135deg,
            rgba(255,255,255,0.16),
            rgba(255,255,255,0.08)
        );

    border: 1px solid rgba(255,255,255,0.16);

    backdrop-filter: blur(20px);

    color: white;
}
@media (max-width: 900px) {

    .flowless-hero {
        min-height: auto;

        grid-template-columns: 1fr;
        gap: 4rem;

        padding:
            8.5rem 6%
            5rem;

        text-align: center;
    }

    .flowless-hero-content {
        display: flex;
        flex-direction: column;
        align-items: center;

        margin: 0 auto;
    }

    .flowless-kicker {
        margin-bottom: 1.2rem;

        font-size: 0.64rem;
        letter-spacing: 0.34em;
    }

    .flowless-hero-title {
        margin-bottom: 2rem;

        font-size: clamp(3.2rem, 15vw, 5.2rem);
        line-height: 0.9;
        letter-spacing: -0.08em;
    }

    .flowless-hero-lead {
        margin-bottom: 1.8rem;

        font-size: clamp(1.9rem, 8vw, 2.8rem);
        line-height: 1.45;
    }

    .flowless-hero-text {
        max-width: 30ch;

        margin: 0 auto;

        font-size: 0.98rem;
        line-height: 2;

        text-align: center;
    }

    .flowless-hero-visual {
        min-height: auto;
    }

    .flowless-hero-image-wrap {
        width: 100%;

        transform: none;
    }

    .flowless-hero-image {
        transform:
            perspective(1000px)
            rotateY(0deg)
            rotateX(0deg)
            scale(1.02);
    }
}

@media (max-width: 430px) {

    .flowless-hero {
        padding:
            7.5rem 6%
            4.5rem;
    }

    .flowless-hero-title {
        font-size: clamp(2.8rem, 15vw, 4.4rem);

        line-height: 0.92;
        letter-spacing: -0.085em;
    }

    .flowless-hero-lead {
        font-size: clamp(1.7rem, 8vw, 2.3rem);

        line-height: 1.5;
    }

    .flowless-hero-text {
        max-width: 28ch;

        font-size: 0.92rem;
        line-height: 1.9;
    }
}
/* =========================
   WORKS HERO RESPONSIVE
========================= */


/* COMMON SECTION */
.flowless-section-head {
    max-width: 860px;

    margin:
        0 auto
        5rem;

    text-align: center;
}


.flowless-section-head h2,
.solution-copy h2,
.ai-copy h2,
.final-cta-inner h2 {

    font-size: clamp(3.6rem, 6vw, 6.4rem);

    line-height: 1.02;
    font-weight: 900;
    letter-spacing: -0.075em;
}

.flowless-problem,
.flowless-map,
.flowless-value {
    position: relative;
    padding: 12rem 8%;
}

/* PROBLEM */
.flowless-section-lead {
    margin:
        2rem auto 0;

    max-width: 680px;

    font-size: clamp(0.98rem, 1.3vw, 1.12rem);

    line-height: 2;
    text-align: center;

    color: var(--text-soft);
    font-weight: 700;
}

.flowless-problem {
    position: relative;
    padding: 12rem 8%;
    overflow: hidden;
}

.flowless-problem::before {
    content: "";
    position: absolute;
    inset: 8%;

    background:
        radial-gradient(circle at 20% 30%, rgba(240,147,251,0.18), transparent 34%),
        radial-gradient(circle at 80% 70%, rgba(79,172,254,0.14), transparent 38%);

    filter: blur(50px);
    z-index: -1;
    pointer-events: none;
}

.problem-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.6rem;
}

.problem-card {
    position: relative;
    min-height: 340px;
    padding: 2.4rem;

    display: flex;
    flex-direction: column;
    justify-content: space-between;

    border-radius: 2.4rem;

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,0.76),
            rgba(255,255,255,0.42)
        );

    border: 1px solid rgba(255,255,255,0.75);

    box-shadow:
        0 34px 90px rgba(15,23,42,0.06),
        inset 0 1px 0 rgba(255,255,255,0.8);

    backdrop-filter: blur(22px);

    overflow: hidden;

    transition:
        transform 0.65s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.45s ease,
        background 0.45s ease;

        text-align: center;
    align-items: center;
}

.problem-card::before {
    content: "";
    position: absolute;
    inset: -1px;

    background:
        radial-gradient(circle at 22% 18%, rgba(79,172,254,0.22), transparent 34%),
        radial-gradient(circle at 90% 90%, rgba(240,147,251,0.16), transparent 34%);

    opacity: 0;
    transition: opacity 0.45s ease;
    pointer-events: none;
}

.problem-card:hover {
    transform: translateY(-14px);
    box-shadow:
        0 44px 120px rgba(79,172,254,0.14),
        inset 0 1px 0 rgba(255,255,255,0.9);
}

.problem-card:hover::before {
    opacity: 1;
}

.problem-card span,
.problem-card h3,
.problem-card p,
.problem-card small {
    position: relative;
    z-index: 1;
}

.problem-card span {
    display: block;

    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 0.18em;
    color: var(--color-1);
}

.problem-card h3 {
    margin-top: 3rem;
    margin-bottom: 1.4rem;

    font-size: clamp(1.8rem, 2.8vw, 3.2rem);
    line-height: 1.02;
    font-weight: 900;
    letter-spacing: -0.06em;

    text-align: center;
}

.problem-card p {
    font-size: 1rem;
    line-height: 1.9;
    color: var(--text-soft);
    font-weight: 700;
}

.problem-card small {
    margin-top: 2rem;

    color: rgba(17,17,17,0.28);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}
@media (max-width: 900px) {

    .flowless-problem {
        padding: 7rem 6%;
    }

.flowless-section-head {
    width: 100%;
    max-width: 100%;

    margin: 0 auto 4rem;

    text-align: center;
    overflow: visible;
}

.flowless-section-head h2 {
    width: fit-content;
    max-width: none;

    margin-left: 50%;

    font-size: clamp(2.35rem, 9.6vw, 3.7rem);
    line-height: 0.98;
    letter-spacing: -0.08em;

    white-space: nowrap;

    transform: translateX(-50%);
}

.flowless-section-head h2 br {
    display: block;
}

.flowless-section-lead {
    max-width: 30ch;

    margin: 1.8rem auto 0;

    font-size: 0.95rem;
    line-height: 1.9;

    text-align: center;
}

    .problem-grid {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }

    .problem-card {

        min-height: auto;

        padding: 2rem 1.8rem;

        border-radius: 2rem;

        text-align: center;
        align-items: center;
    }

    .problem-card span {
        font-size: 0.76rem;
    }

    .problem-card h3 {

        margin-top: 2rem;
        margin-bottom: 1rem;

        font-size: clamp(1.6rem, 9vw, 2.8rem);

        line-height: 1;
        letter-spacing: -0.08em;

        text-align: center;
    }

    .problem-card p {

        max-width: 26ch;

        font-size: 0.92rem;
        line-height: 1.85;

        text-align: center;
    }

    .problem-card small {

        margin-top: 1.6rem;

        font-size: 0.68rem;
        letter-spacing: 0.14em;
    }
}

/* SOLUTION */
.flowless-solution {
    position: relative;
    padding: 14rem 8%;
    overflow: hidden;
}

.solution-head {
    max-width: 980px;
    margin: 0 auto 6rem;

    text-align: center;
}

.solution-head h2 {
    font-size: clamp(3.6rem, 6.4vw, 6.6rem);

    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.08em;
}
.solution-head p:not(.flowless-kicker) {

    margin:
        2rem auto 0;

    max-width: 620px;

    text-align: center;

    font-size: 1rem;
    line-height: 1.9;

    color: var(--text-soft);
    font-weight: 700;
}

.solution-stack {
    display: grid;
    gap: 6rem;
}

.solution-work-card {
    position: relative;
}

.solution-work-card:nth-child(2) {
    width: 86%;
    margin-left: auto;
}

.solution-work-card:nth-child(3) {
    width: 92%;
}

.solution-card-image {
    position: relative;
    min-height: 580px;

    border-radius: 2.8rem;
    overflow: hidden;

background:
    linear-gradient(
        145deg,
        rgba(255,255,255,0.56),
        rgba(255,255,255,0.24)
    );

border: 1px solid rgba(255,255,255,0.52);

box-shadow:
    0 24px 70px rgba(15,23,42,0.06),
    inset 0 1px 0 rgba(255,255,255,0.72);

    backdrop-filter: blur(24px);
}

.solution-card-image::before {
    content: "";
    position: absolute;
    inset: -20%;

    background:
        radial-gradient(circle at 30% 20%, rgba(79,172,254,0.18), transparent 34%),
        radial-gradient(circle at 78% 76%, rgba(240,147,251,0.16), transparent 38%);

    filter: blur(60px);
    z-index: -1;
}

.solution-card-text {
    margin-top: 1.8rem;

    text-align: center;
}

.solution-card-label {
    margin-bottom: 0.9rem;

    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-1);
}

.solution-card-text h3 {
    margin-bottom: 1rem;

    font-size: clamp(2.8rem, 4vw, 5rem);
    line-height: 0.95;
    font-weight: 900;
    letter-spacing: -0.07em;
}

.solution-card-text p:not(.solution-card-label) {
    max-width: 620px;

    margin: 0 auto;

    text-align: center;

    font-size: 1rem;
    line-height: 1.9;
    color: var(--text-soft);
    font-weight: 700;
}

/* Card 01 */
.solution-card-image-guest {
    overflow: visible;
}

.solution-guest-shot {
    position: absolute;
      width: min(38%, 290px);
    border-radius: 2rem;

    box-shadow:
        0 34px 90px rgba(15,23,42,0.14),
        0 12px 36px rgba(79,172,254,0.12);
}

.solution-guest-shot-back {
    top: 12%;
    right: 18%;

    opacity: 0.62;

    filter:
        blur(0.6px)
        saturate(0.96)
        brightness(0.98);

    transform: rotate(5deg) scale(0.96);

    animation: solutionFloatBack 7s ease-in-out infinite;
}

.solution-guest-shot-front {
    left: 17%;
    bottom: 5%;

    z-index: 2;

    transform: rotate(-4deg) scale(1.08);
    animation: solutionFloatFront 6s ease-in-out infinite;
}

/* Card 02 */
.solution-card-image-ai {
    display: grid;
    place-items: center;
    background: rgba(5,10,24,0.96);
}

.solution-card-image-ai img {
    width: 100%;
    height: 100%;
    object-fit: cover;

    opacity: 0.96;

    filter:
        brightness(0.98)
        contrast(1.06)
        saturate(1.04);

    animation: aiContextPulse 7s ease-in-out infinite;
}

/* Card 03 */
.solution-card-image-admin {
    overflow: visible;
}

.solution-admin-shot {
    position: absolute;
    border-radius: 1.8rem;

    box-shadow:
        0 34px 90px rgba(15,23,42,0.14),
        0 12px 36px rgba(79,172,254,0.1);
}

.solution-admin-shot-main {
    width: 88%;
    top: 8%;
    left: 6%;

    transform: rotate(1deg);
    animation: adminFloatMain 7s ease-in-out infinite;
}

.solution-admin-shot-detail {
     width: 58%;
    left: 13%;
    bottom: -5%;

    z-index: 3;

    transform: rotate(-2deg);
    animation: adminFloatDetail 6.5s ease-in-out infinite;
}

/* animations */
@keyframes solutionFloatFront {
    0%, 100% {
        transform: rotate(-4deg) translateY(0) scale(1.08);
    }

    50% {
        transform: rotate(-3deg) translateY(-18px) scale(1.1);
    }
}

@keyframes solutionFloatBack {
    0%, 100% {
        transform: rotate(5deg) translateY(0) scale(0.94);
    }

    50% {
        transform: rotate(4deg) translateY(14px) scale(0.96);
    }
}

@keyframes aiContextPulse {
    0%, 100% {
        transform: scale(1);
        filter:
            brightness(0.98)
            contrast(1.06)
            saturate(1.04);
    }

    50% {
        transform: scale(1.025);
        filter:
            brightness(1.06)
            contrast(1.08)
            saturate(1.08);
    }
}

@keyframes adminFloatMain {
    0%, 100% {
        transform: rotate(1deg) translateY(0);
    }

    50% {
        transform: rotate(0.5deg) translateY(-10px);
    }
}

@keyframes adminFloatDetail {
    0%, 100% {
        transform: rotate(-2deg) translateY(0);
    }

    50% {
        transform: rotate(-1deg) translateY(-14px);
    }
}

/* responsive */
@media (max-width: 900px) {
    .flowless-solution {
        padding: 8rem 6%;
    }

    .solution-head {
        margin-bottom: 4rem;
    }

    .solution-stack {
        gap: 4rem;
    }

    .solution-work-card,
    .solution-work-card:nth-child(2),
    .solution-work-card:nth-child(3) {
        width: 100%;
        margin-left: 0;
    }

    .solution-card-image {
        min-height: 560px;
        border-radius: 2.2rem;
    }

    .solution-card-text h3 {
        font-size: clamp(2.1rem, 10vw, 3.4rem);
    }

    .solution-guest-shot {
        width: 62%;
    }

    .solution-guest-shot-back {
        top: 2%;
        right: -2%;
    }

    .solution-guest-shot-front {
        left: -2%;
        bottom: 2%;
    }

    .solution-card-image-ai img {
        width: 116%;
        max-width: none;
    }

    .solution-admin-shot-main {
         width: 74%;
        left: -4%;
        top: 7%;
    }

    .solution-admin-shot-detail {
        width: 94%;
        left: 3%;
        bottom: -2%;
    }
}

@media (max-width: 430px) {
    .solution-card-image {
        min-height: 520px;
        border-radius: 2rem;
    }

    .solution-guest-shot {
        width: 70%;
    }

    .solution-guest-shot-back {
        right: -10%;
    }

    .solution-guest-shot-front {
        left: -10%;
    }

    .solution-card-image-ai img {
        width: 145%;
    }

    .solution-admin-shot-main {
        width: 128%;
        left: -14%;
        top: 8%;
    }

    .solution-admin-shot-detail {
        width: 112%;
        left: -6%;
        bottom: 2%;
    }

    .solution-card-text p:not(.solution-card-label) {
        font-size: 0.9rem;
        line-height: 1.8;
    }
}
/* Card 01 の位置調整 */
.solution-work-card:first-child {
    padding-top: 4rem;
}

.solution-guest-shot-back {
    top: 14%;
}

.solution-guest-shot-front {
    bottom: -2%;
}


/* AI DARK SECTION */
.flowless-ai {
    position: relative;
    padding: 14rem 8%;

    display: grid;
    grid-template-columns: 1fr 0.9fr;
    gap: 6rem;
    align-items: center;

    background:
        linear-gradient(
            180deg,
            rgba(255,255,255,0) 0%,
            rgba(6,12,24,0.92) 18%,
            rgba(5,10,20,0.98) 100%
        );

    color: #fff;
    overflow: hidden;
}

.flowless-ai::before {
    content: "";
    position: absolute;
    inset: 0;

    background:
        radial-gradient(circle at 20% 30%, rgba(79,172,254,0.24), transparent 34%),
        radial-gradient(circle at 80% 70%, rgba(240,147,251,0.16), transparent 40%);

    filter: blur(40px);
    pointer-events: none;
}

.ai-copy,
.ai-context-card {
    position: relative;
    z-index: 1;
}

.ai-copy p {
    margin-top: 2rem;
    color: rgba(255,255,255,0.68);
}

.ai-context-card {
    padding: 2rem;

    border-radius: 2rem;

    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    backdrop-filter: blur(22px);

    box-shadow: 0 30px 100px rgba(0,0,0,0.24);
}

.ai-context-card small {
    display: block;
    margin-bottom: 1rem;

    font-size: 0.7rem;
    font-weight: 900;
    letter-spacing: 0.2em;
    color: var(--color-2);
}

.ai-context-card h3 {
    margin-bottom: 2rem;

    font-size: clamp(1.8rem, 4vw, 3.4rem);
    line-height: 1.1;
    font-weight: 900;
    letter-spacing: -0.06em;
}

.ai-context-card ul {
    list-style: none;
    display: grid;
    gap: 1rem;
}

.ai-context-card li {
    padding: 1rem 1.2rem;

    border-radius: 1rem;

    background: rgba(255,255,255,0.08);

    color: rgba(255,255,255,0.82);
    font-weight: 700;
}

/* =========================
   VALUE
========================= */

.flowless-value {
    position: relative;

    padding: 0 0 12rem;

    overflow: hidden;

    background:
        rgba(3, 8, 20, 0.92)
        url("./assets/images/flowless/flowless-bg.png");

    background-size: cover;
    background-position: center;
}

.flowless-value::before {
    content: "";
    position: absolute;
    inset: 4%;

    background:
        radial-gradient(circle at 18% 30%, rgba(240,147,251,0.16), transparent 36%),
        radial-gradient(circle at 82% 58%, rgba(79,172,254,0.18), transparent 42%);

    filter: blur(60px);
    z-index: -1;
    pointer-events: none;
}

/* VALUE パネルをより没入感ある黒パネルへ */
.value-premium-panel {
    position: relative;

    max-width: 1480px;
    margin: 0 auto;

    padding: 7.5rem 8% 6.5rem;

    border-radius: 0;
    overflow: visible;

    background: transparent;

    box-shadow: none;

    isolation: isolate;
}

/* 背景に巨大Flowless感を足す */
.value-premium-panel::before {
    content: "Flowless";
    position: absolute;
    left: 50%;
    top: 48%;

    transform: translate(-50%, -50%) scale(1.65);

    font-size: clamp(8rem, 18vw, 22rem);
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.09em;

    color: rgba(255,255,255,0.035);

    z-index: -1;
    pointer-events: none;
    white-space: nowrap;
}

/* 光のラインをカード下ではなく横断させる */
.value-premium-panel::after {
    content: "";
    position: absolute;
    left: -8%;
    right: -8%;
    top: 63%;

    height: 2px;

    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(79,172,254,0.18),
            rgba(255,255,255,0.82),
            rgba(240,147,251,0.22),
            transparent
        );

    filter:
        blur(0.6px)
        drop-shadow(0 0 18px rgba(79,172,254,0.42));

    opacity: 0.78;
    z-index: 0;
    pointer-events: none;
}

/* =========================
   HEAD
========================= */

.flowless-value .flowless-section-head {
    position: relative;
    z-index: 2;

    max-width: 920px;

    margin:
        0 auto
        5.5rem;

    text-align: center;
}
.flowless-value .flowless-kicker {
    color: rgba(79,172,254,0.95);
}

.flowless-value .flowless-section-head h2 {
    margin-top: 1rem;

    font-size: clamp(3.2rem, 6.4vw, 7rem);
    line-height: 1.02;
    font-weight: 900;
    letter-spacing: -0.075em;

    color: #ffffff;
}

.flowless-value-lead {
     margin:
        2.2rem auto 0;
    max-width: 660px;

    font-size: clamp(1rem, 1.5vw, 1.2rem);
    line-height: 2;
    color: rgba(255,255,255,0.62);
    font-weight: 700;
}

/* =========================
   GRID
========================= */

.value-grid {
    position: relative;
    z-index: 2;

    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.4rem;
}

/* =========================
   CARD
========================= */

.value-grid {
    position: relative;
    z-index: 2;

    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;

    align-items: stretch;
}

.value-card {
    position: relative;

    min-height: 370px;
    padding: 2.7rem;

    border-radius: 2.8rem;

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,0.04),
            rgba(255,255,255,0.015)
        );

    border: 1px solid rgba(255,255,255,0.06);

    box-shadow:
        0 18px 40px rgba(0,0,0,0.08);

    backdrop-filter: blur(10px);

    overflow: hidden;

    opacity: 0.22;

    transition:
        transform 0.8s cubic-bezier(0.16, 1, 0.3, 1),
        opacity 0.45s ease,
        border-color 0.45s ease,
        background 0.45s ease,
        box-shadow 0.45s ease,
        backdrop-filter 0.45s ease;
}

/* 中央カードを主役に */
.value-card:nth-child(2) {
    transform: translateY(-0.8rem) scale(1.01);

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,0.075),
            rgba(255,255,255,0.026)
        );

    border-color: rgba(255,255,255,0.1);

    box-shadow:
        0 24px 70px rgba(0,0,0,0.18),
        0 10px 40px rgba(79,172,254,0.06),
        inset 0 1px 0 rgba(255,255,255,0.1);
}

/* 左右は少し奥へ */
.value-card:nth-child(1),
.value-card:nth-child(3) {
    transform: translateY(1.2rem) scale(0.96);
    opacity: 0.92;
}

.value-card:hover {
    transform: translateY(-14px) scale(1.03);

    opacity: 1;

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,0.16),
            rgba(255,255,255,0.06)
        );

    border-color: rgba(255,255,255,0.22);

    box-shadow:
        0 42px 120px rgba(0,0,0,0.34),
        0 18px 70px rgba(79,172,254,0.14);

    backdrop-filter: blur(30px);
}

.value-card:nth-child(2):hover {
    transform: translateY(-3rem) scale(1.07);
}
.value-card p {
  color: rgba(255,255,255,0.88);
}
/* カード内テキスト */
.value-card-num {
    color: rgba(255,255,255,0.42);
}

.value-card-label {
    color: rgba(79,172,254,0.92);
}

.value-card h3 {
    color: rgba(255,255,255,0.98);

    text-shadow:
        0 4px 18px rgba(0,0,0,0.28);
}

.value-card p {
    color: rgba(255,255,255,0.82);
}

/* 左右カード少しだけ見やすく */
.value-card:nth-child(1),
.value-card:nth-child(3) {
    opacity: 0.98;
}

/* 上部コピー */
.flowless-value .flowless-section-head h2 {
    color: rgba(255,255,255,0.98);

    text-shadow:
        0 10px 40px rgba(0,0,0,0.24);
}

.flowless-value-lead {
    color: rgba(255,255,255,0.72);
}
/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px) {
  .value-grid {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }

  .value-card,
  .value-card:nth-child(1),
  .value-card:nth-child(2),
  .value-card:nth-child(3) {
    transform: none;
    opacity: 1;
    min-height: auto;
  }

  .value-card:nth-child(2):hover,
  .value-card:hover {
    transform: translateY(-6px);
  }
}

@media (max-width: 430px) {
    .flowless-value {
        padding: 0 0 8rem;

        background-position: center top;
    }

    .value-premium-panel {
        padding: 5.5rem 6% 4.5rem;

        border-radius: 0;
    }
}


/* =========================
   FINAL CTA
========================= */

.flowless-final-cta {
    position: relative;
    padding: 14rem 8%;

    display: grid;
    place-items: center;

    text-align: center;
    overflow: hidden;

    background:
        radial-gradient(
            circle at 22% 35%,
            rgba(240,147,251,0.13),
            transparent 38%
        ),
        radial-gradient(
            circle at 78% 42%,
            rgba(79,172,254,0.14),
            transparent 42%
        ),
        linear-gradient(
            135deg,
            rgba(255,255,255,0),
            rgba(246,250,255,0.72)
        );

    transition:
        background 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

.flowless-final-cta::before {
    content: "";
    position: absolute;
    inset: 10%;

    background:
        radial-gradient(
            circle at center,
            rgba(79,172,254,0.12),
            transparent 44%
        ),
        radial-gradient(
            circle at 50% 60%,
            rgba(240,147,251,0.1),
            transparent 40%
        );

    filter: blur(70px);
    opacity: 0;
    transform: scale(0.86);

    transition:
        opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
        transform 1s cubic-bezier(0.16, 1, 0.3, 1);

    pointer-events: none;
}

.flowless-final-cta::after {
    content: "Flowless";
    position: absolute;
    left: 50%;
    top: 50%;

    transform: translate(-50%, -50%) scale(1.2);

    font-size: clamp(6rem, 16vw, 18rem);
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.08em;

    color: rgba(17,17,17,0.025);

    opacity: 0;
    pointer-events: none;

    transition:
        opacity 0.9s ease,
        transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.flowless-final-cta:hover {
    background:
        radial-gradient(
            circle at center,
            rgba(79,172,254,0.15),
            transparent 44%
        ),
        radial-gradient(
            circle at 30% 32%,
            rgba(240,147,251,0.16),
            transparent 38%
        ),
        linear-gradient(
            135deg,
            rgba(250,246,255,0.92),
            rgba(238,247,255,0.96)
        );
}

.flowless-final-cta:hover::before {
    opacity: 1;
    transform: scale(1);
}

.flowless-final-cta:hover::after {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.34);
}

.final-cta-inner {
    position: relative;
    z-index: 2;

    max-width: 900px;
}

.final-cta-inner .flowless-kicker {
    margin-bottom: 1.4rem;
}

.final-cta-inner h2 {
    transition:
        transform 0.8s cubic-bezier(0.16, 1, 0.3, 1),
        letter-spacing 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.flowless-final-cta:hover .final-cta-inner h2 {
    transform: translateY(-6px);
    letter-spacing: -0.08em;
}

.final-cta-inner .flowless-cta {
    margin: 3rem auto 0;

    min-width: min(100%, 520px);
    justify-content: space-between;

    transition:
        transform 0.55s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.55s ease,
        background 0.55s ease,
        border-color 0.55s ease;
}

.final-cta-inner .flowless-cta:hover {
    transform: translateY(-8px) scale(1.02);

    background: rgba(255,255,255,0.94);
    border-color: rgba(255,255,255,0.9);

    box-shadow:
        0 28px 80px rgba(15,23,42,0.14),
        0 12px 42px rgba(79,172,254,0.16),
        inset 0 1px 0 rgba(255,255,255,0.9);
}


/* =========================
   RESPONSIVE
========================= */

@media (max-width: 900px) {
    .flowless-hero,
    .flowless-solution,
    .flowless-ai {
        grid-template-columns: 1fr;
        gap: 4rem;
    }

    .flowless-hero {
        padding: 9rem 8% 6rem;
    }

    .flowless-problem,
    .flowless-map,
    .flowless-value,
    .flowless-solution,
    .flowless-ai,
    .flowless-final-cta {
        padding: 8rem 8%;
    }

    .problem-grid,
    .value-grid {
        grid-template-columns: 1fr;
    }

    .flowless-device {
        min-height: 460px;
    }

    .flow-chip-1,
    .flow-chip-2 {
        display: none;
    }

    .flow-map-line {
        flex-direction: column;
    }

    .flow-map-item {
        width: 100%;
    }

    .flowless-final-cta::after {
        font-size: clamp(5rem, 30vw, 10rem);
    }

    .final-cta-inner .flowless-cta {
        width: 100%;
        min-width: 0;
    }
}

@media (max-width: 430px) {
    .flowless-final-cta {
        padding: 7rem 6%;
    }

    .final-cta-inner .flowless-cta {
        padding: 1rem 1.2rem;
    }
}