/*
Theme Name: Massruum
Theme URI: https://massruum.ee
Author: Tanel Teemusk
Author URI: https://massruum.ee
Description: Editorial Studio — a lean, fast, fully block-based (FSE) theme for the Massruum WordPress & WooCommerce studio. Space Grotesk + Inter Tight, light/paper + navy bands, sparing orange. Bilingual ET/EN. No page builder, no build step.
Version: 1.0.4
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: massruum
*/

/* ==========================================================================
   Tokens — shorthands over the theme.json presets
   ========================================================================== */
:root {
	--ms-ink: var(--wp--preset--color--ink);
	--ms-ink-soft: var(--wp--preset--color--ink-soft);
	--ms-muted: var(--wp--preset--color--muted);
	--ms-navy: var(--wp--preset--color--navy);
	--ms-orange: var(--wp--preset--color--orange);
	--ms-coral: var(--wp--preset--color--coral);
	--ms-teal: var(--wp--preset--color--teal);
	--ms-cream: var(--wp--preset--color--cream);
	--ms-paper: var(--wp--preset--color--paper);
	--ms-line: var(--wp--preset--color--line);
	--ms-grotesk: var(--wp--preset--font-family--grotesk);
	--ms-inter: var(--wp--preset--font-family--inter);
	--ms-gutter: 64px;
}

html { -webkit-text-size-adjust: 100%; }
body { font-family: var(--ms-inter); color: var(--ms-ink); background: var(--ms-paper); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

* { text-underline-offset: 2px; }

/* Sharp corners everywhere (radius 0 design language) */
.wp-block-button__link, .wp-block-image img, input, textarea, select, button { border-radius: 0 !important; }

/* ==========================================================================
   Eyebrow / kicker label — Space Grotesk, uppercase, orange
   ========================================================================== */
.ms-eyebrow {
	font-family: var(--ms-grotesk);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ms-orange);
	margin: 0 0 18px;
}
.ms-eyebrow.is-muted { color: var(--ms-muted); }

/* Lede / section intro paragraph */
.ms-lede { font-size: 19px; line-height: 1.6; color: var(--ms-ink-soft); }
/* Width-limited blocks must stay LEFT — WP's constrained layout otherwise
   auto-centers any child narrower than the content width (margin-inline:auto). */
.ms-measure { max-width: 600px; margin-left: 0 !important; margin-right: auto !important; }
.ms-measure-wide { max-width: 720px; margin-left: 0 !important; margin-right: auto !important; }

/* ==========================================================================
   Header
   ========================================================================== */
.ms-header { position: sticky; top: 0; z-index: 100; background: var(--ms-paper); }
.ms-brand .wp-block-site-title { font-family: var(--ms-grotesk); font-weight: 600; }
.ms-badge img { display: block; width: 34px; height: 34px; border-radius: 0 !important; }
.ms-header .wp-block-navigation { gap: 30px; }
.ms-header .wp-block-navigation a { color: var(--ms-ink-soft); font-weight: 500; }
.ms-header .wp-block-navigation a:hover { color: var(--ms-ink); text-decoration: none; }
.ms-header .current-menu-item a, .ms-header .current_page_item a { color: var(--ms-ink); }

.ms-lang { font-family: var(--ms-grotesk); font-size: 13px; font-weight: 500; letter-spacing: 0.04em; color: var(--ms-muted); display: flex; gap: 7px; align-items: center; }
.ms-lang a { color: var(--ms-muted); text-decoration: none; }
.ms-lang a:hover { color: var(--ms-ink); text-decoration: none; }
.ms-lang .current-lang, .ms-lang .lang-item.current-lang a { color: var(--ms-ink); font-weight: 600; }
.ms-lang ul { list-style: none; margin: 0; padding: 0; display: flex; gap: 7px; }
.ms-lang li { margin: 0; }
.ms-lang li + li::before { content: "/"; color: var(--ms-line); margin-right: 7px; }

/* Header CTA button */
.ms-header .wp-block-button__link { padding: 11px 20px; font-size: 14px; }

/* ==========================================================================
   Full-bleed band helper — sections use align:full + a bg color
   ========================================================================== */
.ms-band { padding-top: 88px; padding-bottom: 88px; }
.ms-band-tight { padding-top: 56px; padding-bottom: 56px; }

/* Full-bleed sections stack flush — no white gaps between them (each band
   carries its own vertical padding). Also kills the root-level gap between
   header / main / footer (WP's .wp-site-blocks block-gap). */
.wp-block-post-content > .alignfull { margin-top: 0 !important; margin-bottom: 0 !important; }
.wp-site-blocks > * { margin-block-start: 0 !important; margin-block-end: 0 !important; }
main.wp-block-group { margin-top: 0; margin-bottom: 0; }

/* Full-bleed bands center a fixed 1320 content column via padding, and ALL
   direct children share that one left edge — so eyebrow, heading, ledes and
   grids line up at any viewport width (matches the constrained header column).
   Replaces WP's per-child auto-centering which split narrow blocks off-axis. */
.alignfull.ms-band,
.alignfull.ms-band-tight {
	padding-left: max(var(--ms-gutter), calc((100% - 1320px) / 2 + var(--ms-gutter))) !important;
	padding-right: max(var(--ms-gutter), calc((100% - 1320px) / 2 + var(--ms-gutter))) !important;
}
.alignfull.ms-band > *,
.alignfull.ms-band-tight > * { margin-left: 0 !important; margin-right: 0 !important; max-width: 100%; }
.alignfull.ms-band > .ms-measure { max-width: 600px; }
.alignfull.ms-band > .ms-measure-wide { max-width: 720px; }

/* ==========================================================================
   Home hero
   ========================================================================== */
.ms-hero { padding-top: 70px; padding-bottom: 84px; }
.ms-hero h1 { font-size: 46px; line-height: 1.06; letter-spacing: -0.02em; }
.ms-hero .ms-hero-sub { font-size: 18px; color: var(--ms-ink-soft); max-width: 440px; }
.ms-hero-actions .wp-block-button.is-style-outline .wp-block-button__link { background: transparent; color: var(--ms-ink); border: 1px solid var(--ms-line); }
.ms-hero-actions .wp-block-button.is-style-outline .wp-block-button__link:hover { border-color: var(--ms-ink); background: transparent; }

/* Browser-chrome frame around screenshots */
.ms-browser { border: 1px solid var(--ms-line); background: var(--ms-paper); box-shadow: 0 30px 60px -28px rgba(14,22,51,0.28); }
.ms-browser .ms-browser-bar { display: flex; align-items: center; gap: 7px; padding: 11px 14px; border-bottom: 1px solid var(--ms-line); background: #faf8f3; }
.ms-browser .ms-dot { width: 11px; height: 11px; border-radius: 50% !important; display: inline-block; }
.ms-browser .ms-dot.r { background: #ff5f57; }
.ms-browser .ms-dot.y { background: #febc2e; }
.ms-browser .ms-dot.g { background: #28c840; }
.ms-browser .ms-browser-url { margin-left: 10px; font-family: var(--ms-grotesk); font-size: 12px; color: var(--ms-muted); }
.ms-browser figure, .ms-browser .wp-block-image { margin: 0; }
.ms-browser img { display: block; width: 100%; height: auto; border-radius: 0 !important; }

/* ==========================================================================
   Trusted-by logos strip
   ========================================================================== */
.ms-logos { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 28px 40px; }
.ms-logos .ms-logos-label { font-family: var(--ms-grotesk); font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ms-muted); }
.ms-logos .ms-logos-names { display: flex; flex-wrap: wrap; gap: 32px; }
.ms-logos .ms-logos-names p { margin: 0; font-family: var(--ms-grotesk); font-weight: 500; font-size: 15px; color: var(--ms-ink-soft); }

/* ==========================================================================
   Numbered / hairline columns (services, "how we work", process)
   ========================================================================== */
.ms-rule-cols { border-top: 0; }
.ms-rule-item { border-top: 1.5px solid var(--ms-orange); padding-top: 18px; }
.ms-rule-item.is-cool { border-top-color: var(--ms-line-cool, #E5E7EB); }
.ms-rule-num { font-family: var(--ms-grotesk); font-size: 12px; font-weight: 500; letter-spacing: 0.06em; color: var(--ms-muted); margin: 0 0 14px; }
.ms-rule-item h3 { font-size: 19px; margin: 0 0 8px; }
.ms-rule-item p { margin: 0; font-size: 14px; line-height: 1.55; color: var(--ms-ink-soft); }
/* dark band variant */
.ms-on-navy .ms-rule-item p, .ms-on-navy p { color: rgba(255,255,255,0.72); }
.ms-on-navy .ms-rule-item h3, .ms-on-navy h2, .ms-on-navy h3 { color: #fff; }
.ms-on-navy .ms-rule-num { color: rgba(255,255,255,0.55); }

/* ==========================================================================
   Performance section
   ========================================================================== */
.ms-checklist { list-style: none; margin: 0; padding: 0; }
.ms-checklist li { position: relative; padding-left: 30px; margin: 0 0 14px; font-size: 15px; color: var(--ms-ink-soft); }
.ms-checklist li::before { content: ""; position: absolute; left: 0; top: 2px; width: 18px; height: 18px; background: var(--ms-orange); }
.ms-checklist li::after { content: ""; position: absolute; left: 6px; top: 6px; width: 5px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }
.ms-perfcard { border: 1px solid var(--ms-line); background: var(--ms-paper); padding: 26px 28px; box-shadow: 0 24px 50px -30px rgba(14,22,51,0.25); }
.ms-perfcard .ms-perf-label { font-family: var(--ms-grotesk); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ms-muted); margin: 0 0 18px; }
.ms-perfrow { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 14px; font-size: 14px; }
.ms-perfrow .ms-perf-name { color: var(--ms-ink-soft); min-width: 150px; }
.ms-perfrow .ms-track { flex: 1; height: 8px; background: #f0ece2; position: relative; }
.ms-perfrow .ms-fill { position: absolute; left: 0; top: 0; bottom: 0; }
.ms-perfrow .ms-fill.slow { width: 100%; background: var(--ms-coral); }
.ms-perfrow .ms-fill.fast { width: 19%; background: var(--ms-teal); }
.ms-perfrow .ms-perf-val { font-family: var(--ms-grotesk); font-weight: 600; min-width: 42px; text-align: right; }
.ms-perfrow .ms-perf-val.slow { color: var(--ms-coral); }
.ms-perfrow .ms-perf-val.fast { color: var(--ms-teal); }
.ms-perf-foot { display: flex; align-items: center; gap: 12px; margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--ms-line); font-size: 13px; color: var(--ms-muted); }
.ms-perf-badge { font-family: var(--ms-grotesk); font-weight: 600; font-size: 12px; color: var(--ms-teal); border: 1px solid var(--ms-teal); padding: 3px 8px; }

/* ==========================================================================
   Work grid + cards (browser-framed screenshots)
   ========================================================================== */
.ms-workgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.ms-workcard { display: block; text-decoration: none; }
.ms-workcard .ms-shot { display: block; border: 1px solid var(--ms-line); overflow: hidden; aspect-ratio: 16 / 10; background: #f3efe6; }
.ms-workcard .ms-shot img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; border-radius: 0 !important; transition: transform .5s ease; }
.ms-workcard:hover .ms-shot img { transform: scale(1.03); }
.ms-workcard h3 { font-size: 18px; margin: 16px 0 4px; color: var(--ms-ink); }
.ms-workcard p { margin: 0; font-size: 14px; color: var(--ms-muted); }

/* Featured work (Work page) */
.ms-featured { background: var(--ms-cream); }
.ms-tag { display: inline-block; font-family: var(--ms-grotesk); font-size: 12px; font-weight: 500; color: var(--ms-ink-soft); border: 1px solid var(--ms-line); padding: 6px 12px; margin: 0 8px 8px 0; }

/* Filter bar */
.ms-filterbar { display: flex; flex-wrap: wrap; gap: 10px; }
.ms-filter { font-family: var(--ms-grotesk); font-size: 13px; font-weight: 500; padding: 8px 16px; border: 1px solid var(--ms-line); background: var(--ms-paper); color: var(--ms-ink-soft); cursor: pointer; }
.ms-filter.is-active { background: var(--ms-navy); color: #fff; border-color: var(--ms-navy); }
.ms-workcard[hidden] { display: none; }

/* ==========================================================================
   Approach band (navy)
   ========================================================================== */
.ms-on-navy { color: rgba(255,255,255,0.74); }
.ms-on-navy .ms-eyebrow { color: var(--ms-orange); }

/* ==========================================================================
   Testimonials slider
   ========================================================================== */
.ms-quote { position: relative; }
.ms-quote-mark { font-family: var(--ms-grotesk); font-size: 64px; line-height: 0.5; color: var(--ms-orange); height: 30px; }
.ms-quote-track { overflow: hidden; }
.ms-quote-slides { display: flex; transition: transform .5s ease; }
.ms-quote-slide { flex: 0 0 100%; }
.ms-quote-slide blockquote { margin: 0; border: 0; padding: 0; }
.ms-quote-slide .ms-quote-text { font-family: var(--ms-grotesk); font-size: 28px; line-height: 1.32; font-weight: 500; color: var(--ms-ink); max-width: 900px; }
.ms-quote-cite { display: flex; align-items: center; gap: 14px; margin-top: 26px; }
.ms-quote-cite img { width: 44px; height: 44px; border-radius: 50% !important; object-fit: cover; }
.ms-quote-cite .ms-quote-name { font-weight: 600; font-size: 15px; color: var(--ms-ink); }
.ms-quote-cite .ms-quote-role { font-size: 14px; color: var(--ms-muted); }
.ms-quote-nav { display: flex; gap: 8px; }
.ms-quote-arrow { width: 40px; height: 40px; border: 1px solid var(--ms-line); background: var(--ms-paper); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--ms-ink); }
.ms-quote-arrow:hover { border-color: var(--ms-ink); }
.ms-quote-dots { display: flex; gap: 8px; align-items: center; }
.ms-quote-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ms-line); cursor: pointer; padding: 0; border: 0; }
.ms-quote-dot.is-active { background: var(--ms-orange); }

/* ==========================================================================
   Founder strip
   ========================================================================== */
.ms-founder img { width: 100%; height: auto; display: block; box-shadow: 0 30px 60px -34px rgba(14,22,51,0.4); border-radius: 0 !important; }
.ms-stats { display: flex; gap: 48px; flex-wrap: wrap; }
.ms-stat .ms-stat-num { font-family: var(--ms-grotesk); font-size: 30px; font-weight: 600; color: var(--ms-ink); line-height: 1; }
.ms-stat .ms-stat-label { font-size: 13px; color: var(--ms-muted); margin-top: 6px; }

/* ==========================================================================
   CTA band (orange)
   ========================================================================== */
.ms-cta { background: var(--ms-orange); text-align: center; }
.ms-cta h2 { color: #fff; font-size: 34px; }
.ms-cta .wp-block-button__link { background: var(--ms-navy); color: #fff; }
.ms-cta .wp-block-button__link:hover { background: var(--ms-ink); }
.ms-cta .ms-cta-alt { color: rgba(255,255,255,0.9); font-size: 14px; }
.ms-cta .ms-cta-alt a { color: #fff; text-decoration: underline; }

/* ==========================================================================
   Services tabs
   ========================================================================== */
.ms-tabs { display: flex; flex-wrap: wrap; gap: 6px; border-bottom: 1px solid var(--ms-line); }
.ms-tab { font-family: var(--ms-grotesk); font-size: 15px; font-weight: 500; padding: 13px 20px; border: 1px solid transparent; border-bottom: none; background: transparent; color: var(--ms-muted); cursor: pointer; position: relative; bottom: -1px; }
.ms-tab.is-active { background: var(--ms-navy); color: #fff; }
.ms-tabpanel { display: none; }
.ms-tabpanel.is-active { display: block; }
.ms-tabpanel { background: var(--ms-cream); padding: 40px; }
.ms-tabpanel h3 { font-size: 26px; margin: 0 0 16px; font-family: var(--ms-grotesk); font-weight: 600; }
.ms-tabgrid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 48px; align-items: center; }
.ms-tabcol .ms-rule-num { margin-bottom: 12px; color: var(--ms-orange); }
.ms-tabcol .ms-tab-desc { font-size: 16px; line-height: 1.6; color: var(--ms-ink-soft); margin: 0 0 22px; }
.ms-tabgrid .ms-browser img { display: block; width: 100%; height: auto; }
@media (max-width: 781px) {
	.ms-tabpanel { padding: 24px; }
	.ms-tabgrid { grid-template-columns: 1fr; gap: 28px; }
	.ms-tabs { gap: 4px; }
	.ms-tab { padding: 10px 13px; font-size: 13px; }
}

/* ==========================================================================
   Blog
   ========================================================================== */
.ms-blogfeatured { background: var(--ms-cream); }
.ms-blogfeatured .ms-blog-meta { font-family: var(--ms-grotesk); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ms-muted); margin: 0 0 16px; display: flex; align-items: center; gap: 10px; }
.ms-blogfeatured .ms-blog-meta .ms-dot-orange { width: 7px; height: 7px; border-radius: 50%; background: var(--ms-orange); display: inline-block; }
.ms-bloglist .ms-blogrow { display: grid; grid-template-columns: 200px 1fr; gap: 30px; padding: 28px 0; border-top: 1px solid var(--ms-line); align-items: start; }
.ms-bloglist .ms-blogrow:last-child { border-bottom: 1px solid var(--ms-line); }
.ms-blogrow .ms-blog-when { font-family: var(--ms-grotesk); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ms-muted); }
.ms-blogrow .ms-blog-cat { font-family: var(--ms-grotesk); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ms-orange); margin-top: 4px; }
.ms-blogrow h3 { font-size: 24px; margin: 0 0 6px; }
.ms-blogrow p { margin: 0; color: var(--ms-ink-soft); font-size: 15px; }

/* ==========================================================================
   Contact
   ========================================================================== */
.ms-form .ms-field { margin-bottom: 22px; }
.ms-form label, .ms-field-label { display: block; font-family: var(--ms-grotesk); font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ms-ink); margin-bottom: 8px; }
.ms-form input, .ms-form textarea { width: 100%; padding: 13px 14px; border: 1px solid var(--ms-line); background: var(--ms-paper); font-family: var(--ms-inter); font-size: 15px; color: var(--ms-ink); }
.ms-form input:focus, .ms-form textarea:focus { outline: none; border-color: var(--ms-ink); }
.ms-form textarea { min-height: 150px; resize: vertical; }
.ms-form button { background: var(--ms-navy); color: #fff; border: 0; padding: 14px 28px; font-family: var(--ms-inter); font-weight: 600; font-size: 14px; cursor: pointer; }
.ms-form button:hover { background: var(--ms-ink); }
.ms-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.ms-contact-info dt { font-family: var(--ms-grotesk); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ms-muted); margin-bottom: 4px; }
.ms-contact-info dd { margin: 0 0 22px; font-size: 18px; color: var(--ms-ink); }
.ms-form-note { font-size: 14px; padding: 12px 14px; margin-bottom: 18px; }
.ms-form-note.ok { background: rgba(20,133,122,0.1); color: var(--ms-teal); border: 1px solid rgba(20,133,122,0.3); }
.ms-form-note.err { background: rgba(255,84,54,0.08); color: var(--ms-coral); border: 1px solid rgba(255,84,54,0.3); }

/* ==========================================================================
   FAQ
   ========================================================================== */
.ms-faq .ms-faq-row { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; padding: 30px 0; border-top: 1px solid var(--ms-line); }
.ms-faq .ms-faq-row:last-child { border-bottom: 1px solid var(--ms-line); }
.ms-faq .ms-faq-q { font-family: var(--ms-grotesk); font-size: 20px; font-weight: 500; color: var(--ms-ink); margin: 0; }
.ms-faq .ms-faq-a { margin: 0; font-size: 15px; line-height: 1.6; color: var(--ms-ink-soft); }

/* ==========================================================================
   Footer
   ========================================================================== */
.ms-footer { background: var(--ms-navy); color: rgba(255,255,255,0.66); }
.ms-footer a { color: rgba(255,255,255,0.72); text-decoration: none; }
.ms-footer a:hover { color: #fff; text-decoration: none; }
.ms-footer .ms-footer-brand .wp-block-site-title, .ms-footer .ms-footer-brand p { color: #fff; }
.ms-footer .ms-footer-badge img { width: 30px; height: 30px; }
.ms-footer .ms-foot-head { font-family: var(--ms-grotesk); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin: 0 0 18px; }
.ms-footer .wp-block-navigation { gap: 12px; }
/* Footer nav links use the core/navigation color (ink-soft) by default — too dark
   on navy. Force light, like the social paragraph links. */
.ms-footer .wp-block-navigation,
.ms-footer .wp-block-navigation a,
.ms-footer .wp-block-navigation .wp-block-navigation-item__content { color: rgba(255,255,255,0.7) !important; }
.ms-footer .wp-block-navigation a:hover,
.ms-footer .wp-block-navigation .wp-block-navigation-item__content:hover { color: #fff !important; }
/* Footer language switcher — both languages clearly visible on navy; the
   current one white + medium weight, the other a softer white. */
.ms-footer .ms-lang a,
.ms-footer .ms-lang span { color: rgba(255,255,255,0.6) !important; font-weight: 500; }
.ms-footer .ms-lang a:hover { color: #fff !important; }
.ms-footer .ms-lang .current-lang,
.ms-footer .ms-lang .current-lang a,
.ms-footer .ms-lang a.current-lang { color: #fff !important; font-weight: 600; }
.ms-footer .ms-lang li + li::before { color: rgba(255,255,255,0.3) !important; }
.ms-footer-cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.ms-footer-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; margin-top: 40px; padding-top: 26px; border-top: 1px solid rgba(255,255,255,0.12); font-size: 13px; color: rgba(255,255,255,0.45); }
.ms-footer-bottom .ms-social { display: flex; gap: 22px; }

/* Inline orange word emphasis */
.r, .ms-em { color: var(--ms-orange); }

/* ==========================================================================
   Single post / page content
   ========================================================================== */
.ms-prose { max-width: 720px; }
.ms-prose p { font-size: 18px; line-height: 1.7; color: var(--ms-ink-soft); }
.ms-prose h2 { margin-top: 1.6em; }
.ms-prose img { border-radius: 0 !important; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1100px) {
	.ms-footer-cols { grid-template-columns: 1fr 1fr; }
	.ms-workgrid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 781px) {
	:root { --ms-gutter: 24px; }
	.wp-block-group { --wp--style--root--padding-left: 24px; --wp--style--root--padding-right: 24px; }
	.ms-band { padding-top: 60px; padding-bottom: 60px; }
	.ms-hero { padding-top: 40px; padding-bottom: 56px; }
	.ms-hero h1 { font-size: 34px; }
	.ms-workgrid { grid-template-columns: 1fr; }
	.ms-rule-cols, .ms-stats { gap: 28px; }
	.ms-form-row { grid-template-columns: 1fr; }
	.ms-faq .ms-faq-row, .ms-bloglist .ms-blogrow { grid-template-columns: 1fr; gap: 10px; }
	.ms-footer-cols { grid-template-columns: 1fr; gap: 32px; }
	.ms-quote-slide .ms-quote-text { font-size: 22px; }
	.ms-cta h2 { font-size: 26px; }
	h1, .has-page-font-size { font-size: 36px !important; }
	h2, .has-section-font-size { font-size: 28px !important; }
}
