/* =================================================================
   Talk Studio - 발송 가이드 (광고 컴플라이언스) 페이지 전용 스타일
   - default/style.css 위에 얹는 페이지 전용 추가 스타일
   ================================================================= */

/* 정보성 vs 광고성 구분 박스 */
.iva_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
}

.iva_card {
    background: #fff;
    border: 1px solid var(--tdf-border);
    border-radius: var(--tdf-radius);
    padding: 32px 30px;
    box-shadow: var(--tdf-card-shadow);
    transition: transform 0.25s, box-shadow 0.25s;
}

.iva_card:hover {
    transform: translateY(-3px);
    box-shadow: var(--tdf-card-shadow-hover);
}

.iva_card.info {
    border-top: 4px solid #10b981;
}

.iva_card.ad {
    border-top: 4px solid #f59e0b;
}

.iva_top {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 18px;
}

.iva_icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
}

.iva_card.info .iva_icon { background: rgba(16, 185, 129, 0.12); color: #047857; }
.iva_card.ad .iva_icon { background: rgba(245, 158, 11, 0.14); color: #b45309; }

.iva_card h3 {
    font-size: 20px;
    font-weight: 800;
    color: var(--tdf-text);
    letter-spacing: -0.01em;
}

.iva_lead {
    font-size: 14px;
    color: var(--tdf-text-sub);
    line-height: 1.7;
    margin-bottom: 22px;
    padding-bottom: 22px;
    border-bottom: 1px dashed var(--tdf-border);
}

.iva_examples {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.iva_examples li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    color: var(--tdf-text);
    line-height: 1.6;
}

.iva_examples li i {
    flex-shrink: 0;
    margin-top: 2px;
    font-size: 14px;
    color: var(--tdf-accent);
}

.iva_rules {
    margin-top: 24px;
    padding: 14px 18px;
    background: #f8fafc;
    border-radius: var(--tdf-radius-sm);
    font-size: 12px;
    color: var(--tdf-text-sub);
    line-height: 1.6;
}

.iva_rules strong {
    color: var(--tdf-accent);
    font-weight: 800;
}

/* 광고 표기·발송 시간 카드 */
.rule_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.rule_card {
    background: #fff;
    border: 1px solid var(--tdf-border);
    border-radius: var(--tdf-radius);
    padding: 32px 30px;
    box-shadow: var(--tdf-card-shadow);
    text-align: left;
    transition: transform 0.25s, box-shadow 0.25s;
}

.rule_card:hover {
    transform: translateY(-3px);
    box-shadow: var(--tdf-card-shadow-hover);
}

.rule_no {
    display: inline-block;
    font-size: 28px;
    font-weight: 800;
    color: #cbd5e1;
    line-height: 1;
    margin-bottom: 10px;
    letter-spacing: -0.02em;
}

.rule_card h3 {
    font-size: 18px;
    font-weight: 800;
    color: var(--tdf-text);
    margin-bottom: 10px;
    letter-spacing: -0.01em;
}

.rule_card p {
    font-size: 13px;
    color: var(--tdf-text-sub);
    line-height: 1.6;
    margin-bottom: 16px;
}

.rule_sample {
    padding: 14px 18px;
    background: #f8fafc;
    border-left: 3px solid var(--tdf-accent);
    border-radius: 6px;
    font-size: 12px;
    color: #334155;
    line-height: 1.6;
    font-family: 'Menlo', 'Courier New', monospace;
}

/* 처벌 사례 박스 */
.fines_box {
    background: linear-gradient(135deg, rgba(254, 226, 226, 0.5) 0%, rgba(254, 243, 199, 0.4) 100%);
    border: 1px solid rgba(217, 119, 6, 0.25);
    border-radius: var(--tdf-radius);
    padding: 36px 40px;
}

.fines_head {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 22px;
}

.fines_head i {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: rgba(217, 119, 6, 0.18);
    color: #b45309;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
}

.fines_head h3 {
    font-size: 22px;
    font-weight: 800;
    color: #78350f;
    letter-spacing: -0.01em;
}

.fines_list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.fines_list li {
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(217, 119, 6, 0.18);
    border-radius: var(--tdf-radius-sm);
    padding: 18px 20px;
}

.fines_list h4 {
    font-size: 13px;
    font-weight: 800;
    color: #78350f;
    margin-bottom: 8px;
}

.fines_list .fines_amount {
    display: block;
    font-size: 22px;
    font-weight: 800;
    color: #b45309;
    line-height: 1;
    margin-bottom: 6px;
    letter-spacing: -0.02em;
}

.fines_list p {
    font-size: 12px;
    color: #92400e;
    line-height: 1.5;
}

/* 체크리스트 박스 */
.checklist_box {
    background: #fff;
    border: 1px solid var(--tdf-border);
    border-radius: var(--tdf-radius);
    padding: 40px 44px;
    box-shadow: var(--tdf-card-shadow);
}

.checklist_box h3 {
    font-size: 22px;
    font-weight: 800;
    color: var(--tdf-text);
    margin-bottom: 24px;
    letter-spacing: -0.01em;
}

.checklist_items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}

.checklist_items li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 20px;
    background: #f8fafc;
    border-radius: var(--tdf-radius-sm);
    font-size: 14px;
    color: var(--tdf-text);
    line-height: 1.55;
}

.checklist_items li i {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(16, 185, 129, 0.15);
    color: #047857;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    margin-top: 1px;
}

.checklist_items li strong {
    color: var(--tdf-accent);
    font-weight: 800;
}

@media screen and (max-width: 1023px) {
    .iva_grid { grid-template-columns: 1fr; gap: 16px; }
    .iva_card { padding: 26px 24px; }
    .rule_grid { grid-template-columns: repeat(1, 1fr); gap: 16px; }
    .fines_list { grid-template-columns: 1fr; }
    .fines_box { padding: 28px 26px; }
    .checklist_box { padding: 30px 28px; }
    .checklist_items { grid-template-columns: 1fr; }
}

@media screen and (max-width: 767px) {
    .iva_card { padding: 22px 20px; }
    .iva_card h3 { font-size: 17px; }
    .rule_card { padding: 24px 22px; }
    .fines_head h3 { font-size: 18px; }
    .fines_list h4 { font-size: 12px; }
    .fines_list .fines_amount { font-size: 18px; }
    .checklist_box h3 { font-size: 18px; }
    .checklist_items li { font-size: 13px; padding: 14px 16px; }
}
