*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --eggshell:#F0EDDC;--stone:#B9AC8C;--coffee:#845F4A;--pink:#DFA0AA;
  --pink-light:#E8C3BC;--blush:#F2D5CF;--dark:#2E2924;--cream:#FAF8F2;
  --warm-gray:#4B443E;--text:#5A5249;--bg:#F5F2EB;--accent:#C4917A;
  --nav-height:60px;
}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;color:var(--text);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--pink);color:var(--cream)}

/* ── Preloader ── */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--dark);display:flex;align-items:center;justify-content:center;transition:opacity .6s,visibility .6s}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.4rem,4vw,2.5rem);font-weight:300;font-style:italic;color:var(--eggshell);opacity:0;animation:pIn 1s ease forwards}
.preloader-bar{width:120px;height:1px;background:rgba(240,237,220,.1);margin:1.5rem auto 0;position:relative;overflow:hidden}
.preloader-bar::after{content:'';position:absolute;inset:0;background:var(--pink-light);animation:pBar 1s ease forwards}
@keyframes pIn{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}
@keyframes pBar{from{transform:translateX(-100%)}to{transform:translateX(0)}}

/* ── Cursor ── */
.cursor-ring{position:fixed;width:40px;height:40px;border:1px solid var(--pink);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:difference;will-change:left,top}
.cursor-ring.h{width:60px;height:60px;border-color:var(--pink-light)}
@media(pointer:coarse){.cursor-ring{display:none!important}}
@media(max-width:768px){.cursor-ring{display:none!important}}

/* ── Reveal animations ── */
.rv{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rv.v{opacity:1;transform:translateY(0)}
.rl{opacity:0;transform:translateX(-40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rl.v{opacity:1;transform:translateX(0)}
.rs{opacity:0;transform:scale(.92);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rs.v{opacity:1;transform:scale(1)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ── Navigation ── */
.top-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 3rem;display:flex;justify-content:space-between;align-items:center;mix-blend-mode:difference;transition:padding .3s}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:#fff;text-decoration:none}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-size:.7rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:#fff;text-decoration:none;position:relative;padding-bottom:3px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;background:#fff;transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.22,1,.36,1)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}

/* ── Burger ── */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:28px;height:28px;cursor:pointer;z-index:1002;background:none;border:none;padding:0}
.burger span{display:block;width:100%;height:1.5px;background:#fff;transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .3s}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── Mobile menu ── */
.mobile-menu{position:fixed;inset:0;z-index:999;background:var(--dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,5vw,2.5rem);font-weight:300;color:var(--eggshell);text-decoration:none;letter-spacing:.05em;opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s,color .3s}
.mobile-menu.open a{opacity:1;transform:translateY(0)}
.mobile-menu.open a:nth-child(1){transition-delay:.1s}
.mobile-menu.open a:nth-child(2){transition-delay:.2s}
.mobile-menu.open a:nth-child(3){transition-delay:.3s}
.mobile-menu.open a:nth-child(4){transition-delay:.4s}
.mobile-menu a:active{color:var(--pink-light)}

@media(max-width:900px){
  .top-nav{padding:1rem 1.5rem}
  .nav-links{display:none}
  .burger{display:flex}
}

/* ── Hero ── */
.hero{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--dark)}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;will-change:transform;animation:bf 12s ease-in-out infinite alternate}
.hb1{width:min(500px,80vw);height:min(500px,80vw);background:var(--coffee);top:-10%;left:-5%}
.hb2{width:min(400px,70vw);height:min(400px,70vw);background:var(--pink);bottom:-15%;right:-5%;animation-delay:-4s;animation-duration:15s}
.hb3{width:min(300px,50vw);height:min(300px,50vw);background:var(--stone);top:30%;left:50%;animation-delay:-8s;animation-duration:18s}
@keyframes bf{0%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-40px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.97)}100%{transform:translate(15px,-15px) scale(1.02)}}
.hero-line{position:absolute;background:rgba(240,237,220,.07)}
.hl1{width:1px;height:40vh;top:0;left:25%}.hl2{width:1px;height:60vh;bottom:0;left:50%}.hl3{width:1px;height:35vh;top:10%;right:25%}
.hl4{width:30vw;height:1px;top:30%;left:10%}.hl5{width:25vw;height:1px;bottom:35%;right:5%}
.hero-content{position:relative;z-index:2;text-align:center;padding:2rem 1.5rem}
.hero-eyebrow{font-weight:300;font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:var(--stone);margin-bottom:2.5rem;opacity:0;animation:hIn 1s .6s forwards}
.hero-title{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(3rem,9vw,8rem);color:var(--eggshell);line-height:.95;letter-spacing:-.03em;margin-bottom:.2em;overflow:hidden}
.htl{display:block;opacity:0;animation:hSlide 1.2s cubic-bezier(.16,1,.3,1) forwards}
.htl:nth-child(1){animation-delay:.8s}.htl:nth-child(2){animation-delay:.95s}
.htl.it{font-style:italic;color:var(--pink-light)}
@keyframes hSlide{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}
@keyframes hIn{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}
.hero-sub{font-weight:200;font-size:.85rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(240,237,220,.5);margin-top:2rem;opacity:0;animation:hIn 1s 1.2s forwards}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:hIn 1s 1.6s forwards}
.hero-scroll span{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(240,237,220,.3);writing-mode:vertical-lr}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--pink-light),transparent);animation:sPulse 2s ease-in-out infinite}
@keyframes sPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ── Marquee ── */
.marquee-wrap{overflow:hidden;background:var(--cream);padding:1rem 0;border-top:1px solid rgba(185,172,140,.15);border-bottom:1px solid rgba(185,172,140,.15)}
.marquee{display:flex;width:max-content;animation:mScroll 25s linear infinite}
.marquee span{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-weight:400;font-style:italic;letter-spacing:.08em;color:var(--stone);white-space:nowrap;padding:0 2rem}
.marquee .dot{color:var(--pink);font-style:normal}
@keyframes mScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── About ── */
.about{padding:8rem 3rem;position:relative;overflow:hidden;background:var(--cream)}
.about-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start}
.about-left{position:relative}
.about-label-v{font-weight:300;font-size:.6rem;letter-spacing:.5em;text-transform:uppercase;color:var(--stone);writing-mode:vertical-lr;position:absolute;left:-2.5rem;top:0}
.about-big{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,4vw,3.5rem);font-weight:400;line-height:1.15;color:var(--dark);margin-bottom:2rem}
.about-big em{font-style:italic;color:var(--coffee)}
.about-frame{width:100%;aspect-ratio:2/3;border:1px solid var(--stone);position:relative;margin-top:2rem;overflow:hidden}
.about-frame img{width:100%;height:100%;object-fit:cover;display:block}
.about-right{padding-top:2rem}
.about-p{font-family:'Cormorant Garamond',serif;font-size:clamp(1.05rem,1.8vw,1.2rem);font-weight:300;line-height:1.85;color:var(--dark);margin-bottom:1.5rem}
.about-p strong{font-weight:500;color:var(--coffee)}
.about-quote{margin-top:2.5rem;padding:2rem 2.5rem;position:relative;background:linear-gradient(135deg,rgba(223,160,170,.08),rgba(185,172,140,.08));border-left:3px solid var(--pink)}
.about-quote::before{content:'\00AB';font-family:'Playfair Display',serif;font-size:4rem;color:var(--pink-light);position:absolute;top:.5rem;left:.8rem;line-height:1;opacity:.4}
.about-quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.8;color:var(--coffee)}
.fo{position:absolute;pointer-events:none;opacity:.06}
.fo svg{width:100%;height:100%}
.fo-1{width:300px;height:300px;top:5%;right:-5%}.fo-2{width:200px;height:200px;bottom:10%;left:-3%}

/* ── Numbers ── */
.numbers{background:var(--dark);padding:4rem 2rem;display:flex;justify-content:center;gap:clamp(2rem,6vw,6rem);flex-wrap:wrap;position:relative}
.numbers::before,.numbers::after{content:'';position:absolute;left:10%;right:10%;height:1px;background:rgba(240,237,220,.06)}
.numbers::before{top:0}.numbers::after{bottom:0}
.num-item{text-align:center}
.num-val{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,4rem);font-weight:400;color:var(--pink-light);line-height:1;margin-bottom:.5rem}
.num-lbl{font-weight:300;font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--stone)}

/* ── Philosophy ── */
.philosophy{padding:8rem 3rem;background:var(--bg);position:relative;overflow:hidden}
.phil-hdr{max-width:1200px;margin:0 auto 4rem;display:flex;align-items:baseline;gap:2rem}
.phil-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--dark)}
.phil-line{flex:1;height:1px;background:linear-gradient(to right,var(--stone),transparent)}
.phil-num{font-family:'Cormorant Garamond',serif;font-size:.85rem;font-weight:300;color:var(--stone);letter-spacing:.15em}
.phil-cards{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.phil-card{padding:3rem 2.5rem;position:relative;border:1px solid rgba(185,172,140,.15);overflow:hidden;transition:background .5s}
.phil-card:hover{background:rgba(240,237,220,.5)}
.phil-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(to right,var(--pink),var(--coffee));transform:scaleX(0);transform-origin:left;transition:transform .6s cubic-bezier(.22,1,.36,1)}
.phil-card:hover::before{transform:scaleX(1)}
.pc-num{font-family:'Playfair Display',serif;font-size:3.5rem;font-weight:400;color:var(--pink-light);opacity:.25;position:absolute;top:1rem;right:1.5rem;line-height:1}
.pc-title{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--dark);margin-bottom:1rem}
.pc-body{font-size:.82rem;font-weight:300;line-height:1.85;color:var(--text)}
.pc-accent{position:absolute;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--pink-light) 0%,transparent 70%);opacity:.1;bottom:-30px;left:-30px}

/* ── Services ── */
.services{background:var(--warm-gray);padding:8rem 3rem;position:relative;overflow:hidden}
.services::before{content:'УСЛУГИ';position:absolute;top:3rem;right:-1rem;font-family:'Playfair Display',serif;font-size:clamp(4rem,12vw,10rem);font-weight:700;color:rgba(255,255,255,.02);letter-spacing:.05em;pointer-events:none}
.svc-hdr{max-width:1200px;margin:0 auto 4rem}
.svc-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--eggshell);margin-bottom:.5rem}
.svc-sub{font-weight:200;font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--stone)}
.svc-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:1px;background:rgba(255,255,255,.04)}
.svc-card{background:var(--warm-gray);padding:2.5rem 2rem;position:relative;overflow:hidden;transition:background .4s}
.svc-card:hover{background:rgba(255,255,255,.02)}
.svc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}
.svc-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:500;color:var(--eggshell);flex:1;min-width:0}
.svc-price{font-weight:300;font-size:.7rem;letter-spacing:.1em;color:var(--dark);background:var(--pink-light);padding:.35rem .8rem;border-radius:20px;white-space:nowrap;flex-shrink:0}
.svc-list{list-style:none;margin-bottom:1rem}
.svc-list li{font-size:.78rem;font-weight:300;line-height:1.9;color:rgba(240,237,220,.6);padding-left:1.2rem;position:relative}
.svc-list li::before{content:'';position:absolute;left:0;top:.65em;width:4px;height:4px;background:var(--pink);border-radius:50%;opacity:.5}
.svc-note{font-size:.7rem;font-weight:300;color:rgba(240,237,220,.3);font-style:italic}

/* ── Approach ── */
.approach{padding:8rem 0;background:var(--cream);overflow:hidden}
.approach-hdr{max-width:1200px;margin:0 auto 3rem;padding:0 3rem;display:flex;align-items:baseline;gap:2rem}
.approach-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--dark)}
.approach-line{flex:1;height:1px;background:linear-gradient(to right,var(--stone),transparent)}
.approach-track-wrap{position:relative}
.approach-track{display:flex;gap:2rem;padding:0 3rem 2rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.approach-track::-webkit-scrollbar{display:none}
.scroll-hint{display:none;text-align:center;padding:.8rem 0 0;font-size:.65rem;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);animation:hintPulse 2s ease-in-out infinite}
@keyframes hintPulse{0%,100%{opacity:.4}50%{opacity:.8}}
.ac{flex:0 0 min(340px,80vw);scroll-snap-align:start;padding:3rem 2.5rem;background:var(--bg);border:1px solid rgba(185,172,140,.15);position:relative;overflow:hidden;transition:transform .4s,box-shadow .4s}
.ac:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(46,41,36,.08)}
.ac-icon{font-family:'Playfair Display',serif;font-size:2rem;color:var(--pink);margin-bottom:1.5rem;display:block}
.ac h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--dark);margin-bottom:1rem}
.ac p{font-size:.82rem;font-weight:300;line-height:1.8;color:var(--text)}
.ac::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:3px;background:linear-gradient(to right,var(--pink-light),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.22,1,.3,1)}
.ac:hover::before{transform:scaleX(1)}

/* ── Mobile photo section ── */
.mobile-section{padding:8rem 3rem;background:var(--bg);position:relative;overflow:hidden}
.mobile-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr;gap:5rem;align-items:center}
.mobile-visual{position:relative;height:450px}
.ms{position:absolute;animation:morph 10s ease-in-out infinite;will-change:border-radius}
.ms:nth-child(1){width:min(280px,60vw);height:min(280px,60vw);background:linear-gradient(135deg,var(--pink-light),var(--blush));opacity:.5;top:10%;left:15%;border-radius:30% 70% 70% 30%/30% 30% 70% 70%}
.ms:nth-child(2){width:min(200px,45vw);height:min(200px,45vw);background:linear-gradient(135deg,var(--stone),var(--eggshell));opacity:.4;top:35%;left:45%;animation-delay:-3s;border-radius:70% 30% 30% 70%/70% 70% 30% 30%}
.ms:nth-child(3){width:min(150px,35vw);height:min(150px,35vw);background:linear-gradient(135deg,var(--coffee),var(--accent));opacity:.25;top:15%;right:10%;animation-delay:-6s;border-radius:50% 50% 30% 70%/40% 60% 60% 40%}
.ms-text{position:absolute;bottom:15%;left:20%;font-family:'Playfair Display',serif;font-style:italic;font-size:1.8rem;color:var(--coffee);opacity:.2}
@keyframes morph{0%,100%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}25%{border-radius:50% 50% 30% 70%/40% 60% 60% 40%}50%{border-radius:70% 30% 50% 50%/60% 40% 30% 70%}75%{border-radius:40% 60% 60% 40%/70% 30% 70% 30%}}
.mobile-content .stag{font-weight:300;font-size:.65rem;letter-spacing:.5em;text-transform:uppercase;color:var(--pink);margin-bottom:1.5rem}
.mobile-content h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.5rem);font-weight:400;color:var(--dark);margin-bottom:1.5rem;line-height:1.2}
.mobile-content h2 em{color:var(--coffee);font-style:italic}
.mobile-content p{font-family:'Cormorant Garamond',serif;font-size:clamp(1rem,1.5vw,1.1rem);font-weight:300;line-height:1.8;color:var(--text);margin-bottom:1rem}

/* ── Contact ── */
.contact{background:var(--dark);padding:8rem 3rem;position:relative;overflow:hidden;text-align:center}
.contact-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Playfair Display',serif;font-size:clamp(6rem,18vw,16rem);font-weight:700;color:rgba(255,255,255,.015);white-space:nowrap;pointer-events:none}
.contact-orn{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-bottom:3rem}
.co-ln{width:60px;height:1px;background:rgba(185,172,140,.2)}
.co-dm{width:8px;height:8px;border:1px solid var(--pink);transform:rotate(45deg)}
.contact-name{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,6vw,5rem);font-weight:400;color:var(--eggshell);line-height:1.05;margin-bottom:.5rem}
.contact-name em{font-style:italic;color:var(--pink-light);display:block}
.contact-role{font-weight:200;font-size:.75rem;letter-spacing:.4em;text-transform:uppercase;color:var(--stone);margin-bottom:3.5rem}
.contact-btns{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;padding:0 1rem}
.cbtn{font-weight:400;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--eggshell);text-decoration:none;padding:.85rem 2rem;border:1px solid rgba(240,237,220,.15);position:relative;overflow:hidden;transition:color .4s,border-color .4s}
.cbtn::before{content:'';position:absolute;inset:0;background:var(--pink-light);transform:translateY(100%);transition:transform .5s cubic-bezier(.22,1,.36,1)}
.cbtn:hover{color:var(--dark);border-color:var(--pink-light)}
.cbtn:hover::before{transform:translateY(0)}
.cbtn span{position:relative;z-index:1}
.contact-svg{margin-top:4rem;display:flex;justify-content:center}
.contact-svg svg{opacity:.1}

/* ── Footer ── */
.footer{background:var(--dark);text-align:center;padding:1.5rem 2rem;border-top:1px solid rgba(185,172,140,.06)}
.footer p{font-size:.65rem;font-weight:300;letter-spacing:.15em;color:rgba(240,237,220,.2)}

/* ══ Responsive ══ */
@media(max-width:1100px) and (min-width:901px){
  .about-grid{gap:3rem}
  .phil-cards{gap:0}
  .phil-card{padding:2.5rem 2rem}
  .mobile-grid{gap:3rem}
}
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:2rem}
  .about-left{position:static}
  .about-label-v{writing-mode:horizontal-tb;position:static;margin-bottom:1rem}
  .about-frame{aspect-ratio:3/4}
  .phil-cards{grid-template-columns:1fr}
  .phil-card{border-bottom:none}
  .phil-card:last-child{border-bottom:1px solid rgba(185,172,140,.15)}
  .svc-grid{grid-template-columns:1fr}
  .mobile-grid{grid-template-columns:1fr;gap:2rem}
  .mobile-visual{height:220px}
  .numbers{gap:2.5rem}
  .about,.philosophy,.services,.mobile-section,.contact{padding:5rem 1.5rem}
  .approach{padding:5rem 0}
  .approach-hdr{padding:0 1.5rem}
  .approach-track{padding:0 1.5rem 1rem}
  .scroll-hint{display:block}
}
@media(max-width:500px){
  .hero-eyebrow{letter-spacing:.25em;font-size:.6rem}
  .hero-sub{letter-spacing:.15em;font-size:.75rem}
  .about,.philosophy,.services,.mobile-section,.contact{padding:4rem 1.2rem}
  .approach-hdr{padding:0 1.2rem}
  .approach-track{padding:0 1.2rem 1rem;gap:1rem}
  .ac{flex:0 0 85vw;padding:2.5rem 2rem}
  .phil-card{padding:2.5rem 1.8rem}
  .svc-card{padding:2rem 1.5rem}
  .about-quote{padding:1.5rem 1.8rem}
  .cbtn{padding:.75rem 1.5rem;font-size:.65rem}
  .contact-btns{gap:.8rem}
  .mobile-visual{height:180px}
  .ms:nth-child(1){width:55vw;height:55vw}
  .ms:nth-child(2){width:40vw;height:40vw}
  .ms:nth-child(3){width:30vw;height:30vw}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .rv,.rl,.rs{opacity:1;transform:none}
}
