*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
:root{
  --black:#111111;--off-white:#F7F6F3;--gray:#6B7A8D;
  --mid:#BBBBBB;--white:#FFFFFF;--dark:#0A0A0A;
  --display:'Cormorant Garamond',serif;--body:'DM Sans',sans-serif;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
}
body{font-family:var(--body);background:var(--off-white);color:var(--black);overflow-x:hidden;cursor:none}

/* CURSOR */
.cursor{position:fixed;width:7px;height:7px;background:var(--black);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s}
.cursor-f{position:fixed;width:28px;height:28px;border:1px solid rgba(0,0,0,.35);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s}
.cursor.h{width:4px;height:4px;background:var(--gray)}
.cursor-f.h{width:44px;height:44px;opacity:.3}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:1.4rem 4rem;display:flex;justify-content:space-between;align-items:center;transition:all .5s var(--ease)}
nav.solid{background:rgba(247,246,243,.96);backdrop-filter:blur(16px);padding:1rem 4rem;border-bottom:1px solid rgba(0,0,0,.06)}
.nav-logo img{height:48px;width:auto;display:block}
.nav-links{display:flex;gap:2.5rem;list-style:none;align-items:center}
.nav-links a{font-size:.75rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--black);text-decoration:none;opacity:.5;transition:opacity .2s}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-cta{border:1px solid var(--black)!important;padding:.5rem 1.3rem;border-radius:1px;opacity:1!important;font-size:.72rem!important;transition:all .3s!important}
.nav-cta:hover{background:var(--black)!important;color:var(--white)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer}
.hamburger span{display:block;width:22px;height:1px;background:var(--black);transition:all .3s}

/* MOBILE MENU */
.mob-menu{display:none;position:fixed;inset:0;background:var(--dark);z-index:490;flex-direction:column;justify-content:center;align-items:center;gap:0}
.mob-menu.open{display:flex}
.mob-menu-item{width:100%;text-align:center;padding:1.4rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.mob-menu-item:first-of-type{border-top:1px solid rgba(255,255,255,.06)}
.mob-menu a{font-family:var(--display);font-size:2.8rem;font-weight:300;color:var(--white);text-decoration:none;letter-spacing:.04em;opacity:.75;transition:opacity .2s;display:inline-block}
.mob-menu a:hover{opacity:1}
.mob-close{position:absolute;top:2rem;right:2.5rem;background:none;border:none;color:rgba(255,255,255,.45);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;font-family:var(--body);transition:color .2s}
.mob-close:hover{color:var(--white)}
.mob-logo{margin-bottom:3rem}
.mob-logo img{height:40px;filter:brightness(10);opacity:.7}

/* HERO */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:8rem 4rem 6rem;position:relative;z-index:2}
.hero-eyebrow{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray);margin-bottom:2rem;opacity:0;transform:translateY(16px);animation:fadeUp .8s var(--ease) .2s forwards}
.hero-title{font-family:var(--display);font-size:clamp(3rem,4.5vw,5.5rem);font-weight:300;line-height:1.1;color:var(--black);margin-bottom:2rem;opacity:0;transform:translateY(24px);animation:fadeUp .9s var(--ease) .35s forwards}
.hero-title em{font-style:italic;display:block}
.hero-sub{font-size:.95rem;line-height:1.8;color:var(--gray);max-width:400px;opacity:0;transform:translateY(16px);animation:fadeUp .9s var(--ease) .55s forwards}
.hero-right{background:var(--dark);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-right-inner{display:flex;align-items:center;justify-content:center;padding:4rem;width:100%}
.hero-wordmark{width:clamp(180px,58%,310px);height:auto;opacity:.9;animation:float 9s ease-in-out infinite}
.hero-scroll{position:absolute;bottom:2.5rem;left:4rem;display:flex;align-items:center;gap:.8rem;opacity:0;animation:fadeUp .9s var(--ease) .9s forwards}
.scroll-line{width:36px;height:1px;background:rgba(0,0,0,.2);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--black);animation:scrollLine 2.5s ease-in-out infinite 2s}
.hero-scroll span{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray)}

/* MARQUEE */
.mq-strip{background:var(--black);padding:.85rem 0;overflow:hidden;white-space:nowrap}
.mq-track{display:inline-flex;animation:marquee 22s linear infinite}
.mq-item{font-family:var(--display);font-size:.85rem;font-style:italic;color:rgba(255,255,255,.4);letter-spacing:.08em;padding:0 2rem}
.mq-dot{color:rgba(255,255,255,.18)}

/* COMMON */
section{padding:6rem 0}
.container{max-width:1100px;margin:0 auto;padding:0 4rem}
.sec-label{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gray);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}
.sec-label::before{content:'';display:block;width:20px;height:1px;background:var(--mid)}

/* PAGE TOP — padding for inner pages so content clears the fixed nav */
.page-top{padding-top:8rem}

/* ABOUT */
#about{background:var(--white)}
.about-inner{max-width:700px}
.about-heading{font-family:var(--display);font-size:clamp(2.4rem,3.5vw,3.8rem);font-weight:300;line-height:1.15;margin-bottom:2rem;color:var(--black)}
.about-heading em{font-style:italic}
.about-p{font-size:.97rem;line-height:1.9;color:var(--gray);margin-bottom:1.1rem}
.about-sig{font-family:var(--display);font-size:1.4rem;font-style:italic;color:var(--black);margin-top:2rem}

/* BUTTONS */
.btn-p{background:var(--black);color:var(--white);padding:.85rem 2rem;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;font-family:var(--body);border:1px solid var(--black);border-radius:1px;transition:all .3s var(--ease);display:inline-block}
.btn-p:hover{background:transparent;color:var(--black)}
.btn-s{color:var(--black);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;font-family:var(--body);display:flex;align-items:center;gap:.5rem;transition:gap .3s}
.btn-s:hover{gap:.9rem}

/* SERVICES */
#services{background:var(--off-white)}
.svc-heading{font-family:var(--display);font-size:clamp(2.2rem,3.2vw,3.5rem);font-weight:300;line-height:1.15;color:var(--black);margin-bottom:1rem}
.svc-heading em{font-style:italic}
.svc-intro-row{display:grid;grid-template-columns:1fr auto;align-items:end;gap:3rem;margin-bottom:4rem}
.svc-intro-text{font-size:.95rem;line-height:1.8;color:var(--gray);max-width:500px}
.svc-cta{display:flex;gap:1.25rem;align-items:center;flex-shrink:0}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#E0E0E0;border:1px solid #E0E0E0}
.svc-card{background:var(--white);padding:2.5rem 2rem;position:relative;overflow:hidden;transition:background .4s var(--ease);cursor:default}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--black);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.svc-card:hover{background:var(--black)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-card:hover .svc-num,.svc-card:hover .svc-title,.svc-card:hover .svc-desc{color:var(--white)}
.svc-card:hover .svc-tag{border-color:rgba(255,255,255,.15);color:rgba(255,255,255,.5)}
.svc-num{font-family:var(--display);font-size:.8rem;color:var(--mid);margin-bottom:2rem;letter-spacing:.1em;transition:color .4s}
.svc-title{font-family:var(--display);font-size:1.5rem;font-weight:400;color:var(--black);line-height:1.2;margin-bottom:1rem;transition:color .4s}
.svc-desc{font-size:.85rem;line-height:1.75;color:var(--gray);margin-bottom:1.5rem;transition:color .4s}
.svc-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.svc-tag{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gray);border:1px solid #DDD;padding:.2rem .55rem;border-radius:50px;transition:all .4s}

/* PRICING */
/* PRICING */
#pricing{background:var(--off-white);position:relative;overflow:hidden}
.price-header{text-align:center;margin-bottom:4rem}
.price-header .sec-label{justify-content:center}
.price-h{font-family:var(--display);font-size:clamp(2.2rem,3.5vw,3.5rem);font-weight:300;color:var(--black);margin-bottom:1rem}
.price-h em{font-style:italic;color:var(--gray)}
.price-sub{font-size:.9rem;color:var(--gray);line-height:1.7;max-width:460px;margin:0 auto}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#E0E0E0;border:1px solid #E0E0E0;margin-bottom:2rem}
.price-card{background:var(--white);padding:2.5rem;position:relative;transition:background .4s}
.price-card:hover{background:#F9F9F9}
.price-card.feat{background:#FAFAFA}
.feat-badge{display:inline-block;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;border:1px solid #DDD;color:var(--gray);padding:.25rem .8rem;border-radius:50px;margin-bottom:1.25rem}
.price-tier{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);margin-bottom:.5rem}
.price-amt{font-family:var(--display);font-size:2.8rem;font-weight:300;color:var(--black);line-height:1;margin-bottom:.2rem}
.price-amt sup{font-size:1.2rem;vertical-align:top;margin-top:.5rem;display:inline-block}
.price-amt span{color:var(--mid)!important} /* Overrides the inline HTML style */
.price-period{font-size:.75rem;color:var(--gray);margin-bottom:.25rem}
.price-hours{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #E0E0E0}
.price-feats{list-style:none;margin-bottom:1.5rem}
.price-feats li{font-size:.83rem;color:var(--gray);padding:.45rem 0;border-bottom:1px solid #E0E0E0;display:flex;align-items:flex-start;gap:.6rem;line-height:1.4}
.price-feats li::before{content:'—';color:var(--mid);flex-shrink:0;font-size:.72rem;margin-top:1px}
.price-best{font-size:.75rem;color:var(--gray);font-style:italic;line-height:1.5}
.price-note{text-align:center;font-size:.8rem;color:var(--gray);font-style:italic;margin-bottom:3rem}
.price-note a{color:var(--black)}
.proj-rates{border-top:1px solid #E0E0E0;padding-top:3rem}
.proj-title{font-family:var(--display);font-size:1.1rem;font-style:italic;color:var(--black);margin-bottom:2rem;text-align:center}
.rates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#E0E0E0}
.rate-item{background:var(--white);padding:1.5rem;text-align:center;transition:background .3s}
.rate-item:hover{background:#F9F9F9}
.rate-name{font-size:.75rem;color:var(--gray);margin-bottom:.5rem;line-height:1.4}
.rate-price{font-family:var(--display);font-size:1.4rem;color:var(--black);font-weight:300}

/* CONTACT */
#contact{background:var(--off-white);position:relative;overflow:hidden}
#contact::before{content:'';position:absolute;top:0;right:0;width:38%;height:100%;background:var(--black);clip-path:polygon(18% 0,100% 0,100% 100%,0% 100%)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;position:relative;z-index:2}
.contact-h{font-family:var(--display);font-size:clamp(2.2rem,3.5vw,3.5rem);font-weight:300;color:var(--black);line-height:1.15;margin-bottom:1.5rem}
.contact-h em{font-style:italic}
.contact-p{font-size:.93rem;line-height:1.8;color:var(--gray);margin-bottom:2.5rem}
.contact-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.1rem;font-size:.88rem;color:var(--black)}
.ci-label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray);min-width:72px;margin-top:2px}
.contact-item a{color:var(--black);text-decoration:none;transition:opacity .2s}
.contact-item a:hover{opacity:.6}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray);margin-bottom:.6rem}
.form-group input,.form-group select,.form-group textarea{width:100%;background:transparent;border:none;border-bottom:1px solid #CCC;padding:.75rem 0;font-family:var(--body);font-size:.93rem;color:var(--black);outline:none;transition:border-color .3s;-webkit-appearance:none;border-radius:0}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--black)}
.form-group textarea{resize:none;height:90px}
.form-group select option{background:var(--off-white);color:var(--black)}
.form-submit{background:var(--black);color:var(--white);border:none;padding:1rem 2.5rem;font-family:var(--body);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border-radius:1px;transition:background .3s;width:100%;margin-top:.5rem}
.form-submit:hover{background:#333}
.form-note{font-size:.72rem;color:var(--gray);text-align:center;margin-top:1rem;font-style:italic}

/* FOOTER */
footer{background:var(--dark);padding:2.5rem 0}
.footer-inner{max-width:1100px;margin:0 auto;padding:0 4rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}
.footer-wordmark{height:26px;width:auto;filter:brightness(10);opacity:.45}
.footer-links{display:flex;gap:2rem;list-style:none}
.footer-links a{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:rgba(255,255,255,.7)}
.footer-copy{font-size:.68rem;color:rgba(255,255,255,.18)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* ANIMATIONS */
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(-.5deg)}50%{transform:translateY(-14px) rotate(.5deg)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes scrollLine{0%{left:-100%}100%{left:100%}}

/* RESPONSIVE */
@media(max-width:900px){
  nav{padding:1.25rem 2rem}nav.solid{padding:.9rem 2rem}
  .nav-links{display:none}.hamburger{display:flex}
  #hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:7rem 2rem 3rem}.hero-right{min-height:260px}
  .hero-scroll{left:2rem}
  .svc-intro-row{grid-template-columns:1fr;gap:1.5rem}
  .svc-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}.rates-grid{grid-template-columns:1fr}
  #contact::before{display:none}
  .contact-grid{grid-template-columns:1fr;gap:3rem}
  .container{padding:0 2rem}section{padding:4rem 0}
  .page-top{padding-top:6rem}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
}
@media(max-width:560px){
  .svc-cta{flex-direction:column;align-items:flex-start}
}
