*{box-sizing:border-box}
html{scroll-behavior:smooth}

.wrapper{
  width:min(100%,1200px);
  margin:0 auto;
  padding:15px;
}

.card,.result-card{
  background:var(--bg-card);
  border:1px solid var(--primary-border);
  border-radius:18px;
  padding:24px;
}

.app-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  background:var(--primary-soft);
  color:var(--primary);
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  margin-bottom:14px;
}

.intro{
  margin:0 0 18px;
  color:var(--text-secondary);
  line-height:1.6;
  font-size:15px;
}

.notice{
  margin-bottom:22px;
  padding:14px 16px;
  border-radius:14px;
  background:#fff5dd;
  border:1px solid #f0d7a1;
  color:#825a10;
  line-height:1.55;
  font-size:14px;
}

.block{
  margin-top:22px;
}

.block-label{
  font-size:14px;
  font-weight:700;
  margin-bottom:14px;
  color:var(--text-primary);
}

.grid{
  display:grid;
  gap:16px;
}

.grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.field label{
  display:block;
  font-size:14px;
  font-weight:700;
  margin-bottom:8px;
  color:var(--text-primary);
}

.field input,
.field select{
  width:100%;
  height:52px;
  border:1px solid var(--primary-border);
  border-radius:12px;
  padding:0 14px;
  font-size:15px;
  color:var(--text-primary);
  background-color:var(--bg-card);
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%23152033' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:16px;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.field input{
  background-image:none;
}

.field input:focus,
.field select:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 4px var(--primary-soft);
}

.field.has-error input,
.field.has-error select{
  border-color:#c62828;
  background:#fff8f8;
}

.error-text{
  min-height:18px;
  margin-top:7px;
  color:#c62828;
  font-size:13px;
  line-height:1.45;
}

.actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}

.btn{
  appearance:none;
  border:none;
  border-radius:12px;
  padding:14px 18px;
  min-height:52px;
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  transition:transform .15s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-primary{
  background:var(--primary);
  color:#fff;
}

.btn-secondary{
  background:var(--primary-soft);
  color:var(--text-primary);
}

.result-card{
  margin-top:22px;
  display:none;
  scroll-margin-top:18px;
}

.result-card.is-visible{
  display:block;
}

.result-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:20px;
}

.result-title{
  font-size:20px;
  font-weight:700;
  color:var(--text-primary);
}

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:9px 12px;
  font-size:13px;
  font-weight:700;
  background:var(--primary-soft);
  color:var(--primary);
}

.result-summary{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}

.summary-card{
  background:var(--bg-page);
  border:1px solid var(--primary-border);
  border-radius:16px;
  padding:18px;
}

.summary-label{
  font-size:13px;
  color:var(--text-muted);
  margin-bottom:10px;
  line-height:1.4;
}

.summary-value{
  font-size:28px;
  font-weight:700;
  line-height:1.1;
  margin-bottom:10px;
  color:var(--text-primary);
}

.summary-note{
  color:var(--text-muted);
  font-size:14px;
  line-height:1.45;
}

.metric-list{
  display:grid;
  gap:10px;
}

.metric-item{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:center;
  padding:10px 12px;
  background:var(--bg-card);
  border:1px solid var(--primary-border);
  border-radius:12px;
}

.metric-name{
  font-size:14px;
  color:var(--text-muted);
  line-height:1.3;
}

.metric-value{
  font-size:18px;
  font-weight:700;
  text-align:right;
  white-space:nowrap;
  color:var(--text-primary);
}

.section-box{
  border:1px solid var(--primary-border);
  border-radius:16px;
  background:var(--bg-card);
  padding:18px;
  margin-top:16px;
}

.box-title{
  font-size:16px;
  font-weight:700;
  margin-bottom:12px;
  color:var(--text-primary);
}

.rows{
  display:grid;
  gap:10px;
}

.row{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  padding:10px 0;
  border-bottom:1px solid var(--primary-border);
}

.row:last-child{
  border-bottom:none;
}

.row-label{
  color:var(--text-muted);
  font-size:14px;
}

.row-value{
  font-weight:700;
  font-size:14px;
  text-align:right;
  color:var(--text-primary);
}

.info-box{
  margin-top:16px;
  padding:14px 16px;
  border-radius:14px;
  background:var(--bg-page);
  border:1px solid var(--primary-border);
  color:var(--text-muted);
  font-size:14px;
  line-height:1.6;
}

@media (max-width:720px){
  .card,.result-card{padding:18px}
  .grid-2,.grid-3,.result-summary{grid-template-columns:1fr}
  .result-top,.row,.metric-item{flex-direction:column;align-items:stretch}
  .row-value,.metric-value{text-align:left}
}
