/* ===== CSS Reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,picture,video,canvas,svg{display:block;max-width:100%}
input,button,textarea,select{font:inherit}
p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}

/* ===== Custom Properties ===== */
:root{
  --accent:#1B5E8A;
  --accent-blue:#2563EB;
  --accent-purple:#6E56CF;
  --bg-primary:#F0F2F5;
  --bg-surface:#FFFFFF;
  --bg-elevated:#E8ECF1;
  --border-subtle:#D4DAE3;
  --text-primary:#1A1F2E;
  --text-secondary:#5A6478;
  --text-tertiary:#8A94A6;
  --text-muted:#B0B8C9;
  --text-inverted:#FFFFFF;
  --font-heading:'Space Grotesk',sans-serif;
  --font-body:'Manrope',sans-serif;
  --font-dm:'DM Sans',sans-serif;
  --font-mono:'Space Mono',monospace;
  --max-w:1440px;
  --section-px:max(120px, calc((100vw - var(--max-w)) / 2 + 120px));
  --section-py:80px;
  --header-h:72px;
  --radius-sm:10px;
  --radius-md:16px;
  --radius-lg:20px;
  --radius-pill:100px;
  --shadow-card:0 2px 8px rgba(0,0,0,.04);
  --shadow-screenshot:0 12px 40px -8px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.03);
}

/* ===== Base ===== */
body{
  font-family:var(--font-dm);
  background:var(--bg-primary);
  color:var(--text-primary);
}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none}

/* ===== Layout Utilities ===== */
.page-wrap{
  width:100%;
  overflow-x:hidden;
}

/* ===== Header ===== */
.header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
  padding:0 var(--section-px);
  background:rgba(255,255,255,.8);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  transition:background .3s,box-shadow .3s;
}
.header.scrolled{
  background:rgba(255,255,255,.95);
  box-shadow:0 2px 12px rgba(0,0,0,.08);
}
.header-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.header-logo img{height:36px;width:auto;filter:invert(1)}
.header-logo span{font-family:var(--font-dm);font-size:22px;font-weight:700;color:var(--text-primary)}
.nav{display:flex;align-items:center;gap:40px}
.nav-link{
  font-family:var(--font-dm);font-size:14px;font-weight:500;
  color:var(--text-secondary);transition:color .2s;
}
.nav-link:hover{color:var(--text-primary)}
.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 24px;
  border-radius:var(--radius-pill);
  background:var(--accent);
  font-family:var(--font-dm);font-size:14px;font-weight:600;
  color:var(--text-inverted);
  transition:background .2s,transform .15s;
}
.btn-cta:hover{background:#164d73;transform:translateY(-1px)}
.btn-cta svg,.btn-cta i{width:14px;height:14px}

/* Mobile menu toggle */
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;background:none;border:none}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .3s,opacity .3s}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile overlay */
.mobile-nav{
  display:none;position:fixed;inset:0;top:var(--header-h);
  background:var(--bg-surface);z-index:99;
  flex-direction:column;align-items:center;justify-content:flex-start;
  padding:40px 24px;gap:32px;
}
.mobile-nav.open{display:flex}
.mobile-nav .nav-link{font-size:18px}
.mobile-nav .btn-cta{font-size:16px;padding:14px 32px}

/* ===== Buttons ===== */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;
  border-radius:var(--radius-pill);
  background:var(--accent);
  font-family:var(--font-dm);font-size:15px;font-weight:600;
  color:var(--text-inverted);
  box-shadow:0 4px 16px rgba(27,94,138,.19);
  transition:background .2s,transform .15s;
}
.btn-primary:hover{background:#164d73;transform:translateY(-1px)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;
  border-radius:var(--radius-pill);
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
  font-family:var(--font-dm);font-size:15px;font-weight:600;
  color:var(--text-primary);
  transition:background .2s,border-color .2s;
}
.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--text-muted)}
.btn-form{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:14px 32px;
  border-radius:var(--radius-pill);
  background:var(--accent);
  font-family:var(--font-dm);font-size:15px;font-weight:700;
  color:var(--text-inverted);
  box-shadow:0 4px 16px rgba(27,94,138,.19);
  transition:background .2s,transform .15s;
  cursor:pointer;border:none;
}
.btn-form:hover{background:#164d73;transform:translateY(-1px)}
.btn-outline{
  display:inline-flex;align-items:center;
  padding:14px 32px;
  border-radius:var(--radius-pill);
  background:var(--bg-elevated);
  border:1px solid var(--border-subtle);
  font-family:var(--font-dm);font-size:15px;font-weight:600;
  color:var(--text-primary);
  transition:background .2s;
}
.btn-outline:hover{background:var(--border-subtle)}

/* ===== Sections ===== */
.section{
  padding:var(--section-py) var(--section-px);
  width:100%;
}
.section--surface{background:var(--bg-surface)}
.section--primary{background:var(--bg-primary)}
.section--cta{
  background:var(--accent);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:32px;
}
.section-inner{
  max-width:1200px;margin:0 auto;width:100%;
}

/* Section headers */
.section-badge{
  font-family:var(--font-dm);font-size:13px;font-weight:600;
  letter-spacing:1.5px;color:var(--accent);text-transform:uppercase;
}
.section-badge--mono{
  font-family:var(--font-mono);font-size:13px;font-weight:500;
  letter-spacing:3px;color:var(--accent);text-transform:uppercase;
}
.section-title{
  font-family:var(--font-heading);font-weight:700;
  color:var(--text-primary);line-height:1.15;
}
.section-title--lg{font-size:56px;font-weight:800;line-height:1.05}
.section-title--md{font-size:44px;font-weight:700}
.section-title--sm{font-size:40px}
.section-subtitle{
  font-family:var(--font-body);font-size:20px;font-weight:400;
  color:var(--text-secondary);line-height:1.6;
  max-width:700px;
}
.section-subtitle--narrow{max-width:650px}
.section-subtitle--wide{max-width:900px}

/* ===== Hero (Landing) ===== */
.hero{
  display:flex;flex-direction:column;align-items:center;
  gap:40px;padding:100px var(--section-px) 70px;
  background:var(--bg-primary);text-align:center;
}
.hero-headline{font-family:var(--font-dm);font-size:68px;font-weight:700;letter-spacing:-1.5px;line-height:1.15;color:var(--text-primary)}
.hero-headline-accent{color:var(--accent)}
.hero-sub{
  font-family:var(--font-dm);font-size:18px;font-weight:400;
  line-height:1.7;color:#B0C4DE;max-width:640px;
}
.hero-ctas{display:flex;gap:16px;align-items:center}
.trust-line{
  display:flex;align-items:center;justify-content:center;gap:24px;
  width:100%;
}
.trust-item{display:flex;align-items:center;gap:8px}
.trust-item i{color:var(--accent);width:16px;height:16px}
.trust-item span{font-family:var(--font-dm);font-size:13px;font-weight:500;color:var(--text-tertiary)}
.trust-dot{font-size:18px;color:var(--text-muted)}
.hero-screenshot{
  width:100%;max-width:1000px;
  border-radius:var(--radius-md);
  border:1px solid var(--border-subtle);
  box-shadow:var(--shadow-screenshot);
  overflow:hidden;
}
.hero-screenshot img{width:100%;height:auto;display:block}

/* ===== Page Hero (inner pages) ===== */
.page-hero{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:24px;
  padding:100px var(--section-px) 80px;
}
.page-hero .section-title--lg{max-width:900px}
.page-hero .section-subtitle{text-align:center}

/* ===== Feature Blocks (alternating) ===== */
.feature-block{
  display:flex;align-items:center;gap:48px;
  padding:var(--section-py) var(--section-px);
}
.feature-block.reverse{flex-direction:row-reverse}
.feature-block--surface{background:var(--bg-surface)}
.feature-content{flex:1;display:flex;flex-direction:column;gap:20px}
.feature-content .section-badge--mono,
.feature-content .section-badge{margin-bottom:4px}
.feature-title{
  font-family:var(--font-heading);font-size:36px;font-weight:700;
  line-height:1.15;color:var(--text-primary);
}
.feature-desc{
  font-family:var(--font-body);font-size:17px;font-weight:400;
  line-height:1.7;color:var(--text-secondary);
}
.feature-checks{display:flex;flex-direction:column;gap:16px;margin-top:4px}
.feature-check{display:flex;align-items:center;gap:12px}
.feature-check i{color:var(--accent);width:20px;height:20px;flex-shrink:0}
.feature-check span{font-family:var(--font-body);font-size:15px;font-weight:500;color:var(--text-primary)}
.feature-screenshot{
  width:560px;flex-shrink:0;
  border-radius:var(--radius-md);
  border:1px solid var(--border-subtle);
  overflow:hidden;
  box-shadow:var(--shadow-screenshot);
}
.feature-screenshot img{width:100%;height:auto;display:block}

/* Landing page feature rows (within Core Features section) */
.core-features{
  display:flex;flex-direction:column;align-items:center;
  gap:60px;padding:var(--section-py) var(--section-px);
  background:var(--bg-surface);
}
.core-features-header{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:20px;
}
.core-features-header .section-subtitle{max-width:550px;font-size:16px}
.feat-row{
  display:flex;align-items:center;gap:48px;width:100%;
}
.feat-row.reverse{flex-direction:row-reverse}
.feat-row-text{flex:1;display:flex;flex-direction:column;gap:20px}
.feat-row-tag{display:flex;align-items:center;gap:8px}
.feat-row-tag-icon{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
}
.feat-row-tag-icon i{width:16px;height:16px;color:#fff}
.feat-row-tag-icon--accent{background:var(--accent)}
.feat-row-tag-icon--gradient-blue{background:linear-gradient(135deg,#6E56CF,#2563EB)}
.feat-row-tag-icon--gradient-orange{background:linear-gradient(135deg,#E87040,#F59E0B)}
.feat-row-tag-label{font-family:var(--font-dm);font-size:13px;font-weight:600;letter-spacing:1px}
.feat-row-tag-label--accent{color:var(--accent)}
.feat-row-tag-label--blue{color:var(--accent-blue)}
.feat-row-tag-label--orange{color:#E87040}
.feat-row-title{font-family:var(--font-dm);font-size:28px;font-weight:700;line-height:1.2;color:var(--text-primary)}
.feat-row-desc{font-family:var(--font-dm);font-size:15px;font-weight:400;line-height:1.7;color:var(--text-secondary)}
.feat-row-bullets{display:flex;flex-direction:column;gap:12px}
.feat-row-bullet{display:flex;align-items:center;gap:10px}
.feat-row-bullet i{color:#22C55E;width:18px;height:18px;flex-shrink:0}
.feat-row-bullet span{font-family:var(--font-dm);font-size:14px;font-weight:400;color:var(--text-secondary)}
.feat-row-img{
  width:520px;height:340px;flex-shrink:0;
  border-radius:var(--radius-md);
  border:1px solid var(--border-subtle);
  overflow:hidden;
  background:#F5F5F5;
  box-shadow:var(--shadow-screenshot);
}
.feat-row-img img{width:100%;height:100%;object-fit:cover}
.feat-divider{width:100%;height:1px;background:var(--border-subtle)}

/* Practice areas card (inside Core Features row2) */
.practice-areas-card{
  width:520px;flex-shrink:0;
  border-radius:var(--radius-md);
  border:1px solid var(--border-subtle);
  padding:28px 32px;
  background:var(--bg-surface);
  box-shadow:var(--shadow-screenshot);
  display:flex;flex-direction:column;gap:20px;
}
.practice-areas-card h4{font-family:var(--font-dm);font-size:15px;font-weight:600;color:var(--text-primary)}
.practice-areas-cols{display:flex;gap:12px}
.practice-areas-cols ul{flex:1;display:flex;flex-direction:column;gap:8px}
.practice-areas-cols li{font-family:var(--font-dm);font-size:12.5px;color:var(--text-secondary)}

/* ===== Value Proposition ===== */
.value-section{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:48px;
  padding:var(--section-py) var(--section-px);
  background:var(--bg-surface);
}
.value-section .section-subtitle{max-width:660px;font-size:16px}
.stats-row{display:flex;width:100%}
.stat-item{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:32px 0;
}
.stat-item:not(:last-child){border-right:1px solid var(--border-subtle)}
.stat-num{font-family:var(--font-dm);font-size:40px;font-weight:800;color:var(--accent)}
.stat-label{font-family:var(--font-dm);font-size:14px;font-weight:500;color:var(--text-secondary)}

/* ===== Card Grids ===== */
.card-grid{display:grid;gap:24px;width:100%}
.card-grid--2{grid-template-columns:repeat(2,1fr)}
.card-grid--3{grid-template-columns:repeat(3,1fr)}
.card-grid--4{grid-template-columns:repeat(4,1fr)}

.card{
  border-radius:var(--radius-md);
  border:1px solid var(--border-subtle);
  padding:28px;
  display:flex;flex-direction:column;gap:14px;
  background:var(--bg-primary);
  box-shadow:var(--shadow-card);
}
.card--surface{background:var(--bg-surface)}
.card i{color:var(--accent);width:24px;height:24px}
.card-title{font-family:var(--font-dm);font-size:18px;font-weight:700;color:var(--text-primary)}
.card-desc{font-family:var(--font-dm);font-size:14px;font-weight:400;line-height:1.6;color:var(--text-secondary)}
.card-lg{
  border-radius:var(--radius-lg);padding:40px;gap:24px;
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
}
.card-lg .card-icon-wrap{
  width:56px;height:56px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
}
.card-lg .card-icon-wrap i{color:#fff;width:26px;height:26px}
.card-lg .card-icon-wrap--purple{background:linear-gradient(135deg,#7C3AED,#2563EB)}
.card-lg .card-icon-wrap--accent{background:var(--accent)}
.card-lg .card-icon-wrap--red{background:linear-gradient(135deg,#DC2626,#F97316)}
.card-lg .card-icon-wrap--cyan{background:linear-gradient(135deg,#0891B2,#06B6D4)}
.card-lg-title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text-primary)}
.card-lg-desc{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--text-secondary)}
.card-lg-checks{display:flex;flex-direction:column;gap:14px}
.card-lg-check{display:flex;align-items:center;gap:12px}
.card-lg-check i{color:var(--accent);width:18px;height:18px;flex-shrink:0}
.card-lg-check span{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-primary)}

/* ===== Designed by Attorneys ===== */
.attorneys-section{
  display:flex;align-items:center;gap:48px;
  padding:var(--section-py) var(--section-px);
  background:var(--bg-surface);
}
.attorneys-left{flex:1;display:flex;flex-direction:column;gap:32px}
.attorneys-title{font-family:var(--font-dm);font-size:34px;font-weight:700;line-height:1.2;color:var(--text-primary)}
.attorneys-desc{font-family:var(--font-dm);font-size:15px;line-height:1.7;color:var(--text-secondary)}
.attorneys-features{display:flex;flex-direction:column;gap:20px}
.attorneys-feature{display:flex;align-items:center;gap:14px}
.attorneys-feature i{color:#22C55E;width:22px;height:22px;flex-shrink:0}
.attorneys-feature span{font-family:var(--font-dm);font-size:15px;font-weight:500;color:var(--text-primary)}
.attorneys-img{
  width:520px;flex-shrink:0;height:380px;
  border-radius:var(--radius-md);
  border:1px solid var(--border-subtle);
  overflow:hidden;
  box-shadow:var(--shadow-screenshot);
}
.attorneys-img img{width:100%;height:100%;object-fit:cover}

/* ===== CTA Section ===== */
.cta-section{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:32px;
  padding:var(--section-py) var(--section-px);
  background:var(--accent);
}
.cta-accent-line{width:80px;height:4px;border-radius:2px;background:rgba(255,255,255,.25)}
.cta-title{
  font-family:var(--font-dm);font-size:44px;font-weight:800;
  line-height:1.1;color:var(--text-inverted);max-width:900px;
}
.cta-sub{
  font-family:var(--font-dm);font-size:18px;font-weight:400;
  line-height:1.6;color:rgba(255,255,255,.8);max-width:650px;
}
.cta-btns{display:flex;gap:16px;align-items:center}
.btn-cta-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 36px;border-radius:var(--radius-pill);
  background:var(--bg-surface);
  font-family:var(--font-dm);font-size:16px;font-weight:700;
  color:var(--accent);
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  transition:transform .15s;
}
.btn-cta-primary:hover{transform:translateY(-1px)}
.btn-cta-primary i{color:var(--accent);width:18px;height:18px}
.btn-cta-secondary{
  display:inline-flex;align-items:center;
  padding:16px 36px;border-radius:var(--radius-pill);
  background:rgba(255,255,255,.125);
  border:1px solid rgba(255,255,255,.25);
  font-family:var(--font-dm);font-size:16px;font-weight:600;
  color:var(--text-inverted);
  transition:background .2s;
}
.btn-cta-secondary:hover{background:rgba(255,255,255,.2)}
.cta-trust{font-family:var(--font-dm);font-size:13px;color:rgba(255,255,255,.67)}

/* ===== Pricing Cards ===== */
.pricing-row{display:flex;gap:24px;padding:40px var(--section-px) 80px}
.pricing-card{
  flex:1;display:flex;flex-direction:column;gap:32px;
  padding:40px;border-radius:var(--radius-lg);
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
}
.pricing-card--featured{border:2px solid var(--accent)}
.pricing-badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 16px;border-radius:var(--radius-pill);
  background:var(--accent);
  font-family:var(--font-mono);font-size:11px;font-weight:700;
  letter-spacing:2px;color:var(--text-inverted);
  align-self:flex-start;
}
.pricing-name{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--text-primary)}
.pricing-desc{font-family:var(--font-body);font-size:15px;color:var(--text-secondary)}
.pricing-amount{display:flex;align-items:flex-end;gap:4px}
.pricing-amount strong{font-family:var(--font-heading);font-size:48px;font-weight:800;line-height:1;color:var(--text-primary)}
.pricing-amount span{font-family:var(--font-body);font-size:16px;color:var(--text-tertiary);padding-bottom:4px}
.pricing-divider{width:100%;height:1px;background:var(--border-subtle)}
.pricing-features{display:flex;flex-direction:column;gap:16px;flex:1}
.pricing-feature{display:flex;align-items:center;gap:12px}
.pricing-feature i{color:var(--accent);width:18px;height:18px;flex-shrink:0}
.pricing-feature span{font-family:var(--font-body);font-size:15px;color:var(--text-primary)}
.pricing-feature--highlight span{color:var(--accent);font-weight:600}
.pricing-btn{
  display:flex;align-items:center;justify-content:center;
  width:100%;padding:14px 32px;
  border-radius:var(--radius-pill);
  font-family:var(--font-dm);font-size:15px;font-weight:600;
  transition:background .2s,transform .15s;
}
.pricing-btn--primary{
  background:var(--accent);color:var(--text-inverted);font-weight:700;
  box-shadow:0 4px 16px rgba(27,94,138,.19);
}
.pricing-btn--primary:hover{background:#164d73;transform:translateY(-1px)}
.pricing-btn--outline{
  background:var(--bg-elevated);color:var(--text-primary);
  border:1px solid var(--border-subtle);
}
.pricing-btn--outline:hover{background:var(--border-subtle)}

/* ===== FAQ ===== */
.faq-section{
  display:flex;flex-direction:column;align-items:center;gap:60px;
  padding:100px var(--section-px);background:var(--bg-surface);
}
.faq-header{display:flex;flex-direction:column;align-items:center;gap:20px}
.faq-list{width:100%;max-width:900px}
.faq-item{
  padding:24px 0;border-top:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:12px;
}
.faq-q{font-family:var(--font-heading);font-size:18px;font-weight:600;color:var(--text-primary)}
.faq-a{font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--text-secondary)}

/* ===== How It Works ===== */
.how-section{
  display:flex;flex-direction:column;align-items:center;gap:60px;
  padding:100px var(--section-px);background:var(--bg-surface);
}
.how-header{display:flex;flex-direction:column;align-items:center;gap:20px}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;width:100%}
.how-step{
  border-radius:var(--radius-md);padding:32px 28px;
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:12px;
}
.how-step-num{font-family:var(--font-dm);font-size:36px;font-weight:800;line-height:1;color:var(--accent)}
.how-step-title{font-family:var(--font-dm);font-size:18px;font-weight:700;color:var(--text-primary)}
.how-step-desc{font-family:var(--font-dm);font-size:14px;line-height:1.6;color:var(--text-secondary)}

/* ===== About ===== */
.about-hero{
  display:flex;align-items:center;gap:60px;
  padding:100px var(--section-px);
}
.about-hero-left{flex:1;display:flex;flex-direction:column;gap:24px}
.about-hero-img{
  width:500px;flex-shrink:0;height:400px;
  border-radius:var(--radius-lg);overflow:hidden;
}
.about-hero-img img{width:100%;height:100%;object-fit:cover}
.values-section{
  display:flex;flex-direction:column;align-items:center;gap:60px;
  padding:100px var(--section-px);
}
.values-header{display:flex;flex-direction:column;align-items:center;gap:20px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;width:100%}
.value-card{
  border-radius:var(--radius-lg);padding:32px;
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:16px;
}
.value-card i{color:var(--accent);width:28px;height:28px}
.value-card-title{font-family:var(--font-heading);font-size:20px;font-weight:700;color:var(--text-primary)}
.value-card-desc{font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--text-secondary)}

/* ===== Contact / Demo Forms ===== */
.form-section{
  display:flex;gap:60px;
  padding:100px var(--section-px);
}
.form-left{flex:1;display:flex;flex-direction:column;gap:32px}
.form-left .section-badge{margin-bottom:0}
.form-benefits{display:flex;flex-direction:column;gap:20px}
.form-benefit{display:flex;align-items:center;gap:14px}
.form-benefit i{color:var(--accent);width:22px;height:22px;flex-shrink:0}
.form-benefit span{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--text-primary)}
.form-card{
  width:520px;flex-shrink:0;
  border-radius:var(--radius-lg);padding:40px;
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:24px;
}
.form-card-title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text-primary)}
.form-row{display:flex;gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px;flex:1}
.form-label{font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--text-secondary)}
.form-input,.form-select,.form-textarea{
  width:100%;padding:14px 16px;
  border-radius:var(--radius-sm);
  background:var(--bg-primary);
  border:1px solid var(--border-subtle);
  font-family:var(--font-body);font-size:15px;color:var(--text-primary);
  transition:border-color .2s;
  outline:none;
}
.form-input::placeholder,.form-textarea::placeholder,.form-select option[value=""]{color:var(--text-muted)}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent)}
.form-textarea{resize:vertical;min-height:120px}
.form-select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23B0B8C9' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;background-size:18px;
  padding-right:40px;
}
.form-trust{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);text-align:center}
.form-success,.form-error{
  padding:14px 20px;border-radius:var(--radius-sm);
  font-family:var(--font-dm);font-size:14px;font-weight:500;
  display:none;
}
.form-success{background:#ECFDF5;color:#065F46;border:1px solid #A7F3D0}
.form-error{background:#FEF2F2;color:#991B1B;border:1px solid #FECACA}
.form-success.show,.form-error.show{display:block}

/* ===== Legal Pages ===== */
.legal-hero{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:16px;
  padding:100px var(--section-px) 60px;
}
.legal-date{font-family:var(--font-mono);font-size:14px;color:var(--text-tertiary)}
.legal-body{
  padding:40px 300px;
  display:flex;flex-direction:column;gap:48px;
}
.legal-block{display:flex;flex-direction:column;gap:16px}
.legal-block h2{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text-primary)}
.legal-block p{font-family:var(--font-body);font-size:16px;line-height:1.8;color:var(--text-secondary)}

/* ===== Feature Request Section ===== */
.feature-req-section{
  display:flex;align-items:center;gap:60px;
  padding:var(--section-py) var(--section-px);
  background:var(--bg-primary);
}
.feature-req-content{flex:1;display:flex;flex-direction:column;gap:24px}
.feature-req-content i.icon-lg{color:var(--accent);width:40px;height:40px}
.feature-req-title{font-family:var(--font-heading);font-size:36px;font-weight:700;line-height:1.15;color:var(--text-primary)}
.feature-req-desc{font-family:var(--font-body);font-size:17px;line-height:1.7;color:var(--text-secondary)}
.feature-req-card{
  width:420px;flex-shrink:0;
  border-radius:var(--radius-md);padding:40px;
  background:var(--bg-surface);
  border:1px solid var(--border-subtle);
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:28px;
}
.feature-req-card i.icon-xl{color:var(--accent);width:48px;height:48px}
.feature-req-card-title{font-family:var(--font-dm);font-size:22px;font-weight:700;color:var(--text-primary)}
.feature-req-card-desc{font-family:var(--font-dm);font-size:15px;line-height:1.6;color:var(--text-secondary)}

/* ===== "More Features" grid on features page ===== */
.more-features{
  display:flex;flex-direction:column;align-items:center;gap:60px;
  padding:100px var(--section-px);
}
.more-header{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}
.more-header .section-subtitle{max-width:600px;font-size:16px}
.more-grid{display:flex;flex-direction:column;gap:24px;width:100%}
.more-row{display:flex;gap:24px}
.more-card{
  flex:1;border-radius:var(--radius-md);padding:28px;
  background:var(--bg-primary);
  border:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:16px;
}
.more-card i{color:var(--accent);width:24px;height:24px}
.more-card-title{font-family:var(--font-dm);font-size:18px;font-weight:700;color:var(--text-primary)}
.more-card-desc{font-family:var(--font-dm);font-size:14px;line-height:1.6;color:var(--text-secondary)}

/* ===== Footer ===== */
.footer{
  padding:56px var(--section-px) 36px;
  background:var(--bg-surface);
  border-top:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:40px;
}
.footer-top{display:flex;justify-content:space-between;width:100%}
.footer-brand{width:300px;display:flex;flex-direction:column;gap:16px}
.footer-logo{display:flex;align-items:center;gap:10px}
.footer-logo img{width:32px;height:32px;border-radius:8px}
.footer-logo span{font-family:var(--font-dm);font-size:18px;font-weight:700;color:var(--text-primary)}
.footer-tagline{font-family:var(--font-dm);font-size:13px;line-height:1.6;color:var(--text-tertiary);max-width:280px}
.footer-cols{display:flex;gap:80px}
.footer-col{display:flex;flex-direction:column;gap:16px}
.footer-col-title{font-family:var(--font-dm);font-size:13px;font-weight:700;color:var(--text-primary)}
.footer-col a{font-family:var(--font-dm);font-size:13px;color:var(--text-tertiary);transition:color .2s}
.footer-col a:hover{color:var(--text-primary)}
.footer-divider{width:100%;height:1px;background:var(--border-subtle)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-family:var(--font-dm);font-size:12px;color:var(--text-muted)}

/* ===== Scroll Reveal Animations ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* Hero entrance animations */
.anim-hero{opacity:0;transform:translateY(20px);animation:heroIn .7s ease forwards}
.anim-hero-1{animation-delay:.1s}
.anim-hero-2{animation-delay:.2s}
.anim-hero-3{animation-delay:.3s}
.anim-hero-4{animation-delay:.4s}
.anim-hero-5{animation-delay:.6s}
@keyframes heroIn{to{opacity:1;transform:translateY(0)}}

/* ===== Responsive: Tablet (<=1100px) ===== */
@media(max-width:1100px){
  :root{--section-px:60px}
  .header{padding:0 var(--section-px)}
  .hero{padding:80px var(--section-px) 60px}
  .hero-headline{font-size:52px}
  .hero-sub{font-size:16px}
  .section-title--lg{font-size:44px}
  .feature-block{flex-direction:column!important;gap:40px}
  .feature-screenshot{width:100%}
  .feat-row{flex-direction:column!important;gap:40px}
  .feat-row-img{width:100%;height:auto;aspect-ratio:16/10}
  .practice-areas-card{width:100%}
  .attorneys-section{flex-direction:column;gap:40px}
  .attorneys-img{width:100%;height:300px}
  .about-hero{flex-direction:column;gap:40px}
  .about-hero-img{width:100%;height:300px}
  .form-section{flex-direction:column;gap:40px}
  .form-card{width:100%}
  .feature-req-section{flex-direction:column;gap:40px}
  .feature-req-card{width:100%}
  .pricing-row{flex-direction:column;gap:24px;padding:40px 60px 80px}
  .values-grid{grid-template-columns:1fr}
  .how-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid--2{grid-template-columns:1fr}
  .card-grid--3{grid-template-columns:1fr}
  .more-row{flex-direction:column}
  .legal-body{padding:40px 60px}
  .stats-row{flex-wrap:wrap}
  .stat-item{min-width:50%}
  .stat-item:nth-child(2){border-right:none}
  .footer-top{flex-direction:column;gap:40px}
  .footer-cols{gap:48px}
}

/* ===== Responsive: Mobile (<=768px) ===== */
@media(max-width:768px){
  :root{--section-px:24px;--section-py:60px}
  .header{padding:0 var(--section-px)}
  .nav{display:none}
  .menu-toggle{display:flex}
  .hero{padding:60px 24px 40px;gap:28px}
  .hero-headline{font-size:36px;letter-spacing:-0.5px}
  .hero-sub{font-size:15px;max-width:100%}
  .hero-ctas{flex-direction:column;width:100%}
  .hero-ctas .btn-primary,.hero-ctas .btn-secondary{width:100%;justify-content:center}
  .trust-line{flex-wrap:wrap;gap:16px}
  .section-title--lg{font-size:32px}
  .section-title--md{font-size:28px}
  .section-title--sm{font-size:26px}
  .section-subtitle{font-size:16px}
  .page-hero{padding:80px 24px 48px}
  .feature-block{padding:var(--section-py) var(--section-px)}
  .feature-title{font-size:26px}
  .feat-row-title{font-size:22px}
  .pricing-row{padding:24px 24px 60px}
  .how-grid{grid-template-columns:1fr}
  .cta-title{font-size:30px}
  .cta-btns{flex-direction:column;width:100%}
  .btn-cta-primary,.btn-cta-secondary{width:100%;justify-content:center}
  .form-row{flex-direction:column;gap:16px}
  .legal-body{padding:24px}
  .footer{padding:40px 24px 24px}
  .footer-cols{flex-direction:column;gap:32px}
  .stats-row{flex-direction:column}
  .stat-item{border-right:none!important;border-bottom:1px solid var(--border-subtle);padding:24px 0}
  .stat-item:last-child{border-bottom:none}
  .card-grid--4{grid-template-columns:1fr}
}
