/* ==================================
   RAMEXperts - Product LP Styles
   全ルール body.product-lp スコープ
   既存 style.css との競合を防止
   ================================== */

/* --- Reset: style.css の body/section 上書き --- */
body.product-lp {
    margin: 0;
    padding: 0;
    font-family: 'Noto Sans JP', 'Inter', sans-serif;
    background: #f7f8fb;
    color: #1a1a2e;
    line-height: 1.5;
    overflow-x: hidden;
}
@media (min-width: 960px) {
    body.product-lp {
        overflow-y: hidden;
        height: 100dvh;
        height: 100vh; /* fallback */
    }
    /* dvh が使えるブラウザ */
    @supports (height: 100dvh) {
        body.product-lp { height: 100dvh; }
    }
}

body.product-lp section {
    padding: 0; /* style.css の section { padding:100px 0 } を打消し */
}

/* style-additions.css の promo-delivery-badge を LP では非表示 */
body.product-lp main nav[aria-label="パンくずリスト"]::before {
    display: none;
}

/* --- Header --- */
.plp-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: clamp(38px, 5.2dvh, 54px);
    padding: 0 clamp(20px, 4vw, 48px);
    background: #001f3f;
    color: #fff;
    position: relative;
    z-index: 10;
    flex-shrink: 0;
}
.plp-header__logo {
    font-family: 'Inter', sans-serif;
    font-size: clamp(1.05rem, 1.5vw, 1.25rem);
    font-weight: 800;
    color: #fff;
    text-decoration: none;
    letter-spacing: -0.02em;
}
.plp-header__logo .tm { font-size: 0.7em; vertical-align: super; }
.plp-header__phone {
    display: flex;
    align-items: center;
    gap: 6px;
    color: #fff;
    text-decoration: none;
    font-size: clamp(0.85rem, 1.1vw, 0.95rem);
    font-weight: 600;
}
.plp-header__phone i { font-size: 0.85em; }
.plp-header__phone-sub {
    font-size: 0.7em;
    opacity: 0.75;
    font-weight: 400;
    margin-left: 4px;
}

/* --- Main 2-column --- */
.plp-main {
    display: flex;
    flex-direction: column;
}
@media (min-width: 960px) {
    .plp-main {
        flex-direction: row;
        max-width: 1440px;
        margin: 0 auto;
        /* header + footer 高さを引いた残り */
        height: calc(100dvh - clamp(38px, 5.2dvh, 54px) - clamp(22px, 3dvh, 32px));
        height: calc(100vh - 54px - 32px); /* fallback */
    }
    @supports (height: 100dvh) {
        .plp-main {
            height: calc(100dvh - clamp(38px, 5.2dvh, 54px) - clamp(22px, 3dvh, 32px));
        }
    }
}

/* --- Left column: info --- */
.plp-info {
    padding: clamp(18px, 2.5dvh, 28px) clamp(28px, 4vw, 56px);
    display: flex;
    flex-direction: column;
}
@media (min-width: 960px) {
    .plp-info {
        flex: 0 0 46%;
        overflow-y: auto;
    }
}

/* --- Right column: form --- */
.plp-form-wrap {
    padding: clamp(18px, 2.5dvh, 28px) clamp(28px, 4vw, 56px);
    background: #fff;
}
@media (min-width: 960px) {
    .plp-form-wrap {
        flex: 0 0 54%;
        overflow-y: auto;
        border-left: 1px solid #e4e8ee;
    }
}

/* --- Breadcrumb --- */
.plp-breadcrumb {
    font-size: clamp(0.78rem, 1vw, 0.88rem);
    color: #888;
    margin-bottom: clamp(6px, 0.8dvh, 10px);
}
.plp-breadcrumb a { color: #0074D9; text-decoration: none; }
.plp-breadcrumb a:hover { text-decoration: underline; }

/* --- H1 --- */
.plp-h1 {
    font-size: clamp(1.4rem, 2.8vw, 1.75rem);
    font-weight: 700;
    margin: 0 0 clamp(2px, 0.4dvh, 6px);
    line-height: 1.25;
    overflow-wrap: break-word;
    color: #111;
}
.plp-h1__desc {
    display: block;
    font-size: 0.7em;
    font-weight: 600;
    color: #333;
    margin-top: 2px;
}
.plp-subtitle {
    font-size: clamp(0.9rem, 1.2vw, 1rem);
    color: #555;
    margin: 0 0 clamp(8px, 1.2dvh, 16px);
}

/* --- Badges --- */
.plp-badges {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(4px, 0.6dvh, 8px);
    margin-bottom: clamp(10px, 1.5dvh, 18px);
}
.plp-badge {
    display: inline-block;
    background: #e8f0fe;
    color: #0056b3;
    font-size: clamp(0.78rem, 1vw, 0.88rem);
    font-weight: 600;
    padding: clamp(2px, 0.3dvh, 5px) clamp(8px, 1vw, 12px);
    border-radius: 100px;
    white-space: nowrap;
    line-height: 1.5;
}

/* --- Section titles --- */
.plp-stitle {
    font-size: clamp(1rem, 1.3vw, 1.15rem);
    font-weight: 600;
    margin: clamp(8px, 1.2dvh, 16px) 0 clamp(4px, 0.5dvh, 8px);
    padding-bottom: clamp(2px, 0.3dvh, 4px);
    border-bottom: 2px solid #0074D9;
    color: #111;
}

/* --- Lists --- */
.plp-list {
    margin: 0 0 clamp(8px, 1.2dvh, 16px);
    padding-left: 1.2em;
    font-size: clamp(0.9rem, 1.2vw, 1rem);
    line-height: 1.6;
}
.plp-list li { margin-bottom: clamp(1px, 0.2dvh, 3px); }

.plp-note {
    font-size: clamp(0.82rem, 1vw, 0.9rem);
    color: #777;
    margin-bottom: clamp(6px, 1dvh, 12px);
}

/* --- Credibility footer --- */
.plp-cred {
    margin-top: auto;
    padding-top: clamp(6px, 0.8dvh, 10px);
    border-top: 1px solid #e4e8ee;
    font-size: clamp(0.72rem, 0.9vw, 0.82rem);
    color: #888;
}
.plp-cred p { margin: 0 0 clamp(2px, 0.2dvh, 4px); }
.plp-cred-links {
    display: flex;
    gap: clamp(8px, 1.2vw, 14px);
    flex-wrap: wrap;
}
.plp-cred-links a {
    color: #0074D9;
    text-decoration: none;
    font-size: inherit;
}
.plp-cred-links a:hover { text-decoration: underline; }

/* --- Form heading --- */
.plp-form-heading {
    font-size: clamp(1.1rem, 1.5vw, 1.3rem);
    font-weight: 700;
    color: #0074D9;
    margin: 0 0 clamp(8px, 1.2dvh, 14px);
    text-align: center;
}

/* --- Form container --- */
.plp-form {
    max-width: 560px;
    margin: 0 auto;
}

/* --- Form fields --- */
.plp-field {
    margin-bottom: clamp(8px, 1dvh, 14px);
}
.plp-field label {
    display: block;
    font-size: clamp(0.88rem, 1.1vw, 0.95rem);
    font-weight: 500;
    margin-bottom: clamp(2px, 0.3dvh, 4px);
    color: #333;
}
.plp-field input,
.plp-field select,
.plp-field textarea {
    width: 100%;
    box-sizing: border-box;
    padding: clamp(6px, 0.8dvh, 10px) clamp(8px, 1vw, 12px);
    font-size: clamp(0.92rem, 1.2vw, 1rem);
    border: 1px solid #c5cdda;
    border-radius: 4px;
    font-family: inherit;
    background: #fff;
    color: #111;
    transition: border-color 0.2s;
}
.plp-field input:focus,
.plp-field select:focus,
.plp-field textarea:focus {
    outline: none;
    border-color: #0074D9;
    box-shadow: 0 0 0 2px rgba(0,116,217,0.15);
}
.plp-field textarea {
    resize: none;
    height: clamp(60px, 9dvh, 100px);
    line-height: 1.45;
}

.plp-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(8px, 1vw, 14px);
}

.plp-req {
    color: #d32f2f;
    font-size: 0.72em;
    font-weight: 700;
    margin-left: 2px;
}

/* --- Submit button --- */
.plp-submit {
    display: block;
    width: 100%;
    background: #0074D9;
    color: #fff;
    border: none;
    padding: clamp(10px, 1.5dvh, 16px);
    font-size: clamp(1rem, 1.3vw, 1.1rem);
    font-weight: 700;
    border-radius: 6px;
    cursor: pointer;
    font-family: inherit;
    margin-top: clamp(6px, 0.8dvh, 10px);
    transition: background 0.2s;
    letter-spacing: 0.02em;
}
.plp-submit:hover { background: #005bb5; }
.plp-submit:disabled {
    background: #9dc2e6;
    cursor: not-allowed;
}
.plp-submit i { margin-right: 4px; }

/* --- Success message --- */
.plp-success {
    text-align: center;
    padding: clamp(16px, 3dvh, 32px) 8px;
    color: #1a7f37;
}
.plp-success i {
    font-size: clamp(1.6rem, 4dvh, 2.4rem);
    display: block;
    margin-bottom: 8px;
}
.plp-success p {
    font-size: clamp(0.92rem, 1.4dvh, 1.05rem);
    font-weight: 600;
    margin: 0;
}
.plp-success small {
    display: block;
    margin-top: 4px;
    font-size: clamp(0.78rem, 1.1dvh, 0.88rem);
    color: #555;
    font-weight: 400;
}

/* --- Form privacy note --- */
.plp-form-note {
    font-size: clamp(0.72rem, 0.9vw, 0.78rem);
    color: #999;
    text-align: center;
    margin-top: clamp(6px, 0.7dvh, 8px);
}
.plp-form-note i { margin-right: 3px; }

/* --- Footer --- */
.plp-footer {
    height: clamp(22px, 3dvh, 32px);
    display: flex;
    align-items: center;
    justify-content: center;
    background: #1a1a2e;
    color: #888;
    font-size: clamp(0.65rem, 0.95dvh, 0.75rem);
    flex-shrink: 0;
}

/* ============================
   Mobile (<960px)
   ============================ */
@media (max-width: 959px) {
    body.product-lp {
        overflow-y: auto;
        height: auto;
    }
    .plp-main {
        flex-direction: column;
    }
    .plp-info {
        padding: 16px 18px 12px;
    }
    .plp-form-wrap {
        padding: 16px 18px 22px;
        border-top: 1px solid #e4e8ee;
    }
    .plp-row {
        grid-template-columns: 1fr;
    }
    .plp-field textarea {
        height: 80px;
    }
    .plp-badges {
        gap: 4px;
    }
    .plp-header {
        height: 48px;
    }
    .plp-footer {
        height: 28px;
    }
}
