/* life-info-cards.css — 비즈니스 카드, 리스트 아이템, 팝업 광고 */
/* ========================================
   View All Section
======================================== */
.view-all-section {
  padding-top: var(--spacing-8);
  border-top: 1px solid #F0F0F0;
}

.view-all-button {
  display: block;
  width: 100%;
  padding: var(--spacing-5) 0;
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-18);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-600);
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}

.view-all-button:hover {
  background-color: var(--color-gray-50);
  border-color: var(--color-gray-400);
  color: var(--color-gray-800);
}

.view-all-button:active {
  background-color: var(--color-gray-100);
}

/* ========================================
   Responsive (태블릿)
======================================== */
@media (max-width: 1024px) {
  .business-cards {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .group-search {
    width: 250px;
  }
}

/* ========================================
   Responsive (모바일)
======================================== */
@media (max-width: 768px) {
  

  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  .hero-title {
    font-size: var(--font-size-28);
  }
  
  .layout-container {
    padding: 0 var(--spacing-4);
  }
  
  .categories-wrapper {
    padding: var(--spacing-5);
  }
  
  .group-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-3);
  }
  
  .group-search {
    width: 100%;
  }
  
  .business-slider {
    padding: 0 36px;
  }
  
  .slider-arrow {
    width: 32px;
    height: 32px;
  }
  
  .business-cards {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-3);
  }
  
  .card-image {
    height: 120px;
  }
}

@media (max-width: 480px) {
  .business-cards {
    grid-template-columns: 1fr;
  }
}

/* ========================================
   Popup Ad Modal
======================================== */
.popup-modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-4);
  animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.popup-modal {
  position: relative;
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  overflow: hidden;
  width: 90%;
  max-width: 600px;
  animation: slideUp 0.3s ease-out;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.popup-modal-close {
  position: absolute;
  top: var(--spacing-2);
  right: var(--spacing-2);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.9);
  color: var(--color-gray-600);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
  z-index: 10;
  box-shadow: var(--shadow-lg);
}

.popup-modal-close:hover {
  background-color: var(--color-white);
  transform: scale(1.1);
}

.popup-modal-content {
  display: flex;
  flex-direction: column;
}

/* Header */
.popup-modal-header {
  background: linear-gradient(135deg, var(--color-primary) 0%, #0039CC 100%);
  padding: var(--spacing-8);
}

.popup-modal-title {
  font-size: var(--font-size-28);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  margin-bottom: var(--spacing-2);
}

.popup-modal-subtitle {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.9);
}

/* Body */
.popup-modal-body {
  padding: var(--spacing-8);
}

.popup-event-card {
  background: linear-gradient(135deg, #FFF8E1 0%, #FFE082 100%);
  border-radius: var(--radius-xl);
  padding: var(--spacing-6);
  border: 1px solid rgba(255, 184, 0, 0.2);
}

.popup-event-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  margin-bottom: var(--spacing-3);
}

.popup-event-icon {
  width: 48px;
  height: 48px;
  background-color: #FFB800;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.popup-event-emoji {
  font-size: var(--font-size-24);
}

.popup-event-info {
  flex: 1;
}

.popup-event-title {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-bold);
  color: var(--color-gray-900);
  margin-bottom: var(--spacing-1);
}

.popup-event-desc {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-600);
}

.popup-event-benefits {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  margin-bottom: var(--spacing-4);
}

.popup-benefit-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}

.popup-benefit-dot {
  width: 6px;
  height: 6px;
  background-color: #FFB800;
  border-radius: 50%;
  flex-shrink: 0;
}

.popup-benefit-text {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-700);
}

.popup-benefit-highlight {
  font-weight: var(--font-weight-bold);
  color: #FFB800;
}

.popup-event-note {
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-500);
  text-align: center;
}

/* Footer */
.popup-modal-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-4) var(--spacing-8);
  background-color: var(--color-gray-50);
  border-top: 1px solid var(--color-gray-200);
}

.popup-dont-show {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
  cursor: pointer;
  user-select: none;
}

.popup-checkbox {
  width: 16px;
  height: 16px;
  border-radius: 4px;
  border: 1px solid var(--color-gray-300);
  cursor: pointer;
  accent-color: var(--color-primary);
}

.popup-checkbox-label {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-600);
  transition: color 0.2s;
}

.popup-dont-show:hover .popup-checkbox-label {
  color: var(--color-gray-700);
}

.popup-close-text {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-500);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--spacing-2);
  transition: color 0.2s;
}

.popup-close-text:hover {
  color: var(--color-gray-700);
}

/* Responsive - 모바일 */
@media (max-width: 768px) {
  .popup-modal {
    width: 95%;
    max-width: none;
  }
  
  .popup-modal-close {
    width: 32px;
    height: 32px;
    top: var(--spacing-1);
    right: var(--spacing-1);
  }
  
  .popup-modal-close svg {
    width: 16px;
    height: 16px;
  }
  
  .popup-modal-header {
    padding: var(--spacing-4);
  }
  
  .popup-modal-title {
    font-size: var(--font-size-20);
  }
  
  .popup-modal-subtitle {
    font-size: var(--font-size-13);
  }
  
  .popup-modal-body {
    padding: var(--spacing-4);
  }
  
  .popup-event-card {
    padding: var(--spacing-4);
  }
  
  .popup-event-icon {
    width: 40px;
    height: 40px;
  }
  
  .popup-event-emoji {
    font-size: var(--font-size-20);
  }
  
  .popup-event-title {
    font-size: var(--font-size-16);
  }
  
  .popup-event-desc {
    font-size: var(--font-size-12);
  }
  
  .popup-benefit-text {
    font-size: var(--font-size-12);
  }
  
  .popup-event-note {
    font-size: var(--font-size-11);
  }
  
  .popup-modal-footer {
    padding: var(--spacing-3) var(--spacing-4);
  }
  
  .popup-checkbox {
    width: 14px;
    height: 14px;
  }
  
  .popup-checkbox-label,
  .popup-close-text {
    font-size: var(--font-size-12);
  }
}/* life-info.responsive.patch.css (v14.4)
 * - Mobile overflow fixes for hero category overlay & slider paddings
 * - Include after life-info.css + life-info.slider.patch.css
 */

/* Prevent accidental horizontal scroll */
/* body{overflow-x:hidden} 제거 — sticky 파괴. html{overflow-x:clip}이 대신 처리 */
/* body{ overflow-x:hidden; } */
/* Desktop~Tablet: prevent layout overflow by hiding side ads when the layout
 * can no longer fit reliably.
 * - Keep side ads visible on 1440px (user request)
 */
@media (max-width: 1399px){
  .left-ad, .right-ad{ display:none; }
  .layout-container{ justify-content:center; padding-left: 16px; padding-right: 16px; }
  .main-content{ width:100%; max-width: var(--layout-main-content); }
}


/* Desktop~Tablet: hide side ads earlier to prevent overflow on 1366/1440 widths *
 * (160 + 1200 + 160 + gaps + paddings > 1366)
 */
@media (max-width: 768px){
  
  
  .header-actions{ flex: 0 0 auto; margin-left: auto; }
  .search-container{
    order: 10;
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
  }
  

  .main-container{ padding-left: var(--spacing-4); padding-right: var(--spacing-4); }
  .business-slider{ padding-left: 32px; padding-right: 32px; }
}

@media (max-width: 480px){
  /* Hero category overlay: allow horizontal scroll instead of overflow */
  
  
  .hero-categories-center::-webkit-scrollbar{ display:none; }
  
  
  

  /* Slider padding/arrow hit-area */
  .business-slider{ padding: 0 28px; }
  .slider-arrow{ width: 30px; height: 30px; }

  /* Section titles should not overflow */
  .group-title{ font-size: 18px; line-height: 1.2; }
}

@media (max-width: 360px){
  
  
}

