:root { --bg: #f6f7f3; --paper: #ffffff; --ink: #172023; --muted: #56656c; --line: #d8dfdf; --brand: #0f766e; --brand-2: #0ea5a0; --highlight: #ff7a45; --soft: #edf6f6; --shadow-lg: 0 24px 60px rgba(20, 41, 45, 0.12); --shadow-md: 0 14px 32px rgba(20, 41, 45, 0.1); --radius-lg: 1.25rem; --radius-pill: 999px; --shadow-premium: 0 20px 50px rgba(20, 41, 45, 0.08); --header-bg: rgba(255, 255, 255, 0.94); } *, *::before, *::after { box-sizing: border-box; } html, body { margin: 0; padding: 0; } body { font-family: "Manrope", "Segoe UI", sans-serif; color: var(--ink); line-height: 1.62; overflow-x: hidden; padding-bottom: 8.5rem; background: radial-gradient(ellipse 120% 80% at 10% -20%, rgba(14, 165, 160, 0.12), transparent 50%), radial-gradient(ellipse 90% 60% at 100% 0%, rgba(255, 122, 69, 0.1), transparent 45%), linear-gradient(180deg, #fafbf8 0%, var(--bg) 45%, #e8ece8 100%); text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; } .site-loader { position: fixed; inset: 0; z-index: 100000; display: none; align-items: center; justify-content: center; background: radial-gradient(ellipse 120% 70% at 15% 0%, rgba(14, 165, 160, 0.16), transparent 55%), radial-gradient(ellipse 90% 60% at 95% 10%, rgba(255, 122, 69, 0.12), transparent 55%), rgba(255, 255, 255, 0.92); backdrop-filter: blur(14px) saturate(1.15); } .site-loader.is-active { display: flex; } .site-loader-card { width: min(520px, calc(100% - 2rem)); background: rgba(255, 255, 255, 0.92); border: 1px solid rgba(216, 226, 226, 0.85); box-shadow: 0 30px 80px rgba(20, 41, 45, 0.16); border-radius: 1.4rem; padding: 1.25rem 1.2rem; text-align: center; } .site-loader-mark { width: 72px; height: 72px; margin: 0 auto 0.85rem; border-radius: 1.25rem; display: grid; place-items: center; background: linear-gradient(145deg, rgba(15, 118, 110, 0.98), rgba(14, 165, 160, 0.95)); box-shadow: 0 18px 46px rgba(15, 118, 110, 0.26); position: relative; overflow: hidden; } .site-loader-mark::after { content: ""; position: absolute; inset: -40%; background: radial-gradient(circle, rgba(255, 255, 255, 0.45), transparent 55%); animation: loaderSheen 1.2s ease-in-out infinite; } .site-loader-tooth { width: 40px; height: 40px; position: relative; z-index: 1; filter: drop-shadow(0 2px 10px rgba(0, 0, 0, 0.18)); } .site-loader-title { margin: 0; font-family: "Space Grotesk", "Manrope", sans-serif; font-size: 1.05rem; font-weight: 800; letter-spacing: -0.02em; color: #0d4340; } .site-loader-sub { margin: 0.35rem 0 0.9rem; color: var(--muted); font-size: 0.92rem; } .site-loader-dots { display: inline-flex; gap: 0.35rem; align-items: center; justify-content: center; } .site-loader-dots span { width: 9px; height: 9px; border-radius: 50%; background: linear-gradient(135deg, var(--brand), var(--brand-2)); opacity: 0.55; animation: loaderDot 0.95s ease-in-out infinite; } .site-loader-dots span:nth-child(2) { animation-delay: 0.15s; } .site-loader-dots span:nth-child(3) { animation-delay: 0.3s; } .site-loader.is-hiding { animation: loaderFade 0.45s ease forwards; } .call-popup-dialog { border: 0; padding: 0; margin: auto; background: transparent; max-width: calc(100vw - 2rem); } .call-popup-dialog::backdrop { background: rgba(15, 24, 24, 0.45); backdrop-filter: blur(6px); } .call-popup { position: relative; border: 1px solid rgba(216, 226, 226, 0.9); border-radius: 1.15rem; padding: 1.15rem 1.1rem 1.05rem; background: radial-gradient(ellipse 120% 70% at 10% 0%, rgba(14, 165, 160, 0.12), transparent 55%), radial-gradient(ellipse 90% 60% at 95% 10%, rgba(255, 122, 69, 0.1), transparent 55%), #fff; box-shadow: 0 28px 70px rgba(20, 41, 45, 0.18); max-width: 360px; font-size: 0.95rem; } .call-popup h2 { margin: 0 2.25rem 0.55rem 0; font-family: "Space Grotesk", "Manrope", sans-serif; font-weight: 800; letter-spacing: -0.02em; color: #0d4340; font-size: 1.05rem; } .call-popup p { color: var(--muted); margin: 0 0 0.85rem; line-height: 1.55; } .call-popup-actions { display: grid; gap: 0.5rem; } .call-popup .btn { padding-top: 0.7rem; padding-bottom: 0.7rem; } .call-popup-note { display: block; margin-top: 0.75rem; color: rgba(86, 101, 108, 0.88); font-size: 0.78rem; } .call-popup-close { position: absolute; top: 0.55rem; right: 0.55rem; width: 2rem; height: 2rem; border: 0; border-radius: 999px; background: rgba(23, 32, 35, 0.07); color: var(--ink); font-size: 1.35rem; line-height: 1; cursor: pointer; display: grid; place-items: center; transition: background-color 0.2s ease; } .call-popup-close:hover { background: rgba(23, 32, 35, 0.12); } .site-nav-shell { display: flex; align-items: center; justify-content: space-between; width: 100%; gap: 0.85rem; position: relative; } .nav-burger { display: inline-flex; flex-direction: column; justify-content: center; gap: 5px; width: 22px; } .nav-burger span { display: block; height: 2px; border-radius: 2px; background: var(--ink); } @media (max-width: 991px) { .site-header--lite .site-nav-toggle.menu-toggle { display: inline-flex !important; align-items: center; justify-content: center; } .site-header--lite .site-nav-panel.menu { position: absolute; top: 3.4rem; right: 1rem; width: min(94vw, 340px); border: 1px solid #d8e1e0; border-radius: 0.9rem; background: #fff; box-shadow: 0 18px 35px rgba(20, 41, 45, 0.14); padding: 0.5rem; display: none; flex-direction: column; align-items: stretch; z-index: 80; } .site-header--lite .site-nav-panel.menu.open { display: flex; } .site-header--lite .site-nav-panel.menu a { padding: 0.65rem 0.8rem; } .site-header--lite .site-nav-panel .site-nav-cta { width: 100%; margin-top: 0.25rem; margin-left: 0; text-align: center; } } @media (min-width: 992px) { .site-header--lite .site-nav-toggle.menu-toggle { display: none !important; } .site-header--lite .site-nav-panel.menu { position: static; display: flex !important; flex-direction: row; align-items: center; width: auto; margin: 0; box-shadow: none; z-index: auto; } .site-header--lite .site-nav-panel .site-nav-cta { margin-left: 0.35rem; margin-top: 0; } } @keyframes loaderDot { 0%, 100% { transform: translateY(0); opacity: 0.5; } 50% { transform: translateY(-6px); opacity: 1; } } @keyframes loaderFade { to { opacity: 0; visibility: hidden; } } @keyframes loaderSheen { 0% { transform: translate(-18%, -10%) rotate(0deg); opacity: 0.35; } 50% { transform: translate(12%, 10%) rotate(18deg); opacity: 0.55; } 100% { transform: translate(-18%, -10%) rotate(0deg); opacity: 0.35; } } @media (prefers-reduced-motion: reduce) { .site-loader-mark::after, .site-loader-dots span, .site-loader.is-hiding { animation: none !important; } } a { color: inherit; text-decoration: none; } img { display: block; width: 100%; max-width: 100%; } .container { width: min(1140px, calc(100% - 2rem)); margin: 0 auto; } .site-header .container.inner { position: relative; border-radius: 1.15rem; padding-left: 0.85rem; padding-right: 0.85rem; } @media (min-width: 900px) { .site-header { border-bottom: 0; background: transparent; box-shadow: none; } .site-header::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(ellipse 60% 40% at 20% 0%, rgba(14, 165, 160, 0.11), transparent 55%), radial-gradient(ellipse 50% 35% at 85% 0%, rgba(255, 122, 69, 0.09), transparent 55%); } .site-header .inner { margin-top: 0.9rem; border: 1px solid rgba(216, 226, 226, 0.75); background: rgba(255, 255, 255, 0.92); box-shadow: 0 18px 48px rgba(20, 41, 45, 0.08); border-radius: 1.25rem; padding: 0.85rem 0.9rem; } } .menu { gap: 0.25rem; padding: 0.25rem; border-radius: 999px; background: rgba(245, 249, 248, 0.7); border: 1px solid rgba(216, 226, 226, 0.85); } .menu a { border-radius: 999px; padding: 0.52rem 0.78rem; } .menu a:hover { background: rgba(15, 118, 110, 0.08); color: #0d4340; transform: translateY(0); } .menu a.active { background: linear-gradient(135deg, rgba(15, 118, 110, 0.92), rgba(14, 165, 160, 0.92)); box-shadow: 0 10px 28px rgba(15, 118, 110, 0.18); } .menu a.btn.btn-primary { margin-left: 0.2rem; border-radius: 999px; } .btn { border-radius: 0.95rem; } .btn-primary { box-shadow: 0 18px 40px rgba(15, 118, 110, 0.22); } .btn-ghost { border-radius: 0.95rem; box-shadow: 0 10px 22px rgba(20, 41, 45, 0.06); } .hero-home { padding-top: 2.25rem; } .hero-grid-home { gap: 1.25rem; } .hero-copy { background: radial-gradient(ellipse 120% 90% at 10% 15%, rgba(14, 165, 160, 0.16), transparent 56%), linear-gradient(165deg, #ffffff 0%, #f7fbfa 55%, #eef7f5 100%); } .hero-card { border-radius: 1.35rem; } .hero-card::after { height: 48%; background: linear-gradient(180deg, rgba(23, 32, 35, 0) 0%, rgba(10, 20, 20, 0.58) 100%); } .hero-card img { transform: none; } .hero-card:hover img { transform: none; } .signal-band { padding-top: 1.1rem; } .signal-item { border-radius: 1.35rem; } .card { border-radius: 1.25rem; } .card:hover { transform: translateY(-6px); } .section { padding: 2.8rem 0; } .site-header { position: sticky; top: 0; z-index: 70; border-bottom: 1px solid rgba(216, 223, 223, 0.55); background: var(--header-bg); backdrop-filter: blur(18px) saturate(1.15); box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset, 0 8px 28px rgba(20, 41, 45, 0.06); } .site-header .inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.85rem 0; } .navbar { width: 100%; gap: 0.75rem; } .navbar .navbar-brand.brand { flex: 0 1 auto; min-width: 0; } .navbar .navbar-brand.brand span:not(.brand-mark) { display: inline-block; min-width: 0; max-width: 32ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .navbar .navbar-collapse { flex-grow: 0; } .navbar .navbar-nav.menu { flex-wrap: nowrap; white-space: nowrap; } .brand { display: inline-flex; align-items: center; gap: 0.72rem; font-weight: 800; letter-spacing: 0.2px; } .brand-mark { width: 2.2rem; height: 2.2rem; border-radius: 0.72rem; display: grid; place-items: center; font-family: "Space Grotesk", "Manrope", sans-serif; font-size: 0.86rem; color: #fff; background: linear-gradient(145deg, #0f766e 0%, #16b3ac 70%, #23d6c6 100%); box-shadow: 0 10px 24px rgba(15, 118, 110, 0.34); } .menu-toggle { display: none; border: 1px solid var(--line); background: #fff; color: var(--ink); border-radius: 0.68rem; padding: 0.48rem 0.7rem; font-weight: 700; } .navbar .navbar-toggler { border: 1px solid var(--line); background: #fff; border-radius: 0.68rem; padding: 0.48rem 0.7rem; } .navbar .navbar-toggler:focus { box-shadow: 0 0 0 0.2rem rgba(14, 165, 160, 0.22); } .navbar .navbar-toggler-icon { width: 1.25em; height: 1.25em; } .menu { display: flex; align-items: center; gap: 0.55rem; } .menu a { padding: 0.55rem 0.72rem; border-radius: 0.6rem; color: var(--muted); font-weight: 700; transition: background-color 0.22s ease, color 0.22s ease, transform 0.22s ease; } .menu a:hover { color: var(--ink); background: #f2f6f6; transform: translateY(-1px); } .menu a.active { color: #fff; background: linear-gradient(135deg, var(--brand), var(--brand-2)); box-shadow: 0 6px 18px rgba(15, 118, 110, 0.22); } .menu a.btn.btn-primary { color: #fff; background: linear-gradient(135deg, var(--brand) 0%, #159d97 52%, #20c7bd 100%); box-shadow: 0 10px 26px rgba(15, 118, 110, 0.3); padding: 0.62rem 1.05rem; margin-left: 0.35rem; border: 1px solid rgba(255, 255, 255, 0.28); } .menu a.btn.btn-primary:hover { color: #fff; background: linear-gradient(135deg, #0d6d66 0%, #148f8a 52%, #1db8af 100%); filter: none; transform: translateY(-1px); box-shadow: 0 12px 30px rgba(15, 118, 110, 0.34); } .btn { border: 0; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 0.45rem; padding: 0.82rem 1.08rem; border-radius: 0.82rem; font-weight: 800; transition: transform 0.22s ease, box-shadow 0.22s ease, filter 0.22s ease; } .btn:hover { transform: translateY(-2px); } .btn-primary { color: #fff; background: linear-gradient(135deg, #0f766e 0%, #159d97 55%, #20c7bd 100%); box-shadow: 0 12px 26px rgba(15, 118, 110, 0.32); } .btn-primary:hover { filter: brightness(1.05); } .btn-ghost { color: var(--ink); background: linear-gradient(180deg, #f6f9f8 0%, #e9f3f1 100%); border: 1px solid #d4e4e2; } .hero { padding: 3.5rem 0 2.2rem; } .hero-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 1.1rem; align-items: stretch; } .hero-copy { position: relative; overflow: hidden; border-radius: var(--radius-lg); border: 1px solid rgba(220, 228, 228, 0.95); background: linear-gradient(165deg, #ffffff 0%, #f7fbfa 55%, #eef7f5 100%); box-shadow: var(--shadow-lg), 0 0 0 1px rgba(255, 255, 255, 0.65) inset; padding: 1.65rem 1.55rem; } .hero-copy::before { content: ""; position: absolute; width: 280px; height: 280px; right: -110px; top: -130px; border-radius: 999px; background: radial-gradient(circle, rgba(14, 165, 160, 0.28) 0%, rgba(14, 165, 160, 0) 70%); pointer-events: none; } .badge { display: inline-block; padding: 0.36rem 0.72rem; border-radius: 999px; border: 1px solid #cae4e1; background: #e8f6f3; color: #0a6962; font-family: "Space Grotesk", "Manrope", sans-serif; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.35px; } h1, h2, h3 { font-family: "Space Grotesk", "Manrope", sans-serif; letter-spacing: -0.02em; } h1 { margin: 0.9rem 0 0.78rem; line-height: 1.12; font-size: clamp(1.82rem, 2.7vw, 2.78rem); font-weight: 800; } .hero-title { margin: 0.35rem 0 0.5rem; } .hero-status-pill { display: inline-flex; align-items: center; gap: 0.45rem; background: #fef2f2; color: #dc2626; padding: 0.48rem 1.1rem; border-radius: var(--radius-pill); font-weight: 800; font-size: clamp(0.92rem, 2vw, 1.05rem); margin: 0 0 1.2rem; border: 1px solid #fee2e2; letter-spacing: 0.01em; box-shadow: 0 8px 22px rgba(220, 38, 38, 0.09); } .hero-copy-home .hero-copy > p { margin: 0; font-size: 1.05rem; line-height: 1.68; color: #3a4f55; max-width: 38rem; } .hero-card-main img { width: 100%; height: auto; border-radius: 14px; } h2 { margin: 0 0 0.7rem; line-height: 1.2; font-size: clamp(1.36rem, 2.05vw, 1.88rem); } .hero-actions { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: 0.72rem; } .hero-actions .btn { min-height: 3rem; } .hero-card { position: relative; overflow: hidden; border-radius: var(--radius-lg); border: 1px solid rgba(220, 228, 228, 0.95); box-shadow: var(--shadow-lg), 0 0 0 1px rgba(255, 255, 255, 0.4) inset; } .hero-card::after { content: ""; position: absolute; inset: auto 0 0; height: 42%; background: linear-gradient(180deg, rgba(23, 32, 35, 0) 0%, rgba(23, 32, 35, 0.55) 100%); pointer-events: none; } .hero-card img { height: 100%; min-height: 300px; object-fit: cover; transform: scale(1.03); transition: transform 0.45s ease; } .hero-card:hover img { transform: scale(1.08); } .hero-home { padding-top: 2.8rem; } .hero-topline { display: flex; flex-wrap: wrap; gap: 0.55rem; margin-bottom: 0.9rem; } .hero-topline span { padding: 0.38rem 0.68rem; border-radius: 999px; background: rgba(255, 255, 255, 0.88); border: 1px solid rgba(216, 228, 226, 0.95); color: #0a5f59; font-size: 0.78rem; font-weight: 700; box-shadow: 0 4px 14px rgba(15, 118, 110, 0.07); backdrop-filter: blur(8px); } .hero-grid-home { grid-template-columns: 1.06fr 0.94fr; } .hero-copy-home { min-height: 100%; } .hero-stage { position: relative; min-height: 100%; } .hero-card-main { height: 100%; } .hero-points { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.75rem; margin-top: 1rem; } .hero-point { padding: 0.85rem 0.9rem; border-radius: 0.95rem; border: 1px solid #d7e4e2; background: rgba(255, 255, 255, 0.82); } .hero-point strong { display: block; margin-bottom: 0.18rem; font-size: 0.97rem; } .hero-point span { color: var(--muted); font-size: 0.88rem; } .floating-note { position: absolute; max-width: 220px; padding: 0.85rem 0.95rem; border-radius: 1rem; background: rgba(255, 255, 255, 0.9); border: 1px solid #d8e3e2; box-shadow: var(--shadow-md); } .floating-note strong { display: block; margin-bottom: 0.2rem; font-size: 0.95rem; } .floating-note span { color: var(--muted); font-size: 0.86rem; } .floating-note-top { top: 1rem; left: -1rem; } .floating-note-bottom { right: -0.6rem; bottom: 1rem; } .signal-band { padding: 0.6rem 0 0; } .signal-band-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.85rem; } .signal-item { padding: 1.35rem 1.2rem; border-radius: var(--radius-lg); color: #ecf7f5; background: linear-gradient(155deg, #0f2326 0%, #143d3f 42%, #126f68 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 22px 48px rgba(12, 28, 30, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.07); } .signal-icon { font-size: 1.6rem; line-height: 1; margin-bottom: 0.45rem; filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.22)); } .signal-item p { margin: 0.7rem 0 0; font-size: 0.92rem; line-height: 1.58; color: rgba(236, 247, 245, 0.9); } .signal-item strong { display: block; margin-bottom: 0.18rem; font-size: 1rem; } .signal-item span { color: rgba(236, 247, 245, 0.78); font-size: 0.9rem; } .section-soft { position: relative; } .section-soft::before { content: ""; position: absolute; inset: 1rem 0 1rem; background: linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(237, 246, 246, 0.66)); border-top: 1px solid #dbe6e4; border-bottom: 1px solid #dbe6e4; z-index: -1; } .section-dark { position: relative; color: #f3f8f8; } .section-dark::before { content: ""; position: absolute; inset: 0; background: linear-gradient(145deg, #112326 0%, #14383b 56%, #0f6660 100%); z-index: -1; } .section-head-split { display: flex; align-items: end; justify-content: space-between; gap: 1rem; } .section-head-split p { max-width: 440px; } .eyebrow { display: inline-block; margin-bottom: 0.45rem; color: #0e6a64; font-size: 0.8rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; } .eyebrow-dark { color: #8ce8df; } .section-head-dark p { color: rgba(243, 248, 248, 0.72); } .card-strong, .guide-card { position: relative; overflow: hidden; } .card-kicker { display: inline-flex; align-items: center; justify-content: center; min-width: 2.1rem; height: 2.1rem; margin-bottom: 0.65rem; padding: 0 0.75rem; border-radius: 999px; background: #e8f6f3; color: #0e6963; font-size: 0.76rem; font-weight: 800; } .card-strong::after, .guide-card::after { content: ""; position: absolute; inset: 0 auto auto 0; width: 100%; height: 4px; background: linear-gradient(90deg, #10938b, #ff7a45); } .process-card-strong { position: relative; color: #172023; background: linear-gradient(180deg, #ffffff 0%, #f5fbfb 100%); } .process-no { display: inline-block; margin-bottom: 0.7rem; font-size: 0.78rem; font-weight: 800; letter-spacing: 0.08em; color: #0d6862; } .text-link { color: #0b6a64; font-weight: 800; } .text-link:hover { color: #0a5853; } .contact-box-home { align-items: stretch; } .contact-card-rich { background: linear-gradient(180deg, #ffffff 0%, #f8fbfb 100%); } .contact-strong-home { min-height: 100%; } .btn-ghost-light { color: #fff; background: rgba(255, 255, 255, 0.12); border: 1px solid rgba(255, 255, 255, 0.2); } .section { padding: 2.35rem 0; } @supports (content-visibility: auto) { .section, .blog-article, .site-footer { content-visibility: auto; contain-intrinsic-size: 900px; } .hero { content-visibility: visible; contain-intrinsic-size: auto; } } .section-head { margin-bottom: 1.15rem; } .section-head p { margin: 0; color: var(--muted); } .section .section-head h2 { position: relative; padding-bottom: 0.1rem; } .section .section-head h2::after { content: ""; display: block; width: 3.25rem; height: 3px; border-radius: var(--radius-pill); margin-top: 0.75rem; background: linear-gradient(90deg, var(--brand), var(--highlight)); } .faq-pro-card { background: var(--paper); padding: 1.55rem 1.45rem; border-radius: var(--radius-lg); border: 1px solid rgba(216, 226, 226, 0.98); box-shadow: var(--shadow-premium); transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease; } .faq-pro-card:hover { transform: translateY(-3px); border-color: #b6d6d3; box-shadow: 0 26px 55px rgba(20, 41, 45, 0.11); } .faq-pro-card h3 { color: var(--brand); margin: 0 0 0.75rem; font-size: 1.08rem; line-height: 1.28; } .faq-pro-card p { margin: 0; font-size: 0.95rem; line-height: 1.65; color: var(--muted); } .grid-3, .grid-2, .kpi { display: grid; gap: 0.9rem; } .grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); } .grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); } .card { border: 1px solid rgba(216, 226, 226, 0.95); border-radius: var(--radius-lg); padding: 1.15rem 1.12rem; background: #fff; box-shadow: var(--shadow-premium); transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease; } .card:hover { transform: translateY(-4px); border-color: #b6d6d3; box-shadow: 0 22px 40px rgba(20, 41, 45, 0.16); } .card h3 { margin: 0 0 0.45rem; font-size: 1.03rem; } .card p { margin: 0; color: var(--muted); } .card p + p { margin-top: 0.55rem; } .card strong { color: #0d6862; } .kpi { grid-template-columns: repeat(4, minmax(0, 1fr)); } .kpi .item { border: 1px solid #d7e2e1; border-radius: 0.95rem; background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%); padding: 0.92rem; text-align: center; box-shadow: 0 10px 24px rgba(20, 41, 45, 0.08); } .kpi strong { display: block; margin-bottom: 0.16rem; font-size: 1.03rem; color: #0d4340; } .kpi span { color: var(--muted); font-size: 0.9rem; } .faq details { border: 1px solid #d6e1e0; border-radius: 0.86rem; background: #fff; box-shadow: 0 10px 24px rgba(20, 41, 45, 0.06); padding: 0.78rem 0.9rem; } .faq details + details { margin-top: 0.58rem; } .faq summary { cursor: pointer; font-weight: 800; list-style: none; } .faq summary::-webkit-details-marker { display: none; } .faq p { margin: 0.62rem 0 0; color: var(--muted); } .contact-box { border: 1px solid #d8e1e0; border-radius: 1rem; background: #fff; box-shadow: var(--shadow-md); padding: 1rem; display: grid; grid-template-columns: 1fr 1fr; gap: 0.9rem; align-items: start; } .contact-strong { position: relative; overflow: hidden; border-radius: 1rem; padding: 1.08rem; color: #fff; background: linear-gradient(145deg, #0c5852 0%, #0f766e 45%, #17a69f 100%); } .contact-strong::after { content: ""; position: absolute; width: 230px; height: 230px; right: -110px; bottom: -120px; border-radius: 50%; background: radial-gradient(circle, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0) 72%); } .contact-strong h3 { margin: 0 0 0.4rem; font-size: 1.22rem; } .site-footer { margin-top: 2.1rem; padding: 3.5rem 0 9rem; text-align: center; background: linear-gradient(180deg, #141c1c 0%, #0a0e0e 100%); color: rgba(255, 255, 255, 0.72); border-top: 1px solid rgba(140, 232, 223, 0.14); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04); } .site-footer .footer-title { display: block; color: #fff; font-weight: 800; letter-spacing: -0.02em; font-size: 1.2rem; } .site-footer .footer-title-sm { font-size: 1.1rem; } .site-footer strong { color: #fff; } .site-footer p { margin: 0.55rem 0 0; color: rgba(255, 255, 255, 0.62); } .site-footer nav { margin-top: 1.1rem; } .site-footer .small-links { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 0.55rem 0.65rem; max-width: 52rem; margin: 0 auto; } .site-footer .small-links a { display: inline-flex; align-items: center; gap: 0.45rem; color: #b6fff8; font-weight: 600; font-size: 0.88rem; padding: 0.4rem 1rem; border-radius: var(--radius-pill); border: 1px solid rgba(140, 232, 223, 0.28); background: rgba(140, 232, 223, 0.1); text-decoration: none; transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease; } .site-footer .small-links a:hover { color: #e8fffc; border-color: rgba(182, 255, 248, 0.45); background: rgba(140, 232, 223, 0.18); } .site-footer-copy { font-size: 0.85rem; margin-top: 1.1rem; color: rgba(255, 255, 255, 0.48); } .small-links { display: flex; flex-wrap: wrap; gap: 0.72rem; margin-top: 0.45rem; } .small-links a { color: #0e6761; font-weight: 700; } @keyframes floatIn { from { transform: translateY(8px); opacity: 0; } to { transform: translateY(0); opacity: 1; } } .hero-copy, .hero-card, .card, .kpi .item { animation: floatIn 0.55s ease both; } @media (max-width: 980px) { .hero-grid { grid-template-columns: 1fr; } .hero-card img { min-height: 260px; } .kpi { grid-template-columns: repeat(2, minmax(0, 1fr)); } .signal-band-grid, .hero-points { grid-template-columns: 1fr; } .floating-note-top, .floating-note-bottom { position: static; margin-top: 0.7rem; max-width: none; } .section-head-split { align-items: start; flex-direction: column; } } @media (max-width: 760px) { .menu-toggle { display: inline-flex; } .menu { position: absolute; top: 3.4rem; right: 1rem; width: min(94vw, 340px); border: 1px solid #d8e1e0; border-radius: 0.9rem; background: #fff; box-shadow: 0 18px 35px rgba(20, 41, 45, 0.14); padding: 0.5rem; display: none; flex-direction: column; align-items: stretch; z-index: 80; } .menu a { padding: 0.65rem 0.8rem; } .menu.open { display: flex; } .menu a.btn { width: 100%; margin-top: 0.25rem; } .grid-3, .grid-2, .kpi, .contact-box, .signal-band-grid, .hero-points { grid-template-columns: 1fr; } .hero { padding-top: 2rem; } .hero-actions { flex-direction: column; } .hero-actions .btn { width: 100%; } .hero-topline { gap: 0.45rem; } .floating-note { position: static; max-width: none; margin-top: 0.7rem; } } @media (max-width: 520px) { .site-header .inner { padding: 0.7rem 0; } .brand { gap: 0.6rem; } .brand-mark { width: 2rem; height: 2rem; border-radius: 0.65rem; } .hero-copy { padding: 1.25rem 1.15rem; } .hero-card img { min-height: 220px; } .signal-item { padding: 1.15rem 1.05rem; } .card { padding: 1.05rem 1rem; } .contact-box { padding: 0.9rem; } .site-footer { padding: 3rem 0 9rem; } } @media (max-width: 420px) { .menu { right: 0.75rem; width: min(96vw, 360px); } .hero-status-pill { padding: 0.45rem 0.9rem; } .hero-copy-home .hero-copy > p { font-size: 1rem; } .footer-info-bar { font-size: 0.72rem; padding: 0.5rem 0.6rem; } } .fixed-action-footer { position: fixed; bottom: 0; left: 0; width: 100%; z-index: 9999; box-shadow: 0 -12px 40px rgba(17, 33, 38, 0.14); font-family: "Space Grotesk", "Manrope", sans-serif; display: flex; flex-direction: column; align-items: stretch; background: #fff; border-top: 1px solid rgba(216, 226, 226, 0.85); padding-left: env(safe-area-inset-left, 0); padding-right: env(safe-area-inset-right, 0); } .fixed-action-footer span { margin-right: 6px; font-size: 1.1rem; } .footer-info-bar { background: linear-gradient(90deg, #0a1212 0%, #0f2222 50%, #0a1212 100%); color: #fff; text-align: center; font-size: 0.8rem; padding: 0.72rem max(1rem, env(safe-area-inset-left, 0px)) 0.72rem max(1rem, env(safe-area-inset-right, 0px)); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; width: 100%; line-height: 1.45; box-sizing: border-box; } .fixed-action-footer a { display: flex; align-items: center; justify-content: center; color: #fff; text-decoration: none; font-weight: 700; font-size: 0.95rem; transition: filter 0.24s ease, background-color 0.24s ease; padding: 0.7rem 0.65rem; gap: 0.35rem; box-sizing: border-box; } .fixed-action-footer a:hover { filter: brightness(1.05); } .call-top-btn { background-color: #dc2626; } .bottom-split-btns { display: flex; width: 100%; } .bottom-split-btns a { flex: 1; } .bottom-split-btns .call { background: linear-gradient(180deg, #f43f5e 0%, #dc2626 55%, #b91c1c 100%); border-right: 1px solid rgba(255, 255, 255, 0.2); } .bottom-split-btns .wa { background: linear-gradient(135deg, #16a34a, #22c55e 45%, #27d466 100%); } .bottom-split-btns .map-btn { background-color: #003366; } @media (min-width: 761px) { body { padding-bottom: 95px !important; } .bottom-split-btns { height: 55px; } .bottom-split-btns .wa { border-left: 1px solid rgba(255, 255, 255, 0.2); } } @media (max-width: 760px) { body { padding-bottom: 125px !important; } .bottom-split-btns a { min-height: calc(3.5rem + env(safe-area-inset-bottom, 0px)); padding-bottom: env(safe-area-inset-bottom, 0px); } .bottom-split-btns .wa { border-left: 1px solid rgba(255, 255, 255, 0.16); } } html { scroll-behavior: smooth; } :focus-visible { outline: 2px solid var(--brand-2); outline-offset: 2px; } a:focus-visible, button:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; } @media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } .hero-copy, .hero-card, .card, .kpi .item { animation: none; } .hero-card img { transition: none; } } .fab { position: fixed; bottom: 1rem; right: 1rem; z-index: 9999; display: flex; flex-direction: column; gap: 0.5rem; } .fab a { display: flex; align-items: center; justify-content: center; padding: 0.7rem 1.2rem; border-radius: 999px; color: #fff; font-weight: 700; font-size: 0.88rem; text-decoration: none; box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2); transition: transform 0.22s ease, box-shadow 0.22s ease; } .fab a:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0, 0, 0, 0.25); } .fab .wa { background: linear-gradient(135deg, #1faa52, #27d466); } .fab .ph { background: linear-gradient(135deg, #dc2626, #ef4444); } .scroll-progress { position: fixed; top: 0; left: 0; width: 0%; height: 3px; background: linear-gradient(90deg, #0f766e, #0ea5a0, #ff7a45); z-index: 99999; transition: width 0.1s linear; } .back-to-top { position: fixed; bottom: 160px; right: 1.2rem; width: 44px; height: 44px; border-radius: 50%; border: 1px solid #d0e2e0; background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(8px); color: var(--brand); font-size: 1.3rem; display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 6px 20px rgba(15, 118, 110, 0.15); opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease; z-index: 9998; } .back-to-top.visible { opacity: 1; visibility: visible; transform: translateY(0); } .back-to-top:hover { background: var(--brand); color: #fff; border-color: var(--brand); } .blog-filter-bar { display: flex; flex-wrap: wrap; gap: 0.5rem; justify-content: center; margin-top: 1rem; } .blog-filter-btn { border: 1px solid #d0e2e0; background: #fff; color: var(--muted); padding: 0.45rem 1rem; border-radius: 999px; font-size: 0.82rem; font-weight: 700; cursor: pointer; transition: all 0.22s ease; font-family: inherit; } .blog-filter-btn:hover { border-color: var(--brand); color: var(--brand); } .blog-filter-btn.active { background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #fff; border-color: transparent; } .blog-card-readtime { display: inline-flex; align-items: center; gap: 0.3rem; font-size: 0.72rem; color: var(--muted); font-weight: 600; } .blog-card-link { display: inline-flex; align-items: center; gap: 0.3rem; color: var(--brand); font-weight: 800; font-size: 0.85rem; margin-top: 0.5rem; transition: gap 0.2s ease; } .blog-card-link:hover { gap: 0.5rem; } .related-articles { margin-top: 1.5rem; padding-top: 1.2rem; border-top: 1px solid #e8f0ef; } .related-articles h4 { font-size: 0.88rem; color: var(--muted); font-weight: 700; margin: 0 0 0.6rem; text-transform: uppercase; letter-spacing: 0.05em; } .related-articles a { display: block; color: var(--brand); font-weight: 700; font-size: 0.9rem; padding: 0.3rem 0; transition: padding-left 0.2s ease; } .related-articles a:hover { padding-left: 0.5rem; } .blog-share { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; } .blog-share a, .blog-share button { display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.4rem 0.8rem; border-radius: 999px; font-size: 0.78rem; font-weight: 700; border: 1px solid #d0e2e0; background: #fff; color: var(--muted); cursor: pointer; transition: all 0.22s ease; font-family: inherit; text-decoration: none; } .blog-share a:hover, .blog-share button:hover { border-color: var(--brand); color: var(--brand); } @media (max-width: 380px) { .container { width: calc(100% - 1rem); } .brand span:not(.brand-mark) { font-size: 0.82rem; } h1 { font-size: 1.55rem; } .hero-actions .btn { font-size: 0.85rem; padding: 0.7rem 0.9rem; } .footer-info-bar { font-size: 11px; } } .blog-hero { padding: 3.5rem 0 1.75rem; text-align: center; } .blog-hero h1 { font-size: clamp(1.8rem, 3vw, 2.6rem); margin-bottom: 0.5rem; } .blog-hero p { color: var(--muted); max-width: 600px; margin: 0 auto; font-size: 1.05rem; } .blog-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; margin-top: 1.5rem; } .blog-card { border: 1px solid rgba(216, 226, 226, 0.98); border-radius: var(--radius-lg); background: #fff; box-shadow: var(--shadow-premium); overflow: hidden; transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease; animation: floatIn 0.55s ease both; cursor: default; } .blog-card:hover { transform: translateY(-6px); border-color: #a8d4cf; box-shadow: 0 28px 56px rgba(20, 41, 45, 0.14); } .blog-card-header { padding: 1.2rem 1.4rem 0.6rem; display: flex; align-items: center; gap: 0.6rem; } .blog-card-icon { width: 42px; height: 42px; border-radius: 12px; background: linear-gradient(145deg, #e8f6f3, #d1ede9); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; box-shadow: 0 6px 16px rgba(15, 118, 110, 0.12); } .blog-card-meta { display: flex; flex-direction: column; } .blog-card-category { font-size: 0.72rem; font-weight: 800; color: #0e6a64; text-transform: uppercase; letter-spacing: 0.06em; } .blog-card-date { font-size: 0.78rem; color: var(--muted); } .blog-card-body { padding: 0.4rem 1.4rem 1.4rem; } .blog-card-body h2 { font-size: 1.18rem; margin: 0 0 0.55rem; line-height: 1.3; color: var(--ink); } .blog-card-body p { color: var(--muted); font-size: 0.92rem; line-height: 1.65; margin: 0; } .blog-card-accent { height: 4px; background: linear-gradient(90deg, #10938b, #ff7a45); } .blog-card-full { grid-column: 1 / -1; } .blog-card-full .blog-card-body h2 { font-size: 1.35rem; } .blog-article-section { padding: 2rem 0; } .blog-article { background: #fff; border: 1px solid rgba(216, 226, 226, 0.98); border-radius: var(--radius-lg); padding: 2rem 2.2rem; box-shadow: var(--shadow-premium); margin-bottom: 1.5rem; animation: floatIn 0.55s ease both; } .blog-article h2 { font-size: 1.4rem; margin: 0 0 0.4rem; color: var(--ink); } .blog-article .article-meta { font-size: 0.82rem; color: var(--muted); margin-bottom: 1.2rem; display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; } .blog-article .article-meta span { padding: 0.22rem 0.55rem; background: #e8f6f3; border-radius: 999px; color: #0e6a64; font-weight: 700; font-size: 0.72rem; text-transform: uppercase; } .blog-article h3 { font-size: 1.1rem; margin: 1.4rem 0 0.5rem; color: #0d4340; } .blog-article p { color: #3a4f55; font-size: 0.95rem; line-height: 1.72; margin: 0 0 0.85rem; } .blog-article ul { margin: 0.5rem 0 1rem; padding-left: 1.2rem; color: #3a4f55; font-size: 0.95rem; line-height: 1.72; } .blog-article ul li { margin-bottom: 0.35rem; } .blog-article .article-cta { margin-top: 1.5rem; padding: 1.2rem; background: linear-gradient(145deg, #f0faf9, #e5f4f2); border-radius: 0.9rem; border: 1px solid #cae4e1; text-align: center; } .blog-article .article-cta p { color: #0a5f59; font-weight: 700; font-size: 1rem; margin-bottom: 0.7rem; } .blog-article .highlight-box { background: #fef2f2; border: 1px solid #fee2e2; border-radius: 0.8rem; padding: 1rem 1.2rem; margin: 1rem 0; } .blog-article .highlight-box p { color: #b91c1c; font-weight: 600; margin: 0; } .blog-article .tip-box { background: #f0fdf4; border: 1px solid #d1fae5; border-radius: 0.8rem; padding: 1rem 1.2rem; margin: 1rem 0; } .blog-article .tip-box p { color: #166534; font-weight: 600; margin: 0; } @media (max-width: 760px) { .blog-grid { grid-template-columns: 1fr; } .blog-card-full { grid-column: auto; } .blog-article { padding: 1.4rem 1.2rem; } }