/* ===== プライバシーポリシーページ専用スタイル ===== */

/* プライバシーポリシーコンテンツ */
.privacy-policy-content {
    padding: 80px 0;
    background: white;
}

.policy-container {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
}

.policy-intro {
    margin-bottom: 50px;
    padding: 30px;
    background: #f8f9fa;
    border-radius: 15px;
    border-left: 5px solid #ff6b6b;
}

.intro-text {
    font-size: 1.1rem;
    color: #333;
    margin: 0;
    font-weight: 500;
}

.policy-section {
    margin-bottom: 50px;
    padding-bottom: 30px;
    border-bottom: 1px solid #e9ecef;
}

.policy-section:last-child {
    border-bottom: none;
}

.policy-heading {
    font-size: 1.6rem;
    color: #ff6b6b;
    margin-bottom: 25px;
    font-weight: 600;
    border-bottom: 3px solid #ff6b6b;
    padding-bottom: 10px;
}

.policy-subheading {
    font-size: 1.3rem;
    color: #333;
    margin: 30px 0 15px 0;
    font-weight: 600;
}

.policy-list {
    margin: 15px 0 25px 0;
    padding-left: 0;
    list-style: none;
}

.policy-list li {
    position: relative;
    padding: 8px 0 8px 25px;
    color: #555;
    line-height: 1.6;
}

.policy-list li::before {
    content: "●";
    position: absolute;
    left: 0;
    top: 8px;
    color: #ff6b6b;
    font-size: 0.8rem;
}

.highlight-box {
    background: linear-gradient(135deg, rgba(255, 107, 107, 0.1), rgba(254, 202, 87, 0.1));
    padding: 25px;
    border-radius: 12px;
    border: 1px solid rgba(255, 107, 107, 0.2);
    margin: 25px 0;
}

.highlight-box h4 {
    color: #ff6b6b;
    margin: 0 0 15px 0;
    font-size: 1.1rem;
    font-weight: 600;
}

.highlight-box p {
    margin: 0;
    color: #333;
    font-weight: 500;
}

.note-box {
    background: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: 10px;
    padding: 20px;
    margin: 20px 0;
}

.note-box p {
    margin: 0 0 10px 0;
    color: #856404;
    font-weight: 600;
}

.note-box ul {
    margin: 10px 0 0 0;
    padding-left: 20px;
    color: #856404;
}

.note-box li {
    margin-bottom: 5px;
}

.contact-info-box {
    background: white;
    border: 2px solid #ff6b6b;
    border-radius: 15px;
    padding: 30px;
    margin: 25px 0;
    box-shadow: 0 5px 20px rgba(255, 107, 107, 0.1);
}

.contact-info-box h4 {
    color: #ff6b6b;
    margin: 0 0 20px 0;
    font-size: 1.2rem;
    font-weight: 600;
    text-align: center;
}

.contact-info-box .mobile-break {
    display: none;
}

.contact-details {
    width: 55%;
    margin: 0 20% 0 25%;
}

.contact-info-box p {
    margin: 8px 0;
    color: #333;
    font-weight: 500;
}

.contact-info-box strong {
    color: #ff6b6b;
    min-width: 80px;
    display: inline-block;
}

.policy-footer {
    margin-top: 60px;
    padding: 30px;
    background: #f8f9fa;
    border-radius: 15px;
    text-align: center;
}

.policy-dates p {
    margin: 5px 0;
    color: #666;
    font-weight: 500;
}

.policy-dates p:last-child {
    margin-top: 20px;
    font-size: 1.1rem;
    color: #ff6b6b;
    font-weight: 600;
}

/* プライバシーポリシーページレスポンシブデザイン */
@media (max-width: 768px) {
    .privacy-policy-content {
        padding: 60px 0;
    }

    .page-description {
        width: 90%;
    }
    
    .policy-container {
        padding: 0 15px;
    }
    
    .policy-intro {
        padding: 20px;
        margin-bottom: 40px;
    }
    
    .intro-text {
        font-size: 1rem;
    }
    
    .policy-heading {
        font-size: 1.4rem;
    }
    
    .policy-subheading {
        font-size: 1.2rem;
        margin: 25px 0 12px 0;
    }
    
    .highlight-box,
    .contact-info-box {
        padding: 20px;
        margin: 20px 0;
    }
    
    .policy-footer {
        padding: 20px;
        margin-top: 40px;
    }
}

@media (max-width: 768px) {
    .contact-details {
        width: 80%;
    }
    
    .contact-info-box strong {
        min-width: 60px;
    }
}

@media (max-width: 480px) {
    .policy-heading {
        font-size: 1.3rem;
    }
    
    .policy-subheading {
        font-size: 1.1rem;
    }
    
    .policy-list li {
        padding: 6px 0 6px 20px;
        font-size: 0.95rem;
    }
    
    .highlight-box,
    .note-box,
    .contact-info-box {
        padding: 15px;
    }
    
    .contact-info-box h4 {
        font-size: 1.0rem;
        line-height: 1.4;
        margin-bottom: 15px;
    }
    
    .contact-info-box .mobile-break {
        display: inline;
    }
    
    .contact-details {
        width: 100%;
        margin: 0;
    }
    
    .contact-info-box p {
        margin: 10px 0;
        font-size: 0.9rem;
        line-height: 1.5;
    }
    
    .contact-info-box strong {
        display: block;
        margin-bottom: 2px;
        min-width: auto;
        color: #ff6b6b;
        font-weight: 600;
    }
    
    .contact-info-box p span {
        display: block;
        margin-left: 0;
        color: #333;
    }
    
    .contact-info-box .address-detail {
        margin-left: 80px; /* strongのmin-widthと同じ値で郵便番号の位置に合わせる */
    }
}