/* ============================================================
   theme/42 — 온기 펫메모리얼 (반려동물 장례)
   원본 개별 흡수, WEBIS 가상 브랜드로 재구성.
   본문은 Tailwind utility 중심, 본 파일은 예외 보조만 담당.
   ============================================================ */

:root{
  --brand:#c0a062; --brand-dark:#a4844a; --brand-soft:#e7dcc5;
  --taupe:#8b7355; --ink:#26211c; --cream:#f7f3ec;
  /* 무료 이미지 (Unsplash · HTTP 200 확인) */
  --img-hero:url("https://images.unsplash.com/photo-1450778869180-41d0601e046e?auto=format&fit=crop&w=1800&q=80");
  --img-tree:url("https://images.unsplash.com/photo-1425082661705-1834bfd09dca?auto=format&fit=crop&w=1600&q=80");
  --img-cta:url("https://images.unsplash.com/photo-1543466835-00a7907e9de1?auto=format&fit=crop&w=1600&q=80");
}

html{font-family:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;overflow-x:hidden;scroll-behavior:smooth;}
body{word-break:keep-all;overflow-x:hidden;}

/* 컨테이너 — 원본 콘텐츠 폭 ≈ 1200px */
.theme-area{max-width:75rem;margin:0 auto;padding-left:1.25rem;padding-right:1.25rem;}
@media (min-width:768px){.theme-area{padding-left:2rem;padding-right:2rem;}}

/* 스티키 헤더 축소 상태 */
#siteHeader.is-stuck{box-shadow:0 .5rem 1.5rem rgba(38,33,28,.08);}

/* 네비 밑줄 hover */
.nav-link{position:relative;transition:color .2s;}
.nav-link::after{content:"";position:absolute;left:0;bottom:-.5rem;width:0;height:2px;background:var(--brand);transition:width .25s;}
.nav-link:hover{color:var(--brand-dark);}
.nav-link:hover::after{width:100%;}

/* ===== HERO ===== */
.hero{background:var(--ink);}
.hero-bg{position:absolute;inset:0;background:var(--img-hero) center/cover no-repeat;transform:scale(1.04);}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(38,33,28,.62) 0%,rgba(38,33,28,.5) 45%,rgba(38,33,28,.78) 100%);}

/* ===== QUICK NAV CARDS ===== */
.quick-card{background:#fff;border:1px solid rgba(38,33,28,.06);border-radius:1.25rem;padding:1.5rem 1rem;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 1rem 2.5rem rgba(38,33,28,.1);transition:transform .25s,box-shadow .25s;}
.quick-card:hover{transform:translateY(-.35rem);box-shadow:0 1.5rem 3rem rgba(38,33,28,.16);}
.quick-ico{width:3.25rem;height:3.25rem;border-radius:1rem;background:var(--cream);color:var(--brand-dark);display:grid;place-items:center;margin-bottom:.9rem;}
.quick-ico svg{width:1.6rem;height:1.6rem;}
.quick-card b{font-size:1.05rem;font-weight:800;color:var(--ink);}
.quick-card small{margin-top:.25rem;font-size:.78rem;color:rgba(38,33,28,.5);font-weight:600;}

/* ===== COST CALCULATOR ===== */
.calc{background:var(--ink);}
.calc-bg{position:absolute;inset:0;background:var(--img-tree) center/cover no-repeat;}
.calc-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(38,33,28,.9) 0%,rgba(38,33,28,.72) 55%,rgba(38,33,28,.55) 100%);}
.calc-label{display:block;font-size:.9rem;font-weight:800;color:var(--ink);margin-bottom:.6rem;}
.calc-opt{height:2.9rem;border-radius:.7rem;border:1.5px solid #e6e0d4;background:#fff;font-weight:700;font-size:.9rem;color:rgba(38,33,28,.7);transition:all .18s;cursor:pointer;padding:0 .4rem;}
.calc-opt:hover{border-color:var(--brand);color:var(--brand-dark);}
.calc-opt.is-active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 .4rem 1rem rgba(192,160,98,.35);}
.h-13{height:3.25rem;}

/* ===== SERVICE CARDS ===== */
.service-card{background:#fff;border:1px solid rgba(38,33,28,.08);border-radius:1.5rem;padding:1.9rem 1.6rem;display:flex;flex-direction:column;height:100%;transition:transform .25s,box-shadow .25s,border-color .25s;}
.service-card:hover{transform:translateY(-.4rem);box-shadow:0 1.4rem 3rem rgba(38,33,28,.13);border-color:var(--brand-soft);}
.service-ico{width:3.5rem;height:3.5rem;border-radius:1rem;background:var(--cream);color:var(--brand-dark);display:grid;place-items:center;margin-bottom:1.4rem;transition:background .25s,color .25s;}
.service-ico svg{width:1.7rem;height:1.7rem;}
.service-card:hover .service-ico{background:var(--brand);color:#fff;}
.service-card--accent{background:linear-gradient(160deg,#fffaf0,#fff);border-color:var(--brand-soft);}
.service-card h3{font-size:1.4rem;font-weight:900;letter-spacing:-.02em;color:var(--ink);}
.service-card p{margin-top:.85rem;color:rgba(38,33,28,.55);line-height:1.7;font-weight:500;flex:1;}
.service-foot{margin-top:1.4rem;padding-top:1.1rem;border-top:1px solid rgba(38,33,28,.08);display:flex;align-items:center;justify-content:space-between;}
.service-foot b{font-size:1.25rem;font-weight:900;color:var(--brand-dark);}
.service-foot span{display:inline-flex;align-items:center;gap:.25rem;font-weight:800;font-size:.9rem;color:var(--ink);cursor:pointer;transition:color .2s;}
.service-foot span:hover{color:var(--brand-dark);}

/* ===== PROCESS CARDS ===== */
.process-card{position:relative;background:#fff;border:1px solid rgba(38,33,28,.07);border-radius:1.5rem;padding:2rem 1.7rem;transition:transform .25s,box-shadow .25s;overflow:hidden;}
.process-card:hover{transform:translateY(-.35rem);box-shadow:0 1.2rem 2.8rem rgba(38,33,28,.1);}
.process-no{position:absolute;right:1.3rem;top:1.1rem;font-size:2.6rem;font-weight:900;color:var(--brand-soft);opacity:.7;line-height:1;}
.process-ico{width:2.4rem;height:2.4rem;color:var(--brand-dark);}
.process-card h3{margin-top:1.1rem;font-size:1.3rem;font-weight:900;letter-spacing:-.02em;color:var(--ink);}
.process-card p{margin-top:.7rem;color:rgba(38,33,28,.55);line-height:1.7;font-weight:500;}

/* ===== OUR PROMISE (다크) ===== */
.promise{background:linear-gradient(135deg,var(--ink) 0%,#3a322a 100%);}
.promise-card{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:1.5rem;padding:2.2rem 1.8rem;text-align:center;transition:background .25s,transform .25s;}
.promise-card:hover{background:rgba(255,255,255,.08);transform:translateY(-.3rem);}
.promise-no{position:absolute;left:1.6rem;top:1.2rem;font-size:.85rem;font-weight:900;color:var(--brand);letter-spacing:.1em;}
.promise-card svg{margin:0 auto;}
.promise-card h3{margin-top:1.1rem;font-size:1.35rem;font-weight:900;letter-spacing:-.02em;color:#fff;}
.promise-card p{margin-top:.7rem;color:rgba(255,255,255,.7);line-height:1.7;font-weight:500;}

/* ===== PRICING ===== */
.price-card{position:relative;background:#fff;border:1.5px solid rgba(38,33,28,.1);border-radius:1.6rem;padding:2.2rem 1.9rem;display:flex;flex-direction:column;height:100%;transition:transform .25s,box-shadow .25s;}
.price-card:hover{transform:translateY(-.4rem);box-shadow:0 1.4rem 3.2rem rgba(38,33,28,.12);}
.price-card--best{border-color:var(--brand);box-shadow:0 1.4rem 3.5rem rgba(192,160,98,.25);}
@media (min-width:1024px){.price-card--best{transform:scale(1.04);} .price-card--best:hover{transform:scale(1.04) translateY(-.4rem);}}
.price-badge{position:absolute;right:1.6rem;top:-.9rem;background:var(--brand);color:#fff;font-size:.72rem;font-weight:900;letter-spacing:.12em;padding:.4rem .9rem;border-radius:999rem;box-shadow:0 .4rem 1rem rgba(192,160,98,.4);}
.price-name{font-size:1.45rem;font-weight:900;letter-spacing:-.02em;color:var(--ink);}
.price-desc{margin-top:.4rem;font-size:.9rem;color:rgba(38,33,28,.5);font-weight:600;}
.price-amt{margin-top:1.3rem;padding-bottom:1.3rem;border-bottom:1px solid rgba(38,33,28,.08);color:rgba(38,33,28,.55);font-weight:700;}
.price-amt b{font-size:2.1rem;font-weight:900;color:var(--brand-dark);letter-spacing:-.03em;}
.price-list{margin-top:1.3rem;display:grid;gap:.8rem;flex:1;}
.price-list li{display:flex;align-items:center;gap:.6rem;font-weight:600;color:rgba(38,33,28,.72);}
.price-list svg{width:1.1rem;height:1.1rem;color:var(--brand);flex-shrink:0;}
.price-btn{margin-top:1.6rem;height:3rem;border-radius:.8rem;background:var(--cream);color:var(--ink);font-weight:800;transition:all .2s;}
.price-btn:hover{background:var(--brand);color:#fff;}
.price-btn--best{background:var(--brand);color:#fff;}
.price-btn--best:hover{background:var(--brand-dark);}

/* ===== REVIEWS ===== */
.review-swiper{overflow:visible;}
.review-card{background:#fff;border:1px solid rgba(38,33,28,.07);border-radius:1.5rem;padding:2rem 1.8rem;height:auto;display:flex;flex-direction:column;box-shadow:0 .8rem 2rem rgba(38,33,28,.06);}
.review-text{margin-top:1rem;color:rgba(38,33,28,.72);line-height:1.8;font-weight:500;flex:1;}
.review-by{margin-top:1.6rem;padding-top:1.3rem;border-top:1px solid rgba(38,33,28,.08);display:flex;align-items:center;gap:.8rem;}
.review-ava{width:2.8rem;height:2.8rem;border-radius:999rem;background:var(--cream);color:var(--brand-dark);display:grid;place-items:center;font-weight:900;flex-shrink:0;}
.review-by b{display:block;font-weight:800;color:var(--ink);font-size:.95rem;}
.review-by small{display:block;margin-top:.1rem;font-size:.78rem;color:rgba(38,33,28,.5);font-weight:600;}
.review-stars{margin-left:auto;color:var(--brand);font-size:.85rem;letter-spacing:.05em;}
.review-pagination .swiper-pagination-bullet{width:.6rem;height:.6rem;background:var(--brand-soft);opacity:1;transition:width .25s;}
.review-pagination .swiper-pagination-bullet-active{width:1.8rem;border-radius:999rem;background:var(--brand);}

/* ===== GUIDE ===== */
.guide-card{position:relative;background:#fff;border:1px solid rgba(38,33,28,.08);border-radius:1.25rem;padding:1.6rem 1.4rem;display:flex;flex-direction:column;gap:.8rem;transition:transform .25s,box-shadow .25s,border-color .25s;}
.guide-card:hover{transform:translateY(-.3rem);box-shadow:0 1rem 2.5rem rgba(38,33,28,.1);border-color:var(--brand-soft);}
.guide-q{width:2.4rem;height:2.4rem;border-radius:.7rem;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:900;font-size:1.1rem;}
.guide-card b{font-weight:800;color:var(--ink);line-height:1.4;}
.guide-arrow{position:absolute;right:1.3rem;top:1.5rem;width:1.2rem;height:1.2rem;color:rgba(38,33,28,.3);transition:color .2s,transform .2s;}
.guide-card:hover .guide-arrow{color:var(--brand);transform:translate(.15rem,-.15rem);}

/* ===== FAQ ===== */
.faq-item{background:#fff;border:1px solid rgba(38,33,28,.08);border-radius:1rem;overflow:hidden;transition:box-shadow .2s;}
.faq-item.is-open{box-shadow:0 .8rem 2rem rgba(38,33,28,.08);border-color:var(--brand-soft);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.3rem 1.5rem;text-align:left;font-weight:800;font-size:1.02rem;color:var(--ink);cursor:pointer;}
.faq-icon{width:1.4rem;height:1.4rem;color:var(--brand-dark);flex-shrink:0;transition:transform .25s;}
.faq-item.is-open .faq-icon{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a p{padding:0 1.5rem 1.3rem;color:rgba(38,33,28,.6);line-height:1.8;font-weight:500;}

/* ===== FINAL CTA ===== */
.final-cta{background:var(--ink);}
.final-bg{position:absolute;inset:0;background:var(--img-cta) center 30%/cover no-repeat;}
.final-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(38,33,28,.78),rgba(38,33,28,.6));}

/* ===== FOOTER ===== */
.footer-h{display:block;font-size:.78rem;font-weight:900;letter-spacing:.15em;color:rgba(38,33,28,.4);margin-bottom:1.1rem;}
.footer-list{display:grid;gap:.75rem;font-size:.92rem;font-weight:600;}
.footer-list a:hover{color:var(--brand-dark);}
.sns-btn{width:2.4rem;height:2.4rem;border-radius:.7rem;background:#fff;border:1px solid rgba(38,33,28,.1);display:grid;place-items:center;color:rgba(38,33,28,.55);transition:all .2s;}
.sns-btn:hover{background:var(--brand);color:#fff;border-color:var(--brand);}

/* ===== FLOATING ===== */
.float-btn{width:3.1rem;height:3.1rem;border-radius:999rem;display:grid;place-items:center;box-shadow:0 .6rem 1.5rem rgba(38,33,28,.25);transition:transform .2s;}
.float-btn:hover{transform:scale(1.08);}
#topBtn.show{opacity:1;visibility:visible;}

/* ===== MOBILE DRAWER ===== */
#mobileDrawer.open{display:block;}
#mobileDrawer aside{transform:translateX(100%);transition:transform .26s ease;}
#mobileDrawer.open aside{transform:translateX(0);}

/* ===== POPUP ===== */
.popup-wrap{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:rgba(38,33,28,.55);padding:1rem;}
.popup-wrap.hidden{display:none;}
.popup-card{position:relative;width:min(92vw,24rem);border-radius:1.5rem;background:#fff;overflow:hidden;box-shadow:0 2rem 5rem rgba(38,33,28,.3);}
.popup-thumb{height:8rem;background:linear-gradient(135deg,var(--brand),var(--brand-dark));display:grid;place-items:center;color:rgba(255,255,255,.9);font-size:3rem;}
.popup-body{padding:1.6rem 1.6rem 1.2rem;}
.popup-foot{display:flex;border-top:1px solid var(--cream);}
.popup-today,.popup-close-btn{flex:1;height:3rem;font-weight:700;font-size:.88rem;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;transition:background .2s;}
.popup-today{color:rgba(38,33,28,.55);border-right:1px solid var(--cream);}
.popup-today:hover{background:var(--cream);}
.popup-close-btn{color:var(--ink);font-weight:800;}
.popup-close-btn:hover{background:var(--cream);}

/* ===== AOS 미발동 안전장치 (CDN stale 대비) =====
   IntersectionObserver fallback이 .is-shown을 부여하면 강제 노출 */
[data-aos].is-shown{opacity:1!important;transform:none!important;}

/* ===== 반응형 보정 ===== */
@media (max-width:479.98px){
  .calc-opt{font-size:.8rem;padding:0 .2rem;}
  .process-no{font-size:2.1rem;}
}
@media (max-width:319.98px){
  .theme-area{padding-left:.75rem;padding-right:.75rem;}
  .quick-card{padding:1.1rem .6rem;}
  .quick-card b{font-size:.92rem;}
}
