:root {
  --o3-green: #00b14f;
  --o3-green-soft: #e9fff2;
  --o3-green-strong: #008f3f;
  --o3-ink: #17232c;
  --o3-muted: #66727d;
  --o3-soft: #f5f7f8;
  --o3-line: #dfe7e2;
  --o3-card: #ffffff;
  --o3-shadow: 0 14px 34px rgba(17, 24, 32, .075);
  --o3-radius: 16px;
}
* { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  font-size: 92.5%;
}
body {
  margin: 0;
  font-family: "Aptos", "Segoe UI", system-ui, sans-serif;
  background: #fff;
  color: var(--o3-ink);
  min-height: 100vh;
}
a { color: inherit; }
.text-muted { color: var(--o3-muted) !important; }
.o3-shell {
  overflow-x: clip;
  background: #fff;
}
.o3-navbar {
  position: sticky;
  top: 0;
  z-index: 1030;
  background: rgba(255, 255, 255, .84);
  -webkit-backdrop-filter: saturate(135%) blur(18px);
  backdrop-filter: saturate(135%) blur(18px);
  border-bottom: 1px solid rgba(223, 231, 226, .84);
  box-shadow: 0 10px 30px rgba(17, 24, 32, .055);
}
@supports not (backdrop-filter: blur(1px)) {
  .o3-navbar {
    background: rgba(255, 255, 255, .97);
  }
}
.o3-brand {
  color: var(--o3-ink);
  font-weight: 900;
  letter-spacing: -.04em;
  font-size: 1.55rem;
  display: inline-flex;
  align-items: center;
  min-height: 46px;
}
.o3-brand span { color: var(--o3-green); }
.o3-brand-logo {
  display: block;
  width: auto;
  height: 46px;
  object-fit: contain;
}
.o3-brand-logo--white { filter: none; }
.o3-nav-link {
  color: #1b252d;
  text-decoration: none;
  font-weight: 680;
  font-size: .94rem;
}
.o3-nav-link:hover { color: var(--o3-green); }
.o3-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  border-radius: 10px;
  padding: .78rem 1.08rem;
  font-weight: 760;
  text-decoration: none;
  border: 1px solid transparent;
  transition: .18s ease;
}
.o3-btn-primary {
  background: var(--o3-green);
  color: #fff;
  box-shadow: 0 10px 24px rgba(0, 177, 79, .22);
}
.o3-btn-primary:hover { background: var(--o3-green-strong); color: #fff; transform: translateY(-1px); }
.o3-btn-ghost { border-color: #cfdad3; color: var(--o3-ink); background: #fff; }
.o3-btn-ghost:hover { border-color: var(--o3-green); color: var(--o3-green-strong); background: var(--o3-green-soft); }
.o3-scroll-top {
  position: fixed;
  right: clamp(.9rem, 2vw, 1.35rem);
  bottom: calc(env(safe-area-inset-bottom, 0px) + clamp(.9rem, 2vw, 1.35rem));
  z-index: 990;
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(0, 177, 79, .24);
  border-radius: 999px;
  background: rgba(255, 255, 255, .86);
  color: var(--o3-green-strong);
  box-shadow: 0 12px 28px rgba(17, 24, 32, .12);
  -webkit-backdrop-filter: saturate(135%) blur(14px);
  backdrop-filter: saturate(135%) blur(14px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(12px) scale(.96);
  transition: opacity .2s ease, transform .2s ease, visibility .2s ease, border-color .18s ease, background .18s ease;
}
.o3-scroll-top.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}
.o3-scroll-top:hover,
.o3-scroll-top:focus-visible {
  border-color: var(--o3-green);
  background: rgba(233, 255, 242, .96);
  color: var(--o3-green-strong);
  outline: none;
  box-shadow: 0 0 0 .18rem rgba(0, 177, 79, .14), 0 14px 32px rgba(17, 24, 32, .14);
}
.o3-scroll-top i {
  font-size: 1.55rem;
  line-height: 1;
}
.o3-menu-toggle {
  width: 44px;
  height: 44px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 0;
  border: 1px solid #cfdad3;
  border-radius: 12px;
  background: #fff;
  color: var(--o3-ink);
  transition: .18s ease;
}
.o3-menu-toggle-line {
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}
.o3-menu-toggle:hover,
.o3-menu-toggle:focus-visible {
  border-color: var(--o3-green);
  background: var(--o3-green-soft);
  color: var(--o3-green-strong);
  outline: none;
  box-shadow: 0 0 0 .18rem rgba(0, 177, 79, .14);
}
.o3-mobile-nav {
  --bs-offcanvas-width: min(420px, calc(100vw - .75rem));
  border-left: 1px solid var(--o3-line);
  background: #fff;
  color: var(--o3-ink);
}
.o3-mobile-nav__header {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 1rem .75rem;
  border-bottom: 1px solid var(--o3-line);
}
.o3-mobile-nav__header .o3-brand {
  min-height: 44px;
  min-width: 0;
}
.o3-mobile-nav__header .o3-brand-logo {
  height: 44px;
}
.o3-mobile-nav__close {
  width: 42px;
  height: 42px;
  margin-left: auto;
  flex: 0 0 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #d8e3dc;
  border-radius: 12px;
  background: #fff;
  color: var(--o3-ink);
  transition: .18s ease;
}
.o3-mobile-nav__close:hover,
.o3-mobile-nav__close:focus-visible {
  border-color: var(--o3-green);
  background: var(--o3-green-soft);
  color: var(--o3-green-strong);
  outline: none;
  box-shadow: 0 0 0 .18rem rgba(0, 177, 79, .14);
}
.o3-mobile-nav__body {
  padding: 1rem;
}
.o3-mobile-nav__links {
  display: grid;
  gap: .58rem;
}
.o3-mobile-nav__item {
  min-height: 54px;
  display: flex;
  align-items: center;
  gap: .72rem;
  width: 100%;
  padding: .7rem .78rem;
  border: 1px solid #dfe7e2;
  border-radius: 12px;
  background: #fbfdfb;
  color: var(--o3-ink);
  text-decoration: none;
  font-weight: 780;
  line-height: 1.18;
  transition: .18s ease;
}
.o3-mobile-nav__item:hover,
.o3-mobile-nav__item:focus-visible {
  border-color: var(--o3-green);
  background: var(--o3-green-soft);
  color: var(--o3-green-strong);
  outline: none;
}
.o3-mobile-nav__item--primary {
  border-color: var(--o3-green);
  background: var(--o3-green);
  color: #fff;
  box-shadow: 0 10px 24px rgba(0, 177, 79, .2);
}
.o3-mobile-nav__item--primary:hover,
.o3-mobile-nav__item--primary:focus-visible {
  border-color: var(--o3-green-strong);
  background: var(--o3-green-strong);
  color: #fff;
}
.o3-mobile-nav__icon {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #d6e6dd;
  color: var(--o3-green-strong);
  font-size: 1rem;
}
.o3-mobile-nav__item--primary .o3-mobile-nav__icon {
  border-color: rgba(255, 255, 255, .34);
  background: rgba(255, 255, 255, .16);
  color: #fff;
}
.o3-mobile-nav__label {
  min-width: 0;
  overflow-wrap: anywhere;
}
.o3-hero {
  position: relative;
  padding: 4.8rem 0 3.8rem;
  overflow-x: clip;
  background:
    linear-gradient(90deg, #fff 0%, #fff 52%, rgba(0, 177, 79, .1) 52%, rgba(0, 177, 79, .1) 100%),
    radial-gradient(circle at 84% 18%, rgba(0, 177, 79, .2), transparent 28rem);
}
.o3-grid-bg:before { display: none; }
.o3-kicker {
  display: inline-flex;
  align-items: center;
  color: var(--o3-green-strong);
  background: var(--o3-green-soft);
  border: 1px solid #c9f4d9;
  border-radius: 8px;
  padding: .32rem .55rem;
  font-weight: 760;
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.o3-title {
  font-size: clamp(2.65rem, 5.9vw, 5.45rem);
  line-height: .98;
  letter-spacing: -.062em;
  font-weight: 820;
  margin: 1rem 0;
  color: #17232c;
  max-width: 100%;
}
.o3-title span { display: block; }
.o3-subtitle {
  font-size: clamp(1rem, 1.55vw, 1.2rem);
  color: var(--o3-muted);
  max-width: 760px;
}
.o3-card {
  border: 1px solid var(--o3-line);
  background: var(--o3-card);
  box-shadow: var(--o3-shadow);
  border-radius: var(--o3-radius);
}
.o3-choice-card { min-height: 360px; padding: 1.7rem; position: relative; overflow: hidden; }
.o3-choice-card:after { display: none; }
.o3-choice-card.is-disabled {
  opacity: .72;
}
.o3-price { font-size: 1.08rem; font-weight: 850; color: var(--o3-green-strong); }
.o3-btn-disabled {
  cursor: default;
  pointer-events: none;
}
.o3-badge {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  border: 1px solid #cde7d7;
  background: #f3fff7;
  color: #174f2e;
  border-radius: 8px;
  padding: .42rem .62rem;
  font-weight: 750;
  font-size: .8rem;
  margin: .16rem;
  max-width: 100%;
}
.o3-hero-badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .42rem;
}
.o3-hero-badges .o3-badge,
.o3-hero-badges .o3-kicker {
  margin: 0;
}
.o3-badge--crossed {
  color: #7a868f;
  background: #f7faf8;
  border-color: #d9e4de;
  text-decoration-line: line-through;
  text-decoration-thickness: .11em;
  text-decoration-color: #97a3ad;
}
.o3-hero-promo-badge {
  color: #9a3a0a;
  background: #fff3e8;
  border-color: #ffd8b7;
}
.o3-addon-choice {
  padding-right: .42rem;
}
.o3-addon-price {
  display: inline-flex;
  align-items: center;
  min-height: 1.3rem;
  border-radius: 999px;
  padding: .16rem .38rem;
  background: #fff;
  border: 1px solid #d8e5de;
  color: var(--o3-muted);
  font-size: .68rem;
  font-weight: 820;
  line-height: 1;
}
.o3-addon-price.is-free {
  color: var(--o3-green-strong);
  background: var(--o3-green-soft);
  border-color: #c9f4d9;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.o3-addon-price.is-request {
  color: #9a3a0a;
  background: #fff3e8;
  border-color: #ffd8b7;
}
.o3-section { padding: 3.8rem 0; }
.o3-section-compact { padding: 3.2rem 0; }
.o3-section:nth-of-type(even) { background: #f6f8f7; }
.o3-section-title {
  font-size: clamp(1.85rem, 3.35vw, 3.25rem);
  letter-spacing: -.048em;
  font-weight: 820;
  color: #17232c;
}
.o3-food-landing-page .o3-hero {
  padding: 4.25rem 0 3.25rem;
}
.o3-food-landing-page .o3-title {
  font-size: clamp(2.35rem, 5.25vw, 4.85rem);
}
.o3-food-landing-page .o3-subtitle {
  font-size: clamp(.96rem, 1.35vw, 1.08rem);
}
.o3-food-landing-page .o3-section {
  padding: 3.35rem 0;
}
.o3-food-landing-page .o3-section-compact {
  padding: 2.85rem 0;
}
.o3-food-landing-page .o3-section-title {
  font-size: clamp(1.68rem, 3vw, 2.9rem);
}
.o3-food-landing-page .o3-mockup {
  min-height: 520px;
}
.o3-food-landing-page .phone {
  width: min(335px, 76vw);
}
.o3-feature { height: 100%; padding: 1.15rem; }
.o3-price-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 1.75rem;
  border-radius: 8px;
  padding: .32rem .58rem;
  border: 1px solid #d8e5de;
  background: #f7faf8;
  color: var(--o3-ink);
  font-weight: 780;
  font-size: .8rem;
  line-height: 1.1;
}
.o3-price-label.is-free {
  color: var(--o3-green-strong);
  background: var(--o3-green-soft);
  border-color: #c9f4d9;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.o3-price-label.is-request {
  color: #9a3a0a;
  background: #fff3e8;
  border-color: #ffd8b7;
}
.o3-feature i {
  display: inline-grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 12px;
  color: var(--o3-green-strong);
  background: var(--o3-green-soft);
  border: 1px solid #c8f0d7;
  font-size: 1.05rem;
}
.o3-mockup {
  position: relative;
  min-height: 560px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.phone {
  width: min(360px, 78vw);
  margin: auto;
  border: 1px solid #dae7df;
  border-radius: 32px;
  background: #fff;
  padding: 10px;
  box-shadow: 0 28px 70px rgba(16, 32, 24, .16);
}
.phone-screen {
  border-radius: 24px;
  background: #f7faf8;
  color: #102018;
  padding: 0;
  overflow: hidden;
  border: 1px solid #e4eee8;
}
.phone-screen-image {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 386 / 800;
  object-fit: cover;
  object-position: top center;
}
.mini-card {
  border-radius: 12px;
  background: #fff;
  border: 1px solid #e4eee8;
  padding: .85rem;
  margin: .75rem 0;
  box-shadow: none;
}
.status-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 8px;
  background: #dfffea;
  color: #07551f;
  padding: .32rem .55rem;
  font-weight: 850;
  font-size: .75rem;
}
.float-card { position: absolute; right: 0; bottom: 56px; padding: 1rem 1.1rem; max-width: 260px; }
.form-control, .form-select {
  border-radius: 10px;
  border: 1px solid #ccd8d1;
  background: #fff;
  color: var(--o3-ink);
}
.form-control:focus, .form-select:focus {
  background: #fff;
  color: var(--o3-ink);
  border-color: var(--o3-green);
  box-shadow: 0 0 0 .22rem rgba(0,177,79,.12);
}
.form-control::placeholder { color: #8b969f; }
.form-select option { color: var(--o3-ink); }
.o3-form-card { padding: 1.25rem; }
.o3-inquiry-feedback {
  border-radius: 12px;
  margin: 0;
  padding: .85rem .95rem;
}
.o3-soft-panel { background: #f7faf8; border: 1px solid var(--o3-line); border-radius: 14px; padding: 1rem; }
.o3-platform-card {
  background:
    radial-gradient(circle at 92% 10%, rgba(0, 177, 79, .14), transparent 18rem),
    #fff;
}
.o3-promo-layer {
  border: 1px solid #ffd8b7;
  background:
    radial-gradient(circle at 90% 20%, rgba(255, 138, 66, .2), transparent 18rem),
    linear-gradient(135deg, #fff3e8, #ffffff);
  border-radius: 18px;
  padding: clamp(1.15rem, 3vw, 2rem);
  box-shadow: 0 14px 32px rgba(154, 58, 10, .1);
}
.o3-promo-layer .o3-kicker {
  color: #9a3a0a;
  background: #fff3e8;
  border-color: #ffd8b7;
}
.o3-promo-layer h2 {
  margin: .7rem 0 .35rem;
  font-weight: 820;
  letter-spacing: -.045em;
  color: #7a2d08;
}
.o3-promo-content {
  color: #8a4b27;
  font-size: 1.05rem;
  line-height: 1.58;
}
.o3-promo-content p {
  margin: 0 0 .72rem;
}
.o3-promo-content p:last-child,
.o3-promo-content ul:last-child,
.o3-promo-content ol:last-child {
  margin-bottom: 0;
}
.o3-promo-content h2,
.o3-promo-content h3 {
  margin: .9rem 0 .42rem;
  color: #7a2d08;
  font-weight: 820;
  letter-spacing: -.025em;
}
.o3-promo-content h2 {
  font-size: clamp(1.3rem, 2vw, 1.7rem);
}
.o3-promo-content h3 {
  font-size: clamp(1.08rem, 1.55vw, 1.32rem);
}
.o3-promo-content ul,
.o3-promo-content ol {
  margin: .65rem 0 .8rem;
  padding-left: 1.2rem;
}
.o3-promo-content li + li {
  margin-top: .25rem;
}
.o3-promo-content strong {
  color: #7a2d08;
  font-weight: 840;
}
.o3-promo-content a {
  color: #9a3a0a;
  font-weight: 780;
  text-underline-offset: .16em;
}
.o3-promo-cta {
  margin-top: 1rem;
  width: fit-content;
}
.o3-footer {
  border-top: 1px solid var(--o3-line);
  padding: 2.35rem 0 1rem;
  color: var(--o3-muted);
  background: #fff;
}
.o3-footer strong { color: var(--o3-ink); }
.o3-footer-main {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: .45rem;
  padding-bottom: 1.15rem;
}
.o3-footer-logo {
  display: inline-block;
  width: auto;
  height: 44px;
  object-fit: contain;
}
.o3-footer-slug {
  margin: 0;
  max-width: 620px;
  font-size: .94rem;
  color: var(--o3-muted);
}
.o3-footer-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .5rem .95rem;
  border-top: 1px solid var(--o3-line);
  padding-top: .8rem;
  font-size: .76rem;
  color: #7a868f;
}
.o3-footer-links a,
.o3-footer-links button {
  color: inherit;
  text-decoration: none;
  border: 0;
  background: transparent;
  padding: 0;
  font: inherit;
}
.o3-footer-links a:hover,
.o3-footer-links button:hover {
  color: var(--o3-green-strong);
}
.news-card img, .customer-card img { width: 100%; height: 210px; object-fit: cover; border-radius: 12px; }
.customer-card img { height: 252px; object-position: top center; }
.customer-card {
  display: flex;
  flex-direction: column;
}
.o3-customer-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .2rem;
  margin: .15rem 0 .85rem;
}
.o3-customer-link {
  align-self: flex-start;
  margin-top: auto;
}
.news-card {
  display: flex;
  flex-direction: column;
}
.o3-read-link {
  margin-top: auto;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0;
}
.o3-read-link:hover {
  color: #fff;
  background: var(--o3-green);
  border-color: var(--o3-green);
}
.o3-legal-bg .o3-shell {
  background:
    radial-gradient(circle at 12% 2%, rgba(0, 177, 79, .12), transparent 24rem),
    linear-gradient(180deg, #ffffff 0%, #f6faf7 100%);
}
.o3-legal-page {
  padding: clamp(2.35rem, 4.7vw, 4.5rem) 0;
}
.o3-legal-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.2rem;
  margin-bottom: 1.25rem;
  padding: clamp(1.15rem, 2.6vw, 2rem);
  border: 1px solid rgba(0, 177, 79, .18);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(240,255,246,.94)),
    radial-gradient(circle at 90% 0%, rgba(0, 177, 79, .16), transparent 18rem);
  box-shadow: 0 16px 34px rgba(17, 24, 32, .06);
}
.o3-legal-hero h1 {
  margin: .75rem 0 .45rem;
  max-width: 760px;
  color: var(--o3-ink);
  font-size: clamp(2rem, 4.6vw, 3.15rem);
  line-height: 1;
  letter-spacing: -.055em;
  font-weight: 840;
}
.o3-legal-hero p {
  max-width: 680px;
  margin: 0;
  color: var(--o3-muted);
  font-size: clamp(.98rem, 1.35vw, 1.08rem);
  line-height: 1.55;
}
.o3-legal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 300px);
  gap: 1rem;
  align-items: start;
}
.o3-legal-body {
  padding: clamp(1.15rem, 2.3vw, 2rem);
  color: #24313a;
  font-size: clamp(.96rem, 1vw, 1.03rem);
  line-height: 1.72;
  overflow-wrap: anywhere;
}
.o3-legal-body h2 {
  margin: 1.85rem 0 .75rem;
  color: var(--o3-ink);
  font-size: clamp(1.18rem, 1.8vw, 1.48rem);
  line-height: 1.16;
  letter-spacing: -.035em;
  font-weight: 830;
}
.o3-legal-body h3 {
  margin: 1.25rem 0 .55rem;
  color: var(--o3-ink);
  font-size: 1.05rem;
  line-height: 1.22;
  font-weight: 790;
}
.o3-legal-body h2:first-child,
.o3-legal-body h3:first-child {
  margin-top: 0;
}
.o3-legal-body p,
.o3-legal-body ul,
.o3-legal-body ol {
  margin-bottom: .95rem;
}
.o3-legal-body ul,
.o3-legal-body ol {
  padding-left: 1.15rem;
}
.o3-legal-body li + li {
  margin-top: .28rem;
}
.o3-legal-body a {
  color: var(--o3-green-strong);
  font-weight: 760;
}
.o3-legal-side {
  position: sticky;
  top: 5.7rem;
  display: grid;
  gap: .8rem;
}
.o3-legal-info {
  padding: 1rem;
  box-shadow: 0 10px 24px rgba(17, 24, 32, .055);
}
.o3-legal-info strong {
  display: block;
  margin: .35rem 0 .28rem;
  color: var(--o3-ink);
  font-size: .98rem;
  line-height: 1.25;
}
.o3-legal-info p,
.o3-legal-info ul {
  margin: .45rem 0 0;
  color: var(--o3-muted);
  font-size: .92rem;
  line-height: 1.48;
}
.o3-legal-info ul {
  padding-left: 1.05rem;
}
.o3-legal-info li + li {
  margin-top: .2rem;
}
.o3-legal-eyebrow {
  display: inline-flex;
  width: fit-content;
  border-radius: 8px;
  padding: .25rem .48rem;
  background: var(--o3-green-soft);
  border: 1px solid #c9f4d9;
  color: var(--o3-green-strong);
  font-size: .7rem;
  font-weight: 820;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.o3-legal-small-link,
.o3-legal-settings {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 2.35rem;
  border-radius: 10px;
  border: 1px solid #cde7d7;
  background: #fff;
  color: var(--o3-green-strong);
  padding: .55rem .75rem;
  font-size: .86rem;
  font-weight: 780;
  line-height: 1;
  text-decoration: none;
}
.o3-legal-small-link:hover,
.o3-legal-settings:hover {
  border-color: var(--o3-green);
  background: var(--o3-green-soft);
  color: var(--o3-green-strong);
}
.legal-content { max-width: 900px; }
.legal-content h2 {
  margin: 2rem 0 .85rem;
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 820;
  color: var(--o3-ink);
}
.legal-content h3 {
  margin: 1.35rem 0 .65rem;
  font-size: 1.12rem;
  font-weight: 780;
  color: var(--o3-ink);
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content a { color: var(--o3-green-strong); font-weight: 700; }
.o3-article-bg .o3-shell {
  background:
    radial-gradient(circle at 8% 0%, rgba(0, 177, 79, .11), transparent 24rem),
    linear-gradient(180deg, #ffffff 0%, #f7faf8 100%);
}
.o3-article-page {
  padding: clamp(1.4rem, 3.8vw, 3.6rem) 0 clamp(2.4rem, 4.6vw, 4.3rem);
}
.o3-article-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(300px, .72fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
  margin-bottom: 1rem;
}
.o3-article-hero.is-text-only {
  grid-template-columns: 1fr;
}
.o3-article-hero.is-text-only .o3-article-hero-copy {
  min-height: clamp(260px, 29vw, 360px);
}
.o3-article-hero-copy {
  min-height: clamp(290px, 35vw, 420px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border: 1px solid rgba(0, 177, 79, .18);
  border-radius: 24px;
  padding: clamp(1.1rem, 3.1vw, 2.35rem);
  background:
    radial-gradient(circle at 92% 10%, rgba(0, 177, 79, .18), transparent 18rem),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(241,255,247,.94));
  box-shadow: 0 16px 34px rgba(17, 24, 32, .065);
}
.o3-article-back {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  width: fit-content;
  margin-bottom: auto;
  border: 1px solid #cde7d7;
  border-radius: 10px;
  padding: .48rem .68rem;
  background: #fff;
  color: var(--o3-green-strong);
  font-size: .86rem;
  font-weight: 780;
  line-height: 1;
  text-decoration: none;
}
.o3-article-back:hover {
  border-color: var(--o3-green);
  background: var(--o3-green-soft);
  color: var(--o3-green-strong);
}
.o3-article-hero h1 {
  max-width: 900px;
  margin: .75rem 0 .58rem;
  color: var(--o3-ink);
  font-size: clamp(1.45rem, 2.85vw, 2.65rem);
  line-height: 1.06;
  letter-spacing: -.046em;
  font-weight: 840;
}
.o3-article-hero p {
  max-width: 760px;
  margin: 0;
  color: var(--o3-muted);
  font-size: clamp(.98rem, 1.2vw, 1.08rem);
  line-height: 1.55;
}
.o3-article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .42rem;
  margin-top: 1.15rem;
}
.o3-article-meta span {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  border: 1px solid #cde7d7;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  color: #244033;
  padding: .38rem .62rem;
  font-size: .8rem;
  font-weight: 760;
  line-height: 1;
}
.o3-article-meta i {
  color: var(--o3-green-strong);
  font-size: .9rem;
}
.o3-article-media {
  min-height: clamp(260px, 35vw, 420px);
  margin: 0;
  border: 1px solid var(--o3-line);
  border-radius: 24px;
  overflow: hidden;
  background: #fff;
  aspect-ratio: 4 / 3;
  box-shadow: 0 16px 34px rgba(17, 24, 32, .075);
}
.o3-article-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
.o3-article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 315px);
  gap: 1rem;
  align-items: start;
}
.o3-article-body {
  padding: clamp(1.1rem, 2.5vw, 2.2rem);
  color: #24313a;
  font-size: clamp(.97rem, 1.05vw, 1.04rem);
  line-height: 1.76;
  overflow-wrap: anywhere;
}
.o3-article-body h2 {
  margin: 2rem 0 .75rem;
  color: var(--o3-ink);
  font-size: clamp(1.28rem, 2vw, 1.72rem);
  line-height: 1.15;
  letter-spacing: -.04em;
  font-weight: 830;
}
.o3-article-body h3 {
  margin: 1.35rem 0 .58rem;
  color: var(--o3-ink);
  font-size: clamp(1.07rem, 1.35vw, 1.22rem);
  line-height: 1.2;
  letter-spacing: -.025em;
  font-weight: 790;
}
.o3-article-body h2:first-child,
.o3-article-body h3:first-child {
  margin-top: 0;
}
.o3-article-body p,
.o3-article-body ul,
.o3-article-body ol {
  margin-bottom: 1rem;
}
.o3-article-body ul,
.o3-article-body ol {
  padding-left: 1.15rem;
}
.o3-article-body li + li {
  margin-top: .28rem;
}
.o3-article-body a {
  color: var(--o3-green-strong);
  font-weight: 760;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}
.o3-article-side {
  position: sticky;
  top: 5.7rem;
  display: grid;
  gap: .8rem;
}
.o3-article-info {
  padding: 1rem;
  box-shadow: 0 10px 24px rgba(17, 24, 32, .055);
}
.o3-article-info strong {
  display: block;
  margin: .42rem 0 .32rem;
  color: var(--o3-ink);
  font-size: 1rem;
  line-height: 1.24;
}
.o3-article-info p {
  margin: 0 0 .85rem;
  color: var(--o3-muted);
  font-size: .92rem;
  line-height: 1.48;
}
.o3-article-info .o3-btn,
.o3-article-info .o3-legal-small-link {
  width: 100%;
}
.o3-article-empty {
  max-width: 720px;
  margin: 0 auto;
  padding: clamp(1.2rem, 3vw, 2rem);
  text-align: center;
}
.o3-article-empty h1 {
  margin: .8rem 0 .45rem;
  color: var(--o3-ink);
  font-size: clamp(1.9rem, 4vw, 3rem);
  line-height: 1.03;
  letter-spacing: -.052em;
  font-weight: 840;
}
.o3-article-empty p {
  max-width: 540px;
  margin: 0 auto 1.1rem;
  color: var(--o3-muted);
}
.o3-root-page .o3-shell {
  background:
    linear-gradient(180deg, #ffffff 0%, #f7faf8 68%, #ffffff 100%);
}
.o3-root-hero {
  min-height: auto;
  display: flex;
  align-items: center;
  padding: clamp(1.2rem, 2.75vw, 2.7rem) 0 clamp(.9rem, 1.9vw, 1.65rem);
  overflow-x: clip;
}
.o3-root-page .o3-title {
  max-width: 790px;
  margin: .82rem 0 .75rem;
}
.o3-root-page .o3-subtitle {
  max-width: 680px;
}
.o3-root-page .o3-hero-badges {
  margin-top: 1rem !important;
  margin-bottom: 1.05rem !important;
}
.o3-root-actions {
  align-items: center;
}
.o3-root-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .72rem;
  margin-top: 1rem;
  max-width: 760px;
}
.o3-root-proof div {
  min-height: 104px;
  border: 1px solid rgba(0, 177, 79, .18);
  border-radius: 14px;
  background: rgba(255, 255, 255, .82);
  padding: .76rem .82rem;
  box-shadow: 0 10px 24px rgba(17, 24, 32, .045);
}
.o3-root-proof strong {
  display: block;
  margin-bottom: .24rem;
  color: var(--o3-ink);
  font-size: .96rem;
}
.o3-root-proof span {
  display: block;
  color: var(--o3-muted);
  font-size: .86rem;
  line-height: 1.34;
}
.o3-root-visual {
  position: relative;
  min-height: clamp(390px, 44vw, 520px);
  display: grid;
  place-items: center;
}
.o3-root-mockup {
  width: 100%;
  min-height: auto;
}
.o3-root-mockup .phone {
  width: min(318px, 67vw);
}
.o3-root-next {
  padding: 0 0 clamp(2rem, 3.4vw, 3rem);
}
.o3-root-hub {
  display: grid;
  gap: .9rem;
  border-top: 1px solid var(--o3-line);
  padding-top: .9rem;
}
.o3-root-package {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(300px, .96fr);
  gap: clamp(.9rem, 2.2vw, 1.45rem);
  align-items: center;
  border: 1px solid rgba(0, 177, 79, .2);
  border-radius: 16px;
  background:
    linear-gradient(135deg, rgba(233, 255, 242, .92) 0%, rgba(255, 255, 255, .98) 58%, #ffffff 100%);
  box-shadow: 0 16px 36px rgba(17, 24, 32, .055);
  padding: clamp(.95rem, 2.15vw, 1.35rem);
}
.o3-root-package-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border: 1px solid #c9f4d9;
  border-radius: 999px;
  background: #fff;
  color: var(--o3-green-strong);
  padding: .36rem .65rem;
  font-size: .78rem;
  font-weight: 820;
}
.o3-root-package h3 {
  max-width: 620px;
  margin: .8rem 0 .55rem;
  color: var(--o3-ink);
  font-size: clamp(1.35rem, 2.5vw, 2.1rem);
  line-height: 1.06;
  letter-spacing: -.045em;
  font-weight: 840;
}
.o3-root-package p {
  max-width: 630px;
  margin: 0;
  color: var(--o3-muted);
  font-size: 1rem;
  line-height: 1.55;
}
.o3-root-package-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .72rem;
  margin-top: 1rem;
}
.o3-root-package-points {
  display: grid;
  gap: .62rem;
}
.o3-root-package-points div {
  display: grid;
  grid-template-columns: 42px 1fr;
  column-gap: .72rem;
  align-items: center;
  border: 1px solid rgba(207, 218, 211, .82);
  border-radius: 12px;
  background: rgba(255, 255, 255, .82);
  padding: .72rem .78rem;
}
.o3-root-package-points i {
  grid-row: span 2;
  width: 42px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  border-radius: 11px;
  background: var(--o3-green-soft);
  color: var(--o3-green-strong);
  border: 1px solid #c9f4d9;
  font-size: 1.05rem;
}
.o3-root-package-points span {
  color: var(--o3-green-strong);
  font-size: .78rem;
  font-weight: 820;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.o3-root-package-points strong {
  color: var(--o3-ink);
  font-size: .98rem;
  line-height: 1.28;
}
.o3-root-path {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .72rem;
}
.o3-root-path div {
  display: grid;
  grid-template-columns: 38px 1fr;
  column-gap: .72rem;
  row-gap: .12rem;
  align-items: center;
  border: 1px solid var(--o3-line);
  border-radius: 12px;
  background: #fff;
  padding: .8rem .86rem;
}
.o3-root-path strong {
  grid-row: span 2;
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: #f1f5f3;
  color: var(--o3-ink);
  font-size: .94rem;
}
.o3-root-path span {
  color: var(--o3-ink);
  font-weight: 820;
}
.o3-root-path small {
  color: var(--o3-muted);
  line-height: 1.35;
}
.o3-root-hero-simple {
  min-height: calc(78vh - 74px);
  text-align: center;
}
.o3-root-hero-simple .container {
  max-width: 840px;
}
.o3-start-checklist {
  background:
    radial-gradient(circle at 90% 12%, rgba(0, 177, 79, .12), transparent 18rem),
    #fff;
}
.o3-checklist-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}
.o3-check-item {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  border: 1px solid var(--o3-line);
  background: #fff;
  border-radius: 12px;
  padding: .78rem .86rem;
  color: var(--o3-ink);
  font-weight: 690;
}
.o3-check-item i {
  color: var(--o3-green-strong);
  font-size: 1rem;
  line-height: 1.45;
}
.o3-marketing-section {
  background:
    linear-gradient(135deg, #f2fff7 0%, #ffffff 58%),
    radial-gradient(circle at 12% 10%, rgba(0, 177, 79, .14), transparent 18rem);
}
.o3-marketing-claim {
  display: grid;
  gap: .55rem;
  margin: 1.15rem 0 0;
}
.o3-marketing-claim span {
  display: inline-flex;
  width: fit-content;
  border-radius: 10px;
  padding: .45rem .7rem;
  background: var(--o3-green-soft);
  color: #0f5a2b;
  border: 1px solid #c9f4d9;
  font-weight: 820;
}
.o3-faq-groups { display: grid; gap: 1.4rem; }
.o3-faq-group {
  border-left: 3px solid var(--o3-green);
  padding-left: 1rem;
}
.o3-faq-group-title {
  font-size: 1.05rem;
  font-weight: 820;
  letter-spacing: -.02em;
  color: var(--o3-ink);
  margin: 0 0 .75rem;
}
.o3-faq-list { display: grid; gap: .75rem; }
.o3-faq-card { padding: 0; overflow: hidden; box-shadow: none; }
.o3-faq-card summary {
  cursor: pointer;
  list-style: none;
  padding: 1rem 3rem 1rem 1.15rem;
  font-weight: 760;
  color: var(--o3-ink);
  position: relative;
}
.o3-faq-card summary::-webkit-details-marker { display: none; }
.o3-faq-card summary:after {
  content: "+";
  position: absolute;
  right: 1.15rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--o3-green);
  font-size: 1.25rem;
  line-height: 1;
}
.o3-faq-card[open] summary:after { content: "-"; }
.o3-faq-answer {
  padding: 0 1.15rem 1.05rem;
  color: var(--o3-muted);
}
.o3-faq-answer p { margin: 0 0 .82rem; color: var(--o3-muted); }
.o3-faq-answer p:last-child { margin-bottom: 0; }
.o3-faq-answer ul,
.o3-faq-answer ol {
  margin: .2rem 0 .9rem;
  padding-left: 1.2rem;
}
.o3-faq-answer li { margin: .2rem 0; }
.o3-faq-answer a {
  color: var(--o3-green-strong);
  font-weight: 760;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}
.o3-cookie-banner[hidden] { display: none !important; }
.o3-cookie-banner {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 1000;
  display: flex;
  justify-content: center;
  pointer-events: none;
}
.o3-cookie-card {
  width: min(760px, 100%);
  border: 1px solid rgba(0, 177, 79, .18);
  border-radius: 18px;
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 22px 60px rgba(17, 24, 32, .17);
  padding: 1rem;
  pointer-events: auto;
  backdrop-filter: blur(18px);
}
.o3-cookie-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .8rem;
}
.o3-cookie-head h2 {
  margin: .35rem 0 0;
  color: var(--o3-ink);
  font-size: 1.18rem;
  letter-spacing: -.035em;
  font-weight: 820;
}
.o3-cookie-close {
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--o3-line);
  border-radius: 999px;
  background: #fff;
  color: var(--o3-muted);
  line-height: 1;
}
.o3-cookie-text {
  margin: .75rem 0;
  color: var(--o3-muted);
  font-size: .92rem;
}
.o3-cookie-text a {
  color: var(--o3-green-strong);
  font-weight: 760;
}
.o3-cookie-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
  margin-bottom: .85rem;
}
.o3-cookie-option {
  display: flex;
  align-items: flex-start;
  gap: .62rem;
  border: 1px solid var(--o3-line);
  border-radius: 13px;
  background: #fbfdfb;
  padding: .75rem;
}
.o3-cookie-option input {
  margin-top: .25rem;
  accent-color: var(--o3-green);
}
.o3-cookie-option strong {
  display: block;
  color: var(--o3-ink);
  font-size: .9rem;
}
.o3-cookie-option small {
  display: block;
  margin-top: .15rem;
  color: var(--o3-muted);
  line-height: 1.35;
}
.o3-cookie-providers {
  border: 1px solid var(--o3-line);
  border-radius: 13px;
  background: #fbfdfb;
  padding: .7rem .8rem;
  margin: -.15rem 0 .85rem;
}
.o3-cookie-providers strong {
  display: block;
  color: var(--o3-ink);
  font-size: .82rem;
  margin-bottom: .35rem;
}
.o3-cookie-providers ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .38rem;
}
.o3-cookie-providers li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .25rem .55rem;
  color: var(--o3-muted);
  font-size: .82rem;
}
.o3-cookie-providers li span {
  color: var(--o3-ink);
  font-weight: 760;
}
.o3-cookie-providers li small {
  color: var(--o3-muted);
}
.o3-cookie-providers li a {
  color: var(--o3-green-strong);
  font-weight: 760;
}
.o3-cookie-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .55rem;
}
.skip-link { position: absolute; left: -999px; }
.skip-link:focus { left: 1rem; top: 1rem; z-index: 1000; background: #fff; color: #000; padding: .5rem 1rem; }
.o3-gate-body { background: #f5f7f8; }
.o3-gate-wrap { min-height: 100vh; display: grid; place-items: center; padding: 1rem; }
.o3-gate-card { width: min(440px, 100%); background: #fff; border: 1px solid var(--o3-line); border-radius: 18px; box-shadow: var(--o3-shadow); padding: 1.4rem; }
.o3-gate-card h1 { font-size: 2rem; letter-spacing: -.05em; font-weight: 820; }
@media (max-width: 991px) {
  .o3-hero { padding: 3.15rem 0 1.85rem; background: linear-gradient(180deg, #fff 0%, #fff 58%, #eefbf3 58%, #eefbf3 100%); }
  .o3-mockup { min-height: auto; margin-top: 1.55rem; padding-bottom: 3.2rem; }
  .phone { width: min(360px, 86vw); }
  .float-card {
    position: absolute;
    right: 50%;
    bottom: 0;
    transform: translateX(50%);
    width: min(300px, 82vw);
    margin: 0;
    text-align: center;
  }
  .o3-choice-card { min-height: auto; }
  .o3-root-hero {
    min-height: auto;
    padding: 1.55rem 0 1.1rem;
  }
  .o3-root-visual {
    min-height: auto;
    margin-top: 1.05rem;
  }
  .o3-root-mockup .phone {
    width: min(304px, 72vw);
  }
  .o3-root-package {
    grid-template-columns: 1fr;
  }
  .o3-root-path {
    grid-template-columns: 1fr;
  }
  .o3-section { padding: 2.55rem 0; }
  .o3-title { font-size: clamp(2.35rem, 11vw, 3.8rem); }
  .o3-food-landing-page .o3-hero {
    padding: 2.75rem 0 1.55rem;
  }
  .o3-food-landing-page .o3-title {
    font-size: clamp(2.05rem, 9.5vw, 3.35rem);
  }
  .o3-food-landing-page .o3-section {
    padding: 2.35rem 0;
  }
  .o3-food-landing-page .o3-section-compact {
    padding: 2.1rem 0;
  }
  .o3-food-landing-page .o3-section-title {
    font-size: clamp(1.62rem, 6.8vw, 2.25rem);
  }
  .o3-food-landing-page .o3-mockup {
    min-height: auto;
    margin-top: 1.35rem;
    padding-bottom: 2.7rem;
  }
  .o3-brand { min-height: 40px; }
  .o3-brand-logo { height: 40px; }
  .o3-checklist-grid { grid-template-columns: 1fr; }
  .o3-faq-group { padding-left: .75rem; }
  .o3-legal-page { padding: 2.4rem 0 3rem; }
  .o3-legal-hero {
    align-items: flex-start;
    margin-bottom: 1rem;
  }
  .o3-legal-layout {
    grid-template-columns: 1fr;
  }
  .o3-legal-side {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .o3-legal-small-link {
    grid-column: 1 / -1;
  }
  .o3-article-page {
    padding: 1.75rem 0 2.8rem;
  }
  .o3-article-hero {
    grid-template-columns: 1fr;
  }
  .o3-article-hero-copy {
    min-height: auto;
  }
  .o3-article-media {
    min-height: 0;
    height: min(48vw, 330px);
  }
  .o3-article-layout {
    grid-template-columns: 1fr;
  }
  .o3-article-side {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 576px) and (max-width: 991px) {
  .o3-mobile-nav {
    --bs-offcanvas-width: 460px;
  }
  .o3-mobile-nav__body {
    padding: 1.2rem;
  }
  .o3-mobile-nav__links {
    gap: .68rem;
  }
  .o3-mobile-nav__item {
    min-height: 58px;
    padding: .82rem .9rem;
  }
}
@media (max-width: 575px) {
  html {
    font-size: 95%;
  }
  .o3-navbar nav.container {
    padding-top: .55rem !important;
    padding-bottom: .55rem !important;
  }
  .o3-brand {
    min-height: 48px;
  }
  .o3-brand-logo {
    height: 48px;
  }
  .o3-navbar .o3-btn-ghost {
    padding: .56rem .68rem;
    border-radius: 9px;
  }
  .o3-scroll-top {
    right: .78rem;
    bottom: calc(env(safe-area-inset-bottom, 0px) + .78rem);
    width: 42px;
    height: 42px;
  }
  .o3-scroll-top i {
    font-size: 1.45rem;
  }
  .o3-mobile-nav__body {
    padding: .85rem;
  }
  .o3-mobile-nav__links {
    gap: .5rem;
  }
  .o3-mobile-nav__item {
    min-height: 52px;
    padding: .62rem .68rem;
    border-radius: 11px;
    font-size: .95rem;
  }
  .o3-mobile-nav__icon {
    width: 32px;
    height: 32px;
    flex-basis: 32px;
    border-radius: 9px;
  }
  .o3-hero { padding-top: 1.45rem; }
  .o3-root-hero {
    padding: 1.25rem 0 .85rem;
  }
  .o3-title {
    font-size: clamp(2rem, 8.4vw, 2.2rem);
    line-height: 1.04;
    letter-spacing: -.052em;
  }
  .o3-food-landing-page .o3-hero {
    padding: 1.25rem 0 .85rem;
  }
  .o3-food-landing-page .o3-title {
    font-size: clamp(1.78rem, 7.6vw, 2rem);
  }
  .o3-food-landing-page .o3-subtitle {
    font-size: .92rem;
  }
  .o3-food-landing-page .o3-section {
    padding: 2rem 0;
  }
  .o3-food-landing-page .o3-section-compact {
    padding: 1.8rem 0;
  }
  .o3-food-landing-page .o3-section-title {
    font-size: clamp(1.55rem, 7.1vw, 1.95rem);
  }
  .o3-food-landing-page .phone {
    width: min(292px, 86vw);
  }
  .o3-root-page .o3-title {
    margin: .66rem 0 .55rem;
  }
  .o3-subtitle {
    font-size: .98rem;
    max-width: 100%;
  }
  .text-muted.fs-5,
  .fs-5.text-muted {
    font-size: 1.05rem !important;
  }
  .o3-badge {
    white-space: normal;
    text-align: left;
  }
  .o3-hero .my-4 {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: start;
    gap: .48rem;
    max-width: calc(100vw - 1.5rem);
  }
  .o3-hero .o3-hero-badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-items: normal;
    gap: .42rem;
  }
  .o3-root-proof {
    grid-template-columns: 1fr;
    gap: .5rem;
    margin-top: .85rem;
  }
  .o3-root-page .row > * {
    min-width: 0;
  }
  .o3-root-page .o3-subtitle {
    max-width: 100%;
    overflow-wrap: break-word;
    line-height: 1.45;
  }
  .o3-root-page .o3-hero-badges {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: start;
    max-width: calc(100vw - 1.5rem);
    gap: .42rem;
    margin-top: .85rem !important;
    margin-bottom: .92rem !important;
  }
  .o3-root-page .o3-hero-badges .o3-badge {
    display: block;
    width: fit-content;
    max-width: 100%;
    overflow-wrap: break-word;
  }
  .o3-root-proof div {
    min-height: auto;
    padding: .76rem .82rem;
  }
  .o3-root-actions .o3-btn {
    width: 100%;
    min-height: 46px;
    padding: .62rem .42rem;
    border-radius: 9px;
    font-size: .88rem;
    line-height: 1.08;
    text-align: center;
  }
  .o3-root-visual {
    min-height: auto;
    align-content: center;
    margin-top: .35rem;
  }
  .o3-root-mockup .phone {
    width: min(282px, 86vw);
  }
  .o3-root-next {
    padding-bottom: 1.85rem;
  }
  .o3-root-hub {
    gap: .72rem;
    padding-top: .72rem;
  }
  .o3-root-package {
    padding: .86rem;
    border-radius: 14px;
  }
  .o3-root-package-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: .55rem;
  }
  .o3-root-package-actions .o3-btn {
    width: 100%;
    min-height: 46px;
    padding: .62rem .42rem;
    border-radius: 9px;
    font-size: .88rem;
    line-height: 1.08;
    text-align: center;
  }
  .o3-root-package-points div,
  .o3-root-path div {
    padding: .64rem;
  }
  .o3-hero .d-flex.flex-wrap.gap-3 {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    max-width: calc(100vw - 1.5rem);
    gap: .55rem !important;
  }
  .o3-hero .o3-btn {
    width: 100%;
    min-height: 46px;
    padding: .62rem .42rem;
    border-radius: 9px;
    font-size: .82rem;
    line-height: 1.08;
    text-align: center;
  }
  .o3-promo-cta {
    width: 100%;
    min-height: 46px;
  }
  .phone {
    width: min(315px, 90vw);
    border-radius: 26px;
    padding: 8px;
  }
  .phone-screen { border-radius: 20px; }
  .float-card { width: min(292px, 84vw); }
  .o3-section { padding: 2.25rem 0; }
  .o3-section-title { font-size: clamp(1.75rem, 8vw, 2.15rem); }
  .o3-feature { padding: 1rem; }
  .o3-form-card { padding: 1rem; }
  .customer-card img { height: 230px; }
  .o3-legal-page { padding: 1.5rem 0 2.3rem; }
  .o3-legal-hero {
    display: grid;
    gap: .85rem;
    padding: 1rem;
    border-radius: 18px;
  }
  .o3-legal-hero h1 {
    margin-top: .62rem;
    font-size: clamp(1.85rem, 9vw, 2.25rem);
    line-height: 1.04;
  }
  .o3-legal-hero p {
    font-size: .96rem;
  }
  .o3-legal-hero .o3-btn {
    width: 100%;
    min-height: 42px;
    padding: .64rem .75rem;
    font-size: .88rem;
  }
  .o3-legal-body {
    padding: 1rem;
    border-radius: 14px;
    font-size: .95rem;
    line-height: 1.66;
  }
  .o3-legal-body h2 {
    margin-top: 1.45rem;
    font-size: 1.18rem;
  }
  .o3-legal-body h3 {
    font-size: 1rem;
  }
  .o3-legal-side {
    grid-template-columns: 1fr;
    gap: .65rem;
  }
  .o3-article-page {
    padding: .95rem 0 2.2rem;
  }
  .o3-article-hero {
    gap: .75rem;
    margin-bottom: .75rem;
  }
  .o3-article-hero-copy {
    padding: .9rem;
    border-radius: 18px;
  }
  .o3-article-back {
    width: 100%;
    justify-content: center;
    min-height: 40px;
    margin-bottom: 1rem;
  }
  .o3-article-hero h1 {
    margin-top: .58rem;
    font-size: clamp(1.35rem, 5.6vw, 1.65rem);
    line-height: 1.08;
    letter-spacing: -.038em;
  }
  .o3-article-hero p {
    font-size: .92rem;
    line-height: 1.48;
  }
  .o3-article-meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: .36rem;
    margin-top: .75rem;
  }
  .o3-article-meta span {
    width: 100%;
    justify-content: flex-start;
    border-radius: 10px;
    padding: .4rem .52rem;
    font-size: .76rem;
  }
  .o3-article-media {
    height: min(52vw, 220px);
    border-radius: 18px;
  }
  .o3-article-body {
    padding: 1rem;
    border-radius: 14px;
    font-size: .95rem;
    line-height: 1.68;
  }
  .o3-article-body h2 {
    margin-top: 1.45rem;
    font-size: 1.2rem;
  }
  .o3-article-body h3 {
    font-size: 1.02rem;
  }
  .o3-article-side {
    grid-template-columns: 1fr;
    gap: .65rem;
  }
  .o3-article-info {
    padding: .9rem;
    border-radius: 14px;
  }
  .o3-legal-info {
    padding: .9rem;
    border-radius: 14px;
  }
  .o3-legal-small-link,
  .o3-legal-settings {
    width: 100%;
  }
  .o3-footer {
    background: transparent;
    border-top-color: transparent;
  }
  .o3-footer-logo { height: 40px; }
  .o3-footer-links { font-size: .72rem; }
  .o3-cookie-banner {
    left: .7rem;
    right: .7rem;
    bottom: .7rem;
  }
  .o3-cookie-card {
    max-height: calc(100vh - 1.4rem);
    overflow: auto;
    border-radius: 16px;
  }
  .o3-cookie-options {
    grid-template-columns: 1fr;
  }
  .o3-cookie-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .o3-cookie-actions .o3-btn {
    width: 100%;
  }
}
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}
