:root{--whr-bg:#f9fafb;--whr-card:#fff;--whr-text:#111827;--whr-muted:#6b7280;--whr-gray:#e5e7eb;
  --whr-brand:#2563eb;--whr-ring:rgba(37,99,235,.18);--whr-gold:#f59e0b;--whr-gray:#e5e7eb}
*{box-sizing:border-box}
body{background:var(--whr-card);color:var(--whr-text);line-height:1.75}
body .contents{
  max-width:1100px;
  margin:0px auto;
  padding:20px 20px;
  background:#fff;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
/* 헤더 */
.whr-nav-wrap{background:#fff;border-bottom:1px solid var(--whr-gray)}
.whr-nav{max-width:1100px;margin:0 auto;padding:14px 16px;display:flex;justify-content:space-between;align-items:center}
.whr-menu{display:flex;gap:20px;font-weight:600}
.whr-menu a:hover{color:var(--whr-brand)}
/* 메인 */
.whr-main{max-width:1200px;margin:0 auto;padding:24px 16px}
.whr-h1{font-size:clamp(22px,2.8vw,32px);margin:0 0 8px}
.whr-sub{color:var(--whr-muted);margin:0 0 22px}
/* 카드 그리드 */
.whr-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.whr-card{background:var(--whr-card);border:1px solid var(--whr-gray);border-radius:12px;overflow:hidden;transition:transform .18s,box-shadow .18s}
.whr-card:hover{cursor:pointer;transform:translateY(-3px);box-shadow:0 12px 26px rgba(0,0,0,.06)}
.whr-click{display:block;height:100%}
.whr-thumb{position:relative;aspect-ratio:34/15;background:#f3f4f6;border-bottom:1px solid var(--whr-gray);}
.whr-logo-badge{position:absolute;left:10px;bottom:10px;background:rgba(255,255,255,.94);border:1px solid var(--whr-gray);border-radius:8px;padding:6px 8px}
/* 정보 영역 */
.whr-info{padding:14px 14px 18px}
.whr-title-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}
.whr-title{font-size:18px;font-weight:800;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* 별 아이콘(숫자 없이) */
.whr-rating-inline{display:flex;align-items:center}
.whr-stars-inline{position:relative;display:inline-block;line-height:1}
.whr-stars-inline::before{content:"★★★★★";letter-spacing:2px;color:var(--whr-gray);font-size:16px}
.whr-stars-inline>span{position:absolute;left:0;top:0;white-space:nowrap;overflow:hidden;width:calc(var(--rate)/5 * 100%)}
.whr-stars-inline>span::before{content:"★★★★★";letter-spacing:2px;color:var(--whr-gold);font-size:16px}
/* 설명/칩/버튼 */
.whr-desc{font-size:14px;color:#374151}
.whr-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.whr-chip{font-size:12px;background:#f1f5f9;border:1px solid var(--whr-gray);padding:5px 10px;border-radius:999px;color:#475569}
.whr-cta{margin-top:14px}
.whr-btn-full{display:block;width:100%;text-align:center;font-weight:800;border:1px solid var(--whr-gray);padding:12px;border-radius:8px;background:var(--whr-brand);color:#fff}
.whr-card:hover .whr-btn-full{box-shadow:0 0 0 6px var(--whr-ring)}
.whr-btn-full::after{content:" ↗"}
/* 본문 */
.whr-content{margin-top:40px;color:#374151}
.whr-content h2{margin:24px 0 10px;font-size:20px}
.whr-content h3{margin:16px 0 8px;font-size:17px}
.whr-content p{margin-bottom:12px}
.whr-block{background:#fff;border:1px solid var(--whr-gray);border-radius:12px;padding:16px;margin:16px 0}
.whr-block ul{padding-left:18px}
.whr-block li{margin:6px 0}
.whr-note{font-size:13px;color:#6b7280}
/* 반응형 (상단 메뉴 접기 필요 시 사이트 공통 로직에 맞춰 조정) */
/* 예: .whr-menu{display:none}
@media(max-width:640px){...}
.contents{max-width:1100px;
  margin:0px auto;
  padding:10px 10px;
  background:#fff;}
:root{--whnav-text:#0f172a;
  --whnav-muted:#475569;
  --whnav-bg:#ffffff;
  --whr-gray:#b0b8c4;
  --whnav-brand:#3b82f6;
  --whnav-brand-hover:#2563eb;}
/* 스킵 링크 */
.whnav-skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.whnav-skip:focus{position:fixed;left:12px;top:12px;width:auto;height:auto;padding:10px 12px;background:#111;color:#fff;border-radius:8px;z-index:10000}
/* 헤더 바 */
.whnav-header{background:#fff;border-bottom:1px solid var(--whr-gray)}
.whnav-inner{max-width:1100px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between}
.whnav-logo img{display:block;height:36px;width:auto}
/* 메뉴 공통 */
.whnav-nav{display:block}
.whnav-menu{list-style:none;margin:0;padding:0;display:flex;gap:20px;align-items:center}
.whnav-link{display:inline-block;padding:8px 10px;border-radius:8px;font-weight:700;color:var(--whnav-text);text-decoration:none}
.whnav-link:hover{background:#f8fafc}
.whnav-link.is-active{color:var(--whnav-brand);background:rgba(59,130,246,.10)}
/* 버거 버튼 */
.whnav-burger{display:none;appearance:none;border:1px solid var(--whr-gray);background:#fff;border-radius:10px;padding:8px;cursor:pointer}
.whnav-burger:focus{outline:3px solid rgba(59,130,246,.3);outline-offset:2px}
.whnav-burger-bar{display:block;width:20px;height:2px;background:#0f172a;margin:3px 0}
/* 메인 래퍼(본문 높이 확보용) */
.whnav-main{min-height:1px}
/* 내용은 .contents에서 박스 처리 */

/* ===== Footer ===== */
.whnav-footer{background: var(--whr-card);
  border-top: 1px solid var(--whr-gray);
  color: var(--whnav-muted);
  font-size: 14px;
  margin-top: 40px;}
.whnav-footer-inner{max-width: 1100px;
  margin: 0 auto;
  padding: 20px 16px;
  text-align:center;
}
.whnav-footer-links{display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 10px;}
.whnav-footer-link{color: var(--whnav-text);
  text-decoration: none;}
.whnav-footer-link:hover{color: var(--whnav-brand);}
.whnav-footer-copy{color: var(--whnav-muted);}
/* a11y */
.whshell-visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
/* 반응형: 모바일에서 우측 메뉴를 드로워처럼 */
@media (max-width:860px){.whnav-burger{display:inline-block}
.whnav-nav{position:fixed;right:0;top:0;height:100vh;width:75vw;max-width:340px;
    background:#fff;border-left:1px solid var(--whr-gray);
    transform:translateX(100%);transition:transform .2s ease;z-index:9999;
    padding:70px 16px 16px 16px; /* 상단 여백으로 로고/버거와 분리 */
    box-shadow:-16px 0 24px rgba(0,0,0,.06);}
.whnav-nav.is-open{transform:translateX(0)}
.whnav-menu{flex-direction:column;align-items:flex-start;gap:12px}
.whnav-link{padding:10px 12px;width:100%}
body.whnav-no-scroll{overflow:hidden}