:root{
	--rato-home-blue:#0b6ec2;
	--rato-home-dark:#1f232b;
	--rato-home-yellow:rgba(215,170,18,.88);
}

.rato-home-hero{position:relative}

.rato-home-slider{position:relative;overflow:hidden;background:#000}
.rato-home-track{position:relative;height:clamp(630px,calc(100vh - 120px),860px)}
.rato-home-slide{
	position:absolute;
	inset:0;
	background-size:cover;
	background-position:center center;
	opacity:0;
	transform:scale(1.01);
	transition:opacity 420ms ease, transform 520ms ease;
}
.rato-home-slide.is-active{opacity:1;transform:scale(1)}
.rato-home-slide-img{display:none}

.rato-home-slide-overlay{
	position:absolute;
	inset:0;
	display:flex;
	align-items:center;
	justify-content:flex-end;
	padding:0 26px;
}
.rato-home-slide-card{
	width:min(420px,42vw);
	background:var(--rato-home-yellow);
	color:#101318;
	padding:22px 22px 18px;
}
.rato-home-slide-kicker{
	font-size:26px;
	font-weight:800;
	letter-spacing:1px;
	text-transform:uppercase;
	line-height:1.05;
}
.rato-home-slide-title{
	margin-top:6px;
	font-size:18px;
	font-weight:800;
	letter-spacing:.6px;
	text-transform:uppercase;
}
.rato-home-slide-bullets{
	margin:14px 0 0;
	padding:0 0 0 18px;
	font-size:12px;
	line-height:1.7;
	font-weight:600;
}
.rato-home-slide-bullets li{margin:4px 0}

.rato-home-arrow{
	position:absolute;
	top:50%;
	transform:translateY(-50%);
	width:46px;
	height:46px;
	border:0;
	background:rgba(0,0,0,.55);
	color:#fff;
	display:flex;
	align-items:center;
	justify-content:center;
	cursor:pointer;
	z-index:2;
}
.rato-home-prev{left:14px}
.rato-home-next{right:74px}
.rato-home-arrow:hover{background:rgba(0,0,0,.72)}

.rato-home-dots{
	position:absolute;
	left:50%;
	bottom:12px;
	transform:translateX(-50%);
	display:flex;
	gap:10px;
	z-index:2;
}
.rato-home-dot{
	width:9px;
	height:9px;
	border-radius:999px;
	border:0;
	background:rgba(255,255,255,.7);
	cursor:pointer;
}
.rato-home-dot.is-active{background:var(--rato-home-blue)}

.rato-home-float-email{
	position:absolute;
	right:0;
	top:50%;
	transform:translateY(-50%);
	background:#fff;
	color:#1b1f24;
	text-decoration:none;
	display:flex;
	flex-direction:column;
	align-items:center;
	gap:6px;
	padding:8px 8px 6px;
	border:1px solid rgba(0,0,0,.15);
	z-index:3;
}
.rato-home-float-ic{color:#f39c12;display:flex}
.rato-home-float-text{font-size:11px;font-weight:700}

.rato-home-panels{background:#fff}
.rato-home-panels-grid{
	display:grid;
	grid-template-columns:1fr 1fr 1fr;
	min-height:260px;
}
.rato-home-panel{padding:0;background:transparent;color:#444}
.rato-home-panel-inner{
	padding:44px 48px 40px;
	max-width:520px;
	display:flex;
	align-items:flex-start;
	gap:16px;
}
.rato-home-panel-icon{width:64px;height:64px;object-fit:contain;display:block;margin:0;flex:0 0 64px}
.rato-home-panel-content{min-width:0}
.rato-home-panel-title{margin:0;font-size:20px;font-weight:700;color:#222}
.rato-home-panel-desc{margin-top:12px;font-size:12px;line-height:1.8;max-width:420px}
.rato-home-panel-link{
	margin-top:18px;
	display:inline-flex;
	align-items:center;
	gap:10px;
	text-decoration:none;
	font-size:12px;
	font-weight:700;
	letter-spacing:.2px;
	color:inherit;
	opacity:.95;
}
.rato-home-panel-link:hover{opacity:1}
.rato-home-panel-link-ic{display:flex}

.rato-home-about-cards{background:#fff;padding:26px 0 10px}
.rato-home-about-cards .rato-container{max-width:1500px;padding:0 18px}

.rato-hot-products{background:#fff;padding:44px 0 54px}
.rato-hot-products .rato-container{max-width:1200px;margin:0 auto;padding:0 18px}
.rato-hot-head{text-align:center;margin:0 0 22px}
.rato-hot-kicker{font-size:12px;letter-spacing:.2px;color:#6c7177}
.rato-hot-title{margin:8px 0 0;font-size:24px;letter-spacing:.6px;font-weight:800;color:#222}

.rato-hot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.rato-hot-card{background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.04);overflow:hidden}
.rato-hot-card-link{position:relative;display:block;color:inherit;text-decoration:none;height:100%}
.rato-hot-card-media{background:#f7f7f7;aspect-ratio:4/3;overflow:hidden}
.rato-hot-card-media img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1);transition:transform 360ms ease}
.rato-hot-card-body{padding:14px 14px 54px}
.rato-hot-card-name{font-size:12px;font-weight:800;letter-spacing:.2px;color:#222;text-transform:uppercase}
.rato-hot-card-desc{margin-top:8px;font-size:11px;line-height:1.6;color:#7a7f86;min-height:34px}
.rato-hot-card-cta{
	position:absolute;
	left:0;
	right:0;
	bottom:0;
	height:44px;
	background:var(--rato-home-blue);
	color:#fff;
	font-size:12px;
	font-weight:800;
	display:flex;
	align-items:center;
	justify-content:center;
	letter-spacing:.2px;
	transform:translateY(100%);
	opacity:0;
	transition:transform 260ms ease, opacity 260ms ease;
}
.rato-hot-card-link:hover .rato-hot-card-cta{transform:translateY(0);opacity:1}
.rato-hot-card-link:hover .rato-hot-card-media img{transform:scale(1.03)}

.rato-hot-bottom{margin-top:26px;display:flex;justify-content:center}
.rato-hot-bottom-btn{
	background:#1f232b;
	color:#fff;
	text-decoration:none;
	font-size:12px;
	font-weight:800;
	letter-spacing:.2px;
	padding:10px 28px;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	min-width:160px;
}
.rato-hot-bottom-btn:hover{background:#111418;color:#fff}

.rato-company-adv{background:#fff;padding:56px 0 64px}
.rato-company-adv .rato-container{max-width:1200px;margin:0 auto;padding:0 18px}
.rato-adv-head{text-align:center;margin:0 0 26px}
.rato-adv-kicker{font-size:12px;letter-spacing:.2px;color:#6c7177}
.rato-adv-title{margin:8px 0 0;font-size:24px;letter-spacing:.6px;font-weight:800;color:#222}

.rato-adv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:42px 60px}
.rato-adv-item{display:block}
.rato-adv-item-inner{
	height:100%;
	text-align:center;
	padding:18px 18px 22px;
	border-radius:2px;
	transition:box-shadow 240ms ease, transform 240ms ease, background-color 240ms ease;
}
.rato-adv-item-inner:hover{
	background:#fff;
	box-shadow:0 10px 26px rgba(0,0,0,.08);
	transform:translateY(-2px);
}
.rato-adv-icon{display:flex;align-items:center;justify-content:center;height:56px}
.rato-adv-icon img{width:44px;height:44px;object-fit:contain;display:block}
.rato-adv-name{margin-top:10px;font-size:12px;font-weight:800;color:#222}
.rato-adv-desc{margin-top:10px;font-size:11px;line-height:1.6;color:#7a7f86;max-width:320px;margin-left:auto;margin-right:auto}

.rato-home-visit{background:#fff;padding:40px 0 28px}
.rato-home-visit .rato-container{max-width:1200px;margin:0 auto;padding:0 18px}
.rato-home-visit-head{text-align:center;margin:0 0 18px}
.rato-home-visit-title{
	margin:0;
	font-size:34px;
	font-weight:900;
	letter-spacing:.6px;
	color:#1b1f24;
	text-transform:uppercase;
	line-height:1.12;
}
.rato-home-visit-title::after{
	content:"";
	display:block;
	width:56px;
	height:3px;
	background:var(--rato-home-blue);
	margin:12px auto 0;
}

.rato-visit-slider{position:relative}
.rato-visit-viewport{overflow:hidden}
.rato-visit-track{display:flex;transition:transform 420ms ease;will-change:transform}
.rato-visit-page{flex:0 0 100%;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.rato-visit-item{background:#f2f2f2;overflow:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.08) inset}
.rato-visit-item img{width:100%;height:260px;object-fit:cover;display:block}

.rato-visit-arrow{
	position:absolute;
	top:50%;
	transform:translateY(-50%);
	width:38px;
	height:38px;
	border:0;
	background:rgba(0,0,0,.36);
	color:#fff;
	font-size:28px;
	line-height:1;
	display:flex;
	align-items:center;
	justify-content:center;
	cursor:pointer;
	z-index:2;
}
.rato-visit-prev{left:8px}
.rato-visit-next{right:8px}
.rato-visit-arrow:hover{background:rgba(0,0,0,.52)}

.rato-visit-dots{display:flex;justify-content:center;gap:10px;margin-top:10px}
.rato-visit-dot{
	width:6px;
	height:6px;
	border-radius:999px;
	border:0;
	background:rgba(0,0,0,.22);
	cursor:pointer;
}
.rato-visit-dot.is-active{background:rgba(0,0,0,.62)}

.rato-factory{background:#fff;padding:44px 0 46px}
.rato-factory .rato-container{max-width:1200px;margin:0 auto;padding:0 18px}
.rato-factory-head{text-align:center;margin:0 0 18px}
.rato-factory-title{
	margin:0;
	font-size:34px;
	font-weight:900;
	letter-spacing:.6px;
	color:#1b1f24;
	text-transform:uppercase;
	line-height:1.12;
}
.rato-factory-title::after{
	content:"";
	display:block;
	width:56px;
	height:3px;
	background:var(--rato-home-blue);
	margin:12px auto 0;
}
.rato-factory-grid{
	display:grid;
	grid-template-columns:repeat(3,minmax(0,1fr));
	gap:12px;
}
.rato-factory-item{background:#f2f2f2;overflow:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.08) inset}
.rato-factory-item img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}

.rato-home-services{
	position:relative;
	background:#fff;
	padding:44px 0 40px;
	overflow:hidden;
}
.rato-home-services .rato-container{position:relative;max-width:1200px;margin:0 auto;padding:0 18px}
.rato-home-services-top{
	display:flex;
	align-items:center;
	justify-content:center;
	gap:26px;
	font-size:32px;
	font-weight:800;
	letter-spacing:.2px;
	color:#2b2f35;
	line-height:1.1;
}
.rato-home-services-top::before,
.rato-home-services-top::after{
	content:"";
	width:160px;
	height:2px;
	background:rgba(0,0,0,.22);
}
.rato-home-services-grid{
	position:relative;
	margin-top:26px;
	display:grid;
	grid-template-columns:repeat(6,1fr);
	column-gap:34px;
}
.rato-home-services-grid::before{
	content:"";
	position:absolute;
	left:0;
	right:0;
	top:148px;
	border-top:1px dotted rgba(0,0,0,.28);
}
.rato-home-service{display:flex;flex-direction:column;align-items:center;text-align:center}
.rato-home-service-media{
	width:126px;
	height:126px;
	border-radius:999px;
	overflow:hidden;
	background:rgba(255,255,255,.9);
	box-shadow:0 10px 24px rgba(0,0,0,.14);
}
.rato-home-service-icon{width:100%;height:100%;object-fit:cover;display:block}
.rato-home-service-dot{
	margin-top:16px;
	width:12px;
	height:12px;
	border-radius:999px;
	background:#c62828;
	box-shadow:0 0 0 3px rgba(255,255,255,.94), 0 2px 10px rgba(0,0,0,.18);
}
.rato-home-service-text{
	margin-top:12px;
	font-size:13px;
	font-weight:600;
	color:#2b2f35;
	line-height:1.3;
	white-space:normal;
	max-width:150px;
}

@media (max-width: 1024px){
	.rato-home-track{height:clamp(540px,calc(100vh - 120px),720px)}
	.rato-home-slide-card{width:min(420px,56vw)}
	.rato-home-panel-inner{padding:34px 28px}
	.rato-hot-grid{grid-template-columns:repeat(3,1fr)}
	.rato-adv-grid{grid-template-columns:repeat(3,1fr);gap:34px 36px}
	.rato-home-visit-title{font-size:30px}
	.rato-visit-item img{height:220px}
	.rato-factory-title{font-size:30px}
	.rato-factory-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
	.rato-home-services-top{font-size:28px}
	.rato-home-services-top::before,
	.rato-home-services-top::after{width:120px}
	.rato-home-services-grid{grid-template-columns:repeat(3,1fr);row-gap:26px}
	.rato-home-services-grid::before{display:none}
}

@media (max-width: 780px){
	.rato-home-track{height:clamp(420px,68vh,560px)}
	.rato-home-slide-overlay{justify-content:center;padding:0 14px}
	.rato-home-slide-card{width:min(520px,92vw)}
	.rato-home-panels-grid{grid-template-columns:1fr}
	.rato-home-panel-inner{max-width:none}
	.rato-home-float-email{display:none}
	.rato-hot-products{padding:34px 0 44px}
	.rato-hot-grid{grid-template-columns:repeat(2,1fr);gap:14px}
	.rato-hot-card-body{padding:12px 12px 52px}
	.rato-company-adv{padding:42px 0 52px}
	.rato-adv-grid{grid-template-columns:1fr;gap:18px}
	.rato-adv-item-inner{box-shadow:0 0 0 1px rgba(0,0,0,.05)}
	.rato-home-visit{padding:32px 0 22px}
	.rato-home-visit-title{font-size:22px}
	.rato-visit-page{grid-template-columns:1fr}
	.rato-visit-item img{height:200px}
	.rato-visit-prev{left:6px}
	.rato-visit-next{right:6px}
	.rato-factory{padding:34px 0 38px}
	.rato-factory-title{font-size:22px}
	.rato-factory-grid{grid-template-columns:1fr;gap:10px}
	.rato-home-services{padding:34px 0 32px}
	.rato-home-services-top{font-size:22px;gap:16px}
	.rato-home-services-top::before,
	.rato-home-services-top::after{width:60px}
	.rato-home-services-grid{grid-template-columns:repeat(2,1fr);gap:22px 16px}
	.rato-home-service-media{width:104px;height:104px}
	.rato-home-service-text{font-size:12px}
}

.rato-about-hero{
	position:relative;
	height:260px;
	background:#e9eef5;
	background-size:cover;
	background-position:center;
	overflow:hidden;
}
.rato-about-hero-img{display:none}

.rato-about-intro{
	position:relative;
	background:#fff;
	padding:54px 0 56px;
	overflow:hidden;
}
.rato-about-intro::before{
	content:"";
	position:absolute;
	inset:-140px -140px -140px -140px;
	background:
		radial-gradient(circle at 12% 58%, rgba(0,0,0,.12) 0, rgba(0,0,0,0) 44%),
		radial-gradient(circle at 84% 38%, rgba(0,0,0,.10) 0, rgba(0,0,0,0) 46%),
		radial-gradient(circle at 82% 20%, rgba(0,0,0,.06) 0, rgba(0,0,0,0) 38%),
		radial-gradient(circle, rgba(0,0,0,.12) 1px, rgba(0,0,0,0) 1.6px),
		linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,1));
	background-size:auto, auto, auto, 16px 16px, auto;
	background-position:center, center, center, 74% 26%, center;
	opacity:.32;
	pointer-events:none;
}
.rato-about-intro::after{
	content:"";
	position:absolute;
	left:50%;
	top:8px;
	transform:translateX(-50%);
	width:6px;
	height:6px;
	border-radius:999px;
	background:#c62828;
	box-shadow:0 0 0 6px rgba(198,40,40,.12);
	pointer-events:none;
}
.rato-about-intro-inner{
	position:relative;
	display:grid;
	grid-template-columns:1.18fr .82fr;
	gap:34px;
	align-items:flex-start;
}

.rato-about-video{position:relative}
.rato-about-video-embed,
.rato-about-video-placeholder{
	aspect-ratio:16/9;
	height:auto;
	background:transparent;
	border-radius:12px;
	overflow:hidden;
	box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.rato-about-video-embed{position:relative}
.rato-about-video-embed iframe,
.rato-about-video-embed video{
	position:absolute;
	inset:0;
	width:100%;
	height:100%;
}
.rato-about-video-embed video{object-fit:cover;background:transparent}

.rato-about-content{position:relative;z-index:1}

.rato-about-title{
	margin:0;
	text-align:left;
	font-size:30px;
	font-weight:900;
	letter-spacing:.3px;
	color:#2b2f35;
}
.rato-about-text{
	margin-top:12px;
	font-size:14px;
	line-height:1.85;
	color:#3f4650;
}
.rato-about-text p{margin:0 0 10px}
.rato-about-text p:last-child{margin-bottom:0}

.rato-about-stats{
	margin-top:22px;
	display:grid;
	grid-template-columns:repeat(3,minmax(0,1fr));
	gap:18px 26px;
}
.rato-about-stat{min-width:0}
.rato-about-stat-value{
	display:flex;
	align-items:baseline;
	font-size:20px;
	font-weight:900;
	color:#c62828;
	letter-spacing:.2px;
}
.rato-about-stat-value::before{
	content:"–";
	margin-right:6px;
}
.rato-about-stat-label{
	margin-top:4px;
	font-size:12px;
	color:#7a828a;
}

.rato-about-highlights{background:#fff;padding:0 0 44px}
.rato-about-highlights-grid{
	display:grid;
	grid-template-columns:repeat(4,minmax(0,1fr));
	background:#fff;
	border:1px solid #e6edf6;
	border-radius:12px;
	overflow:hidden;
	box-shadow:0 10px 26px rgba(0,0,0,.06);
}
.rato-about-highlight{
	display:flex;
	align-items:center;
	justify-content:center;
	gap:12px;
	padding:16px 18px;
	min-height:78px;
	border-right:1px solid #e6edf6;
}
.rato-about-highlight:last-child{border-right:0}
.rato-about-highlight-icon{width:38px;height:38px;object-fit:contain;display:block;flex:0 0 auto}
.rato-about-highlight-text{min-width:0;display:flex;flex-direction:column;align-items:flex-start}
.rato-about-highlight-title{font-size:18px;font-weight:900;line-height:1.05;color:#1b1f24;letter-spacing:.2px}
.rato-about-highlight-desc{margin-top:4px;font-size:12px;font-weight:700;line-height:1.2;color:#5f6770}

.rato-about-services{background:#fff}
.rato-about-services .rato-container{z-index:1}
.rato-about-services .rato-home-services-grid{row-gap:22px}
.rato-about-services .rato-home-service-text{font-size:14px;font-weight:700;max-width:180px}
.rato-about-services::before{
	content:"";
	position:absolute;
	inset:0;
	background:
		radial-gradient(circle at 14% 42%, rgba(0,0,0,.08) 0, rgba(0,0,0,0) 48%),
		radial-gradient(circle at 82% 62%, rgba(0,0,0,.07) 0, rgba(0,0,0,0) 48%),
		radial-gradient(circle, rgba(0,0,0,.12) 1px, rgba(0,0,0,0) 1.7px),
		linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.96));
	background-size:auto, auto, 16px 16px, auto;
	background-position:center, center, 50% 14%, center;
	opacity:.38;
	pointer-events:none;
}

@media (max-width: 1024px){
	.rato-about-hero{height:220px}
	.rato-about-intro{padding:44px 0 48px}
	.rato-about-intro-inner{grid-template-columns:1fr;gap:22px}
	.rato-about-video-embed,
	.rato-about-video-placeholder{border-radius:12px}
	.rato-about-title{font-size:26px;text-align:center}
	.rato-about-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 22px}
	.rato-about-highlights{padding:0 0 36px}
	.rato-about-highlights-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
	.rato-about-highlight:nth-child(2n){border-right:0}
	.rato-about-highlight:nth-child(n+3){border-top:1px solid #e6edf6}
}

@media (max-width: 780px){
	.rato-about-hero{height:180px}
	.rato-about-intro{padding:34px 0 40px}
	.rato-about-video-embed,
	.rato-about-video-placeholder{border-radius:12px}
	.rato-about-title{font-size:24px}
	.rato-about-text{font-size:13px}
	.rato-about-stats{grid-template-columns:1fr}
	.rato-about-highlights{padding:0 0 28px}
	.rato-about-highlight{justify-content:flex-start;padding:14px 14px}
	.rato-about-highlight-icon{width:32px;height:32px}
	.rato-about-highlight-title{font-size:16px}
}
