:root{--blue-900:#0d2f5f;--blue-800:#0d47a1;--blue-700:#1565c0;--yellow:#f2c230;--yellow-soft:#fff6d7;--text:#344054;--text-muted:#667085;--text-h:#101828;--bg:#f5f7fb;--surface:#fff;--surface-soft:#f8fafc;--border:#d9e2ef;--danger:#d32f2f;--success:#2e7d32;--shadow:0 14px 34px #0d47a11a;--shadow-soft:0 6px 18px #0f172a14;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/1.45 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}body{background:linear-gradient(#ffffffe0,#f5f7fbeb),radial-gradient(circle at 16% 18%,#f2c23029,#0000 28%),radial-gradient(circle at 90% 8%,#1565c01f,#0000 30%);min-width:320px;min-height:100vh;margin:0}#root{width:100%;min-height:100vh}h1,h2,h3,h4{color:var(--text-h);margin:0}h2{font-size:clamp(24px,3vw,34px);font-weight:750;line-height:1.08}p{margin:0}button,input,select{font:inherit}input,select{border:1px solid var(--border);width:100%;min-height:42px;color:var(--text-h);background:#fff;border-radius:8px;outline:none;padding:9px 11px;transition:border-color .18s,box-shadow .18s}input:focus,select:focus{border-color:var(--blue-700);box-shadow:0 0 0 3px #1565c024}button{cursor:pointer;border:none;border-radius:8px;transition:transform .16s,box-shadow .16s,background .16s}button:hover{transform:translateY(-1px)}button:focus-visible{outline-offset:2px;outline:3px solid #f2c2308c}.app-shell{min-height:100vh}.app-header{z-index:20;border-bottom:4px solid var(--yellow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff5;grid-template-columns:minmax(180px,1fr) auto minmax(180px,1fr);align-items:center;gap:24px;width:100%;min-height:88px;padding:14px 40px;display:grid;position:fixed;top:0;left:0;box-shadow:0 6px 20px #0d47a114}.app-header__logo-slot{min-width:0;display:flex}.app-header__logo-slot--left{justify-content:flex-start;align-items:center}.app-header__logo-slot--right{flex-direction:column;justify-content:flex-start;align-items:flex-end;gap:8px}.app-header__logo{object-fit:contain;display:block}.app-header__logo--primary{max-width:210px;height:54px}.app-header__logo--secondary{max-width:230px;height:50px}.app-header__text{text-align:center;justify-self:center;min-width:300px}.app-header__eyebrow{color:var(--blue-700);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:800}.app-header__title{color:var(--blue-900);font-size:24px;font-weight:800;line-height:1.1}.app-header__home{background:var(--blue-800);color:#fff;border-radius:8px;min-height:30px;padding:5px 14px;font-size:13px;font-weight:800;box-shadow:0 8px 18px #0d47a129}.app-header__home:hover{background:var(--blue-700)}.app-main{width:100%;min-height:100vh;padding:126px 24px 42px}.app-card{width:min(760px,100%);box-shadow:var(--shadow);background:#fffffff5;border:1px solid #d9e2efe6;border-radius:12px;margin:0 auto;padding:28px}.app-card--wide{width:min(980px,100%)}.app-section-title{text-align:center;color:var(--blue-900);margin-bottom:22px}.app-subtitle{color:var(--text-muted);text-align:center;max-width:620px;margin:-10px auto 22px}.app-button{background:var(--blue-800);color:#fff;justify-content:center;align-items:center;min-height:42px;padding:10px 18px;font-weight:700;display:inline-flex;box-shadow:0 10px 22px #0d47a12e}.app-button:hover{background:var(--blue-700)}.app-button--full{width:100%}.app-button--success{background:var(--success);box-shadow:0 10px 22px #2e7d3229}.app-button--success:hover{background:#256b2b}.app-button--danger{background:var(--danger);box-shadow:0 10px 22px #d32f2f29}.form-grid{gap:12px;display:grid}.app-card>.form-group,.app-card>.app-button{margin-bottom:12px}.form-group{gap:6px;display:grid}.form-label{color:var(--blue-900);font-size:14px;font-weight:700}.form-error{color:var(--danger);font-size:12px}.bridge-list{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;display:grid}.bridge-type-button{text-align:left;border:1px solid var(--border);min-height:74px;color:var(--text);box-shadow:var(--shadow-soft);background:#fff;padding:14px 16px}.bridge-type-button:hover{border-color:var(--blue-700);box-shadow:0 12px 28px #0d47a124}.bridge-type-button__code{color:var(--blue-800);margin-bottom:4px;font-weight:850;display:block}.bridge-type-button__description{color:var(--text-muted);font-size:14px;line-height:1.3;display:block}.summary-card{background:var(--surface-soft);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-soft);border-radius:10px;margin:0 0 22px;padding:18px}.summary-card__title{text-align:center;color:var(--blue-900);margin-bottom:14px}.summary-card__grid{gap:7px;display:grid}.summary-card strong{color:var(--text-h)}.loading-state{min-height:220px;color:var(--text);justify-content:center;align-items:center;gap:16px;padding:32px 20px;display:flex}.loading-state--compact{border:1px solid var(--border);background:var(--yellow-soft);border-radius:8px;max-width:460px;min-height:auto;margin:0 auto 18px;padding:10px 12px}.loading-state__spinner{border:3px solid #0d47a129;border-top-color:var(--blue-800);border-radius:50%;flex:none;width:28px;height:28px;animation:.85s linear infinite keyplan-spin}.loading-state__title{color:var(--text-h);font-weight:700;line-height:1.2}.loading-state__message{color:var(--text-muted);margin-top:4px;font-size:14px}.loading-state__dots{vertical-align:middle;gap:3px;margin-left:4px;display:inline-flex}.loading-state__dots span{background:var(--yellow);border-radius:50%;width:4px;height:4px;animation:1.05s ease-in-out infinite keyplan-pulse}.loading-state__dots span:nth-child(2){animation-delay:.15s}.loading-state__dots span:nth-child(3){animation-delay:.3s}@keyframes keyplan-spin{to{transform:rotate(360deg)}}@keyframes keyplan-pulse{0%,80%,to{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}@media (width<=720px){.app-header{grid-template-columns:1fr auto;align-items:flex-start;min-height:106px;padding:14px 18px}.app-header__logo--primary{max-width:140px;height:42px}.app-header__logo--secondary{max-width:120px;height:36px}.app-header__text{width:calc(100% - 36px);min-width:0;position:absolute;top:58px;left:50%;transform:translate(-50%)}.app-header__eyebrow{font-size:10px}.app-header__title{font-size:18px}.app-header__home{min-height:28px;padding:4px 12px;font-size:12px}.app-main{padding:138px 14px 28px}.app-card{padding:18px}}
