.public-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#f7f9ff,#eef1fa)}.public-header{background:#fff;border-bottom:1px solid #e3e6ef}.public-header-inner{max-width:1200px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between}.public-brand{display:flex;align-items:center;gap:12px}.logo-text{font-weight:600;font-size:16px}.public-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:40px 24px}.hero{text-align:center;margin-bottom:32px}.hero h1{font-size:36px;margin:0 0 8px;color:#1a1f36}.hero p{color:#6a7088;font-size:16px;margin:0}.search-form{max-width:100%}.search-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.search-actions{display:flex;gap:12px;margin-top:20px}.autocomplete-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d8dce8;border-radius:6px;margin-top:4px;max-height:220px;overflow-y:auto;z-index:30;box-shadow:0 4px 12px #00000014;list-style:none;padding:4px 0}.autocomplete-list li{padding:8px 12px;cursor:pointer;font-size:14px}.autocomplete-list li:hover{background:#f0f3fb}.results-section{margin-top:32px}.results-title{font-size:18px;font-weight:600;margin-bottom:16px}.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.cert-card{background:#fff;border:1px solid #e3e6ef;border-radius:10px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 2px #00000008;transition:transform .15s,box-shadow .15s}.cert-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000000f}.cert-card-header{display:flex;justify-content:space-between;align-items:flex-start}.cert-card-body{display:flex;flex-direction:column;gap:6px}.cert-row{display:flex;justify-content:space-between;font-size:14px;padding:4px 0;border-bottom:1px dashed #eef0f6}.cert-row:last-child{border-bottom:none}.cert-card-actions{display:flex;gap:8px;margin-top:8px}.empty-state{text-align:center;padding:40px 20px}.empty-icon{font-size:40px;margin-bottom:12px}.public-footer{text-align:center;padding:20px;color:#6a7088;font-size:13px;border-top:1px solid #e3e6ef;background:#fff}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f8cff,#6c5ce7);padding:20px}.login-card{background:#fff;border-radius:12px;padding:36px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000026}.login-brand{text-align:center;margin-bottom:24px}.login-brand h1{margin:12px 0 4px;font-size:22px}.login-form .input{padding:11px 14px}.login-submit{width:100%;padding:12px;font-size:15px}.login-error{background:#ffe5ea;color:#b00020;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.login-footer{text-align:center;margin-top:16px;font-size:13px}.admin-shell{display:flex;min-height:100vh;background:#f4f6fa}.admin-sidebar{width:240px;background:#1a1f36;color:#fff;display:flex;flex-direction:column;transition:width .2s ease;flex-shrink:0}.admin-sidebar.collapsed{width:70px}.admin-brand{padding:20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #2a304a;cursor:pointer}.logo-mark{background:linear-gradient(135deg,#4f8cff,#6c5ce7);color:#fff;font-weight:700;padding:6px 10px;border-radius:6px;font-size:14px}.logo-text{font-size:15px;font-weight:600;white-space:nowrap}.admin-nav{display:flex;flex-direction:column;padding:12px 8px;gap:4px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:#c7cce0;text-decoration:none;font-size:14px;transition:background .15s,color .15s}.nav-item:hover{background:#232a48;color:#fff}.nav-item.active{background:linear-gradient(135deg,#4f8cff20,#6c5ce720);color:#fff;border-left:3px solid #4f8cff}.nav-icon{font-size:18px;width:24px;text-align:center}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}.admin-topbar{display:flex;align-items:center;gap:12px;background:#fff;padding:12px 24px;border-bottom:1px solid #e3e6ef;box-shadow:0 1px 3px #0000000a}.sidebar-toggle{background:transparent;border:1px solid #d8dce8;border-radius:6px;padding:6px 10px;cursor:pointer;font-size:16px}.topbar-title{flex:1;font-weight:600;color:#1a1f36}.topbar-user{display:flex;align-items:center;gap:12px}.user-email{font-size:13px;color:#5a6379}.admin-content{padding:24px;flex:1;overflow:auto}.upload-form{display:flex;flex-direction:column;gap:12px}.dropzone{border:2px dashed #b8c0d8;background:#f7f9fc;border-radius:10px;padding:32px;text-align:center;cursor:pointer;transition:border .15s,background .15s}.dropzone.over{border-color:#4f8cff;background:#eef4ff}.dropzone-icon{font-size:32px;margin-bottom:8px}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.template-card{background:#fff;border:1px solid #e3e6ef;border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.template-card.selected{border-color:#4f8cff;box-shadow:0 0 0 2px #4f8cff33}.template-thumb{position:relative;background:#f7f9fc;aspect-ratio:1.414;overflow:hidden;cursor:pointer}.template-thumb img{width:100%;height:100%;object-fit:contain}.selected-badge{position:absolute;top:8px;right:8px;background:#4f8cff;color:#fff;padding:3px 8px;border-radius:4px;font-size:12px;font-weight:600}.template-meta{padding:10px 12px}.template-actions{display:flex;gap:8px;padding:0 12px 12px}.field-designer{display:flex;flex-direction:column;gap:16px}.designer-toolbar{display:flex;justify-content:space-between;align-items:center}.designer-layout{display:grid;grid-template-columns:1fr;gap:16px}.designer-layout.has-sidebar{grid-template-columns:1fr 340px}@media (max-width: 1100px){.designer-layout.has-sidebar{grid-template-columns:1fr}}.designer-canvas{padding:12px}.canvas-inner{position:relative;background:#f7f9fc;margin:0 auto;max-width:100%;width:100%}.canvas-inner .template-bg{width:100%;height:auto;display:block;pointer-events:none;-webkit-user-select:none;user-select:none}.field-overlay{position:absolute;z-index:2;border:2px dashed transparent;cursor:move;box-sizing:border-box}.field-overlay:hover,.field-overlay.selected{border-color:#4f8cff}.field-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:4px;word-break:break-word;overflow:hidden;background:#4f8cff14;pointer-events:none}.field-preview.qr-preview{background:#ffffffeb}.qr-preview-image{display:block;width:100%;height:100%;object-fit:contain;background:#fff}.qr-placeholder{width:min(100%,72px);aspect-ratio:1;background:linear-gradient(90deg,#111 25%,transparent 25% 50%,#111 50% 75%,transparent 75%) 0 0 / 16px 16px,linear-gradient(#111 25%,transparent 25% 50%,#111 50% 75%,transparent 75%) 0 0 / 16px 16px,#fff;border:4px solid #fff;box-shadow:inset 0 0 0 2px #111}.field-resize-handle{position:absolute;right:-5px;bottom:-5px;width:12px;height:12px;background:#4f8cff;border:2px solid #fff;border-radius:2px;cursor:se-resize;z-index:3}.designer-sidebar{max-height:800px;overflow-y:auto}.grid-2{grid-template-columns:1fr 1fr}.check{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer}.verification-check{font-weight:500;color:#1a1f36}.divider{border:none;border-top:1px solid #e3e6ef;margin:12px 0}.data-input{display:flex;flex-direction:column;gap:16px}.mode-switcher{display:flex;gap:8px;margin-bottom:16px;background:#f0f2f7;padding:4px;border-radius:8px;width:fit-content}.mode-btn{padding:8px 18px;border:none;background:transparent;border-radius:6px;font-weight:500;cursor:pointer}.mode-btn.active{background:#fff;box-shadow:0 1px 2px #0000000d;color:#1a1f36}.upload-row{display:flex;gap:12px;align-items:center;margin-bottom:16px}.mapping-section{margin-top:12px}.mapping-grid{display:flex;flex-direction:column;gap:8px}.mapping-row{display:grid;grid-template-columns:220px 1fr;gap:12px;align-items:center;background:#f7f9fc;padding:10px 12px;border-radius:6px}.single-form{display:flex;flex-direction:column}.divider{border:none;border-top:1px solid #e3e6ef;margin:24px 0}.cert-name-section{background:#f7f9fc;padding:16px;border-radius:8px}.radio-group{display:flex;flex-direction:column;gap:8px}.radio{display:flex;align-items:center;gap:8px;cursor:pointer}.preview-grid{display:flex;flex-direction:column}.preview-cell{display:flex;flex-direction:column;align-items:center}.preview-card{position:relative;background:#fff;border:1px solid #e3e6ef;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000000f;margin:0 auto}.preview-canvas{position:relative;width:100%}.preview-img{width:100%;height:auto;display:block;pointer-events:none;-webkit-user-select:none;user-select:none}.preview-field{position:absolute;display:flex;align-items:center;padding:2px 4px;overflow:hidden;word-break:break-word;box-sizing:border-box}.preview-fixed-qr{position:absolute;display:block;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;background:#fff}.preview-label{margin-top:4px;text-align:center}.cert-generation{display:flex;flex-direction:column;gap:20px}.steps{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e3e6ef;border-radius:10px;padding:12px 16px;overflow-x:auto}.step{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px;color:#6a7088;font-size:14px;flex:1;min-width:130px;cursor:default}.step.active{color:#1a1f36}.step.active .step-num{background:linear-gradient(135deg,#4f8cff,#6c5ce7);color:#fff}.step-num{width:28px;height:28px;border-radius:50%;background:#eef0f6;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}.step-label{font-weight:500}.step-actions{display:flex;justify-content:space-between;gap:12px;padding-top:8px}.generation-result{text-align:center;padding:32px 0}.success-icon{width:64px;height:64px;border-radius:50%;background:#d1f7d6;color:#1a7d34;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 16px}.result-stats{display:flex;gap:20px;justify-content:center;margin:24px 0}.stat{background:#f7f9fc;padding:16px 24px;border-radius:8px}.stat-num{font-size:28px;font-weight:700;color:#4f8cff}🧱 Generation Sub-Components *{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;color:#1a1f36;background:#f4f6fa;-webkit-font-smoothing:antialiased}a{color:#4f8cff;text-decoration:none}button{font-family:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border-radius:6px;border:1px solid transparent;font-size:14px;font-weight:500;transition:background .15s,transform .05s;background:#f0f2f7;color:#1a1f36}.btn:hover{background:#e3e6ef}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,#4f8cff,#6c5ce7);color:#fff;border:none}.btn-primary:hover{filter:brightness(1.05);background:linear-gradient(135deg,#4f8cff,#6c5ce7)}.btn-secondary{background:#fff;border:1px solid #d8dce8}.btn-ghost{background:transparent;border:1px solid transparent}.btn-danger{background:#ff5470;color:#fff;border:none}.btn:disabled{opacity:.5;cursor:not-allowed}.input,.select,.textarea{width:100%;padding:9px 12px;border:1px solid #d8dce8;border-radius:6px;font-size:14px;background:#fff;outline:none;transition:border .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:#4f8cff;box-shadow:0 0 0 3px #4f8cff26}.textarea{min-height:80px;resize:vertical}.label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:#4a5170}.card{background:#fff;border-radius:10px;border:1px solid #e3e6ef;box-shadow:0 1px 2px #00000008;padding:20px;margin-bottom:20px}.card-title{font-size:16px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef0f6}.table th{background:#f7f9fc;color:#5a6379;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.table tbody tr:hover{background:#fafbff}.spinner{width:36px;height:36px;border:3px solid #e3e6ef;border-top-color:#4f8cff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge-success{background:#d1f7d6;color:#1a7d34}.badge-warning{background:#fff1c2;color:#946c00}.badge-danger{background:#ffd5dd;color:#b00020}.badge-info{background:#d3e7ff;color:#1c4e9a}.grid{display:grid;gap:16px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.text-muted{color:#6a7088;font-size:13px}.text-sm{font-size:13px}.text-lg{font-size:18px}.font-bold{font-weight:600}
