.auth-page{max-width:480px;margin:0 auto;padding:0 20px 40px;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.auth-header{padding:14px 0;display:flex;align-items:center;justify-content:space-between}.back-btn{width:40px;height:40px;border-radius:12px;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow);border:none;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center}.back-btn:active{box-shadow:var(--shadow-in)}.step-indicator{display:flex;gap:5px;align-items:center}.step-dot{width:24px;height:4px;border-radius:2px;background:var(--surf-lo);box-shadow:var(--shadow-in);transition:background .3s}.step-dot.active{background:linear-gradient(90deg,var(--acc-hi),var(--accent));box-shadow:0 0 6px #ff5a3c80,inset 1px 1px #ffffff4d}.step-dot.done{background:linear-gradient(90deg,#34d399,#059669)}.auth-logo-block{display:flex;flex-direction:column;align-items:center;margin-top:20px;margin-bottom:24px}.auth-logo-icon{width:80px;height:80px;border-radius:50%;overflow:hidden;box-shadow:-3px 5px 14px #00000073}.auth-logo-icon img{width:100%;height:100%;object-fit:cover;display:block}.auth-logo-name{font-size:22px;font-weight:900;margin-top:12px;letter-spacing:-.5px}.auth-h1{font-size:26px;font-weight:900;letter-spacing:-.6px;margin-bottom:8px;line-height:1.2}.auth-h1 .acc{color:var(--accent)}.auth-sub{font-size:14px;color:var(--dim);line-height:1.5;margin-bottom:28px}.phone-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:18px;padding:16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;margin-bottom:18px}.phone-flag{width:44px;height:44px;border-radius:14px;background:linear-gradient(180deg,#005bbb 50%,#ffd500 50%);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:#fff;flex-shrink:0;box-shadow:-2px 2px 6px #0000004d,inset 2px 2px #ffffff4d}.phone-code{font-size:16px;font-weight:800;color:var(--text)}.phone-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:18px;font-weight:700;font-family:inherit;letter-spacing:1px;min-width:0}.phone-input::placeholder{color:var(--faint);font-weight:500}.code-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:20px}.code-cell{aspect-ratio:1;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;color:var(--text);transition:box-shadow .15s;border:2px solid transparent}.code-cell.filled{background:linear-gradient(165deg,var(--acc-hi),var(--accent));color:#fff;box-shadow:0 4px 12px #ff5a3c66,inset 2px 2px #ffffff4d}.code-cell.active{border-color:var(--accent)}.code-input-hidden{position:absolute;opacity:0;pointer-events:none;height:0;width:0}.timer-row{text-align:center;font-size:13px;color:var(--dim);margin-bottom:24px}.timer-row .accent{color:var(--accent);font-weight:700}.resend-link{color:var(--blue);cursor:pointer;font-weight:700;background:none;border:none;font-size:inherit;font-family:inherit}.resend-link:disabled{color:var(--faint);cursor:not-allowed}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 14px;border-radius:12px;font-size:13px;margin-bottom:16px}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.tile-pick{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:18px;padding:20px 14px;box-shadow:var(--shadow);text-align:center;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .2s}.tile-pick:active{transform:scale(.97)}.tile-pick.selected{border-color:var(--accent);box-shadow:0 0 0 3px #ff5a3c33,var(--shadow)}.tile-pick .ico{width:56px;height:56px;border-radius:18px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6;position:relative;overflow:hidden}.tile-pick .ico:after{content:"";position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.7),transparent 75%)}.tile-title{font-size:15px;font-weight:800;margin-bottom:4px}.tile-desc{font-size:11px;color:var(--dim);line-height:1.4}.warning-card{background:linear-gradient(135deg,#f7c94826,#f7c9480d);border:1px solid rgba(247,201,72,.3);border-radius:14px;padding:12px 14px;display:flex;gap:10px;align-items:flex-start;margin-bottom:24px}.warning-ico{color:var(--gold);font-size:18px;flex-shrink:0}.warning-text{font-size:12px;color:var(--text);line-height:1.5}.warning-text b{color:var(--gold)}.field{margin-bottom:16px}.field-label{font-size:11px;color:var(--faint);letter-spacing:1.5px;text-transform:uppercase;font-weight:700;margin-bottom:8px;padding-left:4px}.text-input{width:100%;background:#00000085;border:2px solid transparent;border-radius:14px;padding:14px 16px;color:var(--text);font-size:15px;font-weight:600;box-shadow:var(--shadow-in);outline:none;font-family:inherit}.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ff5a3c26,var(--shadow-in)}.select-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.select-item{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;cursor:pointer;border:2px solid transparent}.select-item.selected{border-color:var(--accent);box-shadow:0 0 0 2px #ff5a3c26,var(--shadow)}.select-radio{width:22px;height:22px;border-radius:50%;background:var(--surf-lo);box-shadow:var(--shadow-in);flex-shrink:0;position:relative}.select-item.selected .select-radio{background:linear-gradient(165deg,var(--acc-hi),var(--accent));box-shadow:0 2px 6px #ff5a3c66,inset 1px 1px #ffffff4d}.select-item.selected .select-radio:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:#fff}.select-info{flex:1;min-width:0}.select-title{font-size:14px;font-weight:700}.select-sub{font-size:11px;color:var(--dim);margin-top:2px}.toggle-row{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;margin-bottom:16px}.toggle-ico{width:40px;height:40px;border-radius:12px;background:linear-gradient(165deg,#c084fc,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0;box-shadow:-2px 2px 6px #0000004d,inset 2px 2px #fff6}.toggle-info{flex:1}.toggle-title{font-size:13px;font-weight:800}.toggle-desc{font-size:11px;color:var(--dim);margin-top:2px;line-height:1.4}.switch{width:46px;height:26px;border-radius:13px;background:var(--surf-lo);box-shadow:var(--shadow-in);position:relative;cursor:pointer;flex-shrink:0;transition:background .2s;border:none;padding:0}.switch.on{background:linear-gradient(90deg,#34d399,#059669)}.switch-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #0006;transition:left .2s}.switch.on .switch-knob{left:23px}.terms-survey-btn{width:100%;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid #ef4444;border-radius:14px;padding:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;cursor:pointer;color:var(--text);margin-bottom:16px}.terms-survey-btn.agreed{border-color:#7ed957;background:linear-gradient(135deg,#7ed95726,#7ed9570d)}.terms-survey-ico{width:40px;height:40px;border-radius:12px;background:linear-gradient(165deg,#f87171,#dc2626);display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0;box-shadow:-2px 2px 6px #0000004d,inset 2px 2px #fff6}.terms-survey-btn.agreed .terms-survey-ico{background:linear-gradient(165deg,#9ee07a,#5fb83d)}.terms-survey-text{flex:1;text-align:left;font-size:13px;font-weight:700}.terms-survey-text .lbl{font-size:10px;color:#f87171;text-transform:uppercase;letter-spacing:1px}.terms-survey-btn.agreed .terms-survey-text .lbl{color:#7ed957}.bottom-spacer{margin-top:20px;padding-top:4px}.user-banner{background:linear-gradient(155deg,var(--surf-hi),var(--surface));border-radius:10px;padding:6px 10px;box-shadow:var(--shadow);margin-top:4px;border:1px solid var(--border);display:flex;align-items:center;gap:8px}.banner-avatar{width:28px;height:28px;border-radius:8px;background:linear-gradient(165deg,#ff7a5c,#ff5a3c);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;color:#fff;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6;position:relative;overflow:hidden;flex-shrink:0}.banner-avatar:after{content:"";position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.7),transparent 75%)}.banner-info{flex:1;display:flex;align-items:center;gap:6px}.banner-greet{display:none}.banner-name{font-size:12px;font-weight:800}.banner-tag{display:inline-block;background:linear-gradient(165deg,#5b9bff,#2563eb);color:#fff;padding:2px 6px;border-radius:6px;font-size:8px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;box-shadow:0 2px 6px #5b9bff66,inset 1px 1px #ffffff4d}.service-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.svc-tile{background:#0000009e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:13px;padding:14px 10px;box-shadow:var(--shadow);text-align:center;cursor:pointer;border:1px solid rgba(255,255,255,.12);transition:transform .15s,box-shadow .15s}[data-theme=light] .svc-tile{background:#ffffffe0;border-color:#fffc}.svc-tile:active:not(.locked){transform:scale(.97)}.svc-tile.selected{box-shadow:0 0 0 2px var(--green),var(--shadow);border-color:transparent}.svc-tile.locked{opacity:.4;cursor:not-allowed}.svc-tile .ico{width:44px;height:44px;border-radius:14px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6;position:relative;overflow:hidden}.svc-tile .ico:after{content:"";position:absolute;top:-10%;right:-10%;width:65%;height:55%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.65),transparent 75%)}.bk-ico-school{background:linear-gradient(165deg,#5b9bff,#2563eb)}.bk-ico-private{background:linear-gradient(165deg,#c084fc,#7c3aed)}.bk-ico-locked{background:linear-gradient(135deg,#4a4d54,#2e3034)}.svc-title{font-size:13px;font-weight:800;margin-bottom:3px}.svc-dur{font-size:11px;color:var(--dim)}.svc-lock{font-size:10px;color:var(--faint);margin-top:4px;font-style:italic}.dur-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px}.dur-pill{background:var(--surf-lo);border-radius:12px;padding:10px;box-shadow:var(--shadow-in);text-align:center;font-size:13px;font-weight:700;color:var(--text);cursor:pointer;border:none}.dur-pill.active{background:linear-gradient(165deg,#7ed957,#4caf50);color:#0d2a10;box-shadow:0 4px 12px #63d37873,inset 2px 2px #ffffff59}.cal-card{background:#000000a6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:18px;padding:6px 10px 5px;border:1px solid rgba(255,255,255,.14);box-shadow:0 8px 32px #0006;position:relative;overflow:hidden}[data-theme=light] .cal-card{background:#ffffffe0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-color:#fffc;box-shadow:0 8px 32px #0000001a}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;padding:0 2px}.cal-nav-btn{width:22px;height:22px;border-radius:50%;background:#1e2028;border:1px solid rgba(255,255,255,.1);cursor:pointer;color:var(--text);font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s;flex-shrink:0}.cal-nav-btn:hover{background:#2a2d38}.cal-nav-btn:active{transform:scale(.88)}[data-theme=light] .cal-nav-btn{background:#f0f2f7;border-color:#00000012;color:#222}.cal-month{font-size:11px;font-weight:900;letter-spacing:1.5px;color:var(--text);text-align:center;text-transform:uppercase}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:3px;padding-bottom:4px;border-bottom:1px solid rgba(255,255,255,.06)}[data-theme=light] .cal-weekdays{border-bottom-color:#0000000f}.cal-wd{text-align:center;font-size:9px;color:var(--faint);font-weight:700;letter-spacing:.5px;text-transform:uppercase}.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-day{aspect-ratio:1;border-radius:50%;background:transparent;border:none;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;cursor:pointer;position:relative;color:var(--dim);transition:background .12s,color .12s}.cal-day:not(.disabled):not(.selected):not(.day-free):not(.day-partial):not(.day-full):hover{background:#00000085;color:var(--text)}[data-theme=light] .cal-day{color:#888}[data-theme=light] .cal-day:not(.disabled):not(.selected):not(.day-free):not(.day-partial):not(.day-full):hover{background:#f0f2f7;color:#333}.cal-day.empty{cursor:default;visibility:hidden}.cal-day.has-slots{color:var(--text);font-weight:600}.cal-day.day-free{background:#22c55e;color:#fff;font-weight:800;box-shadow:0 4px 12px #22c55e73}.cal-day.day-free:hover{background:#16a34a}.cal-day.day-partial{background:#f59e0b;color:#fff;font-weight:800;box-shadow:0 4px 12px #f59e0b73}.cal-day.day-partial:hover{background:#d97706}.cal-day.day-full{background:#ef4444;color:#fff;font-weight:800;box-shadow:0 4px 12px #ef444459;opacity:.75;cursor:not-allowed}.cal-day.day-full:hover{opacity:.9}.cal-day.selected{background:linear-gradient(155deg,#fde047,#ca8a04);color:#3a2800!important;font-weight:800;border-radius:50%;box-shadow:0 4px 14px #eab3088c}.cal-day.selected:after{display:none}.cal-day.today:not(.selected){color:var(--gold)!important;font-weight:900}.cal-day.today:not(.selected):before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:50%;border:1.5px solid var(--gold);opacity:.7}.cal-day.disabled{color:#ffffff26;cursor:not-allowed}.slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.slot{background:#22c55e26;border-radius:10px;padding:6px 4px;border:1px solid rgba(34,197,94,.35);text-align:center;font-size:13px;font-weight:700;cursor:pointer;color:var(--text);position:relative;overflow:hidden;min-height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;transition:background .12s,border-color .12s}.slot:not(.taken):after{content:"";position:absolute;top:-15%;right:-10%;width:60%;height:85%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.65),transparent 65%);pointer-events:none}.slot:not(.taken):not(.selected):hover{background:#22c55e40;border-color:#22c55e8c}[data-theme=light] .slot{background:#22c55e1f;border-color:#22c55e4d;color:#222}.slot.selected{background:linear-gradient(155deg,#fde047,#ca8a04);color:#3a2800;border-color:#eab308b3;box-shadow:0 4px 14px #eab30873,inset 1px 1px #fff6,inset -1px -1px #0003}.slot.taken{background:#ef444421;border-color:#ef44444d;cursor:not-allowed}.slot.taken .slot-time{text-decoration:line-through;opacity:.5}.slot.my-queue{background:linear-gradient(155deg,#f7c94873,#d9770638);color:#fff;border-color:#f7c94899;box-shadow:-1px 3px 10px #00000080,inset 1px 1px #ffffff38,0 0 8px #f7c9484d}.slot.my-queue .slot-time{text-decoration:none;opacity:1}.slot.my-booked{background:linear-gradient(155deg,#4ade8040,#16a34a1f);color:#fff;border-color:#4ade8080;box-shadow:-1px 3px 10px #00000080,inset 1px 1px #ffffff26,0 0 8px #4ade8033;cursor:default;opacity:.85}.slot.my-booked .slot-time{text-decoration:none;opacity:1}.slot-queue{display:flex;gap:2px;align-items:center;justify-content:center;height:12px}.slot-queue svg{width:10px;height:10px;color:var(--gold);filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}.slot.selected .slot-queue svg{color:#ffffffd9}.slot.my-queue .slot-queue svg{color:#fff}.slot-queue-num{font-size:9px;font-weight:800;color:var(--gold);margin-left:2px}.slot.selected .slot-queue-num,.slot.my-queue .slot-queue-num{color:#fff}.slot-legend{display:flex;gap:12px;margin-top:10px;padding:8px 12px;background:var(--surf-lo);border-radius:10px;box-shadow:var(--shadow-in);font-size:10px;color:var(--dim);align-items:center;flex-wrap:wrap;justify-content:center}.leg-item{display:flex;align-items:center;gap:4px}.leg-dot{width:10px;height:10px;border-radius:3px}.leg-dot.free{background:#22c55e26;border:1px solid rgba(34,197,94,.35)}.leg-dot.taken{background:#ef444421;border:1px solid rgba(239,68,68,.3)}.leg-dot.queue{background:var(--gold)}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;display:none;flex-direction:column;align-items:center;justify-content:flex-start;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.dialog-backdrop.show{display:flex}.dialog{width:100%;max-width:480px;margin:auto 0;background:var(--surface);border-radius:24px;padding:20px;box-shadow:0 8px 40px #00000080;animation:slide-up .3s ease}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dialog-handle{width:40px;height:4px;background:var(--faint);border-radius:2px;margin:0 auto 16px}.dialog-icon{width:56px;height:56px;border-radius:18px;background:linear-gradient(165deg,#fcd34d,#d97706);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px;box-shadow:-2px 3px 10px #0000004d,inset 2px 2px #fff6}.dialog-title{font-size:18px;font-weight:900;text-align:center;margin-bottom:6px}.dialog-sub{font-size:13px;color:var(--dim);text-align:center;line-height:1.5;margin-bottom:16px}.dialog-info-card{background:var(--surf-lo);border-radius:14px;padding:12px;box-shadow:var(--shadow-in);margin-bottom:16px}.dialog-info-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px}.dialog-info-row .lbl{color:var(--dim)}.dialog-info-row .val{font-weight:700}.dialog-actions{display:flex;gap:8px}.dialog-btn{flex:1;padding:14px;border-radius:14px;border:none;cursor:pointer;font-size:13px;font-weight:800}.dialog-btn.secondary{background:var(--surf-lo);color:var(--text);box-shadow:var(--shadow-in)}.dialog-btn.primary{background:linear-gradient(155deg,var(--acc-hi),var(--accent));color:#fff;position:relative;overflow:hidden;box-shadow:0 6px 18px #ff5a3c80,inset 1px 1px #ffffff59,inset -1px -1px #0003}.dialog-btn.primary:before{content:"";position:absolute;top:-15%;right:-5%;width:60%;height:65%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.5) 0%,transparent 65%);pointer-events:none}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.booking-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:12px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1);margin-bottom:8px;display:flex;gap:10px;align-items:center;overflow:hidden}.booking-date{width:48px;flex-shrink:0;background:#00000040;border-radius:10px;padding:7px 4px;text-align:center;box-shadow:var(--shadow-in);border:1px solid rgba(255,255,255,.08)}.booking-day{font-size:22px;font-weight:900;line-height:1}.booking-mon{font-size:10px;color:var(--dim);margin-top:2px;text-transform:uppercase;letter-spacing:1px}.booking-body{flex:1;min-width:0}.booking-time{font-size:13px;font-weight:800;color:var(--accent);margin-bottom:2px}.booking-type{font-size:13px;font-weight:700}.booking-meta{font-size:11px;color:var(--dim);margin-top:3px}.booking-status{display:inline-block;padding:3px 8px;border-radius:8px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-top:5px}.status-confirmed{background:#7ed95726;color:#7ed957}.status-pending{background:#f7c94826;color:var(--gold)}.status-cancelled{background:#ef444426;color:#ef4444}.booking-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.action-btn{width:32px;height:32px;border-radius:10px;background:#00000045;border:none;cursor:pointer;box-shadow:var(--shadow-in);color:var(--text);font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:var(--dim)}.empty-state-emoji{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:8px}.empty-state-desc{font-size:13px;line-height:1.5}.progress-hero{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:22px;padding:20px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1);margin-top:14px;text-align:center}.progress-circle-wrap{position:relative;width:160px;height:160px;margin:0 auto 12px}.progress-circle-bg,.progress-circle-fill{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%}.progress-circle-bg{background:var(--surf-lo);box-shadow:var(--shadow-in)}.progress-svg{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotate(-90deg)}.progress-svg circle{fill:none;stroke-linecap:round;stroke-width:12}.progress-svg .track{stroke:#7f7f7f26}.progress-svg .fill{stroke:url(#gradOrange);transition:stroke-dashoffset .6s}.progress-num{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.progress-num .big{font-size:36px;font-weight:900;color:var(--accent);line-height:1}.progress-num .of{font-size:12px;color:var(--dim);margin-top:4px}.progress-title{font-size:16px;font-weight:800;margin-bottom:4px}.progress-subtitle{font-size:12px;color:var(--dim);line-height:1.5}.unlock-card{background:linear-gradient(135deg,#7ed95726,#7ed9570d);border:1px solid rgba(126,217,87,.3);border-radius:16px;padding:16px;margin-top:16px;display:flex;gap:12px;align-items:center}.unlock-ico{width:48px;height:48px;border-radius:14px;background:linear-gradient(165deg,#9ee07a,#5fb83d);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6}.unlock-info{flex:1}.unlock-title{font-size:14px;font-weight:800;color:#7ed957}.unlock-desc{font-size:11px;color:var(--dim);margin-top:3px;line-height:1.4}.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-block{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;padding:14px;box-shadow:var(--shadow)}.stat-block .num{font-size:22px;font-weight:900;color:var(--accent)}.stat-block .lbl{font-size:10px;color:var(--faint);letter-spacing:1px;text-transform:uppercase;margin-top:4px}.profile-tab{padding-bottom:20px}.profile-banner{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:22px;padding:24px 20px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1);text-align:center;margin-top:14px}.profile-avatar{width:84px;height:84px;border-radius:50%;background:linear-gradient(165deg,#ff7a5c,#ff5a3c);color:#fff;font-size:28px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:-3px 4px 12px #0006,inset 2px 2px #ffffff40;position:relative}.profile-avatar:after{content:"";position:absolute;top:8%;right:12%;width:50%;height:40%;border-radius:50%;background:radial-gradient(ellipse,rgba(255,255,255,.5),transparent 70%);pointer-events:none}.profile-name{font-size:20px;font-weight:900;margin-bottom:4px}.profile-phone{font-size:13px;color:var(--dim);font-family:ui-monospace,monospace}.profile-section{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:18px;padding:16px;margin-top:14px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1)}.section-title{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:10px;font-weight:700}.profile-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.profile-row:last-child{border-bottom:none}.profile-row .key{font-size:13px;color:var(--dim)}.profile-row .val{font-size:13px;font-weight:700;text-align:right;color:var(--text)}.theme-toggle{display:flex;gap:8px;padding:4px;background:var(--surf-lo);border-radius:12px;box-shadow:var(--shadow-in)}.theme-btn{flex:1;padding:8px;background:transparent;border:none;border-radius:9px;font-size:12px;font-weight:700;color:var(--dim);cursor:pointer;transition:all .2s}.theme-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #ff5a3c66}.logout-btn{width:100%;padding:14px;margin-top:18px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:14px;font-size:14px;font-weight:800;cursor:pointer;box-shadow:0 4px 12px #ef44444d}.logout-btn:active{transform:scale(.98)}.contact-link{display:flex;align-items:center;gap:12px;padding:12px;background:#00000045;border-radius:12px;margin-top:8px;text-decoration:none;color:var(--text);box-shadow:var(--shadow-in)}.contact-link .ico{font-size:20px;width:36px;height:36px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center}.contact-link .info{flex:1}.contact-link .info .lbl{font-size:11px;color:var(--dim)}.contact-link .info .val{font-size:13px;font-weight:700}.contact-phone-block{background:#00000045;border-radius:12px;padding:14px 12px;margin-top:8px;box-shadow:var(--shadow-in);display:flex;flex-direction:column;gap:12px}.contact-phone-number{font-size:17px;font-weight:800;letter-spacing:.5px;text-align:center;color:var(--text);font-family:ui-monospace,monospace}.contact-btns{display:flex;justify-content:center;gap:12px}.contact-btn{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;transition:transform .15s,opacity .15s}.contact-btn:active{transform:scale(.92);opacity:.85}.contact-btn svg{width:22px;height:22px}.contact-btn--call{background:#34c759;box-shadow:0 3px 10px #34c75966}.contact-btn--tg{background:#29a8eb;box-shadow:0 3px 10px #29a8eb66}.contact-btn--viber{background:#7360f2;box-shadow:0 3px 10px #7360f266}.contact-btn--wa{background:#25d366;box-shadow:0 3px 10px #25d36666}.chat-tab{display:flex;flex-direction:column;flex:1;min-height:0;background:transparent;padding:0 16px calc(80px + 2*env(safe-area-inset-bottom))}.chat-tabs{display:flex;gap:6px;margin-bottom:10px;background:#00000045;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:4px;box-shadow:var(--shadow-in)}.chat-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 10px;border:none;border-radius:11px;background:transparent;color:var(--dim);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}.chat-tab-btn.active{background:linear-gradient(145deg,var(--acc-hi),var(--accent));color:#fff;box-shadow:0 3px 10px #ff5a3c59}.chat-inner{display:flex;flex-direction:column;flex:1;min-height:0}.chat-header{display:flex;align-items:center;gap:12px;padding:12px 16px;position:relative;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;margin-bottom:10px;box-shadow:var(--shadow);flex-shrink:0}.chat-clear-btn{margin-left:auto;width:32px;height:32px;border-radius:10px;border:none;background:#ff503c1f;color:var(--dim);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.chat-clear-btn:hover{background:#ff503c40;color:#ff5040}.chat-instructor-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,#ff7a5c,#ff5a3c);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 3px 10px #ff5a3c59}.chat-general-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,#5b9bff,#2563eb);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 3px 10px #5b9bff59}.chat-instructor-name{font-size:14px;font-weight:700;color:var(--text)}.chat-instructor-status{font-size:11px;color:var(--dim);margin-top:2px}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:4px 0 8px;min-height:0}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--dim)}.chat-empty-icon{font-size:40px;margin-bottom:12px;opacity:.4}.chat-empty-title{font-size:16px;font-weight:700;color:var(--dim);margin-bottom:6px}.chat-empty-sub{font-size:13px;color:var(--faint);text-align:center}.chat-msg-row{display:flex;align-items:flex-end;gap:8px;padding:2px 4px}.chat-msg-row.out{flex-direction:row-reverse}.chat-msg-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800}.chat-msg-avatar.instructor{background:linear-gradient(145deg,#ff7a5c,#ff5a3c)}.chat-msg-avatar.me{background:linear-gradient(145deg,#3b82f6,#1d4ed8);color:#fff;font-size:11px}.chat-msg-avatar.general-user{color:#fff;font-size:11px}.chat-bubble-wrap{display:flex;flex-direction:column;max-width:72%}.chat-bubble-wrap.wrap-out{align-items:flex-end}.chat-bubble-wrap.wrap-in{align-items:flex-start}.chat-sender-name{font-size:10px;font-weight:700;color:var(--dim);margin-bottom:2px;padding-left:4px}.chat-bubble{max-width:100%;padding:10px 13px;border-radius:16px}.bubble-out{background:linear-gradient(135deg,#2a5298,#1a3a70);border-radius:16px 16px 3px;box-shadow:0 2px 8px #0003}.bubble-in{background:#00000085;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:16px 16px 16px 3px;box-shadow:var(--shadow)}.bubble-broadcast{background:linear-gradient(135deg,#a855f733,#7c3aed1f);border:1px solid rgba(168,85,247,.3);border-radius:16px 16px 16px 3px}.bubble-broadcast-label{font-size:10px;font-weight:700;color:#a855f7e6;margin-bottom:4px;letter-spacing:.3px}.bubble-text{font-size:14px;line-height:1.45;word-break:break-word;color:var(--text)}.bubble-out .bubble-text{color:#fff}.bubble-broadcast .bubble-text{color:var(--text)}.bubble-time{font-size:10px;margin-top:4px;text-align:right;color:var(--faint)}.bubble-out .bubble-time{color:#ffffff80}.chat-input-area{padding:8px 0 4px;border-top:1px solid var(--border);background:transparent;flex-shrink:0}.chat-input-box{display:flex;align-items:flex-end;gap:10px;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:22px;padding:8px 8px 8px 16px;box-shadow:var(--shadow)}.chat-textarea{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:16px;resize:none;font-family:inherit;line-height:1.45;max-height:100px;overflow-y:auto;padding:4px 0}.chat-textarea::placeholder{color:var(--faint)}.chat-send-btn{width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#00000052;transition:all .15s}.chat-send-btn.active{background:linear-gradient(145deg,#ff7a5c,#ff5a3c);box-shadow:0 3px 12px #ff5a3c66}.chat-history-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 3px 10px #f59e0b59}.history-msg-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:#0000006b;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:14px;border:1px solid var(--border)}.history-msg-icon{font-size:20px;flex-shrink:0;margin-top:1px}.history-msg-body{flex:1;min-width:0}.history-msg-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}.history-msg-text{font-size:13px;line-height:1.4;color:var(--dim);word-break:break-word}.history-msg-time{font-size:11px;color:var(--faint);margin-top:4px}@keyframes fade-up{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fade-up .18s ease both}.notif-tab{display:flex;flex-direction:column;gap:8px;padding-bottom:16px}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px}.notif-empty-icon{font-size:40px;margin-bottom:12px;opacity:.35}.notif-empty-title{font-size:16px;font-weight:700;color:var(--dim);margin-bottom:6px}.notif-empty-sub{font-size:13px;color:var(--faint, var(--dim));text-align:center;opacity:.7}.notif-list{display:flex;flex-direction:column;gap:8px}.notif-card{display:flex;align-items:flex-start;gap:12px;padding:12px 14px 12px 12px;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;border:1px solid rgba(255,255,255,.07);box-shadow:var(--shadow);border-left-width:3px}.notif-accent-green{border-left-color:#7ed957}.notif-accent-red{border-left-color:#ef4444}.notif-accent-gold{border-left-color:var(--gold)}.notif-accent-blue{border-left-color:#5b9bff}.notif-accent-dim{border-left-color:#ffffff26}.notif-left{flex-shrink:0}.notif-icon-wrap{width:38px;height:38px;border-radius:11px;background:#0000004d;box-shadow:var(--shadow-in);display:flex;align-items:center;justify-content:center}.notif-accent-green .notif-icon-wrap{background:#7ed9571f}.notif-accent-red .notif-icon-wrap{background:#ef44441f}.notif-accent-gold .notif-icon-wrap{background:#f7c9481f}.notif-accent-blue .notif-icon-wrap{background:#5b9bff1f}.notif-icon{font-size:18px;line-height:1}.notif-body{flex:1;min-width:0}.notif-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.notif-title{font-size:13px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-badge{flex-shrink:0;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:2px 7px;border-radius:7px}.notif-badge-green{background:#7ed95726;color:#7ed957}.notif-badge-red{background:#ef444426;color:#ef4444}.notif-badge-gold{background:#f7c94826;color:var(--gold)}.notif-badge-blue{background:#5b9bff26;color:#5b9bff}.notif-badge-dim{background:#ffffff12;color:var(--dim)}.notif-text{font-size:12px;color:var(--dim);line-height:1.45;margin-bottom:4px;word-break:break-word}.notif-time{font-size:10px;color:var(--dim);opacity:.6}.notif-toolbar{display:flex;justify-content:flex-end;padding:0 2px 4px}.notif-clear-all{background:none;border:none;font-size:12px;font-weight:600;color:var(--dim);cursor:pointer;padding:4px 8px;border-radius:8px;opacity:.7;transition:opacity .15s}.notif-clear-all:hover{opacity:1}.notif-dismiss{flex-shrink:0;align-self:flex-start;background:none;border:none;font-size:11px;color:var(--dim);cursor:pointer;padding:2px 4px;border-radius:6px;opacity:.4;transition:opacity .15s;line-height:1;margin-top:2px}.notif-dismiss:hover{opacity:.9}[data-theme=light] .notif-card{background:var(--surface);border-color:#0000000f}[data-theme=light] .notif-accent-green{border-left-color:#5ab83a}[data-theme=light] .notif-accent-red{border-left-color:#dc2626}[data-theme=light] .notif-accent-gold{border-left-color:#d4a010}[data-theme=light] .notif-accent-blue{border-left-color:#2563eb}[data-theme=light] .notif-icon-wrap{background:#0000000d;box-shadow:var(--shadow-in)}[data-theme=light] .notif-badge-green{background:#5ab83a1f;color:#3a8a20}[data-theme=light] .notif-badge-red{background:#dc26261a;color:#b91c1c}[data-theme=light] .notif-badge-gold{background:#d4a0101f;color:#92610a}[data-theme=light] .notif-badge-blue{background:#2563eb1a;color:#1d4ed8}.cabinet-page{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.cab-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0;display:flex;flex-direction:column;padding:0 16px;padding-bottom:calc(80px + 2*env(safe-area-inset-bottom))}.cab-content--chat{overflow:hidden;padding:0}@media (min-width: 600px){.cabinet-page{max-width:430px;margin:0 auto;position:relative;box-shadow:0 0 80px #0009}.botnav{position:absolute;left:0;right:0;bottom:0}}.cab-topbar{position:sticky;top:0;z-index:50;padding:calc(6px + env(safe-area-inset-top)) 12px 6px;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,var(--bg) 60%,rgba(28,29,33,.9));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.cab-title{font-size:13px;font-weight:800;letter-spacing:-.3px}.cab-actions{display:flex;gap:6px;align-items:center}.cab-icon-btn{width:28px;height:28px;border-radius:9px;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 3px 10px #0000008c,inset 1px 1px #ffffff26,inset -1px -1px #0003;border:1px solid rgba(255,255,255,.1);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--dim);position:relative;overflow:hidden;transition:color .15s}.cab-icon-btn:before{content:"";position:absolute;top:-15%;right:-10%;width:65%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.22) 0%,transparent 65%);pointer-events:none}.cab-icon-btn:active{box-shadow:var(--shadow-in);color:var(--text)}.cab-icon-btn .badge{position:absolute;top:-2px;right:-2px;background:var(--accent);color:#fff;border-radius:10px;padding:1px 6px;font-size:9px;font-weight:800;box-shadow:0 0 8px #ff5a3c99}.botnav{position:fixed;bottom:0;left:0;right:0;padding:0 3px calc(10px + env(safe-area-inset-bottom));background:transparent;z-index:50;pointer-events:none}.botnav>*{pointer-events:auto}.botnav-inner{background:#00000085;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:26px;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 40px #000000a6,0 4px 16px #0006,0 -1px #ffffff0d;display:flex;overflow:hidden;pointer-events:auto}[data-theme=light] .botnav{box-shadow:0 -8px 24px #aeb2bd66}.botnav-btn{flex:1 1 0;min-width:0;background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 2px 9px;position:relative}.botnav-ico{display:flex;align-items:center;justify-content:center;transition:transform .15s,opacity .15s,color .15s;opacity:.55;color:#fff;position:relative}[data-theme=light] .botnav-ico{color:var(--dim)}.botnav-btn.active .botnav-ico{transform:scale(1.1);opacity:1;color:var(--accent)}[data-theme=light] .botnav-btn.active .botnav-ico{color:var(--accent)}.botnav-lbl{font-size:8px;font-weight:700;color:#ffffff73;white-space:nowrap}[data-theme=light] .botnav-lbl{color:var(--faint)}.botnav-btn.active .botnav-lbl{color:var(--accent)}.botnav-badge{position:absolute;top:0;right:30%;background:var(--accent);color:#fff;border-radius:10px;padding:1px 5px;font-size:9px;font-weight:800;box-shadow:0 0 8px #ff5a3c99}.landing-page{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:40px;position:relative}@media (min-width: 600px){.landing-page{height:100vh;overflow-y:auto;overscroll-behavior:none}}.landing-topbar{position:sticky;top:0;z-index:50;background:var(--bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:12px 0}.landing-topbar-row{display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:800;letter-spacing:-.3px}.logo-icon{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;box-shadow:-2px 3px 8px #0006}.logo-icon img{width:100%;height:100%;object-fit:cover;display:block}.topbar-actions{display:flex;gap:8px;align-items:center}.icon-btn{width:40px;height:40px;border-radius:12px;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:box-shadow .2s}.icon-btn:active{box-shadow:var(--shadow-in)}.btn-login{background:linear-gradient(165deg,var(--acc-hi),var(--accent));color:#fff;border:none;cursor:pointer;padding:10px 18px;border-radius:14px;font-size:13px;font-weight:700;box-shadow:0 4px 12px #ff5a3c66,inset 2px 2px #fff6,inset -1px -1px #00000026;position:relative;overflow:hidden}.btn-login:after{content:"";position:absolute;top:0;right:0;width:50%;height:80%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.55),transparent 70%);pointer-events:none}.hero{padding:32px 16px 40px;text-align:center;position:relative}.hero h1{font-size:30px;font-weight:900;line-height:1.15;letter-spacing:-.8px;margin-bottom:14px;position:relative}.hero h1 .accent{color:var(--accent)}.hero p{font-size:14px;color:var(--dim);margin-bottom:24px;line-height:1.5;position:relative}.hero-cta{display:inline-block;padding:16px 32px;background:linear-gradient(165deg,var(--acc-hi),var(--accent));color:#fff;border:none;cursor:pointer;border-radius:18px;font-size:15px;font-weight:800;box-shadow:0 8px 24px #ff5a3c80,inset 3px 3px #ffffff73,inset -2px -2px #00000026;position:relative;overflow:hidden}.hero-cta:after{content:"";position:absolute;top:0;right:0;width:55%;height:85%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.6),rgba(255,255,255,.15) 45%,transparent 75%);pointer-events:none}.hero-stats{display:flex;justify-content:center;gap:8px;margin-top:20px}.stat-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:12px;padding:8px 20px;box-shadow:var(--shadow);text-align:center}.stat-num{font-size:20px;font-weight:900;color:var(--accent)}.stat-lbl{font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:1px;margin-top:1px}.lsection{padding:32px 0 8px;text-align:center}.lsection-title{font-size:11px;color:var(--faint);letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:14px}.lsection h2{font-size:22px;font-weight:900;letter-spacing:-.4px;margin-bottom:16px}.services{display:flex;flex-direction:column;gap:10px}.service-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:18px;padding:16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;cursor:pointer}.service-card:active{box-shadow:var(--shadow-in)}.service-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;flex-shrink:0;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6,inset -1px -1px #0003;position:relative;overflow:hidden}.service-icon:after{content:"";position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.7),rgba(255,255,255,.2) 40%,transparent 75%);pointer-events:none}.service-icon:before{content:"";position:absolute;top:6px;right:8px;width:10px;height:10px;border-radius:50%;background:#ffffffd9;filter:blur(2px);z-index:2}.ico-school{background:linear-gradient(165deg,#5b9bff,#2563eb)}.ico-private{background:linear-gradient(165deg,#c084fc,#7c3aed)}.service-info{flex:1;min-width:0}.service-title{font-size:15px;font-weight:800;margin-bottom:3px}.service-desc{font-size:12px;color:var(--dim);line-height:1.4}.service-arrow{width:28px;height:28px;border-radius:10px;background:#00000045;display:flex;align-items:center;justify-content:center;color:var(--accent);font-weight:700;box-shadow:var(--shadow-in)}.flow-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:22px;padding:18px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1)}.flow-step{display:flex;gap:12px;align-items:flex-start;padding:10px 0;position:relative}.flow-step:not(:last-child):after{content:"";position:absolute;left:19px;top:50px;bottom:-10px;width:2px;background:linear-gradient(to bottom,var(--accent),transparent);opacity:.4}.flow-num{width:38px;height:38px;border-radius:12px;background:linear-gradient(165deg,var(--acc-hi),var(--accent));display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;color:#fff;flex-shrink:0;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6,inset -1px -1px #0003;position:relative;overflow:hidden}.flow-num:after{content:"";position:absolute;top:-10%;right:-10%;width:65%;height:55%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.7),transparent 75%);pointer-events:none}.flow-body{flex:1;padding-top:4px}.flow-title{font-size:14px;font-weight:800;margin-bottom:4px}.flow-desc{font-size:12px;color:var(--dim);line-height:1.5}.flow-choice{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.choice-tile{background:#00000045;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:12px;padding:10px 8px;box-shadow:var(--shadow-in);text-align:center;font-size:11px;font-weight:700;color:var(--text)}.choice-tile .ico{font-size:20px;margin-bottom:4px}.choice-tile.active{background:linear-gradient(165deg,var(--acc-hi),var(--accent));color:#fff;box-shadow:0 4px 12px #ff5a3c66,inset 2px 2px #ffffff4d}.flow-progress{margin-top:10px;background:#00000045;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:10px;box-shadow:var(--shadow-in);padding:4px}.flow-progress-bar{height:10px;border-radius:6px;background:linear-gradient(90deg,#34d399,#059669);width:65%;box-shadow:inset 1px 1px #ffffff4d}.flow-progress-label{font-size:10px;color:var(--faint);margin-top:6px;display:flex;justify-content:space-between;font-weight:700;letter-spacing:.5px}.flow-arrow{text-align:center;font-size:22px;color:var(--accent);margin:4px 0}.features{display:grid;grid-template-columns:1fr 1fr;gap:10px}.feature-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;padding:14px;box-shadow:var(--shadow)}.feature-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;margin-bottom:10px;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6,inset -1px -1px #0003;position:relative;overflow:hidden}.feature-icon:after{content:"";position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.7),rgba(255,255,255,.2) 40%,transparent 75%);pointer-events:none}.feature-icon:before{content:"";position:absolute;top:5px;right:6px;width:7px;height:7px;border-radius:50%;background:#ffffffd9;filter:blur(1.5px);z-index:2}.fi-1{background:linear-gradient(165deg,#34d399,#059669)}.fi-2{background:linear-gradient(165deg,#fb923c,#ea580c)}.fi-3{background:linear-gradient(165deg,#5b9bff,#2563eb)}.fi-4{background:linear-gradient(165deg,#c084fc,#7c3aed)}.fi-5{background:linear-gradient(165deg,#f472b6,#db2777)}.fi-6{background:linear-gradient(165deg,#fbbf24,#d97706)}.feature-title{font-size:13px;font-weight:800;margin-bottom:4px}.feature-desc{font-size:11px;color:var(--dim);line-height:1.4}.instructor-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:22px;padding:20px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:center;border:1px solid rgba(255,255,255,.1)}.instructor-avatar{width:72px;height:72px;border-radius:22px;background:linear-gradient(165deg,#ff7a5c,#ff5a3c);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:#fff;flex-shrink:0;box-shadow:-3px 4px 12px #0006,inset 3px 3px #ffffff73,inset -2px -2px #0003;position:relative;overflow:hidden}.instructor-avatar:after{content:"";position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.75),rgba(255,255,255,.2) 45%,transparent 75%);pointer-events:none}.instructor-avatar:before{content:"";position:absolute;top:8px;right:12px;width:14px;height:14px;border-radius:50%;background:#ffffffe6;filter:blur(3px);z-index:2}.instructor-info{flex:1}.instructor-name{font-size:17px;font-weight:900;letter-spacing:-.3px}.instructor-role{font-size:12px;color:var(--accent);font-weight:700;margin-top:2px}.instructor-meta{font-size:11px;color:var(--dim);margin-top:8px;line-height:1.5}.instructor-meta span{display:block}.reviews-scroll{display:flex;gap:10px;overflow-x:auto;padding:4px 16px 12px;margin:0 -16px;scroll-snap-type:x mandatory}.review-card{flex:0 0 280px;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:18px;padding:16px;box-shadow:var(--shadow);scroll-snap-align:start}.review-stars{color:#fcd34d;font-size:14px;margin-bottom:8px;letter-spacing:1px}.review-text{font-size:13px;line-height:1.5;color:var(--text);margin-bottom:12px}.review-author{display:flex;align-items:center;gap:10px}.review-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;background:linear-gradient(165deg,#9ee07a,#5fb83d);box-shadow:-2px 2px 6px #0000004d,inset 1px 1px #fff3}.review-name{font-size:12px;font-weight:700}.review-date{font-size:10px;color:var(--faint)}.contacts{display:flex;flex-direction:column;gap:8px}.contact-row{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}.contact-row:active{box-shadow:var(--shadow-in)}.contact-ico{width:36px;height:36px;border-radius:11px;background:linear-gradient(165deg,#5b9bff,#2563eb);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;flex-shrink:0;box-shadow:-2px 2px 6px #0000004d,inset 2px 2px #fff6,inset -1px -1px #0003;position:relative;overflow:hidden}.contact-ico:after{content:"";position:absolute;top:-10%;right:-10%;width:65%;height:55%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.65),transparent 75%);pointer-events:none}.contact-ico.tel{background:linear-gradient(165deg,#34d399,#059669)}.contact-ico.loc{background:linear-gradient(165deg,#fb923c,#ea580c)}.contact-ico.tg{background:linear-gradient(165deg,#5b9bff,#2563eb)}.contact-label{font-size:10px;color:var(--faint);letter-spacing:1px;text-transform:uppercase}.contact-val{font-size:13px;font-weight:700}.contact-icon-row{display:flex;justify-content:center;gap:14px;padding:8px 0}.contact-icon-btn{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;transition:transform .15s,opacity .15s}.contact-icon-btn:active{transform:scale(.91);opacity:.8}.contact-icon-btn svg{width:26px;height:26px}.contact-icon-btn--call{background:#34c759;box-shadow:0 4px 14px #34c75973}.contact-icon-btn--tg{background:#29a8eb;box-shadow:0 4px 14px #29a8eb73}.contact-icon-btn--viber{background:#7360f2;box-shadow:0 4px 14px #7360f273}.contact-icon-btn--wa{background:#25d366;box-shadow:0 4px 14px #25d36673}.map-card{background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1)}.map-iframe{width:100%;height:220px;border:none;display:block;filter:brightness(.95)}[data-theme=light] .map-iframe{filter:none}.map-overlay{padding:14px;display:flex;align-items:center;gap:12px;border-top:1px solid var(--border)}.map-pin{width:40px;height:40px;border-radius:12px;background:linear-gradient(165deg,#fb923c,#ea580c);display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0;box-shadow:-2px 2px 6px #0000004d,inset 2px 2px #fff6;position:relative;overflow:hidden}.map-pin:after{content:"";position:absolute;top:-10%;right:-10%;width:65%;height:55%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.65),transparent 75%)}.map-route-btn{margin-left:auto;padding:8px 14px;background:linear-gradient(165deg,var(--acc-hi),var(--accent));color:#fff;border:none;cursor:pointer;border-radius:11px;font-size:11px;font-weight:800;box-shadow:0 3px 10px #ff5a3c66,inset 2px 2px #ffffff59;flex-shrink:0;text-decoration:none;position:relative;overflow:hidden}.map-route-btn:after{content:"";position:absolute;top:0;right:0;width:55%;height:80%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.55),transparent 75%)}.terms-btn{width:100%;background:#00000085;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;border:none;cursor:pointer;color:var(--text)}.terms-btn:active{box-shadow:var(--shadow-in)}.terms-ico{width:36px;height:36px;border-radius:11px;background:linear-gradient(165deg,#fcd34d,#d97706);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;flex-shrink:0;box-shadow:-2px 2px 6px #0000004d,inset 2px 2px #ffffff73,inset -1px -1px #0003;position:relative;overflow:hidden}.terms-ico:after{content:"";position:absolute;top:-10%;right:-10%;width:65%;height:55%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.7),transparent 75%)}.terms-btn-label{flex:1;font-size:14px;font-weight:600;color:#fff;text-align:left}.terms-chevron{font-size:20px;color:#fff6;transition:transform .25s;transform:rotate(90deg);line-height:1}.terms-chevron.open{transform:rotate(-90deg)}.terms-content{margin-top:12px;background:#0000004d;border-radius:14px;padding:4px 0;overflow:hidden}.terms-item{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.terms-item:last-child{border-bottom:none}.terms-num{width:24px;height:24px;border-radius:8px;background:linear-gradient(165deg,#fcd34d,#d97706);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;margin-top:1px}.terms-heading{font-size:13px;font-weight:700;color:#fff;margin-bottom:4px}.terms-text{font-size:12px;color:#fff9;line-height:1.5}[data-theme=light] .icon-btn,[data-theme=light] .stat-card,[data-theme=light] .service-card,[data-theme=light] .flow-card,[data-theme=light] .feature-card,[data-theme=light] .instructor-card,[data-theme=light] .review-card,[data-theme=light] .contact-row,[data-theme=light] .map-card,[data-theme=light] .terms-btn{background:var(--surface);backdrop-filter:none;-webkit-backdrop-filter:none}[data-theme=light] .service-arrow,[data-theme=light] .choice-tile,[data-theme=light] .flow-progress{background:var(--surf-lo);backdrop-filter:none;-webkit-backdrop-filter:none}[data-theme=light] .terms-content{background:var(--surf-lo)}[data-theme=light] .terms-btn-label,[data-theme=light] .terms-heading{color:var(--text)}[data-theme=light] .terms-text{color:var(--dim)}[data-theme=light] .terms-chevron{color:var(--faint)}.footer{padding:32px 16px;text-align:center;color:var(--faint);font-size:11px;margin-top:20px}.footer-cta{background:linear-gradient(165deg,var(--acc-hi),var(--accent));color:#fff;border:none;cursor:pointer;padding:16px 36px;border-radius:16px;font-size:14px;font-weight:800;box-shadow:0 6px 18px #ff5a3c80,inset 3px 3px #ffffff73,inset -2px -2px #00000026;margin-bottom:18px;position:relative;overflow:hidden}.footer-cta:after{content:"";position:absolute;top:0;right:0;width:55%;height:85%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.6),transparent 75%);pointer-events:none}:root{--bg: #1c1d21;--bg-deep: #161719;--surface: #26282c;--surf-hi: #2e3034;--surf-lo: #1f2125;--border: rgba(255,255,255,.06);--text: #e8e8ea;--dim: #8b8d93;--faint: #5a5c62;--accent: #ff5a3c;--acc-hi: #ff7a5c;--green: #7ed957;--blue: #5b9bff;--gold: #f7c948;--shadow: 0 6px 30px rgba(0,0,0,.75), 0 2px 8px rgba(0,0,0,.5), 0 1px 0 rgba(255,255,255,.05);--shadow-in: inset 4px 4px 14px rgba(0,0,0,.7), inset -2px -2px 6px rgba(255,255,255,.03)}[data-theme=light]{--bg: #f0f1f5;--bg-deep: #e4e6ec;--surface: #ffffff;--surf-hi: #f8f9fc;--surf-lo: #e8eaf0;--border: rgba(0,0,0,.06);--text: #1c1d21;--dim: #3c3e45;--faint: #6b6d75;--shadow: 8px 8px 20px rgba(174,178,189,.45), -4px -4px 12px rgba(255,255,255,.9);--shadow-in: inset 3px 3px 8px rgba(174,178,189,.4), inset -2px -2px 6px rgba(255,255,255,.7)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;transition:background .3s,color .3s;overflow-x:hidden;overscroll-behavior-y:none;height:100%;height:100dvh}#root{height:100%;height:100dvh;background:transparent;color:var(--text);isolation:isolate;display:flex;flex-direction:column}#root:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background-image:url(/id4-hero.jpg);background-size:cover;background-position:calc(50% - 173px) top;background-repeat:no-repeat}#root:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:linear-gradient(to bottom,#1c1d2173,#1c1d21b8 55%,#1c1d21e0)}[data-theme=light] #root:after{background:linear-gradient(to bottom,#f0f1f580,#f0f1f5d1 55%,#f0f1f5f2)}@media (min-width: 600px){html,body,#root{height:100vh;overflow:hidden;background:var(--surf-lo)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#7f7f7f4d;border-radius:4px}button{font-family:inherit;touch-action:manipulation}.spinner{width:36px;height:36px;border:3px solid rgba(127,127,127,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shine-3d{position:relative;overflow:hidden;box-shadow:-2px 3px 8px #0000004d,inset 2px 2px #fff6,inset -1px -1px #0003}.shine-3d:after{content:"";position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.65),transparent 75%);pointer-events:none}.container{max-width:480px;margin:0 auto;padding:0 16px}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fade-up .25s ease both}.icon3d{display:inline-flex;align-items:center;justify-content:center;border-radius:14px;position:relative;overflow:hidden;flex-shrink:0;box-shadow:-2px 4px 10px #00000080,inset 1px 1px #ffffff40,inset -1px -1px #0000004d}.icon3d:before{content:"";position:absolute;top:0;right:0;width:60%;height:50%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.4) 0%,transparent 70%);pointer-events:none}.btn-primary{width:100%;padding:14px 16px;background:linear-gradient(155deg,var(--acc-hi),var(--accent));color:#fff;border:none;cursor:pointer;border-radius:14px;font-size:14px;font-weight:800;box-shadow:0 6px 20px #ff5a3c80,inset 1px 1px #ffffff59,inset -1px -1px #00000040;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s;letter-spacing:.2px}.btn-primary:before{content:"";position:absolute;top:-10%;right:-5%;width:60%;height:60%;background:radial-gradient(ellipse at top right,rgba(255,255,255,.55) 0%,transparent 65%);border-radius:50%;filter:blur(2px);pointer-events:none}.btn-primary:active:not(:disabled){transform:scale(.97);box-shadow:0 2px 8px #ff5a3c4d}.btn-primary:disabled{opacity:.35;cursor:not-allowed;background:var(--surf-lo);color:var(--faint);box-shadow:var(--shadow-in)}.section-title{font-size:9px;color:var(--faint);letter-spacing:1.5px;text-transform:uppercase;font-weight:700;margin:14px 2px 8px}
