/* ============================================================
   УльтраКаркас — глобальный CSS для Tilda
   Вставьте содержимое этого файла в:
   Настройки сайта → Дополнительный CSS (или «Свои стили»)
   ============================================================ */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Golos+Text:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ============ Reset & base ============ */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Golos Text',system-ui,-apple-system,sans-serif;color:hsl(0 0% 8%);background:#fff;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
.serif{font-family:'Playfair Display',Georgia,serif}

/* ============ Tokens ============ */
:root{
  --bg:#fff;
  --fg:hsl(0 0% 8%);
  --muted:hsl(0 0% 96%);
  --muted-fg:hsl(0 0% 40%);
  --border:hsl(0 0% 90%);
  --card:#fff;
  --primary:hsl(28 100% 48%);
  --primary-fg:#fff;
  --primary-bg-soft:hsl(28 100% 48% / .1);
  --accent:hsl(28 100% 95%);
  --accent-fg:hsl(28 100% 35%);
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.06),0 2px 4px -2px rgba(0,0,0,.06);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.06);
  --shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.06);
  --shadow-2xl:0 25px 50px -12px rgba(0,0,0,.18);
  --radius:.5rem;
}

/* ============ Layout helpers ============ */
.container{max-width:1280px;margin:0 auto;padding:0 1.25rem}
@media(min-width:640px){.container{padding:0 1.5rem}}
@media(min-width:768px){.container{padding:0 2rem}}
.section{padding-top:3.5rem;padding-bottom:3.5rem}
@media(min-width:768px){.section{padding-top:5rem;padding-bottom:5rem}}
.bg-muted{background:hsl(0 0% 96% / .55)}
.bg-muted-solid{background:hsl(0 0% 96%)}
.text-center{text-align:center}
.section-title{font-family:'Playfair Display',Georgia,serif;font-weight:700;font-size:clamp(1.875rem,4vw,3rem);color:var(--fg);margin-bottom:1.5rem;line-height:1.1}
.section-eyebrow{display:inline-block;color:var(--primary);font-weight:600;font-size:.875rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.section-lead{color:var(--muted-fg);font-size:1.125rem;max-width:48rem;margin:0 auto 2.5rem}
.section-header{max-width:48rem;margin:0 auto 2.5rem;text-align:center}
@media(min-width:768px){.section-header{margin-bottom:3rem}}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500;border-radius:var(--radius);padding:.625rem 1rem;height:2.5rem;font-size:.875rem;transition:background .15s,color .15s,border-color .15s,transform .15s,box-shadow .15s;border:1px solid transparent;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{background:hsl(28 100% 42%)}
.btn-outline{background:transparent;color:var(--fg) !important;border:1px solid var(--border)}
.btn-outline:hover{background:hsl(0 0% 96%)}
.btn-lg{height:3.5rem;padding:1rem 1rem;font-size:1rem}
.btn-block{width:100%}
.btn .icon{width:1rem;height:1rem;flex-shrink:0}
.icon{display:inline-block;vertical-align:middle}
svg{display:block}

/* ============ Header / Navbar ============ */
.header{position:fixed;top:0;left:0;right:0;z-index:50;transition:padding .3s,background .3s,box-shadow .3s,border-color .3s;padding:1.25rem 0;background:#ffffff;backdrop-filter:blur(6px);border-bottom:1px solid transparent}
.header.is-scrolled,.header.is-inner{padding:.75rem 0;background:hsl(0 0% 100% / .95);border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{display:flex;align-items:center;gap:.5rem}
.logo-mark{width:2.5rem;height:2.5rem;background:var(--primary);color:var(--primary-fg);display:flex;align-items:center;justify-content:center;border-radius:.45rem;flex-shrink:0}
.logo-mark .icon{width:1.4rem;height:1.4rem;stroke-width:2}
.logo-text{font-family:'Playfair Display',serif;font-weight:700;font-size:1.25rem;letter-spacing:-.02em;color: black !important}
.nav-desktop{display:none;align-items:center;gap:2rem}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{font-size:.875rem;font-weight:500;color:hsl(0 0% 8% / .8) !important;transition:color .15s}
.nav-desktop a:hover{color:var(--primary)}
.header-actions{display:none;align-items:center;gap:1.5rem}
@media(min-width:768px){.header-actions{display:flex}}
.phone-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;color:var(--fg);transition:color .15s}
.phone-link .icon{color:var(--primary);width:1rem;height:1rem}
.phone-link:hover{color:var(--primary)}
.header-mobile{display:flex;align-items:center;gap:0.8rem}
@media(min-width:1024px){.header-mobile{display:none}}
.phone-pill{padding:.625rem;border-radius:9999px;background:var(--primary);color:var(--primary-fg) !important;box-shadow:var(--shadow-sm)}
.phone-pill .icon{width:1.25rem;height:1.25rem}
.menu-btn{padding:.5rem;color:var(--fg)}
.menu-btn .icon{width:1.5rem;height:1.5rem}

.mobile-menu{position:fixed;inset:0;z-index:60;background:#fff;padding:6rem 1.5rem 1.5rem;display:none;flex-direction:column}
.mobile-menu.is-open{display:flex}
.mobile-menu nav{display:flex;flex-direction:column;gap:1.5rem;text-align:center;font-size:1.125rem}
.mobile-menu nav a{font-weight:500;padding:.5rem 0;color:var(--fg)}
.mobile-menu .footer-area{margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1.5rem}

/* ============ Hero ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:5rem}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to right, hsl(0deg 0% 0% / 92%), hsl(0deg 0% 0% / 70%) 50%, #00000000)} 
.hero-bg::before{content:"";position:absolute;left:0;right:0;bottom:0;height:33%;background:linear-gradient(to top, #000000, transparent));z-index:1}
.hero-inner{position:relative;z-index:10;max-width:48rem}
.eyebrow-badge{display:inline-block;padding:.375rem 1rem;border-radius:9999px;background:var(--primary-bg-soft);color:#ffffff;border:1px solid hsl(28 100% 48% / .2);font-weight:600;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1.5rem}
.hero-title{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.1;color:#ffffff;margin-bottom:1.25rem}
.hero-title em{color:var(--primary);font-style:italic}
.hero-lead{font-size:clamp(1rem,2vw,1.5rem);color:#ffffff;max-width:42rem;line-height:1.6;margin-bottom:2.25rem}
.hero-actions{display:flex;flex-direction:column;gap:1rem}
@media(min-width:640px){.hero-actions{flex-direction:row}}

/* ============ Trust stats ============ */
.stats-section{padding:3rem 0;background:hsl(0 0% 96% / .55);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
@media(min-width:768px){.stats-section{padding:4rem 0}}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem}}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.25rem;transition:transform .25s,box-shadow .25s}
@media(min-width:768px){.stat-card{padding:2rem}}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.stat-icon{width:2.75rem;height:2.75rem;border-radius:.75rem;background:var(--primary-bg-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.stat-icon .icon{width:1.25rem;height:1.25rem}
.stat-num-row{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.5rem}
.stat-num{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(2.25rem,5vw,3.75rem);color:var(--primary);line-height:1}
.stat-suffix{font-weight:500;color:hsl(0 0% 8% / .7);font-size:1rem}
.stat-label{color:var(--muted-fg);font-size:.875rem;line-height:1.3;display:block}
@media(min-width:768px){.stat-label{font-size:1rem}}

/* ============ Project grid ============ */
.cards-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.cards-grid{grid-template-columns:repeat(3,1fr)}}
.project-card{background:#fff;border:1px solid var(--border);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:box-shadow .3s}
.project-card:hover{box-shadow:var(--shadow-xl)}
.project-cover{position:relative;aspect-ratio:4/3;overflow:hidden;background:hsl(0 0% 96%);display:block}
.project-cover img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.project-card:hover .project-cover img{transform:scale(1.05)}
.project-tag{position:absolute;top:1rem;left:1rem;background:hsl(0 0% 100% / .95);backdrop-filter:blur(4px);padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--fg)}
.project-price-tag{position:absolute;bottom:1rem;right:1rem;background:var(--primary);color:var(--primary-fg);padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:700}
.project-body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.project-name{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--fg);margin-bottom:1rem;transition:color .15s}
.project-name:hover{color:var(--primary)}
.project-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:1rem 0;margin-bottom:1.5rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:.875rem}
.project-meta > div{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.25rem}
.project-meta > div + div{border-left:1px solid var(--border)}
.project-meta .icon{width:1rem;height:1rem;color:var(--primary)}
.project-meta .label{color:var(--muted-fg)}
.project-meta .value{font-weight:600;color:var(--fg)}
.project-actions{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}
.project-actions .btn{height:2.75rem}

@media(max-width:768px){
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:5rem}
}


/* ============ Packages tabs ============ */
.tabs{max-width:64rem;margin:0 auto 3rem}
.tablist{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem;padding:.25rem;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:.75rem}
.tab{padding:.75rem;font-size:.875rem;font-weight:500;border-radius:.5rem;color:var(--fg);background:transparent;transition:background .2s,color .2s}
@media(min-width:640px){.tab{font-size:1rem}}
.tab.is-active{background:var(--primary);color:var(--primary-fg)}
.tabpanels{margin-top:2rem;background:#fff;border-radius:1rem;border:1px solid var(--border);box-shadow:var(--shadow-md);overflow:hidden}
.tabpanel{display:none}
.tabpanel.is-active{display:block}
.tab-head{padding:1.5rem;border-bottom:1px solid var(--border);position:relative}
@media(min-width:640px){.tab-head{padding:2.5rem}}
.tab-head-row{display:flex;flex-direction:column;gap:1rem;justify-content:space-between}
@media(min-width:768px){.tab-head-row{flex-direction:row;align-items:flex-end}}
.tab-head h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}
.tab-head .meta{color:var(--muted-fg)}
.tab-price{text-align:left}
@media(min-width:768px){.tab-price{text-align:right}}
.tab-price .label{font-size:.875rem;color:var(--muted-fg);margin-bottom:.25rem}
.tab-price .price{font-size:1.875rem;font-weight:700;color:var(--primary)}
.hit-badge{position:absolute;top:0;right:0;background:var(--primary);color:var(--primary-fg);font-size:.75rem;font-weight:700;padding:.25rem 1rem;border-bottom-left-radius:.5rem}
.tab-body{background:hsl(0 0% 96% / .55);padding:1.5rem}
@media(min-width:640px){.tab-body{padding:2.5rem}}
.tab-body h4{font-weight:600;margin-bottom:1rem}
.feature-list{display:flex;flex-direction:column;gap:.75rem}
.feature-list li{display:flex;align-items:flex-start;gap:.75rem}
.feature-list .check,.feature-list .minus{width:1.25rem;height:1.25rem;color:var(--primary);flex-shrink:0;margin-top:.125rem}
.feature-list .minus{color:var(--muted-fg)}
.feature-list li.dim{color:var(--muted-fg)}


/* ============ Process timeline ============ */
.process{position:relative;max-width:64rem;margin:0 auto}
.process .line{display:none;position:absolute;top:0;bottom:0;left:50%;width:1px;background:var(--border);transform:translateX(-50%)}
@media(min-width:768px){.process .line{display:block}}
.process-step{position:relative;display:flex;flex-direction:column;align-items:center;margin-bottom:3rem}
@media(min-width:768px){.process-step{flex-direction:row;height:12rem;margin-bottom:0}}
.process-num{display:flex;align-items:center;justify-content:center;width:4rem;height:4rem;border-radius:9999px;background:#fff;border:4px solid var(--primary);color:var(--primary);font-family:'Playfair Display',serif;font-weight:700;font-size:1.25rem;z-index:10;box-shadow:var(--shadow-sm);margin-bottom:1.5rem}
@media(min-width:768px){.process-num{position:absolute;left:50%;transform:translateX(-50%);margin-bottom:0}}
.process-content{width:100%}
@media(min-width:768px){.process-content{width:50%;display:flex}}
.process-step.right .process-content{justify-content:flex-end;padding-right:4rem}
.process-step.left .process-content{justify-content:flex-start;padding-left:4rem;margin-left:auto}
.process-box{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s;position:relative}
@media(min-width:768px){.process-box{padding:2rem}}
.process-box:hover{box-shadow:var(--shadow-md)}
.process-box h3{font-size:1.25rem;font-weight:700;margin-bottom:.75rem}
.process-box p{color:var(--muted-fg);line-height:1.6}

/* ============ Services ============ */
.service-card{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.5rem;transition:transform .25s,box-shadow .25s}
@media(min-width:768px){.service-card{padding:2rem}}
.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-xl)}
.service-icon{width:3.5rem;height:3.5rem;background:var(--primary);color:var(--primary-fg);border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
@media(min-width:768px){.service-icon{width:4rem;height:4rem}}
.service-icon .icon{width:1.75rem;height:1.75rem}
.service-card h3{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}
@media(min-width:768px){.service-card h3{font-size:1.5rem}}
.service-price{display:inline-flex;align-items:baseline;gap:.35rem;margin-bottom:1.25rem;padding:.4rem .875rem;border-radius:9999px;background:var(--primary-bg-soft);border:1px solid hsl(28 100% 48% / .2)}
.service-price .amount{font-size:1.125rem;font-weight:700;color:var(--primary)}
.service-price .unit{font-size:.8rem;color:var(--accent-fg);font-weight:500}
.bullet-list{display:flex;flex-direction:column;gap:.75rem}
.bullet-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.95rem;line-height:1.4;color:hsl(0 0% 8% / .8)}
.bullet-dot{width:1.25rem;height:1.25rem;border-radius:9999px;background:var(--primary-bg-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.125rem}
.bullet-dot .icon{width:.75rem;height:.75rem;stroke-width:3}

/* ============ WhyUs cards ============ */
.why-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(3,1fr)}}
.why-card{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:2rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s}
.why-card:hover{box-shadow:var(--shadow-md)}
.why-icon{width:3.5rem;height:3.5rem;background:var(--primary-bg-soft);border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}
.why-icon .icon{width:2rem;height:2rem;color:var(--primary)}
.why-card h3{font-size:1.25rem;font-weight:700;margin-bottom:.75rem}
.why-card p{color:var(--muted-fg);line-height:1.6}

/* ============ Calculator ============ */
.calc-card{background:#fff;border:1px solid var(--border);border-radius:1.5rem;box-shadow:var(--shadow-xl);overflow:hidden;max-width:64rem;margin:0 auto;display:flex;flex-direction:column}
@media(min-width:768px){.calc-card{flex-direction:row}}
.calc-form{padding:2rem;flex:3}
@media(min-width:768px){.calc-form{padding:3rem}}
.calc-form h2{font-family:'Playfair Display',serif;font-size:1.875rem;font-weight:700;margin-bottom:1rem}
.calc-form > p{color:var(--muted-fg);margin-bottom:2.5rem}
.calc-row{margin-bottom:2rem}
.calc-row label.head{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:1.125rem;margin-bottom:1rem}
.calc-row label.head span{color:var(--primary)}
.calc-range{width:100%;height:.5rem;background:hsl(0 0% 96%);border-radius:.5rem;appearance:none;-webkit-appearance:none;cursor:pointer}
.calc-range::-webkit-slider-thumb{-webkit-appearance:none;width:1.25rem;height:1.25rem;background:var(--primary);border-radius:9999px;cursor:pointer}
.calc-range::-moz-range-thumb{width:1.25rem;height:1.25rem;background:var(--primary);border:none;border-radius:9999px;cursor:pointer}
.calc-range-bounds{display:flex;justify-content:space-between;font-size:.75rem;color:var(--muted-fg);margin-top:.5rem}
.pkg-toggle{display:grid;grid-template-columns:1fr;gap:.75rem}
@media(min-width:640px){.pkg-toggle{grid-template-columns:repeat(3,1fr)}}
.pkg-toggle button{padding:.75rem 1rem;border-radius:.75rem;border:1px solid var(--border);background:#fff;font-weight:500;transition:border-color .15s,background .15s,color .15s}
.pkg-toggle button:hover{border-color:hsl(28 100% 48% / .3)}
.pkg-toggle button.is-active{border-color:var(--primary);background:hsl(28 100% 48% / .05);color:var(--primary)}
.calc-result{background:hsl(0 0% 96% / .55);border-top:1px solid var(--border);padding:2rem;flex:2;display:flex;flex-direction:column;justify-content:center}
@media(min-width:768px){.calc-result{padding:3rem;border-top:0;border-left:1px solid var(--border)}}
.calc-result .lbl{color:var(--muted-fg);font-size:.875rem;font-weight:500;margin-bottom:.5rem}
.calc-result .val{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3rem);font-weight:700;color:var(--primary);line-height:1;margin-bottom:.5rem}
.calc-result .perm{font-size:.875rem;color:var(--muted-fg);margin-bottom:2rem}
.calc-result small{display:block;text-align:center;font-size:.75rem;color:var(--muted-fg);margin-top:1rem}

/* ============ FAQ ============ */
.faq{display:flex;flex-direction:column;gap:3rem;max-width:72rem;margin:0 auto}
@media(min-width:768px){.faq{flex-direction:row;gap:6rem}}
.faq-left{flex:1}
.faq-left h2{font-family:'Playfair Display',serif;font-size:clamp(1.875rem,4vw,3rem);font-weight:700;margin-bottom:1.5rem}
.faq-left p{font-size:1.125rem;color:var(--muted-fg)}
.faq-right{flex:2}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;padding:1.5rem 0;font-size:1.125rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--fg);transition:color .15s}
.faq-q:hover{color:var(--primary)}
.faq-q .chev{width:1rem;height:1rem;transition:transform .25s}
.faq-item.open .faq-q .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;color:var(--muted-fg);font-size:1rem;line-height:1.6;transition:max-height .3s ease,padding .3s}
.faq-item.open .faq-a{max-height:32rem;padding-bottom:1.5rem}

/* ============ Contact ============ */
.contact{background:hsl(0 0% 96%);position:relative;overflow:hidden}
.contact-bg{position:absolute;inset:0;opacity:.1}
.contact-bg img{width:100%;height:100%;object-fit:cover}
.contact-card{position:relative;max-width:56rem;margin:0 auto;background:#fff;color:var(--fg);border-radius:1.5rem;padding:1.5rem;box-shadow:var(--shadow-2xl);border:1px solid var(--border)}
@media(min-width:640px){.contact-card{padding:2rem}}
@media(min-width:768px){.contact-card{padding:3rem}}
.contact-card .head{text-align:center;margin-bottom:2.5rem}
.contact-card h2{font-family:'Playfair Display',serif;font-size:clamp(1.875rem,3.5vw,2.25rem);font-weight:700;margin-bottom:1rem}
.contact-card .head p{color:var(--muted-fg);font-size:1.125rem;max-width:36rem;margin:0 auto}
.contact-card .form-wrap{max-width:36rem;margin:0 auto}

/* ============ Footer ============ */
.footer{background:#fff;padding:5rem 0 2.5rem;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-bottom:4rem}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1fr 1fr 2fr}}
.footer h4{font-weight:700;font-size:1.125rem;margin-bottom:1.5rem}
.footer-nav{display:flex;flex-direction:column;gap:1rem}
.footer-nav a{color:var(--muted-fg);transition:color .15s}
.footer-nav a:hover{color:var(--primary)}
.footer-brand p{color:var(--muted-fg);margin-top:1.5rem}
.contact-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.contact-grid{grid-template-columns:repeat(2,1fr)}}
.contact-item{display:flex;gap:.75rem;color:var(--muted-fg);transition:color .15s}
.contact-item .icon-wrap{width:2.5rem;height:2.5rem;background:hsl(0 0% 96%);border-radius:9999px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.contact-item .icon-wrap .icon{color:var(--fg);width:1.25rem;height:1.25rem;transition:color .15s}
a.contact-item:hover{color:var(--primary)}
a.contact-item:hover .icon-wrap{background:var(--primary-bg-soft)}
a.contact-item:hover .icon-wrap .icon{color:var(--primary)}
.contact-item .title{color:var(--fg);font-weight:500;margin-bottom:.25rem}
.contact-item .big{font-size:1.125rem;color:var(--fg);font-weight:500;margin-bottom:.25rem}
.contact-item .small{font-size:.875rem;line-height:1.5}
.icon-wrap.messenger-wa{background:hsl(142 70% 45% / .12)}
.icon-wrap.messenger-wa .icon{color:#25D366}
.icon-wrap.messenger-tg{background:hsl(207 90% 54% / .12)}
.icon-wrap.messenger-tg .icon{color:#2AABEE}
a.messenger-item:hover .icon-wrap.messenger-wa{background:#25D366}
a.messenger-item:hover .icon-wrap.messenger-tg{background:#2AABEE}
a.messenger-item:hover .icon-wrap.messenger-wa .icon,a.messenger-item:hover .icon-wrap.messenger-tg .icon{color:#fff}
.footer-bottom{padding-top:2rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:space-between;color:var(--muted-fg);font-size:.875rem;text-align:center}
@media(min-width:768px){.footer-bottom{flex-direction:row;text-align:left}}
.footer-bottom a{text-decoration:underline;text-underline-offset:4px}
.footer-bottom a:hover{color:var(--primary)}

/* ============ Modal / Dialog ============ */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:1rem}
.modal.is-open{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.modal-card{position:relative;background:#fff;border:1px solid var(--border);border-radius:1rem;width:100%;max-width:600px;max-height:92vh;overflow:auto;box-shadow:var(--shadow-2xl);padding:1.5rem}
@media(min-width:640px){.modal-card{padding:2rem}}
.modal-close{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;border-radius:9999px;background:hsl(0 0% 96%) !important;display:flex;align-items:center;justify-content:center;color:#ff7732 !important}
.modal-close:hover{background:hsl(0 0% 90%) !important}
.modal-card h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}
.modal-card .desc{color:var(--muted-fg);margin-bottom:1.5rem}

/* ============ Lead form ============ */
.lead-form{display:flex;flex-direction:column;gap:1rem}
.lead-row{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.lead-row{grid-template-columns:1fr 1fr}}
.field label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:var(--fg)}
.field input,.field select,.field textarea{width:100%;border:1px solid hsl(0 0% 88%);border-radius:.5rem;padding:.625rem .75rem;font:inherit;background:#fff;color:var(--fg);transition:border-color .15s,box-shadow .15s}
.field textarea{resize:vertical;min-height:6rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px hsl(28 100% 48% / .15)}
.field .err{color:hsl(0 84% 45%);font-size:.8rem;margin-top:.25rem;display:none}
.field.has-err input,.field.has-err select,.field.has-err textarea{border-color:hsl(0 84% 55%)}
.field.has-err .err{display:block}
.consent{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0}
.consent input{margin-top:.25rem;width:40px;height:40px;accent-color:var(--primary)}
.consent label{font-size:.875rem;color:var(--muted-fg);font-weight:400;line-height:1.5}
.consent label a{color:var(--primary);text-decoration:underline}
.lead-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 0;gap:1rem}
.lead-success .circle{width:4rem;height:4rem;border-radius:9999px;background:var(--primary-bg-soft);color:var(--primary);display:flex;align-items:center;justify-content:center}
.lead-success .circle .icon{width:2rem;height:2rem}
.lead-success h3{font-family:'Playfair Display',serif;font-size:1.5rem}
.lead-success p{color:var(--muted-fg)}

/* ============ Breadcrumbs / inner pages ============ */
.crumbs{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-fg) !important;flex-wrap:wrap;margin-bottom:2rem}
.crumbs a:hover{color:var(--primary)}
.crumbs .icon{width:1rem;height:1rem}
.crumbs .current{color:var(--fg)}
.inner-main{padding-top:7rem}
@media(min-width:768px){.inner-main{padding-top:8rem}}
.page-eyebrow{display:inline-block;color:var(--primary);font-weight:600;font-size:.875rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.page-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,3.75rem);font-weight:700;margin-bottom:1.5rem;line-height:1.1}
.page-lead{font-size:1.125rem;color:var(--muted-fg);max-width:48rem}

/* ============ Project detail page ============ */
.detail-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:flex-start}
@media(min-width:1024px){.detail-grid{grid-template-columns:1fr 1fr;gap:4rem}}
.detail-cover{display:block;width:100%;aspect-ratio:4/3;border-radius:1rem;overflow:hidden;background:hsl(0 0% 96%);position:relative}
.detail-cover img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.detail-cover:hover img{transform:scale(1.05)}
.detail-cover .tag{position:absolute;top:1rem;left:1rem;background:hsl(0 0% 100% / .95);padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.detail-cover .open-tag{position:absolute;bottom:1rem;right:1rem;background:hsl(0 0% 100% / .95);padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:500}
.detail-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-top:.75rem}
.detail-thumbs button{aspect-ratio:1/1;border-radius:.375rem;overflow:hidden;background:hsl(0 0% 96%);position:relative}
.detail-thumbs button img{width:100%;height:100%;object-fit:cover;transition:opacity .2s}
.detail-thumbs button:hover img{opacity:.8}
.detail-thumbs .more-overlay{position:absolute;inset:0;background:hsl(0 0% 8% / .7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}
.detail-price{font-size:clamp(1.875rem,4vw,2.25rem);font-weight:700;color:var(--primary);margin-bottom:1rem}
.detail-title{font-family:'Playfair Display',serif;font-size:clamp(1.875rem,4vw,3rem);font-weight:700;margin-bottom:1.5rem;line-height:1.1}
.detail-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:2rem}
.detail-meta > div{background:hsl(0 0% 96%);border-radius:.5rem;padding:1rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.25rem}
.detail-meta .icon{width:1.25rem;height:1.25rem;color:var(--primary);margin-bottom:.25rem}
.detail-meta .num{font-size:1.5rem;font-weight:700}
.detail-meta .lbl{font-size:.7rem;color:var(--muted-fg);text-transform:uppercase;letter-spacing:.06em}
.detail-desc{font-size:1.05rem;color:var(--muted-fg);line-height:1.7;margin-bottom:1.5rem}
.detail-features{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}
.detail-features li{display:flex;gap:.75rem;align-items:flex-start}
.detail-features .icon{width:1.25rem;height:1.25rem;color:var(--primary);flex-shrink:0;margin-top:.125rem}
.detail-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}
@media(min-width:640px){.detail-actions{flex-direction:row}}
.detail-actions .btn{flex:1}
.gift-banner{display:flex;gap:.75rem;padding:1rem;border-radius:.5rem;background:var(--accent);border:1px solid hsl(28 100% 48% / .2)}
.gift-banner .icon{width:1.25rem;height:1.25rem;color:var(--primary);flex-shrink:0;margin-top:.125rem}
.gift-banner .ttl{font-weight:600;color:var(--fg)}
.gift-banner .sub{font-size:.875rem;color:var(--muted-fg)}
.trust-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:4rem;padding-top:3rem;border-top:1px solid var(--border)}
@media(min-width:768px){.trust-strip{grid-template-columns:repeat(4,1fr)}}
.trust-strip > div{display:flex;align-items:center;gap:.75rem}
.trust-strip .ico{width:2.5rem;height:2.5rem;border-radius:.375rem;background:var(--primary-bg-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trust-strip .ico .icon{width:1.25rem;height:1.25rem}
.trust-strip span{font-size:.875rem;font-weight:500}
.spec-list{display:flex;flex-direction:column;gap:0}
.spec-list .row{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border)}
.spec-list dt{color:var(--muted-fg);font-size:.875rem;flex-shrink:0;max-width:55%}
.spec-list dd{font-weight:600;font-size:.9rem;text-align:right}
.rooms-block{display:flex;flex-direction:column;gap:1.5rem}
.rooms-block .floor-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.09em;font-weight:700;color:var(--primary);margin-bottom:.75rem;padding:.2rem .625rem;background:var(--primary-bg-soft);border-radius:9999px;display:inline-block}
.rooms-grid{display:grid;grid-template-columns:1fr 1fr;gap:.625rem}
@media(min-width:400px){.rooms-grid{gap:.75rem}}
@media(min-width:640px){.rooms-grid{grid-template-columns:repeat(3,1fr)}}
.rooms-grid > div{background:hsl(0 0% 97%);border-radius:.625rem;padding:.875rem}
.rooms-grid .nm{font-size:.8rem;color:var(--muted-fg);margin-bottom:.2rem;line-height:1.3}
.rooms-grid .ar{font-weight:700;font-size:.95rem}

.detail-pkg-tabs{max-width:64rem;margin:0 auto}
.detail-pkg-list{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem;padding:.25rem;background:#fff;border:1px solid var(--border);border-radius:.75rem}
.detail-pkg-list button{display:flex;flex-direction:column;gap:.25rem;padding:1rem .5rem;border-radius:.5rem;text-align:center;transition:background .2s,color .2s}
.detail-pkg-list button.is-active{background:var(--primary);color:var(--primary-fg)}
.detail-pkg-list .nm{font-weight:700;font-size:1rem}
.detail-pkg-list .pr{font-size:.75rem;opacity:.9}
.detail-pkg-panel{margin-top:1.5rem;background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}
@media(min-width:768px){.detail-pkg-panel{padding:2rem}}
.detail-pkg-head{display:flex;flex-direction:column;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
@media(min-width:768px){.detail-pkg-head{flex-direction:row;align-items:center}}
.detail-pkg-head .nm{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700}
@media(min-width:640px){.detail-pkg-head .nm{font-size:1.75rem}}
.btn-short{display:inline}
.btn-long{display:none}
@media(min-width:640px){.btn-short{display:none}.btn-long{display:inline}}
.detail-pkg-head .tg{color:var(--muted-fg)}
.detail-pkg-head .pr{font-size:1.875rem;font-weight:700;color:var(--primary)}
.specs-section{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--primary);padding-top:.75rem;display:block}
.specs-row{display:grid;grid-template-columns:1fr;gap:.5rem;font-size:.875rem;padding:.5rem .5rem;border-bottom:1px solid hsl(0 0% 90% / .5);border-radius:.375rem}
@media(min-width:768px){.specs-row{grid-template-columns:5fr 7fr;gap:.75rem}}
.specs-row .lbl{color:var(--muted-fg)}
.specs-row .val{color:var(--fg);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.specs-row-diff{background:hsl(0 0% 97%);border-left:3px solid var(--primary);padding-left:.625rem}
.spec-badge{display:inline-flex;align-items:center;font-size:.65rem;font-weight:700;letter-spacing:.04em;padding:.15rem .45rem;border-radius:9999px;flex-shrink:0;white-space:nowrap}
.spec-no{background:hsl(0 0% 90%);color:hsl(0 0% 45%)}
.spec-yes{background:hsl(28 100% 48% / .12);color:var(--primary)}
.spec-alt{background:hsl(215 80% 55% / .12);color:hsl(215 80% 45%)}

.cta-dark{background:var(--fg);color:#fff;border-radius:1rem;padding:2rem;text-align:center;margin-top:4rem}
@media(min-width:768px){.cta-dark{padding:3rem}}
.cta-dark h2{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700;margin-bottom:1rem}
.cta-dark p{font-size:1rem;opacity:.85;max-width:36rem;margin:0 auto 2rem}
@media(min-width:768px){.cta-dark p{font-size:1.125rem}}

/* ============ Lightbox ============ */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.95);display:none;align-items:center;justify-content:center;padding:1rem}
.lightbox.is-open{display:flex}
.lightbox img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:.5rem}
.lightbox .close,.lightbox .nav{position:absolute;color:hsl(0 0% 100% / .9);padding:0.8rem;background:#f57200;border-radius: 12px}
.lightbox .close{top:1.5rem;right:1.5rem}
.lightbox .close .icon{width:2rem;height:2rem}
.lightbox .nav{font-size:2rem;line-height:1;user-select:none}
.lightbox .nav.prev{left:1.5rem}
.lightbox .nav.next{right:1.5rem}
.lightbox .counter{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);color:hsl(0 0% 100% / .8);font-size:.875rem;background:rgba(0,0,0,.5);padding:.25rem .75rem;border-radius:9999px}

/* ============ Split CTA ============ */
.split-cta{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:2.5rem}
@media(min-width:640px){.split-cta{gap:1.5rem;margin-top:3.5rem}}
@media(min-width:768px){.split-cta{grid-template-columns:1fr 1fr;margin-top:4rem}}
.split-cta-card{border-radius:1.25rem;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}
@media(min-width:768px){.split-cta-card{padding:2.5rem;gap:1.25rem}}
.split-cta-card .scc-icon{width:2.5rem;height:2.5rem;border-radius:.625rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
@media(min-width:768px){.split-cta-card .scc-icon{width:3rem;height:3rem;border-radius:.75rem}}
.split-cta-card .scc-icon .icon{width:1.25rem;height:1.25rem}
@media(min-width:768px){.split-cta-card .scc-icon .icon{width:1.5rem;height:1.5rem}}
.split-cta-card h3{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;line-height:1.25}
@media(min-width:768px){.split-cta-card h3{font-size:1.5rem}}
.split-cta-card p{font-size:.9rem;line-height:1.6;flex:1}
@media(min-width:768px){.split-cta-card p{font-size:.975rem}}
.split-cta-card .btn{width:100%;white-space:normal;word-break:break-word;height:auto;min-height:3.5rem;padding:.75rem 1.25rem;line-height:1.3}
@media(min-width:480px){.split-cta-card .btn{width:auto}}
.split-cta-primary{background:hsl(0 0% 8%);color:#fff}
.split-cta-primary .scc-icon{background:rgba(255,255,255,.1)}
.split-cta-primary p{opacity:.75}
.split-cta-outline{background:#fff;border:2px solid var(--primary);color:var(--fg)}
.split-cta-outline .scc-icon{background:var(--primary-bg-soft);color:var(--primary)}
.split-cta-outline p{color:var(--muted-fg)}
.split-cta-outline h3{color:var(--fg)}

/* ============ Contacts block ============ */
.contacts-block{background:#fff;border-top:1px solid var(--border)}
.contacts-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:1024px){.contacts-grid{grid-template-columns:1fr 1fr;gap:4rem;align-items:flex-start}}
.contacts-info h2{font-family:'Playfair Display',serif;font-size:clamp(1.875rem,3vw,2.5rem);font-weight:700;margin-bottom:.75rem}
.contacts-info .sub{color:var(--muted-fg);font-size:1.05rem;margin-bottom:2.5rem}
.contacts-list{display:flex;flex-direction:column;gap:1.25rem}
.ci{display:flex;align-items:flex-start;gap:1rem}
.ci-icon{width:3rem;height:3rem;border-radius:.75rem;background:var(--primary-bg-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-icon .icon,.ci-icon svg{width:1.35rem;height:1.35rem}
.ci-body .lbl{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--muted-fg);margin-bottom:.2rem}
.ci-body .val{font-size:1rem;font-weight:600;color:var(--fg);line-height:1.4}
.ci-body .val.small{font-size:.9rem;font-weight:400;color:hsl(0 0% 8% / .8)}
a.ci:hover .ci-icon{background:var(--primary);color:#fff}
a.ci:hover .ci-body .val{color:var(--primary)}
.contacts-map{border-radius:1rem;overflow:hidden;background:hsl(0 0% 92%);border:1px solid var(--border);position:sticky;top:6rem}
.contacts-map .map-placeholder{height:22rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--muted-fg);font-size:.875rem;text-align:center;padding:2rem}
.contacts-map .map-placeholder .icon{width:2.5rem;height:2.5rem;color:var(--border)}
.contacts-map iframe{width:100%;height:22rem;border:none;display:block}
.wa-icon{fill:currentColor}
.tg-icon{fill:currentColor}

/* ============ Comparison table ============ */
.compare-toggle{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary);font-weight:500;background:transparent;padding:.5rem 0;transition:opacity .15s;font-size:1rem}
.compare-toggle:hover{opacity:.8}
.compare-toggle .chev{width:1rem;height:1rem;transition:transform .3s}
.compare-toggle.is-open .chev{transform:rotate(180deg)}
.compare-wrap{overflow:hidden;max-height:0;transition:max-height .5s ease;margin-top:0}
.compare-wrap.is-open{max-height:3000px;margin-top:2rem}
.compare-table-scroll{overflow-x:auto}
.compare-table{width:100%;min-width:700px;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm)}
.compare-table th,.compare-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);font-size:.875rem}
.compare-table th{background:hsl(0 0% 96% / .6);font-weight:700}
.compare-table th:not(:first-child){text-align:center}
.compare-table td:not(:first-child){text-align:center}
.compare-table th.optimum-col{background:hsl(28 100% 48% / .06);color:var(--primary)}
.compare-table td.optimum-col{background:hsl(28 100% 48% / .04)}
.compare-table td.primary{font-weight:600;color:var(--primary)}
.compare-table tbody tr:hover{background:hsl(0 0% 96% / .5)}
.compare-table tfoot td{background:hsl(0 0% 96% / .4);color:var(--muted-fg);font-size:.75rem;font-style:italic;text-align:center;padding:.75rem 1rem}
.compare-table .icon{width:1rem;height:1rem;margin:0 auto}
.compare-section-row td{background:hsl(28 100% 48% / .06);color:var(--primary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;padding:.5rem 1rem;border-bottom:1px solid var(--border)}

/* ============ Privacy / prose ============ */
.prose{max-width:none;font-size:1.05rem;line-height:1.75;color:hsl(0 0% 8% / .9)}
.prose section{margin-bottom:2rem}
.prose h2{font-family:'Playfair Display',serif;font-size:clamp(1.25rem,2.4vw,1.5rem);font-weight:700;color:var(--fg);margin-bottom:1rem}
.prose ol,.prose ul{padding-left:1.4rem;display:flex;flex-direction:column;gap:.75rem}
.prose ol{list-style:decimal}
.prose ul{list-style:disc}
.prose p{margin-bottom:.75rem}

/* ============ Footer ============ */
.uk-footer{background:#fff;border-top:1px solid var(--border);padding:5rem 0 2.5rem}
.uk-footer .container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-bottom:4rem}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1fr 1fr 2fr}}
.uk-footer h4{font-weight:700;font-size:1.125rem;margin-bottom:1.5rem;color:var(--fg)}
.footer-nav-list{display:flex;flex-direction:column;gap:1rem}
.footer-nav-list a{color:var(--muted-fg) !important;transition:color .15s}
.footer-nav-list a:hover{color:var(--primary)}
.footer-brand-desc{color:var(--muted-fg);margin-top:1.5rem}
.contact-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.contact-grid{grid-template-columns:repeat(2,1fr)}}
.contact-item{display:flex;gap:.75rem;color:var(--muted-fg) !important;transition:color .15s;text-decoration:none}
.contact-item .icon-wrap{width:2.5rem;height:2.5rem;background:hsl(0 0% 96%);border-radius:9999px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.contact-item .icon-wrap svg{color:var(--fg);width:1.25rem;height:1.25rem;transition:color .15s}
a.contact-item:hover{color:var(--primary)}
a.contact-item:hover .icon-wrap{background:var(--primary-bg-soft)}
a.contact-item:hover .icon-wrap svg{color:var(--primary)}
.contact-item .ci-title{color:var(--fg);font-weight:500;margin-bottom:.25rem}
.contact-item .ci-big{font-size:1.125rem;color:var(--fg);font-weight:500;margin-bottom:.25rem}
.contact-item .ci-small{font-size:.875rem;line-height:1.5}
.contact-item .ci-route{font-size:.875rem;color:var(--primary);margin-top:.2rem}
.icon-wrap.messenger-wa{background:hsl(142 70% 45% / .12)}
.icon-wrap.messenger-wa svg{color:#25D366}
.icon-wrap.messenger-tg{background:hsl(207 90% 54% / .12)}
.icon-wrap.messenger-tg svg{color:#2AABEE}
a.messenger-item:hover .icon-wrap.messenger-wa{background:#25D366}
a.messenger-item:hover .icon-wrap.messenger-tg{background:#2AABEE}
a.messenger-item:hover .icon-wrap.messenger-wa svg,a.messenger-item:hover .icon-wrap.messenger-tg svg{color:#fff}
.footer-bottom{padding-top:2rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:space-between;color:var(--muted-fg);font-size:.875rem;text-align:center}
@media(min-width:768px){.footer-bottom{flex-direction:row;text-align:left}}
.footer-bottom a{text-decoration:underline;text-underline-offset:4px;transition:color .15s}
.footer-bottom a:hover{color:var(--primary)}

/* ============ Animations ============ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

#rec2187098711 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

#rec2186659951 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

#rec2187016101 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

#rec2187016271 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

#rec2187016551 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

#rec2187017431 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}
#rec2187017511 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}
#rec2114006861 {
  position: absolute !important;
  left: -99999px !important;
  top: 0 !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}


#allrecords a {
    color: #000;
}

.t-records a {
    color: #000;
}












/* ================================================================
   УльтраКаркас — unified custom CSS (точная копия React-приложения)
   Primary: #f57a00 | Bg: #fff | Fg: #141414
   Fonts: Golos Text (sans) + Playfair Display (serif)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Golos+Text:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,700&display=swap');

/* ── TOKENS ── */
:root {
  --uk-primary:      #f57a00;
  --uk-primary-90:   rgba(245,122,0,.90);
  --uk-primary-10:   rgba(245,122,0,.10);
  --uk-primary-05:   rgba(245,122,0,.05);
  --uk-primary-20:   rgba(245,122,0,.20);
  --uk-fg:           #141414;  /* hsl(0 0% 8%) */
  --uk-fg-80:        rgba(20,20,20,.80);
  --uk-bg:           #ffffff;
  --uk-muted:        #f5f5f5;  /* hsl(0 0% 96%) */
  --uk-muted-fg:     #666666;  /* hsl(0 0% 40%) */
  --uk-border:       #e5e5e5;  /* hsl(0 0% 90%) */
  --uk-card:         #ffffff;
  --uk-sans:         'Golos Text', system-ui, sans-serif;
  --uk-serif:        'Playfair Display', Georgia, serif;
  --uk-r:            0.5rem;   /* base radius */
  --uk-r-xl:         0.75rem;
  --uk-r-2xl:        1rem;
  --uk-r-3xl:        1.5rem;
  --uk-container:    1280px;
  --uk-px:           1.5rem;
}

/* ── RESET ── */
.uk *, .uk *::before, .uk *::after { box-sizing: border-box; margin: 0; padding: 0; }
.uk { font-family: var(--uk-sans); color: var(--uk-fg); background: var(--uk-bg); -webkit-font-smoothing: antialiased; line-height: 1.5; }
.uk a { color: inherit; text-decoration: none; }
.uk img { display: block; max-width: 100%; }

/* ── CONTAINER ── */
.uk-wrap {
  max-width: var(--uk-container);
  margin: 0 auto;
  padding: 0 var(--uk-px);
}
@media (max-width: 640px) { .uk-wrap { padding: 0 1rem; } }

/* ── SECTION SPACING ── */
.uk-section { padding: 2.5rem 0; }
@media (min-width: 768px) { .uk-section { padding: 3.5rem 0; } }
.uk-section--muted { background: var(--uk-muted); }

/* ── TYPOGRAPHY ── */
.uk-eyebrow {
  display: inline-block;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--uk-primary);
  margin-bottom: 1rem;
}
.uk-h1 {
  font-family: var(--uk-serif);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 700;
  line-height: 1.05;
}
.uk-h2 {
  font-family: var(--uk-serif);
  font-size: clamp(1.875rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
}
.uk-h3 { font-family: var(--uk-serif); font-size: 1.5rem; font-weight: 700; }
.uk-lead { font-size: 1.125rem; color: var(--uk-muted-fg); line-height: 1.65; }
.uk-section-header { text-align: center; max-width: 48rem; margin: 0 auto 2.5rem; }
@media (min-width: 768px) { .uk-section-header { margin-bottom: 3.5rem; } }

/* ── BUTTONS ── */
.uk-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  font-family: var(--uk-sans); font-size: .9375rem; font-weight: 600;
  height: 2.75rem; padding: 0 1.5rem;
  border: none; border-radius: var(--uk-r);
  cursor: pointer; white-space: nowrap; transition: opacity .2s, box-shadow .2s;
  text-decoration: none;
}
.uk-btn--primary { background: var(--uk-primary); color: #fff; }
.uk-btn--primary:hover { opacity: .9; }
.uk-btn--outline { background: transparent; color: var(--uk-fg); border: 1.5px solid var(--uk-border); }
.uk-btn--outline:hover { border-color: var(--uk-primary); color: var(--uk-primary); }
.uk-btn--ghost-white {
  background: transparent; color: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.14);
}
.uk-btn--ghost-white:hover { color: #fff; border-color: rgba(255,255,255,.28); background: rgba(255,255,255,.08); }
.uk-btn--lg { height: 3.25rem; padding: 0 2rem; font-size: 1rem; }

/* ── NAVBAR ── */
.uk-navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  transition: background .3s, border-color .3s, padding .3s, box-shadow .3s;
  border-bottom: 1px solid transparent;
}
.uk-navbar.uk-scrolled, .uk-navbar.uk-inner {
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(12px);
  border-color: var(--uk-border);
  box-shadow: 0 1px 3px rgba(0,0,0,.08);
  padding: .75rem 0;
}
.uk-navbar:not(.uk-scrolled):not(.uk-inner) { padding: 1.25rem 0; }
.uk-navbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.uk-navbar__logo { display: flex; align-items: center; gap: .5rem; cursor: pointer; text-decoration: none; }
.uk-navbar__badge {
  width: 2.5rem; height: 2.5rem; background: var(--uk-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--uk-serif); font-size: 1.25rem; font-weight: 700; border-radius: .25rem;
  flex-shrink: 0;
}
.uk-navbar__name {
  font-family: var(--uk-serif); font-size: 1.25rem; font-weight: 700;
  letter-spacing: -.01em; transition: color .3s;
}
.uk-navbar:not(.uk-scrolled):not(.uk-inner) .uk-navbar__name { color: #fff; }
.uk-navbar.uk-scrolled .uk-navbar__name, .uk-navbar.uk-inner .uk-navbar__name { color: var(--uk-fg); }
.uk-navbar__nav { display: none; }
@media (min-width: 1024px) {
  .uk-navbar__nav { display: flex; align-items: center; gap: 2rem; }
}
.uk-navbar__link {
  font-size: .875rem; font-weight: 500; transition: color .2s;
  text-decoration: none;
}
.uk-navbar:not(.uk-scrolled):not(.uk-inner) .uk-navbar__link { color: rgba(255,255,255,.8); }
.uk-navbar.uk-scrolled .uk-navbar__link, .uk-navbar.uk-inner .uk-navbar__link { color: rgba(20,20,20,.8); }
.uk-navbar__link:hover { color: var(--uk-primary) !important; }
.uk-navbar__right { display: none; align-items: center; gap: 1.5rem; }
@media (min-width: 768px) { .uk-navbar__right { display: flex; } }
.uk-navbar__phone {
  display: flex; align-items: center; gap: .5rem; font-weight: 500;
  font-size: .9375rem; transition: color .2s; text-decoration: none;
}
.uk-navbar:not(.uk-scrolled):not(.uk-inner) .uk-navbar__phone { color: rgba(255,255,255,.9); }
.uk-navbar.uk-scrolled .uk-navbar__phone, .uk-navbar.uk-inner .uk-navbar__phone { color: var(--uk-fg); }
.uk-navbar__phone:hover { color: var(--uk-primary) !important; }
.uk-navbar__phone-dot { width: 1rem; height: 1rem; color: var(--uk-primary); }
.uk-navbar__mobile-right { display: flex; align-items: center; gap: .25rem; }
@media (min-width: 1024px) { .uk-navbar__mobile-right { display: none; } }
.uk-navbar__call-btn {
  width: 2.5rem; height: 2.5rem; border-radius: 50%; background: var(--uk-primary); color: #fff;
  display: flex; align-items: center; justify-content: center; border: none; cursor: pointer;
}
.uk-navbar__menu-btn { background: none; border: none; cursor: pointer; padding: .5rem; }
.uk-navbar__menu-btn svg { width: 1.5rem; height: 1.5rem; }
.uk-navbar:not(.uk-scrolled):not(.uk-inner) .uk-navbar__menu-btn { color: #fff; }
.uk-navbar.uk-scrolled .uk-navbar__menu-btn, .uk-navbar.uk-inner .uk-navbar__menu-btn { color: var(--uk-fg); }

/* Mobile nav */
.uk-mobile-nav {
  position: fixed; inset: 0; z-index: 40; background: var(--uk-bg);
  padding: 6rem 1.5rem 1.5rem; display: flex; flex-direction: column;
  transform: translateY(-100%); transition: transform .3s ease;
}
.uk-mobile-nav.uk-open { transform: translateY(0); }
.uk-mobile-nav__links { display: flex; flex-direction: column; gap: 1.5rem; text-align: center; }
.uk-mobile-nav__link {
  font-size: 1.125rem; font-weight: 500; color: var(--uk-fg);
  text-decoration: none; padding: .5rem 0; transition: color .2s;
}
.uk-mobile-nav__link:hover { color: var(--uk-primary); }
.uk-mobile-nav__bottom { margin-top: auto; padding-top: 1.5rem; border-top: 1px solid var(--uk-border); }
.uk-mobile-nav__phone-big {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  font-size: 1.25rem; font-weight: 500; color: var(--uk-fg); margin-bottom: 1rem;
  text-decoration: none;
}



/* ── PAYMENT STAGES ── */
.uk-pay { background: var(--uk-bg); }
.uk-pay-bar { max-width: 48rem; margin: 0 auto 2.5rem; }
.uk-pay-bar__track { display: flex; border-radius: 9999px; overflow: hidden; height: 1rem; box-shadow: inset 0 1px 4px rgba(0,0,0,.1); margin-bottom: .75rem; }
.uk-pay-bar__seg { height: 100%; position: relative; }
.uk-pay-bar__pcts { display: flex; justify-content: space-between; }
.uk-pay-bar__pct { text-align: center; font-size: .75rem; font-weight: 600; }
.uk-pay-grid {
  display: grid; grid-template-columns: 1fr; gap: 1rem;
  max-width: 75rem; margin: 0 auto;
}
@media (min-width: 640px) { .uk-pay-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .uk-pay-grid { grid-template-columns: repeat(4, 1fr); gap: 1.25rem; } }
.uk-pay-card {
  background: var(--uk-card); border: 1px solid var(--uk-border);
  border-radius: var(--uk-r-2xl); overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.05);
  transition: box-shadow .2s;
}
.uk-pay-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.1); }
.uk-pay-card__top { height: 6px; }
.uk-pay-card__body { padding: 1.25rem; }
.uk-pay-card__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.uk-pay-card__icon { width: 2.5rem; height: 2.5rem; border-radius: .75rem; display: flex; align-items: center; justify-content: center; }
.uk-pay-card__icon svg { width: 1.25rem; height: 1.25rem; }
.uk-pay-card__pct { font-size: 1.5rem; font-weight: 900; line-height: 1; }
.uk-pay-card__pct-sub { font-size: 10px; color: var(--uk-muted-fg); line-height: 1; }
.uk-pay-card__when { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--uk-muted-fg); margin-bottom: .25rem; }
.uk-pay-card__title { font-size: 1rem; font-weight: 700; color: var(--uk-fg); margin-bottom: .75rem; line-height: 1.3; }
.uk-pay-card__list { list-style: none; display: flex; flex-direction: column; gap: .375rem; margin-bottom: 1rem; }
.uk-pay-card__item { display: flex; align-items: flex-start; gap: .5rem; font-size: .75rem; color: var(--uk-muted-fg); line-height: 1.4; }
.uk-pay-card__dot { width: .375rem; height: .375rem; border-radius: 50%; margin-top: .375rem; flex-shrink: 0; }
.uk-pay-card__note { border-radius: .75rem; padding: .75rem; font-size: .75rem; font-weight: 500; line-height: 1.4; }
.uk-pay-banner {
  max-width: 48rem; margin: 2rem auto 0;
  border: 1px solid rgba(245,122,0,.20); border-radius: var(--uk-r-2xl);
  padding: 1.25rem 1.5rem; display: flex; flex-direction: column; gap: 1rem;
  background: var(--uk-primary-05);
}
@media (min-width: 640px) { .uk-pay-banner { flex-direction: row; align-items: center; } }
.uk-pay-banner__icon { padding: .75rem; background: var(--uk-primary-10); border-radius: .75rem; flex-shrink: 0; }
.uk-pay-banner__icon svg { width: 1.75rem; height: 1.75rem; color: var(--uk-primary); stroke: var(--uk-primary); }
.uk-pay-banner__title { font-weight: 700; color: var(--uk-fg); margin-bottom: .25rem; }
.uk-pay-banner__text { font-size: .875rem; color: var(--uk-muted-fg); line-height: 1.65; }





=
/* ── VACANCIES PAGE ── */
.uk-vac-header { text-align: center; max-width: 48rem; margin: 0 auto 3rem; }
.uk-vac-card {
  background: var(--uk-card); border: 1px solid var(--uk-border);
  border-radius: var(--uk-r-2xl); overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.05); margin-bottom: 2rem;
}
.uk-vac-card__top { height: 6px; }
.uk-vac-card__body { padding: 1.5rem 2rem; }
.uk-vac-card__meta { display: flex; flex-wrap: wrap; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; }
.uk-vac-card__badge {
  display: inline-block; font-size: .75rem; font-weight: 600;
  padding: .25rem .75rem; border-radius: 9999px; margin-bottom: .75rem;
}
.uk-vac-card__title { font-family: var(--uk-serif); font-size: 1.5rem; font-weight: 700; margin-bottom: .5rem; }
@media (min-width: 768px) { .uk-vac-card__title { font-size: 2rem; } }
.uk-vac-card__info { display: flex; flex-wrap: wrap; gap: 1rem; font-size: .875rem; color: var(--uk-muted-fg); }
.uk-vac-card__info-item { display: flex; align-items: center; gap: .375rem; }
.uk-vac-card__info-item svg { width: 1rem; height: 1rem; stroke: var(--uk-muted-fg); }
.uk-vac-card__salary { font-weight: 600; }
.uk-vac-apply-btn {
  flex-shrink: 0; display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.5rem; border-radius: .75rem; font-family: var(--uk-sans);
  font-size: .9375rem; font-weight: 600; color: #fff; border: none; cursor: pointer;
  transition: opacity .2s; text-decoration: none;
}
.uk-vac-apply-btn:hover { opacity: .9; }
.uk-vac-card__summary { color: var(--uk-muted-fg); line-height: 1.65; margin-bottom: 1.5rem; }
.uk-vac-3col { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 768px) { .uk-vac-3col { grid-template-columns: repeat(3, 1fr); } }
.uk-vac-col-title { font-size: .875rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .75rem; }
.uk-vac-list { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.uk-vac-list li { display: flex; align-items: flex-start; gap: .5rem; font-size: .875rem; color: var(--uk-muted-fg); line-height: 1.4; }
.uk-vac-dot { width: .375rem; height: .375rem; border-radius: 50%; margin-top: .4rem; flex-shrink: 0; }
.uk-vac-open {
  max-width: 56rem; background: var(--uk-primary-05);
  border: 1px solid rgba(245,122,0,.20); border-radius: var(--uk-r-2xl);
  padding: 1.5rem 2rem; text-align: center; margin-top: 3rem;
}
.uk-vac-open h3 { font-family: var(--uk-serif); font-size: 1.25rem; font-weight: 700; margin-bottom: .5rem; }
.uk-vac-open p { color: var(--uk-muted-fg); margin-bottom: 1.5rem; }
.uk-vac-open__btns { display: flex; flex-wrap: wrap; justify-content: center; gap: 1rem; }


/* ── UTILITIES ── */
.uk-hidden { display: none !important; }
.uk-pt-nav { padding-top: 7rem; }
@media (min-width: 768px) { .uk-pt-nav { padding-top: 8rem; } }
.uk-text-center { text-align: center; }
.uk-mb-0 { margin-bottom: 0 !important; }

/* ════════════════════════════════════════════════════
   T001 — HOME: additional sections
   ════════════════════════════════════════════════════ */

/* ── COMPARISON SECTION (slate-950) ── */
.uk-cmp { position: relative; overflow: hidden; background: #020617; color: #fff; padding: 2.5rem 0; }
@media (min-width:768px){ .uk-cmp { padding: 3.5rem 0; } }
.uk-cmp__gridbg { position:absolute; inset:0; opacity:.04; background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px); background-size:40px 40px; pointer-events:none; }
.uk-cmp__inner { position:relative; }
.uk-cmp__header { text-align:center; max-width:48rem; margin:0 auto 3rem; }
@media (min-width:768px){ .uk-cmp__header { margin-bottom:4rem; } }
.uk-cmp__eyebrow { display:inline-flex; align-items:center; gap:.5rem; color:#fb923c; font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.875rem; margin-bottom:1rem; }
.uk-cmp__eyebrow svg { width:1rem; height:1rem; }
.uk-cmp__h2 { font-family:var(--uk-serif); font-weight:700; color:#fff; font-size:clamp(1.875rem,4vw,3rem); line-height:1.1; margin-bottom:1.25rem; }
.uk-cmp__h2 .uk-cmp-red { color:#ff0000; }
.uk-cmp__h2 .uk-cmp-prim { color:var(--uk-primary); font-style:italic; }
.uk-cmp__lead { font-size:1.125rem; color:#94a3b8; line-height:1.65; }
.uk-cmp-scn-grid { display:grid; grid-template-columns:1fr; gap:1.5rem; margin-bottom:3.5rem; }
@media (min-width:1024px){ .uk-cmp-scn-grid { grid-template-columns:1fr 1fr; } }
.uk-cmp-scn { background:rgba(15,23,42,.7); border:1px solid rgba(51,65,85,.6); border-radius:1rem; overflow:hidden; }
.uk-cmp-scn__head { display:flex; align-items:center; gap:.75rem; padding:.75rem 1.25rem; background:rgba(30,41,59,.6); border-bottom:1px solid rgba(51,65,85,.5); }
.uk-cmp-scn__head svg { width:1.25rem; height:1.25rem; stroke:#cbd5e1; }
.uk-cmp-scn__head span { font-weight:700; color:#e2e8f0; font-size:.875rem; }
.uk-cmp-scn__body { display:grid; grid-template-columns:1fr 1fr; }
.uk-cmp-col { padding:1rem; }
.uk-cmp-col--them { border-right:1px solid rgba(51,65,85,.5); }
.uk-cmp-col__tag { display:flex; align-items:center; gap:.375rem; margin-bottom:.75rem; }
.uk-cmp-col__tag svg { width:1rem; height:1rem; flex-shrink:0; }
.uk-cmp-col__tag span { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
.uk-cmp-col__tag--bad svg { stroke:#ff0000; } .uk-cmp-col__tag--bad span { color:#ff0000; }
.uk-cmp-col__tag--good svg { stroke:#34d399; } .uk-cmp-col__tag--good span { color:#34d399; }
.uk-cmp-house { height:9rem; margin-bottom:.75rem; border-radius:.75rem; overflow:hidden; position:relative; }
.uk-cmp-house svg { width:100%; height:100%; display:block; }
.uk-cmp-badge { position:absolute; top:.5rem; right:.5rem; color:#fff; font-size:9px; font-weight:700; padding:.125rem .5rem; border-radius:9999px; }
.uk-cmp-badge--red { background:rgba(239,68,68,.9); }
.uk-cmp-badge--green { background:rgba(16,185,129,.9); }
.uk-cmp-col__desc { font-size:.75rem; color:#94a3b8; line-height:1.6; }
.uk-cmp-table { background:rgba(15,23,42,.6); border:1px solid rgba(51,65,85,.6); border-radius:1rem; overflow:hidden; margin-bottom:2.5rem; }
.uk-cmp-table__head, .uk-cmp-table__row { display:grid; grid-template-columns:1.1fr 1fr 1fr; }
.uk-cmp-table__head { background:rgba(30,41,59,.8); border-bottom:1px solid rgba(51,65,85,.5); }
.uk-cmp-th { padding:.75rem 1rem; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:#94a3b8; display:flex; align-items:center; gap:.5rem; }
@media (min-width:768px){ .uk-cmp-th { padding:.75rem 1.5rem; } }
.uk-cmp-th--bd { border-left:1px solid rgba(51,65,85,.5); }
.uk-cmp-th--us { background:var(--uk-primary-10); }
.uk-cmp-th svg { width:.875rem; height:.875rem; flex-shrink:0; }
.uk-cmp-th--them svg { stroke:#ff0000; } .uk-cmp-th--them span { color:#ff0000; }
.uk-cmp-th--us svg { stroke:#34d399; } .uk-cmp-th--us span { color:#34d399; }
.uk-cmp-table__row { border-bottom:1px solid rgba(30,41,59,.7); }
.uk-cmp-table__row:last-child { border-bottom:0; }
.uk-cmp-table__row--alt { background:rgba(15,23,42,.3); }
.uk-cmp-td { padding:.875rem 1rem; }
@media (min-width:768px){ .uk-cmp-td { padding:.875rem 1.5rem; } }
.uk-cmp-td--aspect span { font-size:.875rem; font-weight:600; color:#e2e8f0; }
.uk-cmp-td--them, .uk-cmp-td--us { border-left:1px solid rgba(30,41,59,.5); display:flex; align-items:flex-start; gap:.5rem; }
.uk-cmp-td--us { background:var(--uk-primary-05); }
.uk-cmp-td svg { width:.875rem; height:.875rem; margin-top:.125rem; flex-shrink:0; }
.uk-cmp-td--them svg { stroke:rgba(239,68,68,.7); }
.uk-cmp-td--us svg { stroke:#34d399; }
.uk-cmp-td--them span { font-size:.75rem; color:#94a3b8; line-height:1.6; }
.uk-cmp-td--us span { font-size:.75rem; color:#e2e8f0; line-height:1.6; }
.uk-cmp-cta { display:grid; grid-template-columns:1fr; gap:1rem; }
@media (min-width:768px){ .uk-cmp-cta { grid-template-columns:repeat(3,1fr); } }
.uk-cmp-cta__card { border-radius:.75rem; border:1px solid; padding:1.25rem; }
.uk-cmp-cta__card--orange { background:rgba(251,146,60,.1); border-color:rgba(251,146,60,.2); }
.uk-cmp-cta__card--blue { background:rgba(96,165,250,.1); border-color:rgba(96,165,250,.2); }
.uk-cmp-cta__card--green { background:rgba(52,211,153,.1); border-color:rgba(52,211,153,.2); }
.uk-cmp-cta__icon { width:2rem; height:2rem; border-radius:.5rem; background:rgba(255,255,255,.05); display:flex; align-items:center; justify-content:center; margin-bottom:.75rem; }
.uk-cmp-cta__icon svg { width:1.25rem; height:1.25rem; }
.uk-cmp-cta__card--orange .uk-cmp-cta__icon svg { stroke:#fb923c; }
.uk-cmp-cta__card--blue .uk-cmp-cta__icon svg { stroke:#60a5fa; }
.uk-cmp-cta__card--green .uk-cmp-cta__icon svg { stroke:#34d399; }
.uk-cmp-cta__title { font-weight:700; color:#fff; margin-bottom:.25rem; }
.uk-cmp-cta__text { font-size:.875rem; color:#94a3b8; line-height:1.6; }
@media (max-width:480px){ .uk-cmp-scn__body { grid-template-columns:1fr; } .uk-cmp-col--them { border-right:0; border-bottom:1px solid rgba(51,65,85,.5); } }
@media (max-width:640px){
  .uk-cmp-table__head { grid-template-columns:1fr 1fr; }
  .uk-cmp-table__head .uk-cmp-th:first-child { display:none; }
  .uk-cmp-th--them { border-left:0; }
  .uk-cmp-th { padding:.6rem .9rem; }
  .uk-cmp-table__row { grid-template-columns:1fr 1fr; }
  .uk-cmp-td--aspect { grid-column:1 / -1; padding:.75rem .9rem .25rem; }
  .uk-cmp-td--them { border-left:0; }
  .uk-cmp-td--them, .uk-cmp-td--us { padding:.5rem .9rem .75rem; }
  .uk-cmp-td--them span, .uk-cmp-td--us span, .uk-cmp-th span { font-size:.6875rem; }
  .uk-cmp-td--aspect span { font-size:.875rem; }
}

/* ── PROJECT OPTIONS (muted/20) ── */
.uk-popt { background:#fafafa; padding:2.5rem 0; overflow:hidden; }
@media (min-width:768px){ .uk-popt { padding:3.5rem 0; } }
.uk-popt__header { text-align:center; max-width:48rem; margin:0 auto 2.5rem; }
@media (min-width:768px){ .uk-popt__header { margin-bottom:3.5rem; } }
.uk-popt__eyebrow { display:inline-block; color:var(--uk-primary); font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.875rem; margin-bottom:1rem; }
.uk-popt__h2 { font-family:var(--uk-serif); font-weight:700; color:var(--uk-fg); font-size:clamp(1.875rem,4vw,3rem); margin-bottom:1rem; }
.uk-popt__lead { font-size:clamp(1rem,2vw,1.125rem); color:var(--uk-muted-fg); }
.uk-popt-grid { display:grid; grid-template-columns:1fr; gap:1rem; }
@media (min-width:640px){ .uk-popt-grid { grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){ .uk-popt-grid { grid-template-columns:repeat(4,1fr); gap:1.25rem; } }
.uk-popt-card { position:relative; background:var(--uk-card); border:1px solid var(--uk-border); border-radius:1rem; padding:1.25rem; display:flex; flex-direction:column; box-shadow:0 1px 3px rgba(0,0,0,.06); transition:box-shadow .2s; overflow:hidden; }
@media (min-width:768px){ .uk-popt-card { padding:1.5rem; } }
.uk-popt-card:hover { box-shadow:0 8px 24px rgba(0,0,0,.08); }
.uk-popt-card__badge { display:inline-flex; width:fit-content; font-size:.75rem; font-weight:600; padding:.25rem .625rem; border-radius:9999px; border:1px solid; margin-bottom:1rem; }
.uk-popt-card__icon { width:2.75rem; height:2.75rem; border-radius:.75rem; display:flex; align-items:center; justify-content:center; margin-bottom:1rem; flex-shrink:0; }
.uk-popt-card__icon svg { width:1.25rem; height:1.25rem; }
.uk-popt-card__title { font-size:1.125rem; font-weight:700; color:var(--uk-fg); margin-bottom:.25rem; line-height:1.2; }
.uk-popt-card__sub { font-size:.75rem; color:var(--uk-muted-fg); margin-bottom:.75rem; font-weight:500; }
.uk-popt-card__desc { font-size:.875rem; color:var(--uk-muted-fg); line-height:1.6; margin-bottom:1rem; flex:1; }
.uk-popt-card__perks { list-style:none; display:flex; flex-direction:column; gap:.375rem; margin-bottom:1.25rem; }
.uk-popt-card__perks li { display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:var(--uk-fg-80); }
.uk-popt-card__perks li i { width:.375rem; height:.375rem; border-radius:50%; flex-shrink:0; display:block; }
.uk-popt-card__cta { display:inline-flex; align-items:center; gap:.375rem; font-size:.875rem; font-weight:600; background:none; border:none; cursor:pointer; padding:0; transition:gap .2s; font-family:var(--uk-sans); text-align:left; }
.uk-popt-card:hover .uk-popt-card__cta { gap:.625rem; }
.uk-popt-card__cta svg { width:1rem; height:1rem; }
.uk-popt-card__accent { position:absolute; bottom:0; left:1rem; right:1rem; height:2px; border-radius:9999px; transform:scaleX(0); transform-origin:left; transition:transform .3s; }
.uk-popt-card:hover .uk-popt-card__accent { transform:scaleX(1); }

/* ── TECH INTRO (foreground dark) ── */
.uk-tech { background:var(--uk-fg); padding:2.5rem 0; overflow:hidden; }
@media (min-width:768px){ .uk-tech { padding:3.5rem 0; } }
.uk-tech__header { text-align:center; max-width:42rem; margin:0 auto 2.5rem; }
@media (min-width:768px){ .uk-tech__header { margin-bottom:3rem; } }
.uk-tech__eyebrow { display:inline-block; color:var(--uk-primary); font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.875rem; margin-bottom:1rem; }
.uk-tech__h2 { font-family:var(--uk-serif); font-weight:700; color:var(--uk-bg); font-size:clamp(1.875rem,4vw,3rem); line-height:1.15; margin-bottom:1rem; }
.uk-tech__lead { font-size:1rem; color:rgba(255,255,255,.6); line-height:1.65; }
.uk-tech-grid { display:grid; grid-template-columns:1fr; gap:1rem; max-width:64rem; margin:0 auto; }
@media (min-width:768px){ .uk-tech-grid { grid-template-columns:repeat(3,1fr); gap:1.5rem; } }
.uk-tech-card { position:relative; border-radius:1rem; border:1px solid; background:rgba(255,255,255,.05); padding:1.5rem; display:flex; flex-direction:column; gap:1rem; transition:background .2s; text-decoration:none; }
.uk-tech-card:hover { background:rgba(255,255,255,.1); }
.uk-tech-card__top { display:flex; align-items:center; gap:.75rem; }
.uk-tech-card__emoji { width:3rem; height:3rem; border-radius:.75rem; border:1px solid; display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; }
.uk-tech-card__label { font-size:1.25rem; font-weight:700; color:var(--uk-bg); line-height:1.2; }
.uk-tech-card__tagline { font-size:.75rem; color:rgba(255,255,255,.5); line-height:1.3; margin-top:.125rem; }
.uk-tech-card__divider { height:1px; background:rgba(255,255,255,.1); }
.uk-tech-card__opts { list-style:none; display:flex; flex-direction:column; gap:.75rem; flex:1; }
.uk-tech-card__opt { display:flex; align-items:flex-start; gap:.625rem; }
.uk-tech-card__opt i { width:.375rem; height:.375rem; border-radius:50%; margin-top:.375rem; flex-shrink:0; display:block; }
.uk-tech-card__opt-name { font-size:.875rem; font-weight:600; color:var(--uk-bg); line-height:1.3; }
.uk-tech-card__opt-desc { font-size:.75rem; color:rgba(255,255,255,.45); line-height:1.35; margin-top:.125rem; }
.uk-tech-card__more { display:flex; align-items:center; gap:.375rem; font-size:.875rem; font-weight:600; margin-top:.25rem; }
.uk-tech-card__more svg { width:1rem; height:1rem; transition:transform .2s; }
.uk-tech-card:hover .uk-tech-card__more svg { transform:translateY(2px); }

/* ── FOUNDATION (background) ── */
.uk-found { background:var(--uk-bg); padding:2.5rem 0; overflow:hidden; }
@media (min-width:768px){ .uk-found { padding:3.5rem 0; } }
.uk-found__header { text-align:center; max-width:48rem; margin:0 auto 1.75rem; }
@media (min-width:768px){ .uk-found__header { margin-bottom:2.5rem; } }
.uk-found__eyebrow { display:inline-block; color:var(--uk-primary); font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.875rem; margin-bottom:1rem; }
.uk-found__h2 { font-family:var(--uk-serif); font-weight:700; color:var(--uk-fg); font-size:clamp(1.875rem,4vw,3rem); margin-bottom:1rem; }
.uk-found__lead { font-size:clamp(1rem,2vw,1.125rem); color:var(--uk-muted-fg); }
.uk-found-tabs { display:flex; justify-content:center; gap:.75rem; margin-bottom:2.5rem; flex-wrap:wrap; }
.uk-found-tab { padding:.625rem 1.5rem; border-radius:9999px; font-size:.875rem; font-weight:500; border:1px solid var(--uk-border); background:var(--uk-bg); color:var(--uk-fg-80); cursor:pointer; transition:all .2s; font-family:var(--uk-sans); }
.uk-found-tab:hover { border-color:rgba(245,122,0,.4); color:var(--uk-fg); }
.uk-found-tab.uk-active { background:var(--uk-primary); color:#fff; border-color:var(--uk-primary); box-shadow:0 4px 14px rgba(245,122,0,.2); }
.uk-found-panel { display:none; max-width:64rem; margin:0 auto; }
.uk-found-panel.uk-active { display:block; }
.uk-found-card { background:var(--uk-card); border:1px solid var(--uk-border); border-radius:1rem; box-shadow:0 10px 30px rgba(0,0,0,.08); overflow:hidden; }
.uk-found-card__row { display:flex; flex-direction:column; }
@media (min-width:1024px){ .uk-found-card__row { flex-direction:row; } }
.uk-found-card__svg { position:relative; background:linear-gradient(135deg,#f8fafc,#f1f5f9); display:flex; align-items:center; justify-content:center; padding:1.5rem; min-height:280px; }
@media (min-width:1024px){ .uk-found-card__svg { width:40%; } }
.uk-found-card__svg svg { width:100%; max-width:280px; }
.uk-found-badge { position:absolute; top:.75rem; right:.75rem; padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:700; background:var(--uk-primary); color:#fff; }
.uk-found-card__info { padding:1.5rem; }
@media (min-width:768px){ .uk-found-card__info { padding:2rem; } }
@media (min-width:1024px){ .uk-found-card__info { width:60%; } }
.uk-found-card__title-row { display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; margin-bottom:1rem; }
.uk-found-card__title { font-family:var(--uk-serif); font-size:1.5rem; font-weight:700; color:var(--uk-fg); }
.uk-found-card__subtitle { font-size:.875rem; color:var(--uk-muted-fg); font-weight:500; }
.uk-found-stats { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; margin-bottom:1.5rem; }
.uk-found-stat { background:rgba(245,245,245,.6); border-radius:.75rem; padding:.75rem; }
.uk-found-stat__k { font-size:.75rem; color:var(--uk-muted-fg); margin-bottom:.25rem; text-transform:uppercase; letter-spacing:.05em; font-weight:500; }
.uk-found-stat__v { font-size:1.125rem; font-weight:700; color:var(--uk-primary); }
.uk-found-stat__v--fg { font-size:1rem; color:var(--uk-fg); line-height:1.2; }
.uk-found-pros-title { font-size:.875rem; font-weight:600; color:var(--uk-fg); margin-bottom:.75rem; text-transform:uppercase; letter-spacing:.05em; }
.uk-found-pros { list-style:none; display:flex; flex-direction:column; gap:.5rem; margin-bottom:1.25rem; }
.uk-found-pros li { display:flex; align-items:flex-start; gap:.625rem; font-size:.875rem; color:var(--uk-fg-80); }
.uk-found-check { width:1rem; height:1rem; border-radius:50%; background:var(--uk-primary-10); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:.125rem; }
.uk-found-check svg { width:.625rem; height:.625rem; stroke:var(--uk-primary); }
.uk-found-when { background:var(--uk-primary-05); border:1px solid rgba(245,122,0,.15); border-radius:.75rem; padding:1rem; }
.uk-found-when p { font-size:.875rem; color:var(--uk-fg-80); line-height:1.6; }
.uk-found-when b { color:var(--uk-fg); font-weight:600; }

/* ── WALL & ROOF (layer cross-section) ── */
.uk-wall { background:rgba(245,245,245,.6); padding:2.5rem 0; overflow:hidden; }
.uk-roof { background:var(--uk-bg); padding:2.5rem 0; overflow:hidden; }
@media (min-width:768px){ .uk-wall, .uk-roof { padding:3.5rem 0; } }
.uk-lyr__header { text-align:center; max-width:48rem; margin:0 auto 1.75rem; }
@media (min-width:768px){ .uk-lyr__header { margin-bottom:2.5rem; } }
.uk-lyr__eyebrow { display:inline-block; color:var(--uk-primary); font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.875rem; margin-bottom:1rem; }
.uk-lyr__h2 { font-family:var(--uk-serif); font-weight:700; color:var(--uk-fg); font-size:clamp(1.875rem,4vw,3rem); margin-bottom:1rem; }
.uk-lyr__lead { font-size:clamp(1rem,2vw,1.125rem); color:var(--uk-muted-fg); }
.uk-lyr-controls { display:flex; flex-direction:column; align-items:center; gap:1rem; margin-bottom:2rem; }
.uk-lyr-tabs { display:flex; align-items:center; gap:.5rem; background:var(--uk-card); border:1px solid var(--uk-border); border-radius:.75rem; padding:.25rem; box-shadow:0 1px 3px rgba(0,0,0,.06); }
.uk-lyr-tab { padding:.5rem 1.25rem; border-radius:.5rem; font-size:.875rem; font-weight:500; border:none; background:none; color:var(--uk-fg-80); cursor:pointer; transition:all .2s; font-family:var(--uk-sans); }
.uk-lyr-tab:hover { color:var(--uk-fg); background:rgba(245,245,245,.5); }
.uk-lyr-tab.uk-active { background:var(--uk-primary); color:#fff; box-shadow:0 1px 3px rgba(0,0,0,.1); }
.uk-lyr-legend { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:1rem; font-size:.875rem; }
@media (min-width:768px){ .uk-lyr-legend { gap:2rem; } }
.uk-lyr-legend__item { display:flex; align-items:center; gap:.5rem; }
.uk-lyr-legend__dot { width:.75rem; height:.75rem; border-radius:50%; }
.uk-lyr-legend__muted { color:var(--uk-muted-fg); }
.uk-lyr-legend b { color:var(--uk-fg); }
.uk-lyr-legend .uk-lyr-legend__prim { color:var(--uk-primary); font-weight:700; }
.uk-lyr-svg-wrap { width:100%; overflow-x:auto; }
.uk-lyr-svg-inner { min-width:640px; }
.uk-lyr-svg-inner svg { width:100%; max-height:520px; display:block; }
.uk-lyr-detail { min-height:6rem; margin-top:.5rem; }
@media (min-width:768px){ .uk-lyr-detail { min-height:5rem; } }
.uk-lyr-detail__card { max-width:48rem; margin:0 auto; background:var(--uk-primary-05); border:1px solid var(--uk-primary-20); border-radius:1rem; padding:1rem; display:flex; flex-direction:column; gap:.75rem; }
@media (min-width:640px){ .uk-lyr-detail__card { flex-direction:row; align-items:center; padding:1.25rem; } }
.uk-lyr-detail__swatch { width:2.5rem; height:2.5rem; border-radius:.5rem; border:2px solid var(--uk-primary-20); flex-shrink:0; }
.uk-lyr-detail__title { font-weight:700; color:var(--uk-fg); margin-bottom:.125rem; }
.uk-lyr-detail__desc { font-size:.875rem; color:var(--uk-muted-fg); line-height:1.45; }
.uk-lyr-detail__hint { text-align:center; color:var(--uk-muted-fg); font-size:.875rem; padding:1rem 0; }

/* ── HOUSE SCHEMATIC (slate-950) ── */
.uk-hs { background:#020617; padding:2.5rem 0; overflow:hidden; }
@media (min-width:768px){ .uk-hs { padding:3.5rem 0; } }
.uk-hs__header { text-align:center; max-width:48rem; margin:0 auto 1.75rem; }
@media (min-width:768px){ .uk-hs__header { margin-bottom:2.5rem; } }
.uk-hs__eyebrow { display:inline-block; color:var(--uk-primary); font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.875rem; margin-bottom:1rem; }
.uk-hs__h2 { font-family:var(--uk-serif); font-weight:700; color:#fff; font-size:clamp(1.875rem,4vw,3rem); margin-bottom:1rem; }
.uk-hs__lead { font-size:clamp(1rem,2vw,1.125rem); color:#94a3b8; }
.uk-hs-grid { display:grid; grid-template-columns:1fr; gap:1.5rem; margin-top:1rem; align-items:start; }
@media (min-width:1024px){ .uk-hs-grid { grid-template-columns:repeat(5,1fr); } }
.uk-hs-svg-col svg { width:100%; border-radius:.75rem; overflow:hidden; filter:drop-shadow(0 20px 40px rgba(0,0,0,.4)); display:block; }
@media (min-width:1024px){ .uk-hs-svg-col { grid-column:span 3; } .uk-hs-side { grid-column:span 2; } }
.uk-hs-side__inner { display:flex; flex-direction:column; gap:.75rem; }
@media (min-width:1024px){ .uk-hs-side__inner { position:sticky; top:6rem; } }
.uk-hs-zones { background:rgba(30,41,59,.6); border:1px solid rgba(51,65,85,.5); border-radius:1rem; padding:1rem; }
.uk-hs-zones__label { color:#94a3b8; font-size:11px; text-transform:uppercase; letter-spacing:.1em; font-weight:600; margin-bottom:.75rem; }
.uk-hs-zones__list { display:flex; flex-direction:column; gap:.375rem; }
.uk-hs-zone-btn { width:100%; text-align:left; padding:.625rem .75rem; border-radius:.75rem; font-size:.875rem; font-weight:500; border:1px solid rgba(51,65,85,.6); background:rgba(15,23,42,.5); color:#cbd5e1; cursor:pointer; transition:all .2s; display:flex; align-items:center; gap:.75rem; font-family:var(--uk-sans); }
.uk-hs-zone-btn:hover { border-color:#64748b; color:#fff; }
.uk-hs-zone-btn.uk-active { background:var(--uk-primary-10); color:var(--uk-primary); border-color:rgba(245,122,0,.4); }
.uk-hs-zone-btn__dot { width:.625rem; height:.625rem; border-radius:50%; flex-shrink:0; }
.uk-hs-zone-btn__arrow { color:var(--uk-primary); font-weight:700; margin-left:auto; }
.uk-hs-card { background:rgba(30,41,59,.9); border:1px solid rgba(71,85,105,.6); border-radius:1rem; padding:1.25rem; }
@media (min-width:768px){ .uk-hs-card { padding:1.5rem; } }
.uk-hs-card__title { font-size:1.125rem; font-weight:700; color:#fff; margin-bottom:.125rem; }
@media (min-width:768px){ .uk-hs-card__title { font-size:1.25rem; } }
.uk-hs-card__sub { font-size:.875rem; color:#94a3b8; margin-bottom:1rem; }
.uk-hs-card__ftabs { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1rem; }
.uk-hs-card__ftab { padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:600; border:1px solid #475569; background:rgba(51,65,85,.6); color:#cbd5e1; cursor:pointer; transition:all .2s; font-family:var(--uk-sans); }
.uk-hs-card__ftab:hover { border-color:rgba(245,122,0,.5); }
.uk-hs-card__ftab.uk-active { background:var(--uk-primary); color:#fff; border-color:var(--uk-primary); }
.uk-hs-card__specs { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; margin-bottom:1rem; }
@media (min-width:640px){ .uk-hs-card__specs { grid-template-columns:repeat(4,1fr); } }
.uk-hs-spec { background:rgba(15,23,42,.6); border-radius:.75rem; padding:.75rem; }
.uk-hs-spec__k { font-size:10px; font-weight:600; color:#64748b; text-transform:uppercase; letter-spacing:.05em; margin-bottom:.25rem; }
.uk-hs-spec__v { font-size:.75rem; font-weight:500; color:#e2e8f0; line-height:1.3; }
.uk-hs-card__desc { font-size:.875rem; color:#94a3b8; line-height:1.6; }
.uk-hs-hint { background:rgba(30,41,59,.3); border:1px solid rgba(51,65,85,.3); border-radius:1rem; padding:1.25rem; text-align:center; }
.uk-hs-hint__icon { width:3rem; height:3rem; border-radius:50%; background:var(--uk-primary-10); border:1px solid var(--uk-primary-20); display:flex; align-items:center; justify-content:center; margin:0 auto .75rem; color:var(--uk-primary); font-size:1.25rem; font-weight:700; }
.uk-hs-hint p { color:#94a3b8; font-size:.875rem; line-height:1.6; }


/* ════════════════════════════════════════════════════════════════
   PROJECT DETAIL PAGE (.uk-pd-*) — точная копия ProjectDetail.tsx
   hero/галерея · спецификации · описание · комплектации · комнаты
   ════════════════════════════════════════════════════════════════ */

/* ── Header + main image (grid 2 cols on lg) ── */
.uk-pd-top { display:grid; grid-template-columns:1fr; gap:2.5rem; align-items:start; }
@media (min-width:1024px){ .uk-pd-top { grid-template-columns:1fr 1fr; gap:4rem; } }

/* ── Main image (gallery trigger) ── */
.uk-pd-main-img { display:block; width:100%; aspect-ratio:4/3; border-radius:var(--uk-r-3xl); overflow:hidden; background:var(--uk-muted); position:relative; border:none; padding:0; cursor:pointer; }
.uk-pd-main-img img { width:100%; height:100%; object-fit:cover; transition:transform .7s; }
.uk-pd-main-img:hover img { transform:scale(1.05); }
.uk-pd-img-badge { position:absolute; top:1rem; left:1rem; background:rgba(255,255,255,.95); backdrop-filter:blur(4px); padding:.375rem .75rem; border-radius:var(--uk-r); font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--uk-fg); }
.uk-pd-img-open { position:absolute; bottom:1rem; right:1rem; background:rgba(255,255,255,.95); backdrop-filter:blur(4px); padding:.375rem .75rem; border-radius:var(--uk-r); font-size:.75rem; font-weight:500; color:var(--uk-fg); }

/* ── Thumbnails row ── */
.uk-pd-thumbs { display:grid; grid-template-columns:repeat(5,1fr); gap:.5rem; margin-top:.75rem; }
.uk-pd-thumb { aspect-ratio:1/1; border-radius:var(--uk-r); overflow:hidden; background:var(--uk-muted); position:relative; border:none; padding:0; cursor:pointer; }
.uk-pd-thumb img { width:100%; height:100%; object-fit:cover; transition:opacity .2s; }
.uk-pd-thumb:hover img { opacity:.8; }
.uk-pd-thumb-more { position:absolute; inset:0; background:rgba(20,20,20,.7); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:.875rem; }

/* ── Right column: price, title, specs ── */
.uk-pd-price { font-size:1.875rem; font-weight:700; color:var(--uk-primary); margin-bottom:1rem; }
@media (min-width:768px){ .uk-pd-price { font-size:2.25rem; } }
.uk-pd-title { font-family:var(--uk-serif); font-size:1.875rem; font-weight:700; color:var(--uk-fg); margin-bottom:1.5rem; line-height:1.1; }
@media (min-width:768px){ .uk-pd-title { font-size:3rem; } }
.uk-pd-specs { display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; margin-bottom:2rem; }
.uk-pd-spec { background:var(--uk-muted); border-radius:var(--uk-r); padding:1rem; display:flex; flex-direction:column; align-items:center; text-align:center; gap:.25rem; }
.uk-pd-spec svg { width:1.25rem; height:1.25rem; color:var(--uk-primary); stroke:var(--uk-primary); margin-bottom:.25rem; }
.uk-pd-spec__val { font-size:1.5rem; font-weight:700; color:var(--uk-fg); }
.uk-pd-spec__label { font-size:.75rem; color:var(--uk-muted-fg); text-transform:uppercase; letter-spacing:.025em; }

/* ── Description ── */
.uk-pd-desc { font-size:1rem; color:var(--uk-muted-fg); line-height:1.65; margin-bottom:1.5rem; }
@media (min-width:768px){ .uk-pd-desc { font-size:1.125rem; } }

/* ── Features list ── */
.uk-pd-features { list-style:none; display:flex; flex-direction:column; gap:.5rem; margin-bottom:2rem; }
.uk-pd-features li { display:flex; align-items:flex-start; gap:.75rem; color:var(--uk-fg); }
.uk-pd-features svg { width:1.25rem; height:1.25rem; color:var(--uk-primary); stroke:var(--uk-primary); flex-shrink:0; margin-top:.125rem; }

/* ── CTA row (расчёт / позвонить) ── */
.uk-pd-cta-row { display:flex; flex-direction:column; gap:.75rem; margin-bottom:1.5rem; }
@media (min-width:640px){ .uk-pd-cta-row { flex-direction:row; } }
.uk-pd-cta-row .uk-btn { height:3.5rem; font-size:1rem; }
.uk-pd-cta-btn--main { flex:1; }

/* ── Gift banner ── */
.uk-pd-gift { display:flex; align-items:flex-start; gap:.75rem; padding:1rem; border-radius:var(--uk-r); background:var(--uk-primary-05); border:1px solid var(--uk-primary-20); }
.uk-pd-gift svg { width:1.25rem; height:1.25rem; color:var(--uk-primary); stroke:var(--uk-primary); flex-shrink:0; margin-top:.125rem; }
.uk-pd-gift__title { font-weight:600; color:var(--uk-fg); }
.uk-pd-gift__sub { font-size:.875rem; color:var(--uk-muted-fg); }

/* ── Trust strip ── */
.uk-pd-trust { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; margin-top:4rem; padding-top:3rem; border-top:1px solid var(--uk-border); }
@media (min-width:768px){ .uk-pd-trust { grid-template-columns:repeat(4,1fr); } }
.uk-pd-trust__item { display:flex; align-items:center; gap:.75rem; }
.uk-pd-trust__icon { width:2.5rem; height:2.5rem; border-radius:var(--uk-r); background:var(--uk-primary-10); color:var(--uk-primary); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.uk-pd-trust__icon svg { width:1.25rem; height:1.25rem; color:var(--uk-primary); stroke:var(--uk-primary); }
.uk-pd-trust__label { font-size:.875rem; font-weight:500; color:var(--uk-fg); }

/* ── Packages (tabs + panels) ── */
.uk-pd-pkg-wrap { max-width:64rem; margin:0 auto; }
.uk-pd-pkg-tabs { display:grid; grid-template-columns:repeat(3,1fr); gap:0; padding:.25rem; background:var(--uk-bg); border-radius:var(--uk-r-xl); border:1px solid var(--uk-border); }
.uk-pd-pkg-tab { display:flex; flex-direction:column; align-items:center; gap:.25rem; padding:1rem .5rem; background:none; border:none; border-radius:var(--uk-r); cursor:pointer; font-family:var(--uk-sans); color:var(--uk-fg); transition:background .2s, color .2s; }
.uk-pd-pkg-tab[aria-selected="true"] { background:var(--uk-primary); color:#fff; }
.uk-pd-pkg-tab__name { font-weight:700; font-size:1rem; }
.uk-pd-pkg-tab__price { font-size:.75rem; opacity:.9; }
.uk-pd-pkg-panel { display:none; margin-top:1.5rem; }
.uk-pd-pkg-panel.uk-active { display:block; animation:ukFadeIn .25s ease; }
.uk-pd-pkg-card { background:var(--uk-bg); border-radius:var(--uk-r-xl); border:1px solid var(--uk-border); padding:1.5rem; }
@media (min-width:768px){ .uk-pd-pkg-card { padding:2rem; } }
.uk-pd-pkg-head { display:flex; flex-direction:column; gap:1rem; margin-bottom:1.5rem; padding-bottom:1.5rem; border-bottom:1px solid var(--uk-border); }
@media (min-width:768px){ .uk-pd-pkg-head { flex-direction:row; align-items:center; justify-content:space-between; } }
.uk-pd-pkg-name { font-family:var(--uk-serif); font-size:1.5rem; font-weight:700; color:var(--uk-fg); }
@media (min-width:768px){ .uk-pd-pkg-name { font-size:1.875rem; } }
.uk-pd-pkg-tagline { color:var(--uk-muted-fg); }
.uk-pd-pkg-price { font-size:1.5rem; font-weight:700; color:var(--uk-primary); }
@media (min-width:768px){ .uk-pd-pkg-price { font-size:1.875rem; } }

/* ── Packages accordion (полный состав) ── */
.uk-pd-acc-trigger { display:flex; align-items:center; justify-content:space-between; width:100%; background:none; border:none; cursor:pointer; font-family:var(--uk-sans); font-size:1rem; font-weight:600; color:var(--uk-fg); padding:.5rem 0; text-align:left; }
.uk-pd-acc-trigger svg { width:1rem; height:1rem; stroke:var(--uk-fg); transition:transform .2s; flex-shrink:0; }
.uk-pd-acc.uk-open .uk-pd-acc-trigger svg { transform:rotate(180deg); }
.uk-pd-acc-content { display:none; }
.uk-pd-acc.uk-open .uk-pd-acc-content { display:block; }
.uk-pd-acc-list { display:flex; flex-direction:column; gap:1rem; margin-top:1rem; }
.uk-pd-spec-section { font-size:.75rem; text-transform:uppercase; letter-spacing:.05em; font-weight:700; color:var(--uk-primary); padding-top:.75rem; }
.uk-pd-spec-row { display:grid; grid-template-columns:repeat(12,1fr); gap:.75rem; font-size:.875rem; padding:.5rem 0; border-bottom:1px solid rgba(229,229,229,.5); }
.uk-pd-spec-row__label { grid-column:span 12; color:var(--uk-muted-fg); }
.uk-pd-spec-row__val { grid-column:span 12; color:var(--uk-fg); }
@media (min-width:768px){
  .uk-pd-spec-row__label { grid-column:span 5; }
  .uk-pd-spec-row__val { grid-column:span 7; }
}
.uk-pd-acc-note { margin-top:1.5rem; font-size:.75rem; color:var(--uk-muted-fg); font-style:italic; }
.uk-pd-pkg-actions { margin-top:1.5rem; display:flex; flex-direction:column; gap:.75rem; }
@media (min-width:640px){ .uk-pd-pkg-actions { flex-direction:row; } }
.uk-pd-pkg-actions .uk-btn { flex:1; }

/* ── Characteristics + Rooms ── */
.uk-pd-info { display:grid; grid-template-columns:1fr; gap:3rem; }
@media (min-width:1024px){ .uk-pd-info { grid-template-columns:1fr 1fr; } }
.uk-pd-info__h2 { font-family:var(--uk-serif); font-size:1.5rem; font-weight:700; color:var(--uk-fg); margin-bottom:2rem; }
@media (min-width:768px){ .uk-pd-info__h2 { font-size:1.875rem; } }
.uk-pd-char { display:flex; flex-direction:column; gap:1rem; }
.uk-pd-char__row { display:grid; grid-template-columns:repeat(12,1fr); gap:1rem; padding-bottom:1rem; border-bottom:1px solid var(--uk-border); }
.uk-pd-char__label { grid-column:span 12; color:var(--uk-muted-fg); }
.uk-pd-char__val { grid-column:span 12; font-weight:500; color:var(--uk-fg); }
@media (min-width:768px){
  .uk-pd-char__label { grid-column:span 5; }
  .uk-pd-char__val { grid-column:span 7; }
}
.uk-pd-rooms { display:flex; flex-direction:column; gap:2rem; }
.uk-pd-rooms__floor { font-size:.875rem; text-transform:uppercase; letter-spacing:.05em; font-weight:700; color:var(--uk-primary); margin-bottom:1rem; }
.uk-pd-rooms__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:.75rem; }
@media (min-width:640px){ .uk-pd-rooms__grid { grid-template-columns:repeat(3,1fr); } }
.uk-pd-room { background:var(--uk-muted); border-radius:var(--uk-r); padding:1rem; }
.uk-pd-room__name { font-size:.875rem; color:var(--uk-muted-fg); margin-bottom:.25rem; }
.uk-pd-room__area { font-weight:700; color:var(--uk-fg); }

/
/* ── Lightbox ── */
.uk-pd-lightbox { display:none; position:fixed; inset:0; z-index:100; background:rgba(0,0,0,.95); align-items:center; justify-content:center; padding:1rem; }
.uk-pd-lightbox.uk-open { display:flex; }
.uk-pd-lb-close { position:absolute; top:1.5rem; right:1.5rem; background:none; border:none; cursor:pointer; color:rgba(255,255,255,.9); padding:.5rem; }
.uk-pd-lb-close:hover { color:#fff; }
.uk-pd-lb-close svg { width:2rem; height:2rem; }
.uk-pd-lb-nav { position:absolute; background:none; border:none; cursor:pointer; color:rgba(255,255,255,.9); padding:.5rem; font-size:2.25rem; line-height:1; user-select:none; }
.uk-pd-lb-nav:hover { color:#fff; }
.uk-pd-lb-prev { left:1.5rem; }
.uk-pd-lb-next { right:1.5rem; }
.uk-pd-lb-img { max-width:100%; max-height:90vh; object-fit:contain; border-radius:var(--uk-r); }
.uk-pd-lb-counter { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.8); font-size:.875rem; background:rgba(0,0,0,.5); padding:.25rem .75rem; border-radius:9999px; }


/* ── PACKAGES ── */
.uk-pkg-tabs-wrap {
  max-width: 62.5rem; margin: 0 auto;
}
.uk-pkg-tablist {
  display: grid; grid-template-columns: repeat(3, 1fr);
  background: var(--uk-card); border: 1px solid var(--uk-border);
  border-radius: .75rem; padding: .25rem; box-shadow: 0 1px 2px rgba(0,0,0,.05);
  margin-bottom: 1rem; position: relative;
}
.uk-pkg-tab {
  position: relative; padding: .75rem .5rem;
  background: none; border: none; border-radius: .5rem;
  font-family: var(--uk-sans); font-size: .875rem; font-weight: 500;
  color: var(--uk-fg); cursor: pointer; transition: background .2s, color .2s;
}
@media (min-width: 640px) { .uk-pkg-tab { font-size: 1rem; } }
@media (min-width: 768px) { .uk-pkg-tab { font-size: 1.125rem; } }
.uk-pkg-tab[aria-selected="true"] { background: var(--uk-primary); color: #fff; }
.uk-pkg-tab__badge {
  position: absolute; top: -.625rem; left: 50%; transform: translateX(-50%);
  font-size: 9px; font-weight: 700; background: var(--uk-primary); color: #fff;
  padding: .125rem .5rem; border-radius: 9999px; white-space: nowrap; box-shadow: 0 2px 8px rgba(245,122,0,.4);
}
.uk-pkg-panel { display: none; }
.uk-pkg-panel.uk-active {
  display: block;
  animation: ukFadeIn .25s ease;
}
@keyframes ukFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

.uk-pkg-card {
  background: var(--uk-card); border: 1px solid var(--uk-border);
  border-radius: var(--uk-r-2xl); box-shadow: 0 4px 16px rgba(0,0,0,.08); overflow: hidden;
}
.uk-pkg-card__header {
  padding: 1.5rem; border-bottom: 1px solid var(--uk-border);
  background: linear-gradient(to right, rgba(0,0,0,.02), transparent);
  display: flex; flex-direction: column; gap: 1.5rem;
}
@media (min-width: 768px) {
  .uk-pkg-card__header { padding: 2rem; flex-direction: row; align-items: flex-start; justify-content: space-between; }
}
.uk-pkg-card__tagline { font-size: .875rem; font-weight: 700; color: var(--uk-primary); margin-bottom: .5rem; }
.uk-pkg-card__desc { color: var(--uk-muted-fg); font-size: .875rem; line-height: 1.65; max-width: 36rem; }
.uk-pkg-card__price-block { flex-shrink: 0; }
@media (min-width: 768px) { .uk-pkg-card__price-block { text-align: right; } }
.uk-pkg-card__price-label { font-size: .75rem; color: var(--uk-muted-fg); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .25rem; }
.uk-pkg-card__price { font-size: 2.25rem; font-weight: 700; color: var(--uk-primary); line-height: 1; }
@media (min-width: 768px) { .uk-pkg-card__price { font-size: 2.5rem; } }
.uk-pkg-card__price-sub { font-size: .75rem; color: var(--uk-muted-fg); margin-top: .25rem; }

.uk-pkg-card__body { display: grid; }
@media (min-width: 768px) { .uk-pkg-card__body { grid-template-columns: 1fr 1fr; } }
.uk-pkg-card__left { padding: 1.5rem; border-bottom: 1px solid var(--uk-border); }
@media (min-width: 768px) { .uk-pkg-card__left { border-bottom: none; border-right: 1px solid var(--uk-border); } }
.uk-pkg-card__right { padding: 1.5rem; }
@media (min-width: 768px) { .uk-pkg-card__left, .uk-pkg-card__right { padding: 2rem; } }
.uk-pkg-sublabel {
  font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  color: var(--uk-muted-fg); margin-bottom: 1rem;
}
.uk-pkg-wall {
  display: flex; align-items: stretch; height: 2.5rem;
  border-radius: .5rem; overflow: hidden; border: 1px solid rgba(0,0,0,.1); margin-bottom: .5rem;
}
.uk-pkg-wall-seg { display: flex; align-items: center; justify-content: center; font-size: 7px; font-weight: 700; color: rgba(0,0,0,.3); }
.uk-pkg-wall-meta { display: flex; justify-content: space-between; font-size: .75rem; color: var(--uk-muted-fg); margin-bottom: 1.25rem; }
.uk-pkg-wall-meta span { display: flex; align-items: center; gap: .25rem; }
.uk-pkg-wall-dot { width: .5rem; height: .5rem; border-radius: 50%; display: inline-block; }
.uk-pkg-materials { margin-bottom: 0; }
.uk-pkg-mat { display: flex; justify-content: space-between; align-items: center; padding: .375rem 0; border-bottom: 1px solid rgba(0,0,0,.06); }
.uk-pkg-mat:last-child { border-bottom: none; }
.uk-pkg-mat__label { font-size: .75rem; color: var(--uk-muted-fg); }
.uk-pkg-mat__val { font-size: .75rem; font-weight: 600; color: var(--uk-fg); text-align: right; margin-left: 1rem; }
.uk-pkg-perks { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 1.25rem; }
.uk-pkg-perk {
  display: flex; align-items: flex-start; gap: .75rem;
  padding: .75rem; border-radius: .75rem; background: rgba(0,0,0,.03);
  transition: background .2s;
}
.uk-pkg-perk:hover { background: rgba(0,0,0,.06); }
.uk-pkg-perk__icon {
  padding: .375rem; border-radius: .5rem; background: var(--uk-primary-10); flex-shrink: 0;
}
.uk-pkg-perk__icon svg { width: 1rem; height: 1rem; color: var(--uk-primary); stroke: var(--uk-primary); }
.uk-pkg-perk__text { font-size: .875rem; line-height: 1.4; color: var(--uk-fg); }
.uk-pkg-bars { background: rgba(0,0,0,.03); border-radius: .75rem; padding: 1rem; }
.uk-pkg-bars-label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--uk-muted-fg); margin-bottom: .75rem; }
.uk-pkg-bars-row { display: flex; align-items: flex-end; gap: .5rem; height: 4rem; }
.uk-pkg-bar-item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: .25rem; }
.uk-pkg-bar-mm { font-size: 10px; font-weight: 700; color: var(--uk-fg); }
.uk-pkg-bar-fill { width: 100%; border-radius: .25rem .25rem 0 0; }
.uk-pkg-bar-lbl { font-size: 9px; color: var(--uk-muted-fg); }
.uk-pkg-bar-lbl.uk-active { color: var(--uk-primary); font-weight: 700; }
.uk-pkg-show-table {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .9375rem; font-weight: 500; color: var(--uk-primary);
  background: none; border: none; cursor: pointer; text-align: center;
  transition: text-decoration .2s;
}
.uk-pkg-show-table:hover { text-decoration: underline; }
.uk-pkg-table-wrap { overflow-x: auto; margin-top: 2rem; }
.uk-pkg-table {
  width: 100%; min-width: 50rem; border-collapse: collapse;
  background: var(--uk-card); border: 1px solid var(--uk-border);
  border-radius: .75rem; overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.uk-pkg-table th, .uk-pkg-table td { padding: .75rem 1rem; font-size: .875rem; }
.uk-pkg-table thead th { background: rgba(0,0,0,.03); font-weight: 700; text-align: left; }
.uk-pkg-table th:nth-child(3) { background: var(--uk-primary-05); color: var(--uk-primary); }
.uk-pkg-table td { border-top: 1px solid var(--uk-border); }
.uk-pkg-table td:nth-child(3) { background: var(--uk-primary-05); }
.uk-pkg-table tr:hover td { background: rgba(0,0,0,.02); }
.uk-pkg-table tr:hover td:nth-child(3) { background: var(--uk-primary-10); }
.uk-pkg-table .uk-check { color: var(--uk-primary); }
.uk-pkg-table .uk-minus { color: var(--uk-muted-fg); opacity: .5; }
.uk-pkg-table .uk-highlight { color: var(--uk-primary); font-weight: 600; }
.uk-pkg-table thead th:nth-child(n+2), .uk-pkg-table td:nth-child(n+2) { text-align: center; }
.uk-pkg-table tr.uk-pkg-sec td { background: rgba(0,0,0,.045); font-weight: 700; font-size: .8125rem; text-transform: uppercase; letter-spacing: .04em; color: var(--uk-fg); text-align: left; }
.uk-pkg-table tr.uk-pkg-sec:hover td { background: rgba(0,0,0,.045); }


/* ── Packages (tabs + panels) ── */
.uk-pd-pkg-wrap { max-width:64rem; margin:0 auto; }
.uk-pd-pkg-tabs { display:grid; grid-template-columns:repeat(3,1fr); gap:0; padding:.25rem; background:var(--uk-bg); border-radius:var(--uk-r-xl); border:1px solid var(--uk-border); }
.uk-pd-pkg-tab { display:flex; flex-direction:column; align-items:center; gap:.25rem; padding:1rem .5rem; background:none; border:none; border-radius:var(--uk-r); cursor:pointer; font-family:var(--uk-sans); color:var(--uk-fg); transition:background .2s, color .2s; }
.uk-pd-pkg-tab[aria-selected="true"] { background:var(--uk-primary); color:#fff; }
.uk-pd-pkg-tab__name { font-weight:700; font-size:1rem; }
.uk-pd-pkg-tab__price { font-size:.75rem; opacity:.9; }
.uk-pd-pkg-panel { display:none; margin-top:1.5rem; }
.uk-pd-pkg-panel.uk-active { display:block; animation:ukFadeIn .25s ease; }
.uk-pd-pkg-card { background:var(--uk-bg); border-radius:var(--uk-r-xl); border:1px solid var(--uk-border); padding:1.5rem; }
@media (min-width:768px){ .uk-pd-pkg-card { padding:2rem; } }
.uk-pd-pkg-head { display:flex; flex-direction:column; gap:1rem; margin-bottom:1.5rem; padding-bottom:1.5rem; border-bottom:1px solid var(--uk-border); }
@media (min-width:768px){ .uk-pd-pkg-head { flex-direction:row; align-items:center; justify-content:space-between; } }
.uk-pd-pkg-name { font-family:var(--uk-serif); font-size:1.5rem; font-weight:700; color:var(--uk-fg); }
@media (min-width:768px){ .uk-pd-pkg-name { font-size:1.875rem; } }
.uk-pd-pkg-tagline { color:var(--uk-muted-fg); }
.uk-pd-pkg-price { font-size:1.5rem; font-weight:700; color:var(--uk-primary); }
@media (min-width:768px){ .uk-pd-pkg-price { font-size:1.875rem; } }

/* ── Packages accordion (полный состав) ── */
.uk-pd-acc-trigger { display:flex; align-items:center; justify-content:space-between; width:100%; background:none; border:none; cursor:pointer; font-family:var(--uk-sans); font-size:1rem; font-weight:600; color:var(--uk-fg); padding:.5rem 0; text-align:left; }
.uk-pd-acc-trigger svg { width:1rem; height:1rem; stroke:var(--uk-fg); transition:transform .2s; flex-shrink:0; }
.uk-pd-acc.uk-open .uk-pd-acc-trigger svg { transform:rotate(180deg); }
.uk-pd-acc-content { display:none; }
.uk-pd-acc.uk-open .uk-pd-acc-content { display:block; }
.uk-pd-acc-list { display:flex; flex-direction:column; gap:1rem; margin-top:1rem; }
.uk-pd-spec-section { font-size:.75rem; text-transform:uppercase; letter-spacing:.05em; font-weight:700; color:var(--uk-primary); padding-top:.75rem; }
.uk-pd-spec-row { display:grid; grid-template-columns:repeat(12,1fr); gap:.75rem; font-size:.875rem; padding:.5rem 0; border-bottom:1px solid rgba(229,229,229,.5); }
.uk-pd-spec-row__label { grid-column:span 12; color:var(--uk-muted-fg); }
.uk-pd-spec-row__val { grid-column:span 12; color:var(--uk-fg); }
@media (min-width:768px){
  .uk-pd-spec-row__label { grid-column:span 5; }
  .uk-pd-spec-row__val { grid-column:span 7; }
}
.uk-pd-acc-note { margin-top:1.5rem; font-size:.75rem; color:var(--uk-muted-fg); font-style:italic; }
.uk-pd-pkg-actions { margin-top:1.5rem; display:flex; flex-direction:column; gap:.75rem; }
@media (min-width:640px){ .uk-pd-pkg-actions { flex-direction:row; } }
.uk-pd-pkg-actions .uk-btn { flex:1; }

/* ── Characteristics + Rooms ── */
.uk-pd-info { display:grid; grid-template-columns:1fr; gap:3rem; }
@media (min-width:1024px){ .uk-pd-info { grid-template-columns:1fr 1fr; } }
.uk-pd-info__h2 { font-family:var(--uk-serif); font-size:1.5rem; font-weight:700; color:var(--uk-fg); margin-bottom:2rem; }
@media (min-width:768px){ .uk-pd-info__h2 { font-size:1.875rem; } }
.uk-pd-char { display:flex; flex-direction:column; gap:1rem; }
.uk-pd-char__row { display:grid; grid-template-columns:repeat(12,1fr); gap:1rem; padding-bottom:1rem; border-bottom:1px solid var(--uk-border); }
.uk-pd-char__label { grid-column:span 12; color:var(--uk-muted-fg); }
.uk-pd-char__val { grid-column:span 12; font-weight:500; color:var(--uk-fg); }
@media (min-width:768px){
  .uk-pd-char__label { grid-column:span 5; }
  .uk-pd-char__val { grid-column:span 7; }
}
.uk-pd-rooms { display:flex; flex-direction:column; gap:2rem; }
.uk-pd-rooms__floor { font-size:.875rem; text-transform:uppercase; letter-spacing:.05em; font-weight:700; color:var(--uk-primary); margin-bottom:1rem; }
.uk-pd-rooms__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:.75rem; }
@media (min-width:640px){ .uk-pd-rooms__grid { grid-template-columns:repeat(3,1fr); } }
.uk-pd-room { background:var(--uk-muted); border-radius:var(--uk-r); padding:1rem; }
.uk-pd-room__name { font-size:.875rem; color:var(--uk-muted-fg); margin-bottom:.25rem; }
.uk-pd-room__area { font-weight:700; color:var(--uk-fg); }


/* ── PROCESS ── */
.uk-process-wrap { max-width: 62.5rem; margin: 0 auto; position: relative; }
.uk-process-vline {
  display: none; position: absolute; top: 0; bottom: 0;
  left: 50%; width: 1px; background: var(--uk-border); transform: translateX(-50%);
}
@media (min-width: 768px) { .uk-process-vline { display: block; } }
.uk-process-step {
  position: relative; display: flex; flex-direction: column; align-items: center;
  margin-bottom: 3rem;
}
@media (min-width: 768px) { .uk-process-step { flex-direction: row; min-height: 12rem; margin-bottom: 0; } }
.uk-process-step:last-child { margin-bottom: 0; }
.uk-process-num {
  display: flex; align-items: center; justify-content: center;
  width: 4rem; height: 4rem; border-radius: 50%;
  background: var(--uk-bg); border: 4px solid var(--uk-primary);
  font-family: var(--uk-serif); font-size: 1.25rem; font-weight: 700;
  color: var(--uk-primary); z-index: 2; margin-bottom: 1.5rem; box-shadow: 0 2px 8px rgba(0,0,0,.06);
  flex-shrink: 0;
}
@media (min-width: 768px) { .uk-process-num { position: absolute; left: 50%; transform: translateX(-50%); margin-bottom: 0; } }
.uk-process-card {
  background: var(--uk-card); padding: 1.5rem 2rem; border-radius: var(--uk-r-2xl);
  border: 1px solid var(--uk-border); box-shadow: 0 1px 4px rgba(0,0,0,.05);
  transition: box-shadow .2s; position: relative;
}
@media (min-width: 768px) {
  .uk-process-card { width: calc(50% - 3rem); }
  .uk-process-step:nth-child(odd) .uk-process-card { margin-right: auto; margin-left: 0; padding-right: 4rem; }
  .uk-process-step:nth-child(even) .uk-process-card { margin-left: auto; margin-right: 0; padding-left: 4rem; }
  .uk-process-card::after {
    content: ''; position: absolute; top: 50%; width: 1rem; height: 1rem;
    background: var(--uk-card); border: 1px solid var(--uk-border);
    transform: translateY(-50%) rotate(45deg);
  }
  .uk-process-step:nth-child(odd) .uk-process-card::after { right: -.5rem; border-left: none; border-bottom: none; }
  .uk-process-step:nth-child(even) .uk-process-card::after { left: -.5rem; border-right: none; border-top: none; }
}
.uk-process-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.09); }
.uk-process-card__title { font-size: 1.25rem; font-weight: 700; margin-bottom: .75rem; }
.uk-process-card__text { color: var(--uk-muted-fg); line-height: 1.65; }

/* ── SERVICES ── */
.uk-svc-grid {
  display: grid; grid-template-columns: 1fr; gap: 1.5rem;
}
@media (min-width: 768px) { .uk-svc-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }
.uk-svc-card {
  background: var(--uk-bg); border: 1px solid var(--uk-border);
  border-radius: var(--uk-r-2xl); padding: 1.5rem 2rem;
  transition: box-shadow .25s, transform .25s;
}
.uk-svc-card:hover { box-shadow: 0 12px 32px rgba(0,0,0,.12); transform: translateY(-2px); }
.uk-svc-card__icon {
  width: 3.5rem; height: 3.5rem;
  background: var(--uk-primary); color: #fff;
  border-radius: .75rem; display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
}
.uk-svc-card__icon svg { width: 1.75rem; height: 1.75rem; stroke: #fff; }
.uk-svc-card__title { font-family: var(--uk-serif); font-size: 1.5rem; font-weight: 700; margin-bottom: 1.5rem; }
.uk-svc-list { list-style: none; display: flex; flex-direction: column; gap: .75rem; }
.uk-svc-list li { display: flex; align-items: flex-start; gap: .75rem; }
.uk-svc-check {
  width: 1.25rem; height: 1.25rem; border-radius: 50%;
  background: var(--uk-primary-10); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .125rem;
}
.uk-svc-check svg { width: .75rem; height: .75rem; stroke: var(--uk-primary); stroke-width: 3; }
.uk-svc-text { color: rgba(20,20,20,.8); line-height: 1.5; font-size: .9375rem; }



