:root{color:#1f2937;background:#eef2f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}.app-layout{display:grid;grid-template-columns:minmax(300px,370px) minmax(0,1fr);min-height:100vh}.controls-panel{display:flex;flex-direction:column;gap:22px;min-height:100vh;padding:28px;background:#fbfcfd;border-right:1px solid #d6dde4}.brand-block{display:flex;align-items:center;gap:14px}.brand-mark{display:grid;place-items:center;width:48px;height:48px;color:#fff;background:#4c923e;border-radius:8px}.eyebrow{margin:0 0 2px;color:#64748b;font-size:.76rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;color:#0f172a;font-size:1.5rem;line-height:1.15}.control-section{display:flex;flex-direction:column;gap:12px}.field-label,.slider-label,.color-label,.section-heading{color:#334155;font-size:.92rem;font-weight:700}.section-heading,.slider-label,.color-label{display:flex;align-items:center;justify-content:space-between;gap:10px}.section-heading{justify-content:flex-start}input[type=text]{width:100%;min-height:44px;padding:10px 12px;color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none}input[type=text]:focus{border-color:#4c923e;box-shadow:0 0 0 3px #4c923e29}input[type=range]{width:100%;accent-color:#4c923e}input[type=color]{width:42px;height:34px;padding:2px;background:#fff;border:1px solid #cbd5e1;border-radius:8px}.color-control{display:inline-flex;align-items:center;gap:8px}.color-value{color:#64748b;font-size:.86rem;font-weight:700;text-transform:uppercase}.file-drop{display:flex;align-items:center;gap:12px;min-height:70px;padding:14px;color:#1e293b;background:#fff;border:1px dashed #94a3b8;border-radius:8px}.file-drop:hover{border-color:#4c923e}.file-drop span{display:flex;flex-direction:column;gap:3px;min-width:0}.file-drop small{overflow:hidden;color:#64748b;text-overflow:ellipsis;white-space:nowrap}.file-drop input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}.template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.chip,.secondary-button,.ghost-button,.toggle-button,.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border-radius:8px;transition:background .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.chip{padding:9px 10px;color:#334155;background:#f8fafc;border:1px solid #d6dde4}.chip.active{color:#fff;background:#4c923e;border-color:#4c923e}.button-row{display:grid;grid-template-columns:1fr .76fr;gap:8px}.secondary-button{padding:10px 12px;color:#0f172a;background:#fff;border:1px solid #cbd5e1}.ghost-button{padding:10px 12px;color:#9f1239;background:#fff1f2;border:1px solid #fecdd3}.toggle-button{width:100%;padding:10px 12px;color:#0f172a;background:#fff;border:1px solid #cbd5e1}.primary-button,.top-download-button{width:100%;color:#fff;background:#4c923e;border:1px solid #4c923e;font-weight:800}.primary-button{margin-top:auto;padding:14px 16px}.top-download-button{width:auto;min-height:40px;padding:9px 14px;border-radius:8px}.chip:hover,.secondary-button:hover,.ghost-button:hover,.toggle-button:hover,.primary-button:hover{transform:translateY(-1px)}.preview-area{display:flex;justify-content:center;min-width:0;padding:28px;overflow:auto;background:linear-gradient(90deg,rgb(15 23 42 / .06) 1px,transparent 1px),linear-gradient(rgb(15 23 42 / .06) 1px,transparent 1px),#eef2f5;background-size:28px 28px}.preview-shell{width:min(100%,820px)}.preview-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;color:#475569;font-size:.9rem;font-weight:700}.preview-toolbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}.worksheet-canvas{display:block;width:100%;aspect-ratio:1240 / 1754;background:#fff;border:1px solid #cbd5e1;box-shadow:0 18px 44px #0f172a29;cursor:crosshair;touch-action:none;-webkit-user-select:none;user-select:none}.hint{margin:14px 0 0;color:#475569;font-size:.9rem;line-height:1.45}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:849px){.app-layout{grid-template-columns:1fr}.controls-panel{min-height:auto;border-right:0;border-bottom:1px solid #d6dde4}.primary-button{margin-top:0}.preview-area{padding:18px}.preview-toolbar{align-items:flex-start;flex-direction:column}.preview-toolbar-actions{width:100%;justify-content:space-between}}@media(max-width:520px){.controls-panel{padding:20px}.brand-block{align-items:flex-start}h1{font-size:1.3rem}.template-grid,.button-row{grid-template-columns:1fr}}
