@import"https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";:root{color-scheme:light;--bg: #f7f8f5;--surface: #ffffff;--surface-muted: #eef1ec;--text: #131514;--muted: #626963;--line: rgba(19, 21, 20, .13);--accent: #159463;--accent-strong: #0d6f4a;--danger: #b23b3b;--warning: #9b6a18;--shadow: 0 18px 44px rgba(26, 31, 27, .12)}[data-theme=dark]{color-scheme:dark;--bg: #101211;--surface: #181b19;--surface-muted: #222821;--text: #f3f5f0;--muted: #a6aea6;--line: rgba(255, 255, 255, .14);--accent: #3bc78b;--accent-strong: #73e1ad;--danger: #f06f6f;--warning: #e0af52;--shadow: 0 18px 44px rgba(0, 0, 0, .32)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:Barlow,system-ui,sans-serif}button,input{font:inherit}button{color:inherit}.app-shell{width:min(100%,1180px);max-width:100%;min-height:100dvh;margin:0 auto;padding:16px 14px 86px;overflow-x:clip}.topbar,.search-row,.editor-header,.action-row,.caption-controls,.sheet-header{display:flex;align-items:center}.topbar{justify-content:space-between;gap:16px;padding:4px 0 14px}.brand-button{border:0;background:transparent;color:var(--text);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:clamp(1.7rem,8vw,3.2rem);font-weight:700;letter-spacing:0;line-height:.95;padding:0}h2{margin:0;font-family:Space Grotesk,sans-serif;letter-spacing:0}.icon-button,.primary-button,.secondary-button,.template-tile,.segmented button,.saved-captions button{min-height:42px;border:1px solid var(--line);border-radius:8px;background:var(--surface);cursor:pointer}.icon-button{width:44px;display:grid;place-items:center}.search-row{position:sticky;top:0;z-index:3;padding:8px 0 12px;background:var(--bg)}.search-field,.caption-input{display:flex;align-items:center;gap:8px;min-width:0;width:100%;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:0 12px}.search-field{height:46px}.search-field input,.caption-input input,.bottom-sheet input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--text)}.gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.template-tile{position:relative;display:grid;gap:6px;padding:7px;text-align:left;overflow:hidden}.review-badge{position:absolute;top:12px;left:12px;border-radius:999px;background:#9b6a18eb;color:#fff;font-size:.72rem;font-weight:700;padding:3px 7px}.template-tile img{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:6px;background:var(--surface-muted)}.template-tile strong,.template-tile small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-tile strong{font-size:.94rem}.template-tile small{color:var(--muted)}.empty-state,.editor-loading{display:grid;gap:10px;min-height:190px;align-content:center;justify-items:center;border:1px dashed var(--line);border-radius:8px;background:var(--surface);color:var(--muted);text-align:center;padding:18px}.empty-state{grid-column:1 / -1}.empty-state strong{color:var(--text)}.loading-grid{height:180px;border-radius:8px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--surface) 70%,transparent),transparent),var(--surface-muted);background-size:220px 100%,100% 100%;animation:loading-sweep 1.2s linear infinite;margin-bottom:10px}@keyframes loading-sweep{0%{background-position:-220px 0,0 0}to{background-position:calc(100% + 220px) 0,0 0}}.editor-route{display:grid;gap:8px;min-width:0;max-width:100%}.editor-header{justify-content:space-between;gap:12px;min-width:0}.description-row{display:flex;flex-wrap:wrap;gap:6px;min-width:0;justify-content:flex-end}.description-row span{max-width:100%;border:1px solid var(--line);border-radius:999px;color:var(--muted);padding:5px 8px;font-size:.78rem;overflow-wrap:anywhere}.canvas-wrap{width:100%;max-width:100%;max-height:min(54dvh,520px);border-radius:8px;background:var(--surface-muted);overflow:hidden}canvas{display:block;width:100%;max-width:100%;height:auto;max-height:min(54dvh,520px);object-fit:contain}.caption-stack{display:grid;gap:8px;min-width:0}.caption-input{flex:1;min-height:42px}.segmented{display:grid;grid-template-columns:repeat(2,minmax(72px,1fr));border:1px solid var(--line);border-radius:8px;overflow:hidden}.segmented button{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-height:38px;border:0;border-radius:0}.segmented .active{background:var(--accent);color:#06130d;font-weight:700}.action-row{flex-wrap:wrap;gap:8px}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;font-weight:700}.primary-button{border-color:var(--accent);background:var(--accent);color:#06130d}.secondary-button{background:var(--surface-muted)}.primary-button:disabled,.secondary-button:disabled{cursor:wait;opacity:.68}.saved-captions{display:flex;flex-wrap:wrap;gap:8px}.saved-captions button{min-height:34px;padding:0 10px;color:var(--muted);max-width:100%}.fab{position:fixed;right:18px;bottom:18px;z-index:10;display:grid;width:58px;height:58px;place-items:center;border:1px solid var(--accent);border-radius:999px;background:var(--accent);color:#06130d;box-shadow:var(--shadow);cursor:pointer}.sheet-backdrop{position:fixed;inset:0;z-index:20;display:grid;align-items:end;background:#0000005c}.bottom-sheet{display:grid;gap:12px;width:min(100%,620px);margin:0 auto;border:1px solid var(--line);border-radius:14px 14px 0 0;background:var(--surface);box-shadow:var(--shadow);padding:14px}.sheet-header{justify-content:space-between}.sheet-header strong{font-family:Space Grotesk,sans-serif;font-size:1.1rem}.bottom-sheet label{display:grid;gap:6px;color:var(--muted);font-size:.86rem}.bottom-sheet input{min-height:44px;border:1px solid var(--line);border-radius:8px;padding:0 10px}.bottom-sheet .file-input{min-height:52px;padding:8px}.file-input::file-selector-button{min-height:34px;margin-right:10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-muted);color:var(--text);font:inherit;font-weight:700}.notice{position:fixed;right:14px;bottom:86px;z-index:30;max-width:min(92vw,560px);border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);padding:10px 12px;text-align:left}.offline-banner{border:1px solid var(--warning);border-radius:8px;background:color-mix(in srgb,var(--warning) 16%,var(--surface));color:var(--text);margin-bottom:10px;padding:9px 11px}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(min-width:700px){.app-shell{padding:26px 28px 96px}.gallery{grid-template-columns:repeat(3,minmax(0,1fr))}.editor-route{width:min(100%,860px);margin:0 auto}}@media(min-width:1080px){.gallery{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:520px){.app-shell{padding:10px 10px 70px}.topbar{padding-bottom:8px}.brand-button{font-size:clamp(1.5rem,7vw,2.2rem)}.editor-header{align-items:flex-start;gap:8px}.description-row span:nth-child(n+3){display:none}.canvas-wrap,canvas{max-height:46dvh}.caption-controls{flex-direction:column}.action-row>button{flex:1 1 130px}}
