*{box-sizing:border-box}
body{margin:0;font-family:Arial,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}

.page-wrap{max-width:760px;margin:0 auto;padding:16px}

.app-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);z-index:20}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:760px;margin:0 auto;padding:14px 16px}
.home-icon,.menu-btn{width:36px;height:36px;border:1px solid var(--line);display:grid;place-items:center;border-radius:12px;background:#fff}
.menu-btn{cursor:pointer}
.app-title{font-weight:800}

.menu-panel{max-width:760px;margin:0 auto;padding:0 16px 12px;display:flex;gap:8px;flex-wrap:wrap}
.menu-panel[hidden]{display:none !important}
.menu-panel a{padding:10px 12px;background:var(--primary-soft);border-radius:999px;font-size:14px}

.search-row{display:flex;gap:10px;margin-bottom:14px}
.search-row input{flex:1;padding:14px;border:1px solid var(--line);border-radius:14px}

.place-card{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-bottom:14px}
.card-link{display:block}

.hero-cover{
  min-height:180px;
  padding:14px 16px 12px;
  display:flex;
  align-items:flex-end;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
}

.hero-cover__content{
  width:100%;
}

.hero-cover .cat{
  display:inline-block;
  font-size:13px;
  font-weight:700;
  opacity:.96;
  margin-bottom:6px;
  line-height:1.2;
}

.hero-cover strong{
  display:block;
  font-size:22px;
  line-height:1.28;
  letter-spacing:-0.02em;
  word-break:keep-all;
}

.hero-cover em{
  display:block;
  font-size:14px;
  font-style:normal;
  margin-top:6px;
  line-height:1.3;
  opacity:.96;
}

.card-body{padding:14px 14px 6px}
.card-body h3{margin:0 0 8px;font-size:20px}
.card-body p{margin:0 0 10px;color:var(--muted);line-height:1.55}

.badges{display:flex;gap:8px;flex-wrap:wrap}
.badges span,.pill{display:inline-block;padding:8px 10px;background:#f6f7f9;border:1px solid var(--line);border-radius:999px;font-size:12px}

.card-actions,
.cta-row{
  display:flex;
  gap:10px;
  padding:0 14px 14px;
  align-items:center;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 16px;
  border-radius:14px;
  background:var(--primary);
  color:#fff;
  border:none;
  font-weight:800;
  text-align:center;
  cursor:pointer;
  white-space:nowrap;
}
.btn.secondary{
  background:#fff;
  color:var(--text);
  border:1px solid var(--line);
}

.card-primary-btn{
  flex:0 0 auto;
}

.icon-btn{
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:18px;
  font-weight:800;
  flex:0 0 auto;
}

.share-icon-btn{
  margin-left:auto;
}

.hero{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  margin-bottom:14px;
}
.hero h1{
  margin:0 0 10px;
  font-size:clamp(18px, 5.8vw, 28px);
  line-height:1.35;
  letter-spacing:-0.02em;
  word-break:keep-all;
}
.hero p{margin:0;color:var(--muted);line-height:1.7}

.hero-actions{
  display:flex;
  align-items:center;
  gap:10px;
  padding-top:16px;
}

.hero-primary-btn{
  flex:0 0 auto;
}

.hero-sub-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}

.hero-sub-actions .btn{
  flex:0 0 auto;
}

.section{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;margin-bottom:14px}
.section h2{margin:0 0 12px;font-size:22px}

.list{display:flex;flex-direction:column;gap:10px}
.list .item,.reason-item{padding:14px;border:1px solid var(--line);border-radius:16px;background:#fafafb;line-height:1.6}

.meta-grid{display:grid;grid-template-columns:1fr;gap:10px}
.score{font-size:38px;font-weight:900}
.result-badge{display:inline-block;padding:10px 12px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:800;margin-bottom:10px}

.question-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px}
.question-title{font-size:24px;font-weight:800;line-height:1.4;margin:0 0 16px}
.option-list{display:flex;flex-direction:column;gap:10px}
.option-btn{display:block;width:100%;padding:16px;border:1px solid var(--line);border-radius:16px;background:#fff;text-align:left;font-size:17px;font-weight:700;color:var(--text)}

.progress{font-size:14px;color:var(--muted);margin-bottom:10px}
.progress-bar{height:8px;background:#eceef2;border-radius:999px;overflow:hidden;margin-bottom:14px}
.progress-bar span{display:block;height:100%;background:var(--primary)}

.hidden{display:none}

.share-row{display:flex;justify-content:flex-end;margin-top:10px}

@media (max-width:480px){
  .page-wrap{padding:14px}

  .header-inner{padding:12px 14px}
  .app-title{font-size:16px}

  .hero{padding:16px}
  .section{padding:16px}
  .section h2{font-size:18px}

  .hero-actions{
    display:block;
  }

  .hero-primary-btn{
    display:flex;
    width:100%;
    justify-content:center;
    margin-bottom:10px;
  }

  .hero-sub-actions{
    display:flex;
    gap:8px;
  }

  .hero-sub-actions .btn{
    flex:1 1 calc(50% - 4px);
    min-width:0;
    padding:14px 12px;
    white-space:nowrap;
  }

  .card-actions{
    justify-content:space-between;
  }

  .card-primary-btn{
    min-width:110px;
  }

  .icon-btn{
    width:44px;
    height:44px;
  }

  .hero-cover{
    min-height:160px;
  }

  .hero-cover strong{
    font-size:19px;
  }
}

.detail-hero{
  padding:0;
  overflow:hidden;
}

.detail-hero-cover{
  min-height:180px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.detail-hero-cover--title{
  display:flex;
  align-items:flex-end;
  padding:14px 16px 14px;
  color:#fff;
}

.detail-hero-cover__content{
  width:100%;
}

.detail-hero-cover__meta{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.detail-pill{
  background:rgba(255,255,255,.88);
  border:none;
  color:#121316;
  font-weight:800;
}

.detail-region{
  color:#fff;
  font-size:13px;
  font-weight:700;
  text-shadow:0 1px 2px rgba(0,0,0,.28);
}

.detail-cover-title{
  margin:0;
  color:#fff;
  font-size:clamp(22px, 6vw, 34px);
  line-height:1.28;
  letter-spacing:-0.02em;
  word-break:keep-all;
  text-shadow:0 1px 3px rgba(0,0,0,.25);
}

.detail-hero-body{
  padding:18px;
}

.detail-hero-body p{
  margin:0 0 12px;
  color:var(--muted);
  line-height:1.65;
}

.detail-cta-row{
  display:flex;
  gap:10px;
  padding-top:14px;
}

.detail-main-btn,
.detail-sub-btn{
  flex:1 1 0;
}

@media (max-width:480px){
  .detail-hero-cover{
    min-height:160px;
  }

  .detail-hero-cover--title{
    padding:12px 14px 12px;
  }

  .detail-hero-body{
    padding:16px;
  }

  .detail-cover-title{
    font-size:clamp(20px, 7vw, 28px);
  }

  .detail-main-btn,
  .detail-sub-btn{
    min-width:0;
    padding:14px 12px;
  }
}

.place-context{
  padding:16px 18px;
}

.place-context__eyebrow{
  display:inline-block;
  margin-bottom:8px;
  padding:8px 12px;
  border-radius:999px;
  background:var(--primary-soft);
  color:var(--primary);
  font-size:13px;
  font-weight:800;
}

.place-context__title{
  margin:0;
  font-size:clamp(20px, 6vw, 30px);
  line-height:1.3;
  letter-spacing:-0.02em;
  word-break:keep-all;
}

.place-context__meta{
  margin:8px 0 0;
  color:var(--muted);
  line-height:1.55;
}

@media (max-width:480px){
  .place-context{
    padding:14px 16px;
  }
}