*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:Hiragino Kaku Gothic ProN,Meiryo,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:24px 16px}.header{text-align:center;margin-bottom:32px}.header h1{font-size:1.6rem;font-weight:700;color:#38bdf8}.header p{font-size:.85rem;color:#94a3b8;margin-top:6px}.main-layout{display:grid;grid-template-columns:1fr 320px;grid-gap:24px;gap:24px;align-items:start}@media (max-width:768px){.main-layout{grid-template-columns:1fr}}.card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:20px}.card-title{font-size:.8rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}.uploader{border:2px dashed #334155;border-radius:10px;padding:40px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.uploader.drag-over,.uploader:hover{border-color:#38bdf8;background:#1e3a4a}.uploader-icon{font-size:2.5rem;margin-bottom:12px}.uploader p{font-size:.9rem;color:#94a3b8}.uploader span{font-size:.75rem;color:#64748b}.canvas-wrap{position:relative;width:100%;overflow:hidden;border-radius:8px}.canvas-wrap canvas{display:block;width:100%;cursor:crosshair;-webkit-user-select:none;-moz-user-select:none;user-select:none}.seg-btn{display:flex;border:1px solid #334155;border-radius:8px;overflow:hidden;margin-bottom:16px}.seg-btn button{flex:1 1;padding:8px;background:transparent;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;transition:background .2s,color .2s}.seg-btn button.active{background:#0ea5e9;color:#fff;font-weight:700}.field{margin-bottom:14px}.field label{display:block;font-size:.78rem;color:#94a3b8;margin-bottom:6px}.field input[type=color]{width:48px;height:32px;border:1px solid #334155;border-radius:6px;padding:2px;cursor:pointer;background:#0f172a}.field input[type=range]{width:100%;accent-color:#38bdf8}.field .row{display:flex;align-items:center;gap:10px}.field .val{font-size:.8rem;color:#38bdf8;min-width:28px;text-align:right}.checkbox-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:.85rem;color:#94a3b8;cursor:pointer}.checkbox-row input{accent-color:#38bdf8;width:16px;height:16px}.btn{display:block;width:100%;padding:12px;border:none;border-radius:8px;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#0ea5e9;color:#fff}.btn-primary:hover:not(:disabled){background:#0284c7}.btn-reset{background:#334155;color:#e2e8f0;margin-bottom:8px}.preview-section{margin-top:32px}.preview-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:8px;gap:8px}.preview-cell{aspect-ratio:370/320;background:repeating-conic-gradient(#1e293b 0 25%,#263548 0 50%) 0 0 /16px 16px;border-radius:6px;overflow:hidden;border:1px solid #334155}.preview-cell img{width:100%;height:100%;object-fit:contain}.preview-cell .idx{display:flex;align-items:center;justify-content:center;height:100%;font-size:.7rem;color:#475569}.hint{font-size:.75rem;color:#64748b;text-align:center;margin-top:8px}