/* ══ HERO ══ */
.hero { background: var(--green); min-height: 91vh; position: relative; overflow: hidden; }
.hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.022) 1px,transparent 1px); background-size: 54px 54px; pointer-events: none; }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 64px; padding-top: 80px; padding-bottom: 80px; position: relative; z-index: 2; }
.hero-inner::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 65% 75% at 65% 42%,rgba(232,160,32,0.09),transparent 60%),radial-gradient(ellipse 40% 55% at 8% 76%,rgba(18,168,141,0.11),transparent 50%); pointer-events: none; }
.hero-left, .hero-right { position: relative; z-index: 1; }

.hero-badge { display: inline-flex; align-items: center; gap: 9px; background: rgba(232,160,32,0.16); border: 1px solid rgba(232,160,32,0.36); padding: 7px 16px; border-radius: 100px; font-size: 11px; font-weight: 600; color: var(--amber-light); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 26px; font-family: 'DM Sans',sans-serif; }
.badge-pulse { width: 7px; height: 7px; background: var(--amber); border-radius: 50%; animation: pulse 2s infinite; display: inline-block; }

.hero h1 { color: #fff; margin-bottom: 22px; }
.hero h1 em { font-style: italic; color: var(--amber-light); }
.hero-sub { font-size: 16.5px; color: rgba(255,255,255,0.82); max-width: 490px; margin-bottom: 38px; font-weight: 300; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 50px; }
.hero-stats { display: flex; padding-top: 36px; border-top: 1px solid rgba(255,255,255,0.12); flex-wrap: wrap; gap: 0; }
.hstat { padding-right: 28px; margin-right: 28px; border-right: 1px solid rgba(255,255,255,0.14); }
.hstat:last-child { border-right: none; padding-right: 0; margin-right: 0; }
.hstat .num { font-family: 'Cormorant Garamond',serif; font-size: 38px; font-weight: 600; color: var(--amber-light); line-height: 1; display: block; }
.hstat .lbl { font-size: 11px; color: rgba(255,255,255,0.48); text-transform: uppercase; letter-spacing: .08em; margin-top: 4px; display: block; font-family: 'DM Sans',sans-serif; }

/* ── Form Card ── */
.form-card { background: #fff; border-radius: 14px; padding: 38px 34px; box-shadow: 0 24px 80px rgba(0,0,0,0.26),0 4px 16px rgba(0,0,0,0.08); position: relative; overflow: hidden; }
.form-card-top { position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg,var(--amber),var(--green-light)); }
.form-card h2 { font-size: 27px; color: var(--text-dark); margin-bottom: 6px; }
.form-card h2 em { color: var(--green-mid); }
.form-card > p { font-size: 13.5px; color: var(--text-muted); margin-bottom: 20px; font-family: 'DM Sans',sans-serif; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fg { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.fg label { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--text-muted); font-family: 'DM Sans',sans-serif; }
.fg input, .fg select { background: #F7FAFA; border: 1.5px solid var(--border); color: var(--text-dark); padding: 12px 14px; font-family: 'DM Sans',sans-serif; font-size: 14px; border-radius: 7px; outline: none; width: 100%; transition: border-color .2s,box-shadow .2s;}
.fg input::placeholder { color: #B0C8C2; }
.fg input:focus, .fg select:focus { border-color: var(--green-mid); box-shadow: 0 0 0 3px rgba(14,122,104,0.1); }
.fg select { cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B8A84' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.form-submit-btn { width: 100%; padding: 15px; background: var(--green); color: #fff; border: none; border-radius: 7px; font-family: 'DM Sans',sans-serif; font-size: 14px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; cursor: pointer; margin-top: 6px; transition: var(--r); }
.form-submit-btn:hover { background: var(--green-dark); transform: translateY(-1px); box-shadow: 0 8px 28px rgba(14,61,53,0.32); }
.form-disc { text-align: center; font-size: 11.5px; color: var(--text-muted); margin-top: 12px; font-family: 'DM Sans',sans-serif; }

/* ══ TOOLS TICKER ══ */
.tools-bar { background: var(--green-pale); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 20px 0; }
.tools-bar-inner { display: flex; align-items: center; gap: 24px; }
.tools-lbl { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--text-muted); white-space: nowrap; font-family: 'DM Sans',sans-serif; }
.tools-track { overflow: hidden; flex: 1; }
.tools-inner { display: flex; gap: 48px; animation: toolsScroll 22s linear infinite; white-space: nowrap; }
.tool-item { font-size: 13px; font-weight: 600; color: var(--text-body); display: flex; align-items: center; gap: 7px; white-space: nowrap; font-family: 'DM Sans',sans-serif; }
.tool-dot  { color: var(--amber); font-size: 13px; }
@keyframes toolsScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ══ ABOUT STRIP ══ */
.about-strip { display: grid; grid-template-columns: 1fr 1fr; min-height: 480px; }
.about-left  { background: var(--green-pale); padding: 72px 64px; display: flex; flex-direction: column; justify-content: center; }
.about-left p { font-size: 15.5px; line-height: 1.8; margin-bottom: 16px; }
.about-right { background: var(--green); padding: 72px 64px; display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.about-right::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 70% 70% at 80% 30%,rgba(232,160,32,0.1),transparent); pointer-events: none; }
.about-right > * { position: relative; z-index: 1; }
.about-stat { display: flex; align-items: baseline; gap: 4px; }
.about-stat .big { font-family: 'Cormorant Garamond',serif; font-size: 72px; font-weight: 700; color: var(--amber); line-height: 1; }
.about-stat .suf { font-family: 'Cormorant Garamond',serif; font-size: 40px; font-weight: 600; color: var(--amber-light); }
.about-stat-lbl { font-size: 12px; color: rgba(255,255,255,0.48); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 28px; margin-top: 4px; font-family: 'DM Sans',sans-serif; }
.about-right p { font-size: 15px; color: rgba(255,255,255,0.68); line-height: 1.75; margin-bottom: 0; }

/* ══ SERVICES GRID ══ */
.services-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 56px; }
.service-card { background: #fff; border: 1.5px solid var(--border); border-radius: 12px; padding: 36px 28px 30px; position: relative; overflow: hidden; transition: var(--r); text-decoration: none; display: block; color: inherit; }
.service-card::after { content: ''; position: absolute; bottom: 0; left: 0; height: 3px; width: 0; background: linear-gradient(90deg,var(--amber),var(--green-light)); transition: width .4s; border-radius: 0 0 3px 3px; }
.service-card:hover { border-color: var(--green-border); transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.service-card:hover::after { width: 100%; }
.svc-icon { width: 52px; height: 52px; background: var(--green-pale); border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; transition: var(--r); }
.service-card:hover .svc-icon { background: var(--green); }
.service-card:hover .svc-icon svg { stroke: #fff; }
.svc-icon svg { stroke: var(--green-mid); transition: stroke var(--r); }
.service-card h3 { font-size: 21px; color: var(--text-dark); margin-bottom: 10px; }
.service-card p  { font-size: 14px; color: var(--text-muted); }
.svc-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 18px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--green-mid); font-family: 'DM Sans',sans-serif; opacity: 0; transition: opacity var(--r); }
.service-card:hover .svc-link { opacity: 1; }

/* ══ SERVE GRID ══ */
.serve-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 56px; }
.serve-card { background: #fff; border: 1.5px solid var(--border); border-radius: 12px; padding: 30px 26px; position: relative; overflow: hidden; transition: var(--r); }
.serve-card:hover { border-color: var(--amber-border); transform: translateY(-4px); box-shadow: 0 12px 40px rgba(232,160,32,0.11); }
.serve-num { font-family: 'Cormorant Garamond',serif; font-size: 80px; font-weight: 700; color: rgba(14,61,53,0.045); line-height: 1; position: absolute; top: 8px; right: 16px; }
.serve-card h3 { font-size: 20px; color: var(--text-dark); margin-bottom: 9px; position: relative; }
.serve-card p  { font-size: 14px; color: var(--text-muted); position: relative; }

/* ══ WHY LAYOUT ══ */
.why-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; margin-top: 60px; }
.why-items  { display: flex; flex-direction: column; }
.why-item   { display: flex; gap: 20px; padding: 24px 0; border-bottom: 1px solid rgba(255,255,255,0.1); }
.why-item:first-child { padding-top: 0; }
.why-n { font-family: 'Cormorant Garamond',serif; font-size: 42px; font-weight: 300; color: rgba(232,160,32,0.2); line-height: 1; flex-shrink: 0; width: 42px; }
.why-c h3 { font-family: 'Cormorant Garamond',serif; font-size: 21px; font-weight: 600; color: #fff; margin-bottom: 6px; }
.why-c p  { font-size: 14px; color: rgba(255,255,255,0.5); line-height: 1.75; }
.proof-box { background: rgba(255,255,255,0.055); border: 1px solid rgba(255,255,255,0.1); border-radius: 14px; padding: 42px 38px; position: relative; overflow: hidden; }
.proof-box::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg,var(--amber),var(--green-light)); }
.pstat { margin-bottom: 26px; padding-bottom: 26px; border-bottom: 1px solid rgba(255,255,255,0.07); }
.pstat:last-of-type { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.pstat .val  { font-family: 'Cormorant Garamond',serif; font-size: 52px; font-weight: 700; color: var(--amber-light); line-height: 1; }
.pstat .desc { font-size: 13.5px; color: rgba(255,255,255,0.48); margin-top: 4px; font-family: 'DM Sans',sans-serif; }

/* ══ TESTIMONIALS ══ */
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 56px; }
.testi-card { background: #fff; border: 1.5px solid var(--border); border-radius: 12px; padding: 30px 26px; position: relative; transition: var(--r); overflow: hidden; }
.testi-card:hover { border-color: var(--green-border); transform: translateY(-4px); box-shadow: var(--shadow-md); }
.testi-cta  { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 12px; background: var(--green-pale); border: 1.5px solid var(--green-border); border-radius: 12px; padding: 36px 28px; }
.testi-big-num { font-family: 'Cormorant Garamond',serif; font-size: 60px; font-weight: 700; color: var(--green); line-height: 1; }
.testi-cta p { font-size: 15px; color: var(--text-muted); }
.qm   { font-family: 'Cormorant Garamond',serif; font-size: 100px; color: rgba(14,61,53,0.045); position: absolute; top: -4px; left: 14px; line-height: 1; }
.stars { display: flex; gap: 3px; margin-bottom: 12px; font-size: 14px; color: var(--amber); }
.tt   { font-size: 14.5px; color: var(--text-body); line-height: 1.8; margin-bottom: 20px; position: relative; font-family: 'DM Sans',sans-serif; }
.ta   { display: flex; align-items: center; gap: 12px; }
.av   { width: 40px; height: 40px; border-radius: 50%; background: var(--green); color: #fff; display: flex; align-items: center; justify-content: center; font-family: 'Cormorant Garamond',serif; font-size: 17px; font-weight: 600; flex-shrink: 0; }
.an   { font-size: 14px; font-weight: 600; color: var(--text-dark); font-family: 'DM Sans',sans-serif; }
.ac   { font-size: 12px; color: var(--text-muted); font-family: 'DM Sans',sans-serif; }

/* ══ PROCESS ══ */
.process-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; margin-top: 60px; position: relative; }
.process-steps::before { content: ''; position: absolute; top: 33px; left: 12.5%; right: 12.5%; height: 1px; background: linear-gradient(90deg,transparent,var(--amber-border),var(--amber-border),transparent); }
.proc-step { text-align: center; padding: 0 16px; }
.proc-num  { width: 66px; height: 66px; background: var(--white); border: 2px solid var(--amber-border); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; font-family: 'Cormorant Garamond',serif; font-size: 26px; font-weight: 700; color: var(--green); position: relative; z-index: 1; transition: var(--r); }
.proc-step:hover .proc-num { background: var(--green); color: #fff; border-color: var(--green); }
.proc-step h3 { font-size: 19px; color: var(--text-dark); margin-bottom: 9px; }
.proc-step p  { font-size: 13.5px; color: var(--text-muted); }

.acc-toolkit {
  background: var(--green);
  padding: 64px;
  text-align: center;
}
.acc-toolkit-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 40px;
}
.acc-tool-badge {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  padding: 10px 20px; border-radius: 100px;
  font-size: 13px; font-weight: 500; color: rgba(255,255,255,0.75);
  transition: var(--r);
}
.acc-tool-badge:hover { background: var(--amber); color: var(--green); border-color: var(--amber); }
.acc-eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--green-mid); margin-bottom: 16px;
}
.acc-eyebrow::before {
  content: ''; width: 26px; height: 2.5px;
  background: var(--amber); border-radius: 2px;
}
.acc-eyebrow-light { color: var(--amber-light); }
.acc-eyebrow-light::before { background: var(--amber-light); }
.acc-sh {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(34px, 3.6vw, 52px);
  font-weight: 700; line-height: 1.1;
  color: var(--text-dark); margin-bottom: 18px;
}
.acc-sh em       { font-style: italic; color: var(--green-mid); }
.acc-sh em.amber { color: var(--amber); }
.acc-sh-light    { color: #fff; }
.acc-sh-light em { color: var(--amber-light); }

.acc-ssub {
  font-size: 16px; color: var(--text-muted);
  max-width: 560px; line-height: 1.8; font-weight: 300;
}
.acc-ssub-light { color: rgba(255,255,255,0.6); }

.acc-tc { text-align: center; }
.acc-tc .acc-ssub   { margin: 0 auto; }
.acc-tc .acc-eyebrow { justify-content: center; }
.acc-tc .acc-eyebrow::before { display: none; }
/* ══ RESPONSIVE ══ */
@media (max-width: 1100px) {
    .hero-inner   { grid-template-columns: 1fr; }
    .services-grid { grid-template-columns: repeat(2,1fr); }
    .why-layout   { grid-template-columns: 1fr; gap: 48px; }
    .about-strip  { grid-template-columns: 1fr; }
    .about-left, .about-right { padding: 56px 40px; }
}
@media (max-width: 680px) {
    .services-grid, .serve-grid, .testi-grid { grid-template-columns: 1fr; }
    .process-steps { grid-template-columns: repeat(2,1fr); gap: 32px; }
    .process-steps::before { display: none; }
    .form-row { grid-template-columns: 1fr; }
}
