/* ─── OC8 Finance | Design System ─── */
:root {
  --navy:#193342;--teal:#2b7261;--forest:#184b4a;--dark:#262b2d;
  --muted:#6b7a76;--border:#d8e0dc;--off-white:#f8f8f8;--light-bg:#f2f4f3;
  --white:#ffffff;--green-light:#87e9b5;
  --shadow:0 18px 45px rgba(25,51,66,.08);--shadow-sm:0 4px 16px rgba(25,51,66,.06);
  --radius-xl:24px;--radius-lg:18px;--radius-md:12px;--radius-sm:8px;
  --container:1180px;--grotesk:"Space Grotesk",sans-serif;--sora:"Sora",sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sora);color:var(--dark);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}

/* LAYOUT */
.container{width:min(var(--container),calc(100% - 40px));margin:0 auto}
.section{padding:96px 0}.section-tight{padding:56px 0}
.section-muted{background:var(--light-bg)}.section-dark{background:var(--navy);color:var(--white)}.section-forest{background:var(--forest);color:var(--white)}

/* TYPOGRAPHY */
.eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;font-family:var(--grotesk);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal);flex-shrink:0}
.eyebrow.centered{justify-content:center}
.section-dark .eyebrow,.section-forest .eyebrow{color:rgba(255,255,255,.72)}
.section-dark .eyebrow::before,.section-forest .eyebrow::before{background:rgba(255,255,255,.5)}
.headline-xl,.headline-lg,.headline-md{font-family:var(--grotesk);color:var(--navy);letter-spacing:-.03em;line-height:1.06}
.section-dark .headline-lg,.section-forest .headline-lg,.section-dark .headline-md,.section-forest .headline-md{color:var(--white)}
.headline-xl{font-size:clamp(2.8rem,5vw,5rem);font-weight:700}
.headline-lg{font-size:clamp(2rem,3vw,3.1rem);font-weight:700}
.headline-md{font-size:clamp(1.3rem,2vw,1.7rem);font-weight:700}
.body-lg{font-size:1.03rem;line-height:1.85;color:var(--muted);font-weight:300}
.dark-copy{color:rgba(255,255,255,.75)}.accent{color:var(--teal)}
.lead{color:rgba(255,255,255,.6);max-width:580px;font-size:1.03rem;line-height:1.85;font-weight:300;margin-top:1rem}

/* BUTTONS */
.btn-row{display:flex;gap:14px;flex-wrap:wrap}.btn-row.center{justify-content:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:var(--radius-sm);font-family:var(--grotesk);font-size:14px;font-weight:700;transition:.2s ease;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--teal);color:var(--white)}.btn-primary:hover{background:var(--forest);transform:translateY(-1px)}
.btn-secondary{background:transparent;border-color:var(--border);color:var(--navy)}.btn-secondary:hover{border-color:var(--teal);color:var(--teal)}
.btn-appstore{display:inline-flex;align-items:center;gap:12px;background:var(--white);color:var(--navy);padding:12px 20px;border-radius:var(--radius-md);box-shadow:0 4px 20px rgba(0,0,0,.15);transition:.2s ease}
.btn-appstore:hover{background:var(--off-white);transform:translateY(-2px)}
.btn-appstore-sub{display:block;font-size:10px;font-weight:500;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}
.btn-appstore-name{display:block;font-family:var(--grotesk);font-size:16px;font-weight:700;color:var(--navy);line-height:1.2}

/* NAV */
.site-nav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(216,224,220,.85);transition:box-shadow .3s}
.nav-wrap{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:34px;width:auto;display:block}
.brand-mark-img{height:38px;width:38px;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links>li{position:relative}
.nav-links a{display:flex;align-items:center;gap:4px;padding:8px 12px;font-family:var(--grotesk);font-size:14px;font-weight:500;color:var(--muted);border-radius:var(--radius-sm);transition:color .2s,background .2s}
.nav-links a:hover{color:var(--navy);background:rgba(25,51,66,.04)}
.nav-cta{padding:11px 18px!important;background:var(--teal)!important;color:var(--white)!important;font-weight:700!important;border-radius:var(--radius-sm)!important}
.nav-cta:hover{background:var(--forest)!important}
.nav-dropdown-toggle svg{transition:transform .2s}
.nav-dropdown:hover .nav-dropdown-toggle svg{transform:rotate(180deg)}
.dropdown-menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);min-width:560px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(25,51,66,.14);padding:1.5rem;display:grid;grid-template-columns:1fr 1fr 1fr;gap:.25rem;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s,visibility .2s;z-index:300}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown-group{padding:.5rem 0}
.dropdown-group-label{display:block;font-family:var(--grotesk);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);padding:.25rem .75rem;margin-bottom:.25rem;border-left:2px solid var(--teal)}
.dropdown-item{display:block;padding:.5rem .75rem;border-radius:var(--radius-sm);font-family:var(--grotesk);font-size:13px;font-weight:500;color:var(--navy);transition:background .15s,color .15s}
.dropdown-item:hover{background:var(--light-bg);color:var(--teal)}

/* HAMBURGER */
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;border-radius:8px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-mobile{display:none;flex-direction:column;padding:16px 0 20px;border-top:1px solid var(--border)}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:11px 20px;font-family:var(--grotesk);font-size:15px;font-weight:500;color:var(--muted)}
.nav-mobile a:hover{color:var(--navy)}
.mobile-section{padding:8px 20px 4px;font-family:var(--grotesk);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal)}
.mobile-cta{margin:12px 20px 0!important;padding:13px 18px!important;border-radius:8px;background:var(--teal);color:var(--white)!important;font-weight:700!important;text-align:center}

/* HERO */
.hero{padding:72px 0 94px;background:linear-gradient(180deg,var(--off-white) 0%,var(--white) 100%);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero-copy{max-width:680px}.hero-sub{margin:20px 0 28px;max-width:620px}
.hero-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.meta-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.8);font-family:var(--grotesk);font-size:12px;font-weight:600;color:var(--navy)}
.meta-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);flex-shrink:0}

/* PAGE HERO */
.page-hero{padding:72px 0 56px;background:var(--navy);position:relative;overflow:hidden}
.page-hero h1{font-family:var(--grotesk);font-size:clamp(2.2rem,4vw,3.6rem);font-weight:700;line-height:1.1;color:var(--white);letter-spacing:-.03em;margin-bottom:1.2rem}
.page-hero h1 em{color:rgba(43,114,97,.9);font-style:normal}

/* SYMBOL DECOR */
.symbol-decor{position:absolute;pointer-events:none;user-select:none;opacity:.05}
.hero .symbol-decor{right:-80px;bottom:-60px;width:480px;height:480px}
.page-hero .symbol-decor{right:-60px;top:50%;transform:translateY(-50%);width:400px;height:400px;opacity:.06}
.cta-block .symbol-decor{right:-40px;bottom:-40px;width:300px;height:300px;opacity:.04}

/* DASHBOARD */
.dashboard{border:1px solid var(--border);border-radius:var(--radius-xl);background:rgba(255,255,255,.92);box-shadow:var(--shadow);overflow:hidden}
.dashboard-top{padding:16px 20px;background:rgba(248,248,248,.94);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px}
.dashboard-title{font-family:var(--grotesk);font-size:13px;font-weight:700;color:var(--navy)}
.dashboard-status{font-family:var(--grotesk);font-size:12px;font-weight:700;color:var(--teal)}
.dashboard-status.light{color:rgba(255,255,255,.84)}
.dashboard-body{padding:20px}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.kpi-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--white);padding:18px}
.kpi-label{font-family:var(--grotesk);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.kpi-value{font-family:var(--grotesk);font-size:2rem;font-weight:700;letter-spacing:-.03em;color:var(--navy);line-height:1;margin-bottom:8px}
.kpi-note{font-size:13px;color:var(--muted)}.kpi-note.positive{color:var(--teal);font-weight:600}
.dashboard-lower{display:grid;grid-template-columns:1.15fr .85fr;gap:14px}
.panel{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--white);padding:18px}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.panel-title{font-family:var(--grotesk);font-size:13px;font-weight:700;color:var(--navy)}
.panel-tag{padding:4px 10px;border-radius:999px;background:rgba(43,114,97,.08);color:var(--teal);font-family:var(--grotesk);font-size:11px;font-weight:700}
.mini-bars,.mockup-bars{display:flex;align-items:flex-end;gap:6px;height:100px}
.mini-bars span,.mockup-bars span{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(180deg,rgba(43,114,97,.9),rgba(43,114,97,.2))}
.alert-list{display:grid;gap:8px}
.alert-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid rgba(216,224,220,.7);font-size:13px;color:var(--muted)}
.alert-item:last-child{border-bottom:0;padding-bottom:0}
.alert-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);margin-top:5px;flex-shrink:0}
.dashboard-footer{margin-top:14px;padding-top:14px;border-top:1px solid rgba(216,224,220,.8);font-size:13px;color:var(--muted);font-style:italic}

/* GRIDS */
.split-header{display:grid;grid-template-columns:1fr 1fr;align-items:end;gap:20px;margin-bottom:48px}
.problem-grid{display:grid;grid-template-columns:.95fr 1.05fr;align-items:start;gap:40px}
.compare-grid{display:grid;grid-template-columns:.92fr 1.08fr;align-items:center;gap:40px}
.tech-grid{display:grid;grid-template-columns:.95fr 1.05fr;align-items:center;gap:40px}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.service-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}

/* CARDS */
.feature-card,.step-card,.team-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--white);padding:28px;transition:box-shadow .2s,transform .2s}
.feature-card:hover,.step-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.feature-card h3,.step-card h3,.team-card h3{font-family:var(--grotesk);font-size:18px;color:var(--navy);margin-bottom:8px;line-height:1.2}
.feature-card p,.step-card p{font-size:14px;color:var(--muted);line-height:1.75}
.feature-number,.step-number{display:inline-grid;place-items:center;width:42px;height:42px;margin-bottom:16px;border-radius:11px;background:rgba(43,114,97,.1);color:var(--teal);font-family:var(--grotesk);font-size:14px;font-weight:700}

/* SERVICE GRID */
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.service-grid.cols-3{grid-template-columns:repeat(3,1fr)}.service-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.service-card{background:var(--white);padding:28px;border:0;border-radius:0;position:relative;overflow:hidden;transition:background .2s;display:block;color:inherit}
.service-card::after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.service-card:hover{background:var(--light-bg)}.service-card:hover::after{transform:scaleX(1)}
.service-icon{display:inline-grid;place-items:center;width:42px;height:42px;margin-bottom:16px;border-radius:11px;background:rgba(43,114,97,.1);color:var(--teal);font-family:var(--grotesk);font-size:14px;font-weight:700}
.service-card h3{font-family:var(--grotesk);font-size:16px;color:var(--navy);margin-bottom:8px;line-height:1.2}
.service-card p{font-size:13px;color:var(--muted);line-height:1.7}
.group-title{margin-bottom:14px;padding-left:14px;border-left:3px solid var(--teal);font-family:var(--grotesk);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}

/* TEAM */
.team-card-inner{display:flex;gap:1.8rem;align-items:flex-start}
.team-photo-wrap{width:110px;height:110px;border-radius:50%;overflow:hidden;flex-shrink:0;border:3px solid var(--border);box-shadow:0 8px 24px rgba(25,51,66,.12)}
.team-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top}
.team-role{margin-bottom:8px;font-family:var(--grotesk);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal)}
.team-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.team-tag{background:rgba(43,114,97,.08);border:1px solid rgba(43,114,97,.15);border-radius:999px;padding:4px 10px;font-size:11px;font-family:var(--grotesk);font-weight:600;color:var(--teal)}

/* SOCIAL PROOF */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:40px}
.stat-cell{background:var(--white);padding:2rem 1.5rem;text-align:center}
.stat-num{font-family:var(--grotesk);font-size:2.4rem;font-weight:700;color:var(--teal);line-height:1;margin-bottom:.4rem}
.stat-label{font-size:.8rem;color:var(--muted);font-weight:300;line-height:1.4}
.logos-row{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap;padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.logo-placeholder{height:32px;padding:0 1.5rem;background:var(--light-bg);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--grotesk);font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.06em}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:box-shadow .2s}
.testimonial-card:hover{box-shadow:var(--shadow)}
.testimonial-text{font-size:.95rem;line-height:1.75;color:var(--dark);font-weight:300;margin-bottom:20px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--light-bg);border:2px solid var(--border);display:grid;place-items:center;font-family:var(--grotesk);font-size:14px;font-weight:700;color:var(--navy);flex-shrink:0}
.testimonial-name{font-family:var(--grotesk);font-size:14px;font-weight:700;color:var(--navy)}
.testimonial-role{font-size:12px;color:var(--muted)}

/* NUMBER LIST */
.number-list{display:grid;gap:12px}
.number-item{display:grid;grid-template-columns:52px 1fr;gap:14px;padding:16px 18px;border-radius:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1)}
.number-badge{width:38px;height:28px;display:grid;place-items:center;border-radius:8px;background:rgba(43,114,97,.16);color:var(--teal);font-family:var(--grotesk);font-size:12px;font-weight:700}
.number-item p{color:rgba(255,255,255,.82);font-size:15px;line-height:1.6}
.quote-strong{margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);font-family:var(--grotesk);font-size:1.28rem;font-weight:700;line-height:1.3;color:var(--white)}

/* COMPARE */
.compare-wrap{border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);overflow:hidden;background:rgba(255,255,255,.03)}
.compare-table{width:100%;border-collapse:collapse}
.compare-table th,.compare-table td{padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;font-size:14px}
.compare-table th{font-family:var(--grotesk);font-size:12px;text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.compare-table th:first-child,.compare-table td:first-child{color:rgba(255,255,255,.45)}
.compare-table th:last-child,.compare-table td:last-child{color:rgba(255,255,255,.9);font-weight:500}

/* TECH */
.tech-panel{border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);background:rgba(255,255,255,.06);padding:20px;backdrop-filter:blur(8px)}
.tech-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.tech-title{font-family:var(--grotesk);font-size:13px;font-weight:700;color:rgba(255,255,255,.72)}
.tech-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.tech-kpi{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);border-radius:var(--radius-md);padding:14px}
.tech-kpi span{display:block;font-family:var(--grotesk);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:6px}
.tech-kpi strong{display:block;font-family:var(--grotesk);font-size:24px;color:var(--white)}
.tech-kpi small{display:block;margin-top:6px;color:var(--green-light);font-size:12px}
.check-list{display:grid;gap:10px;margin-top:24px}
.check-list li{display:flex;gap:10px;font-size:15px;color:rgba(255,255,255,.82)}
.check-list li::before{content:"";width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);margin-top:9px;flex-shrink:0}

/* SERVICE PAGE */
.deliverables-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1.2rem}
.deliverable-item{display:flex;align-items:flex-start;gap:.8rem;font-size:.9rem;color:var(--dark);line-height:1.55}
.deliverable-item::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:.5rem}
.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.result-cell{background:var(--white);padding:1.5rem}
.result-cell strong{display:block;font-family:var(--grotesk);font-size:.9rem;font-weight:700;color:var(--navy);margin-bottom:.3rem}
.result-cell span{font-size:.8rem;color:var(--muted);font-weight:300}
.related-services{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}
.related-tag{background:var(--light-bg);border:1px solid var(--border);border-radius:999px;padding:.3rem .9rem;font-family:var(--grotesk);font-size:.72rem;font-weight:600;color:var(--navy);transition:border-color .2s,color .2s}
.related-tag:hover{border-color:var(--teal);color:var(--teal)}

/* FORM */
.form-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow)}
.form-title{font-family:var(--grotesk);font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.form-sub{font-size:.82rem;color:var(--muted);font-weight:300;margin-bottom:1.8rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;margin-bottom:1rem}
.form-label{font-family:var(--grotesk);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);margin-bottom:.45rem}
.form-input,.form-select,.form-textarea{width:100%;padding:.8rem 1rem;font-family:var(--sora);font-size:.88rem;color:var(--dark);background:var(--off-white);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .2s,box-shadow .2s;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(43,114,97,.08);background:var(--white)}
.form-textarea{resize:vertical;min-height:100px;line-height:1.6}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7a76' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}
.form-submit{width:100%;padding:1rem;background:var(--teal);color:var(--white);font-family:var(--grotesk);font-size:.95rem;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s,transform .15s;margin-top:.5rem}
.form-submit:hover{background:var(--forest);transform:translateY(-1px)}
.form-disclaimer{font-size:.72rem;color:var(--muted);text-align:center;margin-top:1rem;font-weight:300;line-height:1.5}

/* CONTACT */
.contact-info-grid{display:flex;flex-direction:column;gap:1.2rem}
.info-block{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.6rem}
.info-block-title{font-family:var(--grotesk);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.9rem}
.contact-item{display:flex;align-items:center;gap:.9rem;padding:.7rem 0;border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none;padding-bottom:0}
.contact-icon{width:36px;height:36px;border-radius:8px;background:rgba(43,114,97,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-label{font-family:var(--grotesk);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.1rem}
.contact-value{font-family:var(--grotesk);font-size:.9rem;font-weight:600;color:var(--navy)}
.contact-value a:hover{color:var(--teal)}
.wpp-block{background:var(--teal);border-radius:var(--radius-md);padding:1.6rem;text-align:center}
.wpp-title{font-family:var(--grotesk);font-size:1rem;font-weight:700;color:var(--white);margin-bottom:.4rem}
.wpp-sub{font-size:.8rem;color:rgba(255,255,255,.65);font-weight:300;margin-bottom:1.2rem}
.btn-wpp-full{display:block;background:var(--white);color:var(--teal);padding:.85rem;font-family:var(--grotesk);font-size:.88rem;font-weight:700;border-radius:8px;transition:background .2s;text-align:center}
.btn-wpp-full:hover{background:var(--off-white)}
.processo-block{background:var(--navy);border-radius:var(--radius-md);padding:1.6rem}
.processo-title{font-family:var(--grotesk);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(43,114,97,.9);margin-bottom:1rem}
.proc-step{display:flex;align-items:flex-start;gap:.9rem;margin-bottom:.9rem}
.proc-step:last-child{margin-bottom:0}
.proc-num{width:24px;height:24px;border-radius:50%;background:rgba(43,114,97,.2);border:1px solid rgba(43,114,97,.4);display:grid;place-items:center;font-family:var(--grotesk);font-size:.65rem;font-weight:700;color:rgba(43,114,97,.9);flex-shrink:0;margin-top:.1rem}
.proc-text strong{display:block;font-family:var(--grotesk);font-size:.82rem;font-weight:600;color:var(--white)}
.proc-text span{font-size:.75rem;color:rgba(255,255,255,.35);font-weight:300}

/* CTA */
.cta-block{padding:48px;border-radius:var(--radius-xl);background:linear-gradient(180deg,var(--off-white),var(--white));border:1px solid var(--border);position:relative;overflow:hidden}
.final-cta{text-align:center;max-width:760px;margin:0 auto;position:relative;z-index:1}
.cta-copy{margin:16px auto 28px;max-width:620px}

/* FOOTER */
.footer{padding:32px 0;background:var(--navy)}
.footer-wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-logo{height:36px;width:auto;opacity:.8}
.footer-links{display:flex;gap:20px}
.footer-links a{font-family:var(--grotesk);font-size:13px;color:rgba(255,255,255,.35);transition:color .2s}
.footer-links a:hover{color:rgba(255,255,255,.7)}
.footer-copy{font-size:13px;color:rgba(255,255,255,.35)}

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

/* FOCUS */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:4px}

/* RESPONSIVE */
@media(max-width:1080px){
  .hero-grid,.problem-grid,.split-header,.compare-grid,.tech-grid,.team-grid,.service-page-grid{grid-template-columns:1fr}
  .feature-grid,.steps-grid{grid-template-columns:repeat(2,1fr)}
  .service-grid,.service-grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:1fr 1fr}
  .dropdown-menu{min-width:400px;grid-template-columns:1fr 1fr}
}
@media(max-width:780px){
  .section{padding:72px 0}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .hero-grid,.kpi-grid,.dashboard-lower,.feature-grid,.service-grid,.steps-grid,
  .tech-kpis,.two-col,.form-row,.result-grid{grid-template-columns:1fr}
  .headline-xl{font-size:2.5rem}.headline-lg{font-size:2rem}
  .btn-row{flex-direction:column;align-items:stretch}.btn{width:100%}
  .footer-wrap{flex-direction:column;align-items:flex-start}
  .stats-row,.testimonials-grid{grid-template-columns:1fr}
  .team-card-inner{flex-direction:column}
  .team-photo-wrap{width:90px;height:90px}
  .page-hero .symbol-decor{width:260px;height:260px;opacity:.04}
  .hero .symbol-decor{width:300px;height:300px}
}

/* ─── FOOTER ATUALIZADO ─── */
.footer-main { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding-bottom: 24px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 20px; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.footer-legal { display: flex; gap: 20px; }
.footer-legal a { font-family: var(--grotesk); font-size: 12px; color: rgba(255,255,255,.25); transition: color .2s; }
.footer-legal a:hover { color: rgba(255,255,255,.6); }
.footer-social { display: flex; gap: 14px; align-items: center; }
.footer-social a { color: rgba(255,255,255,.35); transition: color .2s, transform .2s; display: flex; }
.footer-social a:hover { color: rgba(255,255,255,.8); transform: translateY(-2px); }
@media (max-width: 780px) {
  .footer-main, .footer-bottom { flex-direction: column; align-items: flex-start; gap: 16px; }
}

/* ─── POLICY PAGES ─── */
.policy-body h2 { font-family: var(--grotesk); font-size: 1.1rem; font-weight: 700; color: var(--navy); margin: 2.5rem 0 .8rem; padding-bottom: .6rem; border-bottom: 1px solid var(--border); }
.policy-body h2:first-child { margin-top: 0; }
.policy-body p { font-size: .95rem; color: var(--dark); line-height: 1.8; margin-bottom: 1rem; font-weight: 300; }
.policy-body ul { margin: .5rem 0 1rem 1.2rem; display: flex; flex-direction: column; gap: .5rem; }
.policy-body ul li { font-size: .92rem; color: var(--dark); line-height: 1.7; font-weight: 300; list-style: disc; }
.policy-body a { color: var(--teal); text-decoration: underline; text-underline-offset: 3px; }
.policy-body a:hover { color: var(--forest); }
.policy-body strong { font-weight: 600; color: var(--navy); }

/* ─── BLOG ─── */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.blog-card { border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--white); overflow: hidden; transition: box-shadow .2s, transform .2s; }
.blog-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.blog-card-inner { display: flex; flex-direction: column; padding: 28px; height: 100%; color: inherit; }
.blog-cat { font-family: var(--grotesk); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--teal); margin-bottom: 12px; }
.blog-card-title { font-family: var(--grotesk); font-size: 1.05rem; font-weight: 700; color: var(--navy); line-height: 1.25; margin-bottom: 12px; }
.blog-card-desc { font-size: .88rem; color: var(--muted); line-height: 1.7; font-weight: 300; flex: 1; }
.blog-card-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); }
.blog-date { font-size: .78rem; color: var(--muted); font-family: var(--grotesk); }
.blog-read { font-size: .82rem; font-family: var(--grotesk); font-weight: 600; color: var(--teal); }
.post-body h2 { font-family: var(--grotesk); font-size: 1.15rem; font-weight: 700; color: var(--navy); margin: 2.5rem 0 .8rem; padding-bottom: .5rem; border-bottom: 1px solid var(--border); }
.post-body h2:first-child { margin-top: 0; }
.post-body p { font-size: .97rem; color: var(--dark); line-height: 1.85; margin-bottom: 1rem; font-weight: 300; }
.post-body ul { margin: .5rem 0 1.2rem 1.2rem; display: flex; flex-direction: column; gap: .5rem; }
.post-body ul li { font-size: .92rem; color: var(--dark); line-height: 1.7; font-weight: 300; list-style: disc; }
.post-body strong { font-weight: 600; color: var(--navy); }
.post-cta-inline { margin-top: 3rem; padding: 2rem; background: var(--light-bg); border-radius: var(--radius-lg); border: 1px solid var(--border); }

/* ─── LINKEDIN BTN ─── */
.linkedin-btn { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--radius-sm); border: 1px solid rgba(43,114,97,.25); background: rgba(43,114,97,.06); font-family: var(--grotesk); font-size: 13px; font-weight: 600; color: var(--teal); transition: background .2s, border-color .2s; }
.linkedin-btn:hover { background: rgba(43,114,97,.12); border-color: var(--teal); }

/* ─── LANG SWITCHER ─── */
.lang-switcher { display: flex; gap: 8px; align-items: center; margin-left: 8px; }
.lang-btn { font-family: var(--grotesk); font-size: 12px; font-weight: 600; color: var(--muted); padding: 4px 8px; border-radius: 4px; border: 1px solid var(--border); transition: all .2s; }
.lang-btn:hover, .lang-btn.active { color: var(--teal); border-color: var(--teal); background: rgba(43,114,97,.06); }

@media (max-width: 780px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* ─── LANG LINK ─── */
.lang-link { display: inline-flex; align-items: center; gap: 5px; padding: 4px 8px; border-radius: 5px; font-family: var(--grotesk); font-size: 12px; font-weight: 600; color: var(--muted); border: 1px solid var(--border); transition: all .2s; }
.lang-link:hover { color: var(--navy); border-color: var(--navy); background: rgba(25,51,66,.04); }
.lang-link svg { flex-shrink: 0; border-radius: 2px; }

/* ─── SERVICE + FEATURE ICONS SVG ─── */
.service-icon svg,
.feature-number svg,
.step-number svg {
  width: 22px; height: 22px;
  display: block;
  color: var(--teal);
}
.feature-number svg { width: 20px; height: 20px; }

/* ─── SYMBOL DECOR INLINE SVG ─── */
.symbol-decor {
  position: absolute; pointer-events: none; user-select: none;
}
.hero .symbol-decor        { right: -80px; bottom: -60px; width: 480px; height: 500px; opacity: 1; }
.page-hero .symbol-decor   { right: -60px; top: 50%; transform: translateY(-50%); width: 380px; height: 396px; opacity: 1; }
.cta-block .symbol-decor   { right: -40px; bottom: -40px; width: 280px; height: 292px; opacity: 1; }

/* Step numbers mantêm estilo numérico */
.step-number { font-family: var(--grotesk); font-size: 14px; font-weight: 700; }

/* ─── BRAND MARK SVG INLINE ─── */
.brand-mark-svg {
  width: 38px; height: 40px; flex-shrink: 0;
  display: block;
}


.form-status{margin-top:1rem;padding:.9rem 1rem;border-radius:14px;font-size:.9rem;line-height:1.5;font-weight:500}.form-status.pending{background:rgba(25,51,66,.06);color:var(--navy);border:1px solid rgba(25,51,66,.12)}.form-status.error{background:rgba(170,45,45,.08);color:#8f1f1f;border:1px solid rgba(170,45,45,.16)}.form-input.input-error,.form-select.input-error,.form-textarea.input-error{border-color:#c45a5a!important;box-shadow:0 0 0 3px rgba(196,90,90,.10)}.form-submit[disabled]{opacity:.7;cursor:not-allowed}
/* ─── AJUSTES PREMIUM v8 ─── */

/* Service icon SVG — tamanho e cor consistentes */
.service-icon svg {
  width: 22px;
  height: 22px;
  color: var(--teal);
  display: block;
}
.feature-number svg {
  width: 20px;
  height: 20px;
  color: var(--teal);
  display: block;
}

/* Símbolo decorativo — apenas hero e CTA, opacidade controlada */
.hero .symbol-decor {
  right: -60px;
  bottom: -40px;
  width: 420px;
  height: 438px;
  opacity: 1;
  z-index: 0;
}
.cta-block .symbol-decor {
  right: -30px;
  bottom: -30px;
  width: 240px;
  height: 250px;
  opacity: 1;
  z-index: 0;
}
/* Garantir que texto fique sobre o símbolo */
.hero-copy,
.hero-visual,
.final-cta {
  position: relative;
  z-index: 1;
}

/* Mais contraste no hero headline */
.headline-xl {
  line-height: 1.02;
}
.headline-xl .accent {
  position: relative;
}

/* Melhorar hierarquia visual do hero */
.hero-sub {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #5a6a66;
}

/* Botão primário — mais peso visual */
.btn-primary {
  padding: 15px 26px;
  font-size: 15px;
  letter-spacing: 0.01em;
}

/* CTA block — mais contraste */
.cta-block {
  background: linear-gradient(160deg, #f0f4f2 0%, #ffffff 100%);
  border-color: #c8d8d0;
}
.cta-block .headline-lg {
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
}

/* Compare table — mais leitura */
.compare-table td {
  font-size: 14.5px;
}
.compare-table td:last-child {
  font-weight: 600;
}

/* Post CTA inline — destaque maior */
.post-cta-inline {
  margin-top: 3rem;
  padding: 2rem 2.2rem;
  background: var(--light-bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  border-left: 4px solid var(--teal);
}

/* ─── POST META + AUTOR ─── */
.post-header { margin-bottom: 2.5rem; padding-bottom: 2rem; border-bottom: 1px solid var(--border); }
.post-cat { font-family: var(--grotesk); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--teal); margin-bottom: 1rem; display: block; }
.post-title { font-family: var(--grotesk); font-size: clamp(1.6rem,3vw,2.4rem); font-weight: 700; color: var(--navy); letter-spacing: -.03em; line-height: 1.1; margin-bottom: 1rem; }
.post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.post-meta-item { font-size: .82rem; color: var(--muted); font-family: var(--grotesk); }
.post-meta-sep { color: var(--border); }
.post-author { display: flex; align-items: center; gap: 12px; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.post-author-photo { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; object-position: top; border: 2px solid var(--border); flex-shrink: 0; }
.post-author-name { font-family: var(--grotesk); font-size: .9rem; font-weight: 700; color: var(--navy); }
.post-author-role { font-size: .78rem; color: var(--muted); margin-top: 2px; }
.post-author-linkedin { display: inline-flex; align-items: center; gap: 5px; margin-top: 4px; font-family: var(--grotesk); font-size: .72rem; font-weight: 600; color: var(--teal); }
.post-author-linkedin:hover { color: var(--forest); }

/* ─── BLOG CARD SERVICE LINK ─── */
.blog-card-service {
  font-size: .76rem;
  color: var(--muted);
  margin-top: 12px;
  font-family: var(--grotesk);
}
.blog-card-service a {
  color: var(--teal);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.blog-card-service a:hover { color: var(--forest); }

/* ─── AUTHORITY BLOCK ─── */
.authority-section { background: var(--white); }
.authority-intro {
  text-align: center;
  max-width: 640px;
  margin: 0 auto 3.5rem;
}
.authority-intro p {
  font-size: .9rem;
  color: var(--muted);
  font-weight: 300;
  margin-top: .6rem;
  line-height: 1.7;
}
.authority-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.authority-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 2.2rem;
  background: var(--white);
  border-left: 4px solid var(--teal);
  transition: box-shadow .2s;
}
.authority-card:hover { box-shadow: var(--shadow); }
.authority-quote {
  font-size: .95rem;
  line-height: 1.8;
  color: var(--dark);
  font-weight: 300;
  font-style: italic;
  margin-bottom: 1.6rem;
  position: relative;
}
.authority-quote::before {
  content: '"';
  font-family: var(--grotesk);
  font-size: 3rem;
  color: var(--teal);
  opacity: .3;
  position: absolute;
  top: -1rem;
  left: -0.5rem;
  line-height: 1;
}
.authority-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 1.2rem;
  border-top: 1px solid var(--border);
}
.authority-logo {
  height: 28px;
  width: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: .6;
  flex-shrink: 0;
  max-width: 120px;
}
.authority-meta-text strong {
  display: block;
  font-family: var(--grotesk);
  font-size: .82rem;
  font-weight: 700;
  color: var(--navy);
}
.authority-meta-text span {
  font-size: .75rem;
  color: var(--muted);
  font-weight: 300;
}
.authority-divider {
  width: 1px;
  height: 32px;
  background: var(--border);
  flex-shrink: 0;
}
@media (max-width: 780px) {
  .authority-grid { grid-template-columns: 1fr; }
}

/* ─── AUTHORITY CARD TITLE ─── */
.authority-card-title {
  font-family: var(--grotesk);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 1rem;
}
