
:root{
  --bg:#fcfaf9;
  --bg-soft:#f6f1ee;
  --bg-card:#ffffff;
  --text:#1f232b;
  --muted:#5c6572;
  --line:#e6dbd5;
  --line-strong:#d9c6bd;
  --accent:#981828;
  --accent-dark:#7d1622;
  --accent-soft:#f8ecee;
  --shadow:0 20px 50px rgba(28,34,40,.08);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);
  line-height:1.62;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:1000;
  backdrop-filter:saturate(180%) blur(10px);
  background:rgba(255,255,255,.88);
  border-bottom:1px solid rgba(230,219,213,.9);
}
.header-inner{
  display:flex; align-items:center; gap:22px;
  min-height:84px;
}
.brand img{height:56px; width:auto}
.nav-wrap{flex:1}
.nav{
  display:flex; justify-content:center; gap:26px; flex-wrap:wrap;
}
.nav a{
  font-size:.97rem; color:var(--muted); font-weight:600;
  padding:10px 0; position:relative;
}
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:2px;
  height:2px; background:var(--accent); transform:scaleX(0); transform-origin:center;
  transition:transform .2s ease;
}
.nav a:hover, .nav a:focus-visible{color:var(--text)}
.nav a:hover::after, .nav a:focus-visible::after{transform:scaleX(1)}
.header-actions{display:flex; align-items:center; gap:12px}
.lang-switch{
  width:42px; height:42px; border-radius:999px; display:grid; place-items:center;
  border:1px solid var(--line); color:var(--accent); font-weight:700; background:#fff;
}
.button, .button-secondary{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:0 22px; border-radius:999px; font-weight:700;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.button{background:var(--accent); color:#fff; box-shadow:0 12px 24px rgba(152,24,40,.18)}
.button:hover, .button:focus-visible{background:var(--accent-dark); transform:translateY(-1px)}
.button-secondary{background:#fff; border:1px solid var(--line); color:var(--text)}
.button-secondary:hover, .button-secondary:focus-visible{border-color:var(--line-strong); transform:translateY(-1px)}
.mobile-toggle{
  display:none; border:1px solid var(--line); background:#fff; color:var(--text);
  border-radius:12px; width:44px; height:44px; font-size:1.1rem;
}
.hero{
  position:relative; overflow:clip;
  padding:74px 0 44px;
}
.hero::after{
  content:""; position:absolute; inset:auto 0 -1px 0; height:72px;
  background:linear-gradient(180deg, rgba(252,250,249,0), rgba(252,250,249,.86));
  pointer-events:none;
}
.hero-grid{
  display:grid; grid-template-columns:1.45fr .9fr; gap:28px; align-items:stretch;
}
.hero-panel, .card, .metric, .news-card, .contact-panel, .profile-panel, .feature-panel{
  background:var(--bg-card); border:1px solid rgba(230,219,213,.95);
  border-radius:var(--radius); box-shadow:var(--shadow);
}
.hero-copy-panel{
  position:relative; isolation:isolate; overflow:hidden;
  padding:44px;
  background:
    radial-gradient(1200px 400px at -10% -10%, rgba(152,24,40,.08), transparent 40%),
    linear-gradient(180deg,#fff 0%, #fdf8f8 100%);
}
.hero-copy-panel > *{position:relative; z-index:2;}
.hero-tech-bg{position:absolute; inset:0; z-index:0; pointer-events:none;}
.hero-tech-bg::before{
  content:""; position:absolute; inset:-8% -4%;
  background:
    repeating-linear-gradient(90deg, rgba(152,24,40,.05) 0 1px, transparent 1px 74px),
    repeating-linear-gradient(0deg, rgba(152,24,40,.04) 0 1px, transparent 1px 74px),
    linear-gradient(115deg, transparent 0 58%, rgba(125,22,34,.08) 58% 58.6%, transparent 58.6% 100%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0));
  opacity:.78;
  animation:heroBlueprintShift 28s ease-in-out infinite alternate;
}
.hero-tech-bg::after{
  content:""; position:absolute; right:7%; top:12%; width:180px; height:180px;
  border:1px solid rgba(125,22,34,.10); border-radius:26px;
  transform:rotate(8deg); opacity:.55;
  animation:heroFrameFloat 18s ease-in-out infinite alternate;
}
.sched-bar{
  position:absolute; display:block; height:12px; border-radius:999px;
  background:linear-gradient(90deg, rgba(152,24,40,.18), rgba(152,24,40,.05));
  box-shadow:0 0 0 1px rgba(152,24,40,.06) inset;
}
.sched-bar::before{
  content:""; position:absolute; left:10px; top:50%; width:6px; height:6px; border-radius:50%;
  background:rgba(125,22,34,.22); transform:translateY(-50%);
}
.sched-bar::after{
  content:""; position:absolute; right:10px; top:50%; width:18px; height:2px; border-radius:999px;
  background:rgba(125,22,34,.16); transform:translateY(-50%);
}
.bar-a{left:55%; top:18%; width:24%; animation:heroBarA 16s ease-in-out infinite alternate;}
.bar-b{left:46%; top:30%; width:34%; animation:heroBarB 20s ease-in-out infinite alternate;}
.bar-c{left:58%; top:42%; width:20%; animation:heroBarC 14s ease-in-out infinite alternate;}
.bar-d{left:39%; top:57%; width:42%; animation:heroBarD 19s ease-in-out infinite alternate;}
.bar-e{left:52%; top:70%; width:28%; animation:heroBarE 15s ease-in-out infinite alternate;}
.bar-f{left:63%; top:82%; width:16%; animation:heroBarF 17s ease-in-out infinite alternate;}
.eyebrow{
  display:inline-block; letter-spacing:.14em; text-transform:uppercase;
  font-size:.78rem; font-weight:800; color:var(--accent); margin-bottom:14px;
}
.hero h1{
  margin:0 0 18px; font-size:clamp(2.1rem, 4vw, 4rem); line-height:1.08; max-width:11ch;
}
.hero p{font-size:1.06rem; color:var(--muted); margin:0}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin:28px 0 30px}
.hero-stats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
.hero-stat{
  padding:16px; border-radius:18px; background:#fff; border:1px solid var(--line);
}
.hero-stat strong{display:block; font-size:1rem; margin-bottom:6px}
.hero-stat span{display:block; color:var(--muted); font-size:.94rem; line-height:1.5}
.hero-side{display:grid; gap:20px}
.hero-card{padding:28px}
.hero-card small{
  display:block; color:var(--muted); text-transform:uppercase; letter-spacing:.12em; font-weight:800; margin-bottom:10px;
}
.hero-card h3{margin:0 0 10px; font-size:1.5rem}
.hero-card p{margin:0 0 14px; color:var(--muted)}
.list{margin:0; padding-left:1.1rem}
.list li{margin:.4rem 0}
.ghost-link{color:var(--accent); font-weight:700}
.section{position:relative; padding:56px 0; background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.96)); overflow:clip;}
.section + .section{margin-top:-2px;}
.hero + .section::before,
.section + .section::before{
  content:""; position:absolute; inset-inline:0; top:0; height:44px; transform:translateY(-44px);
  background:linear-gradient(180deg, rgba(252,250,249,0), rgba(252,250,249,.74) 58%, rgba(252,250,249,.98) 100%);
  pointer-events:none;
}
.section.soft{
  background:
    linear-gradient(180deg, rgba(152,24,40,.045) 0%, rgba(152,24,40,.024) 58%, rgba(252,250,249,1) 100%),
    var(--bg-soft);
  border-block:1px solid rgba(230,219,213,.75);
}
.metric-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.metric{padding:24px}
.metric strong{display:block; font-size:1.02rem; margin-bottom:8px}
.metric span{color:var(--muted)}
.about-grid{
  display:grid; grid-template-columns:.88fr 1.12fr; gap:30px; align-items:center;
}
.about-layout{
  display:grid; grid-template-columns:minmax(280px,.46fr) minmax(0,.54fr); gap:30px; align-items:start;
}
.about-main{min-width:0;}
.about-sidebar{display:grid; gap:18px; align-self:start; order:0;}
.profile-panel{
  padding:22px; background:linear-gradient(180deg,#fff,#f7f2ef);
}
.profile-panel-tight{padding:18px 18px 14px;}
.profile-art{
  width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center top;
  border-radius:20px;
}
.about-main h2, .section-title h2, .contact-panel h2{margin:.1rem 0 .7rem; font-size:clamp(1.9rem,3vw,2.8rem); line-height:1.12}
.lead{font-size:1.08rem; color:var(--muted)}
.badge-row{display:flex; flex-wrap:wrap; gap:10px; margin:20px 0 16px}
.badge{
  display:inline-flex; align-items:center; min-height:38px; padding:0 14px;
  border-radius:999px; background:var(--accent-soft); border:1px solid #e8cfd4; color:var(--accent); font-weight:700; font-size:.93rem;
}
.section-title{max-width:780px; margin-bottom:24px}
.section-title p{color:var(--muted)}
.service-grid, .card-grid, .news-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.card{padding:26px}
.card h3{margin:0 0 8px; font-size:1.35rem}
.strap{display:block; font-weight:700; color:var(--accent); margin-bottom:12px}
.card p{margin:0; color:var(--muted)}
.divider{height:1px; background:var(--line); margin:26px 0}
.feature-split{
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
}
.feature-panel{padding:28px}
.feature-panel h3{margin:.1rem 0 .7rem; font-size:1.4rem}
.feature-panel p{margin:0; color:var(--muted)}
.feature-list{margin:0; padding-left:1.1rem}
.feature-list li{margin:.45rem 0}
.news-card{overflow:hidden}
.news-card img{
  width:100%; aspect-ratio:16/10; object-fit:cover; background:#eee;
}
.news-body{padding:18px 18px 20px}
.meta{
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-size:.88rem; color:var(--muted); margin-bottom:10px;
}
.news-body h3{margin:0 0 8px; font-size:1.24rem; line-height:1.28}
.news-body p{margin:0; color:var(--muted)}
.contact-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:22px; align-items:stretch;
}
.contact-panel{padding:30px}
.contact-list{list-style:none; padding:0; margin:18px 0 0}
.contact-list li{
  display:grid; grid-template-columns:92px 1fr; gap:14px;
  padding:12px 0; border-bottom:1px solid var(--line);
}
.contact-list li:last-child{border-bottom:none}
.contact-list span{font-weight:700}
.contact-list a{color:var(--accent); overflow-wrap:anywhere}
.qr-card{
  display:grid; place-items:center; padding:26px; background:#fff; border:1px solid var(--line-strong);
  border-radius:24px; max-width:360px;
}
.qr-card img{
  width:min(100%, 290px); height:auto; image-rendering:auto;
}
.contact-note{
  margin-top:16px; color:var(--muted); font-size:.96rem;
}
.site-footer{
  padding:26px 0 42px; background:#fff; border-top:1px solid var(--line);
}
.footer-grid{
  display:grid; grid-template-columns:1.6fr .8fr; gap:24px; align-items:start;
}
.footer-nav{display:grid; gap:10px; justify-content:start}
.note{color:var(--muted); font-size:.95rem}
.footer-brand{font-size:1.08rem}
@media (max-width: 1080px){
  .hero-grid,.about-grid,.about-layout,.contact-grid,.feature-split{grid-template-columns:1fr}
  .about-sidebar{order:0;}
  .full-width-credentials{margin-top:18px;}
  .metric-grid{grid-template-columns:repeat(2,1fr)}
  .service-grid,.card-grid,.news-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 760px){
  .container{width:min(var(--max), calc(100% - 24px))}
  html{scroll-padding-top:84px;}
  .header-inner{min-height:74px; gap:14px; flex-wrap:wrap}
  .brand img{height:44px}
  .mobile-toggle{display:grid; place-items:center; margin-left:auto}
  .nav-wrap{
    width:100%; display:none;
  }
  .nav-wrap.open{display:block}
  .nav{
    justify-content:flex-start; flex-direction:column; gap:0; padding:10px 0 6px;
  }
  .nav a{padding:12px 0; border-top:1px solid var(--line)}
  .header-actions{margin-left:auto}
  .header-actions .button{display:none}
  .hero{padding-top:40px}
  .hero-copy-panel,.hero-card,.metric,.card,.feature-panel,.contact-panel,.profile-panel{padding:22px}
  .hero-tech-bg::after{width:126px; height:126px; right:4%; top:10%;}
  .sched-bar{height:10px; opacity:.88;}
  .bar-a{left:48%; width:28%;}
  .bar-b{left:36%; width:40%;}
  .bar-c{left:54%; width:24%;}
  .bar-d{left:26%; width:52%;}
  .bar-e{left:42%; width:34%;}
  .bar-f{left:56%; width:20%;}
  .hero-stats,.metric-grid,.service-grid,.card-grid,.news-grid,.footer-grid,.triple-grid{grid-template-columns:1fr}
  .contact-list li{grid-template-columns:1fr}
  .meta{flex-direction:column; gap:4px}
}


@keyframes heroBlueprintShift{
  0%{transform:translate3d(0,0,0) scale(1);}
  100%{transform:translate3d(-14px,10px,0) scale(1.015);}
}
@keyframes heroFrameFloat{
  0%{transform:rotate(8deg) translate3d(0,0,0);}
  100%{transform:rotate(10deg) translate3d(8px,-10px,0);}
}
@keyframes heroBarA{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(-8px,4px,0);}}
@keyframes heroBarB{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(10px,-3px,0);}}
@keyframes heroBarC{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(-6px,5px,0);}}
@keyframes heroBarD{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(12px,-4px,0);}}
@keyframes heroBarE{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(-7px,3px,0);}}
@keyframes heroBarF{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(9px,-5px,0);}}

.service-group + .service-group{margin-top:28px}
.group-head{max-width:760px; margin-bottom:18px}
.group-head p{margin:.35rem 0 0; color:var(--muted)}
.mini-title{
  display:inline-block; letter-spacing:.08em; text-transform:uppercase;
  font-size:.78rem; font-weight:800; color:var(--accent);
}
.service-grid-two{grid-template-columns:repeat(2,1fr)}
.service-grid-one{grid-template-columns:1fr; max-width:480px}
.dual-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
}
.triple-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.steps-list{margin:0; padding-left:1.2rem}
.steps-list li{margin:.65rem 0; color:var(--muted)}
.about-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:20px}
.credentials-block{
  margin-top:22px; padding-top:18px; border-top:1px solid var(--line);
}
.full-width-credentials{
  grid-column:1 / -1;
  margin-top:26px; padding-top:22px;
}
.credentials-badge-row{margin:14px 0 0;}
.news-grid-primary{margin-bottom:18px}
.news-actions{display:flex; justify-content:center; margin:8px 0 6px}
.news-toggle{gap:10px}
.news-toggle .arrow{transition:transform .2s ease; font-size:1rem}
.news-toggle[aria-expanded="true"] .arrow{transform:rotate(180deg)}
.news-more{padding-top:8px}
@media (max-width: 1080px){
  .credentials-grid{grid-template-columns:repeat(2,1fr)}
  .dual-grid,.triple-grid{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .credentials-grid,.service-grid-two,.service-grid-one{grid-template-columns:1fr}
  [id]{scroll-margin-top:84px;}
}



[id]{scroll-margin-top:96px;}

.reveal{
  opacity:0; transform:translateY(26px); filter:blur(6px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1), filter .7s ease;
  transition-delay:var(--reveal-delay, 0ms);
}
.reveal.is-visible{opacity:1; transform:none; filter:none;}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *, *::before, *::after{animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important;}
  .hero-tech-bg, .hero-tech-bg::before, .hero-tech-bg::after, .sched-bar{animation:none !important;}
  .reveal{opacity:1 !important; transform:none !important; filter:none !important;}
}

@media (max-width: 760px){
  [id]{scroll-margin-top:84px;}
}


.hero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, transparent 13%, rgba(152,24,40,.16) 13% 13.35%, transparent 13.35% 25.2%, rgba(152,24,40,.14) 25.2% 25.55%, transparent 25.55% 43.6%, rgba(152,24,40,.14) 43.6% 43.95%, transparent 43.95% 61.4%, rgba(152,24,40,.13) 61.4% 61.75%, transparent 61.75% 79.8%, rgba(152,24,40,.13) 79.8% 80.15%, transparent 80.15%),
    linear-gradient(180deg, transparent 16%, rgba(152,24,40,.10) 16% 16.35%, transparent 16.35% 32%, rgba(152,24,40,.10) 32% 32.35%, transparent 32.35% 48%, rgba(152,24,40,.10) 48% 48.35%, transparent 48.35% 64%, rgba(152,24,40,.10) 64% 64.35%, transparent 64.35%),
    radial-gradient(circle at 13% 16%, rgba(152,24,40,.18) 0 1.9px, transparent 2.2px),
    radial-gradient(circle at 25.2% 32%, rgba(152,24,40,.18) 0 1.9px, transparent 2.2px),
    radial-gradient(circle at 43.6% 48%, rgba(152,24,40,.18) 0 1.9px, transparent 2.2px),
    radial-gradient(circle at 61.4% 64%, rgba(152,24,40,.18) 0 1.9px, transparent 2.2px);
  opacity:.34;
  z-index:0;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(134deg, transparent 0 16.1%, rgba(152,24,40,.13) 16.1% 16.5%, transparent 16.5% 100%),
    linear-gradient(135deg, transparent 0 27.9%, rgba(152,24,40,.12) 27.9% 28.3%, transparent 28.3% 100%),
    linear-gradient(136deg, transparent 0 46.2%, rgba(152,24,40,.12) 46.2% 46.6%, transparent 46.6% 100%),
    linear-gradient(133deg, transparent 0 63.9%, rgba(152,24,40,.11) 63.9% 64.3%, transparent 64.3% 100%);
  opacity:.28;
  z-index:0;
}
.hero > *{position:relative; z-index:1;}

