@font-face {
    font-family: "Inter";
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url("/assets/fonts/inter-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: "Inter";
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url("/assets/fonts/inter-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
    --white: #ffffff;
    --off-white: #f5f8f8;
    --surface: #fbfcfc;
    --text: #1d2420;
    --muted: #68716c;
    --line: #d4dcda;
    --blue: #003049;
    --blue-bright: #00deff;
    --blue-dark: #003049;
    --dark: #1d2420;
    --container: 1120px;
}

*, *::before, *::after { box-sizing: border-box; }
[hidden] { display: none !important; }
html { overflow-y: scroll; scroll-behavior: smooth; scrollbar-gutter: stable; }
body {
    min-width: 320px;
    margin: 0;
    color: var(--text);
    background: var(--white);
    font-family: "Inter", sans-serif;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
a { color: inherit; }
img { display: block; max-width: 100%; }
h1, h2, h3 { overflow-wrap: normal; text-wrap: balance; }
.no-break { white-space: nowrap; }
.svg-symbols { position: absolute; width: 0; height: 0; overflow: hidden; }
.content-width, .site-header__inner, .page-shell { width: min(var(--container), calc(100% - 48px)); margin-inline: auto; }

.site-header {
    position: fixed;
    z-index: 30;
    top: 0;
    right: 0;
    left: 0;
    border-bottom: 1px solid rgba(0, 0, 0, .08);
    background: rgba(251, 252, 252, .84);
    backdrop-filter: saturate(180%) blur(20px);
}
.site-header__inner { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; min-height: 52px; gap: 28px; }
.site-logo { width: 112px; text-decoration: none; }
.site-logo img { width: 100%; height: 38px; object-fit: contain; object-position: left center; }
.site-nav { display: flex; align-items: center; justify-content: center; gap: 30px; }
.site-nav a { position: relative; padding: 18px 0 17px; color: #3b4540; font-size: 12px; font-weight: 500; text-decoration: none; transition: color .2s ease; }
.site-nav a:hover, .site-nav a:focus-visible, .site-nav a[aria-current="page"] { color: var(--blue); }
.site-nav a[aria-current="page"]::after { position: absolute; right: 0; bottom: 8px; left: 0; height: 2px; border-radius: 2px; background: var(--blue); content: ""; }
.site-header__actions { display: flex; align-items: center; justify-self: end; gap: 12px; }
.header-cta { padding: 7px 14px; border-radius: 980px; color: var(--white); background: var(--blue); font-size: 12px; text-decoration: none; }
.header-cta:hover, .header-cta:focus-visible { background: #004a70; }
.header-cta[aria-current="page"] { background: #004a70; box-shadow: 0 0 0 3px rgba(0, 48, 73, .12); }
.mobile-menu-toggle { display: none; width: 42px; height: 42px; padding: 10px 8px; border: 0; border-radius: 50%; background: transparent; cursor: pointer; }
.mobile-menu-toggle span { display: block; width: 24px; height: 2px; margin: 4px auto; border-radius: 2px; background: var(--blue-dark); }
.mobile-menu-toggle:hover, .mobile-menu-toggle:focus-visible { background: rgba(0,48,73,.08); }
.mobile-menu { position: fixed; z-index: 60; visibility: hidden; inset: 0; pointer-events: none; }
.mobile-menu.is-open { visibility: visible; pointer-events: auto; }
.mobile-menu__backdrop { position: absolute; opacity: 0; inset: 0; width: 100%; height: 100%; padding: 0; border: 0; background: rgba(10,18,22,.56); transition: opacity .28s ease; }
.mobile-menu.is-open .mobile-menu__backdrop { opacity: 1; }
.mobile-menu__sheet { position: absolute; right: 0; bottom: 0; left: 0; max-height: 88vh; max-height: min(88dvh, 720px); overflow-y: auto; padding: 10px 24px calc(24px + env(safe-area-inset-bottom)); border-radius: 28px 28px 0 0; background: var(--white); box-shadow: 0 -24px 80px rgba(0,0,0,.24); transform: translateY(105%); transition: transform .32s cubic-bezier(.22,.8,.3,1); }
.mobile-menu.is-open .mobile-menu__sheet { transform: translateY(0); }
.mobile-menu__handle { width: 42px; height: 5px; margin: 0 auto 8px; border-radius: 8px; background: #cad2d0; }
.mobile-menu__header { display: flex; min-height: 56px; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); }
.mobile-menu__header strong { font-size: 18px; font-weight: 600; }
.mobile-menu__close { display: grid; width: 38px; height: 38px; padding: 0; border: 0; border-radius: 50%; color: var(--text); background: var(--off-white); font: inherit; cursor: pointer; place-items: center; }
.mobile-menu__close span { font-size: 25px; font-weight: 300; line-height: 1; transform: translateY(-1px); }
.mobile-menu__nav { display: grid; }
.mobile-menu__nav a { display: flex; min-height: 56px; align-items: center; justify-content: space-between; gap: 20px; border-bottom: 1px solid var(--line); color: var(--text); font-size: 17px; font-weight: 500; text-decoration: none; }
.mobile-menu__nav a i { color: #8b9490; font-size: 26px; font-style: normal; font-weight: 300; }
.mobile-menu__nav a[aria-current="page"] { color: var(--blue); }
.mobile-menu__nav a[aria-current="page"] i { color: var(--blue); }
.mobile-menu__contact { display: flex; min-height: 48px; align-items: center; justify-content: center; margin-top: 22px; border-radius: 980px; color: var(--white); background: var(--blue); font-size: 15px; text-decoration: none; }
.mobile-menu__contact:hover, .mobile-menu__contact:focus-visible { background: #004a70; }
body.mobile-menu-open { overflow: hidden; }

.hero { overflow: hidden; padding: 142px 24px 0; background: var(--off-white); text-align: center; }
.hero__content { position: relative; z-index: 2; max-width: 900px; margin-inline: auto; }
.kicker, .section-label { margin: 0 0 17px; color: var(--blue); font-size: 16px; font-weight: 600; letter-spacing: 0; }
.hero h1 { margin: 0; font-size: clamp(42px, 4.8vw, 60px); font-weight: 600; line-height: 1.12; letter-spacing: -.018em; }
.hero__lead { max-width: 710px; margin: 27px auto 0; color: var(--muted); font-size: clamp(18px, 1.6vw, 21px); font-weight: 400; line-height: 1.55; letter-spacing: -.01em; }
.hero__actions { display: flex; align-items: center; justify-content: center; gap: 26px; margin-top: 32px; }
.button { display: inline-flex; min-height: 44px; align-items: center; justify-content: center; padding: 0 22px; border-radius: 980px; font-size: 16px; font-weight: 400; text-decoration: none; transition: background-color .2s ease, transform .2s ease; }
.button--primary { color: var(--white); background: var(--blue); }
.button--primary:hover, .button--primary:focus-visible { background: #004a70; }
.arrow-link { color: var(--blue); font-size: 18px; text-decoration: none; }
.arrow-link span { margin-left: 3px; font-size: 25px; line-height: 0; vertical-align: -1px; }
.arrow-link:hover, .arrow-link:focus-visible { text-decoration: underline; }
.hero__brand { position: relative; display: grid; width: min(680px, 86vw); min-height: 470px; margin: 25px auto 0; place-items: center; }
.hero__brand img { position: relative; z-index: 1; width: 620px; height: auto; border: 1px solid rgba(0,48,73,.1); border-radius: 30px; object-fit: contain; box-shadow: 0 32px 75px rgba(0,48,73,.16); }
.hero__halo { position: absolute; top: 45%; left: 50%; width: 650px; height: 260px; border-radius: 50%; background: radial-gradient(ellipse, rgba(0,222,255,.15), rgba(0,222,255,0) 68%); transform: translate(-50%, -50%); }
.hero-showcase { position: relative; z-index: 1; overflow: hidden; width: min(520px, 76vw); height: 285px; border: 1px solid rgba(0,48,73,.12); border-radius: 24px; background: rgba(255,255,255,.86); box-shadow: 0 28px 65px rgba(0,48,73,.13); transform: perspective(900px) rotateX(2deg); }
.hero-showcase__bar { display: flex; align-items: center; gap: 6px; height: 34px; padding: 0 14px; border-bottom: 1px solid var(--line); }
.hero-showcase__bar i { width: 7px; height: 7px; border-radius: 50%; background: #b8c5c7; }
.hero-showcase__content { display: grid; grid-template-columns: 1.2fr .8fr; gap: 13px; padding: 38px; }
.hero-showcase__content span { grid-column: 1; width: 55%; height: 10px; border-radius: 8px; background: var(--blue-bright); }
.hero-showcase__content strong { grid-column: 1; width: 92%; height: 38px; border-radius: 9px; background: var(--blue); }
.hero-showcase__content b { grid-column: 1; width: 78%; height: 8px; border-radius: 8px; background: #c8d1d0; }
.hero-showcase__content em { grid-column: 2; grid-row: 1 / 5; border-radius: 18px; background: linear-gradient(145deg, var(--blue), #006694 55%, var(--blue-bright)); box-shadow: inset 0 0 0 1px rgba(255,255,255,.2); }

.promise, .services, .choice, .process-section, .pricing-section, .final-cta { padding: 140px 0; }
.promise { background: var(--white); text-align: center; }
.promise h2, .services h2, .choice h2, .process-section h2, .pricing-section h2, .about-strip h2, .focus-section h2, .final-cta h2 { margin: 0; font-size: clamp(34px, 3.8vw, 48px); font-weight: 600; line-height: 1.16; letter-spacing: -.015em; }
.section-intro, .choice__intro { max-width: 720px; margin: 28px auto 0; color: var(--muted); font-size: 19px; line-height: 1.6; letter-spacing: 0; }
.principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 52px; margin-top: 84px; text-align: left; }
.principles article { padding-top: 25px; border-top: 1px solid var(--line); }
.principle-icon { display: grid; width: 48px; height: 48px; border-radius: 14px; color: var(--blue); background: rgba(0,222,255,.12); place-items: center; }
.principle-icon svg { width: 24px; height: 24px; fill: currentColor; }
.principles h3 { margin: 24px 0 12px; font-size: 27px; font-weight: 600; letter-spacing: -.01em; }
.principles p { margin: 0; color: var(--muted); font-size: 16px; line-height: 1.55; }

.home-about { padding: 130px 0; background: var(--surface); }
.home-about__inner { display: grid; grid-template-columns: .85fr 1.15fr; gap: 110px; }
.home-about h2, .home-references h2, .subpage h2 { margin: 0; font-size: clamp(34px, 3.8vw, 48px); font-weight: 600; line-height: 1.16; letter-spacing: -.015em; }
.home-about__copy > p { margin: 0 0 18px; color: var(--muted); font-size: 18px; line-height: 1.65; }
.home-about__copy .arrow-link { display: inline-block; margin-top: 12px; }

.focus-section { overflow: hidden; color: var(--white); background: var(--dark); }
.focus-section__inner { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 55px; min-height: 760px; }
.focus-section h2 { font-size: clamp(34px, 3.2vw, 44px); }
.section-label--dark { color: var(--blue-bright); }
.focus-section__copy > p:not(.section-label) { max-width: 510px; margin: 28px 0; color: #a1a1a6; font-size: 20px; line-height: 1.5; }
.arrow-link--light { color: var(--blue-bright); }
.focus-visual { position: relative; min-height: 690px; }
.focus-aura { position: absolute; right: -170px; bottom: -180px; width: 700px; height: 700px; border-radius: 50%; background: radial-gradient(circle, rgba(0,222,255,.22), rgba(0,222,255,0) 66%); }
.device { position: absolute; z-index: 1; right: 0; bottom: -70px; width: 470px; height: 640px; padding: 12px; border: 1px solid #414147; border-radius: 58px; background: #17171a; box-shadow: 0 50px 120px rgba(0,0,0,.65), inset 0 0 0 1px rgba(255,255,255,.08); transform: rotate(5deg); }
.device__camera { position: absolute; z-index: 2; top: 24px; left: 50%; width: 78px; height: 23px; border-radius: 20px; background: #050506; transform: translateX(-50%); }
.device__screen { display: flex; height: 100%; flex-direction: column; align-items: center; padding: 150px 55px 60px; border-radius: 47px; background: linear-gradient(155deg, #fbfdfd, #e8f8fa); }
.shop-preview { display: grid; width: 100%; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 55px; }
.shop-preview i { height: 82px; border-radius: 15px; background: linear-gradient(145deg, #dcecef, #a8eaf4); box-shadow: inset 0 0 0 1px rgba(0,48,73,.08); }
.focus-visual__image { position: absolute; z-index: 1; top: 50%; right: 0; width: min(590px, 100%); height: auto; border: 1px solid rgba(255,255,255,.15); border-radius: 30px; object-fit: contain; box-shadow: 0 45px 110px rgba(0,0,0,.5); transform: translateY(-50%); }
.screen-line { width: 68%; height: 9px; margin-top: 12px; border-radius: 8px; background: #c7cbd2; }
.screen-line--wide { width: 92%; height: 17px; background: var(--blue); }
.screen-button { width: 108px; height: 34px; margin-top: 35px; border-radius: 20px; background: var(--blue); }

.services { background: var(--off-white); }
.section-head { display: grid; grid-template-columns: 1.25fr .75fr; align-items: end; gap: 80px; margin-bottom: 80px; }
.section-head > p { margin: 0 0 6px; color: var(--muted); font-size: 18px; line-height: 1.55; }
.service-list { border-top: 1px solid var(--line); }
.service-list article { display: grid; grid-template-columns: 1fr .85fr 38px; align-items: center; gap: 50px; min-height: 142px; border-bottom: 1px solid var(--line); }
.service-list__title { display: flex; align-items: baseline; gap: 22px; }
.service-list__title .service-icon { display: grid; width: 38px; height: 38px; flex: 0 0 38px; border-radius: 11px; color: var(--blue); background: rgba(0,222,255,.1); place-items: center; }
.service-icon svg { width: 20px; height: 20px; fill: currentColor; }
.service-list h3 { margin: 0; font-size: clamp(23px, 2.3vw, 31px); font-weight: 600; letter-spacing: -.01em; }
.service-list p { margin: 0; color: var(--muted); font-size: 15px; line-height: 1.55; }
.service-list > article > a { display: grid; width: 34px; height: 34px; place-items: center; border: 1px solid #b7b7bb; border-radius: 50%; color: var(--blue); font-size: 25px; text-decoration: none; }
.service-list > article > a:hover, .service-list > article > a:focus-visible { color: var(--white); background: var(--blue); border-color: var(--blue); }

.choice { text-align: center; }
.choice__options { display: grid; grid-template-columns: 1fr 1fr; max-width: 980px; margin: 78px auto 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); text-align: left; }
.choice__options article { padding: 56px 70px; }
.choice__options article + article { border-left: 1px solid var(--line); }
.choice__overline { margin: 0 0 10px; color: var(--blue); font-size: 13px; font-weight: 600; }
.choice__options h3 { margin: 0; font-size: 30px; font-weight: 600; letter-spacing: -.01em; }
.choice__options h3 + p { min-height: 110px; margin: 20px 0 28px; color: var(--muted); font-size: 16px; line-height: 1.55; }
.choice__options ul { margin: 0; padding: 0; list-style: none; }
.choice__options li { position: relative; margin-top: 14px; padding-left: 23px; font-size: 14px; }
.choice__options li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; }
.choice__note { margin: 32px 0 0; color: var(--muted); font-size: 14px; }

.process-section { background: var(--off-white); }
.process-heading { display: grid; grid-template-columns: 1.2fr .8fr; align-items: end; gap: 80px; margin-bottom: 75px; }
.process-heading > p { margin: 0 0 5px; color: var(--muted); font-size: 18px; line-height: 1.6; }
.process-list { display: grid; grid-template-columns: repeat(3, 1fr); margin: 0; padding: 0; border-top: 1px solid var(--line); list-style: none; }
.process-list li { display: grid; grid-template-columns: 62px 1fr; align-content: start; gap: 20px; min-height: 225px; padding: 38px 28px 35px 0; border-bottom: 1px solid var(--line); }
.process-list li:not(:nth-child(3n + 1)) { padding-left: 28px; border-left: 1px solid var(--line); }
.process-icon { display: grid; width: 58px; height: 58px; border-radius: 17px; color: var(--white); background: linear-gradient(145deg, #00537b, var(--blue)); box-shadow: 0 12px 26px rgba(0,48,73,.16); place-items: center; }
.process-icon svg { width: 29px; height: 29px; fill: currentColor; }
.process-list strong { font-size: 20px; font-weight: 600; }
.process-list p { margin: 12px 0 0; color: var(--muted); font-size: 14px; line-height: 1.6; }

.pricing-section { background: var(--white); }
.pricing-heading { max-width: 780px; margin: 0 auto 70px; text-align: center; }
.pricing-heading > p:last-child { max-width: 670px; margin: 24px auto 0; color: var(--muted); font-size: 18px; line-height: 1.6; }
.pricing-list { border-top: 1px solid var(--line); }
.pricing-list article { display: grid; grid-template-columns: 1fr .8fr 1fr; align-items: center; gap: 40px; min-height: 100px; border-bottom: 1px solid var(--line); }
.pricing-list p { margin: 0; font-size: 18px; font-weight: 600; }
.pricing-list strong { color: var(--blue); font-size: 24px; font-weight: 600; white-space: nowrap; }
.pricing-list span { color: var(--muted); font-size: 14px; }
.pricing-actions { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 28px; margin-top: 48px; }

.home-references { padding: 140px 0; background: var(--off-white); }
.reference-preview-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.reference-preview-grid article { padding: 28px 28px 42px; }
.reference-preview-grid article + article { border-left: 1px solid var(--line); }
.reference-type { margin: 0 0 22px; color: var(--blue); font-size: 12px; font-weight: 600; }
.reference-preview-grid h3 { margin: 0 0 17px; font-size: 27px; font-weight: 600; letter-spacing: -.015em; }
.reference-preview-grid p:not(.reference-type) { min-height: 100px; margin: 0 0 25px; color: var(--muted); font-size: 14px; line-height: 1.65; }
.reference-preview-grid a { color: var(--blue); font-size: 14px; text-decoration: none; }
.reference-preview-grid a:hover { text-decoration: underline; }
.reference-preview__media, .project__media { display: grid; overflow: hidden; border: 1px solid rgba(0,48,73,.1); background: var(--white); place-items: center; }
.reference-preview__media { aspect-ratio: 2 / 1; margin: 0 0 28px; border-radius: 18px; }
.reference-preview__media, .project__media { text-decoration: none; transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.reference-preview__media:hover, .reference-preview__media:focus-visible, .project__media:hover, .project__media:focus-visible { border-color: rgba(0,48,73,.28); box-shadow: 0 16px 36px rgba(0,48,73,.12); transform: translateY(-2px); }
.reference-preview__media img, .project__media img { width: 100%; height: 100%; object-fit: contain; }
.reference-preview__media span, .project__media span { color: #7d8c89; font-size: 11px; letter-spacing: .02em; }
.home-references__action { margin-top: 44px; text-align: center; }

.about-strip { padding: 130px 0; color: var(--white); background: var(--blue-dark); }
.about-strip__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 110px; }
.about-strip__inner > div:last-child > p { margin: 3px 0 40px; color: #bbbfd3; font-size: 20px; line-height: 1.55; }
.about-strip__links { border-top: 1px solid rgba(255,255,255,.18); }
.about-strip__links a { display: flex; min-height: 58px; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(255,255,255,.18); font-size: 15px; text-decoration: none; }
.about-strip__links span { color: var(--blue-bright); font-size: 24px; }
.about-strip__links a:hover { color: var(--blue-bright); }

.final-cta { background: var(--surface); text-align: center; }
.final-cta__content { max-width: 800px; margin-inline: auto; padding-inline: 24px; }
.final-cta p:not(.section-label) { margin: 24px auto 32px; color: var(--muted); font-size: 21px; line-height: 1.5; }

.site-footer { color: #515154; background: var(--off-white); }
.site-footer__main { display: grid; grid-template-columns: 1.5fr 1fr; gap: 100px; padding: 64px 0 45px; border-bottom: 1px solid var(--line); }
.site-footer__brand img { width: 160px; }
.site-footer__brand p { max-width: 390px; margin: 21px 0 0; color: var(--muted); font-size: 13px; line-height: 1.55; }
.site-footer__contact { display: flex; flex-direction: column; align-items: flex-start; gap: 8px; margin-top: 20px; }
.site-footer__contact a { color: var(--blue); font-size: 13px; text-decoration: none; }
.site-footer__contact a:hover { text-decoration: underline; }
.site-footer__links { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; }
.site-footer__links div { display: flex; flex-direction: column; align-items: flex-start; gap: 11px; }
.site-footer__links strong { margin-bottom: 4px; color: var(--text); font-size: 12px; }
.site-footer__links a { font-size: 12px; text-decoration: none; }
.site-footer__links a:hover { text-decoration: underline; }
.site-footer__bottom { display: flex; align-items: center; justify-content: space-between; padding: 22px 0 28px; font-size: 11px; }
.site-footer__bottom p { margin: 0; }
.site-footer__bottom nav { display: flex; gap: 22px; }
.site-footer__bottom a { text-decoration: none; }

.page-shell { min-height: 70vh; padding-top: 140px; padding-bottom: 100px; }
.hero-section { max-width: 860px; }
.hero-section .eyebrow { margin: 0 0 18px; color: var(--blue); font-size: 17px; font-weight: 600; }
.hero-section h1 { margin: 0; font-size: clamp(38px, 4.8vw, 56px); font-weight: 600; line-height: 1.14; letter-spacing: -.018em; }
.hero-section p:last-child { max-width: 700px; margin-top: 26px; color: var(--muted); font-size: 20px; line-height: 1.5; }

.subpage { background: var(--white); }
.subpage-hero { padding: 155px 0 100px; background: var(--off-white); text-align: center; }
.subpage-hero__inner { max-width: 930px; }
.subpage-hero h1 { margin: 0; font-size: clamp(42px, 5.5vw, 68px); font-weight: 600; line-height: 1.08; letter-spacing: -.025em; }
.subpage-hero p:last-child { max-width: 760px; margin: 27px auto 0; color: var(--muted); font-size: 20px; line-height: 1.55; }
.subpage-section { padding: 115px 0; }
.subpage-section--muted { background: var(--off-white); }
.about-intro, .detail-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 100px; }
.prose p { margin: 0 0 20px; color: var(--muted); font-size: 18px; line-height: 1.7; }
.center-heading { max-width: 800px; margin: 0 auto 70px; text-align: center; }
.expertise-columns { display: grid; grid-template-columns: 1fr 1fr; max-width: 980px; margin-inline: auto; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.expertise-columns article { padding: 52px 60px; }
.expertise-columns article + article { border-left: 1px solid var(--line); }
.expertise-columns h3 { margin: 0 0 18px; font-size: 30px; font-weight: 600; }
.expertise-columns h3 + p { min-height: 105px; margin: 0 0 25px; color: var(--muted); line-height: 1.6; }
.expertise-columns ul { margin: 0; padding: 0; list-style: none; }
.expertise-columns li { position: relative; margin-top: 13px; padding-left: 22px; font-size: 14px; line-height: 1.45; }
.expertise-columns li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; }
.feature-lines { border-top: 1px solid var(--line); }
.feature-lines > div { display: grid; grid-template-columns: .65fr 1fr; gap: 30px; padding: 26px 0; border-bottom: 1px solid var(--line); }
.feature-lines strong { font-size: 16px; }
.feature-lines p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.6; }
.about-philosophy { padding: 120px 0; color: var(--white); background: var(--blue-dark); }
.about-philosophy__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; }
.about-philosophy__inner > div:last-child > p { margin: 0 0 20px; color: #c2cdd1; font-size: 18px; line-height: 1.7; }
.about-philosophy .arrow-link { display: inline-block; margin-top: 12px; }

.project-list { border-top: 1px solid var(--line); }
.project { display: grid; grid-template-columns: .72fr 1.28fr; gap: 80px; padding: 62px 0; border-bottom: 1px solid var(--line); }
.project__heading h2 { margin-bottom: 18px; font-size: 34px; }
.project__media { aspect-ratio: 2 / 1; margin-bottom: 26px; border-radius: 20px; }
.project__heading a { color: var(--blue); font-size: 14px; text-decoration: none; }
.project__heading a:hover { text-decoration: underline; }
.project__details { display: grid; gap: 18px; }
.project__details p { display: grid; grid-template-columns: 100px 1fr; gap: 25px; margin: 0; color: var(--muted); font-size: 15px; line-height: 1.65; }
.project__details strong { color: var(--text); font-size: 13px; }

.contact-layout { display: grid; grid-template-columns: .9fr 1.1fr; gap: 110px; }
.contact-direct > p { max-width: 480px; color: var(--muted); font-size: 17px; line-height: 1.6; }
.contact-direct > a { display: flex; flex-direction: column; gap: 7px; padding: 23px 0; border-top: 1px solid var(--line); text-decoration: none; }
.contact-direct > a:last-child { border-bottom: 1px solid var(--line); }
.contact-direct > a span { color: var(--muted); font-size: 12px; }
.contact-direct > a strong { color: var(--blue); font-size: 20px; font-weight: 500; }
.contact-prep ol { margin: 35px 0 0; padding: 0; border-top: 1px solid var(--line); list-style: none; }
.contact-prep li { display: grid; grid-template-columns: 35px 1fr; gap: 15px; padding: 20px 0; border-bottom: 1px solid var(--line); }
.contact-prep li span { color: var(--blue); font-size: 12px; }
.contact-prep li p { margin: 0; color: var(--muted); line-height: 1.5; }
.contact-area { padding: 110px 0; color: var(--white); background: var(--blue-dark); }
.contact-area__inner { display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: 100px; }
.contact-area__inner > p { margin: 0; color: #c2cdd1; font-size: 18px; line-height: 1.7; }

.contact-form-section { background: var(--off-white); }
.contact-form-layout { display: grid; grid-template-columns: .58fr 1.42fr; align-items: start; gap: 80px; }
.contact-form-aside { position: sticky; top: 95px; }
.contact-form-aside > p:not(.section-label) { color: var(--muted); font-size: 15px; line-height: 1.65; }
.contact-aside-links { margin-top: 34px; border-top: 1px solid var(--line); }
.contact-aside-links a { display: flex; flex-direction: column; gap: 6px; padding: 20px 0; border-bottom: 1px solid var(--line); text-decoration: none; }
.contact-aside-links span { color: var(--muted); font-size: 11px; }
.contact-aside-links strong { color: var(--blue); font-size: 17px; font-weight: 600; }
.contact-form-panel { overflow: hidden; border: 1px solid rgba(0,48,73,.1); border-radius: 28px; background: var(--white); box-shadow: 0 24px 65px rgba(0,48,73,.08); }
.project-form { padding: 0 48px 50px; }
.form-section { min-width: 0; margin: 0; padding: 0 0 48px; border: 0; border-bottom: 1px solid var(--line); }
.form-section legend { width: 100%; margin: 0 0 30px; padding: 48px 0 0; font-size: 24px; font-weight: 600; }
.form-section legend span { display: block; margin-bottom: 8px; color: var(--blue); font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.form-section__intro { margin: -18px 0 25px; color: var(--muted); font-size: 13px; }
.form-grid { display: grid; gap: 24px; }
.form-grid--two { grid-template-columns: 1fr 1fr; }
.form-field { display: flex; min-width: 0; flex-direction: column; gap: 9px; }
.form-field + .form-field:not(.form-grid .form-field) { margin-top: 24px; }
.form-field > span { color: var(--text); font-size: 13px; font-weight: 600; }
.form-field > span b { color: #b3261e; font-weight: 600; }
.form-field > span em { margin-left: 5px; color: var(--muted); font-size: 11px; font-style: normal; font-weight: 400; }
.form-field input, .form-field select, .form-field textarea { width: 100%; border: 1px solid #bdc9c6; border-radius: 12px; outline: 0; color: var(--text); background: var(--white); font: inherit; font-size: 15px; transition: border-color .2s ease, box-shadow .2s ease; }
.form-field input, .form-field select { min-height: 50px; padding: 0 14px; }
.form-field textarea { min-height: 150px; padding: 14px; line-height: 1.55; resize: vertical; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(0,48,73,.1); }
.form-field [aria-invalid="true"] { border-color: #b3261e; }
.field-hint { color: var(--muted); font-size: 11px; line-height: 1.45; }
.field-error { display: block; color: #9f1c16; font-size: 12px; line-height: 1.45; }
.choice-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.choice-grid--three { grid-template-columns: repeat(3, 1fr); }
.choice-card { position: relative; cursor: pointer; }
.choice-card input { position: absolute; opacity: 0; pointer-events: none; }
.choice-card span { display: flex; min-height: 64px; align-items: center; padding: 14px 42px 14px 15px; border: 1px solid #c7d1cf; border-radius: 14px; color: var(--text); background: var(--white); font-size: 13px; line-height: 1.4; transition: border-color .2s ease, background-color .2s ease, box-shadow .2s ease; }
.choice-card span::after { position: absolute; top: 50%; right: 16px; width: 16px; height: 16px; border: 1px solid #aebbb8; border-radius: 50%; content: ""; transform: translateY(-50%); }
.choice-card input:checked + span { border-color: var(--blue); background: rgba(0,48,73,.035); box-shadow: inset 0 0 0 1px var(--blue); }
.choice-card input:checked + span::after { border: 5px solid var(--blue); }
.choice-card input:focus-visible + span { box-shadow: 0 0 0 3px rgba(0,48,73,.12); }
.checkbox-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 24px; border-top: 1px solid var(--line); }
.checkbox-grid label { position: relative; display: flex; min-height: 52px; align-items: center; gap: 11px; border-bottom: 1px solid var(--line); cursor: pointer; }
.checkbox-grid input, .privacy-consent input { width: 18px; height: 18px; flex: 0 0 18px; accent-color: var(--blue); }
.checkbox-grid span { color: var(--muted); font-size: 13px; line-height: 1.4; }
.checkbox-grid input:checked + span { color: var(--text); font-weight: 500; }
.conditional-field { max-width: calc(50% - 12px); margin-top: 24px; }
.form-alert { margin: 30px 48px 0; padding: 18px 20px; border-radius: 14px; }
.form-alert strong { font-size: 14px; }
.form-alert p { margin: 6px 0 0; font-size: 13px; line-height: 1.5; }
.form-alert--success { color: #174f34; background: #e7f6ed; }
.form-alert--error { color: #7f1d18; background: #fff0ef; }
.privacy-consent { padding: 34px 0 0; }
.privacy-consent label { display: flex; align-items: flex-start; gap: 13px; cursor: pointer; }
.privacy-consent input { margin-top: 3px; }
.privacy-consent span { color: var(--muted); font-size: 12px; line-height: 1.65; }
.privacy-consent a { color: var(--blue); }
.form-submit-row { display: flex; align-items: center; justify-content: space-between; gap: 25px; padding-top: 30px; }
.form-submit-row p { max-width: 300px; margin: 0; color: var(--muted); font-size: 11px; line-height: 1.5; text-align: right; }
.form-honeypot { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }

.cookie-consent { position: fixed; z-index: 100; inset: 0; pointer-events: none; }
.cookie-consent__bar { position: absolute; right: 22px; bottom: 22px; left: 22px; display: grid; max-width: 1180px; grid-template-columns: 1fr auto; align-items: center; gap: 45px; margin-inline: auto; padding: 24px 26px; border: 1px solid rgba(255,255,255,.16); border-radius: 22px; color: var(--white); background: rgba(0,35,53,.96); box-shadow: 0 24px 80px rgba(0,0,0,.32); backdrop-filter: blur(20px); pointer-events: auto; }
.cookie-consent__bar strong { font-size: 16px; }
.cookie-consent__bar p { max-width: 760px; margin: 7px 0 7px; color: #c7d4d7; font-size: 12px; line-height: 1.6; }
.cookie-consent__bar a { color: var(--blue-bright); font-size: 11px; }
.cookie-consent__actions { display: flex; align-items: center; gap: 10px; }
.cookie-button { min-height: 40px; padding-inline: 16px; border: 0; cursor: pointer; }
.cookie-button--secondary { border: 1px solid rgba(255,255,255,.28); color: var(--white); background: transparent; }
.cookie-settings { position: absolute; inset: 0; display: grid; padding: 20px; place-items: center; pointer-events: auto; }
.cookie-settings__backdrop { position: absolute; inset: 0; background: rgba(3,18,25,.68); backdrop-filter: blur(8px); }
.cookie-settings__panel { position: relative; z-index: 1; width: min(620px, 100%); max-height: calc(100vh - 40px); overflow-y: auto; padding: 34px; border-radius: 26px; background: var(--white); box-shadow: 0 32px 100px rgba(0,0,0,.35); }
.cookie-settings__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 25px; margin-bottom: 28px; }
.cookie-settings__header h2 { margin: 0; font-size: 30px; }
.cookie-settings__header > button { border: 0; color: var(--muted); background: none; font-size: 30px; cursor: pointer; }
.cookie-category { display: flex; min-height: 118px; align-items: center; justify-content: space-between; gap: 30px; padding: 24px 0; border-top: 1px solid var(--line); }
.cookie-category > div { min-width: 0; }
.cookie-category strong { font-size: 15px; }
.cookie-category p { max-width: 465px; margin: 7px 0 0; color: var(--muted); font-size: 12px; line-height: 1.6; }
.cookie-category__meta { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 12px; }
.cookie-category__meta span { padding: 5px 8px; border-radius: 7px; color: #52635f; background: var(--off-white); font-size: 10px; line-height: 1.3; }
.cookie-status { flex: 0 0 auto; font-size: 11px; font-weight: 600; }
.cookie-status--active { padding: 7px 10px; border-radius: 999px; color: #17663b; background: #e7f6ed; }
.cookie-category input { width: 42px; height: 22px; accent-color: var(--blue); }
.cookie-settings__actions { display: flex; justify-content: flex-end; gap: 12px; padding-top: 24px; border-top: 1px solid var(--line); }
.cookie-settings__actions .cookie-button--secondary { border-color: var(--line); color: var(--blue); }
.site-footer__bottom button { padding: 0; border: 0; color: inherit; background: none; font: inherit; cursor: pointer; }
.site-footer__bottom button:hover { text-decoration: underline; }

.package-list { display: grid; gap: 80px; }
.package { display: grid; grid-template-columns: .72fr 1.28fr; gap: 75px; padding-bottom: 80px; border-bottom: 1px solid var(--line); }
.package__summary h2 { margin-bottom: 15px; }
.package__summary > strong { display: block; margin-bottom: 24px; color: var(--blue); font-size: 27px; font-weight: 600; white-space: nowrap; }
.package__summary > p:last-child { color: var(--muted); font-size: 16px; line-height: 1.65; }
.package__details { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.package__details--single { grid-template-columns: 1fr 1fr; }
.package__details h3 { margin: 0 0 18px; font-size: 18px; font-weight: 600; }
.package__details ul { margin: 0; padding: 0; list-style: none; }
.package__details li { position: relative; margin-top: 12px; padding-left: 19px; color: var(--muted); font-size: 13px; line-height: 1.5; }
.package__details li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; }
.price-note { padding: 110px 0; color: var(--white); background: var(--blue-dark); }
.price-note__inner { display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: 100px; }
.price-note__inner > p { margin: 0; color: #c2cdd1; font-size: 18px; line-height: 1.7; }

.faq-list { max-width: 900px; }
.faq-list details { border-top: 1px solid var(--line); }
.faq-list details:last-child { border-bottom: 1px solid var(--line); }
.faq-list summary { position: relative; padding: 28px 45px 28px 0; cursor: pointer; font-size: 20px; font-weight: 600; list-style: none; }
.faq-list summary h2 { margin: 0; font-size: inherit; font-weight: inherit; line-height: 1.35; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { position: absolute; top: 23px; right: 5px; color: var(--blue); content: "+"; font-size: 27px; font-weight: 400; }
.faq-list details[open] summary::after { content: "−"; }
.faq-list details > div { max-width: 730px; padding: 0 0 30px; }
.faq-list details p { margin: 0; color: var(--muted); font-size: 16px; line-height: 1.7; }
.faq-list details a { display: inline-block; margin-top: 15px; color: var(--blue); font-size: 14px; text-decoration: none; }

.commerce-packages, .maintenance-options { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.commerce-packages article, .maintenance-options article { padding: 40px 28px; }
.commerce-packages article { position: relative; }
.commerce-packages article + article, .maintenance-options article + article { border-left: 1px solid var(--line); }
.commerce-packages .is-recommended { z-index: 1; background: rgba(0,48,73,.025); box-shadow: inset 0 0 0 1px rgba(0,48,73,.12); }
.commerce-packages .is-recommended h3 { color: var(--blue); }
.commerce-packages .is-recommended .reference-type { padding-right: 76px; }
.package-badge { position: absolute; top: 37px; right: 24px; display: inline-flex; min-height: 22px; align-items: center; padding: 0 9px; border-radius: 999px; color: var(--white); background: var(--blue); font-size: 10px; font-weight: 600; }
.commerce-packages h3, .maintenance-options h3 { margin: 0 0 11px; font-size: 27px; font-weight: 600; }
.commerce-packages article > strong, .maintenance-options article > strong { display: block; margin-bottom: 20px; color: var(--blue); font-size: 20px; font-weight: 600; white-space: nowrap; }
.commerce-packages .package-offer-note { display: block; margin: -13px 0 20px; color: var(--blue); font-size: 11px; font-weight: 600; }
.commerce-packages article > p:not(.reference-type), .maintenance-options article > p:not(.reference-type) { min-height: 70px; margin: 0 0 23px; color: var(--muted); font-size: 13px; line-height: 1.55; }
.commerce-packages ul, .maintenance-options ul { margin: 0; padding: 0; list-style: none; }
.commerce-packages li, .maintenance-options li { position: relative; margin-top: 12px; padding-left: 18px; color: var(--muted); font-size: 12px; line-height: 1.5; }
.commerce-packages li::before, .maintenance-options li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; }
.package-tax-note { max-width: 780px; margin: 35px auto 0; color: var(--muted); font-size: 13px; line-height: 1.6; text-align: center; }
.custom-commerce { padding: 110px 0; color: var(--white); background: var(--blue-dark); }
.custom-commerce__inner { display: grid; grid-template-columns: .9fr 1.1fr; align-items: end; gap: 100px; }
.custom-commerce__inner p:not(.section-label) { margin: 0 0 24px; color: #c2cdd1; font-size: 18px; line-height: 1.7; }
.custom-commerce__inner strong { color: var(--blue-bright); font-size: 20px; font-weight: 600; }
.comparison-section { padding: 110px 0; color: var(--white); background: var(--blue-dark); }
.comparison-heading { max-width: 700px; margin-bottom: 55px; }
.table-scroll { overflow-x: auto; border-top: 1px solid rgba(255,255,255,.2); border-bottom: 1px solid rgba(255,255,255,.2); }
.table-scroll table { width: 100%; min-width: 760px; border-collapse: collapse; }
.table-scroll th, .table-scroll td { padding: 18px 20px; border-bottom: 1px solid rgba(255,255,255,.12); font-size: 13px; text-align: left; }
.table-scroll thead th { color: var(--blue-bright); font-size: 12px; font-weight: 600; }
.table-scroll tbody th { color: var(--white); font-weight: 500; }
.table-scroll td { color: #c2cdd1; }

.risk-list { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--line); }
.risk-list article { display: grid; grid-template-columns: 36px 1fr; gap: 18px; min-height: 170px; padding: 32px 35px 32px 0; border-bottom: 1px solid var(--line); }
.risk-list article:nth-child(even) { padding-left: 35px; border-left: 1px solid var(--line); }
.risk-list span { color: var(--blue); font-size: 12px; }
.risk-list h3 { margin: 0 0 12px; font-size: 20px; font-weight: 600; }
.risk-list p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.6; }
.maintenance-seo { padding: 115px 0; color: var(--white); background: var(--blue-dark); }
.maintenance-seo__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; }
.maintenance-seo__inner > div:last-child p { margin: 0 0 20px; color: #c2cdd1; font-size: 17px; line-height: 1.7; }

.landing-packages { display: grid; grid-template-columns: 1fr 1fr; max-width: 1020px; margin-inline: auto; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.landing-packages > article { display: grid; grid-template-columns: .8fr 1.2fr; gap: 35px; padding: 48px 42px; }
.landing-packages > article + article { border-left: 1px solid var(--line); }
.landing-packages h3 { margin: 0 0 12px; font-size: 29px; font-weight: 600; }
.landing-packages .package__summary > strong { font-size: 22px; }
.landing-package__content h4 { margin: 0 0 15px; font-size: 14px; font-weight: 600; }
.landing-package__content h4:not(:first-child) { margin-top: 25px; }
.landing-package__content ul { margin: 0; padding: 0; list-style: none; }
.landing-package__content li { position: relative; margin-top: 11px; padding-left: 18px; color: var(--muted); font-size: 12px; line-height: 1.5; }
.landing-package__content li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; }
.landing-package__content .list-muted li::before { color: #9aa39f; content: "—"; }
.delivery-time { margin: 28px 0 0; padding-top: 17px; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; line-height: 1.5; }
.delivery-time strong { color: var(--text); font-weight: 600; }

.social-package { padding: 115px 0; color: var(--white); background: var(--blue-dark); }
.social-package__inner { display: grid; grid-template-columns: .9fr 1.1fr; gap: 100px; }
.social-package__inner > div:first-child > strong { display: block; margin-top: 22px; color: var(--blue-bright); font-size: 20px; font-weight: 600; }
.social-package__inner > div:last-child p { margin: 0 0 20px; color: #c2cdd1; font-size: 16px; line-height: 1.7; }
.social-package__inner ul { margin: 25px 0; padding: 0; list-style: none; }
.social-package__inner li { position: relative; margin-top: 12px; padding-left: 22px; color: #dbe4e6; font-size: 14px; }
.social-package__inner li::before { position: absolute; left: 0; color: var(--blue-bright); content: "✓"; }
.budget-section { display: grid; grid-template-columns: 1fr .85fr; align-items: end; gap: 90px; }
.budget-section > div:first-child > p:last-child { color: var(--muted); font-size: 17px; line-height: 1.6; }
.budget-lines { border-top: 1px solid var(--line); }
.budget-lines > div { display: flex; align-items: center; justify-content: space-between; gap: 25px; padding: 25px 0; border-bottom: 1px solid var(--line); }
.budget-lines span { color: var(--muted); font-size: 14px; }
.budget-lines strong { color: var(--blue); font-size: 18px; font-weight: 600; }

.rental-options { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.rental-options article { padding: 45px 50px; }
.rental-options article + article { border-left: 1px solid var(--line); }
.rental-options h3 { margin: 0 0 24px; font-size: 29px; font-weight: 600; }
.rental-options ul { margin: 0; padding: 0; list-style: none; }
.rental-options li { position: relative; margin-top: 13px; padding-left: 20px; color: var(--muted); font-size: 14px; line-height: 1.55; }
.rental-options li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; }
.rent-buy-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(255,255,255,.2); border-bottom: 1px solid rgba(255,255,255,.2); }
.rent-buy-grid article { padding: 42px 35px; }
.rent-buy-grid article + article { border-left: 1px solid rgba(255,255,255,.2); }
.rent-buy-grid h3 { margin: 0 0 16px; color: var(--blue-bright); font-size: 24px; font-weight: 600; }
.rent-buy-grid p { margin: 0; color: #c2cdd1; font-size: 14px; line-height: 1.7; }
.trial-note { padding: 110px 0; background: var(--off-white); }
.trial-note__inner { display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: 90px; }
.trial-note__inner > p { margin: 0; color: var(--muted); font-size: 18px; line-height: 1.7; }

.calculator-intro { display: grid; grid-template-columns: .9fr 1.1fr; gap: 100px; }
.calculator-intro ol { margin: 0; padding: 0; border-top: 1px solid var(--line); list-style: none; }
.calculator-intro li { display: grid; grid-template-columns: 35px 1fr; gap: 15px; padding: 20px 0; border-bottom: 1px solid var(--line); }
.calculator-intro li span { color: var(--blue); font-size: 12px; }
.calculator-intro li p { margin: 0; color: var(--muted); line-height: 1.55; }
.calculator-section { padding: 115px 0; background: var(--off-white); }
.cost-calculator { max-width: 980px; margin-inline: auto; }
.cost-calculator fieldset { margin: 0; padding: 45px 0; border: 0; border-top: 1px solid var(--line); }
.cost-calculator legend { padding: 0 22px 0 0; color: var(--text); font-size: 20px; font-weight: 600; }
.fieldset-note { max-width: 760px; margin: 10px 0 28px; color: var(--muted); font-size: 13px; line-height: 1.6; }
.calculator-package-options { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.calculator-package-options label { cursor: pointer; }
.calculator-package-options input { position: absolute; opacity: 0; pointer-events: none; }
.calculator-package-options label > span { display: flex; min-height: 155px; flex-direction: column; padding: 25px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); transition: border-color .2s, box-shadow .2s; }
.calculator-package-options input:checked + span { border-color: var(--blue); box-shadow: inset 0 0 0 1px var(--blue); }
.calculator-package-options input:focus-visible + span { outline: 3px solid rgba(0,222,255,.45); outline-offset: 2px; }
.calculator-package-options strong { font-size: 19px; }
.calculator-package-options small { margin: 9px 0 20px; color: var(--muted); font-size: 12px; line-height: 1.5; }
.calculator-package-options b { margin-top: auto; color: var(--blue); font-size: 18px; font-weight: 600; }
.calculator-package-options em { margin-top: 8px; color: var(--muted); font-size: 11px; font-style: normal; }
.external-costs { border-top: 1px solid var(--line); }
.external-costs > label { display: flex; min-height: 68px; align-items: center; justify-content: space-between; gap: 30px; border-bottom: 1px solid var(--line); font-size: 14px; }
.number-input { display: flex; align-items: center; gap: 8px; color: var(--muted); }
.number-input input { width: 140px; padding: 11px 12px; border: 1px solid var(--line); border-radius: 10px; color: var(--text); background: var(--white); font: inherit; text-align: right; }
.feature-checkboxes { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); }
.feature-checkboxes label { display: flex; align-items: center; gap: 14px; min-height: 72px; padding: 12px 25px 12px 4px; border-bottom: 1px solid var(--line); font-size: 13px; cursor: pointer; }
.feature-checkboxes label:nth-child(even) { padding-left: 25px; border-left: 1px solid var(--line); }
.feature-checkboxes input, .maintenance-choice input { width: 17px; height: 17px; accent-color: var(--blue); }
.feature-checkboxes label > span { display: grid; width: 100%; grid-template-columns: minmax(0, 1fr) auto; align-items: start; gap: 4px 18px; }
.feature-checkboxes label strong { font-size: 13px; font-weight: 500; line-height: 1.45; }
.feature-checkboxes label small { color: var(--blue); font-size: 13px; font-weight: 600; white-space: nowrap; }
.feature-checkboxes label em { grid-column: 1 / -1; color: var(--muted); font-size: 11px; font-style: normal; line-height: 1.45; }
.feature-checkboxes label.is-disabled { cursor: not-allowed; opacity: .42; }
.calculator-scope-note { margin-top: 35px; padding: 28px 30px; border-radius: 18px; background: var(--white); }
.calculator-scope-note h3 { margin: 0 0 17px; font-size: 19px; font-weight: 600; }
.calculator-scope-note ul { margin: 0; padding: 0; list-style: none; }
.calculator-scope-note li { display: flex; justify-content: space-between; gap: 25px; padding: 12px 0; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; line-height: 1.5; }
.calculator-scope-note li strong { color: var(--text); font-weight: 500; text-align: right; }
.calculator-scope-note li a { color: var(--blue); font-weight: 600; text-align: right; }
.calculator-dependency-note { margin: 22px 0 0; color: var(--muted); font-size: 12px; line-height: 1.6; }
.maintenance-choice { display: flex; align-items: center; gap: 12px; margin-top: 25px; font-size: 14px; }
.maintenance-choice--card { margin-top: 8px; padding: 24px 26px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); cursor: pointer; }
.maintenance-choice--card > span { display: flex; flex-direction: column; gap: 6px; }
.maintenance-choice--card strong { font-size: 14px; font-weight: 600; }
.maintenance-choice--card small { color: var(--muted); font-size: 12px; line-height: 1.5; }
.calculator-result { padding: 40px; border-radius: 24px; color: var(--white); background: var(--blue-dark); }
.calculator-result__total { display: flex; align-items: flex-end; justify-content: space-between; gap: 25px; }
.calculator-result__total > span { color: #c2cdd1; font-size: 13px; }
.calculator-result output { color: var(--blue-bright); font-size: clamp(29px, 4vw, 42px); font-weight: 600; }
.calculator-result > p { max-width: 700px; margin: 20px 0; color: #c2cdd1; font-size: 13px; line-height: 1.6; }
.calculator-breakdown { margin: 28px 0 0; padding: 18px 0; border-top: 1px solid rgba(255,255,255,.2); border-bottom: 1px solid rgba(255,255,255,.2); }
.calculator-breakdown > div { display: flex; justify-content: space-between; gap: 25px; padding: 7px 0; }
.calculator-breakdown dt { color: #c2cdd1; font-size: 12px; }
.calculator-breakdown dd { margin: 0; color: var(--white); font-size: 13px; font-weight: 600; }
.calculator-breakdown [data-calculator-discount-row] dd { color: var(--blue-bright); }
.calculator-summary { margin-bottom: 28px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.2); color: #e5edef; font-size: 12px; line-height: 1.6; }
.calculator-result__actions { display: flex; align-items: center; flex-wrap: wrap; gap: 18px; }
.calculator-result .button { color: var(--blue-dark); background: var(--blue-bright); }
.calculator-copy { padding: 10px 0; border: 0; color: #dbe4e6; background: transparent; font: inherit; font-size: 13px; text-decoration: underline; text-underline-offset: 4px; cursor: pointer; }
.calculator-copy:hover, .calculator-copy:focus-visible { color: var(--blue-bright); }

.legal-page .subpage-hero { padding-bottom: 80px; }
.legal-layout { display: grid; grid-template-columns: 220px minmax(0, 1fr); align-items: start; gap: 90px; }
.legal-nav { position: sticky; top: 85px; display: flex; flex-direction: column; align-items: flex-start; gap: 12px; padding-top: 20px; border-top: 1px solid var(--line); }
.legal-nav strong { margin-bottom: 6px; color: var(--text); font-size: 12px; }
.legal-nav a { color: var(--muted); font-size: 12px; line-height: 1.4; text-decoration: none; }
.legal-nav a:hover { color: var(--blue); text-decoration: underline; }
.legal-content { max-width: 800px; }
.legal-content > section { padding: 0 0 70px; scroll-margin-top: 90px; }
.legal-content > section + section { padding-top: 70px; border-top: 1px solid var(--line); }
.legal-content h2 { margin-bottom: 28px; font-size: clamp(28px, 3vw, 40px); }
.legal-content h3 { margin: 30px 0 13px; font-size: 20px; font-weight: 600; }
.legal-content p, .legal-content li { color: var(--muted); font-size: 15px; line-height: 1.75; }
.legal-content p { margin: 0 0 18px; }
.legal-content ul, .legal-content ol { margin: 20px 0; padding-left: 22px; }
.legal-content a { color: var(--blue); }
.legal-data { margin: 0; border-top: 1px solid var(--line); }
.legal-data > div { display: grid; grid-template-columns: 190px 1fr; gap: 30px; padding: 18px 0; border-bottom: 1px solid var(--line); }
.legal-data dt { color: var(--muted); font-size: 12px; }
.legal-data dd { margin: 0; color: var(--text); font-size: 14px; line-height: 1.55; }
.legal-source-note { margin-top: 20px; font-size: 12px; }
.legal-processes { border-top: 1px solid var(--line); }
.legal-processes article { padding: 30px 0; border-bottom: 1px solid var(--line); }
.legal-processes h3 { margin-top: 0; }
.legal-processes article p { margin-bottom: 8px; font-size: 14px; }
.legal-processes article p:last-child { margin-bottom: 0; }
.legal-review-note { padding: 25px 0; color: var(--white); background: #6b4f00; }
.legal-review-note > div { display: grid; grid-template-columns: 220px 1fr; gap: 40px; }
.legal-review-note strong { color: #fff4c2; font-size: 13px; }
.legal-review-note p { margin: 0; color: #f6e9b2; font-size: 12px; line-height: 1.55; }
.withdrawal-model { margin-top: 30px; padding: 28px; border: 1px solid var(--line); border-radius: 18px; background: var(--off-white); }
.withdrawal-model h3 { margin-top: 0; }

.blog-hero { padding-bottom: 105px; }
.blog-hero p:last-child { max-width: 800px; }
.blog-section-head { max-width: 720px; margin-bottom: 52px; }
.blog-section-head h2 { margin: 0; font-size: clamp(34px, 4vw, 48px); font-weight: 600; line-height: 1.14; letter-spacing: -.02em; }
.blog-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 32px; }
.blog-card { min-width: 0; overflow: hidden; border: 1px solid rgba(0,48,73,.09); border-radius: 26px; background: var(--white); box-shadow: 0 18px 55px rgba(0,48,73,.07); }
.blog-card--featured { display: grid; grid-column: 1 / -1; grid-template-columns: minmax(0, 1.2fr) minmax(340px, .8fr); min-height: 470px; }
.blog-card__image { display: grid; overflow: hidden; min-height: 280px; background: #f1f5f5; place-items: center; }
.blog-card__image img { width: 100%; height: 100%; object-fit: contain; transition: transform .35s ease; }
.blog-card:hover .blog-card__image img { transform: scale(1.025); }
.blog-card__body { padding: 34px 36px 40px; }
.blog-card--featured .blog-card__body { display: flex; flex-direction: column; justify-content: center; padding: 52px; }
.blog-card__meta { display: flex; align-items: center; flex-wrap: wrap; gap: 8px 18px; margin: 0 0 18px; color: #6e7476; font-size: 13px; }
.blog-card__meta span { color: var(--blue); font-weight: 600; }
.blog-card h3 { margin: 0 0 16px; font-size: clamp(24px, 2.4vw, 32px); font-weight: 600; line-height: 1.18; letter-spacing: -.015em; overflow-wrap: normal; }
.blog-card h3 a, .related-grid h3 a { color: inherit; text-decoration: none; }
.blog-card h3 a:hover, .blog-card h3 a:focus-visible, .related-grid h3 a:hover, .related-grid h3 a:focus-visible { color: var(--blue); }
.blog-card__body > p:not(.blog-card__meta) { margin: 0 0 25px; color: var(--muted); font-size: 16px; line-height: 1.65; }

.article-width { width: min(860px, calc(100% - 48px)); margin-inline: auto; }
.article-hero { padding: 105px 0 62px; text-align: left; background: var(--surface); }
.article-breadcrumb { display: flex; gap: 10px; margin-bottom: 42px; color: var(--muted); font-size: 14px; }
.article-breadcrumb a { color: inherit; }
.article-hero h1 { max-width: 820px; margin: 0; font-size: clamp(42px, 6vw, 72px); font-weight: 600; line-height: 1.05; letter-spacing: -.035em; overflow-wrap: normal; }
.article-lead { max-width: 780px; margin: 28px 0 20px; color: #555b5d; font-size: 21px; line-height: 1.55; }
.article-author { margin: 0; color: var(--muted); font-size: 14px; }
.article-author a { color: var(--blue); }
.article-cover { display: grid; min-height: 260px; margin: 58px 0 70px; border-radius: 28px; background: #f1f5f5; box-shadow: 0 24px 70px rgba(0,48,73,.1); place-items: center; }
.article-cover img { display: block; width: auto; max-width: 100%; height: auto; max-height: 620px; margin-inline: auto; border-radius: inherit; object-fit: contain; }
.article-content { padding-bottom: 110px; color: #303638; font-size: 18px; line-height: 1.78; }
.article-content > p, .article-content > ul, .article-content > ol { margin: 0 0 28px; }
.article-content h2 { margin: 70px 0 22px; color: var(--text); font-size: clamp(31px, 4vw, 44px); font-weight: 600; line-height: 1.16; letter-spacing: -.02em; overflow-wrap: normal; }
.article-content h3 { margin: 42px 0 15px; color: var(--text); font-size: 25px; font-weight: 600; line-height: 1.25; }
.article-content ul, .article-content ol { padding-left: 24px; }
.article-content li { margin-bottom: 12px; }
.article-content a { color: var(--blue); text-underline-offset: 3px; }
.article-note { margin: 0 0 42px; padding: 24px 26px; border-left: 3px solid var(--blue-bright); border-radius: 0 16px 16px 0; background: #f2f7f8; color: #445054; font-size: 16px; line-height: 1.65; }
.related-articles { padding: 110px 0; background: var(--surface); }
.related-articles .section-head { margin-bottom: 48px; }
.related-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.related-grid article { padding: 36px 32px 40px; border: 1px solid rgba(0,48,73,.08); border-radius: 22px; background: var(--white); box-shadow: 0 14px 42px rgba(0,48,73,.055); }
.related-grid h3 { margin: 0 0 15px; font-size: 24px; line-height: 1.2; }
.related-grid article > p:not(.blog-card__meta) { min-height: 105px; margin: 0 0 24px; color: var(--muted); line-height: 1.6; }
.home-articles .home-references__action { margin-top: 42px; }
.related-reading { padding: 78px 0; color: var(--white); background: var(--blue-dark); }
.related-reading__inner { display: grid; grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr); align-items: center; gap: 90px; }
.related-reading h2 { margin: 0; font-size: clamp(30px, 3.5vw, 44px); font-weight: 600; line-height: 1.15; }
.related-reading__inner > div:last-child { display: grid; gap: 12px; }
.related-reading__inner > div:last-child a { display: flex; justify-content: space-between; gap: 20px; padding: 17px 0; border-bottom: 1px solid rgba(255,255,255,.24); color: var(--white); font-size: 17px; line-height: 1.4; text-decoration: none; }
.related-reading__inner > div:last-child a::after { color: var(--blue-bright); content: "›"; font-size: 24px; line-height: 1; }
.related-reading__inner > div:last-child a:hover { color: var(--blue-bright); }

@media (max-width: 900px) {
    .blog-card--featured { grid-template-columns: 1fr; }
    .related-grid { grid-template-columns: 1fr; }
    .related-grid article > p:not(.blog-card__meta) { min-height: 0; }
    .related-reading__inner { grid-template-columns: 1fr; gap: 35px; }
    .site-header__inner { grid-template-columns: 1fr auto; }
    .site-nav { display: none; }
    .header-cta { display: none; }
    .js-enabled .mobile-menu-toggle { display: block; }
    .principles { gap: 28px; }
    .focus-section__inner { grid-template-columns: 1fr; padding-top: 100px; }
    .focus-section__copy { max-width: 680px; }
    .focus-visual { min-height: 620px; }
    .device { right: 50%; transform: translateX(50%) rotate(3deg); }
    .section-head, .process-heading { grid-template-columns: 1fr; gap: 25px; }
    .service-list article { grid-template-columns: 1fr 1fr 38px; gap: 25px; }
    .choice__options article { padding-inline: 42px; }
    .about-strip__inner { gap: 65px; }
    .home-about__inner, .about-intro, .detail-grid, .about-philosophy__inner, .contact-layout, .contact-area__inner, .custom-commerce__inner, .contact-form-layout { gap: 60px; }
    .project { gap: 50px; }
    .package { grid-template-columns: 1fr; gap: 45px; }
    .commerce-packages, .maintenance-options { grid-template-columns: repeat(2, 1fr); }
    .commerce-packages article:nth-child(3), .maintenance-options article:nth-child(3) { border-top: 1px solid var(--line); border-left: 0; }
    .commerce-packages article:nth-child(4), .maintenance-options article:nth-child(4) { border-top: 1px solid var(--line); }
    .maintenance-seo__inner { gap: 60px; }
    .landing-packages > article { grid-template-columns: 1fr; }
    .social-package__inner, .budget-section { gap: 60px; }
    .calculator-intro, .trial-note__inner { gap: 60px; }
    .legal-layout { gap: 55px; }
}

@media (max-width: 680px) {
    .blog-grid { grid-template-columns: 1fr; }
    .blog-grid { gap: 22px; }
    .blog-card, .blog-card--featured { display: block; grid-column: auto; min-height: 0; border-radius: 20px; }
    .blog-card__image { min-height: 0; aspect-ratio: auto; }
    .blog-card__image img { width: 100%; height: auto; max-height: none; object-fit: contain; }
    .blog-card__body { padding: 30px 22px 36px; }
    .blog-card--featured .blog-card__body { display: block; padding: 30px 22px 36px; }
    .article-width { width: min(100% - 32px, 860px); }
    .article-hero { padding: 82px 0 50px; }
    .article-hero h1 { font-size: 42px; line-height: 1.08; }
    .article-lead { font-size: 18px; }
    .article-cover { overflow: visible; margin: 38px 0 50px; border-radius: 16px; box-shadow: 0 14px 35px rgba(0,48,73,.08); }
    .article-cover { min-height: 0; }
    .article-cover img { width: auto; max-width: 100%; height: auto; max-height: 70vh; margin-inline: auto; border-radius: inherit; object-fit: contain; }
    .article-content { padding-bottom: 80px; font-size: 17px; }
    .article-content h2 { margin-top: 55px; font-size: 32px; }
    .related-articles { padding: 80px 0; }
    .content-width, .site-header__inner, .page-shell { width: min(var(--container), calc(100% - 32px)); }
    .hero { padding-top: 120px; }
    .hero h1 { font-size: clamp(36px, 9.5vw, 46px); line-height: 1.14; letter-spacing: -.012em; }
    .hero__lead { font-size: 19px; }
    .hero__actions { flex-direction: column; gap: 18px; }
    .hero__brand { min-height: 270px; margin-top: 25px; }
    .hero__brand img { width: 390px; }
    .promise, .services, .choice, .process-section, .pricing-section, .home-references, .final-cta { padding: 95px 0; }
    .promise h2, .services h2, .choice h2, .process-section h2, .pricing-section h2, .about-strip h2, .focus-section h2, .final-cta h2 { font-size: 33px; line-height: 1.18; }
    .section-intro, .choice__intro { font-size: 18px; }
    .principles { grid-template-columns: 1fr; margin-top: 60px; }
    .principles article { display: grid; grid-template-columns: 48px minmax(0, 1fr); align-items: center; gap: 0 15px; }
    .principles h3 { grid-column: 2; margin: 0; }
    .principles p { grid-column: 1 / -1; margin-top: 18px; }
    .focus-section__inner { min-height: auto; padding-top: 85px; gap: 30px; }
    .focus-section__copy > p:not(.section-label) { font-size: 18px; }
    .focus-visual { min-height: 510px; }
    .device { bottom: -65px; width: 330px; height: 490px; border-radius: 45px; }
    .device__screen { padding: 120px 35px 40px; border-radius: 35px; }
    .service-list article { grid-template-columns: 1fr 36px; gap: 14px; padding: 28px 0; }
    .service-list__title { gap: 12px; }
    .service-list p { grid-column: 1 / -1; grid-row: 2; }
    .service-list > article > a { grid-column: 2; grid-row: 1; }
    .choice__options { grid-template-columns: 1fr; margin-top: 55px; }
    .choice__options article { padding: 45px 18px; }
    .choice__options article + article { border-top: 1px solid var(--line); border-left: 0; }
    .choice__options h3 + p { min-height: auto; }
    .process-list { grid-template-columns: 1fr; }
    .process-list li, .process-list li:not(:nth-child(3n + 1)) { min-height: auto; padding: 28px 0; border-left: 0; }
    .pricing-list article { grid-template-columns: 1fr; gap: 8px; padding: 25px 0; }
    .about-strip { padding: 90px 0; }
    .about-strip__inner { grid-template-columns: 1fr; gap: 34px; }
    .about-strip__inner > div:last-child > p { font-size: 18px; }
    .site-footer__main { grid-template-columns: 1fr; gap: 38px; padding: 58px 0 36px; }
    .site-footer__brand { text-align: center; }
    .site-footer__brand > a { display: inline-flex; justify-content: center; }
    .site-footer__brand img { width: 132px; height: auto; }
    .site-footer__brand p { max-width: 290px; margin: 18px auto 0; font-size: 13px; line-height: 1.55; }
    .site-footer__contact { align-items: center; gap: 9px; margin-top: 20px; }
    .site-footer__links { display: grid; width: min(300px, 100%); grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 30px; margin-inline: auto; padding-top: 2px; }
    .site-footer__links div { display: flex; width: 100%; flex-direction: column; align-items: center; gap: 11px; }
    .site-footer__links strong { width: 100%; margin: 0 0 3px; color: var(--text); font-size: 12px; text-align: center; }
    .site-footer__links a { display: block; width: 100%; color: var(--muted); font-size: 11px; line-height: 1.4; text-align: center; text-decoration: none; }
    .site-footer__bottom { align-items: center; flex-direction: column; gap: 13px; padding: 20px 0 28px; text-align: center; }
    .site-footer__bottom nav { display: flex; max-width: 290px; align-items: center; justify-content: center; flex-wrap: wrap; gap: 9px 18px; }
    .site-footer__bottom nav a, .site-footer__bottom nav button { padding: 0; color: #616a66; background: transparent; line-height: 1.4; }
    .home-about { padding: 90px 0; }
    .home-about__inner, .about-intro, .detail-grid, .about-philosophy__inner, .contact-layout, .contact-area__inner, .custom-commerce__inner, .contact-form-layout { grid-template-columns: 1fr; gap: 35px; }
    .contact-form-aside { position: static; }
    .project-form { padding: 0 22px 35px; }
    .form-alert { margin: 22px 22px 0; }
    .form-grid--two, .choice-grid, .choice-grid--three, .checkbox-grid { grid-template-columns: 1fr; }
    .conditional-field { max-width: none; }
    .form-submit-row { align-items: stretch; flex-direction: column; }
    .form-submit-row p { max-width: none; text-align: left; }
    .cookie-consent__bar { right: 12px; bottom: 12px; left: 12px; grid-template-columns: 1fr; gap: 18px; padding: 20px; }
    .cookie-consent__actions { display: grid; grid-template-columns: 1fr 1fr; }
    .cookie-consent__actions [data-cookie-accept] { grid-column: 1 / -1; grid-row: 1; }
    .cookie-settings { padding: 10px; }
    .cookie-settings__panel { max-height: calc(100vh - 20px); padding: 24px 20px; border-radius: 20px; }
    .cookie-settings__actions { align-items: stretch; flex-direction: column; }
    .home-about h2, .home-references h2, .subpage h2 { font-size: 33px; line-height: 1.18; }
    .reference-preview-grid, .expertise-columns { grid-template-columns: 1fr; }
    .reference-preview-grid article { padding: 35px 18px; }
    .reference-preview-grid article + article, .expertise-columns article + article { border-top: 1px solid var(--line); border-left: 0; }
    .reference-preview-grid p:not(.reference-type), .expertise-columns h3 + p { min-height: auto; }
    .subpage-hero { padding: 125px 0 75px; }
    .subpage-hero h1 { font-size: 42px; }
    .subpage-hero p:last-child { font-size: 18px; }
    .subpage-section { padding: 85px 0; }
    .expertise-columns article { padding: 42px 18px; }
    .feature-lines > div { grid-template-columns: 1fr; gap: 9px; }
    .about-philosophy, .contact-area { padding: 85px 0; }
    .project { grid-template-columns: 1fr; gap: 28px; padding: 45px 0; }
    .project__details p { grid-template-columns: 1fr; gap: 5px; }
    .package-list { gap: 55px; }
    .package { gap: 35px; padding-bottom: 55px; }
    .package__details, .package__details--single { grid-template-columns: 1fr; gap: 35px; }
    .price-note { padding: 85px 0; }
    .price-note__inner { grid-template-columns: 1fr; gap: 30px; }
    .faq-list summary { font-size: 18px; }
    .commerce-packages, .maintenance-options, .risk-list { grid-template-columns: 1fr; }
    .commerce-packages article, .maintenance-options article { padding: 35px 18px; }
    .commerce-packages article + article, .commerce-packages article:nth-child(4), .maintenance-options article + article, .maintenance-options article:nth-child(4) { border-top: 1px solid var(--line); border-left: 0; }
    .commerce-packages article > p:not(.reference-type), .maintenance-options article > p:not(.reference-type) { min-height: auto; }
    .comparison-section { padding: 85px 0; }
    .custom-commerce { padding: 85px 0; }
    .risk-list article, .risk-list article:nth-child(even) { min-height: auto; padding: 28px 0; border-left: 0; }
    .maintenance-seo { padding: 85px 0; }
    .maintenance-seo__inner { grid-template-columns: 1fr; gap: 30px; }
    .landing-packages { grid-template-columns: 1fr; }
    .landing-packages > article { padding: 40px 18px; }
    .landing-packages > article + article { border-top: 1px solid var(--line); border-left: 0; }
    .social-package { padding: 85px 0; }
    .social-package__inner, .budget-section { grid-template-columns: 1fr; gap: 35px; }
    .budget-lines > div { align-items: flex-start; flex-direction: column; gap: 7px; }
    .rental-options, .rent-buy-grid, .calculator-intro, .trial-note__inner { grid-template-columns: 1fr; }
    .rental-options article { padding: 38px 18px; }
    .rental-options article + article, .rent-buy-grid article + article { border-top: 1px solid var(--line); border-left: 0; }
    .rent-buy-grid article + article { border-color: rgba(255,255,255,.2); }
    .trial-note { padding: 85px 0; }
    .calculator-section { padding: 85px 0; }
    .calculator-package-options, .feature-checkboxes { grid-template-columns: 1fr; }
    .feature-checkboxes label:nth-child(even) { padding-left: 0; border-left: 0; }
    .feature-checkboxes label { padding-right: 4px; }
    .external-costs > label, .calculator-result__total { align-items: flex-start; flex-direction: column; gap: 10px; padding: 17px 0; }
    .number-input { width: 100%; }
    .number-input input { width: 100%; }
    .calculator-result { padding: 28px 20px; }
    .feature-checkboxes label > span { grid-template-columns: 1fr; gap: 5px; }
    .feature-checkboxes label small, .feature-checkboxes label em { grid-column: 1; white-space: normal; }
    .calculator-scope-note { padding: 24px 20px; }
    .calculator-scope-note li { align-items: flex-start; flex-direction: column; gap: 5px; }
    .calculator-scope-note li strong, .calculator-scope-note li a { text-align: left; }
    .maintenance-choice--card { align-items: flex-start; padding: 22px 20px; }
    .legal-layout { grid-template-columns: 1fr; gap: 40px; }
    .legal-nav { position: static; display: grid; grid-template-columns: 1fr 1fr; }
    .legal-nav strong { grid-column: 1 / -1; }
    .legal-content > section { padding-bottom: 50px; }
    .legal-content > section + section { padding-top: 50px; }
    .legal-data > div { grid-template-columns: 1fr; gap: 6px; }
    .legal-review-note > div { grid-template-columns: 1fr; gap: 8px; }
    .withdrawal-model { padding: 22px 18px; }
}

@media (max-width: 420px) {
    .site-logo { width: 94px; }
    .header-cta { padding-inline: 12px; }
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { transition-duration: .01ms; }
}
