/*!
 * veilis-brand.css — Veilis shared design system (single source of truth).
 * Versioned here; shipped verbatim to every Veilis surface (veilis.com theme,
 * main.veilis.com portal, kube.veilis.com store). Tokens + reusable components
 * only — NO per-surface layout (header/footer/page grids live in each surface).
 * Drop-in: components are plain `.vl-*` classes (no body-class dependency), so a
 * class selector (0,1,0) beats a theme's bare `a{}` link colour (0,0,1).
 * Version: 1.0.1
 */

/* ---- tokens ---- */
:root{
  --orange:#ff8f00; --blue:#0c71c3; --blue-d:#0a5fa6; --green:#27ae60;
  --ink:#16212e; --body:#5b6b7b; --line:#e7eef4; --alt:#f3f9fd;
  --wrap:1180px;
}

/* ---- base ---- */
.vbrand,.vbrand *{box-sizing:border-box}
.vbrand{font-family:'Rubik',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased}
.vbrand img{max-width:100%;height:auto}
.vl-wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.vl-h,.vbrand h1,.vbrand h2,.vbrand h3,.vbrand h4{color:var(--ink);font-weight:600;line-height:1.2;margin:0}

/* ---- section + eyebrow ---- */
.vl-eyebrow{font-weight:600;letter-spacing:1.5px;text-transform:uppercase;font-size:13px;color:var(--orange);margin:0 0 10px}
.vl-sec{padding:84px 0}
.vl-sec--alt{background:var(--alt)}
.vl-sec-head{max-width:680px;margin:0 auto 48px;text-align:center}
.vl-sec-head h2{font-size:38px;margin:0 0 14px}
.vl-sub{font-size:17px;margin:0;color:var(--body)}

/* ---- hero ---- */
.vl-hero{background:linear-gradient(135deg,#0c71c3 0%,#1b8ae0 100%);color:#fff;padding:90px 0 84px}
.vl-hero h1{color:#fff;font-size:52px}
.vl-hero .vl-eyebrow{color:#bfe1ff}
.vl-lead{font-size:19px;color:#eaf5ff;margin:18px 0 30px;max-width:560px}
.vl-hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---- buttons ---- (plain classes: .vl-btn (0,1,0) beats theme `a` (0,0,1)) */
.vl-btn{display:inline-block;padding:14px 28px;border-radius:8px;font-weight:600;font-size:15px;line-height:1.2;
  text-align:center;text-decoration:none;cursor:pointer;transition:.2s;border:2px solid transparent}
.vl-btn--white{background:#fff;color:var(--blue)}
.vl-btn--white:hover{background:#eef6ff;color:var(--blue)}
.vl-btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.vl-btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.vl-btn--solid{background:var(--blue);color:#fff}
.vl-btn--solid:hover{background:var(--blue-d);color:#fff}
.vl-btn--soft{background:var(--alt);color:var(--blue)}          /* light-bg secondary */
.vl-btn--soft:hover{background:#e7f1fb;color:var(--blue)}
.vl-btn--block{width:100%}
.vl-card--orange .vl-btn--solid{background:var(--orange)}.vl-card--orange .vl-btn--solid:hover{background:#e07f00}
.vl-card--green .vl-btn--solid{background:var(--green)}.vl-card--green .vl-btn--solid:hover{background:#219150}

/* ---- product / pricing cards ---- */
.vl-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
.vl-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 30px;display:flex;flex-direction:column;
  box-shadow:0 30px 60px rgba(20,40,80,.05)}
.vl-card--feature{border-color:var(--blue);box-shadow:0 30px 70px rgba(12,113,195,.16);position:relative}
.vl-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:12px;
  font-weight:600;letter-spacing:.5px;padding:5px 14px;border-radius:20px}
.vl-card-name{font-size:15px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--blue)}
.vl-card--orange .vl-card-name{color:var(--orange)}
.vl-card--blue .vl-card-name{color:var(--blue)}
.vl-card--green .vl-card-name{color:var(--green)}
.vl-price{margin:14px 0 4px;color:var(--ink);font-weight:600;line-height:1}
.vl-price .vl-cur{font-size:22px;vertical-align:top;color:var(--body)}
.vl-price .vl-amt{font-size:52px;letter-spacing:-1px}
.vl-price .vl-per{font-size:16px;color:var(--body);font-weight:400}
.vl-feat{list-style:none;padding:22px 0 0;margin:18px 0 26px;border-top:1px solid var(--line);flex:1}
.vl-feat li{position:relative;padding:0 0 12px 26px;font-size:15px;color:var(--body)}
.vl-feat li:before{content:"\2713";position:absolute;left:0;top:0;color:var(--green);font-weight:700}
.vl-feat li.off{color:#9aa8b5}
.vl-feat li.off:before{content:"\2013";color:#b9c4cd}

/* ---- "everything included" feature grid ---- */
.vl-features{display:grid;grid-template-columns:repeat(3,1fr);gap:34px 40px}
.vl-feature{display:flex;gap:16px;align-items:flex-start}
.vl-feature svg{flex:0 0 auto;width:40px;height:40px;stroke:var(--orange);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.vl-feature h4{color:var(--ink);font-size:17px;font-weight:600;margin:2px 0 4px}
.vl-feature p{margin:0;font-size:15px}

/* ---- 3-step "how it works" ---- */
.vl-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.vl-step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 26px;text-align:center}
.vl-step-n{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;
  background:var(--blue);color:#fff;font-weight:700;font-size:18px;margin-bottom:14px}
.vl-step h4{color:var(--ink);font-size:18px;margin:0 0 6px}
.vl-step p{margin:0;font-size:15px}

/* ---- responsive ---- */
@media(max-width:900px){
  .vl-hero h1{font-size:38px}.vl-sec-head h2{font-size:30px}
  .vl-sec{padding:58px 0}
  .vl-hero-cta{justify-content:center}
  .vl-cards,.vl-features,.vl-steps{grid-template-columns:1fr}
}
@media(min-width:901px) and (max-width:1100px){.vl-features{grid-template-columns:repeat(2,1fr)}}
