/* app.css — Permittory UI on top of tokens.css. Dark regal canvas, gold accent. */

/* nav */
.nav { position: sticky; top: 0; z-index: 40; background: rgba(10,10,18,.82); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.nav__row { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font: 700 1.25rem var(--serif); }
.brand__mark { width: 26px; height: 31px; color: var(--gold-2); }
.brand__gold { color: var(--gold-2); }
.nav__links { display: flex; align-items: center; gap: var(--s-5); }
.nav__links a { color: var(--muted); font-size: .92rem; }
.nav__links a:hover { color: var(--text); }
.nav__county { font: 600 .72rem var(--sans); letter-spacing: .1em; text-transform: uppercase; color: var(--gold); border: 1px solid var(--line-gold); padding: 4px 10px; border-radius: var(--r-pill); }
@media (max-width: 720px){ .nav__links a, .nav__county { display: none; } }

/* hero */
.hero { padding: var(--s-8) 0 var(--s-6); background:
  radial-gradient(1200px 480px at 50% -120px, rgba(110,92,230,.16), transparent 60%),
  radial-gradient(800px 400px at 85% 0, rgba(212,175,55,.10), transparent 55%); }
.hero__tag { display: inline-block; font: 600 .72rem var(--sans); letter-spacing: .14em; text-transform: uppercase; color: var(--gold); border: 1px solid var(--line-gold); padding: 6px 14px; border-radius: var(--r-pill); margin-bottom: var(--s-4); }
.hero__h1 { font-size: clamp(2.3rem, 6vw, 3.9rem); letter-spacing: -.01em; margin-bottom: var(--s-3); }
.grad { background: linear-gradient(110deg, var(--gold-2), var(--gold), var(--indigo-bright)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__sub { color: var(--muted); max-width: 720px; font-size: 1.08rem; margin-bottom: var(--s-6); }

/* form */
.card { background: linear-gradient(180deg, var(--surface), rgba(10,10,18,.45)); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--s-5); box-shadow: var(--shadow); }
.form__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--s-3); }
.form__overlays { margin-top: var(--s-3); }
.f { display: flex; flex-direction: column; gap: 6px; font: 600 .72rem var(--sans); letter-spacing: .04em; text-transform: uppercase; color: var(--muted); grid-column: span 2; }
.f--wide { grid-column: span 6; }
.f .sk-input, .f select { text-transform: none; font-weight: 500; letter-spacing: 0; color: var(--text); }
@media (max-width: 860px){ .form__grid { grid-template-columns: repeat(2, 1fr); } .f, .f--wide { grid-column: span 2; } }
.adv { margin-top: var(--s-4); border-top: 1px solid var(--line); padding-top: var(--s-3); }
.adv summary { cursor: pointer; color: var(--gold); font-size: .85rem; font-weight: 600; }
.adv .form__grid { margin-top: var(--s-3); }
.form__cta { display: flex; align-items: center; gap: var(--s-4); margin-top: var(--s-5); flex-wrap: wrap; }
.form__note { color: var(--muted-2); font-size: .82rem; }
.advisory { color: var(--muted-2); font-size: .8rem; margin-top: var(--s-3); }
.formerr { margin-top: var(--s-3); color: var(--err); background: rgba(224,87,91,.08); border: 1px solid rgba(224,87,91,.3); border-radius: var(--r-sm); padding: 10px 14px; font-size: .9rem; }

/* results */
.results { padding: var(--s-6) 0; }
.verdict { display: flex; align-items: flex-start; gap: var(--s-4); padding: var(--s-5); border-radius: var(--r-lg); margin-bottom: var(--s-4); border: 1px solid var(--line); }
.verdict--ok { background: linear-gradient(180deg, rgba(67,197,158,.12), transparent); border-color: rgba(67,197,158,.35); }
.verdict--abstain { background: linear-gradient(180deg, rgba(224,169,59,.12), transparent); border-color: rgba(224,169,59,.4); }
.verdict__icon { font-size: 1.7rem; line-height: 1; }
.verdict__t { font: 700 1.35rem var(--serif); }
.verdict__sub { color: var(--muted); font-size: .95rem; margin-top: 4px; }
.banner { padding: 12px 16px; border-radius: var(--r-sm); margin-bottom: var(--s-4); font-size: .9rem; border: 1px solid var(--line); }
.banner--warn { background: rgba(224,169,59,.1); border-color: rgba(224,169,59,.35); color: var(--warn); }

.rgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-3); margin-bottom: var(--s-5); }
@media (max-width: 760px){ .rgrid { grid-template-columns: repeat(2,1fr); } }
.rcell { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r); padding: var(--s-4); }
.rcell__k { font: 600 .68rem var(--sans); letter-spacing: .1em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 6px; }
.rcell__v { font: 700 1.05rem var(--sans); color: var(--text); }
.rcell__v.tier-exemption { color: var(--ok); }
.rcell__v.tier-general_permit { color: var(--gold-2); }
.rcell__v.tier-individual_erp { color: var(--warn); }
.rcell__v.tier-human_review { color: var(--warn); }

.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: var(--s-5); }
.chip { font: 600 .78rem var(--sans); padding: 6px 12px; border-radius: var(--r-pill); border: 1px solid var(--line); color: var(--muted); }
.chip b { color: var(--text); font-weight: 700; }
.chip--yes { border-color: rgba(224,87,91,.35); color: var(--err); }
.chip--unknown { border-color: rgba(224,169,59,.35); color: var(--warn); }

.sec__h { font: 700 1.15rem var(--serif); margin: var(--s-5) 0 var(--s-3); }
.gap { display: flex; gap: var(--s-3); padding: var(--s-4); border-radius: var(--r); margin-bottom: var(--s-2); border: 1px solid var(--line); background: var(--surface); }
.gap--blocker { border-color: rgba(224,87,91,.4); background: rgba(224,87,91,.06); }
.gap--warning { border-color: rgba(224,169,59,.35); background: rgba(224,169,59,.05); }
.gap__sev { font: 700 .64rem var(--sans); letter-spacing: .1em; text-transform: uppercase; padding: 4px 8px; border-radius: var(--r-sm); height: fit-content; white-space: nowrap; }
.gap--blocker .gap__sev { background: var(--err); color: #fff; }
.gap--warning .gap__sev { background: var(--warn); color: #1a1407; }
.gap__body { font-size: .93rem; }
.gap__fix { color: var(--muted); font-size: .86rem; margin-top: 4px; }
.gap__ref { color: var(--muted-2); font-size: .76rem; margin-top: 3px; font-family: var(--mono); }

.cl { border: 1px solid var(--line); border-radius: var(--r); margin-bottom: var(--s-2); overflow: hidden; }
.cl summary { cursor: pointer; padding: var(--s-4); font-weight: 700; background: var(--surface-2); list-style: none; display: flex; justify-content: space-between; }
.cl summary::-webkit-details-marker { display: none; }
.cl__items { padding: var(--s-3) var(--s-4); }
.cl__item { display: flex; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: .9rem; }
.cl__item:last-child { border-bottom: 0; }
.cl__box { color: var(--gold); font-weight: 700; }
.cl__note { color: var(--muted-2); font-size: .8rem; margin-top: 2px; }
.cl__opt { color: var(--muted-2); }

.actbar { display: flex; gap: var(--s-3); flex-wrap: wrap; margin: var(--s-5) 0; padding: var(--s-5); border-radius: var(--r-lg); background: linear-gradient(120deg, rgba(110,92,230,.12), rgba(212,175,55,.08)); border: 1px solid var(--line-gold); align-items: center; }
.actbar p { margin-right: auto; font-size: .95rem; }

/* bands */
.band { padding: var(--s-8) 0; border-top: 1px solid var(--line); }
.band--alt { background: var(--bg-2); }
.band__h { font-size: clamp(1.7rem, 4vw, 2.4rem); text-align: center; margin-bottom: var(--s-6); }
.steps, .prices { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); }
.prices { grid-template-columns: repeat(2, 1fr); max-width: 760px; margin: 0 auto; }
@media (max-width: 820px){ .steps, .prices { grid-template-columns: 1fr; } }
.step__n { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; background: var(--gold); color: #1a1407; font-weight: 800; margin-bottom: var(--s-3); }
.step h3 { font-family: var(--serif); margin-bottom: 8px; }
.step p { color: var(--muted); font-size: .92rem; }
.price { text-align: center; }
.price--feature { border-color: var(--line-gold); box-shadow: 0 0 0 1px var(--line-gold), var(--shadow); }
.price__tag { font: 600 .72rem var(--sans); letter-spacing: .12em; text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-2); }
.price__amt { font: 800 2.4rem var(--sans); }
.price__amt span { font-size: 1rem; color: var(--muted); font-weight: 500; }
.price p { color: var(--muted); font-size: .92rem; margin: var(--s-3) 0 var(--s-4); }
.price__foot { text-align: center; color: var(--muted-2); margin-top: var(--s-5); font-size: .88rem; }

/* footer */
.foot { border-top: 1px solid var(--line); padding: var(--s-6) 0; }
.foot__row { display: flex; justify-content: space-between; gap: var(--s-4); flex-wrap: wrap; color: var(--muted-2); font-size: .82rem; }
.foot__disc { max-width: 520px; }

/* modal */
.modal { position: fixed; inset: 0; background: rgba(5,5,10,.7); display: grid; place-items: center; z-index: 60; padding: var(--s-4); }
.modal__box { width: 100%; max-width: 400px; position: relative; }
.modal__box h3 { font-family: var(--serif); margin-bottom: 6px; }
.modal__box .sk-input { margin: var(--s-4) 0 var(--s-3); }
.modal__box .sk-btn { width: 100%; justify-content: center; }
.modal__x { position: absolute; top: 12px; right: 14px; background: none; border: 0; color: var(--muted); font-size: 1.4rem; cursor: pointer; }
.authmsg { margin-top: var(--s-3); font-size: .85rem; color: var(--gold-2); min-height: 1.2em; }

.hide { display: none !important; }
.spin { display: inline-block; width: 14px; height: 14px; border: 2px solid rgba(255,255,255,.3); border-top-color: #1a1407; border-radius: 50%; animation: sp .7s linear infinite; }
@keyframes sp { to { transform: rotate(360deg); } }
