@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700;800;900&family=DM+Sans:wght@300;400;500;600;700;800&family=Montserrat:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--bg2:#f4f4f5;--bg3:#fcfcfc;--surface:#f9e9a9;--surface-2:#f7eab1;--surface-3:#eed996;--accent:#937c38;--accent-h:#9b7641;--accent-g:linear-gradient(135deg, #e4c26d 0%, #c8a559 45%, #9b7641 100%);--border:#22363024;--border-strong:#22363047;--text:#223630;--text-muted:#5f665f;--error:#9d4251;--white:#fff;--radius:18px;--shadow:0 24px 64px #2236301f;--shadow-soft:0 18px 40px #22363014;--charcoal:#313b44;--graphite:#223630;--stone:#858273;--ochre:#b18d47;--mist:#f4f4f5}html,body,#root{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Sans,sans-serif}body{background:linear-gradient(180deg, #fcfcfcb8 0%, #f9e9a929 26%, #d9d6d1eb 100%), var(--bg)}.app-bg{background:radial-gradient(circle at top left, #e4c26d29, transparent 24%), radial-gradient(circle at bottom right, #99874414, transparent 22%), var(--bg);flex-direction:column;min-height:100vh;display:flex}.site-header{border-bottom:1px solid var(--border-strong);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#fefeffd9;padding:20px 32px;position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;display:flex}.header-signout{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#2236300d;border-radius:99px;align-items:center;gap:10px;padding:10px 18px;font-family:Montserrat,sans-serif;font-size:.88rem;font-weight:700;text-decoration:none;transition:all .2s;display:flex}.header-signout:hover{background:var(--accent-g);border-color:#9b76414d;transform:translateY(-1px);box-shadow:0 8px 20px #9b764126}.header-signout svg{opacity:.7;transition:transform .2s}.header-signout:hover svg{opacity:1;transform:translate(2px)}.logo-text{color:var(--graphite);letter-spacing:.02em;text-transform:uppercase;font-family:Montserrat,sans-serif;font-size:1.5rem;font-weight:800}.logo-accent{color:var(--accent)}.main-content{flex:1;padding:40px 24px 60px}.main-content.centered{justify-content:center;align-items:center;display:flex}.card{border:1px solid var(--border-strong);border-radius:var(--radius);width:100%;max-width:500px;box-shadow:var(--shadow);background:linear-gradient(#fcfcfcfa 0%,#f4f4f5f0 100%);padding:48px 40px;animation:.35s slideUp;position:relative;overflow:hidden}.card:before{content:"";background:var(--accent-g);width:100%;height:6px;position:absolute;inset:0 auto auto 0}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.card-icon{text-align:center;margin-bottom:16px;font-size:2.4rem}.card-title{text-align:center;color:var(--graphite);letter-spacing:-.03em;margin-bottom:10px;font-family:Montserrat,sans-serif;font-size:1.9rem;font-weight:800}.card-subtitle{text-align:center;color:var(--text-muted);margin-bottom:32px;font-size:.95rem;line-height:1.6}.card-subtitle strong{color:var(--graphite)}.field{margin-bottom:24px}.field label{letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-bottom:8px;font-size:.82rem;font-weight:700;display:block}.field input{width:100%;color:var(--text);background:#ffffffd9;border:1px solid #22363029;border-radius:12px;outline:none;padding:14px 16px;font-family:DM Sans,sans-serif;font-size:1rem;transition:border-color .2s,box-shadow .2s}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e4c26d47}.field input::placeholder{color:var(--text-muted)}.field input:disabled{opacity:.5;cursor:not-allowed}.otp-input{letter-spacing:.35em;text-align:center;font-weight:600;padding:18px 16px!important;font-size:2.2rem!important}.btn-primary{background:var(--accent-g);width:100%;color:var(--graphite);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:52px;padding:15px;font-family:Montserrat,sans-serif;font-size:1rem;font-weight:800;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;box-shadow:0 14px 30px #9b76413d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 34px #9b76414d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-bottom:20px;padding:0;font-size:.85rem;transition:color .2s}.btn-back:hover{color:var(--text)}.btn-link{color:var(--accent-h);cursor:pointer;background:0 0;border:none;padding:0;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;transition:color .2s}.btn-link:hover{color:var(--white)}.btn-link:disabled{opacity:.5;cursor:not-allowed}.resend-row{text-align:center;margin-top:20px}.resend-timer{color:var(--text-muted);font-size:.88rem}.error-msg{color:var(--error);text-align:center;background:#e05c6b1a;border:1px solid #e05c6b33;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:.88rem}.warn-msg{color:#7b5d24;background:#f9e9a97a;border:1px solid #b18d4742;border-radius:8px;margin-bottom:20px;padding:12px 16px;font-size:.88rem;line-height:1.6}.warn-msg code{background:#ffffffb3;border-radius:4px;padding:1px 5px;font-size:.82rem}.error-card{max-width:480px;margin:0 auto}.spinner{border:2.5px solid #22363033;border-top-color:var(--graphite);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.spinner.large{border-width:4px;width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.centered-spinner{flex-direction:column;align-items:center;gap:20px;padding-top:80px;display:flex}.loading-text{color:var(--text-muted);font-size:.95rem}.cert-wrapper{width:100%;max-width:100%;margin:0 auto;animation:.4s slideUp}.cert-header{text-align:center;margin-bottom:28px;padding:18px 0 4px}.cert-congrats{color:var(--graphite);letter-spacing:-.04em;margin-bottom:8px;font-family:Montserrat,sans-serif;font-size:2rem;font-weight:800}.cert-subtitle{color:var(--text-muted);font-size:1rem}.cert-image-container{border-radius:var(--radius);border:1px solid var(--border-strong);max-width:100%;margin-bottom:28px;overflow:hidden;box-shadow:0 32px 80px #22363024}.cert-renderer-container{aspect-ratio:1472/1040;background:#ffffffbd;width:100%;max-width:1000px;margin-inline:auto}.cert-image{width:100%;max-width:100%;height:auto;display:block}.cert-debug{border:1px solid var(--border);background:#fcfcfceb;border-radius:12px;max-width:1000px;margin:0 auto 28px;padding:16px 18px}.cert-debug summary{cursor:pointer;color:var(--graphite);font-weight:700}.cert-debug-grid{gap:10px;margin-top:14px;display:grid}.cert-debug-line{color:var(--charcoal);white-space:pre-wrap;word-break:break-word;background:#f4f4f5eb;border-radius:10px;margin:0;padding:12px;font-size:.82rem}.cert-verify-card{max-width:1000px;box-shadow:var(--shadow-soft);background:linear-gradient(#f9e9a9d1 0%,#f4f4f5f5 100%);border:1px solid #b18d4742;border-radius:20px;max-width:100%;margin:0 auto 28px;padding:26px 28px}.cert-verify-title{color:var(--graphite);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;font-family:Montserrat,sans-serif;font-size:1.35rem}.cert-verify-grid{gap:12px;display:grid}.cert-verify-row{border-bottom:1px solid #22363014;justify-content:space-between;gap:16px;padding:12px 0;display:flex}.cert-verify-row span{color:var(--text-muted);min-width:0}.cert-verify-row strong{color:var(--graphite);text-align:right;word-break:break-word;overflow-wrap:anywhere;min-width:0;max-width:100%}.cert-verify-multi{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.cert-actions{flex-direction:column;gap:16px;max-width:100%;margin:0 auto;display:flex}.cert-link-box{border:1px solid var(--border);box-shadow:var(--shadow-soft);background:#fcfcfce6;border-radius:16px;max-width:100%;padding:18px 20px}.cert-link-label{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;font-size:.78rem;font-weight:600;display:block}.cert-link-row{align-items:center;gap:12px;max-width:100%;display:flex}.cert-link-url{color:var(--accent-h);word-break:break-all;overflow-wrap:anywhere;flex:1;max-width:100%;font-family:DM Sans,monospace;font-size:.88rem}.btn-copy{border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;background:#f9e9a966;border-radius:8px;flex-shrink:0;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;transition:background .2s,border-color .2s}.btn-copy:hover{background:var(--graphite);border-color:var(--graphite);color:var(--surface)}.btn-download{border:1px solid var(--border-strong);color:var(--graphite);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;text-align:center;background:#f4f4f5eb;border-radius:12px;padding:15px;font-family:Montserrat,sans-serif;font-size:1rem;font-weight:800;transition:background .2s,color .2s,transform .15s}.btn-download:hover{background:var(--accent-g);color:var(--graphite);transform:translateY(-1px)}@media (width<=600px){.card{padding:36px 24px}.card-title{font-size:1.5rem}.cert-congrats{font-size:1.4rem}.cert-link-row{flex-direction:column;align-items:flex-start}}@media (width<=768px){.main-content{padding:24px 14px 40px;overflow-x:hidden}.cert-wrapper{width:100%;max-width:100%;overflow-x:hidden}.cert-header{margin-bottom:20px;padding-top:8px}.cert-congrats{font-size:1.55rem;line-height:1.2}.cert-subtitle{font-size:.95rem}.cert-image-container,.cert-renderer-container,.cert-debug,.cert-verify-card,.cert-actions,.cert-link-box{width:100%;max-width:100%}.cert-renderer-container{min-width:0}.cert-debug{padding:14px}.cert-verify-card{border-radius:18px;padding:18px 16px}.cert-verify-title{margin-bottom:12px;font-size:1.05rem;line-height:1.25}.cert-verify-row{flex-direction:column;align-items:flex-start;gap:8px;padding:14px 0}.cert-verify-row strong{text-align:left}.cert-verify-multi{align-items:flex-start;width:100%}.cert-link-box{padding:16px}.cert-link-row{flex-direction:column;align-items:stretch;gap:10px}.cert-link-url{word-break:break-word;width:100%;font-size:.82rem}.btn-copy,.btn-download{width:100%;min-height:48px}}.designer-shell{background:radial-gradient(circle at 0 0,#e4c26d2e,#0000 26%),radial-gradient(circle at 100% 100%,#99874414,#0000 24%),#fff;min-height:100vh;padding:32px 24px 48px}.designer-page{flex-direction:column;gap:20px;width:min(1520px,100%);margin:0 auto;display:flex}.designer-header{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fcfcfcdb;border:1px solid #2236301f;border-radius:24px;justify-content:space-between;align-items:flex-start;gap:20px;padding:28px 30px;display:flex;box-shadow:0 22px 60px #2236301a}.designer-kicker{color:var(--stone);letter-spacing:.22em;text-transform:uppercase;margin-bottom:8px;font-size:.74rem;font-weight:700}.designer-header h1,.designer-sidebar-card h2,.designer-panel-head h2,.designer-guard-card h1{letter-spacing:-.03em;font-family:Playfair Display,serif}.designer-header h1{color:var(--graphite);margin-bottom:10px;font-size:clamp(2.2rem,3vw,3.2rem)}.designer-subtitle{max-width:720px;color:var(--text-muted);line-height:1.7}.designer-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.designer-close-btn{width:46px;height:46px;color:var(--text-muted);cursor:pointer;background:#2236300a;border:1px solid #2236301a;border-radius:50%;justify-content:center;align-items:center;margin-left:8px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.designer-close-btn:hover{color:var(--error);background:#fdf2f4;border-color:#9d425133;transform:rotate(90deg)scale(1.1);box-shadow:0 8px 20px #9d42511f}.designer-btn{min-height:46px;color:var(--text);letter-spacing:.03em;cursor:pointer;background:#ffffffbd;border:1px solid #22363024;border-radius:999px;padding:0 18px;font-family:Montserrat,sans-serif;font-weight:700;transition:transform .18s,background .18s,border-color .18s}.designer-btn:hover:not(:disabled){background:#f9e9a98a;border-color:#9b764161;transform:translateY(-1px)}.designer-btn.primary{background:var(--accent-g);color:var(--graphite);border-color:#9b764175}.designer-btn.ghost{background:0 0}.designer-btn:disabled{opacity:.55;cursor:not-allowed}.designer-status{border:1px solid #2236301f;border-radius:16px;padding:14px 18px;font-size:.95rem;line-height:1.6}.designer-status.info{color:var(--charcoal);background:#fcfcfcbd}.designer-status.success{color:#6c5921;background:#f9e9a999}.designer-status.error{color:#7f2335;background:#9d42511f}.designer-grid{align-items:start;gap:20px;display:flex}.designer-stage-panel,.designer-sidebar-card,.designer-guard-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fcfcfce0;border:1px solid #2236301f;border-radius:24px;box-shadow:0 24px 70px #2236301a}.designer-stage-panel,.designer-sidebar-card{padding:22px}.designer-stage-panel{flex:1;min-width:0}.designer-sidebar{flex-direction:column;flex-shrink:0;gap:20px;width:400px;display:flex}.designer-panel-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.designer-panel-head.tight{margin-bottom:16px}.designer-panel-head h2{margin-bottom:6px;font-size:1.42rem}.designer-panel-head p,.designer-stage-meta,.designer-guard-meta{color:var(--text-muted);font-size:.92rem;line-height:1.6}.designer-stage-meta{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.designer-sample-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:20px;display:grid}.designer-stage-viewport{justify-content:center;align-items:center;width:100%;min-height:max(500px,100vh - 340px);display:flex;position:relative;overflow:auto}.designer-stage{background:#ffffffb8;border:1px solid #2236301f;border-radius:22px;max-width:100%;position:relative;overflow:hidden;box-shadow:0 20px 50px #2236301f}.designer-canvas-stack{border-radius:22px;flex:none;position:relative;overflow:hidden;box-shadow:0 20px 50px #2236301f}.designer-canvas-stack-main{aspect-ratio:1472/1040;background:#ffffffb8;width:100%;max-width:1000px}.designer-renderer-canvas{width:100%;height:100%;display:block}.designer-renderer{background:#fffc;border-radius:22px;width:100%;position:relative;overflow:hidden}.designer-renderer-image{width:100%;height:auto;display:block}.designer-renderer-text{pointer-events:none;z-index:1;white-space:normal;word-break:normal;overflow-wrap:break-word;position:absolute}.designer-renderer-line{align-items:center;width:100%;display:flex}.designer-renderer-qr{z-index:1;display:block;position:absolute}.designer-overlay-layer{z-index:2;position:absolute;inset:0}.designer-stage-image{object-fit:fill;width:100%;height:100%;display:block;position:absolute;inset:0}.designer-rnd{border:1px dashed #22363042;transition:box-shadow .18s,border-color .18s}.designer-static-overlay{border:1px dashed #22363042;position:absolute}.designer-static-overlay.selected,.designer-rnd.selected{border-color:#9b7641f2;box-shadow:0 0 0 2px #e4c26d59}.designer-overlay-button{cursor:move;background:0 0;border:0;width:100%;height:100%;padding:0;display:block;position:relative}.designer-overlay-handle{border:1px dashed #22363042;border-radius:8px}.designer-overlay-label{color:var(--surface);text-align:left;pointer-events:none;background:#223630eb;border:1px solid #e4c26d47;border-radius:12px;flex-direction:column;gap:2px;padding:8px 10px;font-size:.8rem;display:inline-flex;position:absolute;top:-34px;left:0}.designer-overlay-label small{color:#f9e9a9bd;font-size:.7rem}.designer-text-frame,.designer-qr-frame{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.designer-text-frame{background:#f9e9a942;border-radius:8px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #22363014}.designer-text-lines{position:absolute;inset-inline:0}.designer-text-line{align-items:center;width:100%;display:flex}.designer-signature-line{opacity:.4;height:2px;position:absolute;bottom:5px;left:10px;right:10px}.designer-qr-frame{background:#f9e9a947;border-radius:8px;padding:10px}.designer-qr-preview{object-fit:contain;background:#fff;width:100%;height:100%;padding:4px;display:block}.designer-qr-fallback{color:#111827;background:#ffffffd9;border-radius:8px;place-items:center;width:100%;height:100%;font-weight:700;display:grid}.designer-field-list{gap:10px;display:grid}.designer-field-chip{color:var(--text);cursor:pointer;background:#fcfcfcc2;border:1px solid #2236301a;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;transition:border-color .18s,transform .18s,background .18s;display:flex}.designer-field-chip:hover,.designer-field-chip.active{background:#f9e9a985;border-color:#9b7641a3;transform:translateY(-1px)}.designer-field-chip span,.designer-field-chip small{display:block}.designer-field-chip small{color:var(--text-muted)}.designer-control-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.designer-control{flex-direction:column;gap:8px;display:flex}.designer-control span{color:var(--charcoal);letter-spacing:.08em;text-transform:uppercase;font-size:.8rem;font-weight:700}.designer-control input,.designer-control select,.designer-control textarea{width:100%;color:var(--text);background:#ffffffd1;border:1px solid #2236301f;border-radius:14px;padding:12px 14px;font-family:DM Sans,sans-serif;font-size:.96rem}.designer-control textarea{resize:vertical;min-height:96px}.designer-control input[type=color]{min-height:48px;padding:6px}.designer-control.wide,.designer-toggle-row.wide{grid-column:1/-1}.designer-course-note{color:var(--text-muted);grid-column:1/-1;margin-top:-4px;font-size:.88rem;line-height:1.55}.designer-coord-summary{color:var(--text-muted);grid-column:1/-1;padding-top:2px;font-size:.82rem;line-height:1.6}.designer-debug-panel{background:#f4f4f5eb;border:1px solid #2236301a;border-radius:16px;gap:8px;margin-top:16px;padding:14px 16px;display:grid}.designer-debug-line{color:var(--charcoal);word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem}.designer-canvas-debug{background:#f4f4f5eb;border:1px solid #2236301a;border-radius:16px;gap:6px;margin-bottom:14px;padding:12px 14px;display:grid}.designer-canvas-error{z-index:4;color:#ffd5dd;text-align:center;background:#9d4251eb;border:1px solid #ffffff29;border-radius:22px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px;display:flex;position:absolute;inset:0}.designer-canvas-error span{color:#fff0f3;word-break:break-word}.designer-debug-tag{z-index:2;color:var(--surface);pointer-events:none;background:#223630e6;border-radius:8px;padding:4px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.68rem;position:absolute;bottom:6px;right:6px}.designer-export-divider{background:#2236301a;height:1px;margin:18px 0}.designer-toggle-row{flex-wrap:wrap;gap:10px;display:flex}.designer-toggle{color:var(--text);background:#fcfcfcbd;border:1px solid #2236301a;border-radius:999px;align-items:center;gap:8px;padding:10px 12px;font-size:.9rem;display:inline-flex}.designer-toggle input{accent-color:var(--accent)}.designer-export-preview{width:100%;box-shadow:var(--shadow-soft);border:1px solid #22363024;border-radius:18px;display:block}.designer-export-placeholder{color:var(--text-muted);background:#fcfcfcc2;border:1px dashed #22363024;border-radius:18px;padding:18px;line-height:1.6}.designer-guard-card,.designer-loading{text-align:center;width:min(640px,100%);margin:12vh auto 0;padding:32px}.designer-guard-card p{color:var(--text-muted);line-height:1.7}.designer-login-form{text-align:left;gap:14px;width:min(420px,100%);margin:20px auto 0;display:grid}.designer-login-error{color:#7f2335;background:#9d42511f;border:1px solid #9d425133;border-radius:12px;padding:10px 12px;font-size:.9rem;line-height:1.5}.designer-login-submit{justify-self:stretch}.designer-guard-card code{background:#f9e9a975;border-radius:6px;padding:2px 6px}.designer-link{color:var(--graphite);border-bottom:1px solid #22363038;margin-top:20px;text-decoration:none;display:inline-flex}.designer-loading{place-items:center;gap:16px;display:grid}@media (width<=1180px){.designer-grid{flex-direction:column}.designer-sidebar{width:100%}}@media (width<=820px){.designer-shell{padding:20px 14px 36px}.designer-header{flex-direction:column;padding:22px}.designer-actions{justify-content:flex-start;width:100%}.designer-sample-grid,.designer-control-grid{grid-template-columns:1fr}.designer-stage-meta{align-items:flex-start}}
