:root{
  --navy:#0f1b34;
  --navy-2:#14213d;
  --blue:#2f6bff;
  --blue-2:#2a5bd7;
  --slate:#2b3550;
  --slate-soft:#5a6478;
  --line:#e3e8f2;
  --bg:#ffffff;
  --bg-soft:#f4f6fb;
  --white:#ffffff;
  --radius:14px;
  --shadow:0 10px 30px rgba(15,27,52,.08);
  --shadow-lg:0 24px 60px rgba(15,27,52,.16);
  --maxw:1160px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:104px;}
body{
  margin:0;
  font-family:"Noto Sans JP","Inter",system-ui,-apple-system,sans-serif;
  color:var(--slate);
  background:var(--bg);
  line-height:1.8;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{font-weight:700;line-height:1.35;color:var(--navy);margin:0;letter-spacing:.01em;}

:focus-visible{
  outline:3px solid var(--blue);
  outline-offset:3px;
  border-radius:4px;
}

.skip-link{position:absolute;left:-9999px;top:0;z-index:2000;background:var(--navy);color:#fff;padding:10px 18px;border-radius:0 0 8px 0;font-size:13px;}
.skip-link:focus{left:0;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Placeholder (image to be added later) ---------- */
.ph{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(135deg,#eef2fb 0%, #e3e9f6 100%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  color:#9aa6c2;
  overflow:hidden;
}
.ph::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(420px 220px at 78% 12%, rgba(47,107,255,.10), transparent 62%);
  pointer-events:none;
}
.ph-inner{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  font-family:"Inter",sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.ph-inner svg{width:30px;height:30px;opacity:.55;}
/* real photo dropped into a .ph box — fills and covers the placeholder */
.ph > picture{position:absolute;inset:0;display:block;}
.ph > picture img{width:100%;height:100%;object-fit:cover;}

/* ---------- Demo ribbon ---------- */
.demo-ribbon{
  min-height:40px;
  background:#0a1226;
  color:#cdd6ea;
  font-size:12.5px;
  letter-spacing:.02em;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:6px 14px;
  padding:7px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.demo-ribbon span{font-weight:500;}
.demo-ribbon a{
  color:#fff;
  font-weight:600;
  padding:6px 10px;
  border-radius:6px;
  transition:background .2s;
  white-space:nowrap;
}
.demo-ribbon a:hover{background:rgba(255,255,255,.12);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:64px;
}
.brand{display:flex;align-items:center;gap:10px;}
.brand .star{color:var(--blue);font-size:22px;line-height:1;}
.brand .word{
  font-family:"Inter",sans-serif;
  font-weight:800;
  font-size:21px;
  letter-spacing:.14em;
  color:var(--navy);
}
.brand .sub{
  font-size:11px;
  color:var(--slate-soft);
  letter-spacing:.06em;
  margin-left:2px;
}
.nav{display:flex;align-items:center;gap:4px;}
.nav a{
  font-size:14px;
  font-weight:500;
  color:var(--slate);
  padding:10px 14px;
  border-radius:8px;
  transition:color .2s,background .2s;
}
.nav a:hover{color:var(--blue-2);background:var(--bg-soft);}
.nav a[aria-current="page"]{color:var(--blue-2);background:var(--bg-soft);}
.nav .nav-cta{
  margin-left:8px;
  background:var(--blue);
  color:#fff;
  font-weight:600;
  padding:10px 18px;
}
.nav .nav-cta:hover,.nav .nav-cta[aria-current="page"]{background:var(--blue-2);color:#fff;}
.nav-toggle{display:none;}
.nav-toggle-check{display:none;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  font-weight:600;
  font-size:clamp(14px,1.4vw,15px);
  line-height:1.4;
  min-height:50px;
  padding:12px 28px;
  border-radius:10px;
  border:none;
  cursor:pointer;
  white-space:normal;
  text-align:center;
  transition:transform .15s,box-shadow .2s,background .2s;
}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 22px rgba(47,107,255,.35);}
.btn-primary:hover{background:#1f56e6;transform:translateY(-2px);}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45);}
.btn-ghost:hover{background:rgba(255,255,255,.12);}
.btn-light{background:#fff;color:var(--navy);box-shadow:var(--shadow);}
.btn-light:hover{transform:translateY(-2px);}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  color:#fff;
  overflow:hidden;
  background:var(--navy);
}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media img{width:100%;height:100%;object-fit:cover;}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(105deg, rgba(15,27,52,.94) 0%, rgba(15,27,52,.80) 42%, rgba(20,33,61,.55) 100%),
    radial-gradient(1100px 520px at 88% 8%, rgba(47,107,255,.40), transparent 60%);
}
.hero-inner{
  position:relative;z-index:2;
  padding:128px 0 116px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:"Inter",sans-serif;
  font-size:13px;font-weight:600;letter-spacing:.22em;
  color:#aebfe6;
  text-transform:uppercase;
  margin-bottom:24px;
}
.hero-eyebrow .star{color:var(--blue);}
.hero h1{
  color:#fff;
  font-size:clamp(34px,5.4vw,60px);
  line-height:1.28;
  font-weight:900;
  letter-spacing:.02em;
  margin-bottom:26px;
}
.hero p.lead{
  max-width:560px;
  font-size:clamp(15px,1.7vw,18px);
  color:#d4ddf2;
  margin:0 0 38px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;}

/* ---------- Page hero (sub-pages) ---------- */
.page-hero{
  position:relative;
  color:#fff;
  overflow:hidden;
  background:var(--navy);
}
.page-hero::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(900px 420px at 85% -10%, rgba(47,107,255,.42), transparent 60%);
  pointer-events:none;
}
.page-hero .wrap{position:relative;z-index:1;padding-top:74px;padding-bottom:66px;}
.page-hero .crumbs{
  font-family:"Inter",sans-serif;
  font-size:12.5px;font-weight:600;letter-spacing:.1em;
  color:#9db4ee;margin-bottom:16px;
}
.page-hero .crumbs a:hover{color:#fff;}
.page-hero .crumbs span{color:#6e7da4;margin:0 8px;}
.page-hero h1{
  color:#fff;
  font-size:clamp(30px,4.6vw,48px);
  font-weight:900;letter-spacing:.03em;margin-bottom:12px;
}
.page-hero .en{
  font-family:"Inter",sans-serif;
  font-size:13px;font-weight:600;letter-spacing:.24em;
  color:#aebfe6;text-transform:uppercase;
}
.page-hero p.lead{color:#d4ddf2;max-width:680px;margin:14px 0 0;font-size:clamp(15px,1.7vw,17px);}

/* ---------- Section scaffolding ---------- */
section{padding:96px 0;}
.section-soft{background:var(--bg-soft);}
.sec-head{margin-bottom:52px;max-width:720px;}
.eyebrow{
  font-family:"Inter",sans-serif;
  font-size:13px;font-weight:700;letter-spacing:.2em;
  color:var(--blue-2);
  text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
  margin-bottom:14px;
}
.eyebrow::before{content:"✦";color:var(--blue);}
h2.title{font-size:clamp(26px,3.4vw,38px);margin-bottom:16px;}
.sec-head p{color:var(--slate-soft);font-size:16px;margin:0;}

/* ---------- About / message ---------- */
.about-grid{
  display:grid;
  grid-template-columns:0.95fr 1.05fr;
  gap:56px;
  align-items:center;
}
.about-photo{position:relative;}
.about-photo picture,.about-photo img,.about-photo .ph{
  width:100%;border-radius:var(--radius);
  aspect-ratio:4/3;object-fit:cover;
  box-shadow:var(--shadow-lg);
}
.about-photo .badge{
  position:absolute;left:-18px;bottom:-18px;
  background:var(--blue);color:#fff;
  border-radius:12px;padding:18px 22px;
  box-shadow:var(--shadow-lg);
}
.about-photo .badge b{
  font-family:"Inter",sans-serif;
  display:block;font-size:30px;line-height:1;font-weight:800;
}
.about-photo .badge small{font-size:12px;opacity:.92;}
.about-copy h3{font-size:clamp(20px,2.6vw,27px);margin-bottom:22px;line-height:1.5;}
.about-copy p{color:var(--slate);margin:0 0 18px;}
.about-sign{
  margin-top:26px;
  display:flex;align-items:baseline;gap:12px;
  border-top:1px solid var(--line);padding-top:22px;
}
.about-sign small{color:var(--slate-soft);font-size:13px;}
.about-sign b{font-size:20px;color:var(--navy);}

/* ---------- Values (Mission / Vision / Values) ---------- */
.values{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.value{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:34px 30px;
}
.value .ico{
  width:56px;height:56px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#eaf0ff,#dbe5ff);
  color:var(--blue-2);margin-bottom:20px;
}
.value .ico svg{width:28px;height:28px;}
.value .en{
  font-family:"Inter",sans-serif;
  font-size:12px;font-weight:700;letter-spacing:.14em;
  color:var(--blue-2);text-transform:uppercase;margin-bottom:6px;
}
.value h3{font-size:20px;margin-bottom:12px;}
.value p{color:var(--slate-soft);font-size:14.5px;margin:0;}

/* ---------- Services ---------- */
.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:34px 30px;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.card .ico{
  width:56px;height:56px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#eaf0ff,#dbe5ff);
  color:var(--blue-2);
  margin-bottom:22px;
}
.card .ico svg{width:28px;height:28px;}
.card h3{font-size:20px;margin-bottom:8px;}
.card .en{
  font-family:"Inter",sans-serif;
  font-size:12px;font-weight:600;letter-spacing:.12em;
  color:var(--blue-2);text-transform:uppercase;margin-bottom:14px;
}
.card p{color:var(--slate-soft);font-size:14.5px;margin:0 0 18px;}
.card ul{margin:0;padding:0;list-style:none;}
.card ul li{
  font-size:13.5px;color:var(--slate);
  padding:6px 0 6px 22px;position:relative;
  border-top:1px solid var(--line);
}
.card ul li:first-child{border-top:none;}
.card ul li::before{
  content:"✦";position:absolute;left:0;color:var(--blue);font-size:11px;top:8px;
}

/* ---------- Service detail (business page) ---------- */
.svc-block{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
  padding:0;
}
.svc-block + .svc-block{margin-top:64px;}
.svc-block .ph{aspect-ratio:4/3;width:100%;}
.svc-block.reverse .svc-media{order:2;}
.svc-num{
  font-family:"Inter",sans-serif;font-weight:800;
  color:var(--blue);font-size:14px;letter-spacing:.14em;margin-bottom:10px;
}
.svc-block h3{font-size:clamp(22px,2.8vw,28px);margin-bottom:8px;}
.svc-block .en{
  font-family:"Inter",sans-serif;font-size:12px;font-weight:600;letter-spacing:.14em;
  color:var(--blue-2);text-transform:uppercase;margin-bottom:16px;
}
.svc-block p{color:var(--slate);margin:0 0 20px;}
.svc-tags{display:flex;flex-wrap:wrap;gap:10px;}
.svc-tags span{
  font-size:13px;font-weight:600;color:var(--blue-2);
  background:#eaf0ff;border-radius:999px;padding:7px 14px;
}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px;position:relative;
}
.step b{
  font-family:"Inter",sans-serif;font-weight:800;font-size:13px;letter-spacing:.12em;
  color:var(--blue);display:block;margin-bottom:12px;
}
.step h3{font-size:17px;margin-bottom:8px;}
.step p{color:var(--slate-soft);font-size:13.5px;margin:0;}

/* ---------- Stats band ---------- */
.stats{
  position:relative;
  background:var(--navy-2);
  color:#fff;
  overflow:hidden;
}
.stats::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(900px 400px at 10% 0%, rgba(47,107,255,.30), transparent 60%);
  pointer-events:none;
}
.stats .wrap{position:relative;z-index:1;}
.stats-head{text-align:center;margin-bottom:48px;}
.stats-head .eyebrow{justify-content:center;color:#9db4ee;}
.stats-head .eyebrow::before{color:var(--blue);}
.stats-head h2{color:#fff;}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.stat{
  text-align:center;
  padding:26px 14px;
  border-radius:var(--radius);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
}
.stat b{
  font-family:"Inter",sans-serif;
  display:block;
  font-size:clamp(38px,5vw,52px);
  font-weight:800;line-height:1;color:#fff;
  margin-bottom:10px;
}
.stat b .unit{font-size:22px;color:var(--blue);margin-left:2px;}
.stat span{font-size:14px;color:#c4d0ea;letter-spacing:.04em;}

/* ---------- Work / achievements feature ---------- */
.work-grid{
  display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center;
}
.work-photo picture,.work-photo img,.work-photo .ph{
  width:100%;border-radius:var(--radius);
  aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-lg);
}
.work-copy h2{margin-bottom:18px;}
.work-copy p{color:var(--slate);margin:0 0 24px;}
.work-list{display:grid;gap:14px;}
.work-item{
  display:flex;gap:16px;align-items:flex-start;
  background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:16px 18px;
}
.work-item .num{
  font-family:"Inter",sans-serif;font-weight:800;
  color:var(--blue);font-size:15px;flex:none;
  width:34px;height:34px;border-radius:9px;
  display:grid;place-items:center;background:#eaf0ff;
}
.work-item h3{font-size:16px;margin-bottom:2px;}
.work-item p{font-size:13.5px;color:var(--slate-soft);margin:0;}

/* ---------- Case cards (works page) ---------- */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.case{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.case:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.case .ph{aspect-ratio:16/10;border:none;border-radius:0;}
.case .case-body{padding:24px 24px 28px;}
.case .case-tag{
  display:inline-block;font-size:11.5px;font-weight:600;letter-spacing:.04em;
  padding:4px 11px;border-radius:999px;background:#eaf0ff;color:var(--blue-2);
  margin-bottom:12px;
}
.case h3{font-size:18px;margin-bottom:8px;line-height:1.5;}
.case p{color:var(--slate-soft);font-size:14px;margin:0;}

/* ---------- Definition table (clean profile / spec) ---------- */
.table-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
table.profile{width:100%;border-collapse:collapse;min-width:420px;}
table.profile caption{
  text-align:left;font-weight:700;color:var(--navy);
  padding:18px 22px;font-size:15px;background:var(--bg-soft);
  border-bottom:1px solid var(--line);
}
table.profile th,table.profile td{
  text-align:left;padding:16px 22px;
  border-bottom:1px solid var(--line);
  vertical-align:top;font-size:14.5px;line-height:1.7;
}
table.profile tr:last-child th,table.profile tr:last-child td{border-bottom:none;}
table.profile tbody tr:nth-child(even){background:#fafbfe;}
table.profile th{
  width:32%;color:var(--navy);font-weight:700;white-space:nowrap;
  background:#f2f5fc;
}
table.profile td{color:var(--slate);}

/* ---------- Timeline (沿革) ---------- */
.timeline{position:relative;padding-left:26px;}
.timeline::before{
  content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--blue),rgba(47,107,255,.15));
}
.tl-item{position:relative;padding:0 0 26px 0;}
.tl-item:last-child{padding-bottom:0;}
.tl-item::before{
  content:"";position:absolute;left:-26px;top:7px;
  width:12px;height:12px;border-radius:50%;
  background:#fff;border:3px solid var(--blue);
}
.tl-item time{
  font-family:"Inter",sans-serif;font-weight:800;font-size:14px;
  color:var(--blue-2);letter-spacing:.04em;
}
.tl-item p{margin:4px 0 0;color:var(--slate);font-size:14.5px;}

/* ---------- Locations ---------- */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.loc-list{display:grid;gap:18px;}
.loc{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 24px;
}
.loc h3{font-size:17px;margin-bottom:6px;}
.loc h3 .tag{
  font-family:"Inter",sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;
  color:var(--blue-2);background:#eaf0ff;border-radius:999px;padding:3px 10px;margin-left:8px;
  vertical-align:middle;
}
.loc p{margin:0;font-size:14px;color:var(--slate-soft);}
.loc-map .ph{aspect-ratio:4/3;width:100%;}

/* ---------- Company profile grid ---------- */
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}

/* News */
.news-list{display:flex;flex-direction:column;gap:0;}
.news-row{
  display:grid;
  grid-template-columns:120px 92px 1fr;
  gap:18px;align-items:center;
  padding:18px 4px;
  border-bottom:1px solid var(--line);
  transition:background .15s;
}
.news-row:first-child{border-top:1px solid var(--line);}
.news-row:hover{background:var(--bg-soft);}
.news-row time{
  font-family:"Inter",sans-serif;font-size:13.5px;color:var(--slate-soft);
}
.news-tag{
  justify-self:start;font-size:11.5px;font-weight:600;letter-spacing:.04em;
  padding:4px 11px;border-radius:999px;
  background:#eaf0ff;color:var(--blue-2);white-space:nowrap;
}
.news-tag.ir{background:#e8f5ee;color:#1c8a52;}
.news-tag.recruit{background:#fdeede;color:#c06a12;}
.news-row p{margin:0;font-size:14.5px;color:var(--slate);}
.link-arrow{
  color:var(--blue-2);font-weight:600;font-size:14.5px;
  display:inline-flex;align-items:center;gap:6px;
}
.link-arrow:hover{color:var(--blue);}

/* ---------- Contact / CTA ---------- */
.cta{
  position:relative;overflow:hidden;
  background:var(--navy);color:#fff;text-align:center;
}
.cta::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 300px at 50% -10%, rgba(47,107,255,.40), transparent 60%);
}
.cta .wrap{position:relative;z-index:1;}
.cta .eyebrow{justify-content:center;color:#9db4ee;}
.cta h2{color:#fff;font-size:clamp(26px,3.6vw,40px);margin-bottom:18px;}
.cta p{color:#d4ddf2;max-width:560px;margin:0 auto 36px;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* contact info cards */
.contact-info{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:46px;
}
.ci{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow);text-align:center;
}
.ci .ico{
  width:52px;height:52px;border-radius:14px;margin:0 auto 16px;
  display:grid;place-items:center;color:var(--blue-2);
  background:linear-gradient(135deg,#eaf0ff,#dbe5ff);
}
.ci .ico svg{width:26px;height:26px;}
.ci h3{font-size:17px;margin-bottom:6px;}
.ci p{color:var(--slate-soft);font-size:14px;margin:0;}
.ci a{color:var(--blue-2);font-weight:600;}
.ci a:hover{color:var(--blue);}

/* contact form */
.contact-wrap{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);
  max-width:720px;margin:46px auto 0;padding:36px;
  text-align:left;color:var(--slate);
}
.contact-wrap.solo{margin-top:0;}
.contact-wrap h3{font-size:19px;margin-bottom:6px;}
.contact-wrap > p{color:var(--slate-soft);font-size:14px;margin:0 0 24px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:18px;display:flex;flex-direction:column;}
.field.full{grid-column:1/-1;}
.field label{font-size:13.5px;font-weight:600;color:var(--navy);margin-bottom:7px;}
.field label .req{color:#d33;margin-left:4px;font-size:12px;}
.field input,.field textarea,.field select{
  font-family:inherit;font-size:15px;color:var(--slate);
  padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  background:#fbfcfe;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(47,107,255,.18);
}
.field textarea{resize:vertical;min-height:120px;}
.field .check{
  display:flex;align-items:flex-start;gap:10px;font-size:13.5px;
  color:var(--slate);font-weight:400;
}
.field .check input{width:18px;height:18px;flex:none;margin-top:3px;}
.form-submit{display:flex;justify-content:center;margin-top:6px;}

/* ---------- Footer ---------- */
.site-footer{background:#0a1226;color:#aeb9d2;padding:64px 0 30px;}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.10);
}
.footer-brand .word{
  font-family:"Inter",sans-serif;font-weight:800;font-size:22px;
  letter-spacing:.14em;color:#fff;
}
.footer-brand .star{color:var(--blue);}
.footer-brand p{font-size:13.5px;margin:16px 0 0;max-width:320px;color:#8d99b6;}
.footer-col h2{
  color:#fff;font-size:13px;letter-spacing:.08em;font-weight:700;margin:0 0 16px;
  font-family:"Inter",sans-serif;text-transform:uppercase;
}
.footer-col a{display:block;font-size:14px;padding:6px 0;color:#aeb9d2;}
.footer-col a:hover{color:#fff;}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;padding-top:24px;
  font-size:12.5px;color:#7e8aa6;
}
.footer-bottom .word{font-family:"Inter",sans-serif;letter-spacing:.06em;}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .about-grid,.work-grid,.profile-grid,.loc-grid{grid-template-columns:1fr;gap:40px;}
  .cards,.values,.case-grid,.contact-info{grid-template-columns:1fr;}
  .stats-grid,.steps{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
  .svc-block{grid-template-columns:1fr;gap:32px;}
  .svc-block.reverse .svc-media{order:0;}
}
@media(max-width:720px){
  html{scroll-padding-top:84px;}
  section{padding:64px 0;}
  .hero-inner{padding:96px 0 84px;}
  .page-hero .wrap{padding-top:56px;padding-bottom:50px;}
  .nav{
    position:absolute;top:64px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:2px;
    background:#fff;border-bottom:1px solid var(--line);
    padding:12px 16px 18px;
    box-shadow:var(--shadow);
    display:none;
  }
  .nav a{padding:13px 12px;border-radius:8px;}
  .nav .nav-cta{margin:8px 0 0;text-align:center;justify-content:center;}
  #nav-check:checked ~ .nav{display:flex;}
  .nav-toggle{
    display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
    width:44px;height:44px;border:1px solid var(--line);border-radius:9px;
    background:#fff;cursor:pointer;padding:0 11px;
  }
  .nav-toggle span{height:2px;background:var(--navy);border-radius:2px;display:block;}
  .nav-toggle-check{
    display:block;
    position:absolute;
    width:1px;height:1px;
    margin:0;opacity:0;
    pointer-events:none;
  }
  #nav-check:focus-visible + .nav-toggle{
    outline:3px solid var(--blue);
    outline-offset:3px;
  }
  .form-row{grid-template-columns:1fr;}
  .news-row{grid-template-columns:84px 1fr;grid-template-areas:"date tag" "body body";row-gap:6px;}
  .news-row time{grid-area:date;}
  .news-tag{grid-area:tag;justify-self:end;}
  .news-row p{grid-area:body;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .about-photo .badge{left:auto;right:14px;bottom:-14px;}
  table.profile th{width:38%;}
}
@media(max-width:420px){
  .stats-grid,.steps{grid-template-columns:1fr;}
}
