@import "https://fonts.googleapis.com/css2?family=Fraunces:wght@400;600;700&family=Space+Grotesk:wght@400;500;600&display=swap";:root{color:#1c130e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg:#f4ede2;--bg-2:#e9dccb;--panel:#fff9f1;--panel-strong:#fdf1e5;--ink:#1c130e;--muted:#6f5a47;--accent:#dd7a54;--accent-strong:#b65533;--teal:#1f6e70;--outline:#1c130e24;--shadow:0 22px 40px #1c130e1f;background-color:#f4ede2;font-family:Space Grotesk,Trebuchet MS,sans-serif;font-weight:400;line-height:1.4}*{box-sizing:border-box}body{min-height:100vh;color:var(--ink);background:radial-gradient(60% 80% at 10% 12%,#ffdcb899,#0000 60%),radial-gradient(55% 70% at 90% 0,#c4e6e299,#0000 55%),linear-gradient(130deg,#f7efe3 0%,#efe1cf 100%);margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}img{max-width:100%;display:block}#root{min-height:100vh}.app-shell{flex-direction:column;gap:28px;padding:32px 28px 64px;display:flex}.app-header{justify-content:space-between;align-items:flex-end;gap:24px;display:flex}.eyebrow{text-transform:uppercase;letter-spacing:.35em;color:var(--muted);margin:0;font-size:.7rem}.app-header h1{margin:8px 0 12px;font-family:Fraunces,serif;font-size:clamp(2.4rem,3vw,3.4rem)}.subtitle{max-width:520px;color:var(--muted);margin:0}.header-actions{gap:12px;display:flex}.app-layout{grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start;gap:24px;display:grid}.panel{background:var(--panel);border:1px solid var(--outline);box-shadow:var(--shadow);border-radius:22px;padding:20px}.panel--controls,.panel--preview{flex-direction:column;gap:18px;display:flex}.panel-section{border-bottom:1px dashed #1c130e24;flex-direction:column;gap:12px;padding-bottom:18px;animation:.6s both panel-rise;display:flex}.panel-section:last-child{border-bottom:none;padding-bottom:0}.panel-section:first-child{animation-delay:50ms}.panel-section:nth-child(2){animation-delay:.1s}.panel-section:nth-child(3){animation-delay:.15s}.panel-section:nth-child(4){animation-delay:.2s}.panel-section:nth-child(5){animation-delay:.25s}.panel-section h2{margin:0;font-family:Fraunces,serif;font-size:1.15rem}.section-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.field label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.7rem}.field input,.field select,.field textarea{border:1px solid var(--outline);color:var(--ink);background:#fff;border-radius:10px;padding:10px 12px;font-size:.95rem}.field input[type=color]{height:38px;padding:0}.field input:focus,.field select:focus,.field textarea:focus{border-color:#dd7a5499;outline:2px solid #dd7a5459}.helper{color:var(--muted);margin:0;font-size:.85rem}.helper span{color:var(--ink);font-weight:600}.helper.small{font-size:.8rem}.button{cursor:pointer;border:none;border-radius:999px;align-items:center;gap:6px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.button:hover{transform:translateY(-1px);box-shadow:0 12px 18px #1c130e1f}.button:disabled{opacity:.65;cursor:not-allowed;box-shadow:none;transform:none}.button--primary{background:linear-gradient(120deg,var(--accent),#f0a06f);color:#fff}.button--ghost{border:1px solid var(--outline);color:var(--ink);background:0 0}.button--soft{color:var(--ink);background:#f4e6d6;border:1px solid #1c130e14}.button--danger{color:#fff;background:#7b2f2a}.button--tiny{padding:6px 12px;font-size:.78rem}.button-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.label-list{flex-direction:column;gap:8px;display:flex}.label-item{color:var(--ink);text-align:left;cursor:pointer;background:#ffffffb3;border:1px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:8px 10px;transition:border .2s,background .2s;display:flex}.label-item:hover{border-color:var(--outline);background:#fff}.label-item.is-active{background:#fff;border-color:#dd7a5499}.label-dot{border:1px solid #1c130e33;border-radius:50%;width:10px;height:10px}.label-name{font-size:.9rem;font-weight:600}.empty-state{color:var(--muted);margin:0;font-size:.85rem}.batch-preview{background:#fff9;border:1px dashed #1c130e33;border-radius:12px;flex-direction:column;gap:8px;padding:10px;display:flex}.batch-preview__row{color:var(--ink);justify-content:space-between;gap:12px;font-size:.85rem;display:flex}.batch-preview__row span:first-child{font-weight:600}.preview-toolbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.preview-toolbar h2{margin:0;font-family:Fraunces,serif;font-size:1.25rem}.preview-hint{color:var(--muted);margin:4px 0 0;font-size:.9rem}.certificate-frame{background:var(--panel-strong);border:1px solid #1c130e1a;border-radius:24px;justify-content:center;padding:12px;display:flex}.certificate-stage{max-width:100%;margin:0 auto}.certificate{touch-action:none;-webkit-user-select:none;user-select:none;border-radius:18px;width:100%;height:100%;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #1c130e1f}.certificate-image{object-fit:cover;pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;inset:0}.certificate-overlay{z-index:1;position:absolute;inset:0}.certificate--placeholder{background:linear-gradient(135deg,#fdf9f3 0%,#f3e2ce 50%,#f7efe4 100%)}.certificate--placeholder:before{content:"";z-index:0;opacity:.45;background:repeating-linear-gradient(135deg,#dda8782e,#dda8782e 10px,#fff0 10px 20px);position:absolute;inset:0}.canvas-label{align-items:center;gap:8px;display:flex;position:absolute}.canvas-label__handle{cursor:grab;background:#ffffffb3;border:1px solid #1c130e4d;border-radius:6px;place-items:center;width:16px;height:16px;display:grid}.canvas-label__handle:before{content:"";background:radial-gradient(circle,#1c130e8c 45%,#0000 46%);width:6px;height:6px}.canvas-label__input{letter-spacing:.02em;min-width:120px;color:var(--ink);transform-origin:0;-webkit-user-select:text;user-select:text;background:0 0;border:1px solid #1c130e73;border-radius:8px;outline:none;padding:6px 12px;font-weight:600;box-shadow:0 0 0 1px #ffffff59}.canvas-label__input::placeholder{color:#1c130e66}.canvas-label.is-active .canvas-label__input{border-color:var(--accent);box-shadow:0 0 0 2px #dd7a544d}.canvas-qr{cursor:grab;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);-webkit-user-select:none;user-select:none;background:#ffffffbf;border:1px dashed #1c130e59;border-radius:12px;place-items:center;display:grid;position:absolute;overflow:visible}.canvas-qr__svg{pointer-events:none;width:100%;height:100%}.canvas-qr__svg svg{width:100%;height:100%;display:block}.canvas-qr__handle{cursor:nwse-resize;background:#fff;border:1px solid #1c130e59;border-radius:6px;width:18px;height:18px;position:absolute;bottom:-8px;right:-8px;box-shadow:0 6px 12px #1c130e2e}.canvas-qr.is-empty{letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-weight:600}.preview-footer{justify-content:space-between;align-items:center;gap:12px;display:flex}@keyframes panel-rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width:980px){.app-layout{grid-template-columns:1fr}.app-header{flex-direction:column;align-items:flex-start}}@media (max-width:720px){.app-shell{padding:24px 18px 48px}.field-row,.button-row{grid-template-columns:1fr}.preview-toolbar{flex-direction:column;align-items:flex-start}}
