@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

:root {
  --bg: #FAFAF8; --bg2: #F4F1EB; --bg3: #EDE9DF;
  --white: #FFFFFF; --ink: #111118; --dark: #1C1C28;
  --soft: #5A5A6A; --mute: #9898A8;
  --gold: #B8820A; --gold2: #D4A017; --gold3: #E8BC48;
  --gold-bg: rgba(184,130,10,0.09); --gold-line: rgba(184,130,10,0.28);
  --gold-glow: rgba(184,130,10,0.18);
  --cyan: #0891B2; --green: #16A34A;
  --line: rgba(0,0,0,0.07); --line2: rgba(0,0,0,0.13);
  --card: #FFFFFF; --card-border: rgba(0,0,0,0.08);
  --grad: linear-gradient(135deg,#B8820A,#D4A017,#E8BC48,#D4A017,#B8820A);
  --grad-short: linear-gradient(135deg,#B8820A,#D4A017);
  --shadow: 0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg: 0 16px 60px rgba(0,0,0,0.13);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden;cursor:none;}
img{max-width:100%;display:block;} a{color:inherit;text-decoration:none;}

/* CURSOR */
#cdot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;width:8px;height:8px;background:var(--gold2);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s;}
#cring{position:fixed;top:0;left:0;z-index:9998;pointer-events:none;width:34px;height:34px;border:1.5px solid rgba(184,130,10,.4);border-radius:50%;transform:translate(-50%,-50%);transition:left .1s ease-out,top .1s ease-out,width .3s,height .3s;}
body:has(a:hover) #cdot,body:has(button:hover) #cdot{width:16px;height:16px;background:var(--cyan);}
body:has(a:hover) #cring,body:has(button:hover) #cring{width:50px;height:50px;}

/* LOADER */
#loader{position:fixed;inset:0;background:var(--white);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity .7s,visibility .7s;}
#loader.out{opacity:0;visibility:hidden;}
.ld-logo-img{height:90px;object-fit:contain;}
.ld-sub{font-family:'Space Mono',monospace;font-size:.65rem;letter-spacing:4px;color:var(--mute);text-transform:uppercase;}
.ld-bar{width:200px;height:2px;background:rgba(184,130,10,.15);overflow:hidden;}
.ld-prog{height:100%;width:0;background:var(--grad-short);animation:ldAnim 1.8s cubic-bezier(.4,0,.2,1) forwards;}
@keyframes ldAnim{to{width:100%;}}
.ld-pct{font-family:'Space Mono',monospace;font-size:.7rem;color:var(--gold);letter-spacing:2px;}

/* TOP BAR — ALWAYS VISIBLE / PINNED */
#topbar{
  background:var(--dark);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:9px 64px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:.75rem;
  position:fixed;top:0;left:0;right:0;z-index:1001;
}
.tb-left{display:flex;align-items:center;gap:28px;}
.tb-item{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.55);}
.tb-item strong{color:var(--gold3);}
.tb-item svg{width:13px;height:13px;fill:var(--gold2);flex-shrink:0;}
.tb-right{display:flex;align-items:center;gap:16px;}
.tb-social{display:flex;gap:8px;}
.tb-social a{width:26px;height:26px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);font-size:.65rem;font-family:'Space Mono',monospace;transition:all .3s;border-radius:3px;}
.tb-social a:hover{background:var(--gold-bg);border-color:var(--gold);color:var(--gold3);}

/* NAVBAR — sits below topbar always */
#nav{
  position:fixed;top:42px;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 48px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);
  box-shadow:0 2px 16px rgba(0,0,0,.06);
  transition:padding .3s;
}
.nav-logo{display:flex;align-items:center;gap:14px;}
.nav-logo-img{height:76px;width:auto;object-fit:contain;}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;letter-spacing:1px;color:var(--ink);line-height:1.1;}
.nav-logo-text em{font-style:normal;color:var(--gold);font-weight:400;display:block;font-size:1rem;}
.nl{display:flex;align-items:center;gap:28px;list-style:none;}
.nl a{font-size:.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--soft);transition:color .3s;position:relative;padding-bottom:3px;}
.nl a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--grad-short);transition:width .35s;}
.nl a:hover{color:var(--ink);}
.nl a:hover::after{width:100%;}
.nav-cta{background:var(--dark);color:#fff!important;padding:9px 22px;font-weight:700!important;font-size:.75rem!important;letter-spacing:1px!important;border-radius:4px;transition:all .3s!important;}
.nav-cta::after{display:none!important;}
.nav-cta:hover{background:var(--gold);box-shadow:0 6px 24px rgba(184,130,10,.4);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1002;}
.hamburger span{width:24px;height:1.5px;background:var(--ink);display:block;transition:all .3s;}

#btop{position:fixed;bottom:28px;right:28px;z-index:500;width:44px;height:44px;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;border-radius:4px;}
#btop.show{opacity:1;pointer-events:all;}
#btop:hover{background:var(--gold);transform:translateY(-4px);}

/* LAYOUT */
.sec{padding:96px 64px;position:relative;}
.sec-alt{background:var(--bg2);}
.container{max-width:1260px;margin:0 auto;}
.tag{display:inline-flex;align-items:center;gap:8px;font-family:'Space Mono',monospace;font-size:.68rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.tag::before,.tag::after{content:'';width:20px;height:1px;background:var(--gold-line);}
.h1{font-family:'Playfair Display',serif;font-size:clamp(2.8rem,5vw,5rem);font-weight:900;line-height:1.06;color:var(--ink);}
.h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.8vw,3.4rem);font-weight:900;line-height:1.1;color:var(--ink);}
.accent{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.lead{font-size:1rem;line-height:1.85;color:var(--soft);}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Plus Jakarta Sans',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:14px 28px;border:none;cursor:pointer;transition:all .3s;border-radius:4px;}
.btn-dark{background:var(--dark);color:#fff;}
.btn-dark:hover{background:var(--gold);box-shadow:0 8px 28px rgba(184,130,10,.4);transform:translateY(-2px);}
.btn-gold{background:var(--grad-short);color:#fff;}
.btn-gold:hover{box-shadow:0 8px 28px rgba(184,130,10,.4);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--line2);}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}
.divider{height:1px;background:var(--line);margin:0 64px;}
.rv{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.rv.in{opacity:1;transform:translateY(0);}
.rv-l{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease;}
.rv-l.in{opacity:1;transform:translateX(0);}
.rv-r{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease;}
.rv-r.in{opacity:1;transform:translateX(0);}

/* HERO */
#hero{min-height:100vh;padding:160px 64px 80px;position:relative;overflow:hidden;background:var(--bg);display:flex;align-items:center;}
.hero-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1260px;margin:0 auto;width:100%;}
.hero-left{position:relative;z-index:2;}
.hero-kicker{display:inline-flex;align-items:center;gap:8px;background:var(--dark);color:var(--gold3);padding:7px 16px;border-radius:100px;margin-bottom:24px;font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;}
.hero-kicker::before{content:'';width:6px;height:6px;background:var(--green);border-radius:50%;box-shadow:0 0 8px var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.6)}}
.hero-title{margin-bottom:20px;}
.hero-sub{max-width:500px;margin-bottom:36px;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px;}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1.5px solid var(--line);border-radius:8px;overflow:hidden;}
.hs{padding:20px 24px;border-right:1.5px solid var(--line);background:var(--white);}
.hs:last-child{border-right:none;}
.hs-n{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:900;color:var(--gold);line-height:1;}
.hs-l{font-size:.7rem;color:var(--mute);letter-spacing:1px;text-transform:uppercase;margin-top:4px;font-family:'Space Mono',monospace;}
.hero-right-imgs{position:relative;height:560px;}
.hi-main{position:absolute;top:0;right:0;width:90%;height:340px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow-lg);border:3px solid var(--white);}
.hi-s1{position:absolute;bottom:0;left:0;width:48%;height:210px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow-lg);border:3px solid var(--white);}
.hi-s2{position:absolute;bottom:16px;right:4%;width:45%;height:200px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow-lg);border:3px solid var(--white);}
.hero-badge-float{position:absolute;top:24px;left:0;background:var(--white);border:1.5px solid var(--line);border-radius:8px;padding:14px 18px;box-shadow:var(--shadow);z-index:10;}
.hbf-label{font-family:'Space Mono',monospace;font-size:.6rem;color:var(--mute);letter-spacing:1.5px;text-transform:uppercase;}
.hbf-val{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--gold);margin-top:2px;}
.hero-live-dot{position:absolute;bottom:222px;right:2%;background:var(--dark);color:#fff;border-radius:100px;padding:6px 14px;display:flex;align-items:center;gap:7px;font-family:'Space Mono',monospace;font-size:.62rem;letter-spacing:1px;z-index:10;box-shadow:var(--shadow);}
.hero-live-dot::before{content:'';width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}

/* MARQUEE */
.mq-wrap{overflow:hidden;padding:14px 0;background:var(--dark);}
.mq-track{display:flex;gap:48px;width:max-content;animation:mq 28s linear infinite;}
.mq-item{white-space:nowrap;font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:2.5px;color:rgba(255,255,255,.35);text-transform:uppercase;display:flex;align-items:center;gap:14px;}
.mq-item::after{content:'◆';color:var(--gold3);font-size:.5rem;}
@keyframes mq{to{transform:translateX(-50%);}}

/* SERVICES — with images */
#services{background:var(--bg2);}
.srv-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px;flex-wrap:wrap;gap:20px;}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.sc{background:var(--white);border:1.5px solid var(--card-border);overflow:hidden;position:relative;transition:all .4s;cursor:pointer;border-radius:8px;}
.sc::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad-short);transform:scaleX(0);transform-origin:left;transition:transform .45s;z-index:2;}
.sc:hover{border-color:var(--gold-line);transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.sc:hover::before{transform:scaleX(1);}
.sc-img{width:100%;height:220px;object-fit:cover;object-position:center center;transition:transform .5s;}
.sc:hover .sc-img{transform:scale(1.04);}
.sc-body{padding:22px 28px 28px;}
.sc-n{position:absolute;top:180px;right:18px;font-family:'Playfair Display',serif;font-size:3rem;font-weight:900;color:rgba(184,130,10,.06);line-height:1;pointer-events:none;}
.sc-ico{width:44px;height:44px;background:var(--gold-bg);border:1.5px solid var(--gold-line);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:14px;border-radius:6px;transition:background .3s;}
.sc:hover .sc-ico{background:rgba(184,130,10,.2);}
.sc h3{font-size:.95rem;font-weight:700;margin-bottom:9px;color:var(--ink);}
.sc p{font-size:.84rem;color:var(--soft);line-height:1.75;}
.sc-arr{position:absolute;bottom:20px;right:20px;color:var(--gold);opacity:0;transform:translateX(-8px);transition:all .35s;}
.sc:hover .sc-arr{opacity:1;transform:translateX(0);}

/* ABOUT */
#about{background:var(--bg);}
.about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-vis{position:relative;height:480px;}
.am{width:80%;height:370px;object-fit:cover;object-position:top;border-radius:8px;box-shadow:var(--shadow-lg);border:3px solid var(--white);}
.aa{position:absolute;bottom:-10px;right:0;width:55%;height:250px;object-fit:cover;object-position:top;border-radius:8px;box-shadow:var(--shadow-lg);border:3px solid var(--white);}
.about-badge{position:absolute;top:24px;right:12px;background:var(--grad-short);color:#fff;padding:18px 22px;text-align:center;border-radius:6px;box-shadow:var(--shadow);}
.ab-n{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:900;display:block;line-height:1;}
.ab-l{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:4px;opacity:.85;}
.afs{display:flex;flex-direction:column;gap:12px;margin-top:28px;}
.af{display:flex;gap:14px;padding:18px 20px;background:var(--white);border:1.5px solid var(--card-border);transition:all .3s;border-radius:6px;}
.af:hover{border-color:var(--gold-line);box-shadow:var(--shadow);}
.af-ico{width:40px;height:40px;flex-shrink:0;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-size:1.05rem;border-radius:6px;}
.af h4{font-weight:700;font-size:.9rem;margin-bottom:3px;color:var(--ink);}
.af p{font-size:.82rem;color:var(--soft);line-height:1.6;}

/* CEO */
.ceo-wrap{display:grid;grid-template-columns:420px 1fr;gap:72px;align-items:center;}
.ceo-img-wrap{position:relative;}
.ceo-img{width:100%;height:520px;object-fit:cover;object-position:top center;border-radius:10px;box-shadow:var(--shadow-lg);}
.ceo-badge{position:absolute;bottom:28px;left:-20px;background:var(--dark);color:#fff;padding:18px 24px;border-radius:8px;box-shadow:var(--shadow-lg);}
.ceo-badge-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--gold3);}
.ceo-badge-title{font-size:.75rem;color:rgba(255,255,255,.55);margin-top:4px;font-family:'Space Mono',monospace;letter-spacing:1px;text-transform:uppercase;}
.ceo-badge-line{display:flex;align-items:center;gap:8px;margin-top:10px;}
.ceo-badge-dot{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}
.ceo-badge-status{font-size:.72rem;color:rgba(255,255,255,.4);}

/* PORTFOLIO */
#work{background:var(--bg2);}
.wh{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;flex-wrap:wrap;gap:20px;}
.filter-row{display:flex;gap:8px;flex-wrap:wrap;}
.fb{padding:7px 18px;background:var(--white);border:1.5px solid var(--card-border);color:var(--soft);font-family:'Plus Jakarta Sans',sans-serif;font-size:.74rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .3s;border-radius:4px;}
.fb.on,.fb:hover{background:var(--dark);border-color:var(--dark);color:#fff;}
.work-4{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.work-more{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px;}
.wp{position:relative;overflow:hidden;cursor:pointer;border-radius:8px;border:1.5px solid var(--card-border);transition:all .4s;box-shadow:var(--shadow);background:var(--white);}
.wp:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--gold-line);}
.wp-img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:top center;transition:transform .7s;}
.wp:hover .wp-img{transform:scale(1.04);}
.wp-sm .wp-img{aspect-ratio:4/3;}
.wp-info{padding:18px 20px 22px;}
.wp-cat-badge{display:inline-flex;align-items:center;gap:6px;background:var(--gold-bg);color:var(--gold);font-family:'Space Mono',monospace;font-size:.6rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:100px;margin-bottom:8px;}
.wp-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:4px;}
.wp-sub{font-size:.78rem;color:var(--soft);font-family:'Space Mono',monospace;letter-spacing:.5px;}
.wp-live{display:inline-flex;align-items:center;gap:5px;background:rgba(22,163,74,.1);color:var(--green);border:1px solid rgba(22,163,74,.25);font-size:.6rem;font-weight:700;font-family:'Space Mono',monospace;letter-spacing:1.5px;padding:3px 10px;border-radius:100px;}
.wp-live::before{content:'';width:5px;height:5px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}
.wp-url{display:block;margin-top:6px;font-size:.75rem;color:var(--cyan);font-weight:600;}
.wp-url:hover{text-decoration:underline;}

/* PROCESS */
#process{background:var(--dark);}
#process .h2{color:#fff;}
#process .tag{color:var(--gold3);}
#process .lead{color:rgba(255,255,255,.5);}
.proc-steps{display:grid;grid-template-columns:repeat(5,1fr);position:relative;margin-top:56px;}
.proc-steps::before{content:'';position:absolute;top:30px;left:10%;right:10%;height:1px;background:rgba(255,255,255,.1);}
.ps{padding:0 14px;text-align:center;}
.ps-n{width:60px;height:60px;margin:0 auto 18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;color:var(--gold3);position:relative;z-index:2;transition:all .35s;}
.ps:hover .ps-n{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 0 28px rgba(184,130,10,.5);}
.ps-t{font-weight:700;font-size:.9rem;margin-bottom:8px;color:#fff;}
.ps-d{font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.65;}

/* TESTIMONIALS */
#testi{background:var(--bg);}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px;}
.tc{background:var(--white);border:1.5px solid var(--card-border);padding:32px;transition:all .35s;position:relative;border-radius:8px;}
.tc::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--grad-short);border-radius:8px 8px 0 0;transition:width .5s;}
.tc:hover::before{width:100%;}
.tc:hover{border-color:var(--gold-line);transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.tc-stars{color:var(--gold2);font-size:.7rem;letter-spacing:3px;margin-bottom:14px;}
.tc-q{font-family:'Playfair Display',serif;font-size:3.5rem;line-height:.9;color:var(--gold2);opacity:.2;margin-bottom:12px;}
.tc-txt{font-size:.88rem;color:var(--soft);line-height:1.85;font-style:italic;margin-bottom:24px;}
.tc-author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:18px;}
.tc-av{width:40px;height:40px;background:var(--gold-bg);border:1.5px solid var(--gold-line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:900;color:var(--gold);font-size:.9rem;}
.tc-n{font-weight:700;font-size:.88rem;color:var(--ink);}
.tc-r{font-size:.73rem;color:var(--mute);margin-top:2px;}

/* PRICING */
#pricing{background:var(--bg2);}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1020px;margin:52px auto 0;}
.pc{background:var(--white);border:1.5px solid var(--card-border);padding:40px 32px;position:relative;transition:all .35s;border-radius:8px;}
.pc:hover{border-color:var(--gold-line);transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.pc.star{background:linear-gradient(165deg,#fff,#FFF8EE);border-color:rgba(184,130,10,.4);transform:scale(1.035);}
.pc.star:hover{transform:scale(1.035) translateY(-4px);}
.pc-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad-short);color:#fff;font-family:'Space Mono',monospace;font-size:.62rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 16px;border-radius:100px;}
.pc-plan{font-family:'Space Mono',monospace;font-size:.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.pc-price{font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:900;line-height:1;color:var(--ink);}
.pc-price span{font-size:1rem;vertical-align:top;margin-top:8px;display:inline-block;}
.pc-per{font-size:.78rem;color:var(--mute);margin-top:6px;margin-bottom:24px;}
.pc-feats{list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:11px;}
.pc-feats li{font-size:.84rem;color:var(--soft);display:flex;align-items:center;gap:8px;}
.pc-feats li::before{content:'✓';color:var(--green);font-size:.75rem;font-weight:700;flex-shrink:0;}

/* CONTACT */
#contact{background:var(--bg);}
.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start;}
.ci{display:flex;gap:14px;padding:18px 20px;background:var(--white);border:1.5px solid var(--card-border);margin-bottom:14px;transition:all .3s;border-radius:6px;}
.ci:hover{border-color:var(--gold-line);box-shadow:var(--shadow);}
.ci-ico{width:40px;height:40px;flex-shrink:0;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-size:1rem;border-radius:6px;}
.ci h4{font-family:'Space Mono',monospace;font-size:.62rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.ci p{font-size:.88rem;color:var(--soft);}
.cf{display:flex;flex-direction:column;gap:14px;background:var(--white);padding:36px;border-radius:8px;box-shadow:var(--shadow);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg label{font-family:'Space Mono',monospace;font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}
.fg input,.fg textarea,.fg select{background:var(--bg);border:1.5px solid var(--line2);color:var(--ink);padding:11px 14px;font-family:'Plus Jakarta Sans',sans-serif;font-size:.88rem;outline:none;transition:border-color .3s;border-radius:4px;}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--gold2);background:var(--white);}
.fg textarea{min-height:120px;resize:none;}

/* FOOTER */
footer{background:var(--dark);padding:64px 64px 28px;}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.fl-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.fl-logo-img{height:52px;object-fit:contain;filter:brightness(0) invert(1);opacity:.85;}
.fl-logo-text{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;color:var(--gold3);line-height:1.15;}
.fl-logo-text em{font-style:normal;color:rgba(255,255,255,.5);font-weight:300;font-size:1rem;display:block;}
.fl-desc{font-size:.84rem;color:rgba(255,255,255,.4);line-height:1.8;max-width:270px;}
.fl-social{display:flex;gap:8px;margin-top:18px;}
.fl-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);font-size:.75rem;transition:all .3s;border-radius:4px;}
.fl-social a:hover{background:var(--gold-bg);border-color:var(--gold);color:var(--gold3);}
.fch{font-family:'Space Mono',monospace;font-size:.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold3);margin-bottom:18px;}
.fcl{list-style:none;display:flex;flex-direction:column;gap:10px;}
.fcl a{font-size:.84rem;color:rgba(255,255,255,.4);transition:color .3s;display:flex;align-items:center;gap:6px;}
.fcl a::before{content:'›';color:var(--gold);font-size:.9rem;}
.fcl a:hover{color:var(--gold3);}
.fbar{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);flex-wrap:wrap;gap:12px;}
.fbar p{font-size:.74rem;color:rgba(255,255,255,.3);}
.fbar a{color:var(--gold3);}

/* INNER PAGES */
.ph{min-height:44vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:150px 64px 64px;position:relative;overflow:hidden;background:var(--bg2);}
.ph::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(184,130,10,.06) 0%,transparent 70%);}
.ph-inner{position:relative;z-index:2;}
.ph-title{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,5vw,4.4rem);font-weight:900;line-height:1.1;margin:14px 0 12px;color:var(--ink);}
.ph-sub{color:var(--soft);font-size:1rem;}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.bc{background:var(--white);border:1.5px solid var(--card-border);overflow:hidden;transition:all .35s;border-radius:8px;}
.bc:hover{border-color:var(--gold-line);transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.bc-img{width:100%;height:200px;object-fit:cover;transition:transform .4s;}
.bc:hover .bc-img{transform:scale(1.04);}
.bc-body{padding:24px;}
.bc-tag{display:inline-block;background:var(--gold-bg);color:var(--gold);font-family:'Space Mono',monospace;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;padding:3px 10px;margin-bottom:12px;border-radius:100px;}
.bc-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;margin-bottom:9px;line-height:1.35;color:var(--ink);}
.bc-exc{font-size:.82rem;color:var(--soft);line-height:1.75;margin-bottom:18px;}
.bc-meta{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:12px;}
.bc-meta span{font-size:.72rem;color:var(--mute);}
.bc-meta a{color:var(--gold);font-size:.76rem;font-weight:700;font-family:'Space Mono',monospace;}

/* RESPONSIVE */
@media(max-width:1100px){
  .hero-wrap{grid-template-columns:1fr;}
  .hero-right-imgs{height:300px;order:-1;}
  .srv-grid{grid-template-columns:1fr 1fr;}
  .proc-steps{grid-template-columns:repeat(3,1fr);gap:28px;}
  .proc-steps::before{display:none;}
  .ft{grid-template-columns:1fr 1fr;}
  .work-4{grid-template-columns:1fr;}
  .ceo-wrap{grid-template-columns:1fr;gap:40px;}
  .ceo-img{height:380px;}
  .ceo-badge{left:0;}
}
@media(max-width:900px){
  #topbar{padding:8px 16px;font-size:.68rem;}
  .tb-left{gap:10px;}
  #nav{top:36px!important;padding:8px 16px;}
  .nl{display:none;flex-direction:column;position:fixed;inset:0;background:var(--white);justify-content:center;align-items:center;gap:24px;z-index:999;top:0!important;}
  .nl.open{display:flex;}
  .hamburger{display:flex;}
  .sec{padding:60px 20px;}
  .divider{margin:0 20px;}
  #hero{padding:120px 20px 60px;}
  .hero-stats{grid-template-columns:1fr 1fr;}
  .about-wrap{grid-template-columns:1fr;}
  .about-vis{height:280px;}
  .contact-wrap{grid-template-columns:1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .pricing-grid{grid-template-columns:1fr;max-width:380px;}
  .pc.star{transform:scale(1);}
  .work-more{grid-template-columns:1fr 1fr;}
  .ft{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  footer{padding:48px 20px 20px;}
  .ph{padding:120px 20px 48px;}
  #topbar{display:none;}
  #nav{top:0!important;}
}
@media(max-width:600px){
  .srv-grid{grid-template-columns:1fr;}
  .work-more{grid-template-columns:1fr;}
  .proc-steps{grid-template-columns:1fr 1fr;}
  .hero-stats{grid-template-columns:1fr;}
}

/* CLIENT LOGO AVATARS IN TESTIMONIALS */
.tc-logo {
  width: 52px; height: 52px;
  border-radius: 8px;
  object-fit: contain;
  background: #fff;
  border: 1.5px solid var(--card-border);
  padding: 4px;
  flex-shrink: 0;
}

/* FOOTER LOGO — larger final version */
.fl-logo-img {
  height: 64px !important;
  object-fit: contain;
  background: white;
  border-radius: 8px;
  padding: 6px;
}

/* PORTFOLIO CARD CLIENT LOGOS */
.wp-client-logo {
  width: 44px; height: 44px;
  object-fit: contain;
  border-radius: 6px;
  background: #fff;
  border: 1.5px solid var(--card-border);
  padding: 4px;
}

/* ═══════════════════════════════════════════
   HERO v1.1.0 — PREMIUM CINEMATIC REDESIGN
═══════════════════════════════════════════ */

#hero {
  min-height: 100vh;
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 0;
}

/* Full-screen background */
.hero-bg-img {
  position: absolute; inset: 0;
  background-image: url('https://images.unsplash.com/photo-1497366216548-37526070297c?w=1600&q=90');
  background-size: cover;
  background-position: center;
  transform: scale(1.06);
  animation: heroZoom 18s ease-in-out infinite alternate;
}
@keyframes heroZoom {
  from { transform: scale(1.06); }
  to   { transform: scale(1.14); }
}

/* Dark gradient overlay — heavier on left for text legibility */
.hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(105deg, rgba(5,8,15,.97) 0%, rgba(5,8,15,.88) 40%, rgba(5,8,15,.55) 70%, rgba(5,8,15,.35) 100%),
    linear-gradient(to top, rgba(5,8,15,.7) 0%, transparent 50%);
}

/* Grid pattern overlay */
.hero-grid-pattern {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(212,160,23,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,160,23,.04) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 90% 90% at 50% 50%, black, transparent);
}

/* Glowing orbs */
.hero-orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); pointer-events: none;
}
.hero-orb-1 {
  width: 500px; height: 500px;
  background: rgba(184,130,10,.12);
  top: -100px; left: -100px;
  animation: orbFloat 10s ease-in-out infinite;
}
.hero-orb-2 {
  width: 400px; height: 400px;
  background: rgba(8,145,178,.07);
  bottom: -80px; right: 200px;
  animation: orbFloat 14s ease-in-out infinite reverse;
}
@keyframes orbFloat {
  0%,100% { transform: translate(0,0); }
  50%      { transform: translate(30px,-30px); }
}

/* Inner layout */
.hero-inner {
  position: relative; z-index: 2;
  max-width: 1320px; margin: 0 auto;
  width: 100%; padding: 160px 64px 100px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

/* ── LEFT COLUMN ─────────────────────── */
.hero-left-col {}

/* Kicker badge */
.hero-kicker {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(184,130,10,.1);
  border: 1px solid rgba(184,130,10,.3);
  padding: 8px 18px; border-radius: 100px;
  font-family: 'Space Mono', monospace;
  font-size: .68rem; letter-spacing: 2px; text-transform: uppercase;
  color: var(--gold3); margin-bottom: 28px;
}
.hk-dot {
  width: 7px; height: 7px;
  background: #22C55E; border-radius: 50%;
  box-shadow: 0 0 8px #22C55E;
  animation: pulse 2s infinite;
}

/* Headline */
.hero-headline {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.2rem, 3.8vw, 3.8rem);
  font-weight: 900;
  line-height: 1.12;
  margin-bottom: 28px;
  color: #fff;
}
.hh-line { display: block; }
.hh-gold {
  background: linear-gradient(135deg, #D4A017, #F0CC78, #D4A017);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* Fix typing shift — reserve fixed width so line never jumps */
.typing-wrap {
  display: inline-block;
  min-width: 220px;
  border-bottom: 3px solid var(--gold2);
  padding-bottom: 2px;
  vertical-align: bottom;
}
.typing-cursor { display: none; }

/* Description */
.hero-desc {
  font-size: 1.05rem; line-height: 1.9;
  color: rgba(255,255,255,.58);
  max-width: 520px; margin-bottom: 40px;
  font-weight: 300;
}

/* CTA buttons */
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 52px; }

.hcta-primary {
  display: inline-flex; align-items: center; gap: 10px;
  background: linear-gradient(135deg, #B8820A, #D4A017, #E8BC48);
  color: #fff;
  padding: 16px 34px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .84rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  border-radius: 4px;
  text-decoration: none;
  transition: all .3s;
  box-shadow: 0 8px 32px rgba(184,130,10,.35);
  position: relative; overflow: hidden;
}
.hcta-primary::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.15), transparent);
  opacity: 0; transition: opacity .3s;
}
.hcta-primary:hover { transform: translateY(-3px); box-shadow: 0 16px 48px rgba(184,130,10,.5); }
.hcta-primary:hover::before { opacity: 1; }

.hcta-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.85);
  padding: 16px 34px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .84rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  border-radius: 4px;
  border: 1.5px solid rgba(255,255,255,.18);
  text-decoration: none;
  transition: all .3s;
  backdrop-filter: blur(8px);
}
.hcta-secondary:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.35);
  transform: translateY(-3px);
}

/* Stats row */
.hero-stat-row {
  display: flex; align-items: center; gap: 0;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  backdrop-filter: blur(12px);
  overflow: hidden;
}
.hsr-item { padding: 20px 28px; flex: 1; }
.hsr-num {
  font-family: 'Playfair Display', serif;
  font-size: 2rem; font-weight: 900;
  color: var(--gold2); line-height: 1;
}
.hsr-lbl {
  font-size: .67rem; color: rgba(255,255,255,.4);
  letter-spacing: 1px; text-transform: uppercase;
  font-family: 'Space Mono', monospace; margin-top: 5px;
}
.hsr-divider { width: 1px; height: 52px; background: rgba(255,255,255,.1); flex-shrink: 0; }

/* ── RIGHT COLUMN ────────────────────── */
.hero-right-col { position: relative; height: 580px; }

/* Main card */
.hrc-main {
  position: absolute; top: 0; right: 0;
  width: 88%; height: 340px;
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
  border: 2px solid rgba(255,255,255,.1);
}
.hrc-main-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s;
}
.hrc-main:hover .hrc-main-img { transform: scale(1.05); }
.hrc-main-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(5,8,15,.95) 0%, transparent 100%);
  padding: 28px 24px 22px;
}
.hrc-tag {
  font-family: 'Space Mono', monospace; font-size: .65rem;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--gold3); margin-bottom: 6px;
}
.hrc-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.3rem; font-weight: 700; color: #fff;
  margin-bottom: 3px;
}
.hrc-sub { font-size: .78rem; color: rgba(255,255,255,.5); }

/* Two small cards */
.hrc-smalls {
  position: absolute; bottom: 0; left: 0;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px; width: 84%;
}
.hrc-small {
  border-radius: 10px; overflow: hidden;
  height: 210px;
  box-shadow: 0 16px 48px rgba(0,0,0,.5);
  border: 2px solid rgba(255,255,255,.08);
  position: relative;
  transition: transform .35s;
}
.hrc-small:hover { transform: translateY(-6px); }
.hrc-small-img { width: 100%; height: 100%; object-fit: cover; }
.hrc-small-info {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(5,8,15,.92) 0%, transparent 100%);
  padding: 16px 14px 12px;
}
.hrc-small-label { font-size: .82rem; font-weight: 700; color: #fff; margin-bottom: 2px; }
.hrc-small-stat { font-size: .68rem; color: var(--gold3); font-family: 'Space Mono', monospace; }

/* Floating badge cards */
.hrc-badge {
  position: absolute; z-index: 10;
  background: rgba(255,255,255,.95);
  border-radius: 10px; padding: 12px 16px;
  display: flex; align-items: center; gap: 10px;
  box-shadow: 0 12px 40px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.3);
  min-width: 200px;
}
.hrc-badge-tl { top: 24px; left: -10px; animation: badgeFloat1 4s ease-in-out infinite; }
.hrc-badge-br { bottom: 220px; right: -10px; animation: badgeFloat2 5s ease-in-out infinite; }
@keyframes badgeFloat1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes badgeFloat2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.hrc-badge-icon { font-size: 1.4rem; flex-shrink: 0; }
.hrc-badge-val { font-size: .85rem; font-weight: 700; color: var(--ink); line-height: 1.2; }
.hrc-badge-lbl { font-size: .68rem; color: var(--mute); margin-top: 2px; }

/* Scroll indicator */
.hero-scroll {
  position: absolute; bottom: 28px; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  z-index: 5;
}
.hero-scroll-line {
  width: 1px; height: 48px;
  background: linear-gradient(to bottom, var(--gold2), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse { 0%,100%{opacity:.3;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(1.15)} }
.hero-scroll span {
  font-family: 'Space Mono', monospace; font-size: .6rem;
  letter-spacing: 3px; text-transform: uppercase;
  color: rgba(255,255,255,.3);
}

/* ── HERO RESPONSIVE ─────────────────── */
@media(max-width:1100px) {
  .hero-inner { grid-template-columns: 1fr; padding: 140px 32px 80px; gap: 48px; }
  .hero-right-col { height: 340px; order: -1; }
  .hrc-main { width: 100%; height: 260px; }
  .hrc-smalls { width: 100%; bottom: auto; top: 280px; display: none; }
  .hrc-badge { display: none; }
  .hero-stat-row { flex-wrap: wrap; }
  .hsr-item { padding: 16px 20px; }
}
@media(max-width:700px) {
  .hero-inner { padding: 120px 20px 60px; }
  .hero-headline { font-size: 2.8rem; }
  .hero-ctas { flex-direction: column; }
  .hcta-primary, .hcta-secondary { justify-content: center; }
  .hsr-divider { display: none; }
  .hero-stat-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(255,255,255,.1); }
  .hsr-item { background: rgba(5,8,15,.8); }
}
