:root{color:#1f2926;font-synthesis:none;text-rendering:optimizelegibility;background:#f7f3ea;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(#0f6b631f,#0000 240px),#f7f3ea;min-width:320px;min-height:100vh;margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled,.file-button.disabled{cursor:not-allowed;opacity:.68}.app-shell{min-height:100vh}.app-main{min-height:100vh;padding-bottom:104px}.app-main.detail-active{padding-bottom:0}.page{width:min(100%,760px);margin:0 auto;padding:24px 16px 32px}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.page-header{padding:12px 0 22px}.page-header.compact{padding-bottom:14px}.detail-header{padding-bottom:8px;position:relative}.detail-header.achieved{padding-right:72px}.detail-header.category-nature{--detail-category-color:#16845f}.detail-header.category-history{--detail-category-color:#a83a35}.detail-header.category-culture{--detail-category-color:#7150a1}.detail-header.category-food{--detail-category-color:#b36d00}.detail-header.category-lively{--detail-category-color:#216f9f}.detail-header.category-other{--detail-category-color:#6c655d}.eyebrow{color:#0f6b63;margin:0 0 6px;font-size:.86rem;font-weight:700}.detail-header .eyebrow{color:var(--detail-category-color,#0f6b63)}h1,h2,h3,p{overflow-wrap:anywhere}h1{letter-spacing:0;margin:0;font-size:2rem;line-height:1.15}h2{letter-spacing:0;margin:0 0 10px;font-size:1.12rem}h3{letter-spacing:0;margin:6px 0;font-size:1rem}.section-title{margin:22px 0 10px}.welcome{place-items:center;min-height:100vh;padding:24px 16px;display:grid}.welcome-panel{background:#ffffffd1;border:1px solid #1f29261f;border-radius:8px;width:min(100%,420px);padding:28px 20px;box-shadow:0 20px 60px #1f29261f}.welcome-summary{color:#53645f;margin:14px 0 0;font-size:.92rem;line-height:1.7}.welcome-summary p{margin:0}.welcome-summary p+p{margin-top:8px}.welcome-form,.settings-form{gap:10px;margin-top:24px;display:grid}.welcome-restore{border-top:1px solid #1f29261f;gap:10px;margin-top:18px;padding-top:16px;display:grid}.welcome-restore .notice{color:#53645f;margin:0}label{font-weight:700}input,select,textarea{color:#1f2926;background:#fffdfa;border:1px solid #1f292633;border-radius:8px;width:100%}input,select{min-height:44px;padding:0 12px}textarea{resize:vertical;padding:12px}button,.primary-link,.file-button{color:#fff;background:#0f6b63;border:0;border-radius:8px;justify-content:center;align-items:center;min-height:44px;padding:0 16px;font-weight:800;display:inline-flex}.primary-link{width:fit-content}.detail-meta{color:var(--detail-category-color,#0f6b63);margin:12px 0 0;font-size:.9rem;font-weight:900;line-height:1.5}.detail-text-link{color:#0f6b63;text-underline-offset:3px;font-size:.9rem;font-weight:800;text-decoration:underline;display:inline}.detail-achievement-stamp{color:#2f8b51;background:radial-gradient(circle,#ffffffb8 0 45%,#0000 46%),repeating-radial-gradient(circle,#0000 0 6px,#2f8b511f 7px 8px),#fffdfacc;border:2px solid #2f8b51;border-radius:999px;place-items:center;width:62px;height:62px;display:grid;position:absolute;top:34px;right:0;transform:rotate(-8deg);box-shadow:0 5px 14px #2f8b5129}.detail-achievement-stamp:before{content:"";opacity:.58;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 96 62'%3E%3Cg fill='none' stroke='%232f8b51' stroke-linecap='round' stroke-linejoin='round' stroke-width='5'%3E%3Cpath d='M18 34 39 12l10 13 7-8 22 27'/%3E%3Cpath d='M27 34h43'/%3E%3Cpath d='M12 47c10-6 20-6 30 0s20 6 30 0 14-4 20 0'/%3E%3C/g%3E%3C/svg%3E") 50%/contain no-repeat;position:absolute;inset:18px 9px 8px}.detail-achievement-stamp span{z-index:1;box-sizing:border-box;-webkit-text-stroke:.25px currentColor;border:1px solid #2f8b519e;border-radius:999px;place-items:start center;width:50px;height:50px;padding-top:6px;font-family:Hiragino Maru Gothic ProN,Meiryo,sans-serif;font-size:.82rem;font-weight:900;line-height:1;display:grid;position:relative}.spot-description{color:#1f2926;margin:0 0 14px;font-size:.98rem;line-height:1.75}.related-links{gap:10px;margin-top:16px;display:grid}.related-link{color:#1f2926;background:#fffdfa;border:1px solid #0f6b6338;border-radius:8px;gap:4px;padding:14px;display:grid}.related-link strong{color:#0f6b63;font-size:.98rem}.related-link span{color:#53645f;font-size:.9rem;line-height:1.55}.ghost-button{color:#1f2926;background:#fffdfa;border:1px solid #1f292638}.notice,.error-text,.success-text{font-size:.9rem;line-height:1.6}.error-text{color:#a3332b}.success-text{color:#0f6b63;margin:0;font-weight:700}.content-section button+.success-text{margin-top:10px}.backup-result{gap:4px;margin-top:10px;display:grid}.backup-result .notice{color:#53645f;margin:0;font-weight:800}.import-file-button{width:fit-content}.danger-section{background:#fffaf8eb;border-color:#a3332b3d}.danger-check{color:#1f2926;align-items:flex-start;gap:10px;margin:12px 0;font-size:.92rem;line-height:1.5;display:flex}.danger-check input{accent-color:#a3332b;width:18px;min-width:18px;height:18px;min-height:18px;margin-top:2px}.danger-button{background:#a3332b;margin-top:10px}.danger-button:disabled{color:#ffffffdb;background:#b8aaa5}.confirm-dialog{color:#1f2926;background:#fffdfa;border:1px solid #1f292629;border-radius:8px;width:min(100% - 32px,400px);padding:22px 20px 18px;box-shadow:0 22px 70px #1f292647}.confirm-dialog::backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1f292685}.confirm-dialog h2{margin-bottom:8px}.confirm-dialog p{color:#53645f;margin:0;line-height:1.6}.confirm-dialog-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:20px;display:grid}.confirm-dialog-actions button{width:100%;margin:0}.result-count{color:#53645f;margin:0 0 12px;font-size:.9rem;font-weight:800}.current-rank-panel{background:#ffffffe6;border:1px solid #1f29261f;border-radius:8px;margin-bottom:14px;padding:20px}.current-rank-panel strong{font-size:2.1rem;line-height:1.1;display:block}.current-rank-panel p{color:#53645f;margin:10px 0 0;font-weight:800}.shinsei-actions{border-top:1px solid #1f29261f;margin-top:16px;padding-top:12px}.current-rank-panel .shinsei-description{margin:0 0 10px;font-size:.95rem}.shinsei-actions button{width:100%}.shinsei-actions button:disabled{color:#7b8984;opacity:1;background:#eef1ee;border:1px solid #bfcac5}.backup-result p{margin:0;font-size:.9rem;line-height:1.6}.backup-result .success-text{color:#0f6b63;font-weight:700}.shinsei-actions .photo-warning{font-size:.85rem;font-weight:600}.photo-summary-grid div{text-align:center;background:#fffdfa;border:1px solid #1f29261f;border-radius:8px;min-width:0;padding:12px 4px}.photo-summary-grid span{color:#53645f;margin-bottom:5px;font-size:.72rem;font-weight:900;line-height:1.25;display:block}.photo-summary-grid strong{color:#0f6b63;font-size:1.18rem;line-height:1.1;display:inline}.photo-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px;display:grid}.photo-summary-grid small{color:#53645f;margin-left:2px;font-size:.78rem;font-weight:800}.meter{background:#1f29261a;border-radius:999px;height:10px;overflow:hidden}.meter span{border-radius:inherit;background:linear-gradient(90deg,#0f6b63,#2f8b51);height:100%;display:block}.meter-caption{color:#53645f;margin:8px 0 0;font-size:.86rem;font-weight:800}.breakdown-list{gap:8px;margin-bottom:14px;display:grid}.breakdown-row{background:#ffffffd6;border:1px solid #1f29261f;border-radius:8px;gap:8px;padding:12px;display:grid}.breakdown-row>div:first-child{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.breakdown-row span{color:#1f2926;font-size:.92rem;font-weight:900;line-height:1.35}.breakdown-row strong{color:#0f6b63;white-space:nowrap;font-size:.96rem}.empty-gallery,.gallery-card{background:#ffffffd6;border:1px solid #1f29261f;border-radius:8px}.page-heading{gap:6px;margin-bottom:14px;padding:4px 2px 0;display:grid}.page-heading h1{color:#1f2926;margin:0;font-size:1.8rem;line-height:1.18}.page-heading p,.empty-gallery p{color:#53645f;margin:0;font-size:.92rem;font-weight:800;line-height:1.6}.empty-gallery{gap:8px;padding:18px;display:grid}.empty-gallery .primary-link{margin-top:6px}.gallery-list{gap:12px;display:grid}.gallery-card{gap:12px;padding:0;display:grid;overflow:hidden}.gallery-card.category-nature{--gallery-category-color:#16845f}.gallery-card.category-history{--gallery-category-color:#a83a35}.gallery-card.category-culture{--gallery-category-color:#7150a1}.gallery-card.category-food{--gallery-category-color:#b36d00}.gallery-card.category-lively{--gallery-category-color:#216f9f}.gallery-card.category-other{--gallery-category-color:#6c655d}.gallery-card-header{background:linear-gradient(90deg, color-mix(in srgb, var(--gallery-category-color,#0f6b63), transparent 88%), color-mix(in srgb, var(--gallery-category-color,#0f6b63), transparent 96%)), #fffdfa;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding:14px;display:grid}.gallery-photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:0 14px 14px;display:grid}.gallery-title-line{gap:3px;display:grid}.gallery-number{color:var(--gallery-category-color,#0f6b63);font-size:.82rem;font-weight:900;line-height:1.2}.gallery-card h2{color:#1f2926;margin:0;font-size:1.08rem;line-height:1.35}.gallery-meta-line{color:#53645f;flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;font-size:.86rem;font-weight:800;display:flex}.gallery-detail-link{border:1px solid color-mix(in srgb, var(--gallery-category-color,#0f6b63), transparent 72%);min-height:36px;color:var(--gallery-category-color,#0f6b63);white-space:nowrap;background:#fffdfa;border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-size:.82rem;font-weight:900;display:inline-flex}.status-pill{color:#53645f;background:#53645f1f;border-radius:999px;align-items:center;min-height:24px;padding:0 9px;font-size:.76rem;font-weight:900;display:inline-flex}.status-pill.achieved{color:#2f8b51;background:#2f8b5124}.status-pill.in-progress{color:#9a5b00;background:#b36d0024}.gallery-photo-item{gap:6px;display:grid}.gallery-photo-item span{color:#1f2926;font-size:.84rem;font-weight:900;line-height:1.35}.gallery-photo-item img{object-fit:contain;background:0 0;border-radius:8px;width:100%;height:auto;max-height:320px;display:block}.gallery-photo-item .error-text{margin:0;font-size:.82rem;font-weight:800}.empty-text{color:#53645f;margin:0;font-size:.9rem;font-weight:800}.next-action,.content-section,.rank-list{background:#ffffffd6;border:1px solid #1f29261f;border-radius:8px}.metric-label{color:#53645f;margin-bottom:8px;font-size:.84rem;font-weight:700;display:block}.progress-summary-panel{text-align:center;background:#ffffffd6;border:1px solid #1f29261f;border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:14px;display:grid;overflow:hidden}.progress-summary-panel div{min-width:0;padding:14px 4px}.progress-summary-panel div+div{border-left:1px dashed #1f29262e}.progress-summary-panel span{color:#53645f;margin-bottom:4px;font-size:.74rem;font-weight:800;display:block}.progress-summary-panel strong{font-size:1.4rem;line-height:1.1}.progress-summary-panel small{color:#53645f;margin-left:2px;font-size:.72rem;font-weight:800}.next-action,.content-section{margin-bottom:14px;padding:18px}.next-action .primary-link{margin-top:2px}.next-action p,.content-section p{line-height:1.7}.filters{background:#fffdfae6;border:1px solid #1f29261f;border-radius:8px;gap:10px;margin-bottom:16px;padding:10px;display:grid;box-shadow:0 10px 24px #1f292614}.search-label{display:block;position:relative}.search-label input{background:#fff;border-color:#1f292624;padding-left:40px;padding-right:44px}.search-label input::-webkit-search-cancel-button{display:none}.search-clear{color:#53645f;background:0 0;border:0;border-radius:50%;place-items:center;width:32px;min-width:32px;height:32px;min-height:32px;padding:0;font-size:1.45rem;line-height:1;display:grid;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.search-clear:hover,.search-clear:focus-visible{color:#0f6b63;background:#0f6b631a}.search-icon{z-index:1;border:2px solid #53645f;border-radius:999px;width:16px;height:16px;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.search-icon:after{content:"";background:#53645f;border-radius:999px;width:8px;height:2px;position:absolute;bottom:-4px;right:-6px;transform:rotate(45deg)}.list-hero{background:#dce9e8;border-radius:8px;height:200px;margin-bottom:14px;display:grid;position:relative;overflow:hidden;box-shadow:0 18px 40px #1f29261f}.list-hero picture,.list-hero img{width:100%;height:100%;display:block}.list-hero picture{position:absolute;inset:0}.list-hero img{object-fit:cover;object-position:center 58%}@media (width>=560px){.list-hero img{object-position:center 35%}}.list-hero:after{content:"";pointer-events:none;background:linear-gradient(135deg,#0b232099,#0b232000 52%),linear-gradient(#0b232000 58%,#0b232073);position:absolute;inset:0}.list-hero-copy{z-index:1;color:#fffdf5;text-shadow:0 2px 12px #1f292652;position:absolute;top:14px;left:16px;right:16px}.list-hero-credit{z-index:1;color:#fff;background:#1f2926b3;border-radius:4px;padding:3px 7px;font-size:.68rem;font-weight:700;line-height:1.4;position:absolute;bottom:8px;right:10px}.list-hero p{margin:0 0 4px;font-size:.86rem;font-weight:900}.list-hero h1{white-space:nowrap;margin:0;font-size:1.42rem;line-height:1.18}.list-hero h1 span{color:#ff7a32;font-size:1.18em}.list-summary{background:linear-gradient(135deg,#fffffff5,#fffdfadb),#fffdfa;border:1px solid #1f29261f;border-radius:8px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:14px;display:grid;overflow:hidden;box-shadow:0 10px 26px #1f29261a}.summary-item{text-align:center;min-width:0;padding:12px 8px 11px}.summary-item+.summary-item{border-left:1px dashed #b36d0047}.list-summary span{color:#4b3f37;margin-bottom:4px;font-size:.78rem;font-weight:900;line-height:1.2;display:block}.summary-value{white-space:nowrap;justify-content:center;align-items:baseline;gap:2px;line-height:1;display:inline-flex}.summary-value em{letter-spacing:0;font-size:2.15rem;font-style:normal;font-weight:900}.summary-value small{color:#1f2926;font-size:1rem;font-weight:900}.summary-item.achieved span,.summary-item.achieved em{color:#009b63}.summary-item.total span,.summary-item.total em{color:#1268ad}.summary-item.next em{color:#e64b00}.segmented-control{background:#0f6b631f;border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:4px;display:grid}.segmented-control button{color:#29423d;background:0 0;border-radius:6px;min-height:40px;padding:0 4px;font-size:.82rem}.segmented-control button.active{color:#0f6b63;background:#fffdfa;box-shadow:0 2px 10px #1f29261f}.category-filter{grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;display:grid}.category-filter-button{color:#53645f;background:#fff;border:1px solid #1f29261f;border-radius:8px;place-items:center;gap:2px;min-width:0;min-height:56px;padding:8px 3px 1px;display:grid}.category-filter-button img{filter:brightness(0)invert();object-fit:contain;width:22px;height:22px}.category-filter-icon,.category-filter-all-icon{border-radius:999px;place-items:center;width:30px;height:30px;display:grid}.category-filter-icon{background:var(--category-color,#0f6b63)}.category-filter-all-icon{color:#0f6b63;background:#efebe5;font-size:.86rem;font-weight:900}.category-filter-button small{color:currentColor;overflow-wrap:anywhere;text-align:center;min-height:2em;font-size:.58rem;font-weight:900;line-height:1.05;display:block}.category-filter-button.active{border-color:var(--category-color,#0f6b63);background:var(--category-tint,#0f6b631f);color:var(--category-color,#0f6b63);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--category-color,#0f6b63), transparent 65%)}.category-filter-button.category-all{--category-color:#0f6b63;--category-tint:#0f6b631f}.category-filter-button.category-nature{--category-color:#16845f;--category-tint:#16845f1f}.category-filter-button.category-history{--category-color:#a83a35;--category-tint:#a83a351f}.category-filter-button.category-culture{--category-color:#7150a1;--category-tint:#7150a11f}.category-filter-button.category-food{--category-color:#b36d00;--category-tint:#b36d0024}.category-filter-button.category-lively{--category-color:#216f9f;--category-tint:#216f9f1f}.category-filter-button.category-other{--category-color:#6c655d;--category-tint:#6c655d24}.spot-list{gap:12px;display:grid}.spot-card{background:linear-gradient(90deg, #fffdfafa, #fffdfac2), var(--category-soft,#fffdfa);border:1px solid #1f29261f;border-radius:8px;grid-template-columns:66px minmax(0,1fr);gap:1px 12px;min-height:108px;padding:10px 14px 8px 0;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid;position:relative;overflow:hidden;box-shadow:0 12px 28px #1f292614}.spot-card:hover{border-color:color-mix(in srgb, var(--category-color,#6f8f88), transparent 55%);transform:translateY(-1px);box-shadow:0 16px 34px #1f29261f}.spot-card.category-nature{--category-color:#16845f;--category-soft:#e7f5ec;--category-tint:#16845f1f}.spot-card.category-history{--category-color:#a83a35;--category-soft:#faece8;--category-tint:#a83a351f}.spot-card.category-culture{--category-color:#7150a1;--category-soft:#f0eaf8;--category-tint:#7150a11f}.spot-card.category-food{--category-color:#b36d00;--category-soft:#fff3d1;--category-tint:#b36d0024}.spot-card.category-lively{--category-color:#216f9f;--category-soft:#e5f2f8;--category-tint:#216f9f1f}.spot-card.category-other{--category-color:#6c655d;--category-soft:#efebe5;--category-tint:#6c655d24}.spot-card.achieved{background:linear-gradient(90deg, #fffdfafa, #effaf4cc), var(--category-soft,#f0faf5);padding-right:110px}.category-ribbon{z-index:1;background:var(--category-color,#6f8f88);place-items:center;width:66px;padding:10px 8px;display:grid;position:absolute;inset:0 auto 0 0}.category-ribbon img{filter:brightness(0)invert();object-fit:contain;width:36px;height:36px}.card-topline{color:#53645f;grid-column:2/3;justify-content:flex-start;align-items:center;gap:12px;font-size:.82rem;font-weight:800;display:flex}.spot-number{color:var(--category-color,#0f6b63)}.small-badge{color:#0f6b63;background:#0f6b631f;border-radius:999px;align-items:center;min-height:28px;padding:0 10px;font-size:.78rem;font-weight:900;display:inline-flex}.spot-card h2{z-index:1;grid-column:2/3;margin:0;font-size:1.08rem;line-height:1.16;position:relative}.spot-card p{color:#53645f;margin:0}.spot-meta{z-index:1;grid-column:2/3;font-size:.86rem;font-weight:900;line-height:1.14;position:relative;color:var(--category-color,#0f6b63)!important}.achievement-stamp{z-index:2;color:#2f8b51;background:radial-gradient(circle,#ffffffb8 0 45%,#0000 46%),repeating-radial-gradient(circle,#0000 0 6px,#2f8b511f 7px 8px),#fffdfacc;border:3px solid #2f8b51;border-radius:999px;place-items:center;width:86px;height:86px;display:grid;position:absolute;top:50%;right:14px;transform:translateY(-50%)rotate(-8deg);box-shadow:0 5px 14px #2f8b5129}.achievement-stamp:before{content:"";opacity:.62;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 96 62'%3E%3Cg fill='none' stroke='%232f8b51' stroke-linecap='round' stroke-linejoin='round' stroke-width='5'%3E%3Cpath d='M18 34 39 12l10 13 7-8 22 27'/%3E%3Cpath d='M27 34h43'/%3E%3Cpath d='M12 47c10-6 20-6 30 0s20 6 30 0 14-4 20 0'/%3E%3Cpath d='M18 56c9-4 18-4 27 0s18 4 27 0'/%3E%3C/g%3E%3C/svg%3E") 50%/contain no-repeat;position:absolute;inset:24px 12px 10px}.achievement-stamp span{z-index:1;box-sizing:border-box;-webkit-text-stroke:.35px currentColor;border:2px solid #2f8b519e;border-radius:999px;place-items:start center;width:70px;height:70px;padding-top:10px;font-family:Hiragino Maru Gothic ProN,Meiryo,sans-serif;font-size:1.08rem;font-weight:900;line-height:1;display:grid;position:relative}.photo-progress{z-index:1;grid-column:2/3;justify-content:flex-start;align-items:center;gap:6px;margin-top:0;font-weight:800;line-height:1.05;display:flex;position:relative}.photo-progress span{color:#53645f;font-size:.82rem}.photo-progress strong{color:#1f2926}.bottom-nav{z-index:20;padding:8px max(8px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffdfaf5;border-top:1px solid #1f292624;grid-template-columns:repeat(4,1fr);gap:4px;display:grid;position:fixed;bottom:0;left:0;right:0}.bottom-nav a{color:#53645f;border-radius:8px;align-content:center;place-items:center;gap:3px;min-height:60px;padding-top:3px;font-size:.72rem;font-weight:900;line-height:1.15;display:grid}.bottom-nav-icon{background:currentColor;width:22px;height:22px;display:block;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.nav-icon-list{-webkit-mask-image:url(/images/nav/list.png);mask-image:url(/images/nav/list.png)}.nav-icon-gallery{-webkit-mask-image:url(/images/nav/gallery.png);mask-image:url(/images/nav/gallery.png)}.nav-icon-progress{-webkit-mask-image:url(/images/nav/progress.png);mask-image:url(/images/nav/progress.png)}.nav-icon-settings{-webkit-mask-image:url(/images/nav/settings.png);mask-image:url(/images/nav/settings.png)}.bottom-nav a.active{color:#fff;background:#0f6b63}.spot-image{margin-bottom:12px;position:relative}.detail-page{padding-bottom:calc(104px + env(safe-area-inset-bottom));touch-action:pan-y}.detail-overlay{z-index:40;background:#1f29266b;display:grid;position:fixed;inset:0}.detail-overlay-panel{overscroll-behavior:contain;background:linear-gradient(#0f6b631f,#0000 240px),#f7f3ea;width:min(100%,760px);height:100%;margin:0 auto;overflow-y:auto;box-shadow:0 0 40px #1f29263d}.detail-action-bar{z-index:50;padding:8px max(12px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffdfaf5;border-top:1px solid #1f292624;grid-template-columns:minmax(0,1fr) minmax(104px,1.15fr) minmax(0,1fr);align-items:stretch;gap:8px;display:grid;position:fixed;bottom:0;left:0;right:0}.detail-close-button{width:100%;min-height:48px}.detail-action-slot{display:grid}.detail-move-button{color:#0f6b63;background:#fffdfa;border:1px solid #0f6b6347;place-content:center;gap:1px;min-width:0;min-height:48px;padding:4px 8px;line-height:1.15;display:grid}.detail-move-button span{font-size:.86rem;font-weight:900}.detail-move-button small{font-size:.72rem;font-weight:800}@media (width>=800px){.detail-overlay{padding:24px}.detail-overlay-panel{border-radius:12px;height:calc(100vh - 48px)}.detail-overlay .detail-action-bar{border-radius:0 0 12px 12px;width:min(100% - 48px,760px);bottom:24px;left:auto;right:50%;transform:translate(50%)}}.spot-image-frame{margin:0;position:relative}.spot-image img,.image-placeholder{aspect-ratio:16/9;border-radius:8px;width:100%}.spot-image-frame img{object-fit:cover;display:block}.spot-image-label{color:#24302d;text-overflow:ellipsis;white-space:nowrap;background:#fffdfadb;border-radius:999px;max-width:min(68%,360px);padding:4px 8px;font-size:.76rem;font-weight:800;line-height:1.35;position:absolute;bottom:8px;left:8px;overflow:hidden}.spot-image-frame figcaption{color:#fffdfa;text-align:right;background:#1f2926a3;border-radius:999px;max-width:36%;padding:4px 8px;font-size:.76rem;font-weight:800;line-height:1.35;position:absolute;bottom:8px;right:8px}.spot-image-thumbnails{scrollbar-width:thin;gap:8px;margin-top:8px;padding:2px 1px 4px;display:flex;overflow-x:auto}.spot-image-thumbnails button{cursor:pointer;opacity:.72;background:0 0;border:2px solid #0000;border-radius:8px;flex:0 0 72px;height:46px;padding:0}.spot-image-thumbnails button.active{opacity:1;border-color:#0f8b73;box-shadow:0 0 0 2px #0f8b732e}.spot-image-thumbnails img{object-fit:cover;border-radius:6px;width:100%;height:100%;display:block}.image-placeholder{color:#53645f;background:#ffffff80;border:1px dashed #1f292642;place-items:center;font-weight:800;display:grid}.requirement-list{gap:10px;display:grid}.requirement-card{background:#fffdfa;border:1px solid #1f29261f;border-radius:8px;gap:12px;padding:14px;display:grid}.requirement-card p{color:#53645f;margin:0}.file-name{font-weight:800;color:#1f2926!important;margin-top:8px!important}.photo-warning,.saving-text{font-size:.88rem;font-weight:800;line-height:1.55;margin-top:8px!important}.photo-warning{color:#a3332b!important}.saving-text{color:#0f6b63!important}.registered-photo{background:#e8e2d6;border-radius:8px;width:100%;height:auto;margin-top:12px;display:block}.requirement-actions{flex-wrap:wrap;gap:8px;display:flex}.requirement-status{gap:4px;display:grid}.file-button input{clip:rect(0 0 0 0);width:1px;height:1px;position:absolute;overflow:hidden}.memo-label{margin-bottom:8px;display:block}.rank-list{display:grid;overflow:hidden}.rank-list div{border-bottom:1px solid #1f29261f;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.rank-list div:last-child{border-bottom:0}
