:root{
  --paper:#f7f2eb;
  --paper-deep:#eee4d7;
  --ink:#15211b;
  --muted:#667168;
  --forest:#10271f;
  --forest-deep:#071711;
  --gold:#b78551;
  --gold-soft:#d8b587;
  --line:rgba(21,33,27,.12);
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Manrope", Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit}
.container{width:min(1180px,calc(100% - 64px));margin-inline:auto}
.skip-link{position:absolute;left:-9999px;top:0;z-index:999;background:#fff;padding:12px 16px}.skip-link:focus{left:12px;top:12px}
.site-header{position:sticky;top:0;z-index:60;background:rgba(247,242,235,.88);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
.nav-wrap{min-height:76px;display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:13px;margin-right:auto;min-width:235px}.brand-mark{font-family:var(--serif);font-size:2.25rem;line-height:1;letter-spacing:-.16em}.brand-text{display:grid;gap:2px;line-height:1.05}.brand-text b{font-size:.77rem;letter-spacing:-.02em}.brand-text small{font-size:.63rem;color:var(--muted)}
.site-nav{display:flex;align-items:center;gap:27px;font-size:.76rem;font-weight:600}.site-nav a{position:relative}.site-nav a::after{content:"";position:absolute;bottom:-8px;left:0;width:0;height:1px;background:var(--gold);transition:width .22s ease}.site-nav a:hover::after,.site-nav a:focus-visible::after{width:100%}
.nav-cta,.button{display:inline-flex;align-items:center;justify-content:center;gap:13px;border-radius:12px;font-size:.75rem;font-weight:700;letter-spacing:-.01em;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.nav-cta{padding:14px 18px;background:var(--forest);color:#fff;white-space:nowrap}.nav-cta:hover,.button:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(13,35,26,.18)}
.menu-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:10px;background:transparent;color:var(--ink);cursor:pointer}.menu-toggle span{display:block;width:20px;height:1.5px;margin:4px auto;background:currentColor;transition:.2s}.menu-toggle.is-open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}.menu-toggle.is-open span:nth-child(2){opacity:0}.menu-toggle.is-open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
.hero{position:relative;isolation:isolate;overflow:hidden;background:linear-gradient(108deg,#fbf8f2 0%,#f7f1e8 46%,#e7d6c4 100%)}
.hero::before{content:"";position:absolute;inset:0;z-index:-3;background:radial-gradient(circle at 12% 34%,rgba(255,255,255,.95),transparent 32%),linear-gradient(118deg,rgba(255,255,255,.28),rgba(255,255,255,0) 72%);pointer-events:none}
.hero-grid{position:relative;z-index:1;display:block;min-height:650px}.hero-copy{position:relative;z-index:2;max-width:650px;margin:42px 0;padding:58px 52px 62px;border:1px solid rgba(255,255,255,.7);border-radius:25px;background:linear-gradient(105deg,rgba(255,253,249,.86) 0%,rgba(250,245,238,.73) 48%,rgba(247,240,231,.24) 100%);box-shadow:0 24px 70px rgba(75,55,34,.10);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.eyebrow{margin:0 0 15px;font-size:.68rem;letter-spacing:.22em;font-weight:700;color:#566158}.hero h1{margin:0;font-family:var(--serif);font-size:clamp(4.15rem,7vw,6.85rem);font-weight:600;line-height:.76;letter-spacing:-.07em}.role{margin:23px 0 0;font-size:.94rem;color:#3a443d}.ornament{display:block;width:83px;height:1px;margin:27px 0 21px;background:linear-gradient(90deg,var(--gold),transparent)}.hero-lead{max-width:450px;margin:0;font-family:var(--serif);font-size:1.53rem;line-height:1.12}.hero-support{max-width:410px;margin:18px 0 0;font-size:.82rem;line-height:1.64;color:var(--muted)}.hero-actions{display:flex;align-items:center;gap:27px;margin-top:31px}.button{padding:16px 20px}.button-forest{background:linear-gradient(118deg,#183a2d,#0b2018);color:#fff}.link-arrow{display:inline-flex;align-items:center;gap:12px;font-size:.79rem;font-weight:600;border-bottom:1px solid rgba(21,33,27,.35);padding-bottom:4px}.link-arrow span{font-size:1.08rem}.hero-media{position:absolute;inset:0;z-index:-2;min-height:0;overflow:hidden}.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(251,248,242,1) 0%,rgba(250,246,239,.97) 23%,rgba(248,241,232,.82) 42%,rgba(244,234,222,.44) 58%,rgba(242,229,215,.11) 73%,rgba(242,229,215,0) 100%),radial-gradient(ellipse 52% 100% at 0% 50%,rgba(255,255,255,.62),transparent 72%);pointer-events:none}.hero-media img{width:100%;height:100%;object-fit:cover;object-position:75% center;filter:saturate(.93) contrast(.99)}
.approach{position:relative;overflow:hidden;color:#fbf6ee;background:linear-gradient(135deg,#0b1a14 0%,#17392b 45%,#0a2118 100%)}.approach::before{content:"";position:absolute;inset:0;opacity:.58;background:repeating-linear-gradient(166deg,transparent 0 48px,rgba(238,211,175,.04) 49px 50px),radial-gradient(ellipse 75% 90% at 8% 95%,rgba(118,164,137,.28),transparent 60%),radial-gradient(ellipse 55% 60% at 90% 15%,rgba(54,103,80,.48),transparent 68%)}.approach-glow{position:absolute;border-radius:50%;filter:blur(30px);opacity:.22}.approach-glow-one{width:380px;height:380px;background:#5c806a;left:-130px;top:45%}.approach-glow-two{width:430px;height:430px;background:#b78551;right:-250px;top:-260px}.approach-inner{position:relative;padding:80px 0 50px;text-align:center}.eyebrow-light{color:rgba(250,247,239,.62)}.approach h2{max-width:850px;margin:0 auto 55px;font-family:var(--serif);font-size:clamp(2.35rem,4.1vw,4.15rem);font-weight:500;line-height:.91;letter-spacing:-.04em}.approach-list{display:grid;grid-template-columns:repeat(3,1fr);text-align:left}.approach-list article{display:grid;grid-template-columns:48px 1fr;gap:16px;padding:13px 30px;min-height:118px;border-left:1px solid rgba(255,255,255,.16)}.approach-list article:first-child{border-left:0}.approach-icon{color:var(--gold-soft);font-family:var(--serif);font-size:2rem;line-height:1}.approach h3{margin:1px 0 8px;color:var(--gold-soft);font-size:.69rem;letter-spacing:.15em;text-transform:uppercase}.approach p{margin:0;color:rgba(255,255,255,.83);font-size:.8rem;line-height:1.52}
.section{padding:92px 0}.reasons{background:linear-gradient(180deg,#f8f3ed,#f4ece2)}.reasons-grid{display:grid;grid-template-columns:repeat(4,1fr);margin-top:25px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.reason{min-height:175px;padding:26px 28px;border-left:1px solid var(--line)}.reason:first-child{border-left:0}.reason span{display:block;margin-bottom:26px;color:var(--gold);font-family:var(--serif);font-size:1.55rem;line-height:1}.reason p{margin:0;font-size:.78rem;line-height:1.55;color:#4e584f}
.methods{padding-top:72px;background:var(--paper)}.section-intro h2{max-width:820px;margin:0;font-family:var(--serif);font-size:clamp(2.65rem,4vw,4.4rem);line-height:.89;font-weight:600;letter-spacing:-.05em}.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:39px}.method-card{min-height:273px;padding:30px;border:1px solid var(--line);border-radius:15px;background:linear-gradient(145deg,rgba(255,255,255,.45),rgba(239,229,216,.25));transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.method-card:hover{transform:translateY(-5px);border-color:rgba(183,133,81,.45);box-shadow:0 16px 35px rgba(72,52,30,.07)}.card-icon{display:grid;place-items:center;width:53px;height:53px;border-radius:50%;color:var(--gold);background:#f1e6d7;font-family:var(--serif);font-size:1.65rem}.method-card h3{max-width:260px;margin:23px 0 11px;font-family:var(--serif);font-size:1.72rem;line-height:.96;font-weight:600;letter-spacing:-.035em}.method-card p{margin:0;color:#596259;font-size:.8rem;line-height:1.57}
.requests{padding-top:28px;background:var(--paper)}.intro-wide{display:grid;grid-template-columns:1fr 1.18fr;gap:26px;align-items:end}.intro-wide > .eyebrow{grid-column:1/-1;margin-bottom:-4px}.intro-wide h2{grid-column:1}.intro-wide > p:last-child{max-width:490px;margin:0 0 8px;color:var(--muted);font-size:.89rem;line-height:1.65}.requests-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}.request-card{padding:30px 29px;min-height:330px;border-radius:15px;border:1px solid var(--line);background:linear-gradient(145deg,rgba(255,255,255,.58),rgba(238,226,212,.24))}.request-card h3{margin:0;font-family:var(--serif);font-size:2rem;line-height:.92;letter-spacing:-.04em}.request-card ul{display:grid;gap:12px;margin:24px 0 0;padding:0;list-style:none}.request-card li{position:relative;padding-left:16px;color:#535d54;font-size:.8rem;line-height:1.4}.request-card li::before{content:"";position:absolute;left:0;top:.53em;width:5px;height:5px;border-radius:50%;background:var(--gold)}
.about{padding:62px 0 45px;background:linear-gradient(135deg,#f7f2eb 0%,#f1e7da 100%)}.about-grid{display:grid;grid-template-columns:.95fr 1.1fr .77fr;align-items:stretch}.about-photo{margin:0;min-height:420px;overflow:hidden}.about-photo img{width:100%;height:100%;object-fit:cover;object-position:67% center}.about-copy{padding:35px 50px;background:rgba(255,255,255,.28)}.about-copy h2{margin:0;font-family:var(--serif);font-size:clamp(2.35rem,3vw,3.5rem);line-height:.9;letter-spacing:-.05em}.about-copy p:not(.eyebrow){margin:19px 0 0;color:#536058;font-size:.84rem;line-height:1.6}.about-copy .link-arrow{margin-top:23px}.education-card{padding:35px 33px;border-left:1px solid var(--line)}.education-card ul{display:grid;gap:13px;margin:21px 0 0;padding:0;list-style:none}.education-card li{position:relative;padding-left:17px;font-size:.8rem;line-height:1.35}.education-card li::before{content:"•";position:absolute;left:0;color:var(--gold);font-size:1.1rem;top:-.17em}.education-note{margin:23px 0 0;color:var(--muted);font-size:.74rem;line-height:1.5}

.reviews{position:relative;overflow:hidden;background:radial-gradient(circle at 95% 0%,rgba(203,160,103,.15),transparent 31%),linear-gradient(155deg,#f8f3ed 0%,#f2e8db 100%)}
.reviews::before{content:"";position:absolute;width:430px;height:430px;right:-180px;bottom:-245px;border-radius:50%;background:radial-gradient(circle,rgba(20,53,40,.12),transparent 68%);pointer-events:none}
.reviews .container{position:relative;z-index:1}
.reviews-head{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(230px,.55fr);gap:44px;align-items:end;margin-bottom:39px}
.reviews-head h2{margin:0;font-family:var(--serif);font-size:clamp(2.75rem,4.4vw,4.7rem);line-height:.87;letter-spacing:-.055em}
.reviews-head>p{margin:0 0 6px;color:var(--muted);font-size:.84rem;line-height:1.65}
.reviews-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.review-card{display:flex;flex-direction:column;min-height:282px;padding:28px 27px;border:1px solid rgba(21,33,27,.12);border-radius:15px;background:linear-gradient(145deg,rgba(255,255,255,.72),rgba(244,235,224,.58));box-shadow:0 10px 28px rgba(70,48,23,.035);transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}
.review-card:hover{transform:translateY(-4px);border-color:rgba(183,133,81,.45);box-shadow:0 18px 34px rgba(70,48,23,.09)}
.review-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:28px}
.review-stars{color:#c18a46;font-size:.96rem;letter-spacing:.08em;white-space:nowrap}
.review-date{color:#7a837b;font-size:.7rem;white-space:nowrap}
.review-card blockquote{margin:0;font-family:var(--serif);font-size:1.53rem;line-height:1.05;letter-spacing:-.025em}
.review-author{margin:22px 0 0;padding-top:14px;border-top:1px solid var(--line);color:#4e584f;font-size:.76rem;font-weight:700}
.review-author span{font-weight:500;color:#7d857e}
.review-card-featured{justify-content:space-between;color:#fbf7ef;border-color:rgba(255,255,255,.14);background:radial-gradient(circle at 100% 0%,rgba(202,150,88,.45),transparent 35%),linear-gradient(135deg,#17392b,#0b1d15)}
.review-card-featured .eyebrow{color:rgba(251,247,239,.63)}
.review-card-featured h3{margin:0;font-family:var(--serif);font-size:2.2rem;line-height:.9;letter-spacing:-.04em}
.review-card-featured p:not(.eyebrow){margin:16px 0 28px;color:rgba(251,247,239,.76);font-size:.8rem;line-height:1.55}
.review-card-featured .button{align-self:flex-start;background:linear-gradient(102deg,#c99a63,#a36d38);color:#fff}

.notice-section{padding:22px 0;background:#eee4d7;border-top:1px solid rgba(21,33,27,.07);border-bottom:1px solid rgba(21,33,27,.07)}.notice-inner{display:grid;grid-template-columns:52px 1fr;gap:18px;align-items:start}.notice-icon{color:var(--gold);font-family:var(--serif);font-size:2.7rem;line-height:.72}.notice-inner .eyebrow{margin-bottom:8px}.notice-inner p:last-child{max-width:1040px;margin:0;color:#586259;font-size:.78rem;line-height:1.55}
.contact{color:#fbf7ef;position:relative;overflow:hidden;background:radial-gradient(circle at 8% 10%,#204437 0%,transparent 38%),linear-gradient(120deg,#0f2a20,#071712 75%)}.contact::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(5,19,13,.2),rgba(5,19,13,.92) 55%,rgba(5,19,13,.15));pointer-events:none}.contact-grid{position:relative;z-index:1;display:grid;grid-template-columns:.97fr 1.03fr;gap:62px;padding:78px 0}.contact-copy h2{margin:0;font-family:var(--serif);font-size:clamp(3.15rem,4vw,4.9rem);font-weight:600;line-height:.83;letter-spacing:-.06em}.contact-copy>p:not(.eyebrow){max-width:430px;margin:23px 0 28px;color:rgba(251,247,239,.77);font-size:.88rem;line-height:1.6}.contact-list{border-top:1px solid rgba(255,255,255,.18);max-width:510px}.contact-list>*{display:grid;grid-template-columns:27px 118px 1fr;align-items:center;gap:9px;min-height:48px;border-bottom:1px solid rgba(255,255,255,.18);font-size:.76rem}.contact-list a{transition:background .2s ease}.contact-list a:hover{background:rgba(255,255,255,.05)}.contact-list span{color:var(--gold-soft);font-family:var(--serif);font-size:1.25rem}.contact-list b{font-weight:500}.contact-list em{font-style:normal;color:rgba(251,247,239,.68);overflow-wrap:anywhere}.contact-visual{position:relative;min-height:440px;border-radius:16px;overflow:hidden}.contact-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,25,18,.08),rgba(8,25,18,.85))}.contact-visual>img{width:100%;height:100%;object-fit:cover;object-position:58% center}.contact-card{position:absolute;right:22px;bottom:22px;z-index:2;width:min(365px,calc(100% - 44px));padding:26px;border-radius:12px;background:rgba(20,41,31,.78);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(10px)}.contact-card .eyebrow{margin-bottom:11px}.contact-card h3{margin:0;font-family:var(--serif);font-size:2rem;line-height:.94;letter-spacing:-.035em}.contact-card p:not(.eyebrow){margin:14px 0 20px;color:rgba(251,247,239,.72);font-size:.78rem;line-height:1.5}.button-gold{width:100%;padding:14px;background:linear-gradient(102deg,#c99a63,#a36d38);color:#fff}
.site-footer{background:#07140f;color:rgba(251,247,239,.6);font-size:.72rem}.footer-inner{min-height:62px;display:flex;align-items:center;justify-content:space-between;gap:20px}.footer-inner a{text-decoration:underline;text-underline-offset:4px}.telegram-fab{position:fixed;z-index:80;right:22px;bottom:22px;display:inline-flex;align-items:center;gap:9px;padding:12px 17px;border-radius:999px;background:#2e8dc4;color:#fff;box-shadow:0 14px 35px rgba(12,31,25,.3);font-size:.74rem;font-weight:700;transition:transform .2s ease,box-shadow .2s ease}.telegram-fab span{font-size:1.05rem}.telegram-fab:hover{transform:translateY(-3px);box-shadow:0 18px 44px rgba(12,31,25,.38)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.65,.25,1)}.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}.method-card,.nav-cta,.button,.telegram-fab{transition:none}}
@media(max-width:1040px){.reviews-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.review-card-featured{grid-column:1/-1;min-height:220px}
.site-nav{gap:17px}.nav-cta{padding:13px 14px}.hero-copy{max-width:590px;margin:36px 0;padding:48px 42px 52px}.about-grid{grid-template-columns:1fr 1fr}.education-card{grid-column:2;border-top:1px solid var(--line);border-left:0}.requests-grid{grid-template-columns:repeat(2,1fr)}.request-card:last-child{grid-column:1/-1;min-height:0}.contact-grid{gap:35px}}
@media(max-width:820px){.reviews-head{grid-template-columns:1fr;gap:20px}.reviews-head>p{max-width:560px}
.nav-wrap{min-height:68px}.brand-text{display:none}.brand{min-width:auto}.menu-toggle{display:block}.site-nav{position:absolute;top:68px;left:0;right:0;display:none;gap:0;padding:8px 32px 16px;background:rgba(247,242,235,.98);border-bottom:1px solid var(--line);box-shadow:0 18px 35px rgba(22,35,29,.08)}.site-nav.is-open{display:grid}.site-nav a{padding:14px 0;border-bottom:1px solid var(--line)}.site-nav a:last-child{border-bottom:0}.nav-cta{margin-left:auto;font-size:.67rem}.hero-grid{display:flex;flex-direction:column;min-height:0}.hero-copy{max-width:none;margin:0;padding:69px 0 41px;border:0;border-radius:0;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.hero-media{position:relative;z-index:auto;min-height:500px;margin:0 calc((100vw - min(1180px,calc(100vw - 64px)))/-2)}.hero-media::after{background:linear-gradient(180deg,rgba(247,242,235,.98) 0%,rgba(247,242,235,.60) 18%,rgba(247,242,235,0) 38%),linear-gradient(90deg,rgba(247,242,235,.10),rgba(247,242,235,0) 45%)}.hero-media img{object-position:70% center}.approach-list{grid-template-columns:1fr}.approach-list article{border-left:0;border-top:1px solid rgba(255,255,255,.16);padding:19px 0}.approach-list article:first-child{border-top:0}.reason{min-height:150px;padding:23px 18px}.intro-wide{grid-template-columns:1fr;gap:18px}.intro-wide h2{grid-column:auto}.methods-grid{grid-template-columns:1fr 1fr}.method-card:last-child{grid-column:1/-1}.contact-grid{grid-template-columns:1fr;gap:38px}.contact-visual{max-width:680px}.contact-copy h2{font-size:4.3rem}}
@media(max-width:580px){.reviews-grid{grid-template-columns:1fr}.review-card{min-height:0;padding:25px 22px}.review-card blockquote{font-size:1.42rem}.review-card-featured{grid-column:auto;min-height:255px}.review-card-featured h3{font-size:2.05rem}
.container{width:min(100% - 40px,540px)}.nav-cta{display:none}.hero h1{font-size:clamp(4.1rem,18vw,5.5rem)}.role{font-size:.83rem}.hero-lead{font-size:1.34rem}.hero-actions{display:grid;justify-items:start;gap:21px}.hero-media{min-height:390px;margin:0 -20px}.hero-media img{object-position:72% center}.approach-inner{padding:63px 0 35px}.approach h2{font-size:2.6rem;text-align:left}.section{padding:62px 0}.reasons-grid{grid-template-columns:1fr 1fr}.reason{border-top:1px solid var(--line)}.reason:nth-child(odd){border-left:0}.reason:nth-child(-n+2){border-top:0}.reason span{margin-bottom:18px}.method-grid{grid-template-columns:1fr}.method-card:last-child{grid-column:auto}.method-card{min-height:0}.requests{padding-top:8px}.requests-grid{grid-template-columns:1fr}.request-card:last-child{grid-column:auto}.about{padding-top:34px}.about-grid{grid-template-columns:1fr}.about-photo{min-height:330px;margin:0 -20px}.about-copy{padding:40px 0 31px;background:transparent}.about-copy h2{font-size:2.7rem}.education-card{grid-column:auto;padding:29px 0 0}.notice-inner{grid-template-columns:1fr;gap:10px}.notice-icon{font-size:2.35rem}.contact-grid{padding:61px 0 45px}.contact-copy h2{font-size:3.65rem}.contact-list>*{grid-template-columns:25px 99px 1fr;font-size:.7rem}.contact-visual{min-height:410px;margin:0 -20px;border-radius:0}.contact-card{right:18px;bottom:18px;width:calc(100% - 36px)}.telegram-fab{right:16px;bottom:16px;width:56px;height:56px;padding:0;justify-content:center;border-radius:50%}.telegram-fab b{display:none}.footer-inner{min-height:70px;align-items:flex-start;justify-content:center;flex-direction:column;gap:4px;padding:12px 0}}


/* HERO BACKGROUND REFINEMENT — one continuous full-width image, no detached card */
.hero{
  position:relative;
  min-height:clamp(620px,calc(100svh - 76px),760px);
  isolation:isolate;
  overflow:hidden;
  display:flex;
  align-items:stretch;
  background:#e7dbcf;
}
.hero .hero-media{
  position:absolute;
  inset:0;
  z-index:-4;
  min-height:0;
  margin:0;
  overflow:hidden;
}
.hero .hero-media img{
  width:100%;
  height:100%;
  max-width:none;
  object-fit:cover;
  object-position:72% center;
  filter:saturate(.9) contrast(.98) brightness(.99);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background:
    linear-gradient(90deg,
      rgba(248,244,237,1) 0%,
      rgba(248,244,237,.98) 19%,
      rgba(247,242,235,.91) 35%,
      rgba(247,242,235,.68) 48%,
      rgba(247,242,235,.31) 61%,
      rgba(247,242,235,.08) 76%,
      rgba(247,242,235,0) 100%);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:
    radial-gradient(ellipse 60% 92% at 8% 48%,rgba(255,255,255,.64),transparent 67%),
    linear-gradient(180deg,rgba(255,255,255,.16) 0%,transparent 35%,rgba(25,43,33,.06) 100%);
}
.hero-grid{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  min-height:inherit;
}
.hero-copy{
  max-width:560px;
  margin:0;
  padding:64px 0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.hero-copy .eyebrow,.hero-copy .role,.hero-copy .hero-support{ text-shadow:0 1px 0 rgba(255,255,255,.28); }
.hero-lead{ text-shadow:0 1px 0 rgba(255,255,255,.4); }

@media(max-width:1040px){
  .hero .hero-media img{object-position:70% center}
  .hero-copy{max-width:540px;padding:56px 0}
}
@media(max-width:820px){
  .hero{min-height:760px}
  .hero-grid{display:flex;align-items:flex-start;min-height:760px}
  .hero-copy{max-width:380px;margin:0;padding:72px 0 48px}
  .hero .hero-media{position:absolute;inset:0;min-height:0;margin:0}
  .hero .hero-media img{width:100%;height:100%;object-position:74% center}
  .hero::before{
    background:
      linear-gradient(180deg,
        rgba(248,244,237,1) 0%,
        rgba(248,244,237,.98) 34%,
        rgba(248,244,237,.76) 52%,
        rgba(248,244,237,.36) 69%,
        rgba(248,244,237,.06) 84%,
        rgba(248,244,237,0) 100%),
      linear-gradient(90deg,rgba(248,244,237,.84) 0%,rgba(248,244,237,.20) 73%,transparent 100%);
  }
  .hero::after{background:radial-gradient(ellipse 95% 62% at 0% 18%,rgba(255,255,255,.56),transparent 72%)}
}
@media(max-width:580px){
  .hero{min-height:735px}
  .hero-grid{min-height:735px}
  .hero-copy{max-width:350px;padding:55px 0 38px}
  .hero .hero-media img{object-position:75% center}
  .hero h1{font-size:clamp(3.9rem,17vw,5.1rem)}
  .hero-lead{font-size:1.28rem}
  .hero-support{max-width:340px}
}


/* FINAL HERO + APPROACH CARDS — one banner background, no detached boxes */
.hero{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  min-height:clamp(620px, calc(100svh - 76px), 760px);
  display:flex;
  align-items:stretch;
  background-color:#e7dbcf;
  background-image:
    linear-gradient(90deg,
      rgba(248,244,237,1) 0%,
      rgba(248,244,237,.985) 21%,
      rgba(247,242,235,.91) 38%,
      rgba(247,242,235,.63) 52%,
      rgba(247,242,235,.23) 67%,
      rgba(247,242,235,.03) 82%,
      rgba(247,242,235,0) 100%),
    radial-gradient(ellipse 55% 92% at 5% 48%, rgba(255,255,255,.7), transparent 70%),
    url("images/konstantin-hero.webp");
  background-repeat:no-repeat;
  background-size:100% 100%, 100% 100%, cover;
  background-position:center, center, 72% center;
}
.hero::before,
.hero::after,
.hero .hero-media{display:none!important}
.hero-grid{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  min-height:inherit;
}
.hero-copy{
  max-width:565px;
  margin:0;
  padding:64px 0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.hero-copy .eyebrow,
.hero-copy .role,
.hero-copy .hero-support{ text-shadow:0 1px 0 rgba(255,255,255,.34); }
.hero-lead{ text-shadow:0 1px 0 rgba(255,255,255,.46); }

.approach{
  position:relative;
  overflow:hidden;
  color:#fbf6ee;
  background:
    radial-gradient(ellipse 40% 72% at 0% 86%, rgba(100,138,111,.42), transparent 72%),
    radial-gradient(ellipse 37% 62% at 100% 15%, rgba(80,120,94,.42), transparent 70%),
    linear-gradient(132deg,#071a12 0%,#103a2b 48%,#071a12 100%);
}
.approach::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.8;
  background:
    radial-gradient(ellipse 44% 52% at -5% 100%, rgba(214,180,127,.14), transparent 74%),
    radial-gradient(ellipse 36% 46% at 105% 6%, rgba(213,179,126,.13), transparent 76%),
    repeating-linear-gradient(157deg, transparent 0 54px, rgba(234,216,188,.032) 55px 56px);
}
.approach::after{
  content:"";
  position:absolute;
  inset:-6%;
  pointer-events:none;
  opacity:.23;
  background:
    radial-gradient(ellipse 26% 78% at -3% 72%, rgba(255,255,255,.16) 0 1%, transparent 1.3%),
    radial-gradient(ellipse 18% 56% at 104% 28%, rgba(255,255,255,.11) 0 1%, transparent 1.3%);
  filter:blur(.2px);
}
.approach-glow{display:none}
.approach-inner{
  position:relative;
  z-index:1;
  padding:92px 0 94px;
  text-align:center;
}
.approach-inner > .eyebrow{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:15px;
  margin-bottom:18px;
  color:rgba(232,204,158,.9);
  letter-spacing:.28em;
}
.approach-inner > .eyebrow::before,
.approach-inner > .eyebrow::after{
  content:"";
  width:62px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(216,181,135,.75));
}
.approach-inner > .eyebrow::after{transform:scaleX(-1)}
.approach h2{
  max-width:900px;
  margin:0 auto 54px;
  font-family:var(--serif);
  font-size:clamp(2.6rem,4.25vw,4.5rem);
  font-weight:500;
  line-height:.92;
  letter-spacing:-.045em;
  text-wrap:balance;
}
.approach-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  max-width:1080px;
  margin:0 auto;
  text-align:center;
}
.approach-list .approach-card{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  min-height:358px;
  padding:40px 32px 35px;
  overflow:hidden;
  border:1px solid rgba(216,181,135,.64);
  border-radius:18px;
  background:
    linear-gradient(148deg,rgba(39,86,63,.58),rgba(13,42,30,.72)),
    radial-gradient(circle at 50% 0%,rgba(216,181,135,.12),transparent 44%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 16px 42px rgba(0,0,0,.17);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  transition:transform .42s cubic-bezier(.2,.72,.2,1), border-color .34s ease, box-shadow .34s ease, background .34s ease;
  will-change:transform;
}
.approach-list .approach-card::before{
  content:"";
  position:absolute;
  inset:-55% -40% auto;
  height:120%;
  background:radial-gradient(circle, rgba(227,196,146,.15), transparent 61%);
  opacity:.55;
  transition:transform .7s ease, opacity .4s ease;
}
.approach-list .approach-card::after{
  content:"";
  position:absolute;
  left:18px;
  right:18px;
  bottom:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(224,192,142,.85),transparent);
  transform:scaleX(.42);
  transition:transform .42s ease;
}
.approach-list .approach-card:hover,
.approach-list .approach-card:focus-within{
  transform:translateY(-10px);
  border-color:rgba(230,198,148,.98);
  background:
    linear-gradient(148deg,rgba(51,105,77,.7),rgba(11,38,27,.82)),
    radial-gradient(circle at 50% 0%,rgba(226,193,142,.2),transparent 49%);
  box-shadow:0 26px 54px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.12);
}
.approach-list .approach-card:hover::before{transform:translateY(18px);opacity:.9}
.approach-list .approach-card:hover::after{transform:scaleX(1)}
.approach-card .approach-icon{
  position:relative;
  z-index:1;
  display:grid;
  place-items:center;
  width:82px;
  height:82px;
  margin:0 0 26px;
  border:1px solid rgba(218,184,132,.74);
  border-radius:50%;
  color:#edcc96;
  background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.1),transparent 50%);
  box-shadow:inset 0 0 0 8px rgba(216,181,135,.035), 0 0 30px rgba(213,179,126,.1);
  font-family:var(--serif);
  font-size:2.85rem;
  line-height:1;
  transition:transform .5s cubic-bezier(.2,.75,.2,1),box-shadow .35s ease;
}
.approach-card:hover .approach-icon{transform:translateY(-4px) rotate(6deg);box-shadow:inset 0 0 0 8px rgba(216,181,135,.07),0 0 36px rgba(227,196,146,.23)}
.approach-card h3{
  position:relative;
  z-index:1;
  margin:0;
  color:#e8c18c;
  font-family:var(--serif);
  font-size:1.7rem;
  line-height:.98;
  font-weight:600;
  letter-spacing:-.025em;
  text-transform:uppercase;
}
.approach-card .approach-divider{
  position:relative;
  z-index:1;
  margin:15px 0 17px;
  color:#e8c18c;
  font-size:.9rem;
  line-height:1;
}
.approach-card p{
  position:relative;
  z-index:1;
  max-width:270px;
  margin:0;
  color:rgba(255,250,241,.92);
  font-size:1rem;
  line-height:1.62;
}
.approach-list .reveal{transition-delay:var(--reveal-delay,0ms)}

@media (prefers-reduced-motion:reduce){
  .approach-list .approach-card,
  .approach-list .approach-card::before,
  .approach-list .approach-card::after,
  .approach-card .approach-icon{transition:none!important}
}
@media(max-width:1040px){
  .hero{background-position:center,center,68% center}
  .hero-copy{max-width:540px;padding:56px 0}
  .approach-list{gap:15px}
  .approach-list .approach-card{min-height:345px;padding:36px 23px 32px}
  .approach-card h3{font-size:1.48rem}
  .approach-card p{font-size:.92rem}
}
@media(max-width:820px){
  .hero{
    min-height:760px;
    background-image:
      linear-gradient(180deg,
        rgba(248,244,237,1) 0%,
        rgba(248,244,237,.98) 32%,
        rgba(248,244,237,.76) 52%,
        rgba(248,244,237,.33) 70%,
        rgba(248,244,237,.04) 88%,
        rgba(248,244,237,0) 100%),
      linear-gradient(90deg,rgba(248,244,237,.78) 0%,rgba(248,244,237,.1) 72%,transparent 100%),
      url("images/konstantin-hero.webp");
    background-size:100% 100%,100% 100%,cover;
    background-position:center,center,74% center;
  }
  .hero-grid{min-height:760px;align-items:flex-start}
  .hero-copy{max-width:390px;padding:72px 0 48px}
  .approach-inner{padding:72px 0 76px}
  .approach h2{max-width:680px;margin-bottom:38px}
  .approach-list{grid-template-columns:1fr;max-width:560px;gap:16px}
  .approach-list .approach-card{min-height:0;padding:34px 28px 31px}
  .approach-card .approach-icon{width:68px;height:68px;margin-bottom:19px;font-size:2.35rem}
}
@media(max-width:580px){
  .hero{min-height:735px;background-position:center,center,74% center}
  .hero-grid{min-height:735px}
  .hero-copy{max-width:350px;padding:55px 0 38px}
  .hero h1{font-size:clamp(3.9rem,17vw,5.1rem)}
  .hero-lead{font-size:1.28rem}
  .approach-inner{padding:60px 0 64px}
  .approach-inner > .eyebrow{gap:10px;font-size:.62rem}
  .approach-inner > .eyebrow::before,.approach-inner > .eyebrow::after{width:33px}
  .approach h2{font-size:2.65rem;text-align:center;margin-bottom:32px}
  .approach-list .approach-card{padding:32px 24px 29px;border-radius:16px}
  .approach-card h3{font-size:1.55rem}
  .approach-card p{max-width:285px;font-size:.94rem}
}


/* CONTACT ICONS + SPACED KO LOGO — refinement requested by client */
.brand-mark{
  display:inline-flex;
  align-items:baseline;
  gap:.16em;
  font-family:var(--serif);
  font-size:2.25rem;
  line-height:.82;
  letter-spacing:0;
  font-weight:600;
  transform:translateY(-.02em);
}
.brand-mark span{display:inline-block;}
.brand-mark span:first-child{margin-right:.01em;}

.contact-list > * > .contact-icon{
  display:grid;
  place-items:center;
  width:22px;
  height:22px;
  color:var(--gold-soft);
  font-family:inherit;
  font-size:inherit;
}
.contact-icon svg{display:block;width:20px;height:20px;}
.contact-icon--telegram svg{width:21px;height:21px;}
.contact-icon--phone svg{width:20px;height:20px;}
.contact-list > * > .contact-icon + b{align-self:center;}

.telegram-fab .fab-icon{
  display:grid;
  place-items:center;
  width:20px;
  height:20px;
}
.telegram-fab .fab-icon svg{display:block;width:20px;height:20px;}

@media(max-width:680px){
  .brand-mark{font-size:2.05rem;gap:.14em;}
  .contact-list > * > .contact-icon{width:21px;height:21px;}
  .contact-icon svg{width:19px;height:19px;}
  .telegram-fab .fab-icon{width:25px;height:25px;}
  .telegram-fab .fab-icon svg{width:25px;height:25px;}
}

/* KO MONOGRAM — custom mark based on approved reference */
.brand-mark{
  display:grid;
  place-items:center;
  width:54px;
  height:46px;
  flex:0 0 54px;
  overflow:visible;
  transform:none;
}
.brand-mark img{
  display:block;
  width:54px;
  height:46px;
  max-width:none;
  object-fit:contain;
  object-position:center;
}
@media(max-width:820px){
  .brand-mark{width:51px;height:44px;flex-basis:51px}
  .brand-mark img{width:51px;height:44px}
}
@media(max-width:580px){
  .brand-mark{width:49px;height:42px;flex-basis:49px}
  .brand-mark img{width:49px;height:42px}
}


/* MOBILE TYPE + HERO — refined for a real phone layout */
:root{
  --display:"Prata", "Cormorant Garamond", Georgia, serif;
}

.hero h1,
.section-intro h2,
.reviews-head h2,
.contact-copy h2{
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-.038em;
  font-kerning:normal;
}

.hero h1{
  font-size:clamp(4.35rem,6.45vw,6.45rem);
  line-height:.86;
  letter-spacing:-.052em;
  text-wrap:balance;
}
.hero .role{
  margin-top:26px;
  font-size:.93rem;
  letter-spacing:.005em;
}
.hero-lead{
  font-size:1.48rem;
  line-height:1.18;
  letter-spacing:-.018em;
}
.hero-support{
  font-size:.86rem;
  line-height:1.62;
}
.hero-mobile-photo{display:none}

@media (max-width:680px){
  /* A real phone composition: text first, then a separate portrait with the face visible. */
  .site-header{background:rgba(250,247,241,.96)}
  .nav-wrap{min-height:72px;gap:13px}
  .brand{min-width:0;gap:8px}
  .brand-text{display:none}
  .brand-mark{width:48px;height:42px;flex-basis:48px}
  .brand-mark img{width:48px;height:42px}
  .menu-toggle{order:2;margin-left:auto;display:grid}
  .nav-cta{order:3;display:inline-flex;padding:12px 13px;border-radius:11px;font-size:.61rem;line-height:1.15;max-width:134px;text-align:center}

  .hero{
    min-height:0;
    background:linear-gradient(144deg,#fbf8f2 0%,#f4ece3 100%);
    overflow:visible;
  }
  .hero-grid{
    display:block;
    min-height:0;
    width:100%;
    padding:0;
  }
  .hero-copy{
    max-width:none;
    padding:52px 0 34px;
    margin:0;
  }
  .hero .eyebrow{
    margin-bottom:18px;
    font-size:.62rem;
    letter-spacing:.23em;
  }
  .hero h1{
    max-width:100%;
    font-size:clamp(3.52rem,15.2vw,4.8rem);
    line-height:.88;
    letter-spacing:-.053em;
  }
  .hero .role{
    margin-top:23px;
    font-size:.86rem;
    line-height:1.42;
  }
  .hero .ornament{margin:25px 0 23px;width:90px}
  .hero-lead{
    max-width:345px;
    font-size:clamp(1.42rem,6.7vw,1.72rem);
    line-height:1.18;
    letter-spacing:-.017em;
  }
  .hero-support{
    max-width:340px;
    margin-top:17px;
    font-size:.84rem;
    line-height:1.62;
  }
  .hero-actions{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:16px 20px;
    margin-top:28px;
  }
  .hero-actions .button{padding:15px 17px;font-size:.75rem}
  .hero-actions .link-arrow{font-size:.76rem}

  .hero-mobile-photo{
    display:block;
    height:clamp(360px,106vw,470px);
    margin:0 calc((100vw - min(100% - 40px,540px)) / -2);
    border-radius:28px 28px 0 0;
    background-image:
      linear-gradient(180deg,rgba(247,242,235,.08) 0%,rgba(20,39,31,.03) 72%,rgba(16,39,31,.22) 100%),
      url("images/konstantin-hero.webp");
    background-repeat:no-repeat;
    background-size:cover;
    background-position:71% 38%;
    box-shadow:0 -14px 35px rgba(99,75,45,.06);
  }
  .hero::before,.hero::after{display:none!important}

  .approach-inner{padding-top:62px}
  .approach h2{font-family:var(--serif);font-weight:500;letter-spacing:-.04em}
}

@media (max-width:390px){
  .nav-cta{padding:10px 10px;font-size:.58rem;max-width:122px}
  .hero-copy{padding-top:44px}
  .hero h1{font-size:3.46rem}
  .hero-lead{font-size:1.36rem}
  .hero-actions{gap:14px}
  .hero-actions .link-arrow{font-size:.71rem}
  .hero-mobile-photo{height:350px;background-position:71% 35%}
}

@media (min-width:681px){
  .hero-mobile-photo{display:none!important}
}

/* TYPOGRAPHY SYSTEM — unified to match the approved editorial reference.
   One elegant serif for every title, quote and card heading;
   one neutral sans for navigation, labels and readable body copy. */
:root{
  --display:"Cormorant Garamond", Georgia, serif;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Manrope", Arial, sans-serif;
}

body{
  font-family:var(--sans);
  font-weight:400;
  letter-spacing:0;
}

/* Shared display rhythm */
.hero h1,
.hero-lead,
.approach h2,
.section-intro h2,
.intro-wide h2,
.about-copy h2,
.reviews-head h2,
.contact-copy h2,
.method-card h3,
.request-card h3,
.approach-card h3{
  font-family:var(--display)!important;
  font-kerning:normal;
  font-feature-settings:"kern","liga","clig";
  text-wrap:balance;
}

/* The headline is elegant but still confident, matching the original visual reference. */
.hero h1{
  font-weight:600!important;
  line-height:.83!important;
  letter-spacing:-.055em!important;
}
.hero-lead{
  font-weight:500!important;
  line-height:1.16!important;
  letter-spacing:-.022em!important;
}

/* All section titles now share one family and a consistent visual density. */
.approach h2,
.section-intro h2,
.intro-wide h2,
.about-copy h2,
.reviews-head h2,
.contact-copy h2{
  font-weight:500!important;
  line-height:.94!important;
  letter-spacing:-.045em!important;
}

/* Card titles use the same serif, only one step denser for readability. */
.method-card h3,
.request-card h3,
.approach-card h3{
  font-weight:600!important;
  letter-spacing:-.028em!important;
}

/* Keep utility text visually consistent across header, cards and contacts. */
.eyebrow,
.site-nav,
.nav-cta,
.button,
.link-arrow,
.role,
.hero-support,
.method-card p,
.request-card li,
.approach-card p,
.reason p,
.contact-list,
.review-card,
.brand-text{
  font-family:var(--sans)!important;
}

.eyebrow{
  font-weight:700!important;
  letter-spacing:.21em!important;
}
.site-nav,
.nav-cta,
.button,
.link-arrow{
  font-weight:600!important;
}

/* Reference-like mobile typography: larger breathing room and no cramped display type. */
@media (max-width:680px){
  .hero h1{
    font-size:clamp(3.72rem,15.8vw,4.95rem)!important;
    line-height:.85!important;
    letter-spacing:-.06em!important;
  }
  .hero-lead{
    font-size:clamp(1.5rem,7vw,1.78rem)!important;
    line-height:1.17!important;
  }
  .section-intro h2,
  .intro-wide h2,
  .about-copy h2,
  .reviews-head h2,
  .contact-copy h2{
    letter-spacing:-.048em!important;
    line-height:.96!important;
  }
  .approach h2{
    font-size:clamp(2.75rem,11vw,3.45rem)!important;
    line-height:.94!important;
  }
  .method-card h3,
  .request-card h3,
  .approach-card h3{
    line-height:1.02!important;
  }
}


/* MOBILE PHOTO FIX — direct <img>, not CSS background. This works both locally and on Netlify. */
.hero-mobile-photo{display:none}
.hero-mobile-photo img{display:block;width:100%;height:100%;object-fit:cover;object-position:71% 35%}
@media (max-width:680px){
  .hero-mobile-photo{
    display:block;
    height:clamp(360px,106vw,470px);
    margin:0 calc((100vw - min(100% - 40px,540px)) / -2);
    overflow:hidden;
    border-radius:28px 28px 0 0;
    background:#e7dbcf;
    box-shadow:0 -14px 35px rgba(99,75,45,.06);
  }
  .hero-mobile-photo::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:linear-gradient(180deg,rgba(247,242,235,.06) 0%,rgba(20,39,31,.03) 72%,rgba(16,39,31,.18) 100%);
  }
  .hero-mobile-photo{position:relative}
  .hero-mobile-photo img{object-position:71% 32%}
}
@media (max-width:390px){
  .hero-mobile-photo{height:350px}
  .hero-mobile-photo img{object-position:71% 30%}
}
@media (min-width:681px){.hero-mobile-photo{display:none!important}}
