:root{--green:#2f7d38;--green-dark:#1f5f2b;--green-soft:#eef7ec;--gold:#c79220;--ink:#241914;--muted:#6d6964;--line:#e7e1d8;--paper:#fffdf8;--paper-strong:#fff;--sand:#f7f3ea;--shadow:0 16px 45px #31251514;--radius:8px;--content:1120px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;color:var(--ink);background:linear-gradient(180deg, #ffffffdb, #faf6eef0 48%, #fffdf8), var(--paper);letter-spacing:0;margin:0;font-family:-apple-system,BlinkMacSystemFont,Hiragino Kaku Gothic ProN,Yu Gothic,Noto Sans JP,sans-serif;line-height:1.65}body.menu-open{overflow:hidden}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}.site-header{z-index:50;height:70px;padding:0 max(20px, calc((100vw - var(--content)) / 2));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffeb;border-bottom:1px solid #e7e1d8db;align-items:center;gap:24px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;min-width:max-content;display:inline-flex}.brand-mark,.loading-logo{flex:none;width:30px;height:40px;position:relative}.brand-mark:before,.loading-logo:before{content:"";background:var(--green);border-radius:999px;width:21px;height:21px;position:absolute;top:0;left:5px}.brand-mark:after,.loading-logo:after{content:"";background:var(--green);clip-path:polygon(50% 0,78% 100%,8% 100%);width:30px;height:25px;position:absolute;bottom:0;left:0}.brand-text{line-height:1.08;display:grid}.brand-text strong{letter-spacing:.04em;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:24px;font-weight:800}.brand-text small{letter-spacing:.2em;margin-top:2px;font-size:9px;font-weight:800}.desktop-nav{flex:1;justify-content:center;align-items:center;gap:28px;font-size:14px;font-weight:800;display:flex}.desktop-nav a{padding:24px 0;position:relative}.desktop-nav a:after{content:"";background:var(--green);opacity:0;height:2px;transition:all .2s;position:absolute;bottom:16px;left:0;right:0;transform:scaleX(.4)}.desktop-nav a:hover:after,.desktop-nav a.active:after,.desktop-nav a[aria-current=page]:after{opacity:1;transform:scaleX(1)}.header-actions{align-items:center;gap:10px;display:flex}.icon-button,.menu-button{width:44px;height:44px;color:var(--ink);background:0 0;border:0;border-radius:999px;place-items:center;display:inline-grid}.icon-button svg,.menu-button svg,.bottom-nav svg,.action-icon,.feature-icon{fill:none;stroke:currentColor;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round;width:24px;height:24px}.login-button,.signup-button,.primary-button,.secondary-button,.ghost-button,.line-button{white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;min-height:42px;padding:0 18px;font-weight:800;display:inline-flex}.login-button,.secondary-button,.line-button{border:1px solid var(--line);color:var(--ink);background:#fff}.signup-button,.primary-button{border:1px solid var(--green);color:#fff;background:linear-gradient(135deg, var(--green), var(--green-dark));box-shadow:0 10px 22px #2f7d382e}.ghost-button{color:var(--green);background:0 0;border:0}.menu-button{display:none}.mobile-menu{z-index:49;border-bottom:1px solid var(--line);box-shadow:var(--shadow);background:#fffffff5;padding:18px 22px 26px;display:none;position:fixed;inset:70px 0 auto}.mobile-menu a{border-bottom:1px solid var(--line);padding:14px 0;font-weight:800;display:block}.mobile-menu.open{display:block}.mobile-auth-actions{grid-template-columns:1fr 1fr;gap:10px;padding-top:16px;display:grid}.signup-button.user-pill{text-overflow:ellipsis;max-width:150px;overflow:hidden}.app-shell{min-height:calc(100vh - 70px)}.loading-card{min-height:50vh;color:var(--muted);align-content:center;place-items:center;gap:14px;display:grid}.page{width:min(var(--content), calc(100% - 40px));margin:0 auto}.hero{min-height:500px;color:var(--ink);background-image:linear-gradient(90deg,#ffffffc2,#ffffff3d 58%,#ffffffb8),url(../media/green-mound.0eukrwu~0zvwk.jpg);background-position:50%;background-size:cover;position:relative;overflow:hidden}.hero-inner{width:min(var(--content), calc(100% - 40px));grid-template-columns:minmax(0,1fr) 250px;gap:80px;min-height:500px;margin:0 auto;padding:62px 0 42px;display:grid}.hero-copy h1{letter-spacing:.05em;margin:0 0 12px;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:clamp(34px,5vw,54px);font-weight:800;line-height:1.18}.hero-copy p{margin:0 0 100px;font-size:17px;font-weight:700}.search-card{border-radius:var(--radius);width:min(640px,100%);box-shadow:var(--shadow);background:#ffffffe6;border:1px solid #d9cebee6;padding:24px 28px}.search-card h2,.card-title{margin:0;font-size:24px;line-height:1.3}.search-row{grid-template-columns:1fr 58px;gap:0;margin-top:16px;display:grid}.search-row input,.field,.comment-box textarea,.filter-select{width:100%;min-height:52px;color:var(--ink);background:#fff;border:1px solid #ddd6cc;border-radius:6px}.search-row input,.field,.comment-box textarea{padding:0 16px}.search-row input{border-radius:6px 0 0 6px}.search-row button{color:#fff;background:var(--green);border:0;border-radius:0 6px 6px 0;place-items:center;display:grid}.search-row svg{fill:none;stroke:currentColor;stroke-width:2.2px;width:26px;height:26px}.keyword-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:14px;font-size:13px;display:flex}.chip,.tag{border:1px solid var(--line);min-height:30px;color:var(--ink);background:#fff;border-radius:5px;align-items:center;padding:0 11px;font-size:13px;font-weight:700;display:inline-flex}.tag.green,.chip.green{color:var(--green);background:var(--green-soft);border-color:#2f7d3829}.record-card{border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;background:#fffff5db;border:1px solid #c9bda4c7;align-self:center;padding:24px}.record-card .pin-badge{margin:0 auto 12px}.pin-badge{width:64px;height:64px;color:var(--green);background:var(--green-soft);border-radius:999px;place-items:center;display:grid}.pin-badge svg{fill:none;stroke:currentColor;stroke-width:2px;width:38px;height:38px}.record-card h2{margin:0 0 8px;font-size:18px}.record-card p{color:var(--muted);margin:0 0 18px;font-weight:700}.quick-actions{width:min(var(--content), calc(100% - 40px));border-bottom:1px solid var(--line);grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin:0 auto;padding:30px 0;display:grid}.quick-action{border-right:1px solid var(--line);grid-template-columns:48px 1fr;align-items:center;gap:14px;min-height:80px;padding:0 28px;display:grid}.quick-action:first-child{border-left:1px solid #0000}.quick-action:last-child{border-right:0}.quick-action svg{width:42px;height:42px;color:var(--green);fill:none;stroke:currentColor;stroke-width:1.9px}.quick-action strong{font-size:17px;display:block}.quick-action span{color:var(--muted);font-size:13px;font-weight:700}.section-grid{grid-template-columns:1.45fr 1fr;gap:24px;padding:28px 0 72px;display:grid}.card{border:1px solid var(--line);border-radius:var(--radius);background:#ffffffdb;box-shadow:0 10px 30px #2b22140a}.card-pad{padding:22px}.section-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.section-head h2{margin:0;font-size:24px;line-height:1.3}.section-head a,.section-head button{color:var(--green);background:0 0;border:0;font-size:13px;font-weight:800}.article-feature{grid-template-columns:1.08fr .92fr;gap:18px;display:grid}.article-main img,.article-list img,.record-item img,.rank-item img,.detail-gallery-main img,.related-row img,.kofun-list-card img,.my-list-card img{object-fit:cover;width:100%}.article-main img{border-radius:6px;height:250px}.article-main h3{margin:12px 0 8px;font-size:22px;line-height:1.45}.article-main p{color:var(--muted);margin:0}.article-main a{display:block}.article-detail-page{gap:24px;display:grid}.article-detail{gap:16px;display:grid}.article-detail-cover{object-fit:cover;border-radius:8px;width:100%;max-height:420px}.article-body{gap:18px;max-width:820px;display:grid}.article-body p{margin:0;font-size:16px;line-height:2.05}.meta-row{color:var(--muted);flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px;font-size:13px;font-weight:700;display:flex}.article-list,.news-list,.rank-list,.record-list{gap:0;display:grid}.article-list-item,.news-item,.rank-item,.record-item,.related-row{border-bottom:1px solid var(--line);grid-template-columns:112px 1fr;gap:14px;padding:14px 0;display:grid}.article-list-item:first-child,.news-item:first-child,.rank-item:first-child,.record-item:first-child,.related-row:first-child{padding-top:0}.article-list-item:last-child,.news-item:last-child,.rank-item:last-child,.record-item:last-child,.related-row:last-child{border-bottom:0;padding-bottom:0}.article-list img,.record-item img,.rank-item img,.related-row img{border-radius:5px;height:72px}.article-list h3,.news-item h3,.news-item h2,.record-item h3,.rank-item h3,.related-row h3{margin:0;font-size:15px;line-height:1.48}.news-item{color:inherit;grid-template-columns:52px 1fr;text-decoration:none}.news-item-body{min-width:0}.news-item:hover h3,.news-item:hover h2{color:var(--green)}.news-item small{color:var(--muted);margin-top:5px;font-size:12px;font-weight:700;display:block}.news-pagination{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:24px;display:flex}.news-page-link{min-width:42px;padding:0 12px}.news-page-link.active{border-color:var(--green);color:#fff;background:var(--green)}.news-page-ellipsis{min-height:42px;color:var(--muted);align-items:center;font-weight:900;display:inline-flex}.seo-page{width:min(var(--content), calc(100% - 40px));margin:0 auto;padding:28px 0 86px}.seo-breadcrumb{color:var(--muted);flex-wrap:wrap;gap:8px;margin:0 0 22px;font-size:13px;font-weight:800;display:flex}.seo-breadcrumb a{color:var(--green)}.seo-hero{border-bottom:1px solid var(--line);gap:12px;padding:44px 0 26px;display:grid}.seo-eyebrow{color:var(--green);letter-spacing:.16em;margin:0;font-size:12px;font-weight:900}.seo-hero h1,.seo-hero h2{margin:0;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:42px;font-weight:900;line-height:1.22}.seo-hero-embedded{padding-top:10px}.seo-hero p:last-child{max-width:780px;color:var(--muted);margin:0;font-size:17px;font-weight:800}.seo-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:24px 0;display:grid}.seo-stat{border:1px solid var(--line);border-radius:var(--radius);background:#fff;align-content:center;gap:4px;min-height:104px;padding:18px;display:grid;box-shadow:0 10px 30px #2b22140a}.seo-stat span{color:var(--muted);font-size:13px;font-weight:900}.seo-stat strong{overflow-wrap:anywhere;font-size:22px;line-height:1.32}.seo-section{border:1px solid var(--line);border-radius:var(--radius);background:#ffffffdb;margin-top:24px;padding:24px;box-shadow:0 10px 30px #2b22140a}.seo-section-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.seo-section-head h2{margin:0;font-size:24px;line-height:1.35}.seo-section-head span{color:var(--muted);font-size:13px;font-weight:900}.seo-copy{gap:12px;max-width:920px;display:grid}.seo-copy p{color:#3f3934;margin:0;font-weight:700;line-height:1.95}.seo-link-cloud{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.seo-link-cloud a{border:1px solid var(--line);background:#fff;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;min-height:44px;padding:9px 12px;font-weight:900;display:flex}.seo-link-cloud a:hover{color:var(--green);border-color:#2f7d3873}.seo-link-cloud small{color:var(--muted);white-space:nowrap;font-size:12px}.seo-kofun-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.seo-kofun-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden}.seo-kofun-card img{object-fit:cover;width:100%;height:150px}.seo-kofun-card>div{gap:8px;padding:14px;display:grid}.seo-kofun-card h3{margin:0;font-size:18px;line-height:1.38}.seo-kofun-card h3:hover{color:var(--green)}.seo-kofun-subtitle,.seo-kofun-meta{color:var(--muted);margin:0;font-size:13px;font-weight:800;line-height:1.55}.seo-kofun-tags{flex-wrap:wrap;gap:6px;display:flex}.seo-search-map-placeholder{min-height:310px;color:var(--green);text-align:center;align-content:center;place-items:center;gap:12px;display:grid}.seo-search-map-placeholder strong{color:var(--ink)}.news-badge{color:#fff;background:var(--green);border-radius:4px;justify-content:center;align-self:start;min-width:40px;padding:2px 7px;font-size:10px;font-weight:900;display:inline-flex}.news-item time,.article-list time,.record-item small,.rank-item small{color:var(--muted);font-size:13px;font-weight:700}.rank-item{grid-template-columns:56px 82px 1fr;align-items:center}.rank-no{color:#8d8a85;font-size:27px;font-weight:900}.rank-no.top{color:#d79a14}.rank-no.second{color:#8b98a5}.rank-no.third{color:#bf6530}.record-item{grid-template-columns:88px 1fr auto;align-items:center}.avatar{color:#fff;background:var(--green);border-radius:999px;place-items:center;width:24px;height:24px;font-size:12px;font-weight:900;display:inline-grid}.heart{color:#c45b4a;font-weight:900}.like-button{cursor:pointer;font:inherit;background:0 0;border:0;align-self:start;padding:0}.home-map-card img{object-fit:cover;border-radius:6px;width:100%;height:255px}.wide-button{width:100%;margin-top:16px}.breadcrumb{color:var(--muted);gap:8px;margin:24px 0;font-size:13px;font-weight:700;display:flex}.detail-hero{grid-template-columns:minmax(0,1.45fr) minmax(310px,.75fr);align-items:start;gap:28px;display:grid}.detail-gallery-main img{border-radius:6px;height:330px}.detail-side h1{margin:6px 0 4px;font-size:clamp(30px,4vw,42px);line-height:1.15}.detail-side .subtitle{margin:0 0 8px;font-size:22px;font-weight:900}.reading{color:var(--muted);margin:0 0 14px;font-weight:800}.action-row{grid-template-columns:1.35fr 1fr;gap:10px;margin:14px 0;display:grid}.photo-file-input{display:none}.photo-record-form svg{fill:none;stroke:currentColor;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px}.visit-photo-strip{grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0 16px;display:grid}.visit-photo-strip img{object-fit:cover;border-radius:6px;width:100%;height:68px}.visitor-box{padding:18px}.visitor-box strong{margin-top:6px;font-size:32px;line-height:1;display:block}.visitor-avatars{vertical-align:middle;align-items:center;margin-left:10px;display:inline-flex}.visitor-avatars .avatar{border:2px solid #fff;margin-left:-5px}.content-columns{grid-template-columns:minmax(0,1.1fr) minmax(310px,.76fr);gap:22px;padding:28px 0 74px;display:grid}.stack{gap:18px;display:grid}.info-table{border-collapse:collapse;width:100%;font-size:14px}.info-table th,.info-table td{border-top:1px solid var(--line);text-align:left;vertical-align:top;padding:13px 16px}.info-table th{background:#f8f6f1b3;width:150px}.lead-text{margin:0;font-size:15px;line-height:1.95}.mini-article-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.mini-article{gap:8px;display:grid}.mini-article img{object-fit:cover;border-radius:5px;width:100%;height:92px}.mini-article h3{margin:0;font-size:14px;line-height:1.45}.comment-box textarea{resize:vertical;min-height:108px;padding:14px 16px}.comment-box form{gap:10px;display:grid}.comment-item{border-top:1px solid var(--line);grid-template-columns:38px 1fr auto;gap:12px;padding:16px 0;display:grid}.comment-item:first-of-type{margin-top:14px}.comment-item p{margin:4px 0 8px}.comment-photos{gap:8px;display:flex;overflow:hidden}.comment-photos img{object-fit:cover;border-radius:4px;width:78px;height:48px}.map-frame,.map-shell{background:#eaf0e5;border:0;border-radius:6px;width:100%;height:240px}.map-shell{position:relative;overflow:hidden}.map-shell .pin-map{border-radius:6px;height:100%;min-height:0}.spot-list{gap:14px;margin:0;padding:0;list-style:none;display:grid}.spot-list li{grid-template-columns:28px 1fr;gap:10px;display:grid}.spot-list svg{width:24px;height:24px;color:var(--green);fill:none;stroke:currentColor;stroke-width:2px}.search-page,.listing-page{padding:36px 0 86px}.page-title{margin:0 0 8px;font-size:clamp(30px,4.5vw,42px);line-height:1.18}.page-lead{color:var(--muted);margin:0 0 24px;font-weight:700}.search-tools{grid-template-columns:1fr auto auto;align-items:center;gap:12px;margin:18px 0 28px;display:grid}.tool-button{border:1px solid var(--line);background:#fff;border-radius:6px;justify-content:center;align-items:center;gap:9px;min-height:52px;padding:0 18px;font-weight:900;display:inline-flex}.tool-button svg{width:22px;height:22px;color:var(--green);fill:none;stroke:currentColor;stroke-width:2.2px}.count-pill{color:#fff;background:var(--green);border-radius:999px;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;display:inline-flex}.result-head{justify-content:space-between;align-items:center;margin:0 0 14px;font-weight:900;display:flex}.photo-record-card{background:linear-gradient(#fff,#fbfff8);border-color:#2f7d3838}.photo-record-form{gap:14px;display:grid}.photo-record-form label,.photo-kofun-field{gap:7px;font-weight:900;display:grid}.kofun-suggestion-list{gap:6px;display:grid}.kofun-suggestion-list[hidden]{display:none}.kofun-suggestion-list p{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:7px;margin:0;padding:10px 12px;font-size:13px}.kofun-suggestion{border:1px solid var(--line);width:100%;color:var(--ink);text-align:left;cursor:pointer;background:#fff;border-radius:7px;gap:3px;padding:10px 12px;display:grid}.kofun-suggestion:hover{background:#fbfff8;border-color:#2f7d3873}.kofun-suggestion small{color:var(--muted);font-weight:700}.photo-map-picker{gap:8px;margin-top:4px;display:grid}.photo-map-picker-title{color:var(--green);align-items:center;gap:7px;font-size:14px;font-weight:900;display:inline-flex}.photo-map-picker-title svg{fill:none;stroke:currentColor;stroke-width:2.4px;width:18px;height:18px}.photo-map-picker .pin-map{border:1px solid var(--line);min-height:220px;box-shadow:0 10px 24px #3125150f}.photo-record-form input[type=file]{padding:12px 14px}.photo-count-tag{color:var(--green);background:var(--green-soft);margin-left:6px}.kofun-photo-gallery .section-head span{color:var(--muted);font-size:13px;font-weight:900}.photo-gallery-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.photo-gallery-grid img{aspect-ratio:4/3;object-fit:cover;background:var(--sand);border-radius:6px;width:100%}.pin-map{background:#eaf0e5;border-radius:8px;min-height:310px;position:relative;overflow:hidden}.pin-map.compact{min-height:235px}.leaflet-map{width:100%;min-height:inherit;height:100%}.leaflet-map .leaflet-control-attribution{font-size:10px}.kofun-leaflet-marker{background:var(--green);border:2px solid #fff;border-radius:999px 999px 999px 4px;place-items:center;width:28px;height:34px;display:grid;transform:rotate(-45deg);box-shadow:0 8px 18px #1e5c2a3d}.kofun-leaflet-marker span{background:#fff;border-radius:999px;width:10px;height:10px}.kofun-leaflet-marker.user{background:#3e8ed0}.leaflet-popup-link{color:var(--ink);gap:3px;text-decoration:none;display:grid}.leaflet-popup-link small{color:var(--muted);font-weight:700}.photo-map-select-button{width:100%;font:inherit;text-align:left;background:0 0;border:0}.photo-map-select-button span{color:var(--green);margin-top:4px;font-size:12px;font-weight:900}.leaflet-map-error{height:100%;min-height:inherit;color:var(--muted);place-items:center;font-weight:900;display:grid}.map-action{z-index:10;justify-content:center;display:flex;position:absolute;bottom:18px;left:18px;right:18px}.results-layout{grid-template-columns:minmax(0,.9fr) minmax(360px,1.1fr);align-items:start;gap:22px;display:grid}.kofun-results{gap:16px;display:grid}.kofun-list-card,.my-list-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;grid-template-columns:150px 1fr auto;gap:18px;padding:16px;display:grid;position:relative;box-shadow:0 10px 24px #2a22150a}.my-list-card>button{background:0 0;border:0;padding:0;display:block}.kofun-list-card img,.my-list-card img{border-radius:7px;height:120px}.kofun-list-card h3,.my-list-card h3{margin:0 0 4px;font-size:21px;line-height:1.35}.kofun-list-card p,.my-list-card p{color:var(--muted);margin:0 0 8px;font-weight:700}.card-actions{align-content:space-between;justify-items:end;display:grid}.bookmark-button{width:38px;height:38px;color:var(--muted);background:0 0;border:0;place-items:center;display:grid}.bookmark-button.active{color:var(--green)}.bookmark-button svg{fill:none;stroke:currentColor;stroke-width:2px;width:26px;height:26px}.more-dot{color:var(--muted);font-size:22px;line-height:1}.load-more{width:100%;margin-top:4px}.modal-backdrop{z-index:1000;background:#1a18167a;place-items:end center;display:grid;position:fixed;inset:0}.filter-panel{background:#fff;border-radius:14px 14px 0 0;width:min(520px,100%);max-height:min(90vh,980px);overflow:auto;box-shadow:0 -18px 50px #0000002e}.auth-panel{background:#fff;border-radius:12px;width:min(430px,100% - 28px);overflow:hidden;box-shadow:0 22px 70px #00000038}.visit-method-panel{background:#fff;border-radius:12px;width:min(460px,100% - 28px);overflow:hidden;box-shadow:0 22px 70px #00000038}.visit-method-body{gap:12px;padding:22px 24px 24px;display:grid}.visit-method-body p{color:var(--muted);margin:0 0 4px;font-weight:800}.visit-method-option{border:1px solid var(--line);width:100%;color:var(--ink);text-align:left;background:#fff;border-radius:8px;grid-template-columns:44px 1fr;gap:4px 14px;padding:15px;display:grid}.visit-method-option:hover{background:#fbfff8;border-color:#2f7d3873}.visit-method-option>span{width:44px;height:44px;color:var(--green);background:var(--green-soft);border-radius:999px;grid-row:span 2;place-items:center;display:grid}.visit-method-option svg{fill:none;stroke:currentColor;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round;width:23px;height:23px}.visit-method-option strong{line-height:1.25}.visit-method-option small{color:var(--muted);white-space:normal;font-weight:700;line-height:1.45}.auth-form{gap:14px;padding:22px 24px 24px;display:grid}.auth-form label{gap:7px;font-weight:900;display:grid}.google-button{border:1px solid var(--line);min-height:48px;color:var(--ink);cursor:pointer;background:#fff;border-radius:7px;justify-content:center;align-items:center;gap:10px;font-weight:900;display:inline-flex}.google-button:hover{background:#fbfdf9;border-color:#2f7d3261}.google-mark{color:#fff;background:#4285f4;border-radius:50%;place-items:center;width:22px;height:22px;font-size:14px;font-weight:900;display:inline-grid}.auth-divider{color:var(--muted);grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;font-size:12px;font-weight:800;display:grid}.auth-divider:before,.auth-divider:after{background:var(--line);content:"";height:1px}.auth-message{color:var(--green-dark);background:var(--green-soft);border-radius:7px;margin:0;padding:12px 14px;font-weight:800}.auth-error{color:#b33424;min-height:20px;margin:0;font-weight:800}.filter-head{z-index:1;border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;padding:22px 24px;display:flex;position:sticky;top:0}.filter-head h2{margin:0;font-size:20px}.filter-body{gap:22px;padding:22px 24px 24px;display:grid}.filter-section{border-bottom:1px solid var(--line);gap:12px;padding-bottom:20px;display:grid}.filter-section:last-child{border-bottom:0}.filter-title{justify-content:space-between;align-items:center;font-weight:900;display:flex}.check-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.check-card,.check-line{border:1px solid var(--line);border-radius:6px;align-items:center;gap:9px;min-height:44px;padding:0 12px;font-weight:800;display:flex}.check-line{border:0;padding:0}.check-card input,.check-line input{width:18px;height:18px;accent-color:var(--green)}.range-wrap input,.distance-range-wrap input{width:100%;accent-color:var(--green)}.distance-filter-section{gap:14px}.distance-toggle-row{justify-content:space-between;align-items:center;gap:18px;min-height:42px;font-weight:900;display:flex}.distance-toggle-label{align-items:center;gap:9px;display:inline-flex}.distance-toggle-label svg{fill:none;stroke:currentColor;stroke-width:2.4px;width:22px;height:22px}.switch-control{flex:none;align-items:center;width:58px;height:32px;display:inline-flex;position:relative}.switch-control input{z-index:1;cursor:pointer;opacity:0;margin:0;position:absolute;inset:0}.switch-track{background:#d7e1de;border-radius:999px;width:100%;height:100%;transition:all .18s;position:relative}.switch-track:after{content:"";background:#fff;border-radius:999px;width:24px;height:24px;transition:all .18s;position:absolute;top:4px;left:4px;box-shadow:0 3px 10px #2720182e}.switch-control input:checked+.switch-track{background:#24b9bf}.switch-control input:checked+.switch-track:after{transform:translate(26px)}.distance-range-wrap{color:var(--ink);grid-template-columns:1fr auto;gap:12px;font-weight:800;display:grid}.distance-range-wrap input{grid-column:1/-1}.distance-range-wrap.disabled{color:var(--muted);opacity:.55}.distance-range-wrap.disabled input{cursor:not-allowed}.filter-actions{grid-template-columns:1fr 1.4fr;gap:12px;padding-top:6px;display:grid}.record-page-grid,.my-page-grid{grid-template-columns:minmax(320px,.8fr) minmax(0,1.2fr);gap:24px;padding:32px 0 84px;display:grid}.radius-control{grid-template-columns:1fr 92px;align-items:end;gap:10px;display:grid}.radius-control label{gap:8px;font-weight:900;display:grid}.radius-control input{min-height:46px;padding:0 12px}.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.stat{background:var(--green-soft);border-radius:7px;padding:16px}.stat strong{font-size:28px;line-height:1;display:block}.prefecture-progress-card .section-head{align-items:baseline}.prefecture-progress-list{gap:12px;max-height:520px;padding-right:4px;display:grid;overflow:auto}.prefecture-progress-row{gap:6px;display:grid}.prefecture-progress-row>div:first-child,.prefecture-progress-row small{justify-content:space-between;gap:10px;display:flex}.prefecture-progress-row strong{font-size:14px}.prefecture-progress-row span,.prefecture-progress-row small{color:var(--muted);font-size:12px;font-weight:800}.prefecture-progress-track{background:#ece5dc;border-radius:999px;height:8px;overflow:hidden}.prefecture-progress-track span{border-radius:inherit;background:var(--green);min-width:0;height:100%;display:block}.tabs{gap:8px;margin-bottom:14px;display:flex}.tab-button{border:1px solid var(--line);background:#fff;border-radius:999px;min-height:42px;padding:0 18px;font-weight:900}.tab-button.active{border-color:var(--green);color:#fff;background:var(--green)}.map-list{gap:12px;margin-top:16px;display:grid}.empty-state{border-radius:var(--radius);min-height:190px;color:var(--muted);text-align:center;border:1px dashed #cfc5b8;place-items:center;padding:24px;display:grid}.ranking-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.62fr);gap:24px;padding:32px 0 84px;display:grid}.footer-link-row{border-top:1px solid var(--line);color:var(--green);justify-content:center;gap:44px;padding:24px 0 44px;font-weight:900;display:flex}.bottom-nav{display:none}.toast{z-index:1200;color:#fff;max-width:min(420px,100vw - 40px);box-shadow:var(--shadow);opacity:0;pointer-events:none;background:#1f5f2bf2;border-radius:8px;padding:13px 16px;font-weight:800;transition:all .2s;position:fixed;bottom:20px;right:20px;transform:translateY(12px)}.toast.show{opacity:1;transform:translateY(0)}@media (max-width:980px){.desktop-nav,.login-button,.signup-button{display:none}.mobile-auth-actions .login-button,.mobile-auth-actions .signup-button{display:inline-flex}.site-header{height:76px;padding:0 18px}.menu-button{display:inline-grid}.brand-text strong{font-size:24px}.hero,.hero-inner{min-height:auto}.hero-inner{padding:58px 18px 22px;display:block}.hero-copy p{margin-bottom:140px}.search-card{padding:20px}.record-card{margin-top:18px}.quick-actions{border-bottom:0;grid-template-columns:repeat(4,1fr);gap:12px;width:calc(100% - 36px);padding:22px 0}.quick-action{border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;grid-template-columns:1fr;justify-items:center;gap:8px;min-height:118px;padding:14px 8px;display:grid}.quick-action strong{font-size:13px}.quick-action span{font-size:11px}.section-grid,.detail-hero,.content-columns,.results-layout,.record-page-grid,.my-page-grid,.ranking-grid,.article-feature{grid-template-columns:1fr}.detail-gallery-main img{height:290px}.page{width:calc(100% - 28px)}.search-tools{grid-template-columns:1fr}.bottom-nav{z-index:48;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff2;border:1px solid #d9d1c4e6;border-radius:22px;grid-template-columns:repeat(5,minmax(0,1fr));min-height:72px;padding:7px 8px;display:grid;position:fixed;bottom:12px;left:14px;right:14px;box-shadow:0 18px 45px #2a221529}.bottom-nav a,.bottom-nav button{color:#5f5b56;cursor:pointer;background:0 0;border:0;place-items:center;gap:2px;padding:0;font-family:inherit;font-size:11px;font-weight:800;text-decoration:none;display:grid}.bottom-nav a.active,.bottom-nav button.active{color:var(--green)}.bottom-nav svg{stroke-width:2px;width:24px;height:24px}.bottom-nav .bottom-primary svg{color:#fff;background:var(--green);border-radius:999px;width:38px;height:38px;padding:8px}.app-shell{padding-bottom:88px}.seo-stat-grid,.seo-kofun-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.seo-link-cloud{grid-template-columns:repeat(3,minmax(0,1fr))}.footer-link-row{display:none}}@media (max-width:640px){.brand-mark{width:28px;height:38px}.brand-text strong{font-size:21px}.icon-button{width:40px;height:40px}.hero{background-position:top}.hero-inner{width:100%;padding:58px 14px 18px}.hero-copy h1{letter-spacing:0;margin-left:24px;margin-right:24px;font-size:31px}.hero-copy p{margin-bottom:110px;margin-left:24px;margin-right:24px;font-size:15px}.search-card{background:#fffffff0;border-color:#d9cebef2;width:100%;padding:17px 18px 18px;box-shadow:0 14px 36px #3125151f}.search-card h2{font-size:21px}.search-card .search-row{grid-template-columns:1fr 52px;margin-top:12px}.search-card .search-row input,.search-card .search-row button{min-height:44px}.search-card .search-row input{padding:0 13px;font-size:14px}.search-card .keyword-row{gap:5px;margin-top:11px;font-size:11px;line-height:1.25}.keyword-row span:first-child{width:100%}.search-card .chip{border-radius:5px;min-height:25px;padding:0 7px;font-size:11px}.record-card{text-align:left;background:#fafff2f0;border-color:#cbdcb9e6;grid-template-columns:84px 1fr;gap:8px 16px;width:100%;margin-top:16px;padding:16px 18px;display:grid;box-shadow:0 12px 30px #2f7d3814}.record-card .pin-badge{background:#edf8e8;grid-row:1/3;width:64px;height:64px;margin:3px 0 0}.record-card .pin-badge svg{width:38px;height:38px}.record-card h2{align-self:end;margin:0;font-size:17px;line-height:1.35}.record-card p{margin:0;font-size:12px;line-height:1.55}.record-card .primary-button,.record-card .ghost-button{grid-column:1/-1}.record-card .primary-button{min-height:39px;margin-top:1px}.record-card .ghost-button{min-height:24px;margin-top:0;padding:0;font-size:13px}.quick-actions{grid-template-columns:repeat(4,minmax(74px,1fr));overflow-x:auto}.section-grid{padding-top:12px}.card-pad{padding:18px}.section-head h2,.card-title{font-size:21px}.article-main img{height:220px}.article-list-item,.record-item,.rank-item,.related-row{grid-template-columns:86px 1fr}.record-item{grid-template-columns:78px 1fr auto}.rank-item{grid-template-columns:42px 74px 1fr}.mini-article-grid,.action-row,.filter-actions,.stat-grid,.radius-control{grid-template-columns:1fr}.detail-side h1{font-size:30px}.detail-side .subtitle{font-size:18px}.content-columns{padding-top:18px}.info-table th,.info-table td{width:100%;padding:10px 12px;display:block}.info-table td{border-top:0;padding-top:0}.pin-map{min-height:230px}.photo-map-picker .pin-map{min-height:210px}.kofun-list-card,.my-list-card{grid-template-columns:126px 1fr 32px;gap:12px;padding:12px}.kofun-list-card img,.my-list-card img{height:118px}.kofun-list-card h3,.my-list-card h3{font-size:18px}.kofun-list-card p,.my-list-card p{font-size:13px}.check-grid{grid-template-columns:1fr 1fr}.photo-gallery-grid{grid-template-columns:repeat(2,1fr)}.seo-page{width:calc(100% - 28px);padding-top:20px}.seo-hero{padding:28px 0 20px}.seo-hero h1,.seo-hero h2{font-size:31px}.seo-hero p:last-child{font-size:15px}.seo-stat-grid,.seo-link-cloud,.seo-kofun-grid{grid-template-columns:1fr}.seo-section{padding:18px}.seo-section-head{gap:6px;display:grid}.seo-section-head h2{font-size:21px}.seo-kofun-card{grid-template-columns:118px 1fr;display:grid}.seo-kofun-card img{height:100%;min-height:136px}}
