:root{--canvas:#f6f4ef;--canvas-deep:#e8e1d5;--ink:#1d1c18;--muted:#6f6a5f;--line:rgba(29,28,24,0.13);--surface:#fffdfa;--surface-strong:#f2eee4;--green:#355f50;--green-dark:#18352d;--coral:#c94c35;--coral-dark:#9f3524;--gold:#b48638;--shadow-sm:0 12px 28px -24px rgba(29,28,24,0.46);--shadow-md:0 28px 72px -48px rgba(29,28,24,0.52);--radius-sm:8px;--radius-md:14px;--radius-lg:22px;--radius-pill:999px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:linear-gradient(180deg,rgba(53,95,80,.08),transparent 340px),linear-gradient(90deg,rgba(29,28,24,.035) 1px,transparent 1px),var(--canvas);background-size:auto,72px 72px,auto;color:var(--ink);font-family:Avenir Next,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input{font:inherit}a,button,label{touch-action:manipulation}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:inherit;text-decoration:none}svg{display:block}.page-shell{min-height:100vh;overflow:hidden;padding:24px}.boundary-section,.hero-section,.workspace-section{width:min(1180px,100%);margin:0 auto}.hero-section{min-height:92vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 0}.brand-lockup,.download-button,.primary-button,.primary-link,.privacy-chip,.topbar-link{min-height:44px}.brand-lockup,.primary-link,.privacy-chip,.topbar-link{display:inline-flex;align-items:center}.brand-lockup{gap:12px;color:var(--green-dark);font-weight:800}.brand-symbol{display:grid;width:42px;height:42px;place-items:center;border-radius:13px;background:var(--green-dark);color:#f8f4e7;box-shadow:var(--shadow-sm)}.brand-symbol svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.topbar-link{padding:0 18px;border-radius:var(--radius-pill);background:rgba(255,253,250,.78);box-shadow:var(--shadow-sm);color:var(--green-dark);font-weight:700;transition-duration:.18s;transition-property:transform,background-color}.download-button:focus-visible,.download-button:hover,.primary-button:hover:not(:disabled),.primary-link:focus-visible,.primary-link:hover,.topbar-link:focus-visible,.topbar-link:hover{transform:translateY(-1px)}.download-button:active,.primary-button:active:not(:disabled),.primary-link:active,.topbar-link:active{transform:scale(.97)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(340px,.82fr);gap:56px;align-items:center;flex:1;padding:60px 0 74px}.hero-copy{animation:riseIn .42s cubic-bezier(.16,1,.3,1) both}.section-note{margin:0 0 18px;color:var(--coral-dark);font-size:14px;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1,h2{font-family:Georgia,Times New Roman,serif;font-weight:700;letter-spacing:0;text-wrap:balance}h1{max-width:820px;margin-bottom:26px;font-size:72px;line-height:.98}h2{font-size:42px;line-height:1.06}h3{margin-bottom:6px;color:var(--green-dark);font-size:19px;line-height:1.2}p{color:var(--muted);line-height:1.65;text-wrap:pretty}.hero-lede{max-width:660px;margin-bottom:32px;font-size:20px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}.download-button,.primary-button,.primary-link{border:0;border-radius:var(--radius-pill);font-weight:800;transition-duration:.18s;transition-property:transform,background-color,color,box-shadow,opacity}.primary-button,.primary-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 22px;background:var(--green-dark);color:#fffaf1;box-shadow:0 22px 46px -30px rgba(24,53,45,.9)}.download-button svg,.primary-button svg,.primary-link svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.primary-button:disabled{opacity:.46}.privacy-chip{padding:0 16px;border-radius:var(--radius-pill);background:rgba(201,76,53,.09);color:var(--coral-dark);font-size:14px;font-weight:800}.hero-visual{position:relative;min-height:540px;animation:riseIn .42s cubic-bezier(.16,1,.3,1) .12s both}.portrait-sheet{position:absolute;inset:8px 18px 42px 38px;display:grid;grid-template-rows:1fr auto;padding:16px;border-radius:32px;background:var(--surface);box-shadow:var(--shadow-md);transform:rotate(-2.5deg)}.portrait-sheet:before{position:absolute;inset:18px;border:1px solid rgba(53,95,80,.16);border-radius:22px;content:"";pointer-events:none}.portrait-art{position:relative;display:grid;place-items:center;overflow:hidden;border-radius:22px;background:linear-gradient(135deg,rgba(53,95,80,.28),transparent 46%),linear-gradient(180deg,#d8e0d8,#f4eadb)}.portrait-art:before{position:absolute;inset:0;background:linear-gradient(90deg,transparent 0 45%,rgba(255,255,255,.3) 45% 47%,transparent 47%),linear-gradient(180deg,rgba(255,255,255,.22),transparent 38%);content:""}.placeholder-head,.placeholder-shoulders,.portrait-body,.portrait-head{display:block;background:var(--green-dark)}.portrait-head{position:relative;z-index:1;width:126px;height:146px;margin-top:92px;border-radius:48% 48% 45% 45%;background:linear-gradient(180deg,rgba(255,255,255,.15),transparent 42%),#9f6d53}.portrait-body{position:absolute;right:78px;bottom:0;left:78px;height:210px;border-radius:46% 46% 0 0;background:linear-gradient(90deg,#18352d,#355f50 58%,#213d35)}.sheet-caption{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 4px 2px;color:var(--green-dark)}.sheet-caption span{color:var(--coral-dark);font-size:14px;font-weight:800}.studio-rail{position:absolute;right:0;bottom:0;display:flex;gap:10px;align-items:center;padding:14px;background:var(--green-dark);color:#fffaf1;box-shadow:var(--shadow-md)}.studio-rail,.studio-rail span{border-radius:var(--radius-pill)}.studio-rail span{padding:8px 12px;background:rgba(255,255,255,.1);font-size:13px;font-weight:800}.workspace-section{padding:64px 0 42px}.boundary-section,.workspace-header{display:grid;grid-template-columns:minmax(0,.9fr) minmax(280px,.7fr);gap:48px;align-items:end}.workspace-header{margin-bottom:34px}.boundary-section h2,.workspace-header h2{margin-bottom:0}.access-panel,.boundary-section,.control-panel,.result-panel{border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-md)}.access-panel{display:grid;grid-template-columns:minmax(260px,1fr) minmax(220px,.7fr) auto;gap:18px;align-items:end;padding:26px}.access-panel p{margin-bottom:0}.panel-step{display:inline-grid;width:34px;height:34px;margin-bottom:12px;place-items:center;border-radius:50%;background:var(--surface-strong);color:var(--coral-dark);font-size:13px;font-weight:900;font-variant-numeric:tabular-nums}.access-field{display:grid;gap:8px;color:var(--green-dark);font-weight:800}.access-field input{width:100%;min-height:50px;border:1px solid var(--line);border-radius:var(--radius-md);background:#fffaf1;color:var(--ink);padding:0 15px;outline:none;transition-duration:.18s;transition-property:border-color,box-shadow}.access-field input:focus{border-color:rgba(53,95,80,.48);box-shadow:0 0 0 4px rgba(53,95,80,.12)}.form-error{grid-column:1/-1;margin:0;color:var(--coral-dark);font-weight:800}.workspace-grid{display:grid;grid-template-columns:minmax(360px,.95fr) minmax(360px,1fr);gap:24px;align-items:stretch}.control-panel{padding:28px}.panel-heading{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}.panel-heading .panel-step,.panel-heading p{margin-bottom:0}.panel-heading-spaced{margin-top:28px}.upload-dropzone{display:grid;gap:16px;place-items:center;min-height:246px;margin-top:22px;padding:28px;border:1px dashed rgba(53,95,80,.34);border-radius:var(--radius-lg);background:linear-gradient(180deg,rgba(255,250,241,.86),rgba(242,238,228,.88));color:var(--green-dark);text-align:center;transition-duration:.18s;transition-property:transform,border-color,background-color}.upload-dropzone.is-dragging,.upload-dropzone:focus-visible,.upload-dropzone:hover{border-color:var(--green);transform:translateY(-1px)}.upload-input{display:none}.upload-icon{display:grid;width:62px;height:62px;place-items:center;border-radius:20px;background:var(--green-dark);color:#fffaf1}.upload-icon svg{width:36px;height:36px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.upload-copy{display:grid;gap:6px}.upload-copy strong{font-size:22px}.upload-copy span,.upload-meta{color:var(--muted)}.upload-meta{display:grid;gap:8px;font-size:14px}.upload-meta strong{color:var(--coral-dark)}.style-selector{min-inline-size:0;margin:20px 0 0;padding:0;border:0}.style-selector legend{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.style-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.style-card{display:grid;gap:9px;min-height:168px;padding:16px;border:0;border-radius:var(--radius-md);background:var(--surface-strong);color:var(--ink);text-align:left;box-shadow:inset 0 0 0 1px rgba(29,28,24,.06);transition-duration:.18s;transition-property:transform,background-color,box-shadow}.style-card:focus-visible,.style-card:hover{transform:translateY(-1px);box-shadow:inset 0 0 0 1px rgba(53,95,80,.26),var(--shadow-sm)}.style-card:active{transform:scale(.98)}.style-card.is-selected{background:#e4ece5;box-shadow:inset 0 0 0 2px rgba(53,95,80,.72),var(--shadow-sm)}.style-card-topline{display:inline-flex;align-items:center;gap:8px;color:var(--coral-dark);font-size:13px;font-weight:900}.style-dot{width:9px;height:9px;border-radius:50%;background:var(--coral)}.style-card strong{color:var(--green-dark);font-size:18px;line-height:1.2}.style-card span:last-child{color:var(--muted);font-size:14px;line-height:1.45}.generate-row{display:grid;gap:14px;margin-top:24px}.generate-button{width:100%;min-height:56px}.status-message{min-height:48px;margin:0;padding:13px 15px;border-radius:var(--radius-md);background:var(--surface-strong);color:var(--green-dark);font-weight:750}.status-error{background:rgba(201,76,53,.1);color:var(--coral-dark)}.status-success{background:rgba(53,95,80,.12);color:var(--green-dark)}.result-panel{display:grid;grid-template-rows:minmax(420px,1fr) auto;overflow:hidden}.result-frame{position:relative;display:grid;min-height:420px;place-items:center;overflow:hidden;background:linear-gradient(135deg,rgba(53,95,80,.16),transparent 42%),linear-gradient(180deg,#efe5d6,#dfe8df)}.result-frame img{width:100%;height:100%;object-fit:contain;outline:1px solid rgba(29,28,24,.08);outline-offset:-1px}.studio-placeholder{position:relative;width:min(70%,320px);height:360px}.placeholder-head{position:absolute;top:50px;left:calc(50% - 58px);width:116px;height:136px;border-radius:48% 48% 45% 45%;background:linear-gradient(180deg,rgba(255,255,255,.16),transparent 50%),#ad765a}.placeholder-shoulders{position:absolute;right:20px;bottom:0;left:20px;height:188px;border-radius:48% 48% 0 0;background:linear-gradient(90deg,#18352d,#355f50)}.processing-layer{position:absolute;inset:0;display:grid;gap:14px;place-content:center;background:rgba(24,53,45,.76);color:#fffaf1;font-weight:850}.spinner{width:42px;height:42px;margin:0 auto;border:3px solid rgba(255,250,241,.24);border-top-color:#fffaf1;border-radius:50%;animation:spin .9s linear infinite}.result-copy{padding:28px}.result-label{color:var(--coral-dark);font-size:13px;font-weight:900;text-transform:uppercase}.result-copy h2{margin:8px 0 12px;font-size:34px}.result-copy p{margin-bottom:20px}.download-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 18px;background:var(--coral);color:#fffaf1}.boundary-section{margin-bottom:34px;padding:34px;align-items:center;background:linear-gradient(90deg,rgba(53,95,80,.08),transparent 46%),var(--surface)}.boundary-section p{margin-bottom:0;color:var(--green-dark);font-weight:720}a:focus-visible,button:focus-visible,input:focus-visible,label:focus-visible{outline:3px solid rgba(201,76,53,.42);outline-offset:3px}@keyframes riseIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}}@media (max-width:980px){.hero-section{min-height:auto}.boundary-section,.hero-grid,.workspace-grid,.workspace-header{grid-template-columns:1fr}.hero-grid{gap:32px;padding:44px 0 58px}h1{font-size:56px}.hero-visual{min-height:460px}.portrait-sheet{inset:0 56px 40px 12px}.access-panel{grid-template-columns:1fr}.result-panel{grid-template-rows:minmax(380px,1fr) auto}}@media (max-width:640px){.page-shell{padding:14px}.topbar{align-items:flex-start}.brand-lockup{max-width:230px}.topbar-link{padding:0 14px}h1{font-size:42px}h2{font-size:32px}.hero-lede{font-size:18px}.hero-actions,.primary-link,.privacy-chip{width:100%}.primary-link,.privacy-chip{justify-content:center}.hero-visual{min-height:390px}.portrait-sheet{inset:0 20px 54px 0;border-radius:24px}.portrait-head{width:94px;height:110px;margin-top:76px}.portrait-body{right:44px;left:44px;height:160px}.studio-rail{right:4px;left:4px;justify-content:center}.workspace-section{padding-top:36px}.access-panel,.boundary-section,.control-panel,.result-copy{padding:20px}.panel-heading,.style-grid{grid-template-columns:1fr}.result-frame,.result-panel{min-height:0}.result-panel{grid-template-rows:340px auto}.upload-copy strong{font-size:20px}}