@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}@font-face{font-family:MyCustomFont;src:url(https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap);font-weight:400;font-style:normal}:root{--bg:#f4f5f7;--surface:#fff;--surface2:#f0f1f4;--border:#d8dbe5;--blue:#3a7bff;--teal:#00a882;--text:#1a1d2b;--muted:#6b7090;--red:#e5364b;--r:16px;--shadow:0 2px 12px #0000000f,0 1px 3px #0000000a;--shadow-lg:0 8px 32px #00000014}html,body{background:var(--bg);color:var(--text);min-height:100vh;font-family:MyCustomFont,sans-serif}body{flex-direction:column;align-items:center;padding:0 1rem 4rem;display:flex}.hdr{text-align:center;margin-top:2rem;margin-bottom:2rem}.hdr h1{background:linear-gradient(130deg, #1a1d2b 30%, var(--blue) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:DM Serif Display,serif;font-size:2rem}.hdr p{color:var(--muted);margin-top:6px;font-size:.88rem}.layout{align-items:flex-start;gap:24px;width:100%;max-width:1100px;display:flex}.sidebar{flex-direction:column;flex:0 0 300px;gap:20px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:22px}.lbl{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-size:.7rem;font-weight:600}#dropZone{border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:12px;padding:32px 16px;transition:border-color .2s,background .2s;position:relative}#dropZone:hover,#dropZone.drag-over{border-color:var(--blue);background:#3a7bff0a}#dropZone.has-file{border-color:var(--teal);background:#00a8820a;padding:16px}#dropZone input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.drop-ico{margin-bottom:8px;font-size:2rem;display:block}.drop-txt{color:var(--muted);font-size:.85rem}.drop-txt strong{color:var(--text)}#fileName{color:var(--teal);margin-top:6px;font-size:.82rem;font-weight:500;display:none}.stamp-group{grid-template-columns:1fr 1fr;gap:10px;display:grid}.stamp-btn{background:var(--surface2);border:2px solid var(--border);cursor:pointer;text-align:center;color:var(--text);border-radius:10px;padding:14px 8px;transition:border-color .2s,background .2s,transform .15s}.stamp-btn:hover{border-color:var(--blue);transform:translateY(-2px)}.stamp-btn.selected{border-color:var(--blue);background:#3a7bff0f}.stamp-badge{letter-spacing:.07em;text-transform:uppercase;border:1.5px solid;border-radius:3px;margin-bottom:6px;padding:2px 7px;font-size:.58rem;font-weight:700;display:inline-block}.stamp-btn[data-stamp=australia] .stamp-badge{border-color:var(--blue);color:var(--blue)}.stamp-btn[data-stamp=studybird] .stamp-badge{border-color:var(--teal);color:var(--teal)}.stamp-name{font-family:DM Serif Display,serif;font-size:.8rem;display:block}.stamp-sub{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.page-nav{justify-content:center;align-items:center;gap:10px;display:flex}.nav-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;padding:6px 12px;font-family:DM Sans,sans-serif;font-size:.82rem;transition:border-color .2s}.nav-btn:hover:not(:disabled){border-color:var(--blue)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.page-info{color:var(--muted);text-align:center;min-width:70px;font-size:.82rem}.scope-group{flex-direction:column;gap:8px;display:flex}.scope-row{gap:8px;display:flex}.scope-btn{background:var(--surface2);border:2px solid var(--border);cursor:pointer;color:var(--muted);text-align:center;border-radius:8px;flex:1;padding:9px 6px;font-family:DM Sans,sans-serif;font-size:.76rem;transition:border-color .2s,color .2s}.scope-btn:hover{border-color:var(--blue);color:var(--text)}.scope-btn.selected{border-color:var(--blue);color:var(--text);background:#3a7bff0f}#genBtn{background:linear-gradient(135deg,var(--blue),#1a45c0);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:14px;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 6px 20px #3a7bff38}#genBtn:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}#genBtn:disabled{opacity:.32;cursor:not-allowed;box-shadow:none;transform:none}.preview-panel{flex:1;min-width:0}.preview-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.preview-title{color:var(--muted);font-size:.88rem}.preview-hint{color:var(--blue);font-size:.78rem;font-style:italic}#canvasWrap{box-shadow:var(--shadow-lg);cursor:crosshair;border:1px solid var(--border);background:#fff;border-radius:10px;width:100%;display:inline-block;position:relative;overflow:hidden}#canvasWrap canvas{width:100%;height:auto;display:block}#stampGhost{pointer-events:none;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;background:#ffffffe6;border:2px solid;border-radius:4px;padding:4px 8px;font-size:.6rem;font-weight:700;line-height:1.5;display:none;position:absolute;transform:translate(-50%,-50%)}.stamp-marker{letter-spacing:.06em;text-transform:uppercase;cursor:move;-webkit-user-select:none;user-select:none;background:#ffffffe6;border:2px solid;border-radius:4px;padding:3px 7px;font-size:.55rem;font-weight:700;line-height:1.5;position:absolute;transform:translate(-50%,-50%)}.stamp-marker .del-btn{background:var(--red);cursor:pointer;color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;line-height:1;display:flex;position:absolute;top:-8px;right:-8px}#emptyState{background:var(--surface);border:2px dashed var(--border);min-height:420px;color:var(--muted);text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex}#emptyState .big{margin-bottom:12px;font-size:3rem}#emptyState p{font-size:.88rem;line-height:1.6}#toast{background:var(--surface);border:1px solid var(--border);color:var(--text);opacity:0;pointer-events:none;white-space:nowrap;z-index:999;box-shadow:var(--shadow-lg);border-radius:40px;padding:10px 20px;font-size:.85rem;font-weight:500;transition:opacity .3s,transform .3s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(16px)}#toast.show{opacity:1;transform:translate(-50%)translateY(0)}#toast.ok{border-color:var(--teal);color:var(--teal)}#toast.err{border-color:var(--red);color:var(--red)}@keyframes spin{to{transform:rotate(360deg)}}.spin:after{content:"";vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:12px;height:12px;margin-left:8px;animation:.7s linear infinite spin;display:inline-block}@media (width<=720px){.layout{flex-direction:column}.sidebar{flex:none;width:100%}}
