/* styles.css - KUWANA QUEST basic styles and animations */
:root{
  --bg1:#0f172a;
  --bg2:#05264a;
  --accent:#ffd166;
  --muted:#9aa6b2;
  --white:#ffffff;
  --glass: rgba(255,255,255,0.06);
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,'Hiragino Kaku Gothic ProN',Meiryo,sans-serif;background:var(--bg1);color:var(--white);}
a{color:inherit}

.hero{position:relative;padding:6rem 1rem 4rem;overflow:hidden}
.hero-inner{max-width:900px;margin:0 auto;text-align:center}
.site-logo{display:block;margin:0 auto 0.6rem;max-width:240px;height:auto}
.hero .site-logo{filter:drop-shadow(0 6px 18px rgba(0,0,0,0.25));}
.title{font-size:3.25rem;margin:0 0 .25rem;letter-spacing:2px;animation:pop 1.2s ease both;font-family:'Press Start 2P',monospace;text-transform:uppercase}
.subtitle{margin:0 0 .75rem;color:#fff7bd;font-weight:700;font-family:system-ui,'Hiragino Kaku Gothic ProN',Meiryo,serif}
.lead{color:var(--muted);max-width:760px;margin:0 auto 1rem}

/* Poster / pamphlet look */
.hero.poster{padding:3rem 1rem 4rem;background-color:#f6efe0;background-image:linear-gradient(180deg,#f6efe0 0%,#fffaf0 60%), url('assets/pamphlet_bg.jpg');background-size:cover;background-position:center;background-repeat:no-repeat, no-repeat;color:#281b12}
.poster-graphics{display:none}

/* Adjust title/subtitle for parchment/pamphlet theme */
.hero.poster .title{color:#2b1f10}
.hero.poster .subtitle{color:#4a2f18}
/* Use a more natural, readable type for the pamphlet hero */
.hero.poster .title{font-family:system-ui,-apple-system,'Hiragino Kaku Gothic ProN',Meiryo,sans-serif;font-weight:800;text-transform:none;letter-spacing:0.6px;font-size:2.4rem}
.hero.poster .title small{display:block;font-size:0.6em;font-weight:600}
.hero.poster .lead{color:#5a4a36}

/* subtle overlay to keep text legible on busy background */
.hero.poster::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(8,6,4,0.45), rgba(255,250,240,0.06));pointer-events:none}

.poster-info{display:flex;gap:1rem;justify-content:center;margin-top:1.25rem}
.poster-card{background:#fff;border-radius:12px;padding:12px 14px;color:#0b1220;min-width:240px;box-shadow:0 8px 18px rgba(11,18,32,0.25);border:4px solid rgba(0,0,0,0.06)}
.poster-card .card-title{font-weight:800;color:#1b3a57;margin-bottom:6px}
.poster-card.period{background:linear-gradient(180deg,#fff,#f6fbff)}
.poster-card.reward{background:linear-gradient(180deg,#fff7e6,#fff)}

/* style card action links to use accent/link color instead of button look */
.poster-card .card-actions a{background:transparent;border:none;color:var(--accent);padding:0;text-decoration:underline}
.poster-card .card-actions a.btn{/* override btn class specifics if present */
  background:transparent;color:var(--accent);border:none;padding:0;text-decoration:underline;box-shadow:none
}


.period-badge{display:inline-block;background:rgba(255,255,255,0.08);padding:.4rem .75rem;border-radius:999px;color:var(--accent);font-weight:700;margin-bottom:1rem}

.app-links{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}
.app-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:rgba(255,255,255,0.06);border-radius:8px;border:1px solid rgba(255,255,255,0.06);color:var(--white);text-decoration:none}
.app-btn img{height:24px}

.faq .question{padding:.75rem 1rem;background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent);border-radius:8px;margin-bottom:.5rem;cursor:pointer}
.faq .answer{padding:.75rem 1rem;margin-top:.25rem;margin-bottom:.5rem;color:var(--muted);display:none}
.faq .open .answer{display:block}


.cta-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn{background:transparent;border:1px solid rgba(255,255,255,0.14);color:var(--white);padding:.65rem 1rem;border-radius:8px;cursor:pointer}
.btn.primary{background:var(--accent);color:#0b1220;border:none}

.hero-decor{position:absolute;inset:0;pointer-events:none}
.stamp{width:64px;height:64px;fill:rgba(255,255,255,0.08);position:absolute;transform-origin:center;}
.stamp-1{top:10%;left:8%;animation:float 6s ease-in-out infinite}
.stamp-2{top:18%;right:6%;animation:float 5s ease-in-out infinite;opacity:.9}
.stamp-3{bottom:8%;left:14%;animation:spin 12s linear infinite;opacity:.7}

@keyframes pop{0%{transform:translateY(12px) scale(.98);opacity:0}100%{transform:none;opacity:1}}
@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-18px)}100%{transform:translateY(0)}}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

main{max-width:1000px;margin:2rem auto;padding:0 1rem}
.panel{background:var(--glass);backdrop-filter:blur(6px);padding:1rem 1.25rem;border-radius:12px;margin-bottom:1rem}
h2{margin-top:0}
.map-grid{display:flex;gap:1rem;flex-wrap:wrap}
.spot{flex:1 1 220px;padding:1rem;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent);border:1px solid rgba(255,255,255,0.06);cursor:pointer;color:var(--white)}
.spot:hover{transform:translateY(-6px);transition:transform .18s}

/* スタンプコレクション表示は削除されたため関連スタイルは省略 */

.site-footer{max-width:1000px;margin:0 auto;padding:1rem;color:var(--muted);font-size:.9rem}

.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:40;visibility:hidden}
.modal[aria-hidden="false"]{visibility:visible;background:linear-gradient(180deg,rgba(2,6,23,0.6),rgba(2,6,23,0.85))}
.modal-panel{background:#071428;padding:1rem;border-radius:12px;max-width:460px;width:100%;color:var(--white);box-shadow:0 12px 40px rgba(2,6,23,0.7)}
.modal-close{position:absolute;right:1rem;top:1rem;background:transparent;border:none;color:var(--white);font-size:1.35rem;cursor:pointer}
.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}

@media (max-width:900px){.title{font-size:1.6rem}.poster-graphics{width:320px;height:100px;top:36px}.poster-card{min-width:160px;padding:10px}}
@media (max-width:600px){.title{font-size:1.2rem}.stamp{width:48px;height:48px}.map-grid{flex-direction:column}.poster-graphics{display:none}}
@media (max-width:420px){.site-logo{max-width:160px}}

/* Leaflet map adjustments */
#leafletMap{width:100%;height:480px;border:4px solid rgba(255,255,255,0.04);box-shadow:0 8px 20px rgba(2,6,23,0.35);border-radius:10px}

@media (max-width:800px){#leafletMap{height:360px}}

/* --- Reference-like animations & layout --- */
.hero .ribbon{position:absolute;right:12px;top:14px;background:linear-gradient(90deg,#ffd166,#ffb56b);color:#0b1220;padding:.5rem 1rem;border-radius:999px;font-weight:700;box-shadow:0 8px 20px rgba(0,0,0,0.12);transform-origin:center;animation:floaty 3.6s ease-in-out infinite}

@keyframes floaty{0%{transform:translateY(0)}50%{transform:translateY(-8px)}100%{transform:translateY(0)}}

.btn.primary{box-shadow:0 10px 24px rgba(217,83,79,0.18);transition:transform .18s ease,box-shadow .18s ease}
.btn.primary.pulse{animation:ctapulse 2.2s infinite}
@keyframes ctapulse{0%{transform:scale(1);box-shadow:0 8px 20px rgba(217,83,79,0.14)}50%{transform:scale(1.04);box-shadow:0 16px 36px rgba(217,83,79,0.22)}100%{transform:scale(1);box-shadow:0 8px 20px rgba(217,83,79,0.14)}}

/* animate-on-scroll: fade+slide */
.animate-on-scroll{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.animate-on-scroll.in-view{opacity:1;transform:translateY(0)}

/* stagger helpers */
.stagger > *{opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease}
.stagger.in-view > *{opacity:1;transform:translateY(0)}

/* small legend */
.map-legend{display:flex;gap:8px;align-items:center;margin-top:.75rem;color:var(--muted)}
.map-legend .item{display:flex;gap:6px;align-items:center}
.legend-swatch{width:18px;height:18px;border-radius:6px;border:2px solid rgba(0,0,0,0.06)}
.legend-stamp{background:#d9534f}
.legend-coupon{background:#ffd166}

/* counts box shown when zoomed out / aggregated view */
.map-counts{margin-left:12px;color:var(--muted);font-size:0.95rem;padding:.3rem .6rem;border-radius:0px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.04)}

/* aggregated badge icon on map */
.agg-icon{background:transparent;border:none}
.agg-icon .agg-badge{font-family:system-ui, -apple-system, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif}
.agg-icon img{max-width:100%}

/* combined half-and-half badge style (if extra refinement needed) */
.agg-badge.agg-combined{color:#111}

/* small colored dots used inline in popups */
.dot-stamp, .dot-coupon{display:inline-block;width:10px;height:10px;border-radius:50%;margin-left:0px;vertical-align:middle;box-shadow:0 1px 2px rgba(0,0,0,0.18)}
.dot-stamp{background:#d9534f}
.dot-coupon{background:#ffd166}

/* remove default list marker for aggregate popup lists and tidy spacing */
.agg-list{list-style:none;padding-left:0;margin-left:0}
.agg-list li{margin:.20rem 0;display:flex;align-items:center;gap:.0rem}

/* small utility */
.note{color:var(--muted);font-size:.90rem}
