:root{
  --bg:#f4fbf6;
  --paper:#ffffff;
  --ink:#123023;
  --muted:#637667;
  --line:#dbeadd;
  --blue:#2f8b5f;
  --blue-dark:#226743;
  --green:#7aad37;
  --green-dark:#587d25;
  --navy:#11321f;
  --soft:#edf7e8;
  --hero-a:#f7fff9;
  --hero-b:#eaf8ee;
  --glow-a:rgba(25,156,84,.22);
  --glow-b:rgba(36,122,162,.12);
  --wash-a:rgba(36,122,162,.11);
  --wash-b:rgba(25,156,84,.12);
  --radius:24px;
  --shadow:0 24px 68px rgba(14,74,51,.15);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Open Sans",Arial,Helvetica,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1160px,calc(100% - 40px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);border-bottom:1px solid rgba(220,231,239,.8);backdrop-filter:blur(14px)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:78px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--navy)}
.brand small{display:block;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.logo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--green));color:white;display:grid;place-items:center;font-weight:900;box-shadow:0 12px 28px rgba(14,118,188,.22)}
.nav{display:flex;align-items:center;gap:22px;color:#31495d;font-size:14px;font-weight:700}
.nav a{transition:.2s ease}.nav a:hover{color:var(--blue)}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:13px 20px;font-weight:800;cursor:pointer;transition:.2s ease;white-space:nowrap;font-family:inherit}
.btn.primary{background:linear-gradient(135deg,var(--blue),var(--green));color:white;box-shadow:0 14px 28px rgba(14,118,188,.25)}
.btn.secondary{background:white;color:var(--navy);border:1px solid var(--line)}
.btn:hover{transform:translateY(-1px)}
.hero{position:relative;overflow:hidden;background:radial-gradient(circle at top right,rgba(29,166,111,.18),transparent 32%),linear-gradient(180deg,#f7fbff 0%,#edf6fb 100%);padding:78px 0 64px}
.hero:before{content:"";position:absolute;inset:auto -14% -220px -14%;height:360px;background:linear-gradient(90deg,rgba(14,118,188,.12),rgba(29,166,111,.11));border-radius:50% 50% 0 0;filter:blur(4px)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:54px}
.eyebrow{margin:0 0 14px;color:var(--green-dark);font-size:13px;text-transform:uppercase;letter-spacing:.16em;font-weight:900}
h1,h2,h3,p{margin-top:0}h1{font-size:clamp(42px,5.2vw,72px);line-height:1.02;letter-spacing:-.05em;margin-bottom:20px;color:var(--navy)}h2{font-size:clamp(30px,3vw,46px);line-height:1.08;letter-spacing:-.035em;color:var(--navy);margin-bottom:18px}.lead{font-size:19px;color:#40576a;max-width:650px}.hero-copy .lead{margin-bottom:24px}
.search-card{display:flex;align-items:center;gap:14px;width:min(620px,100%);padding:12px 12px 12px 18px;border-radius:22px;background:white;border:1px solid var(--line);box-shadow:var(--shadow);color:#6a7887;margin:26px 0 22px}
.search-icon{font-size:28px;color:var(--blue);font-weight:900}.search-card span:nth-child(2){flex:1}.search-card button{border:0;background:var(--navy);color:white;border-radius:16px;padding:12px 18px;font-weight:800;font-family:inherit}.hero-actions,.store-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.hero-actions{margin-bottom:18px}.store-badge{display:inline-flex;flex-direction:column;gap:1px;background:#101820;color:white;border-radius:16px;padding:10px 18px;min-width:168px;box-shadow:0 14px 30px rgba(16,24,32,.16)}.store-badge small{font-size:11px;color:#d7dde3}.store-badge b{font-size:18px;line-height:1.1}.hero-visual{display:flex;justify-content:center}.map-panel{position:relative;width:min(480px,100%);padding:16px;border-radius:34px;background:rgba(255,255,255,.76);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.9)}.map-panel img{border-radius:26px;aspect-ratio:1/1;object-fit:cover}.floating-card{position:absolute;background:white;border:1px solid var(--line);border-radius:18px;padding:12px 16px;box-shadow:0 18px 38px rgba(15,63,95,.18)}.floating-card b{display:block;color:var(--navy)}.floating-card span{display:block;color:var(--muted);font-size:13px}.forecast-mini{left:-28px;top:46px}.map-mini{right:-22px;bottom:48px}
.feature-strip{background:white;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0}.strip-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.strip-grid div{padding:18px 14px;border-radius:18px;background:#f7fbfe;border:1px solid #edf4f8}.strip-grid b{display:block;color:var(--navy);font-size:14px}.strip-grid span{display:block;color:var(--muted);font-size:13px;margin-top:3px}.section{padding:92px 0}.section.soft{background:var(--soft)}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}.split-grid.reverse{grid-template-columns:.95fr 1.05fr}.section-copy p:not(.eyebrow){color:var(--muted);font-size:17px}.check-list{margin:24px 0 0;padding:0;list-style:none;display:grid;gap:12px}.check-list li{position:relative;padding-left:32px;color:#40576a}.check-list li:before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:#dff5eb;color:var(--green-dark);display:grid;place-items:center;font-weight:900;font-size:13px}.visual-card{padding:14px;border-radius:34px;background:white;border:1px solid var(--line);box-shadow:var(--shadow)}.visual-card img{border-radius:24px;aspect-ratio:1/1;object-fit:cover}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}.info-grid div,.card-grid article,.forecast-cards article{background:white;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:0 14px 32px rgba(15,63,95,.08)}.info-grid b,.card-grid b{display:block;color:var(--navy);margin-bottom:5px}.info-grid span,.card-grid p{color:var(--muted);margin:0}.centered{text-align:center;margin:0 auto}.narrow{max-width:760px}.forecast-layout{display:grid;gap:34px}.forecast-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.forecast-cards span{display:block;color:var(--muted);font-size:14px}.forecast-cards b{display:block;font-size:30px;color:var(--blue);margin:8px 0}.forecast-cards small{color:#6f7f8b}.logbook-tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}.logbook-tags span{background:white;border:1px solid var(--line);border-radius:999px;padding:10px 14px;color:#3f596c;font-weight:800;font-size:14px}.toolkit{background:#f7fbff}.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}.card-grid article{min-height:170px}.download-section{padding:44px 0 86px;background:linear-gradient(180deg,var(--bg),#e4f2f9)}.download-card{display:flex;justify-content:space-between;gap:30px;align-items:center;background:linear-gradient(135deg,var(--navy),#0d5d8c);color:white;border-radius:34px;padding:40px;box-shadow:var(--shadow)}.download-card h2{color:white;margin-bottom:10px}.download-card p{color:#d5e8f3}.download-card .eyebrow{color:#8defc7}.store-row-large{justify-content:flex-end}.impressions{background:white}.review-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:26px}blockquote{margin:0;background:#f7fbfe;border:1px solid var(--line);border-radius:26px;padding:28px;color:#344d60;font-size:18px}cite{display:block;margin-top:16px;color:var(--blue-dark);font-style:normal;font-weight:800}.faq-list{display:grid;gap:12px;max-width:870px;margin:26px auto 0}details{background:white;border:1px solid var(--line);border-radius:20px;padding:18px 22px}summary{cursor:pointer;font-weight:900;color:var(--navy)}details p{color:var(--muted);margin:10px 0 0}.contact-grid{display:grid;grid-template-columns:1fr .85fr;gap:28px;align-items:center}.contact-card{background:white;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:28px;padding:30px;display:grid;gap:12px;color:#40576a}.contact-card a{color:var(--blue);font-weight:900}.site-footer{background:#071d2d;color:white;padding:56px 0 24px}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr .7fr;gap:42px}.footer-brand{color:white;margin-bottom:14px}.site-footer p,.site-footer li{color:#b8c9d7}.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:6px}.site-footer h4{margin:0 0 12px}.legal-links{display:grid;gap:8px}.legal-links a{color:#d9edf8;font-weight:800}.copyright{border-top:1px solid rgba(255,255,255,.1);margin-top:30px;padding-top:20px}.copyright p{margin:0;font-size:13px}.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:80;max-width:980px;margin:0 auto;padding:18px 20px;border-radius:22px;background:rgba(6,18,30,.94);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px);box-shadow:var(--shadow);display:flex;gap:18px;align-items:center;justify-content:space-between;color:white}.cookie-banner p{margin:0;color:#c6d6e3;font-size:14px;max-width:64ch}.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}.cookie-banner[hidden]{display:none}.policy-hero{padding:72px 0 42px;background:linear-gradient(180deg,#f7fbff,var(--soft))}.policy-shell{padding:52px 0 76px}.policy-card{background:white;border:1px solid var(--line);box-shadow:0 12px 32px rgba(15,63,95,.07);border-radius:24px;padding:28px}.policy-card h2{font-size:24px;margin-bottom:10px}.muted{color:var(--muted)}.spacer{height:18px}.h1{font-size:clamp(38px,5vw,64px);line-height:1.02;letter-spacing:-.04em;margin:0 0 16px;color:var(--navy)}
@media (max-width:980px){.header-btn{display:none}.nav{gap:12px;font-size:13px}.hero-grid,.split-grid,.split-grid.reverse,.contact-grid{grid-template-columns:1fr}.hero{padding-top:52px}.forecast-mini{left:12px}.map-mini{right:12px}.strip-grid{grid-template-columns:repeat(3,1fr)}.forecast-cards,.card-grid{grid-template-columns:repeat(2,1fr)}.download-card{align-items:flex-start;flex-direction:column}.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.container{width:min(100% - 28px,1160px)}.site-header{position:static}.header-inner{min-height:auto;padding:16px 0;align-items:flex-start}.nav{display:none}.brand small{font-size:10px}.hero{padding:42px 0}.search-card{align-items:stretch;flex-direction:column}.search-card button{width:100%}h1{font-size:40px}.lead{font-size:17px}.feature-strip{padding:12px 0}.strip-grid,.forecast-cards,.card-grid,.review-grid,.footer-grid,.info-grid{grid-template-columns:1fr}.section{padding:62px 0}.download-card{padding:28px;border-radius:24px}.store-badge{min-width:100%}.cookie-banner{left:12px;right:12px;bottom:12px;flex-direction:column;align-items:flex-start}.cookie-actions,.cookie-actions .btn{width:100%}}

.hero{background:radial-gradient(circle at top right,var(--glow-a),transparent 34%),linear-gradient(180deg,var(--hero-a) 0%,var(--hero-b) 100%)}
.hero:before{background:linear-gradient(90deg,var(--wash-a),var(--wash-b))}
.logo,.btn.primary{background:linear-gradient(135deg,var(--blue),var(--green))}
.visual-card,.map-panel,.download-card{border-radius:calc(var(--radius) + 8px)}
.visual-card img,.map-panel img{border-radius:var(--radius)}
.contact-stack{display:grid;gap:18px}
.contact-form{background:white;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:var(--shadow);display:grid;gap:12px}
.contact-form label{display:grid;gap:6px;color:var(--navy);font-size:13px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}
.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:13px 14px;font:inherit;color:var(--ink);background:#fbfdff;outline:none}
.contact-form textarea{min-height:104px;resize:vertical}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(14,118,188,.10)}
.contact-form .btn{width:max-content}
@media (max-width:680px){.contact-form .btn{width:100%}}

/* site variation 17: kalviro.eu */
.hero{background:radial-gradient(circle at top right,rgba(132,120,204,.16),transparent 34%),linear-gradient(180deg,var(--bg),var(--soft));}
.visual-card,.map-panel{border-radius:29px}
