@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../fonts/archivo-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../fonts/archivo-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../fonts/archivo-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../fonts/archivo-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../fonts/archivo-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../fonts/archivo-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/inter-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../fonts/inter-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../fonts/inter-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(../fonts/inter-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../fonts/inter-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../fonts/inter-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
  --v3-acc: #3a6ea5;
  --v3-acc-deep: #2a527d;
  --v3-night: #11161c;
  --v3-surface: #ffffff;
  --v3-surface-2: #f3f6f9;
  --v3-line: #dfe5ec;
  --v3-fg: #0b0f14;
  --v3-fg-dim: rgba(0,0,0,.56);
  --v3-rhythm: 76px;
  --v3-edge: 6px;
  --ff-h: 'Archivo', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --ff-b: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--ff-b);
  background: var(--v3-surface-2);
  color: var(--v3-fg);
  line-height: 1.63;
  font-size: 17px;
}
img { max-width: 100%; height: auto; }
a { color: var(--v3-acc-deep); }
.ns2-ico { display: inline-flex; vertical-align: middle; line-height: 0; }
.ns2-ico svg { width: 1em; height: 1em; }

h1, h2, h3, h4 {
  font-family: var(--ff-h);
  line-height: 1.16;
  color: var(--v3-fg);
  font-weight: 700;
  letter-spacing: -.018em;
}
h1 { font-size: 2.5rem; margin: 0 0 .5em; font-weight: 800; }
h2 { font-size: 1.72rem; margin: 1.7em 0 .55em; }
h3 { font-size: 1.21rem; margin: 1.1em 0 .4em; }
p { margin: 0 0 1em; }

.ns2-btn {
  display: inline-flex;
  align-items: center;
  gap: .42em;
  padding: 12px 22px;
  border-radius: var(--v3-edge);
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  font-family: var(--ff-h);
  font-size: 1rem;
  transition: background .15s ease, color .15s ease;
}
.ns2-btn-fill { background: var(--v3-acc); color: #fff; }
.ns2-btn-fill:hover { background: var(--v3-acc-deep); }
.ns2-btn-line { border: 1px solid var(--v3-acc); color: var(--v3-acc-deep); background: transparent; }
.ns2-btn-line:hover { background: var(--v3-surface-2); }
.ns2-btn .ns2-ico { font-size: 1.05em; }

.ns2-wrap { max-width: 1280px; margin: 0 auto; padding: 0 22px; }
.ns2-band { padding: var(--v3-rhythm) 0; background: var(--v3-surface-2); }
.ns2-band-soft { background: var(--v3-surface-2); }
.ns2-band-plain { background: var(--v3-surface); }
.ns2-lead { color: var(--v3-fg-dim); max-width: 760px; margin-bottom: 1.8em; }
.ns2-body { max-width: 760px; }

.ns2-crumb { background: var(--v3-surface); padding: 14px 0; font-size: .92rem; color: var(--v3-fg-dim); border-bottom: 1px solid var(--v3-line); }
.ns2-crumb a { color: var(--v3-acc-deep); text-decoration: none; }

.ns2-hero { background: var(--v3-surface); padding-top: 66px; border-bottom: 1px solid var(--v3-line); }
.ns2-hero h1 { max-width: 880px; }
.ns2-hero-sub { font-size: 1.2rem; color: var(--v3-fg-dim); max-width: 720px; }
.ns2-vlist { list-style: none; padding: 0; margin: 28px 0 26px; max-width: 640px; }
.ns2-vlist li { display: flex; align-items: flex-start; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--v3-line); }
.ns2-vlist li:last-child { border-bottom: none; }
.ns2-vlist .ns2-ico { color: var(--v3-acc); flex: 0 0 auto; font-size: 1.3rem; margin-top: 2px; }
.ns2-vlist b { font-weight: 600; }
.ns2-vlist span.ns2-vtxt { color: var(--v3-fg-dim); }
.ns2-hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }

.ns2-head { background: var(--v3-surface); border-bottom: 1px solid var(--v3-line); position: sticky; top: 0; z-index: 50; }
.ns2-head-row { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding-top: 16px; padding-bottom: 16px; }
.ns2-brandmark { font-family: var(--ff-h); font-size: 1.4rem; font-weight: 800; text-decoration: none; color: var(--v3-fg); letter-spacing: -.02em; }
.ns2-brandmark span { color: var(--v3-acc-deep); }
.ns2-menu { display: flex; gap: 24px; }
.ns2-menu a { text-decoration: none; color: var(--v3-fg); font-weight: 500; }
.ns2-menu a:hover { color: var(--v3-acc-deep); }
.ns2-burger { display: none; background: none; border: none; color: var(--v3-fg); cursor: pointer; }

.ns2-stars { display: inline-flex; align-items: baseline; gap: 7px; white-space: nowrap; }
.ns2-stars-g { color: var(--v3-acc); font-size: 1rem; letter-spacing: 1px; }
.ns2-stars-n { font-family: var(--ff-h); font-weight: 700; font-size: .92rem; color: var(--v3-acc-deep); }
.ns2-top { display: inline-block; background: var(--v3-acc); color: #fff; font-size: .76rem; font-weight: 600; padding: 3px 11px; border-radius: 999px; letter-spacing: .01em; }

.ns2-cards { display: grid; gap: 18px; grid-template-columns: 1fr; margin: 26px 0 0; }
.ns2-row { display: grid; grid-template-columns: 50px 1fr auto; gap: 18px; align-items: start; background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 22px 24px; }
.ns2-row.is-top { border-color: var(--v3-acc); box-shadow: inset 3px 0 0 var(--v3-acc); }
.ns2-rank { font-family: var(--ff-h); font-size: 1.6rem; font-weight: 800; color: var(--v3-acc); text-align: center; }
.ns2-row-main { min-width: 0; }
.ns2-row-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ns2-logo { width: 28px; height: 28px; border-radius: 7px; }
.ns2-name { font-size: 1.22rem; font-weight: 600; text-decoration: none; color: var(--v3-fg); }
.ns2-name:hover { color: var(--v3-acc-deep); }
.ns2-row-meta { display: flex; align-items: center; gap: 14px; margin: 9px 0; flex-wrap: wrap; }
.ns2-facts { color: var(--v3-fg-dim); font-size: .92rem; }
.ns2-blurb { color: var(--v3-fg-dim); margin: 4px 0 0; }
.ns2-row-act { display: flex; flex-direction: column; gap: 8px; align-items: flex-end; }
.ns2-mini { font-size: .9rem; color: var(--v3-acc-deep); text-decoration: none; white-space: nowrap; }
.ns2-spec { display: flex; flex-wrap: wrap; gap: 16px 22px; margin: 13px 0 2px; padding: 0; }
.ns2-spec div { margin: 0; }
.ns2-spec dt { font-size: .76rem; text-transform: uppercase; letter-spacing: .05em; color: var(--v3-fg-dim); margin: 0; }
.ns2-spec dd { margin: 0; font-weight: 600; }

.ns2-stats { display: flex; flex-wrap: wrap; gap: 30px 44px; justify-content: center; text-align: center; }
.ns2-stat { min-width: 150px; }
.ns2-stat-n { display: block; font-family: var(--ff-h); font-size: 2.3rem; font-weight: 800; color: var(--v3-acc-deep); }
.ns2-stat-l { color: var(--v3-fg-dim); }

.ns2-pick { margin-top: 26px; display: grid; grid-template-columns: 1.25fr 1fr; gap: 22px; }
.ns2-pick-card { background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 26px; }
.ns2-pick-card .ns2-top { margin-bottom: 10px; }
.ns2-pick-media { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.ns2-pick-logo { width: 54px; height: 54px; border-radius: 12px; flex: 0 0 auto; }
.ns2-pick-pts { padding-left: 20px; margin: 12px 0 16px; }
.ns2-pick-pts li { margin-bottom: 6px; }
.ns2-pick-side { background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 22px; }
.ns2-pick-side h3 { margin-top: 0; }
.ns2-pick-side p { color: var(--v3-fg-dim); margin-bottom: 1em; }
.ns2-pick-side p:last-child { margin-bottom: 0; }

.ns2-method { display: grid; grid-template-columns: 1.3fr 1fr; gap: 26px; margin-top: 26px; }
.ns2-method-col { background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 24px; }
.ns2-method-col h3 { margin-top: 0; }
.ns2-method-list { list-style: none; padding: 0; margin: 0; }
.ns2-method-list li { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; color: var(--v3-fg-dim); }
.ns2-method-list .ns2-ico { color: var(--v3-acc); flex: 0 0 auto; margin-top: 3px; }
.ns2-method-col.is-skip .ns2-ico { color: var(--v3-fg-dim); }

.ns2-teasers, .ns2-guidegrid, .ns2-nf-cards, .ns2-alts { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); margin: 24px 0; }
.ns2-teaser { display: block; background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 22px; text-decoration: none; color: var(--v3-fg); }
.ns2-teaser:hover { border-color: var(--v3-acc); }
.ns2-teaser h2, .ns2-teaser h3 { margin-top: 0; }
.ns2-teaser p { color: var(--v3-fg-dim); margin-bottom: 0; }

.ns2-faq { max-width: 860px; margin-top: 22px; display: grid; grid-template-columns: 1fr; gap: 12px; }
.ns2-faq-cell { border: 1px solid var(--v3-line); border-radius: var(--v3-edge); background: var(--v3-surface); padding: 20px 22px; }
.ns2-faq-cell h3 { margin: 0 0 .4em; font-size: 1.06rem; }
.ns2-faq-cell p { margin: 0; color: var(--v3-fg-dim); font-size: .96rem; }

.ns2-cta { background: var(--v3-surface); border-top: 1px solid var(--v3-line); border-bottom: 1px solid var(--v3-line); text-align: center; }
.ns2-cta p { color: var(--v3-fg-dim); max-width: 560px; margin: 0 auto 1.4em; }

.ns2-shell { max-width: 820px; }
.ns2-review-top { margin-bottom: 26px; }
.ns2-review-rate { display: flex; align-items: center; gap: 12px; margin: 8px 0 12px; }
.ns2-byline { display: flex; align-items: center; gap: 8px; color: var(--v3-fg-dim); font-size: .92rem; margin-bottom: 18px; }
.ns2-byline .ns2-ico { color: var(--v3-acc); }
.ns2-brand-hero { display: flex; align-items: center; gap: 14px; margin: 18px 0; }
.ns2-brand-hero-logo { width: 56px; height: 56px; border-radius: 13px; flex: 0 0 auto; }
.ns2-brand-hero-cap { font-size: .92rem; color: var(--v3-fg-dim); margin: 0; }
.ns2-brand-hero-cap a { color: var(--v3-acc-deep); }

.ns2-pc { display: grid; gap: 18px; grid-template-columns: 1fr 1fr; margin: 26px 0; }
.ns2-pc-yes, .ns2-pc-no { background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 22px; }
.ns2-pc-yes h3, .ns2-pc-no h3 { margin-top: 0; }
.ns2-pc-yes ul, .ns2-pc-no ul { padding-left: 20px; margin: 0; }
.ns2-pc-yes li, .ns2-pc-no li { margin-bottom: 6px; }

.ns2-score { width: 100%; border-collapse: collapse; margin: 18px 0; }
.ns2-score th, .ns2-score td { text-align: left; padding: 9px 14px; border-bottom: 1px solid var(--v3-line); }
.ns2-score th { background: var(--v3-surface-2); }
.ns2-score td.ns2-bar-cell { width: 46%; }
.ns2-score .ns2-bar { display: block; height: 8px; background: var(--v3-surface-2); border-radius: 999px; overflow: hidden; }
.ns2-score .ns2-bar > span { display: block; height: 100%; background: var(--v3-acc); }
.ns2-score td.ns2-score-n { font-weight: 600; text-align: right; white-space: nowrap; }

.ns2-alt { background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 20px; }
.ns2-alt-top { display: flex; align-items: center; gap: 9px; }
.ns2-alt h3 { margin: 0; font-size: 1.1rem; }
.ns2-alt-logo { width: 24px; height: 24px; border-radius: 6px; }
.ns2-alt p { color: var(--v3-fg-dim); margin: .6em 0 1em; }

.ns2-form { display: flex; flex-direction: column; gap: 14px; max-width: 520px; margin-top: 18px; }
.ns2-form label { display: flex; flex-direction: column; gap: 6px; font-weight: 600; }
.ns2-form input, .ns2-form textarea { padding: 12px 14px; border: 1px solid var(--v3-line); border-radius: var(--v3-edge); font-family: var(--ff-b); font-size: 1rem; }

.ns2-team { display: flex; gap: 18px; align-items: flex-start; background: var(--v3-surface); border: 1px solid var(--v3-line); border-radius: var(--v3-edge); padding: 22px; margin: 18px 0; }
.ns2-team-badge { flex: 0 0 auto; width: 54px; height: 54px; border-radius: 13px; background: var(--v3-acc); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.15rem; font-family: var(--ff-h); }
.ns2-team-role { color: var(--v3-acc-deep); font-weight: 600; margin: 0 0 .4em; }

.ns2-legal h2 { font-size: 1.4rem; }
.ns2-legal ul { padding-left: 20px; }
.ns2-legal li { margin-bottom: 6px; }

.ns2-nf { text-align: center; }

.ns2-risk { background: var(--v3-surface); border-top: 1px solid var(--v3-line); padding: 22px 0; }
.ns2-risk .ns2-wrap { display: flex; align-items: center; gap: 12px; }
.ns2-risk .ns2-ico { flex: 0 0 auto; color: var(--v3-acc-deep); font-size: 1.3rem; }
.ns2-risk p { margin: 0; color: var(--v3-fg-dim); font-size: .92rem; }

.ns2-foot { background: var(--v3-night); color: rgba(255,255,255,.85); padding: 54px 0 24px; }
.ns2-foot a { color: rgba(255,255,255,.85); }
.ns2-foot-grid { display: grid; gap: 36px; grid-template-columns: 1.4fr 1fr; }
.ns2-foot-mark { font-family: var(--ff-h); font-size: 1.35rem; font-weight: 800; color: #fff; text-decoration: none; display: inline-block; margin-bottom: 12px; letter-spacing: -.02em; }
.ns2-foot-mark span { color: var(--v3-acc); }
.ns2-foot-note { color: rgba(255,255,255,.62); font-size: .92rem; max-width: 460px; }
.ns2-foot-cols { display: grid; gap: 28px; grid-template-columns: 1fr 1fr; }
.ns2-foot h4 { color: #fff; font-size: 1rem; margin: 0 0 12px; }
.ns2-foot-nav a, .ns2-foot-legal a { display: block; text-decoration: none; padding: 4px 0; font-size: .94rem; }
.ns2-foot-base { border-top: 1px solid rgba(255,255,255,.12); margin-top: 32px; padding-top: 18px; font-size: .85rem; color: rgba(255,255,255,.55); display: flex; flex-wrap: wrap; gap: 6px 24px; justify-content: space-between; }
.ns2-foot-base p { margin: 0; }
.ns2-foot-base a { color: rgba(255,255,255,.7); }

.ns2-consent { position: fixed; left: 0; right: 0; bottom: 0; background: var(--v3-surface); border-top: 1px solid var(--v3-line); box-shadow: 0 -4px 24px rgba(0,0,0,.1); z-index: 90; }
.ns2-consent-row { display: flex; flex-wrap: wrap; align-items: center; gap: 18px; padding-top: 18px; padding-bottom: 18px; }
.ns2-consent-text { flex: 1 1 320px; }
.ns2-consent-text h4 { margin: 0 0 6px; }
.ns2-consent-text p { margin: 0; font-size: .92rem; color: var(--v3-fg-dim); }
.ns2-consent-prefs { flex: 1 1 100%; display: flex; flex-wrap: wrap; gap: 18px; }
.ns2-consent-line { display: flex; align-items: center; gap: 8px; font-size: .92rem; }
.ns2-consent-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.ns2-consent-reopen { position: fixed; left: 16px; bottom: 16px; width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--v3-line); background: var(--v3-surface); color: var(--v3-fg-dim); cursor: pointer; z-index: 80; display: flex; align-items: center; justify-content: center; }

@media (max-width: 1024px) {
  :root { --v3-rhythm: 60px; }
  .ns2-method { grid-template-columns: 1fr; }
  .ns2-pick { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  h1 { font-size: 2rem; }
  .ns2-burger { display: block; }
  .ns2-menu { display: none; position: absolute; left: 0; right: 0; top: 100%; flex-direction: column; gap: 0; background: var(--v3-surface); border-bottom: 1px solid var(--v3-line); padding: 8px 22px 16px; }
  .ns2-menu.is-open { display: flex; }
  .ns2-menu a { padding: 10px 0; }
  .ns2-head-row { position: relative; }
  .ns2-foot-grid { grid-template-columns: 1fr; }
  .ns2-foot-cols { grid-template-columns: 1fr 1fr; }
  .ns2-pc { grid-template-columns: 1fr; }
  .ns2-row { grid-template-columns: 40px 1fr; }
  .ns2-row-act { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: flex-start; flex-wrap: wrap; }
}
@media (max-width: 480px) {
  body { font-size: 16px; }
  .ns2-form input, .ns2-form textarea { width: 100%; }
}
