:root{--bg: #e8e6e1;--surface: #faf9f7;--surface-2: #f3f0eb;--surface-3: #f0ede8;--text: #111111;--muted: #666666;--muted-2: #999999;--line: rgba(0, 0, 0, .08);--line-2: rgba(0, 0, 0, .06);--accent: #8b5cf6;--accent-2: #a78bfa;--black: #1a1a1a;--white: #ffffff;--danger: #ef4444;--shadow-lg: 0 16px 40px rgba(0, 0, 0, .08);--shadow-md: 0 10px 24px rgba(0, 0, 0, .06);--radius-xl: 24px;--radius-lg: 18px;--radius-md: 14px;--radius-sm: 12px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--tg-bg-color: #faf9f7;--tg-secondary-bg-color: #f3f0eb;--tg-text-color: #111111;--tg-hint-color: #8e8e93;--tg-button-color: #1a1a1a;--tg-button-text-color: #ffffff}*{box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;overscroll-behavior-y:none}button,input,textarea{font:inherit}button{border:none;background:none;cursor:pointer}input,textarea{outline:none}img{display:block;max-width:100%}.app-root{height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:radial-gradient(circle at top,rgba(255,255,255,.4),transparent 36%),var(--bg)}.app-shell{position:relative;width:min(100%,430px);min-height:100dvh;margin:0 auto;background:var(--surface);box-shadow:var(--shadow-lg)}.hidden-file-input{display:none}.offer-screen{width:min(100%,430px);min-height:100dvh;margin:0 auto;background:var(--surface);position:relative;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.offer-screen__bg-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center top;z-index:0}.offer-screen__hero-gradient{position:absolute;bottom:0;left:0;right:0;height:330px;background:linear-gradient(to top,var(--surface) 40%,transparent);z-index:1}.offer-screen__content{position:relative;z-index:2;margin-top:auto;padding:0 24px max(40px,calc(28px + var(--safe-bottom)))}.offer-screen__title{margin:0 0 12px;font-size:30px;line-height:1.05;letter-spacing:-.03em;font-weight:700;color:var(--text)}.offer-screen__subtitle{margin:0 0 24px;font-size:15px;line-height:1.5;color:var(--muted)}.offer-screen .primary-action{width:100%}.offer-screen .small-note{margin-top:12px;text-align:center;font-size:12px;color:#bbb}.hero{position:relative;min-height:clamp(360px,46vh,470px);background:linear-gradient(160deg,#f7f2ec,#f0e8de 55%,#ebe2d4);overflow:hidden}.hero--result{min-height:clamp(360px,46vh,470px)}.hero-topbar{position:absolute;inset:max(12px,calc(var(--safe-top) + 8px)) 14px auto 14px;z-index:5;display:flex;justify-content:space-between;gap:10px}.hero-topbar-actions{display:flex;gap:8px}.icon-button{width:38px;height:38px;border-radius:999px;color:#2d2d2d;background:#ffffffc7;border:1px solid rgba(0,0,0,.06);display:inline-flex;align-items:center;justify-content:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:transform .18s ease,background .18s ease,color .18s ease}.icon-button:active{transform:scale(.96)}.icon-button--active{color:#fff;background:#8b5cf6eb}.hero-center{min-height:inherit;display:grid;place-items:center;padding:calc(84px + var(--safe-top)) 18px 70px}.hero-center--empty{cursor:pointer;transition:opacity .2s}.hero-center--empty:active{opacity:.7}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:14px;padding:0;background:transparent;border:none;text-align:center}.upload-placeholder__icon{width:96px;height:96px;border-radius:24px;border:2px dashed rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;background:transparent}.upload-placeholder__icon svg{width:36px;height:36px}.upload-placeholder__title{font-size:17px;font-weight:700;color:var(--text)}.upload-placeholder__hint{font-size:13px;color:var(--muted-2);max-width:240px;line-height:1.4}.hero-photo{position:relative;min-height:inherit;display:flex;align-items:stretch;justify-content:stretch}.hero-photo__image{width:100%;min-height:inherit;object-fit:cover;object-position:center top}.hero-photo__image--dimmed{filter:brightness(.72)}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#faf9f757;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:20px}.hero-overlay__title{font-size:18px;font-weight:700;color:#333}.hero-overlay__subtitle{max-width:280px;font-size:13px;line-height:1.45;color:#666}.sparkle{font-size:22px;animation:pulse 1.9s ease-in-out infinite}.change-photo-chip{position:absolute;right:14px;bottom:18px;z-index:4;min-height:38px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;color:#222;background:#ffffffe0;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-md);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.result-placeholder{width:100%;min-height:inherit;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:radial-gradient(circle at top,rgba(255,255,255,.35),transparent 30%),linear-gradient(160deg,#ebe5dc,#ddd4c8)}.result-placeholder__badge{padding:8px 12px;border-radius:999px;background:#8b5cf61f;color:#6d28d9;font-size:12px;font-weight:700}.result-placeholder__hint{color:#777;font-size:14px}.hero-gradient{position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to top,var(--surface),transparent);pointer-events:none;z-index:2}.hero--result .hero-gradient,.hero-photo~.hero-gradient,.hero:has(.hero-photo) .hero-gradient{display:none}.main-content{position:relative;z-index:1;padding:12px 14px max(40px,calc(28px + var(--safe-bottom)));background:var(--surface)}.main-content--with-sticky{padding-bottom:140px}.pill-row{display:flex;flex-wrap:nowrap;gap:6px;margin-top:6px;margin-bottom:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.pill-row::-webkit-scrollbar{display:none}.pill{min-height:32px;padding:0 12px;border-radius:999px;background:#0000000a;border:1px dashed rgba(0,0,0,.12);color:#555;font-size:12px;font-weight:500;white-space:nowrap}.pill--purple{background:#8b5cf614;color:#7c3aed}.title-block{padding:2px 2px 4px}.title-block__title{margin:0;color:var(--text);font-size:clamp(22px,4.7vw,28px);line-height:1.1;letter-spacing:-.03em}.title-block__subtitle{margin:6px 0 0;color:var(--muted-2);font-size:12.5px;line-height:1.5}.status-inline{margin-top:8px;color:#7a7a7a;font-size:12px;line-height:1.45}.cost-bar{margin:8px 0 12px;padding:10px 12px;border-radius:12px;background:var(--surface-2)}.cost-bar__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.cost-bar__label{color:var(--muted-2);font-size:11px;font-weight:500}.cost-bar__value{font-size:12px;color:#222;font-weight:700}.cost-bar__budget{font-weight:400;color:#b0b0b0}.cost-bar__track{width:100%;height:5px;border-radius:999px;background:#ddd8d1;overflow:hidden}.cost-bar__fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.product-carousel{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;scrollbar-width:none;-ms-overflow-style:none}.product-carousel::-webkit-scrollbar{display:none}.product-card{flex:0 0 112px;scroll-snap-align:start;border-radius:16px;background:var(--white);border:1px solid var(--line-2);overflow:hidden}.product-card--vitrine{min-height:108px;display:grid;place-items:center;padding:12px;background:#ffffffb3}.product-card__vitrine-name{text-align:center;font-size:11px;line-height:1.35;font-weight:700;color:#7a7a7a}.product-card__image-wrap{position:relative;width:100%;height:112px;background:#eee8de;overflow:hidden}.product-card__image{width:100%;height:100%;object-fit:cover}.product-card__image--placeholder{display:grid;place-items:center;color:#a89f92;font-size:11px;text-align:center;padding:10px;background:radial-gradient(circle at top,rgba(255,255,255,.45),transparent 34%),linear-gradient(160deg,#efe8dd,#e4d9ca)}.product-card__link-btn{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:999px;color:#7f7f7f;background:#ffffffeb;border:1px solid rgba(0,0,0,.05);display:grid;place-items:center}.product-card__meta{padding:8px 9px 10px}.product-card__brand{font-size:9px;color:#aaa;margin-bottom:2px}.product-card__name{min-height:28px;color:#4b4b4b;font-size:11px;line-height:1.25;margin-bottom:3px;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.product-card__price{font-size:13px;font-weight:700;color:#222}.request-box{margin-top:6px;margin-bottom:14px}.request-box__label{display:block;margin-bottom:6px;color:var(--muted-2);font-size:11px;font-weight:500}.request-box__textarea{width:100%;resize:none;border-radius:16px;border:1.5px solid rgba(0,0,0,.08);background:#fff;color:#222;padding:13px 14px;line-height:1.45;font-size:14px}.primary-action-wrap{margin-top:4px}.primary-action{width:100%;min-height:50px;padding:0 18px;border-radius:14px;background:var(--black);color:#fff;font-size:15px;font-weight:700;letter-spacing:-.02em;display:inline-flex;align-items:center;justify-content:center;gap:8px}.primary-action:disabled{cursor:default;opacity:.85}.primary-action--disabled{background:#e0ddd8;color:#aaa}.primary-action--loading{background:#e0ddd8;color:#888}.small-note{margin-top:8px;text-align:center;color:#b8b8b8;font-size:11px;line-height:1.4}.edit-box{min-height:46px;margin-top:6px;display:flex;align-items:center;gap:8px;background:var(--surface-3);border-radius:20px;padding:6px 6px 6px 14px;border:1.5px solid rgba(0,0,0,.06);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.edit-box--focused{background:#fff;border-color:var(--accent);box-shadow:0 4px 18px #8b5cf61a}.edit-box__input{flex:1;min-width:0;border:none;background:transparent;color:#222;caret-color:var(--black);font-size:16px}.edit-box__input::placeholder{color:#a0a0a0}.edit-box__send{width:34px;height:34px;border-radius:999px;background:#ccc9c2;display:grid;place-items:center;flex-shrink:0}.edit-box__send--active{background:var(--black)}.edit-box__send:disabled{cursor:default}.next-look-bar{min-height:48px;border-radius:14px;background:var(--black);display:flex;align-items:center;padding:0 5px;color:#fff}.next-look-bar--blocked{opacity:.35}.next-look-bar__nav{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;color:#fff;background:#ffffff26;flex-shrink:0}.next-look-bar__nav--disabled{background:#ffffff0f;color:#ffffff4d}.next-look-bar__center{flex:1;display:flex;justify-content:center;align-items:center;gap:8px;min-width:0}.next-look-bar__label{font-size:14px;font-weight:700}.next-look-bar__progress{color:#ffffff73;font-size:12px}.next-look-bar__spacer{width:36px;flex-shrink:0}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:50}.sheet{position:fixed;left:50%;bottom:0;transform:translate(-50%);width:min(100%,430px);max-height:min(76vh,700px);overflow-y:auto;background:#fff;border-radius:22px 22px 0 0;padding:12px 14px max(28px,calc(20px + var(--safe-bottom)));z-index:60;box-shadow:0 -18px 36px #00000029}.sheet__handle{width:38px;height:4px;border-radius:999px;background:#ddd;margin:0 auto 14px}.sheet__title{margin-bottom:14px;color:#111;font-size:16px;font-weight:700}.sheet__block{margin-bottom:14px}.sheet__input{width:100%;min-height:42px;border-radius:12px;border:1.5px solid rgba(0,0,0,.08);background:#f9f7f4;padding:0 12px;font-size:14px;color:#222}.sheet__range{width:100%;margin:0 0 18px;accent-color:var(--accent)}.sheet__empty-hint{margin-bottom:14px;color:#999;font-size:12px}.field-label{margin-bottom:6px;color:#999;font-size:11px;font-weight:500}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.chip{min-height:34px;padding:0 12px;border-radius:999px;background:#f3f1ee;color:#555;font-size:12px;font-weight:500;white-space:nowrap}.chip--selected{color:#fff;background:var(--black)}.chip--custom{color:#7c3aed;background:#8b5cf614;border:1px dashed #8b5cf6}.budget-line{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;color:#aaa;font-size:11px}.budget-line strong{color:#222;font-size:12px}.spinner{width:30px;height:30px;border:3px solid rgba(139,92,246,.16);border-top-color:var(--accent);border-radius:999px;animation:spin .85s linear infinite}.spinner--small{width:15px;height:15px;border-width:2px}.spinner--light{border-color:#ffffff4d;border-top-color:#fff}@media (max-width: 390px){.app-shell,.offer-screen,.sheet{width:100%}.offer-screen__content{padding-left:16px;padding-right:16px}.main-content{padding-left:12px;padding-right:12px}.product-card{flex-basis:104px}.product-card__image-wrap{height:104px}}@media (min-width: 431px){.app-root{padding:16px 0}.app-shell,.offer-screen{border-radius:28px;min-height:calc(100dvh - 32px)}.sheet{bottom:16px;border-radius:22px}}@media (hover: hover){.primary-action:hover,.pill:hover,.chip:hover,.icon-button:hover,.change-photo-chip:hover,.product-card__link-btn:hover{filter:brightness(.98)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.45;transform:scale(.98)}50%{opacity:1;transform:scale(1)}}.onboarding-screen{width:min(100%,430px);min-height:100dvh;margin:0 auto;background:var(--surface);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.onboarding-screen__content{flex:1;padding:max(80px,calc(60px + var(--safe-top))) 24px 0}.onboarding-screen__title{margin:0 0 8px;font-size:28px;font-weight:700;color:var(--text);letter-spacing:-.5px}.onboarding-screen__hint{margin:0 0 40px;font-size:15px;color:var(--muted-2);line-height:1.5}.onboarding-screen__group{margin-bottom:32px}.onboarding-screen__label{margin-bottom:12px;font-size:12px;font-weight:500;color:#aaa;letter-spacing:.5px;text-transform:uppercase}.onboarding-screen__gender-row{display:flex;gap:10px}.onboarding-screen__age-row{display:flex;flex-wrap:wrap;gap:8px}.onboarding-btn{background:var(--surface-2);color:#555;border:1px solid var(--line-2);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.onboarding-btn--gender{flex:1;height:58px;font-size:17px;font-weight:600}.onboarding-btn--age{padding:16px 26px;font-size:16px}.onboarding-btn--selected{background:var(--black);color:var(--white);border-color:transparent}.onboarding-screen__footer{padding:0 24px max(70px,calc(58px + var(--safe-bottom)))}.onboarding-screen__age-break{flex-basis:100%;height:0}.change-photo-icon{position:absolute;bottom:16px;right:16px;width:38px;height:38px;border-radius:50%;background:#ffffffe6;border:1px solid rgba(0,0,0,.06);color:#2d2d2d;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:3;transition:transform .18s ease}.change-photo-icon:active{transform:scale(.94)}:root{--keyboard-offset: 0px}body{padding-bottom:0}.sticky-bottom{position:fixed;bottom:var(--kb-inset, 0px);left:50%;transform:translate(-50%);width:min(100%,430px);background:var(--surface);padding:12px 14px max(16px,var(--safe-bottom));z-index:10;box-shadow:none;display:grid;grid-template-rows:auto 48px;row-gap:8px;transition:bottom .28s ease-out,transform 0s}
