/* SME — Subdivisions Made Easy. Production stylesheet. */
@import url('colors_and_type.css');

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--fg1);background:var(--bg-page);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--sme-orange);color:#fff}
section[id]{scroll-margin-top:96px}

.container{max-width:var(--container);margin:0 auto;padding-inline:var(--gutter)}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding-inline:var(--gutter)}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

.eyebrow{font-family:var(--font-brand);font-weight:500;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sme-orange);display:inline-flex;align-items:center;gap:14px}
.eyebrow.line::before{content:"";width:34px;height:2px;background:var(--sme-orange)}

h1,h2,h3{font-family:var(--font-brand);letter-spacing:-.01em;line-height:1.08;color:var(--fg1);margin:0}
.h-display{font-size:var(--t-display);font-weight:600;line-height:1.04}
.h1{font-size:var(--t-h1);font-weight:600}
.h2{font-size:var(--t-h2);font-weight:600;line-height:1.12}
.h3{font-size:var(--t-h3);font-weight:600}
.lead{font-size:var(--t-body-lg);line-height:1.6;color:var(--fg2)}
.muted{color:var(--fg2)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-brand);font-weight:500;font-size:1rem;border-radius:var(--r-sm);padding:13px 24px;border:1.5px solid transparent;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur-fast) var(--ease),box-shadow var(--dur) var(--ease);letter-spacing:.01em;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--sme-orange);color:#fff}
.btn-primary:hover{background:var(--sme-orange-600);box-shadow:var(--shadow-accent);transform:translateY(-1px)}
.btn-primary:active{background:var(--sme-orange-700);transform:translateY(0)}
.btn-secondary{background:#fff;color:var(--fg1);border-color:var(--border-strong)}
.btn-secondary:hover{border-color:var(--sme-orange);color:var(--sme-orange)}
.btn-light{background:#fff;color:var(--n-900)}
.btn-light:hover{background:var(--n-100);transform:translateY(-1px)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-lg{padding:16px 30px;font-size:1.06rem}

/* nav */
.nav{position:fixed;inset:0 0 auto;z-index:50;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);border-bottom:1px solid transparent;--nav-fg:rgba(255,255,255,.82);--nav-fg-strong:#fff}
.nav-inner{display:flex;align-items:center;gap:36px;height:104px}
.nav-home{display:inline-flex;align-items:center}
.nav-logo{height:76px;width:auto;transition:opacity var(--dur)}
.nav-logo-dark{display:none}
.nav-links{display:flex;gap:30px;margin-left:6px}
.nav-links a{font-family:var(--font-brand);font-weight:500;font-size:.95rem;color:var(--nav-fg);position:relative;padding:6px 0;transition:color var(--dur)}
.nav-links a:hover{color:var(--nav-fg-strong)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--sme-orange);transition:right var(--dur) var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-spacer{flex:1}
.nav.scrolled{background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-color:var(--border);box-shadow:var(--shadow-sm);--nav-fg:var(--fg2);--nav-fg-strong:var(--fg1)}
.nav.scrolled .nav-logo-light{display:none}
.nav.scrolled .nav-logo-dark{display:block}
.nav-burger{display:none;background:none;border:none;cursor:pointer;color:var(--nav-fg);padding:6px}
.nav-burger svg{width:26px;height:26px}
.nav-burger .ic-close{display:none}
.nav-burger.is-open .ic-menu{display:none}
.nav-burger.is-open .ic-close{display:block}

/* hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden;padding-top:104px}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(43,43,43,.92) 0%,rgba(43,43,43,.72) 42%,rgba(43,43,43,.30) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-block:80px}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:rgba(255,255,255,.82);max-width:46ch}
.hero-accent{color:var(--sme-orange)}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-points{margin-top:40px;display:flex;gap:26px;flex-wrap:wrap;color:rgba(255,255,255,.78);font-size:.9rem;list-style:none;padding:0}
.hero-points li{display:inline-flex;align-items:center;gap:9px}
.hero-points svg{width:17px;height:17px;color:var(--sme-orange)}

/* section rhythm */
.section{padding-block:var(--sp-9)}
.section-sm{padding-block:var(--sp-8)}
.section-dark{background:var(--bg-dark);color:#fff}
.section-subtle{background:var(--bg-subtle)}
.section-head{max-width:640px;margin-bottom:48px}
.section-head .h2{margin-top:18px}
.section-head .lead{margin-top:14px}

/* about */
.about-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:64px;align-items:center}
.about-quote{font-family:var(--font-serif);font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.28;color:#fff;margin:22px 0 0;font-weight:500}
.about-by{margin-top:28px;display:flex;align-items:center;gap:14px}
.about-by-badge{width:46px;height:46px;border-radius:50%;background:var(--sme-orange);display:flex;align-items:center;justify-content:center;font-family:var(--font-brand);font-weight:600;color:#fff}
.about-by-name{font-family:var(--font-brand);font-weight:600;color:#fff}
.about-by-role{font-size:.88rem;color:rgba(255,255,255,.6)}
.stat-2x2{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.stat .n{font-family:var(--font-brand);font-weight:600;font-size:3rem;line-height:1;color:#fff;letter-spacing:-.02em}
.stat .l{font-size:.92rem;color:rgba(255,255,255,.7);margin-top:10px}
.about-watermark{position:absolute;right:-40px;bottom:-30px;width:360px;opacity:.06;pointer-events:none}

/* about — partners strip */
.about-partners{margin-top:56px;padding-top:30px;border-top:1px solid rgba(255,255,255,.12);display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.about-partners-label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45);font-family:var(--font-brand);font-weight:500}
.about-partners-logos{display:flex;align-items:center;gap:34px;flex-wrap:wrap}
.about-partners-logos img{height:34px;width:auto;opacity:.6;filter:grayscale(1) brightness(2.2);transition:opacity var(--dur)}
.about-partners-logos img:hover{opacity:.95}
@media(max-width:600px){.about-partners-logos img{height:26px}}

/* generic card */
.card{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease),border-color var(--dur)}
.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--n-300)}

/* service tile */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc{padding:30px 28px}
.svc-ic{width:50px;height:50px;border-radius:11px;background:var(--sme-orange-tint);display:flex;align-items:center;justify-content:center;color:var(--sme-orange);margin-bottom:20px}
.svc-ic svg{width:26px;height:26px}
.svc h3{font-size:1.3rem;margin-bottom:9px}
.svc p{font-size:.96rem;line-height:1.6;color:var(--fg2);margin:0 0 18px}
.svc .link{font-family:var(--font-brand);font-weight:500;font-size:.92rem;color:var(--sme-orange);display:inline-flex;align-items:center;gap:7px;transition:gap var(--dur)}
.svc .link svg{width:16px;height:16px}
.card-hover:hover .link{gap:11px}

/* process */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.step{position:relative;padding:0 18px}
.step-num{font-family:var(--font-serif);font-size:2.4rem;font-weight:500;color:var(--sme-orange);line-height:1}
.step h4{font-family:var(--font-brand);font-weight:600;font-size:1.06rem;margin:14px 0 7px;color:var(--fg1)}
.step p{font-size:.9rem;line-height:1.55;color:var(--fg2);margin:0}
.step::before{content:"";position:absolute;top:34px;left:calc(-50% + 30px);right:calc(50% + 30px);height:1.5px;background:var(--border-strong)}
.step:first-child::before{display:none}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{padding:34px 26px;text-align:center;display:flex;flex-direction:column;align-items:center}
.team-avatar{width:84px;height:84px;border-radius:50%;background:var(--sme-orange-tint);color:var(--sme-orange);display:flex;align-items:center;justify-content:center;font-family:var(--font-brand);font-weight:600;font-size:1.6rem;letter-spacing:.01em;margin-bottom:18px}
.team-avatar.lead{background:var(--sme-orange);color:#fff;box-shadow:var(--shadow-accent)}
.team-card h3{font-family:var(--font-brand);font-weight:600;font-size:1.16rem;color:var(--fg1);margin:0 0 6px}
.team-role{font-size:.92rem;line-height:1.5;color:var(--fg2);margin:0}
.team-link{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-family:var(--font-brand);font-weight:500;font-size:.86rem;color:var(--sme-orange);transition:gap var(--dur)}
.team-link svg{width:16px;height:16px}
.card-hover:hover .team-link{gap:10px}

/* contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:start}
.field{margin-bottom:18px}
.field label{display:block;font-size:.84rem;font-weight:700;color:var(--fg1);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--fg1);padding:13px 15px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);background:#fff;transition:border-color var(--dur),box-shadow var(--dur)}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sme-orange);box-shadow:0 0 0 3px rgba(255,144,18,.16)}
.field input::placeholder,.field textarea::placeholder{color:var(--n-400)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.8rem;color:var(--fg3);text-align:center;margin-top:14px;margin-bottom:0}
.form-error{display:none;margin:0 0 16px;padding:12px 15px;border-radius:var(--r-sm);background:var(--error-bg);color:var(--error);font-size:.9rem}
.success{text-align:center;padding:40px 24px}
.success-ic{width:64px;height:64px;border-radius:50%;background:var(--success-bg);color:var(--success);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.success-ic svg{width:32px;height:32px}
.btn[aria-busy="true"]{opacity:.7;pointer-events:none}

.contact-aside .line{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--hairline)}
.contact-aside .line .ic{width:40px;height:40px;border-radius:9px;background:var(--bg-page);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--sme-orange);flex:none}
.contact-aside .line .ic svg{width:19px;height:19px}
.contact-aside .k{font-size:.78rem;color:var(--fg3);text-transform:uppercase;letter-spacing:.1em}
.contact-aside .v{font-family:var(--font-brand);font-weight:500;font-size:1.05rem;color:var(--fg1);margin-top:3px}

/* footer */
.footer{background:var(--bg-darker);color:rgba(255,255,255,.7);padding-block:var(--sp-8) var(--sp-6)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-logo{height:42px;margin-bottom:18px}
.footer h2{font-family:var(--font-brand);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.footer a{display:block;font-size:.94rem;color:rgba(255,255,255,.66);padding:6px 0;transition:color var(--dur)}
.footer a:hover{color:var(--sme-orange)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:.84rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px}

/* reveal on scroll — progressive enhancement: visible by default, hidden only when JS active */
.reveal{opacity:1;transform:none}
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
html.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;transition:none}}

/* mobile */
.mobile-menu{display:none}
@media(max-width:920px){
  .svc-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .step::before{display:none}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .stat-2x2{gap:32px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px}
  .nav-links{display:none}
  .nav-burger{display:block}
  .nav-cta-desktop{display:none}
  .mobile-menu{display:block;position:fixed;inset:104px 0 auto;z-index:49;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);padding:18px var(--gutter) 26px;transform:translateY(-120%);transition:transform var(--dur) var(--ease);visibility:hidden}
  .mobile-menu.open{transform:none;visibility:visible}
  .mobile-menu a{display:block;font-family:var(--font-brand);font-weight:500;font-size:1.1rem;color:var(--fg1);padding:13px 0;border-bottom:1px solid var(--hairline)}
  .mobile-menu .btn{width:100%;justify-content:center;margin-top:18px}
}
@media(max-width:560px){
  .form-row{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .stat-2x2{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr}
}
