:root{--pink:#f472b6;--pink2:#ec4899;--cream:#fff8ea;--cream2:#fff1c7;--ink:#26151d;--muted:#806877;--line:#f2d7df}*{box-sizing:border-box}body{color:var(--ink);background:linear-gradient(135deg, var(--cream), #ffe6f2);margin:0;font-family:-apple-system,BlinkMacSystemFont,Noto Sans CJK SC,PingFang SC,sans-serif}button,input,textarea,select{font:inherit}button{border:0;border:1px solid var(--line);color:var(--ink);cursor:pointer;background:#fff;border-radius:14px;padding:11px 16px;transition:all .2s}.button-like{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:14px;justify-content:center;align-items:center;padding:11px 16px;display:inline-flex}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #ef75b633}button:disabled{opacity:.45;cursor:not-allowed}.primary{background:linear-gradient(135deg, var(--pink), var(--pink2));color:#fff;border:0;font-weight:800}.splash{min-height:100vh;color:var(--pink2);place-items:center;font-weight:800;display:grid}.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:#fffdf8e6;border:1px solid #fff;border-radius:28px;width:min(460px,100%);padding:36px;box-shadow:0 30px 90px #e96bac40}.brand-badge{background:var(--cream2);color:#9d5c00;border-radius:999px;padding:8px 12px;font-size:13px;display:inline-block}.login-card h1{letter-spacing:.05em;margin:18px 0 8px;font-size:44px}.login-card p{color:var(--muted);line-height:1.7}.form-stack,label{flex-direction:column;gap:7px;display:flex}.form-stack{gap:16px;margin-top:24px}input,textarea,select{border:1px solid var(--line);background:#fff;border-radius:14px;outline:none;width:100%;padding:12px}textarea{resize:vertical;min-height:84px}.error{color:#d12c4f;background:#fff1f4;border-radius:12px;padding:10px}.warn{color:#8a5a00;background:#fff4cd;border-radius:12px;padding:10px}.hint{color:var(--muted);border:1px dashed var(--line);background:#fff8;border-radius:12px;padding:10px}.app-shell{min-height:100vh;display:flex}.side{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffdf8c7;border-right:1px solid #fff;width:220px;height:100vh;padding:20px;position:sticky;top:0}.logo{color:var(--pink2);margin:10px 0 24px;font-size:25px;font-weight:900}.side button{text-align:left;width:100%;margin:7px 0}.side button.active{background:var(--pink);color:#fff}.content{flex:1;min-width:0;padding:22px}.topbar{justify-content:flex-end;margin-bottom:16px;display:flex}.topbar div{background:#fff9;border:1px solid #fff;border-radius:18px;padding:10px 14px}.topbar span{color:var(--muted);margin-left:10px}.workspace{gap:16px;display:grid}.panel{background:#fffdf8e0;border:1px solid #fff;border-radius:24px;padding:20px;box-shadow:0 16px 50px #e96bac1c}.panel h2,.panel h3{margin-top:0}.grid-form{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px;display:grid}.actions{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.upload-box{text-align:center;background:#fff8;border:2px dashed #f3a4c9;border-radius:22px;place-items:center;min-height:110px;display:grid}.upload-box strong{color:var(--pink2);font-size:20px}.upload-box span,.generate-row small{color:var(--muted)}.thumbs{gap:10px;margin-top:14px;padding-bottom:4px;display:flex;overflow:auto}.thumb-item{flex:none;gap:6px;display:grid}.thumb-item>button:first-child{width:88px;height:88px;padding:0;position:relative;overflow:hidden}.thumb-item img{object-fit:cover;width:100%;height:100%}.thumb-item.sel>button:first-child{outline:4px solid var(--pink)}.thumb-item span{color:#fff;background:#0009;border-radius:99px;padding:2px 7px;font-size:12px;position:absolute;top:6px;left:6px}.thumb-delete{color:#d12c4f;border-radius:10px;width:88px;padding:6px;font-size:12px}.generate-row{flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px;display:flex}.editor-layout{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:16px;display:grid}.canvas-panel{place-items:center;min-height:440px;display:grid;overflow:hidden}.empty{min-height:260px;color:var(--muted);border:1px dashed var(--line);border-radius:22px;place-items:center;width:100%;display:grid}.empty.small{min-height:120px}.image-editor{touch-action:none;border-radius:20px;width:fit-content;max-width:100%;max-height:58vh;position:relative;overflow:hidden}.image-editor>img{border-radius:20px;max-width:100%;max-height:58vh;display:block;box-shadow:0 14px 40px #1f11182b}.text-overlay{text-align:center;cursor:move;-webkit-user-select:none;user-select:none;word-break:break-word;overflow-wrap:anywhere;border-radius:14px;place-items:center;font-weight:900;line-height:1.15;display:grid;position:absolute;overflow:hidden;box-shadow:0 0 0 2px #fff8,0 10px 25px #0002}.caption-list{gap:8px;display:grid}.caption-list button{text-align:left}.caption-list .active{background:var(--cream2);border-color:var(--pink)}.preset-grid{display:none}.preview-select{margin-bottom:12px;position:relative}.preview-select-trigger{text-align:left;justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.preview-menu{z-index:12;border:1px solid var(--line);background:#fffdf8;border-radius:16px;gap:6px;max-height:320px;padding:8px;display:grid;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:auto;box-shadow:0 18px 48px #26151d29}.preview-menu button{text-align:left;justify-content:space-between;align-items:center;gap:10px;display:flex}.style-swatch{border:1px solid #ead5dd;border-radius:12px;place-items:center;min-width:112px;min-height:38px;padding:7px 12px;font-weight:900;display:inline-grid}.style-swatch.no-bg{box-shadow:none;border-color:#0000}.font-sample{font-size:22px;font-weight:800;line-height:1.2}.font-menu button{justify-items:start;display:grid}.font-menu small{color:var(--muted)}.export-box{border-top:1px solid var(--line);gap:9px;margin-top:18px;padding-top:18px;display:grid}.video-editor-page{gap:16px;display:grid}.video-header{justify-content:space-between;align-items:start;gap:16px;display:flex}.video-header p{color:var(--muted);margin:0;line-height:1.6}.video-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.video-summary{border:1px solid var(--line);color:var(--muted);background:#fff8;border-radius:16px;padding:12px 14px}.timeline-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.timeline-card{border:1px solid var(--line);cursor:grab;background:#fff;border-radius:18px;grid-template-columns:40px minmax(0,1fr);align-items:start;gap:12px;padding:12px;display:grid}.timeline-card:active{cursor:grabbing}.timeline-index{background:var(--cream2);color:#9d5c00;border-radius:999px;place-items:center;width:36px;height:36px;font-weight:900;display:grid}.timeline-card img{object-fit:contain;border:1px solid var(--line);background:#111;border-radius:12px;grid-column:1/-1;width:100%;height:240px}.timeline-meta{grid-column:1/-1;gap:8px;min-width:0;display:grid}.timeline-meta strong{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.timeline-meta small{color:var(--muted)}.timeline-meta input{max-width:120px}.timeline-stepper{flex-wrap:wrap;grid-column:1/-1;justify-content:flex-start;gap:8px;display:flex}.toast{color:#fff;z-index:20;background:#26151dee;border-radius:999px;padding:13px 18px;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 40px #0004}.history-list,.user-table{gap:10px;display:grid}.history-item,.user-table>div{border:1px solid var(--line);background:#fff;border-radius:16px;grid-template-columns:1.5fr 1fr 1fr auto;align-items:center;gap:10px;padding:12px;display:grid}.history-item{text-align:left;grid-template-columns:120px 1fr 1.5fr 1fr;width:100%}.history-preview{align-items:center;gap:6px;min-height:92px;display:flex}.history-preview img{object-fit:contain;border:1px solid var(--line);background:#111;border-radius:10px;width:92px;height:92px}.history-preview span{color:var(--muted)}.inline-form,.admin-create-form{grid-template-columns:1fr 1fr 180px auto;align-items:end;gap:10px;margin-bottom:16px;display:grid}.user-row{grid-template-columns:1fr 80px 90px 160px 1fr auto auto auto!important}.user-row label{gap:4px}.user-row input{padding:9px}@media (width<=960px){.app-shell{display:block}.side{gap:8px;width:auto;height:auto;display:flex;position:static;overflow:auto}.logo{min-width:120px;margin:8px}.side button{white-space:nowrap;width:auto}.content{padding:12px}.grid-form,.editor-layout{grid-template-columns:1fr}.canvas-panel{min-height:360px}.image-editor,.image-editor>img{max-height:54vh}.style-panel{position:relative}.history-item,.user-table>div,.inline-form,.admin-create-form,.user-row{grid-template-columns:1fr!important}.video-header{display:grid}.video-actions{justify-content:stretch}.timeline-list{grid-template-columns:1fr}.timeline-card{grid-template-columns:42px 1fr}.timeline-card img{width:100%;height:220px}.login-card h1{font-size:36px}}@media (width<=560px){.panel{border-radius:18px;padding:14px}.side{padding:10px}.editor-layout{gap:10px}.text-overlay{border-radius:10px}.thumb-item>button:first-child{width:72px;height:72px}.thumb-delete{width:72px}}
