:root{--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-bg: #f8fafc;--color-surface: #ffffff;--color-border: #e2e8f0;--color-text: #0f172a;--color-muted: #64748b;--color-danger: #dc2626;--color-success: #16a34a;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--header-h: 56px;--nav-h: 60px;--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 18px;border:none;border-radius:var(--radius);background:var(--color-primary);color:#fff;font-weight:600;cursor:pointer;transition:background .15s}.btn:hover{background:var(--color-primary-dark)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-outline:hover{background:#eff6ff}.btn-danger{background:var(--color-danger)}.btn-sm{min-height:36px;padding:0 12px;font-size:.875rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%;min-height:44px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff}.form-group input:focus,.form-group select:focus{outline:2px solid #93c5fd;border-color:var(--color-primary)}.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:.9rem}.alert-error{background:#fef2f2;color:var(--color-danger);border:1px solid #fecaca}.alert-info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600}.badge-ready{background:#dcfce7;color:#166534}.badge-processing{background:#fef9c3;color:#854d0e}.badge-failed{background:#fee2e2;color:#991b1b}.badge-completed{background:#dbeafe;color:#1e40af}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;height:var(--header-h);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center}.app-header .container{display:flex;align-items:center;justify-content:space-between;gap:12px}.logo{font-weight:800;font-size:1.125rem;color:var(--color-text);text-decoration:none}.logo span{color:var(--color-primary)}.header-nav{display:none;gap:20px}.header-nav a{color:var(--color-muted);font-weight:500;text-decoration:none}.header-nav a.active,.header-nav a:hover{color:var(--color-primary)}.app-main{flex:1;padding:20px 0 80px}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;z-index:100}.mobile-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:.7rem;color:var(--color-muted);text-decoration:none;padding:8px 4px}.mobile-nav a.active{color:var(--color-primary)}.mobile-nav svg{width:22px;height:22px}@media (min-width: 768px){.header-nav{display:flex}.mobile-nav{display:none}.app-main{padding-bottom:32px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px}.auth-card{width:100%;max-width:400px}.auth-card h1{margin:0 0 8px;font-size:1.5rem}.auth-card p.sub{color:var(--color-muted);margin:0 0 24px}.doc-list{list-style:none;padding:0;margin:0}.doc-item{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--color-border)}.doc-item:last-child{border-bottom:none}.doc-item-info{flex:1;min-width:200px}.doc-item-info h3{margin:0 0 4px;font-size:1rem}.doc-item-meta{font-size:.8rem;color:var(--color-muted)}.doc-item-actions{display:flex;gap:8px;flex-wrap:wrap}.page-title{margin:0 0 20px;font-size:1.5rem}.empty-state{text-align:center;padding:48px 16px;color:var(--color-muted)}.editor-layout{display:flex;flex-direction:column;gap:16px}.editor-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.editor-canvas-wrap{position:relative;background:#94a3b8;border-radius:var(--radius);overflow:auto;display:flex;justify-content:center;padding:16px;min-height:300px;touch-action:none}.editor-canvas{position:relative;display:inline-block;-webkit-user-select:none;user-select:none;touch-action:none;box-shadow:0 4px 20px #0003}.editor-canvas img.page-bg{display:block;max-width:100%;height:auto}.placement-overlay{position:absolute;border:2px dashed var(--color-primary);cursor:move;touch-action:none;overflow:visible}.placement-overlay.selected{border-color:var(--color-danger);border-style:solid;box-shadow:0 0 0 1px #dc262626}.placement-delete-btn{position:absolute;top:-14px;right:-14px;width:28px;height:28px;padding:0;border:2px solid #fff;border-radius:50%;background:var(--color-danger);color:#fff;font-size:20px;font-weight:700;line-height:1;cursor:pointer;touch-action:manipulation;box-shadow:0 2px 6px #00000040;z-index:3;display:flex;align-items:center;justify-content:center}.placement-delete-btn:hover{background:#b91c1c}.placement-resize-handle{position:absolute;right:-14px;bottom:-14px;width:30px;height:30px;box-sizing:border-box;background-color:var(--color-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath fill='%23ffffff' d='M21.434 11.975l8.602-8.549-0.028 4.846c-0.009 0.404 0.311 0.755 0.716 0.746l0.513-0.001c0.404-0.009 0.739-0.25 0.748-0.654l0.021-7.219c0-0.007-0.027-0.012-0.027-0.019l0.040-0.366c0.004-0.203-0.044-0.384-0.174-0.513-0.13-0.131-0.311-0.21-0.512-0.204l-0.366 0.009c-0.007 0-0.012 0.003-0.020 0.004l-7.172-0.032c-0.404 0.009-0.738 0.343-0.747 0.748l-0.001 0.513c0.061 0.476 0.436 0.755 0.84 0.746l4.726 0.013-8.572 8.52c-0.39 0.39-0.39 1.024 0 1.415s1.023 0.39 1.414 0zM10.597 20.025l-8.602 8.523 0.027-4.82c0.010-0.404-0.312-0.756-0.716-0.747l-0.544 0.001c-0.405 0.010-0.739 0.25-0.748 0.654l-0.021 7.219c0 0.007 0.028 0.011 0.028 0.019l-0.040 0.365c-0.005 0.203 0.043 0.385 0.174 0.514 0.129 0.131 0.311 0.21 0.512 0.205l0.366-0.009c0.007 0 0.012-0.003 0.020-0.003l7.203 0.032c0.404-0.010 0.738-0.344 0.748-0.748l0.001-0.514c-0.062-0.476-0.436-0.755-0.84-0.746l-4.726-0.012 8.571-8.518c0.39-0.39 0.39-1.023 0-1.414s-1.023-0.391-1.413-0zM32.007 30.855l-0.021-7.219c-0.009-0.404-0.343-0.645-0.747-0.654l-0.513-0.001c-0.404-0.009-0.725 0.343-0.716 0.747l0.028 4.846-8.602-8.549c-0.39-0.39-1.023-0.39-1.414 0s-0.39 1.023 0 1.414l8.571 8.518-4.726 0.012c-0.404-0.009-0.779 0.27-0.84 0.746l0.001 0.514c0.009 0.404 0.344 0.739 0.747 0.748l7.172-0.032c0.008 0 0.013 0.003 0.020 0.003l0.366 0.009c0.201 0.005 0.384-0.074 0.512-0.205 0.131-0.129 0.178-0.311 0.174-0.514l-0.040-0.365c0-0.008 0.027-0.012 0.027-0.019zM3.439 2.041l4.727-0.012c0.404 0.009 0.778-0.27 0.84-0.746l-0.001-0.513c-0.010-0.405-0.344-0.739-0.748-0.748l-7.204 0.031c-0.008-0.001-0.013-0.004-0.020-0.004l-0.366-0.009c-0.201-0.005-0.383 0.074-0.512 0.204-0.132 0.13-0.179 0.31-0.174 0.514l0.040 0.366c0 0.007-0.028 0.012-0.028 0.020l0.021 7.219c0.009 0.404 0.343 0.645 0.748 0.654l0.545 0.001c0.404 0.009 0.724-0.342 0.715-0.746l-0.028-4.819 8.602 8.523c0.39 0.39 1.024 0.39 1.414 0s0.39-1.024 0-1.415z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:20px 20px;border:2px solid #fff;border-radius:6px;cursor:nwse-resize;touch-action:none;box-shadow:0 2px 6px #00000040;z-index:2;flex-shrink:0}.placement-overlay.selected .placement-resize-handle{background-color:var(--color-primary-dark)}.scale-control{display:flex;align-items:center;gap:8px;flex:1 1 180px;min-width:160px;max-width:280px}.scale-control label{font-size:.875rem;font-weight:600;white-space:nowrap}.scale-control input[type=range]{flex:1;min-height:44px;accent-color:var(--color-primary)}.scale-control span{font-size:.8rem;color:var(--color-muted);min-width:36px;text-align:right}.placement-overlay img{width:100%;height:100%;object-fit:contain;pointer-events:none}.page-thumbs{display:flex;gap:8px;overflow-x:auto;padding:8px 0}.page-thumb{flex-shrink:0;width:64px;border:2px solid transparent;border-radius:4px;cursor:pointer;opacity:.7}.page-thumb.active{border-color:var(--color-primary);opacity:1}.page-thumb img{width:100%;display:block;border-radius:2px}.asset-preview{max-width:200px;max-height:120px;border:1px solid var(--color-border);border-radius:var(--radius);padding:8px;background:#f1f5f9}.asset-preview img{max-width:100%;max-height:100px;display:block;margin:0 auto}.grid-2{display:grid;gap:16px}@media (min-width: 640px){.grid-2{grid-template-columns:1fr 1fr}.editor-layout.with-sidebar{flex-direction:row}.editor-sidebar{width:120px;flex-shrink:0}.editor-main{flex:1;min-width:0}}.landing{min-height:100vh;display:flex;flex-direction:column}.landing-hero{flex:1;display:flex;align-items:center;padding:48px 16px;text-align:center}.landing-hero h1{font-size:clamp(1.75rem,5vw,2.5rem);margin:0 0 16px}.landing-hero p{color:var(--color-muted);font-size:1.125rem;max-width:560px;margin:0 auto 32px}.landing-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:border-color .15s}.upload-zone:hover,.upload-zone.dragover{border-color:var(--color-primary);background:#eff6ff}.upload-zone input{display:none}.spinner{display:inline-block;width:20px;height:20px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
