/*
Theme Name: Astra Child - Krasiva
Theme URI: http://localhost:9090
Description: Krasiva Studio child theme based on Astra
Author: Krasiva Studio
Template: astra
Version: 1.0.0
*/

/* === GLOBAL === */
:root {
    --c-brown:    #422A00;
    --c-brown-dk: #271900;
    --c-brown-md: #55391C;
    --c-bg:       #ECE7E0;
    --c-bg2:      #F2F1EC;
    --c-text:     #4F4637;
    --c-grey:     #7A7A7A;
    --c-border:   #C4BFB9;
    --c-accent:   #B19983;
}

body {
    background: var(--c-bg);
    color: var(--c-text);
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-weight: 500;
}

a { color: var(--c-text); }
a:hover { color: var(--c-brown); }

h1,h2,h3,h4 { font-family: "Spectral", serif; color: var(--c-text); }
h1 { font-size: 45px; font-weight: 200; letter-spacing: -1.2px; }
h2 { font-size: 46px; font-weight: 300; letter-spacing: -2.2px; }
h5,h6 { font-family: "Arial", sans-serif; }

/* Header */
.site-header, #masthead, .main-header-bar { background: var(--c-bg) !important; border-bottom: 1px solid var(--c-border); }
.site-title a { color: var(--c-brown) !important; }
.menu-item a { font-family: "Montserrat", sans-serif; font-size: 13px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.7px; color: var(--c-text) !important; }
.menu-item a:hover { color: var(--c-brown) !important; }

/* Logo – image logo (2026-06-08: show logo image, hide text title per client) */
.custom-logo-link { display: inline-block !important; }
.ast-site-identity .site-title,
.ast-site-title-wrap,
.ast-site-identity .site-description { display: none !important; }
.ast-site-identity { display: flex; align-items: center; }
.ast-site-identity .site-title a {
    font-family: 'Cinzel Decorative', serif !important;
    font-size: 19px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    color: var(--c-brown) !important;
    text-decoration: none !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}
body.page-template-page-home .ast-site-identity .site-title a { color: #fff !important; }
@media (max-width: 767px) {
    .ast-site-identity .site-title a { font-size: 15px !important; }
}

/* Buttons global */
.ast-button, .button, button, input[type="button"], input[type="submit"] {
    background: var(--c-brown) !important;
    color: #fff !important;
    font-family: "Montserrat", sans-serif;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.7px;
    border: 1px solid var(--c-brown);
    border-radius: 0 !important;
    padding: 12px 28px;
}
.ast-button:hover, .button:hover, button:hover { background: var(--c-brown-dk) !important; }

/* Footer */
.site-footer, #colophon { background: var(--c-brown); color: #fff; }
.site-footer a { color: var(--c-border); }
.site-footer a:hover { color: #fff; }

/* WooCommerce */
.woocommerce-Price-amount { color: var(--c-brown) !important; }
.woocommerce span.onsale { background: var(--c-brown); border-radius: 0; }
.site-content, #content { background: var(--c-bg); }

/* Hide page stuff on home */
.page-template-page-home .entry-title,
.page-template-page-home .ast-breadcrumbs-wrapper { display: none !important; }
.page-template-page-home .entry-content,
.page-template-page-home .site-content { padding: 0 !important; margin: 0 !important; }
.page-template-page-home #content { padding: 0 !important; }
.page-template-page-home .ast-container { max-width: 100% !important; padding: 0 !important; }

/* ==============================
   HOME PAGE
   ============================== */

#krasiva-home { font-family: "Montserrat", sans-serif; }

/* HERO */
.kh-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    text-align: center;
    overflow: hidden;
}
.kh-hero__bg {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center 22%;
    background-repeat: no-repeat;
}
.kh-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, var(--c-brown-md) 0%, var(--c-brown-md) 100%);
    opacity: 0.44;
}
.kh-hero__content {
    position: relative;
    z-index: 2;
    color: #fff;
    padding: 0 20px 200px;
    width: 100%;
}
.kh-hero__content h1 {
    font-family: "Spectral", serif;
    font-size: 73px;
    font-weight: 300;
    color: #fff;
    letter-spacing: -2px;
    margin-bottom: 20px;
    line-height: 1.05;
}
.kh-hero__content h1 em { font-style: italic; }
.kh-hero__content p {
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    color: #fff;
    line-height: 1.8;
    max-width: 520px;
    margin: 0 auto 32px;
    opacity: 0.9;
}

/* BUTTONS */
.kh-btn {
    display: inline-block;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.4px;
    text-decoration: none;
    padding: 25px 25px;
    border: 2px solid currentColor;
    border-radius: 0;
    transition: all 0.25s;
    line-height: 1;
}
.kh-btn--outline { color: #fff; border-color: #fff; background: transparent; }
.kh-btn--outline:hover { background: #fff; color: var(--c-brown); }
/* "ЗАПИШИ ЧАС" button inside the dark "why us" section — make it pop */
.kh-why .kh-btn { background: #fff !important; color: var(--c-brown) !important; border-color: #fff !important; }
.kh-why .kh-btn:hover { background: transparent !important; color: #fff !important; border-color: #fff !important; }
.kh-btn--outline-sm {
    display: inline-block;
    font-family: "Montserrat", sans-serif;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.3px;
    text-decoration: none;
    padding: 20px 40px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #fff;
    transition: opacity 0.25s;
}
.kh-btn--outline-sm:hover { opacity: 0.7; color: #fff; }

/* FEATURE */
.kh-feature {
    position: relative;
    overflow: hidden;
    min-height: 500px;
}
.kh-feature__bg {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: 0px 100%;
    background-repeat: no-repeat;
}
.kh-feature__gradient {
    position: absolute; inset: 0;
    background: linear-gradient(181deg, var(--c-brown-md) 51%, rgba(255,255,255,0.52) 83%);
}
.kh-feature__inner {
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 50px 80px;
    gap: 60px;
}
.kh-feature__text { flex: 0 0 30%; }
.kh-feature__text h2 {
    font-family: "Spectral", serif;
    font-size: 41px;
    font-weight: 300;
    color: #fff;
    letter-spacing: -1px;
    margin-bottom: 16px;
    line-height: 1.15;
}
.kh-italic {
    font-family: "EB Garamond", serif;
    font-size: 20px;
    font-weight: 300;
    font-style: italic;
    color: #fff;
    margin-bottom: 20px;
    letter-spacing: 0.1px;
}
.kh-feature__text p:not(.kh-italic) {
    font-family: "Lato", sans-serif;
    font-size: 14px;
    color: #fff;
    line-height: 1.9;
    margin-bottom: 28px;
}
.kh-feature__products { flex: 0 0 50%; }
.kh-feature__img-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.kh-feature__img-row img {
    width: 100%;
    aspect-ratio: 3/4;
    object-fit: cover;
    background: #f5f1ec;
}
.kh-feature__labels {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 10px;
    font-size: 12px;
    color: rgba(255,255,255,0.8);
}
.kh-feature__labels strong { color: #fff; display: block; }

/* INGREDIENTS */
.kh-ingredients {
    background: var(--c-bg2);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 100px 50px;
    gap: 60px;
    min-height: 400px;
}
.kh-ingredients__text { text-align: center; }
.kh-ingredients__text h2 {
    font-family: "Spectral", serif;
    font-size: 41px;
    font-weight: 300;
    color: var(--c-text);
    letter-spacing: -1.5px;
    margin-bottom: 16px;
    line-height: 1.15;
}
.kh-ingredients__text .kh-italic { color: var(--c-text); }
.kh-ingredients__img { position: relative; }
.kh-ingredients__img img {
    width: 320px;
    position: relative;
    top: 60px;
}

/* BESTSELLERS BANNER */
.kh-bestsellers-banner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
}
.kh-bestsellers-banner__bg {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: 50% -200px;
    background-repeat: no-repeat;
}
.kh-bestsellers-banner__overlay {
    position: absolute; inset: 0;
    background: var(--c-brown-md);
    opacity: 0.39;
}
.kh-bestsellers-banner__content {
    position: relative;
    z-index: 2;
    color: #fff;
    padding: 150px 40px 250px;
}
.kh-bestsellers-banner__content h2 {
    font-family: "Spectral", serif;
    font-size: 41px;
    font-weight: 300;
    color: #fff;
    letter-spacing: -1.5px;
    margin-bottom: 16px;
}
.kh-bestsellers-banner__content .kh-italic { color: #fff; }

/* PRODUCTS GRID */
.kh-products-grid {
    background: var(--c-bg);
    padding: 0 60px 80px;
    margin-top: -148px;
    position: relative;
    z-index: 2;
}
.kh-products {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    max-width: 1140px;
    margin: 0 auto;
}
.kh-product a { text-decoration: none; }
.kh-product__img {
    background: #f0ece6;
    overflow: hidden;
    aspect-ratio: 3/4;
    margin-bottom: 14px;
}
.kh-product__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s;
}
.kh-product:hover .kh-product__img img { transform: scale(1.04); }
.kh-product h5 {
    font-family: "Montserrat", sans-serif;
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.7px;
    color: var(--c-text);
    margin-bottom: 6px;
    line-height: 1.5;
}
.kh-price {
    font-size: 13px;
    color: var(--c-grey);
    font-family: "Montserrat", sans-serif;
}

/* COURSES */
.kh-courses {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 100vh;
    margin-top: 90px;
    overflow: hidden;
}
.kh-courses__images {
    display: grid;
    grid-template-columns: 2fr 1fr;
    overflow: hidden;
}
.kh-courses__img-main {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.kh-courses__img-side {
    width: 100%;
    height: 50%;
    object-fit: cover;
    align-self: end;
}
.kh-courses__text {
    background: var(--c-bg2);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 100px 100px;
}
.kh-courses__text h2 {
    font-family: "Spectral", serif;
    font-size: 41px;
    font-weight: 300;
    color: var(--c-text);
    letter-spacing: -1.5px;
    margin-bottom: 24px;
    line-height: 1.2;
}
.kh-link-underline {
    font-family: "Nunito Sans", sans-serif;
    font-size: 15px;
    font-weight: 800;
    text-decoration: underline;
    letter-spacing: 1.1px;
    color: var(--c-text);
    text-transform: uppercase;
}
.kh-link-underline:hover { color: var(--c-brown); }

/* FAQ */
.kh-faq {
    background: var(--c-bg);
    text-align: center;
    padding: 150px 40px;
}
.kh-faq h2 {
    font-family: "Spectral", serif;
    font-size: 41px;
    font-weight: 300;
    color: var(--c-text);
    letter-spacing: -1.5px;
    margin-bottom: 20px;
    line-height: 1.2;
}
.kh-faq p {
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-weight: 500;
    color: var(--c-text);
    margin-bottom: 5px;
    letter-spacing: 0.3px;
}
.kh-faq__sub { margin-bottom: 20px; }
.kh-phone {
    display: inline-block;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-weight: 800;
    color: var(--c-text);
    text-decoration: none;
    letter-spacing: 0.3px;
}
.kh-phone:hover { color: var(--c-brown); }

/* RESPONSIVE */
@media (max-width: 1024px) {
    .kh-hero__content h1 { font-size: 50px; }
    .kh-feature__inner { padding: 50px 40px; }
    .kh-products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .kh-hero__content h1 { font-size: 32px; }
    .kh-hero__content { padding: 0 20px 90px; }
    .kh-feature__inner { flex-direction: column; padding: 50px 20px; }
    .kh-ingredients { flex-direction: column; padding: 60px 20px; }
    .kh-ingredients__img img { top: 0; width: 100%; }
    .kh-courses { grid-template-columns: 1fr; }
    .kh-courses__images { grid-template-columns: 1fr; }
    .kh-courses__img-side { display: none; }
    .kh-courses__text { padding: 60px 24px; }
    .kh-products { grid-template-columns: repeat(2, 1fr); }
    .kh-products-grid { padding: 0 20px 60px; }
    .kh-faq { padding: 90px 20px; }
}

/* ==============================
   INNER PAGE HERO
   ============================== */
.kp-hero-inner {
    position: relative;
    min-height: 480px;
    display: flex; align-items: flex-end; justify-content: center;
    text-align: center; overflow: hidden;
}
.kp-hero-inner--short { min-height: 360px; }
.kp-hero-inner__bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center 30%;
}
.kp-hero-inner__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, var(--c-brown-md) 0%, var(--c-brown-md) 100%);
    opacity: 0.55;
}
.kp-hero-inner__content {
    position: relative; z-index: 2; color: #fff;
    padding: 0 20px 60px; width: 100%;
}
.kp-hero-inner__content h1 {
    font-family: "Spectral", serif; font-size: 56px; font-weight: 300;
    color: #fff; letter-spacing: -2px; margin-bottom: 12px;
}
.kp-hero-inner__content p { font-size: 15px; color: rgba(255,255,255,0.85); }
.kh-label {
    font-family: "Montserrat", sans-serif; font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 2.5px; color: var(--c-accent);
    display: block; margin-bottom: 12px;
}
.kh-label--light { color: rgba(255,255,255,0.7); }

/* ==============================
   HOME – NEW SECTIONS
   ============================== */
.kh-hero__eyebrow {
    font-family: "Montserrat", sans-serif; font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 3px;
    color: rgba(255,255,255,0.7); margin-bottom: 16px;
}

/* About strip */
.kh-about-strip { background: var(--c-bg2); padding: 100px 60px; }
.kh-about-strip__inner {
    max-width: 1140px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.kh-about-strip__text h2 {
    font-family: "Spectral", serif; font-size: 44px; font-weight: 300;
    color: var(--c-text); letter-spacing: -2px; margin: 12px 0 20px;
}
.kh-about-strip__text p { font-size: 14px; color: var(--c-grey); line-height: 1.9; margin-bottom: 28px; }
.kh-about-strip__img img { width: 100%; height: 480px; object-fit: cover; }

/* Services cards */
.kh-services { background: var(--c-bg); padding: 100px 60px; }
.kh-section-header { text-align: center; margin-bottom: 60px; }
.kh-section-header h2 {
    font-family: "Spectral", serif; font-size: 44px; font-weight: 300;
    color: var(--c-text); letter-spacing: -2px; margin: 12px 0 12px;
}
.kh-section-header p { color: var(--c-grey); font-size: 14px; }
.kh-services__grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px; max-width: 1140px; margin: 0 auto;
}
.kh-service-card {
    background: var(--c-bg2); text-decoration: none;
    display: flex; flex-direction: column; overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
}
.kh-service-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(66,42,0,0.12); }
.kh-service-card__img {
    height: 280px; background-size: cover; background-position: center;
}
.kh-service-card__body { padding: 32px; }
.kh-service-card__icon { font-size: 24px; display: block; margin-bottom: 12px; }
.kh-service-card h3 {
    font-family: "Spectral", serif; font-size: 28px; font-weight: 300;
    color: var(--c-text); margin-bottom: 12px;
}
.kh-service-card p { font-size: 13px; color: var(--c-grey); line-height: 1.8; margin-bottom: 20px; }

/* Why us (home) */
.kh-why {
    display: grid; grid-template-columns: 1fr 1fr;
    min-height: 600px; overflow: hidden;
}
.kh-why__img img { width: 100%; height: 100%; object-fit: cover; }
.kh-why__text {
    background: var(--c-brown);
    display: flex; flex-direction: column; justify-content: center;
    padding: 80px 80px; color: #fff;
}
.kh-why__text .kh-label { color: rgba(255,255,255,0.6); }
.kh-why__text h2 {
    font-family: "Spectral", serif; font-size: 42px; font-weight: 300;
    color: #fff; letter-spacing: -1.5px; margin: 12px 0 32px;
}
.kh-checklist { list-style: none; padding: 0; margin: 0 0 36px; }
.kh-checklist li {
    font-size: 14px; color: rgba(255,255,255,0.9);
    padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.15);
    padding-left: 24px; position: relative;
}
.kh-checklist li::before {
    content: '✔'; position: absolute; left: 0;
    color: var(--c-border); font-size: 12px;
}

/* CTA section */
.kh-cta {
    position: relative; min-height: 460px;
    display: flex; align-items: center; justify-content: center;
    text-align: center; overflow: hidden;
}
.kh-cta__bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
}
.kh-cta__overlay {
    position: absolute; inset: 0;
    background: var(--c-brown-md); opacity: 0.6;
}
.kh-cta__content { position: relative; z-index: 2; color: #fff; padding: 60px 20px; }
.kh-cta__content h2 {
    font-family: "Spectral", serif; font-size: 48px; font-weight: 300;
    color: #fff; letter-spacing: -2px; margin-bottom: 16px;
}
.kh-cta__content h2 em { font-style: italic; }
.kh-cta__content p { color: rgba(255,255,255,0.85); font-size: 15px; margin-bottom: 32px; }

/* ==============================
   ABOUT PAGE
   ============================== */
.kp-about-intro { background: var(--c-bg); padding: 100px 60px; }
.kp-about-intro__inner {
    max-width: 1140px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.kp-about-intro__text .kh-label { margin-bottom: 12px; }
.kp-about-intro__text h2 {
    font-family: "Spectral", serif; font-size: 44px; font-weight: 300;
    color: var(--c-text); letter-spacing: -2px; margin: 12px 0 24px;
}
.kp-about-intro__text p { font-size: 14px; color: var(--c-grey); line-height: 1.9; margin-bottom: 16px; }
.kp-about-intro__img img { width: 100%; height: 520px; object-fit: cover; }

.kp-why { background: var(--c-bg2); padding: 100px 60px; }
.kp-why__inner { max-width: 1140px; margin: 0 auto; }
.kp-why__inner h2 {
    font-family: "Spectral", serif; font-size: 44px; font-weight: 300;
    color: var(--c-text); letter-spacing: -2px; margin: 12px 0 48px;
}
.kp-why__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.kp-why__item {
    display: flex; gap: 20px; align-items: flex-start;
    background: var(--c-bg); padding: 28px 24px;
}
.kp-why__icon { font-size: 18px; color: var(--c-brown); flex-shrink: 0; margin-top: 2px; }
.kp-why__item h4 {
    font-family: "Montserrat", sans-serif; font-size: 14px; font-weight: 600;
    color: var(--c-text); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px;
}
.kp-why__item p { font-size: 13px; color: var(--c-grey); line-height: 1.7; margin: 0; }

/* ==============================
   SERVICES LIST PAGE
   ============================== */
.kp-services-list { background: var(--c-bg); padding: 0; }
.kp-services-list__inner { max-width: 100%; }
.kp-service-row {
    display: grid; grid-template-columns: 1fr 1fr;
    min-height: 480px; text-decoration: none;
    border-bottom: 1px solid var(--c-border);
    transition: opacity 0.2s;
}
.kp-service-row:hover { opacity: 0.92; }
.kp-service-row--reverse { direction: rtl; }
.kp-service-row--reverse > * { direction: ltr; }
.kp-service-row__img { background-size: cover; background-position: center; }
.kp-service-row__text {
    background: var(--c-bg2);
    display: flex; align-items: center; gap: 32px;
    padding: 60px 80px;
}
.kp-service-row__num {
    font-family: "Spectral", serif; font-size: 80px; font-weight: 200;
    color: var(--c-border); line-height: 1; flex-shrink: 0;
}
.kp-service-row__text h2 {
    font-family: "Spectral", serif; font-size: 40px; font-weight: 300;
    color: var(--c-text); letter-spacing: -1.5px; margin: 8px 0 16px;
}
.kp-service-row__text p { font-size: 14px; color: var(--c-grey); line-height: 1.9; margin-bottom: 20px; }

/* ==============================
   SINGLE SERVICE
   ============================== */
.kp-service-intro { background: var(--c-bg); padding: 100px 60px; }
.kp-service-intro__inner {
    max-width: 1140px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
}
.kp-service-intro__text h2 {
    font-family: "Spectral", serif; font-size: 38px; font-weight: 300;
    color: var(--c-text); letter-spacing: -1.5px; margin: 12px 0 20px;
}
.kp-service-intro__text p { font-size: 14px; color: var(--c-grey); line-height: 1.9; }
.kp-service-intro__steps h4 {
    font-size: 13px; font-weight: 600; text-transform: uppercase;
    letter-spacing: 1.5px; margin-bottom: 16px; color: var(--c-text);
}
.kp-steps { list-style: none; padding: 0; margin: 0 0 20px; }
.kp-steps li {
    padding: 10px 0 10px 24px; border-bottom: 1px solid var(--c-border);
    font-size: 14px; color: var(--c-grey); position: relative;
}
.kp-steps li::before {
    content: '•'; position: absolute; left: 0; color: var(--c-accent);
}
.kp-note {
    font-size: 13px; font-style: italic;
    color: var(--c-accent); margin-top: 16px;
}
.kp-variants { background: var(--c-bg2); padding: 100px 60px; }
.kp-variants__inner { max-width: 1140px; margin: 0 auto; }
.kp-variants__inner h2 {
    font-family: "Spectral", serif; font-size: 42px; font-weight: 300;
    color: var(--c-text); letter-spacing: -2px; margin: 12px 0 48px;
}
.kp-variants__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.kp-variant-card {
    background: var(--c-bg); padding: 40px 32px;
    display: flex; flex-direction: column; gap: 12px;
}
.kp-variant-card__num {
    font-family: "Spectral", serif; font-size: 48px; font-weight: 200;
    color: var(--c-border); line-height: 1;
}
.kp-variant-card h3 {
    font-family: "Spectral", serif; font-size: 24px; font-weight: 300; color: var(--c-text);
}
.kp-variant-card p { font-size: 13px; color: var(--c-grey); line-height: 1.8; flex-grow: 1; }
.kp-service-footer {
    background: var(--c-bg); padding: 40px 60px;
    display: flex; align-items: center; justify-content: space-between;
    border-top: 1px solid var(--c-border);
    max-width: 100%;
}

/* ==============================
   BOOKING PAGE
   ============================== */
.kp-booking-section { background: var(--c-bg); padding: 80px 60px; }
.kp-booking-section__inner {
    max-width: 1140px; margin: 0 auto;
    display: grid; grid-template-columns: 340px 1fr; gap: 60px; align-items: start;
}
.kp-booking-info { position: sticky; top: 100px; }
.kp-booking-info h3 {
    font-family: "Spectral", serif; font-size: 28px; font-weight: 300;
    color: var(--c-text); margin-bottom: 28px; letter-spacing: -0.5px;
}
.kp-booking-steps { display: flex; flex-direction: column; gap: 24px; margin-bottom: 40px; }
.kp-booking-step { display: flex; gap: 16px; align-items: flex-start; }
.kp-booking-step__num {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--c-brown); color: #fff;
    font-size: 13px; font-weight: 600;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.kp-booking-step strong { font-size: 13px; font-weight: 600; color: var(--c-text); display: block; margin-bottom: 4px; }
.kp-booking-step p { font-size: 12px; color: var(--c-grey); line-height: 1.6; margin: 0; }
.kp-booking-contact {
    background: var(--c-bg2); padding: 24px;
    border-left: 3px solid var(--c-brown);
}
.kp-booking-contact h4 { font-size: 13px; font-weight: 600; color: var(--c-text); margin-bottom: 8px; }
.kp-booking-contact a {
    font-family: "Spectral", serif; font-size: 22px; font-weight: 300;
    color: var(--c-brown); text-decoration: none; display: block; margin-bottom: 12px;
}
.kp-booking-hours { font-size: 12px; color: var(--c-grey); line-height: 1.8; margin: 0; }

/* Form */
.kp-booking-form-wrap { background: var(--c-bg2); padding: 48px; }
.kp-form { display: flex; flex-direction: column; gap: 0; }

.kp-form-section { padding: 32px 0; border-bottom: 1px solid var(--c-border); }
.kp-form-section:first-child { padding-top: 0; }
.kp-form-section:last-of-type { border-bottom: none; }
.kp-form-section__title {
    display: flex; align-items: center; gap: 12px;
    font-family: "Montserrat", sans-serif; font-size: 13px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1.5px; color: var(--c-text);
    margin-bottom: 24px;
}
.kp-form-section__title span {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--c-brown); color: #fff;
    font-size: 12px; font-weight: 700;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.kp-form-cat {
    font-size: 10px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 2px; color: var(--c-grey); margin: 0 0 10px;
}
.kp-service-cards { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px; }
.kp-service-card input[type="radio"] { display: none; }
.kp-service-card__inner {
    display: flex; flex-direction: column; gap: 2px;
    border: 1px solid var(--c-border); background: var(--c-bg);
    padding: 12px 16px; cursor: pointer; transition: border-color 0.2s, background 0.2s;
    min-width: 180px;
}
.kp-service-card input:checked + .kp-service-card__inner {
    border-color: var(--c-brown); background: #fff;
    box-shadow: inset 0 0 0 1px var(--c-brown);
}
.kp-service-card__inner:hover { border-color: var(--c-brown); }
.kp-service-card__name { font-size: 13px; font-weight: 600; color: var(--c-text); }
.kp-service-card__dur { font-size: 11px; color: var(--c-grey); }

.kp-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.kp-form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.kp-form-group:last-child { margin-bottom: 0; }
.kp-form-group label {
    font-size: 11px; font-weight: 600; text-transform: uppercase;
    letter-spacing: 1.5px; color: var(--c-text);
}
.kp-form input[type="text"],
.kp-form input[type="email"],
.kp-form input[type="tel"],
.kp-form input[type="date"],
.kp-form select,
.kp-form textarea {
    border: 1px solid var(--c-border); background: var(--c-bg);
    padding: 12px 16px; font-family: "Montserrat", sans-serif;
    font-size: 14px; color: var(--c-text); outline: none;
    border-radius: 0; transition: border-color 0.2s; width: 100%; box-sizing: border-box;
}
.kp-form input:focus, .kp-form select:focus, .kp-form textarea:focus {
    border-color: var(--c-brown);
}
.kp-form select {
    appearance: none; cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23422A00' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px;
    background-color: var(--c-bg);
}
.kp-form textarea { resize: vertical; min-height: 80px; }

.kp-form-submit {
    margin-top: 32px;
    background: var(--c-brown) !important; color: #fff !important;
    border: none; padding: 18px 48px;
    font-family: "Montserrat", sans-serif; font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px; cursor: pointer;
    transition: background 0.2s; width: 100%;
}
.kp-form-submit:hover { background: var(--c-brown-dk) !important; }

.kp-booking-alert {
    background: #fdf0f0; border-left: 3px solid #c0392b;
    padding: 12px 16px; margin-bottom: 24px;
    font-size: 13px; color: #c0392b;
}
.kp-booking-success {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; padding: 80px 40px; gap: 16px;
}
.kp-booking-success__icon {
    width: 72px; height: 72px; border-radius: 50%;
    background: var(--c-brown); color: #fff;
    font-size: 32px; display: flex; align-items: center; justify-content: center;
}
.kp-booking-success h3 {
    font-family: "Spectral", serif; font-size: 32px; font-weight: 300; color: var(--c-text); margin: 0;
}
.kp-booking-success p { color: var(--c-grey); font-size: 14px; margin: 0; }

/* Shared page reset */
#krasiva-page .entry-title,
#krasiva-page .ast-breadcrumbs-wrapper { display: none !important; }
#krasiva-page .entry-content,
#krasiva-page .site-content { padding: 0 !important; margin: 0 !important; }
#krasiva-page .ast-container { max-width: 100% !important; padding: 0 !important; }

/* ==============================
   RESPONSIVE
   ============================== */
@media (max-width: 1024px) {
    .kh-about-strip__inner, .kp-about-intro__inner,
    .kp-service-intro__inner, .kp-booking-section__inner { grid-template-columns: 1fr; }
    .kp-booking-section__inner { grid-template-columns: 1fr; }
    .kp-booking-info { position: static; }
    .kh-why { grid-template-columns: 1fr; min-height: 0; }
    .kh-why__img { display: none; }
    .kp-variants__grid { grid-template-columns: 1fr 1fr; }
    .kp-why__grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
    .kh-about-strip, .kp-about-intro, .kp-why, .kp-service-intro,
    .kp-variants, .kh-services, .kp-booking-section { padding: 60px 20px; }
    .kp-booking-form-wrap { padding: 28px 20px; }
    .kh-services__grid { grid-template-columns: 1fr; }
    .kp-service-row { grid-template-columns: 1fr; min-height: auto; }
    .kp-service-row--reverse { direction: ltr; }
    .kp-service-row__text { padding: 40px 24px; flex-direction: column; }
    .kp-service-row__num { font-size: 48px; }
    .kp-variants__grid { grid-template-columns: 1fr; }
    .kp-form-row { grid-template-columns: 1fr; }
    .kh-why__text { padding: 50px 24px; }
    .kp-service-footer { flex-direction: column; gap: 20px; padding: 32px 24px; }
    .kp-hero-inner__content h1 { font-size: 36px; }
    .kh-cta__content h2 { font-size: 32px; }
}

/* ==============================
   HOMEPAGE – TRANSPARENT HEADER
   ============================== */
/* Reset any body padding Astra adds for sticky header */
body.page-template-page-home { padding-top: 0 !important; }

/* Make entire masthead absolutely positioned over the hero */
body.page-template-page-home #masthead {
    position: absolute !important;
    top: 0; left: 0; right: 0;
    z-index: 200;
    width: 100%;
    background: transparent !important;
    border-bottom: none !important;
    box-shadow: none !important;
}
/* All inner header bars — desktop and mobile */
body.page-template-page-home .main-header-bar,
body.page-template-page-home .ast-main-header-wrap,
body.page-template-page-home .ast-desktop-header,
body.page-template-page-home .ast-mobile-header,
body.page-template-page-home .ast-hfb-header {
    background: transparent !important;
    border-bottom: none !important;
    box-shadow: none !important;
}
body.page-template-page-home .ast-above-header-bar,
body.page-template-page-home .ast-below-header-bar { display: none; }

/* White text — desktop nav */
body.page-template-page-home .site-title a { color: #fff !important; }
body.page-template-page-home .main-header-bar .menu-item a,
body.page-template-page-home .ast-desktop-header .menu-item a,
body.page-template-page-home .main-navigation .menu-item a { color: rgba(255,255,255,0.88) !important; }
body.page-template-page-home .main-header-bar .menu-item a:hover,
body.page-template-page-home .ast-desktop-header .menu-item a:hover,
body.page-template-page-home .main-navigation .menu-item a:hover { color: #fff !important; }

/* Mobile hamburger icon */
body.page-template-page-home .menu-toggle,
body.page-template-page-home .ast-mobile-menu-trigger-minimal { color: #fff !important; background: transparent !important; border: none !important; }
body.page-template-page-home .menu-toggle svg,
body.page-template-page-home .menu-toggle .ahfb-svg-iconset { fill: #fff !important; color: #fff !important; }

/* Mobile menu OPEN — dark text on beige background (target the mobile menu by id) */
body.page-template-page-home .ast-mobile-header-content,
body.page-template-page-home #ast-hf-mobile-menu { background: var(--c-bg) !important; }
body.page-template-page-home #ast-hf-mobile-menu .menu-item a,
body.page-template-page-home #ast-hf-mobile-menu .menu-link { color: var(--c-text) !important; }
body.page-template-page-home #ast-hf-mobile-menu .menu-item a:hover,
body.page-template-page-home #ast-hf-mobile-menu .menu-link:hover { color: var(--c-brown) !important; }
body.page-template-page-home #ast-hf-mobile-menu .ast-menu-toggle,
body.page-template-page-home #ast-hf-mobile-menu .icon-arrow svg { color: var(--c-text) !important; fill: var(--c-text) !important; }

/* Logo — white text on homepage handled above */

/* Gradient overlay: dark at top (nav readable) + light in middle (image shows) + dark at bottom (text readable) */
.page-template-page-home .kh-hero__overlay {
    background: linear-gradient(180deg,
        rgba(85,57,28,0.60) 0%,
        rgba(85,57,28,0.08) 30%,
        rgba(85,57,28,0.08) 60%,
        rgba(85,57,28,0.65) 100%
    );
    opacity: 1;
}

/* Mobile: zoom out hero image so it fits without side cropping */
@media (max-width: 767px) {
    .kh-hero { background-color: #EEE8DF; min-height: 132vw; }
    .kh-hero__bg {
        background-image: url('/wp-content/uploads/criteria/hero-mobile-20260606.jpg') !important;
        background-size: cover;
        background-position: left center;
    }
    .kh-hero__content {
        box-sizing: border-box;
        width: 100%;
        padding-left: 24px;
        padding-right: 24px;
        padding-bottom: 28px;
        overflow-wrap: break-word;
        word-break: break-word;
    }
    .kh-hero__eyebrow { margin-bottom: 8px; }
    .kh-hero__content h1 { font-size: 28px; margin-bottom: 10px; }
    .kh-hero__content p { margin-bottom: 18px; }
}

/* ==============================
   CONTACT INFO BLOCK
   ============================== */
.kh-contact-info {
    display: flex; flex-direction: column;
    max-width: 480px; margin: 40px auto 0;
}
.kh-contact-row {
    display: flex; align-items: baseline; gap: 20px;
    padding: 16px 0; border-bottom: 1px solid var(--c-border);
}
.kh-contact-row:first-child { border-top: 1px solid var(--c-border); }
.kh-contact-label {
    font-family: "Montserrat", sans-serif; font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px; color: var(--c-accent);
    flex-shrink: 0; min-width: 130px;
}
.kh-contact-value { font-size: 14px; color: var(--c-text); }
.kh-contact-link {
    font-size: 14px; color: var(--c-brown);
    text-decoration: none; transition: opacity 0.2s;
}
.kh-contact-link:hover { opacity: 0.7; color: var(--c-brown); }

/* Service card body without icon */
.kh-service-card__body { padding: 32px; }

@media (max-width: 767px) {
    .kh-contact-label { min-width: 100px; }
    .kh-contact-info { margin: 28px auto 0; }
}

/* ==============================
   IMAGE LOGO (2026-06-08: show logo image, hide text title per client)
   ============================== */
.custom-logo-link { display: inline-block !important; }
.ast-site-identity .site-title,
.ast-site-title-wrap,
.ast-site-title { display: none !important; }
.ast-site-identity .site-description { display: none !important; }
/* logo image sizing in header */
.site-logo-img .custom-logo,
.custom-logo-link .custom-logo { height: 64px !important; width: auto !important; max-width: none !important; }
.site-logo-img { padding-right: 0 !important; }
@media (max-width: 767px) {
    .site-logo-img .custom-logo,
    .custom-logo-link .custom-logo { height: 52px !important; }
}

/* ==============================
   BOOKING HERO – SOLID (no photo)
   ============================== */
.kp-hero-inner--solid {
    background: var(--c-brown);
    min-height: 280px;
}
.kp-hero-inner--solid .kp-hero-inner__bg,
.kp-hero-inner--solid .kp-hero-inner__overlay { display: none !important; }
.kp-hero-inner--solid .kp-hero-inner__content { padding-bottom: 48px; padding-top: 48px; }

/* ==============================
   FORM DATE+TIME – fix stacking
   ============================== */
.kp-form-row--datetime { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }
@media (max-width: 640px) {
    .kp-form-row--datetime { grid-template-columns: 1fr; }
    .kp-form-row { grid-template-columns: 1fr; }
}

/* ==============================
   LASER PRICES SECTION
   ============================== */
.kp-laser-prices { background: var(--c-bg); padding: 100px 60px; }
.kp-laser-prices__inner { max-width: 900px; margin: 0 auto; }
.kp-laser-prices__inner h2 {
    font-family: 'Spectral', serif; font-size: 42px; font-weight: 300;
    color: var(--c-text); letter-spacing: -2px; margin: 12px 0 12px;
}
.kp-laser-prices__sub {
    text-align: center; font-size: 13px; color: var(--c-grey);
    margin-bottom: 48px; font-style: italic;
}

/* Tab nav */
.kp-price-tab-nav {
    display: flex; justify-content: center;
    gap: 0; margin-bottom: 40px;
    border: 1px solid var(--c-border);
    width: fit-content; margin-left: auto; margin-right: auto;
}
.kp-price-tab-btn {
    background: transparent; border: none; cursor: pointer;
    font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px;
    color: var(--c-grey); padding: 14px 48px;
    transition: background 0.2s, color 0.2s;
    border-right: 1px solid var(--c-border);
}
.kp-price-tab-btn:last-child { border-right: none; }
.kp-price-tab-btn--active {
    background: var(--c-brown); color: #fff !important;
}
.kp-price-tab-btn:not(.kp-price-tab-btn--active):hover {
    background: var(--c-bg2); color: var(--c-brown);
}

/* Price panel */
.kp-price-panel--hidden { display: none !important; }

/* Price grid */
.kp-price-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
}
.kp-price-item {
    display: flex; flex-direction: column; align-items: center;
    justify-content: center; gap: 6px;
    background: var(--c-bg2);
    padding: 20px 12px; text-align: center;
    transition: background 0.2s;
}
.kp-price-item:hover { background: #e8e1d8; }
.kp-price-item__zone {
    font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.5px;
    color: var(--c-grey); line-height: 1.4;
}
.kp-price-item__price {
    font-family: 'Spectral', serif; font-size: 22px; font-weight: 300;
    color: var(--c-brown); letter-spacing: -0.5px;
}
.kp-price-item--highlight {
    grid-column: 1 / -1;
    background: var(--c-brown) !important;
    flex-direction: row; justify-content: space-between;
    padding: 22px 36px; gap: 0;
}
.kp-price-item--highlight:hover { background: var(--c-brown-dk) !important; }
.kp-price-item--highlight .kp-price-item__zone {
    font-size: 13px; font-weight: 700; color: rgba(255,255,255,0.85);
    letter-spacing: 2px;
}
.kp-price-item--highlight .kp-price-item__price {
    font-size: 30px; color: #fff;
}

@media (max-width: 1024px) {
    .kp-price-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 767px) {
    .kp-laser-prices { padding: 60px 20px; }
    .kp-price-grid { grid-template-columns: repeat(2, 1fr); }
    .kp-price-tab-btn { padding: 12px 32px; font-size: 11px; }
    .kp-price-item--highlight { flex-direction: row; padding: 18px 20px; }
    .kp-price-item--highlight .kp-price-item__price { font-size: 24px; }
}
@media (max-width: 480px) {
    .kp-price-grid { grid-template-columns: 1fr 1fr; }
}

/* ==============================
   ADDED 2026-05-27 (Drago tasks)
   ============================== */

/* Sub-menu (Услуги dropdown) — force brown text on the theme background.
   Astra defaults can flip the submenu link colour to white in some header
   variants which becomes invisible on the cream bg. */
.main-header-menu .sub-menu li a,
.ast-desktop-header-content .sub-menu li a,
.ast-mobile-header-content .sub-menu li a,
.ast-header-break-point .sub-menu li a,
.menu-item-has-children .sub-menu li a,
nav .sub-menu li a {
    color: var(--c-brown) !important;
    background-color: var(--c-bg) !important;
}
.main-header-menu .sub-menu li a:hover,
.main-header-menu .sub-menu li a:focus,
.ast-desktop-header-content .sub-menu li a:hover,
.ast-mobile-header-content .sub-menu li a:hover,
.ast-header-break-point .sub-menu li a:hover,
.menu-item-has-children .sub-menu li a:hover,
nav .sub-menu li a:hover {
    color: var(--c-brown-dk) !important;
    background-color: var(--c-bg2) !important;
}

/* Tariff list — small grey duration after the service name */
.kp-price-item__dur {
    display: inline;
    margin-left: 8px;
    font-size: 11px;
    color: var(--c-grey);
    letter-spacing: 0.3px;
    font-weight: 400;
    white-space: nowrap;
}

/* Booking page service-card — show price under the duration */
.kp-service-card__price {
    display: block;
    margin-top: 4px;
    font-family: "Spectral", serif;
    font-size: 18px;
    color: var(--c-brown);
    font-weight: 500;
    line-height: 1.2;
}

/* Mobile (≤767px): hide the two decorative home-page <img> tags
   (feature-bg.png + hero-correct.jpg). Background-image variants of
   the same files on other pages are intentionally NOT affected — only
   the inline <img> uses get hidden, per Drago's spec. */
@media (max-width: 767px) {
    .page-template-page-home img[src*="feature-bg.png"],
    .page-template-page-home img[src*="hero-correct.jpg"] {
        display: none !important;
    }
}

/* Working-hours notice in the booking-info column (KAN-2, 2026-05-28) */
.kp-booking-hours {
    margin-top: 28px;
    padding: 16px 18px;
    background: var(--c-bg2);
    border-left: 3px solid var(--c-brown);
    font-size: 14px;
}
.kp-booking-hours strong {
    display: block;
    color: var(--c-brown);
    font-family: "Spectral", serif;
    font-size: 16px;
    margin-bottom: 4px;
}
.kp-booking-hours p { margin: 0; color: var(--c-text); }
