﻿:root{
  --bg:#f6efe6;
  --paper:#fffaf4;
  --panel:#fffdf9;
  --ink:#19130f;
  --muted:#6b6058;
  --line:rgba(57,35,24,.12);
  --accent:#c45a35;
  --accent-strong:#9d3d1e;
  --accent-soft:#f4d8c7;
  --olive:#4d5b41;
  --shadow:0 22px 80px rgba(53,30,17,.12);
  --radius-xl:34px;
}
html[data-theme="dark"]{
  --bg:#16110e;
  --paper:#1d1714;
  --panel:#241d19;
  --ink:#f4e8de;
  --muted:#b7a69a;
  --line:rgba(255,235,220,.12);
  --accent:#ef8f5f;
  --accent-strong:#ffb185;
  --accent-soft:rgba(239,143,95,.16);
  --olive:#b4c49b;
  --shadow:0 26px 90px rgba(0,0,0,.34);
}
*{box-sizing:border-box}
html,body,#root{margin:0;min-height:100%}
body{
  font-family:"Manrope",system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(248,212,186,.9), transparent 28%),
    radial-gradient(circle at 90% 20%, rgba(242,228,188,.7), transparent 24%),
    linear-gradient(180deg, #fcf7f1 0%, #f3e9de 46%, #f7efe5 100%);
}
html[data-theme="dark"] body{
  background:
    radial-gradient(circle at top left, rgba(239,143,95,.16), transparent 28%),
    radial-gradient(circle at 90% 20%, rgba(141,115,97,.14), transparent 24%),
    linear-gradient(180deg, #181210 0%, #140f0d 46%, #1a1412 100%);
}
html.tg-mini-app,body.tg-mini-app,#root{min-height:100dvh}
body.tg-mini-app{
  background:var(--tg-bg-color, #17212b);
  color:var(--tg-text-color, var(--ink));
}
body.tg-mini-app::before,
body.tg-mini-app::after{display:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
a{text-decoration:none;color:inherit}
.page{position:relative;overflow:hidden}
.page::before,.page::after{content:"";position:absolute;border-radius:999px;filter:blur(20px);opacity:.75;pointer-events:none}
.page::before{width:360px;height:360px;left:-120px;top:120px;background:radial-gradient(circle, rgba(196,90,53,.24), transparent 62%)}
.page::after{width:420px;height:420px;right:-120px;top:460px;background:radial-gradient(circle, rgba(77,91,65,.16), transparent 58%)}
body.tg-mini-app .page{min-height:100dvh}
body.tg-mini-app .page::before,
body.tg-mini-app .page::after{display:none}
.wrap{width:min(1240px, calc(100% - 32px));margin:0 auto;position:relative;z-index:1}
body.tg-mini-app .wrap{
  width:min(100% - 20px, 1240px);
  min-height:100dvh;
  padding-bottom:calc(20px + env(safe-area-inset-bottom, 0px));
}
.header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 0 18px;gap:18px}
body.tg-mini-app .header{padding:12px 0 10px}
body.tg-mini-app .brandText{gap:2px;padding-top:1px}
body.tg-mini-app .brandTitle{font-size:32px}
body.tg-mini-app .brandText span{font-size:11px;opacity:.78}
.brand{display:flex;align-items:flex-start;gap:16px}
.brandMark{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg, #1b140f, #463126);color:#fff;font-weight:800;box-shadow:var(--shadow)}
.brandMarkImage{width:50px;height:50px;flex-shrink:0;display:block}
.brandText{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:6px;padding-top:3px}
.brandTitle{display:block;font-size:39px;line-height:.92;letter-spacing:-.04em;font-weight:800;background:linear-gradient(90deg,#a84beb 0%,#ea4b73 58%,#ff9f4b 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.brandText span{display:block;color:var(--muted);font-size:13px;line-height:1.2;padding-left:2px}
.headerMeta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.pill{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(255,255,255,.65);background:rgba(255,250,244,.72);backdrop-filter:blur(18px);color:var(--muted);font-size:12px;font-weight:700}
.pill.hot{color:var(--accent-strong);background:rgba(255,238,226,.85)}
.themeToggle{display:inline-flex;align-items:center;gap:10px;min-height:40px;padding:0 14px;border-radius:999px;border:1px solid rgba(255,255,255,.6);background:rgba(255,250,244,.72);color:var(--ink);box-shadow:var(--shadow);backdrop-filter:blur(18px);cursor:pointer;transition:transform .18s ease, border-color .18s ease, background .18s ease}
.themeToggle:hover{transform:translateY(-1px)}
.themeLabel{font-size:12px;font-weight:800;color:var(--muted)}
.themeSwatch{width:14px;height:14px;border-radius:999px;display:inline-flex;box-shadow:0 0 0 2px rgba(0,0,0,.05)}
.themeSwatch.light{background:linear-gradient(180deg, #ffddb9 0%, #f5b07b 100%)}
.themeSwatch.dark{background:linear-gradient(180deg, #302722 0%, #12100f 100%);box-shadow:0 0 0 2px rgba(255,255,255,.08)}
.hero{display:grid;grid-template-columns:minmax(0, 1.08fr) minmax(360px, .92fr);gap:26px;align-items:start;padding:10px 0 24px}
body.tg-mini-app .hero{padding:0 0 14px;gap:18px}
body.tg-mini-app .hero{grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr)}
.generatedHero{align-items:stretch}
.heroStage,.formShell{transition:transform .42s ease, opacity .32s ease, order .01s linear}
.heroStage{position:relative;min-height:100%}
.swappedHero .heroStage{order:2;transform:translateX(0);animation:hero-swap-right .46s ease}
.swappedHero .formShell{order:1;transform:translateX(0);animation:hero-swap-left .46s ease}
.story{padding:36px 8px 0 0}
body.tg-mini-app .story{padding:10px 4px 0 0}
.storyVisible{opacity:1;transform:translateX(0);transition:opacity .42s ease, transform .42s ease}
.storyHidden{opacity:0;transform:translateX(-26px);pointer-events:none;position:absolute;inset:0;transition:opacity .32s ease, transform .32s ease}
.postHeroPanel{opacity:0;transform:translateX(22px) scale(.985);animation:panel-in .45s ease forwards;height:100%}
.panelReveal{animation-delay:.08s}
.eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;padding:10px 16px;border-radius:999px;background:rgba(255,248,241,.8);border:1px solid rgba(57,35,24,.08);color:var(--accent-strong);font-size:13px;font-weight:800;letter-spacing:.02em}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 6px rgba(196,90,53,.12)}
.story h1{margin:0;font-family:"Cormorant Garamond",serif;font-size:clamp(42px, 5.3vw, 76px);line-height:.98;letter-spacing:-.03em;max-width:620px}
body.tg-mini-app .story h1{font-family:"Manrope",system-ui,sans-serif;font-size:26px;line-height:1.05;letter-spacing:-.03em;max-width:320px}
.lead{margin:18px 0 0;max-width:560px;color:var(--muted);font-size:17px;line-height:1.74}
.heroGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:24px;max-width:760px}
.heroPanel,.teaseCard,.formShell,.resultShell,.analysisCard,.giftCard,.footerCard,.loaderCard{background:rgba(255,251,246,.76);border:1px solid rgba(255,255,255,.7);backdrop-filter:blur(18px);box-shadow:var(--shadow);border-radius:var(--radius-xl)}
html[data-theme="dark"] .themeToggle,
html[data-theme="dark"] .pill,
html[data-theme="dark"] .heroPanel,
html[data-theme="dark"] .teaseCard,
html[data-theme="dark"] .formShell,
html[data-theme="dark"] .resultShell,
html[data-theme="dark"] .analysisCard,
html[data-theme="dark"] .giftCard,
html[data-theme="dark"] .footerCard,
html[data-theme="dark"] .loaderCard{background:rgba(33,25,22,.76);border-color:rgba(255,235,220,.08)}
.heroPanel,.teaseCard,.footerCard,.analysisCard,.resultShell,.loaderCard{padding:22px}
.heroPanel h3,.teaseCard h3,.analysisCard h3,.resultShell h3,.footerCard h3,.loaderCopy h3{margin:0 0 10px;font-size:23px}
.heroPanel p,.teaseCard p,.analysisCard p,.resultShell p,.footerCard p,.loaderCopy p{margin:0;color:var(--muted);line-height:1.72}
.luckyTile{
  margin-top:24px;
  width:min(360px, 100%);
  min-height:360px;
  padding:24px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:left;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.74);
  background:
    radial-gradient(circle at top left, rgba(255,173,122,.18), transparent 34%),
    linear-gradient(180deg, rgba(255,249,244,.86), rgba(253,241,231,.9));
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
  cursor:pointer;
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.luckyTile.revealing{animation:dice-roll .55s ease}
.luckyTile:hover{
  transform:translateY(-2px);
  border-color:rgba(196,90,53,.26);
  box-shadow:0 24px 80px rgba(53,30,17,.16);
}
html[data-theme="dark"] .luckyTile{
  background:
    radial-gradient(circle at top left, rgba(255,152,102,.18), transparent 32%),
    linear-gradient(180deg, rgba(41,31,27,.88), rgba(28,22,19,.92));
  border-color:rgba(255,235,220,.08);
}
body.tg-mini-app .luckyTile{
  min-height:280px;
  padding:16px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border-color:rgba(255,255,255,.08);
  box-shadow:none;
}
.luckyTileIdle,.luckyTileBody{display:flex;flex-direction:column;height:100%}
.luckyTileIdle{justify-content:center}
.luckyRevealState{
  min-height:100%;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:14px;
}
.luckyRevealState strong{
  color:var(--ink);
  font-size:26px;
  line-height:1.04;
  letter-spacing:-.03em;
}
.luckyRevealOrb{
  width:82px;
  height:82px;
  border-radius:28px;
  background:
    radial-gradient(circle at 34% 30%, rgba(255,255,255,.92), rgba(255,255,255,.22) 38%, transparent 40%),
    linear-gradient(180deg, rgba(255,174,123,.26), rgba(255,140,84,.12));
  border:1px solid rgba(196,90,53,.22);
  box-shadow:0 18px 40px rgba(157,61,30,.12);
  animation:lucky-orb-pulse 1.1s ease-in-out infinite;
}
.luckyRevealLine{
  display:block;
  width:100%;
  height:12px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,255,255,.12), rgba(255,255,255,.74), rgba(255,255,255,.12));
  background-size:180% 100%;
  animation:lucky-line-sheen 1.25s linear infinite;
}
.luckyRevealLine.short{width:52%}
.luckyRevealLine.wide{width:84%}
html[data-theme="dark"] .luckyRevealLine{
  background:linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.26), rgba(255,255,255,.08));
  background-size:180% 100%;
}
.diceRoller{
  min-height:100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:12px;
}
.diceSceneButton{
  width:100%;
  flex:1;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
}
.diceSceneButton:disabled,
.diceAction:disabled{cursor:default}
body.tg-mini-app .diceStage{min-height:180px}
body.tg-mini-app .diceCube{width:102px;height:102px}
body.tg-mini-app .face1{transform:translateZ(51px)}
body.tg-mini-app .face6{transform:rotateY(180deg) translateZ(51px)}
body.tg-mini-app .face2{transform:rotateY(90deg) translateZ(51px)}
body.tg-mini-app .face5{transform:rotateY(-90deg) translateZ(51px)}
body.tg-mini-app .face3{transform:rotateX(90deg) translateZ(51px)}
body.tg-mini-app .face4{transform:rotateX(-90deg) translateZ(51px)}
body.tg-mini-app .diceFace{
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.06));
  border-color:rgba(255,255,255,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18), 0 10px 24px rgba(0,0,0,.12);
}
body.tg-mini-app .pip{width:14px;height:14px}
body.tg-mini-app .topLeft,
body.tg-mini-app .midLeft,
body.tg-mini-app .bottomLeft{left:20px}
body.tg-mini-app .topRight,
body.tg-mini-app .midRight,
body.tg-mini-app .bottomRight{right:20px}
body.tg-mini-app .topLeft,
body.tg-mini-app .topRight{top:20px}
body.tg-mini-app .bottomLeft,
body.tg-mini-app .bottomRight{bottom:20px}
.diceStage{
  position:relative;
  min-height:244px;
  display:grid;
  place-items:center;
  perspective:1200px;
}
.diceGlow{
  position:absolute;
  width:240px;
  height:240px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(196,90,53,.18) 0%, rgba(196,90,53,.08) 42%, transparent 72%);
  filter:blur(14px);
}
.diceShadow{
  position:absolute;
  bottom:28px;
  width:168px;
  height:38px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(84,39,24,.34), rgba(84,39,24,0) 72%);
  filter:blur(10px);
}
.diceCube{
  position:relative;
  width:118px;
  height:118px;
  transform-style:preserve-3d;
  transition:transform 1.9s cubic-bezier(.18,.84,.2,1);
}
.diceCube.isRolling{transition-timing-function:cubic-bezier(.12,.86,.16,1)}
.diceFace{
  position:absolute;
  inset:0;
  display:block;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,252,248,.78), rgba(248,232,219,.58));
  border:1px solid rgba(255,255,255,.42);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    0 14px 36px rgba(78,34,18,.18);
  backdrop-filter:blur(16px);
}
html[data-theme="dark"] .diceFace{
  background:linear-gradient(180deg, rgba(255,246,240,.16), rgba(255,223,203,.08));
  border-color:rgba(255,238,226,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 14px 36px rgba(0,0,0,.22);
}
.face1{transform:translateZ(59px)}
.face6{transform:rotateY(180deg) translateZ(59px)}
.face2{transform:rotateY(90deg) translateZ(59px)}
.face5{transform:rotateY(-90deg) translateZ(59px)}
.face3{transform:rotateX(90deg) translateZ(59px)}
.face4{transform:rotateX(-90deg) translateZ(59px)}
.pip{
  position:absolute;
  width:16px;
  height:16px;
  border-radius:999px;
  background:linear-gradient(180deg, #d67143 0%, #bd5228 100%);
  box-shadow:0 3px 10px rgba(157,61,30,.18);
}
.center{top:50%;left:50%;transform:translate(-50%,-50%)}
.topLeft{top:24px;left:24px}
.topRight{top:24px;right:24px}
.midLeft{top:50%;left:24px;transform:translateY(-50%)}
.midRight{top:50%;right:24px;transform:translateY(-50%)}
.bottomLeft{left:24px;bottom:24px}
.bottomRight{right:24px;bottom:24px}
.luckyTileBody strong{
  display:block;
  margin-top:16px;
  font-size:30px;
  line-height:1.02;
  letter-spacing:-.03em;
}
.luckyTileBody p{
  margin:14px 0 0;
  color:var(--muted);
  line-height:1.7;
}
.luckyTileBadge{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(57,35,24,.08);
  color:var(--accent-strong);
  font-size:12px;
  font-weight:800;
}
html[data-theme="dark"] .luckyTileBadge{background:rgba(255,248,244,.08);border-color:rgba(255,235,220,.08)}
.luckyCaption{
  display:block;
  width:100%;
  margin-top:4px;
  text-align:center;
  font-size:25px;
  line-height:1.04;
  letter-spacing:-.03em;
  font-weight:800;
  color:var(--ink);
  text-shadow:0 1px 0 rgba(255,255,255,.18);
}
body.tg-mini-app .luckyCaption{
  font-size:20px;
  text-align:center;
  color:var(--tg-text-color, var(--ink));
  text-shadow:none;
}
.diceAction{
  min-height:48px;
  border-radius:999px;
  border:1px solid rgba(196,90,53,.24);
  background:linear-gradient(180deg, rgba(255,174,123,.24), rgba(255,140,84,.14));
  color:var(--ink);
  font:inherit;
  font-weight:800;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.diceAction:hover{
  transform:translateY(-1px);
  border-color:rgba(196,90,53,.42);
  box-shadow:0 14px 26px rgba(157,61,30,.14);
}
.diceAction.busy{opacity:.82}
.diceMeta{
  display:block;
  text-align:center;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
body.tg-mini-app .diceAction,
body.tg-mini-app .diceMeta{display:none}
.luckyTileFoot{
  margin-top:auto;
  padding-top:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
.luckyBackButton{
  min-height:36px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(57,35,24,.12);
  background:rgba(255,255,255,.64);
  color:var(--muted);
  font:inherit;
  font-weight:800;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
html[data-theme="dark"] .luckyBackButton{
  background:rgba(255,248,244,.06);
  border-color:rgba(255,235,220,.12);
}
.luckyBackButton:hover{
  transform:translateY(-1px);
  border-color:rgba(196,90,53,.24);
}
.luckyInlineAction{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 14px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,174,123,.18), rgba(255,140,84,.12));
  border:1px solid rgba(196,90,53,.24);
  color:var(--ink);
  font-weight:800;
}
.profilePanel{display:flex;flex-direction:column;gap:14px;min-height:100%;padding:16px 16px 18px;border-radius:var(--radius-xl);background:rgba(255,251,246,.76);border:1px solid rgba(255,255,255,.7);backdrop-filter:blur(18px);box-shadow:var(--shadow)}
html[data-theme="dark"] .profilePanel{background:rgba(33,25,22,.76);border-color:rgba(255,235,220,.08)}
.profileVisual{display:flex;align-items:stretch;justify-content:center}
.profileFrame{position:relative;overflow:hidden;isolation:isolate;width:100%;aspect-ratio:1/1;border-radius:28px;background:linear-gradient(180deg, rgba(250,240,230,.96), rgba(241,226,211,.88));border:1px solid rgba(57,35,24,.08);display:flex;align-items:center;justify-content:center;margin:0 auto}
html[data-theme="dark"] .profileFrame{background:linear-gradient(180deg, rgba(53,40,33,.96), rgba(34,26,22,.92));border-color:rgba(255,235,220,.08)}
.profilePhoto{width:100%;height:100%;object-fit:cover;object-position:50% 35%;transform:scale(1.06)}
.profilePlaceholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:
  radial-gradient(circle at 50% 28%, rgba(255,255,255,.18), transparent 18%),
  linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.08)),
  linear-gradient(180deg, rgba(95,77,65,.24), rgba(66,52,44,.52))}
.placeholderHead{width:92px;height:92px;border-radius:50%;background:linear-gradient(180deg, rgba(247,209,176,.95) 0%, rgba(205,152,103,.92) 100%);box-shadow:0 16px 40px rgba(0,0,0,.1)}
.placeholderBody{width:170px;height:132px;margin-top:12px;border-radius:82px 82px 28px 28px;background:linear-gradient(180deg, rgba(245,235,228,.2), rgba(28,22,19,.4))}
html[data-theme="dark"] .placeholderBody{background:linear-gradient(180deg, rgba(255,240,230,.1), rgba(12,10,9,.46))}
.scanBeam{position:absolute;left:0;right:0;top:-12%;height:22%;background:linear-gradient(180deg, rgba(94, 255, 223, 0) 0%, rgba(94, 255, 223, .18) 34%, rgba(94, 255, 223, .42) 52%, rgba(94, 255, 223, .16) 72%, rgba(94, 255, 223, 0) 100%);mix-blend-mode:screen;animation:scan-beam 2.9s ease-in-out infinite}
.scanLabel{position:absolute;left:14px;right:14px;bottom:14px;min-height:34px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.72);backdrop-filter:blur(12px);color:#25685c;font-size:12px;font-weight:800;letter-spacing:.03em}
html[data-theme="dark"] .scanLabel{background:rgba(18,16,15,.74);color:#8df4de}
.profileCopy{display:flex;flex-direction:column;justify-content:flex-start}
.profileCopy h2{margin:6px 0 10px;font-size:clamp(30px, 4vw, 44px);line-height:.98}
.profileCopy p{margin:0;color:var(--muted);font-size:16px;line-height:1.78}
.profileLead{max-width:62ch}
.profileTraits{margin-top:14px}
.formShell{position:sticky;top:18px;padding:22px}
body.tg-mini-app .formShell{top:8px;padding:18px}
body.tg-mini-app .formShell{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
  border-color:rgba(255,255,255,.08);
  box-shadow:none;
}
.formHeader{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:18px}
body.tg-mini-app .formHeader{margin-bottom:12px}
.formHeaderMeta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.formHeader h2{margin:0;font-size:28px;line-height:1.05}
body.tg-mini-app .formHeader h2{font-size:24px}
.formHeader p{margin:8px 0 0;color:var(--muted);font-size:14px;line-height:1.6}
body.tg-mini-app .formHeader p{display:none}
.miniBadge{padding:8px 10px;border-radius:14px;background:var(--accent-soft);color:var(--accent-strong);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
body.tg-mini-app .miniBadge{display:none}
.collapseToggle{min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(57,35,24,.12);background:rgba(255,255,255,.7);color:var(--ink);font-size:12px;font-weight:800;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}
.collapseToggle:hover{transform:translateY(-1px)}
.formShellCollapsed{padding-bottom:18px}
.collapsedFormBody{display:none}
.telegramSubmitHint{
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
  padding:0 16px;
  border-radius:20px;
  border:1px dashed rgba(196,90,53,.24);
  background:rgba(255,255,255,.38);
  color:var(--muted);
  font-size:14px;
  font-weight:700;
  text-align:center;
}
html[data-theme="dark"] .telegramSubmitHint{background:rgba(255,248,244,.05);border-color:rgba(255,235,220,.12)}
body.tg-mini-app .telegramSubmitHint{
  min-height:48px;
  margin-bottom:8px;
  padding:0 14px;
  border-radius:16px;
  border-style:solid;
  background:rgba(255,255,255,.06);
}
.formSection{margin-bottom:12px;padding:14px;border-radius:22px;border:1px solid rgba(57,35,24,.08);background:linear-gradient(180deg, rgba(255,250,246,.55), rgba(255,247,241,.32))}
body.tg-mini-app .formSection{
  margin-bottom:8px;
  padding:10px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.06);
}
.sectionIntro{margin-bottom:10px}
.tg-mini-app .sectionIntro{margin-bottom:8px}
.sectionIntro h3{margin:0;font-size:18px;line-height:1.2}
body.tg-mini-app .sectionIntro h3{font-size:14px}
.sectionIntro p{margin:6px 0 0;color:var(--muted);font-size:12px;line-height:1.5}
.field{display:block;margin-bottom:12px}
body.tg-mini-app .field{margin-bottom:8px}
.heroField{margin-bottom:0}
.fieldLabel{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:8px}
body.tg-mini-app .fieldLabel{display:none}
.fieldLabel strong{font-size:14px}
.field textarea,.field input,.field select{width:100%;border:1px solid rgba(57,35,24,.1);background:rgba(255,255,255,.82);color:var(--ink);border-radius:18px;padding:15px 16px;outline:none;transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease}
body.tg-mini-app .field textarea,
body.tg-mini-app .field input,
body.tg-mini-app .field select{
  border-radius:14px;
  padding:12px 13px;
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.08);
}
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field select,
html[data-theme="dark"] .budgetNumber input{background:rgba(17,14,12,.88);border-color:rgba(255,235,220,.12);color:var(--ink)}
.field textarea{min-height:150px;resize:none}
.compactTextarea{min-height:108px !important;max-height:108px;overflow-y:auto}
.majorTextarea{min-height:124px !important;max-height:180px;font-size:15px;line-height:1.62}
body.tg-mini-app .compactTextarea.majorTextarea{min-height:110px !important;max-height:140px}
.fieldNote{display:block;margin-top:6px;color:var(--muted);font-size:11px;line-height:1.45}
.promptHints{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.promptHint{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:rgba(255,255,255,.66);border:1px solid rgba(57,35,24,.08);color:var(--muted);font-size:11px;font-weight:700}
.tg-mini-app .promptHints,
.tg-mini-app .fieldNote{display:none}
.field textarea:focus,.field input:focus,.field select:focus{border-color:rgba(196,90,53,.48);box-shadow:0 0 0 4px rgba(196,90,53,.1);transform:translateY(-1px)}
.fieldGrid,.analysisBand{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
body.tg-mini-app .fieldGrid{gap:8px}
.moodGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}
.compactMoodGrid{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:0}
.moodButton{padding:11px 12px;border-radius:16px;border:1px solid rgba(57,35,24,.1);background:rgba(255,255,255,.7);color:var(--muted);cursor:pointer;text-align:left;transition:.18s ease}
.moodButton strong{display:block;color:var(--ink);font-size:14px}
.moodButton.active{border-color:rgba(196,90,53,.5);background:linear-gradient(180deg, rgba(255,237,228,.95), rgba(255,248,243,.95));color:var(--accent-strong);transform:translateY(-1px)}
.toggleGrid{display:grid;gap:10px;margin-bottom:12px}
body.tg-mini-app .toggleGrid{gap:8px;margin-bottom:10px}
.compactOptions{grid-template-columns:repeat(2,minmax(0,1fr))}
.toggleCard{display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.68);border:1px solid rgba(57,35,24,.08);min-height:54px}
.statusCard{justify-content:flex-start}
.statusCard strong{display:block}
.statusCard span{display:block;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.45}
.statusDot{width:14px;height:14px;border-radius:999px;flex:0 0 auto;background:linear-gradient(180deg, #6de6b7 0%, #2faa75 100%);box-shadow:0 0 0 4px rgba(109,230,183,.14)}
body.tg-mini-app .toggleCard{
  padding:11px 12px;
  min-height:48px;
  border-radius:15px;
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.08);
}
body.tg-mini-app .toggleCard strong{font-size:13px}
.toggleCard.active{
  border-color:rgba(196,90,53,.38);
  background:linear-gradient(180deg, rgba(255,239,229,.96), rgba(255,248,243,.92));
  box-shadow:0 12px 28px rgba(157,61,30,.12);
}
html[data-theme="dark"] .toggleCard,
html[data-theme="dark"] .uploadBox,
html[data-theme="dark"] .bullet,
html[data-theme="dark"] .loaderCaption{background:rgba(31,24,21,.86)}
html[data-theme="dark"] .moodButton,
html[data-theme="dark"] .toggleCard,
html[data-theme="dark"] .uploadBox,
html[data-theme="dark"] .bullet{background:rgba(31,24,21,.78);border-color:rgba(255,235,220,.08);color:var(--muted)}
html[data-theme="dark"] .toggleCard.active{
  background:linear-gradient(180deg, rgba(60,37,28,.96), rgba(42,29,23,.92));
  border-color:rgba(239,143,95,.28);
  box-shadow:0 14px 30px rgba(0,0,0,.22);
}
html[data-theme="dark"] .toggleCard input{background:rgba(255,248,244,.96);border-color:rgba(255,235,220,.12)}
.toggleCard input{
  margin-top:0;
  width:22px;
  height:22px;
  appearance:none;
  -webkit-appearance:none;
  border-radius:999px;
  border:1px solid rgba(57,35,24,.16);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.toggleCard input:hover{transform:translateY(-1px)}
.toggleCard input:checked{
  background:rgba(255,248,244,.98);
  border-color:rgba(157,61,30,.28);
  box-shadow:0 8px 18px rgba(157,61,30,.14);
}
.toggleCard input::after{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:transparent;
  transition:background .18s ease, transform .18s ease;
}
.toggleCard input:checked::after{
  background:#4a3125;
  transform:scale(1);
}
html[data-theme="dark"] .toggleCard input:checked::after{background:#1a120f}
.toggleCard strong{display:block;font-size:14px;line-height:1.35}
.telegramLinkNotice{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:12px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.72);border:1px solid rgba(57,35,24,.08)}
.telegramLinkNotice p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}
.telegramLinkNotice a{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong);font-size:12px;font-weight:800;white-space:nowrap}
.telegramLinkNotice.connected{background:rgba(223,246,230,.82);border-color:rgba(26,125,72,.16)}
.telegramLinkNotice.connected p{color:#1f6b43}
.telegramLinkNotice.connecting{background:rgba(255,244,226,.84);border-color:rgba(196,90,53,.16)}
.telegramLinkNotice.connecting p{color:#8d4d24}
.telegramLinkNotice.browser{background:rgba(238,242,255,.86);border-color:rgba(92,115,196,.16)}
.telegramLinkNotice.browser p{color:#415495}
.telegramLinkNotice.error{background:rgba(255,235,235,.86);border-color:rgba(179,62,62,.16)}
.telegramLinkNotice.error p{color:#8f2e2e}
.budgetShell{margin-bottom:12px;padding:14px;border-radius:22px;background:linear-gradient(180deg, rgba(255,249,244,.9), rgba(253,241,231,.95));border:1px solid rgba(57,35,24,.08)}
body.tg-mini-app .budgetShell{
  margin-bottom:6px;
  padding:10px;
  border-radius:16px;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.07);
}
html[data-theme="dark"] .budgetShell{background:linear-gradient(180deg, rgba(35,27,23,.94), rgba(27,21,18,.96));border-color:rgba(255,235,220,.08)}
.budgetHeader{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.budgetHeader strong{font-size:15px}
.budgetHeader span{display:block;color:var(--muted);font-size:13px;max-width:220px;text-align:right}
body.tg-mini-app .budgetHeader strong{font-size:14px}
body.tg-mini-app .budgetHeader span{font-size:12px;max-width:180px}
body.tg-mini-app .budgetInputs{gap:8px;margin-bottom:8px}
.budgetInputs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px}
.budgetNumber span{display:block;margin-bottom:6px;color:var(--muted);font-size:12px;font-weight:700}
.budgetNumber input{width:100%;border:1px solid rgba(57,35,24,.1);background:#fff;border-radius:16px;padding:12px 14px;outline:none}
.dualRange{position:relative;height:32px;display:flex;align-items:center}
.dualTrack,.dualRangeFill{position:absolute;left:0;right:0;height:8px;border-radius:999px}
.dualTrack{background:linear-gradient(90deg, #efe0d3, #dcb499)}
.dualRangeFill{background:linear-gradient(90deg, #9d3d1e, #c45a35)}
.dualRange input[type="range"]{position:absolute;left:0;top:0;width:100%;height:32px;appearance:none;background:transparent;pointer-events:none}
.dualRange input[type="range"]::-webkit-slider-runnable-track{height:8px;background:transparent}
.dualRange input[type="range"]::-webkit-slider-thumb{appearance:none;margin-top:-7px;width:22px;height:22px;border-radius:50%;background:#1f1712;border:2px solid #fff6;box-shadow:var(--shadow);pointer-events:auto}
.dualRange input[type="range"]::-moz-range-track{height:8px;background:transparent}
.dualRange input[type="range"]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#1f1712;border:2px solid #fff6;box-shadow:var(--shadow);pointer-events:auto}
.budgetValues{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:13px}
.uploadBox{display:flex;justify-content:space-between;gap:10px;align-items:center;min-height:56px;padding:10px 12px;border-radius:18px;border:1px dashed rgba(57,35,24,.18);background:rgba(255,255,255,.72)}
.standoutUpload{background:linear-gradient(180deg, rgba(255,244,236,.94), rgba(255,250,246,.82));border-color:rgba(196,90,53,.24)}
.uploadInner{flex:1;display:flex;align-items:center;min-height:38px;cursor:pointer}
.uploadBox strong{display:block;font-size:14px}
.uploadBox span{display:block;color:var(--muted);font-size:12px;line-height:1.5}
.uploadBox input{display:none}
.clearPhoto{width:34px;height:34px;border-radius:999px;border:1px solid rgba(57,35,24,.14);background:#fff;color:#9d3d1e;font-size:20px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.themeToggle:focus-visible,
.clearPhoto:focus-visible,
.submitButton:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.clearPhoto.active{background:#fff3ea;border-color:rgba(157,61,30,.28)}
.submitButton{width:100%;min-height:60px;border:0;border-radius:20px;background:linear-gradient(180deg, var(--accent) 0%, var(--accent-strong) 100%);color:#fff;font-size:16px;font-weight:800;cursor:pointer;box-shadow:0 16px 36px rgba(157,61,30,.25)}
.submitButton:disabled{opacity:.7;cursor:wait}
.statusRow{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-top:14px}
body.tg-mini-app .statusRow{margin-top:10px}
body.tg-mini-app .statusRow p{display:none}
.statusRow p{margin:0;color:var(--muted);font-size:13px;line-height:1.6;max-width:440px}
.sourceBadge{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:800;white-space:nowrap}
.sourceBadge.demo{background:#fff1da;color:#7b5605;border:1px solid #edd8a1}
.sourceBadge.openai{background:#def6e6;color:#155b2d;border:1px solid #b7e5c7}
.resultArea{padding:10px 0 42px}
.resultArea.hidden{display:none}
.telegramReminderCard{display:flex;justify-content:space-between;gap:16px;align-items:center;margin:0 0 18px;padding:16px 18px;border-radius:24px;background:rgba(255,250,244,.76);border:1px solid rgba(57,35,24,.08);box-shadow:var(--shadow)}
.telegramReminderCard strong{display:block;font-size:18px}
.telegramReminderCard p{margin:6px 0 0;color:var(--muted);line-height:1.6;max-width:720px}
.telegramReminderCard a{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong);font-size:14px;font-weight:800;white-space:nowrap}
.resultHeader{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;margin-bottom:18px}
.resultHeader h2{margin:0;font-size:36px;line-height:1}
.resultHeader p{margin:8px 0 0;color:var(--muted);line-height:1.7}
.compactCardsHeader{margin:6px 0 14px}
.compactCardsHeader p{margin:8px 0 0;color:var(--muted);line-height:1.68;max-width:720px}
.portraitWide{margin-bottom:16px}
.analysisBand{margin-bottom:16px}
.singleRow{grid-template-columns:1fr;margin-bottom:18px}
.bulletList{display:grid;gap:10px;margin-top:14px}
.inlineBullets{grid-template-columns:repeat(3,minmax(0,1fr))}
.bullet{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.65);border:1px solid rgba(57,35,24,.08);color:var(--muted);line-height:1.65}
.cardsHeader{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;margin:20px 0 14px}
.cardsHeader h3{margin:0;font-size:28px}
.cards{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:16px}
.giftCard{overflow:hidden;transition:transform .18s ease, box-shadow .18s ease}
.giftCard:hover{transform:translateY(-3px)}
.giftMedia{aspect-ratio:16/10;background:linear-gradient(135deg, rgba(244,216,199,.9), rgba(244,239,211,.72))}
html[data-theme="dark"] .giftMedia{background:linear-gradient(135deg, rgba(74,54,42,.9), rgba(52,42,35,.82))}
.giftMedia img{width:100%;height:100%;object-fit:cover}
.giftBody{padding:18px}
.giftMeta{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.giftTitle{margin:0;font-size:22px;line-height:1.15}
.giftBadge{padding:7px 9px;border-radius:12px;background:#fff3ea;color:var(--accent-strong);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.giftBody p{margin:12px 0 0;color:var(--muted);line-height:1.7}
.giftFoot{margin-top:14px;padding-top:14px;border-top:1px solid rgba(57,35,24,.08)}
.giftQuery{color:var(--olive);font-size:13px;font-weight:700;line-height:1.5}
.giftLinks{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.giftLinks a{min-height:40px;padding:0 14px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;background:#f4ecdf;border:1px solid rgba(57,35,24,.08);font-weight:700}
.giftLinks a:hover{background:#ece0d1}
html[data-theme="dark"] .giftLinks a{background:#2a211d;border-color:rgba(255,235,220,.08)}
html[data-theme="dark"] .giftLinks a:hover{background:#362923}
html[data-theme="dark"] .collapseToggle{background:rgba(31,24,21,.82);border-color:rgba(255,235,220,.08);color:var(--ink)}
html[data-theme="dark"] .formSection{background:linear-gradient(180deg, rgba(36,28,24,.94), rgba(29,22,19,.86));border-color:rgba(255,235,220,.08)}
html[data-theme="dark"] .promptHint{background:rgba(31,24,21,.82);border-color:rgba(255,235,220,.08)}
html[data-theme="dark"] .telegramLinkNotice{background:rgba(31,24,21,.82);border-color:rgba(255,235,220,.08)}
html[data-theme="dark"] .telegramLinkNotice.connected{background:rgba(20,48,35,.86);border-color:rgba(98,179,132,.18)}
html[data-theme="dark"] .telegramLinkNotice.connected p{color:#b6ebcb}
html[data-theme="dark"] .telegramLinkNotice.connecting{background:rgba(63,40,24,.9);border-color:rgba(239,143,95,.16)}
html[data-theme="dark"] .telegramLinkNotice.connecting p{color:#ffd1b3}
html[data-theme="dark"] .telegramLinkNotice.browser{background:rgba(28,33,54,.9);border-color:rgba(129,149,255,.16)}
html[data-theme="dark"] .telegramLinkNotice.browser p{color:#c8d3ff}
html[data-theme="dark"] .telegramLinkNotice.error{background:rgba(64,26,26,.9);border-color:rgba(227,112,112,.16)}
html[data-theme="dark"] .telegramLinkNotice.error p{color:#ffc7c7}
html[data-theme="dark"] .telegramLinkNotice a{background:rgba(255,248,244,.12);color:#f4e8de;border:1px solid rgba(255,235,220,.08)}
html[data-theme="dark"] .statusCard span{color:#cbb8ab}
html[data-theme="dark"] .telegramReminderCard{background:rgba(33,25,22,.76);border-color:rgba(255,235,220,.08)}
html[data-theme="dark"] .telegramReminderCard a{background:rgba(255,248,244,.12);color:#f4e8de;border:1px solid rgba(255,235,220,.08)}
html[data-theme="dark"] .standoutUpload{background:linear-gradient(180deg, rgba(48,34,28,.96), rgba(31,24,21,.86));border-color:rgba(239,143,95,.18)}
.loaderOverlay{position:fixed;inset:0;z-index:50;background:radial-gradient(circle at center, rgba(255,241,225,.14), rgba(41,27,19,.48));backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;padding:24px}
html[data-theme="dark"] .loaderOverlay{background:radial-gradient(circle at center, rgba(70,49,37,.18), rgba(12,10,9,.68))}
.loaderOrb{position:relative;width:420px;max-width:100%;display:flex;align-items:center;justify-content:center;background:transparent;box-shadow:none;border:0}
.loaderOrb::before{content:"";position:absolute;left:50%;top:50%;width:320px;height:170px;transform:translate(-50%,-50%);border-radius:999px;background:radial-gradient(circle at center, rgba(255,250,243,.92) 0%, rgba(255,244,230,.7) 34%, rgba(255,236,214,.26) 64%, rgba(255,236,214,0) 78%);filter:blur(14px);pointer-events:none}
.loaderCaption{max-width:620px;text-align:center;padding:14px 18px;border-radius:28px;background:rgba(255,249,242,.74);border:1px solid rgba(255,255,255,.5);box-shadow:0 18px 48px rgba(58,34,21,.12);backdrop-filter:blur(8px)}
.loaderCaption h3{margin:0 0 8px;font-size:30px;line-height:1.04;color:#3e271c;text-shadow:none}
.loaderCaption p{margin:0 auto;max-width:520px;color:#6e5445;line-height:1.75;font-size:16px;text-shadow:none}
html[data-theme="dark"] .loaderCaption{background:rgba(31,24,21,.86);border-color:rgba(255,235,220,.08)}
html[data-theme="dark"] .loaderCaption h3{color:#f4e8de}
html[data-theme="dark"] .loaderCaption p{color:#c8b8ac}
.diesel-loader{position:relative;z-index:1;width:320px;height:210px;display:inline-flex;align-items:center;justify-content:center;overflow:visible;user-select:none;filter:drop-shadow(0 18px 36px rgba(68,39,19,.22))}
.loader-scene{width:300px;height:200px;overflow:visible}
.bg{fill:none;stroke:none}
.ground{stroke:#73563f;stroke-width:3.2;stroke-linecap:round;stroke-dasharray:3 4;opacity:.95}
.flywheel-wrap{transform-origin:78px 118px;animation:flywheel-shake 2.9s infinite ease-in-out}
.flywheel.outer,.flywheel.inner{fill:none;stroke:#4f4b48}
.flywheel.outer{stroke-width:8}
.flywheel.inner{stroke-width:4;opacity:.8}
.hub{fill:#4b4644}
.spoke{stroke:#69615d;stroke-width:3;stroke-linecap:round;opacity:.86}
.tire-wrap{transform-box:fill-box;transform-origin:center;animation:tire-journey 2.9s infinite linear}
.tire{transform-origin:112px 102px}
.spin-phase{animation:tire-spin 2.9s infinite linear}
.tire-outer{fill:#302c2a;stroke:#1b1716;stroke-width:2}
.tire-inner{fill:#d4cdca;stroke:#7f7773;stroke-width:1.5}
.tire-mark{stroke:#efefef;stroke-width:1.4;stroke-linecap:round;opacity:.9}
.worker .head{fill:#f0c089;stroke:#5f4026;stroke-width:1.2}
.body-line,.stick,.ladder-rail,.ladder-rung{fill:none;stroke-linecap:round}
.body-line{stroke:#48413d;stroke-width:3}
.stick{stroke:#8c5a34;stroke-width:4}
.worker-left{transform-origin:135px 135px;animation:left-worker 2.9s infinite ease-in-out}
.arm-kick{transform-origin:135px 119px;animation:poke-arm 2.9s infinite ease-in-out}
.worker-right{transform-origin:240px 137px;animation:right-worker 2.9s infinite ease-in-out}
.ladder{transform-origin:231px 151px;animation:ladder-hit 2.9s infinite ease-in-out}
.ladder-rail{stroke:#95612f;stroke-width:4}
.ladder-rung{stroke:#a56f3a;stroke-width:3}
.dust{fill:#a78662;opacity:0}
.dust-left{animation:dust-left 2.9s infinite linear}
.dust-hit{animation:dust-hit 2.9s infinite linear}
.footerSection{padding:8px 0 44px}
.footerGrid{display:grid;grid-template-columns:repeat(3, 1fr);gap:16px}
.seoSection{padding:0 0 52px}
.seoIntro{margin:0 0 16px}
.seoIntro h3{margin:0;font-size:30px;line-height:1.02}
.seoIntro p{margin:10px 0 0;color:var(--muted);line-height:1.72;max-width:860px}
.seoGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.seoCard{min-height:100%}
@keyframes flywheel-shake{0%,8%{transform:translate(0,0) rotate(0deg)}10%,12%,14%,16%,18%,20%{transform:translate(-0.7px,0.4px) rotate(-0.8deg)}11%,13%,15%,17%,19%,21%{transform:translate(0.8px,-0.4px) rotate(0.8deg)}23%,100%{transform:translate(0,0) rotate(0deg)}}
@keyframes tire-spin{0%{transform:rotate(0deg)}18%{transform:rotate(2200deg)}38%{transform:rotate(2600deg)}56%,100%{transform:rotate(3040deg)}}
@keyframes tire-journey{0%,14%,18%{transform:translate(0px,0px);opacity:1}26%{transform:translate(32px,28px);opacity:1}34%{transform:translate(72px,50px);opacity:1}40%{transform:translate(103px,52px);opacity:1}46%{transform:translate(120px,20px);opacity:1}52%{transform:translate(138px,-35px);opacity:1}56%{transform:translate(154px,-85px);opacity:0}57%,100%{transform:translate(0px,0px);opacity:0}}
@keyframes left-worker{0%,13%{transform:rotate(0deg) translateY(0)}16%{transform:rotate(-4deg) translateY(-1px)}18%{transform:rotate(6deg) translateY(0)}21%,100%{transform:rotate(0deg) translateY(0)}}
@keyframes poke-arm{0%,14%{transform:rotate(0deg)}17%{transform:rotate(18deg)}20%,100%{transform:rotate(0deg)}}
@keyframes right-worker{0%,39%{transform:rotate(0deg)}43%{transform:rotate(3deg) translateX(1px)}47%{transform:rotate(-6deg) translateX(-2px)}52%{transform:rotate(2deg) translateX(1px)}58%,100%{transform:rotate(0deg)}}
@keyframes ladder-hit{0%,39%{transform:rotate(0deg)}42%{transform:rotate(-8deg)}45%{transform:rotate(12deg)}49%{transform:rotate(-6deg)}55%,100%{transform:rotate(0deg)}}
@keyframes dust-left{0%,17%{opacity:0;transform:translate(0,0) scale(0.6)}20%{opacity:.85;transform:translate(0,-1px) scale(1)}26%{opacity:0;transform:translate(8px,-4px) scale(1.4)}100%{opacity:0}}
@keyframes dust-hit{0%,39%{opacity:0;transform:translate(0,0) scale(0.6)}43%{opacity:.95;transform:translate(0,0) scale(1)}50%{opacity:0;transform:translate(10px,-8px) scale(1.8)}100%{opacity:0}}
@keyframes scan-beam{0%,100%{transform:translateY(-16%)}50%{transform:translateY(430%)}}
@keyframes panel-in{0%{opacity:0;transform:translateX(24px) scale(.985)}100%{opacity:1;transform:translateX(0) scale(1)}}
@keyframes hero-swap-left{0%{opacity:.72;transform:translateX(28px)}100%{opacity:1;transform:translateX(0)}}
@keyframes hero-swap-right{0%{opacity:.72;transform:translateX(-28px)}100%{opacity:1;transform:translateX(0)}}
@keyframes dice-roll{
  0%{transform:translateY(0) rotate(0deg) scale(1)}
  24%{transform:translateY(-6px) rotate(-10deg) scale(1.04)}
  52%{transform:translateY(3px) rotate(12deg) scale(.98)}
  78%{transform:translateY(-2px) rotate(-6deg) scale(1.02)}
  100%{transform:translateY(0) rotate(0deg) scale(1)}
}
@keyframes lucky-orb-pulse{
  0%,100%{transform:scale(1);box-shadow:0 18px 40px rgba(157,61,30,.12)}
  50%{transform:scale(1.06);box-shadow:0 22px 50px rgba(157,61,30,.18)}
}
@keyframes lucky-line-sheen{
  0%{background-position:100% 0}
  100%{background-position:-100% 0}
}
@media (max-width:1080px){
  .hero,.heroGrid,.analysisBand,.cards,.footerGrid,.seoGrid{grid-template-columns:1fr}
  .fieldGrid,.moodGrid,.inlineBullets,.budgetInputs{grid-template-columns:1fr}
  .profileFrame{width:100%;max-width:none}
  .story{order:2;padding:8px 0 0}
  .luckyTile{width:100%;max-width:360px}
  .formShell{order:1;position:static}
  .loaderOrb{width:min(340px, 100%);height:auto}
  .loaderOrb::before{width:280px;height:150px}
  .diesel-loader{width:280px;height:190px}
}
@media (max-width:720px){
  .wrap{width:min(100% - 16px, 1240px)}
  body.tg-mini-app .wrap{width:min(100% - 12px, 1240px)}
  .header{gap:14px;align-items:stretch;flex-direction:column;padding:16px 0 12px}
  body.tg-mini-app .header{padding:10px 0 8px}
  .brand{gap:10px;align-items:flex-start}
  .brandMarkImage{width:46px;height:46px}
  .brandText{padding-top:1px;gap:5px}
  .brandTitle{font-size:34px}
  .brandText span{font-size:12px}
  .headerMeta{justify-content:flex-start}
  .themeToggle{min-height:42px;padding:0 12px}
  .hero{gap:14px;padding:6px 0 18px}
  body.tg-mini-app .hero{gap:10px;padding:0 0 12px}
  body.tg-mini-app .hero{grid-template-columns:1fr}
  .heroStage{order:2}
  .formShell{order:1}
  body.tg-mini-app .formShell{padding:14px}
  .story{padding:0}
  .story h1{font-size:40px;line-height:1}
  body.tg-mini-app .story h1{font-size:22px}
  .lead{margin-top:16px;font-size:17px;line-height:1.72}
  .eyebrow{margin-bottom:14px;padding:9px 14px;font-size:12px}
  .heroPanel,.teaseCard,.formShell,.resultShell,.analysisCard,.giftCard,.footerCard,.loaderCard{border-radius:22px;padding:18px}
  .luckyTile{margin-top:18px;padding:18px;border-radius:24px;max-width:none;min-height:332px}
  .luckyTileIdle strong,.luckyTileBody strong{font-size:26px}
  .diceStage{min-height:208px}
  .diceCube{width:104px;height:104px}
  .face1,.face6,.face2,.face5,.face3,.face4{transform-origin:center}
  .face1{transform:translateZ(52px)}
  .face6{transform:rotateY(180deg) translateZ(52px)}
  .face2{transform:rotateY(90deg) translateZ(52px)}
  .face5{transform:rotateY(-90deg) translateZ(52px)}
  .face3{transform:rotateX(90deg) translateZ(52px)}
  .face4{transform:rotateX(-90deg) translateZ(52px)}
  .diceFace{border-radius:24px}
  .pip{width:14px;height:14px}
  .topLeft,.midLeft,.bottomLeft{left:20px}
  .topRight,.midRight,.bottomRight{right:20px}
  .topLeft,.topRight{top:20px}
  .bottomLeft,.bottomRight{bottom:20px}
  .luckyCaption{font-size:22px}
  .luckyTileFoot{align-items:flex-start;flex-direction:column}
  .formHeader{margin-bottom:14px}
  .formHeader h2{font-size:26px}
  .formHeader p{font-size:15px}
  .formHeaderMeta{width:100%;justify-content:space-between}
  .collapseToggle{min-height:40px;font-size:13px}
  .formSection{padding:14px;border-radius:20px;margin-bottom:14px}
  .sectionIntro h3{font-size:17px}
  .sectionIntro p{font-size:13px;line-height:1.55}
  .field{margin-bottom:12px}
  .fieldLabel strong,.toggleCard strong,.moodButton strong{font-size:15px}
  .field textarea,.field input,.field select{padding:16px 15px;border-radius:16px;font-size:16px}
  .compactTextarea{min-height:120px !important;max-height:120px}
  .majorTextarea{min-height:148px !important;max-height:240px}
  .promptHints{gap:6px}
  .promptHint{font-size:11px;padding:0 10px;min-height:32px}
  .uploadBox{min-height:64px;padding:12px 14px}
  .uploadBox strong{font-size:15px}
  .uploadBox span{font-size:13px}
  .profilePanel{padding:12px 12px 16px;border-radius:22px;gap:12px}
  .profileFrame{border-radius:22px}
  .scanLabel{left:10px;right:10px;bottom:10px;font-size:11px}
  .profileCopy h2{font-size:28px;margin-top:2px}
  .profileCopy p{font-size:15px;line-height:1.72}
  .moodGrid{grid-template-columns:1fr 1fr;gap:8px}
  .compactMoodGrid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .moodButton{padding:12px}
  .budgetShell{padding:14px;border-radius:20px}
  .budgetHeader{flex-direction:column;align-items:flex-start}
  .budgetHeader span{max-width:none;text-align:left;font-size:14px}
  .budgetInputs{gap:10px}
  .budgetNumber span{font-size:13px}
  .budgetNumber input{padding:13px 14px;font-size:16px}
  .toggleGrid{gap:8px}
  .compactOptions{grid-template-columns:1fr 1fr}
  .toggleCard{padding:13px 14px;min-height:54px}
  .telegramReminderCard{flex-direction:column;align-items:flex-start}
  .telegramReminderCard a{width:100%}
  .telegramLinkNotice{flex-direction:column;align-items:flex-start}
  .telegramLinkNotice a{width:100%}
  .submitButton{min-height:58px;font-size:17px}
  .telegramSubmitHint{min-height:52px;font-size:13px;border-radius:18px}
  body.tg-mini-app .telegramSubmitHint{min-height:46px;border-radius:15px}
  .statusRow,.resultHeader,.cardsHeader{flex-direction:column;align-items:flex-start}
  .statusRow p{font-size:14px;line-height:1.65}
  .resultArea{padding:4px 0 28px}
  .resultHeader h2{font-size:30px}
  .resultHeader p,.analysisCard p,.resultShell p,.giftBody p,.footerCard p{font-size:15px;line-height:1.72}
  .analysisBand,.cards,.footerGrid,.inlineBullets{grid-template-columns:1fr}
  .cardsHeader h3{font-size:24px}
  .compactCardsHeader p{font-size:14px;line-height:1.62}
  .giftBody{padding:16px}
  .giftTitle{font-size:21px}
  .giftLinks a{min-height:42px;padding:0 12px;font-size:14px}
  .footerSection{padding:0 0 28px}
  .seoSection{padding:0 0 28px}
  .seoIntro h3{font-size:24px}
  .seoIntro p{font-size:15px;line-height:1.68}
  .loaderOverlay{padding:18px}
  .loaderCaption{padding:14px 16px}
  .loaderCaption h3{font-size:24px}
  .loaderCaption p{font-size:15px;line-height:1.68}
}
