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

body {
    font-family: Arial, sans-serif;
    background: #f5f7fb;
    color: #071739;
}


/* HEADER */

.site-header {
    width: 100%;
    background: #ffffff;
    padding: 18px 38px 14px;
}

.header-inner {
    max-width: 1500px;
    margin: 0 auto;

    display: flex;
    align-items: center;
    justify-content: space-between;

    gap: 30px;
}

.logo {
    line-height: 1;
    font-weight: 900;
    font-size: 28px;
    letter-spacing: -1px;
    color: #071739;
}

.logo span {
    color: #ff4b1f;
}

.logo small {
    display: block;
    font-size: 8px;
    letter-spacing: 7px;
    color: #7b8495;
    margin-top: 5px;
    padding-left: 6px;
}

.nav {
    display: flex;
    align-items: center;
    gap: 42px;

    font-size: 13px;
    font-weight: 700;
}

.nav a {
    text-decoration: none;
    color: #101b3b;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 18px;
}

.icon-btn {
    font-size: 22px;
    color: #101b3b;
}

.lang {
    font-size: 14px;
    font-weight: 700;
}

.btn-outline {
    padding: 13px 24px;
    border: 1px solid #17213e;
    border-radius: 7px;

    text-decoration: none;
    color: #101b3b;

    font-size: 13px;
    font-weight: 700;
}

.btn-login {
    padding: 14px 24px;
    background: #ff4b1f;
    border-radius: 7px;

    text-decoration: none;
    color: white;

    font-size: 13px;
    font-weight: 800;
}


/* HERO */

.hero-wrap {
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 30px;
}

.hero {
    position: relative;

    min-height: 515px;

    border-radius: 18px;
    overflow: hidden;

    background:
            linear-gradient(
                    90deg,
                    rgba(5, 15, 38, 0.98) 0%,
                    rgba(5, 15, 38, 0.92) 35%,
                    rgba(5, 15, 38, 0.25) 62%,
                    rgba(5, 15, 38, 0.05) 100%
            ),
            url("img/hero.png") center right / cover no-repeat;

    box-shadow: 0 18px 45px rgba(8, 18, 44, 0.18);
}

.hero-content {
    width: 48%;
    padding: 21px 0 0 50px;
    color: white;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;

    padding: 7px 16px;

    background: rgba(255, 255, 255, 0.08);

    border-radius: 12px;

    font-size: 13px;
    font-weight: 700;

    margin-bottom: 32px;
}

.hero-badge span {
    background: #ff4b1f;

    width: 18px;
    height: 18px;

    border-radius: 50%;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    font-size: 11px;
}

.hero h1 {
    font-size: 39px;
    line-height: 1.03;
    letter-spacing: -1.5px;

    max-width: 560px;

    margin-bottom: 24px;
}

.hero p {
    max-width: 620px;

    font-size: 16px;
    line-height: 1.55;

    color: #dce5f4;

    margin-bottom: 34px;
}


/* BUTTONS */

.hero-buttons {
    display: flex;
    align-items: center;
    gap: 28px;

    margin-bottom: 45px;
}

.btn-orange {
    background: #ff4b1f;
    color: white;

    text-decoration: none;

    padding: 18px 28px;

    border-radius: 10px;

    font-size: 15px;
    font-weight: 800;

    box-shadow: 0 12px 25px rgba(255, 75, 31, 0.35);
}

/* PWA INSTALL HERO BUTTON */
.hero-app-install-btn{
    min-height:58px;
    padding:9px 18px 9px 12px;
    border:1px solid rgba(255,255,255,.26);
    border-radius:14px;
    background:rgba(255,255,255,.08);
    color:#ffffff;
    text-decoration:none;
    display:inline-flex;
    align-items:center;
    gap:12px;
    cursor:pointer;
    font-family:inherit;
    box-shadow:0 14px 32px rgba(0,0,0,.18);
    backdrop-filter:blur(10px);
    transition:.22s ease;
}

.hero-app-install-btn:hover{
    transform:translateY(-2px);
    background:rgba(255,255,255,.13);
    border-color:rgba(255,255,255,.38);
}

.hero-app-install-icon{
    width:40px;
    height:40px;
    border-radius:12px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,75,31,.18);
    color:#ff8a66;
    font-size:20px;
}

.hero-app-install-text{
    display:grid;
    gap:2px;
    text-align:left;
    line-height:1.1;
}

.hero-app-install-text strong{
    color:#ffffff;
    font-size:14px;
    font-weight:900;
    white-space:nowrap;
}

.hero-app-install-text small{
    color:#cfd8ea;
    font-size:12px;
    font-weight:700;
}

.pwa-install-help{
    position:fixed;
    inset:0;
    z-index:99999;
    display:none;
    align-items:center;
    justify-content:center;
    padding:20px;
    background:rgba(2,8,22,.72);
    backdrop-filter:blur(8px);
}

.pwa-install-help.active{
    display:flex;
}

.pwa-install-card{
    width:min(420px,100%);
    padding:24px;
    border-radius:24px;
    background:#ffffff;
    color:#071739;
    box-shadow:0 30px 90px rgba(0,0,0,.34);
}

.pwa-install-card h3{
    font-size:24px;
    line-height:1.15;
    margin-bottom:10px;
}

.pwa-install-card p{
    color:#5f6b82;
    font-size:15px;
    line-height:1.5;
    margin-bottom:18px;
}

.pwa-install-steps{
    display:grid;
    gap:10px;
    margin-bottom:18px;
}

.pwa-install-steps div{
    padding:13px 14px;
    border-radius:14px;
    background:#f5f7fb;
    color:#071739;
    font-size:14px;
    font-weight:800;
}

.pwa-install-close{
    width:100%;
    height:50px;
    border:0;
    border-radius:14px;
    background:#ff4b1f;
    color:#ffffff;
    font-size:15px;
    font-weight:900;
    cursor:pointer;
}

@media (max-width:900px){
    .hero-app-install-btn{
        width:100%;
        justify-content:center;
        min-height:62px;
        border-radius:16px;
    }

    .hero-app-install-text strong{
        font-size:15px;
    }
}

.video-link {
    display: flex;
    align-items: center;
    gap: 14px;

    color: white;
    text-decoration: none;

    font-weight: 800;
    font-size: 14px;
}

.play {
    width: 52px;
    height: 52px;

    border: 2px solid rgba(255,255,255,0.55);

    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    padding-left: 4px;
}

.video-link small {
    display: block;

    color: #aeb9cc;

    font-weight: 600;

    margin-top: 5px;
}


/* BENEFITS */

.hero-benefits {
    position: absolute;

    left: 50px;
    bottom: 28px;

    width: 820px;

    display: grid;
    grid-template-columns: repeat(4, 1fr);

    gap: 14px;
}

.benefit {
    display: flex;
    align-items: center;
    gap: 12px;

    padding: 18px;

    border-radius: 14px;

    background: rgba(255, 255, 255, 0.08);

    backdrop-filter: blur(8px);

    color: white;

    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
}

.benefit-icon {
    min-width: 34px;
    height: 34px;

    border-radius: 10px;

    background: rgba(255,255,255,0.12);

    display: flex;
    align-items: center;
    justify-content: center;

    color: #ff4b1f;
    font-size: 18px;
}


/* RATING */

.rating-card {
    position: absolute;
    right: 5px;
    bottom: 30px;

    width: 320px;

    background: #ffffff;
    border-radius: 14px;

    padding: 16px 18px;

    display: flex;
    align-items: center;
    gap: 14px;

    box-shadow: 0 16px 38px rgba(7, 17, 40, 0.22);
}
.avatars {
    display: flex;
    align-items: center;
}

.avatar {
    width: 34px;
    height: 34px;

    border-radius: 50%;
    border: 3px solid white;

    margin-left: -10px;

    background-size: cover;
    background-position: center;
}
.avatar:nth-child(1) {
    background-image: url("img/bloc3/client-1.png");
}

.avatar:nth-child(2) {
    background-image: url("img/bloc3/client-2.png");
}

.avatar:nth-child(3) {
    background-image: url("img/bloc3/client-3.png");
}

.avatar:first-child {
    margin-left: 0;
}

.more {
    width: 42px;
    height: 24px;

    border-radius: 20px;
    background: #eef2f8;
    border: 3px solid white;

    margin-left: -10px;

    font-size: 10px;
    font-weight: 900;

    display: flex;
    align-items: center;
    justify-content: center;

    color: #071739;
}

.rating-text strong {
    font-size: 13px;
    margin-bottom: 6px;
    line-height: 1.25;
}

.stars {
    font-size: 14px;
    letter-spacing: 2px;
}

.score {
    font-size: 12px;
}

.stars {
    color: #ff4b1f;

    font-size: 17px;
    letter-spacing: 3px;
}

.score {
    color: #071739;

    font-size: 13px;
    font-weight: 900;

    margin-left: 10px;
}


/* MOBILE */

@media (max-width: 900px) {

    .nav,
    .header-actions {
        display: none;
    }

    .site-header {
        padding: 16px 20px;
    }

    .hero-wrap {
        padding: 0 14px;
    }

    .hero {
        min-height: 720px;

        background:
                linear-gradient(
                        180deg,
                        rgba(5,15,38,0.96) 0%,
                        rgba(5,15,38,0.78) 55%,
                        rgba(5,15,38,0.25) 100%
                ),
                url("img/hero.png") center right / cover no-repeat;
    }

    .hero-content {
        width: 100%;
        padding: 36px 24px 0;
    }

    .hero h1 {
        font-size: 36px;
    }

    .hero p {
        font-size: 15px;
    }

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

    .hero-benefits {
        left: 20px;
        right: 20px;

        bottom: 150px;

        width: auto;

        grid-template-columns: 1fr 1fr;
    }

    .rating-card {
        left: 20px;
        right: 20px;

        bottom: 24px;

        width: auto;
    }
}.insurance-dashboard {
     max-width: 1500px;
     margin: 28px auto 0;
     padding: 34px;
     border-radius: 26px;
     background:
             radial-gradient(circle at top left, rgba(255, 75, 31, 0.12), transparent 28%),
             linear-gradient(135deg, #061226 0%, #071428 45%, #020816 100%);
     box-shadow: 0 25px 70px rgba(3, 10, 25, 0.35);
 }

.dashboard-grid {
    display: grid;
    grid-template-columns: 1.35fr 1fr 1fr;
    gap: 22px;
    margin-bottom: 24px;
}

.dash-main {
    grid-row: span 2;
    min-height: 430px;
    padding: 44px;
    border-radius: 24px;
    background: linear-gradient(145deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025));
    border: 1px solid rgba(255,255,255,0.12);
    color: white;
}

.dash-main span,
.dash-compare-intro span {
    display: inline-block;
    color: #ff4b1f;
    font-size: 15px;
    font-weight: 900;
    margin-bottom: 24px;
}

.dash-main h2 {
    font-size: 48px;
    line-height: 1.08;
    letter-spacing: -1.8px;
    max-width: 460px;
    margin-bottom: 28px;
}

.dash-main p,
.dash-compare-intro p {
    color: #c7d0df;
    font-size: 18px;
    line-height: 1.6;
    max-width: 470px;
    margin-bottom: 46px;
}

.dash-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ff3b18;
    color: white;
    text-decoration: none;
    padding: 18px 30px;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 900;
    box-shadow: 0 15px 35px rgba(255, 59, 24, 0.38);
}

.dash-service {
    min-height: 190px;
    padding: 34px;
    border-radius: 24px;
    background: #ffffff;
    color: #070c35;
    box-shadow: 0 18px 45px rgba(0,0,0,0.12);
}

.dash-icon {
    width: 58px;
    height: 58px;
    border-radius: 17px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    margin-bottom: 28px;
}

.dash-icon.blue { background: #e9efff; }
.dash-icon.orange { background: #fff0df; }
.dash-icon.pink { background: #ffe1f0; }
.dash-icon.purple { background: #f0ebff; }

.dash-service h3 {
    font-size: 25px;
    line-height: 1.18;
    letter-spacing: -0.8px;
    margin-bottom: 16px;
}

.dash-service p {
    color: #73809b;
    font-size: 16px;
    line-height: 1.55;
}

.compare-dashboard {
    display: grid;
    grid-template-columns: 1fr 1fr 1.08fr;
    gap: 22px;
}

.dash-compare-intro,
.dash-compare-card {
    min-height: 300px;
    padding: 38px 40px;
    border-radius: 24px;
    background: linear-gradient(145deg, rgba(255,255,255,0.075), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.12);
    color: white;
    position: relative;
}

.dash-compare-intro h2 {
    font-size: 36px;
    line-height: 1.15;
    letter-spacing: -1px;
    margin-bottom: 22px;
}

.dash-compare-card h3 {
    font-size: 27px;
    line-height: 1.2;
    margin-bottom: 34px;
}

.dash-compare-card ul {
    list-style: none;
}

.dash-compare-card li {
    position: relative;
    padding-left: 42px;
    margin-bottom: 20px;
    color: #e7ecf5;
    font-size: 17px;
}

.dash-compare-card li::before {
    position: absolute;
    left: 0;
    top: -2px;
    font-size: 22px;
    font-weight: 900;
}

.dash-compare-card li.yes::before {
    content: "✓";
    color: #22d65f;
}

.dash-compare-card li.no::before {
    content: "×";
    color: #ff2f45;
}

.dash-best {
    position: absolute;
    top: 28px;
    right: 28px;
    background: #ff3b18;
    color: white;
    padding: 10px 16px;
    border-radius: 30px;
    font-size: 13px;
    font-weight: 900;
}

.dash-service,
.dash-main,
.dash-compare-card,
.dash-compare-intro {
    transition: 0.25s ease;
}

.dash-service:hover,
.dash-main:hover,
.dash-compare-card:hover,
.dash-compare-intro:hover {
    transform: translateY(-4px);
}

@media (max-width: 1100px) {
    .dashboard-grid,
    .compare-dashboard {
        grid-template-columns: 1fr;
    }

    .dash-main {
        grid-row: auto;
        min-height: auto;
    }

    .dash-main h2 {
        font-size: 36px;
    }

    .insurance-dashboard {
        padding: 18px;
    }
}.trust-section {
     max-width: 1500px;
     margin: 28px auto 0;
     padding: 0 30px;
     display: grid;
     grid-template-columns: 1fr 1fr;
     gap: 24px;
 }

.reviews-card,
.about-card {
    background: #ffffff;
    border-radius: 26px;
    padding: 34px;
    box-shadow: 0 18px 45px rgba(7, 17, 40, 0.05);
}

.small-label {
    display: inline-block;
    color: #ff4b1f;
    font-size: 13px;
    font-weight: 900;
    margin-bottom: 10px;
}

.trust-section h2 {
    font-size: 34px;
    line-height: 1.1;
    color: #08113a;
    letter-spacing: -0.8px;
    margin-bottom: 12px;
}

.section-desc {
    color: #7c87a3;
    font-size: 15px;
    line-height: 1.55;
    max-width: 620px;
    margin-bottom: 24px;
}

.reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-bottom: 24px;
}

.review-item {
    background: #ffffff;
    border: 1px solid #edf0f6;
    border-radius: 20px;
    padding: 20px;
    min-height: 230px;
    box-shadow: 0 12px 30px rgba(7, 17, 40, 0.05);
}

.review-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}

.review-head img {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    object-fit: cover;
}

.review-head strong {
    display: block;
    color: #08113a;
    font-size: 14px;
}

.review-head small {
    color: #8a94aa;
    font-size: 12px;
}

.review-item p {
    color: #546078;
    font-size: 13px;
    line-height: 1.55;
    margin-bottom: 16px;
}

.stars-orange {
    color: #ff4b1f;
    letter-spacing: 3px;
    font-size: 16px;
}

.review-cta {
    text-align: center;
    background: #ffffff;
    border: 1px solid #edf0f6;
    border-radius: 22px;
    padding: 24px;
    box-shadow: 0 12px 30px rgba(7, 17, 40, 0.04);
}

.review-cta h3 {
    color: #08113a;
    font-size: 24px;
    margin-bottom: 8px;
}

.review-cta p {
    color: #7c87a3;
    font-size: 14px;
    line-height: 1.5;
    max-width: 600px;
    margin: 0 auto 18px;
}

.review-buttons {
    display: flex;
    justify-content: center;
    gap: 14px;
}

.whatsapp-btn,
.light-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 24px;
    border-radius: 40px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 900;
}

.whatsapp-btn {
    background: #10c768;
    color: #ffffff;
}

.light-btn {
    background: #ffffff;
    color: #08113a;
    border: 1px solid #dfe4ee;
}

.trust-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-bottom: 22px;
}

.trust-stats div {
    background: #f7f9fd;
    border-radius: 16px;
    padding: 18px 14px;
    text-align: center;
}

.trust-stats strong {
    display: block;
    color: #08113a;
    font-size: 17px;
    margin-bottom: 6px;
}

.trust-stats span {
    color: #7c87a3;
    font-size: 12px;
}

.team-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}

.team-card {
    position: relative;
    height: 260px;
    border-radius: 18px;
    overflow: hidden;
    background: #eef2f8;
}

.team-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 30%;
}

.team-overlay {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 18px;
    color: white;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,0.78));
}

.team-overlay strong {
    display: block;
    font-size: 15px;
    margin-bottom: 5px;
}

.team-overlay span {
    font-size: 12px;
    color: rgba(255,255,255,0.85);
}

.team-overlay.orange {
    background: linear-gradient(180deg, rgba(255,75,31,0.2), rgba(255,75,31,0.95));
    text-align: center;
}

.mission-box {
    background: #fff0e9;
    color: #08113a;
    border-radius: 18px;
    padding: 22px 28px;
    text-align: center;
    font-size: 15px;
    line-height: 1.55;
    font-weight: 800;
}

@media (max-width: 1100px) {
    .trust-section {
        grid-template-columns: 1fr;
    }

    .reviews-grid,
    .team-grid,
    .trust-stats {
        grid-template-columns: 1fr;
    }
}/* FINAL SECTION + FOOTER */

.final-section {
    max-width: 1500px;
    margin: 28px auto 0;
    padding: 0 30px;
}

.final-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 24px;
    align-items: stretch;
}

.lead-form-card,
.life-card,
.office-card {
    position: relative;
    overflow: hidden;
    min-height: 180px;
    padding: 12px;
    border-radius: 26px;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(7, 17, 40, 0.05);
}

.lead-form-card {
    background: linear-gradient(135deg, #071326 0%, #020b1a 100%);
    color: #ffffff;
}

.lead-form-card span,
.life-card span,
.office-card span {
    display: inline-block;
    margin-bottom: 12px;
    color: #ff4b1f;
    font-size: 13px;
    font-weight: 900;
}

.lead-form-card h2,
.life-card h2,
.office-card h2 {
    margin-bottom: 14px;
    color: #08113a;
    font-size: 30px;
    line-height: 1.12;
    letter-spacing: -0.8px;
}

.lead-form-card h2 {
    color: #ffffff;
}

.lead-form-card p,
.life-card p,
.office-card p {
    margin-bottom: 20px;
    color: #7b86a0;
    font-size: 15px;
    line-height: 1.55;
}

.lead-form-card p {
    color: #c5cede;
}

.lead-form {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.lead-form input {
    width: 100%;
    height: 56px;
    padding: 0 18px;
    border: none;
    border-radius: 12px;
    outline: none;
    background: #ffffff;
    color: #08113a;
    font-size: 14px;
}

.lead-form button {
    grid-column: 1 / -1;
    height: 58px;
    border: none;
    border-radius: 12px;
    background: #ff3b18;
    color: #ffffff;
    font-size: 16px;
    font-weight: 900;
    cursor: pointer;
    box-shadow: 0 14px 35px rgba(255, 59, 24, 0.35);
}

.lead-form-card small {
    display: block;
    margin-top: 18px;
    color: #8c98ad;
    font-size: 12px;
    text-align: center;
}

/* LIFE CARD */

.life-card {
    padding-right: 180px;
}

.life-card ul {
    list-style: none;
    margin: 0 0 11px;
    padding: 0;

    display: flex;
    flex-direction: column;
    gap: 10px;
}

.life-card li {
    width: 100%;

    padding: 13px 16px;

    border-radius: 12px;

    background: #f7f9fd;

    color: #101b3b;

    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;

    display: flex;
    align-items: center;
}

.life-card li::before {
    content: "✓";

    margin-right: 10px;

    color: #071739;

    font-size: 12px;
    font-weight: 900;
}

.orange-small-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 22px;
    border-radius: 12px;
    background: #ff4b1f;
    color: #ffffff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 900;
}

.life-photo {
    position: absolute;
    right: 28px;
    top: 95px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    object-fit: cover;
}

/* OFFICE CARD */

.map-box {
    width: 100%;
    height: 115px;
    margin-bottom: 18px;
    overflow: hidden;
    border-radius: 16px;
    background: #edf2f8;
}

.map-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.office-info strong {
    display: block;
    margin-bottom: 4px;
    color: #08113a;
    font-size: 14px;
}

.office-info p {
    margin-bottom: 10px;
    color: #7b86a0;
    font-size: 14px;
}

.orange-text {
    color: #ff4b1f !important;
    font-weight: 800;
}

/* FOOTER */

.site-footer {
    margin-top: 28px;
    padding: 38px 30px;
    background: #061326;
    color: #ffffff;
}

.footer-inner {
    max-width: 1500px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
    gap: 50px;
}

.footer-logo {
    margin-bottom: 14px;
    color: #ffffff;
    font-size: 26px;
    font-weight: 900;
}

.footer-logo span {
    color: #ff4b1f;
}

.footer-brand p,
.footer-col p,
.footer-col a {
    color: #b9c3d4;
    font-size: 14px;
    line-height: 1.6;
}

.footer-brand ul {
    list-style: none;
    margin-top: 14px;
    padding: 0;
}

.footer-brand li {
    margin-bottom: 7px;
    color: #b9c3d4;
    font-size: 14px;
}

.footer-col h4 {
    margin-bottom: 16px;
    color: #ffffff;
    font-size: 16px;
}

.footer-col a {
    display: block;
    margin-bottom: 9px;
    text-decoration: none;
}

.footer-whatsapp {
    margin-top: 14px;
    padding: 12px 20px;
    border-radius: 30px;
    background: #10c768;
    color: #ffffff !important;
    text-align: center;
    font-weight: 900;
}

/* MOBILE */

@media (max-width: 1100px) {
    .final-grid,
    .footer-inner {
        grid-template-columns: 1fr;
    }

    .life-card {
        padding-right: 34px;
        padding-bottom: 230px;
    }

    .life-photo {
        left: 34px;
        right: auto;
        top: auto;
        bottom: 34px;
    }

    .lead-form {
        grid-template-columns: 1fr;
    }

    .lead-form button {
        grid-column: auto;
    }
}/* FIX HERO MOBILE */

@media (max-width: 900px) {

    .hero-wrap {
        padding: 0;
    }

    .hero {
        border-radius: 0;
        min-height: auto;
        padding-bottom: 24px;

        background:
                linear-gradient(
                        180deg,
                        rgba(5,15,38,0.96) 0%,
                        rgba(5,15,38,0.82) 55%,
                        rgba(5,15,38,0.65) 100%
                ),
                url("img/mobile-hero-bg.png") center center / cover no-repeat;
    }

    .hero-content {
        width: 100%;
        padding: 26px 22px 0;
    }

    .hero-badge {
        font-size: 14px;
        margin-bottom: 34px;
        max-width: 100%;
    }

    .hero h1 {
        font-size: 42px;
        line-height: 1.08;
        letter-spacing: -1px;
        margin-bottom: 28px;
    }

    .hero p {
        font-size: 18px;
        line-height: 1.6;
        margin-bottom: 30px;
    }

    .hero-buttons {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
        margin-bottom: 26px;
    }

    .btn-orange {
        width: 100%;
        text-align: center;
        padding: 18px 20px;
        font-size: 16px;
        border-radius: 16px;
    }

    .video-link {
        width: 100%;
        justify-content: center;
        padding: 14px 18px;
        border-radius: 16px;
        background: rgba(255,255,255,0.08);
    }

    .hero-benefits {
        position: static;
        width: 100%;
        padding: 0 22px;
        margin-top: 18px;

        display: grid;
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .benefit {
        min-height: 86px;
        padding: 18px;
        font-size: 17px;
        border-radius: 18px;
        background: rgba(255,255,255,0.12);
    }

    .benefit-icon {
        min-width: 50px;
        height: 50px;
        font-size: 22px;
        border-radius: 15px;
    }

    .rating-card {
        position: static;
        width: calc(100% - 44px);
        margin: 18px auto 0;
        border-radius: 18px;
    }
}

/* QUIZ POPUP */

.quiz-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(2, 8, 22, 0.72);
    backdrop-filter: blur(8px);
}

.quiz-overlay.active {
    display: flex;
}

body.quiz-open {
    overflow: hidden;
}

.quiz-modal {
    position: relative;
    width: min(760px, 100%);
    max-height: 92vh;
    overflow-y: auto;
    padding: 34px;
    border-radius: 26px;
    background: #ffffff;
    color: #071739;
    box-shadow: 0 35px 100px rgba(0,0,0,0.35);
    animation: quizIn 0.22s ease;
}

@keyframes quizIn {
    from {
        opacity: 0;
        transform: translateY(18px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.quiz-close {
    position: absolute;
    top: 20px;
    right: 22px;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 50%;
    background: #f4f6fb;
    color: #071739;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
}

.quiz-progress {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 30px;
    padding-right: 44px;
}

.quiz-step-label {
    display: flex;
    align-items: center;
    gap: 9px;
    color: #8a94aa;
    font-size: 13px;
    font-weight: 800;
    white-space: nowrap;
}

.quiz-step-label span {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid #cfd6e4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    color: #8a94aa;
    font-size: 12px;
    font-weight: 900;
}

.quiz-step-label.active {
    color: #071739;
}

.quiz-step-label.active span {
    border-color: #ff1f12;
    background: #ff1f12;
    color: #ffffff;
}

.quiz-line {
    height: 1px;
    flex: 1;
    min-width: 28px;
    background: #dfe5ef;
}

.quiz-step {
    display: none;
}

.quiz-step.active {
    display: block;
}

.quiz-step h2 {
    margin-bottom: 10px;
    font-size: 30px;
    line-height: 1.15;
    letter-spacing: -0.8px;
    color: #071739;
}

.quiz-step p {
    margin-bottom: 24px;
    color: #6f7a92;
    font-size: 16px;
    line-height: 1.45;
}

.quiz-options {
    display: grid;
    gap: 12px;
    margin-bottom: 24px;
}

.quiz-options-2 {
    grid-template-columns: repeat(2, 1fr);
}

.quiz-option {
    position: relative;
    min-height: 86px;
    padding: 18px;
    border: 1px solid #dfe5ef;
    border-radius: 16px;
    background: #ffffff;
    color: #071739;
    text-align: left;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: 0.2s ease;
}

.quiz-option:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 75, 31, 0.55);
    box-shadow: 0 12px 28px rgba(7, 17, 40, 0.08);
}

.quiz-option.selected {
    border-color: #ff1f12;
    box-shadow: 0 14px 34px rgba(255, 31, 18, 0.12);
}

.quiz-option strong {
    font-size: 15px;
    line-height: 1.35;
}

.quiz-option em {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
    background: #ff1f12;
    color: #ffffff;
    font-style: normal;
    font-size: 13px;
    font-weight: 900;
}

.quiz-option.selected em {
    display: flex;
}

.quiz-icon {
    min-width: 46px;
    height: 46px;
    border-radius: 14px;
    background: #f3f6fb;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 23px;
}

.quiz-wide {
    grid-column: 1 / -1;
}

.quiz-main-btn,
.quiz-whatsapp-btn {
    width: 100%;
    height: 62px;
    border: none;
    border-radius: 14px;
    background: #ff1f12;
    color: #ffffff;
    font-size: 17px;
    font-weight: 900;
    cursor: pointer;
    box-shadow: 0 14px 35px rgba(255, 31, 18, 0.28);
}

.quiz-whatsapp-btn {
    background: #ff1f12;
}

.quiz-safe {
    margin-top: 16px;
    text-align: center;
    color: #7d879b;
    font-size: 13px;
    line-height: 1.4;
}

.quiz-kasse-grid {
    grid-template-columns: repeat(3, 1fr);
}

.kasse-option {
    min-height: 130px;
    flex-direction: column;
    justify-content: center;
    text-align: center;
}

.kasse-logo {
    font-size: 30px !important;
    line-height: 1;
}

.kasse-logo.green { color: #138048; }
.kasse-logo.blue { color: #20a8e8; }
.kasse-logo.lime { color: #73bf20; }
.kasse-logo.orange { color: #ff6a00; }
.kasse-logo.gray { color: #8b94a7; }

.kasse-option span {
    color: #071739;
    font-size: 14px;
    font-weight: 700;
}

.quiz-actions {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px;
    align-items: center;
}

.quiz-back {
    height: 54px;
    padding: 0 8px;
    border: none;
    background: transparent;
    color: #0b4abf;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
}

.quiz-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 18px;
}

.quiz-fields input {
    width: 100%;
    height: 58px;
    padding: 0 18px;
    border: 1px solid #dfe5ef;
    border-radius: 14px;
    outline: none;
    background: #ffffff;
    color: #071739;
    font-size: 15px;
}

.quiz-fields input:focus {
    border-color: #ff4b1f;
    box-shadow: 0 0 0 4px rgba(255, 75, 31, 0.1);
}

.quiz-next-box {
    margin-bottom: 18px;
    padding: 18px 20px;
    border-radius: 16px;
    background: #eafff0;
    color: #071739;
}

.quiz-next-box strong {
    display: block;
    margin-bottom: 10px;
    font-size: 16px;
}

.quiz-next-box ul {
    list-style: none;
}

.quiz-next-box li {
    position: relative;
    padding-left: 25px;
    margin-bottom: 8px;
    color: #26334f;
    font-size: 15px;
}

.quiz-next-box li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #10c768;
    font-weight: 900;
}

.quiz-actions-bottom {
    display: block;
    margin-top: 12px;
}

@media (max-width: 700px) {
    .quiz-overlay {
        align-items: flex-end;
        padding: 0;
    }

    .quiz-modal {
        width: 100%;
        max-height: 96vh;
        padding: 26px 18px 22px;
        border-radius: 26px 26px 0 0;
    }

    .quiz-progress {
        gap: 7px;
        margin-bottom: 24px;
        padding-right: 38px;
    }

    .quiz-step-label {
        font-size: 0;
    }

    .quiz-step-label span {
        font-size: 12px;
    }

    .quiz-line {
        min-width: 18px;
    }

    .quiz-step h2 {
        font-size: 26px;
    }

    .quiz-step p {
        font-size: 15px;
    }

    .quiz-options-2,
    .quiz-kasse-grid,
    .quiz-fields {
        grid-template-columns: 1fr 1fr;
    }

    .quiz-option {
        min-height: 118px;
        padding: 14px;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
    }

    .quiz-option strong {
        font-size: 14px;
    }

    .quiz-icon {
        min-width: 42px;
        width: 42px;
        height: 42px;
    }

    .quiz-wide {
        min-height: 72px;
        grid-column: 1 / -1;
        flex-direction: row;
        align-items: center;
    }

    .kasse-option {
        align-items: center;
        text-align: center;
    }

    .kasse-logo {
        font-size: 25px !important;
    }

    .quiz-fields {
        grid-template-columns: 1fr;
    }

    .quiz-main-btn,
    .quiz-whatsapp-btn {
        height: 58px;
        font-size: 16px;
    }
}html {
     scroll-behavior: smooth;
 }


/* SOCIAL ICONS + BONUS OFFER */

.header-socials-wrap{
    padding: 4px;
    border-radius: 14px;

    background: #f4f6fb;

    border: 1px dashed rgba(7,23,57,0.12);
}

.header-socials{
    display:flex;
    align-items:center;
    gap:6px;
}

.header-socials a{
    width:30px;
    height:30px;

    border-radius:9px;

    color:#071739;
    text-decoration:none;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:15px;
    font-weight:900;

    transition:.2s ease;
}

.header-socials a:hover{
    background:white;
    color:#ff4b1f;

    transform:translateY(-1px);

    box-shadow:0 8px 18px rgba(255,75,31,.12);
}

.bonus-offer {
    margin: -4px auto 28px;
    padding: 0 0;
    position: relative;
    z-index: 2;
}

.bonus-offer-inner {
    min-height: 104px;
    padding: 22px 28px;
    border-radius: 22px;
    background:
            radial-gradient(circle at left, rgba(255, 191, 71, 0.18), transparent 28%),
            linear-gradient(135deg, rgba(6, 18, 38, 0.98), rgba(11, 15, 38, 0.96));
    border: 1px solid rgba(255, 191, 71, 0.35);
    box-shadow: 0 22px 55px rgba(7, 17, 40, 0.18);
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 22px;
    overflow: hidden;
}

.bonus-offer-inner::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 191, 71, 0.65), transparent);
}

.bonus-offer-icon {
    width: 68px;
    height: 68px;
    border-radius: 20px;
    background: rgba(255, 191, 71, 0.12);
    border: 1px solid rgba(255, 191, 71, 0.45);
    color: #ffbf47;
    font-size: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 35px rgba(255, 191, 71, 0.18);
}

.bonus-offer-text strong {
    display: block;
    color: #ffffff;
    font-size: 25px;
    line-height: 1.25;
    letter-spacing: -0.4px;
}

.bonus-offer-text span {
    color: #ffbf47;
}

.bonus-offer-btn {
    height: 58px;
    padding: 0 26px;
    border-radius: 14px;
    border: 1px solid rgba(255, 191, 71, 0.55);
    background: rgba(255, 255, 255, 0.04);
    color: #ffbf47;
    font-size: 15px;
    font-weight: 900;
    cursor: pointer;
    transition: 0.22s ease;
    white-space: nowrap;
}

.bonus-offer-btn:hover {
    transform: translateY(-2px);
    background: #ff3b18;
    border-color: #ff3b18;
    color: #ffffff;
    box-shadow: 0 18px 35px rgba(255, 59, 24, 0.25);
}

@media (max-width: 1100px) {
    .header-inner {
        gap: 18px;
    }

    .nav {
        gap: 24px;
    }

    .header-socials a {
        width: 32px;
        height: 32px;
        font-size: 16px;
    }

    .bonus-offer-inner {
        grid-template-columns: auto 1fr;
    }

    .bonus-offer-btn {
        grid-column: 1 / -1;
        width: 100%;
    }
}

@media (max-width: 900px) {
    .site-header {
        padding: 16px 18px 18px;
    }

    .header-inner {
        flex-wrap: wrap;
        gap: 14px;
    }

    .header-actions {
        width: 100%;
        display: flex;
        justify-content: space-between;
        gap: 10px;
        order: 2;
    }

    .icon-btn {
        display: none;
    }

    .lang {
        min-width: 58px;
    }

    .header-socials {
        flex: 1;
        justify-content: center;
        gap: 10px;
    }

    .header-socials a {
        width: 42px;
        height: 42px;
        border-radius: 14px;
        background: #f4f6fb;
        font-size: 18px;
    }

    .header-actions .btn-orange {
        width: auto;
        min-width: 135px;
        padding: 13px 16px;
        border-radius: 14px;
        font-size: 14px;
        box-shadow: 0 12px 25px rgba(255, 75, 31, 0.22);
    }

    .bonus-offer {
        margin: 18px 18px 24px;
    }

    .bonus-offer-inner {
        min-height: auto;
        padding: 22px;
        grid-template-columns: 1fr;
        text-align: center;
        border-radius: 24px;
        gap: 16px;
    }

    .bonus-offer-icon {
        margin: 0 auto;
        width: 74px;
        height: 74px;
        border-radius: 22px;
        font-size: 32px;
    }

    .bonus-offer-text strong {
        font-size: 25px;
        line-height: 1.22;
    }

    .bonus-offer-btn {
        height: 58px;
        font-size: 16px;
    }
}

@media (max-width: 430px) {
    .header-socials a {
        width: 38px;
        height: 38px;
    }

    .header-actions {
        gap: 8px;
    }

    .header-actions .btn-orange {
        min-width: 126px;
        padding-left: 12px;
        padding-right: 12px;
    }

    .bonus-offer-text strong {
        font-size: 22px;
    }
}.rating-text strong{
     color:#0b1230 !important;
 }/* LOGIN PAGE */

.login-page{
    position: relative;
    width: 100%;
    height: 100vh;

    display: flex;
    justify-content: center;
    align-items: center;

    overflow: hidden;

    background:
            radial-gradient(circle at top left, #2140ff 0%, transparent 30%),
            radial-gradient(circle at bottom right, #001d5c 0%, transparent 30%),
            #050816;

    font-family: Arial, sans-serif;
}

.login-overlay{
    position: absolute;
    inset: 0;

    background:
            linear-gradient(
                    135deg,
                    rgba(255,255,255,0.03),
                    rgba(255,255,255,0)
            );

    backdrop-filter: blur(10px);
}

.login-box{
    position: relative;

    width: 420px;

    padding: 50px;

    border-radius: 28px;

    background: rgba(12,18,45,0.85);

    border: 1px solid rgba(255,255,255,0.08);

    box-shadow:
            0 0 40px rgba(0,68,255,0.25);

    z-index: 2;
}

.login-logo{
    font-size: 28px;
    font-weight: 800;

    color: #fff;

    margin-bottom: 40px;
}

.login-box h1{
    color: #fff;
    font-size: 34px;
    margin-bottom: 10px;
}

.login-box p{
    color: rgba(255,255,255,0.6);
    margin-bottom: 35px;
}

.input-box{
    margin-bottom: 20px;
}

.input-box input{
    width: 100%;
    height: 58px;

    border: none;
    outline: none;

    padding: 0 20px;

    border-radius: 16px;

    background: rgba(255,255,255,0.05);

    color: #fff;

    font-size: 16px;
}

.input-box input::placeholder{
    color: rgba(255,255,255,0.4);
}

.login-btn{
    width: 100%;
    height: 58px;

    border: none;

    border-radius: 16px;

    background: linear-gradient(
            90deg,
            #2458ff,
            #3a7bff
    );

    color: #fff;

    font-size: 17px;
    font-weight: 700;

    cursor: pointer;

    transition: 0.3s;
}

.login-btn:hover{
    transform: translateY(-3px);

    box-shadow:
            0 10px 25px rgba(36,88,255,0.4);
}

@media(max-width:768px){

    .login-box{
        width: 92%;
        padding: 35px 25px;
    }

    .login-box h1{
        font-size: 28px;
    }

}



/* ==============================
   FIX MOBILE HEADER + BURGER
   ============================== */

.mobile-header-actions,
.mobile-menu{
    display: none;
}

@media (max-width: 900px){

    .site-header{
        position: relative;
        z-index: 1000;
        background: #ffffff;
        padding: 21px 46px;
        box-shadow: 0 8px 24px rgba(7, 23, 57, 0.06);
    }

    .header-inner{
        width: 100%;
        gap: 10px;
    }

    .logo{
        font-size: 17px;
        flex-shrink: 0;
        transform: translateY(17px);
    }

    .logo small{
        font-size: 7px;
        letter-spacing: 4px;
    }

    .nav,
    .header-actions{
        display: none !important;
    }

    .mobile-header-actions{
        margin-left: auto;
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .mobile-cabinet-link{
        display: inline-flex;
        align-items: center;
        justify-content: center;
        height: 38px;
        padding: 0 12px;
        border-radius: 12px;
        background: #071739;
        color: #ffffff;
        text-decoration: none;
        font-size: 12px;
        font-weight: 900;
        white-space: nowrap;
        box-shadow: 0 8px 18px rgba(7, 23, 57, .18);
    }

    .mobile-burger{
        width: 42px;
        height: 42px;
        border: none;
        border-radius: 13px;
        background: #ff4b1f;
        display: inline-flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 5px;
        cursor: pointer;
        box-shadow: 0 10px 22px rgba(255, 75, 31, .24);
    }

    .mobile-burger span{
        width: 18px;
        height: 2px;
        border-radius: 10px;
        background: #ffffff;
        transition: .25s ease;
    }

    .mobile-burger.active span:nth-child(1){
        transform: translateY(7px) rotate(45deg);
    }

    .mobile-burger.active span:nth-child(2){
        opacity: 0;
    }

    .mobile-burger.active span:nth-child(3){
        transform: translateY(-7px) rotate(-45deg);
    }

    .mobile-menu{
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        z-index: 999;
        display: block;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
        transition: .25s ease;
        padding: 0 14px 14px;
        pointer-events: none;
    }

    .mobile-menu.active{
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
        pointer-events: auto;
    }

    .mobile-menu-panel{
        border-radius: 22px;
        background: rgba(255,255,255,.98);
        border: 1px solid rgba(7, 23, 57, .08);
        box-shadow: 0 24px 60px rgba(7, 23, 57, .20);
        padding: 14px;
        display: grid;
        gap: 8px;
    }

    .mobile-menu-panel > a:not(.mobile-whatsapp-btn){
        min-height: 46px;
        display: flex;
        align-items: center;
        padding: 0 14px;
        border-radius: 14px;
        background: #f5f7fb;
        color: #071739;
        text-decoration: none;
        font-size: 14px;
        font-weight: 900;
    }

    .mobile-menu-socials{
        display: flex;
        gap: 8px;
        padding: 6px 0;
    }

    .mobile-menu-socials a{
        width: 42px;
        height: 42px;
        border-radius: 13px;
        background: #f5f7fb;
        color: #071739;
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 17px;
    }

    .mobile-whatsapp-btn{
        width: 100%;
        height: 50px;
        padding: 0 18px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 15px;
        margin-top: 4px;
    }
}

@media (max-width: 380px){
    .mobile-cabinet-link{
        padding: 0 9px;
        font-size: 11px;
    }

    .logo{
        font-size: 20px;
    }
}.cabinet-link{
     position: relative;

     display: inline-flex;
     align-items: center;
     justify-content: center;

     height: 54px;
     padding: 0 26px;

     border-radius: 16px;

     background:
             linear-gradient(
                     135deg,
                     #071739 0%,
                     #0d1f52 100%
             );

     color: #ffffff;

     text-decoration: none;

     font-size: 14px;
     font-weight: 800;

     letter-spacing: 0.2px;

     box-shadow:
             0 10px 30px rgba(7,23,57,0.18);

     transition: 0.25s ease;

     overflow: hidden;
 }

.cabinet-link::before{
    content:"";

    position:absolute;
    inset:0;

    background:
            linear-gradient(
                    120deg,
                    transparent,
                    rgba(255,255,255,0.12),
                    transparent
            );

    transform:translateX(-120%);
    transition:0.5s;
}

.cabinet-link:hover{
    transform: translateY(-2px);

    box-shadow:
            0 16px 35px rgba(7,23,57,0.25);
}

.cabinet-link:hover::before{
    transform:translateX(120%);
}


/* =========================
   AUTH TABS + CABINET FINAL
   Added safely for dashboard.html and cabinet.html
========================= */
.auth-switch{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    margin:0 0 24px;
    padding:6px;
    border-radius:18px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
}
.auth-tab{
    height:48px;
    border:0;
    border-radius:14px;
    background:transparent;
    color:rgba(255,255,255,.62);
    font-size:14px;
    font-weight:900;
    cursor:pointer;
    transition:.25s ease;
}
.auth-tab.active{
    background:linear-gradient(135deg,#ff4b1f,#ff1f12);
    color:#fff;
    box-shadow:0 14px 30px rgba(255,75,31,.26);
}
.auth-form{
    display:none;
}
.auth-form.active{
    display:grid;
    gap:18px;
}
.cabinet-register-form label,
.cabinet-login-form label{
    display:grid;
    gap:9px;
    color:#e8edf8;
    font-size:14px;
    font-weight:800;
}
.auth-mode-note{
    margin-top:18px;
    color:#93a0bb;
    font-size:13px;
    line-height:1.45;
    text-align:center;
}
.cabinet-app-body{
    min-height:100vh;
    background:#050816;
    color:#fff;
    font-family:Arial,sans-serif;
}
.cabinet-app{
    min-height:100vh;
    display:grid;
    grid-template-columns:280px 1fr;
    background:
        radial-gradient(circle at 20% 0%,rgba(36,88,255,.35),transparent 30%),
        radial-gradient(circle at 100% 20%,rgba(255,75,31,.16),transparent 28%),
        linear-gradient(135deg,#020817 0%,#071739 55%,#020817 100%);
}
.cabinet-sidebar{
    padding:28px;
    border-right:1px solid rgba(255,255,255,.08);
    background:rgba(6,12,31,.56);
    backdrop-filter:blur(16px);
}
.cabinet-brand{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:34px;
}
.cabinet-brand-icon{
    width:48px;
    height:48px;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#ff4b1f,#ff1f12);
    color:#fff;
    font-size:24px;
    font-weight:900;
}
.cabinet-brand strong{
    display:block;
    font-size:22px;
    letter-spacing:-.7px;
}
.cabinet-brand span{
    color:#ff4b1f;
}
.cabinet-brand small{
    display:block;
    margin-top:3px;
    color:#8d9bb8;
    font-size:10px;
    letter-spacing:3px;
    font-weight:900;
}
.cabinet-nav{
    display:grid;
    gap:10px;
}
.cabinet-nav a,
.cabinet-nav button{
    min-height:48px;
    padding:0 16px;
    border-radius:15px;
    border:0;
    display:flex;
    align-items:center;
    gap:12px;
    background:transparent;
    color:#bac5db;
    text-decoration:none;
    font-size:14px;
    font-weight:900;
    cursor:pointer;
    transition:.2s ease;
    text-align:left;
}
.cabinet-nav a.active,
.cabinet-nav a:hover,
.cabinet-nav button:hover{
    background:rgba(255,255,255,.08);
    color:#fff;
}
.cabinet-nav i{
    color:#ff4b1f;
    width:18px;
}
.cabinet-main{
    padding:34px;
}
.cabinet-topbar{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
    margin-bottom:28px;
}
.cabinet-kicker{
    color:#ff4b1f;
    font-size:13px;
    font-weight:900;
    margin-bottom:10px;
}
.cabinet-topbar h1{
    font-size:42px;
    line-height:1.05;
    letter-spacing:-1.4px;
    margin-bottom:8px;
}
.cabinet-topbar p{
    color:#b9c3d4;
    font-size:15px;
}
.cabinet-user-card{
    min-width:260px;
    padding:18px;
    border-radius:22px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.1);
}
.cabinet-user-card small{
    display:block;
    color:#8d9bb8;
    margin-bottom:7px;
}
.cabinet-user-card strong{
    font-size:14px;
    word-break:break-word;
}
.cabinet-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
    margin-bottom:22px;
}
.cabinet-card{
    padding:24px;
    min-height:160px;
    border-radius:24px;
    background:rgba(255,255,255,.075);
    border:1px solid rgba(255,255,255,.1);
    box-shadow:0 18px 55px rgba(0,0,0,.18);
}
.cabinet-card-icon{
    width:48px;
    height:48px;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,75,31,.12);
    color:#ff4b1f;
    font-size:21px;
    margin-bottom:20px;
}
.cabinet-card h3{
    font-size:20px;
    margin-bottom:8px;
}
.cabinet-card p{
    color:#bac5db;
    font-size:14px;
    line-height:1.5;
}
.cabinet-panel{
    padding:26px;
    border-radius:26px;
    background:rgba(255,255,255,.075);
    border:1px solid rgba(255,255,255,.1);
}
.cabinet-panel h2{
    font-size:26px;
    margin-bottom:12px;
}
.cabinet-panel p{
    color:#bac5db;
    line-height:1.6;
}

/* moved cabinet/mobile rules to mobile-app.css */


/* moved cabinet/mobile rules to mobile-app.css */
/* ADMIN CRM */

.admin-body {
    min-height: 100vh;
    background: #f5f7fb;
    color: #071739;
    font-family: Arial, sans-serif;
}

.admin-app {
    display: grid;
    grid-template-columns: 280px 1fr;
    min-height: 100vh;
}

.admin-sidebar {
    background: #061326;
    color: #ffffff;
    padding: 28px;
}

.admin-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 36px;
}

.admin-brand-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: #ff4b1f;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 24px;
}

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

.admin-brand span {
    color: #ff4b1f;
}

.admin-brand small {
    display: block;
    margin-top: 4px;
    color: #8d9bb8;
    font-size: 10px;
    letter-spacing: 3px;
}

.admin-nav {
    display: grid;
    gap: 10px;
}

.admin-nav a,
.admin-nav button {
    width: 100%;
    padding: 15px 16px;
    border: none;
    border-radius: 14px;
    background: transparent;
    color: #b9c3d4;
    text-decoration: none;
    font-size: 14px;
    font-weight: 800;
    text-align: left;
    cursor: pointer;
}

.admin-nav a i,
.admin-nav button i {
    margin-right: 10px;
}

.admin-nav a.active,
.admin-nav a:hover,
.admin-nav button:hover {
    background: rgba(255,255,255,0.08);
    color: #ffffff;
}

.admin-main {
    padding: 34px;
}

.admin-topbar {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 28px;
}

.admin-topbar span {
    color: #ff4b1f;
    font-size: 13px;
    font-weight: 900;
}

.admin-topbar h1 {
    margin-top: 8px;
    font-size: 42px;
    letter-spacing: -1px;
}

.admin-topbar p {
    margin-top: 10px;
    color: #7b86a0;
}

.admin-user-box {
    min-width: 260px;
    padding: 20px;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 16px 35px rgba(7,17,40,0.06);
}

.admin-user-box small {
    display: block;
    color: #7b86a0;
    margin-bottom: 8px;
}

.admin-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 28px;
}

.admin-stat-card {
    padding: 24px;
    border-radius: 22px;
    background: #ffffff;
    box-shadow: 0 16px 35px rgba(7,17,40,0.06);
}

.admin-stat-card span {
    color: #7b86a0;
    font-size: 13px;
    font-weight: 800;
}

.admin-stat-card strong {
    display: block;
    margin: 12px 0;
    font-size: 38px;
    color: #071739;
}

.admin-stat-card p {
    color: #7b86a0;
    font-size: 13px;
}

.admin-panel {
    background: #ffffff;
    border-radius: 26px;
    padding: 26px;
    box-shadow: 0 16px 35px rgba(7,17,40,0.06);
}

.admin-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 24px;
}

.admin-panel-head h2 {
    font-size: 28px;
}

.admin-panel-head p {
    margin-top: 8px;
    color: #7b86a0;
}

.admin-add-btn {
    height: 48px;
    padding: 0 20px;
    border: none;
    border-radius: 14px;
    background: #ff4b1f;
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
    cursor: pointer;
}

.admin-table-wrap {
    overflow-x: auto;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-table th {
    text-align: left;
    padding: 16px;
    color: #7b86a0;
    font-size: 13px;
    border-bottom: 1px solid #edf0f6;
}

.admin-table td {
    padding: 16px;
    color: #071739;
    font-size: 14px;
    border-bottom: 1px solid #edf0f6;
}

.status-badge {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 30px;
    font-size: 12px;
    font-weight: 900;
}

.status-new {
    background: #fff0e9;
    color: #ff4b1f;
}

@media (max-width: 900px) {
    .admin-app {
        grid-template-columns: 1fr;
    }
    .mobile-header-actions{
        margin-top: -22px;
    }

    .admin-sidebar {
        position: relative;
    }

    .admin-main {
        padding: 22px;
    }

    .admin-topbar {
        flex-direction: column;
    }

    .admin-stats {
        grid-template-columns: 1fr;
    }

    .admin-panel-head {
        flex-direction: column;
    }
}.admin-access-btn {
     display: inline-flex;
     align-items: center;
     gap: 9px;
     margin-top: 16px;
     padding: 14px 20px;
     border-radius: 14px;
     background: #ff4b1f;
     color: #ffffff;
     text-decoration: none;
     font-size: 14px;
     font-weight: 900;
     box-shadow: 0 14px 30px rgba(255, 75, 31, 0.28);
 }

.admin-access-btn:hover {
    transform: translateY(-2px);
}.status-work {
     background: #e9efff;
     color: #2458ff;
 }

.status-done {
    background: #e9fff3;
    color: #10a85a;
}.lead-status-select {
     min-width: 130px;
     height: 38px;
     padding: 0 12px;
     border: 1px solid #dfe4ee;
     border-radius: 12px;
     background: #ffffff;
     color: #071739;
     font-size: 13px;
     font-weight: 900;
     outline: none;
     cursor: pointer;
 }.lead-status-select.status-new {
      background: #fff0e9;
      color: #ff4b1f;
      border-color: #ffd2c4;
  }

.lead-status-select.status-work {
    background: #e9efff;
    color: #2458ff;
    border-color: #cbd8ff;
}

.lead-status-select.status-done {
    background: #e9fff3;
    color: #10a85a;
    border-color: #bff0d3;
}

.lead-trash-btn {
    height: 38px;
    padding: 0 14px;
    border: none;
    border-radius: 12px;
    background: #fff0f0;
    color: #d71920;
    font-size: 13px;
    font-weight: 900;
    cursor: pointer;
}

.lead-trash-btn:hover {
    background: #d71920;
    color: #ffffff;
}.account-role-select {
     min-width: 150px;
     height: 38px;
     padding: 0 12px;
     border: 1px solid #dfe4ee;
     border-radius: 12px;
     background: #ffffff;
     color: #071739;
     font-size: 13px;
     font-weight: 900;
     outline: none;
     cursor: pointer;
 }

.account-role-select.role-client {
    background: #f7f9fd;
    color: #071739;
}

.account-role-select.role-manager {
    background: #e9efff;
    color: #2458ff;
}

.account-role-select.role-admin {
    background: #fff0e9;
    color: #ff4b1f;
}.no-trash-access {
     color: #8c98ad;
     font-size: 13px;
     font-weight: 800;
 }/* LEAD DETAILS PANEL */

.lead-details-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 20, 40, 0.55);
    backdrop-filter: blur(6px);

    opacity: 0;
    visibility: hidden;

    transition: 0.3s ease;

    z-index: 9998;
}

.lead-details-overlay.active {
    opacity: 1;
    visibility: visible;
}

.lead-details-panel {
    position: fixed;
    top: 0;
    right: 0;

    width: 430px;
    max-width: 100%;

    height: 100vh;

    background: #ffffff;

    border-left: 1px solid #edf0f6;

    padding: 32px;

    overflow-y: auto;

    transform: translateX(100%);

    transition: 0.35s ease;

    z-index: 9999;
}

.lead-details-panel.active {
    transform: translateX(0);
}

.lead-details-close {
    position: absolute;
    top: 20px;
    right: 20px;

    width: 42px;
    height: 42px;

    border: none;
    border-radius: 14px;

    background: #f4f7fb;

    cursor: pointer;

    font-size: 18px;
}

.lead-details-head span {
    color: #2458ff;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.lead-details-head h2 {
    margin-top: 8px;
    font-size: 28px;
    color: #071739;
}

.lead-details-head p {
    margin-top: 6px;
    color: #8c98ad;
    font-size: 14px;
}

.lead-details-block {
    margin-top: 34px;
}

.lead-details-block h3 {
    font-size: 16px;
    color: #071739;
    margin-bottom: 18px;
}

.lead-detail-item {
    display: flex;
    align-items: center;
    gap: 14px;

    margin-bottom: 18px;
}

.lead-detail-item i {
    width: 42px;
    height: 42px;

    border-radius: 12px;

    background: #f4f7fb;

    display: flex;
    align-items: center;
    justify-content: center;

    color: #2458ff;
}

.lead-detail-item small {
    display: block;
    color: #8c98ad;
    font-size: 12px;
    margin-bottom: 4px;
}

.lead-detail-item strong {
    color: #071739;
    font-size: 15px;
}

.lead-interest-box {
    background: #f7f9fd;
    border-radius: 18px;
    padding: 18px;
    color: #071739;
    line-height: 1.7;
}

.lead-details-actions {
    margin-top: 38px;

    display: flex;
    flex-direction: column;
    gap: 14px;
}

.lead-whatsapp-btn {
    height: 52px;

    border-radius: 16px;

    background: #25D366;

    color: #fff;

    font-weight: 800;

    text-decoration: none;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.lead-details-actions .lead-trash-btn {
    height: 52px;

    border: none;
    border-radius: 16px;

    background: #ffede8;
    color: #ff4b1f;

    font-weight: 800;

    cursor: pointer;
}

.lead-row {
    cursor: pointer;
    transition: 0.2s ease;
}

.lead-row:hover {
    background: #f7f9fd;
}.admin-panel-head {
     gap: 18px;
 }

.admin-search-box {
    height: 54px;
    min-width: 360px;
    padding: 0 18px;
    border-radius: 18px;
    background: #f7f9fd;
    border: 1px solid #e1e6f0;

    display: flex;
    align-items: center;
    gap: 12px;
}

.admin-search-box i {
    color: #8c98ad;
}

.admin-search-box input {
    width: 100%;
    border: none;
    outline: none;
    background: transparent;
    color: #071739;
    font-size: 14px;
    font-weight: 700;
}

.admin-search-box input::placeholder {
    color: #8c98ad;
}

@media (max-width: 900px) {
    .admin-search-box {
        min-width: 100%;
        width: 100%;
    }
}/* CREATE LEAD MODAL */

.create-lead-overlay {
    position: fixed;
    inset: 0;

    background: rgba(15, 20, 40, 0.55);
    backdrop-filter: blur(6px);

    opacity: 0;
    visibility: hidden;

    transition: 0.3s ease;

    z-index: 10000;
}

.create-lead-overlay.active {
    opacity: 1;
    visibility: visible;
}

.create-lead-modal {
    position: fixed;

    top: 50%;
    left: 50%;

    transform: translate(-50%, -50%) scale(0.96);

    width: 1100px;
    max-width: calc(100% - 40px);

    max-height: 90vh;

    overflow-y: auto;

    background: #ffffff;

    border-radius: 34px;

    padding: 38px;

    box-shadow:
            0 40px 100px rgba(0,0,0,0.18);

    opacity: 0;
    visibility: hidden;

    transition: 0.28s ease;

    z-index: 10001;
}

.create-lead-modal.active {
    opacity: 1;
    visibility: visible;

    transform: translate(-50%, -50%) scale(1);
}

.create-lead-close {
    position: absolute;

    top: 20px;
    right: 20px;

    width: 44px;
    height: 44px;

    border: none;
    border-radius: 14px;

    background: #f4f7fb;

    cursor: pointer;

    font-size: 18px;
}

.create-lead-head span {
    color: #2458ff;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.create-lead-head h2 {
    margin-top: 8px;

    font-size: 30px;
    color: #071739;
}

.create-lead-head p {
    margin-top: 8px;

    color: #8c98ad;
}

.create-lead-form {
    margin-top: 30px;

    display: grid;
    grid-template-columns: 1fr 1fr;

    gap: 22px;
}

.create-input-group label {
    display: block;

    margin-bottom: 10px;

    color: #071739;
    font-size: 14px;
    font-weight: 800;
}

.create-input-group input {
    width: 100%;
    height: 56px;

    padding: 0 18px;

    border-radius: 18px;
    border: 1px solid #e1e6f0;

    background: #f7f9fd;

    outline: none;

    font-size: 14px;
    font-weight: 700;

    color: #071739;
}

.create-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 12px;

    background: #f7f9fd;

    padding: 18px;

    border-radius: 20px;
}

.create-checkboxes label {
    display: flex;
    align-items: center;
    gap: 10px;

    margin: 0;

    font-size: 14px;
    font-weight: 700;

    color: #071739;
}

.create-checkboxes input {
    width: 18px;
    height: 18px;
}

.create-lead-submit {
    height: 58px;

    border: none;
    border-radius: 18px;

    background: #ff2f0a;
    color: #ffffff;

    font-size: 15px;
    font-weight: 800;

    cursor: pointer;

    transition: 0.25s ease;
}

.create-lead-submit:hover {
    transform: translateY(-2px);

    box-shadow: 0 16px 40px rgba(255, 47, 10, 0.25);
}



/* CRM MANAGER + COMMENT FIELDS */

.lead-detail-input,
.lead-detail-textarea,
.create-lead-textarea {
    width: 100%;
    padding: 16px 18px;
    border: 1px solid #e1e6f0;
    border-radius: 18px;
    background: #f7f9fd;
    color: #071739;
    font-size: 14px;
    font-weight: 700;
    outline: none;
}

.lead-detail-input {
    height: 54px;
}

.lead-detail-textarea,
.create-lead-textarea {
    min-height: 110px;
    resize: vertical;
    line-height: 1.5;
    font-family: Arial, sans-serif;
}

.lead-detail-input:focus,
.lead-detail-textarea:focus,
.create-lead-textarea:focus {
    border-color: #2458ff;
    box-shadow: 0 0 0 4px rgba(36, 88, 255, 0.08);
}

.lead-save-note-btn {
    width: 100%;
    height: 52px;
    margin-top: 18px;
    border: none;
    border-radius: 16px;
    background: #071739;
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
    cursor: pointer;
    transition: 0.25s ease;
}

.lead-save-note-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 35px rgba(7, 23, 57, 0.18);
}

.crm-empty-state {
    padding: 36px 20px;
    text-align: center;
    color: #8c98ad;
}

.crm-empty-state strong {
    display: block;
    margin-bottom: 8px;
    color: #071739;
    font-size: 17px;
}

.crm-empty-state span {
    font-size: 14px;
}


/* ==============================
   CRM FULL UPDATE: FILTERS / EXPORT / CLIENT CABINET / TRASH
   ============================== */

.crm-filter-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.crm-filter-btn,
.admin-export-btn {
    height: 42px;
    padding: 0 14px;
    border: 1px solid #e1e6f0;
    border-radius: 14px;
    background: #ffffff;
    color: #071739;
    font-size: 13px;
    font-weight: 900;
    cursor: pointer;
    transition: 0.2s ease;
}

.crm-filter-btn.active,
.crm-filter-btn:hover {
    background: #071739;
    color: #ffffff;
    border-color: #071739;
}

.admin-export-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #f7f9fd;
}

.admin-export-btn:hover {
    background: #e9efff;
    color: #2458ff;
}

.lead-client-cell {
    display: flex;
    align-items: center;
    gap: 12px;
}

.lead-client-cell strong {
    display: block;
    color: #071739;
    font-size: 14px;
}

.lead-client-cell small {
    display: block;
    color: #8c98ad;
    font-size: 12px;
    margin-top: 3px;
}

.lead-avatar {
    min-width: 38px;
    width: 38px;
    height: 38px;
    border-radius: 14px;
    background: linear-gradient(135deg, #071739, #2458ff);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
}

.lead-activity-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.lead-activity-list > span {
    color: #8c98ad;
    font-size: 14px;
}

.lead-activity-item {
    padding: 12px 14px;
    border-radius: 14px;
    background: #f7f9fd;
    border: 1px solid #e1e6f0;
}

.lead-activity-item strong {
    display: block;
    color: #071739;
    font-size: 13px;
    margin-bottom: 5px;
}

.lead-activity-item small {
    color: #8c98ad;
    font-size: 12px;
}

.lead-restore-btn {
    height: 38px;
    padding: 0 14px;
    border: none;
    border-radius: 12px;
    background: #e9fff3;
    color: #10a85a;
    font-size: 13px;
    font-weight: 900;
    cursor: pointer;
}

.lead-restore-btn:hover {
    background: #10a85a;
    color: #ffffff;
}

.client-leads-list {
    margin-top: 22px;
    display: grid;
    gap: 14px;
}

.client-lead-card {
    padding: 20px;
    border-radius: 20px;
    background: #ffffff;
    border: 1px solid #e1e6f0;
    box-shadow: 0 12px 28px rgba(7, 17, 40, 0.04);
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 18px;
}

.client-lead-card h3 {
    margin: 10px 0 8px;
    color: #071739;
    font-size: 18px;
}

.client-lead-card p {
    color: #66728a;
    line-height: 1.5;
    font-size: 14px;
}

.client-lead-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: #8c98ad;
    font-size: 13px;
}

.client-lead-status {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
}

.client-lead-status.status-new {
    background: #fff0e9;
    color: #ff4b1f;
}

.client-lead-status.status-work {
    background: #e9efff;
    color: #2458ff;
}

.client-lead-status.status-done {
    background: #e9fff3;
    color: #10a85a;
}

.cabinet-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.cabinet-new-lead-btn,
.cabinet-cancel-btn {
    min-height: 46px;
    padding: 0 18px;
    border: none;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 900;
    cursor: pointer;
}

.cabinet-new-lead-btn {
    background: #ff4b1f;
    color: #ffffff;
}

.cabinet-cancel-btn {
    background: #f4f7fb;
    color: #071739;
}

.client-lead-form {
    margin-top: 22px;
    display: grid;
    gap: 16px;
}

.client-lead-form label {
    display: grid;
    gap: 8px;
    color: #071739;
    font-size: 14px;
    font-weight: 800;
}

.client-lead-form input,
.client-lead-form textarea {
    width: 100%;
    border: 1px solid #e1e6f0;
    border-radius: 16px;
    background: #f7f9fd;
    color: #071739;
    outline: none;
    padding: 15px 16px;
    font-size: 14px;
    font-weight: 700;
}

.client-lead-form textarea {
    min-height: 110px;
    resize: vertical;
    font-family: Arial, sans-serif;
}

.client-form-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}


/* moved cabinet/mobile rules to mobile-app.css */
.client-new-lead-btn,
 #createClientLeadBtn {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     gap: 10px;

     min-height: 54px;
     padding: 0 24px;

     border: none;
     border-radius: 16px;

     background: linear-gradient(135deg, #ff4b1f, #ff1f12);
     color: #ffffff;

     font-size: 15px;
     font-weight: 900;
     text-decoration: none;

     cursor: pointer;

     box-shadow: 0 18px 36px rgba(255, 75, 31, 0.28);
     transition: 0.25s ease;
 }

.client-new-lead-btn:hover,
#createClientLeadBtn:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 46px rgba(255, 75, 31, 0.38);
}

.cabinet-panel {
    overflow: hidden;
}

.cabinet-empty-state {
    margin-top: 28px;
    padding: 34px;

    border-radius: 24px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);

    text-align: center;
}

.cabinet-empty-state strong {
    display: block;
    color: #ffffff;
    font-size: 22px;
    margin-bottom: 10px;
}

.cabinet-empty-state p {
    color: #c7d0df;
    font-size: 15px;
}.admin-panel-head {
     display: grid;
     grid-template-columns: 1fr auto auto auto;
     align-items: center;
     gap: 18px;
 }

.admin-panel-head h2 {
    white-space: nowrap;
}

.admin-panel-head p {
    max-width: 360px;
}

.admin-search-box {
    min-width: 420px;
}

.admin-filters {
    display: flex;
    align-items: center;
    gap: 10px;
}

.admin-filter-btn {
    height: 46px;
    padding: 0 18px;
    border-radius: 14px;
    white-space: nowrap;
}

.admin-add-btn {
    min-width: 170px;
    white-space: nowrap;
}.create-input-full {
     grid-column: 1 / -1;
 }

.create-lead-submit {
    grid-column: 1 / -1;
}

@media (max-width: 900px) {

    .create-lead-modal {
        width: calc(100% - 20px);

        padding: 24px;

        border-radius: 24px;
    }

    .create-lead-form {
        grid-template-columns: 1fr;
    }
}


/* ==============================
   AD ANALYTICS PAGE
   ============================== */

.analytics-main {
    background:
            radial-gradient(circle at top right, rgba(104, 88, 255, 0.10), transparent 32%),
            #f5f7fb;
}

.analytics-hero {
    background:
            radial-gradient(circle at top right, rgba(124, 92, 255, 0.18), transparent 30%),
            linear-gradient(135deg, #ffffff, #f9fbff);
}

.analytics-note {
    margin-bottom: 24px;
    padding: 18px 22px;
    border-radius: 22px;
    background: #fff8ef;
    border: 1px solid rgba(255, 155, 42, 0.25);
    color: #071739;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    box-shadow: 0 16px 35px rgba(7, 17, 40, 0.04);
}

.analytics-note i {
    color: #ff8a1f;
    font-size: 20px;
    margin-top: 2px;
}

.analytics-note strong {
    display: block;
    margin-bottom: 4px;
    font-size: 14px;
}

.analytics-note span {
    color: #6d7891;
    font-size: 13px;
    line-height: 1.5;
}

.analytics-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 24px;
}

.analytics-card {
    min-height: 160px;
    padding: 26px;
    border-radius: 28px;
    background: #ffffff;
    border: 1px solid #edf0f6;
    box-shadow: 0 18px 45px rgba(7, 17, 40, 0.05);
}

.analytics-card-primary {
    background:
            radial-gradient(circle at top right, rgba(124, 92, 255, 0.20), transparent 35%),
            linear-gradient(135deg, #131b48, #071226);
    color: #ffffff;
    border: none;
}

.analytics-card span {
    display: block;
    color: #8c98ad;
    font-size: 13px;
    font-weight: 900;
    margin-bottom: 16px;
}

.analytics-card-primary span {
    color: rgba(255,255,255,0.65);
}

.analytics-card strong {
    display: block;
    color: #071739;
    font-size: 38px;
    line-height: 1;
    margin-bottom: 14px;
}

.analytics-card-primary strong {
    color: #ffffff;
}

.analytics-card p {
    color: #8c98ad;
    font-size: 13px;
    font-weight: 800;
}

.analytics-card-primary p {
    color: rgba(255,255,255,0.72);
}

.analytics-grid {
    display: grid;
    grid-template-columns: 1.45fr 1fr;
    gap: 24px;
}

.analytics-panel {
    min-height: 300px;
    padding: 28px;
    border-radius: 30px;
    background: #ffffff;
    border: 1px solid #edf0f6;
    box-shadow: 0 18px 45px rgba(7, 17, 40, 0.05);
}

.analytics-panel-large {
    grid-column: span 1;
}

.analytics-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 24px;
}

.analytics-panel-head h2 {
    color: #071739;
    font-size: 22px;
    line-height: 1.2;
    margin-bottom: 8px;
}

.analytics-panel-head p {
    color: #8c98ad;
    font-size: 13px;
    line-height: 1.5;
}

.analytics-badge {
    padding: 9px 14px;
    border-radius: 999px;
    background: #eef2ff;
    color: #6058ff;
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.analytics-badge.orange {
    background: #fff0e9;
    color: #ff4b1f;
}

.analytics-chart {
    height: 270px;
    padding: 18px 10px 0;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    align-items: end;
    gap: 18px;
}

.traffic-day {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
}

.traffic-bars {
    height: 180px;
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 7px;
}

.traffic-bar {
    width: 18px;
    min-height: 12px;
    border-radius: 999px 999px 8px 8px;
    display: block;
}

.traffic-bar-visits {
    background: linear-gradient(180deg, #6c63ff, #1f3bff);
    box-shadow: 0 12px 26px rgba(75, 87, 255, 0.25);
}

.traffic-bar-leads {
    background: linear-gradient(180deg, #ff8a55, #ff3b18);
    box-shadow: 0 12px 26px rgba(255, 75, 31, 0.22);
}

.traffic-day strong {
    color: #071739;
    font-size: 13px;
}

.traffic-day small {
    color: #8c98ad;
    font-size: 12px;
    font-weight: 900;
}

.analytics-source-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.source-item-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.source-item-top strong {
    color: #071739;
    font-size: 14px;
}

.source-item-top span {
    color: #8c98ad;
    font-size: 12px;
    font-weight: 900;
}

.source-progress {
    height: 10px;
    border-radius: 999px;
    background: #eef2f8;
    overflow: hidden;
}

.source-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #6c63ff, #ff4b1f);
}

.analytics-funnel {
    display: grid;
    gap: 14px;
}

.analytics-funnel div {
    padding: 20px;
    border-radius: 22px;
    background: #f7f9fd;
    border: 1px solid #edf0f6;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.analytics-funnel span {
    color: #68748c;
    font-size: 14px;
    font-weight: 900;
}

.analytics-funnel strong {
    color: #071739;
    font-size: 28px;
}

.analytics-table-wrap {
    overflow-x: auto;
}

.analytics-table {
    width: 100%;
    border-collapse: collapse;
}

.analytics-table th,
.analytics-table td {
    padding: 16px 14px;
    border-bottom: 1px solid #edf0f6;
    text-align: left;
    font-size: 13px;
    color: #5d6880;
    white-space: nowrap;
}

.analytics-table th {
    color: #8c98ad;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.analytics-table td strong {
    color: #071739;
}

.campaign-status {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    background: #edf8f1;
    color: #16a34a;
    font-size: 12px;
    font-weight: 900;
}

.analytics-empty {
    padding: 22px;
    border-radius: 18px;
    background: #f7f9fd;
    color: #8c98ad;
    font-size: 14px;
    font-weight: 800;
    text-align: center;
}

@media (max-width: 1200px) {
    .analytics-stats,
    .analytics-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 800px) {
    .analytics-stats,
    .analytics-grid {
        grid-template-columns: 1fr;
    }

    .analytics-chart {
        gap: 10px;
    }

    .traffic-bar {
        width: 13px;
    }
}


/* ==============================
   CLIENT CABINET PROFILE UPGRADE
   Добавлено аккуратно поверх старых стилей
   ============================== */

.cabinet-profile-hero {
    display: block;
    position: relative;
    padding: 0 0 26px;
    margin-bottom: 22px;
    border-bottom: 1px solid rgba(255,255,255,.08);
}

.cabinet-profile-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 28px;
}

.cabinet-edit-profile-btn {
    min-height: 48px;
    padding: 0 22px;
    border-radius: 15px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 900;
    cursor: pointer;
}

.cabinet-profile-content {
    display: flex;
    align-items: center;
    gap: 40px;
}

.cabinet-avatar-box {
    position: relative;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    padding: 8px;
    background: radial-gradient(circle at 50% 20%, rgba(255,75,31,.4), rgba(255,255,255,.08));
    box-shadow: 0 0 55px rgba(255,75,31,.16);
    flex: 0 0 auto;
}

.cabinet-avatar-box img,
.cabinet-avatar-placeholder {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    background: rgba(255,255,255,.08);
}

.cabinet-avatar-placeholder {
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.68);
    font-size: 54px;
}

.cabinet-avatar-upload {
    position: absolute;
    right: 6px;
    bottom: 10px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 0;
    background: linear-gradient(135deg,#ff4b1f,#ff1f12);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 15px 30px rgba(255,31,18,.35);
}

.cabinet-profile-info h2 {
    font-size: 34px;
    line-height: 1.05;
    letter-spacing: -1px;
    margin-bottom: 4px;
}

.cabinet-profile-info h3 {
    font-size: 24px;
    color: #ff4b1f;
    margin-bottom: 22px;
}

.cabinet-profile-meta {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: #dce5f4;
    margin-bottom: 18px;
}

.cabinet-profile-meta i {
    color: #ff4b1f;
    margin-top: 3px;
}

.cabinet-profile-meta small {
    display: block;
    color: #9faac0;
    margin-bottom: 4px;
}

.cabinet-profile-meta strong {
    color: #ffffff;
}

.cabinet-profile-user-card {
    max-width: 320px;
    min-width: 0;
    padding: 14px 16px;
    background: rgba(255,255,255,.045);
}

.cabinet-stats-grid {
    margin-top: 20px;
}

.cabinet-stat-card {
    min-height: 118px;
    display: flex;
    align-items: center;
    gap: 20px;
}

.cabinet-stat-card .cabinet-card-icon {
    margin-bottom: 0;
}

.cabinet-card-icon.purple {
    background: rgba(105,62,255,.18);
    color: #8c65ff;
}

.cabinet-card-icon.green {
    background: rgba(34,214,95,.16);
    color: #57e082;
}

.cabinet-card-icon.orange {
    background: rgba(255,150,32,.16);
    color: #ff9b24;
}

.cabinet-stat-card strong {
    display: block;
    color: #ffffff;
    font-size: 32px;
    line-height: 1;
    margin-bottom: 7px;
}

.cabinet-stat-card h3 {
    font-size: 16px;
    margin-bottom: 4px;
}

.cabinet-stat-card p {
    font-size: 13px;
}

.client-leads-table-wrap {
    margin-top: 22px;
    overflow-x: auto;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(7,12,35,.34);
}

.client-leads-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 780px;
}

.client-leads-table th,
.client-leads-table td {
    padding: 17px 16px;
    text-align: left;
    border-bottom: 1px solid rgba(255,255,255,.08);
    color: #dce5f4;
    font-size: 14px;
}

.client-leads-table th {
    color: #aeb9cc;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .6px;
}

.client-leads-table tr:last-child td {
    border-bottom: 0;
}

.client-leads-table .client-lead-status {
    color: #ffffff;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* PROFILE EDIT MODAL — added safely */
.profile-edit-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(3, 5, 20, 0.72);
    backdrop-filter: blur(12px);
}

.profile-edit-overlay.active {
    display: flex;
}

.profile-edit-modal {
    position: relative;
    width: min(620px, 100%);
    padding: 34px;
    border-radius: 28px;
    color: #ffffff;
    background:
        radial-gradient(circle at top right, rgba(255, 44, 24, 0.24), transparent 32%),
        linear-gradient(145deg, rgba(34, 23, 74, 0.98), rgba(10, 7, 34, 0.98));
    border: 1px solid rgba(255,255,255,0.14);
    box-shadow: 0 30px 90px rgba(0,0,0,0.45);
}

.profile-edit-close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 14px;
    color: #ffffff;
    background: rgba(255,255,255,0.09);
    cursor: pointer;
}

.profile-edit-head span {
    color: #ff2b1c;
    font-size: 14px;
    font-weight: 900;
}

.profile-edit-head h2 {
    margin: 10px 0 8px;
    font-size: 34px;
    line-height: 1.1;
}

.profile-edit-head p {
    color: #c7c2e8;
    line-height: 1.5;
    margin-bottom: 24px;
}

.profile-edit-avatar-row {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 24px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
}

.profile-edit-avatar-preview {
    position: relative;
    width: 96px;
    height: 96px;
    flex: 0 0 96px;
    border-radius: 50%;
    overflow: hidden;
    background: rgba(255,255,255,0.08);
    border: 4px solid rgba(255, 43, 28, 0.28);
    display: flex;
    align-items: center;
    justify-content: center;
}

.profile-edit-avatar-preview img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 2;
}

.profile-edit-avatar-preview i {
    color: rgba(255,255,255,0.7);
    font-size: 34px;
}

.profile-upload-btn,
.profile-save-btn,
.profile-cancel-btn {
    border: 0;
    cursor: pointer;
    font-weight: 900;
}

.profile-upload-btn {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 14px;
    color: #ffffff;
    background: linear-gradient(90deg, #ff2b1c, #ff4b1f);
    box-shadow: 0 12px 28px rgba(255, 43, 28, 0.28);
}

.profile-edit-avatar-row small {
    display: block;
    margin-top: 9px;
    color: #aaa5d5;
    line-height: 1.4;
}

.profile-edit-form {
    display: grid;
    gap: 16px;
}

.profile-edit-form label {
    display: grid;
    gap: 8px;
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
}

.profile-edit-form input {
    width: 100%;
    height: 56px;
    padding: 0 16px;
    border: 1px solid rgba(255,255,255,0.12);
    outline: 0;
    border-radius: 16px;
    background: rgba(255,255,255,0.075);
    color: #ffffff;
    font-size: 15px;
}

.profile-edit-form input:focus {
    border-color: rgba(255, 75, 31, 0.85);
    box-shadow: 0 0 0 4px rgba(255, 75, 31, 0.12);
}

.profile-edit-actions {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}

.profile-save-btn,
.profile-cancel-btn {
    min-height: 54px;
    padding: 0 22px;
    border-radius: 16px;
}

.profile-save-btn {
    flex: 1;
    color: #ffffff;
    background: linear-gradient(90deg, #ff2b1c, #ff4b1f);
    box-shadow: 0 14px 32px rgba(255, 43, 28, 0.3);
}

.profile-cancel-btn {
    color: #ffffff;
    background: rgba(255,255,255,0.09);
}

@media (max-width: 620px) {
    .profile-edit-modal {
        padding: 24px;
        border-radius: 22px;
    }

    .profile-edit-avatar-row,
    .profile-edit-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .profile-edit-avatar-preview {
        margin: 0 auto;
    }
}


/* CABINET AVATAR SIZE FIX — added safely, only overrides profile image */
.cabinet-profile-hero {
    padding-top: 38px;
}

.cabinet-profile-content {
    align-items: flex-start;
}

.cabinet-avatar-box {
    width: 210px;
    height: 230px;
    border-radius: 26px;
    padding: 9px;
    margin-top: -10px;
}

.cabinet-avatar-box img,
.cabinet-avatar-placeholder {
    border-radius: 20px;
}

.cabinet-avatar-upload {
    right: 10px;
    bottom: 12px;
    width: 48px;
    height: 48px;
}

.profile-edit-avatar-preview {
    width: 128px;
    height: 142px;
    flex: 0 0 128px;
    border-radius: 22px;
}

.profile-edit-avatar-preview img {
    border-radius: 18px;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* =========================================================
   LÖWEN FDL — REALTIME CHAT MODULE
   Добавлено аккуратно в конец файла, старые стили не трогаем
========================================================= */

.chat-unread-badge {
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    margin-left: auto;
    border-radius: 999px;
    background: #ff2b18;
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 20px rgba(255, 43, 24, 0.35);
}

.cabinet-chat-nav-link,
#adminChatMenuLink {
    position: relative;
}

.client-chat-panel,
.admin-chat-panel {
    overflow: hidden;
}

.client-chat-head {
    align-items: center;
}

.chat-consultant-status,
.admin-chat-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    border-radius: 18px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
}

.chat-consultant-status small {
    display: block;
    color: #aeb8d6;
    font-size: 11px;
    font-weight: 700;
}

.chat-online-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #24d366;
    box-shadow: 0 0 0 6px rgba(36, 211, 102, 0.12);
}

.client-chat-box {
    margin-top: 22px;
    border-radius: 24px;
    overflow: hidden;
    background: rgba(5, 8, 22, 0.28);
    border: 1px solid rgba(255,255,255,0.08);
}

.chat-messages {
    height: 420px;
    padding: 22px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 14px;
    scroll-behavior: smooth;
}

.chat-empty-state {
    min-height: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
    color: #b9c4df;
}

.chat-empty-state i {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ff3b18;
    background: rgba(255, 59, 24, 0.12);
    font-size: 22px;
    margin-bottom: 8px;
}

.chat-empty-state strong {
    color: #ffffff;
    font-size: 18px;
}

.chat-empty-state span {
    color: #aeb8d6;
    font-size: 14px;
}

.chat-empty-state.compact {
    min-height: 140px;
    padding: 20px;
}

.chat-message {
    display: flex;
    width: 100%;
}

.chat-message.client,
.chat-message.admin.is-own {
    justify-content: flex-end;
}

.chat-message.admin,
.chat-message.client.is-other {
    justify-content: flex-start;
}

.chat-bubble {
    max-width: min(76%, 620px);
    padding: 14px 16px;
    border-radius: 20px;
    background: rgba(255,255,255,0.09);
    border: 1px solid rgba(255,255,255,0.1);
    color: #ffffff;
    box-shadow: 0 12px 30px rgba(0,0,0,0.16);
}

.chat-message.client .chat-bubble,
.chat-message.admin.is-own .chat-bubble {
    background: linear-gradient(135deg, #ff4b1f, #ff1f12);
    border-color: rgba(255,255,255,0.08);
}

.chat-message.admin .chat-bubble,
.chat-message.client.is-other .chat-bubble {
    background: rgba(255,255,255,0.1);
}

.chat-bubble p {
    margin: 0 0 7px;
    color: inherit;
    font-size: 15px;
    line-height: 1.45;
    white-space: pre-wrap;
    word-break: break-word;
}

.chat-bubble small {
    display: block;
    color: rgba(255,255,255,0.68);
    font-size: 11px;
    text-align: right;
}

.chat-form {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: rgba(255,255,255,0.05);
    border-top: 1px solid rgba(255,255,255,0.08);
}

.chat-form input {
    flex: 1;
    height: 54px;
    border: 1px solid rgba(255,255,255,0.12);
    outline: none;
    border-radius: 18px;
    padding: 0 18px;
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    font-size: 15px;
}

.chat-form input::placeholder {
    color: rgba(255,255,255,0.45);
}

.chat-form button {
    width: 54px;
    height: 54px;
    border: 0;
    border-radius: 18px;
    background: linear-gradient(135deg, #ff4b1f, #ff1f12);
    color: #ffffff;
    cursor: pointer;
    font-size: 18px;
    box-shadow: 0 12px 26px rgba(255, 43, 24, 0.34);
}

.chat-form button:disabled,
.chat-form input:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.admin-chat-panel {
    margin-bottom: 26px;
    padding: 28px;
    border-radius: 28px;
    background: linear-gradient(145deg, rgba(255,255,255,0.075), rgba(255,255,255,0.025));
    border: 1px solid rgba(255,255,255,0.1);
    box-shadow: 0 24px 60px rgba(0,0,0,0.18);
}

.admin-chat-panel-head {
    margin-bottom: 20px;
}

.admin-chat-layout {
    display: grid;
    grid-template-columns: 360px 1fr;
    min-height: 620px;
    border-radius: 24px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.09);
    background: rgba(3, 8, 22, 0.32);
}

.admin-chat-list {
    border-right: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.035);
    overflow-y: auto;
}

.admin-chat-item {
    width: 100%;
    border: 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    background: transparent;
    padding: 18px;
    display: grid;
    grid-template-columns: 48px 1fr auto;
    gap: 12px;
    align-items: center;
    text-align: left;
    color: #ffffff;
    cursor: pointer;
}

.admin-chat-item:hover,
.admin-chat-item.active {
    background: linear-gradient(90deg, rgba(255,75,31,0.16), rgba(255,75,31,0.03));
}

.admin-chat-avatar {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,75,31,0.16);
    color: #ff4b1f;
    font-size: 18px;
    font-weight: 900;
}

.admin-chat-meta strong {
    display: block;
    color: #ffffff;
    font-size: 14px;
    margin-bottom: 5px;
}

.admin-chat-meta span {
    display: block;
    max-width: 210px;
    color: #aeb8d6;
    font-size: 12px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-chat-side {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 7px;
}

.admin-chat-time {
    color: #7f8bad;
    font-size: 11px;
}

.admin-chat-unread {
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: #ff2b18;
    color: #fff;
    font-size: 11px;
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.admin-chat-window {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.admin-chat-window-head {
    min-height: 96px;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.admin-chat-window-head span {
    color: #ff4b1f;
    font-size: 12px;
    font-weight: 900;
}

.admin-chat-window-head h3 {
    color: #ffffff;
    font-size: 22px;
    margin: 4px 0;
}

.admin-chat-window-head p {
    color: #aeb8d6;
    font-size: 13px;
}

.admin-chat-messages {
    flex: 1;
    height: 390px;
}

.quick-replies {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0 16px 16px;
    background: rgba(255,255,255,0.05);
}

.quick-replies button {
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 999px;
    padding: 10px 14px;
    background: rgba(255,255,255,0.07);
    color: #dce5ff;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
}

.quick-replies button:hover {
    background: rgba(255,75,31,0.16);
    color: #ffffff;
}

@media (max-width: 1100px) {
    .admin-chat-layout {
        grid-template-columns: 1fr;
    }

    .admin-chat-list {
        max-height: 320px;
        border-right: 0;
        border-bottom: 1px solid rgba(255,255,255,0.08);
    }
}

@media (max-width: 760px) {
    .chat-messages {
        height: 360px;
        padding: 16px;
    }

    .chat-bubble {
        max-width: 92%;
    }

    .chat-form {
        padding: 12px;
    }

    .chat-form input,
    .chat-form button {
        height: 48px;
        border-radius: 15px;
    }
}


/* =========================================================
   LÖWEN FDL — MESSENGER CRM LAYOUT UPDATE
   Добавлено в конец: старые стили не удалены
========================================================= */

.client-chat-panel,
.admin-chat-panel {
    display: none;
}

body.cabinet-chat-mode .client-chat-panel,
body.admin-chat-mode .admin-chat-panel {
    display: block;
}

body.cabinet-chat-mode .cabinet-stats-grid,
body.cabinet-chat-mode #clientLeadsPanel,
body.cabinet-chat-mode #clientCreatePanel,
body.cabinet-chat-mode .cabinet-manager-panel {
    display: none !important;
}

body.admin-chat-mode .admin-stats,
body.admin-chat-mode .admin-main > .admin-panel {
    display: none !important;
}

body.cabinet-chat-mode .cabinet-chat-nav-link,
body.admin-chat-mode #adminChatMenuLink {
    background: linear-gradient(90deg, rgba(255,75,31,0.18), rgba(255,75,31,0.04));
    color: #ffffff;
}

.client-messenger-panel,
.admin-messenger-panel {
    min-height: calc(100vh - 150px);
}

.client-messenger-layout,
.admin-messenger-layout {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr) 300px;
    min-height: 640px;
    border-radius: 26px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.1);
    background:
            radial-gradient(circle at top left, rgba(255, 75, 31, 0.12), transparent 28%),
            linear-gradient(135deg, rgba(3, 8, 22, 0.92), rgba(8, 18, 44, 0.86));
}

.client-messenger-list,
.admin-chat-list {
    background: rgba(255,255,255,0.045);
    border-right: 1px solid rgba(255,255,255,0.08);
    overflow-y: auto;
}

.client-messenger-list-head {
    padding: 22px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.client-messenger-list-head span,
.admin-client-profile-card span,
.admin-client-info-grid span,
.client-info-mini-list span {
    display: block;
    color: #ff4b1f;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 6px;
}

.client-messenger-list-head strong {
    color: #ffffff;
    font-size: 22px;
}

.client-chat-contact {
    width: 100%;
    border: 0;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    padding: 18px;
    display: grid;
    grid-template-columns: 48px 1fr auto;
    gap: 12px;
    align-items: center;
    text-align: left;
    background: linear-gradient(90deg, rgba(255,75,31,0.16), rgba(255,75,31,0.03));
    color: #ffffff;
}

.client-chat-contact-avatar,
.client-messenger-avatar,
.client-info-icon,
.admin-client-avatar-large {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,75,31,0.16);
    color: #ff4b1f;
}

.client-chat-contact-avatar {
    width: 48px;
    height: 48px;
    border-radius: 16px;
}

.client-chat-contact strong {
    display: block;
    font-size: 14px;
    margin-bottom: 5px;
}

.client-chat-contact span,
.client-chat-contact small {
    color: #aeb8d6;
    font-size: 12px;
}

.client-messenger-window,
.admin-chat-window {
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: rgba(3,8,22,0.20);
}

.client-messenger-window-head {
    min-height: 102px;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.client-messenger-avatar {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    flex: 0 0 auto;
}

.client-messenger-window-head span {
    color: #ff4b1f;
    font-size: 12px;
    font-weight: 900;
}

.client-messenger-window-head h3 {
    color: #ffffff;
    font-size: 22px;
    margin: 4px 0;
}

.client-messenger-window-head p {
    color: #aeb8d6;
    font-size: 13px;
}

.client-messenger-window-head .chat-consultant-status {
    margin-left: auto;
}

.client-messenger-info,
.admin-chat-client-card {
    padding: 20px;
    background: rgba(255,255,255,0.035);
    border-left: 1px solid rgba(255,255,255,0.08);
    overflow-y: auto;
}

.client-info-card,
.admin-client-profile-card,
.admin-client-note-card,
.client-info-tip {
    padding: 22px;
    border-radius: 22px;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.09);
    color: #ffffff;
    margin-bottom: 16px;
}

.client-info-icon {
    width: 62px;
    height: 62px;
    border-radius: 20px;
    font-size: 24px;
    margin-bottom: 16px;
}

.client-info-card h3,
.admin-client-profile-card h3 {
    color: #ffffff;
    font-size: 22px;
    margin-bottom: 8px;
}

.client-info-card p,
.admin-client-profile-card p,
.admin-client-note-card p,
.client-info-tip p {
    color: #aeb8d6;
    font-size: 14px;
    line-height: 1.55;
}

.client-info-mini-list,
.admin-client-info-grid {
    display: grid;
    gap: 12px;
    margin-bottom: 16px;
}

.client-info-mini-list div,
.admin-client-info-grid div {
    padding: 16px;
    border-radius: 18px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
}

.client-info-mini-list strong,
.admin-client-info-grid strong {
    color: #ffffff;
    font-size: 14px;
}

.admin-chat-head-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.admin-messenger-layout {
    grid-template-columns: 330px minmax(0, 1fr) 320px;
}

.admin-client-avatar-large {
    width: 78px;
    height: 78px;
    border-radius: 24px;
    font-size: 28px;
    font-weight: 900;
    margin-bottom: 16px;
}

.admin-client-info-grid i {
    color: #24d366;
    font-size: 9px;
    margin-right: 6px;
}

body.admin-chat-mode .admin-chat-panel {
    margin-top: 0;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */



/* =========================================================
   LÖWEN FDL — FULLSCREEN CLIENT MESSENGER MODE
   Добавлено в конец: старый кабинет не удалён, только скрывается в режиме чата
========================================================= */

body.cabinet-chat-mode {
    overflow: hidden;
    background: #050816 !important;
}

body.cabinet-chat-mode .cabinet-app {
    display: block;
    min-height: 100vh;
    background: radial-gradient(circle at top right, rgba(255, 31, 18, 0.16), transparent 34%), linear-gradient(135deg, #050816 0%, #080522 52%, #030612 100%);
}

body.cabinet-chat-mode .cabinet-sidebar,
body.cabinet-chat-mode .cabinet-profile-hero,
body.cabinet-chat-mode .cabinet-stats-grid,
body.cabinet-chat-mode #clientLeadsPanel,
body.cabinet-chat-mode #clientCreatePanel,
body.cabinet-chat-mode .cabinet-manager-panel {
    display: none !important;
}

body.cabinet-chat-mode .cabinet-main {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: none !important;
}

body.cabinet-chat-mode .client-chat-panel {
    display: block !important;
    position: fixed;
    inset: 0;
    z-index: 9998;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    overflow: hidden;
}

.client-fullscreen-layout {
    height: 100vh;
    width: 100vw;
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr) 390px;
    background: #070a18;
    color: #ffffff;
}

.client-fullscreen-sidebar {
    min-width: 0;
    padding: 26px 24px;
    background: radial-gradient(circle at top left, rgba(255,31,18,0.12), transparent 35%), linear-gradient(180deg, #080b20 0%, #060716 100%);
    border-right: 1px solid rgba(255,255,255,0.08);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.client-fullscreen-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-bottom: 26px;
    margin-bottom: 26px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.client-fullscreen-logo {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: linear-gradient(135deg, #ff1f12, #8b0711);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    font-weight: 900;
    box-shadow: 0 18px 35px rgba(255,31,18,0.28);
}

.client-fullscreen-brand strong {
    display: block;
    font-size: 27px;
    line-height: 1;
    letter-spacing: -0.8px;
}

.client-fullscreen-brand strong span {
    color: #ff1f12;
}

.client-fullscreen-brand small {
    display: block;
    margin-top: 7px;
    color: #9ba4c7;
    letter-spacing: 3px;
    font-size: 11px;
    font-weight: 900;
}

.client-fullscreen-chats-head span {
    color: #ffffff;
    font-size: 18px;
    font-weight: 900;
}

.client-fullscreen-chats-head strong {
    display: inline-flex;
    margin-left: 8px;
    width: 28px;
    height: 28px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    font-size: 13px;
}

.client-fullscreen-search {
    height: 54px;
    margin: 18px 0 22px;
    padding: 0 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.055);
    border: 1px solid rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    gap: 12px;
    color: #9ba4c7;
}

.client-fullscreen-search input {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #ffffff;
    font-size: 14px;
}

.client-fullscreen-chat-item {
    width: 100%;
    min-height: 104px;
    border: 0;
    border-radius: 18px;
    padding: 16px;
    display: grid;
    grid-template-columns: 54px 1fr auto;
    gap: 13px;
    align-items: center;
    text-align: left;
    cursor: pointer;
    color: #ffffff;
    background: linear-gradient(90deg, rgba(79,48,186,0.58), rgba(255,31,18,0.1));
    box-shadow: 0 18px 40px rgba(0,0,0,0.18);
    position: relative;
    overflow: hidden;
}

.client-fullscreen-chat-item:after {
    content: "";
    position: absolute;
    right: 0;
    top: 18px;
    bottom: 18px;
    width: 3px;
    border-radius: 3px 0 0 3px;
    background: #ff1f12;
}

.client-fullscreen-chat-avatar,
.client-fullscreen-head-avatar,
.client-fullscreen-consultant-icon {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ff1f12;
    background: rgba(255,31,18,0.14);
    border: 1px solid rgba(255,31,18,0.22);
}

.client-fullscreen-chat-avatar {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    font-size: 22px;
}

.client-fullscreen-chat-avatar span {
    position: absolute;
    width: 10px;
    height: 10px;
    right: 5px;
    bottom: 5px;
    border-radius: 50%;
    background: #24d366;
    border: 2px solid #17172c;
}

.client-fullscreen-chat-item strong,
.client-fullscreen-nav-btn {
    font-size: 15px;
    font-weight: 900;
}

.client-fullscreen-chat-item small,
.client-fullscreen-chat-item em {
    color: #b7bfdc;
    font-style: normal;
    font-size: 12px;
}

.client-fullscreen-bottom-nav {
    margin-top: auto;
    padding: 14px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.045);
    display: grid;
    gap: 8px;
}

.client-fullscreen-nav-btn {
    width: 100%;
    min-height: 54px;
    padding: 0 14px;
    border: 0;
    border-radius: 15px;
    background: transparent;
    color: #ffffff;
    display: flex;
    align-items: center;
    gap: 14px;
    cursor: pointer;
    text-align: left;
    transition: 0.2s ease;
}

.client-fullscreen-nav-btn:hover {
    background: rgba(255,255,255,0.075);
}

.client-fullscreen-nav-btn i {
    width: 24px;
    color: #c4cae0;
    font-size: 20px;
}

.client-fullscreen-chat-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: radial-gradient(circle at 50% 0%, rgba(79,48,186,0.16), transparent 32%), #090b1b;
}

.client-fullscreen-chat-top {
    min-height: 102px;
    padding: 20px 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.035);
}

.client-fullscreen-chat-title {
    display: flex;
    align-items: center;
    gap: 16px;
}

.client-fullscreen-head-avatar {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    font-size: 23px;
}

.client-fullscreen-chat-title h2 {
    margin: 0 0 6px;
    font-size: 21px;
    color: #ffffff;
}

.client-fullscreen-chat-title p {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #d7ddf0;
    font-size: 14px;
}

.client-fullscreen-chat-actions {
    display: flex;
    gap: 10px;
}

.client-fullscreen-chat-actions button,
.client-fullscreen-info-head button {
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 14px;
    cursor: pointer;
    background: transparent;
    color: #b9c0da;
    font-size: 18px;
    transition: 0.2s ease;
}

.client-fullscreen-chat-actions button:hover,
.client-fullscreen-info-head button:hover {
    background: rgba(255,255,255,0.075);
    color: #ffffff;
}

.client-fullscreen-messages {
    flex: 1;
    height: auto !important;
    min-height: 0;
    padding: 34px;
    background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 32px 32px;
    overflow-y: auto;
}

.client-fullscreen-form {
    margin: 0;
    padding: 18px 22px;
    border-top: 1px solid rgba(255,255,255,0.08);
    display: grid;
    grid-template-columns: 48px 1fr 62px;
    gap: 12px;
    background: rgba(255,255,255,0.035);
}

.client-fullscreen-form input {
    height: 58px;
    border-radius: 18px;
    padding: 0 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.07);
    color: #ffffff;
    font-size: 15px;
}

.client-fullscreen-form input::placeholder {
    color: #8e96b6;
}

.client-fullscreen-form button {
    height: 58px;
    border: 0;
    border-radius: 18px;
    color: #ffffff;
    cursor: pointer;
}

.client-fullscreen-form button[type="submit"] {
    background: linear-gradient(135deg, #ff1f12, #b40b18);
    font-size: 22px;
    box-shadow: 0 16px 30px rgba(255,31,18,0.28);
}

.client-fullscreen-form .client-attach-btn {
    background: rgba(255,255,255,0.06);
    color: #c8cee4;
    font-size: 20px;
}

.client-fullscreen-info {
    min-width: 0;
    padding: 0;
    border-left: 1px solid rgba(255,255,255,0.08);
    background: linear-gradient(180deg, #0c0e22 0%, #080a19 100%);
    overflow-y: auto;
}

.client-fullscreen-info-head {
    min-height: 102px;
    padding: 22px 26px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.client-fullscreen-info-head h3 {
    font-size: 18px;
    color: #ffffff;
}

.client-fullscreen-consultant-card {
    padding: 44px 28px 30px;
    text-align: center;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.client-fullscreen-consultant-icon {
    width: 112px;
    height: 112px;
    margin: 0 auto 24px;
    border-radius: 50%;
    font-size: 44px;
    box-shadow: 0 0 0 14px rgba(255,255,255,0.035);
}

.client-fullscreen-consultant-card h2 {
    font-size: 24px;
    color: #ffffff;
    margin-bottom: 10px;
}

.client-fullscreen-consultant-card p {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    color: #d8def1;
    margin-bottom: 18px;
}

.client-fullscreen-consultant-card > span {
    display: block;
    color: #aeb6d2;
    line-height: 1.55;
}

.client-fullscreen-info-box {
    margin: 20px;
    padding: 22px;
    border-radius: 22px;
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.06);
}

.client-fullscreen-info-box h4 {
    color: #ffffff;
    margin-bottom: 16px;
    font-size: 16px;
}

.client-fullscreen-info-box p,
.client-fullscreen-info-box button {
    color: #c9cfe5;
    font-size: 14px;
}

.client-fullscreen-info-box p {
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.client-fullscreen-info-box button {
    width: 100%;
    min-height: 48px;
    border: 0;
    border-radius: 14px;
    background: transparent;
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    text-align: left;
}

.client-fullscreen-info-box button:hover {
    background: rgba(255,255,255,0.06);
}

.client-fullscreen-info-box button span {
    margin-left: auto;
    color: #9fa7c6;
    font-size: 22px;
}

body.cabinet-chat-mode .chat-bubble.mine {
    background: linear-gradient(135deg, #4b25d2, #32128f);
    color: #ffffff;
    border-radius: 18px 18px 4px 18px;
}

body.cabinet-chat-mode .chat-bubble.other {
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    border-radius: 18px 18px 18px 4px;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */



/* =========================================================
   LÖWEN FDL — FULLSCREEN ADMIN MESSENGER MODE
   Добавлено в конец: обычная CRM не удаляется, а скрывается только в режиме чата
========================================================= */

body.admin-chat-mode {
    overflow: hidden;
    background: #050816 !important;
}

body.admin-chat-mode .admin-app {
    display: block;
    min-height: 100vh;
    background:
        radial-gradient(circle at top right, rgba(255, 31, 18, 0.14), transparent 34%),
        linear-gradient(135deg, #050816 0%, #080522 52%, #030612 100%);
}

body.admin-chat-mode .admin-sidebar,
body.admin-chat-mode .admin-topbar,
body.admin-chat-mode .admin-stats,
body.admin-chat-mode .admin-main > .admin-panel {
    display: none !important;
}

body.admin-chat-mode .admin-main {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: none !important;
}

body.admin-chat-mode .admin-chat-panel {
    display: block !important;
    position: fixed;
    inset: 0;
    z-index: 9998;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    overflow: hidden;
}

.admin-fullscreen-layout {
    height: 100vh;
    width: 100vw;
    display: grid;
    grid-template-columns: 370px minmax(0, 1fr) 390px;
    background: #070a18;
    color: #ffffff;
}

.admin-fullscreen-sidebar {
    min-width: 0;
    padding: 26px 24px;
    background:
        radial-gradient(circle at top left, rgba(255,31,18,0.12), transparent 35%),
        linear-gradient(180deg, #080b20 0%, #060716 100%);
    border-right: 1px solid rgba(255,255,255,0.08);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.admin-fullscreen-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-bottom: 26px;
    margin-bottom: 26px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.admin-fullscreen-logo {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: linear-gradient(135deg, #ff1f12, #8b0711);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    font-weight: 900;
    box-shadow: 0 18px 35px rgba(255,31,18,0.28);
}

.admin-fullscreen-brand strong {
    display: block;
    font-size: 27px;
    line-height: 1;
    letter-spacing: -0.8px;
}

.admin-fullscreen-brand strong span {
    color: #ff1f12;
}

.admin-fullscreen-brand small {
    display: block;
    margin-top: 7px;
    color: #9ba4c7;
    letter-spacing: 3px;
    font-size: 11px;
    font-weight: 900;
}

.admin-fullscreen-chats-head span {
    color: #ffffff;
    font-size: 18px;
    font-weight: 900;
}

.admin-fullscreen-chats-head strong {
    display: inline-flex;
    margin-left: 8px;
    min-width: 28px;
    height: 28px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    padding: 0 8px;
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    font-size: 13px;
}

.admin-fullscreen-search {
    height: 54px;
    margin: 18px 0 22px;
    padding: 0 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.055);
    border: 1px solid rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    gap: 12px;
    color: #9ba4c7;
}

.admin-fullscreen-search input {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #ffffff;
    font-size: 14px;
}

.admin-fullscreen-chat-list {
    overflow-y: auto;
    display: grid;
    gap: 10px;
    padding-right: 3px;
}

body.admin-chat-mode .admin-chat-item {
    width: 100%;
    min-height: 92px;
    border: 0;
    border-radius: 18px;
    padding: 14px;
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    text-align: left;
    cursor: pointer;
    color: #ffffff;
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.06);
    transition: 0.2s ease;
}

body.admin-chat-mode .admin-chat-item.active,
body.admin-chat-mode .admin-chat-item:hover {
    background: linear-gradient(90deg, rgba(79,48,186,0.58), rgba(255,31,18,0.1));
    box-shadow: 0 18px 40px rgba(0,0,0,0.18);
}

body.admin-chat-mode .admin-chat-avatar,
.admin-fullscreen-head-avatar,
.admin-fullscreen-client-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ff1f12;
    background: rgba(255,31,18,0.14);
    border: 1px solid rgba(255,31,18,0.22);
}

body.admin-chat-mode .admin-chat-avatar {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    font-size: 21px;
    font-weight: 900;
}

body.admin-chat-mode .admin-chat-meta {
    min-width: 0;
}

body.admin-chat-mode .admin-chat-meta strong {
    display: block;
    font-size: 14px;
    margin-bottom: 5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.admin-chat-mode .admin-chat-meta span,
body.admin-chat-mode .admin-chat-time {
    color: #b7bfdc;
    font-size: 12px;
}

body.admin-chat-mode .admin-chat-unread,
body.admin-chat-mode .chat-unread-badge {
    display: inline-flex;
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    align-items: center;
    justify-content: center;
    border-radius: 20px;
    background: #ff1f12;
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
}

.admin-fullscreen-bottom-nav {
    margin-top: auto;
    padding: 14px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.045);
    display: grid;
    gap: 8px;
}

.admin-fullscreen-nav-btn {
    width: 100%;
    min-height: 54px;
    padding: 0 14px;
    border: 0;
    border-radius: 15px;
    background: transparent;
    color: #ffffff;
    display: flex;
    align-items: center;
    gap: 14px;
    cursor: pointer;
    text-align: left;
    font-size: 15px;
    font-weight: 900;
    transition: 0.2s ease;
}

.admin-fullscreen-nav-btn.active,
.admin-fullscreen-nav-btn:hover {
    background: rgba(255,255,255,0.075);
}

.admin-fullscreen-nav-btn i {
    width: 24px;
    color: #c4cae0;
    font-size: 20px;
}

.admin-fullscreen-chat-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: radial-gradient(circle at 50% 0%, rgba(79,48,186,0.16), transparent 32%), #090b1b;
}

.admin-fullscreen-chat-top {
    min-height: 102px;
    padding: 20px 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.035);
}

.admin-fullscreen-chat-title {
    display: flex;
    align-items: center;
    gap: 16px;
}

.admin-fullscreen-head-avatar {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    font-size: 23px;
    font-weight: 900;
}

.admin-fullscreen-chat-title h2 {
    margin: 0 0 6px;
    font-size: 21px;
    color: #ffffff;
}

.admin-fullscreen-chat-title p {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #d7ddf0;
    font-size: 14px;
}

.admin-fullscreen-chat-actions {
    display: flex;
    gap: 10px;
}

.admin-fullscreen-chat-actions button,
.admin-fullscreen-info-head button {
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 14px;
    cursor: pointer;
    background: transparent;
    color: #b9c0da;
    font-size: 18px;
    transition: 0.2s ease;
}

.admin-fullscreen-chat-actions button:hover,
.admin-fullscreen-info-head button:hover {
    background: rgba(255,255,255,0.075);
    color: #ffffff;
}

.admin-fullscreen-messages {
    flex: 1;
    height: auto !important;
    min-height: 0;
    padding: 34px;
    background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 32px 32px;
    overflow-y: auto;
}

.admin-fullscreen-form {
    margin: 0;
    padding: 18px 22px;
    border-top: 1px solid rgba(255,255,255,0.08);
    display: grid;
    grid-template-columns: 48px 1fr 62px;
    gap: 12px;
    background: rgba(255,255,255,0.035);
}

.admin-fullscreen-form input {
    height: 58px;
    border-radius: 18px;
    padding: 0 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.07);
    color: #ffffff;
    font-size: 15px;
}

.admin-fullscreen-form input::placeholder {
    color: #8e96b6;
}

.admin-fullscreen-form button {
    height: 58px;
    border: 0;
    border-radius: 18px;
    color: #ffffff;
    cursor: pointer;
}

.admin-fullscreen-form button[type="submit"] {
    background: linear-gradient(135deg, #ff1f12, #b40b18);
    font-size: 22px;
    box-shadow: 0 16px 30px rgba(255,31,18,0.28);
}

.admin-fullscreen-form .admin-attach-btn {
    background: rgba(255,255,255,0.06);
    color: #c8cee4;
    font-size: 20px;
}

.admin-fullscreen-quick-replies {
    padding: 0 22px 18px;
    background: rgba(255,255,255,0.035);
}

.admin-fullscreen-info {
    min-width: 0;
    padding: 0;
    border-left: 1px solid rgba(255,255,255,0.08);
    background: linear-gradient(180deg, #0c0e22 0%, #080a19 100%);
    overflow-y: auto;
}

.admin-fullscreen-info-head {
    min-height: 102px;
    padding: 22px 26px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.admin-fullscreen-info-head h3 {
    font-size: 18px;
    color: #ffffff;
}

.admin-fullscreen-client-card {
    padding: 44px 28px 30px;
    text-align: center;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.admin-fullscreen-client-avatar {
    width: 112px;
    height: 112px;
    margin: 0 auto 24px;
    border-radius: 50%;
    font-size: 44px;
    font-weight: 900;
    box-shadow: 0 0 0 14px rgba(255,255,255,0.035);
}

.admin-fullscreen-client-card h2 {
    font-size: 24px;
    color: #ffffff;
    margin-bottom: 10px;
}

.admin-fullscreen-client-card p {
    color: #d8def1;
    margin-bottom: 18px;
    word-break: break-word;
}

.admin-fullscreen-client-card > span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #aeb6d2;
}

.admin-fullscreen-client-card > span i,
.chat-online-dot {
    color: #24d366;
}

.admin-fullscreen-info-box {
    margin: 20px;
    padding: 22px;
    border-radius: 22px;
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.06);
}

.admin-fullscreen-info-box h4 {
    color: #ffffff;
    margin-bottom: 16px;
    font-size: 16px;
}

.admin-fullscreen-info-box p,
.admin-fullscreen-info-box button {
    color: #c9cfe5;
    font-size: 14px;
}

.admin-fullscreen-info-box p {
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.admin-fullscreen-info-box p strong {
    margin-left: auto;
    color: #ffffff;
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-fullscreen-info-box button {
    width: 100%;
    min-height: 48px;
    border: 0;
    border-radius: 14px;
    background: transparent;
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    text-align: left;
}

.admin-fullscreen-info-box button:hover {
    background: rgba(255,255,255,0.06);
}

.admin-fullscreen-info-box button span {
    margin-left: auto;
    color: #9fa7c6;
    font-size: 22px;
}

body.admin-chat-mode .chat-bubble {
    max-width: min(560px, 78%);
}

body.admin-chat-mode .chat-bubble p {
    color: inherit;
}

body.admin-chat-mode .chat-message.is-own .chat-bubble,
body.admin-chat-mode .chat-message.admin .chat-bubble {
    background: linear-gradient(135deg, #4b25d2, #32128f);
    color: #ffffff;
    border-radius: 18px 18px 4px 18px;
}

body.admin-chat-mode .chat-message.is-other .chat-bubble,
body.admin-chat-mode .chat-message.client .chat-bubble {
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    border-radius: 18px 18px 18px 4px;
}

@media (max-width: 1250px) {
    .admin-fullscreen-layout {
        grid-template-columns: 330px minmax(0, 1fr);
    }

    .admin-fullscreen-info {
        display: none;
    }
}


/* moved cabinet/mobile rules to mobile-app.css */


/* =========================================================
   LÖWEN FDL — CABINET HERO V2
   Новый premium hero: фото + данные + action panel справа.
   Добавлено в конец, старые стили не удаляются.
========================================================= */

.cabinet-profile-hero-v2 {
    padding: 56px 0 34px !important;
    margin-bottom: 24px;
    border-bottom: 1px solid rgba(255,255,255,.10);
}

.cabinet-profile-content-v2 {
    display: grid !important;
    grid-template-columns: 280px minmax(320px, 1fr) 430px;
    align-items: start !important;
    gap: 48px !important;
}

.cabinet-profile-hero-v2 .cabinet-avatar-box {
    width: 260px !important;
    height: 290px !important;
    margin-top: 0 !important;
    border-radius: 28px !important;
    padding: 9px !important;
    background: radial-gradient(circle at 50% 18%, rgba(255,31,18,.38), rgba(255,255,255,.08));
    box-shadow: 0 24px 70px rgba(255,31,18,.12);
}

.cabinet-profile-hero-v2 .cabinet-avatar-box img,
.cabinet-profile-hero-v2 .cabinet-avatar-placeholder {
    border-radius: 22px !important;
}

.cabinet-profile-hero-v2 .cabinet-avatar-upload {
    right: 10px !important;
    bottom: 12px !important;
    width: 54px !important;
    height: 54px !important;
    font-size: 17px;
}

.cabinet-profile-info-v2 {
    padding-top: 28px;
}

.cabinet-profile-info-v2 h2 {
    font-size: 40px !important;
    line-height: 1.05;
    margin-bottom: 8px;
}

.cabinet-profile-info-v2 h3 {
    color: #ff1f12 !important;
    font-size: 28px !important;
    line-height: 1.1;
    margin-bottom: 28px !important;
}

.cabinet-profile-info-v2 .cabinet-profile-meta {
    margin-bottom: 18px;
}

.cabinet-profile-info-v2 .cabinet-profile-meta i {
    width: 24px;
    color: #ffffff;
    opacity: .92;
}

.cabinet-profile-info-v2 .cabinet-profile-meta strong {
    color: #ffffff;
}

.cabinet-profile-user-card-v2 {
    width: min(300px, 100%);
    margin-top: 20px;
}

.cabinet-profile-actions-panel {
    width: 100%;
    padding: 14px;
    border-radius: 24px;
    background:
            radial-gradient(circle at top right, rgba(255,31,18,.16), transparent 44%),
            rgba(255,255,255,.055);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: 0 24px 70px rgba(0,0,0,.18);
    display: grid;
    gap: 14px;
}

.cabinet-profile-action-card {
    min-height: 86px;
    width: 100%;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.045);
    color: #ffffff;
    text-decoration: none;
    cursor: pointer;
    display: grid;
    grid-template-columns: 56px 1fr auto;
    align-items: center;
    gap: 16px;
    transition: transform .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease;
    font-family: inherit;
    text-align: left;
}

.cabinet-profile-action-card:hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,.075);
    border-color: rgba(255,255,255,.22);
    box-shadow: 0 16px 40px rgba(0,0,0,.18);
}

.cabinet-profile-action-card strong {
    display: block;
    font-size: 17px;
    font-weight: 900;
    line-height: 1.2;
    margin-bottom: 5px;
}

.cabinet-profile-action-card small {
    display: block;
    color: rgba(224,230,255,.72);
    font-size: 13px;
    line-height: 1.3;
}

.cabinet-profile-action-card > i {
    color: rgba(255,255,255,.78);
    font-size: 16px;
}

.cabinet-profile-action-icon {
    width: 48px;
    height: 48px;
    border-radius: 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}

.cabinet-profile-action-icon.purple {
    background: rgba(143,65,255,.18);
    color: #b98cff;
}

.cabinet-profile-action-icon.blue {
    background: rgba(52,163,255,.16);
    color: #85cfff;
}

.cabinet-profile-action-icon.chat {
    background: rgba(255,255,255,.10);
    color: #ffffff;
}

.cabinet-profile-action-icon.red {
    background: rgba(255,31,18,.18);
    color: #ffffff;
}

.cabinet-profile-action-card-admin {
    background: linear-gradient(135deg, rgba(255,31,18,.76), rgba(140,8,18,.66)) !important;
    border-color: rgba(255,97,84,.46) !important;
    box-shadow: 0 18px 42px rgba(255,31,18,.18);
}

.cabinet-profile-action-card-admin:hover {
    background: linear-gradient(135deg, rgba(255,31,18,.92), rgba(154,12,24,.78)) !important;
    box-shadow: 0 24px 54px rgba(255,31,18,.24);
}

.cabinet-profile-action-card-admin small {
    color: rgba(255,255,255,.78);
}


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */



/* CABINET ACCOUNT STATUS CARD UPDATE */
.cabinet-account-status-card {
    width: min(300px, 100%);
    margin-top: 20px;
    padding: 18px 20px;
    border-radius: 20px;
    background:
            radial-gradient(circle at top left, rgba(255,31,18,.10), transparent 45%),
            rgba(255,255,255,.055);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: 0 18px 45px rgba(0,0,0,.14);
}

.cabinet-account-status-block small {
    display: block;
    margin-bottom: 8px;
    color: rgba(220,229,255,.72);
    font-size: 14px;
    line-height: 1.2;
}

.cabinet-online-status,
.cabinet-real-role {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: #ffffff;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.25;
}

.cabinet-status-dot {
    width: 11px;
    height: 11px;
    border-radius: 999px;
    background: #18e66f;
    box-shadow: 0 0 0 5px rgba(24,230,111,.12), 0 0 18px rgba(24,230,111,.45);
}

.cabinet-real-role::before {
    content: "\f521";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    color: #ff1f12;
    font-size: 15px;
}

.cabinet-status-divider {
    width: 100%;
    height: 1px;
    margin: 15px 0 14px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
}

.cabinet-hidden-user-name {
    display: none !important;
}

@media (max-width: 760px) {
    .cabinet-account-status-card {
        width: 100%;
    }
}

/* ===============================
   FLOATING SITE CHAT WIDGET
   =============================== */

.site-chat-widget {
    position: fixed;
    right: 26px;
    bottom: 26px;
    z-index: 99999;
    font-family: Arial, sans-serif;
}

.site-chat-float-btn {
    position: relative;
    width: 76px;
    height: 76px;
    border: none;
    border-radius: 26px;
    cursor: pointer;
    color: #ffffff;
    background:
            radial-gradient(circle at 30% 20%, rgba(255,255,255,0.24), transparent 28%),
            linear-gradient(135deg, #ff3b18 0%, #8d1cff 100%);
    box-shadow: 0 22px 55px rgba(255, 59, 24, 0.35), 0 0 0 1px rgba(255,255,255,0.12) inset;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    transition: 0.22s ease;
}

.site-chat-float-btn:hover {
    transform: translateY(-4px) scale(1.03);
    box-shadow: 0 28px 70px rgba(141, 28, 255, 0.38), 0 0 0 1px rgba(255,255,255,0.15) inset;
}

.site-chat-float-btn i {
    font-size: 26px;
    position: relative;
    z-index: 2;
}

.site-chat-float-btn strong {
    font-size: 10px;
    letter-spacing: 0.4px;
    position: relative;
    z-index: 2;
}

.site-chat-pulse {
    position: absolute;
    inset: -8px;
    border-radius: 32px;
    background: rgba(255, 59, 24, 0.22);
    animation: siteChatPulse 1.8s infinite;
}

@keyframes siteChatPulse {
    0% { transform: scale(0.9); opacity: 0.85; }
    70% { transform: scale(1.18); opacity: 0; }
    100% { transform: scale(1.18); opacity: 0; }
}

.site-chat-panel {
    position: absolute;
    right: 0;
    bottom: 92px;
    width: 390px;
    height: 560px;
    max-height: calc(100vh - 130px);
    display: none;
    overflow: hidden;
    border-radius: 28px;
    background:
            radial-gradient(circle at top left, rgba(255, 59, 24, 0.16), transparent 32%),
            radial-gradient(circle at bottom right, rgba(141, 28, 255, 0.18), transparent 35%),
            linear-gradient(145deg, #0a1024 0%, #11162e 45%, #050814 100%);
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow: 0 35px 95px rgba(2, 8, 22, 0.45);
    color: #ffffff;
}

body.site-chat-open .site-chat-panel {
    display: grid;
    grid-template-rows: auto 1fr auto;
    animation: siteChatIn 0.2s ease;
}

@keyframes siteChatIn {
    from { opacity: 0; transform: translateY(18px) scale(0.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.site-chat-head {
    height: 78px;
    padding: 16px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.035);
}

.site-chat-brand-mini {
    display: flex;
    align-items: center;
    gap: 12px;
}

.site-chat-logo-mini {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: linear-gradient(135deg, #ff3b18, #8d1cff);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    box-shadow: 0 12px 28px rgba(255,59,24,0.22);
}

.site-chat-brand-mini strong {
    display: block;
    font-size: 14px;
    letter-spacing: 0.2px;
}

.site-chat-brand-mini span {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 4px;
    color: #aeb8d0;
    font-size: 12px;
}

.site-chat-brand-mini em {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #23d56b;
    box-shadow: 0 0 0 4px rgba(35,213,107,0.12);
}

.site-chat-head button {
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 13px;
    cursor: pointer;
    color: #ffffff;
    background: rgba(255,255,255,0.08);
}

.site-chat-body {
    min-height: 0;
    padding: 18px;
    overflow-y: auto;
}

.site-chat-welcome {
    margin-bottom: 14px;
    padding: 16px;
    border-radius: 20px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
}

.site-chat-welcome strong {
    display: block;
    margin-bottom: 7px;
    font-size: 17px;
}

.site-chat-welcome span {
    color: #b7c0d5;
    font-size: 13px;
    line-height: 1.45;
}

.site-chat-start-form {
    display: grid;
    gap: 11px;
}

.site-chat-fields-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.site-chat-start-form input,
.site-chat-start-form textarea,
.site-chat-send-form input {
    width: 100%;
    border: 1px solid rgba(255,255,255,0.1);
    outline: none;
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    border-radius: 16px;
    font-size: 14px;
}

.site-chat-start-form input {
    height: 48px;
    padding: 0 14px;
}

.site-chat-start-form textarea {
    min-height: 110px;
    resize: none;
    padding: 14px;
    line-height: 1.45;
}

.site-chat-start-form input::placeholder,
.site-chat-start-form textarea::placeholder,
.site-chat-send-form input::placeholder {
    color: #8f9ab5;
}

.site-chat-start-form button {
    height: 52px;
    border: none;
    border-radius: 16px;
    cursor: pointer;
    background: linear-gradient(135deg, #ff3b18, #8d1cff);
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
    box-shadow: 0 16px 34px rgba(255,59,24,0.22);
}

.site-chat-start-form small {
    color: #7f8aa6;
    font-size: 11px;
    line-height: 1.35;
    text-align: center;
}

.site-chat-messages {
    height: 100%;
    min-height: 360px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.site-chat-message {
    display: flex;
}

.site-chat-message.from-visitor {
    justify-content: flex-end;
}

.site-chat-message.from-admin {
    justify-content: flex-start;
}

.site-chat-bubble {
    max-width: 82%;
    padding: 12px 14px;
    border-radius: 18px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.08);
}

.site-chat-message.from-visitor .site-chat-bubble {
    background: linear-gradient(135deg, #ff3b18, #8d1cff);
    border-color: transparent;
}

.site-chat-bubble p {
    margin: 0;
    color: #ffffff;
    font-size: 14px;
    line-height: 1.45;
}

.site-chat-bubble small {
    display: block;
    margin-top: 6px;
    color: rgba(255,255,255,0.62);
    font-size: 10px;
}

.site-chat-empty {
    margin: auto;
    text-align: center;
    color: #8f9ab5;
}

.site-chat-empty i {
    display: block;
    margin-bottom: 12px;
    font-size: 30px;
    color: #ff4b1f;
}

.site-chat-empty strong {
    display: block;
    color: #ffffff;
    margin-bottom: 6px;
}

.site-chat-send-form {
    padding: 14px;
    border-top: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.035);
    gap: 10px;
    align-items: center;
}

.site-chat-send-form input {
    height: 48px;
    padding: 0 15px;
}

.site-chat-send-form button {
    min-width: 48px;
    height: 48px;
    border: none;
    border-radius: 15px;
    cursor: pointer;
    color: #ffffff;
    background: #ff3b18;
    box-shadow: 0 12px 28px rgba(255,59,24,0.22);
}

.admin-chat-label-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin: 5px 0 4px;
}

.admin-chat-type-badge,
.admin-chat-status-badge,
.admin-chat-card-label {
    display: inline-flex;
    align-items: center;
    width: max-content;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-style: normal;
    font-weight: 900;
    letter-spacing: 0.2px;
}

.admin-chat-type-badge.client,
.admin-chat-card-label.client {
    color: #8ee7ff;
    background: rgba(32, 168, 232, 0.14);
    border: 1px solid rgba(32, 168, 232, 0.25);
}

.admin-chat-type-badge.guest,
.admin-chat-card-label.guest {
    color: #ffd28a;
    background: rgba(255, 170, 54, 0.14);
    border: 1px solid rgba(255, 170, 54, 0.28);
}

.admin-chat-status-badge {
    color: #dbe5ff;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.1);
}

.admin-chat-card-phone {
    display: inline-block;
    margin-top: 5px;
    color: #9aa7c3;
    font-size: 12px;
}

.admin-chat-card-label {
    margin-top: 8px;
}

@media (max-width: 700px) {
    .site-chat-widget {
        right: 18px;
        bottom: 18px;
    }

    .site-chat-float-btn {
        width: 66px;
        height: 66px;
        border-radius: 22px;
    }

    .site-chat-panel {
        position: fixed;
        inset: 0;
        width: 100%;
        height: 100%;
        max-height: none;
        border-radius: 0;
        border: none;
    }

    body.site-chat-open .site-chat-panel {
        display: grid;
    }

    body.site-chat-open {
        overflow: hidden;
    }

    .site-chat-body {
        padding: 16px;
    }

    .site-chat-fields-grid {
        grid-template-columns: 1fr;
    }

    .site-chat-messages {
        min-height: calc(100vh - 170px);
    }
}


/* ===============================
   FIX: MOBILE SITE CHAT + CRM BLOCK
   =============================== */
@media (max-width: 700px) {
    .site-chat-widget {
        right: 16px;
        bottom: 16px;
        z-index: 2147483000;
    }

    .site-chat-panel {
        position: fixed !important;
        inset: 0 !important;
        width: 100vw !important;
        height: 100dvh !important;
        max-height: none !important;
        border-radius: 0 !important;
        border: none !important;
    }

    body.site-chat-open .site-chat-panel {
        display: grid !important;
        grid-template-rows: auto 1fr auto;
    }

    .site-chat-head {
        height: 76px;
        padding: 14px 16px;
    }

    .site-chat-body {
        min-height: 0;
        overflow-y: auto;
        padding: 14px;
    }

    .site-chat-start-form input,
    .site-chat-start-form textarea {
        font-size: 16px;
    }

    .site-chat-start-form textarea {
        min-height: 145px;
    }

    .site-chat-messages {
        min-height: 0 !important;
        height: 100%;
        overflow-y: auto;
    }

    .site-chat-send-form {
        padding: 12px;
        padding-bottom: max(12px, env(safe-area-inset-bottom));
    }

    .site-chat-send-form input {
        font-size: 16px;
    }
}

@media (max-width: 900px) {
    .admin-body::before {
        content: "CRM доступна только с компьютера";
        position: fixed;
        inset: 0;
        z-index: 2147483647;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 26px;
        text-align: center;
        color: #ffffff;
        font-size: 22px;
        font-weight: 900;
        background: linear-gradient(135deg, #07031f, #250035);
    }
}


/* ADMIN CHAT CLOSE BUTTON */
.admin-close-chat-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 10px;
    border: 1px solid rgba(255, 80, 80, 0.22) !important;
    background: linear-gradient(135deg, rgba(255, 59, 24, 0.16), rgba(255, 255, 255, 0.04)) !important;
    color: #ffe7e2 !important;
}

.admin-close-chat-btn i {
    color: #ff6b5a;
}

.admin-close-chat-btn:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 80, 80, 0.42) !important;
    box-shadow: 0 14px 34px rgba(255, 59, 24, 0.16);
}

.admin-chat-status-badge.closed {
    color: #ffb4aa;
    background: rgba(255, 59, 24, 0.12);
    border-color: rgba(255, 59, 24, 0.25);
}


/* =========================================================
   LÖWEN FDL CHAT FIX v2.4 — compact admin messenger + reset-safe site chat
========================================================= */
body.admin-chat-mode .admin-chat-panel {
    width: 100% !important;
    max-width: 100vw !important;
}

body.admin-chat-mode .admin-fullscreen-layout {
    width: 100% !important;
    max-width: 100vw !important;
    height: 100vh !important;
    grid-template-columns: 340px minmax(0, 1fr) 340px !important;
    overflow: hidden !important;
}

body.admin-chat-mode .admin-fullscreen-sidebar,
body.admin-chat-mode .admin-fullscreen-chat-main,
body.admin-chat-mode .admin-fullscreen-info {
    min-width: 0 !important;
}

body.admin-chat-mode .admin-fullscreen-messages {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

body.admin-chat-mode .chat-bubble {
    max-width: min(440px, 72%) !important;
    overflow-wrap: anywhere !important;
}

body.admin-chat-mode .chat-message {
    width: 100% !important;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */



/* =========================================================
   LÖWEN FDL CHAT FIX v2.5 — stable lifecycle + compact messenger
========================================================= */
body.admin-chat-mode .admin-fullscreen-layout {
    grid-template-columns: 320px minmax(520px, 1fr) 320px !important;
}

body.admin-chat-mode .admin-fullscreen-messages {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    padding: 28px clamp(22px, 3vw, 44px) !important;
    overflow-x: hidden !important;
}

body.admin-chat-mode .chat-message {
    display: flex !important;
    width: 100% !important;
    max-width: 860px !important;
}

body.admin-chat-mode .chat-message.is-own,
body.admin-chat-mode .chat-message.admin.is-own {
    align-self: flex-end !important;
    justify-content: flex-end !important;
}

body.admin-chat-mode .chat-message.is-other,
body.admin-chat-mode .chat-message.client.is-other {
    align-self: flex-start !important;
    justify-content: flex-start !important;
}

body.admin-chat-mode .chat-bubble {
    width: fit-content !important;
    max-width: min(430px, 72vw) !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
}

body.admin-chat-mode .admin-fullscreen-sidebar {
    width: 320px !important;
}

body.admin-chat-mode .admin-fullscreen-info {
    width: 320px !important;
}


/* moved cabinet/mobile rules to mobile-app.css */




/* =========================================================
   LÖWEN FDL — MOBILE APP CABINET V1
   Десктоп не трогаем. Работает только на телефоне.
========================================================= */

.mobile-app-topbar,
.mobile-app-welcome,
.mobile-app-bottom-nav {
    display: none;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */


/* =========================================================
   LÖWEN FDL — MOBILE APP DASHBOARD V2
   Добавлено поверх V1. Desktop не затрагивается.
========================================================= */
.mobile-app-section,
.mobile-app-block-title {
    display: none;
}


/* moved cabinet/mobile rules to mobile-app.css */


@media (max-width: 390px) {
    .mobile-quick-card {
        min-height: 108px;
        padding: 14px 12px;
    }

    .mobile-quick-card span {
        width: 44px;
        height: 44px;
        border-radius: 16px;
    }

    .mobile-quick-card strong {
        font-size: 14px;
    }
}

/* === LOWEN MOBILE APP V3 FORCE LAYER === */

.mobile-app-topbar,
.mobile-app-welcome,
.mobile-app-quick-menu,
.mobile-app-bottom-nav {
    display: none;
}


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */


/* =========================================================
   DESKTOP CABINET REPAIR — ONLY FIX, NO NEW FUNCTIONALITY
   Purpose: restore desktop cabinet layout after mobile-app experiment.
   Works only on PC/tablet wide screens. Mobile rules remain untouched.
========================================================= */

/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */



/* =========================================================
   DESKTOP CABINET REPAIR ONLY — 2026-05-17
   Аккуратно возвращает ПК-версию. Mobile app блоки НЕ удалены,
   но на desktop они не вмешиваются в layout.
========================================================= */


/* moved cabinet/mobile rules to mobile-app.css */



/* moved cabinet/mobile rules to mobile-app.css */


/* =========================================================
   SAFE DESKTOP GUARD — mobile app v6 isolation
   Keeps the new phone app out of desktop / narrow desktop windows.
========================================================= */
@media (min-width:901px), (max-width:900px) and (hover:hover) and (pointer:fine){
    .mobile-app-layout,
    .mobile-app-return,
    .mobile-app-bottom-nav,
    .mobile-app-topbar,
    .mobile-app-welcome,
    .mobile-app-status-card,
    .mobile-app-quick-menu,
    .mobile-app-section,
    .mobile-app-block-title{
        display:none !important;
    }

    .desktop-cabinet-layout{
        display:grid !important;
    }
}


/* =========================================================
   LÖWEN FDL — PREMIUM MOBILE HERO 2026
   Только телефонная версия. Desktop не трогаем.
   ========================================================= */
.mobile-hero-app-card{
    display:none;
}

@media (max-width: 900px){
    html,
    body{
        background:#020812;
        overflow-x:hidden;
    }

    .site-header{
        position:absolute !important;
        left:0;
        right:0;
        top:0;
        z-index:1000;
        padding:calc(18px + env(safe-area-inset-top)) 26px 10px !important;
        background:transparent !important;
        box-shadow:none !important;
    }

    .header-inner{
        max-width:none;
        width:100%;
        gap:12px;
        align-items:center;
    }

    .logo{
        color:#ffffff !important;
        font-size:25px !important;
        letter-spacing:-1px;
        text-shadow:0 12px 30px rgba(0,0,0,.35);
    }

    .logo span{
        color:#ff4b1f !important;
    }

    .logo small{
        color:rgba(255,255,255,.76) !important;
        font-size:7px !important;
        letter-spacing:6px !important;
        margin-top:7px;
    }

    .mobile-header-actions{
        gap:12px !important;
    }

    .mobile-cabinet-link{
        height:60px !important;
        padding:0 18px !important;
        border-radius:20px !important;
        background:rgba(5,12,25,.42) !important;
        color:#ffffff !important;
        border:1px solid rgba(255,255,255,.20);
        box-shadow:0 18px 42px rgba(0,0,0,.24);
        backdrop-filter:blur(14px);
        -webkit-backdrop-filter:blur(14px);
        font-size:14px !important;
    }

    .mobile-cabinet-link::before{
        content:"\f007";
        font-family:"Font Awesome 6 Free";
        font-weight:900;
        margin-right:9px;
        font-size:14px;
    }

    .mobile-burger{
        width:60px !important;
        height:60px !important;
        border-radius:19px !important;
        background:linear-gradient(135deg,#ff602d,#ff3d17) !important;
        box-shadow:0 18px 36px rgba(255,75,31,.34) !important;
        gap:6px !important;
    }

    .mobile-burger span{
        width:24px !important;
        height:3px !important;
    }

    .mobile-menu{
        position:fixed !important;
        top:calc(88px + env(safe-area-inset-top)) !important;
        padding:0 18px 14px !important;
    }

    .mobile-menu-panel{
        background:rgba(6,13,28,.94) !important;
        border-color:rgba(255,255,255,.12) !important;
        backdrop-filter:blur(18px);
        -webkit-backdrop-filter:blur(18px);
    }

    .mobile-menu-panel > a:not(.mobile-whatsapp-btn),
    .mobile-menu-socials a{
        background:rgba(255,255,255,.08) !important;
        color:#ffffff !important;
    }

    .hero-wrap{
        max-width:none !important;
        width:100% !important;
        padding:0 !important;
        margin:0 !important;
    }

    .hero{
        position:relative;
        min-height:100svh !important;
        padding:152px 32px calc(28px + env(safe-area-inset-bottom)) !important;
        border-radius:0 !important;
        overflow:hidden;
        display:flex;
        flex-direction:column;
        justify-content:flex-start;
        background:
            radial-gradient(circle at 92% 20%, rgba(255,75,31,.18), transparent 28%),
            linear-gradient(180deg, rgba(2,8,18,.78) 0%, rgba(2,8,18,.78) 44%, rgba(2,8,18,.96) 100%),
            linear-gradient(90deg, rgba(2,8,18,.98) 0%, rgba(2,8,18,.76) 45%, rgba(2,8,18,.36) 100%),
            url("img/hero.png") 67% top / cover no-repeat !important;
        box-shadow:none !important;
    }

    .hero::before{
        content:"";
        position:absolute;
        inset:0;
        pointer-events:none;
        background:linear-gradient(90deg, rgba(2,8,18,.96) 0%, rgba(2,8,18,.74) 48%, rgba(2,8,18,.34) 100%);
        z-index:0;
    }

    .hero::after{
        content:"";
        position:absolute;
        left:-18%;
        right:-18%;
        bottom:-24%;
        height:46%;
        pointer-events:none;
        background:radial-gradient(circle, rgba(255,75,31,.18), transparent 64%);
        filter:blur(14px);
        z-index:0;
    }

    .hero-content,
    .hero-benefits,
    .rating-card,
    .mobile-hero-app-card{
        position:relative !important;
        z-index:2;
    }

    .hero-content{
        width:100% !important;
        padding:0 !important;
        color:#ffffff;
    }

    .hero-badge{
        display:inline-flex;
        align-items:center;
        width:auto;
        max-width:max-content;
        padding:10px 14px !important;
        margin:0 0 34px !important;
        border-radius:16px !important;
        background:rgba(255,255,255,.10) !important;
        border:1px solid rgba(255,255,255,.08);
        color:#ffffff;
        font-size:14px !important;
        font-weight:900;
        box-shadow:0 12px 28px rgba(0,0,0,.22);
        backdrop-filter:blur(10px);
        -webkit-backdrop-filter:blur(10px);
    }

    .hero-badge span{
        width:23px !important;
        height:23px !important;
        font-size:13px !important;
        box-shadow:0 8px 18px rgba(255,75,31,.32);
    }

    .hero h1{
        max-width:560px;
        margin:0 0 22px !important;
        color:#ffffff;
        font-size:clamp(39px, 10.7vw, 56px) !important;
        line-height:1.14 !important;
        letter-spacing:-1.7px !important;
        font-weight:950;
        text-shadow:0 16px 38px rgba(0,0,0,.38);
    }

    .hero p{
        max-width:460px;
        margin:0 0 30px !important;
        color:rgba(255,255,255,.86) !important;
        font-size:20px !important;
        line-height:1.55 !important;
        font-weight:500;
    }

    .hero-buttons{
        width:100%;
        margin:0 0 18px !important;
        display:block !important;
    }

    .hero-buttons .btn-orange{
        width:100% !important;
        min-height:72px;
        display:flex;
        align-items:center;
        justify-content:center;
        border-radius:18px !important;
        background:linear-gradient(135deg,#ff602d,#ff3d17) !important;
        color:#ffffff;
        font-size:18px !important;
        font-weight:950 !important;
        box-shadow:0 18px 44px rgba(255,75,31,.40), 0 0 28px rgba(255,75,31,.20) !important;
    }

    .hero-buttons .hero-app-install-btn{
        display:none !important;
    }

    .hero-content::after{
        content:"\f023  Конфиденциально и безопасно";
        font-family:Arial, sans-serif;
        display:flex;
        align-items:center;
        justify-content:center;
        gap:8px;
        margin:0 auto 24px;
        color:rgba(255,255,255,.72);
        font-size:14px;
        font-weight:700;
    }

    .hero-benefits{
        width:100% !important;
        margin:0 0 18px !important;
        padding:0 !important;
        display:grid !important;
        grid-template-columns:1fr 1fr !important;
        gap:0 !important;
        border:1px solid rgba(255,255,255,.14);
        border-radius:22px;
        background:rgba(255,255,255,.075);
        box-shadow:0 18px 46px rgba(0,0,0,.26);
        backdrop-filter:blur(16px);
        -webkit-backdrop-filter:blur(16px);
        overflow:hidden;
    }

    .hero-benefits .benefit:nth-child(2),
    .hero-benefits .benefit:nth-child(3){
        display:none !important;
    }

    .benefit{
        min-height:92px !important;
        padding:16px 18px !important;
        border-radius:0 !important;
        background:transparent !important;
        box-shadow:none !important;
        color:#ffffff !important;
        font-size:16px !important;
        font-weight:850 !important;
        line-height:1.25 !important;
        gap:13px !important;
    }

    .benefit:first-child{
        border-right:1px solid rgba(255,255,255,.09);
    }

    .benefit-icon{
        min-width:52px !important;
        width:52px !important;
        height:52px !important;
        border-radius:50% !important;
        background:radial-gradient(circle at 50% 30%, rgba(255,95,45,.30), rgba(255,255,255,.08)) !important;
        color:#ff6b38 !important;
        font-size:23px !important;
    }

    .rating-card{
        width:100% !important;
        margin:0 0 20px !important;
        padding:18px 18px !important;
        border-radius:23px !important;
        background:#ffffff !important;
        display:flex !important;
        align-items:center !important;
        gap:18px !important;
        box-shadow:0 22px 55px rgba(0,0,0,.30) !important;
    }

    .avatars{
        min-width:184px;
    }

    .avatar{
        width:43px !important;
        height:43px !important;
        border-width:3px !important;
        margin-left:-13px !important;
    }

    .avatar:first-child{
        margin-left:0 !important;
    }

    .more{
        width:56px !important;
        height:34px !important;
        margin-left:-10px !important;
        font-size:14px !important;
        color:#071739 !important;
        background:#f1f5fb !important;
    }

    .rating-text{
        flex:1;
        min-width:0;
    }

    .rating-text strong{
        display:block;
        margin-bottom:10px !important;
        color:#071739;
        font-size:17px !important;
        line-height:1.25 !important;
        font-weight:950;
    }

    .rating-text > div{
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:10px;
    }

    .stars{
        font-size:22px !important;
        letter-spacing:2px !important;
        color:#ff4b1f !important;
        white-space:nowrap;
    }

    .score{
        margin-left:0 !important;
        color:#071739 !important;
        font-size:15px !important;
        font-weight:950 !important;
        white-space:nowrap;
    }

    .mobile-hero-app-card{
        width:100%;
        min-height:90px;
        padding:16px 18px;
        border:1px solid rgba(255,255,255,.14);
        border-radius:22px;
        background:rgba(255,255,255,.075);
        color:#ffffff;
        display:flex;
        align-items:center;
        gap:16px;
        font-family:inherit;
        text-align:left;
        cursor:pointer;
        box-shadow:0 18px 46px rgba(0,0,0,.24);
        backdrop-filter:blur(16px);
        -webkit-backdrop-filter:blur(16px);
    }

    .mobile-hero-app-icon{
        width:52px;
        height:52px;
        border-radius:50%;
        display:flex;
        align-items:center;
        justify-content:center;
        background:radial-gradient(circle at 50% 30%, rgba(255,95,45,.30), rgba(255,255,255,.08));
        color:#ff6b38;
        font-size:25px;
        flex:0 0 auto;
    }

    .mobile-hero-app-text{
        display:grid;
        gap:4px;
        flex:1;
    }

    .mobile-hero-app-text strong{
        color:#ffffff;
        font-size:17px;
        font-weight:950;
        line-height:1.15;
    }

    .mobile-hero-app-text small{
        color:rgba(255,255,255,.78);
        font-size:14px;
        font-weight:700;
    }

    .mobile-hero-app-arrow{
        color:rgba(255,255,255,.72);
        font-size:22px;
    }

    .insurance-dashboard,
    .trust-section,
    .final-section{
        margin-top:0 !important;
    }

    .floating-chat,
    .site-chat-widget,
    .chat-widget,
    #siteChatWidget{
        z-index:900 !important;
    }
}

@media (max-width: 430px){
    .site-header{
        padding-left:26px !important;
        padding-right:26px !important;
    }

    .mobile-cabinet-link{
        height:56px !important;
        padding:0 15px !important;
        font-size:13px !important;
    }

    .mobile-burger{
        width:56px !important;
        height:56px !important;
    }

    .hero{
        padding-left:26px !important;
        padding-right:26px !important;
        padding-top:146px !important;
    }

    .hero h1{
        font-size:clamp(36px, 10.4vw, 44px) !important;
    }

    .hero p{
        font-size:18px !important;
    }

    .avatars{
        min-width:180px;
    }

    .rating-text strong{
        font-size:16px !important;
    }

    .stars{
        font-size:19px !important;
    }
}

@media (max-width: 380px){
    .site-header{
        padding-left:20px !important;
        padding-right:20px !important;
    }

    .logo{
        font-size:22px !important;
    }

    .mobile-cabinet-link{
        height:50px !important;
        padding:0 12px !important;
        font-size:12px !important;
        border-radius:16px !important;
    }

    .mobile-burger{
        width:50px !important;
        height:50px !important;
        border-radius:16px !important;
    }

    .hero{
        padding-left:20px !important;
        padding-right:20px !important;
        padding-top:132px !important;
    }

    .hero h1{
        font-size:34px !important;
    }

    .hero p{
        font-size:16px !important;
    }

    .rating-card{
        flex-direction:column;
        align-items:flex-start !important;
    }

    .avatars{
        min-width:0;
    }
}

/* =========================================================
   LÖWEN FDL — MOBILE HERO LAYOUT HOTFIX v2
   Исправляет наложение CTA / преимуществ / рейтинга на узких экранах.
   ========================================================= */
@media (max-width: 900px){
    .hero{
        display:block !important;
        min-height:auto !important;
        height:auto !important;
        padding-top:128px !important;
        padding-left:28px !important;
        padding-right:28px !important;
        padding-bottom:28px !important;
        overflow:hidden !important;
    }

    .hero-content{
        display:block !important;
        position:relative !important;
        z-index:4 !important;
        margin:0 0 16px !important;
    }

    .hero-badge{
        margin-bottom:28px !important;
    }

    .hero h1{
        max-width:100% !important;
        font-size:clamp(32px, 8.3vw, 43px) !important;
        line-height:1.09 !important;
        margin-bottom:18px !important;
        overflow:visible !important;
    }

    .hero p{
        max-width:100% !important;
        max-height:none !important;
        overflow:visible !important;
        font-size:16px !important;
        line-height:1.48 !important;
        margin-bottom:22px !important;
    }

    .hero-buttons{
        position:relative !important;
        z-index:6 !important;
        width:100% !important;
        display:block !important;
        margin:0 0 10px !important;
    }

    .hero-buttons .btn-orange{
        min-height:64px !important;
        padding:18px 16px !important;
        font-size:17px !important;
        line-height:1.15 !important;
        position:relative !important;
        z-index:7 !important;
    }

    .hero-content::after{
        margin:14px auto 18px !important;
        font-size:12px !important;
        position:relative !important;
        z-index:5 !important;
    }

    .hero-benefits{
        position:relative !important;
        inset:auto !important;
        left:auto !important;
        right:auto !important;
        top:auto !important;
        bottom:auto !important;
        transform:none !important;
        z-index:4 !important;
        width:100% !important;
        margin:0 0 22px !important;
        padding:0 !important;
        grid-template-columns:1fr 1fr !important;
    }

    .benefit{
        min-width:0 !important;
        min-height:78px !important;
        padding:14px 14px !important;
        font-size:14px !important;
        line-height:1.18 !important;
        gap:10px !important;
        overflow:hidden !important;
    }

    .benefit-icon{
        min-width:44px !important;
        width:44px !important;
        height:44px !important;
        font-size:19px !important;
    }

    .rating-card{
        position:relative !important;
        inset:auto !important;
        left:auto !important;
        right:auto !important;
        top:auto !important;
        bottom:auto !important;
        transform:none !important;
        z-index:4 !important;
        width:100% !important;
        margin:0 0 20px !important;
        padding:16px 16px !important;
        gap:14px !important;
    }

    .avatars{
        min-width:112px !important;
        width:112px !important;
        flex:0 0 112px !important;
    }

    .avatar{
        width:31px !important;
        height:31px !important;
        margin-left:-9px !important;
    }

    .more{
        width:45px !important;
        height:28px !important;
        margin-left:-8px !important;
        font-size:12px !important;
    }

    .rating-text strong{
        font-size:15px !important;
        line-height:1.22 !important;
        margin-bottom:8px !important;
    }

    .stars{
        font-size:17px !important;
        letter-spacing:2px !important;
    }

    .score{
        font-size:13px !important;
    }

    .mobile-hero-app-card{
        position:relative !important;
        z-index:4 !important;
        min-height:74px !important;
        padding:14px 16px !important;
    }

    .mobile-hero-app-icon{
        width:46px !important;
        height:46px !important;
        font-size:22px !important;
    }

    .site-chat-widget,
    #siteChatWidget{
        z-index:850 !important;
    }
}

@media (max-width: 430px){
    .hero{
        padding-top:124px !important;
        padding-left:24px !important;
        padding-right:24px !important;
    }

    .hero h1{
        font-size:clamp(31px, 8.8vw, 38px) !important;
    }

    .hero p{
        font-size:15px !important;
    }

    .benefit{
        font-size:13px !important;
        padding:13px 12px !important;
    }

    .benefit-icon{
        min-width:40px !important;
        width:40px !important;
        height:40px !important;
    }

    .rating-card{
        align-items:center !important;
    }

    .avatars{
        min-width:105px !important;
        width:105px !important;
        flex-basis:105px !important;
    }

    .rating-text strong{
        font-size:14px !important;
    }

    .stars{
        font-size:15px !important;
    }
}

@media (max-width: 380px){
    .hero{
        padding-top:116px !important;
        padding-left:18px !important;
        padding-right:18px !important;
    }

    .hero h1{
        font-size:31px !important;
    }

    .hero-benefits{
        grid-template-columns:1fr !important;
    }

    .benefit:first-child{
        border-right:0 !important;
        border-bottom:1px solid rgba(255,255,255,.09) !important;
    }

    .rating-card{
        flex-direction:column !important;
        align-items:flex-start !important;
    }
}


/* =========================================================
   PREMIUM MEGA MENU + MOBILE FULLSCREEN MENU
   ========================================================= */
.site-header{
    position:relative;
    z-index:5000;
}

.main-nav{
    gap:26px;
}

.nav-mega-item{
    position:relative;
}

.nav-mega-trigger{
    height:48px;
    padding:0 23px;
    border:0;
    border-radius:14px;
    background:#070c24;
    color:#ffffff;
    font-family:inherit;
    font-size:15px;
    font-weight:900;
    display:inline-flex;
    align-items:center;
    gap:10px;
    cursor:pointer;
    box-shadow:0 16px 36px rgba(7,12,36,.20);
    transition:.22s ease;
}

.nav-mega-trigger i{
    font-size:11px;
    transition:.22s ease;
}

.nav-mega-item:hover .nav-mega-trigger,
.nav-mega-item.mega-open .nav-mega-trigger{
    transform:translateY(-1px);
    box-shadow:0 18px 40px rgba(255,75,31,.20), 0 16px 36px rgba(7,12,36,.18);
}

.nav-mega-item:hover .nav-mega-trigger i,
.nav-mega-item.mega-open .nav-mega-trigger i{
    transform:rotate(180deg);
}

.desktop-mega-menu{
    position:fixed;
    left:50%;
    top:86px;
    transform:translateX(-50%) translateY(-10px);
    width:min(1460px, calc(100vw - 58px));
    min-height:310px;
    padding:34px 38px;
    border-radius:24px;
    background:linear-gradient(145deg, rgba(8,15,32,.97), rgba(5,10,22,.94));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:0 34px 90px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06);
    backdrop-filter:blur(22px);
    -webkit-backdrop-filter:blur(22px);
    display:grid;
    grid-template-columns:repeat(5, 1fr);
    gap:32px;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:.24s ease;
}

.nav-mega-item:hover .desktop-mega-menu,
.nav-mega-item.mega-open .desktop-mega-menu{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0);
}

.desktop-mega-menu::before{
    content:"";
    position:absolute;
    top:-10px;
    left:340px;
    width:22px;
    height:22px;
    background:rgba(8,15,32,.97);
    border-left:1px solid rgba(255,255,255,.12);
    border-top:1px solid rgba(255,255,255,.12);
    transform:rotate(45deg);
}

.mega-column{
    position:relative;
    padding-right:20px;
}

.mega-column:not(:last-child)::after{
    content:"";
    position:absolute;
    top:0;
    right:0;
    width:1px;
    height:100%;
    background:linear-gradient(180deg, transparent, rgba(255,255,255,.22), transparent);
}

.mega-title{
    display:flex;
    align-items:center;
    gap:13px;
    color:#ffffff;
    font-size:18px;
    font-weight:1000;
    line-height:1.2;
    margin-bottom:22px;
}

.mega-title i{
    width:34px;
    height:34px;
    border-radius:12px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:#ff6a3d;
    background:rgba(255,75,31,.12);
    border:1px solid rgba(255,75,31,.24);
}

.mega-column:nth-child(1) .mega-title i{color:#8a8cff;background:rgba(90,92,255,.13);border-color:rgba(90,92,255,.24);}
.mega-column:nth-child(2) .mega-title i{color:#ff916d;background:rgba(255,111,60,.13);border-color:rgba(255,111,60,.24);}
.mega-column:nth-child(3) .mega-title i{color:#d86bff;background:rgba(216,107,255,.13);border-color:rgba(216,107,255,.24);}
.mega-column:nth-child(4) .mega-title i{color:#4ab7ff;background:rgba(74,183,255,.13);border-color:rgba(74,183,255,.24);}
.mega-column:nth-child(5) .mega-title i{color:#72f283;background:rgba(114,242,131,.13);border-color:rgba(114,242,131,.24);}

.mega-column a{
    display:block;
    color:rgba(255,255,255,.78);
    text-decoration:none;
    font-size:16px;
    line-height:1.3;
    margin-bottom:15px;
    transition:.18s ease;
}

.mega-column a:hover{
    color:#ffffff;
    transform:translateX(4px);
}

body.mobile-menu-open{
    overflow:hidden;
}

@media (max-width:900px){
    .mobile-menu{
        position:fixed !important;
        inset:0 !important;
        z-index:99999 !important;
        padding:0 !important;
        display:block !important;
        opacity:0 !important;
        visibility:hidden !important;
        pointer-events:none !important;
        transform:none !important;
        background:
            radial-gradient(circle at 100% 0%, rgba(255,75,31,.22), transparent 34%),
            radial-gradient(circle at 0% 100%, rgba(61,121,255,.16), transparent 34%),
            linear-gradient(180deg, rgba(2,7,18,.98), rgba(3,9,22,.98)) !important;
        transition:.24s ease !important;
    }

    .mobile-menu.active{
        opacity:1 !important;
        visibility:visible !important;
        pointer-events:auto !important;
    }

    .mobile-menu-shell{
        width:100%;
        max-width:520px;
        height:100%;
        margin:0 auto;
        padding:calc(34px + env(safe-area-inset-top)) 22px calc(26px + env(safe-area-inset-bottom));
        overflow-y:auto;
    }

    .mobile-menu-head{
        display:flex;
        align-items:flex-start;
        justify-content:space-between;
        gap:20px;
        margin-bottom:28px;
    }

    .mobile-menu-logo{
        color:#ffffff;
        font-size:28px;
        line-height:1;
        font-weight:1000;
        letter-spacing:-1px;
    }

    .mobile-menu-logo span{
        color:#ff2418;
    }

    .mobile-menu-logo small{
        display:block;
        color:rgba(255,255,255,.72);
        font-size:9px;
        letter-spacing:7px;
        margin-top:8px;
        padding-left:4px;
    }

    .mobile-menu-close{
        width:44px;
        height:44px;
        border:0;
        background:transparent;
        color:#ffffff;
        font-size:34px;
        display:grid;
        place-items:center;
        cursor:pointer;
    }

    .mobile-menu-screen{
        display:none;
        animation:mobileMenuIn .22s ease both;
    }

    .mobile-menu-screen.active{
        display:block;
    }

    @keyframes mobileMenuIn{
        from{opacity:0; transform:translateX(12px);}
        to{opacity:1; transform:translateX(0);}
    }

    .mobile-menu-row,
    .mobile-category-card,
    .mobile-menu-cabinet{
        width:100%;
        min-height:76px;
        padding:0 18px;
        border-radius:18px;
        border:1px solid rgba(255,255,255,.09);
        background:linear-gradient(145deg, rgba(255,255,255,.095), rgba(255,255,255,.035));
        color:#ffffff;
        text-decoration:none;
        display:grid;
        grid-template-columns:48px 1fr auto;
        align-items:center;
        gap:16px;
        margin-bottom:10px;
        box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
        backdrop-filter:blur(18px);
        -webkit-backdrop-filter:blur(18px);
        font-family:inherit;
        cursor:pointer;
        text-align:left;
    }

    .mobile-menu-row:first-child{
        border-color:rgba(255,31,18,.58);
        box-shadow:0 0 36px rgba(255,31,18,.12), inset 0 1px 0 rgba(255,255,255,.07);
    }

    .mobile-menu-row strong,
    .mobile-menu-cabinet{
        font-size:20px;
        font-weight:1000;
    }

    .menu-row-icon,
    .category-icon{
        width:48px;
        height:48px;
        border-radius:16px;
        display:grid;
        place-items:center;
        font-size:22px;
        color:#dce6ff;
    }

    .menu-row-icon.purple,
    .category-icon.purple{background:rgba(116,83,255,.20); color:#a993ff;}
    .menu-row-icon.white{background:transparent; color:rgba(255,255,255,.82);}
    .category-icon.orange{background:rgba(255,111,60,.18); color:#ff825c;}
    .category-icon.green{background:rgba(43,229,120,.16); color:#2be578;}
    .category-icon.blue{background:rgba(56,166,255,.16); color:#38a6ff;}
    .category-icon.yellow{background:rgba(255,196,57,.16); color:#ffc439;}

    .premium-mobile-socials{
        display:flex !important;
        justify-content:center;
        gap:22px;
        padding:16px 0 20px !important;
    }

    .premium-mobile-socials a{
        width:58px !important;
        height:58px !important;
        border-radius:50% !important;
        color:#ffffff !important;
        background:rgba(255,255,255,.04) !important;
        border:1px solid rgba(255,255,255,.11);
        font-size:25px !important;
    }

    .mobile-menu-cabinet{
        grid-template-columns:48px 1fr;
        min-height:72px;
        background:linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.032));
    }

    .mobile-menu-cabinet i{
        font-size:24px;
        color:rgba(255,255,255,.75);
    }

    .mobile-whatsapp-btn{
        height:72px !important;
        margin-top:16px !important;
        border-radius:18px !important;
        font-size:22px !important;
        gap:12px;
        box-shadow:0 18px 42px rgba(255,31,18,.28) !important;
    }

    .mobile-menu-back{
        height:44px;
        border:0;
        background:transparent;
        color:#ffffff;
        font-size:16px;
        font-weight:800;
        display:inline-flex;
        align-items:center;
        gap:12px;
        margin-bottom:24px;
        cursor:pointer;
    }

    .mobile-submenu-title{
        display:flex;
        align-items:center;
        gap:18px;
        margin-bottom:26px;
    }

    .mobile-submenu-title > span{
        width:62px;
        height:62px;
        border-radius:18px;
        display:grid;
        place-items:center;
        background:rgba(116,83,255,.18);
        color:#aa98ff;
        font-size:30px;
    }

    .mobile-submenu-title strong{
        display:block;
        color:#ffffff;
        font-size:30px;
        line-height:1.05;
        font-weight:1000;
    }

    .mobile-submenu-title small{
        display:block;
        color:rgba(255,255,255,.62);
        font-size:17px;
        margin-top:8px;
    }

    .mobile-category-card{
        min-height:104px;
        grid-template-columns:64px 1fr auto;
        padding:16px;
        border-radius:22px;
        margin-bottom:13px;
    }

    .mobile-category-card strong{
        display:block;
        color:#ffffff;
        font-size:20px;
        line-height:1.2;
        margin-bottom:7px;
        font-weight:1000;
    }

    .mobile-category-card small{
        display:block;
        color:rgba(255,255,255,.62);
        font-size:15px;
        line-height:1.38;
    }

    .mobile-category-card .category-icon{
        width:64px;
        height:64px;
        border-radius:22px;
        font-size:27px;
    }
}

@media (max-width:380px){
    .mobile-menu-shell{
        padding-left:18px;
        padding-right:18px;
    }

    .mobile-menu-row strong,
    .mobile-category-card strong{
        font-size:18px;
    }

    .mobile-category-card small{
        font-size:14px;
    }
}

/* =========================================================
   DESKTOP SAFETY GUARD — prevents mobile layout on PC/laptop
   Mobile design is now only for real touch phones/tablets.
========================================================= */
@media (max-width: 900px) and (hover: hover) and (pointer: fine) {
    html,
    body{
        background:#f5f7fb !important;
        overflow-x:hidden !important;
    }

    .site-header{
        position:relative !important;
        top:auto !important;
        left:auto !important;
        right:auto !important;
        z-index:100 !important;
        background:#ffffff !important;
        padding:18px 38px 14px !important;
        box-shadow:none !important;
    }

    .header-inner{
        max-width:1500px !important;
        margin:0 auto !important;
        display:flex !important;
        align-items:center !important;
        justify-content:space-between !important;
        gap:30px !important;
        flex-wrap:nowrap !important;
    }

    .logo{
        color:#071739 !important;
        font-size:28px !important;
        letter-spacing:-1px !important;
        text-shadow:none !important;
    }

    .logo span{color:#ff4b1f !important;}

    .logo small{
        color:#7b8495 !important;
        font-size:8px !important;
        letter-spacing:7px !important;
        margin-top:5px !important;
    }

    .nav,
    .main-nav,
    .header-actions{
        display:flex !important;
    }

    .mobile-header-actions,
    .mobile-menu,
    .mobile-hero-app-card{
        display:none !important;
    }

    .hero-wrap{
        max-width:1500px !important;
        margin:0 auto !important;
        padding:0 30px !important;
        width:auto !important;
    }

    .hero{
        min-height:515px !important;
        border-radius:18px !important;
        padding-bottom:0 !important;
        background:
            linear-gradient(90deg, rgba(5,15,38,.98) 0%, rgba(5,15,38,.92) 35%, rgba(5,15,38,.25) 62%, rgba(5,15,38,.05) 100%),
            url("img/hero.png") center right / cover no-repeat !important;
    }

    .hero-content{
        width:48% !important;
        padding:21px 0 0 50px !important;
    }

    .hero h1{
        font-size:39px !important;
        line-height:1.03 !important;
    }

    .hero p{
        font-size:16px !important;
    }

    .hero-buttons{
        flex-direction:row !important;
        align-items:center !important;
        gap:28px !important;
    }

    .hero-buttons .btn-orange{
        width:auto !important;
    }

    .hero-benefits{
        position:absolute !important;
        left:50px !important;
        bottom:28px !important;
        width:820px !important;
        padding:0 !important;
        margin:0 !important;
        grid-template-columns:repeat(4, 1fr) !important;
    }

    .benefit{
        min-height:auto !important;
        font-size:13px !important;
        padding:18px !important;
        border-radius:14px !important;
    }

    .benefit-icon{
        min-width:34px !important;
        height:34px !important;
        font-size:18px !important;
    }

    .rating-card{
        position:absolute !important;
        right:5px !important;
        left:auto !important;
        bottom:30px !important;
        width:320px !important;
        margin:0 !important;
    }
}

/* =========================================================
   DESKTOP DENSITY FIX — визуально ближе к 80% browser zoom
   Только ПК. Mobile до 900px не трогаем.
========================================================= */
@media (min-width: 901px){
    .site-header{
        padding:12px 28px 10px !important;
    }

    .header-inner,
    .hero-wrap,
    .insurance-dashboard,
    .trust-section,
    .final-section,
    .footer-inner{
        max-width:1760px !important;
    }

    .header-inner{
        gap:22px !important;
    }

    .logo{
        font-size:24px !important;
    }

    .logo small{
        font-size:7px !important;
        letter-spacing:6px !important;
        margin-top:4px !important;
    }

    .nav{
        gap:28px !important;
        font-size:12px !important;
    }

    .nav-mega-trigger{
        min-height:46px !important;
        padding:0 22px !important;
        border-radius:14px !important;
        font-size:13px !important;
    }

    .header-actions{
        gap:14px !important;
    }

    .header-socials-wrap{
        padding:3px !important;
        border-radius:13px !important;
    }

    .header-socials a{
        width:28px !important;
        height:28px !important;
        font-size:14px !important;
    }

    .cabinet-link{
        height:48px !important;
        padding:0 22px !important;
        border-radius:14px !important;
        font-size:13px !important;
    }

    .header-actions .btn-orange{
        min-height:48px !important;
        padding:0 24px !important;
        border-radius:14px !important;
        font-size:13px !important;
        display:inline-flex !important;
        align-items:center !important;
        justify-content:center !important;
    }

    .hero-wrap{
        padding:0 24px !important;
    }

    .hero{
        min-height:470px !important;
        border-radius:17px !important;
    }

    .hero-content{
        width:46% !important;
        padding:24px 0 0 44px !important;
    }

    .hero-badge{
        padding:6px 14px !important;
        font-size:12px !important;
        margin-bottom:26px !important;
        border-radius:11px !important;
    }

    .hero h1{
        font-size:36px !important;
        line-height:1.05 !important;
        max-width:520px !important;
        margin-bottom:20px !important;
    }

    .hero p{
        font-size:15px !important;
        line-height:1.52 !important;
        max-width:560px !important;
        margin-bottom:28px !important;
    }

    .hero-buttons{
        gap:20px !important;
        margin-bottom:34px !important;
    }

    .btn-orange{
        padding:15px 24px !important;
        border-radius:10px !important;
        font-size:14px !important;
    }

    .hero-app-install-btn{
        min-height:52px !important;
        padding:8px 16px 8px 11px !important;
        border-radius:13px !important;
    }

    .hero-app-install-icon{
        width:36px !important;
        height:36px !important;
        font-size:18px !important;
    }

    .hero-app-install-text strong{
        font-size:13px !important;
    }

    .hero-app-install-text small{
        font-size:11px !important;
    }

    .hero-benefits{
        left:44px !important;
        bottom:24px !important;
        width:760px !important;
        gap:12px !important;
    }

    .benefit{
        padding:15px !important;
        border-radius:13px !important;
        font-size:12px !important;
        gap:10px !important;
    }

    .benefit-icon{
        min-width:30px !important;
        height:30px !important;
        font-size:16px !important;
        border-radius:9px !important;
    }

    .rating-card{
        width:290px !important;
        right:18px !important;
        bottom:26px !important;
        padding:14px 16px !important;
        border-radius:13px !important;
    }

    .avatar{
        width:30px !important;
        height:30px !important;
    }

    .more{
        width:38px !important;
        height:22px !important;
        font-size:9px !important;
    }

    .rating-text strong{
        font-size:12px !important;
    }

    .stars{
        font-size:15px !important;
    }

    .score{
        font-size:12px !important;
    }

    .insurance-dashboard{
        margin-top:22px !important;
        padding:28px !important;
        border-radius:24px !important;
    }

    .dashboard-grid{
        gap:18px !important;
        margin-bottom:20px !important;
    }

    .dash-main{
        min-height:380px !important;
        padding:36px !important;
        border-radius:22px !important;
    }

    .dash-main h2{
        font-size:40px !important;
    }

    .dash-main p,
    .dash-compare-intro p{
        font-size:16px !important;
        margin-bottom:34px !important;
    }

    .dash-service{
        min-height:165px !important;
        padding:28px !important;
        border-radius:22px !important;
    }

    .dash-icon{
        width:50px !important;
        height:50px !important;
        font-size:21px !important;
        margin-bottom:22px !important;
    }

    .dash-service h3{
        font-size:22px !important;
    }

    .dash-service p{
        font-size:14px !important;
    }

    .compare-dashboard{
        gap:18px !important;
    }

    .dash-compare-intro,
    .dash-compare-card{
        min-height:260px !important;
        padding:32px 34px !important;
        border-radius:22px !important;
    }

    .dash-compare-intro h2{
        font-size:31px !important;
    }

    .dash-compare-card h3{
        font-size:24px !important;
        margin-bottom:26px !important;
    }

    .dash-compare-card li{
        font-size:15px !important;
        margin-bottom:15px !important;
        padding-left:34px !important;
    }

    .trust-section,
    .final-section{
        margin-top:22px !important;
        padding-left:24px !important;
        padding-right:24px !important;
        gap:20px !important;
    }

    .reviews-card,
    .about-card,
    .lead-form-card,
    .life-card,
    .office-card{
        border-radius:24px !important;
        padding:28px !important;
    }

    .trust-section h2{
        font-size:30px !important;
    }

    .section-desc{
        font-size:14px !important;
    }

    .desktop-mega-menu{
        max-width:1680px !important;
        padding:36px 42px !important;
        gap:28px !important;
    }

    .mega-title{
        font-size:18px !important;
    }

    .mega-column a{
        font-size:15px !important;
        margin-top:15px !important;
    }
}


/* =========================================================
   CABINET / CRM DESKTOP DENSITY FIX — общий масштаб как main site
   Только ПК. Mobile до 900px не трогаем.
========================================================= */
@media (min-width: 901px){

    /* Login / auth */
    .login-box{
        width:380px !important;
        padding:40px !important;
        border-radius:24px !important;
    }

    .login-logo{
        font-size:24px !important;
        margin-bottom:30px !important;
    }

    .login-box h1{
        font-size:30px !important;
    }

    .login-box p{
        margin-bottom:28px !important;
        font-size:14px !important;
    }

    .input-box input,
    .login-btn{
        height:52px !important;
        border-radius:14px !important;
        font-size:15px !important;
    }

    /* Cabinet dashboard */
    .cabinet-app{
        grid-template-columns:240px 1fr !important;
    }

    .cabinet-sidebar{
        padding:22px !important;
    }

    .cabinet-brand{
        gap:12px !important;
        margin-bottom:28px !important;
    }

    .cabinet-brand-icon{
        width:42px !important;
        height:42px !important;
        border-radius:14px !important;
        font-size:21px !important;
    }

    .cabinet-brand strong{
        font-size:19px !important;
    }

    .cabinet-brand small{
        font-size:9px !important;
        letter-spacing:2.5px !important;
    }

    .cabinet-nav{
        gap:8px !important;
    }

    .cabinet-nav a,
    .cabinet-nav button{
        min-height:42px !important;
        padding:0 14px !important;
        border-radius:13px !important;
        font-size:13px !important;
        gap:10px !important;
    }

    .cabinet-main{
        padding:26px !important;
    }

    .cabinet-topbar{
        margin-bottom:22px !important;
        gap:16px !important;
    }

    .cabinet-kicker{
        font-size:12px !important;
        margin-bottom:8px !important;
    }

    .cabinet-topbar h1{
        font-size:34px !important;
        letter-spacing:-1px !important;
    }

    .cabinet-topbar p{
        font-size:14px !important;
    }

    .cabinet-user-card{
        min-width:230px !important;
        padding:15px !important;
        border-radius:18px !important;
    }

    .cabinet-grid{
        grid-template-columns:repeat(4, minmax(0,1fr)) !important;
        gap:14px !important;
        margin-bottom:18px !important;
    }

    .cabinet-card{
        min-height:135px !important;
        padding:20px !important;
        border-radius:20px !important;
    }

    .cabinet-card-icon{
        width:42px !important;
        height:42px !important;
        border-radius:14px !important;
        font-size:18px !important;
        margin-bottom:16px !important;
    }

    .cabinet-card h3{
        font-size:18px !important;
        margin-bottom:7px !important;
    }

    .cabinet-card p{
        font-size:13px !important;
        line-height:1.45 !important;
    }

    .cabinet-panel{
        padding:22px !important;
        border-radius:22px !important;
    }

    .cabinet-panel h2{
        font-size:23px !important;
    }

    .cabinet-panel p{
        font-size:14px !important;
    }

    /* Admin / CRM */
    .admin-app{
        grid-template-columns:240px 1fr !important;
    }

    .admin-sidebar{
        padding:22px !important;
    }

    .admin-brand{
        gap:12px !important;
        margin-bottom:28px !important;
    }

    .admin-brand-icon{
        width:42px !important;
        height:42px !important;
        border-radius:13px !important;
        font-size:21px !important;
    }

    .admin-brand strong{
        font-size:18px !important;
    }

    .admin-nav{
        gap:8px !important;
    }

    .admin-nav a,
    .admin-nav button{
        padding:12px 14px !important;
        border-radius:13px !important;
        font-size:13px !important;
    }

    .admin-main{
        padding:26px !important;
    }

    .admin-topbar{
        gap:18px !important;
        margin-bottom:22px !important;
    }

    .admin-topbar span{
        font-size:12px !important;
    }

    .admin-topbar h1{
        font-size:34px !important;
        margin-top:6px !important;
    }

    .admin-topbar p{
        font-size:14px !important;
    }

    .admin-user-box{
        min-width:230px !important;
        padding:16px !important;
        border-radius:18px !important;
    }

    .admin-stats{
        gap:14px !important;
        margin-bottom:22px !important;
    }

    .admin-stat-card{
        padding:20px !important;
        border-radius:20px !important;
    }

    .admin-stat-card strong{
        font-size:32px !important;
        margin:9px 0 !important;
    }

    .admin-panel{
        padding:22px !important;
        border-radius:22px !important;
    }

    .admin-panel-head{
        margin-bottom:20px !important;
    }

    .admin-panel-head h2{
        font-size:24px !important;
    }

    .admin-add-btn{
        height:42px !important;
        padding:0 18px !important;
        border-radius:13px !important;
        font-size:13px !important;
    }

    .admin-table th,
    .admin-table td{
        padding:13px !important;
        font-size:13px !important;
    }
}

/* =========================================================
   DESKTOP SAFETY: если на ПК окно узкое, не проваливаемся в phone app layout
========================================================= */
@media (max-width: 900px) and (hover: hover) and (pointer: fine){
    .cabinet-app{
        grid-template-columns:240px 1fr !important;
    }

    .cabinet-main{
        padding:26px !important;
    }

    .cabinet-sidebar{
        padding:22px !important;
    }

    .cabinet-grid{
        grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    }

    .admin-app{
        grid-template-columns:240px 1fr !important;
    }

    .admin-main{
        padding:26px !important;
    }

    .admin-sidebar{
        padding:22px !important;
    }

    .admin-stats{
        grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    }
}@media (max-width: 900px){

    .mobile-header-actions{
        transform: translateY(17px) !important;
    }

}@media (max-width:900px){

    .dental-v2-content{
        padding-top:900px !important;
    }

    .dental-v2-btn{
        margin-top:14px !important;
        margin-bottom:28px !important;
        position:relative !important;
        z-index:5 !important;
    }

    .dental-v2-benefits{
        margin-top:26px !important;
    }

}@media (max-width:900px){

    .team-card{
        height: 630px !important;
    }

    .team-card img{
        object-position:center top !important;
    }

}
