@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg:#f6f8f5;--surface:#fff;--surface-subtle:#f9faf8;--surface-muted:#f1f4f0;--ink:#141614;--text:#323730;--muted:#747b72;--faint:#a8aea5;--border:#e3e8df;--border-strong:#d1dacd;--green:#15983d;--green-dark:#087528;--green-soft:#e8f7ec;--green-ring:#15983d29;--danger:#bd4d35;--warning-bg:#fff7ed;--shadow-sm:0 1px 2px #1416140a;--shadow-md:0 14px 38px #14161414;--shadow-lg:0 24px 70px #1416141f;color:var(--ink);background:radial-gradient(circle at 12% 8%, #15983d14, transparent 26rem), linear-gradient(180deg, #fbfcfa 0%, var(--bg) 48%, #f2f5f0 100%);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Manrope,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled,select:disabled{cursor:not-allowed;opacity:.5}.app-shell{min-height:100vh;padding:20px}.topbar,.workspace,.page-shell{width:min(1680px,100%);margin:0 auto}.topbar{z-index:20;border:1px solid var(--border);min-height:68px;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffdb;border-radius:24px;grid-template-columns:180px 1fr auto;align-items:center;padding:0 20px;display:grid;position:sticky;top:14px}.brand{color:var(--green);letter-spacing:-.05em;font-size:21px;font-weight:800;line-height:1}.topnav{justify-content:center;align-items:center;gap:6px;display:flex}.ghost-button,.back-link{color:var(--muted);background:0 0;border:0;font-size:14px;font-weight:700}.ghost-button{border-radius:999px;min-height:38px;padding:0 14px}.ghost-button:hover{background:var(--surface-muted);color:var(--text)}.ghost-button.active{background:var(--ink);color:#fff}.top-actions{white-space:nowrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.toast-stack{z-index:80;pointer-events:none;gap:10px;width:min(420px,100vw - 32px);display:grid;position:fixed;top:118px;right:24px}.toast{border:1px solid var(--border);box-shadow:var(--shadow-md);color:var(--text);pointer-events:auto;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff5;border-radius:18px;grid-template-columns:1fr auto;align-items:start;gap:14px;padding:14px 14px 14px 16px;animation:.18s ease-out toast-in;display:grid}.toast strong{color:var(--ink);font-size:13px;font-weight:850;line-height:1.25;display:block}.toast p{color:var(--muted);margin:4px 0 0;font-size:13px;font-weight:700;line-height:1.45}.toast button{background:var(--surface-muted);width:28px;height:28px;color:var(--muted);border:0;border-radius:999px;justify-content:center;align-items:center;font-size:18px;line-height:1;display:inline-flex}.toast button:hover{background:var(--border);color:var(--ink)}.toast-error{background:#fff6f1fa;border-color:#bd4d3552}.toast-error strong{color:var(--danger)}.toast-warning{background:#fffaf4fa;border-color:#f0d7c5}.toast-success{background:#f8fffafa;border-color:#15983d42}.toast-success strong{color:var(--green-dark)}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.credits,.avatar{border-radius:999px;justify-content:center;align-items:center;min-height:34px;font-size:13px;font-weight:800;display:inline-flex}.credits{background:var(--surface-muted);color:var(--text);border:0;gap:5px;padding:0 12px}.credits.auth-entry,.credits.subscription-entry{cursor:pointer}.credits.auth-entry:hover,.credits.subscription-entry:hover{background:var(--green-soft);color:var(--green-dark)}.credits img{width:16px;height:16px;display:block}.avatar{border:1px solid var(--border-strong);width:38px;height:38px;color:var(--muted);background:#fff;padding:0;overflow:hidden}.avatar.active,.avatar:hover{border-color:var(--green);color:var(--green-dark);background:var(--green-soft)}.avatar.with-image{background:#fff}.avatar img{object-fit:cover;width:100%;height:100%;display:block}.profile-menu{position:relative}.profile-dropdown{z-index:40;border:1px solid var(--border);width:220px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff5;border-radius:18px;gap:6px;padding:8px;display:grid;position:absolute;top:calc(100% + 10px);right:0}.profile-dropdown button{min-height:40px;color:var(--text);text-align:left;background:0 0;border:0;border-radius:12px;padding:0 12px;font-size:12px;font-weight:900}.profile-dropdown button:hover{background:var(--surface-muted)}.profile-dropdown .subscription-item{background:var(--green-soft);color:var(--green-dark)}.profile-dropdown .danger-item{color:var(--danger)}.page-shell{min-height:calc(100vh - 112px);padding-top:18px}.page-card{border:1px solid var(--border);min-height:calc(100vh - 130px);box-shadow:var(--shadow-md);background:#ffffffeb;border-radius:28px;padding:32px}.page-head{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:26px;display:flex}.page-head span{color:var(--green);text-transform:uppercase;font-size:13px;font-weight:900}.page-head h1{color:var(--ink);letter-spacing:-.06em;margin:8px 0 0;font-size:clamp(32px,4vw,56px);font-weight:800;line-height:.98}.page-head p{max-width:560px;color:var(--muted);margin:12px 0 0;font-size:15px;font-weight:650;line-height:1.45}.project-grid{grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px;display:grid}.project-card,.profile-card,.empty-state{border:1px solid var(--border);background:var(--surface-subtle);border-radius:22px;padding:18px}.project-card{cursor:pointer;grid-template-columns:112px minmax(0,1fr);gap:16px;min-height:190px;transition:border-color .18s,box-shadow .18s,transform .18s,background .18s;display:grid;position:relative}.project-card:hover,.project-card:focus-visible{background:#fff;border-color:#15983d5c;outline:none;transform:translateY(-1px);box-shadow:0 18px 40px #1a231d14}.project-card.is-busy{pointer-events:none;opacity:.72}.project-preview{border:1px solid var(--border);background:var(--surface-muted);border-radius:18px;width:112px;height:112px;display:grid;overflow:hidden}.project-preview img{object-fit:cover;width:100%;min-width:0;height:100%;min-height:0;display:block}.project-preview.count-1{grid-template-columns:1fr}.project-preview.count-2,.project-preview.count-3{grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:1.15fr .85fr;gap:2px}.project-preview.count-2 img:first-child,.project-preview.count-3 img:first-child,.project-preview.count-2 img:nth-child(2){grid-row:1/3}.project-preview.empty{color:var(--green);letter-spacing:-.05em;place-items:center;font-size:18px;font-weight:900}.project-card-body{min-width:0;padding:2px 0 28px;position:relative}.project-card-top{justify-content:space-between;min-height:32px;display:flex}.project-status-wrap{z-index:3;position:relative}.project-status{background:var(--green-soft);color:var(--green-dark);text-transform:uppercase;border:0;border-radius:999px;align-items:center;gap:4px;padding:5px 9px;font-size:11px;font-weight:900;display:inline-flex}.project-status:hover{background:#dff3e8}.project-status.status-archived{color:#716b5f;background:#f0eee6}.project-status-dropdown{border:1px solid var(--border);width:132px;box-shadow:var(--shadow-lg);background:#fff;border-radius:14px;gap:4px;padding:6px;display:grid;position:absolute;top:calc(100% + 6px);left:0}.project-status-dropdown button{min-height:34px;color:var(--text);text-align:left;background:0 0;border:0;border-radius:10px;padding:0 10px;font-size:12px;font-weight:850}.project-status-dropdown button:hover,.project-status-dropdown button.selected{background:var(--green-soft);color:var(--green-dark)}.project-title-row{align-items:center;gap:8px;min-width:0;margin-top:14px;display:flex}.project-card h2,.empty-state strong{color:var(--ink);letter-spacing:-.04em;margin:0;font-size:22px;font-weight:900}.empty-state strong{margin-top:18px}.project-title-row h2{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.project-title-row input{border:1px solid var(--border-strong);width:min(100%,260px);min-width:0;height:42px;color:var(--ink);letter-spacing:-.03em;background:#fff;border-radius:12px;padding:0 12px;font-size:17px;font-weight:900}.project-rename-button,.project-title-action,.project-title-cancel{background:var(--surface-muted);min-height:32px;color:var(--muted);border:0;border-radius:999px;flex:none;padding:0 10px;font-size:11px;font-weight:900}.project-rename-button{opacity:0;transition:opacity .16s,transform .16s;transform:translate(-4px)}.project-card:hover .project-rename-button,.project-rename-button:focus-visible{opacity:1;transform:translate(0)}.project-title-action{background:var(--green);color:#fff}.project-title-cancel{width:32px;padding:0}.project-card p,.empty-state p,.profile-card p{color:var(--muted);margin:8px 0 0;font-size:13px;font-weight:650;line-height:1.45}.project-card .project-date{color:var(--faint);margin:0;font-size:11px;font-weight:800;position:absolute;bottom:0;right:0}.project-open-cue{color:var(--green);opacity:0;font-size:12px;font-weight:900;transition:opacity .16s,transform .16s;position:absolute;bottom:0;left:0;transform:translateY(4px)}.project-card:hover .project-open-cue,.project-card:focus-visible .project-open-cue{opacity:1;transform:translateY(0)}.empty-state{text-align:center;place-items:center;min-height:360px;display:grid}.empty-state p{max-width:420px}.projects-auth-state{background:linear-gradient(135deg, #15983d12, #ffffffd6), var(--surface-subtle);text-align:left;align-content:center;place-items:stretch stretch;gap:18px;min-height:270px;padding:28px}.projects-auth-state p{max-width:760px;color:var(--text);letter-spacing:-.04em;margin:0;font-size:clamp(20px,2vw,30px);font-weight:850;line-height:1.18}.empty-state-action{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding-top:14px;display:flex}.empty-state-action strong{color:var(--muted);letter-spacing:0;margin:0;font-size:15px}.empty-state-action .more-button{border:1px solid var(--green);min-height:44px;color:var(--green-dark);box-shadow:none;background:#fff;border-radius:999px}.empty-state-action .more-button:hover{background:var(--green);color:#fff}.profile-grid{grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px;display:grid}.profile-card{gap:10px;min-height:180px;display:grid}.profile-card-actions{background:#fff}.profile-card span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:900}.profile-card strong{color:var(--ink);letter-spacing:-.04em;align-items:center;gap:8px;font-size:24px;font-weight:900;display:inline-flex}.profile-card strong img{width:24px;height:24px}.profile-user-row{align-items:center;gap:12px;display:flex}.profile-user-row p{margin-top:4px}.profile-avatar{object-fit:cover;border:1px solid var(--border-strong);background:#fff;border-radius:18px;flex:0 0 56px;width:56px;height:56px}.profile-avatar.fallback{color:var(--green-dark);background:var(--green-soft);justify-content:center;align-items:center;font-size:14px;display:inline-flex}.profile-action{cursor:pointer;border-radius:14px;width:100%;min-height:44px;margin-top:auto;font-size:13px;font-weight:900}.profile-action.primary{border:1px solid var(--green);background:var(--green);color:#fff;box-shadow:0 8px 16px #15983d1a}.profile-action.primary:hover{background:var(--green-dark)}.profile-action.danger{color:#a63a24;background:#fff6f3;border:1px solid #c8462d3d}.profile-action.danger:hover{background:#ffe9e1;border-color:#c8462d5c}.payment-result-shell{justify-content:center;align-items:center;display:flex}.payment-result-card{width:min(760px,100%);min-height:0;padding:34px}.payment-result-copy{gap:12px;display:grid}.payment-result-kicker{background:var(--green-soft);width:fit-content;color:var(--green-dark);text-transform:uppercase;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900}.payment-result-card.is-fail .payment-result-kicker{color:#a63a24;background:#fff4ef}.payment-result-copy h1{color:var(--ink);letter-spacing:-.06em;margin:0;font-size:clamp(34px,5vw,64px);font-weight:900;line-height:.96}.payment-result-copy p{max-width:560px;color:var(--muted);margin:0;font-size:17px;font-weight:750;line-height:1.42}.payment-result-details{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:28px;display:grid}.payment-result-details div{border:1px solid var(--border);background:var(--surface-subtle);border-radius:16px;padding:14px}.payment-result-details span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:850;display:block}.payment-result-details strong{color:var(--ink);margin-top:8px;font-size:18px;font-weight:900;line-height:1.1;display:block}.payment-result-note{color:var(--muted);margin:18px 0 0;font-size:14px;font-weight:750}.payment-result-note.is-error{color:#a63a24}.payment-result-actions{flex-wrap:wrap;gap:10px;margin-top:28px;display:flex}.payment-result-actions .more-button{justify-content:center;align-items:center;min-width:210px;display:inline-flex}.payment-result-actions .more-button.primary{border-color:var(--green);background:var(--green);color:#fff}.payment-result-actions .more-button.primary:hover{background:var(--green-dark)}@media (width<=760px){.payment-result-card{padding:24px}.payment-result-details{grid-template-columns:repeat(2,minmax(0,1fr))}.payment-result-actions .more-button{width:100%}}.workspace{grid-template-columns:392px minmax(0,1fr);gap:18px;min-height:calc(100vh - 112px);padding-top:18px;display:grid}.settings-panel,.results-panel{border:1px solid var(--border);box-shadow:var(--shadow-md);background:#ffffffeb;border-radius:28px}.settings-panel{max-height:calc(100vh - 116px);padding:18px 18px 0;position:sticky;top:100px;overflow:auto}.panel-section{border-bottom:1px solid var(--border);margin-bottom:20px;padding:0 0 20px}.panel-section:last-of-type{border-bottom:0}.panel-section.is-disabled{opacity:.38}.panel-section.is-disabled,.panel-section.is-disabled *{cursor:not-allowed}.panel-section.is-disabled .selected{border-color:var(--border-strong);background:var(--surface);color:var(--muted);box-shadow:none}.panel-section.is-disabled .radio-list button.selected .radio-dot{border:1px solid var(--border-strong)}button:disabled,input:disabled,select:disabled,textarea:disabled{cursor:not-allowed}.field-stack input:disabled,.field-stack select:disabled,textarea:disabled{background:var(--surface-muted);color:var(--muted)}.upload-box.is-disabled,.photo-tile.is-disabled,.small-button.is-disabled{cursor:not-allowed}.upload-box button:disabled,.photo-tile button:disabled,.mini-upload-remove:disabled{opacity:.55;pointer-events:none}.section-title{color:var(--ink);letter-spacing:.02em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;font-weight:800;display:flex}.inline-actions,.settings-group{align-items:center;gap:10px;display:flex}.field-stack input,.field-stack select,textarea{border:1px solid var(--border-strong);background:var(--surface);width:100%;min-height:44px;color:var(--ink);border-radius:14px;outline:none;padding:10px 12px;transition:border-color .16s,box-shadow .16s,background-color .16s}.field-stack input:focus,.field-stack select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px var(--green-ring)}.field-stack input.is-invalid,textarea.is-invalid,.upload-box.is-invalid{border-color:var(--danger);background:#fff8f6;box-shadow:0 0 0 4px #c4392a1f}.field-stack input.is-invalid:focus,textarea.is-invalid:focus{border-color:var(--danger);box-shadow:0 0 0 4px #c4392a29}.upload-box.empty.is-invalid:hover{border-color:var(--danger);color:var(--danger);background:#fff8f6}.small-button{border:1px solid var(--border-strong);background:var(--surface);min-height:42px;color:var(--text);border-radius:14px;flex-shrink:0;padding:0 12px;font-size:13px;font-weight:800}.small-button:hover{border-color:var(--green);color:var(--green-dark)}.upload-box{aspect-ratio:1;border:1px solid var(--border-strong);background:var(--surface-muted);border-radius:24px;justify-content:center;align-items:center;width:min(100%,340px);margin-bottom:14px;display:flex;position:relative;overflow:hidden}.upload-box.empty{cursor:pointer;color:var(--muted);text-align:center;border-style:dashed;flex-direction:column;gap:8px}.upload-box.empty:hover{border-color:var(--green);background:var(--green-soft);color:var(--green-dark)}.upload-box input,.file-button input,.add-photo-button input,.mini-upload input,.photo-tile input{opacity:0;pointer-events:none;position:absolute}.upload-plus{width:56px;height:56px;color:var(--green);box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:36px;font-weight:600;display:inline-flex}.upload-box strong{color:var(--text);font-size:15px;font-weight:900}.upload-box small{max-width:210px;color:var(--muted);font-size:12px;line-height:1.35}.upload-box img{object-fit:cover;width:100%;height:100%;transition:filter .18s;display:block}.upload-box.filled{cursor:pointer}.upload-box.analyzing img{filter:saturate(.9)brightness(.72)}.upload-box button{z-index:4;color:#fff;background:#141614b8;border:0;border-radius:50%;width:34px;height:34px;font-size:18px;line-height:1;position:absolute;top:10px;right:10px}.upload-box.filled>span{z-index:3;color:var(--green-dark);background:#ffffffe0;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:800;position:absolute;bottom:12px;left:12px}.upload-box.filled>em{z-index:3;color:#fff;opacity:0;background:#141614b3;border-radius:999px;padding:6px 10px;font-size:11px;font-style:normal;font-weight:800;transition:opacity .16s,transform .16s;position:absolute;bottom:12px;right:12px;transform:translateY(4px)}.upload-box.filled:hover>em{opacity:1;transform:translateY(0)}.upload-box.analyzing>em{opacity:0;transform:translateY(4px)}.analysis-overlay{z-index:2;color:#fff;text-align:center;pointer-events:none;background:radial-gradient(circle at 50% 44%,#ffffff2e,#0000 34%),linear-gradient(#111c161f,#111c168a);flex-direction:column;justify-content:center;align-items:center;gap:9px;padding:24px;display:flex;position:absolute;inset:0}.analysis-overlay strong{color:#fff;font-size:17px;font-weight:900}.analysis-overlay small{color:#ffffffd1;max-width:230px;font-size:12px}.analysis-spinner{border:3px solid #fff;border-color:#fff #fff #ffffff57 #ffffff57;border-radius:50%;width:46px;height:46px;animation:.78s linear infinite spin}.upload-box.error>span{color:var(--danger)}.photo-grid{aspect-ratio:1;grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:min(100%,340px);margin-bottom:14px;display:grid}.photo-tile{border:1px dashed var(--border-strong);background:var(--surface-muted);min-width:0;color:var(--muted);cursor:pointer;border-radius:18px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.photo-tile:hover{border-color:var(--green);background:var(--green-soft);color:var(--green-dark)}.photo-tile.filled{background:var(--surface-subtle);border-style:solid}.photo-tile img{object-fit:cover;width:100%;height:100%;transition:filter .18s;display:block}.photo-tile.analyzing img{filter:saturate(.88)brightness(.74)}.photo-tile button{z-index:2;color:#fff;background:#141614b3;border:0;border-radius:50%;width:28px;height:28px;font-size:16px;line-height:1;position:absolute;top:8px;right:8px}.photo-tile.filled>span{z-index:2;width:26px;height:26px;color:var(--green-dark);background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:900;display:inline-flex;position:absolute;bottom:8px;left:8px}.photo-tile.filled>.photo-tile-loader{border:3px solid #ffffff73;border-top-color:var(--green);border-right-color:var(--green);background:#ffffffdb;width:28px;height:28px;animation:.78s linear infinite spin}.photo-tile.empty>span{font-size:30px;font-weight:700}.file-button{justify-content:center;align-items:center;display:flex;position:relative}.photo-actions{grid-template-columns:1fr auto;align-items:center;gap:10px;margin-bottom:10px;display:grid}.photo-actions span{color:var(--muted);font-size:12px;font-weight:700}.add-photo-button{cursor:pointer;text-align:center;justify-content:center;align-items:center;width:100%;min-height:46px;display:inline-flex;position:relative}.add-photo-button span{color:inherit;font-size:inherit;font-weight:inherit;line-height:1}.small-button.is-disabled,.small-button:disabled{opacity:.45;pointer-events:none}.clear-button{width:100%;margin-top:12px}.field-stack{gap:10px;display:grid}.analysis-fields{pointer-events:none}.analysis-field-placeholder{border:1px solid var(--border);background:linear-gradient(90deg, #fff0 0%, #ffffffb8 50%, #fff0 100%), var(--surface-muted);min-height:58px;color:var(--muted);background-size:220% 100%,100% 100%;border-radius:18px;align-items:center;padding:0 22px;font-size:14px;font-weight:850;animation:1.35s ease-in-out infinite field-shimmer;display:flex}.field-stack small,.inline-actions span,.warning-line,.settings-group>span,.result-card footer small,.generate-footer small{color:var(--muted);font-size:12px;line-height:1.45}.inline-actions{justify-content:space-between;align-items:start;gap:12px;margin-top:12px;display:flex}.segmented{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.segmented.three{grid-template-columns:repeat(3,minmax(0,1fr))}.segmented button,.ratio-grid button,.radio-list button{border:1px solid var(--border-strong);background:var(--surface);color:var(--muted);font-size:13px;font-weight:800;transition:border-color .16s,color .16s,background-color .16s,box-shadow .16s}.segmented button,.ratio-grid button{border-radius:14px;min-height:42px;padding:8px 10px}.segmented button:hover,.ratio-grid button:hover,.radio-list button:hover{border-color:var(--green);color:var(--green-dark)}.segmented button.selected,.ratio-grid button.selected,.radio-list button.selected{border-color:var(--green);background:var(--green-soft);color:var(--green-dark);box-shadow:0 0 0 3px var(--green-ring)}.segmented button.is-disabled,.segmented button.is-disabled:hover{border-color:var(--border-strong);background:var(--surface-muted);color:var(--faint);box-shadow:none;cursor:not-allowed}.warning-line,.danger{color:var(--danger)!important}.radio-list{gap:8px;display:grid}.radio-list button{text-align:left;border-radius:16px;grid-template-columns:54px 18px 1fr;grid-template-areas:"icon dot title""icon dot hint";align-items:center;gap:2px 10px;width:100%;padding:12px;display:grid}.scenario-icon{object-fit:cover;background:var(--surface-muted);border-radius:12px;grid-area:icon;width:48px;height:48px;display:block}.scenario-icon.fallback{color:var(--faint);justify-content:center;align-items:center;font-size:20px;display:inline-flex}.radio-dot{border:1px solid var(--border-strong);background:#fff;border-radius:50%;grid-area:dot;width:16px;height:16px}.radio-list button.selected .radio-dot{border:4px solid var(--green)}.radio-list strong{grid-area:title;font-size:13px}.radio-list small{color:var(--muted);grid-area:hint;font-size:11px;font-weight:600}textarea{resize:vertical;min-height:124px;line-height:1.5}textarea::placeholder{color:var(--faint)}.ai-assistant{position:relative}.ai-menu{z-index:25;border:1px solid var(--border);background:#fff;border-radius:16px;gap:8px;width:250px;padding:10px;display:grid;position:fixed;box-shadow:0 8px 18px #14161414}.ai-menu p{color:var(--muted);margin:0;font-size:12px;font-weight:700;line-height:1.35}.ai-menu button,.quiz-head button,.quiz-question button{background:var(--surface-muted);color:var(--text);text-align:left;border:0;border-radius:10px;padding:8px 10px;font-size:11px;font-weight:800}.ai-menu button{justify-content:center;align-items:center;min-height:42px;line-height:1.25;transition:border-color .18s,background .18s,transform .18s;display:flex}.ai-menu-primary{box-shadow:0 6px 14px #15983d24;background:var(--green)!important;color:#fff!important}.ai-menu-secondary{border:1px solid var(--border-strong)!important;background:#fff!important}.ai-menu button:hover{transform:translateY(-1px)}.ai-menu button:hover,.quiz-head button:hover,.quiz-question button:hover,.quiz-question button.selected{background:var(--green-soft);color:var(--green-dark)}.ai-menu-primary:hover{background:var(--green-dark)!important;color:#fff!important}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1416142e;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.quiz-modal{border:1px solid var(--border);width:min(680px,100%);max-height:min(760px,100vh - 48px);box-shadow:var(--shadow-lg);background:#fff;border-radius:28px;padding:24px;animation:.18s both modal-in;overflow:auto}.auth-modal{border:1px solid var(--border);width:min(860px,100%);min-height:560px;box-shadow:var(--shadow-lg);background:#fff;border-radius:30px;grid-template-columns:.9fr 1.1fr;animation:.18s both modal-in;display:grid;position:relative;overflow:hidden}.paywall-modal{border:1px solid var(--border);width:min(820px,100%);max-height:min(760px,100vh - 48px);box-shadow:var(--shadow-lg);background:#fff;border-radius:30px;padding:28px;animation:.18s both modal-in;position:relative;overflow:auto}.auth-close{z-index:2;width:38px;height:38px;color:var(--muted);box-shadow:var(--shadow-sm);background:#ffffffd1;border:0;border-radius:50%;font-size:22px;font-weight:700;position:absolute;top:18px;right:18px}.auth-close:hover{color:var(--ink);background:#fff}.auth-visual{color:#fff;background:linear-gradient(145deg,#13943d 0%,#0d7832 48%,#092715 100%);flex-direction:column;justify-content:space-between;gap:24px;padding:32px;display:flex}.auth-visual>span{letter-spacing:-.04em;background:#ffffff29;border-radius:999px;width:fit-content;padding:8px 12px;font-size:13px;font-weight:900}.auth-visual h2{letter-spacing:-.07em;margin:auto 0 0;font-size:38px;font-weight:900;line-height:.96}.auth-visual p{color:#ffffffc7;margin:0;font-size:14px;font-weight:650;line-height:1.45}.auth-visual ul{gap:10px;margin:0;padding:0;list-style:none;display:grid}.auth-visual li{color:#ffffffdb;align-items:center;gap:9px;font-size:13px;font-weight:800;display:flex}.auth-visual li:before{content:"";background:#fff;border-radius:50%;width:8px;height:8px}.auth-content{flex-direction:column;justify-content:center;padding:38px 42px;display:flex}.auth-head{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.auth-head strong{color:var(--ink);letter-spacing:-.06em;font-size:30px;font-weight:900}.auth-head p{color:var(--muted);margin:8px 0 0;font-size:13px;font-weight:650;line-height:1.45}.auth-stack{gap:14px;margin-top:26px;display:grid}.auth-google,.auth-form input,.auth-submit{border:1px solid var(--border-strong);border-radius:16px;width:100%;min-height:52px;font-size:14px;font-weight:900}.auth-google{color:var(--ink);box-shadow:var(--shadow-sm);background:#fff;justify-content:center;align-items:center;gap:10px;display:inline-flex}.auth-google:hover{border-color:var(--green);color:var(--green-dark)}.google-mark{flex:0 0 24px;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex}.google-mark svg{width:22px;height:22px;display:block}.auth-divider{color:var(--muted);justify-content:center;font-size:12px;font-weight:800;display:flex;position:relative}.auth-divider:before{content:"";background:var(--border);height:1px;position:absolute;top:50%;left:0;right:0}.auth-divider span{z-index:1;background:#fff;padding:0 10px;position:relative}.auth-form{gap:12px;display:grid}.auth-form label{gap:7px;display:grid}.auth-form label span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:900}.auth-form input{background:var(--surface);color:var(--ink);outline:none;padding:12px 14px}.auth-form input:focus{border-color:var(--green);box-shadow:0 0 0 4px var(--green-ring)}.auth-submit{background:var(--green);color:#fff;border:0;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 8px 14px #15983d1f}.auth-submit:hover{background:var(--green-dark)}.paywall-head{max-width:560px;padding-right:48px}.paywall-head span{color:var(--green-dark);text-transform:uppercase;font-size:12px;font-weight:900}.paywall-head strong{color:var(--ink);letter-spacing:-.07em;margin-top:8px;font-size:clamp(30px,4vw,48px);font-weight:900;line-height:.98;display:block}.paywall-head p{color:var(--muted);margin:12px 0 0;font-size:14px;font-weight:650;line-height:1.45}.paywall-state{min-height:240px;color:var(--muted);place-items:center;font-size:16px;font-weight:800;display:grid}.paywall-market-note{width:fit-content;color:var(--muted);background:0 0;border:0;margin:18px 0 0;padding:0;font-size:12px;font-weight:750;line-height:1.45}.paywall-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.paywall-plan{border:1px solid var(--border);background:linear-gradient(180deg, white 0%, var(--surface-subtle) 100%);border-radius:22px;gap:18px;padding:46px 18px 18px;display:grid;position:relative;overflow:hidden}.plan-saving-ribbon{z-index:1;background:var(--green);width:188px;box-shadow:none;color:#fff;text-align:center;padding:8px 0;font-size:12px;font-weight:950;line-height:1;position:absolute;top:18px;right:-48px;transform:rotate(35deg)}.paywall-plan>div:first-child span{background:var(--green-soft);width:fit-content;color:var(--green-dark);text-transform:uppercase;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;display:inline-flex}.paywall-plan strong{color:var(--ink);letter-spacing:-.05em;margin-top:12px;font-size:26px;font-weight:900;display:block}.paywall-plan p{color:var(--muted);margin:8px 0 0;font-size:13px;font-weight:650;line-height:1.42}.plan-meta{border-top:1px solid var(--border);gap:3px;padding-top:14px;display:grid}.plan-meta b{color:var(--ink);font-size:18px;font-weight:900}.plan-meta small{color:var(--muted);font-size:12px;font-weight:700}.plan-meta span{color:var(--green-dark);font-size:13px;font-weight:950}.paywall-plan button{background:var(--green);color:#fff;cursor:pointer;border:0;border-radius:14px;min-height:44px;padding:0 14px;font-size:12px;font-weight:900}.paywall-plan button:hover{background:var(--green-dark)}.paywall-plan button:disabled{cursor:wait;background:var(--surface-muted);color:var(--muted)}.auth-submit:disabled{background:var(--surface-muted);color:var(--faint);box-shadow:none}.auth-switch{color:var(--green-dark);background:0 0;border:0;font-size:13px;font-weight:900}.auth-switch:hover{color:var(--green);text-decoration:underline}.auth-error{color:var(--danger);background:#fff0eb;border:1px solid #bd4d353d;border-radius:14px;margin-top:14px;padding:10px 12px;font-size:12px;font-weight:800}.legal-links{color:var(--muted);flex-wrap:wrap;gap:4px;margin-top:16px;font-size:12px;font-weight:650;line-height:1.45;display:flex}.legal-links a{color:var(--green-dark);font-weight:900;text-decoration:none}.legal-links a:hover{color:var(--green);text-decoration:underline}.quiz-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.quiz-head p{color:var(--muted);margin:4px 0 0;font-size:13px;font-weight:600}.quiz-head strong{color:var(--ink);letter-spacing:-.03em;font-size:20px;font-weight:900}.quiz-list{gap:14px;margin:18px 0;display:grid}.quiz-progress{gap:10px;margin:22px 0;display:grid}.quiz-progress>div:first-child{color:var(--muted);justify-content:space-between;align-items:center;font-size:12px;font-weight:900;display:flex}.quiz-progress b{color:var(--text)}.quiz-progress-track{background:var(--surface-muted);border-radius:999px;height:8px;overflow:hidden}.quiz-progress-track span{border-radius:inherit;background:var(--green);height:100%;transition:width .22s;display:block}.quiz-question{border:1px solid var(--border);background:var(--surface-subtle);border-radius:18px;gap:8px;padding:14px;display:grid}.quiz-question>span{color:var(--text);font-size:13px;font-weight:800;line-height:1.35}.quiz-question>div{flex-wrap:wrap;gap:6px;display:flex}.wizard-question{min-height:220px;padding:22px}.wizard-question>span{letter-spacing:-.03em;font-size:20px}.wizard-question>div{grid-template-columns:1fr;align-content:flex-start;gap:10px;display:grid}.wizard-question button{align-items:center;gap:10px;width:100%;min-height:44px;padding:12px 14px;font-size:13px;display:flex}.quiz-option-number{width:26px;height:26px;color:var(--muted);background:#fff;border-radius:50%;flex:0 0 26px;justify-content:center;align-items:center;font-size:11px;font-weight:900;display:inline-flex}.wizard-question button.selected .quiz-option-number,.wizard-question button:hover .quiz-option-number{background:var(--green);color:#fff}.quiz-custom-input{border:1px solid var(--border-strong);width:100%;min-height:48px;color:var(--ink);background:#fff;border-radius:14px;outline:none;padding:0 14px;font-size:13px;font-weight:750}.quiz-custom-input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-ring)}.quiz-nav{grid-template-columns:1fr 1.3fr;gap:10px;margin-top:16px;display:grid}.small-button.primary{border-color:var(--green);background:var(--green);color:#fff}.small-button.primary:hover{background:var(--green-dark);color:#fff}.quiz-submit{justify-content:center;width:100%}.quiz-empty{text-align:center;place-items:center;min-height:220px;display:grid}.quiz-empty strong{color:var(--ink);font-size:18px}.quiz-empty p{color:var(--muted);margin:8px 0 0;font-size:13px}.quiz-loader{text-align:center;place-items:center;gap:10px;min-height:260px;display:grid}.quiz-loader span{border:4px solid var(--green-soft);border-top-color:var(--green);border-radius:50%;width:42px;height:42px;animation:.8s linear infinite spin}.quiz-loader strong{color:var(--ink);font-size:18px}.quiz-loader p{color:var(--muted);margin:0;font-size:13px}.two-columns{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;display:grid}.mini-upload{border:1px dashed var(--border-strong);background:var(--surface-subtle);min-height:88px;color:var(--muted);cursor:pointer;border-radius:16px;justify-content:center;align-items:center;font-size:12px;font-weight:800;display:flex;position:relative;overflow:hidden}.mini-upload:hover{border-color:var(--green);background:var(--green-soft);color:var(--green-dark)}.mini-upload img{object-fit:cover;width:100%;height:100%}.mini-upload-wrap{min-width:0;position:relative}.mini-upload-wrap .mini-upload{width:100%}.mini-upload-wrap.has-image .mini-upload{border-style:solid}.mini-upload-remove{color:#fff;background:#0f1410b8;border:0;border-radius:50%;width:28px;height:28px;font-size:18px;font-weight:800;line-height:1;position:absolute;top:8px;right:8px;box-shadow:0 8px 18px #0a120c29}.mini-upload-remove:hover{background:#0f1410e6}.settings-group{flex-direction:column;align-items:stretch;margin-top:16px}.ratio-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.ratio-grid button{flex-direction:column;min-width:0;display:flex}.ratio-grid small{color:var(--muted);font-size:10px;font-weight:600}input[type=range]{accent-color:var(--green)}.variant-picker{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.variant-picker button{border:1px solid var(--border-strong);background:var(--surface);min-width:0;min-height:58px;color:var(--muted);box-shadow:none;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:10px;transition:border-color .16s,background-color .16s,color .16s;display:flex}.variant-picker button:hover{color:var(--ink);background:#fbfdfb;border-color:#15983d57}.variant-picker button.selected{border-color:var(--green);color:var(--green-dark);background:#f2fbf4;box-shadow:inset 0 0 0 1px #15983d29}.variant-picker button:disabled{transform:none}.variant-preview{display:none}.variant-preview i{width:10px;height:20px;box-shadow:none;background:#fff;border:1px solid #15983d42;border-radius:5px;margin-left:-4px}.variant-preview i:first-child{margin-left:0}.variant-picker button.selected .variant-preview i{background:#e9f8ed;border-color:#15983d6b}.variant-picker strong{font-size:17px;font-weight:900;line-height:1}.variant-picker small{color:currentColor;opacity:.72;margin-top:0;font-size:10px;font-weight:700;display:block}.dropdown-title{text-align:left;background:0 0;border:0;width:100%;padding:0}.dropdown-title span:last-child{color:var(--muted);font-size:11px}.advanced-body{opacity:0;gap:0;max-height:0;padding-top:0;transition:max-height .26s,opacity .18s,padding-top .26s,transform .26s;display:grid;overflow:hidden;transform:translateY(-6px)}.advanced-body.is-open{opacity:1;max-height:920px;padding-top:2px;transform:translateY(0)}.generate-footer{z-index:15;border-top:1px solid var(--border);text-align:center;background:#fff;gap:8px;margin:20px -18px 0;padding:16px 18px 18px;display:grid;position:sticky;bottom:0;box-shadow:0 -12px 24px #ffffffeb,0 -4px 12px #14161406}.generate-button,.more-button{background:var(--green);color:#fff;border:0;border-radius:16px;justify-content:center;align-items:center;gap:8px;min-height:52px;padding:0 18px;font-size:15px;font-weight:900;display:inline-flex;box-shadow:0 14px 26px #15983d38}.generate-button:hover,.more-button:hover{background:var(--green-dark)}.generate-button.is-disabled,.generate-button.is-disabled:hover{background:var(--surface-muted);color:var(--faint);box-shadow:none}.generate-button.is-disabled .button-price{opacity:.55;color:var(--faint)}.generate-button:disabled,.generate-button:disabled:hover,.more-button:disabled,.more-button:disabled:hover{border-color:var(--border);background:var(--surface-muted);color:var(--faint);box-shadow:none;opacity:1}.button-price{color:#fff;background:0 0;border-radius:999px;justify-content:center;align-items:center;gap:3px;padding:0;font-size:13px;font-weight:900;line-height:1;display:inline-flex}.button-price img{flex:none;width:15px;height:15px;display:block}.generate-button:disabled .button-price{color:var(--faint);background:0 0}.results-panel{min-width:0;padding:26px;position:relative}.results-head{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:20px;display:flex}.back-link{color:var(--green);padding:0;font-size:13px;font-weight:900}.results-head h1{color:var(--ink);letter-spacing:-.06em;margin:8px 0 0;font-size:clamp(28px,3vw,44px);font-weight:800;line-height:.98}.results-head p{color:var(--muted);margin:12px 0 0;font-size:14px;font-weight:700}.more-button{border:1px solid var(--border-strong);background:var(--surface);min-height:46px;color:var(--ink);box-shadow:none;flex-shrink:0}.more-button:hover{border-color:var(--green);background:var(--green-soft);color:var(--green-dark)}.results-empty-copy{width:min(420px,100% - 52px);color:var(--muted);text-align:center;pointer-events:none;position:absolute;top:52%;left:50%;transform:translate(-50%,-50%)}.results-empty-copy strong{color:#9aa29a;letter-spacing:-.04em;font-size:clamp(20px,2vw,28px);font-weight:900;line-height:1.1;display:block}.results-empty-copy p{color:#a6aea4;margin:10px auto 0;font-size:14px;font-weight:750;line-height:1.45}.results-grid{grid-template-columns:repeat(3,minmax(230px,1fr));gap:18px;display:grid}.result-card{border:1px solid var(--border);background:var(--surface-subtle);border-radius:24px;flex-direction:column;min-height:560px;transition:transform .18s,border-color .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 18px #1416140a}.result-card:hover,.result-card.selected{border-color:#15983d75;transform:translateY(-1px);box-shadow:0 10px 24px #1416140f}.result-actions{z-index:5;gap:8px;display:flex;position:absolute;top:14px;right:14px}.icon-button{width:42px;height:42px;color:var(--ink);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffdb;border:1px solid #e3e8dfe6;border-radius:999px;font-size:18px;font-weight:900;line-height:1;box-shadow:0 8px 18px #14161414}.icon-button svg{width:18px;height:18px;margin:0 auto;display:block}.icon-button:hover,.icon-button.active{border-color:var(--green);color:var(--green-dark);background:var(--green-soft)}.icon-button:disabled{cursor:default}.result-media{object-fit:cover;background:var(--surface-muted);flex:1;width:100%;min-height:500px}.result-placeholder{min-height:500px;color:var(--muted);text-align:center;background:linear-gradient(135deg,#ffffffb8,#f1f4f0e0),radial-gradient(circle at 50% 42%,#15983d14,#0000 18rem);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex}.result-placeholder.error{color:var(--danger)}.result-mark{color:var(--border-strong);font-size:54px;line-height:1}.result-spinner{border:3px solid #15983d24;border-top-color:var(--green);border-right-color:var(--green);border-radius:50%;width:52px;height:52px;animation:2.34s linear infinite spin;position:relative}.result-spinner:after{content:"";background:#fff;border-radius:50%;position:absolute;inset:11px;box-shadow:inset 0 0 0 1px #15983d1a}.pending-progress{background:#15983d1a;border-radius:999px;width:min(220px,72%);height:5px;margin-top:14px;overflow:hidden}.pending-progress span{border-radius:inherit;background:var(--green);transform-origin:0;width:100%;height:100%;animation:120s linear forwards pending-progress;display:block;transform:scaleX(.02)}.result-placeholder strong,.result-title-button{font-size:15px;font-weight:900}.result-card footer{color:var(--text);background:#fff;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px 16px;display:flex}.result-card footer.editing-title{display:block}.result-card footer.editing-title>small{display:none}.result-title-button{max-width:58%;color:var(--text);text-align:left;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:0;padding:0;overflow:hidden}.result-title-button:hover{color:var(--green-dark)}.pending-title{max-width:58%;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:900;overflow:hidden}.result-title-form{grid-template-columns:1fr;gap:8px;min-width:0;display:grid}.result-title-form input{border:1px solid var(--border-strong);width:100%;min-width:0;min-height:34px;color:var(--ink);background:#fff;border-radius:10px;outline:none;padding:7px 9px}.result-title-form input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-ring)}.result-title-form button{border:1px solid var(--border-strong);background:var(--surface);min-height:34px;color:var(--text);border-radius:10px;padding:0 9px;font-size:11px;font-weight:900}.result-title-form-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.result-title-form button[type=submit]{border-color:var(--green);background:var(--green-soft);color:var(--green-dark)}.skeleton{border-style:dashed}.fullscreen-backdrop{z-index:140;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0d0f0dbd;place-items:center;padding:22px;display:grid;position:fixed;inset:0}.fullscreen-viewer{background:#0c0e0c;border:1px solid #ffffff29;border-radius:24px;grid-template-rows:auto 1fr;width:min(1180px,100%);height:min(820px,100vh - 44px);display:grid;overflow:hidden;box-shadow:0 22px 70px #0000004d}.fullscreen-viewer-head{color:#fff;background:#ffffff0f;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.fullscreen-viewer-head strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:16px;font-weight:900;overflow:hidden}.fullscreen-viewer-head button{color:#fff;background:#ffffff1f;border:1px solid #ffffff24;border-radius:999px;flex:none;width:42px;height:42px;font-size:28px;font-weight:700;line-height:1}.fullscreen-viewer-head button:hover{background:#ffffff2e}.fullscreen-viewer-media{background:#060706;place-items:center;min-height:0;display:grid}.fullscreen-viewer-media img,.fullscreen-viewer-media video{object-fit:contain;width:100%;height:100%;display:block}@media (width<=720px){.fullscreen-backdrop{padding:10px}.fullscreen-viewer{border-radius:18px;height:calc(100vh - 20px)}}@keyframes pulse{0%,to{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pending-progress{0%{transform:scaleX(.02)}8%{transform:scaleX(.18)}22%{transform:scaleX(.38)}46%{transform:scaleX(.64)}74%{transform:scaleX(.86)}to{transform:scaleX(.98)}}@keyframes field-shimmer{0%{background-position:120% 0,0 0}to{background-position:-120% 0,0 0}}@keyframes modal-in{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1320px){.workspace{grid-template-columns:360px minmax(0,1fr)}.results-grid{grid-template-columns:repeat(2,minmax(230px,1fr))}.project-grid,.profile-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (width<=920px){.app-shell{padding:12px}.topbar{grid-template-columns:1fr;gap:12px;padding:16px;position:static}.topnav{justify-content:flex-start;overflow-x:auto}.top-actions{flex-wrap:wrap;justify-content:flex-start}.toast-stack{width:calc(100vw - 24px);top:12px;right:12px}.workspace{grid-template-columns:1fr}.settings-panel{max-height:none;position:static}.results-head{flex-direction:column}.results-grid{grid-template-columns:1fr}.page-card{padding:22px}.paywall-grid{grid-template-columns:1fr}.paywall-modal{padding:22px}.page-head{flex-direction:column}.project-grid,.profile-grid{grid-template-columns:1fr}.project-card{grid-template-columns:88px minmax(0,1fr);min-height:170px}.project-preview{border-radius:16px;width:88px;height:88px}.result-card{min-height:420px}.result-media,.result-placeholder{min-height:360px}}
