/* ============================================================
   White Bear — 下層ページ共通スタイル (site.css)
   トップ(index v16)の世界観を継承。全下層ページで共有。
   ============================================================ */
:root{
  --navy:#004887;
  --navy-deep:#003566;
  --navy-2:#326c9f;
  --ink:#111111;
  --ink-2:#3a3a3a;
  --ink-3:#666666;
  --line:#e0e0e0;
  --bg:#ffffff;
  --bg-2:#fafafa;
  --bg-3:#f1f5fa;
  --container:1280px;
  --pad:80px;
  --sec:120px;
  --t-fast:.24s ease;
  --t:.32s ease;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter','Noto Sans JP',-apple-system,BlinkMacSystemFont,'Hiragino Sans','Hiragino Kaku Gothic ProN','Meiryo',sans-serif;
  color:var(--ink);background:var(--bg);
  line-height:1.7;font-size:15px;font-weight:400;letter-spacing:.02em;overflow-x:hidden;
}
img,svg{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:opacity var(--t-fast),color var(--t-fast)}
a:hover{opacity:.62}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}
em{font-style:normal}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}
.eyebrow{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy);font-weight:600;display:flex;align-items:center;gap:12px}
.eyebrow::before{content:"";display:inline-block;width:2px;height:14px;background:var(--navy);transform:skewX(-18deg)}
.section-head{margin-bottom:56px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{font-family:'Playfair Display','Inter',serif;font-size:40px;line-height:1.18;letter-spacing:-.01em;font-weight:500;color:var(--ink)}
.section-head p{font-size:14px;color:var(--ink-3);margin-top:14px;max-width:560px;line-height:1.85}
.section-flex{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:56px}
.view-all{display:inline-flex;align-items:center;gap:14px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);font-weight:600;padding:14px 0;border-bottom:1px solid var(--navy)}
.view-all:hover{opacity:1;color:var(--navy-deep)}
.view-all .arrow{width:34px;height:34px;border:1px solid var(--navy);border-radius:50%;display:inline-flex;align-items:center;justify-content:center}
.view-all .arrow::after{content:"";width:8px;height:8px;border-top:1px solid var(--navy);border-right:1px solid var(--navy);transform:rotate(45deg) translate(-1px,1px)}
.btn{display:inline-flex;align-items:center;gap:14px;padding:18px 30px;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast),opacity var(--t-fast)}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-deep);opacity:1}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;opacity:1}
.btn .arrow{width:12px;height:12px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg)}

/* HEADER（下層は常時 white ＝ scrolled 固定。page-hero が navy のため transparent→scroll でも可だが、JS で常時付与） */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;border-bottom:1px solid transparent;transition:border-color var(--t-fast),background var(--t-fast),backdrop-filter var(--t-fast)}
.header .brand-name,.header .nav-main > a,.header .lang-switch a,.header .lang-switch span{color:#fff;transition:color var(--t-fast)}
.header .brand .brand-mark{filter:brightness(0) invert(1);transition:filter var(--t-fast)}
.header .nav-main > a + a::before{background:rgba(255,255,255,.32)}
.header .menu-toggle span,.header .menu-toggle span::before,.header .menu-toggle span::after{background:#fff}
.header .cta-contact{background:#fff;color:var(--navy)}
.header .cta-contact:hover{background:#e7eef5}
.header .cta-contact .arrow{border-color:var(--navy)}
.header.scrolled{background:rgba(255,255,255,.98);border-bottom-color:var(--line);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px)}
.header.scrolled .brand-name,.header.scrolled .nav-main > a,.header.scrolled .lang-switch a{color:var(--ink)}
.header.scrolled .nav-main > a[aria-current],.header.scrolled .lang-switch a.active{color:var(--navy)}
.header.scrolled .lang-switch span{color:var(--line)}
.header.scrolled .nav-main > a + a::before{background:var(--line)}
.header.scrolled .brand img{filter:none}
.header.scrolled .menu-toggle span,.header.scrolled .menu-toggle span::before,.header.scrolled .menu-toggle span::after{background:var(--ink)}
.header.scrolled .cta-contact{background:var(--navy);color:#fff}
.header.scrolled .cta-contact:hover{background:var(--navy-deep)}
.header.scrolled .cta-contact .arrow{border-color:#fff}
.header .nav-main > a[aria-current]{color:#fff}
.header .nav-main > a:hover{color:rgba(255,255,255,.7)}
.header.scrolled .nav-main > a:hover{color:var(--navy)}
.header-inner{padding:0 40px;height:84px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand .brand-mark{width:34px;height:auto;flex-shrink:0}
.brand-name{font-family:'Playfair Display',serif;font-size:17px;letter-spacing:.04em;font-weight:500;color:var(--ink);display:inline-flex;align-items:baseline;gap:2px;text-transform:uppercase}
.brand-name-bear{font-style:italic;font-size:.82em;text-transform:none;letter-spacing:.02em;font-weight:400;padding-left:1px}
.nav-main{display:flex;align-items:center;gap:0}
.nav-main > a{position:relative;padding:0 22px;height:84px;display:inline-flex;align-items:center;font-size:13px;font-weight:500;letter-spacing:.06em;color:var(--ink)}
.nav-main > a + a::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:14px;background:var(--line)}
.nav-main > a:hover{opacity:1;color:var(--navy)}
.header-utils{display:flex;align-items:center;gap:18px;flex-shrink:0}
.lang-switch{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.18em;color:var(--ink-3)}
.lang-switch a{font-weight:600}
.lang-switch a.active{color:var(--navy)}
.lang-switch span{color:var(--line)}
.cta-contact{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;background:var(--navy);color:#fff;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;transition:background var(--t-fast)}
.cta-contact:hover{background:var(--navy-deep);opacity:1}
.cta-contact .arrow{width:12px;height:12px;border-top:1px solid #fff;border-right:1px solid #fff;transform:rotate(45deg)}
.menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center}
.menu-toggle span{display:block;width:22px;height:1px;background:var(--ink);position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;right:0;height:1px;background:var(--ink)}
.menu-toggle span::before{top:-7px}
.menu-toggle span::after{top:7px}
.drawer{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:99;transform:translateY(-100%);transition:transform .4s cubic-bezier(.7,0,.2,1);overflow-y:auto;padding:100px 24px 60px;display:none}
.drawer.open{transform:translateY(0)}
.drawer a{display:block;padding:18px 0;border-bottom:1px solid var(--line);font-size:18px;font-weight:500}

/* PAGE HERO（下層共通・コンパクト navy） */
.page-hero{position:relative;background:#0a1e35;color:#fff;padding:138px 0 52px;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 82% 18%,rgba(50,108,159,.28) 0,transparent 55%);pointer-events:none}
.page-hero .container{position:relative;z-index:1}
.page-hero .breadcrumb{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:22px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.page-hero .breadcrumb a{color:rgba(255,255,255,.55)}
.page-hero .breadcrumb a:hover{color:#fff;opacity:1}
.page-hero .breadcrumb .sep{opacity:.4}
.page-hero .eyebrow{color:#fff;margin-bottom:18px}
.page-hero .eyebrow::before{background:#fff}
.page-hero h1{font-family:'Playfair Display','Noto Sans JP',serif;font-size:36px;line-height:1.36;font-weight:500;letter-spacing:0;max-width:860px}
.page-hero .lead{font-size:14px;line-height:1.9;color:rgba(255,255,255,.74);max-width:600px;margin-top:20px}
.page-hero .hero-stripe{position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,#fff 0%,#fff 33%,var(--navy) 33%,var(--navy) 66%,#fff 66%,#fff 100%);opacity:.95}

/* セクション余白の汎用 */
.section{padding:var(--sec) 0}
.section.alt{background:var(--bg-2)}
.section.tight{padding:80px 0}

/* SVC / 交互ブロック（説明系：Services / Situations / About） */
.svc{padding:var(--sec) 0;border-bottom:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
.svc:nth-child(even) .svc-media{order:-1}
.svc-num{font-family:'Playfair Display',serif;font-size:14px;color:var(--navy);letter-spacing:.2em;font-weight:500}
.svc h2{font-family:'Playfair Display','Inter',serif;font-size:34px;line-height:1.24;font-weight:500;margin:10px 0 4px;color:var(--ink)}
.svc .svc-ja{font-size:14px;color:var(--ink-3);letter-spacing:.06em;margin-bottom:24px}
.svc .svc-desc{font-size:15px;line-height:2;color:var(--ink-2);margin-bottom:8px}
.svc-cols{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:34px;padding-top:30px;border-top:1px solid var(--line)}
.svc-col h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:16px}
.svc-col ul{list-style:none}
.svc-col li{font-size:13.5px;color:var(--ink-2);padding:8px 0;display:flex;gap:11px;line-height:1.65}
.svc-col li::before{content:"";width:14px;height:1px;background:var(--navy);flex-shrink:0;margin-top:11px}

/* CARD GRID（カード一覧：Cases / Insights / Situations） */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.card-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{display:flex;flex-direction:column;background:#fff}
.card .card-media{aspect-ratio:4/3;overflow:hidden;margin-bottom:24px}
.card .card-media .ph{height:100%}
.card-meta{display:flex;align-items:center;gap:12px;margin-bottom:13px;font-size:11px;letter-spacing:.16em;color:var(--ink-3);text-transform:uppercase}
.card-tag{color:var(--navy);font-weight:600}
.card-dot{width:3px;height:3px;background:var(--ink-3);border-radius:50%;display:inline-block}
.card h3{font-family:'Inter','Noto Sans JP',sans-serif;font-size:18px;line-height:1.55;font-weight:600;color:var(--ink);margin-bottom:13px}
.card p{font-size:13.5px;color:var(--ink-3);line-height:1.75;margin-bottom:20px;flex-grow:1}
.card .card-link{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.18em;color:var(--navy);font-weight:600;text-transform:uppercase;border-bottom:1px solid var(--navy);padding-bottom:6px;align-self:flex-start;transition:gap var(--t)}
.card .card-link:hover{gap:18px;opacity:1}
.card .card-link .arrow-i{width:8px;height:8px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg);display:inline-block}

/* LIST BLOCK（リスト型：Careers 人物像 / About 施策一覧 / 局面の箇条） */
.list-block{border-top:1px solid var(--line)}
.list-row{display:grid;grid-template-columns:64px 1fr;gap:32px;align-items:start;padding:36px 8px;border-bottom:1px solid var(--line);transition:padding var(--t-fast),background var(--t-fast)}
.list-row:hover{padding-left:20px;padding-right:20px;background:var(--bg-2)}
.list-row .list-num{font-family:'Playfair Display',serif;font-size:18px;color:var(--navy);font-weight:500;letter-spacing:.06em}
.list-row .list-body h3{font-family:'Inter','Noto Sans JP',sans-serif;font-size:19px;line-height:1.5;font-weight:600;color:var(--ink);margin-bottom:10px}
.list-row .list-body p{font-size:14px;line-height:1.85;color:var(--ink-2);max-width:760px}

/* SIMPLE GRID（タグ・領域などの簡易グリッド） */
.tag-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.tag-cell{background:#fff;padding:36px 28px;min-height:150px;display:flex;flex-direction:column;gap:10px;transition:background var(--t-fast)}
.tag-cell:hover{background:var(--bg-3)}
.tag-cell .tc-num{font-family:'Playfair Display',serif;font-size:12px;color:var(--navy);letter-spacing:.16em}
.tag-cell h3{font-family:'Playfair Display','Inter',serif;font-size:22px;line-height:1.3;font-weight:500;color:var(--ink)}
.tag-cell .tc-ja{font-size:12px;color:var(--ink-3)}

/* PROSE（About 等の本文ブロック） */
.prose{max-width:760px}
.prose p{font-size:15px;line-height:2.05;color:var(--ink-2);margin-bottom:22px}
.prose h3{font-family:'Playfair Display','Inter',serif;font-size:24px;font-weight:500;color:var(--ink);margin:44px 0 18px}
.about-grid{display:grid;grid-template-columns:.82fr 1fr;gap:88px;align-items:start}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:44px;padding-top:34px;border-top:1px solid var(--line)}
.stat .stat-num{font-family:'Playfair Display',serif;font-size:44px;line-height:1;color:var(--navy);font-weight:500}
.stat .stat-label{font-size:11px;color:var(--ink-3);letter-spacing:.16em;text-transform:uppercase;margin-top:10px;font-weight:600}

/* CONTACT FORM */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:start}
.contact-info .ci-block{margin-bottom:36px}
.contact-info h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:12px}
.contact-info p{font-size:14px;line-height:1.9;color:var(--ink-2)}
.contact-info a{color:var(--navy);border-bottom:1px solid var(--line)}
.form-row{margin-bottom:26px}
.form-row label{display:block;font-size:12px;letter-spacing:.08em;color:var(--ink-2);font-weight:600;margin-bottom:10px}
.form-row label .req{color:var(--navy);margin-left:6px;font-size:10px}
.form-row input,.form-row textarea,.form-row select{width:100%;font-family:inherit;font-size:14px;color:var(--ink);padding:15px 16px;border:1px solid var(--line);background:#fff;transition:border-color var(--t-fast)}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--navy)}
.form-row textarea{min-height:150px;resize:vertical;line-height:1.7}
.form-note{font-size:12px;color:var(--ink-3);line-height:1.8;margin:8px 0 28px}
.form-submit{width:100%;justify-content:center}

/* 仮画像プレースホルダー */
.ph{position:relative;width:100%;height:100%;background:repeating-linear-gradient(45deg,#eef3f8,#eef3f8 11px,#e6edf4 11px,#e6edf4 22px);border:1px dashed #b9c8d6;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;min-height:120px}
.ph::before{content:"IMAGE";position:absolute;top:12px;left:14px;font-size:9px;letter-spacing:.26em;color:var(--navy);font-weight:700;opacity:.55}
.ph .ph-label{font-size:12.5px;line-height:1.85;color:var(--ink-2);padding:24px;max-width:86%;font-weight:500}
.ph .ph-label b{color:var(--navy);font-weight:600}
.ph.filled{background:none;border:0;min-height:0}
.ph.filled::before{display:none}
.ph.filled .ph-label{display:none}
.ph img{display:block;width:100%;height:100%;object-fit:cover}

/* CTA band */
.cta-band{background:var(--bg-2);padding:100px 0;border-top:1px solid var(--line)}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap}
.cta-text h2{font-family:'Playfair Display','Noto Sans JP',serif;font-size:36px;line-height:1.3;font-weight:500;color:var(--ink)}
.cta-text p{font-size:14px;color:var(--ink-3);margin-top:14px;max-width:520px;line-height:1.9}
.cta-acts{display:flex;gap:16px;flex-wrap:wrap}

/* FOOTER（index v16 と同一） */
.footer{background:#0a1e35;color:#fff;padding:96px 0 40px;position:relative}
.footer-top{display:grid;grid-template-columns:1.1fr 2fr;gap:80px;padding-bottom:64px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand{display:flex;flex-direction:column;gap:18px}
.footer-brand .footer-wordmark{width:240px;height:auto;filter:brightness(0) invert(1)}
.footer-tagline{font-family:'Playfair Display',serif;font-size:16px;color:rgba(255,255,255,.66);letter-spacing:.06em;font-style:normal}
.footer-address{font-style:normal;margin-top:14px;font-size:13px;line-height:1.95;color:rgba(255,255,255,.6)}
.footer-address .addr-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.42);font-weight:600;display:block;margin-bottom:10px}
.footer-address .addr-line{display:block}
.footer-address .addr-contact{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.12)}
.footer-address a{color:rgba(255,255,255,.72);letter-spacing:.04em}
.footer-address a:hover{color:#fff;opacity:1}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.footer-col h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#fff;font-weight:600;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.18)}
.footer-col a{display:block;padding:8px 0;font-size:13px;color:rgba(255,255,255,.7)}
.footer-col a:hover{color:#fff;opacity:1}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:36px;gap:24px;flex-wrap:wrap}
.footer-bottom .copyright{font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.1em}
.footer-bottom .legal{display:flex;gap:24px}
.footer-bottom .legal a{font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.06em}
.footer-bottom .legal a:hover{color:#fff;opacity:1}
.scroll-top{position:absolute;right:40px;top:-28px;width:56px;height:56px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:background var(--t-fast)}
.scroll-top:hover{background:#fff;opacity:1}
.scroll-top:hover::after{border-color:var(--navy)}
.scroll-top::after{content:"";width:10px;height:10px;border-top:1.5px solid #fff;border-right:1.5px solid #fff;transform:rotate(-45deg) translate(1px,2px);transition:border-color var(--t-fast)}

/* NEWS LIST（ニュースリリース一覧・IR会社定番フォーマット） */
.news-list{border-top:1px solid var(--line);margin-top:8px}
.news-item{display:grid;grid-template-columns:130px 130px 1fr 40px;gap:32px;align-items:center;padding:28px 8px;border-bottom:1px solid var(--line);transition:padding var(--t-fast),background var(--t-fast)}
.news-item:hover{padding-left:24px;padding-right:24px;background:var(--bg-2)}
.news-date{font-size:13px;color:var(--ink-3);font-weight:500;letter-spacing:.06em;font-family:'Playfair Display',serif}
.news-tag{font-size:10px;letter-spacing:.2em;font-weight:600;text-transform:uppercase;text-align:center;padding:6px 0;border:1px solid var(--navy);color:var(--navy)}
.news-tag.alert{border-color:#c1473a;color:#c1473a}
.news-tag.event{border-color:#4a7c3b;color:#4a7c3b}
.news-title{font-size:15px;font-weight:500;line-height:1.6;color:var(--ink)}
.news-arrow{width:32px;height:32px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;justify-self:end;transition:border-color var(--t-fast),background var(--t-fast)}
.news-item:hover .news-arrow{border-color:var(--navy);background:var(--navy)}
.news-item:hover .news-arrow::after{border-color:#fff}
.news-arrow::after{content:"";width:6px;height:6px;border-top:1px solid var(--ink-3);border-right:1px solid var(--ink-3);transform:rotate(45deg) translate(-1px,1px);transition:border-color var(--t-fast)}

/* ARTICLE（記事詳細：Insights記事・Newsお知らせ 共通） */
.article{padding:80px 0 var(--sec)}
.article-wrap{max-width:760px;margin:0 auto}
.article-cat{display:flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:16px}
.article-cat .c-tag{color:var(--navy);font-weight:600}
.article-wrap .lead-p{font-size:17px;line-height:1.95;color:var(--ink);font-weight:500;margin-bottom:40px;padding-bottom:36px;border-bottom:1px solid var(--line)}
.article-wrap h2{font-family:'Playfair Display','Noto Sans JP',serif;font-size:25px;line-height:1.4;font-weight:500;color:var(--ink);margin:46px 0 18px}
.article-wrap h3{font-size:16px;font-weight:600;color:var(--ink);margin:32px 0 12px}
.article-wrap p{font-size:15px;line-height:2.05;color:var(--ink-2);margin-bottom:24px}
.article-wrap ul{margin:0 0 24px;padding-left:0;list-style:none}
.article-wrap ul li{font-size:15px;line-height:1.9;color:var(--ink-2);padding:6px 0 6px 24px;position:relative}
.article-wrap ul li::before{content:"";position:absolute;left:0;top:16px;width:14px;height:1px;background:var(--navy)}
.article-wrap blockquote{margin:32px 0;padding:20px 28px;border-left:2px solid var(--navy);background:var(--bg-2);font-size:15px;line-height:1.9;color:var(--ink-2)}
.article-back{margin-top:56px;padding-top:32px;border-top:1px solid var(--line)}
.article-note{margin-top:40px;font-size:12px;color:var(--ink-3);line-height:1.8}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s ease}
.reveal.visible{opacity:1;transform:none}

/* responsive */
@media (max-width:1100px){
  :root{--pad:40px;--sec:96px}
  .nav-main > a{padding:0 16px;font-size:12px}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .tag-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .header-inner{padding:0 24px;height:72px}
  .nav-main,.header-utils .lang-switch,.header-utils .cta-contact{display:none}
  .menu-toggle{display:flex}
  .drawer{display:block}
  .page-hero{padding:128px 0 48px}
  .section-head h2{font-size:30px}
  .svc-grid{grid-template-columns:1fr;gap:40px}
  .svc:nth-child(even) .svc-media{order:0}
  .svc h2{font-size:28px}
  .card-grid,.card-grid.cols-2{grid-template-columns:1fr;gap:40px}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .cta-inner{flex-direction:column;align-items:flex-start;gap:28px}
  .news-item{grid-template-columns:84px 1fr;gap:14px;padding:20px 0}
  .news-item:hover{padding-left:12px;padding-right:12px}
  .news-tag,.news-arrow{display:none}
  .footer-top{grid-template-columns:1fr;gap:48px}
  .footer-cols{grid-template-columns:repeat(2,1fr);gap:32px}
  .container{padding:0 24px}
  .footer{padding:64px 0 32px}
  .scroll-top{right:24px}
}
@media (max-width:600px){
  .page-hero h1{font-size:26px;line-height:1.45}
  .svc h2,.cta-text h2,.section-head h2{font-size:24px}
  .svc-cols{grid-template-columns:1fr;gap:24px}
  .tag-grid{grid-template-columns:1fr}
  .list-row{grid-template-columns:1fr;gap:8px}
  .about-stats{grid-template-columns:repeat(3,1fr);gap:16px}
  .stat .stat-num{font-size:30px}
  .footer-cols{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{transition-duration:0!important;animation-duration:0!important}
}
