:root{--gold:#C9A84C;--gold-lt:#DFC070;--gold-dim:rgba(201,168,76,.18);--ink:#0A0908;--ink2:#0F0E0C;--ink3:#161410;--parch:#F2EDE3;--muted:rgba(242,237,227,.45);--dim:rgba(242,237,227,.25);--line:rgba(242,237,227,.06);--serif:'Cormorant Garamond',Georgia,serif;--body:'Jost',system-ui,sans-serif;--ease:cubic-bezier(.76,0,.24,1);--ease-out:cubic-bezier(.33,1,.68,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--ink);color:var(--parch);font-family:var(--body);font-size:16px;font-weight:300;line-height:1.7;overflow-x:hidden;cursor:none;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* CURSOR */
#cur{position:fixed;pointer-events:none;z-index:99999;top:0;left:0;will-change:transform}
.c-dot{position:absolute;width:5px;height:5px;background:var(--gold);border-radius:50%;transform:translate(-50%,-50%);transition:width .2s,height .2s}
.c-ring{position:absolute;width:34px;height:34px;border:1px solid rgba(201,168,76,.4);border-radius:50%;transform:translate(-50%,-50%);transition:width .45s var(--ease),height .45s var(--ease),border-color .3s}
body.cur-hov .c-dot{width:3px;height:3px}
body.cur-hov .c-ring{width:56px;height:56px;border-color:rgba(201,168,76,.65)}
@media(pointer:coarse){body{cursor:auto}#cur{display:none}}

/* LOADER */
#loader{position:fixed;inset:0;z-index:9900;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px}
.ld-mark{display:flex;flex-direction:column;align-items:center;opacity:0;transform:translateY(20px);animation:ldRise .9s .2s var(--ease) forwards}
.ld-triangle{width:72px;height:62px}
.ld-triangle svg{width:100%;height:100%;overflow:visible}
.ld-tri-path{stroke-dasharray:290;stroke-dashoffset:290;animation:drawTri 1.4s .6s var(--ease) forwards}
.ld-wordmark{font-family:var(--serif);font-size:10px;letter-spacing:10px;color:rgba(242,237,227,.42);margin-top:16px;opacity:0;animation:ldFade .6s 1.4s ease forwards}
.ld-progress{width:160px;height:1px;background:rgba(242,237,227,.05);overflow:hidden;opacity:0;animation:ldFade .4s 1s ease forwards}
.ld-bar{height:100%;width:0;background:linear-gradient(90deg,transparent,var(--gold),transparent);animation:ldFill 1.5s 1.2s var(--ease-out) forwards}
@keyframes ldRise{to{opacity:1;transform:translateY(0)}}
@keyframes ldFade{to{opacity:1}}
@keyframes ldFill{to{width:100%}}
@keyframes drawTri{to{stroke-dashoffset:0}}
#loader.out{animation:ldOut .8s 2.7s var(--ease) forwards;pointer-events:none}
@keyframes ldOut{to{opacity:0;visibility:hidden}}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:800;display:flex;align-items:center;justify-content:space-between;padding:32px 72px;background:transparent;transition:padding .5s var(--ease),background .5s,backdrop-filter .5s;font-family:var(--body)}
header.stuck{padding:18px 72px;background:rgba(10,9,8,.95) !important;backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08)}
.hd-logo{display:flex;align-items:center;gap:14px}
.hd-logo-mark{height:50px;width:auto;flex-shrink:0;image-rendering:-webkit-optimize-contrast;filter:brightness(1.15) contrast(1.1)}
nav{display:flex;align-items:center;gap:44px}
nav a{font-size:10px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;color:rgba(242,237,227,0.7);position:relative;transition:color .3s}
nav a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
nav a:hover,nav a.active{color:var(--parch)}
nav a:hover::after,nav a.active::after{width:100%}
.hd-cta{padding:11px 26px;border:1px solid rgba(201,168,76,.28);font-size:9px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);white-space:nowrap;transition:background .3s,color .3s,border-color .3s}
.hd-cta:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}

/* BURGER */
.burg{display:none;align-items:center;justify-content:center;width:44px;height:44px;cursor:pointer;background:transparent;border:none;padding:4px;position:relative;z-index:801;transition:opacity .3s}
.burg-lines{display:flex;flex-direction:column;gap:6px;width:26px;pointer-events:none}
.burg-line{display:block;height:1.5px;background:var(--parch);transform-origin:center;transition:transform .38s var(--ease),opacity .25s,width .38s var(--ease),background .25s;border-radius:2px}
.burg-line:nth-child(1){width:26px}
.burg-line:nth-child(2){width:18px;margin-left:auto}
.burg-line:nth-child(3){width:22px}
.burg:hover .burg-line{background:var(--gold)}
.burg:hover .burg-line:nth-child(2){width:26px;margin-left:0}
body.menu-open .burg{opacity:0;pointer-events:none}

/* MOBILE */
.mob-back{position:fixed;inset:0;z-index:820;background:rgba(5,4,3,.65);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .45s ease}
.mob-back.open{opacity:1;pointer-events:auto}
.mob-nav{display:flex !important;position:fixed;top:0;left:0;bottom:0;z-index:830;width:min(300px,82vw);background:linear-gradient(165deg,#0d0c0a 0%,#0a0908 55%,#0f0d0b 100%);border-right:1px solid rgba(201,168,76,.1);flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:0;padding:0;transform:translateX(-100%);transition:transform .52s cubic-bezier(.86,0,.07,1);box-shadow:28px 0 80px rgba(0,0,0,.5);will-change:transform;opacity:1;pointer-events:none;overflow-y:auto;text-align:left}
.mob-nav::before{display:none !important}
.mob-nav.open{transform:translateX(0);pointer-events:all}
.mob-nav-head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:22px 20px 18px;border-bottom:1px solid rgba(242,237,227,.05);flex-shrink:0}
.mob-nav-brand{display:flex;align-items:center;gap:10px}
.mob-logo-img{height:50px;width:auto;image-rendering:-webkit-optimize-contrast;filter:brightness(1.2) contrast(1.15)}
.mob-nav-brand-txt{display:none}
.mob-close{width:34px;height:34px;border-radius:50%;border:1px solid rgba(201,168,76,.22);background:rgba(201,168,76,.04);display:flex;align-items:center;justify-content:center;color:rgba(242,237,227,.6);cursor:pointer;transition:all .3s var(--ease);flex-shrink:0;position:static;top:auto;right:auto}
.mob-close:hover{border-color:var(--gold);background:rgba(201,168,76,.1);color:var(--gold);transform:rotate(90deg)}
.mob-close svg{width:13px;height:13px}
.mob-nav a{position:relative;display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 20px;font-family:var(--serif);font-size:25px;font-weight:400;letter-spacing:.01em;color:rgba(242,237,227,.72);transition:color .3s,padding-left .35s var(--ease),background .3s;border-bottom:1px solid rgba(242,237,227,.04);transform:none}
.mob-nav a::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .35s var(--ease)}
.mob-nav a::after{display:none !important}
.mob-nav a:hover,.mob-nav a.active{color:var(--gold);padding-left:28px;background:rgba(201,168,76,.03);transform:none}
.mob-nav a:hover::before,.mob-nav a.active::before{transform:scaleY(1)}
.arr-icon{font-size:13px;opacity:0;transform:translateX(-8px);transition:opacity .3s,transform .3s}
.mob-nav a:hover .arr-icon{opacity:.5;transform:translateX(0)}
.mob-nav-cta-wrap{width:100%;padding:18px 20px 32px;margin-top:auto;border-top:1px solid rgba(242,237,227,.05)}
.mob-nav .mob-cta{display:block;width:100%;padding:12px 20px;margin-top:0;background:var(--gold);color:var(--ink);font-size:8.5px;font-weight:500;letter-spacing:3px;text-transform:uppercase;text-align:center;border:none;transition:opacity .3s,transform .3s}
.mob-nav .mob-cta:hover{opacity:.88;transform:translateY(-1px);background:var(--gold);color:var(--ink)}
.mob-nav-tel{margin-top:11px;font-size:10.5px;color:rgba(242,237,227,.28);letter-spacing:1px;text-align:center}
.mob-nav-tel a{color:rgba(201,168,76,.55);transition:color .3s}
.mob-nav-tel a:hover{color:var(--gold)}
body.menu-open{overflow:hidden}

/* HERO */
#hero{position:relative;height:100svh;min-height:640px;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.04fr) minmax(420px,.96fr);align-items:stretch;background:radial-gradient(circle at 12% 18%,rgba(201,168,76,.12),transparent 28%),radial-gradient(circle at 82% 18%,rgba(255,255,255,.05),transparent 22%),linear-gradient(135deg,#050504 0%,#0b0908 48%,#13100d 100%)}
#hero::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,9,8,.96) 0%,rgba(10,9,8,.84) 34%,rgba(10,9,8,.42) 58%,rgba(10,9,8,.2) 100%),repeating-linear-gradient(90deg,rgba(242,237,227,.014) 0 1px,transparent 1px 72px);z-index:1;pointer-events:none}
#hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18),transparent 22%,transparent 78%,rgba(0,0,0,.34));z-index:1;pointer-events:none}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.06);transition:opacity 2.2s var(--ease),transform 10s ease}
.hero-slide.on{opacity:1;transform:scale(1)}
.hero-right-ov{position:absolute;inset:0;z-index:2;background:linear-gradient(to right,rgba(10,9,8,.7) 0%,rgba(10,9,8,.18) 36%,transparent 56%),linear-gradient(to top,rgba(10,9,8,.82) 0%,rgba(10,9,8,.26) 40%,transparent 66%);pointer-events:none}
.hero-left{position:relative;z-index:4;display:flex;flex-direction:column;justify-content:center;padding:140px clamp(36px,5vw,72px) 100px clamp(28px,6vw,88px)}
.hero-left::after{content:'';position:absolute;top:0;right:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent 0%,rgba(201,168,76,.38) 28%,rgba(201,168,76,.13) 72%,transparent 100%)}
.hero-left::before{content:'';position:absolute;left:24px;top:50%;transform:translateY(-50%);height:200px;width:1px;background:linear-gradient(to bottom,transparent,rgba(201,168,76,.16) 50%,transparent)}
.hero-right{position:relative;z-index:3;overflow:hidden;min-width:0}
.hero-slides{position:absolute;inset:0}
.hero-watermark{position:absolute;z-index:3;right:28px;bottom:18px;font-family:var(--serif);font-size:clamp(50px,6.5vw,88px);font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(242,237,227,.055);letter-spacing:-.04em;pointer-events:none}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:9px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:28px;opacity:0;transform:translateY(16px)}
.hero-eyebrow::before{content:'';width:28px;height:1px;background:var(--gold)}
.hero-h1{font-family:var(--serif);font-size:clamp(56px,5.4vw,96px);font-weight:400;line-height:.94;letter-spacing:-.025em;color:var(--parch);opacity:0;transform:translateY(32px)}
.hero-h1 em{font-style:italic;color:var(--gold-lt);font-weight:300}
.hero-divider{display:flex;align-items:center;gap:16px;margin:32px 0 26px;opacity:0;transform:scaleX(0);transform-origin:left}
.hero-divider::before{content:'';width:48px;height:1px;background:linear-gradient(to right,var(--gold),rgba(201,168,76,.25));flex-shrink:0}
.hero-divider::after{content:'';flex:1;height:1px;background:var(--line)}
.hero-divider span{font-size:7px;letter-spacing:3px;text-transform:uppercase;color:rgba(201,168,76,.5);white-space:nowrap}
.hero-sub{font-size:15px;line-height:1.9;color:rgba(242,237,227,.72);max-width:520px;opacity:0;transform:translateY(16px)}
.hero-actions{display:flex;align-items:center;gap:28px;margin-top:44px;opacity:0;transform:translateY(16px)}
.hero-btn-main{display:inline-flex;align-items:center;gap:12px;padding:14px 38px;background:var(--gold);color:var(--ink);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.14);box-shadow:0 16px 34px rgba(201,168,76,.16);transition:transform .3s var(--ease),box-shadow .3s}
.hero-btn-main::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.18);transform:translateX(-101%);transition:transform .42s var(--ease)}
.hero-btn-main:hover::after{transform:translateX(0)}
.hero-btn-main:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(201,168,76,.22)}
.hero-btn-ghost{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(242,237,227,.82);border-bottom:1px solid rgba(242,237,227,.24);padding-bottom:2px;transition:color .3s,border-color .3s}
.hero-btn-ghost:hover{color:var(--parch);border-color:rgba(242,237,227,.4)}
.hero-stats{display:flex;gap:0;margin-top:52px;padding-top:36px;border-top:1px solid var(--line);opacity:0;transform:translateY(16px)}
.hero-stat{flex:1;padding-right:28px;border-right:1px solid var(--line)}
.hero-stat:last-child{border-right:none;padding-right:0;padding-left:28px}
.hero-stat:first-child{padding-left:0}
.hero-stat .hs-n{font-family:var(--serif);font-size:30px;font-weight:400;color:var(--gold-lt);line-height:1}
.hero-stat .hs-l{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-top:6px}
.hero-counter{position:absolute;bottom:32px;right:32px;z-index:5;font-size:9px;letter-spacing:3px;color:rgba(242,237,227,.28)}
.hero-counter b{color:var(--gold);font-weight:400;font-family:var(--serif);font-size:13px}
.hero-prog{position:absolute;bottom:0;left:0;right:0;z-index:5;height:1px;background:rgba(242,237,227,.04)}
.hero-prog-bar{height:100%;width:0;background:var(--gold)}
.hero-scroll{position:absolute;bottom:32px;left:80px;z-index:5;display:flex;align-items:center;gap:10px;opacity:0;animation:fadeUp .8s 3.8s ease forwards}
.hero-scroll-line{width:36px;height:1px;background:rgba(201,168,76,.36);animation:hsPulse 2.2s 4s ease-in-out infinite}
.hero-scroll span{font-size:7.5px;letter-spacing:4px;text-transform:uppercase;color:var(--dim)}
@keyframes hsPulse{0%,100%{opacity:.22}50%{opacity:.78}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* MARQUEE */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(180deg,#0f0d0b,#14110e);padding:20px 0}
.mq-track{display:inline-flex;gap:68px;animation:mq 38s linear infinite;white-space:nowrap}
.mq-track:hover{animation-play-state:paused}
.mq-item{font-family:var(--serif);font-size:clamp(18px,2vw,24px);font-style:italic;font-weight:400;color:rgba(242,237,227,.7);display:flex;align-items:center;gap:68px;letter-spacing:.02em}
.mq-item::after{content:'✦';font-style:normal;font-size:14px;color:var(--gold);opacity:.95}
@keyframes mq{to{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:120px 80px}
.lbl{display:inline-flex;align-items:center;gap:10px;font-size:8px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.lbl::before{content:'';width:24px;height:1px;background:var(--gold)}
h2.stitle{font-family:var(--serif);font-size:clamp(30px,3.5vw,54px);font-weight:400;line-height:1.08;letter-spacing:-.01em}
h2.stitle em{font-style:italic;color:var(--gold-lt);font-weight:300}
p{font-size:15px}

/* ABOUT */
#about{background:var(--ink2)}
.about-grid{display:grid;grid-template-columns:9fr 11fr;gap:96px;align-items:center;max-width:1280px;margin:0 auto}
.about-img-frame{position:relative}
.about-img-inner{position:relative;overflow:hidden}
.about-img-inner .img-reveal{position:absolute;inset:0;z-index:3;background:linear-gradient(135deg,var(--ink2),rgba(15,14,12,.92));transform-origin:left center}
.about-img-inner::before{content:'';position:absolute;top:-16px;left:-16px;width:48%;height:48%;border-top:1px solid rgba(201,168,76,.2);border-left:1px solid rgba(201,168,76,.2);pointer-events:none;z-index:4}
.about-img-inner::after{content:'';position:absolute;bottom:-16px;right:-16px;width:48%;height:48%;border-bottom:1px solid rgba(201,168,76,.2);border-right:1px solid rgba(201,168,76,.2);pointer-events:none;z-index:4}
.about-img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;display:block;filter:brightness(.88) contrast(1.06);transition:transform 8s ease,filter .5s}
.about-img-inner:hover .about-img{transform:scale(1.03);filter:brightness(.94) contrast(1.04)}
.about-badge{position:absolute;right:-22px;bottom:36px;background:var(--gold);padding:22px 28px;border-radius:4px;text-align:center;min-width:130px;z-index:5}
.about-badge .bn{font-family:var(--serif);font-size:44px;font-weight:400;color:var(--ink);line-height:1}
.about-badge .bl{font-size:7.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink);margin-top:6px}
.about-txt p{font-size:15px;line-height:1.95;color:rgba(242,237,227,.66);margin-top:18px}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:44px;padding-top:32px;border-top:1px solid rgba(201,168,76,.15)}
.stat{padding:0 20px;text-align:center;border-right:1px solid rgba(201,168,76,.15)}
.stat:first-child{padding-left:0}
.stat:last-child{border-right:none}
.stat .sn{font-family:var(--serif);font-size:38px;font-weight:300;color:var(--gold);line-height:1}
.stat .sl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(242,237,227,.5);margin-top:8px}
.about-link{display:inline-flex;align-items:center;gap:12px;margin-top:36px;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);padding-bottom:5px;border-bottom:1px solid rgba(201,168,76,.18);transition:gap .3s,border-color .3s}
.about-link:hover{gap:22px;border-color:var(--gold)}

/* ABOUT INTRO (from about.php) */
.about-intro-section{padding:80px 80px;background:var(--ink)}
.about-intro-grid{display:grid;grid-template-columns:45% 55%;gap:60px;max-width:1100px;margin:0 auto;align-items:center}
.about-intro-img{position:relative;width:100%}
.about-intro-img img{width:100%;height:auto;max-width:420px;border-radius:2px;box-shadow:0 24px 48px rgba(0,0,0,.35)}
.about-intro-badge{position:absolute;bottom:-20px;right:-20px;background:var(--gold);padding:20px 24px;border-radius:4px;text-align:center}
.about-intro-badge .bn{font-family:var(--serif);font-size:32px;font-weight:400;color:var(--ink);line-height:1}
.about-intro-badge .bl{font-size:7px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);margin-top:3px}
.about-intro-txt{padding-top:20px}
.about-intro-txt .lbl{display:inline-flex;align-items:center;gap:12px;font-size:9px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.about-intro-txt .lbl::before{content:'';width:32px;height:1px;background:var(--gold)}
.about-intro-txt h2{font-family:var(--serif);font-size:clamp(26px,3vw,36px);font-weight:400;line-height:1.25;color:var(--parch);margin-bottom:24px}
.about-intro-txt h2 em{font-style:italic;color:var(--gold-lt)}
.about-intro-txt p{font-size:14px;line-height:1.8;color:rgba(242,237,227,.7);margin-bottom:18px;max-width:460px}
.about-intro-txt p:last-child{margin-bottom:0}

.about-stats-section{padding:120px 80px;background:var(--ink2)}
.home-stats-mobile{display:none}
.about-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:60px;max-width:1000px;margin:0 auto;text-align:center;border-top:1px solid rgba(201,168,76,.15);border-bottom:1px solid rgba(201,168,76,.15)}
.about-stat{padding:48px 24px}
.about-stat-n{font-family:var(--serif);font-size:clamp(52px,7vw,72px);font-weight:300;color:var(--gold);line-height:1}
.about-stat-l{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(242,237,227,.5);margin-top:12px}

/* SERVICES */
#services{background:var(--ink)}
.svc-wrap{max-width:1280px;margin:0 auto}
.svc-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;gap:24px}
.svc-hd-r{max-width:320px;font-size:14px;line-height:1.9;color:rgba(242,237,227,.58);text-align:right}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(242,237,227,.08)}
.svc-card{background:linear-gradient(180deg,rgba(12,11,9,.98),rgba(10,9,8,.98));padding:40px 30px 44px;position:relative;overflow:hidden;transition:background .4s,transform .35s var(--ease);min-height:100%}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card:hover{background:linear-gradient(180deg,rgba(26,21,13,.96),rgba(11,10,8,.98));transform:translateY(-4px)}
.svc-n{position:absolute;top:14px;right:16px;font-family:var(--serif);font-size:46px;font-weight:600;color:rgba(242,237,227,.022);line-height:1;user-select:none}
.svc-ico{width:54px;height:54px;border:1px solid rgba(201,168,76,.28);display:flex;align-items:center;justify-content:center;margin-bottom:26px;transition:border-color .3s,background .3s,box-shadow .3s;background:rgba(201,168,76,.05)}
.svc-card:hover .svc-ico{border-color:var(--gold);background:rgba(201,168,76,.07);box-shadow:0 12px 28px rgba(201,168,76,.08)}
.svc-ico svg{width:22px;height:22px;stroke:var(--gold-lt);fill:none;stroke-width:1.6}
.svc-card h3{font-family:var(--serif);font-size:21px;font-weight:400;margin-bottom:12px;transition:color .3s;color:rgba(242,237,227,.96)}
.svc-card:hover h3{color:var(--gold-lt)}
.svc-card p{font-size:14px;line-height:1.9;color:rgba(242,237,227,.7)}

/* PROJECTS (Homepage) */
#projects{background:var(--ink2);padding-bottom:0}
.proj-wrap{max-width:1360px;margin:0 auto}
.proj-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:56px;gap:20px}
.proj-hd-note{font-size:14px;line-height:1.8;color:rgba(242,237,227,.54);text-align:right;max-width:260px}
.proj-gallery-new{display:none;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(3,260px);gap:14px;padding:0 80px;margin-top:18px}
@media(min-width:769px){.proj-gallery-new{display:grid}}
.pgn-card{position:relative;overflow:hidden;cursor:pointer;border-radius:16px;background:var(--ink3);transition:transform .4s var(--ease),box-shadow .4s}
.pgn-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(0,0,0,.35)}
.pgn-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);display:block}
.pgn-card:hover img{transform:scale(1.06)}
.pgn-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.82) 100%);opacity:.7;transition:opacity .3s}
.pgn-card:hover::after{opacity:.85}
.pgn-ov{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:2;opacity:0;transform:translateY(12px);transition:opacity .35s,transform .35s}
.pgn-card:hover .pgn-ov{opacity:1;transform:translateY(0)}
.pgn-ov h4{font-family:var(--serif);font-size:22px;font-weight:400;margin-bottom:4px}
.pgn-ov span{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-lt)}
.pgn-tag{position:absolute;top:14px;left:14px;padding:5px 14px;font-size:7px;letter-spacing:2px;text-transform:uppercase;background:var(--gold);color:var(--ink);z-index:3;border-radius:4px}
.pgn-tag.wip{background:rgba(242,237,227,.12);color:rgba(242,237,227,.6)}
.pgn-card:nth-child(1){grid-column:1/5;grid-row:1/2}
.pgn-card:nth-child(2){grid-column:5/9;grid-row:1/2}
.pgn-card:nth-child(3){grid-column:9/13;grid-row:1/2}
.pgn-card:nth-child(4){grid-column:1/4;grid-row:2/3}
.pgn-card:nth-child(5){grid-column:4/7;grid-row:2/3}
.pgn-card:nth-child(6){grid-column:7/10;grid-row:2/3}
.pgn-card:nth-child(7){grid-column:10/13;grid-row:2/3}
.pgn-card:nth-child(8){grid-column:1/5;grid-row:3/4}
.pgn-card:nth-child(9){grid-column:5/13;grid-row:3/4}

/* Mobile Carousel */
.proj-mobile-carousel{display:none}
@media(max-width:768px){.proj-mobile-carousel{display:block;margin-top:4px}}
.pmc-viewport{overflow:hidden;position:relative;padding:20px 0 30px}
.pmc-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:12px calc((100vw - 74vw)/2) 20px}
.pmc-track::-webkit-scrollbar{display:none}
.pmc-slide{flex:0 0 74vw;max-width:300px;border-radius:20px;overflow:hidden;position:relative;cursor:pointer;height:420px;scroll-snap-align:center;box-shadow:0 10px 28px rgba(0,0,0,.25);transform:scale(0.87);filter:brightness(.76);transition:transform .5s cubic-bezier(.23,1,.32,1),filter .5s cubic-bezier(.23,1,.32,1),box-shadow .5s;-webkit-tap-highlight-color:transparent}
.pmc-slide.pmc-active{transform:scale(1);filter:brightness(1);box-shadow:0 28px 68px rgba(0,0,0,.52)}
.pmc-slide img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.pmc-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 28%,rgba(0,0,0,.9) 100%);z-index:1}
.pmc-info{position:absolute;bottom:0;left:0;right:0;padding:28px 22px;z-index:2;transform:translateY(18px);opacity:0;transition:all .48s cubic-bezier(.23,1,.32,1)}
.pmc-slide.pmc-active .pmc-info{transform:translateY(0);opacity:1;transition-delay:.12s}
.pmc-info h4{font-family:var(--serif);font-size:24px;font-weight:400;margin-bottom:5px}
.pmc-info span{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold-lt)}
.pmc-tag{position:absolute;top:16px;left:16px;padding:5px 14px;font-size:7px;letter-spacing:2px;text-transform:uppercase;background:var(--gold);color:var(--ink);z-index:3;border-radius:4px}
.pmc-controls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:6px;padding:0 22px}
.pmc-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(201,168,76,.38);background:rgba(201,168,76,.06);color:var(--parch);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;flex-shrink:0}
.pmc-btn:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pmc-btn svg{width:19px;height:19px}
.pmc-dots{display:flex;gap:8px;align-items:center}
.pmc-dot{width:6px;height:6px;border-radius:50%;border:1px solid rgba(201,168,76,.45);background:transparent;cursor:pointer;transition:all .35s;padding:0}
.pmc-dot.active{background:var(--gold);border-color:var(--gold);transform:scale(1.5);box-shadow:0 0 10px rgba(201,168,76,.38)}
.pmc-viewall{display:flex;justify-content:center;padding:24px 22px 0}
.pmc-viewall a{display:inline-flex;align-items:center;gap:10px;padding:13px 34px;border:1px solid rgba(201,168,76,.28);font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);position:relative;overflow:hidden;transition:color .4s,border-color .4s}
.pmc-viewall a::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-101%);transition:transform .45s var(--ease)}
.pmc-viewall a:hover{color:var(--ink);border-color:var(--gold)}
.pmc-viewall a:hover::before{transform:translateX(0)}
.pmc-viewall a span{position:relative}

/* CTA Block */
.proj-cta-block{padding:100px 80px 120px;display:flex;flex-direction:column;align-items:center;gap:28px;position:relative;text-align:center}
.proj-cta-block::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;height:64px;background:linear-gradient(to bottom,var(--gold),transparent);opacity:.28}
.proj-cta-label{font-size:8px;letter-spacing:5px;text-transform:uppercase;color:var(--dim)}
.proj-cta-heading{font-family:var(--serif);font-size:clamp(28px,3vw,46px);font-weight:400;color:var(--parch);line-height:1.1}
.proj-cta-heading em{font-style:italic;color:var(--gold-lt);font-weight:300}
.btn-view-all{display:inline-flex;align-items:center;gap:14px;padding:17px 58px;border:1px solid rgba(201,168,76,.32);font-size:9.5px;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold);position:relative;overflow:hidden;transition:color .4s,border-color .4s,transform .3s;margin-top:8px}
.btn-view-all::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-101%);transition:transform .45s var(--ease)}
.btn-view-all:hover{color:var(--ink);border-color:var(--gold);transform:translateY(-2px)}
.btn-view-all:hover::before{transform:translateX(0)}
.btn-view-all span{position:relative}
.btn-view-all .arr{position:relative;transition:transform .3s var(--ease)}
.btn-view-all:hover .arr{transform:translateX(5px)}

/* WHY */
#why{background:var(--ink)}
.why-wrap{max-width:1280px;margin:0 auto}
.why-intro{text-align:center;max-width:560px;margin:0 auto 72px}
.why-intro .lbl{justify-content:center}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.why-card{background:var(--ink);padding:50px 28px;position:relative;overflow:hidden;transition:background .4s}
.why-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.why-card:hover::after{transform:scaleX(1)}
.why-card:hover{background:rgba(201,168,76,.022)}
.wc-num{font-family:var(--serif);font-size:56px;font-weight:600;color:rgba(242,237,227,.022);line-height:1;position:absolute;top:14px;right:18px;user-select:none}
.why-ico{width:48px;height:48px;border-radius:50%;background:rgba(201,168,76,.06);display:flex;align-items:center;justify-content:center;margin-bottom:24px;transition:background .3s}
.why-card:hover .why-ico{background:rgba(201,168,76,.13)}
.why-ico svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.5}
.why-card h3{font-family:var(--serif);font-size:18px;font-weight:400;margin-bottom:12px;transition:color .3s}
.why-card:hover h3{color:var(--gold-lt)}
.why-card p{font-size:11.5px;line-height:1.95;color:rgba(242,237,227,.37)}

/* QUOTE */
#quote{background:var(--ink2);padding:100px 80px;position:relative;overflow:hidden}
#quote::before,#quote::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);opacity:.11}
#quote::before{top:0}
#quote::after{bottom:0}
.quote-in{max-width:700px;margin:0 auto;text-align:center}
.quote-mk{font-family:var(--serif);font-size:100px;line-height:.38;color:var(--gold);opacity:.09;margin-bottom:24px}
.quote-txt{font-family:var(--serif);font-size:clamp(18px,1.9vw,28px);font-weight:300;font-style:italic;line-height:1.75;color:rgba(242,237,227,.73)}
.quote-auth{margin-top:28px;font-size:8px;letter-spacing:5px;text-transform:uppercase;color:var(--gold)}

/* CTA */
#cta{position:relative;padding:140px 80px;text-align:center;overflow:hidden;isolation:isolate}
.cta-parallax-bg{position:absolute;inset:-25%;z-index:0;background-image:url('img/final-projects/8.jpeg');background-size:cover;background-position:center;will-change:transform}
.cta-parallax-ov{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(5,4,3,.94) 0%,rgba(10,8,6,.89) 42%,rgba(9,7,5,.86) 70%,rgba(5,4,3,.93) 100%)}
.cta-parallax-ov::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(201,168,76,.07) 0%,transparent 65%)}
.cta-bg-text{position:absolute;font-family:var(--serif);font-size:clamp(64px,11vw,170px);font-weight:600;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(201,168,76,.038);white-space:nowrap;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;user-select:none;z-index:2}
.cta-in{position:relative;z-index:3;max-width:640px;margin:0 auto}
.cta-in h2{font-family:var(--serif);font-size:clamp(34px,4.2vw,66px);font-weight:400;line-height:1.08}
.cta-in h2 em{font-style:italic;color:var(--gold-lt);font-weight:300}
.cta-in p{font-size:13px;line-height:1.95;color:rgba(242,237,227,.5);margin:20px 0 48px}
.cta-row{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}
.btn-gold{display:inline-flex;align-items:center;gap:10px;padding:15px 48px;background:var(--gold);color:var(--ink);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.btn-gold::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.16);transform:translateX(-101%);transition:transform .42s var(--ease)}
.btn-gold:hover::after{transform:translateX(0)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(201,168,76,.2)}
.cta-phone{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--parch);transition:color .3s}
.cta-phone:hover{color:var(--gold)}

/* FOOTER */
footer{background:linear-gradient(180deg,#080706,#050504);padding:72px 80px 36px;border-top:1px solid var(--line);color:rgba(255,255,255,0.85);font-family:var(--body)}
.ft-grid{display:grid;grid-template-columns:minmax(0,1.7fr) repeat(3,minmax(0,1fr));gap:52px;padding-bottom:56px;border-bottom:1px solid rgba(242,237,227,.1)}
.ft-brand{font-family:var(--body)}
.ft-brand p{font-size:15px;line-height:1.6;color:rgba(255,255,255,0.75);max-width:320px;margin-top:18px}
.ft-brand>img{height:48px;width:auto;margin-bottom:12px;image-rendering:-webkit-optimize-contrast;filter:brightness(1.15) contrast(1.1)}
.ft-socs{display:flex;gap:10px;margin-top:22px}
.ft-soc{width:36px;height:36px;border:1px solid rgba(242,237,227,.14);display:flex;align-items:center;justify-content:center;transition:border-color .3s,color .3s;color:rgba(242,237,227,.8)}
.ft-soc svg{width:18px;height:18px}
.ft-soc:hover{border-color:var(--gold);color:var(--gold)}
.ft-col{font-family:var(--body)}
.ft-col h4{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.ft-col li{margin-bottom:14px}
.ft-col li a{font-size:14px;font-weight:400;color:rgba(255,255,255,0.85);transition:color .3s,padding-left .25s}
.ft-col li a:hover{color:#ffffff;padding-left:6px}
.ft-info{margin-bottom:18px;font-family:var(--body)}
.ft-info .k{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-bottom:6px}
.ft-info a,.ft-info p{font-size:14px;font-weight:400;color:rgba(255,255,255,0.8);transition:color .3s}
.ft-info a:hover{color:var(--gold)}
.ft-bot{display:flex;justify-content:space-between;align-items:center;padding-top:28px;gap:10px;flex-wrap:wrap;font-family:var(--body)}
.ft-bot p{font-size:14px;font-weight:400;color:rgba(255,255,255,0.75)}
.ft-bot p a{color:#d4af37;text-decoration:none;font-weight:500}
.ft-bot p a:hover{color:#ffffff}
.ft-bot .script-tag{font-family:'Libre Baskerville',Georgia,serif;font-style:italic;font-size:14px;color:rgba(212,175,55,0.85)}
.wa-stick{position:fixed;right:22px;bottom:24px;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(180deg,#25d366,#1eb757);color:#fff;box-shadow:0 14px 34px rgba(0,0,0,.28);z-index:820;transition:transform .3s var(--ease),box-shadow .3s}
.wa-stick::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(37,211,102,.18)}
.wa-stick:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 20px 44px rgba(0,0,0,.4)}
.wa-stick svg{width:24px;height:24px}

/* LIGHTBOX */
#lb{display:none;position:fixed;inset:0;background:rgba(4,4,3,.97);z-index:9800;align-items:center;justify-content:center}
#lb.on{display:flex}
#lb img{max-width:90vw;max-height:88vh;object-fit:contain;animation:lbIn .4s var(--ease)}
@keyframes lbIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
#lb-x{position:absolute;top:24px;right:30px;font-size:20px;color:rgba(242,237,227,.28);cursor:pointer;transition:color .25s}
#lb-x:hover{color:var(--gold)}

/* RESPONSIVE */
@media(max-width:1100px){
  section{padding:88px 44px}
  header{padding:22px 44px}
  header.stuck{padding:14px 44px}
  .about-grid{gap:52px;grid-template-columns:1fr 1fr}
  .about-badge{right:-8px;bottom:-16px;padding:16px 20px}
  .about-badge .bn{font-size:28px}
  .about-badge .bl{font-size:6px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr;gap:36px}
  footer{padding:60px 44px 30px}
  .proj-gallery-new{padding:0 44px;grid-template-rows:repeat(3,230px)}
  .proj-cta-block{padding:80px 44px 100px}
  .proj-wrap{padding:0}
}
@media(max-width:992px){
  .about-intro-img{position:relative;width:100%;border:none;border-bottom:1px solid rgba(201,168,76,.15);border-right:1px solid rgba(201,168,76,.15);padding:12px 12px 0 0;margin-bottom:12px;box-shadow:12px 12px 24px rgba(0,0,0,.2)}
}
@media(max-width:768px){
  header{padding:20px 22px;font-family:var(--body)}
  header.stuck{padding:14px 22px}
  section{padding:68px 22px}
  nav,.hd-cta{display:none}
  .burg{display:flex}
  .about-intro-section{padding:50px 20px;overflow:hidden}
  .about-intro-grid{grid-template-columns:45% 55%;gap:16px;align-items:center;max-width:100%;overflow:hidden}
  .about-intro-img{position:relative;width:100%}
  .about-intro-img img{width:100%;height:auto;max-height:250px;object-fit:contain;border-radius:4px}
  .about-intro-badge{position:absolute;bottom:8px;right:8px;padding:12px 14px}
  .about-intro-badge .bn{font-size:24px;color:var(--ink)}
  .about-intro-badge .bl{font-size:6px;color:var(--ink);letter-spacing:1px;text-transform:uppercase}
  .about-intro-txt{padding-left:8px;overflow:hidden}
  .about-intro-txt .lbl{font-size:7px;margin-bottom:10px}
  .about-intro-txt h2{font-size:clamp(18px,5vw,24px);margin-bottom:12px;line-height:1.3}
  .about-intro-txt h2 br{display:none}
  .about-intro-txt p{font-size:11px;line-height:1.5;margin-bottom:10px;max-width:100%;overflow:hidden}
  .about-intro-txt p:last-child{display:none}
  .about-stats-section{padding:40px 20px}
  .about-stats-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .about-stat{padding:20px 8px;text-align:center}
  .about-stat-n{font-family:var(--serif);font-size:clamp(28px,6vw,36px);font-weight:300;color:var(--gold);line-height:1}
  .about-stat-l{font-size:8px;letter-spacing:1px;text-transform:uppercase;color:rgba(242,237,227,.5)}
  .home-stats-mobile{display:block}
  .about-link{margin-top:20px}
  .svc-grid,.why-grid{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:24px 16px}
  .ft-brand{grid-column:1/-1;font-family:var(--body)}
  .ft-brand p{font-size:14px;line-height:1.6}
  .ft-brand>img{height:44px;width:auto;margin-bottom:10px;filter:brightness(1.3) contrast(1.4)}
  .ft-col{font-family:var(--body)}
  .ft-col h4{font-size:10px;letter-spacing:1.5px}
  .ft-col li a{font-size:13px}
  .ft-info{font-family:var(--body)}
  .ft-info .k{font-size:10px;letter-spacing:1px}
  .ft-info a,.ft-info p{font-size:13px}
  .ft-bot{flex-direction:column;gap:8px;text-align:center;font-family:var(--body)}
  .ft-bot p{font-size:13px}
  .ft-bot .script-tag{font-size:13px}
  footer{padding:52px 22px 28px;font-family:var(--body)}
  .svc-hd{flex-direction:column;gap:12px}
  .svc-hd-r{text-align:left;max-width:100%}
  .proj-hd{flex-direction:column;align-items:flex-start;gap:14px}
  .proj-hd-note{display:none}
  .cta-row{flex-direction:column}
  #cta{padding:80px 22px}
  #quote{padding:68px 22px}
  .hd-logo-mark{height:40px;width:auto;max-width:140px;object-fit:contain;filter:brightness(1.3) contrast(1.4);image-rendering:-webkit-optimize-contrast}
  .hero-scroll{left:22px;bottom:16px}
  .proj-gallery-new{display:none!important}
  .proj-cta-block{display:none}
  #hero{grid-template-columns:1fr;height:88svh;min-height:520px;max-height:700px;display:flex;flex-direction:column}
  #hero::before{background:linear-gradient(180deg,rgba(6,5,4,.75) 0%,rgba(6,5,4,.55) 28%,rgba(6,5,4,.6) 55%,rgba(6,5,4,.92) 100%)}
  #hero::after{background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.1) 28%,rgba(0,0,0,.18) 55%,rgba(0,0,0,.6) 100%)}
  .hero-left{position:relative;z-index:4;justify-content:flex-end;padding:0 20px 40px;background:none;flex:1;min-height:0}
  .hero-left::after,.hero-left::before{display:none}
  .hero-right{position:absolute;inset:0;z-index:1;min-height:0;pointer-events:none}
  .hero-right-ov{background:linear-gradient(180deg,rgba(0,0,0,.52) 0%,rgba(0,0,0,.28) 30%,rgba(0,0,0,.48) 60%,rgba(0,0,0,.92) 100%),linear-gradient(90deg,rgba(0,0,0,.3) 0%,rgba(0,0,0,.06) 42%,rgba(0,0,0,.25) 100%)}
  .hero-watermark{display:none}
  .hero-scroll{left:20px;bottom:18px}
  .hero-stats{display:none!important}
  .hero-h1{font-size:clamp(36px,10vw,52px);line-height:1;margin-bottom:14px}
  .hero-h1 br{display:none}
  .hero-sub{font-size:14px;line-height:1.7;max-width:100%;color:rgba(242,237,227,.86);text-shadow:0 2px 14px rgba(0,0,0,.55)}
  .hero-eyebrow{color:var(--gold-lt);margin-bottom:14px}
  .hero-btn-main{width:100%;justify-content:center;font-size:10px;letter-spacing:3.2px;padding:14px 28px}
  .hero-btn-ghost{color:var(--parch);border-color:rgba(242,237,227,.38)}
  .hero-divider{margin:16px 0 14px}
  .hero-actions{margin-top:22px;gap:14px;flex-direction:column}
  .hero-counter{bottom:20px;right:20px}
}
@media(max-width:480px){
  .svc-grid,.why-grid{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:24px 16px}
  .ft-brand{grid-column:1/-1}
  .ft-brand p{max-width:100%}
  .ft-col{padding:0}
  .ft-col h4{margin-bottom:16px}
  .ft-col li{margin-bottom:12px}
  .ft-col li a{font-size:14px}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:16px}
  .wa-stick{width:52px;height:52px;right:16px;bottom:16px}
  .pmc-slide{flex:0 0 82vw;height:370px}
  .pmc-track{padding:12px calc((100vw - 82vw)/2) 20px}
}