.ribbon{background:#4a3527;color:#cbb9a5;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:60}.ribbon b{color:#f6f1e7}.ribbon a{display:inline-block;margin-left:12px;background:#c96f2e;color:#fff;font-weight:600;padding:3px 14px;border-radius:6px;font-size:13px}.ribbon a:hover{background:#a85820}
*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#f6f1e7;--card:#fffdf8;--ink:#2e2318;--mut:#7a6a58;--wood:#4a3527;--acc:#c96f2e;--acc-d:#a85820;--line:#e3d9c8}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);line-height:1.7;font-size:16px;overflow-x:hidden}
h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;line-height:1.18}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

header{position:sticky;top:0;z-index:50;background:rgba(246,241,231,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px;max-width:1180px;margin:0 auto;padding:0 24px}
.logo{font-family:'Fraunces',serif;font-weight:700;font-size:22px;display:flex;align-items:center;gap:10px}
.logo svg{width:32px;height:32px}
nav.menu{display:flex;gap:28px;align-items:center}
nav.menu a{font-size:15px;font-weight:500;color:var(--mut);transition:.15s}
nav.menu a:hover,nav.menu a.on{color:var(--ink)}
.cta-btn{background:var(--wood);color:#fff!important;padding:11px 22px;border-radius:6px;font-weight:600!important}
.cta-btn:hover{background:#5d442f}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2px;background:var(--ink);margin:6px 0}

/* split hero */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 70px)}
.hero .txt{display:flex;flex-direction:column;justify-content:center;padding:70px 60px 80px;max-width:640px;margin-left:auto}
.hero .txt .kicker{color:var(--acc);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:12px;margin-bottom:16px}
.hero h1{font-size:clamp(38px,4.6vw,62px);margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--acc)}
.hero .txt p{color:var(--mut);font-size:17.5px;margin-bottom:30px}
.hero .foto{position:relative}
.hero .foto img{width:100%;height:100%;object-fit:cover;min-height:calc(100vh - 70px)}
.hero .foto .badge{position:absolute;left:-70px;bottom:70px;background:var(--wood);color:#f6f1e7;padding:22px 28px;border-radius:8px;max-width:230px;box-shadow:0 20px 50px rgba(46,35,24,.3)}
.hero .foto .badge b{font-family:'Fraunces',serif;font-size:30px;display:block}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;background:var(--acc);color:#fff;padding:14px 28px;border-radius:6px;font-weight:600;transition:.15s;border:0;cursor:pointer;font-family:'Inter',sans-serif;font-size:15.5px}
.btn:hover{background:var(--acc-d)}
.btn.ghost{background:transparent;border:2px solid var(--wood);color:var(--wood);padding:12px 26px}
.btn.ghost:hover{background:var(--wood);color:#fff}

section{padding:92px 0}
.shead{max-width:660px;margin-bottom:50px}
.shead .eyebrow{color:var(--acc);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:10px}
.shead h2{font-size:clamp(30px,4vw,46px)}
.shead p{color:var(--mut);margin-top:14px}

/* services */
.svc-g{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:34px 30px;position:relative;overflow:hidden;transition:.18s}
.svc::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--acc),var(--wood))}
.svc:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(46,35,24,.12)}
.svc h3{font-size:21px;margin:14px 0 10px}
.svc p{color:var(--mut);font-size:14.5px}
.svc .ico{width:52px;height:52px;border-radius:10px;background:#f0e7d6;display:flex;align-items:center;justify-content:center}
.svc .ico svg{width:28px;height:28px;stroke:var(--wood)}

/* horizontal gallery */
.hscroll{display:flex;gap:20px;overflow-x:auto;padding:6px 24px 24px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.hscroll::-webkit-scrollbar{height:8px}
.hscroll::-webkit-scrollbar-thumb{background:var(--wood);border-radius:99px}
.hscroll::-webkit-scrollbar-track{background:var(--line)}
.hcard{flex:0 0 420px;scroll-snap-align:start;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.hcard img{width:100%;height:280px;object-fit:cover}
.hcard .b{padding:22px 24px}
.hcard .tag{display:inline-block;background:#f0e7d6;color:var(--wood);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border-radius:99px;margin-bottom:10px}
.hcard h3{font-size:19px;margin-bottom:6px}
.hcard p{color:var(--mut);font-size:14px}

/* process */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-left:2px solid var(--line)}
.proc .p{padding:0 26px 8px;border-right:2px solid var(--line)}
.proc .n{font-family:'Fraunces',serif;font-size:44px;color:var(--acc);font-style:italic}
.proc h3{font-size:18px;margin:8px 0}
.proc p{color:var(--mut);font-size:14px}

/* wood dark band */
.dark{background:var(--wood);color:#f6f1e7}
.dark .shead h2{color:#f6f1e7}
.dark .shead p{color:#cbb9a5}
.mat-g{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.mat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:24px}
.mat h3{font-size:17px;margin-bottom:6px}
.mat p{color:#cbb9a5;font-size:13.5px}

/* calc */
.calc{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:40px;box-shadow:0 20px 50px rgba(46,35,24,.08)}
.calc-g{display:grid;grid-template-columns:1.2fr .8fr;gap:44px}
.cfg label{display:block;font-weight:600;font-size:14px;margin:20px 0 8px}
.cfg input[type=range]{width:100%;accent-color:var(--acc)}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{border:1.5px solid var(--line);background:#fff;padding:9px 16px;border-radius:8px;cursor:pointer;font-family:inherit;font-size:14px;transition:.12s}
.seg button.on{background:var(--wood);color:#fff;border-color:var(--wood)}
.calc-out{background:var(--bg);border-radius:12px;padding:30px;text-align:center;align-self:start}
.calc-out .sum{font-family:'Fraunces',serif;font-size:42px;color:var(--wood)}
.calc-out p{color:var(--mut);font-size:13.5px;margin-top:8px}
.calc-out .val{font-weight:700;font-size:20px}

/* refs grid */
.ref-g{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.ref{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.18s}
.ref:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(46,35,24,.12)}
.ref img{width:100%;height:300px;object-fit:cover}
.ref .b{padding:24px 28px}
.ref h3{font-size:20px;margin-bottom:6px}
.ref p{color:var(--mut);font-size:14.5px}

/* quote/about */
.quote{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.quote img{border-radius:14px;width:100%;height:460px;object-fit:cover}
.quote blockquote{font-family:'Fraunces',serif;font-size:26px;font-style:italic;line-height:1.5;margin-bottom:20px}
.quote .who{color:var(--mut)}

/* form */
.form-g{display:grid;grid-template-columns:1fr 1fr;gap:54px}
label{font-size:14px;font-weight:600}
.fg{margin-bottom:16px}
.fg label{display:block;margin-bottom:7px}
input,select,textarea{width:100%;background:#fff;border:1.5px solid var(--line);border-radius:8px;color:var(--ink);padding:13px 15px;font-family:inherit;font-size:15px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--acc)}
.fnote{font-size:13px;color:var(--mut);margin-top:10px}
.ok-msg{display:none;background:#eef7ea;border:1px solid #7cb26a;color:#3c6b2e;padding:16px;border-radius:8px;margin-top:14px}
.kontakt-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:28px;margin-bottom:18px}
.kontakt-card h3{font-size:18px;margin-bottom:8px}
.kontakt-card p,.kontakt-card a{color:var(--mut);font-size:15px}

.band{background:var(--acc);color:#fff;padding:72px 0;text-align:center}
.band h2{font-family:'Fraunces',serif;font-size:clamp(28px,4vw,44px);margin-bottom:12px}
.band p{opacity:.9;margin-bottom:24px}
.band a{background:var(--wood);color:#fff;display:inline-block;padding:15px 32px;border-radius:8px;font-weight:600}

footer{background:var(--wood);color:#cbb9a5;padding:56px 0 40px}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:1180px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Fraunces',serif;color:#f6f1e7;font-size:17px;margin-bottom:14px}
footer a,footer p{color:#cbb9a5;font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.f-bot{max-width:1180px;margin:36px auto 0;padding:20px 24px 0;border-top:1px solid rgba(255,255,255,.14);font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{padding:60px 0 30px}
.phero .eyebrow{color:var(--acc);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:12px}
.phero h1{font-size:clamp(34px,5vw,56px)}
.phero h1 em{font-style:italic;color:var(--acc)}
.phero p{color:var(--mut);max-width:640px;margin-top:16px;font-size:17px}

@media(max-width:960px){
 .hero{grid-template-columns:1fr}
 .hero .txt{padding:50px 24px 40px;max-width:none}
 .hero .foto img{min-height:340px;height:340px}
 .hero .foto .badge{left:20px;bottom:20px;padding:16px 20px}
 .svc-g{grid-template-columns:1fr 1fr}
 .proc{grid-template-columns:1fr 1fr;row-gap:34px}
 .mat-g{grid-template-columns:1fr 1fr}
 .ref-g,.quote,.form-g,.calc-g{grid-template-columns:1fr}
 .quote img{height:340px}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 nav.menu{position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;gap:0;padding:10px 0 20px;border-bottom:1px solid var(--line);display:none}
 nav.menu.open{display:flex}
 nav.menu a{padding:14px 24px;width:100%;font-size:16px}
 .cta-btn{margin:12px 24px 0;width:calc(100% - 48px);text-align:center}
 .burger{display:block}
 .svc-g{grid-template-columns:1fr}
 .proc{grid-template-columns:1fr;border-left:0}
 .proc .p{border-right:0;border-left:2px solid var(--line);margin-bottom:10px}
 .mat-g{grid-template-columns:1fr}
 .hcard{flex-basis:320px}
 section{padding:64px 0}
 .phero{padding:50px 0 20px}
 .f-g{grid-template-columns:1fr}
 .calc{padding:26px 20px}
}
