:root{--green:#43a047;--green-soft:#86b049;--green-dark:#2f7d32;--mint:#eef8ea;--cream:#fffaf0;--ink:#183120;--muted:#5d6d61;--line:#dfe9dc;--card:#ffffff;--shadow:0 24px 70px rgba(34,72,39,.12);--radius:26px}*{box-sizing:border-box}body.front-body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:linear-gradient(180deg,#fbfff8 0%,#fffaf0 55%,#f3fbef 100%);line-height:1.65}a{color:inherit}.front-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px clamp(18px,4vw,54px);background:rgba(255,255,255,.82);backdrop-filter:blur(18px);border-bottom:1px solid rgba(67,160,71,.12)}.front-brand{display:flex;align-items:center;gap:12px;text-decoration:none}.front-brand img{width:58px;height:58px;object-fit:contain;border-radius:18px;background:#fff;box-shadow:0 10px 28px rgba(34,72,39,.12)}.front-brand strong{display:block;font-size:1.15rem;line-height:1.1}.front-brand small{display:block;color:var(--muted);font-weight:700;font-size:.78rem}.front-nav{display:flex;align-items:center;gap:18px;font-weight:800;font-size:.95rem}.front-nav a{text-decoration:none;color:#325039}.front-nav a:hover{color:var(--green-dark)}.front-login,.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;text-decoration:none;font-weight:900}.front-login{padding:10px 18px;background:var(--ink);color:#fff}.btn{padding:14px 22px;border:1px solid var(--line)}.btn.primary{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;border:0;box-shadow:0 14px 34px rgba(67,160,71,.25)}.btn.light{background:#fff;color:var(--ink)}.hero{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:44px;align-items:center;max-width:1920px;margin:0 auto;padding:clamp(46px,8vw,105px) clamp(20px,6vw,86px)}.hero h1,.page-hero h1{font-size:clamp(2.4rem,6vw,5.7rem);line-height:.96;margin:.22em 0;color:#122318;letter-spacing:-.06em}.lead{font-size:clamp(1.12rem,2vw,1.45rem);color:#405746;max-width:780px}.pill,.eyebrow{display:inline-flex;align-items:center;gap:8px;margin:0 0 12px;padding:7px 12px;border-radius:999px;background:var(--mint);color:var(--green-dark);font-weight:900;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.hero-card{position:relative;text-align:center;background:rgba(255,255,255,.8);border:1px solid var(--line);border-radius:34px;padding:34px;box-shadow:var(--shadow);overflow:hidden}.hero-card:before{content:"";position:absolute;inset:-70px -50px auto auto;width:180px;height:180px;background:#c9efbd;border-radius:50%;opacity:.55}.hero-card img{position:relative;width:min(250px,78%);display:block;margin:0 auto 22px}.fake-qr{width:210px;height:210px;margin:0 auto 18px;background:#fff;border:12px solid #fff;border-radius:24px;box-shadow:inset 0 0 0 3px #152b1b,0 18px 40px rgba(0,0,0,.08);display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}.fake-qr span,.fake-qr em{background:#152b1b;border-radius:12px}.fake-qr em{display:flex;align-items:center;justify-content:center;color:#fff;font-style:normal;font-weight:1000}.section,.page-hero,.content-page,.faq-list{max-width:1040px;margin:0 auto;padding:clamp(42px,6vw,80px) clamp(20px,4vw,34px)}.intro{text-align:center}.intro h2,.section h2,.content-page h2,.cta h2{font-size:clamp(1.9rem,3vw,3rem);line-height:1.08;letter-spacing:-.04em;margin:0 0 16px}.intro p:not(.eyebrow),.content-page p{font-size:1.08rem;color:#415847}.feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;max-width:1180px;margin:0 auto;padding:20px clamp(20px,4vw,34px) 70px}.feature-grid.wide{grid-template-columns:repeat(3,minmax(0,1fr));padding-top:0}.feature-card,.info-grid>div,.benefit,.faq-list details{background:rgba(255,255,255,.84);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 16px 44px rgba(34,72,39,.08)}.feature-card span{font-size:2rem}.feature-card h3,.info-grid h3{font-size:1.25rem;margin:12px 0 8px}.feature-card p,.benefit p,.faq-list p{color:#506451;margin:0}.split{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}.check-list{margin:0;padding:0;list-style:none;display:grid;gap:12px}.check-list li{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 16px;font-weight:800}.check-list li:before{content:"✓";display:inline-flex;margin-right:10px;color:var(--green-dark);font-weight:1000}.cta{max-width:1040px;margin:10px auto 80px;text-align:center;background:linear-gradient(135deg,#e7f7df,#fff);border:1px solid var(--line);border-radius:36px;padding:clamp(34px,6vw,72px) 24px;box-shadow:var(--shadow)}.page-hero{text-align:center;padding-bottom:34px}.content-page{padding-top:16px}.content-page h2{margin-top:38px}.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:28px 0}.steps{counter-reset:item;list-style:none;padding:0;display:grid;gap:12px}.steps li{background:#fff;border:1px solid var(--line);border-radius:18px;padding:15px 18px;font-weight:850}.benefit{margin:18px 0}.benefit h2{font-size:1.55rem}.faq-list{display:grid;gap:14px}.faq-list details{padding:0;overflow:hidden}.faq-list summary{cursor:pointer;padding:20px 24px;font-weight:950;font-size:1.08rem}.faq-list p{padding:0 24px 22px}.front-footer{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin:0 clamp(20px,6vw,86px) 30px;padding:30px;border-top:1px solid var(--line);color:#4e624f}.front-footer p{margin:.35rem 0 0}.front-footer-links{display:flex;gap:16px;flex-wrap:wrap}.front-footer-links a{font-weight:850;text-decoration:none}code{background:#f0f7ec;border:1px solid #d9e8d3;border-radius:8px;padding:2px 6px}@media(max-width:990px){.front-header{position:relative;flex-wrap:wrap}.front-nav{order:3;width:100%;overflow:auto;padding-bottom:4px}.hero,.split{grid-template-columns:1fr}.feature-grid,.feature-grid.wide,.info-grid{grid-template-columns:1fr 1fr}.hero-card{max-width:520px;margin:0 auto}.front-footer{flex-direction:column}}@media(max-width:620px){.front-nav{font-size:.88rem;gap:12px}.front-login{padding:9px 14px}.front-brand span{display:none}.hero{padding-top:34px}.hero h1,.page-hero h1{font-size:2.55rem}.feature-grid,.feature-grid.wide,.info-grid{grid-template-columns:1fr}.front-footer{margin-left:16px;margin-right:16px;padding:24px 0}.fake-qr{width:180px;height:180px}}

/* v18: responsive frontend navigation, preloader and footer */
.front-header-actions{display:flex;align-items:center;gap:12px}.front-menu-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:16px;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer;box-shadow:0 10px 24px rgba(34,72,39,.08)}.front-menu-toggle span{display:block;width:20px;height:2px;border-radius:999px;background:var(--ink);transition:.2s ease}.front-menu-open .front-menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}.front-menu-open .front-menu-toggle span:nth-child(2){opacity:0}.front-menu-open .front-menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.qrator-preloader{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(251,255,248,.84);backdrop-filter:blur(12px)}.qrator-preloader.is-active{display:flex}.preloader-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;min-width:230px;padding:30px 34px;border-radius:32px;background:rgba(255,255,255,.95);border:1px solid var(--line);box-shadow:var(--shadow);text-align:center}.preloader-card:before{content:"";position:absolute;inset:12px;border-radius:26px;border:2px dashed rgba(67,160,71,.28);animation:qratorSpin 2.4s linear infinite}.preloader-card img{position:relative;width:88px;height:88px;object-fit:contain;animation:qratorBounce 1.25s ease-in-out infinite}.preloader-card p{position:relative;margin:0;font-weight:950;color:var(--green-dark)}.preloader-qr{position:relative;width:64px;height:64px;display:grid;grid-template-columns:repeat(2,1fr);gap:7px;padding:8px;border-radius:16px;background:#fff;border:2px solid var(--green);box-shadow:0 12px 24px rgba(67,160,71,.16)}.preloader-qr span,.preloader-qr strong{border-radius:7px;background:var(--ink)}.preloader-qr strong{display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem}.front-footer{display:block;margin:0 clamp(20px,6vw,86px) 30px;padding:34px 0;border-top:1px solid var(--line);color:#4e624f}.footer-brand-block{display:flex;align-items:center;gap:14px;margin-bottom:24px}.footer-brand-block img{width:64px;height:64px;object-fit:contain;border-radius:18px;background:#fff;box-shadow:0 10px 24px rgba(34,72,39,.08)}.footer-brand-block strong{display:block;color:var(--ink);font-size:1.25rem}.footer-brand-block p{margin:.25rem 0 0}.front-footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1.25fr;gap:26px}.front-footer-grid h3{margin:0 0 10px;color:var(--ink);font-size:.95rem;text-transform:uppercase;letter-spacing:.06em}.front-footer-grid a{display:block;text-decoration:none;font-weight:850;margin:7px 0}.front-footer-grid a:hover{color:var(--green-dark)}.front-footer-grid p{margin:0 0 8px}@keyframes qratorSpin{to{transform:rotate(360deg)}}@keyframes qratorBounce{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.03)}}@media(max-width:990px){.front-header{position:sticky;flex-wrap:nowrap}.front-menu-toggle{display:flex}.front-nav{position:absolute;top:calc(100% + 10px);left:18px;right:18px;order:initial;width:auto;display:none;flex-direction:column;align-items:stretch;gap:4px;padding:14px;background:rgba(255,255,255,.97);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);overflow:visible}.front-nav a{padding:12px 14px;border-radius:14px}.front-nav a:hover{background:var(--mint)}.front-menu-open .front-nav{display:flex}.front-footer-grid{grid-template-columns:1fr 1fr}.front-brand span{display:block}}@media(max-width:620px){.front-brand span{display:none}.front-footer-grid{grid-template-columns:1fr}.footer-brand-block{align-items:flex-start}.preloader-card{min-width:210px;padding:26px}.preloader-card img{width:76px;height:76px}}

/* v18.1: calmer logo preloader and coloured frontend footer */
.qrator-preloader .preloader-card:before{animation:none;border-style:solid;border-color:rgba(67,160,71,.18);background:radial-gradient(circle at center,rgba(67,160,71,.08),transparent 64%)}
.qrator-preloader .preloader-card{overflow:hidden}
.qrator-preloader .preloader-card:after{content:"";position:absolute;left:-40%;right:-40%;bottom:-52px;height:84px;background:linear-gradient(90deg,rgba(67,160,71,.08),rgba(67,160,71,.22),rgba(67,160,71,.08));animation:qratorWave 2.2s ease-in-out infinite;border-radius:50%}
.qrator-preloader .preloader-card img{z-index:1;animation:qratorMoo 1.45s ease-in-out infinite;filter:drop-shadow(0 10px 16px rgba(34,72,39,.12))}
.qrator-preloader .preloader-card p{z-index:1}
.qrator-preloader .preloader-qr{z-index:1;animation:qratorQrPulse 1.35s ease-in-out infinite}
.qrator-preloader .preloader-qr span:nth-child(1){animation:qratorBlink 1.2s ease-in-out infinite}
.qrator-preloader .preloader-qr span:nth-child(2){animation:qratorBlink 1.2s ease-in-out .2s infinite}
.qrator-preloader .preloader-qr span:nth-child(3){animation:qratorBlink 1.2s ease-in-out .4s infinite}
@keyframes qratorMoo{0%,100%{transform:translateY(0) rotate(-1deg) scale(1)}50%{transform:translateY(-5px) rotate(1deg) scale(1.035)}}
@keyframes qratorQrPulse{0%,100%{transform:scale(1);box-shadow:0 12px 24px rgba(67,160,71,.16)}50%{transform:scale(1.045);box-shadow:0 16px 34px rgba(67,160,71,.24)}}
@keyframes qratorBlink{0%,100%{opacity:1}50%{opacity:.42}}
@keyframes qratorWave{0%,100%{transform:translateX(-8%) translateY(0)}50%{transform:translateX(8%) translateY(-6px)}}
.front-footer{margin:46px 0 0;padding:44px clamp(20px,6vw,86px) 34px;border-top:1px solid rgba(255,255,255,.18);background:linear-gradient(135deg,#14321d 0%,#214c29 55%,#3f8f38 100%);color:rgba(255,255,255,.82);box-shadow:0 -24px 70px rgba(34,72,39,.1)}
.front-footer .footer-brand-block strong,.front-footer .front-footer-grid h3{color:#fff}.front-footer .footer-brand-block p,.front-footer .front-footer-grid p{color:rgba(255,255,255,.76)}.front-footer a{color:#fff}.front-footer a:hover{color:#e6f8d6}.front-footer code{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#fff}
@media(max-width:620px){.front-footer{margin-top:34px;padding:34px 18px}}

/* v18.3: frontend mobile menu aligned with backend offcanvas */
.front-mobile-overlay{display:none}
@media(max-width:990px){
  .front-mobile-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(3px);z-index:80;opacity:0;pointer-events:none;transition:.2s ease}
  .front-menu-open .front-mobile-overlay{opacity:1;pointer-events:auto}
  .front-menu-toggle{position:relative;z-index:95;background:linear-gradient(135deg,var(--green),var(--green-soft));border-color:rgba(255,255,255,.18);box-shadow:0 12px 30px rgba(0,0,0,.2)}
  .front-menu-toggle span{background:#fff}
  .front-nav{position:fixed;top:0;right:0;left:auto;bottom:0;width:min(88vw,360px);height:100vh;z-index:90;display:flex;flex-direction:column;align-items:stretch;gap:8px;padding:92px 18px 24px;background:linear-gradient(180deg,#102016,#183721);border:0;border-radius:26px 0 0 26px;box-shadow:14px 0 40px rgba(0,0,0,.12);transform:translateX(105%);transition:transform .22s ease;overflow:hidden;color:#eef8ea}
  .front-menu-open .front-nav{transform:translateX(0)}
  .front-nav a{color:#eef8ea;padding:13px 14px;border-radius:14px;font-weight:850;text-decoration:none}
  .front-nav a:hover{background:rgba(255,255,255,.11);color:#fff;transform:translateX(2px)}
}

/* v18.4: corrected frontend mobile offcanvas and removed output artefacts */
@media(max-width:990px){
  body.front-menu-open{overflow:hidden}
  .front-header{position:sticky;top:0;z-index:100;flex-wrap:nowrap}
  .front-header-actions{margin-left:auto}
  .front-mobile-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(3px);z-index:80;opacity:0;pointer-events:none;transition:opacity .2s ease}
  .front-menu-open .front-mobile-overlay{opacity:1;pointer-events:auto}
  .front-menu-toggle{display:flex;position:relative;z-index:110;background:linear-gradient(135deg,var(--green),var(--green-soft));border-color:rgba(255,255,255,.18);box-shadow:0 12px 30px rgba(0,0,0,.20)}
  .front-menu-toggle span{background:#fff}
  .front-nav{position:fixed;top:0;right:0;left:auto;bottom:0;width:min(88vw,360px);height:100dvh;max-height:100dvh;z-index:100;display:flex;flex-direction:column;align-items:stretch;gap:8px;padding:92px 18px 24px;background:linear-gradient(180deg,#102016,#183721);border:0;border-radius:26px 0 0 26px;box-shadow:-14px 0 40px rgba(0,0,0,.28);transform:translateX(105%);transition:transform .22s ease;overflow-y:auto;overflow-x:hidden;color:#eef8ea;overscroll-behavior:contain}
  .front-menu-open .front-nav{transform:translateX(0)}
  .front-nav a{display:block;color:#eef8ea;padding:13px 14px;border-radius:14px;font-weight:850;text-decoration:none}
  .front-nav a:hover{background:rgba(255,255,255,.11);color:#fff;transform:translateX(2px)}
}

/* v22.3: home hero width limit, footer cleanup, system requirements page and cookie consent controls */
.footer-cookie-button{display:block;margin:7px 0 0;padding:0;border:0;background:transparent;color:#fff;font:inherit;font-weight:850;text-align:left;cursor:pointer}.footer-cookie-button:hover{color:#e6f8d6}.cookie-consent{position:fixed;right:22px;bottom:22px;z-index:10000;width:min(440px,calc(100vw - 36px));}.cookie-consent[hidden]{display:none}.cookie-consent-card{display:grid;grid-template-columns:1fr;gap:18px;padding:24px;border-radius:28px;background:linear-gradient(180deg,#ffffff 0%,#f6fff0 100%);border:2px solid rgba(92,154,47,.45);box-shadow:0 28px 90px rgba(16,32,22,.34),0 0 0 8px rgba(92,154,47,.10)}.cookie-consent h2{margin:.1rem 0 .45rem;font-size:1.45rem}.cookie-consent p{margin:.2rem 0 1rem;color:#4e624f}.cookie-option{display:flex;align-items:center;gap:10px;margin:8px 0;padding:10px 12px;border:1px solid var(--line);border-radius:16px;background:#fbfff8;font-weight:900;color:var(--ink)}.cookie-option input{width:18px;height:18px;accent-color:var(--green)}.cookie-option span{margin-left:auto;font-size:.86rem;color:#647564;font-weight:800}.cookie-option.is-disabled{opacity:.82}.cookie-consent-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.cookie-consent-actions .btn{border:0;cursor:pointer;white-space:nowrap}.table-wrap{margin-top:22px;overflow-x:auto;border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:0 18px 50px rgba(16,32,22,.08)}.requirements-table{width:100%;min-width:920px;border-collapse:separate;border-spacing:0;font-size:.96rem}.requirements-table th,.requirements-table td{padding:16px 18px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}.requirements-table th{background:#15351f;color:#fff;font-weight:900;letter-spacing:.01em}.requirements-table th:first-child{border-top-left-radius:22px}.requirements-table th:last-child{border-top-right-radius:22px}.requirements-table tbody tr:nth-child(even){background:#f8fcf5}.requirements-table tbody tr:last-child td{border-bottom:0}.requirements-table td:first-child{font-weight:900;color:var(--ink);white-space:nowrap}.system-requirements-detail p{max-width:880px}@media(max-width:820px){.cookie-consent{left:14px;right:14px;bottom:14px;width:auto}.cookie-consent-actions{justify-content:stretch}.cookie-consent-actions .btn{width:100%;text-align:center}.cookie-option{align-items:flex-start}.cookie-option span{margin-left:0;display:block}.requirements-table{font-size:.92rem}}
