/*
Theme Name: Oooka Furusato
Theme URI: https://www.oookafurusatozukuri.com/
Author: 大岡ふるさとづくり協議会
Description: 大岡ふるさとづくり協議会 公式サイトテーマ。活動ハブ（お知らせ先行）型トップページ、カテゴリ色分けニュース、取り組み紹介、アクセスを備えた農村RMO向けオリジナルテーマ。
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: oooka-furusato
*/

:root{
  --green-900:#1B2A22;--green-800:#22382E;--green-700:#284A3D;--green-600:#36604F;--green-400:#5E7C6C;
  --sage-300:#C7D4C2;--sage-200:#DCE5D6;--sage-100:#EBF0E6;
  --paper:#F6F3EA;--paper-2:#FCFAF3;--ink:#23302A;--muted:#6E7669;
  --amber:#C5862A;--amber-dark:#9E6817;--clay:#B05A34;--teal:#2F6E6A;
  --line:rgba(40,74,61,.16);--maxw:1180px;
  --serif:"Shippori Mincho",serif;--sans:"Noto Sans JP",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.9;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{writing-mode:vertical-rl;font-family:var(--serif);font-weight:600;letter-spacing:.32em;color:var(--amber-dark);font-size:13px;line-height:1;padding-top:4px;position:relative}
.eyebrow::after{content:"";position:absolute;left:50%;bottom:-26px;transform:translateX(-50%);width:1px;height:20px;background:var(--amber);opacity:.6}

/* ---------- header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(246,243,234,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:transform .35s ease}
.bar{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:34px;height:34px;flex:none;border-radius:50%;background:radial-gradient(circle at 35% 30%,#3E6A55,#22382E);display:grid;place-items:center;color:#EBF0E6;font-family:var(--serif);font-weight:700;font-size:15px;box-shadow:0 2px 8px rgba(34,56,46,.25)}
.brand .custom-logo{width:38px;height:38px;object-fit:contain;border-radius:50%}
.brand .name{font-family:var(--serif);font-weight:700;font-size:18px;letter-spacing:.04em;color:var(--green-800);line-height:1.2}
.brand .name small{display:block;font-family:var(--sans);font-weight:400;font-size:10px;letter-spacing:.18em;color:var(--muted)}
nav.main{display:flex;align-items:center;gap:24px}
nav.main ul{list-style:none;display:flex;align-items:center;gap:24px}
nav.main a{font-size:14px;font-weight:500;color:var(--green-800);position:relative;padding:4px 0}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--amber);transition:width .28s ease}
nav.main a:hover::after,nav.main .current-menu-item a::after{width:100%}
.util{display:flex;align-items:center;gap:10px}
.btn-shop{display:inline-flex;align-items:center;gap:6px;background:var(--amber);color:#fff;font-size:13px;font-weight:700;padding:9px 16px;border-radius:999px;transition:background .25s,transform .25s}
.btn-shop:hover{background:var(--amber-dark);transform:translateY(-1px)}
.btn-cam{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--green-700);border:1px solid var(--line);padding:8px 14px;border-radius:999px;transition:background .25s}
.btn-cam:hover{background:var(--sage-100)}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.hamb span{width:24px;height:2px;background:var(--green-800)}
.mobile-nav{position:fixed;inset:0;z-index:99;background:var(--green-800);display:flex;flex-direction:column;justify-content:center;gap:8px;padding:40px;transform:translateY(-100%);transition:transform .4s cubic-bezier(.4,0,.2,1);visibility:hidden}
.mobile-nav.open{transform:translateY(0);visibility:visible}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.mobile-nav a{color:#EBF0E6;font-family:var(--serif);font-size:20px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.12);display:block}
.mobile-nav .m-util{display:flex;gap:12px;margin-top:24px}
.mobile-nav .m-util a{border:1px solid rgba(255,255,255,.3);border-radius:999px;font-size:14px;padding:10px 18px;text-align:center;flex:1;font-family:var(--sans)}

/* ---------- front hero ---------- */
.hero{position:relative;min-height:60vh;display:flex;align-items:center;overflow:hidden;padding:104px 0 56px}
.hero-slides{position:absolute;inset:0}
.hero-slides .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease}
.hero-slides .slide.active{opacity:1}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(20,34,27,.7) 0%,rgba(20,34,27,.4) 55%,rgba(20,34,27,.25) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;color:#fff}
.hh-left .badge{display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(6px);padding:6px 14px;border-radius:999px;font-size:12px;letter-spacing:.1em}
.hh-left h1{font-family:var(--serif);font-weight:700;font-size:clamp(28px,3.6vw,42px);line-height:1.5;letter-spacing:.04em;text-shadow:0 2px 20px rgba(0,0,0,.4);margin-bottom:14px}
.hh-left h1 .ac{color:#F4D8A0}
.hh-left p.lead{font-size:15px;max-width:440px;color:#EAF0E5;text-shadow:0 1px 10px rgba(0,0,0,.5);margin-bottom:24px}
.hh-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-ghost{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.55);color:#fff;font-size:14px;font-weight:600;padding:11px 20px;border-radius:999px;transition:background .25s}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-amber{display:inline-flex;align-items:center;gap:6px;background:var(--amber);color:#fff;font-size:14px;font-weight:700;padding:11px 22px;border-radius:999px;transition:background .25s,transform .25s;border:0;cursor:pointer}
.btn-amber:hover{background:var(--amber-dark);transform:translateY(-1px);color:#fff}
.pickup{background:rgba(252,250,243,.96);border-radius:18px;padding:24px;box-shadow:0 22px 50px rgba(0,0,0,.34)}
.pk-label{font-size:11px;letter-spacing:.18em;color:var(--amber-dark);font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.pk-label::before{content:"";width:18px;height:2px;background:var(--amber)}
.pk-item{display:block;color:var(--ink)}
.pk-item+.pk-item{margin-top:14px;padding-top:16px;border-top:1px solid var(--line)}
.pk-meta{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.pk-item time{font-family:var(--serif);color:var(--muted);font-size:13px;font-weight:600}
.pk-item h3{font-family:var(--serif);font-size:17px;color:var(--green-800);font-weight:700;line-height:1.5;transition:color .2s}
.pk-item:hover h3{color:var(--amber-dark)}
.pk-item .go{font-size:12px;color:var(--amber-dark);font-weight:600;margin-top:6px;display:inline-block}

/* tag chips */
.tag{font-size:11px;font-weight:700;letter-spacing:.04em;padding:3px 9px;border-radius:999px;color:#fff;flex:none;white-space:nowrap;display:inline-block}
.t-oshirase{background:var(--green-600)} .t-event{background:var(--amber)} .t-shutten{background:var(--clay)} .t-boshu{background:var(--teal)} .t-default{background:var(--green-400)}

/* ---------- sections ---------- */
.block{padding:84px 0}
.sec-head{display:flex;gap:24px;align-items:flex-start;margin-bottom:34px}
.sec-head .titles h2{font-family:var(--serif);font-weight:700;font-size:clamp(23px,2.8vw,32px);color:var(--green-800);letter-spacing:.05em;line-height:1.4}
.sec-head .titles p{color:var(--muted);font-size:14px;margin-top:8px}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* hub news */
.hub{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%)}
.cats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.cat{font-size:13px;font-weight:600;color:var(--green-700);background:#fff;border:1px solid var(--line);padding:9px 18px;border-radius:999px;cursor:pointer;transition:all .2s}
.cat:hover{background:var(--sage-100)}
.cat.on{background:var(--green-700);color:#fff;border-color:var(--green-700)}
.news-list{display:flex;flex-direction:column;border-top:1px solid var(--line);margin-top:22px}
.news-item{display:flex;gap:18px;align-items:center;padding:18px 6px;border-bottom:1px solid var(--line);transition:background .25s;flex-wrap:wrap}
.news-item:hover{background:var(--sage-100)}
.news-item time{font-family:var(--serif);color:var(--green-600);font-weight:600;font-size:14px;letter-spacing:.05em;flex:none;min-width:84px}
.news-item .nt{font-size:15px;font-weight:500;flex:1;min-width:220px}
.news-item .arrow{color:var(--green-400);transition:transform .25s}
.news-item:hover .arrow{transform:translateX(4px)}
.news-more{margin-top:26px;text-align:right}
.news-more a{font-size:14px;color:var(--green-700);border-bottom:1px solid var(--amber);padding-bottom:2px}

/* CTA band */
.cta-band{background:var(--green-800);color:#fff;position:relative;overflow:hidden}
.cta-band .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.16}
.cta-inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:30px;padding:54px 0;flex-wrap:wrap}
.cta-inner .ct-eye{font-family:var(--serif);font-size:13px;color:#F4D8A0;letter-spacing:.18em;margin-bottom:10px}
.cta-inner h2{font-family:var(--serif);font-size:clamp(22px,2.6vw,30px);font-weight:700;letter-spacing:.04em;margin-bottom:10px}
.cta-inner p{font-size:14.5px;color:#D8E2D2;max-width:560px}
.cta-inner .btn-amber{font-size:15px;padding:14px 26px;flex:none}

/* works */
.works{background:var(--sage-100)}
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.work-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 6px 22px rgba(34,56,46,.08);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.work-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(34,56,46,.16)}
.work-card .ph{aspect-ratio:4/3;overflow:hidden;background:var(--sage-200)}
.work-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.work-card:hover .ph img{transform:scale(1.07)}
.work-card .tx{padding:18px 16px 20px}
.work-card .tx h3{font-family:var(--serif);font-size:17px;color:var(--green-800);font-weight:700;margin-bottom:7px;letter-spacing:.04em}
.work-card .tx p{font-size:12.5px;color:var(--muted);line-height:1.8}
.work-card .tx .go{margin-top:12px;font-size:12.5px;color:var(--amber-dark);font-weight:600;display:inline-flex;gap:6px;align-items:center}

/* shop */
.shop{background:var(--paper-2)}
.shop-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.shop-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;display:flex;flex-direction:column}
.shop-card .ph{aspect-ratio:16/8;overflow:hidden;background:var(--sage-200)}
.shop-card .ph img{width:100%;height:100%;object-fit:cover}
.shop-card .tx{padding:26px 24px 28px}
.shop-card .tx .lab{font-family:var(--serif);font-size:12px;letter-spacing:.16em;color:var(--amber-dark);font-weight:700;margin-bottom:10px}
.shop-card .tx h3{font-family:var(--serif);font-size:21px;color:var(--green-800);font-weight:700;margin-bottom:10px;letter-spacing:.04em}
.shop-card .tx p{font-size:14px;color:var(--muted);margin-bottom:18px}
.btn-green{background:var(--green-700)}
.btn-green:hover{background:var(--green-800)}

/* about condensed */
.about-min{background:var(--green-800);color:#EAF0E5}
.about-min .eyebrow{color:#F4D8A0}.about-min .eyebrow::after{background:#F4D8A0}
.about-min .sec-head .titles h2{color:#fff}
.am-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center}
.am-body p{color:#D8E2D2;font-size:15px;margin-bottom:18px}
.pillars{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap}
.pillar{flex:1;min-width:120px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:16px 12px;text-align:center}
.pillar .n{font-family:var(--serif);font-size:12px;color:#F4D8A0;letter-spacing:.18em;margin-bottom:6px}
.pillar h3{font-family:var(--serif);font-size:17px;color:#fff;font-weight:700;letter-spacing:.06em}
.am-link{display:inline-flex;align-items:center;gap:8px;margin-top:24px;color:#F4D8A0;font-size:14px;border-bottom:1px solid rgba(244,216,160,.5);padding-bottom:2px}
.am-photo{border-radius:16px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.4);aspect-ratio:4/5}
.am-photo img{width:100%;height:100%;object-fit:cover}

/* access */
.access{background:var(--green-900);color:#E6EDE1}
.access .eyebrow{color:#F4D8A0}.access .eyebrow::after{background:#F4D8A0}
.access .sec-head .titles h2{color:#fff}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.routes{list-style:none}
.routes li{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.14);font-size:15px}
.routes li .from{color:#D8E2D2}
.routes li .time{font-family:var(--serif);color:#F4D8A0;font-weight:600;white-space:nowrap}
.addr-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:28px}
.addr-card .zip{font-size:13px;color:#A9B8A4;letter-spacing:.1em}
.addr-card .ad{font-family:var(--serif);font-size:20px;color:#fff;margin:8px 0 20px;letter-spacing:.04em}
.addr-card .row{display:flex;align-items:center;gap:12px;padding:9px 0;font-size:15px}
.addr-card .row .ic{width:34px;height:34px;border-radius:50%;background:rgba(244,216,160,.16);display:grid;place-items:center;flex:none}
.addr-card .row a{color:#F4D8A0}

/* ---------- sub pages ---------- */
.page-hero{position:relative;padding:150px 0 64px;background:var(--green-800);color:#fff;overflow:hidden}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.22}
.page-hero .wrap{position:relative}
.page-hero .crumbs{font-size:12px;color:#A9B8A4;letter-spacing:.06em;margin-bottom:14px}
.page-hero .crumbs a{color:#C7D4C2;border-bottom:1px solid rgba(255,255,255,.3)}
.page-hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(26px,3.4vw,40px);letter-spacing:.05em;line-height:1.5}
.page-hero .sub{color:#D8E2D2;font-size:14px;margin-top:10px;letter-spacing:.08em}
.page-body{padding:72px 0 96px}
.entry{max-width:820px;margin:0 auto}
.entry h2{font-family:var(--serif);font-size:clamp(21px,2.4vw,27px);color:var(--green-800);font-weight:700;letter-spacing:.05em;margin:52px 0 20px;padding-left:16px;border-left:4px solid var(--amber);line-height:1.5}
.entry h2:first-child{margin-top:0}
.entry h3{font-family:var(--serif);font-size:19px;color:var(--green-700);font-weight:700;margin:36px 0 14px}
.entry p{margin-bottom:22px;font-size:16px}
.entry ul,.entry ol{margin:0 0 22px 1.4em}
.entry li{margin-bottom:8px}
.entry img{border-radius:14px;margin:10px 0 26px}
.entry blockquote{border-left:3px solid var(--sage-300);padding:6px 0 6px 20px;color:var(--muted);font-family:var(--serif);margin-bottom:22px}
.entry a{color:var(--amber-dark);border-bottom:1px solid rgba(197,134,42,.4)}
.entry .wp-block-table table,.entry table{width:100%;border-collapse:collapse;margin-bottom:26px;font-size:14.5px}
.entry th,.entry td{border:1px solid var(--line);padding:10px 14px;text-align:left}
.entry th{background:var(--sage-100);font-family:var(--serif);font-weight:700;color:var(--green-800)}

/* single article */
.article-meta{display:flex;align-items:center;gap:14px;margin-bottom:30px;flex-wrap:wrap}
.article-meta time{font-family:var(--serif);color:var(--green-600);font-weight:600;font-size:15px}
.post-nav{display:flex;justify-content:space-between;gap:16px;margin-top:64px;padding-top:28px;border-top:1px solid var(--line)}
.post-nav a{font-size:14px;color:var(--green-700);max-width:46%}
.post-nav a:hover{color:var(--amber-dark)}
.back-to-list{text-align:center;margin-top:40px}
.back-to-list a{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:11px 30px;font-size:14px;color:var(--green-700);transition:background .2s}
.back-to-list a:hover{background:var(--sage-100)}

/* archive list */
.archive-list{max-width:900px;margin:0 auto}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:44px}
.pagination .page-numbers{min-width:40px;height:40px;display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:10px;font-size:14px;color:var(--green-700);padding:0 10px}
.pagination .page-numbers.current{background:var(--green-700);color:#fff;border-color:var(--green-700)}
.pagination .page-numbers:hover:not(.current){background:var(--sage-100)}

/* members */
.member-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:26px 0 10px}
.member-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 20px;text-align:center}
.member-card .role{font-size:12px;color:var(--amber-dark);letter-spacing:.12em;font-weight:700;margin-bottom:8px}
.member-card .nm{font-family:var(--serif);font-size:19px;color:var(--green-800);font-weight:700}
.member-card p{font-size:13px;color:var(--muted);margin-top:10px;line-height:1.8}

/* contact page */
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:8px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;text-align:center}
.contact-card .ic{font-size:30px;margin-bottom:12px}
.contact-card h3{font-family:var(--serif);font-size:18px;color:var(--green-800);margin-bottom:8px}
.contact-card p{font-size:13.5px;color:var(--muted);margin-bottom:16px}
.contact-card a.big{font-family:var(--serif);font-size:20px;color:var(--amber-dark);font-weight:700}

/* footer */
.site-footer{background:var(--green-800);color:#CBD7C4;padding:64px 0 28px;border-top:4px solid var(--amber)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:38px;margin-bottom:46px}
.foot-brand .name{font-family:var(--serif);font-size:21px;color:#fff;font-weight:700;letter-spacing:.05em;margin-bottom:14px}
.foot-brand p{font-size:13px;color:#9FB098;line-height:1.9}
.foot-col h4{font-size:13px;color:#F4D8A0;letter-spacing:.1em;margin-bottom:15px;font-weight:700}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;color:#CBD7C4;transition:color .2s}
.foot-col a:hover{color:#fff}
.sns{display:flex;gap:12px;margin-top:16px}
.sns a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;color:#CBD7C4;font-size:13px;transition:all .25s}
.sns a:hover{background:var(--amber);color:#fff;border-color:var(--amber);transform:translateY(-2px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12px;color:#8FA088}

/* 404 */
.nf{padding:170px 0 120px;text-align:center}
.nf h1{font-family:var(--serif);font-size:60px;color:var(--green-700)}
.nf p{color:var(--muted);margin:14px 0 30px}

@media(max-width:980px){
  nav.main,.util .btn-cam{display:none}
  .hamb{display:flex}
  .hero-inner,.access-grid,.am-grid,.shop-grid,.contact-cards{grid-template-columns:1fr;gap:30px}
  .work-grid,.member-grid{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
  .am-photo{aspect-ratio:16/10;max-height:340px}
}
@media(max-width:560px){
  .block{padding:60px 0}.wrap{padding:0 18px}
  .hero-inner{padding:0 18px}
  .work-grid,.member-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .sec-head{gap:14px;margin-bottom:26px}
  .cta-inner{padding:42px 0}
  .page-hero{padding:120px 0 46px}
}
