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

:root {
  --teal:      #06514E;
  --teal-deep: #033a38;
  --teal-mid:  #0a6e6a;
  --citron:    #DEDB7C;
  --lavender:  #C5B1F4;
  --coral:     #ED7A60;
  --cream:     #F8F2EC;
  --charcoal:  #28272A;
  --muted:     #6b6a6d;
  --FB: 'DM Sans','Helvetica Neue',Helvetica,Arial,sans-serif;
  --FD: 'Playfair Display',Georgia,'Times New Roman',serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth}body{font-family:var(--FB);color:var(--charcoal);background:var(--cream);margin:0;padding-top:70px}

/* NAV — sticky, scrolls with page */
nav{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 3vw;box-sizing:border-box;background:#06514E;border-bottom:2px solid #DEDB7C;transition:box-shadow .3s}
nav.sc{box-shadow:0 2px 40px rgba(3,58,56,.4)}

/* Logo */
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo-wrap{display:flex;flex-direction:column;gap:4px}
.logo-row{display:flex;align-items:center;gap:8px}
.logo-primus{font-family:var(--FB);font-size:1.05rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);line-height:1;white-space:nowrap}
.logo-fin-box{background:var(--citron);padding:3px 9px 4px;display:inline-flex;align-items:center;line-height:1}
.logo-fin-box span{font-family:var(--FB);font-size:1.05rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-deep);line-height:1}
.logo-sub{font-size:.5rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(248,242,236,.75);white-space:nowrap}

/* Desktop links — full nav visible on all screens >= 860px */
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none;flex-shrink:1;min-width:0}
.nav-links a{font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#DEDB7C;text-decoration:none;transition:color .2s;white-space:nowrap}
.nav-links a:hover{color:#ffffff}

/* Nav right — always visible: CTA + hamburger */
.nav-right{display:flex;align-items:center;gap:.8rem;flex-shrink:0;padding-right:.5rem}
.ncta-btn{background:var(--citron);color:var(--teal-deep);padding:.55rem 1.2rem;border-radius:100px;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;white-space:nowrap;transition:opacity .2s;flex-shrink:0}
.ncta-btn:hover{opacity:.82}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;flex-shrink:0;z-index:201}
.hbg span{display:block;width:24px;height:2px;background:var(--cream);transition:transform .3s,opacity .3s;border-radius:2px}
.hbg.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hbg.open span:nth-child(2){opacity:0}
.hbg.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Fullscreen mobile menu — overlay when hamburger open */
.nav-links.open{
  display:flex !important;
  flex-direction:column;
  position:fixed;
  inset:0;
  background:var(--teal-deep);
  z-index:200;
  padding:7rem 3rem 3rem;
  gap:0;
  align-items:stretch;
  justify-content:center;
  overflow-y:auto;
}
.nav-links.open li{border-bottom:1px solid rgba(248,242,236,.07)}
.nav-links.open a{
  font-size:1.4rem !important;
  letter-spacing:.06em !important;
  color:rgba(248,242,236,.85) !important;
  padding:1.2rem 0 !important;
  font-weight:400 !important;
  display:block;
}
.nav-links.open a:hover{color:var(--citron) !important}

/* HERO */
#hero{min-height:100vh;background:var(--teal-deep);display:grid;place-items:center;padding:80px 5vw 80px;position:relative;overflow:hidden;background-image:url("../images/hero-bg.jpg");background-size:cover;background-position:center 60%;background-repeat:no-repeat}
#hero::before{content:'';position:absolute;inset:0;pointer-events:none;z-index:1;background:linear-gradient(105deg,rgba(6,81,78,.92) 0%,rgba(6,81,78,.82) 45%,rgba(6,81,78,.50) 100%)}
#hero::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(222,219,124,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(222,219,124,.025) 1px,transparent 1px);background-size:64px 64px}
.blob{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:2}
.b1{width:650px;height:650px;top:-220px;right:-180px;background:rgba(197,177,244,.13);animation:fl 20s ease-in-out infinite alternate}
.b2{width:480px;height:480px;bottom:-120px;left:-120px;background:rgba(237,122,96,.09);animation:fl 26s ease-in-out infinite alternate-reverse}
.b3{width:280px;height:280px;top:55%;left:42%;background:rgba(222,219,124,.09);animation:fl 15s ease-in-out infinite alternate}
@keyframes fl{from{transform:translate(0,0)}to{transform:translate(24px,18px)}}
.hi{position:relative;z-index:2;max-width:1120px;width:100%;display:grid;grid-template-columns:1.1fr .9fr;gap:6vw;align-items:center}
.hbadge{display:inline-flex;align-items:center;gap:.55rem;background:var(--citron);color:var(--teal-deep);font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:.28rem .9rem;border-radius:100px;margin-bottom:1.8rem}
.hbadge::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--teal-deep)}
h1{font-family:var(--FD);font-size:clamp(3rem,5.5vw,5rem);font-weight:700;line-height:1.06;color:#ffffff;margin-bottom:1.5rem;text-shadow:0 2px 20px rgba(0,0,0,.35)}
h1 em{font-style:italic;color:var(--citron);display:block}
.hp{font-size:1.05rem;line-height:1.85;color:rgba(255,255,255,.90);font-weight:400;max-width:480px;margin-bottom:2.8rem}
.hbtns{display:flex;gap:.9rem;flex-wrap:wrap}
.bf{background:var(--citron);color:var(--teal-deep);padding:.85rem 2rem;border-radius:100px;font-weight:600;font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:opacity .2s,transform .15s}
.bf:hover{opacity:.85;transform:translateY(-1px)}
.bg{border:1px solid rgba(248,242,236,.22);color:rgba(248,242,236,.65);padding:.85rem 2rem;border-radius:100px;font-size:.84rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:border-color .2s,background .2s}
.bg:hover{border-color:var(--citron);background:rgba(222,219,124,.06);color:var(--cream)}
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.tile{border-radius:16px;padding:2rem 1.8rem;transition:transform .25s;min-height:150px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.tile:hover{transform:translateY(-4px)}
.ta{background:rgba(197,177,244,.1);border:1px solid rgba(197,177,244,.18)}
.tb{background:rgba(237,122,96,.1);border:1px solid rgba(237,122,96,.18)}
.tc{background:rgba(222,219,124,.09);border:1px solid rgba(222,219,124,.18)}
.td{background:rgba(6,81,78,.5);border:1px solid rgba(248,242,236,.08)}
.tn{font-family:var(--FD);font-size:3.4rem;font-weight:700;line-height:1;margin-bottom:.5rem}
.ta .tn{color:var(--lavender)}.tb .tn{color:var(--coral)}.tc .tn{color:var(--citron)}.td .tn{color:var(--cream)}
.tl{font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(248,242,236,.55);font-weight:500}
.tile-logos{display:flex;flex-direction:column;justify-content:center;padding:1.4rem 1.2rem}
.tile-logo-row{display:flex;align-items:center;justify-content:center;gap:0}
.tile-logo-item{flex:1;display:flex;align-items:center;justify-content:center;padding:0 .4rem}
.tile-logo-divider{width:1px;height:36px;background:rgba(248,242,236,.15);flex-shrink:0}
.tile-logo-single{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.2rem}

/* SHARED */
section{padding:110px 5vw}
.sin{max-width:1120px;margin:0 auto}
.ey{font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.ey::after{content:'';flex:0 0 26px;height:1px}
.st{font-family:var(--FD);font-size:clamp(2.2rem,3.8vw,3.4rem);font-weight:400;line-height:1.15;margin-bottom:1rem}
.st em{font-style:italic}
.ss{font-size:1rem;line-height:1.8;font-weight:300;max-width:560px;margin-bottom:3.5rem}

/* DIFF — cream bg */
#differentiators{background:var(--cream)}
#differentiators .ey{color:var(--teal)}
#differentiators .ey::after{background:var(--teal)}
#differentiators .st{color:var(--charcoal)}
#differentiators .st em{color:var(--teal)}
#differentiators .ss{color:var(--muted)}
.dgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(6,81,78,.15)}
.dc{background:var(--cream);padding:2.5rem 2rem;transition:background .35s;cursor:default}
.dc:hover{background:var(--teal)}
.dc:hover .di{background:rgba(222,219,124,.15)}
.dc:hover .di svg{stroke:var(--citron)}
.dc:hover .dt{color:var(--cream)}
.dc:hover .db{color:rgba(248,242,236,.65)}
.di{width:48px;height:48px;border-radius:12px;background:rgba(6,81,78,.08);display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;transition:background .35s}
.di svg{stroke:var(--teal);transition:stroke .35s}
.dt{font-size:.97rem;font-weight:600;color:var(--charcoal);margin-bottom:.55rem;transition:color .35s}
.db{font-size:.875rem;color:var(--muted);line-height:1.7;font-weight:300;transition:color .35s}

/* SERVICES — teal-deep bg (not black) */
#services{background:var(--teal-deep)}
#services .ey{color:var(--citron)}
#services .ey::after{background:var(--citron)}
#services .st{color:var(--cream)}
#services .st em{color:var(--citron)}
#services .ss{color:rgba(248,242,236,.6)}
.sgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;background:rgba(222,219,124,.08)}
.sc{background:var(--teal-deep);padding:2.2rem 1.8rem;position:relative;overflow:hidden;transition:background .35s}
.sc:hover{background:rgba(255,255,255,.08)}
.sbar{position:absolute;top:0;left:0;width:3px;height:0;transition:height .45s ease}
.sc:hover .sbar{height:100%}
.barc{background:var(--citron)}.barl{background:var(--lavender)}.barr{background:var(--coral)}
.sn{font-family:var(--FD);font-size:2.4rem;font-weight:700;color:rgba(248,242,236,.35);line-height:1;margin-bottom:.3rem;transition:color .35s}
.sc:has(.barc):hover .sn{color:rgba(222,219,124,.4)}
.sc:has(.barl):hover .sn{color:rgba(197,177,244,.4)}
.sc:has(.barr):hover .sn{color:rgba(237,122,96,.4)}
.snm{font-size:.95rem;font-weight:600;color:var(--cream);margin-bottom:.55rem;transition:color .35s}
.sc:has(.barc):hover .snm{color:var(--citron)}
.sc:has(.barl):hover .snm{color:var(--lavender)}
.sc:has(.barr):hover .snm{color:var(--coral)}
.sd{font-size:.86rem;color:rgba(248,242,236,.78);line-height:1.7;font-weight:300;margin-bottom:1.2rem;transition:color .35s}
.sc:hover .sd{color:rgba(248,242,236,.92)}
.tags{display:flex;flex-wrap:wrap;gap:.4rem}
.tag{font-size:.68rem;padding:.2rem .65rem;border-radius:100px;border:1px solid rgba(248,242,236,.25);color:rgba(248,242,236,.7);letter-spacing:.04em;transition:border-color .35s,color .35s,background .35s}
.sc:has(.barc):hover .tag{border-color:rgba(222,219,124,.45);color:rgba(222,219,124,.95);background:rgba(222,219,124,.08)}
.sc:has(.barl):hover .tag{border-color:rgba(197,177,244,.45);color:rgba(197,177,244,.95);background:rgba(197,177,244,.08)}
.sc:has(.barr):hover .tag{border-color:rgba(237,122,96,.45);color:rgba(237,122,96,.95);background:rgba(237,122,96,.08)}

/* ABOUT — white bg, high-contrast principal card */
#about{background:#f0f7f7}
#about .ey{color:var(--teal)}
#about .ey::after{background:var(--teal)}
#about .st{color:var(--charcoal)}
#about .st em{color:var(--teal)}
#about .ss{color:var(--muted)}
.alayout{display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:start}
.aleft p{font-size:.95rem;color:var(--muted);line-height:1.85;font-weight:300;margin-bottom:1.2rem}
.profile-card{background:var(--teal);border-radius:20px;padding:2.4rem;position:relative;overflow:hidden;box-shadow:0 16px 48px rgba(6,81,78,.25)}
.profile-card::after{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:rgba(222,219,124,.12);pointer-events:none}
.pname{font-family:var(--FD);font-size:1.6rem;color:#ffffff;font-weight:400}
.prole{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--citron);font-weight:700;margin-bottom:1.4rem;margin-top:.4rem}
.creds{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.creds li{display:flex;gap:.85rem;align-items:flex-start;font-size:.88rem;color:rgba(255,255,255,.92);font-weight:300;line-height:1.5}
.dot{flex-shrink:0;width:7px;height:7px;border-radius:50%;margin-top:6px}
.dotc{background:var(--citron)}.dotl{background:var(--lavender)}.dotr{background:var(--coral)}

/* TESTIMONIALS — CSS kept, section removed from HTML */
#testimonials{display:none}

/* PRICING — cream bg (light break before industries) */
#pricing{background:#f0f7f7}
#pricing .ey{color:var(--teal)}
#pricing .ey::after{background:var(--teal)}
#pricing .st{color:var(--charcoal)}
#pricing .st em{color:var(--teal)}
#pricing .ss{color:var(--muted)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pcard{background:#ffffff;border:2px solid rgba(6,81,78,.15);border-radius:20px;padding:2.4rem 2rem;position:relative;display:flex;flex-direction:column;transition:box-shadow .3s,transform .25s}
.pcard:hover{box-shadow:0 12px 40px rgba(6,81,78,.12);transform:translateY(-4px)}
.pcard.featured{background:var(--teal-deep);border-color:transparent;box-shadow:0 16px 60px rgba(3,58,56,.3)}
.pcard.featured:hover{transform:translateY(-4px)}
.pcard.featured .ptier{color:var(--citron)}
.pcard.featured .pprice{color:var(--cream)}
.pcard.featured .psub{color:rgba(248,242,236,.6)}
.pcard.featured .pline{background:rgba(248,242,236,.12)}
.pcard.featured .pfeature{color:rgba(248,242,236,.85)}
.pcard.featured .pfeature svg{stroke:var(--citron)}
.pcard.featured .pbtn{background:var(--citron);color:var(--teal-deep);border-color:var(--citron)}
.pcard.featured .pbtn:hover{opacity:.88}
.pbadge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--citron);color:var(--teal-deep);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .9rem;border-radius:100px;white-space:nowrap}
.ptier{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:.8rem}
.pprice{font-family:var(--FD);font-size:2.4rem;font-weight:700;color:var(--charcoal);line-height:1;margin-bottom:.3rem}
.pprice span{font-size:1rem;font-weight:400;font-family:var(--FB)}
.psub{font-size:.82rem;color:var(--muted);margin-bottom:1.6rem;font-weight:300}
.pline{height:1px;background:rgba(6,81,78,.08);margin-bottom:1.6rem}
.pfeatures{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:2rem;flex:1}
.pfeature{display:flex;align-items:flex-start;gap:.7rem;font-size:.86rem;color:var(--muted);font-weight:300;line-height:1.4}
.pfeature svg{flex-shrink:0;stroke:var(--teal);margin-top:2px}
.pbtn{display:block;text-align:center;padding:.82rem 1.5rem;border-radius:100px;font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:1.5px solid var(--teal);color:var(--teal);transition:background .2s,color .2s;cursor:pointer}
.pbtn:hover{background:var(--teal);color:var(--cream)}
.pnote{text-align:center;font-size:.8rem;color:var(--muted);margin-top:2rem;font-weight:300}
.pnote a{color:var(--teal);text-decoration:none;font-weight:500}

/* INDUSTRIES — teal header, lighter distinctive slide gradients */
#who{background:var(--teal);padding-bottom:0}
#who .sin{padding-bottom:0}
#who .ey{color:var(--citron)}
#who .ey::after{background:var(--citron)}
#who .st{color:var(--cream)}
#who .st em{color:var(--citron)}
#who .ss{color:rgba(248,242,236,.7)}
.ind-outer{position:relative;overflow:hidden;margin-top:3rem}
.ind-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.ind-slide{flex:0 0 100%;min-width:0;position:relative;height:560px;display:flex;align-items:center}
.ind-bg{position:absolute;inset:0}
.ind-bg::after{content:'';position:absolute;inset:0}
.ind-bg-fb{background:linear-gradient(135deg,#055a55 0%,#078078 100%)}
.ind-bg-fb::after{background:radial-gradient(ellipse at 75% 50%,rgba(222,219,124,.2) 0%,transparent 60%)}
.ind-bg-ps{background:linear-gradient(135deg,#4a4850 0%,#06514E 100%)}
.ind-bg-ps::after{background:radial-gradient(ellipse at 30% 55%,rgba(197,177,244,.25) 0%,transparent 60%)}
.ind-bg-ac{background:linear-gradient(135deg,#06514E 0%,#3d5f70 100%)}
.ind-bg-ac::after{background:radial-gradient(ellipse at 70% 40%,rgba(237,122,96,.22) 0%,transparent 60%)}
.ind-bg-rt{background:linear-gradient(135deg,#304870 0%,#078078 100%)}
.ind-bg-rt::after{background:radial-gradient(ellipse at 40% 60%,rgba(222,219,124,.18) 0%,transparent 65%)}
.ind-bg-hc{background:linear-gradient(135deg,#06514E 0%,#584868 100%)}
.ind-bg-hc::after{background:radial-gradient(ellipse at 65% 35%,rgba(197,177,244,.22) 0%,transparent 60%)}
.ind-bg-md{background:linear-gradient(135deg,#078078 0%,#4a4850 100%)}
.ind-bg-md::after{background:radial-gradient(ellipse at 35% 65%,rgba(237,122,96,.2) 0%,transparent 60%)}
.ind-bg-re{background:linear-gradient(135deg,#30586a 0%,#06514E 100%)}
.ind-bg-re::after{background:radial-gradient(ellipse at 68% 40%,rgba(197,177,244,.22) 0%,transparent 60%)}
.ind-bg-hw{background:linear-gradient(135deg,#06514E 0%,#685068 100%)}
.ind-bg-hw::after{background:radial-gradient(ellipse at 35% 55%,rgba(237,122,96,.22) 0%,transparent 60%)}
.ind-bg-ec{background:linear-gradient(135deg,#4a4850 0%,#078078 100%)}
.ind-bg-ec::after{background:radial-gradient(ellipse at 65% 45%,rgba(222,219,124,.2) 0%,transparent 60%)}
.ind-content{position:relative;z-index:2;max-width:1120px;width:100%;margin:0 auto;padding:4rem 5vw;display:grid;grid-template-columns:3fr 2fr;gap:4vw;align-items:center}
.ind-left{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;opacity:1;transform:none}
.ind-title{font-family:var(--FD);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:400;color:#ffffff;line-height:1.1;margin-bottom:1.2rem}
.ind-body{font-size:.93rem;color:rgba(255,255,255,.82);line-height:1.8;font-weight:300;margin-bottom:1.6rem;max-width:520px}
.ind-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.8rem}
.ind-tags span{font-size:.68rem;padding:.28rem .8rem;border-radius:100px;border:1px solid rgba(222,219,124,.55);color:var(--citron);background:rgba(222,219,124,.1);letter-spacing:.03em;white-space:nowrap}
.ind-cta{display:inline-flex;align-items:center;background:var(--citron);color:var(--teal-deep);padding:.72rem 1.6rem;border-radius:100px;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:opacity .2s,transform .15s;white-space:nowrap}
.ind-cta:hover{opacity:.85;transform:translateY(-1px)}
.ind-deco-right{display:flex;align-items:center;justify-content:center;position:relative;height:100%;overflow:hidden;opacity:1;transform:none}
.ind-deco-icon{position:relative;display:flex;align-items:center;justify-content:center;z-index:2}
.ind-deco-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.12)}
.ind-deco-ring1{width:220px;height:220px}
.ind-deco-ring2{width:300px;height:300px;border-color:rgba(255,255,255,.06)}
.ind-deco-ring3{width:380px;height:380px;border-color:rgba(255,255,255,.03)}
.ind-progress{width:100%;height:2px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.ind-progress-fill{height:100%;background:var(--citron);border-radius:2px;transition:width .55s cubic-bezier(.4,0,.2,1)}
.ind-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1.8rem 5vw 2.5rem;background:var(--teal)}
.ind-prev,.ind-next{width:44px;height:44px;border-radius:50%;border:1px solid rgba(248,242,236,.25);background:none;color:rgba(248,242,236,.7);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,color .2s}
.ind-prev:hover,.ind-next:hover{border-color:var(--citron);background:rgba(222,219,124,.1);color:var(--citron)}
.ind-dots{display:flex;gap:.6rem;align-items:center}
.ind-dot{width:8px;height:8px;border-radius:50%;background:rgba(248,242,236,.25);border:none;cursor:pointer;padding:0;transition:background .3s,transform .3s}
.ind-dot.active{background:var(--citron);transform:scale(1.3)}
@media(max-width:900px){
  .ind-slide{height:auto;min-height:480px}
  .ind-content{grid-template-columns:1fr}
  .ind-deco-right{display:none}
}

/* FAQ — cream bg (light break before dark contact) */
#faq{background:#edf5f4}
#faq .ey{color:var(--teal)}
#faq .ey::after{background:var(--teal)}
#faq .st{color:var(--charcoal)}
#faq .st em{color:var(--teal)}
#faq .ss{color:var(--muted)}
.faq-list{display:flex;flex-direction:column;gap:2px;background:rgba(6,81,78,.15)}
.faq-item{background:#edf5f4;overflow:hidden}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:1.5rem 2rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;transition:background .2s}
.faq-q:hover{background:rgba(6,81,78,.04)}
.faq-q span{font-size:.97rem;font-weight:500;color:var(--teal-deep);line-height:1.4}
.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1px solid rgba(6,81,78,.2);display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .3s}
.faq-item.open .faq-icon{background:var(--teal);border-color:var(--teal);transform:rotate(45deg)}
.faq-icon svg{stroke:rgba(6,81,78,.5);transition:stroke .3s}
.faq-item.open .faq-icon svg{stroke:#ffffff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 2rem 1.5rem;font-size:.9rem;color:var(--muted);line-height:1.8;font-weight:300;max-width:700px}
.faq-item.open .faq-a{max-height:300px}

/* CONTACT — teal-deep bg */
#contact{background:var(--teal-deep)}
#contact .ey{color:var(--citron)}
#contact .ey::after{background:var(--citron)}
#contact .st{color:var(--cream)}
#contact .st em{color:rgba(248,242,236,.5)}
#contact .ss{color:rgba(248,242,236,.65)}
.clayout{display:grid;grid-template-columns:1fr 1fr;gap:7vw;align-items:start}
.citems{display:flex;flex-direction:column;gap:2.2rem}
.ci{display:flex;gap:1rem;align-items:flex-start}
.cico{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ica{background:rgba(222,219,124,.15)}.icb{background:rgba(197,177,244,.15)}.icc{background:rgba(237,122,96,.15)}
.clabel{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(248,242,236,.5);font-weight:500;margin-bottom:.15rem}
.cval{font-size:.95rem;color:rgba(248,242,236,.9)}
.cval a{color:rgba(248,242,236,.9);text-decoration:none;transition:color .2s}
.cval a:hover{color:var(--citron)}
.fcard{background:var(--cream);border-radius:20px;padding:2.6rem;box-shadow:0 20px 80px rgba(0,0,0,.25)}
.ftitle{font-family:var(--FD);font-size:1.7rem;color:var(--charcoal);margin-bottom:.3rem}
.fsub{font-size:.83rem;color:var(--muted);font-weight:300;margin-bottom:2rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.fg{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.fg label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-deep)}
.fg input,.fg select,.fg textarea{padding:.78rem 1rem;border:1.5px solid rgba(6,81,78,.14);border-radius:10px;background:#fff;font-family:var(--FB);font-size:.9rem;color:var(--charcoal);outline:none;transition:border-color .2s,box-shadow .2s;appearance:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(6,81,78,.08)}
.fg textarea{resize:vertical;min-height:90px}
.fbtn{width:100%;padding:.95rem;border:none;border-radius:100px;background:var(--teal);color:var(--cream);font-family:var(--FB);font-size:.88rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s}
.fbtn:hover{background:var(--teal-mid);transform:translateY(-1px)}
.fsuccess{display:none;text-align:center;padding:2.5rem 1rem}
.fsuccess .ico{display:flex;justify-content:center;margin-bottom:.8rem}
.fsuccess p{color:var(--teal-deep);font-size:1rem}


/* INDUSTRY PHOTO PLACEHOLDERS */
.ind-photo-slot{display:flex;align-items:center;justify-content:center;border-radius:16px;border:2px dashed rgba(222,219,124,.4);background:rgba(0,0,0,.18);min-height:340px;overflow:hidden}
.ind-photo-img{width:100%;height:100%;object-fit:cover;border-radius:14px;display:none}
.ind-ph-box{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem;padding:2rem}
.ind-ph-label{font-size:.88rem;font-weight:600;color:rgba(248,242,236,.85);letter-spacing:.04em;margin:0}
.ind-ph-hint{font-size:.72rem;color:rgba(248,242,236,.4);font-weight:300;margin:0}
.ind-ph-id{font-size:.62rem;color:rgba(222,219,124,.6);letter-spacing:.06em;background:rgba(222,219,124,.1);padding:.2rem .6rem;border-radius:4px;font-family:monospace}
/* On deployment: set img src → placeholder hides, photo shows */
.ind-photo-slot:has(.ind-photo-img[src]:not([src=""])) .ind-ph-box{display:none}
.ind-photo-slot:has(.ind-photo-img[src]:not([src=""])) .ind-photo-img{display:block!important}

/* LINE WIDGET */
.line-widget{position:fixed;bottom:2rem;right:2rem;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:.6rem}
.line-bubble{background:#06C755;color:#fff;border:none;width:58px;height:58px;border-radius:50%;cursor:pointer;box-shadow:0 4px 20px rgba(6,199,85,.35);display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}
.line-bubble:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(6,199,85,.45)}
.line-tooltip{background:var(--charcoal);color:var(--cream);font-size:.78rem;font-weight:500;padding:.45rem .9rem;border-radius:100px;white-space:nowrap;opacity:0;transform:translateX(8px);transition:opacity .2s,transform .2s;pointer-events:none}
.line-widget:hover .line-tooltip{opacity:1;transform:translateX(0)}

/* FOOTER */
footer{background:var(--teal-deep);color:rgba(248,242,236,.85);padding:2.8rem 5vw;text-align:center;font-size:.82rem;letter-spacing:.04em;border-top:1px solid rgba(222,219,124,.35)}
footer a{color:var(--citron);text-decoration:none;font-weight:500}

/* REVEAL — starts visible, animates in on scroll */
.rv{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}

/* Hamburger only on tablet/mobile — desktop always shows full nav */
/* ── TABLET (≤900px) ─────────────────────────── */
@media(max-width:900px){
  /* Sections */
  section{padding:70px 5vw}

  /* Hero */
  #hero{padding:100px 5vw 60px;min-height:auto}
  .hi{grid-template-columns:1fr;gap:3rem}
  .tiles{grid-template-columns:1fr 1fr;margin-top:2rem;gap:10px}
  h1{font-size:clamp(2.2rem,7vw,3.2rem)}
  .hp{font-size:.95rem}

  /* Nav */
  .nav-links{display:none}
  .hbg{display:flex}

  /* Why us */
  .dgrid{grid-template-columns:1fr 1fr}

  /* Services */
  .sgrid{grid-template-columns:1fr 1fr}

  /* About */
  .alayout{grid-template-columns:1fr;gap:3rem}

  /* Pricing */
  .pgrid{grid-template-columns:1fr;gap:1.2rem}
  .pcard.featured{transform:none}

  /* FAQ */
  .frow{grid-template-columns:1fr}

  /* Contact */
  .clayout{grid-template-columns:1fr;gap:3rem}

  /* Carousel */
  .ind-deco-right{display:none}
  .ind-content{grid-template-columns:1fr}
  .ind-slide{height:auto;min-height:440px}

  /* Profile card */
  .profile-card{margin-top:0}
}

/* ── MOBILE (≤600px) ─────────────────────────── */
@media(max-width:600px){
  /* Base */
  html,body{font-size:15px}
  section{padding:55px 6vw}
  body{padding-top:60px}

  /* Nav */
  nav{padding:.7rem 4vw}
  .logo-primus{font-size:.85rem}
  .logo-fin-box span{font-size:.85rem}
  .logo-sub{display:none}
  .ncta-btn{padding:.45rem .9rem;font-size:.7rem}

  /* Hero */
  #hero{padding:80px 6vw 50px}
  h1{font-size:clamp(1.9rem,8vw,2.6rem);margin-bottom:1.2rem}
  h1 em{font-size:inherit}
  .hp{font-size:.9rem;margin-bottom:2rem}
  .hbtns{flex-direction:column;gap:.7rem}
  .bf,.bg{text-align:center;padding:.8rem 1.5rem}
  .hbadge{font-size:.6rem;margin-bottom:1.2rem}

  /* Tiles */
  .tiles{grid-template-columns:1fr 1fr;gap:8px}
  .tile{padding:1.4rem 1.2rem;min-height:110px}
  .tn{font-size:2.4rem}
  .tl{font-size:.65rem}
  .tile-logo-single{padding:1rem .8rem}

  /* Why us */
  .dgrid{grid-template-columns:1fr}
  .dc{padding:1.8rem 1.4rem}

  /* Services */
  .sgrid{grid-template-columns:1fr}
  .sc{padding:1.8rem 1.4rem}

  /* About */
  .alayout{gap:2rem}
  .aleft p{font-size:.9rem}
  .profile-card{padding:1.8rem}
  .pname{font-size:1.3rem}

  /* Pricing */
  .pgrid{gap:1rem}
  .pcard{padding:1.8rem 1.4rem}
  .pprice{font-size:2rem}
  .pbadge{font-size:.58rem}

  /* Carousel */
  .ind-slide{height:auto;min-height:400px}
  .ind-content{padding:2.5rem 6vw}
  .ind-title{font-size:1.6rem}
  .ind-body{font-size:.88rem}
  #carWrap [style]{height:auto!important}

  /* FAQ */
  .faq-q{padding:1.2rem 1.2rem}
  .faq-q span{font-size:.9rem}
  .faq-a-inner{padding:0 1.2rem 1.2rem;font-size:.87rem}

  /* Contact */
  .clayout{gap:2rem}
  .fcard{padding:1.8rem 1.4rem}
  .ftitle{font-size:1.4rem}
  .citems{gap:1.5rem}

  /* Footer */
  footer{padding:2rem 6vw;font-size:.75rem}

  /* Headings */
  .st{font-size:clamp(1.7rem,7vw,2.4rem)}
  .ss{font-size:.92rem;margin-bottom:2.5rem}
}

/* ── SMALL MOBILE (≤380px) ───────────────────── */
@media(max-width:380px){
  .tiles{grid-template-columns:1fr 1fr;gap:6px}
  .tile{padding:1.2rem 1rem;min-height:100px}
  .tn{font-size:2rem}
  h1{font-size:1.8rem}
  .bf,.bg{font-size:.76rem;padding:.75rem 1.2rem}
  .pcard{padding:1.4rem 1.2rem}
  .profile-card{padding:1.4rem}
}


/* TEAM TABS */
.team-tabs{display:flex;gap:4px;margin-bottom:2.5rem;background:rgba(6,81,78,.08);padding:5px;border-radius:12px;width:fit-content;flex-wrap:wrap}
.team-tab{background:none;border:none;padding:.65rem 1.4rem;border-radius:9px;font-family:var(--FB);font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--muted);cursor:pointer;transition:background .2s,color .2s;white-space:nowrap;display:flex;flex-direction:column;align-items:center;gap:2px;line-height:1.2}
.team-tab.active{background:#fff;color:var(--teal);box-shadow:0 1px 6px rgba(6,81,78,.12)}
.team-tab:hover:not(.active){color:var(--teal)}
.tab-role{font-size:.6rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);opacity:.7}
.team-tab.active .tab-role{opacity:1}
.team-panel{display:none}
.team-panel.active{display:block}
.team-panel .aleft p{font-size:.95rem;color:var(--muted);line-height:1.85;font-weight:300;margin-bottom:1.2rem}
/* Pricing fees note — inline in Growth card */
.psub-fees{font-size:.72rem;color:var(--citron);font-weight:600;letter-spacing:.04em;margin:.3rem 0 1.2rem;opacity:.9}
/* Enlarged testimony logos */
.tlogo{flex-shrink:0;height:70px;width:130px;display:flex;align-items:center;justify-content:center;border-radius:8px;overflow:hidden;background:#fff;padding:6px}
.tlogo img{width:100%;height:100%;object-fit:contain}
.tlogo-bow{padding:4px}
@media(max-width:600px){
  .team-tabs{width:100%}
  .team-tab{flex:1;text-align:center;padding:.6rem .8rem;font-size:.76rem}
  .tlogo{height:54px;width:90px}
}

/* TESTIMONIALS */
#testimonials{display:block;background:var(--teal-deep)}
#testimonials .ey{color:var(--citron)}
#testimonials .ey::after{background:var(--citron)}
#testimonials .st{color:var(--cream)}
#testimonials .st em{color:var(--citron)}
#testimonials .ss{color:rgba(248,242,236,.6)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch}
.tcard{background:rgba(255,255,255,.06);border:1px solid rgba(248,242,236,.1);border-radius:16px;padding:2.2rem;display:flex;flex-direction:column;gap:0}
.tquote{font-size:.9rem;color:rgba(248,242,236,.85);line-height:1.85;font-weight:300;font-style:italic;position:relative;padding-top:2rem;flex:1}
.tquote::before{content:'\201C';position:absolute;top:-.4rem;left:0;font-family:var(--FD);font-size:3.5rem;color:var(--citron);line-height:1}
.tauthor{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;border-top:1px solid rgba(248,242,236,.12);padding-top:1.4rem;margin-top:1.8rem}
.tinfo{flex:1;min-width:0}
.tname{font-size:.88rem;font-weight:600;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trole{font-size:.75rem;color:rgba(248,242,236,.5);margin-top:.25rem;font-weight:300}
@media(max-width:900px){.tgrid{grid-template-columns:1fr}}
