:root{
  --md-primary:#0f2442;
  --md-primary-soft:#1a355f;
  --md-accent:#c6922b;
  --md-accent-soft:#d9ab4a;
  --md-bg:#f5f2ea;
  --md-text:#1a1a1a;
  --md-muted:#5a6678;
  --md-card:#ffffff;
  --md-border:#d8d4c6;
  --md-success:#2d6a4f;
  --md-warn:#9a5d00;
  --md-shadow:0 4px 18px rgba(15,36,66,.08);
  --md-shadow-lg:0 12px 36px rgba(15,36,66,.14);
  --md-radius:10px;
  --md-radius-sm:6px;
  --md-max:1200px;
  --md-font-serif:"Noto Serif JP",serif;
  --md-font-sans:"Noto Sans JP",system-ui,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --md-font-mono:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--md-bg);
  color:var(--md-text);
  font-family:var(--md-font-sans);
  font-size:16px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--md-primary);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--md-accent)}
img{max-width:100%;display:block;height:auto}
h1,h2,h3,h4,h5{
  font-family:var(--md-font-serif);
  color:var(--md-primary);
  line-height:1.3;
  margin:0 0 .6em;
  font-weight:700;
}
h1{font-size:2.1rem;letter-spacing:.01em}
h2{font-size:1.55rem}
h3{font-size:1.25rem}
h4{font-size:1.08rem}
p{margin:0 0 1em}
.num,.kpi-value,.byline time,.breadcrumbs time{font-family:var(--md-font-mono);font-weight:500}
.container{max-width:var(--md-max);margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section-tight{padding:48px 0}
.section-dark{background:var(--md-primary);color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-cream{background:var(--md-bg)}
.section-white{background:#fff}
.section-head{margin-bottom:36px;max-width:760px}
.section-eyebrow{
  display:inline-block;
  font-family:var(--md-font-mono);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.78rem;
  color:var(--md-accent);
  margin-bottom:10px;
}
.section-lead{color:var(--md-muted);font-size:1.02rem;max-width:680px}
.topbar{
  background:var(--md-primary);
  color:#fff;
  font-size:.82rem;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  justify-content:space-between;
  align-items:center;
  padding:10px 24px;
  max-width:var(--md-max);
  margin:0 auto;
}
.topbar-kpi{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  color:#e5dfce;
}
.topbar-kpi span{display:inline-flex;align-items:center;gap:6px}
.topbar-kpi i{color:var(--md-accent-soft)}
.topbar-note{color:#c5cbd6;font-size:.74rem}
.site-header{
  background:#fff;
  border-bottom:1px solid var(--md-border);
  position:sticky;
  top:0;
  z-index:40;
}
.site-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  max-width:var(--md-max);
  margin:0 auto;
  padding:16px 24px;
}
.brand{display:flex;align-items:center;gap:12px;color:var(--md-primary)}
.brand-mark{
  width:42px;
  height:42px;
  border-radius:8px;
  background:linear-gradient(135deg,var(--md-primary) 0%,var(--md-primary-soft) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--md-accent);
  font-size:1.35rem;
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:var(--md-font-serif);font-weight:700;font-size:1.05rem;color:var(--md-primary)}
.brand-sub{font-size:.72rem;color:var(--md-muted);margin-top:2px;letter-spacing:.02em}
.nav{display:flex;align-items:center;gap:28px}
.nav-list{
  display:flex;
  gap:24px;
  list-style:none;
  margin:0;
  padding:0;
  align-items:center;
}
.nav-list > li{position:relative}
.nav-list a{
  color:var(--md-primary);
  font-weight:500;
  font-size:.94rem;
  padding:8px 2px;
  display:inline-block;
  border-bottom:2px solid transparent;
  transition:border-color .2s ease,color .2s ease;
}
.nav-list a:hover,.nav-list a.active{border-bottom-color:var(--md-accent);color:var(--md-primary)}
.has-dropdown > a::after{
  content:"\25BE";
  margin-left:6px;
  color:var(--md-muted);
  font-size:.7rem;
}
.dropdown{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  box-shadow:var(--md-shadow-lg);
  min-width:320px;
  padding:12px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(-6px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  list-style:none;
  margin:0;
  z-index:50;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown,
.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li{margin:0}
.dropdown a{
  padding:10px 18px;
  display:block;
  font-size:.88rem;
  font-weight:400;
  border:none;
  color:var(--md-primary);
  line-height:1.45;
}
.dropdown a:hover{background:var(--md-bg);color:var(--md-accent)}
.nav-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 18px;
  background:var(--md-accent);
  color:var(--md-primary)!important;
  border-radius:var(--md-radius-sm);
  font-weight:700;
  font-size:.88rem;
  border:none!important;
  transition:background .2s ease,transform .2s ease;
}
.nav-cta:hover{background:var(--md-accent-soft);color:var(--md-primary)!important;transform:translateY(-1px)}
.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--md-border);
  border-radius:6px;
  padding:8px 10px;
  color:var(--md-primary);
  cursor:pointer;
  font-size:1.2rem;
}
.hero{
  position:relative;
  min-height:560px;
  background:url('../media/home-macro-dashboard-hero.jpg') center/cover no-repeat,var(--md-primary);
  color:#fff;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(15,36,66,.88) 0%,rgba(15,36,66,.65) 55%,rgba(15,36,66,.78) 100%);
}
.hero-inner{
  position:relative;
  z-index:2;
  max-width:var(--md-max);
  margin:0 auto;
  padding:96px 24px 80px;
  width:100%;
}
.hero-eyebrow{
  display:inline-block;
  font-family:var(--md-font-mono);
  color:var(--md-accent-soft);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:.8rem;
  margin-bottom:14px;
  padding:6px 12px;
  border:1px solid rgba(198,146,43,.5);
  border-radius:999px;
}
.hero h1{
  color:#fff;
  font-size:2.55rem;
  max-width:820px;
  margin-bottom:20px;
  line-height:1.25;
}
.hero-sub{
  color:#e9e4d7;
  font-size:1.08rem;
  max-width:680px;
  margin-bottom:32px;
  line-height:1.75;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:42px}
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:13px 24px;
  border-radius:var(--md-radius-sm);
  font-weight:700;
  font-size:.95rem;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
  font-family:inherit;
  text-align:center;
}
.btn-primary{background:var(--md-accent);color:var(--md-primary);border-color:var(--md-accent)}
.btn-primary:hover{background:var(--md-accent-soft);border-color:var(--md-accent-soft);color:var(--md-primary);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--md-accent-soft);border-color:var(--md-accent-soft)}
.btn-outline:hover{background:rgba(198,146,43,.15);color:#fff}
.btn-ghost{background:transparent;color:var(--md-primary);border-color:var(--md-border)}
.btn-ghost:hover{border-color:var(--md-accent);color:var(--md-accent)}
.btn-block{display:flex;width:100%;justify-content:center}
.hero-kpi{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  max-width:880px;
  padding:18px;
  background:rgba(10,22,42,.55);
  border:1px solid rgba(198,146,43,.3);
  border-radius:var(--md-radius);
  backdrop-filter:blur(4px);
}
.hero-kpi .kpi-item{text-align:left;padding:4px 6px}
.kpi-value{
  font-size:1.6rem;
  color:var(--md-accent-soft);
  font-weight:700;
  line-height:1;
  margin-bottom:6px;
  display:block;
}
.kpi-label{font-size:.78rem;color:#cbd3e0;letter-spacing:.05em}
.hero-disclose{
  margin-top:16px;
  font-size:.72rem;
  color:#b6bdca;
  max-width:880px;
  line-height:1.6;
}
.cards-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
}
.cards-grid.three{grid-template-columns:repeat(3,1fr)}
.card{
  background:var(--md-card);
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  box-shadow:var(--md-shadow);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--md-shadow-lg);border-color:#cdc4a8}
.card-cover{aspect-ratio:16/10;overflow:hidden;background:#e9e4d3}
.card-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card-cover img{transform:scale(1.04)}
.card-body{padding:24px 24px 22px;display:flex;flex-direction:column;flex-grow:1}
.card-tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--md-font-mono);
  font-size:.7rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--md-accent);
  margin-bottom:12px;
}
.card-tag.status-live{color:var(--md-success)}
.card h3{font-size:1.18rem;margin-bottom:10px;line-height:1.4}
.card h3 a{color:var(--md-primary)}
.card h3 a:hover{color:var(--md-accent)}
.card-summary{color:var(--md-muted);font-size:.94rem;margin-bottom:18px;flex-grow:1}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.card-cta{
  font-weight:700;
  color:var(--md-accent);
  font-size:.88rem;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.card-cta:hover{color:var(--md-primary)}
.card-meta{font-family:var(--md-font-mono);font-size:.72rem;color:var(--md-muted);letter-spacing:.03em}
.advantages-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.advantage{
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  padding:26px 22px;
  position:relative;
  transition:border-color .2s ease;
}
.advantage:hover{border-color:var(--md-accent)}
.advantage-icon{
  width:46px;
  height:46px;
  border-radius:10px;
  background:linear-gradient(135deg,var(--md-primary) 0%,var(--md-primary-soft) 100%);
  color:var(--md-accent-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.3rem;
  margin-bottom:16px;
}
.advantage h4{font-size:1.05rem;margin-bottom:8px}
.advantage p{font-size:.9rem;color:var(--md-muted);margin:0}
.mission{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:48px;
  align-items:center;
}
.mission-image{
  border-radius:var(--md-radius);
  overflow:hidden;
  aspect-ratio:5/4;
  box-shadow:var(--md-shadow);
}
.mission-image img{width:100%;height:100%;object-fit:cover}
.mission-body p{color:var(--md-muted);font-size:1rem}
.mission-body ul{margin:18px 0 0;padding-left:22px;color:var(--md-muted)}
.mission-body li{margin-bottom:8px}
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  padding:0;
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  padding:18px 22px;
  font-weight:700;
  color:var(--md-primary);
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  font-family:var(--md-font-serif);
  font-size:1.02rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--md-accent);font-size:1.3rem;line-height:1;transition:transform .2s}
.faq-item[open] summary::after{content:"\2212"}
.faq-item-body{padding:0 22px 20px;color:var(--md-muted);font-size:.95rem;border-top:1px solid var(--md-border)}
.faq-item-body p{margin-top:14px}
.about-preview{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:48px;
  align-items:center;
}
.about-preview-image{
  border-radius:var(--md-radius);
  overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:var(--md-shadow);
}
.about-preview-image img{width:100%;height:100%;object-fit:cover}
.closing-cta{
  background:linear-gradient(135deg,var(--md-primary) 0%,#17305a 55%,#1c3a6b 100%);
  color:#fff;
  border-radius:14px;
  padding:52px 48px;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:32px;
  align-items:center;
  box-shadow:var(--md-shadow-lg);
}
.closing-cta h2{color:#fff;margin-bottom:12px}
.closing-cta p{color:#dde3ef;margin-bottom:0}
.closing-cta .btn-primary{background:var(--md-accent);color:var(--md-primary)}
.closing-cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-end}
.breadcrumbs{
  font-size:.85rem;
  color:var(--md-muted);
  padding:20px 0 0;
}
.breadcrumbs a{color:var(--md-muted)}
.breadcrumbs a:hover{color:var(--md-accent)}
.breadcrumbs span{margin:0 8px;color:var(--md-border)}
.page-header{padding:56px 0 32px}
.page-header h1{margin-bottom:14px}
.page-header p{color:var(--md-muted);max-width:720px;font-size:1.02rem}
.article-hero{
  background:var(--md-card);
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  overflow:hidden;
  margin-bottom:36px;
  box-shadow:var(--md-shadow);
}
.article-hero-img{aspect-ratio:21/9;overflow:hidden;background:#e9e4d3}
.article-hero-img img{width:100%;height:100%;object-fit:cover}
.article-hero-body{padding:32px 36px 28px}
.article-hero-body h1{font-size:2rem;margin-bottom:10px;line-height:1.3}
.byline{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  color:var(--md-muted);
  font-size:.84rem;
  margin-bottom:8px;
}
.byline .chip{
  font-family:var(--md-font-mono);
  padding:3px 9px;
  border:1px solid var(--md-border);
  border-radius:999px;
  color:var(--md-primary);
  font-size:.72rem;
  letter-spacing:.05em;
}
.article-body{
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  padding:40px 44px;
  font-size:1.02rem;
  line-height:1.85;
  color:#222;
  box-shadow:var(--md-shadow);
}
.article-body h2{
  font-size:1.4rem;
  margin-top:2em;
  padding-left:14px;
  border-left:4px solid var(--md-accent);
}
.article-body h3{font-size:1.15rem;margin-top:1.6em;color:var(--md-primary-soft)}
.article-body p{margin-bottom:1.1em;color:#2a2a2a}
.article-body ul,.article-body ol{padding-left:22px;margin-bottom:1.2em;color:#2a2a2a}
.article-body li{margin-bottom:6px}
.article-body .callout{
  background:#fdf7e8;
  border:1px solid #ecd99a;
  border-left:4px solid var(--md-accent);
  padding:18px 22px;
  border-radius:var(--md-radius-sm);
  margin:1.5em 0;
  color:#2a2a2a;
  font-size:.96rem;
}
.article-body .callout strong{color:var(--md-warn)}
.prevnext{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:28px;
}
.prevnext a{
  display:block;
  padding:20px 22px;
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  transition:border-color .2s ease,transform .2s ease;
}
.prevnext a:hover{border-color:var(--md-accent);transform:translateY(-2px)}
.prevnext-label{
  font-family:var(--md-font-mono);
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--md-accent);
  display:block;
  margin-bottom:6px;
}
.prevnext-title{font-weight:700;color:var(--md-primary);font-size:.98rem;line-height:1.45}
.prevnext .next{text-align:right}
.contact-top{
  background:#eef1f7;
  padding:56px 0 40px;
}
.contact-top h1{margin-bottom:12px}
.contact-top p{color:var(--md-muted);max-width:720px}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:36px;
  padding:56px 0 48px;
}
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-info-item{
  display:flex;
  gap:14px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  padding:20px 22px;
  box-shadow:var(--md-shadow);
}
.contact-info-icon{
  width:42px;
  height:42px;
  flex-shrink:0;
  border-radius:10px;
  background:var(--md-primary);
  color:var(--md-accent-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
}
.contact-info-item h4{font-size:.95rem;margin:0 0 4px;color:var(--md-primary)}
.contact-info-item p{margin:0;color:var(--md-muted);font-size:.92rem;line-height:1.6}
.contact-info-item a{color:var(--md-primary)}
.contact-info-item a:hover{color:var(--md-accent)}
.contact-form-card{
  background:#fff;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  padding:32px 34px;
  box-shadow:var(--md-shadow);
}
.contact-form-card h2{font-size:1.25rem;margin-bottom:16px}
.form-field{margin-bottom:18px}
.form-field label{display:block;font-weight:600;margin-bottom:6px;color:var(--md-primary);font-size:.9rem}
.form-field input,.form-field textarea{
  width:100%;
  padding:11px 14px;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius-sm);
  font:inherit;
  background:#fff;
  color:var(--md-text);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.form-field textarea{resize:vertical;min-height:130px}
.form-field input:focus,.form-field textarea:focus{
  border-color:var(--md-accent);
  outline:none;
  box-shadow:0 0 0 3px rgba(198,146,43,.18);
}
.form-consent{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:.84rem;
  color:var(--md-muted);
  margin-bottom:16px;
  line-height:1.55;
}
.form-consent input{margin-top:3px}
.map-wrap{padding:0 0 72px}
.map-frame{
  width:100%;
  height:520px;
  border:1px solid var(--md-border);
  border-radius:var(--md-radius);
  overflow:hidden;
  box-shadow:var(--md-shadow);
}
.map-frame iframe{width:100%;height:100%;border:0;display:block}
.map-link{margin-top:14px;font-size:.9rem}
.map-link a{font-weight:600;color:var(--md-accent)}
.list-intro{background:#eef1f7;padding:60px 0 36px}
.list-intro h1{margin-bottom:12px}
.list-grid{padding:48px 0 72px}
.list-grid .cards-grid{grid-template-columns:repeat(2,1fr)}
.legal-wrap{max-width:860px;margin:0 auto;background:#fff;padding:46px 50px;border:1px solid var(--md-border);border-radius:var(--md-radius);box-shadow:var(--md-shadow)}
.legal-wrap h2{font-size:1.2rem;margin-top:1.6em;padding-left:12px;border-left:3px solid var(--md-accent)}
.legal-wrap h2:first-of-type{margin-top:0}
.legal-wrap p,.legal-wrap li{color:#2a2a2a}
.legal-wrap .updated{color:var(--md-muted);font-family:var(--md-font-mono);font-size:.85rem;margin-bottom:1.6em}
.site-footer{
  background:#0a1a33;
  color:#d8dde8;
  padding:56px 0 24px;
  margin-top:72px;
  font-size:.92rem;
}
.footer-grid{
  max-width:var(--md-max);
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:1.2fr 1fr 1.2fr;
  gap:42px;
}
.footer-col h4{
  color:#fff;
  font-size:1rem;
  margin-bottom:16px;
  font-family:var(--md-font-serif);
  letter-spacing:.02em;
}
.footer-contact{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;line-height:1.6}
.footer-contact i{color:var(--md-accent-soft);font-size:1.05rem;margin-top:3px;flex-shrink:0}
.footer-contact a{color:#d8dde8}
.footer-contact a:hover{color:var(--md-accent-soft)}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-links a{color:#d8dde8}
.footer-links a:hover{color:var(--md-accent-soft)}
.footer-links button{
  background:transparent;
  border:none;
  color:#d8dde8;
  font:inherit;
  padding:0;
  cursor:pointer;
  text-align:left;
}
.footer-links button:hover{color:var(--md-accent-soft)}
.footer-news p{color:#a9b1c1;font-size:.84rem;margin-bottom:14px;line-height:1.6}
.footer-news .form-field{margin-bottom:12px}
.footer-news .form-field label{color:#d8dde8;font-size:.8rem}
.footer-news .form-field input{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.2);
  color:#fff;
}
.footer-news .form-field input::placeholder{color:#8f97a8}
.footer-news .form-consent{color:#a9b1c1;font-size:.78rem}
.footer-news .form-consent a{color:var(--md-accent-soft)}
.footer-news .btn-primary{width:100%;padding:10px 16px;font-size:.85rem}
.footer-cta-row{
  max-width:var(--md-max);
  margin:36px auto 0;
  padding:22px 24px 0;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  color:#a9b1c1;
  font-size:.84rem;
  letter-spacing:.02em;
}
.footer-cta-row a{color:var(--md-accent-soft);font-weight:600}
.cookie-bar{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  background:#0a1a33;
  color:#edf0f7;
  border-top:2px solid var(--md-accent);
  padding:18px 24px;
  display:none;
  z-index:100;
  box-shadow:0 -8px 32px rgba(10,26,51,.4);
}
.cookie-bar.visible{display:block}
.cookie-inner{
  max-width:var(--md-max);
  margin:0 auto;
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  align-items:center;
  justify-content:space-between;
}
.cookie-text{flex:1 1 440px;font-size:.88rem;line-height:1.6;color:#d8dde8}
.cookie-text strong{color:#fff}
.cookie-text a{color:var(--md-accent-soft);font-weight:600}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions button{
  padding:10px 20px;
  border-radius:var(--md-radius-sm);
  border:1px solid transparent;
  font-weight:600;
  font-family:inherit;
  font-size:.88rem;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.cookie-accept{background:var(--md-accent);color:var(--md-primary);border-color:var(--md-accent)}
.cookie-accept:hover{background:var(--md-accent-soft)}
.cookie-reject{background:transparent;color:#edf0f7;border-color:rgba(255,255,255,.3)}
.cookie-reject:hover{border-color:var(--md-accent-soft);color:var(--md-accent-soft)}
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(10,26,51,.55);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:200;
  padding:24px;
}
.modal-backdrop.visible{display:flex}
.modal-card{
  background:#fff;
  border-radius:12px;
  padding:36px 36px 32px;
  max-width:440px;
  width:100%;
  text-align:center;
  box-shadow:var(--md-shadow-lg);
  border-top:4px solid var(--md-success);
}
.modal-card h3{color:var(--md-success);margin-bottom:10px;font-size:1.2rem}
.modal-card p{color:var(--md-muted);font-size:.95rem;margin-bottom:0}
@media (max-width:1024px){
  .hero h1{font-size:2.15rem}
  .hero-kpi{grid-template-columns:repeat(2,1fr)}
  .advantages-grid{grid-template-columns:repeat(2,1fr)}
  .closing-cta{grid-template-columns:1fr;padding:44px 32px}
  .closing-cta-actions{justify-content:flex-start}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-news{grid-column:1 / -1}
}
@media (max-width:768px){
  h1{font-size:1.75rem}
  h2{font-size:1.35rem}
  .section{padding:56px 0}
  .site-header-inner{flex-wrap:wrap;gap:14px}
  .nav{width:100%;display:none}
  .nav.open{display:flex;flex-direction:column;align-items:stretch;gap:18px;padding-top:10px;border-top:1px solid var(--md-border)}
  .nav-list{flex-direction:column;gap:14px;align-items:stretch}
  .dropdown{position:static;box-shadow:none;opacity:1;visibility:visible;transform:none;border:none;padding:8px 0 0 14px;min-width:0}
  .nav-toggle{display:inline-flex}
  .nav-cta{justify-content:center}
  .hero{min-height:400px}
  .hero-inner{padding:64px 20px 56px}
  .hero h1{font-size:1.75rem}
  .cards-grid{grid-template-columns:1fr;gap:22px}
  .cards-grid.three{grid-template-columns:1fr}
  .mission,.about-preview{grid-template-columns:1fr;gap:28px}
  .contact-grid{grid-template-columns:1fr;padding:40px 0}
  .map-frame{height:320px}
  .article-body{padding:28px 22px}
  .article-hero-body{padding:24px 22px}
  .legal-wrap{padding:32px 22px}
  .prevnext{grid-template-columns:1fr}
  .prevnext .next{text-align:left}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-news{grid-column:auto}
}
@media (max-width:480px){
  .hero h1{font-size:1.55rem}
  .hero-sub{font-size:.96rem}
  .btn{padding:11px 18px;font-size:.88rem}
  .hero-kpi{grid-template-columns:1fr 1fr;padding:14px}
  .kpi-value{font-size:1.3rem}
  .topbar-inner{padding:8px 16px;gap:10px}
  .topbar-kpi{gap:12px}
  .container{padding:0 18px}
  .list-grid .cards-grid{grid-template-columns:1fr}
  .advantages-grid{grid-template-columns:1fr}
}
