
:root{
  --navy:#0D1B2A;
  --navy2:#14263D;
  --text:#182336;
  --muted:#667389;
  --soft:#F3F5F7;
  --cool:#F7F9FB;
  --line:#DCE3EA;
  --green:#1E513B;
  --radius:6px;
  --max:1240px;
  --shadow:0 20px 55px rgba(13,27,42,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Montserrat,"Helvetica Neue",Arial,sans-serif;color:var(--text);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit} img{display:block;max-width:100%}
.container{width:min(var(--max),calc(100% - 56px));margin:0 auto}
section{padding:104px 0}.section-tight{padding:74px 0}
.eyebrow{display:inline-flex;align-items:center;gap:14px;color:var(--navy);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:22px}.eyebrow:before{content:"";width:44px;height:1px;background:currentColor}
h1{font-size:clamp(46px,5.4vw,82px);line-height:1.02;letter-spacing:-.065em;color:var(--navy);font-weight:620}h2{font-size:clamp(36px,4.1vw,62px);line-height:1.08;letter-spacing:-.06em;color:var(--navy);font-weight:620}h3{color:var(--navy)}p{color:var(--muted)}strong{color:var(--navy)}
.btn{min-height:52px;padding:0 28px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:750;transition:.22s;cursor:pointer;border:0}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:#1B3049;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--navy);border:1px solid var(--line)}.btn-secondary:hover{border-color:var(--navy);transform:translateY(-1px)}.actions{display:flex;gap:14px;flex-wrap:wrap}.meta{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--navy);font-weight:750;margin-bottom:22px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:56px;margin-bottom:56px}.section-head p{max-width:560px;font-size:17px}
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);border-bottom:1px solid rgba(13,27,42,.08);backdrop-filter:blur(14px)}.nav{height:76px;display:flex;justify-content:space-between;align-items:center;gap:28px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:48px;height:32px;object-fit:contain}.brand-name{font-size:20px;line-height:1;font-weight:700;letter-spacing:.18em;color:var(--navy);white-space:nowrap}.menu{display:flex;align-items:center;gap:30px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);white-space:nowrap}.menu a{opacity:.72;transition:.22s}.menu a.active,.menu a:hover{opacity:1}.nav-cta{opacity:1!important;padding:10px 20px;border:1px solid var(--navy);border-radius:999px;font-weight:700}.nav-cta:hover{background:var(--navy);color:#fff}.mobile-toggle{display:none}.hamburger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:999px;align-items:center;justify-content:center;cursor:pointer}.hamburger span,.hamburger span:before,.hamburger span:after{display:block;width:18px;height:2px;background:var(--navy);position:relative;transition:.25s}.hamburger span:before,.hamburger span:after{content:"";position:absolute;left:0}.hamburger span:before{top:-6px}.hamburger span:after{top:6px}
.hero{min-height:690px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);background:#fff}.hero-copy{display:flex;align-items:flex-start;justify-content:center;padding:54px 64px 50px}.hero-copy-inner{width:min(100%,590px)}.hero-copy h1{margin-bottom:24px}.hero-copy p{font-size:19px;max-width:560px;margin-bottom:34px}.hero-image{position:relative;min-height:620px;margin:18px 22px 22px 0;border-radius:var(--radius);overflow:hidden;background:linear-gradient(180deg,rgba(13,27,42,.04),rgba(13,27,42,.45)),var(--hero-img) center/cover no-repeat}.hero-image:after{content:"";position:absolute;inset:24px;border:1px solid rgba(255,255,255,.34);border-radius:6px;pointer-events:none}.hero-caption{position:absolute;left:34px;bottom:34px;width:min(520px,calc(100% - 68px));background:rgba(13,27,42,.9);color:#fff;padding:28px;border-radius:6px;backdrop-filter:blur(16px)}.hero-caption strong{display:block;font-size:32px;line-height:1.06;letter-spacing:-.04em;margin-bottom:10px;color:#fff}.hero-caption span{color:rgba(255,255,255,.74);font-size:15px}
.trust-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;background:#fff}.trust-items{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.trust-item{padding:8px 0}.trust-item strong{display:block;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}.trust-item p{font-size:15px}.dark-band{background:var(--navy);color:#fff;padding:82px 0}.dark-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.dark-card{padding:40px;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius)}.dark-card span{display:block;color:rgba(255,255,255,.54);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:34px}.dark-card h3{color:#fff;font-size:32px;line-height:1.1;letter-spacing:-.045em;font-weight:600;margin-bottom:18px}.dark-card p{color:rgba(255,255,255,.72);font-size:16px}.statement{text-align:center;background:var(--soft)}.statement h2{max-width:920px;margin:0 auto 24px}.statement p{max-width:760px;margin:0 auto;font-size:18px}
.two-col{display:grid;grid-template-columns:.9fr 1.1fr;gap:72px;align-items:center}.photo-panel{min-height:650px;overflow:hidden;border-radius:var(--radius)}.photo-panel img{width:100%;height:100%;object-fit:cover}.number-list{display:grid;border-top:1px solid var(--line)}.number-row{display:grid;grid-template-columns:78px 1fr;gap:28px;padding:28px 0;border-bottom:1px solid var(--line)}.number-row span{font-size:28px;color:#A7B2C1;letter-spacing:-.04em}.number-row h3{font-size:30px;line-height:1.08;letter-spacing:-.04em;margin-bottom:10px}.number-row p{font-size:16px}.project-types{background:var(--cool)}.type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.type-card{position:relative;min-height:390px;overflow:hidden;border-radius:var(--radius);background:#111}.type-card.large{grid-column:span 2}.type-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s;filter:saturate(.92) contrast(1.04)}.type-card:hover img{transform:scale(1.05)}.type-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,27,42,.04),rgba(13,27,42,.78))}.type-content{position:absolute;left:32px;right:32px;bottom:30px;z-index:2;color:#fff}.type-content h3{font-size:34px;line-height:1.05;letter-spacing:-.045em;color:#fff;margin-bottom:10px}.type-content p{color:rgba(255,255,255,.74)}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.case-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.25s}.case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.case-card img{height:250px;width:100%;object-fit:cover}.case-card-body{padding:28px}.case-card-body h3{font-size:28px;line-height:1.1;letter-spacing:-.04em;margin-bottom:12px}.case-card-body p{font-size:16px;margin-bottom:18px}.case-tags{display:flex;flex-wrap:wrap;gap:10px}.case-tag{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);background:var(--soft);padding:10px 12px;border-radius:999px}.highlight{display:grid;grid-template-columns:1fr 1fr;min-height:630px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}.highlight-image{overflow:hidden;background:var(--soft)}.highlight-image img{width:100%;height:100%;object-fit:cover}.highlight-copy{padding:72px;display:flex;flex-direction:column;justify-content:center}.highlight-copy h2{margin-bottom:22px}.highlight-copy p{font-size:17px;margin-bottom:28px}.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.metric{background:var(--soft);padding:22px;border-radius:6px}.metric strong{display:block;font-size:24px;line-height:1}.metric span{display:block;margin-top:8px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.value-card{padding:34px;border:1px solid var(--line);border-radius:var(--radius);background:#fff}.value-card h3{font-size:24px;line-height:1.1;letter-spacing:-.03em;margin-bottom:12px}.value-card p{font-size:15px}
.home-form-card{display:grid;grid-template-columns:.88fr 1.12fr;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.home-form-copy{background:var(--navy);color:#fff;padding:72px;display:flex;flex-direction:column;justify-content:center}.home-form-copy h2{color:#fff;margin-bottom:18px}.home-form-copy p{color:rgba(255,255,255,.76);font-size:18px}.home-form-points{list-style:none;display:grid;gap:10px;margin-top:28px}.home-form-points li{color:rgba(255,255,255,.8)}.home-form-points li:before{content:"— ";color:#fff}.form-panel{padding:40px;background:#fff}.form-grid{display:grid;gap:16px}input,select,textarea{width:100%;border:1px solid var(--line);padding:17px 18px;border-radius:6px;font:inherit;background:#fff;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--navy)}textarea{min-height:160px;resize:vertical}.form-note,.form-status{font-size:13px;color:var(--muted)}.form-status.success{color:var(--green)}.form-status.error{color:#9B1C1C}.cta{background:linear-gradient(135deg,var(--navy),#07111D);color:#fff;text-align:center;padding:120px 0}.cta h2{color:#fff;max-width:820px;margin:0 auto 20px}.cta p{max-width:720px;margin:0 auto 36px;color:rgba(255,255,255,.74);font-size:18px}.cta .btn-primary{background:#fff;color:var(--navy)}
.page-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--navy),#07111D);color:#fff;padding:118px 0}.page-hero:after{content:"ER";position:absolute;right:4%;bottom:-18%;font-size:280px;line-height:1;font-weight:800;letter-spacing:-.12em;color:rgba(255,255,255,.045)}.page-hero h1{color:#fff;max-width:980px;margin-bottom:22px}.page-hero p{color:rgba(255,255,255,.74);font-size:18px;max-width:840px}.breadcrumb{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:24px}.breadcrumb a{color:rgba(255,255,255,.78)}.service-overview{display:grid;grid-template-columns:.88fr 1.12fr;gap:72px;align-items:start}.sticky-intro{position:sticky;top:112px}.sticky-intro p{font-size:18px;margin-top:18px}.service-list{border-top:1px solid var(--line)}.service-row{display:grid;grid-template-columns:90px 1fr;gap:32px;padding:34px 0;border-bottom:1px solid var(--line)}.service-row span{font-size:28px;color:#A7B2C1;letter-spacing:-.04em}.service-row h3{font-size:30px;line-height:1.1;letter-spacing:-.04em;margin-bottom:10px}.service-row p{font-size:16px}.scope-section{background:var(--soft)}.scope-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.scope-card{background:#fff;border:1px solid var(--line);padding:34px;min-height:304px;border-radius:var(--radius)}.scope-card h3{font-size:28px;line-height:1.08;letter-spacing:-.04em;margin-bottom:14px}.scope-card p{font-size:16px}.scope-card ul{list-style:none;display:grid;gap:8px;margin-top:18px;color:var(--muted)}.process-list{border-top:1px solid var(--line)}.process-row{display:grid;grid-template-columns:120px 1fr 320px;gap:40px;padding:42px 0;border-bottom:1px solid var(--line)}.process-row .n{font-size:48px;color:#A7B2C1;line-height:1;letter-spacing:-.05em}.process-row h3{font-size:34px;line-height:1.08;letter-spacing:-.05em;margin-bottom:12px}.process-row p{font-size:17px}.process-row ul{list-style:none;display:grid;gap:8px;color:var(--muted)}.projects-stack{display:grid;gap:34px}.project-case{display:grid;grid-template-columns:1.02fr .98fr;min-height:620px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}.project-case:nth-child(even){grid-template-columns:.98fr 1.02fr}.project-case:nth-child(even) .case-copy-panel{order:1}.project-case:nth-child(even) .case-photo{order:2}.case-photo{min-height:620px;overflow:hidden}.case-photo img{width:100%;height:100%;object-fit:cover}.case-copy-panel{padding:72px;display:flex;flex-direction:column;justify-content:center}.case-copy-panel h2{margin-bottom:20px}.case-copy-panel p{font-size:17px;margin-bottom:28px}.case-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.case-spec{background:var(--soft);padding:18px;border-radius:6px}.case-spec strong{display:block;color:var(--navy);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}.case-spec span{color:var(--text);font-size:15px}
.case-hero{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch}.case-hero-photo{min-height:460px;border-radius:var(--radius);overflow:hidden}.case-hero-photo img{width:100%;height:100%;object-fit:cover}.case-hero-copy{padding:8px 0}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}.kpi{background:var(--soft);padding:18px;border-radius:6px}.kpi strong{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}.kpi span{font-size:15px;color:var(--text)}.case-detail-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:42px;align-items:start}.case-side{position:sticky;top:112px;border:1px solid var(--line);border-radius:var(--radius);padding:30px;background:#fff}.case-side ul{list-style:none;display:grid;gap:12px}.case-main{display:grid;gap:18px}.detail-card{border:1px solid var(--line);border-radius:var(--radius);padding:30px;background:#fff}.detail-card h3{font-size:28px;line-height:1.08;letter-spacing:-.04em;margin-bottom:12px}.detail-card p{font-size:16px}.detail-card ul{margin-top:14px;display:grid;gap:8px;padding-left:18px;color:var(--muted)}.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.journal-feature{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:72px;margin-bottom:50px}.journal-feature img{height:500px;width:100%;object-fit:cover;border-radius:var(--radius)}.journal-feature h2{margin-bottom:18px}.journal-feature p{font-size:17px;margin-bottom:24px}.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.article{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:.25s}.article:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.article img{height:260px;width:100%;object-fit:cover}.article div{padding:28px}.article h3{font-size:26px;line-height:1.14;letter-spacing:-.035em;margin-bottom:12px}.about-split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}.about-split img{width:100%;height:620px;object-fit:cover;border-radius:var(--radius)}.about-split p{font-size:18px;margin-top:18px}.founder-block{background:var(--soft)}.founder-inner{display:grid;grid-template-columns:.92fr 1.08fr;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}.founder-photo{min-height:620px;overflow:hidden;background:#e7ecf1}.founder-photo img{width:100%;height:100%;object-fit:cover}.founder-copy{padding:72px;display:flex;flex-direction:column;justify-content:center}.founder-copy h2{margin-bottom:20px}.founder-copy p{font-size:18px;margin-bottom:16px}.signature{margin-top:24px;color:var(--navy);font-weight:750}.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.about-proof{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.about-proof-card{padding:34px;border:1px solid var(--line);border-radius:var(--radius);background:#fff}.about-proof-card h3{font-size:24px;line-height:1.1;margin-bottom:10px}.contact-grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:72px}.contact-list{list-style:none;display:grid;gap:14px;margin-top:30px;color:var(--muted)}.contact-steps{margin-top:28px;display:grid;gap:12px}.contact-step{padding:16px 18px;background:var(--soft);border-radius:6px}.contact-step strong{display:block;color:var(--navy);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:34px}.faq-card{padding:24px;border:1px solid var(--line);border-radius:var(--radius);background:#fff}.faq-card h3{font-size:20px;line-height:1.2;margin-bottom:10px}
.footer{background:#fff;border-top:1px solid var(--line);padding:54px 0 28px}.footer-main{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:56px}.footer-brand .brand{margin-bottom:18px}.footer-brand p{max-width:380px}.footer h4{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);margin-bottom:16px}.footer p,.footer a,.footer li{color:var(--muted);font-size:14px}.footer ul{list-style:none;display:grid;gap:9px}.footer-links{display:grid;grid-template-columns:repeat(2,1fr);gap:34px}.copy{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line);margin-top:40px;padding-top:22px;color:var(--muted);font-size:13px}.copy a{margin-left:14px}.whatsapp{position:fixed;right:24px;bottom:24px;z-index:70;background:var(--green);color:#fff;padding:14px 18px;border-radius:999px;font-size:14px;font-weight:750;box-shadow:0 16px 40px rgba(0,0,0,.18)}
@media(max-width:1100px){.trust-items,.dark-grid,.scope-grid,.values-grid,.article-grid,.value-grid,.case-grid,.related-grid,.about-proof{grid-template-columns:1fr 1fr}.hero,.two-col,.highlight,.service-overview,.project-case,.project-case:nth-child(even),.journal-feature,.about-split,.founder-inner,.contact-grid,.home-form-card,.case-hero,.case-detail-grid{grid-template-columns:1fr}.case-copy-panel,.project-case:nth-child(even) .case-copy-panel{order:2}.case-photo,.project-case:nth-child(even) .case-photo{order:1}.case-side{position:static}.footer-main{grid-template-columns:1fr}}
@media(max-width:920px){.nav{height:74px}.hamburger{display:flex}.menu{position:fixed;top:74px;left:0;right:0;display:grid;gap:0;padding:18px 28px 28px;background:#fff;border-bottom:1px solid var(--line);transform:translateY(-140%);opacity:0;pointer-events:none;transition:.25s ease;box-shadow:var(--shadow)}.menu a{padding:16px 0;border-bottom:1px solid var(--line);opacity:1}.menu a:last-child{border-bottom:0}.mobile-toggle:checked ~ .menu{transform:translateY(0);opacity:1;pointer-events:auto}.mobile-toggle:checked + .hamburger span{background:transparent}.mobile-toggle:checked + .hamburger span:before{top:0;transform:rotate(45deg)}.mobile-toggle:checked + .hamburger span:after{top:0;transform:rotate(-45deg)}.hero{min-height:auto}.hero-copy{padding:42px 28px 38px}.hero-image{min-height:500px;margin:0 28px 28px}.section-head{display:grid}.sticky-intro{position:static}.process-row{grid-template-columns:1fr;gap:14px}.highlight-copy,.case-copy-panel,.founder-copy,.home-form-copy{padding:52px}}
@media(max-width:640px){.container{width:min(100% - 34px,var(--max))}.brand-mark{width:42px;height:28px}.brand-name{font-size:16px;letter-spacing:.14em}h1{font-size:40px}h2{font-size:36px}section{padding:76px 0}.page-hero{padding:88px 0}.hero-copy{padding:28px 24px 32px}.hero-copy p,.statement p,.cta p,.home-form-copy p,.page-hero p,.highlight-copy p,.about-split p,.founder-copy p{font-size:16px}.btn{width:100%}.trust-items,.dark-grid,.type-grid,.scope-grid,.values-grid,.article-grid,.metrics,.footer-links,.case-grid,.value-grid,.related-grid,.kpi-grid,.case-specs,.faq-grid,.about-proof{grid-template-columns:1fr}.type-card.large{grid-column:span 1}.type-card,.type-card.large,.photo-panel,.case-photo,.project-case,.case-hero-photo{min-height:420px}.hero-image{min-height:420px;margin:0 17px 17px;border-radius:6px}.hero-image:after{inset:18px}.hero-caption{left:20px;right:20px;bottom:20px;width:auto;padding:24px}.hero-caption strong{font-size:26px}.highlight-copy,.case-copy-panel,.founder-copy,.form-panel,.home-form-copy,.case-side,.detail-card{padding:30px}.footer-main{gap:34px}.copy{display:grid}.copy a{margin-left:0;margin-right:12px}.whatsapp{right:16px;bottom:16px}}

/* ===== V17 homepage clean banner refinement ===== */
.text-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);font-weight:750}
.text-link:after{content:"↗"}
.hero-v17{position:relative;padding:132px 0 78px;background:linear-gradient(90deg, rgba(8,17,27,.82) 0%, rgba(8,17,27,.62) 34%, rgba(8,17,27,.28) 58%, rgba(8,17,27,.22) 100%),url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=1800&q=80') center/cover no-repeat}
.hero-v17:before{content:"";position:absolute;inset:20px;border:1px solid rgba(255,255,255,.12);border-radius:26px;pointer-events:none}.hero-v17-shell{position:relative;z-index:2;min-height:620px;display:grid;grid-template-columns:1fr 410px;gap:32px;align-items:end}.hero-v17-copy{max-width:690px;padding-bottom:72px}.hero-v17-copy h1{font-size:clamp(70px,8.2vw,122px);line-height:.86;letter-spacing:-.085em;color:#fff;margin-bottom:20px;max-width:660px}.hero-v17-copy p{font-size:21px;line-height:1.55;color:rgba(255,255,255,.84);max-width:560px;margin-bottom:30px}.hero-light{color:rgba(255,255,255,.72)}.hero-v17 .btn-secondary{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.24);color:#fff}.hero-v17 .btn-secondary:hover{background:rgba(255,255,255,.2)}
.hero-v17-panel{align-self:end;margin-bottom:72px;background:rgba(255,255,255,.9);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.52);border-radius:20px;padding:28px;box-shadow:0 24px 70px rgba(8,17,27,.22)}.hero-v17-badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#f4f7fa;border:1px solid rgba(13,27,42,.08);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#8c97a7;margin-bottom:16px}.hero-v17-panel strong{display:block;font-size:34px;line-height:1.02;letter-spacing:-.05em;color:var(--navy);margin-bottom:10px}.hero-v17-panel p{font-size:15px;line-height:1.65;color:var(--muted);margin:0}
.home-opening-v17{padding:84px 0 108px;background:#fff}.opening-v17-grid{display:grid;grid-template-columns:.76fr 1.24fr;gap:34px;align-items:start}.opening-v17-intro{padding-top:10px}.opening-v17-intro h2{font-size:clamp(42px,4.8vw,68px);line-height:.96;letter-spacing:-.06em;margin-bottom:16px;max-width:500px}.opening-v17-intro p{font-size:18px;line-height:1.7;max-width:460px;margin-bottom:20px}.opening-v17-layout{display:grid;grid-template-columns:1.08fr .92fr;gap:18px}.opening-v17-featured,.opening-v17-card{border-radius:22px;padding:28px;border:1px solid var(--line);box-shadow:0 18px 42px rgba(13,27,42,.05)}.opening-v17-featured{grid-row:span 2;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(180deg, #10263b 0%, #0d1b2a 100%)}.opening-v17-featured span,.opening-v17-card span{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px}.opening-v17-featured span{color:rgba(255,255,255,.48)}.opening-v17-featured h3{font-size:42px;line-height:1.02;letter-spacing:-.055em;color:#fff;margin:0;max-width:420px}.opening-v17-card{background:#f8fafb}.opening-v17-card p{font-size:16px;line-height:1.65;margin:0}.opening-v17-card span{color:#8c97a7}.opening-v17-card.wide{grid-column:1 / -1;display:grid;grid-template-columns:.78fr 1.22fr;gap:18px;align-items:center;background:#fff}.opening-v17-card.wide h3{font-size:30px;line-height:1.05;letter-spacing:-.045em;margin:0}
@media(max-width:1100px){.opening-v17-grid{grid-template-columns:1fr}}
@media(max-width:980px){.hero-v17{padding:104px 0 64px}.hero-v17-shell{grid-template-columns:1fr;min-height:auto}.hero-v17-copy,.hero-v17-panel{margin-bottom:0;padding-bottom:0}.hero-v17-panel{max-width:440px}}
@media(max-width:920px){.opening-v17-layout{grid-template-columns:1fr}.opening-v17-featured{grid-row:auto;min-height:auto}.opening-v17-card.wide{grid-column:auto;grid-template-columns:1fr}}
@media(max-width:640px){.hero-v17{padding:88px 0 52px}.hero-v17:before{inset:12px;border-radius:18px}.hero-v17-copy h1{font-size:clamp(50px,14vw,74px)}.hero-v17-copy p,.opening-v17-intro p{font-size:17px}.hero-v17 .actions{display:grid}.hero-v17-panel{border-radius:16px;padding:22px}.hero-v17-panel strong{font-size:28px}.home-opening-v17{padding:72px 0 86px}.opening-v17-intro h2{font-size:clamp(36px,10vw,50px)}.opening-v17-featured,.opening-v17-card{padding:22px;border-radius:18px}.opening-v17-featured h3{font-size:32px}.opening-v17-card.wide h3{font-size:24px}}

/* ===== V18 homepage refined premium banner ===== */
.text-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);font-weight:750}
.text-link:after{content:"↗"}
.hero-v18{
  position:relative;
  padding:140px 0 96px;
  background:
    radial-gradient(circle at 78% 22%, rgba(255,255,255,.12), transparent 18%),
    linear-gradient(90deg, rgba(8,17,27,.84) 0%, rgba(8,17,27,.62) 34%, rgba(8,17,27,.26) 58%, rgba(8,17,27,.18) 100%),
    url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=2200&q=80') center/cover no-repeat;
}
.hero-v18:before{
  content:"";
  position:absolute;
  inset:22px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:28px;
  pointer-events:none;
}
.hero-v18:after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:120px;
  background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.92) 100%);
}
.hero-v18-shell{
  position:relative;
  z-index:2;
  min-height:650px;
  display:grid;
  grid-template-columns:1fr 360px;
  gap:36px;
  align-items:end;
}
.hero-v18-copy{
  max-width:700px;
  padding:0 0 92px;
}
.hero-v18-copy h1{
  font-size:clamp(72px,8.4vw,126px);
  line-height:.84;
  letter-spacing:-.09em;
  color:#fff;
  margin-bottom:20px;
  max-width:680px;
}
.hero-v18-copy p{
  font-size:20px;
  line-height:1.58;
  color:rgba(255,255,255,.84);
  max-width:520px;
  margin-bottom:32px;
}
.hero-light{color:rgba(255,255,255,.7)}
.hero-v18 .btn-secondary{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.24);
  color:#fff;
}
.hero-v18 .btn-secondary:hover{background:rgba(255,255,255,.2)}
.hero-v18-panel{
  align-self:end;
  margin-bottom:92px;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.52);
  border-radius:22px;
  padding:30px;
  box-shadow:0 26px 72px rgba(8,17,27,.24);
}
.hero-v18-badge{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:#f4f7fa;
  border:1px solid rgba(13,27,42,.08);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#8c97a7;
  margin-bottom:16px;
}
.hero-v18-panel strong{
  display:block;
  font-size:34px;
  line-height:1.02;
  letter-spacing:-.05em;
  color:var(--navy);
  margin-bottom:12px;
}
.hero-v18-panel p{
  font-size:15px;
  line-height:1.68;
  color:var(--muted);
  margin:0;
}

.home-opening-v18{
  padding:66px 0 108px;
  background:#fff;
}
.opening-v18-grid{
  display:grid;
  grid-template-columns:.74fr 1.26fr;
  gap:36px;
  align-items:start;
}
.opening-v18-intro{
  padding-top:14px;
}
.opening-v18-intro h2{
  font-size:clamp(42px,4.9vw,70px);
  line-height:.96;
  letter-spacing:-.06em;
  margin-bottom:16px;
  max-width:500px;
}
.opening-v18-intro p{
  font-size:18px;
  line-height:1.72;
  max-width:470px;
  margin-bottom:22px;
}
.opening-v18-layout{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:18px;
}
.opening-v18-featured,
.opening-v18-card{
  border-radius:22px;
  padding:30px;
  border:1px solid var(--line);
  box-shadow:0 18px 42px rgba(13,27,42,.05);
}
.opening-v18-featured{
  grid-row:span 2;
  min-height:340px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  background:linear-gradient(180deg, #10263b 0%, #0d1b2a 100%);
}
.opening-v18-featured span,
.opening-v18-card span{
  display:block;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.opening-v18-featured span{color:rgba(255,255,255,.48)}
.opening-v18-featured h3{
  font-size:44px;
  line-height:1.02;
  letter-spacing:-.055em;
  color:#fff;
  margin:0;
  max-width:400px;
}
.opening-v18-card{
  background:#f8fafb;
}
.opening-v18-card span{color:#8c97a7}
.opening-v18-card p{
  font-size:16px;
  line-height:1.65;
  margin:0;
}
.opening-v18-card.wide{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:18px;
  align-items:center;
  background:#fff;
}
.opening-v18-card.wide h3{
  font-size:30px;
  line-height:1.06;
  letter-spacing:-.045em;
  margin:0;
}

@media(max-width:1100px){
  .hero-v18-shell,
  .opening-v18-grid{grid-template-columns:1fr}
}
@media(max-width:980px){
  .hero-v18{padding:112px 0 82px}
  .hero-v18-shell{min-height:auto}
  .hero-v18-copy,.hero-v18-panel{margin-bottom:0;padding-bottom:0}
  .hero-v18-panel{max-width:460px}
}
@media(max-width:920px){
  .opening-v18-layout{grid-template-columns:1fr}
  .opening-v18-featured{grid-row:auto;min-height:auto}
  .opening-v18-card.wide{grid-column:auto;grid-template-columns:1fr}
}
@media(max-width:640px){
  .hero-v18{padding:92px 0 62px}
  .hero-v18:before{inset:12px;border-radius:18px}
  .hero-v18:after{height:80px}
  .hero-v18-copy h1{font-size:clamp(52px,14vw,76px)}
  .hero-v18-copy p,.opening-v18-intro p{font-size:17px}
  .hero-v18 .actions{display:grid}
  .hero-v18-panel{padding:22px;border-radius:16px}
  .hero-v18-panel strong{font-size:28px}
  .home-opening-v18{padding:54px 0 86px}
  .opening-v18-intro h2{font-size:clamp(36px,10vw,50px)}
  .opening-v18-featured,.opening-v18-card{padding:22px;border-radius:18px}
  .opening-v18-featured h3{font-size:32px}
  .opening-v18-card.wide h3{font-size:24px}
}

/* ===== V19 homepage rebuilt: stronger cinematic hero + simpler second screen ===== */
.hero-v19{
  position:relative;
  min-height:820px;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:#08111b;
}
.hero-v19-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(8,17,27,.28) 0%, rgba(8,17,27,.36) 42%, rgba(8,17,27,.76) 100%),
    linear-gradient(90deg, rgba(8,17,27,.66) 0%, rgba(8,17,27,.26) 48%, rgba(8,17,27,.56) 100%),
    url('https://e-reaching.com/wp-content/uploads/2026/04/ChatGPT-Image-2026年4月28日-17_13_07.png') center/cover no-repeat;
  transform:scale(1.02);
  @media (max-width: 1200px) {
    .hero-v19-bg { min-height: 50vh; }
}
@media (max-width: 768px) {
    .hero-v19-bg { min-height: 40vh; }
    .hero-v19-inner h1 { font-size: 2rem; }
    .hero-v19-inner p { font-size: 1rem; }
}
@media (max-width: 480px) {
    .hero-v19-bg { min-height: 35vh; }
    .hero-v19-inner h1 { font-size: 1.6rem; }
    .hero-v19-inner p { font-size: 0.9rem; }
}
}
.hero-v19:before{
  content:"";
  position:absolute;
  inset:22px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:30px;
  z-index:1;
  pointer-events:none;
}
.hero-v19:after{
  content:"E-REACHING";
  position:absolute;
  right:34px;
  top:50%;
  transform:translateY(-50%) rotate(90deg);
  transform-origin:center;
  z-index:1;
  color:rgba(255,255,255,.26);
  font-size:12px;
  letter-spacing:.42em;
  font-weight:700;
}
.hero-v19-inner{
  position:relative;
  z-index:2;
  text-align:center;
  color:#fff;
  padding-top:38px;
}
.hero-v19-kicker{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-bottom:24px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.72);
}
.hero-v19-kicker:before,
.hero-v19-kicker:after{
  content:"";
  width:42px;
  height:1px;
  background:rgba(255,255,255,.42);
}
.hero-v19 h1{
  color:#fff;
  font-size:clamp(74px,10vw,146px);
  line-height:.86;
  letter-spacing:-.09em;
  max-width:980px;
  margin:0 auto 28px;
}
.hero-v19 p{
  color:rgba(255,255,255,.82);
  font-size:21px;
  line-height:1.55;
  max-width:660px;
  margin:0 auto 34px;
}
.hero-v19-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}
.hero-v19 .btn-primary{
  background:#fff;
  color:var(--navy);
}
.hero-v19 .btn-secondary{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.26);
  color:#fff;
}
.hero-v19-caption{
  position:absolute;
  left:50%;
  bottom:44px;
  transform:translateX(-50%);
  z-index:2;
  width:min(760px,calc(100% - 80px));
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:22px;
  padding:18px 22px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(16px);
  color:#fff;
}
.hero-v19-caption span{
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.66);
}
.hero-v19-caption strong{
  color:#fff;
  font-size:16px;
  font-weight:650;
}

.home-opening-v19{
  padding:116px 0 112px;
  background:#fff;
}
.opening-v19-shell{
  display:grid;
  grid-template-columns:.86fr 1.14fr;
  gap:72px;
  align-items:start;
}
.opening-v19-left h2{
  font-size:clamp(48px,5.8vw,84px);
  line-height:.94;
  letter-spacing:-.07em;
  max-width:560px;
  margin:0;
}
.opening-v19-right p{
  font-size:22px;
  line-height:1.62;
  max-width:720px;
  margin:0 0 34px;
  color:var(--text);
}
.opening-v19-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.opening-v19-grid article{
  min-height:210px;
  padding:32px 28px;
  border-left:1px solid var(--line);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  background:#fff;
}
.opening-v19-grid article:first-child{border-left:none}
.opening-v19-grid span{
  font-size:12px;
  letter-spacing:.18em;
  color:#9aa5b4;
}
.opening-v19-grid h3{
  font-size:32px;
  line-height:1.02;
  letter-spacing:-.05em;
  margin:0;
}

@media(max-width:1100px){
  .opening-v19-shell{grid-template-columns:1fr;gap:34px}
}
@media(max-width:920px){
  .hero-v19{min-height:760px}
  .opening-v19-grid{grid-template-columns:1fr}
  .opening-v19-grid article{border-left:none;border-top:1px solid var(--line);min-height:160px}
  .opening-v19-grid article:first-child{border-top:none}
}
@media(max-width:640px){
  .hero-v19{min-height:720px}
  .hero-v19:before{inset:12px;border-radius:18px}
  .hero-v19:after{display:none}
  .hero-v19 h1{font-size:clamp(54px,15vw,78px)}
  .hero-v19 p{font-size:17px;max-width:340px}
  .hero-v19-actions{display:grid}
  .hero-v19-caption{
    bottom:24px;
    width:calc(100% - 34px);
    border-radius:18px;
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }
  .home-opening-v19{padding:82px 0 88px}
  .opening-v19-left h2{font-size:clamp(40px,11vw,58px)}
  .opening-v19-right p{font-size:18px}
  .opening-v19-grid article{padding:26px 0;min-height:138px}
  .opening-v19-grid h3{font-size:30px}
}

/* ===== V21 homepage polish ===== */
.opening-v19-grid article,
.opening-v19-grid h3,
.opening-v19-grid span,
.dark-card,
.dark-card h3,
.dark-card span,
.metric{
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, background-color .24s ease, color .24s ease, opacity .24s ease;
}

/* Second screen hover: restrained, premium */
.opening-v19-grid article{
  position:relative;
  overflow:hidden;
}
.opening-v19-grid article:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:2px;
  background:linear-gradient(90deg, #c4a97a 0%, rgba(196,169,122,0) 82%);
  opacity:0;
}
.opening-v19-grid article:hover{
  background:#fbfbfc;
  transform:translateY(-4px);
  box-shadow:0 14px 28px rgba(13,27,42,.06);
}
.opening-v19-grid article:hover:after{opacity:1}
.opening-v19-grid article:hover span{color:#b5955c}
.opening-v19-grid article:hover h3{transform:translateY(-2px);color:var(--navy)}

/* Third screen hover: subtle lift, unified with homepage */
.dark-card{
  position:relative;
  overflow:hidden;
}
.dark-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(196,169,122,.05) 0%, rgba(196,169,122,.12) 100%);
  opacity:0;
  pointer-events:none;
}
.dark-card:hover{
  transform:translateY(-6px);
  border-color:rgba(196,169,122,.28);
  box-shadow:0 18px 36px rgba(0,0,0,.14);
}
.dark-card:hover:after{opacity:1}
.dark-card:hover span{color:rgba(255,255,255,.72)}
.dark-card:hover h3{transform:translateY(-2px)}

/* Process block refined to feel more natural */
.process-flow{
  padding-top:24px;
}
.process-flow-card{
  min-height:560px;
  border-radius:var(--radius);
  border:1px solid #e8edf2;
  background:linear-gradient(180deg, #fbfbfc 0%, #f6f8fa 100%);
  box-shadow:0 10px 30px rgba(13,27,42,.04);
}
.process-flow-card .highlight-image{
  background:#edf2f5;
}
.process-flow-card .highlight-copy{
  padding:78px 72px;
}
.process-flow-card .meta{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#8c97a7;
  margin-bottom:18px;
}
.process-flow-card .highlight-copy h2{
  margin-bottom:18px;
  max-width:520px;
}
.process-flow-card .highlight-copy p{
  margin-bottom:26px;
  max-width:540px;
}
.process-flow-card .metric{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
}
.process-flow-card .metric:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 22px rgba(13,27,42,.06);
  border-color:#dde5ec;
}

@media(max-width:920px){
  .opening-v19-grid article:hover,
  .dark-card:hover,
  .process-flow-card .metric:hover{transform:none}
}
@media(max-width:640px){
  .process-flow{padding-top:10px}
  .process-flow-card .highlight-copy{padding:34px 30px}
}

/* ===== V22 process strip option ===== */
.process-strip-section{
  padding:18px 0 28px;
}
.process-strip{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:26px;
  align-items:center;
  padding:24px 28px;
  border:1px solid #e7ecf1;
  border-radius:18px;
  background:linear-gradient(180deg, #fbfbfc 0%, #f6f8fa 100%);
  box-shadow:0 10px 26px rgba(13,27,42,.04);
}
.process-strip-copy{
  display:grid;
  gap:10px;
}
.process-strip-label{
  display:inline-flex;
  width:fit-content;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#8c97a7;
}
.process-strip-copy strong{
  font-size:30px;
  line-height:1.05;
  letter-spacing:-.04em;
  color:var(--navy);
  max-width:520px;
}
.process-strip-steps{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.process-strip-step{
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.process-strip-step span{
  display:block;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#8c97a7;
  margin-bottom:8px;
}
.process-strip-step p{
  margin:0;
  font-size:15px;
  line-height:1.45;
  color:var(--navy);
  font-weight:650;
}
.process-strip-step:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 20px rgba(13,27,42,.05);
  border-color:#dce3ea;
}
@media(max-width:1100px){
  .process-strip{grid-template-columns:1fr}
}
@media(max-width:640px){
  .process-strip-section{padding:8px 0 18px}
  .process-strip{padding:20px 20px 18px;gap:18px;border-radius:14px}
  .process-strip-copy strong{font-size:24px}
  .process-strip-steps{grid-template-columns:1fr}
}

/* ===== V23 tighter spacing between cases and process strip ===== */
.process-strip-section{
  margin-top:-44px;
  padding-top:0;
  padding-bottom:24px;
}
@media(max-width:640px){
  .process-strip-section{
    margin-top:-28px;
    padding-bottom:16px;
  }
}

/* ===== V24 final polish: unified small-radius system ===== */
:root{
  --radius:6px;
  --radius-card:8px;
  --radius-panel:10px;
}

/* Core cards and layout containers */
.dark-card,
.case-card,
.highlight,
.value-card,
.home-form-card,
.scope-card,
.project-case,
.case-hero-photo,
.case-side,
.detail-card,
.article,
.about-proof-card,
.faq-card,
.founder-inner,
.process-flow-card,
.process-strip,
.process-strip-step,
.opening-v17-featured,
.opening-v17-card,
.opening-v18-featured,
.opening-v18-card,
.hero-v17-panel,
.hero-v18-panel{
  border-radius:var(--radius-card);
}

/* Image containers and media blocks */
.hero-image,
.photo-panel,
.type-card,
.journal-feature img,
.about-split img,
.case-card,
.case-hero-photo,
.process-strip,
.project-case,
.founder-inner{
  border-radius:var(--radius-card);
}

/* Small utility surfaces */
.hero-image:after,
.hero-caption,
.metric,
.case-spec,
.kpi,
.contact-step,
input,
select,
textarea{
  border-radius:var(--radius);
}

/* Featured homepage / premium frame elements */
.hero-v17:before,
.hero-v18:before,
.hero-v19:before,
.hero-v19-caption{
  border-radius:var(--radius-panel);
}

.process-strip,
.process-strip-step,
.opening-v19-grid article:hover,
.dark-card:hover{
  box-shadow:0 14px 30px rgba(13,27,42,.06);
}

/* Mobile consistency */
@media(max-width:640px){
  .hero-v17:before,
  .hero-v18:before,
  .hero-v19:before,
  .hero-v19-caption,
  .process-strip,
  .hero-v17-panel,
  .hero-v18-panel,
  .opening-v17-featured,
  .opening-v17-card,
  .opening-v18-featured,
  .opening-v18-card{
    border-radius:8px;
  }
}

/* ===== V25: restore V14 contact page layout with final small-radius system ===== */
.contact-page-hero{padding-bottom:96px}
.contact-v14-grid{
  display:grid;
  grid-template-columns:.78fr 1.22fr;
  gap:30px;
  align-items:start;
}
.contact-v14-side{
  display:grid;
  gap:18px;
  position:sticky;
  top:108px;
}
.contact-v14-company-card,
.contact-v14-support-card,
.contact-v14-form-card{
  border:1px solid var(--line);
  border-radius:var(--radius-card);
  background:#fff;
  box-shadow:0 14px 30px rgba(13,27,42,.045);
}
.contact-v14-company-card,
.contact-v14-support-card{padding:28px}
.contact-v14-company-card h2{
  font-size:clamp(28px,3vw,40px);
  line-height:1.06;
  letter-spacing:-.045em;
  margin-bottom:18px;
}
.contact-list.compact{gap:16px;margin-top:0}
.contact-whatsapp{margin-top:24px}
.contact-v14-main{display:grid;gap:18px}
.contact-v14-form-card{padding:30px}
.contact-form-head{
  padding-bottom:20px;
  border-bottom:1px solid var(--line);
  margin-bottom:22px;
}
.contact-form-head h2{
  font-size:36px;
  line-height:1.05;
  margin-bottom:10px;
}
.contact-form-head p{
  font-size:16px;
  max-width:520px;
}
.contact-v14-faq-grid{margin-top:0}
.contact-steps.compact-vertical{margin-top:0;gap:12px}
.contact-steps.compact-vertical .contact-step{padding:16px 18px;border-radius:var(--radius)}
@media(max-width:1100px){
  .contact-v14-grid{grid-template-columns:1fr}
  .contact-v14-side{position:static}
}
@media(max-width:640px){
  .contact-v14-company-card,
  .contact-v14-support-card,
  .contact-v14-form-card{padding:22px}
  .contact-form-head h2{font-size:32px}
}


/* ===== V26 Legal Pages: SEO-friendly privacy and terms layout ===== */
.legal-hero p{
  max-width:760px;
}
.legal-section{
  padding:92px 0 104px;
  background:#fff;
}
.legal-layout{
  display:grid;
  grid-template-columns:300px minmax(0,1fr);
  gap:34px;
  align-items:start;
}
.legal-toc{
  position:sticky;
  top:106px;
}
.legal-toc-card{
  border:1px solid var(--line);
  border-radius:var(--radius-card, 8px);
  background:#fff;
  padding:24px;
  box-shadow:0 12px 28px rgba(13,27,42,.04);
}
.legal-toc-card h2{
  font-size:24px;
  line-height:1.08;
  letter-spacing:-.035em;
  margin-bottom:10px;
}
.legal-toc-card p{
  font-size:14px;
  margin-bottom:18px;
}
.legal-toc-card nav{
  display:grid;
  gap:10px;
}
.legal-toc-card a{
  color:var(--muted);
  font-size:14px;
  border-top:1px solid var(--line);
  padding-top:10px;
  transition:.22s ease;
}
.legal-toc-card a:hover{
  color:var(--navy);
  transform:translateX(3px);
}
.legal-content{
  display:grid;
  gap:18px;
}
.legal-card{
  border:1px solid var(--line);
  border-radius:var(--radius-card, 8px);
  background:#fff;
  padding:34px;
  box-shadow:0 12px 28px rgba(13,27,42,.035);
}
.legal-card h2{
  font-size:30px;
  line-height:1.08;
  letter-spacing:-.04em;
  margin-bottom:14px;
}
.legal-card p{
  font-size:16px;
  margin-bottom:14px;
}
.legal-card p:last-child{
  margin-bottom:0;
}
.legal-card ul{
  padding-left:18px;
  color:var(--muted);
  display:grid;
  gap:8px;
}
.legal-note{
  border:1px solid #dfe6ee;
  border-radius:var(--radius-card, 8px);
  background:#f7f9fb;
  padding:22px 24px;
  color:var(--muted);
  font-size:15px;
}
.legal-note strong{
  color:var(--navy);
}
@media(max-width:920px){
  .legal-layout{
    grid-template-columns:1fr;
  }
  .legal-toc{
    position:static;
  }
}
@media(max-width:640px){
  .legal-section{
    padding:72px 0 84px;
  }
  .legal-card,
  .legal-toc-card{
    padding:24px;
  }
  .legal-card h2{
    font-size:26px;
  }
}
/* =========================
   SINGLE ARTICLE PAGE
========================= */
/* =========================
   E-REACHING Single Journal Article Styles
========================= */
/* =========================
   E-REACHING Single Article - Asymmetrical Layout
========================= */

/* 主体 */
.journal-single--asym {
    background-color: #f7f7f5;
    color: #0d1b2a;
    font-family: 'Montserrat', Helvetica, Arial, sans-serif;
}

/* 顶部文章区 */
.container--article-hero {
    max-width: 1080px;
    margin: 0 auto;
    padding: 56px 20px 24px;
}

.article-kicker,
.side-label {
    display: inline-block;
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #7c8795;
    margin-bottom: 16px;
}

.article-title {
    font-size: clamp(38px, 5vw, 64px);
    line-height: 1.03;
    font-weight: 700;
    margin-bottom: 18px;
    max-width: 900px;
}

.article-excerpt {
    font-size: 1.25rem;
    line-height: 1.6;
    color: #566273;
    margin-bottom: 20px;
}

.article-meta-top {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    font-size: 14px;
    color: #7c8795;
    margin-bottom: 28px;
}

.article-meta-top .sep { opacity: 0.45; }

/* 特色图 */
.article-featured img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    display: block;
    margin-bottom: 30px;
}

/* 文章布局 */
.article-layout {
    display: grid;
    grid-template-columns: 240px minmax(0, 760px);
    gap: 56px;
    align-items: start;
    justify-content: center;
}

/* 左侧窄栏 */
.article-sidebar {
    position: sticky;
    top: 110px;
}

.article-side-card {
    background: #fff;
    border: 1px solid rgba(13,27,42,0.08);
    border-radius: 14px;
    padding: 18px;
    margin-bottom: 14px;
}

.side-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.side-tags a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(13,27,42,0.05);
    color: #0d1b2a;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
}

.share-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.share-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(13,27,42,0.10);
    background: #fff;
    color: #0d1b2a;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s ease;
}

.share-pill:hover,
.save-article-btn:hover,
.side-back-link:hover { background: rgba(13,27,42,0.04); }

.save-article-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(13,27,42,0.10);
    background: #fff;
    color: #0d1b2a;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s ease;
}

.save-article-btn.is-saved {
    background: #0d1b2a;
    color: #fff;
    border-color: #0d1b2a;
}

.side-note {
    margin: 10px 0 0;
    font-size: 12px;
    color: #7c8795;
}

.side-back-link {
    display: inline-block;
    margin-top: 8px;
    color: #0d1b2a;
    text-decoration: none;
    font-weight: 600;
}

/* 主文章内容 */
.article-main {
    min-width: 0;
}

.article-content {
    max-width: 760px;
}

.article-content > *:first-child { margin-top: 0; }

.article-content p { font-size:18px; line-height:1.9; margin-bottom:1.5em; color:#243445; }
.article-content h2 { font-size:38px; margin:1.8em 0 0.55em; color:#0d1b2a; }
.article-content h3 { font-size:28px; margin:1.6em 0 0.6em; color:#0d1b2a; }
.article-content h4 { font-size:22px; margin:1.4em 0 0.6em; color:#0d1b2a; }
.article-content ul,
.article-content ol { margin:0 0 1.6em 1.2em; padding:0; }
.article-content li { font-size:18px; line-height:1.85; margin-bottom:0.5em; color:#243445; }
.article-content a { color:#0d1b2a; text-decoration:underline; text-underline-offset:3px; }
.article-content strong { color:#0d1b2a; }
.article-content blockquote {
    margin:2em 0;
    padding:22px 24px;
    border-left:3px solid #0d1b2a;
    border-radius:12px;
    background:#ffffff;
}
.article-content blockquote p { font-size:22px; line-height:1.65; margin:0; color:#0d1b2a; }
.article-content img {
    max-width:100%;
    height:auto;
    object-fit:contain;
    display:block;
    margin:1.2em auto;
    border-radius:12px;
    box-shadow:0 4px 12px rgba(0,0,0,0.08);
}

.article-content figure { margin:2em 0; }
.article-content table {
    width:100%;
    border-collapse:collapse;
    margin:2em 0;
    background:#fff;
    border-radius:12px;
    overflow:hidden;
}
.article-content th,
.article-content td {
    border:1px solid rgba(13,27,42,0.08);
    padding:14px 16px;
    text-align:left;
    font-size:15px;
}

/* 相关文章模块 */
.er-related-articles { margin-top:60px; }
.er-related-articles h3 { font-size:1.8rem; font-weight:600; color:#0d1b2a; margin-bottom:30px; }
.er-related-articles div { display:flex; flex-wrap:wrap; gap:24px; }
.er-related-articles a { text-decoration:none; color:#0d1b2a; font-weight:600; }
.er-related-articles img {
    width:100%;
    height:auto;
    display:block;
    border-radius:12px;
    box-shadow:0 4px 12px rgba(0,0,0,0.08);
}

/* 响应式 */
@media (max-width:1024px){
    .article-layout { grid-template-columns: 1fr; gap:28px; }
    .article-sidebar { position: static; order:2; }
    .article-main { order:1; }
    .article-content { max-width:100%; }
}
@media (max-width:768px){
    .container--article-hero { padding:42px 16px 20px; }
    .container--article-body { padding:20px 16px 70px; }
    .article-title { font-size:40px; line-height:1.04; }
    .article-content p, .article-content li { font-size:16px; line-height:1.8; }
    .article-content h2 { font-size:30px; }
    .article-content h3 { font-size:24px; }
}
/* =========================
   Fix article featured image spacing
========================= */
/* =========================
   Single article spacing correction
========================= */

.single-post .article-hero-wrap {
    padding-top: 36px !important;
    padding-bottom: 0 !important;
    margin: 0 !important;
}

.single-post .container--article-hero {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.single-post .article-title {
    margin-bottom: 18px !important;
}

.single-post .article-excerpt {
    margin-bottom: 18px !important;
}

.single-post .article-meta-top {
    margin-bottom: 24px !important;
}

.single-post .article-featured {
    margin: 0 0 54px 0 !important;
    padding: 0 !important;
}

.single-post .article-featured img {
    display: block;
    margin: 0 !important;
}

.single-post .article-body-wrap {
    padding-top: 0 !important;
    padding-bottom: 80px !important;
    margin: 0 !important;
}

.single-post .container--article-body {
    padding-top: 0 !important;
}

.single-post .article-layout {
    margin-top: 0 !important;
}
/* =========================
   Mobile Single Article Fix
   Fix featured image distortion + mobile reading layout
========================= */

@media (max-width: 768px) {

  /* 整体页面防止横向溢出 */
  .single-post .journal-single,
  .single-post .journal-single--asym {
    overflow-x: hidden;
    background: #f7f7f5;
  }

  /* 手机端容器宽度 */
  .single-post .container--article-hero,
  .single-post .container--article-body {
    width: calc(100% - 28px) !important;
    max-width: 760px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* 顶部标题区域 */
  .single-post .article-hero-wrap {
    padding-top: 38px !important;
    padding-bottom: 0 !important;
  }

  .single-post .article-kicker {
    font-size: 11px !important;
    letter-spacing: .16em !important;
    margin-bottom: 14px !important;
  }

  .single-post .article-title {
    font-size: 36px !important;
    line-height: 1.06 !important;
    letter-spacing: -0.035em !important;
    margin-bottom: 16px !important;
  }

  .single-post .article-excerpt {
    font-size: 16px !important;
    line-height: 1.7 !important;
    margin-bottom: 18px !important;
    color: #566273 !important;
  }

  .single-post .article-meta-top {
    font-size: 13px !important;
    line-height: 1.5 !important;
    margin-bottom: 20px !important;
  }

  /* 特色图片：防止手机端被拉伸变形 */
  .single-post .article-featured {
    width: 100% !important;
    aspect-ratio: 16 / 10;
    border-radius: 14px !important;
    overflow: hidden !important;
    margin: 0 0 28px 0 !important;
    background: #e8eaed;
  }

  .single-post .article-featured img {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
    border-radius: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
  }

  /* 文章主体 */
  .single-post .article-body-wrap {
    padding-top: 0 !important;
    padding-bottom: 58px !important;
  }

  .single-post .article-layout {
    display: block !important;
    margin-top: 0 !important;
  }

  .single-post .article-main {
    width: 100% !important;
  }

  .single-post .article-content {
    width: 100% !important;
    max-width: 100% !important;
  }

  /* 正文排版优化 */
  .single-post .article-content p {
    font-size: 16px !important;
    line-height: 1.82 !important;
    margin-bottom: 1.35em !important;
    color: #243445 !important;
  }

  .single-post .article-content h2 {
    font-size: 28px !important;
    line-height: 1.18 !important;
    letter-spacing: -0.025em !important;
    margin: 1.75em 0 .65em !important;
  }

  .single-post .article-content h3 {
    font-size: 23px !important;
    line-height: 1.25 !important;
    margin: 1.55em 0 .65em !important;
  }

  .single-post .article-content h4 {
    font-size: 20px !important;
    line-height: 1.3 !important;
  }

  .single-post .article-content ul,
  .single-post .article-content ol {
    margin-left: 1.1em !important;
    margin-bottom: 1.4em !important;
    padding-left: 0 !important;
  }

  .single-post .article-content li {
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin-bottom: .55em !important;
  }

  /* 正文图片：防止文章内图片变形 */
  .single-post .article-content img,
  .single-post .article-content figure img,
  .single-post .wp-block-image img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
    border-radius: 12px !important;
    margin: 1.4em auto !important;
  }

  .single-post .article-content figure,
  .single-post .wp-block-image {
    margin: 1.6em 0 !important;
  }

  .single-post .article-content figcaption {
    font-size: 13px !important;
    line-height: 1.5 !important;
    color: #7c8795 !important;
    text-align: center !important;
    margin-top: 8px !important;
  }

  /* 引用块 */
  .single-post .article-content blockquote {
    margin: 1.8em 0 !important;
    padding: 18px 18px !important;
    border-radius: 12px !important;
  }

  .single-post .article-content blockquote p {
    font-size: 18px !important;
    line-height: 1.65 !important;
  }

  /* 左侧分享栏在手机端放到文章后面，不要影响阅读 */
  .single-post .article-sidebar {
    position: static !important;
    margin-top: 42px !important;
  }

  .single-post .article-side-card {
    padding: 16px !important;
    border-radius: 14px !important;
    margin-bottom: 12px !important;
  }

  .single-post .share-links {
    gap: 8px !important;
  }

  .single-post .share-pill,
  .single-post .save-article-btn {
    min-height: 38px !important;
    font-size: 13px !important;
  }

  /* 相关文章手机端 */
  .single-post .related-articles-grid,
  .single-post .er-related-articles > div {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }
}