/* ═══════════════════════════════════════
   PactApp — styles.css
   ═══════════════════════════════════════ */

/* ── RESET & VARS ── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#0B6E4F;--gl:#E3F5EE;--gd:#064D37;--gm:#5DCAA5;
  --blue:#1a6bb5;
  --amber:#FEF3C7;--ad:#92400E;
  --rl:#FEF2F2;--rd:#B91C1C;
  --g0:#FFFFFF;--g1:#F8F8F6;--g2:#F0F0EC;--g3:#E2E2DB;--g4:#C8C8C0;
  --t1:#111110;--t2:#3D3D3A;--t3:#737370;--t4:#ADADAA;
  --tech:#1B2624;--steel:#5B6663;--warm:#FCFBF8;--mint-line:#CDEBDD;
  --r:10px;--rl2:14px;--rl3:20px;
  --nav-h:68px;
  --sh-sm:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --sh-md:0 4px 12px rgba(0,0,0,.09),0 2px 4px rgba(0,0,0,.05);
  --sh-lg:0 10px 30px rgba(0,0,0,.10),0 4px 8px rgba(0,0,0,.05);
}

/* ── BASE ── */
html{height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  background:#E5E5E0;min-height:100%;
  display:flex;justify-content:center;
  -webkit-tap-highlight-color:transparent;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.app{
  max-width:430px;width:100%;background:var(--g0);
  min-height:100vh;display:flex;flex-direction:column;
  position:relative;box-shadow:var(--sh-lg);
}
.app-shell{
  width:100%;
  max-width:430px;
  display:none;
}

.gate-screen{
  position:fixed;
  inset:0;
  z-index:3000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.gate-screen{
  background:linear-gradient(145deg,#F8F8F6 0%,#E7F4EE 100%);
}

.gate-card{
  width:min(390px,100%);
  background:#fff;
  border:1px solid rgba(255,255,255,.65);
  border-radius:24px;
  box-shadow:0 24px 70px rgba(20,36,30,.18);
  padding:24px;
}

.brand-lockup{
  font-size:26px;
  font-weight:900;
  letter-spacing:-.9px;
  line-height:1;
}
.brand-lockup span{font-weight:650}
.brand-dark{color:var(--gd);text-align:center}
.brand-dark span{color:var(--green)}

.gate-subtitle{
  text-align:center;
  font-size:13px;
  color:var(--t3);
  line-height:1.55;
  margin:9px 0 18px;
}

.soft-note{
  background:var(--gl);
  border:1px solid #B7E6D2;
  border-radius:16px;
  padding:13px 14px;
  margin-bottom:16px;
}
.soft-note-title{font-size:12px;font-weight:850;color:var(--gd);margin-bottom:4px}
.soft-note-body{font-size:12px;line-height:1.6;color:var(--t2)}
.form-group-left{text-align:left}
.form-error-slot{
  min-height:18px;
  font-size:12px;
  color:var(--rd);
  font-weight:700;
  margin:-4px 0 8px;
}
.nota-spaced{margin-top:14px}

button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.tcard:focus-visible,
.copt:focus-visible,
.nav-btn:focus-visible{
  outline:3px solid rgba(11,110,79,.22);
  outline-offset:2px;
}

/* ── SCREENS ── */
.screen{
  display:none;flex:1;flex-direction:column;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 4px);
  background:var(--g0);
}
.screen.active{display:flex}
.sc{padding:1rem}
.sc-tight{padding-top:.8rem}
.sc-form{padding-top:.9rem}
.sc-link{padding-top:.85rem}
.sc-compact-top{padding-top:.5rem}

/* ── TOPBAR ── */
.topbar{
  position:sticky;top:0;z-index:90;background:var(--g0);
  border-bottom:1px solid var(--g2);
  padding:.75rem 1rem .6rem;
  display:flex;align-items:center;gap:.5rem;flex-shrink:0;
}
.topbar-title{font-size:15px;font-weight:700;color:var(--t1);flex:1;letter-spacing:-.1px}
.topbar-flat{box-shadow:none}
.back-btn{
  background:none;border:none;color:var(--t3);font-size:13px;font-weight:600;
  cursor:pointer;padding:5px 0;
  display:flex;align-items:center;gap:4px;flex-shrink:0;
  transition:color .15s;
}
.back-btn:active{color:var(--green)}

/* ── HERO ── */
.hero{
  background:linear-gradient(145deg,#152120 0%,#0B6E4F 58%,#139067 100%);
  padding:2rem 1.25rem 1.75rem;position:relative;overflow:hidden;flex-shrink:0;
}
.hero::before{
  content:'';position:absolute;top:-50px;right:-50px;
  width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,.05);pointer-events:none;
}
.hero::after{
  content:'';position:absolute;bottom:-35px;left:-25px;
  width:150px;height:150px;border-radius:50%;
  background:rgba(255,255,255,.04);pointer-events:none;
}
.hero-brand-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  position:relative;
  z-index:1;
  margin-bottom:1.15rem;
}
.hero-brand{
  color:#fff;
  font-size:24px;
  font-weight:950;
  letter-spacing:-.9px;
  cursor:pointer;
}
.hero-brand span{
  color:rgba(255,255,255,.68);
  font-weight:650;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  border-radius:20px;padding:4px 12px;
  font-size:11px;font-weight:700;color:rgba(255,255,255,.85);
  margin-bottom:1rem;letter-spacing:.2px;
}
.hero-tag-tight{margin-bottom:0}
.hero > h1,
.hero-sub,
.hero-flow,
.trust-row,
.hero-inline-note,
.hero-actions{
  position:relative;
  z-index:1;
}
.hero h1{
  font-size:28px;font-weight:900;color:#fff;
  line-height:1.13;margin-bottom:.75rem;letter-spacing:-.7px;
}
.hero-sub{font-size:18px;color:#fff;line-height:1.42;margin-bottom:.35rem;font-weight:850;max-width:24ch}
.hero-sub-detail{
  font-size:13.5px;
  font-weight:600;
  color:rgba(255,255,255,.78);
  line-height:1.65;
  margin-bottom:.7rem;
  max-width:56ch;
}
.hero-inline-note{
  font-size:11.5px;
  line-height:1.5;
  color:rgba(255,255,255,.70);
  margin-bottom:12px;
}
.hero-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:7px;
}
.hero-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:#FFFFFF;
  color:var(--gd);
  text-decoration:none;
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  box-shadow:0 12px 22px rgba(6,77,55,.18);
}
.hero-cta-note{
  font-size:10.5px;
  line-height:1.45;
  color:rgba(255,255,255,.82);
  font-weight:700;
}
.hero-flow{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:7px;
  margin:0 0 1rem;
}
.hero-flow div{
  background:rgba(255,255,255,.11);
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:8px 7px;
  min-height:54px;
}
.hero-flow strong{
  display:block;
  width:20px;
  height:20px;
  border-radius:999px;
  background:#fff;
  color:var(--gd);
  font-size:11px;
  line-height:20px;
  text-align:center;
  margin-bottom:5px;
}
.hero-flow span{
  display:block;
  color:rgba(255,255,255,.86);
  font-size:10.5px;
  font-weight:850;
  line-height:1.25;
}
.trust-row{display:flex;gap:.7rem;flex-wrap:wrap}
.trust-item{
  display:flex;align-items:center;gap:5px;
  font-size:11px;font-weight:750;color:rgba(255,255,255,.78);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  padding:6px 10px;
}

/* ── SECTION LABELS ── */
.sec-label{
  font-size:10px;font-weight:800;color:var(--t3);
  text-transform:uppercase;letter-spacing:1px;
  margin:1.2rem 0 .6rem;
}
.home-section-head{
  margin:2px 0 12px;
}
.home-section-head .sec-label{
  margin:0 0 6px;
}
.home-section-copy{
  font-size:12px;
  color:var(--t3);
  line-height:1.6;
}

/* ── TEMPLATE GRID ── */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.template-grid{margin-bottom:18px}
.tcard{
  background:var(--g0);border:1.5px solid var(--g2);
  border-radius:var(--rl2);padding:14px 12px;
  cursor:pointer;transition:all .15s;
  box-shadow:var(--sh-sm);position:relative;overflow:hidden;
}
.tcard::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--green),var(--gm));
  transform:scaleX(0);transition:transform .2s;transform-origin:left;
}
.tcard:active{border-color:var(--green);background:#FAFFF9;box-shadow:var(--sh-md)}
.tcard:active::after{transform:scaleX(1)}
.tcard-icon{font-size:26px;margin-bottom:8px;display:block}
.tcard-name{font-size:14px;font-weight:700;color:var(--t1);margin-bottom:2px;line-height:1.2}
.tcard-desc{font-size:11px;color:var(--t3);line-height:1.4}
.price-tag{
  display:inline-block;background:var(--gl);color:var(--gd);
  font-size:11px;font-weight:800;padding:3px 9px;
  border-radius:20px;margin-top:7px;
}

/* ── VALUE PROP ── */
.vp-row{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}
.vp-icon-wrap{
  width:40px;height:40px;border-radius:10px;background:var(--gl);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.vp-title{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:2px}
.vp-desc{font-size:12px;color:var(--t3);line-height:1.5}

/* ── PRICING COMPARISON ── */
.price-compare{
  background:var(--g0);border:1.5px solid var(--g2);
  border-radius:var(--rl2);padding:14px;margin-bottom:10px;
  box-shadow:var(--sh-sm);
}
.price-compare-title{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:10px}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--g2);font-size:13px}
.price-row:last-child{border-bottom:none}
.price-old{color:var(--t3);text-decoration:line-through;font-size:12px}
.price-new{font-weight:800;color:var(--green);font-size:15px}
.price-save{background:var(--gl);color:var(--gd);font-size:10px;font-weight:800;padding:2px 7px;border-radius:20px;margin-left:6px}

/* ── VALUE PANEL ── */
.value-panel{
  background:linear-gradient(145deg,#F4F6F5 0%,#DCE3E0 36%,#B2BBB7 70%,#7E8784 100%);
  color:#F6F6F3;
  border-radius:var(--rl3);
  padding:16px;
  margin:4px 0 18px;
  box-shadow:var(--sh-md);
  position:relative;
  overflow:hidden;
  border:1px solid #B8C1BE;
}
.value-panel::after{
  content:'';
  position:absolute;
  right:-38px;
  top:-42px;
  width:120px;
  height:120px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
}
.value-panel-kicker{
  font-size:12px;
  font-weight:900;
  letter-spacing:.9px;
  text-transform:uppercase;
  color:var(--gd);
  margin-bottom:7px;
}
.value-panel-title{
  font-size:19px;
  font-weight:850;
  line-height:1.28;
  letter-spacing:-.2px;
  margin-bottom:7px;
  max-width:310px;
  color:var(--tech);
}
.value-panel-copy{
  position:relative;
  z-index:1;
  font-size:12px;
  line-height:1.62;
  color:var(--t2);
  margin-bottom:12px;
}
.value-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  position:relative;
  z-index:1;
}
.value-flow{
  position:relative;
  z-index:1;
  margin-top:2px;
}
.value-flow-title{
  font-size:15px;
  font-weight:900;
  color:var(--gd);
  margin-bottom:10px;
}
.value-flow-list{
  display:grid;
  gap:9px;
}
.value-flow-step{
  display:grid;
  grid-template-columns:28px minmax(0,1fr);
  gap:10px;
  align-items:flex-start;
  background:var(--gl);
  border:1px solid #BFE7D5;
  border-radius:14px;
  padding:11px 12px;
}
.value-flow-step-num{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--gd);
  color:#fff;
  font-size:12px;
  font-weight:900;
  line-height:1;
}
.value-flow-step-copy strong{
  display:block;
  font-size:12px;
  color:var(--gd);
  margin-bottom:3px;
}
.value-flow-step-copy span{
  display:block;
  font-size:11px;
  line-height:1.55;
  color:var(--t2);
}
.value-item{
  background:var(--gl);
  border:1px solid #BFE7D5;
  border-radius:12px;
  padding:10px;
}
.value-item strong{
  display:block;
  font-size:11px;
  color:var(--gd);
  margin-bottom:4px;
}
.value-item span{
  display:block;
  font-size:10.5px;
  line-height:1.5;
  color:var(--t2);
}
.comparison-strip{
  position:relative;
  z-index:1;
  margin-top:11px;
  padding-top:11px;
  border-top:1px solid rgba(255,255,255,.10);
  display:grid;
  grid-template-columns:1fr;
  gap:7px;
}
.comparison-strip div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  font-size:11px;
}
.comparison-strip span{
  color:rgba(255,255,255,.64);
  font-weight:800;
}
.comparison-strip strong{
  color:#FFFFFF;
  font-size:11px;
  text-align:right;
}
.value-note{
  position:relative;
  z-index:1;
  font-size:10.5px;
  line-height:1.55;
  color:rgba(255,255,255,.66);
  margin-top:11px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.10);
}

/* ── SERVICE FEATURES ── */
.service-section{
  margin:2px 0 14px;
}
.service-section .sec-label{
  margin:0 0 8px;
}
.service-list{
  display:grid;
  gap:8px;
}
.service-row{
  display:grid;
  grid-template-columns:112px 1fr;
  gap:10px;
  align-items:start;
  background:linear-gradient(180deg,#F7FAF8 0%,#F0F5F2 100%);
  border:1px solid #DDE6E1;
  border-radius:14px;
  padding:11px 12px;
}
.service-row span{
  font-size:11px;
  font-weight:900;
  color:var(--t1);
  line-height:1.25;
}
.service-row small{
  font-size:10.8px;
  color:var(--t3);
  line-height:1.45;
}
.home-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:18px 0 12px;
}
.home-legal-footer{
  border:1px solid #DCE5E0;
  background:linear-gradient(180deg,#FAFBF9 0%,#F4F7F5 100%);
  border-radius:18px;
  margin:8px 0 6px;
  padding:12px 14px;
}
.home-legal-footer summary{
  cursor:pointer;
  color:var(--steel);
  font-size:11px;
  font-weight:800;
  letter-spacing:.4px;
}
.home-legal-footer p{
  color:var(--t3);
  font-size:11px;
  line-height:1.65;
  margin-top:8px;
}
.helper-card{
  background:#F8FFFB;
  border:1px solid #CDEBDD;
  border-radius:14px;
  padding:12px 13px;
  margin-bottom:14px;
}
.helper-card-title{
  font-size:12px;
  font-weight:850;
  color:var(--gd);
  margin-bottom:4px;
}
.helper-card-copy{
  font-size:12px;
  line-height:1.55;
  color:var(--t2);
}
.helper-card-copy + .helper-card-copy{
  margin-top:6px;
}

.helper-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.helper-chip{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:6px 10px;
  border-radius:999px;
  background:#FFFFFF;
  border:1px solid #D4ECDD;
  color:var(--gd);
  font-size:11px;
  font-weight:800;
  line-height:1.3;
}
.support-hero,
.cp-guide-card,
.link-next-steps{
  border-radius:var(--rl2);
  padding:14px;
  box-shadow:var(--sh-sm);
}
.support-hero{
  display:flex;
  align-items:flex-start;
  gap:12px;
  background:linear-gradient(135deg,#F8FFFB,#EEF8F1);
  border:1px solid #CDEBDD;
  margin-bottom:14px;
}
.support-hero-icon{
  width:34px;
  height:34px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--green);
  color:#fff;
  font-size:18px;
  font-weight:900;
  flex-shrink:0;
}
.support-hero-title,
.cp-guide-title,
.link-next-title{
  font-size:15px;
  font-weight:850;
  color:var(--t1);
  margin-bottom:4px;
}
.support-hero-copy{
  font-size:12px;
  line-height:1.65;
  color:var(--t3);
}
.support-faq{
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:var(--rl2);
  padding:13px;
  margin:14px 0 8px;
}
.support-faq-title{
  font-size:12px;
  font-weight:900;
  color:var(--t2);
  margin-bottom:8px;
}
.support-faq details{
  background:#fff;
  border:1px solid var(--g2);
  border-radius:10px;
  padding:10px 11px;
  margin-top:8px;
}
.support-faq summary{
  cursor:pointer;
  font-size:12px;
  font-weight:800;
  color:var(--t1);
}
.support-faq p{
  font-size:11.5px;
  line-height:1.65;
  color:var(--t3);
  margin-top:7px;
}

/* ── BUTTONS ── */
.btn{
  width:100%;padding:13px;border-radius:var(--r);
  font-size:15px;font-weight:700;cursor:pointer;border:none;
  transition:all .15s;letter-spacing:-.1px;
  -webkit-tap-highlight-color:transparent;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 2px 8px rgba(11,110,79,.3)}
.btn-primary:active{background:#064D37;box-shadow:none}
.btn-secondary{background:var(--g1);color:var(--t1);border:1.5px solid var(--g3)}
.btn-secondary:active{background:var(--g2)}
.btn-ghost{background:none;color:var(--green);border:1.5px solid var(--gl);font-size:14px}
.btn-identity{
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 2px 8px rgba(26,107,181,.25);
}
.btn-identity:active{background:#154d87;box-shadow:none}
.btn-stack{display:flex;flex-direction:column;gap:9px}
.btn-stack-spaced{margin-top:14px}
.btn-sm{width:auto;padding:7px 14px;font-size:12px;font-weight:700}
.btn:disabled{opacity:.4;pointer-events:none}
.btn-space-top{margin-top:12px}
.btn-space-top-sm{margin-top:10px}
.btn-subscription-cta{margin-top:18px}
.btn-space-bottom{margin-bottom:10px}
.btn-center-narrow{
  max-width:230px;
  margin:0 auto;
}

/* ── FORMS ── */
.section-copy{
  font-size:13px;
  color:var(--t3);
  line-height:1.65;
  margin-bottom:14px;
}
.section-copy-compact{margin-bottom:12px}
.form-section-label{
  font-size:12px;
  font-weight:850;
  color:var(--t2);
  margin-bottom:8px;
}
.payer-grid{margin-bottom:2px}
.form-group{margin-bottom:14px;position:relative}
.form-label{font-size:12px;font-weight:700;color:var(--t2);margin-bottom:5px;display:block;letter-spacing:.1px}
.field-note{
  display:block;
  margin-top:6px;
  font-size:11px;
  line-height:1.35;
  color:var(--t3);
}
.field-example-note{
  margin-top:3px;
}
input,textarea,select{
  width:100%;padding:11px 13px;border:1.5px solid var(--g3);
  border-radius:var(--r);font-size:15px;color:var(--t1);
  background:var(--g0);font-family:inherit;
  -webkit-appearance:none;appearance:none;
  transition:border-color .15s,box-shadow .15s;
}
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--green);
  box-shadow:0 0 0 3px rgba(11,110,79,.1);
}
input.v-ok{border-color:var(--gm)}
input.v-ko{border-color:#E24B4A}
.field-icon{position:absolute;right:13px;bottom:12px;font-size:14px;pointer-events:none}
textarea{resize:none;height:74px;line-height:1.6}
select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23737370' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:36px;
  background-color:#fff;
  color:var(--t1);
}
select option{
  color:var(--t1);
  background:#fff;
}
.hint-box{
  font-size:11px;font-weight:700;color:var(--gd);background:var(--gl);
  padding:6px 10px;border-radius:7px;margin-top:5px;
  display:flex;align-items:center;gap:5px;
}
.hint-box-spaced{margin-top:6px}
.form-group-dynamic{
  background:linear-gradient(180deg,#F8FFFB,#F1FAF5);
  border:1px solid #CDEBDD;
  border-radius:var(--rl2);
  padding:12px;
  margin-bottom:16px;
}

.consent-card{
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:var(--rl2);
  padding:14px;
  margin-top:12px;
}

.inline-link-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.btn-inline-link{
  appearance:none;
  width:auto;
  border:none;
  background:transparent;
  color:var(--green);
  font-size:11.5px;
  font-weight:800;
  line-height:1.4;
  padding:0;
  cursor:pointer;
  text-decoration:underline;
  text-underline-offset:2px;
}

.btn-inline-link:hover,
.btn-inline-link:focus-visible{
  color:var(--gd);
  outline:none;
}

.payment-consent-card{
  margin:14px 0 8px;
}

.btn-full{
  width:100%;
}

.check-row{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:12px;
  color:var(--t2);
  line-height:1.6;
  margin-bottom:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid transparent;
  transition:background .15s,border-color .15s,box-shadow .15s;
}

.check-row:last-child{margin-bottom:0}
.check-row-compact{
  background:#F8FFFB;
  border-color:#D9ECE2;
  padding:9px 11px;
}
.check-row-compact span{
  font-size:11.6px;
  line-height:1.55;
}
.check-row input{
  width:20px;
  height:20px;
  margin-top:1px;
  flex-shrink:0;
  border:2px solid var(--g4);
  border-radius:6px;
  background:#fff;
  appearance:none;
  -webkit-appearance:none;
  display:grid;
  place-content:center;
  transition:background .15s,border-color .15s,box-shadow .15s;
}

.check-row input::before{
  content:'';
  width:11px;
  height:8px;
  transform:scale(0) rotate(-45deg);
  border-left:2px solid #fff;
  border-bottom:2px solid #fff;
  margin-top:-2px;
  transition:transform .12s ease;
}

.check-row input:checked{
  background:var(--green);
  border-color:var(--green);
  box-shadow:0 0 0 4px rgba(11,110,79,.12);
}

.check-row input:checked::before{
  transform:scale(1) rotate(-45deg);
}

.check-row span{
  display:block;
  flex:1;
}

.check-row:has(input:checked){
  background:var(--gl);
  border-color:#A7F3D0;
  box-shadow:inset 0 0 0 1px rgba(11,110,79,.04),0 4px 14px rgba(11,110,79,.06);
}

.check-row input:checked + span{
  color:var(--gd);
  font-weight:700;
}

.subscription-intro{
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:flex-start;
  background:linear-gradient(135deg,#F8FFFB,#EEF8F1);
  border:1.5px solid #CDEBDD;
  border-radius:var(--rl2);
  padding:16px;
  margin-bottom:14px;
}
.subscription-intro h3,
.manual-party-head h3{
  margin:2px 0 4px;
  font-size:17px;
  color:var(--t1);
  letter-spacing:-.2px;
}
.subscription-intro p{
  margin:0;
  font-size:12px;
  color:var(--t3);
  line-height:1.6;
}
.section-kicker{
  font-size:10px;
  font-weight:900;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.9px;
}
.subscription-current{
  white-space:normal;
  background:#fff;
  color:var(--gd);
  border:1px solid #B7E4CD;
  border-radius:16px;
  padding:9px 11px;
  font-size:11px;
  font-weight:850;
  line-height:1.5;
  box-shadow:var(--sh-sm);
  max-width:100%;
  width:100%;
  align-self:flex-start;
}
.subscription-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:14px;
}
.subscription-badge-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:10px;
}
.idv-prep-card{
  display:flex;
  gap:12px;
  align-items:flex-start;
  background:linear-gradient(135deg,#F7FBFF,#EEF6FF);
  border:1px solid #BFDBFE;
  border-radius:var(--rl2);
  padding:13px;
  margin:-2px 0 14px;
  box-shadow:var(--sh-sm);
}
.idv-prep-card[hidden]{display:none}
.idv-prep-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#DBEAFE;
  flex-shrink:0;
}
.idv-prep-title{
  font-size:12px;
  font-weight:900;
  color:#1E3A8A;
  margin-bottom:3px;
}
.idv-prep-copy{
  font-size:11.5px;
  line-height:1.65;
  color:#31507D;
}
.verified-payment-card{
  background:linear-gradient(180deg,#FCF8FF,#F5F2FF);
  border:1.5px solid #D8B4FE;
  border-radius:var(--rl2);
  padding:15px;
  margin:0 0 14px;
  box-shadow:var(--sh-sm);
}
.verified-payment-card[hidden]{display:none}
.verified-payment-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.verified-payment-head h3{
  margin:2px 0 0;
  font-size:15px;
  color:var(--t1);
}
.verified-payment-card p{
  margin:0;
  color:var(--t2);
  font-size:12px;
  line-height:1.65;
  font-weight:650;
}
.verified-payment-badge{
  white-space:nowrap;
  border-radius:999px;
  background:#F3E8FF;
  color:#6D28D9;
  padding:6px 9px;
  font-size:10px;
  font-weight:900;
}
.verified-payment-status{
  margin-top:10px;
  padding:10px 11px;
  border-radius:12px;
  background:#FFFFFF;
  border:1px solid #D8B4FE;
  color:#5B21B6;
  font-size:11.5px;
  font-weight:850;
  line-height:1.5;
}
.subscription-card{
  appearance:none;
  text-align:left;
  border:1.5px solid var(--g2);
  background:#fff;
  border-radius:18px;
  padding:16px;
  box-shadow:var(--sh-sm);
  cursor:pointer;
  transition:transform .16s,border-color .16s,box-shadow .16s,background .16s;
}
.subscription-card:hover,
.subscription-card:focus-visible{
  transform:translateY(-1px);
  border-color:#9BDCBF;
  box-shadow:var(--sh-md);
}
.subscription-card:disabled{
  cursor:not-allowed;
  opacity:.58;
  transform:none;
  box-shadow:var(--sh-sm);
}
.subscription-card.selected{
  background:linear-gradient(180deg,#DDF6E8,#C8EED8);
  border-color:#064D37;
  box-shadow:0 16px 34px rgba(6,77,55,.22);
  transform:translateY(-1px);
}
.subscription-card.selected .subscription-badge{
  color:#fff;
  background:#064D37;
}
.subscription-card.selected strong{color:#052E22}
.subscription-card.selected .subscription-note{color:#064D37}
.subscription-card-featured{
  border-color:#BFD7FF;
  background:linear-gradient(180deg,#F7FBFF,#FFFFFF);
}
.subscription-badge{
  display:inline-flex;
  color:var(--gd);
  background:var(--gl);
  border-radius:999px;
  padding:4px 9px;
  font-size:10px;
  font-weight:900;
}
.subscription-card-featured .subscription-badge{
  color:#1E3A8A;
  background:#DBEAFE;
}
.subscription-badge-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:26px;
  padding:5px 9px;
  border-radius:999px;
  background:#EAF7F0;
  border:1px solid #C8E7D8;
  color:var(--gd);
  font-size:10px;
  font-weight:900;
  letter-spacing:.02em;
  flex-shrink:0;
}
.subscription-card strong{
  display:block;
  font-size:15px;
  color:var(--t1);
  margin-bottom:8px;
}
.subscription-price{
  display:block;
  font-size:21px;
  font-weight:900;
  color:var(--green);
  margin-bottom:8px;
  letter-spacing:-.4px;
}
.subscription-copy,
.subscription-note{
  display:block;
  font-size:12px;
  color:var(--t2);
  line-height:1.55;
}
.subscription-note{
  color:var(--t3);
  margin-top:8px;
}
.manual-party-card{
  background:#fff;
  border:1.5px solid var(--g2);
  border-radius:var(--rl2);
  padding:15px;
  box-shadow:var(--sh-sm);
  margin:14px 0;
}
.manual-party-card[hidden]{
  display:none;
}
.billing-card{
  margin-top:14px;
  border-style:dashed;
  border-color:#B7E6D2;
  background:linear-gradient(180deg,#F8FFFB,#FFFFFF);
}
.billing-copy{
  margin:0 0 12px;
  color:var(--t2);
  font-size:12px;
  line-height:1.65;
  font-weight:650;
}
.billing-country-chip{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  padding:0 12px;
  border-radius:14px;
  background:#F6FBF8;
  border:1px solid #D8EDE2;
  color:var(--gd);
  font-size:13px;
  font-weight:800;
}
.field-optional{
  color:var(--t4);
  font-size:11px;
  font-weight:700;
}
.provider-party-card{
  background:linear-gradient(180deg,#F7FBFF,#fff);
  border-color:#BFDBFE;
}
.verification-link{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  margin:10px 0 12px;
  padding:12px 14px;
  border-radius:12px;
  background:#EAF2FF;
  border:1.5px solid #9EC5FE;
  color:#1E40AF;
  font-size:13px;
  font-weight:850;
  text-decoration:none;
  box-shadow:var(--sh-sm);
}
.verification-link::before{
  content:'↗';
  font-size:14px;
  line-height:1;
}
.verification-link:hover{
  background:#DBEAFE;
}
.verification-link:active{
  transform:translateY(1px);
}
.verification-link[hidden]{
  display:none;
}
.manual-party-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.manual-party-note{
  max-width:150px;
  text-align:right;
  color:var(--t3);
  font-size:11px;
  line-height:1.45;
}
.form-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

/* ── STATUS BANNERS ── */
.status{
  display:flex;align-items:flex-start;gap:9px;
  padding:12px 14px;border-radius:var(--r);margin-bottom:13px;
  font-size:13px;line-height:1.6;
}
.status svg{flex-shrink:0;margin-top:1px}
.status-sm{font-size:12px}
.s-info{background:#EEF4FF;color:#1E40AF;border:1px solid #BFDBFE}
.s-ok{background:var(--gl);color:var(--gd);border:1px solid #A7F3D0}
.s-warn{background:var(--amber);color:var(--ad);border:1px solid #FDE68A}
.s-err{background:var(--rl);color:var(--rd);border:1px solid #FECACA}

/* ── INFO ROWS ── */
.info-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;border-bottom:1px solid var(--g2);font-size:13px;
}
.info-row:last-child{border-bottom:none}
.ir-lbl{color:var(--t3);font-weight:500}
.ir-val{font-weight:700;color:var(--t1);text-align:right;max-width:58%}
.divider{border:none;border-top:1px solid var(--g2);margin:.8rem 0}

/* ── PILLS ── */
.pill{display:inline-flex;align-items:center;border-radius:20px;padding:4px 11px;font-size:11px;font-weight:800}
.p-green{background:var(--gl);color:var(--gd)}
.p-amber{background:var(--amber);color:var(--ad)}
.p-gray{background:var(--g2);color:var(--t3)}

/* ── CHOICE GRID ── */
.cg{display:grid;gap:10px}
.cg2{grid-template-columns:1fr 1fr}
.copt{
  border:1.5px solid #D9E1DC;border-radius:22px;
  padding:18px 14px;cursor:pointer;text-align:center;transition:all .18s;
  background:linear-gradient(180deg,#FFFFFF 0%,#F7FAF8 100%);
  box-shadow:0 12px 24px rgba(17,17,16,.05);
}
.copt:hover,
.copt:focus-visible{
  transform:translateY(-1px);
  border-color:#93B3A5;
  box-shadow:0 16px 30px rgba(17,17,16,.08);
}
.copt:active,.copt.sel{
  border-color:#10251D;
  background:linear-gradient(160deg,#182322 0%,#0B6E4F 100%);
  border-width:2px;
  box-shadow:0 18px 34px rgba(6,77,55,.22);
}
.copt-icon{font-size:28px;margin-bottom:10px}
.copt-name{font-size:16px;font-weight:800;color:var(--t1)}
.copt-desc{font-size:11.5px;color:var(--t3);margin-top:5px;line-height:1.5}
.copt.sel .copt-name,
.copt.sel .copt-desc{
  color:#fff;
}
.copt.sel .copt-desc{
  color:rgba(255,255,255,.82);
}

/* ── STEPS ── */
.steps{display:flex;justify-content:center;gap:5px;padding:.6rem 0}
.sd{width:6px;height:6px;border-radius:50%;background:var(--g3);transition:.2s}
.sd.a{background:var(--green);width:18px;border-radius:3px}
.sd.d{background:var(--gm)}

/* ── PROGRESS BAR ── */
.progress-wrap{
  background:var(--g2);border-radius:20px;height:4px;margin:.3rem 0 .8rem;
  overflow:hidden;
}
.progress-bar{
  height:100%;background:linear-gradient(90deg,var(--green),var(--gm));
  border-radius:20px;transition:width .3s ease;
}
.progress-17{width:17%}
.progress-33{width:33%}
.progress-50{width:50%}
.progress-57{width:57%}
.progress-67{width:67%}
.progress-83{width:83%}
.progress-100{width:100%}

/* ── WIZARD HEADER ── */
.wizard-header{
  padding:.8rem 1rem .2rem;flex-shrink:0;
}
.wizard-step-label{
  font-size:11px;font-weight:700;color:var(--t3);
  text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;
}
.wizard-step-title{font-size:17px;font-weight:800;color:var(--t1);letter-spacing:-.2px}

/* ── CONTRACT BOX ── */
.contract-box{
  background:var(--g1);border:1.5px solid var(--g2);
  border-radius:var(--rl2);padding:16px;
  font-size:13px;line-height:1.9;color:var(--t2);
}
.contract-box strong{color:var(--t1);font-weight:700}

#s-preview #contract-preview{
  margin-top:12px;
}

#s-preview #pv-guidance{
  margin-top:12px;
}

.contract-record{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.contract-record-kicker{
  font-size:10px;
  font-weight:800;
  color:var(--green);
  letter-spacing:1px;
  text-transform:uppercase;
}

.contract-record-title{
  font-size:18px;
  font-weight:800;
  color:var(--t1);
  line-height:1.3;
  letter-spacing:-.2px;
}

.contract-record-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:11px;
  color:var(--t3);
  font-weight:700;
}

.contract-record-meta span{
  background:var(--g0);
  border:1px solid var(--g2);
  border-radius:999px;
  padding:4px 10px;
}

.contract-section{
  background:rgba(255,255,255,.72);
  border:1px solid var(--g2);
  border-radius:12px;
  padding:12px 13px;
}

.contract-section h4{
  font-size:12px;
  color:var(--t1);
  font-weight:800;
  margin-bottom:7px;
}

.contract-section ul{
  padding-left:18px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.contract-section li{
  font-size:12px;
  color:var(--t2);
  line-height:1.65;
}

/* ── LINK BOX ── */
.link-cta-panel{
  background:
    radial-gradient(circle at 92% 8%,rgba(93,202,165,.22),transparent 28%),
    linear-gradient(155deg,#F7FFFB 0%,#E8F7F0 100%);
  border:2px solid #9EDFC7;
  border-radius:20px;
  padding:16px;
  margin:4px 0 16px;
  box-shadow:0 16px 36px rgba(11,110,79,.16);
}
.link-cta-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:10px;
}
.link-cta-icon{
  width:42px;
  height:42px;
  border-radius:14px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:var(--sh-sm);
  flex-shrink:0;
}
.link-cta-kicker{
  font-size:10px;
  font-weight:900;
  color:var(--green);
  letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:5px;
}
.link-cta-title{
  font-size:16px;
  font-weight:800;
  color:var(--t1);
  line-height:1.35;
  margin-bottom:0;
}
.link-cta-copy{
  color:var(--t2);
  font-size:12px;
  line-height:1.65;
  margin-bottom:12px;
}
.link-box{
  background:#fff;
  border:2px solid rgba(11,110,79,.38);
  border-radius:15px;
  padding:13px 92px 13px 13px;
  color:var(--t1);
  word-break:break-all;
  position:relative;
  box-shadow:inset 0 0 0 1px rgba(11,110,79,.05),0 10px 24px rgba(11,110,79,.09);
}
.link-label{
  display:block;
  font-size:10px;
  font-weight:900;
  letter-spacing:.7px;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:5px;
}
#link-url-text{
  display:block;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:11px;
  line-height:1.55;
}
.copy-btn{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:var(--green);color:#fff;border:none;border-radius:6px;
  padding:8px 12px;font-size:11px;cursor:pointer;font-weight:850;
  box-shadow:0 7px 16px rgba(11,110,79,.20);
}
.share-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
  margin-top:12px;
}
.link-validity-note{
  margin-top:10px;
  padding:9px 11px;
  border-radius:12px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(11,110,79,.16);
  color:var(--t2);
  font-size:11px;
  line-height:1.45;
}
.btn-share{
  padding:13px 10px;
  font-size:13px;
  border:1.5px solid transparent;
  box-shadow:var(--sh-sm);
}
.btn-share.whatsapp{
  background:#DFF8EA;
  color:#075E3C;
  border-color:#7ED9A6;
}
.btn-share.email{
  background:#EAF2FF;
  color:#1E40AF;
  border-color:#9EC5FE;
}
.creator-recovery-panel{
  background:#fff;
  border:1px solid rgba(30,64,175,.18);
  border-radius:18px;
  padding:14px;
  margin:0 0 14px;
  box-shadow:0 10px 26px rgba(20,55,90,.07);
}
.creator-recovery-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}
.creator-recovery-kicker{
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:#1E40AF;
  margin-bottom:4px;
}
.creator-recovery-title{
  font-size:15px;
  font-weight:850;
  color:var(--t1);
}
.creator-recovery-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  background:#EAF2FF;
  color:#1E40AF;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  flex-shrink:0;
}
.creator-recovery-copy{
  color:var(--t2);
  font-size:12px;
  line-height:1.6;
  margin-bottom:10px;
}
.recovery-link-box{
  background:var(--g1);
  border:1.5px dashed rgba(30,64,175,.38);
  border-radius:14px;
  padding:12px 150px 12px 12px;
  position:relative;
  word-break:break-all;
}
#creator-recovery-url-text{
  display:block;
  color:var(--t2);
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:11px;
  line-height:1.55;
}
.recovery-copy-btn{
  background:#1E40AF;
}
.link-next-steps{
  background:#fff;
  border:1px solid var(--g2);
  margin:0 0 12px;
}
.link-next-grid{
  display:grid;
  gap:8px;
}
.link-next-grid div{
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:10px;
  padding:10px;
}
.link-next-grid strong{
  display:block;
  font-size:12px;
  color:var(--t1);
  margin-bottom:3px;
}
.link-next-grid span{
  display:block;
  font-size:11px;
  line-height:1.55;
  color:var(--t3);
}

/* ── IDENTITY BADGE ── */
.id-logo{
  width:38px;height:38px;border-radius:9px;background:var(--blue);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:9px;color:#fff;letter-spacing:.3px;flex-shrink:0;
}
.id-logo-ok{
  background:var(--green);
  font-size:18px;
  letter-spacing:0;
}

/* ── AUTH BADGE ── */
.auth-badge{
  display:flex;align-items:center;gap:12px;
  background:var(--gl);border:1.5px solid #A7F3D0;
  border-radius:var(--rl2);padding:13px 15px;margin-bottom:16px;
}
.auth-main{flex:1}
.auth-check{font-size:20px;font-weight:850;color:var(--green)}
.auth-name{font-size:14px;font-weight:700;color:var(--gd)}
.auth-sub{font-size:11px;color:var(--gm);margin-top:1px;font-weight:700}

.identity-main-cta{
  margin-top:12px;
  margin-bottom:12px;
}

.identity-hero{
  text-align:center;
  margin:1.2rem 0;
}
.identity-hero-icon{
  width:80px;
  height:80px;
  background:var(--blue);
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 12px;
  font-size:32px;
  box-shadow:0 4px 16px rgba(26,107,181,.3);
}
.identity-hero-title{font-size:16px;font-weight:800;color:var(--t1)}
.identity-hero-copy{
  font-size:13px;
  color:var(--t3);
  margin-top:4px;
  line-height:1.55;
}

.identity-result{
  background:#F7FBFF;
  border:1.5px solid #BFDBFE;
  border-radius:var(--rl2);
  padding:13px 14px;
}
.identity-result.is-success{
  background:linear-gradient(180deg,#F7FFF9,#EEF8F1);
  border-color:#B7E6D2;
  box-shadow:0 10px 24px rgba(11,110,79,.08);
}
.identity-result.is-warning{
  background:linear-gradient(180deg,#FFFBF2,#FFF2D9);
  border-color:#F3D08B;
  box-shadow:0 10px 24px rgba(180,120,0,.08);
}
.identity-result.is-error{
  background:linear-gradient(180deg,#FFF5F5,#FFEAEA);
  border-color:#F2B8B8;
  box-shadow:0 10px 24px rgba(170,60,60,.08);
}
.identity-result.is-pending{
  background:linear-gradient(180deg,#FFFDF5,#FFF8E1);
  border-color:#FDE68A;
}
.identity-result-spaced{margin-bottom:14px}
.identity-result-top{margin-top:14px}

.identity-result[hidden]{
  display:none;
}

.identity-result-kicker{
  font-size:10px;
  font-weight:900;
  color:#1E40AF;
  text-transform:uppercase;
  letter-spacing:.9px;
  margin-bottom:5px;
}

.identity-result-name{
  font-size:15px;
  font-weight:800;
  color:var(--t1);
}

.identity-result-meta{
  font-size:11px;
  color:var(--t3);
  line-height:1.55;
  margin-top:4px;
}
.identity-result-warning-copy{
  font-size:12px;
  font-weight:800;
  color:inherit;
  line-height:1.7;
}
.identity-result-warning-soft{
  margin-top:6px;
  font-size:11.5px;
  font-weight:650;
  color:inherit;
  line-height:1.7;
}
.identity-result-note{
  margin-top:8px;
  font-size:11px;
  color:var(--green);
  font-weight:700;
}
.cp-guide-card{
  background:linear-gradient(135deg,#F8FFFB,#EEF8F1);
  border:1.5px solid #CDEBDD;
  margin-bottom:14px;
}
.cp-guide-kicker{
  font-size:10px;
  font-weight:900;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.9px;
  margin-bottom:4px;
}
.cp-guide-card p{
  font-size:12px;
  color:var(--t3);
  line-height:1.65;
  margin-bottom:10px;
}
.cp-guide-steps{
  display:flex;
  flex-direction:column;
  gap:7px;
}
.cp-guide-steps span{
  background:#fff;
  border:1px solid var(--g2);
  border-radius:10px;
  padding:8px 10px;
  font-size:11.5px;
  font-weight:750;
  color:var(--t2);
}

.dossier-heading{
  font-size:11px;
  font-weight:900;
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.9px;
  margin:16px 0 7px;
}

.compact-dossier{
  max-height:360px;
  overflow:auto;
  border-color:#D9E7DF;
}

/* ── STRIPE ── */
#stripe-el,
#stripe-el-a,
#stripe-el-cp{
  padding:12px 13px;border:1.5px solid var(--g3);border-radius:var(--r);
  background:var(--g0);min-height:44px;transition:.15s;
}
#stripe-el.StripeElement--focus,
#stripe-el-a.StripeElement--focus,
#stripe-el-cp.StripeElement--focus{
  border-color:var(--green);box-shadow:0 0 0 3px rgba(11,110,79,.1);
}
#stripe-el.StripeElement--invalid,
#stripe-el-a.StripeElement--invalid,
#stripe-el-cp.StripeElement--invalid{border-color:#E24B4A}
#stripe-err,
#stripe-err-a,
#stripe-err-cp{color:#B91C1C;font-size:12px;font-weight:600;margin-top:6px;min-height:18px}
.payment-method-note{display:block;margin-bottom:8px}
.express-checkout-panel{
  background:linear-gradient(180deg,#F8FFFB,#F1FAF5);
  border:1px solid #CDEBDD;
  border-radius:14px;
  padding:10px 12px;
  margin-bottom:14px;
}
.express-checkout-title{
  font-size:11.5px;
  font-weight:850;
  color:var(--gd);
  margin-bottom:3px;
}
.express-checkout-copy{
  font-size:11.5px;
  line-height:1.45;
  color:var(--t2);
  margin-bottom:8px;
}
#stripe-express-a{
  max-width:430px;
  margin:0 auto;
}
.express-checkout-panel iframe{
  width:100% !important;
}
.express-checkout-panel [data-testid="express-checkout-element"],
.express-checkout-panel [data-testid="hosted-payment-element"]{
  width:100%;
}
@media (max-width: 640px){
  #stripe-express-a{
    max-width:none;
  }
}
.stripe-loading-copy{
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:700;
  color:var(--t3);
}
.stripe-seal{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:10px;font-size:11px;color:var(--t4);font-weight:600;
}
.amount-big{
  font-size:34px;font-weight:800;color:var(--green);
  text-align:center;margin:.5rem 0;letter-spacing:-.5px;
}
.payment-ready-card{
  background:linear-gradient(180deg,#F8FFFB,#F1FAF5);
  border:1.5px solid #B7E6D2;
  border-radius:var(--rl2);
  padding:14px;
  margin-bottom:14px;
}
.payment-ready-title{
  color:var(--gd);
  font-size:13px;
  font-weight:850;
  margin-bottom:8px;
}
.payment-ready-row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-size:12px;
  color:var(--t2);
}
.payment-ready-row strong{color:var(--t1)}
.payment-type{
  text-align:center;
  color:var(--t3);
  font-size:12px;
  font-weight:700;
  margin:-2px 0 14px;
}
.payment-purpose-note{
  background:#F7FBFF;
  border:1px solid #BFDBFE;
  color:#1E3A8A;
  border-radius:14px;
  padding:12px;
  margin:0 0 14px;
  font-size:12px;
  line-height:1.6;
  font-weight:750;
}
.payment-purpose-note[hidden]{display:none}
.payment-discount-card{
  background:#fff;
  border:1.5px solid rgba(11,110,79,.18);
  border-radius:18px;
  padding:13px 14px;
  margin:0 0 14px;
  box-shadow:0 12px 28px rgba(11,110,79,.06);
}
.payment-discount-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.payment-discount-title{
  color:var(--green);
  font-size:12px;
  font-weight:850;
  letter-spacing:.1px;
}
.payment-discount-price{
  color:var(--t2);
  font-size:11px;
  font-weight:800;
  text-align:right;
  white-space:nowrap;
}
.payment-discount-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
}
.payment-discount-input{
  min-width:0;
  border:1.5px solid #CFE4DA;
  border-radius:14px;
  padding:12px 14px;
  font-size:13px;
  font-weight:700;
  color:var(--t1);
  background:#FDFEFD;
  text-transform:uppercase;
}
.payment-discount-input::placeholder{
  color:var(--t4);
  font-weight:600;
  text-transform:none;
}
.payment-discount-input:focus{
  outline:none;
  border-color:#0B6E4F;
  box-shadow:0 0 0 3px rgba(11,110,79,.12);
}
.payment-discount-btn{
  padding:11px 14px;
  min-width:90px;
  border-radius:14px;
  font-size:12px;
  font-weight:850;
}
.payment-discount-status{
  margin-top:9px;
  border-radius:12px;
  padding:10px 11px;
  font-size:11.5px;
  line-height:1.55;
  font-weight:700;
}
.payment-discount-status[hidden]{display:none}
.payment-discount-status.is-ok{
  background:#EDF9F3;
  border:1px solid #B8E6D0;
  color:#0B6E4F;
}
.payment-discount-status.is-error{
  background:#FEF2F2;
  border:1px solid #FECACA;
  color:#B91C1C;
}
.payment-discount-status.is-info{
  background:#F6FAF8;
  border:1px solid #DCEBE3;
  color:var(--t2);
}
.stripe-error{
  color:var(--rd);
  font-size:12px;
  font-weight:700;
  line-height:1.5;
  margin-top:7px;
  min-height:18px;
}
.payment-feedback{
  margin-top:9px;
  border-radius:12px;
  padding:11px 12px;
  font-size:12px;
  line-height:1.55;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.payment-feedback[hidden]{display:none}
.payment-feedback.is-error{
  background:var(--rl);
  color:var(--rd);
  border:1px solid #FECACA;
}
.payment-feedback.is-warn{
  background:var(--amber);
  color:var(--ad);
  border:1px solid #FDE68A;
}
.payment-feedback.is-processing{
  background:#f3ecff;
  color:#6f3bc2;
  border:1px solid #d7c2fb;
}
.payment-feedback-title{
  font-weight:850;
  margin-bottom:3px;
}
.payment-feedback-copy{font-weight:600}

@media (max-width:460px){
  .payment-discount-head{
    flex-direction:column;
    align-items:flex-start;
    margin-bottom:9px;
  }
  .payment-discount-price{
    text-align:left;
    white-space:normal;
  }
  .payment-discount-row{
    grid-template-columns:1fr;
  }
  .payment-discount-btn{
    width:100%;
  }
}

/* ── BIG CHECK ── */
.big-check{
  width:68px;height:68px;background:var(--gl);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto;
  box-shadow:0 0 0 10px rgba(93,202,165,.12);
}

.outcome-mini{
  text-align:center;
  margin:1.5rem 0;
}
.outcome-mini-tight{margin:1rem 0 1.2rem}
.outcome-mini-title{
  font-size:18px;
  font-weight:850;
  margin-top:12px;
  color:var(--t1);
}
.outcome-main-title{
  font-size:20px;
  font-weight:850;
  margin-top:12px;
  color:var(--t1);
}
.outcome-mini-copy{
  font-size:13px;
  color:var(--t3);
  margin-top:4px;
  line-height:1.55;
}
.complete-final-status{
  margin-top:14px;
}

.complete-panel-title{
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--steel);
  margin-bottom:10px;
}

.complete-timeline-card,
.complete-summary-card{
  background:linear-gradient(180deg,#FAFBF9 0%,#F4F7F5 100%);
  border:1px solid #DFE5E1;
  border-radius:18px;
  padding:14px;
  margin-top:12px;
  box-shadow:0 10px 22px rgba(17,17,16,.04);
}

.complete-summary-card .info-row{
  padding:11px 0;
}

.complete-summary-card .ir-lbl{
  color:var(--steel);
  font-weight:700;
}

.complete-timeline-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
}

.complete-timeline-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 11px;
  border-radius:14px;
  background:#fff;
  border:1px solid #E4E9E5;
}

.complete-timeline-item strong{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--green);
  color:#fff;
  font-size:11px;
  flex-shrink:0;
}

.complete-timeline-item span{
  font-size:12px;
  font-weight:800;
  color:var(--tech);
}
.outcome-mini-emoji{font-size:40px}
.outcome-mini-icon{
  width:68px;
  height:68px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto;
  font-size:30px;
}
.outcome-mini-icon-error{background:var(--rl)}
.outcome-title-error{color:var(--rd)}

.outcome-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:calc(100vh - 190px);
}
.outcome-card{
  width:100%;
  background:
    radial-gradient(circle at 90% 8%,rgba(93,202,165,.14),transparent 28%),
    var(--g0);
  border:1.5px solid var(--g2);
  border-radius:24px;
  box-shadow:var(--sh-md);
  padding:22px;
  text-align:center;
}
.outcome-card.tone-ok{border-color:#A7F3D0;background:linear-gradient(180deg,#F8FFFB,#fff)}
.outcome-card.tone-warn{border-color:#FDE68A;background:linear-gradient(180deg,#FFFBEB,#fff)}
.outcome-card.tone-error{border-color:#FECACA;background:linear-gradient(180deg,#FFF7F7,#fff)}
.outcome-card.tone-info{border-color:#BFDBFE;background:linear-gradient(180deg,#F7FBFF,#fff)}
.outcome-icon{
  width:70px;
  height:70px;
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 14px;
  font-size:33px;
  background:var(--g1);
  box-shadow:var(--sh-sm);
}
.outcome-icon.outcome-icon-check{
  width:68px;
  height:68px;
  border-radius:50%;
  background:var(--gl);
  box-shadow:0 0 0 10px rgba(93,202,165,.12);
}
.outcome-kicker{
  font-size:10px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--green);
  margin-bottom:8px;
}
.outcome-card h2{
  font-size:22px;
  line-height:1.22;
  letter-spacing:-.4px;
  color:var(--t1);
  margin-bottom:9px;
}
.outcome-card p{
  font-size:13px;
  color:var(--t2);
  line-height:1.7;
}
.outcome-detail{
  margin-top:14px;
  text-align:left;
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:14px;
  padding:12px;
  font-size:12px;
  line-height:1.65;
  color:var(--t2);
}
.outcome-detail[hidden]{display:none}
.outcome-actions{
  display:flex;
  flex-direction:column;
  gap:9px;
  margin-top:18px;
}

/* ── LEGAL INFO ── */
.legal-info{
  background:#F0FDF4;border-left:3px solid var(--green);
  border-radius:0 var(--r) var(--r) 0;
  padding:12px 14px;font-size:12px;color:var(--gd);line-height:1.65;margin-top:12px;
}

.audit-panel{
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:var(--rl2);
  padding:14px;
  margin-top:12px;
}
.audit-secondary{
  margin-top:16px;
  background:#FAFAF8;
  border-style:dashed;
}

.audit-panel-title{
  font-size:12px;
  font-weight:800;
  color:var(--t1);
  margin-bottom:10px;
  letter-spacing:.2px;
}

.audit-item{
  position:relative;
  padding:10px 0 10px 14px;
  border-bottom:1px solid var(--g2);
}

.audit-item::before{
  content:'';
  position:absolute;
  left:0;
  top:14px;
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 4px rgba(11,110,79,.10);
}

@media (max-width:480px){
  .featured-vehicle-head{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    flex-wrap:nowrap;
  }

  .featured-vehicle-price{
    text-align:left;
  }

  .vehicle-checklist-grid{
    grid-template-columns:1fr;
  }
}

.audit-item:first-child{
  padding-top:0;
}

.audit-item:last-child{
  border-bottom:none;
  padding-bottom:0;
}

.audit-item-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:12px;
  font-size:11px;
  color:var(--t3);
  margin-bottom:4px;
}

.audit-item-head strong{
  color:var(--t1);
  font-size:12px;
  flex:1;
  min-width:180px;
}

.audit-item-body{
  font-size:12px;
  color:var(--t2);
  line-height:1.6;
}
.audit-item-copy{
  color:var(--t2);
}
.audit-item-meta-lines{
  margin-top:6px;
  display:grid;
  gap:4px;
}
.audit-item-meta-line{
  font-size:11px;
  line-height:1.55;
  color:var(--t3);
}

.audit-empty{
  font-size:12px;
  color:var(--t3);
  line-height:1.6;
}

.summary-card{
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:var(--rl2);
  padding:14px;
}

.summary-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:9px 0;
  border-bottom:1px solid var(--g2);
  font-size:12px;
  color:var(--t2);
}

.summary-row:first-child{
  padding-top:0;
}

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

.summary-row strong{
  color:var(--t1);
  text-align:right;
}

.formal-ack{
  margin-top:14px;
  background:#FFF7ED;
  border:1px solid #FED7AA;
  color:#9A3412;
  border-radius:var(--rl2);
  padding:14px;
  font-size:12px;
  line-height:1.7;
}

/* ── ACCORDI ── */
.acc-item{
  background:var(--g0);border:1.5px solid var(--g2);
  border-radius:var(--rl2);padding:15px;margin-bottom:10px;
  box-shadow:var(--sh-sm);
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.acc-item-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  margin-bottom:6px;
}
.acc-item-title{
  font-size:14px;
  font-weight:800;
  color:var(--t1);
}
.acc-item-meta{
  font-size:12px;
  color:var(--t3);
  margin-bottom:6px;
}
.acc-item-parties{
  font-size:11px;
  color:var(--t3);
  margin-bottom:10px;
  line-height:1.5;
}
.acc-item-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.acc-empty{text-align:center;padding:3rem 1rem}
.acc-empty-icon{font-size:48px;margin-bottom:14px}
.list-loading{
  text-align:center;
  color:var(--t4);
  padding:1.5rem;
  font-size:13px;
}
.acc-restore-hidden-btn{
  display:block;
  width:auto;
  margin:12px auto calc(78px + env(safe-area-inset-bottom));
  padding:4px 8px;
  font-size:11px;
  font-weight:800;
  color:#6D28D9;
}
.acc-restore-hidden-btn[hidden]{
  display:none;
}
.confirm-overlay{
  position:fixed;
  inset:0;
  z-index:320;
  background:rgba(17,17,16,.46);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.confirm-overlay[hidden]{
  display:none;
}
.confirm-dialog{
  width:min(100%,340px);
  background:#FFFFFF;
  border:1px solid var(--g2);
  border-radius:22px;
  box-shadow:0 20px 40px rgba(17,17,16,.16);
  padding:20px 18px 16px;
  text-align:center;
}
.confirm-dialog-title{
  font-size:16px;
  font-weight:850;
  color:var(--t1);
  line-height:1.45;
}
.confirm-dialog-copy{
  margin-top:8px;
  font-size:12px;
  color:var(--t3);
  line-height:1.65;
}
.confirm-dialog-actions{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:16px;
}
.btn-danger{
  background:var(--rd);
  color:#fff;
  border-color:var(--rd);
}
.btn-danger:active{
  background:#B91C1C;
  border-color:#B91C1C;
}

/* ── GUIDE ── */
.gstep{background:var(--g1);border-radius:var(--rl2);padding:16px;margin-bottom:12px}
.gstep-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;background:var(--green);color:#fff;
  border-radius:50%;font-size:12px;font-weight:800;flex-shrink:0;
}
.gstep-title{font-size:14px;font-weight:700;color:var(--t1);margin:7px 0}
.gstep-body{font-size:12px;color:var(--t2);line-height:1.8}
.gstep-body code{
  background:var(--g2);padding:1px 5px;border-radius:4px;
  font-family:monospace;font-size:11px;color:var(--t1);
}
.code-block{
  background:#1C1C2E;color:#E2E8F0;font-family:monospace;font-size:11px;
  line-height:1.75;padding:14px 15px;border-radius:var(--r);margin:8px 0;
  overflow-x:auto;white-space:pre;
}
.kw{color:#C084FC}.str{color:#86EFAC}.cm{color:#64748B}.fn{color:#7DD3FC}

/* ── BOTTOM NAV ── */
.nav{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:430px;background:#E4F1E7;
  border-top:1px solid #D1E1D5;display:flex;z-index:200;
  padding-bottom:env(safe-area-inset-bottom);
  box-shadow:0 -6px 22px rgba(17,17,16,.08);
}
.nav-btn{
  flex:1;display:flex;flex-direction:column;align-items:center;
  padding:10px 4px 8px;cursor:pointer;color:var(--t4);
  font-size:10px;font-weight:700;gap:3px;
  border:none;background:none;transition:.15s;
  -webkit-tap-highlight-color:transparent;
  position:relative;
  isolation:isolate;
}
.nav-btn.active{color:var(--gd)}
.nav-btn.active::before{
  content:'';
  position:absolute;
  top:50%;
  left:50%;
  width:72px;
  height:50px;
  transform:translate(-50%,-50%);
  border-radius:999px;
  background:rgba(109,40,217,.16);
  box-shadow:0 8px 16px rgba(109,40,217,.10);
  z-index:-1;
}
.nav-btn svg{
  width:22px;
  height:22px;
  stroke-width:2;
  padding:5px;
  border-radius:999px;
  box-sizing:content-box;
  transition:background .15s ease, box-shadow .15s ease, color .15s ease;
}
.nav-btn.active svg{
  background:transparent;
  box-shadow:none;
}

/* ── TOAST ── */
#toast{
  position:fixed;bottom:76px;left:50%;transform:translateX(-50%);
  background:rgba(17,17,16,.9);backdrop-filter:blur(8px);
  color:#fff;font-size:13px;font-weight:700;
  padding:12px 16px;border-radius:18px;z-index:1000;
  opacity:0;transition:opacity .25s;pointer-events:none;
  width:max-content;
  max-width:min(92vw,390px);
  text-align:center;
  line-height:1.55;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}
#toast.show{opacity:1}
body.has-blocking-loader{
  overflow:hidden;
}

/* ── SPINNER ── */
.spin{
  display:inline-block;width:16px;height:16px;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  border-radius:50%;animation:rot .7s linear infinite;
  margin-right:8px;vertical-align:middle;
}
.spin-dark{
  border-color:rgba(11,110,79,.18);
  border-top-color:var(--green);
}
.inline-loading{
  display:inline-flex;
  align-items:center;
  gap:3px;
}
@keyframes rot{to{transform:rotate(360deg)}}

/* ── MISC ── */
.doc-id{font-family:monospace;font-size:11px;color:var(--t3)}
.signers-line{font-size:11px}
.nota{font-size:11px;color:var(--t4);line-height:1.5;text-align:center;margin-top:7px}
.card-sm{background:var(--g1);border-radius:var(--rl2);padding:15px;margin-bottom:10px}
.card-spaced,
.block-spaced{margin-bottom:14px}
.card-kicker{
  font-size:12px;
  font-weight:800;
  color:var(--t2);
  margin-bottom:4px;
}
.card-title-sm{font-size:14px;font-weight:800;color:var(--t1)}
.card-copy-sm{font-size:11px;color:var(--t3);margin-top:3px;line-height:1.5}
.technical-copy{
  font-size:12px;
  color:var(--t2);
  line-height:1.85;
}
.retry-attention-note{
  margin-top:8px;
  font-size:13px;
  font-weight:800;
  color:#6D28D9;
  line-height:1.75;
}
.retry-attention-note strong{
  font-weight:900;
  letter-spacing:.2px;
}
.is-hidden{display:none}
.empty-title{font-size:17px;font-weight:850;color:var(--t1);margin-bottom:5px}
.empty-copy{font-size:13px;color:var(--t3);line-height:1.55;margin-bottom:14px}
.fine-print-card{
  background:#FFF7ED;
  border:1px solid #FED7AA;
  border-radius:var(--rl2);
  color:#9A3412;
  font-size:11px;
  line-height:1.65;
  padding:12px 13px;
  margin:12px 0;
}
.ir-price{color:var(--green)}
.text-amber{color:var(--ad)}
.loading-state{
  min-height:60vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.loading-icon{font-size:30px;margin-bottom:12px}
.loading-title{font-size:15px;font-weight:700;color:var(--t2)}

.blocking-loader-overlay{
  position:fixed;
  inset:0;
  z-index:1600;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(17,17,16,.42);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  pointer-events:auto;
}
.blocking-loader-overlay[hidden]{
  display:none;
}
.blocking-loader-card{
  width:min(92vw,420px);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.7);
  border-radius:22px;
  box-shadow:0 24px 60px rgba(0,0,0,.18);
  padding:22px 20px;
  text-align:center;
}
.blocking-loader-spinner{
  width:38px;
  height:38px;
  border:3px solid rgba(11,110,79,.14);
  border-top-color:var(--green);
  border-radius:50%;
  margin:0 auto 14px;
  animation:rot .7s linear infinite;
}
.blocking-loader-title{
  font-size:17px;
  font-weight:850;
  color:var(--t1);
  margin-bottom:8px;
}
.blocking-loader-copy{
  font-size:13px;
  line-height:1.65;
  color:var(--t2);
}

.docs-wrap{display:flex;flex-direction:column;gap:14px}
.docs-section{
  background:#fff;
  border:1px solid var(--g2);
  border-radius:var(--rl2);
  padding:16px;
  box-shadow:var(--sh-sm);
}
.docs-section h3{
  font-size:15px;
  font-weight:800;
  color:var(--t1);
  margin-bottom:8px;
}
.docs-section h4{
  font-size:11px;
  font-weight:900;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.8px;
  margin:12px 0 6px;
}
.docs-section h4:first-of-type{
  margin-top:2px;
}
.docs-section p,
.docs-section li{
  font-size:12px;
  color:var(--t2);
  line-height:1.75;
}
.docs-section a{
  color:var(--green);
  font-weight:800;
  text-decoration:none;
}
.docs-section a:hover{
  text-decoration:underline;
}
.docs-section ul{
  padding-left:18px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.docs-note{
  font-size:11px;
  color:var(--t3);
  line-height:1.6;
  margin-top:8px;
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:10px;
  padding:9px 10px;
}
.docs-table-wrap{
  margin-top:8px;
  border:1px solid var(--g2);
  border-radius:14px;
  overflow-x:auto;
  background:#fff;
}
.docs-table{
  width:100%;
  min-width:720px;
  border-collapse:collapse;
}
.docs-table th{
  font-size:11px;
  font-weight:900;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.7px;
  background:#F8FFFB;
  padding:11px 12px;
  text-align:left;
  border-bottom:1px solid var(--g2);
  vertical-align:top;
}
.docs-table td{
  font-size:12px;
  color:var(--t2);
  line-height:1.7;
  padding:11px 12px;
  border-bottom:1px solid #E7F0EA;
  vertical-align:top;
}
.docs-table tr:last-child td{
  border-bottom:none;
}

.owner-panel-hero{
  background:linear-gradient(145deg,#F7FBFF 0%,#EEF8F1 100%);
  border:1px solid #D7E7DE;
  border-radius:18px;
  padding:16px;
  margin-bottom:14px;
  box-shadow:var(--sh-sm);
}

.owner-panel-hero-compact{
  margin-bottom:12px;
}

.owner-panel-kicker{
  font-size:10px;
  font-weight:900;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:6px;
}

.owner-panel-title{
  font-size:17px;
  font-weight:850;
  color:var(--t1);
  line-height:1.35;
  margin-bottom:6px;
}

.owner-panel-hero p{
  font-size:12px;
  color:var(--t2);
  line-height:1.7;
}

.owner-search-panel{
  margin-bottom:14px;
}

.owner-search-separator{
  font-size:11px;
  font-weight:800;
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.8px;
  margin:2px 0 10px;
}

.owner-results{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.owner-empty-state{
  background:#fff;
  border:1px dashed var(--g3);
  border-radius:16px;
  padding:18px 16px;
  text-align:center;
  color:var(--t3);
}

.owner-empty-title{
  font-size:14px;
  font-weight:800;
  color:var(--t1);
  margin-bottom:6px;
}

.owner-empty-copy{
  font-size:12px;
  line-height:1.65;
}

.owner-result-card{
  background:#fff;
  border:1px solid var(--g2);
  border-radius:18px;
  padding:15px;
  box-shadow:var(--sh-sm);
}

.owner-result-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
}

.owner-result-kicker{
  font-size:10px;
  font-weight:900;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.9px;
  margin-bottom:4px;
}

.owner-result-title{
  font-size:16px;
  font-weight:850;
  color:var(--t1);
  line-height:1.3;
}

.owner-result-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-bottom:12px;
}

.owner-result-grid div{
  background:var(--g1);
  border:1px solid var(--g2);
  border-radius:12px;
  padding:10px 11px;
}

.owner-result-grid span{
  display:block;
  font-size:10px;
  font-weight:800;
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.7px;
  margin-bottom:4px;
}

.owner-result-grid strong{
  display:block;
  font-size:12px;
  color:var(--t1);
  line-height:1.55;
}

.owner-result-snippet{
  font-size:11px;
  color:var(--t2);
  line-height:1.65;
  background:#FAFCFB;
  border:1px solid #E4ECE7;
  border-radius:12px;
  padding:10px 11px;
  margin-bottom:12px;
}

.owner-result-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.owner-result-actions .btn{
  flex:1 1 180px;
}

.owner-openapi-panel{
  margin-top:12px;
  padding:12px;
  border:1px solid #DCEEE5;
  border-radius:14px;
  background:#F8FCFA;
}

.owner-openapi-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}

.owner-openapi-head strong{
  display:block;
  font-size:13px;
  color:var(--t1);
}

.owner-openapi-head span{
  display:block;
  font-size:11px;
  color:var(--t3);
  text-align:right;
}

.owner-openapi-group + .owner-openapi-group{
  margin-top:10px;
  padding-top:10px;
  border-top:1px dashed #D7E6DE;
}

.owner-openapi-group-title{
  font-size:12px;
  font-weight:800;
  color:var(--t1);
  margin-bottom:8px;
}

.owner-openapi-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.owner-openapi-actions .btn{
  flex:1 1 120px;
}

.owner-openapi-panel .status{
  margin-top:10px;
}

.template-grid-home{
  gap:14px;
}

.template-grid-secondary{
  margin-top:4px;
}

.secondary-dossiers-panel{
  margin:2px 0 20px;
  padding:12px;
  border-radius:24px;
  background:linear-gradient(180deg,#F8F7F3 0%,#F1F0EA 100%);
  border:1px solid #E2E0D7;
  box-shadow:0 14px 28px rgba(17,17,16,.045);
}

.secondary-dossiers-head{
  margin-bottom:6px;
}

.secondary-dossiers-head .sec-label{
  margin:0 0 2px;
}

.tcard-home{
  text-decoration:none;
  color:inherit;
  min-height:unset;
  padding:18px;
  gap:8px;
  background:linear-gradient(180deg,#FFFFFF 0%,#FAFAF8 100%);
  border-color:#E4E8E5;
}

.tcard-home .tcard-name{
  font-size:17px;
}

.tcard-home .tcard-desc{
  min-height:unset;
}

.template-grid-secondary .tcard-home{
  padding:11px 11px 10px;
  box-shadow:0 7px 14px rgba(17,17,16,.035);
  border-radius:16px;
  background:linear-gradient(180deg,#FFFFFF 0%,#FBFBF9 100%);
}

.template-grid-secondary .tcard-home .tcard-icon{
  font-size:18px;
  margin-bottom:4px;
}

.template-grid-secondary .tcard-home .tcard-name{
  font-size:14px;
  margin-bottom:2px;
  line-height:1.22;
}

.template-grid-secondary .tcard-home .tcard-desc{
  font-size:10.4px;
  line-height:1.4;
}

.template-grid-secondary .price-tag{
  margin-top:5px;
  font-size:10px;
  padding:2px 7px;
}

.template-grid-secondary .tcard-link{
  margin-top:6px;
  min-height:24px;
  padding:4px 9px;
  font-size:10px;
}

.featured-vehicle-card{
  display:block;
  text-decoration:none;
  color:inherit;
  margin:0 0 14px;
  padding:18px 18px 17px;
  border-radius:26px;
  background:
    radial-gradient(circle at right top,rgba(56,154,110,.28),transparent 34%),
    linear-gradient(155deg,#FCFBF8 0%,#EDF6F0 36%,#C8E3D0 100%);
  border:1px solid #C2DBC9;
  box-shadow:0 18px 38px rgba(17,17,16,.08);
}

.featured-vehicle-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}

.featured-vehicle-badge,
.featured-vehicle-kicker{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:6px 11px;
  border-radius:999px;
  font-size:11px;
  font-weight:850;
}

.featured-vehicle-badge{
  background:#10251D;
  color:#fff;
}

.featured-vehicle-kicker{
  background:#E7F4EE;
  color:var(--gd);
  border:1px solid #CBE6D8;
}

.featured-vehicle-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 94px;
  gap:12px;
  align-items:flex-start;
}
.featured-vehicle-copy{
  min-width:0;
  grid-column:1;
  grid-row:1;
}
.featured-vehicle-side{
  grid-column:2;
  grid-row:1;
  flex-shrink:0;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:7px;
}

.featured-vehicle-body h2{
  font-size:25px;
  line-height:1.08;
  letter-spacing:-.04em;
  color:var(--tech);
  margin-bottom:8px;
}

.featured-vehicle-body p{
  font-size:13px;
  line-height:1.65;
  color:var(--steel);
  max-width:none;
}

.featured-vehicle-price{
  flex-shrink:0;
  font-size:18px;
  font-weight:900;
  color:var(--gd);
}

.featured-vehicle-price-wrap{text-align:right}

.featured-vehicle-price-note{
  margin-top:4px;
  font-size:10px;
  line-height:1.35;
  color:var(--gd);
  font-weight:700;
  opacity:.82;
}

.featured-vehicle-cta-group{
  margin-top:14px;
}

.featured-vehicle-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:var(--green);
  color:#fff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.03em;
  box-shadow:0 12px 22px rgba(11,110,79,.17);
}

.featured-vehicle-cta-note{
  margin-top:7px;
  font-size:10px;
  line-height:1.4;
  color:var(--gd);
  font-weight:700;
}
.featured-vehicle-preview{
  display:block;
  position:relative;
  isolation:isolate;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(6,77,55,.12);
  border-radius:16px;
  padding:7px 7px 8px;
  box-shadow:0 8px 20px rgba(17,17,16,.06);
  text-align:left;
  cursor:pointer;
  appearance:none;
  width:94px;
  max-width:94px;
  overflow:hidden;
  opacity:.92;
}

.featured-vehicle-preview::before{
  content:'FACSIMILE';
  position:absolute;
  top:52%;
  left:50%;
  transform:translate(-50%,-50%) rotate(-33deg);
  font-size:15px;
  font-weight:900;
  letter-spacing:.16em;
  color:rgba(6,77,55,.18);
  z-index:1;
  pointer-events:none;
  white-space:nowrap;
}

.featured-vehicle-preview-clickhint{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%) rotate(32deg);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:112px;
  max-width:92%;
  padding:4px 9px;
  border-radius:999px;
  background:rgba(109,40,217,.16);
  border:1px solid rgba(109,40,217,.34);
  box-shadow:0 8px 18px rgba(109,40,217,.12);
  color:#6D28D9;
  font-size:5.8px;
  line-height:1.18;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
  white-space:nowrap;
  pointer-events:none;
  z-index:3;
}

@media (max-width:480px){
  .featured-vehicle-preview-clickhint{
    transform:translate(-50%,-50%) rotate(70deg);
    min-width:148px;
    width:148px;
    max-width:none;
    font-size:6.8px;
    letter-spacing:.01em;
    line-height:1.04;
    padding:5px 9px;
    white-space:nowrap;
    text-align:center;
    text-transform:uppercase;
  }
}

.featured-vehicle-preview-head{
  font-size:7.5px;
  font-weight:900;
  letter-spacing:.08em;
  color:var(--gd);
  margin-bottom:4px;
}

.featured-vehicle-preview-meta{
  font-size:7px;
  line-height:1.35;
  color:rgba(6,77,55,.72);
  margin-bottom:6px;
  font-weight:700;
}

.featured-vehicle-preview-divider{
  height:1px;
  background:rgba(11,110,79,.22);
  margin:6px 0;
}

.featured-vehicle-preview-party-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:5px;
}

.featured-vehicle-preview-party{
  display:block;
  border-radius:9px;
  background:rgba(235,253,245,.96);
  border:1px solid rgba(11,110,79,.16);
  padding:6px 7px;
  filter:blur(.28px);
}

.featured-vehicle-preview-party strong{
  display:block;
  font-size:6.8px;
  line-height:1.25;
  color:var(--gd);
  margin-bottom:2px;
}

.featured-vehicle-preview-party small{
  display:block;
  font-size:6.6px;
  line-height:1.3;
  color:rgba(45,105,82,.92);
  font-weight:700;
}

.featured-vehicle-preview-section{
  font-size:6.8px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--gd);
  margin-bottom:5px;
}

.featured-vehicle-preview-line,
.featured-vehicle-preview-grid span,
.featured-vehicle-preview-row span{
  display:block;
  border-radius:8px;
  background:rgba(11,110,79,.10);
  color:rgba(17,17,16,.58);
  font-size:7px;
  font-weight:800;
  line-height:1.35;
  padding:6px 7px;
  filter:blur(.3px);
}

.featured-vehicle-preview-line{
  margin-bottom:6px;
}

.featured-vehicle-preview-line-strong{
  color:rgba(6,77,55,.72);
  background:rgba(11,110,79,.16);
}

.featured-vehicle-preview-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  margin:7px 0;
}

.featured-vehicle-preview-grid span{
  min-height:22px;
}

.featured-vehicle-preview-row{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:6px;
  margin-top:6px;
}

.featured-vehicle-preview-row span{
  min-height:20px;
}

.featured-vehicle-preview-foot{
  margin-top:8px;
  font-size:7px;
  line-height:1.45;
  color:var(--gd);
  font-weight:800;
}

.featured-vehicle-preview-extra{
  display:none;
}

.vehicle-checklist-panel{
  background:linear-gradient(180deg,#FFFFFF 0%,#F7F8F6 100%);
  border:1px solid #E1E6E2;
  border-radius:24px;
  padding:16px;
  margin:0 0 18px;
  box-shadow:0 14px 28px rgba(17,17,16,.05);
}

.vehicle-checklist-head .sec-label{
  margin:0 0 6px;
}

.vehicle-checklist-head h3{
  font-size:19px;
  line-height:1.2;
  letter-spacing:-.03em;
  color:var(--tech);
  margin-bottom:13px;
}

.vehicle-checklist-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.vehicle-checklist-item{
  background:var(--warm);
  border:1px solid #E5E9E6;
  border-radius:16px;
  padding:12px;
}

.vehicle-checklist-item strong{
  display:block;
  font-size:12px;
  font-weight:850;
  color:var(--tech);
  margin-bottom:4px;
}

.vehicle-checklist-item span{
  display:block;
  font-size:11px;
  line-height:1.55;
  color:var(--steel);
}

.tcard-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  margin-top:10px;
  padding:5px 11px;
  border-radius:999px;
  background:var(--green);
  border:1px solid rgba(6,77,55,.14);
  color:#fff;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  box-shadow:0 8px 18px rgba(11,110,79,.14);
}

.agreement-hero,
.agreement-role-panel{
  background:linear-gradient(180deg,#F3FBF7 0%,#E6F5EE 100%);
  border:1px solid #D4EADF;
  border-radius:26px;
  padding:24px;
  box-shadow:0 18px 40px rgba(11,110,79,.07);
}

.agreement-hero h2{
  margin:8px 0 10px;
  font-size:30px;
  line-height:1.08;
  letter-spacing:-.03em;
  color:var(--t1);
}

.agreement-hero p,
.agreement-role-head p{
  margin:0;
  color:var(--t3);
  line-height:1.6;
}

.agreement-list{
  margin:0;
  padding-left:18px;
  color:#393934;
  line-height:1.65;
}

.agreement-hero-meta{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:18px;
}

.agreement-hero-meta div{
  background:#fff;
  border:1px solid #DCEEE5;
  border-radius:18px;
  padding:14px 16px;
}

.agreement-hero-meta span{
  display:block;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--t3);
  margin-bottom:4px;
}

.agreement-hero-meta strong{
  font-size:16px;
  color:var(--t1);
}

.agreement-landing-helper{
  margin-top:10px;
}

.agreement-prep-card{
  margin-top:12px;
  background:linear-gradient(180deg,#FFFDF8 0%,#F8FAF7 100%);
  border:1px solid #E3E6DF;
  border-radius:20px;
  padding:14px;
  box-shadow:0 12px 24px rgba(17,17,16,.04);
}

.agreement-prep-card .agreement-secondary-title{
  color:var(--tech);
  margin-bottom:10px;
}

.agreement-flow{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}

.agreement-flow-step{
  display:flex;
  gap:12px;
  align-items:flex-start;
  background:rgba(255,255,255,.86);
  border:1px solid #DCEEE5;
  border-radius:18px;
  padding:14px 16px;
}

.agreement-flow-step strong{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--green);
  color:#fff;
  font-size:13px;
  flex-shrink:0;
}

.agreement-flow-step span{
  color:#393934;
  line-height:1.5;
}

.agreement-role-panel{
  margin-top:14px;
}

.agreement-role-head{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:18px;
  text-align:center;
}

.agreement-role-head h3{
  margin:6px 0 0;
  font-size:25px;
  line-height:1.1;
  color:var(--t1);
}

.agreement-role-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(158px,1fr));
  gap:12px;
  align-items:stretch;
}

.agreement-role-card{
  appearance:none;
  border:1px solid rgba(11,110,79,.18);
  background:linear-gradient(180deg,#FFFFFF 0%,#EEF8F3 100%);
  border-radius:22px;
  min-height:156px;
  padding:18px 16px;
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:8px;
  justify-content:center;
  align-items:center;
  cursor:pointer;
  transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease;
  text-decoration:none;
  color:inherit;
  box-shadow:0 10px 22px rgba(11,110,79,.08);
}

.agreement-role-card:hover,
.agreement-role-card:focus-visible{
  transform:translateY(-1px);
  border-color:#6EA98E;
  box-shadow:0 14px 28px rgba(11,110,79,.13);
  outline:none;
}

.agreement-role-icon{
  font-size:26px;
}

.agreement-role-name{
  font-size:18px;
  font-weight:800;
  color:var(--t1);
  text-align:center;
}

.agreement-role-desc{
  color:var(--t3);
  line-height:1.5;
  font-size:13px;
  text-align:center;
  max-width:22ch;
}

.agreement-role-cta{
  margin-top:4px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:6px 10px;
  border-radius:999px;
  background:#EAF7F0;
  border:1px solid #C8E7D8;
  color:var(--gd);
  font-size:11px;
  font-weight:850;
  letter-spacing:.02em;
}

.agreement-secondary-grid{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(220px,1fr);
  gap:12px;
  margin-top:16px;
  overflow-x:auto;
  padding-bottom:4px;
  scroll-snap-type:x proximity;
}

.agreement-secondary-card{
  background:#fff;
  border:1px solid #E4EEE8;
  border-radius:18px;
  padding:14px 14px 12px;
  box-shadow:0 10px 20px rgba(17,17,16,.04);
  scroll-snap-align:start;
}

.agreement-secondary-card:first-child{
  background:linear-gradient(180deg,#FFFFFF 0%,#FAFBF9 100%);
}

.agreement-secondary-card:nth-child(2){
  background:linear-gradient(180deg,#F7FBF8 0%,#FFFFFF 100%);
}

.agreement-secondary-title{
  font-size:13px;
  font-weight:800;
  color:var(--t1);
  margin-bottom:8px;
}

.agreement-list-compact{
  padding-left:16px;
  font-size:12px;
  line-height:1.5;
  color:var(--t3);
}

.agreement-list-compact li + li{
  margin-top:5px;
}

.agreement-flow-compact{
  gap:8px;
}

.agreement-flow-compact .agreement-flow-step{
  gap:10px;
  padding:10px 11px;
  border-radius:14px;
}

.agreement-flow-compact .agreement-flow-step strong{
  width:24px;
  height:24px;
  font-size:11px;
}

.agreement-flow-compact .agreement-flow-step span{
  font-size:12px;
  line-height:1.45;
  color:var(--t3);
}

.cookie-banner{
  display:none;
  position:fixed;
  left:50%;
  bottom:90px;
  transform:translateX(-50%);
  width:min(400px, calc(100vw - 24px));
  background:rgba(17,17,16,.96);
  color:#fff;
  border-radius:18px;
  padding:14px;
  z-index:1200;
  box-shadow:0 16px 40px rgba(0,0,0,.22);
}
.cookie-banner-text{
  font-size:12px;
  line-height:1.6;
  color:rgba(255,255,255,.86);
  margin-bottom:10px;
}

@media (max-width:520px){
  .subscription-intro,
  .manual-party-head{
    flex-direction:column;
  }
  .subscription-current,
  .manual-party-note{
    align-self:flex-start;
    text-align:left;
    max-width:none;
  }
  .subscription-grid,
  .form-grid-2,
  .owner-result-grid,
  .agreement-role-grid,
  .agreement-hero-meta{
    grid-template-columns:1fr;
  }
  .recovery-link-box{
    padding:12px;
  }
  .recovery-copy-btn{
    position:static;
    transform:none;
    margin-top:10px;
    width:100%;
  }
}

@media (min-width:760px){
  .agreement-hero-meta{
    grid-template-columns:minmax(0,1fr);
  }

  .agreement-hero-meta div{
    width:100%;
  }
  .agreement-secondary-grid{
    grid-auto-flow:column;
    grid-auto-columns:minmax(320px,34vw);
    overflow-x:auto;
    overflow-y:hidden;
  }
}

@media (min-width:1040px){
  .agreement-role-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .agreement-secondary-grid{
    grid-auto-columns:minmax(360px,32vw);
  }
}

@media (min-width:900px){
  :root{
    --desktop-shell:1180px;
    --desktop-form:860px;
  }

  body{
    background:linear-gradient(180deg,#F1F2EE 0%,#E7ECE8 100%);
    align-items:stretch;
  }

  .app-shell{
    max-width:none;
    width:100%;
  }

  .app{
    max-width:none;
    width:100%;
    box-shadow:none;
    background:var(--g1);
  }

  .screen{
    background:var(--g1);
    padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 24px);
  }

  .topbar,
  .wizard-header{
    padding-left:max(24px, calc((100% - var(--desktop-shell)) / 2));
    padding-right:max(24px, calc((100% - var(--desktop-shell)) / 2));
    background:rgba(248,248,246,.92);
    backdrop-filter:blur(10px);
  }

  .hero{
    width:min(var(--desktop-shell), calc(100% - 56px));
    margin:24px auto 0;
    border-radius:30px;
    padding:2.4rem 2.4rem 2rem;
    box-shadow:0 24px 60px rgba(17,17,16,.10);
  }

  .hero h1{
    max-width:16ch;
    font-size:42px;
  }

  .hero-sub{
    max-width:18ch;
    font-size:22px;
  }

  .hero-sub-detail{
    max-width:64ch;
    font-size:16px;
  }

  .hero-actions{
    align-items:flex-start;
  }

  .hero-flow{
    max-width:760px;
    gap:10px;
  }

  .trust-row{
    gap:10px;
  }

  .sc,
  .sc-tight,
  .sc-compact-top{
    width:min(var(--desktop-shell), calc(100% - 56px));
    margin:0 auto;
    padding:24px 0;
  }

  .sc-form,
  .sc-link{
    width:min(var(--desktop-form), calc(100% - 56px));
    margin:0 auto;
    padding:24px 0;
  }

  .home-section-head{
    display:block;
    margin:6px 0 16px;
  }

  .home-section-head .sec-label{
    display:block;
    margin:0 0 8px;
    font-size:13px;
    letter-spacing:1.2px;
    color:var(--gd);
  }

  .home-section-copy{
    max-width:75%;
    line-height:1.7;
  }

  .template-grid-secondary .price-tag{
    display:block;
    width:max-content;
    margin-top:7px;
  }

  .template-grid-secondary .tcard-link{
    margin-top:12px;
  }

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

  .featured-vehicle-card{
    padding:20px 22px 20px;
  }

  .featured-vehicle-body{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:20px;
    align-items:start;
  }

  .featured-vehicle-copy{
    grid-column:auto;
    grid-row:auto;
  }

  .featured-vehicle-body p{
    max-width:44ch;
  }

  .featured-vehicle-cta-group{
    margin-top:16px;
  }

  .featured-vehicle-side{
    display:grid;
    grid-template-columns:minmax(360px,504px) auto;
    align-items:start;
    min-width:0;
    gap:12px;
  }

  .featured-vehicle-price-wrap{
    grid-column:2;
    text-align:right;
    align-self:start;
    padding-top:4px;
  }

  .featured-vehicle-preview{
    display:block;
    position:relative;
    isolation:isolate;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(6,77,55,.12);
    border-radius:18px;
    padding:10px 10px 11px;
    box-shadow:0 10px 24px rgba(17,17,16,.06);
    text-align:left;
    cursor:pointer;
    appearance:none;
    width:100%;
    max-width:504px;
    overflow:hidden;
    opacity:.94;
    grid-column:1;
    align-self:start;
  }

  .featured-vehicle-preview::before{
    content:'FACSIMILE';
    position:absolute;
    top:46%;
    left:50%;
    transform:translate(-50%,-50%) rotate(-33deg);
    font-size:27px;
    font-weight:900;
    letter-spacing:.16em;
    color:rgba(6,77,55,.18);
    z-index:1;
    pointer-events:none;
    white-space:nowrap;
  }

  .featured-vehicle-preview-clickhint{
    top:50%;
    left:50%;
    transform:translate(-50%,-50%) rotate(-17deg);
    min-width:258px;
    max-width:78%;
    padding:7px 16px;
    font-size:9.6px;
    letter-spacing:.08em;
    box-shadow:0 10px 22px rgba(109,40,217,.14);
  }

  .featured-vehicle-preview-head{
    font-size:10px;
    font-weight:900;
    letter-spacing:.08em;
    color:var(--gd);
    margin-bottom:6px;
  }

  .featured-vehicle-preview-meta{
    font-size:8.5px;
    margin-bottom:8px;
  }

  .featured-vehicle-preview-divider{
    margin:8px 0;
  }

  .featured-vehicle-preview-party-grid{
    grid-template-columns:1fr 1fr;
    gap:6px;
  }

  .featured-vehicle-preview-party{
    padding:7px 8px;
    border-radius:10px;
  }

  .featured-vehicle-preview-party strong{
    font-size:7.2px;
    margin-bottom:3px;
  }

  .featured-vehicle-preview-party small{
    font-size:7px;
  }

  .featured-vehicle-preview-section{
    font-size:7.4px;
    margin-bottom:6px;
  }

  .featured-vehicle-preview-line,
  .featured-vehicle-preview-grid span,
  .featured-vehicle-preview-row span{
    display:block;
    border-radius:10px;
    background:rgba(11,110,79,.10);
    color:rgba(17,17,16,.58);
    font-size:9px;
    font-weight:800;
    line-height:1.35;
    padding:8px 9px;
    filter:blur(.25px);
  }

  .featured-vehicle-preview-line{
    margin-bottom:7px;
  }

  .featured-vehicle-preview-line-strong{
    color:rgba(6,77,55,.72);
    background:rgba(11,110,79,.16);
  }

  .featured-vehicle-preview-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    margin:8px 0 0;
  }

  .featured-vehicle-preview-grid span{
    min-height:28px;
  }

  .featured-vehicle-preview-extra{
    display:block;
  }

  .featured-vehicle-preview-row,
  .featured-vehicle-preview-foot{
    display:none;
  }

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

  .value-panel{
    padding:22px;
    margin:10px 0 22px;
  }

  .value-panel-title{
    font-size:24px;
    max-width:520px;
  }

  .value-panel-copy{
    max-width:78ch;
    font-size:13px;
  }

  .value-flow-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }

  .value-flow-title{
    font-size:17px;
    margin-bottom:12px;
  }

  .value-flow-step{
    min-height:100%;
    padding:12px 13px;
  }

  .comparison-strip{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
  }

  .comparison-strip div{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:4px;
    padding:12px;
    border-radius:14px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.10);
  }

  .comparison-strip strong{
    text-align:left;
  }

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

  .home-actions{
    flex-direction:row;
  }

  .home-actions .btn{
    width:auto;
    min-width:280px;
  }

  .agreement-hero,
  .agreement-role-panel{
    padding:28px;
  }

  .agreement-hero h2{
    font-size:36px;
    max-width:16ch;
  }

  .agreement-prep-card{
    padding:18px;
  }

  .agreement-secondary-grid{
    grid-auto-flow:row;
    grid-auto-columns:auto;
    grid-template-columns:repeat(3,minmax(0,1fr));
    overflow:visible;
  }

  .agreement-list-compact{
    font-size:12.5px;
  }

  .subscription-grid,
  .form-grid-2{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
  }

  .manual-party-card,
  .billing-card,
  .summary-card,
  .audit-panel,
  .helper-card,
  .support-faq{
    box-shadow:0 14px 28px rgba(17,17,16,.04);
  }

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

  .complete-timeline-item{
    min-height:88px;
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
  }

  .complete-summary-card .ir-val{
    max-width:65%;
  }

  .btn-stack{
    flex-direction:row;
    flex-wrap:wrap;
  }

  .btn-stack .btn{
    width:auto;
    min-width:220px;
    flex:1 1 220px;
  }

  .nav{
    width:min(760px, calc(100% - 56px));
    max-width:760px;
    border:1px solid #D1E1D5;
    border-bottom:none;
    border-radius:22px 22px 0 0;
    box-shadow:0 -10px 28px rgba(17,17,16,.08);
    background:rgba(228,241,231,.96);
    backdrop-filter:blur(12px);
  }

  .nav-btn{
    padding:12px 8px 10px;
    font-size:11px;
  }
}
