.wrap{ max-width:1100px; margin:28px auto; padding:0 14px; }
.topbar{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px; }
.title{ font-size:22px; font-weight:900; }
.btn{ border:1px solid var(--line); background:#fff; padding:10px 14px; border-radius:10px; cursor:pointer; font-weight:700; }
.btn.primary{ background:var(--accent); border-color:var(--accent); color:#fff; }
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:16px; }
.grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.grid3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
label{ display:block; font-size:16px; color:var(--black); margin:10px 0 6px; }
input, select, textarea{
    width:100%; box-sizing:border-box;
    border:1px solid var(--line); border-radius:10px;
    padding:10px 12px; font-size:14px; background:#fff;
}
textarea{ min-height:78px; resize:vertical; }
.sectionTitle{ font-size:14px; font-weight:900; margin:6px 0 10px; }
.hr{ height:1px; background:var(--line); margin:14px 0; }
.row{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.hint{ color:var(--muted); font-size:12px; }
.msg{ margin-top:10px; font-size:12px; white-space:pre-wrap; }
.msg.ok{ color:var(--ok); }
.msg.err{ color:var(--danger); }
.hidden{ display:none; }