:root{--sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:"SFMono-Regular", Consolas, "Liberation Mono", Menlo, ui-monospace, monospace;color:#152033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fb}*{box-sizing:border-box}body{min-width:320px;font-family:var(--sans);margin:0}#root{min-height:100vh}.app-shell{color:#152033;background:linear-gradient(135deg,#1f559014,#0000 38%),linear-gradient(225deg,#d6635414,#0000 34%),#f5f7fb;min-height:100vh}.workspace{width:min(1480px,100% - 32px);margin:0 auto;padding:28px 0}.topbar{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:18px;display:flex}.topbar h1{color:#101827;margin:0;font-size:32px;font-weight:780;line-height:1.05}.topbar p,.panel-heading p,.preview-heading p,.field-section h3,.raw-notice,.print-note{color:#647084;margin:0}.topbar p{max-width:720px;margin-top:8px;font-size:15px}.top-actions,.payload-actions{flex-wrap:wrap;gap:10px;display:flex}button{color:#172033;min-height:38px;font:700 13px/1 var(--sans);cursor:pointer;background:#eef3f8;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 13px;display:inline-flex;box-shadow:inset 0 0 0 1px #d8e0eb}button:hover{background:#e4edf6}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #1771be38}.primary-button{color:#fff;background:#176f83;box-shadow:0 10px 24px #176f8338}.primary-button:hover{background:#0f6478}.secondary-button{background:#fff}.safety-banner{color:#594318;background:#fff8e8;border:1px solid #f1d795;border-radius:8px;align-items:center;gap:10px;margin-bottom:18px;padding:12px 14px;font-size:13px;display:flex}.builder-grid{grid-template-columns:minmax(520px,1.05fr) minmax(420px,.95fr);align-items:start;gap:16px;display:grid}.panel{background:#ffffffeb;border:1px solid #dce3ed;border-radius:8px;box-shadow:0 18px 45px #242d3f14}.form-panel,.raw-panel{padding:18px}.panel-heading,.preview-heading{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px;display:flex}.panel-heading h2,.preview-heading h2{color:#152033;margin:0;font-size:20px}.panel-heading p,.preview-heading p{margin-top:4px;font-size:13px}.state-picker{color:#566278;gap:6px;min-width:180px;font-size:12px;font-weight:700;display:grid}.state-picker select{min-height:36px}.field-section{border-top:1px solid #e5ebf2;padding-top:15px}.field-section+.field-section{margin-top:16px}.field-section h3{letter-spacing:0;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:800}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.field-control{gap:6px;display:grid}.field-control span{color:#39465a;justify-content:space-between;align-items:center;gap:10px;min-width:0;font-size:12px;font-weight:760;display:flex}.field-control small{color:#7d889a;font:700 11px/1 var(--mono)}input,select,textarea{box-sizing:border-box;color:#142033;width:100%;font:600 13px/1.25 var(--sans);background:#fff;border:1px solid #d5deea;border-radius:8px}input,select{min-height:38px;padding:0 10px}textarea{resize:vertical;min-height:280px;font:12px/1.42 var(--mono);white-space:pre;padding:12px}.mode-pill{color:#126b5e;background:#e7f5f3;border-radius:999px;flex:none;align-items:center;min-height:28px;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.mode-pill.raw{color:#3d4fa1;background:#eef0ff}.barcode-lab{background:#f8fafc;border:1px dashed #cbd6e4;border-radius:8px;margin-bottom:14px;padding:14px}.barcode-lab-header{color:#263447;align-items:center;gap:8px;margin-bottom:10px;font-size:13px;display:flex}.barcode-frame{background:#fff;border:1px solid #e0e7ef;border-radius:6px;padding:10px;overflow:auto}.barcode-frame canvas{max-width:100%;height:auto;image-rendering:pixelated;display:block}.barcode-frame.has-image canvas{display:none}.barcode-image{max-width:100%;height:auto;image-rendering:pixelated;display:block}.barcode-frame.print-sized{box-sizing:border-box;justify-content:center;align-items:center;width:70mm;height:19mm;padding:1.5mm;display:flex;overflow:hidden}.barcode-frame.print-sized canvas,.barcode-frame.print-sized .barcode-image{object-fit:contain;width:100%;max-height:100%}.barcode-error{color:#ad2d25;margin:10px 0 0;font-size:12px}.payload-editor{color:#39465a;gap:8px;font-size:12px;font-weight:760;display:grid}.payload-actions{margin-top:12px}.raw-notice{margin-top:10px;font-size:13px}.print-preview{width:min(1480px,100% - 32px);margin:0 auto;padding:0 0 40px}.preview-heading{align-items:center;margin:4px 0 14px}.preview-heading>span{color:#576277;background:#fff;border:1px solid #dce3ed;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:800}.a4-sheet{box-sizing:border-box;background:#fff;border:1px solid #dbe1ea;width:210mm;max-width:100%;min-height:297mm;margin:0 auto;padding:24mm 7mm;position:relative;overflow:hidden;box-shadow:0 25px 70px #242d3f29}.sheet-ruler{color:#8a95a7;font:700 10px/1 var(--mono);position:absolute}.sheet-ruler.horizontal{text-align:center;border-top:1px solid #c8d0dc;padding-top:3mm;top:8mm;left:16mm;right:16mm}.sheet-ruler.vertical{writing-mode:vertical-rl;border-right:1px solid #c8d0dc;padding-right:3mm;top:24mm;right:5mm}.card-row{grid-template-columns:repeat(2,max-content);justify-content:center;align-items:start;gap:5mm;display:grid}.card-label{color:#566278;font:800 11px/1 var(--sans);text-transform:uppercase;margin-bottom:3mm;display:block}.id-card{width:var(--printed-card-width);height:var(--printed-card-height);box-sizing:border-box;background:var(--state-card-bg);color:#142033;box-shadow:none;border:.35mm solid #202a39;border-radius:3.18mm;position:relative;overflow:hidden}.card-header{height:var(--state-header-height);box-sizing:border-box;background:var(--state-primary);color:#fff;justify-content:space-between;align-items:center;padding:2.6mm 3.2mm;display:flex}.card-header strong{font-size:var(--state-header-title-size);line-height:1;display:block}.card-header span{opacity:.82;margin-top:1mm;font-size:1.9mm;display:block}.card-header b{border:.3mm solid #ffffffc7;border-radius:1.4mm;place-items:center;width:9mm;height:7mm;font-size:3.2mm;display:grid}.abstract-watermark,.back-watermark{pointer-events:none;color:var(--state-primary);opacity:.12;position:absolute}.abstract-watermark{place-items:center;width:40mm;height:25mm;display:grid;inset:13.5mm 16mm auto auto}.state-visual-icon,.abstract-watermark svg{width:24mm;height:24mm}.watermark-code{font:900 9mm/1 var(--sans);letter-spacing:0;position:absolute;bottom:2mm;right:2mm}.watermark-signature{color:currentColor;max-width:22mm;font:900 1.65mm/1 var(--sans);letter-spacing:.04em;text-transform:uppercase;position:absolute;bottom:1.6mm;left:1.4mm}.watermark-ring{border:.35mm solid;border-radius:999px;position:absolute}.ring-one{width:26mm;height:13mm;transform:rotate(-18deg)}.ring-two{width:17mm;height:8mm;transform:rotate(24deg)}.state-ribbon{z-index:1;height:6.2mm;color:var(--state-primary);opacity:.22;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.ribbon-layer,.ribbon-signature{pointer-events:none;position:absolute}.ribbon-layer{height:100%;bottom:0}.ribbon-primary{background:var(--state-secondary);width:52%;left:0}.ribbon-secondary{background:var(--state-primary);width:34%;left:41%}.ribbon-accent{background:var(--state-accent);width:31%;right:0}.ribbon-signature{color:#142033;font:900 1.65mm/1 var(--sans);letter-spacing:.06em;text-transform:uppercase;opacity:.72;bottom:1.4mm;right:4mm}.pattern-peaks .ribbon-primary{border-radius:0 8mm 0 0;height:72%}.pattern-peaks .ribbon-secondary{border-radius:8mm 8mm 0 0;height:92%}.pattern-desert .ribbon-primary,.pattern-fields .ribbon-primary,.pattern-plains .ribbon-primary{height:34%}.pattern-desert .ribbon-secondary{border-radius:999px;width:11mm;height:11mm;bottom:2.3mm;left:18%}.pattern-coast .ribbon-primary,.pattern-waves .ribbon-primary,.pattern-island .ribbon-primary,.pattern-river .ribbon-primary{border-radius:0 9mm 0 0;height:58%}.pattern-coast .ribbon-secondary,.pattern-waves .ribbon-secondary,.pattern-island .ribbon-secondary,.pattern-river .ribbon-secondary{border-radius:9mm 0 0;height:42%}.pattern-forest .ribbon-primary{width:36%}.pattern-forest .ribbon-secondary{width:24%;left:28%}.pattern-forest .ribbon-accent{width:18%}.pattern-city .ribbon-primary{height:62%}.pattern-city .ribbon-secondary{width:8mm;height:100%}.pattern-city .ribbon-accent{width:6mm;height:78%}.pattern-stars .ribbon-primary{width:64%}.pattern-stars .ribbon-secondary{border-radius:999px;width:7mm;height:7mm;left:8mm}.pattern-arch .ribbon-secondary{border:1.2mm solid var(--state-primary);background:0 0;border-bottom:0;border-radius:9mm 9mm 0 0;width:14mm;height:12mm;bottom:-5.5mm;left:45%}.seal-placeholder{z-index:2;border:.35mm solid var(--state-accent);width:11mm;height:11mm;color:var(--state-accent);background:#ffffffb8;border-radius:999px;place-items:center;display:grid;position:absolute;bottom:8.5mm;right:17mm}.seal-placeholder svg{width:5.5mm;height:5.5mm}.seal-placeholder span{font:900 1.7mm/1 var(--sans);position:absolute;bottom:1.2mm}.security-patch{z-index:4;box-sizing:border-box;color:#38536f;background:#e9eef8;border:.3mm solid #aab6c8;border-radius:.8mm;place-items:center;width:10.5mm;height:7.2mm;display:grid;position:absolute;top:2.25mm;right:14.2mm;overflow:hidden}.security-patch svg,.security-patch b{z-index:2;position:relative}.security-patch svg{width:3.2mm;height:3.2mm}.security-patch b{font:900 1.35mm/1 var(--sans);margin-top:-.7mm}.patch-stripe{position:absolute;inset:0}.patch-a{clip-path:polygon(0 0,62% 0,35% 100%,0 100%);background:#7cc8d8}.patch-b{clip-path:polygon(48% 0,100% 0,100% 100%,28% 100%);background:#d9a1ce}.patch-c{clip-path:polygon(0 68%,100% 26%,100% 48%,0 90%);background:#e6d782}.front-body{z-index:2;grid-template-columns:var(--state-portrait-width) 1fr;gap:var(--state-field-gap);padding:3mm 3mm 0;display:grid;position:relative}.portrait-box{height:var(--state-portrait-height);background:#dfe6ee;border:.35mm solid #b8c4d2;align-content:center;place-items:center;gap:.6mm;display:grid}.portrait-box>span{color:#4e5b6e;font-size:1.8mm;font-weight:900}.cartoon-portrait{width:min(15mm, calc(var(--state-portrait-width) - 4mm));height:calc(var(--state-portrait-height) - 7mm);min-height:17mm;position:relative}.avatar-head{background:#eeaa76;border-radius:42% 42% 48% 48%;width:8.8mm;height:10mm;position:absolute;top:.7mm;left:50%;transform:translate(-50%)}.avatar-hair{background:#5b331d;border-radius:4mm 4mm 1.5mm 1.5mm;height:3.2mm;position:absolute;inset:-.1mm .2mm auto}.avatar-ear{background:#eeaa76;border-radius:999px;width:1.3mm;height:2.8mm;position:absolute;top:4.1mm}.avatar-ear.left{left:-.8mm}.avatar-ear.right{right:-.8mm}.avatar-jacket{background:#1f4a54;border-radius:2mm 2mm .6mm .6mm;width:14mm;height:8mm;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.avatar-shirt{clip-path:polygon(0 0,100% 0,78% 100%,22% 100%);background:#f7f8f8;width:4.8mm;height:8mm;position:absolute;top:0;left:50%;transform:translate(-50%)}.avatar-tie{clip-path:polygon(50% 0,100% 28%,70% 100%,30% 100%,0 28%);background:#bb2630;width:2mm;height:6.3mm;position:absolute;top:1.2mm;left:50%;transform:translate(-50%)}.front-fields{z-index:2;gap:var(--state-field-gap);min-width:0;display:grid;position:relative}.front-fields p,.mini-grid p{color:#142033;min-width:0;font-size:var(--state-main-field-size);overflow-wrap:anywhere;margin:0;font-weight:850;line-height:1.02}.front-fields span,.mini-grid span{min-width:var(--state-label-width);color:#596376;vertical-align:middle;font-size:1.7mm;font-weight:900;display:inline-block}.mini-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.1mm 2mm;display:grid}.mini-grid p{font-size:var(--state-mini-field-size)}.front-fields address{color:#273448;font-size:var(--state-address-field-size);margin-top:.8mm;font-style:normal;font-weight:700;line-height:1.15}.signature-strip{z-index:3;color:#253344;border-top:.25mm solid #4b5361;min-width:24mm;padding-top:.8mm;position:absolute;bottom:3.4mm;left:4mm;transform:rotate(-4deg)}.signature-strip span{letter-spacing:0;font:500 3mm/1.05 Bradley Hand,Segoe Script,cursive}.id-card footer{min-height:4mm;color:var(--state-accent);letter-spacing:0;border-top:.25mm solid #d8dee8;justify-content:center;align-items:center;font-size:2mm;font-weight:900;display:flex;position:absolute;bottom:1.8mm;left:3mm;right:3mm}.mag-strip{height:var(--state-mag-strip-height);background:#222936;margin-top:3.6mm}.back-copy{z-index:2;gap:.7mm;padding:2.2mm 5mm 1.2mm;display:grid;position:relative}.back-watermark{z-index:1;place-items:center;width:30mm;height:24mm;display:grid;bottom:7mm;right:13mm}.back-watermark svg{width:21mm;height:21mm}.back-watermark span{font:900 7mm/1 var(--sans);position:absolute}.front-classic-left .front-body{grid-template-columns:var(--state-portrait-width) 1fr}.front-center-stack .card-header{height:10mm}.front-center-stack .front-body{grid-template-columns:var(--state-portrait-width) 1fr;gap:2.2mm}.front-center-stack .front-fields>p:first-child,.front-center-stack .front-fields>p:nth-child(2){font-size:var(--state-feature-field-size)}.front-right-portrait .front-body{grid-template-columns:1fr var(--state-portrait-width)}.front-right-portrait .portrait-box{grid-area:1/2}.front-right-portrait .front-fields{grid-area:1/1}.front-top-band-grid .card-header{height:9.5mm}.front-top-band-grid .front-body{grid-template-columns:var(--state-portrait-width) 1fr;gap:var(--state-field-gap);padding-top:2mm}.front-top-band-grid .portrait-box{height:var(--state-portrait-height)}.front-vertical-minor:before{content:"DL";width:var(--state-vertical-band-width);color:var(--state-accent);writing-mode:vertical-rl;font:900 3mm/1 var(--sans);background:#eef2f6;place-items:center;display:grid;position:absolute;top:12mm;bottom:0;left:0}.front-vertical-minor .card-header,.front-vertical-minor .front-body,.front-vertical-minor footer{margin-left:var(--state-vertical-band-width)}.front-vertical-minor .front-body{grid-template-columns:var(--state-portrait-width) 1fr;gap:2mm}.density-dense .front-fields{gap:.85mm}.density-dense .front-fields p{font-size:var(--state-main-field-size)}.density-dense .mini-grid p{font-size:var(--state-mini-field-size)}.density-extra-dense .front-fields{gap:.55mm}.density-extra-dense .front-fields p{font-size:var(--state-main-field-size)}.density-extra-dense .mini-grid{gap:.75mm 1.2mm}.density-extra-dense .mini-grid p,.density-extra-dense address{font-size:var(--state-mini-field-size)}.back-copy strong{font-size:3mm}.back-copy span{color:#5f6b7c;font-size:2.1mm;font-weight:750}.back-card .barcode-frame{z-index:2;margin:var(--state-barcode-top) auto 0;position:relative}.back-card .barcode-frame.print-sized{width:var(--state-barcode-width);height:var(--state-barcode-height)}.back-lower-wide .barcode-frame{margin-top:var(--state-barcode-top)}.back-upper-wide .mag-strip{height:6mm;margin-top:2.2mm}.back-upper-wide .back-copy{padding-top:1.5mm}.back-left-stack .barcode-frame{margin-left:var(--state-barcode-side-offset);margin-right:auto}.back-right-stack .barcode-frame{margin-left:auto;margin-right:var(--state-barcode-side-offset)}.back-left-stack .back-copy,.back-right-stack .back-copy{padding-bottom:1mm}.back-card footer{min-height:3.4mm;font-size:1.8mm;bottom:1mm}.print-note{text-align:center;margin-top:18mm;font-size:12px}@media (width<=1120px){.topbar,.panel-heading,.preview-heading{flex-direction:column}.builder-grid,.form-grid{grid-template-columns:1fr}.a4-sheet{transform-origin:top}}@media print{@page{size:A4 portrait;margin:5mm}body{background:#fff}.app-shell{background:#fff!important}.workspace,.preview-heading,.sheet-ruler,.print-note{display:none!important}.print-preview{width:auto;padding:0}.a4-sheet{width:auto;min-height:auto;box-shadow:none;border:0;margin:0;padding:8mm 0 0;overflow:visible}.id-card{box-shadow:none;-webkit-print-color-adjust:exact;print-color-adjust:exact}.card-row{grid-template-columns:repeat(2, var(--printed-card-width));gap:3mm}.barcode-frame{box-shadow:none!important}.barcode-image{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
