:root {
  --navy: #0e0f3b;
  --navy-2: #080925;
  --blue: #07407b;
  --sky: #7fcdee;
  --orange: #f7931e;
  --orange-2: #ffb14f;
  --white: #fff;
  --ink: #111432;
  --muted: #64677c;
  --mist: #f3f8fc;
  --line: #dce7f0;
  --radius: 24px;
  --shadow: 0 24px 70px rgba(14, 15, 59, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 86px; }
body { margin: 0; color: var(--ink); background: #fff; font-family: "Manrope", sans-serif; line-height: 1.6; overflow-x: hidden; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; position: relative; }
.section { padding: 120px 0; }
.dark-section { color: var(--white); background: var(--navy); }
.page-noise { pointer-events: none; position: fixed; inset: 0; z-index: 99; opacity: .025; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E"); }

.site-header { position: fixed; inset: 0 0 auto; z-index: 50; transition: .35s ease; }
.site-header.scrolled { background: rgba(255,255,255,.92); box-shadow: 0 10px 40px rgba(8,9,37,.08); backdrop-filter: blur(18px); }
.nav-wrap { width: min(1240px, calc(100% - 40px)); height: 88px; margin: auto; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 12px; color: var(--white); }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; background: linear-gradient(145deg, var(--sky), #2a7fbd); border-radius: 12px 12px 4px 12px; color: var(--navy); font: 800 24px/1 "Outfit"; box-shadow: inset 0 0 0 1px rgba(255,255,255,.35); }
.brand-copy { display: flex; flex-direction: column; line-height: 1.05; }
.brand-copy strong { font: 700 20px/1.1 "Outfit"; }
.brand-copy small { margin-top: 5px; font-size: 7px; letter-spacing: .19em; opacity: .68; }
.nav-links { display: flex; gap: 29px; align-items: center; }
.nav-links a { color: rgba(255,255,255,.7); font-size: 13px; font-weight: 600; position: relative; transition: .25s; }
.nav-links a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -8px; height: 2px; background: var(--orange); transition: .25s; }
.nav-links a:hover, .nav-links a.active { color: white; }
.nav-links a:hover::after, .nav-links a.active::after { right: 0; }
.site-header.scrolled .brand, .site-header.scrolled .nav-links a { color: var(--navy); }
.site-header.scrolled .nav-links a { opacity: .68; }
.site-header.scrolled .nav-links a.active, .site-header.scrolled .nav-links a:hover { opacity: 1; }
.nav-toggle { display: none; }

.btn { min-height: 54px; padding: 0 24px; display: inline-flex; align-items: center; justify-content: center; gap: 18px; border-radius: 12px; font-size: 14px; font-weight: 800; transition: transform .25s, box-shadow .25s, background .25s; }
.btn:hover { transform: translateY(-3px); }
.btn-orange { color: #1d1740; background: linear-gradient(135deg, var(--orange), var(--orange-2)); box-shadow: 0 12px 35px rgba(247,147,30,.25); }
.btn-orange:hover { box-shadow: 0 16px 40px rgba(247,147,30,.42); }
.btn-small { min-height: 42px; padding: 0 18px; gap: 9px; border-radius: 10px; font-size: 12px; }
.btn-large { min-height: 62px; padding: 0 30px; }
.btn-ghost { color: white; border: 1px solid rgba(255,255,255,.25); background: rgba(255,255,255,.05); }
.btn-ghost:hover { background: rgba(255,255,255,.1); }
.wa-dot { width: 8px; height: 8px; background: #24d366; border-radius: 50%; box-shadow: 0 0 0 4px rgba(36,211,102,.14); }

.hero { min-height: 850px; padding-top: 170px; position: relative; overflow: hidden; background: radial-gradient(circle at 72% 38%, rgba(7,64,123,.9), transparent 34%), linear-gradient(130deg, var(--navy-2), var(--navy) 52%, #092d59); }
.hero::before { content: ""; position: absolute; inset: 0; opacity: .06; background-image: linear-gradient(rgba(127,205,238,.5) 1px, transparent 1px), linear-gradient(90deg, rgba(127,205,238,.5) 1px, transparent 1px); background-size: 70px 70px; mask-image: linear-gradient(to right, transparent, #000 65%); }
.hero-grid { display: grid; grid-template-columns: .96fr 1.04fr; align-items: center; gap: 38px; }
.eyebrow { display: flex; align-items: center; gap: 11px; color: var(--sky); font-size: 11px; letter-spacing: .2em; font-weight: 800; }
.eyebrow::before { content: ""; width: 24px; height: 2px; background: var(--orange); }
.eyebrow.blue { color: var(--blue); }
.eyebrow.light { color: var(--sky); }
.hero h1, h2 { font-family: "Outfit", sans-serif; letter-spacing: -.045em; line-height: 1.03; margin: 0; }
.hero h1 { max-width: 650px; margin-top: 24px; font-size: clamp(56px, 6vw, 90px); font-weight: 600; }
.hero h1 span, h2 span { color: var(--sky); }
.hero-intro { max-width: 600px; margin: 25px 0 14px; color: rgba(255,255,255,.72); font-size: 17px; line-height: 1.7; }
.clarifier { color: white; display: flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 700; }
.clarifier span { width: 7px; height: 7px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 5px rgba(247,147,30,.12); }
.hero-actions { display: flex; gap: 13px; margin-top: 31px; }
.hero-metrics { display: flex; gap: 45px; margin-top: 44px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.12); }
.hero-metrics div { display: flex; flex-direction: column; }
.hero-metrics strong { font: 600 16px "Outfit"; }
.hero-metrics span { color: rgba(255,255,255,.48); font-size: 10px; margin-top: 4px; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(2px); }
.orb-one { width: 400px; height: 400px; right: -230px; top: 30px; border: 1px solid rgba(127,205,238,.18); box-shadow: 0 0 90px rgba(127,205,238,.08); }
.orb-two { width: 170px; height: 170px; left: 42%; bottom: 30px; background: rgba(7,64,123,.1); border: 1px solid rgba(255,255,255,.06); }

.hero-visual { height: 565px; position: relative; perspective: 1200px; }
.visual-glow { position: absolute; width: 430px; height: 430px; left: 10%; top: 8%; border-radius: 50%; background: var(--sky); opacity: .13; filter: blur(65px); }
.mockup { position: absolute; box-shadow: 0 30px 70px rgba(0,0,0,.35); }
.poster { width: 270px; height: 390px; left: 19%; top: 11%; padding: 27px; color: var(--navy); background: #eefaff; transform: rotate(-4deg); z-index: 3; animation: float 5.8s ease-in-out infinite; overflow: hidden; }
.poster::after { content: ""; position: absolute; width: 190px; height: 190px; border-radius: 50%; right: -75px; bottom: -55px; background: linear-gradient(145deg, var(--orange), #ffbd69); }
.mini-label { font-size: 7px; letter-spacing: .2em; }
.poster-logo, .tiny-mark { display: grid; place-items: center; font: 700 21px "Outfit"; color: white; background: var(--blue); }
.poster-logo { width: 49px; height: 49px; margin-top: 44px; border-radius: 13px 13px 3px 13px; }
.poster h3 { font: 600 35px/1.05 "Outfit"; letter-spacing: -.04em; margin: 24px 0; }
.poster-lines { display: grid; gap: 6px; }
.poster-lines i { display: block; width: 88px; height: 3px; background: var(--blue); opacity: .18; }
.poster-lines i:nth-child(2) { width: 65px; }
.card-stack { width: 250px; height: 155px; right: 2%; top: 6%; z-index: 4; transform: rotate(8deg); animation: float 6.5s ease-in-out -2s infinite; }
.business-card { width: 220px; height: 125px; position: absolute; border-radius: 4px; }
.bc-back { right: 0; top: 20px; background: linear-gradient(135deg, var(--blue), var(--sky)); transform: rotate(7deg); }
.bc-front { left: 0; top: 0; padding: 20px; display: flex; justify-content: space-between; flex-direction: column; background: white; color: var(--navy); }
.tiny-mark { width: 26px; height: 26px; font-size: 13px; border-radius: 7px 7px 2px 7px; }
.bc-front b { display: block; font: 700 8px "Outfit"; letter-spacing: .1em; }
.bc-front small { display: block; font-size: 6px; color: #8493a2; }
.package { width: 190px; height: 220px; right: 3%; bottom: 16%; padding: 24px; color: white; background: var(--blue); transform: rotate(3deg) skewY(-1deg); z-index: 5; animation: float 7s ease-in-out -1s infinite; }
.package::before { content: ""; position: absolute; width: 34px; height: 100%; left: -34px; top: -12px; background: #062e5a; transform: skewY(35deg); }
.package span { font-size: 6px; letter-spacing: .2em; opacity: .7; }
.package strong { display: block; margin-top: 30px; font: 600 24px/1.1 "Outfit"; }
.package i { position: absolute; left: 24px; bottom: 23px; width: 42px; height: 5px; background: var(--orange); }
.phone { width: 175px; height: 310px; left: 4%; bottom: 0; padding: 9px; border: 3px solid #172055; border-radius: 27px; background: #f8fbff; transform: rotate(-7deg); z-index: 2; animation: float 6.3s ease-in-out -3s infinite; }
.phone-top { width: 55px; height: 12px; border-radius: 0 0 9px 9px; margin: -9px auto 20px; background: #172055; }
.social-post { height: 220px; padding: 17px; color: white; background: linear-gradient(155deg, var(--navy), var(--blue)); position: relative; overflow: hidden; }
.social-post b { display: block; margin-top: 36px; font: 600 23px/1.08 "Outfit"; }
.social-post i { position: absolute; width: 130px; height: 130px; right: -65px; bottom: -50px; border-radius: 50%; background: var(--orange); }
.float-tag { position: absolute; z-index: 8; padding: 8px 13px; border: 1px solid rgba(255,255,255,.15); border-radius: 20px; color: white; background: rgba(12,23,66,.75); backdrop-filter: blur(9px); font-size: 9px; font-weight: 700; box-shadow: 0 12px 30px rgba(0,0,0,.2); animation: float 5s ease-in-out infinite; }
.float-tag::before { content: ""; display: inline-block; width: 5px; height: 5px; margin-right: 7px; border-radius: 50%; background: var(--sky); }
.tag-design { left: 0; top: 16%; }
.tag-print { right: 1%; top: 38%; animation-delay: -2s; }
.tag-pack { left: 22%; bottom: 4%; animation-delay: -1s; }
.tag-brand { right: 22%; bottom: 4%; animation-delay: -3s; }
@keyframes float { 0%,100% { translate: 0 0; } 50% { translate: 0 -12px; } }
.trust-strip { position: absolute; left: 0; right: 0; bottom: 0; border-top: 1px solid rgba(255,255,255,.1); background: rgba(6,8,35,.45); backdrop-filter: blur(10px); }
.trust-track { min-height: 72px; display: flex; align-items: center; justify-content: space-between; color: rgba(255,255,255,.63); font-size: 10px; letter-spacing: .08em; font-weight: 700; text-transform: uppercase; }
.trust-track i { width: 4px; height: 4px; border-radius: 50%; background: var(--orange); }
.scroll-cue { position: absolute; bottom: 93px; left: 50%; width: 22px; height: 38px; border: 1px solid rgba(255,255,255,.25); border-radius: 20px; }
.scroll-cue span { position: absolute; width: 3px; height: 6px; left: 8px; top: 8px; border-radius: 4px; background: var(--sky); animation: scroll 1.8s infinite; }
@keyframes scroll { 0% { opacity: 0; transform: translateY(0); } 50% { opacity: 1; } 100% { opacity: 0; transform: translateY(13px); } }

h2 { font-size: clamp(42px, 5vw, 66px); font-weight: 600; }
.section-copy h2, .section-heading h2 { margin: 20px 0 26px; }
.section-copy p { color: var(--muted); font-size: 15px; }
.section-copy .lead { color: var(--ink); font-size: 18px; line-height: 1.65; }
.split-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.about { overflow: hidden; background: linear-gradient(115deg, #fff 45%, #f5faff); }
.about-art { height: 560px; position: relative; }
.about-art::before { content: ""; position: absolute; width: 430px; height: 430px; top: 50px; left: 20px; border-radius: 50%; background: rgba(127,205,238,.18); filter: blur(30px); }
.paper { position: absolute; box-shadow: var(--shadow); }
.paper-main { width: 330px; height: 450px; left: 20px; top: 35px; z-index: 3; padding: 35px; background: white; transform: rotate(-4deg); }
.paper-main small { font-size: 8px; letter-spacing: .2em; color: var(--blue); }
.paper-main h3 { margin: 27px 0; font: 600 38px/1.04 "Outfit"; letter-spacing: -.04em; color: var(--navy); }
.paper-image { height: 220px; display: flex; flex-direction: column; justify-content: center; padding: 25px; background: linear-gradient(150deg, var(--navy), var(--blue)); overflow: hidden; position: relative; }
.paper-image::after { content: ""; position: absolute; width: 170px; height: 170px; right: -80px; bottom: -60px; border-radius: 50%; background: var(--orange); }
.paper-image span { color: white; font: 700 22px/1.1 "Outfit"; z-index: 1; }
.paper-image span:nth-child(2) { color: var(--sky); margin-left: 18px; }
.paper-image span:nth-child(3) { margin-left: 36px; }
.paper-blue { width: 210px; height: 270px; right: 0; top: 5px; z-index: 2; padding: 28px; color: white; background: var(--blue); transform: rotate(7deg); }
.paper-blue strong { font: 700 12px "Outfit"; color: var(--sky); }
.paper-blue span { position: absolute; bottom: 30px; left: 28px; font: 500 19px/1.2 "Outfit"; }
.paper-orange { width: 170px; height: 175px; right: 20px; bottom: 5px; z-index: 4; padding: 28px; color: var(--navy); background: var(--orange); transform: rotate(4deg); font: 700 24px/1.04 "Outfit"; }
.color-chip { position: absolute; left: 11px; bottom: 4px; z-index: 5; display: flex; gap: 7px; padding: 12px; background: white; box-shadow: 0 13px 30px rgba(14,15,59,.15); }
.color-chip i { width: 22px; height: 22px; background: var(--navy); }
.color-chip i:nth-child(2) { background: var(--blue); }.color-chip i:nth-child(3) { background: var(--sky); }.color-chip i:nth-child(4) { background: var(--orange); }
.feature-list { margin: 30px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 13px; }
.feature-list span { font-size: 12px; font-weight: 700; }
.feature-list i { display: inline-grid; width: 20px; height: 20px; margin-right: 7px; place-items: center; color: var(--blue); background: rgba(127,205,238,.22); border-radius: 50%; font-style: normal; font-size: 10px; }
.text-link { display: inline-flex; gap: 12px; align-items: center; color: var(--blue); font-size: 12px; font-weight: 800; border-bottom: 1px solid rgba(7,64,123,.3); padding-bottom: 5px; }
.text-link span { transition: .2s; }.text-link:hover span { transform: translateX(4px); }

.services { background: var(--mist); }
.section-heading { margin-bottom: 55px; display: flex; align-items: end; justify-content: space-between; gap: 60px; }
.section-heading > p { max-width: 400px; color: var(--muted); font-size: 14px; margin: 0 0 8px; }
.section-heading.compact { align-items: center; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card { min-height: 375px; padding: 34px; position: relative; border: 1px solid #e0eaf1; border-radius: var(--radius); background: white; overflow: hidden; transition: transform .35s, box-shadow .35s, border-color .35s; }
.service-card::after { content: ""; position: absolute; inset: auto 0 0; height: 4px; background: linear-gradient(90deg, var(--blue), var(--sky), var(--orange)); transform: scaleX(0); transform-origin: left; transition: .35s; }
.service-card:hover { transform: translateY(-9px); border-color: rgba(127,205,238,.6); box-shadow: var(--shadow); }
.service-card:hover::after { transform: scaleX(1); }
.service-card.featured { color: white; background: linear-gradient(145deg, var(--navy), var(--blue)); border-color: transparent; }
.service-card.featured p { color: rgba(255,255,255,.67); }
.service-card.featured a { color: var(--sky); }
.card-number { position: absolute; right: 30px; top: 28px; color: #becbd5; font: 600 11px "Outfit"; }
.featured .card-number { color: rgba(255,255,255,.35); }
.service-card h3 { margin: 38px 0 14px; font: 600 22px "Outfit"; }
.service-card p { min-height: 110px; color: var(--muted); font-size: 12px; line-height: 1.7; }
.service-card a { display: inline-flex; gap: 8px; margin-top: 15px; color: var(--blue); font-size: 11px; font-weight: 800; }
.service-card a span { transition: .25s; }.service-card:hover a span { transform: translate(3px,-3px); }
.icon { width: 54px; height: 54px; position: relative; border-radius: 15px; background: rgba(127,205,238,.2); }
.featured .icon { background: rgba(255,255,255,.1); }
.icon span, .icon::before, .icon::after { content: ""; position: absolute; border: 2px solid var(--blue); transition: .3s; }
.featured .icon span, .featured .icon::before, .featured .icon::after { border-color: var(--sky); }
.icon-pen span { width: 8px; height: 30px; left: 23px; top: 11px; transform: rotate(43deg); border-radius: 4px; }.icon-pen::after { width: 4px; height: 4px; left: 11px; bottom: 10px; border-radius: 50%; background: var(--orange); border: 0; }
.icon-print span { width: 28px; height: 20px; left: 13px; top: 19px; border-radius: 3px; }.icon-print::before { width: 20px; height: 12px; left: 17px; top: 8px; }.icon-print::after { width: 19px; height: 13px; left: 17px; bottom: 6px; background: var(--navy); }
.icon-layers span, .icon-layers::before, .icon-layers::after { width: 25px; height: 18px; left: 14px; transform: skewY(-25deg); }.icon-layers span { top: 12px; }.icon-layers::before { top: 18px; }.icon-layers::after { top: 24px; }
.icon-social span { width: 25px; height: 25px; left: 14px; top: 14px; border-radius: 7px; }.icon-social::before { width: 7px; height: 7px; left: 23px; top: 23px; border-radius: 50%; }.icon-social::after { width: 3px; height: 3px; left: 34px; top: 18px; border-radius: 50%; background: var(--orange); border: 0; }
.icon-web span { width: 32px; height: 24px; left: 11px; top: 13px; border-radius: 3px; }.icon-web::before { width: 17px; left: 18px; bottom: 10px; border-width: 0 0 2px; }.icon-web::after { width: 6px; height: 6px; left: 16px; top: 19px; background: var(--sky); border: 0; border-radius: 50%; }
.icon-box span { width: 27px; height: 25px; left: 13px; top: 16px; transform: skewY(8deg); }.icon-box::before { width: 20px; height: 11px; left: 17px; top: 10px; transform: rotate(24deg); }.icon-box::after { height: 25px; left: 27px; top: 16px; border-width: 0 0 0 2px; }
.service-card:hover .icon { transform: rotate(-4deg) scale(1.05); }

.products { background: white; }
.product-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.product-card { min-height: 195px; padding: 17px; border: 1px solid var(--line); border-radius: 18px; background: #fbfdff; transition: .3s; }
.product-card:hover { transform: translateY(-6px); border-color: var(--sky); box-shadow: 0 18px 38px rgba(7,64,123,.1); }
.product-card > span { display: block; margin-top: 14px; font-size: 11px; font-weight: 800; }
.product-visual { height: 125px; position: relative; overflow: hidden; border-radius: 12px; background: linear-gradient(145deg, #eaf7fc, #d8ecf6); }
.product-visual i { position: absolute; display: block; box-shadow: 0 9px 20px rgba(14,15,59,.15); }
.pv-card i { width: 75px; height: 45px; left: 20px; top: 30px; background: var(--navy); transform: rotate(-8deg); }.pv-card i+ i { left: 55px; top: 48px; background: white; transform: rotate(8deg); }
.pv-brochure i { width: 45px; height: 80px; top: 20px; background: var(--blue); }.pv-brochure i:nth-child(1){left:28px;transform:skewY(-7deg)}.pv-brochure i:nth-child(2){left:73px;background:white}.pv-brochure i:nth-child(3){left:118px;width:22px;background:var(--orange);transform:skewY(7deg)}
.pv-flyer i { width: 82px; height: 100px; left: 46px; top: 12px; background: linear-gradient(160deg,var(--navy) 55%,var(--orange) 56%); transform: rotate(5deg); }
.pv-poster i { width: 105px; height: 75px; left: 34px; top: 25px; background: var(--blue); border: 7px solid white; }
.pv-menu i { width: 60px; height: 95px; top: 15px; background: white; }.pv-menu i:first-child { left: 30px; transform: rotate(-6deg); }.pv-menu i:last-child { left: 85px; background: var(--navy); transform: rotate(7deg); }
.pv-box i { width: 80px; height: 70px; left: 48px; top: 33px; background: var(--orange); transform: skewY(-7deg); }.pv-box i::after { content:"EP"; padding: 20px; font:700 18px "Outfit"; color:var(--navy); }
.pv-stationery i { background:white; }.pv-stationery i:first-child { width:85px;height:100px;left:26px;top:13px;transform:rotate(-4deg); }.pv-stationery i:last-child { width:65px;height:42px;left:77px;top:59px;background:var(--blue);transform:rotate(8deg); }
.pv-label i { border-radius:50%; background:var(--orange); }.pv-label i:nth-child(1){width:55px;height:55px;left:25px;top:28px}.pv-label i:nth-child(2){width:45px;height:45px;left:76px;top:50px;background:var(--blue)}.pv-label i:nth-child(3){width:30px;height:30px;left:112px;top:23px;background:white}
.pv-event i:first-child { width:80px;height:88px;left:25px;top:19px;background:var(--navy);transform:rotate(-4deg) }.pv-event i:last-child { width:64px;height:50px;left:85px;top:45px;background:var(--orange);transform:rotate(8deg) }
.pv-gift i { width:65px;height:82px;left:56px;top:25px;background:var(--blue);border-radius:5px 5px 15px 15px }.pv-gift i::before { content:"";position:absolute;width:35px;height:25px;left:15px;top:-13px;border:5px solid var(--blue);border-radius:50% }
.product-more { margin-top: 20px; padding: 15px 20px; text-align: center; color: var(--muted); border-radius: 10px; background: var(--mist); font-size: 11px; }

.why { position: relative; overflow: hidden; background: radial-gradient(circle at 50% -15%, rgba(7,64,123,.8), transparent 45%), var(--navy-2); }
.why::before { content: ""; position: absolute; inset: 0; opacity: .07; background-image: linear-gradient(30deg, transparent 48%, var(--sky) 49%, transparent 51%); background-size: 70px 70px; }
.why-glow { position: absolute; width: 480px; height: 480px; right: -180px; bottom: -180px; background: var(--blue); border-radius: 50%; filter: blur(90px); opacity: .3; }
.center-heading { max-width: 700px; margin: 0 auto 58px; text-align: center; }
.center-heading .eyebrow { justify-content: center; }.center-heading h2 { margin: 20px 0; }.center-heading p { color: rgba(255,255,255,.55); font-size: 14px; }
.center-heading.dark p { color: var(--muted); }
.benefit-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }
.benefit { min-height: 260px; padding: 30px; position: relative; border: 1px solid rgba(255,255,255,.1); border-radius: 20px; background: rgba(255,255,255,.045); backdrop-filter: blur(6px); transition: .3s; }
.benefit:hover { transform: translateY(-7px); background: rgba(255,255,255,.08); border-color: rgba(127,205,238,.4); }
.benefit > span { position: absolute; top: 27px; right: 27px; color: rgba(255,255,255,.27); font-size: 9px; }
.benefit-icon { width: 42px; height: 42px; display: grid; place-items: center; color: var(--sky); border-radius: 12px; background: rgba(127,205,238,.1); }
.benefit h3 { margin: 27px 0 11px; font: 600 19px "Outfit"; }
.benefit p { color: rgba(255,255,255,.52); font-size: 11px; }

.process { background: #fff; }
.timeline { display: grid; grid-template-columns: repeat(4, 1fr); position: relative; margin-top: 90px; }
.timeline-line { position: absolute; left: 8%; right: 8%; top: 0; height: 2px; background: var(--line); }
.timeline-line span { display: block; height: 100%; width: 0; background: linear-gradient(90deg,var(--blue),var(--sky),var(--orange)); transition: width 1.8s ease; }
.timeline.in-view .timeline-line span { width: 100%; }
.step { padding: 0 25px; position: relative; text-align: center; }
.step-dot { width: 30px; height: 30px; margin: -14px auto 35px; display: grid; place-items: center; position: relative; z-index: 2; border-radius: 50%; color: var(--blue); background: white; border: 2px solid var(--sky); font: 700 8px "Outfit"; box-shadow: 0 0 0 8px white; }
.step-icon { width: 66px; height: 66px; margin: auto; display: grid; place-items: center; color: var(--blue); border-radius: 19px; background: var(--mist); font-size: 25px; transition: .3s; }
.step:hover .step-icon { transform: rotate(-5deg) scale(1.06); color: white; background: var(--blue); }
.step h3 { margin: 22px 0 10px; font: 600 18px "Outfit"; }
.step p { color: var(--muted); font-size: 11px; }

.cta-banner { min-height: 440px; padding: 90px 0; display: flex; align-items: center; color: white; position: relative; overflow: hidden; background: linear-gradient(120deg, var(--navy-2), var(--blue)); }
.cta-banner::after { content: ""; position: absolute; width: 500px; height: 500px; right: -90px; top: -190px; border-radius: 50%; border: 80px solid rgba(127,205,238,.1); }
.cta-pattern { position: absolute; width: 260px; height: 260px; left: 48%; bottom: -140px; border-radius: 50%; background: var(--orange); filter: blur(70px); opacity: .25; }
.cta-content { display: flex; justify-content: space-between; align-items: center; gap: 60px; z-index: 2; }
.cta-content h2 { margin: 18px 0; font-size: clamp(46px,5vw,70px); }
.cta-content p { max-width: 600px; color: rgba(255,255,255,.62); font-size: 14px; }
.cta-actions { min-width: 270px; display: flex; flex-direction: column; align-items: center; gap: 18px; }
.call-link { font-size: 12px; color: rgba(255,255,255,.7); border-bottom: 1px solid rgba(255,255,255,.25); }

.contact { background: linear-gradient(115deg, #fff, #f3f9fd); }
.contact-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 100px; align-items: center; }
.contact-copy h2 { margin: 20px 0 27px; }.contact-copy p { max-width: 500px; color: var(--muted); margin-bottom: 32px; font-size: 14px; }
.contact-details { padding: 38px; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: var(--shadow); }
.contact-item { padding: 5px 0 20px; border-bottom: 1px solid var(--line); }
.contact-item small { display: block; margin-bottom: 12px; color: var(--blue); font-size: 8px; letter-spacing: .15em; font-weight: 800; }
.contact-item a { font: 600 18px "Outfit"; }.contact-item p { margin: 0; color: var(--muted); font-size: 11px; }
.map-placeholder { grid-column: 1/-1; height: 230px; display: grid; place-items: center; position: relative; overflow: hidden; border-radius: 15px; background: #eef5f9; }
.map-lines { position: absolute; inset: -40px; opacity: .5; background-image: linear-gradient(25deg,transparent 47%,#c2d8e5 48%,#c2d8e5 51%,transparent 52%),linear-gradient(115deg,transparent 47%,#d2e4ed 48%,#d2e4ed 51%,transparent 52%); background-size: 90px 70px; transform: rotate(6deg); }
.map-pin { width: 48px; height: 48px; display: grid; place-items: center; z-index: 2; color: white; border-radius: 50% 50% 50% 8px; background: var(--blue); transform: rotate(-45deg); font: 700 20px "Outfit"; box-shadow: 0 12px 25px rgba(7,64,123,.25); }
.map-pin::first-letter { transform: rotate(45deg); }
.map-placeholder p { position: absolute; bottom: 12px; z-index: 2; margin: 0; color: var(--muted); font-size: 9px; }

.footer { padding: 80px 0 25px; color: white; background: var(--navy-2); }
.footer-grid { display: grid; grid-template-columns: 1.7fr .8fr 1.2fr 1fr; gap: 70px; }
.footer-brand p { max-width: 310px; margin: 24px 0; color: rgba(255,255,255,.48); font-size: 11px; }
.footer h4 { margin: 0 0 22px; color: var(--sky); font: 600 12px "Outfit"; }
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a, .footer-contact a, .footer-contact p { color: rgba(255,255,255,.5); font-size: 10px; transition: .2s; }
.footer-links a:hover, .footer-contact a:hover { color: white; transform: translateX(3px); }
.footer-contact p { margin: 17px 0; line-height: 1.8; }
.footer-contact span { font-size: 9px; color: var(--orange); letter-spacing: .15em; }
.footer-bottom { margin-top: 65px; padding-top: 22px; display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.08); color: rgba(255,255,255,.3); font-size: 9px; }
.floating-wa { position: fixed; right: 22px; bottom: 22px; z-index: 40; height: 48px; padding: 0 16px 0 8px; display: flex; align-items: center; gap: 9px; color: white; border-radius: 30px; background: #1fbd62; box-shadow: 0 14px 35px rgba(31,189,98,.35); transition: .25s; }
.floating-wa:hover { transform: translateY(-4px); }
.floating-wa span { width: 33px; height: 33px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.17); font-size: 20px; }
.floating-wa b { font-size: 10px; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .75s ease, transform .75s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }
.service-grid .reveal:nth-child(2), .benefit-grid .reveal:nth-child(2), .product-grid .reveal:nth-child(2) { transition-delay: .08s; }
.service-grid .reveal:nth-child(3), .benefit-grid .reveal:nth-child(3), .product-grid .reveal:nth-child(3) { transition-delay: .16s; }
.service-grid .reveal:nth-child(5), .benefit-grid .reveal:nth-child(5) { transition-delay: .08s; }
.service-grid .reveal:nth-child(6), .benefit-grid .reveal:nth-child(6) { transition-delay: .16s; }

@media (max-width: 980px) {
  .nav-links { position: fixed; inset: 0; display: flex; flex-direction: column; justify-content: center; gap: 27px; background: rgba(8,9,37,.98); transform: translateX(100%); transition: .35s; }
  .nav-links.open { transform: translateX(0); }
  .nav-links a, .site-header.scrolled .nav-links a { color: white; font: 600 22px "Outfit"; opacity: 1; }
  .nav-toggle { width: 42px; height: 42px; display: block; position: relative; z-index: 3; border: 0; border-radius: 10px; background: rgba(255,255,255,.1); }
  .nav-toggle span { width: 18px; height: 2px; position: absolute; left: 12px; top: 16px; background: white; transition: .3s; }
  .nav-toggle span:last-child { top: 24px; }
  .site-header.scrolled .nav-toggle { background: var(--navy); }
  .nav-toggle.open span:first-child { top: 20px; transform: rotate(45deg); }.nav-toggle.open span:last-child { top: 20px; transform: rotate(-45deg); }
  .nav-cta { display: none; }
  .hero { min-height: 1180px; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-copy { text-align: center; }
  .hero-copy .eyebrow, .clarifier { justify-content: center; }
  .hero-intro { margin-left: auto; margin-right: auto; }
  .hero-actions, .hero-metrics { justify-content: center; }
  .hero-visual { max-width: 640px; width: 100%; margin: 0 auto; }
  .split-layout, .contact-grid { grid-template-columns: 1fr; gap: 65px; }
  .about-art { max-width: 590px; width: 100%; margin: auto; order: 2; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .product-grid { grid-template-columns: repeat(3, 1fr); }
  .benefit-grid { grid-template-columns: 1fr 1fr; }
  .timeline { grid-template-columns: 1fr 1fr; gap: 70px 0; }
  .timeline-line { display: none; }
  .step-dot { margin-top: 0; }
  .cta-content { flex-direction: column; align-items: flex-start; }
  .cta-actions { align-items: flex-start; }
  .footer-grid { grid-template-columns: 1.6fr 1fr 1fr; }
  .footer-contact { grid-column: 2; }
}

@media (max-width: 640px) {
  .container, .nav-wrap { width: min(100% - 28px, 1180px); }
  .section { padding: 85px 0; }
  .nav-wrap { height: 74px; }
  .brand-mark { width: 37px; height: 37px; font-size: 20px; }
  .brand-copy strong { font-size: 18px; }
  .hero { min-height: 1080px; padding-top: 126px; }
  .hero h1 { font-size: 48px; }
  .hero-intro { font-size: 14px; }
  .clarifier { font-size: 10px; }
  .hero-actions { flex-direction: column; max-width: 300px; margin-left: auto; margin-right: auto; }
  .hero-metrics { gap: 20px; text-align: left; }
  .hero-metrics strong { font-size: 13px; }
  .hero-visual { height: 425px; transform: scale(.84); transform-origin: top center; margin-bottom: -60px; }
  .poster { left: 17%; width: 230px; height: 340px; }
  .poster h3 { font-size: 30px; }
  .card-stack { right: -15%; transform: rotate(8deg) scale(.8); }
  .package { right: -2%; bottom: 9%; transform: rotate(3deg) scale(.82); }
  .phone { left: -8%; transform: rotate(-7deg) scale(.8); }
  .tag-design { left: -5%; }.tag-print { right: -2%; }
  .trust-track { overflow: hidden; gap: 25px; justify-content: flex-start; }
  .trust-track span { flex: 0 0 auto; }
  .trust-track span:nth-of-type(n+4), .trust-track i:nth-of-type(n+3) { display: none; }
  .scroll-cue { display: none; }
  h2 { font-size: 40px; }
  .split-layout { gap: 40px; }
  .section-copy h2 { margin-bottom: 20px; }
  .feature-list { grid-template-columns: 1fr; }
  .about-art { height: 430px; transform: scale(.78); transform-origin: top left; width: 127%; margin-bottom: -90px; }
  .section-heading { display: block; margin-bottom: 35px; }
  .section-heading > p { margin-top: 20px; }
  .section-heading.compact .text-link { margin-top: 10px; }
  .service-grid, .benefit-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 340px; }
  .service-card p { min-height: auto; }
  .product-grid { grid-template-columns: 1fr 1fr; }
  .product-card { min-height: 170px; }
  .product-visual { height: 105px; }
  .timeline { display: block; margin-top: 55px; padding-left: 34px; }
  .timeline::before { content: ""; position: absolute; left: 13px; top: 10px; bottom: 70px; width: 2px; background: linear-gradient(var(--blue),var(--sky),var(--orange)); }
  .step { min-height: 210px; text-align: left; padding: 0 0 20px 35px; }
  .step-dot { position: absolute; left: -35px; top: 2px; margin: 0; box-shadow: 0 0 0 7px white; }
  .step-icon { margin: 0; width: 54px; height: 54px; }
  .cta-banner { padding: 75px 0; }
  .cta-content h2 { font-size: 44px; }
  .contact-details { grid-template-columns: 1fr; padding: 24px; }
  .map-placeholder { grid-column: auto; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 45px 25px; }
  .footer-brand { grid-column: 1/-1; }
  .footer-contact { grid-column: auto; }
  .footer-bottom { gap: 20px; align-items: flex-end; }
  .footer-bottom span:last-child { text-align: right; }
  .floating-wa b { display: none; }
  .floating-wa { width: 50px; padding: 0; justify-content: center; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
