:root{--paper: #faf6f0;--paper-2: #f3ece1;--card: #fffdfa;--ink: #2b2722;--ink-soft: #6f655a;--muted: #9b8f80;--line: #e7ddd0;--clay: #c36b4b;--clay-dark: #a8563a;--clay-soft: #f0ddd0;--green: #6b9a64;--shadow: 0 1px 2px rgba(75, 55, 40, .06), 0 6px 18px rgba(75, 55, 40, .07);--font-serif: "Poppins", sans-serif;--font-sans: "Poppins", sans-serif;--nav-h: 64px;--radius: 16px;--photo-h: clamp(300px, 46vh, 520px);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overscroll-behavior-y:none}h1,h2,h3{font-family:var(--font-serif);font-weight:600;letter-spacing:.01em;margin:0}button,input,textarea{font-family:inherit;font-size:inherit;color:inherit}input,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none}.app{min-height:100%;display:flex;flex-direction:column}.screen{flex:1;display:flex;flex-direction:column;padding:calc(var(--safe-top) + 18px) 18px calc(var(--nav-h) + var(--safe-bottom) + 28px);max-width:680px;width:100%;margin:0 auto}.screen-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px}.screen-header h1{font-size:22px}.screen-sub{color:var(--muted);font-size:14px;margin:2px 0 22px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px;padding:0 22px;border:none;border-radius:999px;background:var(--clay);color:#fff;font-weight:600;font-size:16px;cursor:pointer;transition:transform .08s ease,background .15s ease}.btn:active{transform:scale(.97);background:var(--clay-dark)}.btn:disabled{opacity:.55;cursor:default}.btn-ghost{background:transparent;color:var(--clay-dark);border:1.5px solid var(--line)}.btn-ghost:active{background:var(--paper-2)}.btn-block{width:100%}.field{display:block;margin-bottom:16px}.field label{display:block;font-size:13px;color:var(--ink-soft);margin-bottom:6px;font-weight:600}.input{width:100%;min-height:52px;padding:12px 16px;background:var(--card);border:1.5px solid var(--line);border-radius:14px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus{border-color:var(--clay);box-shadow:0 0 0 3px var(--clay-soft)}textarea.input{min-height:120px;resize:vertical;line-height:1.55}.filter-bar{display:flex;align-items:center;gap:8px;overflow-x:auto;padding-bottom:2px;margin-bottom:16px;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;padding:5px 14px;border-radius:20px;border:1.5px solid var(--line);background:transparent;font-size:13px;font-weight:500;color:var(--ink-soft);cursor:pointer;transition:all .15s;font-family:var(--font-sans)}.filter-chip.active{background:var(--clay-soft);border-color:var(--clay);color:var(--clay-dark)}.sort-btn{flex-shrink:0;margin-left:auto;display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;border:1.5px solid var(--line);background:transparent;font-size:13px;font-weight:500;color:var(--ink-soft);cursor:pointer;font-family:var(--font-sans)}.project-grid{display:flex;flex-direction:column;gap:14px}.project-card{display:flex;align-items:flex-start;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);cursor:pointer;text-align:left;position:relative;transition:transform .08s ease;-webkit-tap-highlight-color:transparent}.project-card:active{transform:scale(.99)}.card-cover{flex:0 0 auto;width:80px;height:80px;border-radius:12px;background:linear-gradient(135deg,var(--clay-soft),var(--paper-2));overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.card-cover img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}.card-cover-letter{font-family:var(--font-serif);font-size:32px;color:var(--clay-dark);opacity:.45;-webkit-user-select:none;user-select:none}.progress-badge{display:inline-block;width:fit-content;font-size:11px;font-weight:600;letter-spacing:.03em;padding:3px 9px;border-radius:100px;background:var(--clay-soft);color:var(--clay-dark)}.badge-idea{background:#ede9fe;color:#5b21b6}.badge-pre-bisque{background:#fef9c3;color:#854d0e}.badge-pre-glaze{background:#ffedd5;color:#9a3412}.badge-final{background:#dcfce7;color:#166534}.card-body{flex:1;min-width:0;padding-right:28px;display:flex;flex-direction:column;gap:4px}.card-name-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.card-name{font-family:var(--font-serif);font-size:17px;font-weight:600}.card-date{font-size:12px;color:var(--muted)}.card-desc{font-size:13px;color:var(--ink-light);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-dots-btn{position:absolute;top:10px;right:10px;z-index:2;background:none;border:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;cursor:pointer;color:var(--muted)}.card-dots-btn:active{background:var(--paper-2)}.card-menu{position:absolute;top:40px;right:10px;z-index:3;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px #0000002e;overflow:hidden;min-width:120px;animation:fade .1s ease}.card-menu-item{display:block;width:100%;padding:12px 16px;background:none;border:none;text-align:left;font-size:15px;cursor:pointer;color:var(--ink)}.card-menu-item+.card-menu-item{border-top:1px solid var(--line)}.card-menu-item.danger{color:#c0392b}.card-menu-item:active{background:var(--paper-2)}.menu-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#1c19168c;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .15s ease}.confirm-sheet{background:var(--card);border-radius:18px;padding:24px 22px 20px;width:100%;max-width:340px;box-shadow:0 20px 60px #0000004d}.confirm-sheet p{font-size:16px;line-height:1.5;margin-bottom:6px}.confirm-sheet .confirm-sub{font-size:13px;color:var(--muted);margin-bottom:20px}.confirm-actions{display:flex;gap:10px}.confirm-actions .btn{flex:1;min-height:42px;font-size:13px}.btn-danger{background:#c0392b;color:#fff}.btn-danger:active{background:#a93226}.btn-chosen{background:#eaf4ea;color:#3a7d3a;border:1.5px solid #b3d9b3}.btn-chosen:active{background:#d4ecce}.edit-drawer-label{display:block;font-size:13px;font-weight:600;color:var(--ink-light);margin-bottom:6px}.placeholder{text-align:center;color:var(--muted);padding:56px 24px}.placeholder .mark{font-size:44px;margin-bottom:12px}.placeholder p{margin:0 0 20px}.spinner{width:28px;height:28px;border:3px solid var(--line);border-top-color:var(--clay);border-radius:50%;animation:spin .8s linear infinite;margin:60px auto}@keyframes spin{to{transform:rotate(360deg)}}.toast-error{background:#fbeae5;color:#8a3b22;border:1px solid #f0cbbf;border-radius:12px;padding:12px 14px;font-size:14px;margin-bottom:16px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:calc(var(--nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);display:flex;background:#fffdfaeb;-webkit-backdrop-filter:saturate(1.4) blur(12px);backdrop-filter:saturate(1.4) blur(12px);border-top:1px solid var(--line);z-index:20}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--muted);font-size:11px;font-weight:600;transition:color .15s ease}.bottom-nav a .icon{width:24px;height:24px;display:block}.bottom-nav a.active{color:var(--clay-dark)}.bottom-nav a.new-tab .icon-wrap{width:48px;height:48px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;margin-top:-18px;box-shadow:0 6px 16px #c36b4b66}.bottom-nav a.new-tab.active .icon-wrap{background:var(--clay-dark)}.auth-wrap{min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:calc(var(--safe-top) + 24px) 24px calc(var(--safe-bottom) + 24px);max-width:420px;margin:0 auto}.auth-brand{text-align:center;margin-bottom:28px}.auth-brand .logo{width:72px;height:72px;margin:0 auto 14px;display:block}.auth-brand h1{font-size:28px}.auth-brand p{color:var(--muted);margin:6px 0 0;font-size:15px}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon .input{flex:1;padding-right:42px}.input-eye{position:absolute;right:10px;background:none;border:none;padding:4px;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;line-height:0}.auth-toggle{text-align:center;margin-top:18px;font-size:14px;color:var(--ink-soft)}.auth-toggle button{background:none;border:none;color:var(--clay-dark);font-weight:600;cursor:pointer;padding:4px}.auth-note{text-align:center;font-size:13px;color:var(--muted);margin-top:14px}.back-btn{min-height:40px;padding:0 16px;margin-bottom:14px}.danger-text{color:#a23a1f}.detail-title{display:flex;align-items:center;gap:8px;margin-bottom:16px}.title-back{flex:0 0 auto;width:36px;height:36px;margin-left:-8px;border:none;background:none;color:var(--clay-dark);display:grid;place-items:center;cursor:pointer}.title-back:active{color:var(--ink)}.detail-title h1{font-size:20px;cursor:text;flex:1;min-width:0}.title-input{font-family:var(--font-serif);font-size:20px;font-weight:600;flex:1;min-width:0}.title-delete{flex:0 0 auto;width:38px;height:38px;border-radius:50%;border:none;background:none;color:var(--muted);display:grid;place-items:center;cursor:pointer}.title-delete:active{color:#a23a1f}.stage-tabs-wrap{margin-bottom:18px;border-bottom:1px solid var(--line);padding-bottom:0}.stage-tabs{display:flex;gap:4px;overflow-x:auto;padding:0;scrollbar-width:none}.stage-tabs::-webkit-scrollbar{display:none}.stage-tab{position:relative;flex-shrink:0;padding:8px 14px;border:none;border-radius:0;background:none;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--ink-muted);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease;display:flex;align-items:center;gap:5px}.stage-tab:active{color:var(--ink)}.stage-tab.active{color:var(--clay-dark);border-bottom-color:var(--clay);font-weight:600}.stage-tab-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}.stage-tab.active .stage-tab-dot{background:var(--green)}.chapter-view{flex:1;display:flex;flex-direction:column;gap:14px;animation:stage-fade .22s ease}@keyframes stage-fade{0%{opacity:0;transform:translateY(4px)}}.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.section-title{display:flex;align-items:center;gap:8px;font-family:var(--font-serif);font-size:17px;font-weight:600;color:var(--ink)}.photo-skel{display:block;width:100%;height:100%;background:linear-gradient(110deg,var(--paper-2) 30%,#fff 50%,var(--paper-2) 70%);background-size:200% 100%;animation:shimmer 1.2s infinite}.photo-skel.big{width:100%;height:var(--photo-h);border-radius:16px}@keyframes shimmer{to{background-position:-200% 0}}.empty-photo{width:100%;height:var(--photo-h);border:1.5px dashed var(--line);background:var(--card);border-radius:16px;color:var(--ink-soft);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;font-size:15px;font-weight:600;cursor:pointer}.empty-photo:disabled{opacity:.6}.head-add{width:32px;height:32px;border-radius:50%;border:none;background:none;color:var(--clay-dark);display:grid;place-items:center;cursor:pointer}.head-add:active{color:var(--clay)}.head-add:disabled{opacity:.5}.new-project-close{width:34px;height:34px;border-radius:50%;border:none;background:var(--paper-2);color:var(--ink-soft);display:grid;place-items:center;cursor:pointer;flex-shrink:0}.new-project-close:active{background:var(--line);color:var(--ink)}.uploading-note{font-size:13px;color:var(--clay-dark);margin:0 0 14px}.sheet-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191666;z-index:40}.action-sheet{position:fixed;left:8px;right:8px;bottom:calc(var(--safe-bottom) + 8px);z-index:41;display:flex;flex-direction:column;gap:1px;background:var(--line);border-radius:16px;overflow:hidden;box-shadow:0 -8px 30px #00000040}.action-row{display:flex;align-items:center;justify-content:center;gap:10px;min-height:56px;border:none;background:var(--card);color:var(--clay-dark);font-size:16px;font-weight:600;cursor:pointer}.action-row.generate{color:#6a4fb0}.action-row.cancel{color:var(--ink-soft);margin-top:6px;border-radius:16px}.empty-photo.generating{cursor:default;color:var(--clay-dark)}.empty-photo.generating .spinner{margin:0}.pin-editor-head{display:flex;align-items:center;gap:8px}.count-badge{min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--clay-soft);color:var(--clay-dark);font-family:var(--font-sans);font-size:12px;font-weight:700;display:grid;place-items:center}.notes-wrap{flex:1;position:relative;display:flex;flex-direction:column}.notes-area{flex:1;min-height:160px;resize:none}.notes-clear{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--muted);border:none;color:#fff;font-size:16px;line-height:1;display:grid;place-items:center;cursor:pointer;opacity:.6}.notes-clear:active{opacity:1}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.pinnable{margin-bottom:0}.stage{text-align:center}.imgwrap{position:relative;display:block;width:100%;height:var(--photo-h);line-height:0;border-radius:16px;overflow:hidden;background:var(--paper-2);box-shadow:var(--shadow);cursor:crosshair;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.imgwrap img{display:block;width:100%;height:100%;object-fit:cover;object-position:center center;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-user-drag:none;pointer-events:none}.photo-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000eb;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.photo-fullscreen img{max-width:100%;max-height:100%;object-fit:contain;object-position:center center;border-radius:8px;cursor:default}.fullscreen-close{position:absolute;top:16px;right:16px;background:#ffffff26;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;cursor:pointer}.pin{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;border:2.5px solid #fff;background:var(--clay);color:#fff;font-size:14px;font-weight:800;line-height:1;display:grid;place-items:center;cursor:pointer;box-shadow:0 2px 8px #00000073;z-index:2}.pin:after{content:"";position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;border:2px solid rgba(255,255,255,.55);opacity:0;animation:halo 2.4s ease-out infinite}@keyframes halo{0%{opacity:.7;transform:scale(.6)}70%{opacity:0;transform:scale(1.25)}to{opacity:0}}.pin.active{background:var(--clay-dark);transform:translate(-50%,-50%) scale(1.18)}.pin.active:after{animation:none}.pin.draft{background:#fff;color:var(--clay-dark);border-color:var(--clay);animation:pop .15s ease}.pin.draft:after{animation:none}@keyframes pop{0%{transform:translate(-50%,-50%) scale(.4)}}.pin-cue{position:absolute;left:50%;bottom:10px;transform:translate(-50%);white-space:nowrap;background:#1c1916b8;color:#fff;font-size:12px;font-weight:600;line-height:1.2;padding:7px 12px;border-radius:999px;z-index:2;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stage-trash{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;border:none;background:#fff;color:#c0492a;display:grid;place-items:center;cursor:pointer;z-index:3;box-shadow:0 2px 8px #00000047}.stage-trash:active{background:#fbeae5}.photo-download{position:absolute;bottom:10px;right:10px;width:36px;height:36px;border-radius:50%;border:none;background:#fff;color:var(--ink);display:grid;place-items:center;cursor:pointer;z-index:3;box-shadow:0 2px 8px #00000047}.photo-download:active{background:var(--paper-2)}.photo-edit-ai{position:absolute;bottom:10px;left:10px;width:36px;height:36px;border-radius:50%;border:none;background:#fff;color:var(--clay);display:grid;place-items:center;cursor:pointer;z-index:3;box-shadow:0 2px 8px #00000047}.photo-edit-ai:active{background:var(--clay-soft)}.gen-drawer{max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px;position:relative}.gen-preview-img-wrap img{width:100%;border-radius:12px;object-fit:contain;max-height:40vh;background:var(--paper-2);display:block}.img-counter{position:absolute;top:10px;left:10px;background:#1c191699;color:#fff;font-size:12px;font-weight:700;line-height:1;white-space:nowrap;padding:6px 12px;border-radius:999px;z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.img-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;border:none;background:#1c191680;color:#fff;display:grid;place-items:center;cursor:pointer;z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.img-nav:active{background:#1c1916c7}.img-nav.prev{left:8px}.img-nav.next{right:8px}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191673;z-index:45;animation:fade .15s ease}@keyframes fade{0%{opacity:0}}.pin-drawer{position:fixed;left:0;right:0;bottom:0;z-index:46;background:var(--card);border-top-left-radius:22px;border-top-right-radius:22px;padding:10px 18px calc(var(--safe-bottom) + 18px);box-shadow:0 -10px 30px #00000047;animation:slide-up .2s ease}@keyframes slide-up{0%{transform:translateY(100%)}}.drawer-grip{display:block;width:40px;height:4px;border-radius:2px;background:var(--line);margin:0 auto 14px}.drawer-handle{display:flex;justify-content:center;align-items:center;padding:8px 0 12px;margin:-8px 0 0;cursor:grab;touch-action:none}.drawer-handle:active{cursor:grabbing}.drawer-handle .drawer-grip{margin:0;width:48px;height:5px}.pin-editor-head{font-size:14px;font-weight:700;color:var(--clay-dark);margin-bottom:10px;display:flex;align-items:center;gap:4px}.pin-drawer textarea.input{min-height:130px;margin-bottom:14px}.pin-editor-actions{display:flex;gap:10px}.pin-editor-actions .btn{flex:1;min-height:42px;font-size:13px}.gen-time-hint{font-size:11px;color:var(--muted);font-weight:600;margin-left:6px}.gen-close-btn{margin-left:auto;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:none;color:var(--ink-soft);cursor:pointer;border-radius:50%;padding:0;flex-shrink:0}.gen-close-btn:hover,.gen-close-btn:active{background:var(--paper-2);color:var(--ink)}.gen-prompt-display{font-size:13px;color:var(--ink-soft);line-height:1.5;margin:0;text-align:center}.gen-back-link{display:inline-flex;align-items:center;gap:2px;background:none;border:none;color:var(--clay);font-size:13px;font-weight:600;cursor:pointer;padding:0 0 6px;font-family:inherit}.gen-prompt-tools{display:flex;justify-content:center;margin:10px 0 12px}.gen-mic-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;min-height:38px;border-radius:20px;border:1.5px solid var(--line);background:var(--card);color:var(--clay-dark);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer}.gen-mic-btn:disabled{opacity:.6;cursor:default}.gen-mic-btn.recording{border-color:#d9534f;color:#d9534f;background:#d9534f14}.gen-mic-btn .mic-dot{width:10px;height:10px;border-radius:50%;background:#d9534f;animation:mic-pulse 1.1s ease-in-out infinite}@keyframes mic-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.spinner.mic-spinner{width:14px;height:14px;border-width:2px}.gen-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#2b272273;display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:10}.gen-confirm-sheet{background:var(--card);border-radius:16px;padding:22px 20px 18px;margin:20px;text-align:center}.gen-confirm-title{font-size:15px;font-weight:700;color:var(--ink);margin:0 0 6px}.gen-confirm-sub{font-size:13px;color:var(--ink-soft);margin:0 0 18px}.gen-img-download{position:absolute;top:8px;right:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#00000073;border:none;border-radius:8px;color:#fff;cursor:pointer;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.gen-img-download:active{background:#000000a6}.gen-preview-img-wrap{width:100%;position:relative}.gen-history-nav{display:flex;align-items:center;justify-content:center;gap:16px}.gen-history-arrow{background:none;border:1.5px solid var(--line);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-soft);padding:0}.gen-history-arrow:disabled{opacity:.3;cursor:default}.gen-history-counter{font-size:13px;color:var(--muted);font-weight:500;min-width:40px;text-align:center}.gen-preview-prompt{font-size:12px;color:var(--muted);margin:6px 0 10px;line-height:1.4;text-align:center}.gen-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px 0 20px}.gen-spinner{width:36px;height:36px;border-width:3px;margin:0}.gen-loading-text{font-size:15px;font-weight:600;color:var(--clay-dark);margin:0}.gen-loading-sub{font-size:12px;color:var(--muted);margin:0}.tile-list{display:flex;flex-direction:column;gap:10px;padding:4px 0 0}.tile-card{width:100%;text-align:left;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;cursor:pointer;display:flex;align-items:flex-start;gap:14px;box-shadow:var(--shadow);transition:transform .08s ease;-webkit-tap-highlight-color:transparent;position:relative}.tile-card:active{transform:scale(.99)}.tile-card-name{font-size:15px;font-weight:700;color:var(--ink)}.tile-card-layers{display:flex;flex-direction:column;gap:5px}.tile-card-layer-row{display:flex;align-items:center;gap:8px}.tile-coat-count{font-size:12px;color:var(--ink-soft);white-space:nowrap}.tile-layer-chip{font-size:12px;font-weight:600;background:var(--clay-soft);color:var(--clay-dark);border-radius:20px;padding:3px 10px}.tile-card-empty{font-size:12px;color:var(--muted)}.tile-card-projects{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}.tile-project-pill{font-size:11px;font-weight:600;background:var(--paper-2);color:var(--ink-soft);border-radius:20px;padding:2px 8px}.tile-drawer{height:92vh;overflow:hidden;display:flex;flex-direction:column}.tile-drawer-scroll{flex:1;overflow-y:auto;padding-bottom:4px}.tile-section-label{font-size:12px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.tile-label-hint{font-weight:400;text-transform:none;letter-spacing:0;margin-left:8px}.layers-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;-webkit-user-select:none;user-select:none}.layer-item{padding:6px 0;transition:transform .18s ease,box-shadow .18s ease}.layer-item+.layer-item{border-top:1px solid rgba(0,0,0,.07)}.layer-item.layer-dragging{transition:box-shadow .18s ease}.layer-row{display:flex;align-items:center;gap:10px;padding:0 4px 0 0}.layer-drag-handle{width:22px;height:38px;border:none;background:none;color:var(--muted);display:grid;place-items:center;cursor:grab;flex-shrink:0;touch-action:none;padding:0}.layer-drag-handle:active{cursor:grabbing;color:var(--ink-soft)}.layer-glaze-input{flex:1;min-width:0;height:36px;padding:0 10px;font-size:14px}.layer-count-ctrl{display:flex;align-items:center;gap:10px;flex-shrink:0}.layer-count-btn{width:28px;height:28px;border:1.5px solid var(--line);border-radius:50%;background:var(--card);color:var(--ink);font-size:16px;line-height:1;display:grid;place-items:center;cursor:pointer;padding:0}.layer-count-btn:disabled{opacity:.3;cursor:default}.layer-count-val{font-size:13px;font-weight:600;color:var(--ink);min-width:44px;text-align:center;white-space:nowrap}.layer-remove-btn{width:28px;height:28px;border:none;background:none;color:var(--muted);font-size:18px;line-height:1;display:grid;place-items:center;cursor:pointer;flex-shrink:0;border-radius:50%;padding:0}.layer-remove-btn:active{color:#c0492a;background:#fbeae5}.tile-add-layer-btn{display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:flex-start;width:38px;height:38px;min-width:38px;min-height:38px;margin:6px 0 24px;border:1.5px dashed var(--line);border-radius:50%;background:none;color:var(--clay);cursor:pointer;padding:0;transition:background .12s,border-color .12s}.tile-add-layer-btn:active{background:var(--clay-soft);border-color:var(--clay)}.tile-drawer-actions{flex-shrink:0;border-top:1px solid var(--line);padding-top:14px;margin-top:4px}.tile-drawer-actions .btn{flex:1}.tile-project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.tile-project-tag{font-size:13px;font-weight:600;padding:6px 14px;border-radius:20px;border:1.5px solid var(--line);background:var(--card);color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.tile-project-tag.active{background:var(--clay-soft);color:var(--clay-dark);border-color:var(--clay)}.tile-project-tag:active{opacity:.75}.tile-card-cover{flex:0 0 auto;width:80px;height:80px;border-radius:12px;background:linear-gradient(135deg,var(--clay-soft),var(--paper-2));overflow:hidden;display:flex;align-items:center;justify-content:center}.tile-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.tile-card-cover-letter{font-family:var(--font-serif);font-size:26px;color:var(--clay-dark);opacity:.5;-webkit-user-select:none;user-select:none}.tile-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.tile-card-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tile-card-num{font-size:15px;font-weight:500;color:var(--ink)}.tile-card-type{font-size:12px;font-weight:600;color:var(--clay-dark);background:var(--clay-soft);border-radius:20px;padding:2px 8px}.tile-photo-area{width:100%;height:auto;min-height:180px;max-height:40vh;border-radius:12px;border:2px dashed var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;margin-bottom:12px;overflow:hidden;position:relative;background:var(--paper-2);flex-shrink:0}.tile-photo-area.has-photo{border-style:solid;border-color:transparent}.tile-photo-area:active{opacity:.8}.tile-photo-img{width:100%;height:100%;min-height:180px;max-height:40vh;object-fit:cover;display:block}.tile-photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--muted)}.tile-photo-placeholder span{font-size:13px;font-weight:600}.tile-photo-remove{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:16px;line-height:1;display:grid;place-items:center;cursor:pointer;z-index:2}.tile-name-input{margin-bottom:10px}.input-error{border-color:#c0492a!important;background:#fff8f6!important}.field-error{font-size:12px;color:#c0492a;margin:0 0 10px;padding-left:2px}.project-tiles-bar{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-top:16px;background:var(--paper-2);border-radius:12px}.project-tiles-summary{flex:1;min-width:0;display:flex;align-items:center;gap:8px;color:var(--clay-dark)}.project-tiles-empty{font-size:13px;color:var(--muted)}.project-tiles-chips{display:flex;flex-wrap:wrap;gap:5px;min-width:0}.project-tiles-edit{flex-shrink:0;min-height:34px;padding:0 14px;font-size:13px}.pin-drawer .project-tiles-bar{margin-top:0;margin-bottom:14px}.tile-tag-drawer{max-height:80vh;overflow-y:auto}.tile-tag-list{display:flex;flex-direction:column;gap:6px}.tile-tag-row{display:flex;align-items:center;gap:12px;padding:8px 10px;border:1.5px solid var(--line);border-radius:12px;background:var(--card);cursor:pointer;text-align:left;transition:border-color .12s,background .12s}.tile-tag-row.active{border-color:var(--clay);background:var(--clay-soft)}.tile-tag-thumb{width:52px;height:52px;border-radius:10px;object-fit:cover;flex-shrink:0;align-self:flex-start}.tile-tag-thumb.placeholder{display:grid;place-items:center;background:var(--paper-2);color:var(--muted)}.tile-tag-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.tile-tag-name{font-size:14px;font-weight:700;color:var(--ink)}.tile-tag-layers{display:flex;flex-direction:column;gap:5px}.tile-tag-layer-row{display:flex;align-items:center;gap:8px}.tile-tag-empty-layers{font-size:12px;color:var(--muted)}.tile-tag-check{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;color:#fff}.tile-tag-check.on{background:var(--clay);border-color:var(--clay)}.tile-tag-empty{text-align:center;padding:16px 0}.tile-tag-empty p{color:var(--muted);font-size:14px;margin:0 0 14px}.aigen-result{margin-bottom:18px}.aigen-result-imgwrap{position:relative;width:100%;border-radius:16px;overflow:hidden;background:var(--paper-2);box-shadow:var(--shadow);line-height:0}.aigen-result-imgwrap img{display:block;width:100%;aspect-ratio:1 / 1;object-fit:cover}.aigen-download{position:absolute;bottom:10px;right:10px;width:38px;height:38px;border-radius:50%;border:none;background:#fff;color:var(--ink);display:grid;place-items:center;cursor:pointer;box-shadow:0 2px 8px #00000047}.aigen-download:active{background:var(--paper-2)}.aigen-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin:12px 0 4px}.aigen-nav-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--line);background:var(--card);color:var(--ink-soft);display:grid;place-items:center;cursor:pointer;padding:0}.aigen-nav-btn:disabled{opacity:.3;cursor:default}.aigen-nav-counter{font-size:13px;font-weight:600;color:var(--muted);min-width:44px;text-align:center}.aigen-result-prompt{font-size:13px;color:var(--ink-soft);line-height:1.5;text-align:center;margin:10px 0 0}.aigen-composer{display:flex;flex-direction:column;gap:12px;margin-top:auto}.aigen-input-row{display:flex;gap:10px;align-items:flex-start}.aigen-ref{position:relative;flex-shrink:0;width:64px;height:64px;border-radius:12px;overflow:hidden;background:var(--paper-2)}.aigen-ref img{width:100%;height:100%;object-fit:cover;display:block}.aigen-ref-remove{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:14px;line-height:1;display:grid;place-items:center;cursor:pointer;padding:0}.aigen-textarea{flex:1;min-height:76px;resize:none}.aigen-actions{display:flex;gap:10px}.aigen-attach{display:inline-flex;align-items:center;gap:7px;flex-shrink:0}.aigen-generate{flex:1}.aigen-hint{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);text-align:center;padding:40px 0}.aigen-hint p{font-size:14px;margin:0}
