:root{
    --bg:#15171d;
    --bg-2:#1d2027;
    --surface:#202229;
    --surface-2:#2a2c34;
    --text:#f8fafc;
    --muted:#a7b0c2;
    --line:rgba(255,255,255,0.08);
    --primary:#22c7f5;
    --primary-2:#2563eb;
    --accent:#8b5cf6;
    --success:#22c55e;
    --warning:#facc15;
    --danger:#ef4444;
    --shadow:0 24px 70px rgba(0,0,0,0.35);
}

*{
    box-sizing:border-box;
    margin:0;
    padding:0;
}

html{
    scroll-behavior:smooth;
    scrollbar-color:rgba(34,199,245,0.72) rgba(16,18,26,0.96);
    scrollbar-width:thin;
}

*::-webkit-scrollbar{
    height:10px;
    width:10px;
}

*::-webkit-scrollbar-track{
    background:linear-gradient(180deg, rgba(16,18,26,0.98), rgba(29,32,39,0.96));
    border-left:1px solid rgba(255,255,255,0.08);
}

*::-webkit-scrollbar-thumb{
    background:linear-gradient(180deg, rgba(34,199,245,0.95), rgba(37,99,235,0.92));
    border:2px solid #10121a;
    border-radius:999px;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,0.14), 0 0 18px rgba(34,199,245,0.22);
}

*::-webkit-scrollbar-thumb:hover{
    background:linear-gradient(180deg, #67e8f9, #3b82f6);
}

*::-webkit-scrollbar-corner{
    background:#10121a;
}

body.light-mode{
    scrollbar-color:rgba(37,99,235,0.62) rgba(237,245,255,0.96);
}

body.light-mode *::-webkit-scrollbar-track{
    background:linear-gradient(180deg, rgba(248,251,255,0.98), rgba(232,241,251,0.94));
    border-left:1px solid rgba(37,99,235,0.12);
}

body.light-mode *::-webkit-scrollbar-thumb{
    border-color:#edf5ff;
}

body{
    background:var(--bg);
    color:var(--text);
    font-family:"Inter", Arial, sans-serif;
    min-height:100vh;
}

body.light-mode{
    --bg:#edf5ff;
    --bg-2:#f8fbff;
    --surface:#ffffff;
    --surface-2:#e8f1fb;
    --text:#0f172a;
    --muted:#52657f;
    --line:rgba(37,99,235,0.14);
    --shadow:0 24px 70px rgba(37,99,235,0.16);
}

a{
    color:inherit;
}

button,
input,
select{
    font:inherit;
}

.site-nav{
    align-items:center;
    backdrop-filter:blur(18px);
    background:rgba(21,23,29,0.92);
    border-bottom:1px solid var(--line);
    display:flex;
    gap:24px;
    justify-content:space-between;
    min-height:76px;
    padding:0 8vw;
    position:sticky;
    top:0;
    z-index:20;
}

body.light-mode .site-nav{
    background:rgba(255,255,255,0.92);
}

.site-brand{
    align-items:center;
    display:flex;
    gap:10px;
    text-decoration:none;
}

.site-brand img,
.auth-logo img{
    width:34px;
    height:34px;
    object-fit:contain;
    border-radius:12px;
    display:block;
}
.auth-logo img{
    width:72px;
    height:72px;
}



.site-brand strong{
    font-size:20px;
}

.site-links{
    align-items:center;
    display:flex;
    gap:14px;
}

.site-links a,
.nav-ghost,
.nav-primary,
.nav-select{
    align-items:center;
    border:none;
    border-radius:10px;
    display:inline-flex;
    gap:6px;
    min-height:40px;
    padding:0 12px;
    text-decoration:none;
}

.site-links a{
    color:var(--muted);
    font-weight:700;
}

.site-links a:hover,
.site-links a.active{
    color:var(--text);
}

.nav-ghost{
    background:var(--surface-2);
    color:var(--text);
    cursor:pointer;
    justify-content:center;
    width:42px;
}

.public-dropdown{
    position:relative;
}

.nav-select{
    background:var(--surface-2);
    color:var(--text);
    cursor:pointer;
    font-weight:900;
    justify-content:center;
    min-width:86px;
}

.public-dropdown-menu{
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:8px;
    box-shadow:var(--shadow);
    display:none;
    min-width:170px;
    padding:8px;
    position:absolute;
    right:0;
    top:calc(100% + 10px);
    z-index:30;
}

.public-dropdown.open .public-dropdown-menu{
    display:grid;
    gap:4px;
}

.public-dropdown-menu button{
    background:transparent;
    border:none;
    border-radius:8px;
    color:var(--text);
    cursor:pointer;
    font-weight:800;
    min-height:38px;
    padding:0 12px;
    text-align:left;
}

.public-dropdown-menu button:hover,
.public-dropdown-menu button.active{
    background:var(--surface-2);
    color:var(--primary);
}

.nav-primary,
.link-button{
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    color:white !important;
    cursor:pointer;
    font-weight:900;
    justify-content:center;
    min-width:118px;
}

.mobile-menu-btn{
    background:var(--surface-2);
    border:none;
    border-radius:10px;
    color:var(--text);
    cursor:pointer;
    display:none;
    font-size:22px;
    height:42px;
    width:42px;
}

.hero-section{
    display:grid;
    gap:34px;
    grid-template-columns:minmax(320px, 1fr) minmax(330px, 430px);
    min-height:720px;
    overflow:hidden;
    padding:76px 8vw 58px;
    position:relative;
}

.hero-section::before,
.catalog-hero::before{
    background:radial-gradient(circle, rgba(34,199,245,0.2), transparent 44%);
    content:"";
    height:520px;
    left:50%;
    position:absolute;
    top:30px;
    transform:translateX(-50%);
    width:760px;
    z-index:0;
}

.star-field{
    background-image:
        radial-gradient(circle, rgba(255,255,255,0.7) 1px, transparent 1px),
        radial-gradient(circle, rgba(255,255,255,0.38) 1px, transparent 1px);
    background-position:0 0, 42px 56px;
    background-size:120px 120px, 170px 170px;
    inset:0;
    opacity:.22;
    position:absolute;
}

.hero-copy,
.auth-card,
.section-block,
.catalog-hero,
.catalog-tools,
.platform-filter-panel,
.public-services-panel,
.site-footer{
    position:relative;
    z-index:1;
}

.hero-copy{
    align-self:center;
    max-width:820px;
}

.eyebrow{
    align-items:center;
    background:rgba(255,255,255,0.07);
    border:1px solid var(--line);
    border-radius:999px;
    color:var(--text);
    display:inline-flex;
    font-size:14px;
    font-weight:900;
    gap:8px;
    padding:9px 14px;
}

.eyebrow i{
    color:var(--primary);
}

.hero-copy h1,
.catalog-hero h1{
    font-size:clamp(38px, 5vw, 70px);
    letter-spacing:0;
    line-height:1.04;
    margin:22px 0 18px;
}

.hero-copy p,
.catalog-hero p{
    color:var(--muted);
    font-size:17px;
    line-height:1.7;
    max-width:720px;
}

.hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:28px;
}

.hero-btn{
    border:1px solid var(--line);
    border-radius:10px;
    cursor:pointer;
    font-weight:900;
    min-height:48px;
    padding:0 20px;
    text-decoration:none;
}

.hero-btn.primary{
    align-items:center;
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    border-color:transparent;
    color:white;
    display:inline-flex;
}

.hero-btn.secondary{
    background:var(--surface);
    color:var(--text);
}

.hero-stats{
    display:grid;
    gap:12px;
    grid-template-columns:repeat(3, minmax(110px, 1fr));
    margin-top:34px;
    max-width:620px;
}

.hero-stats article,
.auth-card,
.benefit-grid article,
.service-card,
.platform-grid article,
.steps-grid article,
.faq-item,
.catalog-tools,
.platform-filter-panel,
.public-services-panel,
.public-service-row{
    background:rgba(32,34,41,0.88);
    border:1px solid var(--line);
    border-radius:8px;
    box-shadow:var(--shadow);
}

body.light-mode .hero-stats article,
body.light-mode .auth-card,
body.light-mode .benefit-grid article,
body.light-mode .service-card,
body.light-mode .platform-grid article,
body.light-mode .steps-grid article,
body.light-mode .faq-item,
body.light-mode .catalog-tools,
body.light-mode .platform-filter-panel,
body.light-mode .public-services-panel,
body.light-mode .public-service-row{
    background:rgba(255,255,255,0.9);
}

.hero-stats article{
    padding:16px;
}

.hero-stats strong{
    display:block;
    font-size:26px;
}

.hero-stats span,
.service-meta span,
.service-card small,
.public-service-row small{
    color:var(--muted);
    font-size:12px;
    font-weight:800;
}

.auth-card{
    align-self:center;
    padding:28px;
}

.auth-logo{
    font-size:22px;
    height:58px;
    margin:0 auto 16px;
    width:58px;
}

.auth-card h2,
.auth-card > p{
    text-align:center;
}

.auth-card h2{
    font-size:26px;
}

.auth-card > p{
    color:var(--muted);
    font-size:14px;
    margin:8px 0 22px;
}

.tabs{
    background:var(--bg-2);
    border:1px solid var(--line);
    border-radius:8px;
    display:flex;
    margin-bottom:18px;
    padding:5px;
}

.tab{
    background:transparent;
    border:none;
    border-radius:8px;
    color:var(--muted);
    cursor:pointer;
    flex:1;
    font-weight:900;
    min-height:42px;
}

.tab.active{
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    color:white;
}

.form{
    display:none;
}

.form.active{
    display:block;
}

.input-group{
    color:var(--muted);
    display:flex;
    flex-direction:column;
    font-size:13px;
    font-weight:900;
    gap:8px;
    margin-bottom:14px;
}

.input,
.catalog-tools input,
.catalog-tools select{
    background:var(--bg-2);
    border:1px solid var(--line);
    border-radius:8px;
    color:var(--text);
    min-height:46px;
    outline:none;
    padding:0 14px;
    width:100%;
}

.input:focus,
.catalog-tools input:focus,
.catalog-tools select:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(34,199,245,0.14);
}

.password-field{
    position:relative;
    width:100%;
}

.password-field .input,
.password-field input{
    padding-right:48px;
}

.password-toggle,
.reset-form .password-toggle{
    align-items:center;
    background:rgba(255,255,255,0.05);
    border:1px solid var(--line);
    border-radius:8px;
    color:var(--muted);
    cursor:pointer;
    display:flex;
    height:34px;
    justify-content:center;
    min-height:0;
    padding:0;
    position:absolute;
    right:7px;
    top:50%;
    transform:translateY(-50%);
    transition:color .18s ease, border-color .18s ease, background .18s ease;
    width:34px;
}

.password-toggle:hover,
.password-toggle.is-visible{
    background:rgba(34,199,245,0.12);
    border-color:rgba(34,199,245,0.35);
    color:var(--primary);
}

.two-factor-group{
    background:linear-gradient(135deg, rgba(34,199,245,0.1), rgba(37,99,235,0.08));
    border:1px solid rgba(34,199,245,0.2);
    border-radius:8px;
    margin-bottom:14px;
    padding:12px;
}

.two-factor-group[hidden]{
    display:none;
}

.two-factor-group small{
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    line-height:1.45;
}

.two-factor-group .input{
    letter-spacing:4px;
    text-align:center;
}

.options{
    align-items:center;
    display:flex;
    justify-content:space-between;
    gap:10px;
    margin:6px 0 18px;
}

.checkbox{
    align-items:center;
    color:var(--muted);
    display:flex;
    font-size:13px;
    gap:8px;
}

.checkbox input{
    accent-color:var(--primary);
}

.link{
    color:var(--primary);
    font-size:13px;
    font-weight:800;
    text-decoration:none;
}

.link-inline{
    background:transparent;
    border:none;
    cursor:pointer;
    padding:0;
}

.forgot-panel{
    background:linear-gradient(135deg, rgba(34,199,245,0.1), rgba(37,99,235,0.08));
    border:1px solid rgba(34,199,245,0.2);
    border-radius:8px;
    display:grid;
    gap:12px;
    margin:-4px 0 16px;
    padding:14px;
}

.forgot-panel[hidden]{
    display:none;
}

.forgot-panel-header{
    align-items:flex-start;
    display:flex;
    gap:12px;
}

.forgot-panel-header i{
    align-items:center;
    background:rgba(34,199,245,0.14);
    border:1px solid rgba(34,199,245,0.22);
    border-radius:999px;
    color:var(--primary);
    display:flex;
    flex:0 0 auto;
    height:36px;
    justify-content:center;
    width:36px;
}

.forgot-panel-header strong,
.forgot-panel-header span{
    display:block;
}

.forgot-panel-header strong{
    color:var(--text);
    font-size:14px;
    margin-bottom:4px;
}

.forgot-panel-header span{
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    line-height:1.45;
}

.forgot-panel .input-group{
    margin-bottom:0;
}

.forgot-actions{
    display:grid;
    gap:10px;
    grid-template-columns:1fr auto;
}

.forgot-primary,
.forgot-secondary{
    border:none;
    border-radius:8px;
    cursor:pointer;
    font-size:13px;
    font-weight:900;
    min-height:42px;
    padding:0 14px;
}

.forgot-primary{
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    color:white;
}

.forgot-primary:disabled{
    cursor:wait;
    filter:saturate(.75);
    opacity:.72;
}

.forgot-secondary{
    background:var(--surface-2);
    color:var(--text);
}

.btn{
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    border:none;
    border-radius:8px;
    color:white;
    cursor:pointer;
    font-weight:900;
    min-height:48px;
    width:100%;
}

.message{
    font-size:14px;
    font-weight:800;
    margin-top:16px;
    min-height:20px;
    text-align:center;
}

.public-toast{
    align-items:center;
    backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,0.16);
    border-radius:8px;
    box-shadow:0 24px 60px rgba(2,6,23,0.34);
    display:flex;
    gap:12px;
    max-width:420px;
    min-width:280px;
    padding:14px 16px;
    position:fixed;
    right:28px;
    top:92px;
    z-index:90;
    animation:publicToastIn .24s ease;
}

.public-toast.success{
    background:linear-gradient(135deg, rgba(37,99,235,0.95), rgba(56,189,248,0.92));
    color:white;
}

.public-toast.error{
    background:linear-gradient(135deg, rgba(127,29,29,0.96), rgba(239,68,68,0.9));
    color:white;
}

.public-toast.is-leaving{
    opacity:0;
    transform:translate(10px, -8px);
    transition:.2s ease;
}

.public-toast i{
    align-items:center;
    background:rgba(255,255,255,0.18);
    border-radius:999px;
    display:flex;
    flex:0 0 auto;
    font-size:18px;
    height:34px;
    justify-content:center;
    width:34px;
}

.public-toast div{
    display:grid;
    gap:3px;
    min-width:0;
}

.public-toast strong{
    font-size:14px;
    font-weight:900;
}

.public-toast span{
    display:block;
    font-size:13px;
    font-weight:700;
    line-height:1.35;
    opacity:.94;
}

@keyframes publicToastIn{
    from{
        opacity:0;
        transform:translate(10px, -8px);
    }
    to{
        opacity:1;
        transform:translate(0, 0);
    }
}

.platform-strip{
    background:var(--surface);
    border-bottom:1px solid var(--line);
    border-top:1px solid var(--line);
    display:flex;
    gap:14px;
    overflow:hidden;
    padding:18px 8vw;
}

.platform-strip span{
    align-items:center;
    background:var(--surface-2);
    border:1px solid var(--line);
    border-radius:8px;
    display:inline-flex;
    flex:0 0 auto;
    font-weight:900;
    gap:10px;
    min-width:170px;
    padding:16px;
}

.platform-strip i,
.platform-grid i,
.public-platforms i{
    color:var(--primary);
}

.section-block,
.catalog-page{
    padding:84px 8vw;
}

.section-block:nth-of-type(even){
    background:var(--bg-2);
}

.section-heading{
    margin:0 auto 44px;
    max-width:760px;
    text-align:center;
}

.section-heading > span{
    align-items:center;
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    border-radius:999px;
    box-shadow:0 0 45px rgba(34,199,245,0.45);
    display:flex;
    height:54px;
    justify-content:center;
    margin:0 auto 18px;
    width:54px;
}

.section-heading h2{
    font-size:32px;
    margin-bottom:12px;
}

.section-heading p{
    color:var(--muted);
    line-height:1.6;
}

.benefit-grid,
.platform-grid,
.steps-grid,
.service-preview-grid{
    display:grid;
    gap:18px;
    grid-template-columns:repeat(4, minmax(180px, 1fr));
}

.benefit-grid{
    grid-template-columns:repeat(3, minmax(220px, 1fr));
}

.benefit-grid article,
.platform-grid article,
.steps-grid article{
    display:grid;
    gap:14px;
    min-height:210px;
    padding:28px;
    text-align:center;
}

.benefit-grid i,
.platform-grid i,
.steps-grid i{
    color:var(--accent);
    font-size:34px;
}

.benefit-grid p,
.platform-grid p,
.steps-grid p{
    color:var(--muted);
    line-height:1.55;
}

.service-preview-grid{
    grid-template-columns:repeat(4, minmax(220px, 1fr));
}

.service-card{
    display:grid;
    gap:18px;
    min-height:230px;
    padding:20px;
}

.service-platform{
    color:var(--primary);
    display:block;
    font-size:12px;
    font-weight:900;
    margin-bottom:12px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.service-card h3{
    font-size:15px;
    line-height:1.45;
}

.service-meta{
    align-self:end;
}

.service-meta strong{
    display:block;
    font-size:24px;
}

.wide-link{
    align-items:center;
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    border-radius:8px;
    color:white;
    display:flex;
    font-weight:900;
    justify-content:center;
    margin:28px auto 0;
    min-height:48px;
    max-width:260px;
    text-decoration:none;
}

.steps-grid article{
    position:relative;
}

.steps-grid em{
    align-items:center;
    background:var(--success);
    border-radius:999px;
    bottom:14px;
    color:white;
    display:flex;
    font-size:12px;
    font-style:normal;
    font-weight:900;
    height:24px;
    justify-content:center;
    position:absolute;
    right:14px;
    width:24px;
}

.faq-grid{
    display:grid;
    gap:14px;
    grid-template-columns:repeat(2, minmax(260px, 1fr));
}

.faq-item{
    color:var(--text);
    cursor:pointer;
    display:grid;
    gap:0;
    grid-template-columns:1fr auto;
    min-height:64px;
    padding:20px;
    text-align:left;
}

.faq-item span{
    font-weight:900;
}

.faq-item p{
    color:var(--muted);
    display:none;
    grid-column:1 / -1;
    line-height:1.6;
    margin-top:12px;
}

.faq-item.open p{
    display:block;
}

.site-footer{
    align-items:flex-start;
    background:linear-gradient(135deg, var(--bg), #252936);
    border-top:1px solid var(--line);
    display:flex;
    justify-content:space-between;
    gap:28px;
    padding:54px 8vw;
}

.site-footer p{
    color:var(--muted);
    line-height:1.6;
    margin-top:14px;
    max-width:420px;
}

.site-footer nav{
    display:flex;
    gap:16px;
}

.site-footer a{
    color:var(--muted);
    font-weight:800;
    text-decoration:none;
}

.catalog-page{
    min-height:calc(100vh - 76px);
}

.catalog-hero{
    overflow:hidden;
    padding:54px 0 30px;
    text-align:left;
}

.catalog-hero h1{
    font-size:clamp(34px, 4vw, 56px);
    max-width:980px;
}

.catalog-tools{
    align-items:end;
    display:grid;
    gap:18px;
    grid-template-columns:minmax(280px, 1fr) minmax(220px, 360px);
    margin:18px 0;
    padding:18px;
}

.catalog-tools label{
    color:var(--muted);
    display:grid;
    font-size:13px;
    font-weight:900;
    gap:8px;
}

.platform-filter-panel{
    margin-bottom:18px;
    padding:18px;
}

.platform-filter-panel h2{
    color:var(--muted);
    font-size:15px;
    margin-bottom:14px;
}

.public-platforms{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.public-platforms button{
    align-items:center;
    background:var(--bg-2);
    border:1px solid var(--line);
    border-radius:8px;
    color:var(--text);
    cursor:pointer;
    display:flex;
    font-weight:900;
    gap:8px;
    min-height:42px;
    padding:0 14px;
}

.public-platforms button.active{
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    color:white;
}

.public-platforms button.active i{
    color:white;
}

.public-services-panel{
    padding:18px;
}

.catalog-count{
    align-items:center;
    display:flex;
    gap:8px;
    margin-bottom:16px;
}

.catalog-count strong{
    color:var(--primary);
    font-size:28px;
}

.catalog-count span{
    color:var(--muted);
    font-weight:800;
}

.public-service-list{
    display:grid;
    gap:10px;
}

.public-service-row{
    align-items:center;
    display:grid;
    gap:18px;
    grid-template-columns:48px minmax(260px, 1fr) 150px 140px 34px;
    padding:16px;
}

.public-service-icon{
    align-items:center;
    background:var(--surface-2);
    border-radius:8px;
    display:flex;
    height:46px;
    justify-content:center;
    width:46px;
}

.public-service-icon i{
    color:var(--primary);
    font-size:22px;
}

.public-service-main strong{
    display:block;
    line-height:1.45;
}

.public-service-main span{
    color:var(--muted);
    display:block;
    font-size:12px;
    margin-top:5px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.public-price strong{
    color:var(--primary);
    display:block;
    font-size:20px;
}

.public-range{
    color:var(--muted);
    font-size:13px;
    font-weight:900;
}

.public-arrow{
    color:var(--muted);
    font-size:22px;
}

.empty-public{
    color:var(--muted);
    font-weight:900;
    padding:28px;
    text-align:center;
}

.reset-auth-page{
    background:
        radial-gradient(circle at 50% 0%, rgba(34,199,245,0.18), transparent 34%),
        var(--bg);
    min-height:100vh;
}

.reset-shell{
    align-items:center;
    display:flex;
    flex-direction:column;
    justify-content:center;
    min-height:100vh;
    padding:28px;
}

.reset-brand{
    margin-bottom:22px;
}

.reset-card{
    background:rgba(32,34,41,0.88);
    border:1px solid var(--line);
    border-radius:8px;
    box-shadow:var(--shadow);
    max-width:430px;
    padding:30px;
    position:relative;
    text-align:center;
    width:100%;
}

.reset-icon{
    align-items:center;
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    border-radius:999px;
    box-shadow:0 0 45px rgba(34,199,245,0.35);
    display:flex;
    height:62px;
    justify-content:center;
    margin:0 auto 18px;
    width:62px;
}

.reset-icon i{
    color:white;
    font-size:28px;
}

.reset-card h1{
    font-size:28px;
    margin-bottom:8px;
}

.reset-card > p{
    color:var(--muted);
    font-size:14px;
    line-height:1.6;
    margin-bottom:20px;
}

.reset-message{
    align-items:flex-start;
    border-radius:8px;
    display:flex;
    gap:10px;
    font-size:13px;
    font-weight:800;
    line-height:1.45;
    margin-bottom:16px;
    padding:12px;
    text-align:left;
}

.reset-message.success{
    background:rgba(34,197,94,0.14);
    border:1px solid rgba(34,197,94,0.24);
    color:#86efac;
}

.reset-message.error{
    background:rgba(239,68,68,0.14);
    border:1px solid rgba(239,68,68,0.24);
    color:#fca5a5;
}

.reset-form{
    display:grid;
    gap:14px;
    text-align:left;
}

.reset-form label{
    color:var(--muted);
    display:grid;
    font-size:13px;
    font-weight:900;
    gap:8px;
}

.reset-form input{
    background:var(--bg-2);
    border:1px solid var(--line);
    border-radius:8px;
    color:var(--text);
    min-height:48px;
    outline:none;
    padding:0 14px;
    width:100%;
}

.reset-form input:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(34,199,245,0.14);
}

.reset-form button{
    background:linear-gradient(135deg, var(--primary), var(--primary-2));
    border:none;
    border-radius:8px;
    color:white;
    cursor:pointer;
    font-weight:900;
    min-height:48px;
}

.reset-back-link{
    color:var(--primary);
    display:inline-flex;
    font-size:13px;
    font-weight:900;
    margin-top:18px;
    text-decoration:none;
}

@media(max-width:1180px){
    .benefit-grid,
    .platform-grid,
    .steps-grid,
    .service-preview-grid{
        grid-template-columns:repeat(2, minmax(220px, 1fr));
    }

    .hero-section{
        grid-template-columns:1fr;
    }

    .auth-card{
        max-width:520px;
    }
}

@media(max-width:860px){
    .site-nav{
        padding:14px 18px;
    }

    .mobile-menu-btn{
        display:block;
    }

    .site-links{
        align-items:stretch;
        background:var(--surface);
        border:1px solid var(--line);
        border-radius:8px;
        display:none;
        flex-direction:column;
        left:18px;
        padding:14px;
        position:absolute;
        right:18px;
        top:70px;
    }

    .site-links.open{
        display:flex;
    }

    .site-links a,
    .nav-primary,
    .nav-ghost,
    .nav-select{
        justify-content:center;
        width:100%;
    }

    .public-dropdown{
        width:100%;
    }

    .public-dropdown-menu{
        position:static;
        width:100%;
    }

    .hero-section,
    .section-block,
    .catalog-page{
        padding-left:18px;
        padding-right:18px;
    }

    .hero-stats,
    .catalog-tools,
    .faq-grid,
    .site-footer{
        grid-template-columns:1fr;
    }

    .site-footer{
        display:grid;
    }

    .public-service-row{
        grid-template-columns:42px 1fr;
    }

    .public-price,
    .public-range,
    .public-arrow{
        grid-column:2;
    }
}

@media(max-width:620px){
    .hero-section{
        padding-top:40px;
    }

    .auth-card{
        padding:20px;
    }

    .benefit-grid,
    .platform-grid,
    .steps-grid,
    .service-preview-grid{
        grid-template-columns:1fr;
    }

    .options{
        align-items:flex-start;
        flex-direction:column;
    }

    .forgot-actions{
        grid-template-columns:1fr;
    }

    .public-toast{
        left:14px;
        max-width:none;
        min-width:0;
        right:14px;
        top:82px;
    }
}
