/*
Theme Name: 정보마루 (Jeongbomaru)
Theme URI: https://datapediahub.com
Description: 보호 동물 입양 정보를 위한 에디토리얼 워드프레스 테마. 실제 공고 데이터를 The Loop으로 표시하며, 대표 이미지가 없으면 본문 첫 이미지를 자동 썸네일로 사용합니다. 반응형·SEO·접근성 대응.
Author: 정보마루
Version: 1.0.2
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jeongbomaru
*/

:root{
  --bg:#FAF6F0; --surface:#FFFFFF; --ink:#221E1B; --muted:#6E665F; --faint:#998F86;
  --accent:#C2543B; --accent-deep:#A6402B; --accent-soft:#F2E5DC;
  --green:#4F7A63; --line:#EAE1D6;
  --serif:'Nanum Myeongjo',serif;
  --sans:'Pretendard',system-ui,-apple-system,sans-serif;
  --maxw:1140px;
  --sh:0 1px 2px rgba(34,30,27,.04), 0 8px 24px -12px rgba(34,30,27,.14);
  --sh-hover:0 6px 14px rgba(34,30,27,.06), 0 22px 44px -18px rgba(34,30,27,.26);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}
h1,h2,h3{font-family:var(--serif);font-weight:800;letter-spacing:-.01em;line-height:1.28}
.kicker{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.lead{color:var(--muted)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:10px;background:#fff;padding:8px 14px;border-radius:6px;z-index:100}
.link-more{font-weight:600;font-size:.92rem;color:var(--accent-deep);display:inline-flex;align-items:center;gap:6px;border-bottom:1px solid transparent;padding-bottom:1px}
.link-more:hover{border-color:var(--accent)}

/* ---- top utility ---- */

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,246,240,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:30px;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:800;font-size:1.32rem;letter-spacing:-.01em}
.brand .mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--accent);flex:0 0 auto}
.brand .mark svg{width:20px;height:20px}
.nav-links{display:flex;gap:28px;font-weight:600;font-size:.96rem;color:#463F39;list-style:none;align-items:center}
.nav-links a{padding:6px 0;border-bottom:2px solid transparent;display:inline-block}
.nav-links a:hover,.nav-links .current-menu-item>a,.nav-links a.active{color:var(--accent-deep);border-color:var(--accent)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:8px 12px;width:230px}
.search input{border:none;outline:none;background:none;font-family:inherit;font-size:.9rem;width:100%;color:var(--ink)}
.search input::placeholder{color:#A89E94}
.search svg{flex:0 0 auto;opacity:.55}
.search button{background:none;border:none;padding:0;cursor:pointer;display:flex}
.menu-btn{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;border-radius:8px;align-items:center;justify-content:center}
.menu-btn .ic-close{display:none}
.menu-btn[aria-expanded="true"] .ic-open{display:none}
.menu-btn[aria-expanded="true"] .ic-close{display:block}
.mobile-menu{display:none;flex-direction:column;padding:6px 28px 22px}
.mobile-menu a{font-weight:600;font-size:1.02rem;padding:14px 2px;border-bottom:1px solid var(--line)}
.mobile-menu ul{list-style:none}
.m-search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:11px 14px;margin:8px 0 6px}
.m-search input{border:none;outline:none;background:none;font-family:inherit;font-size:.95rem;width:100%}
.m-search button{background:none;border:none;padding:0;cursor:pointer;display:flex}
.menu-overlay{position:fixed;inset:0;background:rgba(34,30,27,.35);z-index:40}
body.menu-open{overflow:hidden}

/* ---- hero ---- */
.hero{padding:62px 0 56px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1fr 1.02fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.15rem,3.6vw,3.05rem);margin:18px 0 20px}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero p.lead{font-size:1.08rem;max-width:30em;margin-bottom:26px}
.hero-search{display:flex;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:6px 6px 6px 16px;max-width:430px;box-shadow:var(--sh)}
.hero-search input{border:none;outline:none;background:none;font-family:inherit;font-size:1rem;width:100%}
.hero-search button{flex:0 0 auto;background:var(--accent);color:#fff;border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:.95rem;padding:11px 20px;border-radius:7px}
.hero-search button:hover{background:var(--accent-deep)}
.hero-meta{margin-top:22px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:.88rem}
.hero-meta a{color:var(--muted);border-bottom:1px solid var(--line)}
.hero-meta a:hover{color:var(--accent-deep)}
.dot{width:3px;height:3px;border-radius:50%;background:#C9BEB2;display:inline-block;flex:0 0 auto}

/* featured photo card */
.feature{position:relative;border-radius:14px;overflow:hidden;background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh);display:block;color:inherit}
.feature .ph{position:relative;aspect-ratio:4/3;background:#EFE7DD}
.feature .ph img{width:100%;height:100%;object-fit:cover}
.feature .tag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.94);color:var(--green);font-weight:700;font-size:.76rem;padding:5px 11px;border-radius:6px;letter-spacing:.02em}
.feature .cap{padding:18px 20px}
.feature .cap .nm{font-family:var(--serif);font-weight:800;font-size:1.2rem}
.feature .cap .info{color:var(--muted);font-size:.9rem;margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.feature .cap .cta{margin-top:12px;font-weight:600;font-size:.9rem;color:var(--accent-deep)}

/* ---- section frame ---- */
section.block{padding:66px 0;border-bottom:1px solid var(--line)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(1.6rem,2.6vw,2.05rem)}
.sec-head .lead{margin-top:8px}

/* ---- editorial post layout ---- */
.editorial{display:grid;grid-template-columns:1.15fr 1fr;gap:44px;align-items:start}
.lead-post .ph{position:relative;aspect-ratio:16/10;border-radius:12px;overflow:hidden;background:#EFE7DD;border:1px solid var(--line);display:block}
.lead-post .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.lead-post:hover .ph img{transform:scale(1.03)}
.pmeta{display:flex;align-items:center;gap:9px;font-size:.8rem;color:var(--muted);margin:16px 0 8px;flex-wrap:wrap}
.pmeta .cat{color:var(--accent-deep);font-weight:700}
.lead-post h3{font-size:1.42rem;line-height:1.34}
.lead-post h3 a:hover{color:var(--accent-deep)}
.lead-post p{color:var(--muted);margin-top:10px;font-size:.96rem}

.post-list{display:flex;flex-direction:column}
.row-post{display:grid;grid-template-columns:118px 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}
.row-post:first-child{padding-top:0}
.row-post:last-child{border-bottom:none}
.row-post .ph{aspect-ratio:1/1;border-radius:9px;overflow:hidden;background:#EFE7DD;border:1px solid var(--line);display:block}
.row-post .ph img{width:100%;height:100%;object-fit:cover}
.row-post h4{font-family:var(--serif);font-weight:700;font-size:1.04rem;line-height:1.4}
.row-post h4 a:hover{color:var(--accent-deep)}
.row-post .pmeta{margin:0 0 6px}

/* ---- archive/search grid ---- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--sh);display:flex;flex-direction:column;transition:.2s}
.card:hover{box-shadow:var(--sh-hover);transform:translateY(-3px)}
.card .ph{aspect-ratio:16/10;background:#EFE7DD;display:block}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .cbody{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:1.12rem;line-height:1.4;margin-bottom:6px}
.card h3 a:hover{color:var(--accent-deep)}
.card p{color:var(--muted);font-size:.9rem;flex:1}
.page-head{padding:48px 0 8px}
.page-head h1{font-size:clamp(1.8rem,3vw,2.4rem)}
.page-head .lead{margin-top:10px}
.pagination{display:flex;gap:8px;justify-content:center;padding:44px 0;flex-wrap:wrap}
.pagination .page-numbers{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:9px 15px;font-weight:600;color:var(--ink)}
.pagination .current,.pagination .page-numbers:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---- category cards ---- */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.cat-card{display:flex;gap:16px;align-items:flex-start;border:1px solid var(--line);background:var(--surface);border-radius:14px;padding:22px 24px;transition:.18s}
.cat-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 24px -16px rgba(80,40,25,.4)}
.cat-card .ic{flex:0 0 auto;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:11px;background:var(--accent-soft);color:var(--accent-deep)}
.cat-card .cc-body{display:flex;flex-direction:column;gap:5px;min-width:0}
.cat-card .cc-top{display:flex;align-items:baseline;gap:10px}
.cat-card .cc-name{font-family:var(--serif);font-weight:800;font-size:1.12rem;color:var(--ink)}
.cat-card .cc-cnt{font-size:.8rem;font-weight:700;color:var(--accent-deep);background:var(--accent-soft);padding:2px 9px;border-radius:999px;white-space:nowrap}
.cat-card .cc-desc{font-size:.9rem;color:var(--muted);line-height:1.55}
.cat-card .cc-go{font-size:.84rem;font-weight:700;color:var(--accent-deep);margin-top:3px;opacity:0;transform:translateX(-4px);transition:.18s}
.cat-card:hover .cc-go{opacity:1;transform:none}

/* ---- region ---- */
.region{background:#F4ECE2}
.region-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface)}
.reg{padding:18px 16px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:.18s;display:flex;flex-direction:column;gap:6px}
.reg:nth-child(6n){border-right:none}
.reg:nth-last-child(-n+6){border-bottom:none}
.reg:hover{background:var(--accent-soft)}
.reg .reg-head{display:flex;align-items:center;justify-content:space-between}
.reg .reg-l{font-weight:700;font-size:.96rem;color:var(--ink)}
.reg .reg-go{color:var(--accent);font-weight:700;opacity:0;transform:translateX(-3px);transition:.18s}
.reg:hover .reg-go{opacity:1;transform:none}
.reg .reg-n{font-family:var(--serif);font-weight:800;font-size:1.5rem;color:var(--accent-deep);line-height:1}
.reg .reg-n small{font-family:var(--sans);font-weight:600;font-size:.72rem;color:var(--muted);margin-left:3px}

/* ---- source note ---- */
.note{display:flex;gap:20px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px;padding:24px 26px}
.note h4{font-family:var(--serif);font-size:1.08rem;margin-bottom:5px}
.note p{color:var(--muted);font-size:.92rem}
.note svg{flex:0 0 auto;color:var(--accent);margin-top:2px}

/* ---- single post ---- */
.single-wrap{max-width:760px;margin:0 auto;padding:48px 28px 20px}
.single-wrap .pmeta{font-size:.85rem}
.single-wrap h1.entry-title{font-size:clamp(1.8rem,3.4vw,2.5rem);line-height:1.3;margin:6px 0 18px}
.entry-content{font-size:1.05rem;line-height:1.85;color:#312A25}
.entry-content p{margin:1.1em 0}
.entry-content h2{font-size:1.5rem;margin:1.6em 0 .6em}
.entry-content h3{font-size:1.22rem;margin:1.4em 0 .5em}
.entry-content img{border-radius:10px;margin:1.2em 0}
.entry-content a{color:var(--accent-deep);border-bottom:1px solid var(--accent-soft)}
.entry-content table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:.96rem}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:11px 14px;text-align:left}
.entry-content th{background:var(--accent-soft)}
.entry-content ul,.entry-content ol{margin:1.1em 0 1.1em 1.3em}
.entry-content li{margin:.4em 0}
.entry-tags{display:flex;gap:8px;flex-wrap:wrap;margin:30px 0}
.entry-tags a{font-size:.82rem;font-weight:600;color:var(--accent-deep);background:var(--accent-soft);padding:6px 12px;border-radius:999px}

/* ---- footer ---- */
.site-footer{background:var(--ink);color:#C2B8AD;padding:56px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px;margin-bottom:34px}
.site-footer .brand{color:#fff;margin-bottom:14px}
.site-footer .brand .mark{background:var(--accent)}
.site-footer p.desc{color:#968C82;font-size:.9rem;max-width:25em}
.site-footer h5{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.site-footer ul a{color:#968C82;font-size:.9rem}
.site-footer ul a:hover{color:#fff}
.foot-meta{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);padding-top:22px;margin-bottom:18px;font-size:.82rem;color:#A89E94}
.foot-meta .src{color:#7E756B}
.foot-bottom{padding-top:0;font-size:.8rem;color:#7E756B;line-height:1.7}

@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .feature{max-width:460px}
  .editorial{grid-template-columns:1fr;gap:36px}
  .post-grid{grid-template-columns:repeat(2,1fr)}
  .region-grid{grid-template-columns:repeat(4,1fr)}
  .reg:nth-child(6n){border-right:1px solid var(--line)}
  .reg:nth-child(4n){border-right:none}
  .reg:nth-last-child(-n+6){border-bottom:1px solid var(--line)}
  .reg:nth-last-child(-n+4){border-bottom:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links,.search{display:none}
  .menu-btn{display:flex}
  .mobile-menu.open{display:flex}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  .post-grid{grid-template-columns:1fr}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  .reg:nth-child(4n){border-right:1px solid var(--line)}
  .reg:nth-child(2n){border-right:none}
  .reg:nth-last-child(-n+4){border-bottom:1px solid var(--line)}
  .reg:nth-last-child(-n+2){border-bottom:none}
  .foot-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .foot-meta{flex-direction:column;align-items:flex-start;gap:6px}
  section.block{padding:48px 0}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
