*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#fafaf7;--card:#ffffff;--ink:#33383b;--mut:#71787c;--sage:#5c7466;--sage-d:#48594f;--lav:#8b8fa8;--line:#e6e7e1}
html{scroll-behavior:smooth}
body{font-family:'Assistant',sans-serif;background:var(--bg);color:var(--ink);line-height:1.8;font-size:17px;overflow-x:hidden}
h1,h2,h3{font-family:'Crimson Pro',serif;font-weight:500;line-height:1.3}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:920px;margin:0 auto;padding:0 24px}

.ribbon{background:var(--ink);color:#b4b9bc;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:60}
.ribbon b{color:#fafaf7}
.ribbon a{display:inline-block;margin-left:12px;background:var(--sage);color:#fff;font-weight:600;padding:3px 14px;border-radius:99px;font-size:13px}
.ribbon a:hover{background:var(--sage-d)}

header{position:sticky;top:0;z-index:50;background:rgba(250,250,247,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1080px;margin:0 auto;padding:0 24px}
.logo{font-family:'Crimson Pro',serif;font-size:22px;display:flex;align-items:center;gap:11px}
.logo svg{width:30px;height:30px}
.logo small{display:block;font-family:'Assistant',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mut)}
.nonstop{display:flex;align-items:center;gap:16px}
.nonstop .tel{text-align:right;line-height:1.3}
.nonstop .tel b{font-size:18px;color:var(--sage-d)}
.nonstop .tel span{display:block;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut)}
/* drawer trigger */
.dtrig{background:none;border:1.5px solid var(--line);border-radius:99px;padding:10px 20px;font-family:'Assistant',sans-serif;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;display:flex;align-items:center;gap:9px}
.dtrig:hover{border-color:var(--sage)}
.dtrig span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.dtrig span::before,.dtrig span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.dtrig span::before{top:-6px}
.dtrig span::after{top:6px}

/* ===== RIGHT DRAWER MENU ===== */
.drawer-bg{position:fixed;inset:0;background:rgba(51,56,59,.4);z-index:80;opacity:0;pointer-events:none;transition:opacity .25s}
.drawer{position:fixed;top:0;right:-360px;bottom:0;width:340px;max-width:88vw;background:#fff;z-index:81;transition:right .28s ease;display:flex;flex-direction:column;padding:30px 32px;box-shadow:-20px 0 60px rgba(51,56,59,.15)}
body.dopen .drawer{right:0}
body.dopen .drawer-bg{opacity:1;pointer-events:auto}
.drawer .dhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}
.drawer .dhead b{font-family:'Crimson Pro',serif;font-size:20px;font-weight:500}
.drawer .dclose{background:none;border:1.5px solid var(--line);width:40px;height:40px;border-radius:50%;font-size:17px;cursor:pointer;color:var(--ink)}
.drawer nav{display:flex;flex-direction:column}
.drawer nav a{padding:15px 2px;font-size:16.5px;border-bottom:1px solid var(--line);color:var(--ink);display:flex;justify-content:space-between}
.drawer nav a::after{content:"→";color:var(--sage)}
.drawer nav a.on{color:var(--sage-d);font-weight:600}
.drawer .dfoot{margin-top:auto;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:18px;text-align:center}
.drawer .dfoot b{font-size:19px;color:var(--sage-d);display:block}
.drawer .dfoot span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut)}

/* hero — centered serene */
.hero{position:relative;overflow:hidden;color:#fff;text-align:center}
.hero .bgimg{position:absolute;inset:0;background:url(../img/hero.jpg) center/cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,46,44,.45),rgba(40,46,44,.65))}
.hero .in{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:110px 24px 116px}
.hero h1{font-size:clamp(32px,4.8vw,52px);font-weight:500}
.hero p{color:#e3e6e0;font-size:18px;margin:18px auto 30px;max-width:560px}
.btn{display:inline-block;background:var(--sage);color:#fff;padding:15px 34px;border-radius:99px;font-weight:600;font-size:16px;transition:.15s;border:0;cursor:pointer;font-family:'Assistant',sans-serif}
.btn:hover{background:var(--sage-d)}
.btn.ghost{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.55)}
.btn.ghost:hover{background:#fff;color:var(--ink)}
.hero .telbig{margin-top:26px;font-size:15px;color:#e3e6e0}
.hero .telbig b{font-size:26px;color:#fff;display:block;font-family:'Crimson Pro',serif}

section{padding:78px 0}
.shead{text-align:center;max-width:620px;margin:0 auto 44px}
.shead h2{font-size:clamp(26px,3.6vw,36px)}
.shead p{color:var(--mut);margin-top:12px}

/* steps accordion */
.krok{background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden}
.krok summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:18px;padding:20px 24px;font-weight:600;font-size:16.5px}
.krok summary::-webkit-details-marker{display:none}
.krok summary .n{width:38px;height:38px;border-radius:50%;background:#eef1ec;color:var(--sage-d);display:flex;align-items:center;justify-content:center;font-family:'Crimson Pro',serif;font-size:18px;flex-shrink:0}
.krok summary::after{content:"+";margin-left:auto;font-size:22px;color:var(--sage);font-weight:400}
.krok[open] summary::after{content:"–"}
.krok .a{padding:0 24px 20px 80px;color:var(--mut);font-size:15.5px}

/* services */
.svc-g{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:28px}
.svc h3{font-size:20px;margin-bottom:8px}
.svc p{color:var(--mut);font-size:15px}

/* quiet band */
.quiet{background:var(--sage);color:#fff;text-align:center;padding:70px 0}
.quiet h2{font-size:clamp(25px,3.6vw,36px);font-family:'Crimson Pro',serif;font-weight:500}
.quiet p{color:#dee7e0;margin:12px auto 24px;max-width:520px}
.quiet a{background:#fff;color:var(--sage-d);display:inline-block;padding:14px 32px;border-radius:99px;font-weight:600}
.quiet .telbig{margin-top:22px;font-size:14px;color:#dee7e0}
.quiet .telbig b{font-size:24px;color:#fff;display:block;font-family:'Crimson Pro',serif}

/* form */
.form-g{display:grid;grid-template-columns:1fr 1fr;gap:46px}
.fg{margin-bottom:16px}
.fg label{display:block;margin-bottom:7px;font-weight:600;font-size:14.5px}
input,select,textarea{width:100%;background:#fff;border:1.5px solid var(--line);border-radius:10px;color:var(--ink);padding:13px 15px;font-family:inherit;font-size:15.5px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--sage)}
.fnote{font-size:13.5px;color:var(--mut);margin-top:10px}
.ok-msg{display:none;background:#eef1ec;border:1.5px solid var(--sage);color:var(--sage-d);padding:16px;border-radius:10px;margin-top:14px}
.k-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:26px;margin-bottom:16px}
.k-card h3{font-size:18.5px;margin-bottom:6px}
.k-card p,.k-card a{color:var(--mut);font-size:15px}

footer{background:var(--ink);color:#b4b9bc;padding:52px 0 40px}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:38px;max-width:1080px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Crimson Pro',serif;color:#fafaf7;font-size:18px;margin-bottom:12px;font-weight:500}
footer a,footer p{color:#b4b9bc;font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.f-bot{max-width:1080px;margin:32px auto 0;padding:18px 24px 0;border-top:1px solid #494e51;font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{background:linear-gradient(180deg,#eef1ec,var(--bg));text-align:center}
.phero .in{max-width:760px;margin:0 auto;padding:64px 24px 52px}
.phero h1{font-size:clamp(28px,4.2vw,44px);font-weight:500}
.phero p{color:var(--mut);margin-top:14px;font-size:17px}
section.hero,section.phero{padding:0}

@media(max-width:960px){
 .svc-g,.form-g{grid-template-columns:1fr}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 .nonstop .tel{display:none}
 .f-g{grid-template-columns:1fr}
 section{padding:54px 0}
 .hero .in{padding:70px 20px 78px}
 .phero .in{padding:44px 20px 38px}
 .krok .a{padding-left:24px}
}
