@import "https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;700;900&family=Sora:wght@700;800&display=swap";:root{--brand-50:#f1eefe;--brand-100:#d9d1fb;--brand-300:#a593f4;--brand-500:#6c4cf1;--brand-600:#5235d4;--brand-800:#3c2f9e;--surface:#fff;--bg:#fafafc;--border:#eceaf2;--border-strong:#d9d1fb;--text-tertiary:#9b98ab;--text-secondary:#57546a;--text-primary:#1a1726;--tag-bg:#f1eff7;--success:#16a34a;--success-bg:#e7f6ec;--warning:#f59e0b;--danger:#dc2626;--danger-bg:#fdeaea;--danger-border:#fecaca;--info:var(--brand-500);--font-display:"Sora", system-ui, sans-serif;--font-sans:"Noto Sans TC", system-ui, sans-serif;--text-2xl:28px;--text-xl:20px;--text-lg:16px;--text-base:14px;--text-sm:12px;--leading-normal:1.6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-pill:999px;--shadow-card:0 1px 3px #1a17260f;--shadow-focus:0 0 0 3px #6c4cf11f;--page-max:1080px}*,:before,:after{box-sizing:border-box}*{margin:0}img,canvas,svg{max-width:100%;display:block}button{font:inherit;cursor:pointer}ul{padding:0;list-style:none}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--brand-600);text-decoration:none}a:hover{text-decoration:underline}h1{font-size:var(--text-2xl);letter-spacing:-.01em;font-weight:900}h2{font-size:var(--text-xl);font-weight:700}h3{font-size:var(--text-lg);font-weight:500}.btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-base);border:1px solid #0000;padding:9px 18px;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s;display:inline-flex}.btn:hover{text-decoration:none}.btn-primary{background:var(--brand-500);color:#fff}.btn-primary:hover{background:var(--brand-600)}.btn-secondary{background:var(--surface);color:var(--brand-600);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--brand-50)}.btn-text{color:var(--text-secondary);background:0 0;padding:9px 12px}.btn-text:hover{color:var(--text-primary)}.btn-danger{background:var(--surface);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover{background:var(--danger-bg)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed}input[type=text],input[type=search],input[type=number],textarea,select{width:100%;font:inherit;color:var(--text-primary);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px}input:focus,textarea:focus,select:focus{border-color:var(--brand-500);box-shadow:var(--shadow-focus);outline:none}label{font-size:var(--text-base);color:var(--text-secondary)}.tag{border-radius:var(--radius-pill);font-size:var(--text-sm);background:var(--tag-bg);color:var(--text-secondary);padding:3px 11px;text-decoration:none;display:inline-block}.tag--active{background:var(--brand-50);color:var(--brand-800);font-weight:500}.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.badge{border-radius:var(--radius-pill);font-size:var(--text-sm);padding:1px 8px;font-weight:500;display:inline-block}.badge--public{background:var(--success-bg);color:var(--success)}.badge--private{background:var(--tag-bg);color:var(--text-secondary)}.badge--gif{color:#fff;background:#1a1726c7}.flash{max-width:var(--page-max);margin:var(--space-2) auto 0;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-base)}.flash-notice{background:var(--success-bg);color:var(--success)}.flash-alert{background:var(--danger-bg);color:var(--danger)}main{max-width:var(--page-max);padding:var(--space-4);margin:0 auto}.search-bar{gap:var(--space-2);max-width:460px;margin:0 0 var(--space-4);display:flex}.search-bar input[type=search]{flex:1}.tag-filter{gap:var(--space-2);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.site-header{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface);border-bottom:.5px solid var(--border);display:flex}.site-header .logo{font-family:var(--font-display);color:var(--brand-500);font-size:22px;font-weight:800;text-decoration:none}.site-header nav{align-items:center;gap:var(--space-4);display:flex}.site-header nav .user-name{font-size:var(--text-base);color:var(--text-secondary)}.site-footer{border-top:.5px solid var(--border);background:var(--surface);margin-top:var(--space-8);padding:var(--space-6) var(--space-4)}.site-footer .inner{max-width:var(--page-max);gap:var(--space-4);font-size:var(--text-sm);color:var(--text-tertiary);flex-wrap:wrap;justify-content:space-between;margin:0 auto;display:flex}.site-footer a{color:var(--text-secondary)}.site-footer .footer-links{gap:var(--space-4);flex-wrap:wrap;display:flex}.meme-grid{gap:var(--space-3);grid-template-columns:repeat(4,1fr);display:grid}.meme-grid li a{color:inherit;text-decoration:none;display:block}.meme-grid .thumb{aspect-ratio:1;border-radius:var(--radius-md);background:var(--tag-bg);position:relative;overflow:hidden}.meme-grid .thumb img{object-fit:cover;width:100%;height:100%}.meme-grid .badge--gif{top:var(--space-2);left:var(--space-2);position:absolute}.meme-grid .name{padding:var(--space-2) 2px;font-size:var(--text-base);font-weight:500;display:block}@media (width<=960px){.meme-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.meme-grid{grid-template-columns:repeat(2,1fr)}}.creation-list{gap:var(--space-4);flex-direction:column;display:flex}.creation-list li{gap:var(--space-3);align-items:flex-start;display:flex}.creation-list .thumb{aspect-ratio:1;border-radius:var(--radius-md);object-fit:cover;background:var(--tag-bg);flex-shrink:0;width:120px}.creation-list time{color:var(--text-tertiary);margin:var(--space-1) 0;font-size:13px;display:block}.meme-detail{max-width:640px;margin:0 auto}.meme-detail h1{margin-bottom:var(--space-3)}.meme-detail .figure{background:var(--tag-bg);border:.5px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);justify-content:center;display:flex}.meme-detail .figure img{object-fit:contain;border-radius:var(--radius-sm);width:auto;max-width:100%;max-height:70vh}.meme-detail .actions{gap:var(--space-2);margin:var(--space-4) 0;display:flex}.meme-detail .tags{gap:var(--space-2);flex-wrap:wrap;display:flex}.related{max-width:640px;margin:var(--space-8) auto 0}.related h2{margin-bottom:var(--space-4)}.creations{max-width:640px;margin:var(--space-8) auto 0}.creations h2{margin-bottom:var(--space-4)}.meme-detail .submitter{color:var(--text-tertiary);font-size:var(--text-sm);margin-top:calc(var(--space-1) * -1);margin-bottom:var(--space-3)}.meme-editor .editor-body{gap:var(--space-4);align-items:flex-start;display:flex}.meme-editor .canvas-stage{flex:1;min-width:320px;max-width:520px}.meme-editor .editor-canvas{width:100%!important;height:auto!important}.meme-editor .layer-panel{flex:0 0 240px}@media (width<=640px){.meme-editor .editor-body{flex-direction:column}.meme-editor .canvas-stage,.meme-editor .layer-panel{flex:auto;width:100%;max-width:none}}.meme-editor .editor-toolbar{align-items:center;gap:var(--space-2);padding-bottom:var(--space-3);flex-wrap:wrap;display:flex}.meme-editor .tool-group{gap:2px;display:inline-flex}.meme-editor .tool-divider{background:var(--border);width:1px;height:20px}.meme-editor .editor-toolbar .spacer{flex:1}.meme-editor .tb-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);height:34px;color:var(--text-secondary);font-size:var(--text-base);align-items:center;gap:6px;padding:0 13px;font-weight:500;display:inline-flex}.meme-editor .tb-btn.icon{justify-content:center;width:34px;padding:0}.meme-editor .history .tb-btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.meme-editor .history .tb-btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:none}.meme-editor .tb-btn.primary{background:var(--brand-500);color:#fff;border-color:#0000}.meme-editor .tb-btn.primary:hover{background:var(--brand-600)}.meme-editor .tb-btn.outline{color:var(--brand-600);border-color:var(--border-strong)}.meme-editor .tb-btn:disabled{opacity:.5;cursor:not-allowed}.meme-editor .play-pill{font-size:var(--text-sm);color:var(--text-secondary);background:var(--tag-bg);border-radius:var(--radius-pill);font-variant-numeric:tabular-nums;align-items:center;gap:5px;padding:5px 10px;display:inline-flex}.meme-editor .public-toggle{font-size:var(--text-base);color:var(--text-secondary);align-items:center;gap:5px;display:inline-flex}.meme-editor .field{flex-direction:column;gap:5px;display:flex}.meme-editor .field.inline{flex-direction:row;align-items:center;gap:6px}.meme-editor .field-label{color:var(--text-tertiary);letter-spacing:.03em;font-size:11px;font-weight:500}.meme-editor .seg{border:1px solid var(--border);border-radius:var(--radius-sm);height:38px;display:flex;overflow:hidden}.meme-editor .seg button{background:var(--surface);border:none;border-left:1px solid var(--border);color:var(--text-secondary);flex:1;justify-content:center;align-items:center;display:flex}.meme-editor .seg button:first-child{border-left:none}.meme-editor .seg button.on{background:var(--brand-50);color:var(--brand-500)}.meme-editor .swatches{gap:var(--space-1);flex-wrap:nowrap;align-items:center;display:flex}.meme-editor .swatch{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;flex:none;width:28px;height:28px;padding:0}.meme-editor .swatch.on{box-shadow:0 0 0 2px var(--brand-500)}.meme-editor .swatches .color-field{flex:none;display:flex}.meme-editor .swatches .color-field .trigger{width:28px;height:28px}.meme-editor .field-select select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2357546a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6l6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}.meme-editor .advanced summary{cursor:pointer;font-size:var(--text-base);color:var(--text-secondary);align-items:center;gap:6px;list-style:none;display:flex}.meme-editor .advanced summary::-webkit-details-marker{display:none}.meme-editor .delete-layer{color:var(--danger);font-size:var(--text-base);cursor:pointer;background:0 0;border:none;align-self:flex-end;align-items:center;gap:5px;font-weight:500;display:inline-flex}.meme-editor input[type=checkbox]{appearance:none;border:1.5px solid var(--border-strong);background:var(--surface);cursor:pointer;border-radius:5px;flex-shrink:0;width:18px;height:18px;position:relative}.meme-editor input[type=checkbox]:checked{background:var(--brand-500);border-color:var(--brand-500);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5l9-10'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat}.meme-editor input[type=checkbox]:focus-visible{box-shadow:var(--shadow-focus);outline:none}.meme-editor .layer-panel input[type=text],.meme-editor .layer-panel input[type=number],.meme-editor .layer-panel select,.meme-editor .layer-panel textarea{font-size:var(--text-base);padding:6px 10px}.meme-editor .seg{height:32px}.meme-editor .field-select select{padding-right:30px}.meme-editor .transport{align-items:center;gap:var(--space-3);margin-top:var(--space-3);display:flex}.meme-editor .seek-bar{background:var(--border);touch-action:none;cursor:pointer;border-radius:3px;flex:1;height:6px;position:relative}.meme-editor .seek-fill{background:var(--brand-500);border-radius:3px;position:absolute;top:0;bottom:0;left:0}.meme-editor .seek-knob{background:var(--surface);border:2px solid var(--brand-500);pointer-events:none;border-radius:50%;width:14px;height:14px;margin-left:-7px;position:absolute;top:50%;transform:translateY(-50%)}.meme-editor .transport-time{font-size:var(--text-sm);color:var(--text-secondary);font-variant-numeric:tabular-nums}.meme-editor .layer-list li{cursor:grab}.meme-editor .layer-list li.dragging{opacity:.5}.meme-editor .layer-list .grip{color:var(--text-tertiary);flex-shrink:0;display:inline-flex}.meme-editor .layer-list button{gap:6px}.admin-form{gap:var(--space-4);flex-direction:column;max-width:480px;margin:0 auto;display:flex}.admin-form label{gap:var(--space-1);flex-direction:column;display:flex}.empty-state{text-align:center;color:var(--text-secondary);padding:var(--space-8) var(--space-4)}.submissions-head{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.submission-form{gap:var(--space-4);flex-direction:column;max-width:480px;display:flex}.submission-form label{gap:var(--space-1);flex-direction:column;display:flex}.submission-form .preview{border-radius:var(--radius-md);border:.5px solid var(--border);max-width:200px}.submission-list{gap:var(--space-4);flex-direction:column;display:flex}.submission-list li{gap:var(--space-3);align-items:flex-start;display:flex}.submission-list .thumb{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-md);background:var(--tag-bg);flex-shrink:0;width:88px}.submission-list .meta{min-width:0}.submission-list .reason{font-size:var(--text-sm);color:var(--danger);margin:var(--space-1) 0}.submission-list .actions{align-items:center;gap:var(--space-2);margin-top:var(--space-1);display:flex}.submission-list .actions form{margin:0}.submission-list .linklike{color:var(--brand-600);cursor:pointer;font-size:var(--text-base);background:0 0;border:none;padding:0}.badge--pending{background:var(--warning-bg,#fef3e2);color:var(--warning)}.badge--approved{background:var(--success-bg);color:var(--success)}.badge--rejected{background:var(--danger-bg);color:var(--danger)}.badge--info{background:var(--brand-50);color:var(--brand-600)}.queue-head{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.review-queue{gap:var(--space-3);flex-direction:column;display:flex}.review-queue .card{gap:var(--space-4);background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-4);align-items:flex-start;display:flex}.review-queue .thumb{border-radius:var(--radius-sm);background:var(--tag-bg);flex-shrink:0;width:84px;height:84px;position:relative;overflow:hidden}.review-queue .thumb img{object-fit:cover;width:100%;height:100%}.review-queue .thumb .badge--gif{position:absolute;top:4px;left:4px}.review-queue .info{flex:1;min-width:0}.review-queue .info .who{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:2px;display:block}.review-queue .info .desc{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-2) 0}.review-queue .info .tags{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.review-queue .decide{gap:var(--space-2);flex-direction:column;flex-shrink:0;align-items:stretch;display:flex}.review-queue .decide form{margin:0}.review-queue .reject summary{text-align:center;list-style:none}.review-queue .reject summary::-webkit-details-marker{display:none}.review-queue .reject-form{gap:var(--space-2);margin-top:var(--space-2);flex-direction:column;display:flex}
