@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD (Granvalue)
    Theme URI: https://granvalue.jp/
    Description: 株式会社グランバリュー 公式サイト用 SWELL子テーマ
    Version: 1.0.0
    Author: Granvalue Inc.
    Author URI: https://granvalue.jp/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* ==========================================================================
   0. Design Tokens
   ========================================================================== */
:root {
    --gv-navy-900: #051438;
    --gv-navy-800: #0A1F5C;
    --gv-navy-700: #112C7A;
    --gv-blue-600: #1E5FBF;
    --gv-blue-500: #3A7EDB;
    --gv-blue-400: #5FA3E5;
    --gv-blue-200: #BFDCF5;
    --gv-blue-50:  #EAF3FC;
    --gv-white:    #FFFFFF;
    --gv-bg:       #F7F9FD;
    --gv-ink:      #0F172A;
    --gv-ink-2:    #334155;
    --gv-mute:     #64748B;
    --gv-line:     #E5EAF2;

    --gv-shadow-sm: 0 2px 8px rgba(10,31,92,.06);
    --gv-shadow-md: 0 10px 30px rgba(10,31,92,.10);
    --gv-shadow-lg: 0 20px 50px rgba(10,31,92,.18);

    --gv-radius: 14px;
    --gv-radius-lg: 22px;

    --gv-font-jp: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
    --gv-font-en: "Inter", "Montserrat", "Helvetica Neue", Arial, sans-serif;

    --gv-maxw: 1180px;
    --gv-header-h: 76px;
}

body {
    font-family: var(--gv-font-jp);
    color: var(--gv-ink);
    background: var(--gv-white);
    -webkit-font-smoothing: antialiased;
    letter-spacing: .02em;
}
.gv-en { font-family: var(--gv-font-en); letter-spacing: .08em; }
.l-container { max-width: var(--gv-maxw); }
a { color: var(--gv-blue-600); }
a:hover { color: var(--gv-navy-800); }

/* Header */
.l-header {
    background: rgba(255,255,255,.88) !important;
    -webkit-backdrop-filter: saturate(180%) blur(10px);
    backdrop-filter: saturate(180%) blur(10px);
    border-bottom: 1px solid rgba(10,31,92,.06);
}
.l-header.-top-visible { background: rgba(255,255,255,.72) !important; }
.c-gnav a { font-weight: 600; letter-spacing: .05em; color: var(--gv-navy-800); }
.c-gnav a:hover { color: var(--gv-blue-600); }
.c-gnav .gv-contact-btn > a,
.c-gnav .menu-item.gv-contact-btn > a {
    background: linear-gradient(135deg, var(--gv-blue-600), var(--gv-navy-800));
    color: #fff !important;
    padding: .65em 1.4em !important;
    border-radius: 999px;
    box-shadow: var(--gv-shadow-sm);
    transition: transform .25s ease, box-shadow .25s ease;
}
.c-gnav .gv-contact-btn > a:hover { transform: translateY(-2px); box-shadow: var(--gv-shadow-md); }

/* Hero */
.gv-hero {
    position: relative;
    min-height: 92vh;
    overflow: hidden;
    background: radial-gradient(1200px 600px at 70% -10%, rgba(95,163,229,.35), transparent 60%),
                radial-gradient(900px 500px at 10% 110%, rgba(30,95,191,.25), transparent 65%),
                linear-gradient(180deg, #030B26 0%, #0A1F5C 60%, #102F8E 100%);
    color: #fff;
    display: flex; align-items: center;
}
.gv-hero::before,
.gv-hero::after {
    content: "";
    position: absolute; inset: 0;
    background-image:
        linear-gradient(to right, rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(1100px 600px at 60% 40%, #000 0%, transparent 80%);
    -webkit-mask-image: radial-gradient(1100px 600px at 60% 40%, #000 0%, transparent 80%);
    pointer-events: none;
}
.gv-hero::after {
    background-image: none;
    background: conic-gradient(from 200deg at 80% 20%, rgba(95,163,229,.25), transparent 30%, transparent 70%, rgba(30,95,191,.3));
    mix-blend-mode: screen;
    animation: gv-spin 40s linear infinite;
}
@keyframes gv-spin { to { transform: rotate(1turn); } }
.gv-hero__inner {
    position: relative; z-index: 2;
    width: 100%; max-width: var(--gv-maxw);
    margin: 0 auto; padding: 140px 24px 120px;
}
.gv-hero__eyebrow {
    display: inline-flex; align-items: center; gap: .6em;
    font-family: var(--gv-font-en); letter-spacing: .2em;
    font-size: .82rem; color: var(--gv-blue-200);
    padding: .4em 1em; border: 1px solid rgba(191,220,245,.35); border-radius: 999px;
    backdrop-filter: blur(4px);
}
.gv-hero__title {
    font-size: clamp(2.2rem, 5.2vw, 4.4rem);
    font-weight: 800; line-height: 1.22;
    margin: 28px 0 20px; letter-spacing: .02em;
}
.gv-hero__title .gv-gradient-text {
    background: linear-gradient(90deg, #BFDCF5 0%, #5FA3E5 40%, #3A7EDB 70%, #FFFFFF 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.gv-hero__lead {
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 2; color: rgba(255,255,255,.86); max-width: 760px;
}
.gv-hero__cta { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 48px; }
.gv-btn {
    display: inline-flex; align-items: center; gap: .6em;
    padding: 1em 2em; border-radius: 999px;
    font-weight: 700; letter-spacing: .05em;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s;
    text-decoration: none;
}
.gv-btn.-primary {
    background: linear-gradient(135deg, #3A7EDB, #0A1F5C);
    color: #fff !important; box-shadow: 0 10px 25px rgba(58,126,219,.4);
}
.gv-btn.-primary:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(58,126,219,.5); }
.gv-btn.-ghost { border: 1.5px solid rgba(255,255,255,.5); color: #fff !important; background: transparent; }
.gv-btn.-ghost:hover { border-color: #fff; background: rgba(255,255,255,.08); }
.gv-btn.-dark { background: var(--gv-navy-800); color: #fff !important; }
.gv-btn.-dark:hover { background: var(--gv-navy-900); transform: translateY(-2px); }

.gv-hero__arrow {
    position: absolute; left: 50%; bottom: 28px; transform: translateX(-50%);
    color: rgba(255,255,255,.6); font-size: 12px; letter-spacing: .4em; z-index: 2;
}
.gv-hero__arrow::after {
    content: ""; display: block; width: 1px; height: 40px; margin: 10px auto 0;
    background: linear-gradient(to bottom, rgba(255,255,255,.7), transparent);
    animation: gv-scroll-line 2s ease-in-out infinite;
}
@keyframes gv-scroll-line {
    0% { transform: scaleY(0); transform-origin: top; }
    50% { transform: scaleY(1); transform-origin: top; }
    51% { transform: scaleY(1); transform-origin: bottom; }
    100% { transform: scaleY(0); transform-origin: bottom; }
}

/* Section common */
.gv-section { padding: clamp(80px, 10vw, 140px) 24px; }
.gv-section.-bg { background: var(--gv-bg); }
.gv-section.-dark { background: linear-gradient(180deg, #051438 0%, #0A1F5C 100%); color: #fff; }
.gv-inner { max-width: var(--gv-maxw); margin: 0 auto; }

.gv-sec-head { display: flex; flex-direction: column; gap: 10px; margin-bottom: 56px; }
.gv-sec-head__en {
    font-family: var(--gv-font-en);
    letter-spacing: .3em; font-size: .82rem;
    color: var(--gv-blue-600); text-transform: uppercase;
}
.gv-section.-dark .gv-sec-head__en { color: var(--gv-blue-400); }
.gv-sec-head__ja {
    font-size: clamp(1.8rem, 3.4vw, 2.6rem);
    font-weight: 800; line-height: 1.3; color: var(--gv-navy-900);
}
.gv-section.-dark .gv-sec-head__ja { color: #fff; }
.gv-sec-head__lead { margin-top: 12px; color: var(--gv-ink-2); line-height: 2; max-width: 720px; }
.gv-section.-dark .gv-sec-head__lead { color: rgba(255,255,255,.82); }

/* About / Stats */
.gv-about { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 860px) { .gv-about { grid-template-columns: 1fr; } }

.gv-about__visual {
    position: relative; aspect-ratio: 4 / 3;
    border-radius: var(--gv-radius-lg);
    background:
        radial-gradient(circle at 30% 30%, rgba(95,163,229,.5), transparent 60%),
        linear-gradient(135deg, #0A1F5C 0%, #1E5FBF 80%);
    overflow: hidden; box-shadow: var(--gv-shadow-lg);
}
.gv-about__visual::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        linear-gradient(to right, rgba(255,255,255,.08) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,.08) 1px, transparent 1px);
    background-size: 32px 32px;
    mask-image: linear-gradient(to bottom right, #000, transparent 80%);
    -webkit-mask-image: linear-gradient(to bottom right, #000, transparent 80%);
}
.gv-about__visual::after {
    content: "GV"; position: absolute; right: -10px; bottom: -20px;
    font-family: var(--gv-font-en);
    font-size: clamp(10rem, 22vw, 18rem);
    font-weight: 800; color: rgba(255,255,255,.08); line-height: 1;
}

.gv-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
@media (max-width: 640px) { .gv-stats { grid-template-columns: 1fr 1fr; } }
.gv-stat {
    background: #fff; padding: 28px 20px; border-radius: var(--gv-radius);
    border: 1px solid var(--gv-line); box-shadow: var(--gv-shadow-sm);
    text-align: center;
}
.gv-section.-dark .gv-stat { background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.1); color: #fff; }
.gv-stat__num {
    font-family: var(--gv-font-en); font-weight: 800;
    font-size: clamp(2rem, 4vw, 2.8rem);
    background: linear-gradient(135deg, #3A7EDB, #0A1F5C);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    line-height: 1;
}
.gv-section.-dark .gv-stat__num {
    background: linear-gradient(135deg, #BFDCF5, #5FA3E5);
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.gv-stat__unit { font-size: .9rem; color: var(--gv-mute); margin-left: .2em; }
.gv-stat__label { margin-top: 10px; font-size: .9rem; color: var(--gv-ink-2); }
.gv-section.-dark .gv-stat__label { color: rgba(255,255,255,.75); }

/* Service cards */
.gv-services { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
@media (max-width: 720px) { .gv-services { grid-template-columns: 1fr; } }

.gv-service {
    position: relative; overflow: hidden;
    padding: 40px 36px 36px;
    background: #fff; border: 1px solid var(--gv-line);
    border-radius: var(--gv-radius-lg);
    transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s;
}
.gv-service:hover { transform: translateY(-6px); box-shadow: var(--gv-shadow-md); border-color: var(--gv-blue-400); }
.gv-service::before {
    content: ""; position: absolute; left: 0; top: 0; width: 0; height: 3px;
    background: linear-gradient(90deg, var(--gv-blue-600), var(--gv-navy-800));
    transition: width .5s ease;
}
.gv-service:hover::before { width: 100%; }
.gv-service__num { font-family: var(--gv-font-en); font-size: 2rem; font-weight: 800; color: var(--gv-blue-200); }
.gv-service__title { margin: 8px 0 14px; font-size: 1.35rem; font-weight: 700; color: var(--gv-navy-900); }
.gv-service__desc { color: var(--gv-ink-2); line-height: 1.9; font-size: .95rem; }
.gv-service__icon {
    position: absolute; right: 28px; top: 28px;
    width: 48px; height: 48px; border-radius: 14px;
    background: linear-gradient(135deg, var(--gv-blue-50), #fff);
    display: flex; align-items: center; justify-content: center;
    color: var(--gv-blue-600);
    box-shadow: inset 0 0 0 1px rgba(58,126,219,.15);
}
.gv-service__icon svg { width: 24px; height: 24px; }

/* Features */
.gv-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 24px; }
@media (max-width: 860px) { .gv-features { grid-template-columns: 1fr; } }
.gv-feature {
    padding: 36px 28px; border-radius: var(--gv-radius);
    background: #fff; border: 1px solid var(--gv-line);
    transition: transform .3s ease;
}
.gv-feature:hover { transform: translateY(-4px); border-color: var(--gv-blue-400); }
.gv-feature__num {
    font-family: var(--gv-font-en);
    font-size: .78rem; letter-spacing: .3em; color: var(--gv-blue-600);
    margin-bottom: 12px;
}
.gv-feature__title {
    font-size: 1.1rem; font-weight: 700; color: var(--gv-navy-900);
    margin-bottom: 12px; line-height: 1.55;
}
.gv-feature__desc { color: var(--gv-ink-2); font-size: .92rem; line-height: 1.9; }

/* Steps */
.gv-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; counter-reset: step; }
@media (max-width: 860px) { .gv-steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .gv-steps { grid-template-columns: 1fr; } }
.gv-step {
    position: relative; padding: 32px 22px 26px;
    border-radius: var(--gv-radius);
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.12);
    counter-increment: step;
}
.gv-step::before {
    content: counter(step, decimal-leading-zero);
    position: absolute; top: 14px; right: 18px;
    font-family: var(--gv-font-en);
    font-size: 1.8rem; font-weight: 800;
    color: rgba(95,163,229,.35);
}
.gv-step__title { font-size: 1.05rem; font-weight: 700; color: #fff; margin-bottom: 10px; }
.gv-step__desc { color: rgba(255,255,255,.76); line-height: 1.85; font-size: .88rem; }

/* CTA */
.gv-cta {
    position: relative; overflow: hidden;
    padding: clamp(70px, 9vw, 110px) 24px;
    background: linear-gradient(120deg, #0A1F5C 0%, #1E5FBF 100%);
    color: #fff; text-align: center;
}
.gv-cta::before {
    content: ""; position: absolute; inset: 0;
    background:
        radial-gradient(500px 300px at 20% 20%, rgba(255,255,255,.12), transparent),
        radial-gradient(500px 300px at 80% 80%, rgba(95,163,229,.25), transparent);
    pointer-events: none;
}
.gv-cta__inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.gv-cta__en { font-family: var(--gv-font-en); letter-spacing: .3em; color: rgba(255,255,255,.7); font-size: .82rem; }
.gv-cta__title { font-size: clamp(1.8rem, 3.4vw, 2.6rem); font-weight: 800; line-height: 1.4; margin: 16px 0 24px; }
.gv-cta__lead { color: rgba(255,255,255,.86); line-height: 2; margin-bottom: 36px; }

/* Company table */
.gv-table {
    width: 100%; border-collapse: collapse; background: #fff;
    border-radius: var(--gv-radius); overflow: hidden;
    box-shadow: var(--gv-shadow-sm);
}
.gv-table th, .gv-table td {
    padding: 22px 28px; border-bottom: 1px solid var(--gv-line);
    text-align: left; vertical-align: top; font-size: .96rem;
}
.gv-table th { width: 28%; font-weight: 700; color: var(--gv-navy-900); background: var(--gv-blue-50); }
.gv-table td { color: var(--gv-ink-2); line-height: 1.9; }
.gv-table tr:last-child th, .gv-table tr:last-child td { border-bottom: 0; }
@media (max-width: 640px) {
    .gv-table th, .gv-table td { display: block; width: 100%; padding: 14px 20px; }
    .gv-table th { background: var(--gv-blue-50); }
}

/* Contact */
.gv-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
@media (max-width: 860px) { .gv-contact-grid { grid-template-columns: 1fr; } }
.gv-contact-card {
    padding: 36px 32px; border-radius: var(--gv-radius);
    background: var(--gv-blue-50); border: 1px solid rgba(30,95,191,.12);
}
.gv-contact-card__label { font-family: var(--gv-font-en); letter-spacing: .2em; color: var(--gv-blue-600); font-size: .78rem; }
.gv-contact-card__val { font-size: 1.4rem; font-weight: 700; color: var(--gv-navy-900); margin-top: 10px; letter-spacing: .04em; }
.gv-contact-card__note { color: var(--gv-ink-2); font-size: .88rem; margin-top: 8px; line-height: 1.8; }

.wpcf7 p { margin: 0 0 18px; }
.wpcf7-form-control-wrap input,
.wpcf7-form-control-wrap textarea,
.wpcf7-form-control-wrap select {
    width: 100%; padding: 14px 16px;
    border: 1.5px solid var(--gv-line); border-radius: 10px;
    background: #fff; font: inherit; color: var(--gv-ink);
    transition: border-color .2s ease, box-shadow .2s ease;
}
.wpcf7-form-control-wrap input:focus,
.wpcf7-form-control-wrap textarea:focus {
    outline: none; border-color: var(--gv-blue-600);
    box-shadow: 0 0 0 3px rgba(58,126,219,.18);
}
.wpcf7 .wpcf7-submit {
    padding: 16px 48px; border-radius: 999px; border: 0;
    background: linear-gradient(135deg, #3A7EDB, #0A1F5C); color: #fff;
    font-weight: 700; letter-spacing: .08em; cursor: pointer;
    box-shadow: 0 10px 25px rgba(58,126,219,.3);
    transition: transform .25s ease, box-shadow .25s ease;
}
.wpcf7 .wpcf7-submit:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(58,126,219,.4); }

/* Footer */
.l-footer {
    background: linear-gradient(180deg, #030B26 0%, #051438 100%) !important;
    color: #fff;
}
.l-footer a { color: rgba(255,255,255,.82); }
.l-footer a:hover { color: #fff; }
.c-fnav { border: 0 !important; }
.c-fnav a { color: rgba(255,255,255,.8) !important; }
.c-copyright { background: transparent !important; color: rgba(255,255,255,.5) !important; font-size: .78rem; letter-spacing: .05em; }

/* Scroll reveal */
.gv-reveal {
    opacity: 0; transform: translateY(24px);
    transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
    will-change: opacity, transform;
}
.gv-reveal.is-in { opacity: 1; transform: none; }
.gv-reveal[data-delay="1"] { transition-delay: .08s; }
.gv-reveal[data-delay="2"] { transition-delay: .16s; }
.gv-reveal[data-delay="3"] { transition-delay: .24s; }
.gv-reveal[data-delay="4"] { transition-delay: .32s; }
.gv-hero .gv-reveal { transform: translateY(18px); transition-duration: 1.1s; }

/* Marquee */
.gv-marquee {
    overflow: hidden; white-space: nowrap;
    border-top: 1px solid rgba(255,255,255,.08);
    border-bottom: 1px solid rgba(255,255,255,.08);
    padding: 18px 0; background: rgba(0,0,0,.2);
}
.gv-marquee__track {
    display: inline-flex; gap: 48px;
    animation: gv-marquee 30s linear infinite;
    font-family: var(--gv-font-en); letter-spacing: .25em; font-size: .82rem;
    color: rgba(255,255,255,.55);
}
@keyframes gv-marquee { to { transform: translateX(-50%); } }

/* News */
.gv-news__list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--gv-line); }
.gv-news__item a {
    display: grid; grid-template-columns: 160px 120px 1fr; gap: 24px;
    padding: 22px 4px; border-bottom: 1px solid var(--gv-line);
    color: var(--gv-ink); text-decoration: none;
    transition: background .2s ease;
}
.gv-news__item a:hover { background: var(--gv-bg); }
.gv-news__date { font-family: var(--gv-font-en); color: var(--gv-mute); font-size: .9rem; }
.gv-news__cat {
    justify-self: start; padding: 3px 10px; border-radius: 999px;
    font-size: .72rem; letter-spacing: .1em;
    background: var(--gv-blue-50); color: var(--gv-blue-600);
}
.gv-news__title { font-size: .98rem; font-weight: 600; line-height: 1.7; }
@media (max-width: 640px) { .gv-news__item a { grid-template-columns: 1fr; gap: 6px; } }

/* Page head */
.gv-pagehead {
    position: relative; padding: 160px 24px 80px;
    background: linear-gradient(120deg, #051438 0%, #102F8E 100%);
    color: #fff; overflow: hidden;
}
.gv-pagehead::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        linear-gradient(to right, rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(900px 400px at 80% 30%, #000 0%, transparent 80%);
    -webkit-mask-image: radial-gradient(900px 400px at 80% 30%, #000 0%, transparent 80%);
}
.gv-pagehead__inner { position: relative; z-index: 1; max-width: var(--gv-maxw); margin: 0 auto; }
.gv-pagehead__en { font-family: var(--gv-font-en); letter-spacing: .3em; color: var(--gv-blue-400); font-size: .85rem; }
.gv-pagehead__ja { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; margin-top: 16px; letter-spacing: .03em; }

/* Utilities */
.gv-bar { display:inline-block; width: 48px; height: 2px; background: var(--gv-blue-600); margin-right: 10px; vertical-align: middle; }
.gv-center { text-align: center; }
.gv-mt-l { margin-top: 56px; }
.gv-mt-s { margin-top: 20px; }
.gv-nowrap { white-space: nowrap; }
.page-template-page-custom .p_title { display: none; }

.gv-footer { padding: 70px 24px 30px; }
.gv-footer__inner {
    max-width: var(--gv-maxw); margin: 0 auto;
    display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 48px;
}
@media (max-width: 860px) { .gv-footer__inner { grid-template-columns: 1fr; gap: 32px; } }
.gv-footer__brand-en {
    font-family: var(--gv-font-en); font-weight: 800; letter-spacing: .08em;
    font-size: 1.6rem; color: #fff;
}
.gv-footer__brand-note { margin-top: 12px; color: rgba(255,255,255,.6); font-size: .85rem; line-height: 1.9; }
.gv-footer__title { color: #fff; font-size: .82rem; letter-spacing: .2em; font-family: var(--gv-font-en); margin-bottom: 18px; }
.gv-footer__list { list-style: none; padding: 0; margin: 0; }
.gv-footer__list li { margin-bottom: 10px; }
.gv-footer__list a { color: rgba(255,255,255,.75); font-size: .9rem; }
.gv-footer__list a:hover { color: #fff; }

/* ==========================================================================
   17. SWELL container overrides (フル幅・余白の最適化)
   ========================================================================== */

/* トップページ：SWELLの内側ラッパーの max-width / padding を無効化 */
.home .l-mainContent,
.home #content,
.home .p-articleThumb,
.page-template-front-page .l-mainContent,
.page-template-page-company .l-mainContent,
.page-template-page-service .l-mainContent,
.page-template-page-contact .l-mainContent,
.page-template-page-privacy .l-mainContent,
.gv-front .l-mainContent,
.gv-front #content {
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* ポストタイトル（SWELL既定のH1 "ホーム" 表示）をフロントと固定ページで非表示 */
.home .p-mainHeader,
.home .p-mainHeader__inner,
.home .post_title,
.home .p_title,
.page-template-front-page .p-mainHeader,
.page-template-page-company .p-mainHeader,
.page-template-page-service .p-mainHeader,
.page-template-page-contact .p-mainHeader,
.page-template-page-privacy .p-mainHeader {
    display: none !important;
}

/* フロントの記事本文ラッパーが margin を持つ場合の対策：フル幅に突破 */
.home .post_content,
.home article,
.page article {
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
}

/* .gv-hero / .gv-section / .gv-cta / .gv-pagehead / .gv-marquee を強制フル幅 */
.gv-hero,
.gv-section,
.gv-cta,
.gv-pagehead,
.gv-marquee {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    box-sizing: border-box;
}

/* モバイル時のヒーロー上下パディング再調整 */
@media (max-width: 640px) {
    .gv-hero__inner { padding: 110px 20px 90px; }
    .gv-section { padding: 72px 20px; }
    .gv-cta { padding: 72px 20px; }
    .gv-pagehead { padding: 120px 20px 60px; }
}

/* ==========================================================================
   18. SWELL header / gnav refinements
   ========================================================================== */

/* グローバルナビ：リンク間隔と下線アニメーション */
.l-header .c-gnav > li { margin: 0 4px; }
.l-header .c-gnav > li > a {
    position: relative;
    padding: 26px 16px !important;
    font-weight: 600;
    font-size: .92rem;
    color: var(--gv-navy-900);
    letter-spacing: .06em;
    transition: color .25s ease;
}
.l-header .c-gnav > li > a::after {
    content: "";
    position: absolute;
    left: 16px; right: 16px; bottom: 18px;
    height: 2px;
    background: linear-gradient(90deg, var(--gv-blue-600), var(--gv-navy-800));
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform .35s cubic-bezier(.2,.8,.2,1);
}
.l-header .c-gnav > li > a:hover { color: var(--gv-blue-600); }
.l-header .c-gnav > li > a:hover::after { transform: scaleX(1); }

/* 「お問い合わせ」メニュー項目 (CSSクラス gv-contact-btn) はボタン化（下線を消す） */
.l-header .c-gnav > li.gv-contact-btn { margin-left: 16px; }
.l-header .c-gnav > li.gv-contact-btn > a {
    padding: 12px 24px !important;
    margin: 16px 0;
    background: linear-gradient(135deg, var(--gv-blue-600), var(--gv-navy-800));
    color: #fff !important;
    border-radius: 999px;
    box-shadow: 0 6px 16px rgba(10,31,92,.22);
}
.l-header .c-gnav > li.gv-contact-btn > a::after { display: none !important; }
.l-header .c-gnav > li.gv-contact-btn > a:hover {
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(10,31,92,.28);
}

/* キャッチコピー（ヘッダー上部のグレーバー）を落ち着いたトーンへ */
.l-header__catchCopy,
.p-catchCopy,
header .catchCopy {
    background: var(--gv-navy-900) !important;
    color: rgba(255,255,255,.72) !important;
    font-size: .78rem !important;
    letter-spacing: .08em;
    padding: 6px 24px !important;
}

/* ロゴ（サイトタイトル）の余白 */
.l-header__logo,
.c-siteLogoWrap {
    padding: 8px 0 !important;
}
.c-siteTitle a {
    font-weight: 800;
    letter-spacing: .04em;
    color: var(--gv-navy-900) !important;
}

/* ==========================================================================
   19. Body pad for fixed header
   ========================================================================== */
/* SWELL は通常 sticky header なので body padding は不要、でもヒーローが画面上端に付くように */
.home .l-content,
.gv-front .l-content { padding-top: 0 !important; }

/* ヒーローが上のキャッチコピーバーの分だけ少しズレないように */
.gv-hero { margin-top: 0 !important; }
