*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:Arial,sans-serif;color:#0f172a;background:#e8f4ff}button,textarea{font:inherit}button{cursor:pointer}.page{min-height:100vh;padding:14px}.shell{display:grid;grid-template-columns:320px 1fr;grid-gap:20px;gap:20px;align-items:start}.sidebar{display:grid;grid-gap:16px;gap:16px}.panel{background:#f6fbff;border:1px solid #c5ddf3;border-radius:16px;padding:12px;box-shadow:0 1px 2px rgba(7,89,133,.1)}.panel h1,.panel h2{margin:0 0 10px}.muted{color:#64748b;margin:0 0 12px}.label{display:block;font-size:14px;font-weight:600;margin-bottom:8px}.textarea{width:100%;min-height:100px;resize:vertical;border:1px solid #cbd5e1;border-radius:12px;padding:12px;background:#fff}.panelHeader{display:flex;justify-content:space-between;align-items:center;gap:12px}.clearCanvasBtn,.linkBtn,.miniBtn{border:1px solid #9bc5e8;background:#ffffff;border-radius:10px;padding:6px 9px}.tokenWrap{display:flex;flex-wrap:wrap;gap:8px}.token{border:1px solid #cbd5e1;background:#fff;border-radius:999px;padding:8px 12px}.tokenActive{border-color:#0ea5e9;background:#e0f2fe}.selectedBox{margin-top:12px;font-size:14px}.componentGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.componentBtn{display:grid;place-items:center;border:1px solid #9bc5e8;background:#ffffff;border-radius:10px;padding:8px;min-height:52px}.componentBtn:disabled{opacity:.5;cursor:not-allowed}.componentIcon{display:block;width:76px;height:30px;object-fit:contain}.lineBreakSection{margin-top:10px;padding-top:10px;border-top:1px solid #c5ddf3;display:flex;align-items:center;justify-content:space-between}.lineBreakActions{display:flex;gap:8px}.lineBreakLabel{margin:0;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#5b7c9d;font-weight:700}.lineBreakBtn{width:98px}.canvasPanel{min-height:620px}.canvasHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.canvasActions{display:flex;gap:8px}.downloadCanvasBtn{border-color:#1d4ed8;background:linear-gradient(180deg,#3b82f6,#2563eb);color:#ffffff;font-weight:700}.canvasFooter{margin-top:10px;display:flex;justify-content:flex-start}.canvas{position:relative;min-height:540px;border-radius:18px;border:1px solid #c5ddf3;background-image:linear-gradient(#e8eef5 1px,transparent 0),linear-gradient(90deg,#e8eef5 1px,transparent 0);background-size:24px 24px;background-color:#f3f9ff;overflow:hidden}.canvasEmpty{position:absolute;inset:0;display:grid;place-items:center;color:#94a3b8;pointer-events:none}.snapGuide{position:absolute;width:12px;height:12px;transform:translate(-50%,-50%);border-radius:999px;border:2px solid #0ea5e9;background:#e0f2fe;pointer-events:none;z-index:20}.canvasItemShell{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.canvasItemFrame{position:absolute;inset:0;border-radius:16px;border:1px solid #c7daec;background:rgba(255,255,255,.96);box-shadow:0 1px 2px rgba(15,23,42,.08)}.canvasItemFrameSelected{border-color:#0ea5e9;box-shadow:0 0 0 2px rgba(186,230,253,.9)}.canvasItemFrameGhost{opacity:.7}.itemBar{position:absolute;top:8px;left:12px;right:12px;display:flex;justify-content:flex-end;align-items:center;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;z-index:8}.itemActions{display:flex;gap:8px}.miniBtn{padding:4px 8px;font-size:12px}.colorPickerRow{position:absolute;left:14px;top:38px;display:flex;gap:6px;z-index:12}.colorSwatch{width:16px;height:16px;border-radius:999px;border:1px solid rgba(15,23,42,.25);padding:0}.colorSwatchActive{box-shadow:0 0 0 2px rgba(14,165,233,.55)}.graphicWrap{position:absolute;inset:0;display:grid;place-items:center;padding:6px 12px 0;pointer-events:none;transform-origin:center center;z-index:1}.wordAnchor{position:absolute;width:0;height:0;overflow:visible;z-index:10}.wordBody{position:absolute;left:0;top:0;transform-origin:center center;pointer-events:auto}.itemText{pointer-events:auto;border:0;background:transparent;padding:0 4px;margin:0;line-height:1;text-align:center;font-size:clamp(14px,.55vw + 12px,18px);font-weight:600;color:#0f172a;cursor:-webkit-grab;cursor:grab;white-space:nowrap}.itemTextEditing{background:rgba(255,255,255,.92);border-radius:8px;box-shadow:0 0 0 1px rgba(203,213,225,.9)}.anchorDot{width:10px;height:10px;transform:translate(-50%,-50%);border-radius:999px;border:1px solid #0ea5e9;background:#ffffff}.anchorDot,.rotationCenter{position:absolute;pointer-events:none;z-index:9}.rotationCenter{width:4px;height:4px;border-radius:999px;border:1px solid #cbd5e1;background:#e2e8f0}.rotationStem{position:absolute;width:1px;background:#cbd5e1;pointer-events:none;z-index:9}.rotationHandle{position:absolute;width:20px;height:20px;transform:translate(-50%,-50%);border-radius:999px;border:1px solid #94a3b8;background:#ffffff;box-shadow:0 1px 2px rgba(15,23,42,.12);cursor:crosshair;z-index:11}.wordRotationHandle{width:16px;height:16px}.rotationHandle:hover{border-color:#0ea5e9}.scaleHandle{width:16px;height:16px;border-radius:4px;border:1px solid #0ea5e9;background:#e0f2fe;z-index:12}.annotationTag,.scaleHandle{position:absolute;transform:translate(-50%,-50%)}.annotationTag{border:1px solid #cbd5e1;background:#ffffff;color:#334155;border-radius:8px;padding:4px 8px;font-size:12px;font-weight:600;z-index:13}.selectionBox{position:absolute;border:1px dashed #0ea5e9;background:rgba(14,165,233,.16);pointer-events:none;z-index:25}@media (max-width:960px){.shell{grid-template-columns:1fr}.canvasHeader{flex-direction:column}}