
:root{
  --bg:#f7fafb;
  --paper:#ffffff;
  --paper-2:#f2f7f8;
  --text:#11242d;
  --muted:#536972;
  --line:rgba(17,36,45,.12);
  --accent:#11485e;
  --accent-2:#0e6885;
  --accent-3:#7fb4ca;
  --shadow:0 18px 55px rgba(11,31,40,.08);
  --shadow-soft:0 8px 24px rgba(11,31,40,.05);
  --container:min(1180px, calc(100vw - 2rem));
  --hero:clamp(3rem,7vw,7rem);
  --h2:clamp(2rem,4vw,3.4rem);
  --h3:clamp(1.25rem,2vw,1.75rem);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,#fcfefe,#f5f9fa 45%,#fcfefe);line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
.container{width:var(--container);margin:0 auto}
main{padding-top:4.3rem;overflow:hidden}
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:transform .3s ease}
.site-header.is-hidden{transform:translateY(-110%)}
.nav-shell{width:min(calc(100vw - 1rem),1180px);margin:8px auto 0;padding:.45rem .8rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:rgba(255,255,255,.72);border:1px solid rgba(17,72,94,.1);backdrop-filter:blur(14px);box-shadow:var(--shadow-soft)}
.brand{display:flex;align-items:center;gap:.9rem;min-width:0}
.brand img{height:52px;width:auto;max-width:none}
.brand small{display:block;color:var(--muted);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}
.nav-links{display:flex;gap:1.15rem;align-items:center}
.nav-links a{position:relative;color:var(--muted);padding:.15rem 0;font-weight:500;font-size:.98rem;line-height:1.1}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-.25rem;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .22s ease}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.menu-btn{display:none;border:0;background:transparent;width:46px;height:46px;position:relative;flex:none}
.menu-btn span,.menu-btn::before,.menu-btn::after{content:"";position:absolute;left:11px;right:11px;height:2px;background:var(--text);transition:.24s ease}
.menu-btn span{top:22px}.menu-btn::before{top:15px}.menu-btn::after{bottom:15px}
.menu-btn.is-open span{opacity:0}.menu-btn.is-open::before{top:22px;transform:rotate(45deg)}.menu-btn.is-open::after{bottom:22px;transform:rotate(-45deg)}
.mobile-scrim{position:fixed;inset:0;background:rgba(9,22,30,.35);opacity:0;visibility:hidden;transition:.24s ease;z-index:96}
.mobile-scrim.is-open{opacity:1;visibility:visible}
.mobile-panel{position:fixed;top:0;right:0;height:100vh;width:min(90vw,380px);background:#fff;transform:translateX(105%);transition:transform .25s ease;z-index:101;box-shadow:-25px 0 70px rgba(0,0,0,.18);padding:1rem 1rem 1.5rem;display:flex;flex-direction:column}
.mobile-panel.is-open{transform:translateX(0)}
.mobile-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.mobile-top img{width:145px}
.mobile-close{border:0;background:transparent;font-size:2rem;line-height:1;padding:0 .25rem}
.mobile-links{display:grid}
.mobile-links a{padding:1rem 0;border-bottom:1px solid var(--line);font-size:1.05rem}
.hero,.page-hero{position:relative}
.hero::before,.page-hero::before{content:"";position:absolute;inset:0;z-index:-2;background:
radial-gradient(circle at 12% 12%, rgba(17,72,94,.11), transparent 22%),
radial-gradient(circle at 100% 0, rgba(17,104,133,.08), transparent 16%),
linear-gradient(180deg,rgba(255,255,255,.95),rgba(245,250,251,.9) 52%,rgba(255,255,255,.98))}
.hero::after,.page-hero::after{content:"";position:absolute;inset:0;z-index:-3;background-image:linear-gradient(rgba(17,72,94,.04) 1px, transparent 1px),linear-gradient(90deg, rgba(17,72,94,.04) 1px, transparent 1px);background-size:64px 64px;mask-image:linear-gradient(180deg,rgba(0,0,0,.95),rgba(0,0,0,.15))}
.hero{padding:5rem 0 3.2rem;min-height:min(92vh,920px);display:flex;align-items:flex-end}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:1.5rem;align-items:end}
.hero-copy{max-width:760px}
.hero-logo{width:min(300px,52vw);opacity:.86;margin-bottom:1rem}
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;text-transform:uppercase;letter-spacing:.13em;color:var(--accent);font-size:.78rem;font-weight:700;margin-bottom:1rem}
.eyebrow::before{content:"";width:56px;height:2px;background:var(--accent)}
.hero h1,.page-hero h1{margin:0;font-size:var(--hero);line-height:.95;letter-spacing:-.05em;max-width:10ch}
.hero-tag{font-size:clamp(1.15rem,2.2vw,1.8rem);color:var(--accent);font-weight:700;margin-top:1.15rem}
.hero-lead{max-width:61ch;color:var(--muted);font-size:1.08rem;margin:1rem 0 0}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.7rem}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:.9rem 1.3rem;border:1px solid transparent;font-weight:600;transition:transform .22s ease, box-shadow .22s ease, background .22s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 18px 40px rgba(17,72,94,.22)}
.btn-secondary{background:#fff;border-color:rgba(17,72,94,.15);box-shadow:var(--shadow-soft)}
.hero-side{display:grid;gap:1rem}
.info-card{background:rgba(255,255,255,.82);backdrop-filter:blur(12px);padding:1.15rem;border:1px solid rgba(17,72,94,.1);box-shadow:var(--shadow-soft);position:relative;overflow:hidden}
.info-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--accent),transparent)}
.info-card span{display:block}
.info-kicker{text-transform:uppercase;letter-spacing:.12em;font-size:.73rem;color:var(--muted);font-weight:700;margin-bottom:.35rem}
.info-title{font-size:1.08rem;font-weight:700;margin-bottom:.4rem}
.info-copy{color:var(--muted)}
.section{padding:4.75rem 0;position:relative}
.section-head{margin-bottom:2rem;max-width:820px}
.section-accent{width:80px;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));margin-bottom:1rem}
.section h2{margin:0;font-size:var(--h2);line-height:1;letter-spacing:-.045em}
.section-intro{margin:1rem 0 0;color:var(--muted);max-width:64ch}
.story-layout{display:grid;grid-template-columns:minmax(0,1.35fr) 340px;gap:1rem;align-items:start}
.card{background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow);padding:1.8rem;position:relative;overflow:hidden}
.card::after{content:"";position:absolute;right:-50px;bottom:-50px;width:160px;height:160px;background:radial-gradient(circle, rgba(17,72,94,.08), transparent 70%)}
.card p{margin:0;font-size:1.08rem;color:var(--text)}
.stack{display:grid;gap:1rem}
.mini-card{padding:1.1rem 1rem;background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.mini-card strong{display:block;margin-bottom:.35rem}
.mini-card p{margin:0;color:var(--muted)}
.tech-preview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.preview-card{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1.35rem;position:relative}
.preview-card::before{content:"";position:absolute;left:0;right:35%;top:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.preview-card h3,.service-copy h3,.tech-copy h3,.contact-card h3,.profile-copy h3{margin:.2rem 0 .7rem;font-size:var(--h3);line-height:1.05;letter-spacing:-.03em}
.preview-card p,.service-copy p,.tech-copy p,.contact-card p,.profile-copy p{margin:0;color:var(--muted)}
.inline-link{display:inline-flex;align-items:center;gap:.55rem;color:var(--accent);font-weight:700;margin-top:1rem}
.inline-link svg{width:17px;height:17px}
.projects-grid{display:grid;grid-template-columns:1.1fr .9fr;grid-template-areas:"a b" "a c" "d d";gap:1rem}
.project{display:flex;flex-direction:column;gap:.8rem}
.project.one{grid-area:a}.project.two{grid-area:b}.project.three{grid-area:c}.project.four{grid-area:d}
.frame, .project-frame, .portrait-frame, .service-frame, .tech-frame{border:1px solid var(--line);background:
linear-gradient(180deg, rgba(255,255,255,.82), rgba(243,248,249,.93)),
linear-gradient(rgba(17,72,94,.05) 1px, transparent 1px),
linear-gradient(90deg, rgba(17,72,94,.05) 1px, transparent 1px);
background-size:auto, 62px 62px, 62px 62px;position:relative;overflow:hidden}
.frame::before,.project-frame::before,.portrait-frame::before,.service-frame::before,.tech-frame::before{content:"";position:absolute;inset:12px;border:1px solid rgba(17,72,94,.11);pointer-events:none}
.project-frame{min-height:320px;box-shadow:var(--shadow-soft)}
.project.four .project-frame{min-height:240px}
.project p{margin:0;color:var(--muted)}
.cta-strip{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1rem;align-items:center;padding:1.5rem;border:1px solid var(--line);background:linear-gradient(135deg, rgba(17,72,94,.06), rgba(17,104,133,.03));box-shadow:var(--shadow-soft)}
.cta-strip h2{margin:0 0 .35rem;font-size:clamp(1.6rem,3vw,2.3rem)}
.cta-strip p{margin:0;color:var(--muted)}
.page-hero{padding:1rem 0 .65rem}
.page-hero p{max-width:62ch;color:var(--muted);margin:1rem 0 0;font-size:1.05rem}
.page-hero .hero-logo{display:none}
.profile-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:1.2rem}
.profile-card{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;align-items:start;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1.2rem}
.portrait-frame{height:420px}
.service-grid,.tech-grid{display:grid;gap:1rem}
.service-card,.tech-card{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;align-items:start;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1.2rem}
.service-frame{min-height:240px}
.tech-frame{min-height:260px}
.sub-block{margin-top:1rem;padding:1rem;border-left:3px solid var(--accent);background:linear-gradient(180deg, rgba(17,72,94,.04), rgba(17,72,94,.02))}
.faq-list{display:grid;gap:.85rem}
.faq-item{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);overflow:hidden}
.faq-q{width:100%;border:0;background:none;padding:1.1rem 1.15rem;display:flex;justify-content:space-between;align-items:center;text-align:left;font-weight:700;color:var(--text);cursor:pointer}
.faq-q svg{width:18px;height:18px;transition:transform .22s ease;flex:none}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}
.faq-item.open .faq-a{grid-template-rows:1fr}
.faq-a-inner{overflow:hidden}
.faq-a p{margin:0;padding:0 1.15rem 1.15rem;color:var(--muted)}
.contact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.contact-card{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1.2rem;min-height:170px}
.contact-card a{color:var(--accent);font-weight:700}
.site-footer{padding:2rem 0 3rem}
.footer-box{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1rem;align-items:center;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1.3rem}
.footer-left{display:grid;gap:.55rem}
.footer-contact{display:flex;gap:1rem;flex-wrap:wrap;color:var(--muted)}
.footer-contact a{color:var(--accent);font-weight:700}
.footer-note{color:var(--muted);font-size:.95rem}
.footer-actions{display:flex;justify-content:flex-end}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
.reveal.show{opacity:1;transform:none}
@media (max-width: 980px){
  .nav-links{display:none}
  .menu-btn{display:block}
  .hero-grid,.story-layout,.service-card,.tech-card,.profile-card,.footer-box,.cta-strip{grid-template-columns:1fr}
  .hero{padding-top:4.2rem}
  .hero-side{grid-template-columns:repeat(3,minmax(0,1fr))}
  .tech-preview,.contact-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 760px){
  main{padding-top:4.9rem}
  .brand img{height:44px;width:auto;max-width:none}
  .hero{min-height:auto;padding-bottom:2.5rem}
  .hero-side{grid-template-columns:1fr}
  .tech-preview,.contact-grid,.projects-grid{grid-template-columns:1fr;grid-template-areas:none}
  .project.one,.project.two,.project.three,.project.four{grid-area:auto}
  .project-frame,.project.four .project-frame,.portrait-frame,.service-frame,.tech-frame{min-height:220px}
  .portrait-frame{height:220px}
  .btn{width:100%}
  .hero-actions{display:grid}
  .footer-actions{justify-content:stretch}
  .footer-actions .btn{width:100%}
  .contact-grid{grid-template-columns:1fr}
}

.frame-media{width:100%;height:100%;display:block;position:relative;z-index:1}
.media-cover{object-fit:cover}
.media-contain{object-fit:contain;background:#f7fafb;padding:.35rem}
.project-frame.has-image,.portrait-frame.has-image,.service-frame.has-image,.tech-frame.has-image{background:#fff}
.project-frame.has-image::before,.portrait-frame.has-image::before,.service-frame.has-image::before,.tech-frame.has-image::before{inset:10px}
.hero-photo-card{padding:.7rem;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.hero-photo{aspect-ratio: 5 / 4;overflow:hidden;border:1px solid var(--line);background:#fff}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width: 980px){
  .hero-photo{aspect-ratio: 16 / 10}
}

.page-hero h1{margin-top:0;line-height:.92}
.site-header{padding-top:0}
@media (max-width: 980px){
  .nav-shell{padding:.4rem .7rem;margin-top:6px}
}


/* remove leftover inner-page logo on about hero */
.page-hero .hero-logo{display:none !important;width:0 !important;height:0 !important;opacity:0 !important;overflow:hidden !important;position:absolute !important;pointer-events:none !important;}


/* v7 header and hero spacing fix */
main{padding-top:7.4rem !important;overflow:hidden}
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:transform .3s ease;padding-top:.2rem !important}
.nav-shell{margin:4px auto 0 !important;padding:.22rem .8rem !important;min-height:68px !important;align-items:center !important}
.brand img{height:44px !important;width:auto !important;max-width:none !important}
.nav-links a{font-size:.95rem !important;line-height:1 !important;padding:.1rem 0 !important}
.page-hero{padding:.35rem 0 .5rem !important}
.page-hero h1{margin-top:0 !important;line-height:.9 !important}
.hero{padding:4.7rem 0 3rem !important}
@media (max-width:980px){main{padding-top:6.8rem !important}.nav-shell{margin-top:4px !important;padding:.2rem .7rem !important;min-height:62px !important}.brand img{height:40px !important}}
@media (max-width:760px){main{padding-top:6.4rem !important}.nav-shell{padding:.15rem .55rem !important;min-height:58px !important}.brand img{height:36px !important}}


/* v8 logo crop + inner-page spacing fix */
.brand img{height:38px !important;width:auto !important;max-width:none !important;}
.nav-shell{margin:4px auto 0 !important;padding:.12rem .8rem !important;min-height:56px !important;align-items:center !important;}
main{padding-top:5.6rem !important;overflow:hidden;}
.page-hero{padding:2.15rem 0 .8rem !important;}
.page-hero .container{position:relative;z-index:1;}
.page-hero h1{font-size:clamp(3.6rem,8vw,5.8rem) !important;line-height:.94 !important;}
.page-hero .eyebrow{margin-bottom:.75rem !important;}
.hero{padding-top:5.2rem !important;}
@media (max-width:980px){main{padding-top:5.3rem !important}.brand img{height:34px !important}.nav-shell{min-height:52px !important;padding:.1rem .65rem !important}.page-hero{padding-top:1.8rem !important}.page-hero h1{font-size:clamp(3rem,10vw,4.5rem) !important;}}
@media (max-width:760px){main{padding-top:5rem !important}.brand img{height:30px !important}.nav-shell{min-height:48px !important;padding:.08rem .55rem !important}.page-hero{padding-top:1.35rem !important}}


/* v9 new tighter logo */
.brand img{height:34px !important;width:auto !important;max-width:none !important;}
.nav-shell{min-height:50px !important;padding:.08rem .75rem !important;margin-top:4px !important;}
main{padding-top:5.15rem !important;}
@media (max-width:980px){main{padding-top:4.95rem !important}.brand img{height:31px !important}.nav-shell{min-height:47px !important;padding:.08rem .6rem !important}}
@media (max-width:760px){main{padding-top:4.7rem !important}.brand img{height:28px !important}.nav-shell{min-height:44px !important;padding:.06rem .5rem !important}}


/* v11 keep floating header, lower inner-page titles instead */
.page-hero{padding:4.2rem 0 .9rem !important;}
.page-hero .container{position:relative;z-index:1;}
.page-hero .eyebrow{margin-bottom:.85rem !important;}
.page-hero h1{margin-top:0 !important;line-height:.95 !important;}
@media (max-width:980px){.page-hero{padding-top:3.6rem !important;}}
@media (max-width:760px){.page-hero{padding-top:3rem !important;}}


/* v12: keep floating header, push inner-page text well below it */
.page-hero{padding:7.25rem 0 1rem !important;}
.page-hero .container{padding-top:0 !important;position:relative;z-index:2;}
.page-hero h1{margin-top:0 !important;line-height:.96 !important;}
.page-hero p{margin-top:1rem !important;}
@media (max-width:980px){.page-hero{padding-top:6.1rem !important;}}
@media (max-width:760px){.page-hero{padding-top:5.2rem !important;}}


/* v13: keep floating header, lower all subpage title content even more */
.page-hero .container{
  padding-top: 2.6rem !important;
  position: relative !important;
  z-index: 3 !important;
}
.page-hero h1{
  margin-top: .25rem !important;
}
.page-hero p{
  margin-top: 1.15rem !important;
}
@media (max-width:980px){
  .page-hero .container{
    padding-top: 2.1rem !important;
  }
}
@media (max-width:760px){
  .page-hero .container{
    padding-top: 1.6rem !important;
  }
}


/* v15 cache-busted header logo */
.brand img{height:28px !important;width:auto !important;max-width:none !important;}
.nav-shell{min-height:46px !important;padding:.06rem .7rem !important;}
@media (max-width:980px){.brand img{height:26px !important}.nav-shell{min-height:44px !important;padding:.05rem .6rem !important}}
@media (max-width:760px){.brand img{height:24px !important}.nav-shell{min-height:42px !important;padding:.04rem .5rem !important}}


/* v16: user examples show inner-page titles still too high; push all subpage hero content well below floating header */
.page-hero{padding:7.75rem 0 1rem !important;}
.page-hero .container{padding-top:5.25rem !important; position:relative !important; z-index:4 !important;}
.page-hero h1{margin-top:.35rem !important; line-height:.98 !important;}
.page-hero p{margin-top:1.2rem !important;}
@media (max-width:980px){.page-hero{padding-top:6.8rem !important}.page-hero .container{padding-top:4.4rem !important}}
@media (max-width:760px){.page-hero{padding-top:5.8rem !important}.page-hero .container{padding-top:3.4rem !important}}


/* Revision 17 — stronger image-led layout and Gallery page */
.hero-photo{aspect-ratio:16/11 !important;}
.hero-photo img{object-fit:cover !important;}
.image-led-section .project-frame,
.visual-section .project-frame{min-height:420px;}
.projects-grid-large{grid-template-columns:1.2fr .8fr;}
.projects-grid-large .project.one .project-frame{min-height:560px;}
.feature-service .service-frame{min-height:360px;}
.service-card p + p,
.tech-card p + p,
.profile-copy p + p{margin-top:.8rem;}
.talk-card{grid-template-columns:minmax(0,1fr) 420px;}
.gallery-hero p{max-width:78ch;}
.gallery-grid{display:grid;grid-template-columns:1fr;gap:1.4rem;}
.gallery-card{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:0;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;}
.gallery-card-feature{grid-template-columns:minmax(0,1.35fr) minmax(320px,.75fr);}
.gallery-image{min-height:430px;background:#f7fafb;overflow:hidden;}
.gallery-card-feature .gallery-image{min-height:560px;}
.gallery-image img{width:100%;height:100%;object-fit:cover;display:block;}
.gallery-image-contain img{object-fit:contain;padding:.45rem;background:#f7fafb;}
.gallery-content{padding:1.5rem;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;}
.gallery-content h2{margin:.2rem 0 .8rem;font-size:clamp(1.7rem,3vw,2.6rem);line-height:1;letter-spacing:-.04em;}
.gallery-content p{margin:0;color:var(--muted);}
.gallery-details{margin:1rem 0 1.15rem;padding:0;list-style:none;display:grid;gap:.35rem;color:var(--muted);}
.gallery-details strong{color:var(--text);}
.gallery-note{font-size:.92rem;margin-top:.9rem !important;}
.footer-actions .btn::first-letter{text-transform:uppercase;}
@media (max-width:980px){
  .gallery-card,.gallery-card-feature,.talk-card{grid-template-columns:1fr;}
  .gallery-image,.gallery-card-feature .gallery-image{min-height:320px;}
  .projects-grid-large .project.one .project-frame{min-height:360px;}
}
@media (max-width:760px){
  .gallery-image,.gallery-card-feature .gallery-image{min-height:250px;}
  .gallery-content{padding:1.1rem;}
  .feature-service .service-frame{min-height:260px;}
}


/* updated no-addresses rebuild */
.brand img{height:28px !important;width:auto !important;max-width:none !important;}
.nav-shell{min-height:46px !important;padding:.06rem .7rem !important;}
@media (max-width:980px){.brand img{height:26px !important}.nav-shell{min-height:44px !important;padding:.05rem .6rem !important}}
@media (max-width:760px){.brand img{height:24px !important}.nav-shell{min-height:42px !important;padding:.04rem .5rem !important}}

.about-tight{padding-bottom:1.5rem !important;}
.about-people-section{padding-top:0 !important;}
.about-people-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;align-items:start;}
.person-card{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1rem;}
.person-card .portrait-frame{height:360px;min-height:360px;margin-bottom:.9rem;}
.person-copy h3{margin:.15rem 0 .55rem;font-size:var(--h3);line-height:1.05;letter-spacing:-.03em}
.person-copy p{margin:0;color:var(--muted)}
.talk-inline{margin-top:.9rem;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);padding:1rem 1.1rem;}
.talk-copy h3{margin:.1rem 0 .55rem;font-size:var(--h3);line-height:1.05;letter-spacing:-.03em}
.talk-copy p{margin:.45rem 0 0;color:var(--muted)}
.talk-copy p:first-of-type{margin-top:0}

.service-card{grid-template-columns:minmax(0,1fr) 320px !important;align-items:start;}
.service-frame{height:240px !important;min-height:240px !important;}
.feature-service .service-frame{height:240px !important;min-height:240px !important;}
.service-frame .frame-media{width:100%;height:100%;display:block;}
.service-frame[aria-label]{background:
linear-gradient(180deg, rgba(255,255,255,.82), rgba(243,248,249,.93)),
linear-gradient(rgba(17,72,94,.05) 1px, transparent 1px),
linear-gradient(90deg, rgba(17,72,94,.05) 1px, transparent 1px);
background-size:auto, 62px 62px, 62px 62px;}
.tech-frame{height:260px;min-height:260px}
.gallery-card .gallery-image img{width:100%;height:100%;display:block;object-fit:cover}
.gallery-image-contain img{object-fit:contain !important;background:#f7fafb}

@media (max-width:900px){
  .about-people-grid{grid-template-columns:1fr;}
  .person-card .portrait-frame{height:280px;min-height:280px;}
  .service-card{grid-template-columns:1fr !important;}
}
