:root{--red:#c1121f;--red-d:#9a0e18;--red-dd:#7a0b13;--ink:#181818;--body:#3f3f3f;--muted:#7c7c7c;--line:#e7e7e9;--bg:#ffffff;--bg2:#f7f7f8;--radius:12px}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,sans-serif;color:var(--body);background:var(--bg);line-height:1.65;font-size:17px}
h1,h2,h3,h4{color:var(--ink);line-height:1.2;margin:0 0 .5em}
h1{font-size:2.6rem;font-weight:800;letter-spacing:-.02em}h2{font-size:2rem;font-weight:700;letter-spacing:-.01em}h3{font-size:1.25rem;font-weight:700}
a{color:var(--red);text-decoration:none}a:hover{color:var(--red-d)}
p{margin:0 0 1rem}img{max-width:100%}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.btn{display:inline-block;background:var(--red);color:#fff;padding:.8rem 1.6rem;border-radius:8px;font-weight:600;transition:.15s}
.btn:hover{background:var(--red-d);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.6);color:#fff}.btn-ghost:hover{background:rgba(255,255,255,.14);color:#fff}
/* topbar */
.topbar{background:var(--ink);color:#d8d8d8;font-size:.85rem}
.topbar-in{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar-contacts{display:flex;gap:1.4rem}.topbar-contacts a{color:#d8d8d8}.topbar-contacts a:hover{color:#fff}
.topbar-lang a,.topbar-lang span{padding:.15rem .5rem;font-weight:600}.topbar-lang a{color:#b3b3b3}.topbar-lang span{color:#fff;background:var(--red);border-radius:4px}
/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
.header-in{display:flex;align-items:center;justify-content:space-between;height:84px}
.logo{display:flex;align-items:center;gap:.8rem;color:var(--ink)}
.logo-img{height:56px;width:auto;display:block}
.logo-txt{font-size:.72rem;color:var(--muted);letter-spacing:.02em;max-width:120px;line-height:1.2}
.nav{display:flex;gap:1.7rem;align-items:center}
.nav a{color:var(--body);font-weight:500}.nav a:hover{color:var(--red)}
.navtog,.navbtn{display:none}
/* hero */
.hero{position:relative;background:linear-gradient(120deg,var(--red-dd) 0%,var(--red) 60%,var(--red-d) 100%);color:#fff;overflow:hidden}
.hero:after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:44px 44px;opacity:.6}
.hero-in{position:relative;z-index:1;padding:5.5rem 0 5rem;max-width:770px}
.hero h1{color:#fff;margin-bottom:.4rem}
.hero .kicker{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:700;color:#ffd2d2;margin-bottom:1rem}
.hero p{color:#fdeaea;font-size:1.15rem;max-width:640px}
.hero-cta{margin-top:1.8rem;display:flex;gap:.9rem;flex-wrap:wrap}
/* sections */
.section{padding:4.5rem 0}.section.alt{background:var(--bg2)}
.section-head{max-width:740px;margin:0 auto 2.8rem;text-align:center}
.section-head .kicker,.kicker{text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:700;color:var(--red);margin-bottom:.6rem}
.lead{font-size:1.15rem;color:var(--body)}
/* cards */
.grid{display:grid;gap:1.4rem}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;transition:.18s}
.card:hover{box-shadow:0 12px 30px rgba(193,18,31,.1);transform:translateY(-3px);border-color:#f0c9cc}
.card .ico{width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--red),var(--red-dd));display:grid;place-items:center;margin-bottom:1rem;font-size:1.4rem}
.card h3{margin-bottom:.4rem}.card p{color:var(--body);margin:0;font-size:.98rem}
/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat b{display:block;font-size:2.2rem;color:var(--red);font-weight:800}.stat span{color:var(--muted);font-size:.92rem}
/* prose */
.prose{max-width:820px;margin:0 auto}.prose h2{margin-top:1.7rem}.prose ul{padding-left:1.2rem}.prose li{margin:.4rem 0}
.callout{background:#fdf3f3;border-left:4px solid var(--red);border-radius:8px;padding:1.2rem 1.5rem;margin:1.6rem 0}
/* reference / partner lists */
.reflist{list-style:none;padding:0;margin:1rem 0;display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.reflist li{padding:.6rem .9rem;background:var(--bg2);border-radius:8px;border-left:3px solid var(--red);font-size:.96rem}
.partners{display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center;margin:1.2rem 0}
.partners img{height:56px;width:auto;filter:grayscale(.2)}
.licence-img{max-width:340px;border:1px solid var(--line);border-radius:10px;margin-top:.6rem}
/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem}
.contact-row{display:flex;gap:1rem;padding:.9rem 0;border-bottom:1px solid var(--line)}.contact-row:last-child{border:0}
.contact-row .k{font-weight:600;color:var(--ink);min-width:130px}
.map-embed{border:0;width:100%;height:100%;min-height:380px;border-radius:var(--radius)}
/* cta band */
.cta-band{background:linear-gradient(120deg,var(--red-dd),var(--red-d));color:#fff;border-radius:16px;padding:3rem;text-align:center}
.cta-band h2{color:#fff}.cta-band p{color:#fdeaea}
/* footer */
.site-footer{background:var(--ink);color:#b8b8b8;padding-top:3rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:2rem;padding-bottom:2.5rem}
.footer-logo{height:52px;width:auto;background:#fff;padding:6px 10px;border-radius:8px}
.footer-brand{margin-bottom:.9rem}
.site-footer h4{color:#fff;font-size:.95rem;margin-bottom:.7rem}.site-footer .muted{color:#9a9a9a;font-size:.92rem}
.site-footer a{color:#e0a3a7}.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.2rem 0;font-size:.85rem;color:#8a8a8a}
@media(max-width:860px){
 h1{font-size:2rem}h2{font-size:1.6rem}
 .grid-3,.grid-2,.stats,.contact-grid,.footer-grid,.reflist{grid-template-columns:1fr}
 .stats{grid-template-columns:repeat(2,1fr)}
 .logo-txt{display:none}
 .nav{position:fixed;inset:84px 0 auto 0;background:#fff;flex-direction:column;padding:1rem 24px;gap:0;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:.25s;box-shadow:0 12px 24px rgba(0,0,0,.08)}
 .nav a{padding:.8rem 0;border-bottom:1px solid var(--line)}
 .navtog:checked~.nav{transform:translateY(0)}
 .navbtn{display:block;width:26px;height:20px;position:relative;cursor:pointer}
 .navbtn span,.navbtn span:before,.navbtn span:after{content:"";position:absolute;left:0;width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.2s}
 .navbtn span{top:9px}.navbtn span:before{top:-8px}.navbtn span:after{top:8px}
 .topbar-contacts{gap:.8rem;font-size:.78rem}.topbar-contacts a:nth-child(2){display:none}
 .cta-band{padding:2rem 1.2rem}
}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:1.4rem 0}
.gal-item{display:block;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;transition:.15s;color:var(--body)}
.gal-item:hover{box-shadow:0 10px 24px rgba(193,18,31,.14);transform:translateY(-3px);color:var(--red)}
.gal-item img{width:100%;height:210px;object-fit:cover;object-position:top center;display:block;background:#f0f0f0}
.gal-item span{display:block;padding:.55rem .7rem;font-size:.8rem;font-weight:600}
.logo-strip{display:flex;flex-wrap:wrap;gap:2.4rem;align-items:center;justify-content:center;margin-top:1.2rem}
.logo-strip img{height:62px;width:auto;filter:grayscale(.15);transition:.15s}.logo-strip img:hover{filter:none}
.card-link{color:var(--red);font-weight:600;font-size:.9rem;display:inline-block;margin-top:.7rem}
@media(max-width:860px){.gallery{grid-template-columns:1fr 1fr}}
/* mobile edge-padding fix: co-classes (.content/.hero-in/etc) redeclare the
   padding shorthand and wipe .wrap's horizontal padding; re-assert it with
   higher specificity + longhand so vertical padding is preserved. */
.wrap.wrap{padding-left:24px;padding-right:24px}
@media(max-width:600px){.wrap.wrap{padding-left:18px;padding-right:18px}}