.btn{width:100%;border:0;border-radius:18px;height:58px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .15s ease,opacity .2s ease}.btn:active{transform:scale(.98)}.btn--primary{color:var(--button-main-text);background:var(--button-main);box-shadow:0 8px 24px #5bbfa04d}.btn--primary:disabled{background:#e8edf2;color:#a0aec0;box-shadow:none;cursor:not-allowed}.btn--secondary{border:2px solid var(--stroke);color:#a0aec0;background:var(--surface)}.progress-bar{display:grid;grid-template-columns:repeat(var(--steps, 4),minmax(0,1fr));gap:6px}.progress-bar__item{height:3px;border-radius:99px;background:#e2eef8}.progress-bar__item.is-active{background:var(--mint)}.screen-layout{max-width:430px;margin:0 auto;min-height:100vh;min-height:100dvh;padding:calc(52px + env(safe-area-inset-top)) 20px calc(18px + env(safe-area-inset-bottom));display:flex;flex-direction:column;background:var(--app-bg)}.screen-layout--with-nav{padding-bottom:calc(92px + env(safe-area-inset-bottom))}.section-title{margin:0;font-size:26px;line-height:1.2;text-align:center}.section-subtitle{margin:8px 0 0;text-align:center;font-size:14px;color:var(--text-muted);line-height:1.5}.card{border:2px solid var(--stroke);border-radius:18px;background:var(--surface);box-shadow:0 2px 10px #0000000d}.onboarding-hero{margin:28px auto 10px}.onboarding-hero__circle{width:120px;height:120px;border-radius:50%;display:grid;place-items:center;font-size:42px;background:linear-gradient(160deg,#e8f8f2,#eef6ff);border:2px solid #d0eadf}.reasons-grid{margin-top:26px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.reason-card{border:2px solid var(--stroke);border-radius:18px;background:var(--surface);min-height:116px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;font-size:13px;font-weight:500;color:#4a5568;cursor:pointer}.reason-card.is-selected{border-color:#9ad7c3;background:#f4fffb}.screen-footer{margin-top:auto;padding-top:20px}.smoking-type-grid{margin-top:28px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.smoking-type-card{border:2px solid var(--stroke);background:var(--surface);border-radius:20px;padding:22px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:border-color .15s,background .15s,transform .1s}.smoking-type-card:active{transform:scale(.97)}.smoking-type-card__icon{font-size:40px;line-height:1}.smoking-type-card__label{font-size:14px;font-weight:600;color:#4a5568}.smoking-type-card.is-selected{border-color:var(--mint);background:linear-gradient(145deg,#e8f8f2,#edf6ff)}.smoking-type-card.is-selected .smoking-type-card__label{color:var(--mint-dark)}.habit-form{margin-top:26px;display:flex;flex-direction:column;gap:20px}.input-row{display:flex;flex-direction:column;gap:8px}.input-row>span{color:var(--text-muted);font-size:13px;font-weight:600;letter-spacing:.03em}.input-row__field{border:2px solid var(--stroke);border-radius:16px;background:var(--surface);min-height:62px;padding:2px 16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0000000a;transition:border-color .15s}.input-row__field:focus-within{border-color:var(--mint);outline:none}.input-row__field input{border:0;outline:none;width:100%;background:transparent;font-size:17px;color:var(--text-primary)}.input-row__field em{font-style:normal;color:#a0aec0;font-size:15px}.monthly-card{border-radius:16px;border:1px solid #c8eae0;background:linear-gradient(163deg,#e8f8f2,#edf6ff);padding:16px 20px}.monthly-card small{display:block;font-size:13px;font-weight:600;color:var(--mint)}.monthly-card strong{display:block;margin-top:4px;font-size:30px;line-height:1.1}.monthly-card p{margin:4px 0 0;font-size:13px;color:var(--text-muted)}.trigger-grid{margin-top:24px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.trigger-chip{border:2px solid var(--stroke);background:var(--surface);border-radius:100px;height:52px;padding:0 18px;display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#4a5568}.trigger-chip.is-selected{background:#e8f8f2;border-color:var(--mint);color:var(--mint-dark);font-weight:600}.hint-card{margin-top:28px;border-radius:16px;background:#5bbfa014;padding:14px 18px;display:flex;align-items:flex-start;gap:12px}.hint-card p{margin:0;color:#7a9bae;font-size:13px;line-height:1.5}.bottom-nav{position:fixed;left:50%;bottom:calc(12px + env(safe-area-inset-bottom));transform:translate(-50%);width:min(390px,calc(100% - 24px));background:#fffffff0;border:1px solid #edf2f7;border-radius:20px;box-shadow:0 8px 24px #00000014;padding:8px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.bottom-nav__item{border-radius:14px;min-height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:11px;color:#8a9bae}.bottom-nav__item.is-active{background:#e8f8f2;color:var(--mint-dark);font-weight:600}.home-header{display:flex;justify-content:space-between;align-items:center}.home-header small{color:#a0aec0;font-size:13px}.home-header h1{margin:2px 0 0;font-size:36px;line-height:1.1}.home-header__badge{width:42px;height:42px;border-radius:21px;display:grid;place-items:center;background:linear-gradient(135deg,var(--mint),var(--blue))}.streak-banner{margin-top:24px;border:1px solid #d0eadf;border-radius:20px;background:linear-gradient(163deg,#e8f8f2,#edf6ff);padding:18px 20px}.streak-banner small{color:var(--mint);font-size:13px;font-weight:700}.streak-banner h2{margin:4px 0;font-size:17px}.streak-banner h2 span{color:var(--mint)}.streak-banner p{margin:0;color:var(--text-muted);font-size:13px}.home-craving{margin-top:24px;text-align:center}.home-craving__button{width:200px;height:200px;border:0;border-radius:50%;color:#fff;background:linear-gradient(145deg,var(--mint),var(--mint-dark));box-shadow:0 12px 40px #5bbfa073;display:inline-flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;font-size:13px;font-weight:600}.home-craving__icon{font-size:42px}.home-craving p{margin:16px 0 0;font-size:13px;color:#a0aec0}.home-stats-grid{margin-top:28px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.home-tile{border-radius:18px;padding:16px}.home-tile span{font-size:20px}.home-tile strong{display:block;margin-top:6px;font-size:26px}.home-tile p{margin:2px 0 0;font-size:12px;color:var(--text-muted)}.home-tile--mint{background:#e8f8f2}.home-tile--mint strong{color:var(--mint)}.home-tile--rose{background:#fef0f0}.home-tile--rose strong{color:var(--danger)}.home-streak-card{margin-top:14px;padding:16px 20px;border-radius:18px;background:#fff;box-shadow:0 2px 12px #0000000d;display:flex;justify-content:space-between;align-items:center}.home-streak-card small{color:#a0aec0;font-size:13px}.home-streak-card h3{margin:0;font-size:30px}.home-streak-card h3 span{color:var(--text-muted);font-size:14px;font-weight:500}.home-streak-card__fire{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:#fff3e0}.back-btn{width:36px;height:36px;border:1px solid var(--stroke);border-radius:12px;background:#fff;color:#a0aec0;font-size:18px}.craving-emoji{margin:20px auto 0;font-size:84px}.timer-zone{margin-top:12px;display:flex;justify-content:center}.timer-ring-wrap{position:relative;width:200px;height:200px}.timer-svg{display:block}.timer-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.timer-content strong{font-size:48px;line-height:1;font-weight:700;background:linear-gradient(135deg,#5bbfa0,#4aaed0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.timer-content small{color:#a0aec0;font-size:13px;margin-top:4px}.breath-hint{margin:18px auto 0;width:max-content;border-radius:100px;background:#5bbfa01a;color:var(--mint);padding:10px 24px;font-size:13px;font-weight:600}.tip-card{margin-top:16px;border-radius:16px;background:#fff;box-shadow:0 2px 10px #0000000d;padding:14px 18px;display:flex;gap:12px;align-items:flex-start;color:#7a9bae;font-size:13px;line-height:1.5}.tip-card p{margin:0}.craving-actions{display:flex;flex-direction:column;gap:12px}.result-hero{width:140px;height:140px;margin:36px auto 0;border-radius:50%;display:grid;place-items:center;font-size:64px}.result-hero--success{background:radial-gradient(circle,#5bbfa0,#9fdfc7,#e8f8f2)}.result-hero--fail{background:radial-gradient(circle,#eaf3fa,#f1f4f8)}.result-card{margin:24px auto 0;border-radius:20px;padding:20px;text-align:center;width:min(260px,100%)}.result-card--success{border:2px solid #c0e8d8;background:linear-gradient(145deg,#e8f8f2,#edf6ff)}.result-card small{color:var(--mint);font-size:13px;font-weight:700}.result-card strong{display:block;font-size:48px;color:var(--mint)}.result-card p{margin:0;color:var(--text-muted)}.result-quote{margin:18px 0 0;text-align:center;font-size:16px;color:#4a6275;font-style:italic}.tip-card--centered{text-align:center;justify-content:center;margin-top:18px}.fail-card{margin-top:20px;border-radius:20px;background:#fff;padding:22px 18px;box-shadow:0 4px 20px #0000000d;text-align:center}.fail-card p{margin:0;color:#4a6275;font-size:16px;line-height:1.7}.fail-card strong{color:var(--mint)}.fail-card small{display:block;margin-top:10px;color:var(--text-muted);font-size:14px}.link-btn{border:0;background:transparent;color:var(--mint);font-size:15px;font-weight:600;padding:10px}.stats-header small{color:#a0aec0;font-size:13px}.stats-header h1{margin:2px 0 0;font-size:24px}.period-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;background:var(--app-bg);border-radius:14px;padding:4px;margin-bottom:16px}.period-tab{border:none;background:transparent;border-radius:10px;padding:8px 4px;font-size:12px;font-weight:500;color:var(--text-muted);white-space:nowrap;transition:background .15s,color .15s}.period-tab.is-active{background:var(--surface);color:var(--mint-dark);font-weight:700;box-shadow:0 1px 4px #00000014}.stats-grid{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stats-card{background:#fff;border-radius:20px;box-shadow:0 2px 12px #0000000d;padding:16px}.stats-card span{font-size:18px}.stats-card small{display:block;margin-top:6px;color:#a0aec0;font-size:11px;font-weight:600}.stats-card strong{display:block;margin-top:6px;font-size:32px}.stats-card p{margin:0;color:#8a9bae;font-size:13px}.stats-journey-card{margin-top:14px;border-radius:20px;padding:20px 24px;background:linear-gradient(160deg,var(--mint),var(--blue));color:#fff;position:relative}.stats-journey-card small,.stats-journey-card p{color:#fffc}.stats-journey-card h2{margin:4px 0;font-size:36px}.stats-journey-card span{position:absolute;right:24px;top:38px;font-size:44px}.week-card,.milestones-card{margin-top:14px;background:#fff;border-radius:20px;box-shadow:0 2px 12px #0000000d;padding:20px}.week-card header{display:flex;justify-content:space-between;align-items:baseline}.week-card h3,.milestones-card h3{margin:0;font-size:24px}.week-card header small{color:#a0aec0;font-size:12px}.week-bars{margin-top:16px;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.week-bars__item{text-align:center}.week-bars__column{height:108px;display:flex;flex-direction:column;justify-content:flex-end;gap:2px}.week-bars__column span{display:block;border-radius:6px 6px 0 0}.week-bars__column .wins{background:#b8e8da}.week-bars__column .smoked{background:#f4a0a0}.week-bars__column .level-0{height:0}.week-bars__column .level-1{height:20px}.week-bars__column .level-2{height:32px}.week-bars__column .level-3{height:44px}.week-bars__column .level-4{height:56px}.week-bars__column .level-5{height:68px}.week-bars__item small{color:#a0aec0;font-size:11px}.week-card footer{margin-top:12px;display:flex;gap:16px;justify-content:center;color:#8a9bae;font-size:12px}.legend{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:4px}.legend.wins{background:#5bbfa0}.legend.smoked{background:#f4a0a0}.milestones-card ul{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}.milestones-card li{display:grid;grid-template-columns:36px 1fr 20px;align-items:center;gap:12px}.milestones-card li>span{width:36px;height:36px;border-radius:12px;background:#e8f8f2;display:grid;place-items:center}.milestones-card li strong{font-size:14px}.milestones-card li small{display:block;color:#b0bec5;font-size:12px;margin-top:2px}.milestones-card li b{color:var(--mint)}.lb-header small{color:#a0aec0;font-size:13px}.lb-header h1{margin:2px 0 0;font-size:24px}.lb-consent{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 0 32px;gap:0}.lb-consent__icon{font-size:64px;margin-bottom:16px}.lb-consent h2{margin:0 0 10px;font-size:22px}.lb-consent>p{margin:0 0 20px;color:#8a9bae;font-size:14px;line-height:1.6}.lb-consent__note{width:100%;border-radius:16px;background:#5bbfa014;padding:14px 16px;display:flex;align-items:flex-start;gap:10px;text-align:left;margin-bottom:24px}.lb-consent__note p{margin:0;color:#7a9bae;font-size:13px;line-height:1.5}.lb-consent__btn{width:100%;height:56px;border:none;border-radius:18px;background:linear-gradient(170deg,#5bbfa0,#4aaed0);color:#fff;font-size:16px;font-weight:600}.lb-consent__btn:disabled{opacity:.6}.lb-meta{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#8a9bae;margin-bottom:12px}.lb-list{display:flex;flex-direction:column;gap:8px}.lb-row{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000d;padding:14px 16px;display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:12px}.lb-row--me{background:linear-gradient(135deg,#e8f8f2,#edf6ff);border:1.5px solid #9ad7c3}.lb-row__rank{font-size:22px;text-align:center;line-height:1;font-weight:700;color:#8a9bae}.lb-row--me .lb-row__rank{color:var(--mint-dark)}.lb-row__info strong{display:block;font-size:15px;color:#1c2b3a}.lb-row__info small{display:block;margin-top:2px;font-size:12px;color:#a0aec0}.lb-row__score{text-align:right}.lb-row__score strong{display:block;font-size:20px;color:var(--mint-dark)}.lb-row__score small{display:block;font-size:11px;color:#a0aec0}.lb-separator{text-align:center;color:#c8d8e4;font-size:20px;letter-spacing:4px;padding:4px 0}.lb-empty{text-align:center;padding:48px 0;color:#8a9bae;font-size:15px}.profile-header small{color:#a0aec0;font-size:13px}.profile-header h1{margin:2px 0 0;font-size:24px}.profile-banner{margin-top:20px;border-radius:24px;background:linear-gradient(162deg,var(--mint),var(--blue));padding:18px 20px;display:flex;gap:16px;align-items:center;color:#fff}.profile-banner>div{width:60px;height:60px;border-radius:20px;background:#ffffff40;display:grid;place-items:center;font-size:28px}.profile-banner h2{margin:0;font-size:27px}.profile-banner p{margin:2px 0 0;color:#ffffffbf}.profile-section{margin-top:20px}.profile-section h3{margin:0 0 10px;padding-left:4px;color:#a0aec0;font-size:12px;letter-spacing:.06em}.profile-card{background:#fff;border-radius:20px;box-shadow:0 2px 12px #0000000d;overflow:hidden}.profile-item{width:100%;border:0;border-top:1px solid #f0f4f8;background:#fff;min-height:64px;padding:0 16px;display:grid;grid-template-columns:36px 1fr auto auto;gap:14px;align-items:center;font-size:15px;color:#1c2b3a;text-align:left}.profile-item:first-of-type{border-top:0}.profile-item>span:first-child{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:#f5f8fa}.profile-item small{color:#a0aec0;font-size:14px}.profile-item b{color:#c0c8d0;font-size:20px;font-weight:400}.chip-row{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px}.chip{height:32px;border-radius:100px;display:inline-flex;align-items:center;padding:0 12px;font-size:13px;color:#5a6877;background:#f5f8fa}.chip--mint{background:#e8f8f2;border:1px solid #c0e8d8;color:#3daa8a}.chip--sand{background:#fef6e8;border:1px solid #f0ddb8;color:#c8882a}.profile-quote{margin-top:20px;border:1px solid #fdecc8;border-radius:16px;background:linear-gradient(167deg,#fff9e6,#fef3f2);color:#8a6a2a;text-align:center;padding:16px;font-size:14px;line-height:1.6}:root{--app-bg: var(--tg-secondary-bg-color, #f7f9fb);--surface: var(--tg-bg-color, #ffffff);--text-primary: var(--tg-text-color, #1c2b3a);--text-muted: var(--tg-hint-color, #8a9bae);--stroke: #edf2f7;--mint: #5bbfa0;--mint-dark: #3daa8a;--blue: #4aaed0;--danger: #f4a0a0;--warning: #c8882a;--button-main: var(--tg-button-color, linear-gradient(170deg, #5bbfa0, #4aaed0));--button-main-text: var(--tg-button-text-color, #ffffff)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;min-height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--app-bg);color:var(--text-primary)}button,input{font:inherit;outline:none}button{cursor:pointer}input{caret-color:var(--mint);color:var(--text-primary)}a{color:inherit;text-decoration:none}
