/* ============================================================
   VOCALISTERONA — SWISS MINIMAL
   Black & white, strict grid, red accent
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --bg:#ffffff; --ink:#0a0a0a; --ink-soft:#555; --line:#0a0a0a;
  --accent:#e60023; --soft:#f4f4f4;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Space Grotesk',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1240px;margin:0 auto;padding:0 28px}
section{padding:90px 0}

h1,h2,h3{font-weight:700;line-height:1.04;letter-spacing:-.025em}
h1{font-size:clamp(2.6rem,6vw,5rem);text-transform:uppercase}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem);text-transform:uppercase}
h3{font-size:1.15rem;text-transform:uppercase;letter-spacing:0}
.grad{color:var(--accent)}

/* header */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:2px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1240px;margin:0 auto;padding:0 28px}
.brand{font-weight:700;font-size:1.3rem;display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:-.02em}
.brand i{color:var(--accent)}
nav ul{display:flex;gap:0;list-style:none;align-items:center}
nav ul a{padding:10px 18px;font-weight:500;font-size:.88rem;text-transform:uppercase;letter-spacing:.02em;transition:.2s}
nav ul a:hover{color:var(--accent)}
.nav-cta{background:var(--ink)!important;color:#fff!important;padding:10px 22px!important;margin-left:10px}
.nav-cta:hover{background:var(--accent)!important;color:#fff!important}
.burger{display:none;background:none;border:none;font-size:1.4rem;color:var(--ink);cursor:pointer}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 30px;font-weight:600;font-family:inherit;cursor:pointer;border:2px solid var(--ink);transition:.18s;font-size:.92rem;text-transform:uppercase;letter-spacing:.02em;border-radius:0}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--accent);border-color:var(--accent)}
.btn-ghost{background:#fff;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}

/* hero */
.hero{padding:80px 0 0;border-bottom:2px solid var(--line)}
.hero .container{position:relative}
.eyebrow{display:inline-block;border:2px solid var(--ink);color:var(--ink);padding:6px 16px;font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:28px}
.hero p{font-size:1.25rem;color:var(--ink-soft);max-width:600px;margin:24px 0 34px}
.hero-actions{display:flex;gap:0;flex-wrap:wrap;margin-bottom:70px}
.hero-actions .btn+.btn{margin-left:-2px}
.hero-visual{margin-top:0;border-top:2px solid var(--line);overflow:hidden}
.hero-visual img{width:100%;height:auto}

/* trust */
.trust{border-bottom:2px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(5,1fr)}
.trust-item{padding:30px 20px;text-align:left;border-left:2px solid var(--line)}
.trust-item:first-child{border-left:none}
.trust-item .num{font-size:2.1rem;font-weight:700;letter-spacing:-.03em}
.trust-item .lbl{font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.03em;margin-top:4px}

/* section head */
.sec-head{max-width:720px;margin:0 0 56px}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head p{color:var(--ink-soft);font-size:1.1rem;margin-top:16px}

/* features */
.features{display:grid;grid-template-columns:repeat(3,1fr);border-top:2px solid var(--line);border-left:2px solid var(--line)}
.feature-card{padding:36px;border-right:2px solid var(--line);border-bottom:2px solid var(--line);transition:.2s}
.feature-card:hover{background:var(--ink);color:#fff}
.feature-card:hover p{color:rgba(255,255,255,.7)}
.feature-card:hover .feature-icon{color:var(--accent)}
.feature-icon{width:auto;height:auto;font-size:1.6rem;color:var(--ink);margin-bottom:24px}
.feature-card h3{margin-bottom:10px}
.feature-card p{color:var(--ink-soft)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;border:2px solid var(--line)}
.split>div:first-child{padding:54px}
.split h2{margin-bottom:18px}
.split p{color:var(--ink-soft);margin-bottom:18px}
.split-media{overflow:hidden;border-left:2px solid var(--line)}
.split-media img{width:100%;height:100%;object-fit:cover}
.check-list{list-style:none;display:grid;gap:14px}
.check-list li{display:flex;gap:12px;align-items:flex-start}
.check-list i{color:var(--accent);margin-top:4px}

/* steps */
.steps-wrap{border:2px solid var(--line)}
.steps{display:grid;grid-template-columns:repeat(4,1fr)}
.step{text-align:left;padding:40px 32px;border-left:2px solid var(--line)}
.step:first-child{border-left:none}
.step .n{width:auto;height:auto;background:none;color:var(--accent);font-weight:700;font-size:2.6rem;margin-bottom:16px;letter-spacing:-.04em}
.step h3{margin-bottom:10px}
.step p{color:var(--ink-soft);font-size:.95rem}

/* pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);border-top:2px solid var(--line);border-left:2px solid var(--line)}
.price-card{padding:40px;border-right:2px solid var(--line);border-bottom:2px solid var(--line);position:relative}
.price-card.featured{background:var(--ink);color:#fff}
.price-card.featured .price,.price-card.featured h3{color:#fff}
.price-card.featured .svc-list i{color:var(--accent)}
.price-badge{position:absolute;top:0;right:0;background:var(--accent);color:#fff;padding:6px 16px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.price-card h3{margin-bottom:6px}
.price{font-size:2.8rem;font-weight:700;margin:16px 0;letter-spacing:-.03em}
.price span{font-size:1rem;color:var(--ink-soft);font-weight:400;text-transform:none;letter-spacing:0}
.price-card.featured .price span{color:rgba(255,255,255,.6)}
.svc-list{list-style:none;display:grid;gap:13px;margin:24px 0}
.svc-list li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem}
.svc-list i{color:var(--accent);margin-top:4px}

/* faq */
.faq{max-width:900px;margin:0 auto;border-top:2px solid var(--line)}
.faq-item{border-bottom:2px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:26px 4px;cursor:pointer;font-weight:600;font-size:1.1rem;text-transform:uppercase;letter-spacing:-.01em}
.faq-q i{transition:.3s;color:var(--accent)}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:.35s;color:var(--ink-soft)}
.faq-item.open .faq-a{max-height:260px;padding-bottom:26px}

/* cta band */
.cta-band{background:var(--ink);color:#fff;padding:80px 40px;text-align:center}
.cta-band h2{margin-bottom:16px}
.cta-band p{max-width:560px;margin:0 auto 30px;color:rgba(255,255,255,.7)}
.cta-band .btn-primary{background:var(--accent);border-color:var(--accent)}
.cta-band .btn-ghost{background:transparent;color:#fff;border-color:#fff}
.cta-band .btn-ghost:hover{background:#fff;color:var(--ink)}

/* page hero */
.page-hero{padding:80px 0 60px;border-bottom:2px solid var(--line)}
.page-hero .eyebrow{margin-bottom:20px}
.page-hero p{color:var(--ink-soft);font-size:1.15rem;max-width:640px;margin:18px 0 0}

/* services list */
.svc-item{display:flex;gap:24px;padding:34px 0;border-bottom:2px solid var(--line)}
.svc-item:first-child{border-top:2px solid var(--line)}
.svc-item .ci-icon{flex:none;width:auto;height:auto;background:none;color:var(--accent);font-size:1.8rem}
.svc-item h3{margin-bottom:8px}
.svc-item p{color:var(--ink-soft)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;border:2px solid var(--line)}
.contact-form{padding:44px;border-right:2px solid var(--line)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-form label{display:block;font-weight:600;margin:16px 0 7px;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:13px 14px;border:2px solid var(--ink);border-radius:0;font-family:inherit;font-size:1rem;background:#fff;color:var(--ink)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent)}
.contact-form textarea{min-height:130px;resize:vertical}
.contact-info-card{padding:44px;background:var(--soft)}
.contact-info-card .ci{display:flex;gap:14px;align-items:flex-start;margin-bottom:26px}
.ci-icon{width:auto;height:auto;background:none;color:var(--accent);font-size:1.3rem;flex:none}
.ci h3{font-size:.95rem;margin-bottom:4px}
.ci p{color:var(--ink-soft);font-size:.95rem}
.map-box{margin-top:24px;overflow:hidden;height:220px;border:2px solid var(--line)}
.map-box iframe{width:100%;height:100%;border:0}

/* footer */
.site-footer{background:var(--ink);color:#fff;padding:70px 0 28px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px}
.foot-brand .brand{color:#fff}
.foot-brand p{color:rgba(255,255,255,.55);margin-top:16px}
.foot-col h4{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;color:var(--accent)}
.foot-col ul{list-style:none;display:grid;gap:11px}
.foot-col a{color:rgba(255,255,255,.6)}
.foot-col a:hover{color:#fff}
.foot-contact li{display:flex;gap:10px;align-items:center;color:rgba(255,255,255,.6);margin-bottom:11px}
.foot-contact i{color:var(--accent)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.18);margin-top:44px;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:rgba(255,255,255,.5);font-size:.84rem}
.foot-bottom a{color:rgba(255,255,255,.5)}

/* legal */
.legal{max-width:860px;margin:0 auto}
.legal h2{margin:32px 0 14px}
.legal p,.legal li{color:var(--ink-soft);margin-bottom:12px}
.legal ul{padding-left:22px}
.updated{color:var(--ink-soft);font-style:italic;margin-bottom:24px}

/* cookies */
.accept-cookies{position:fixed;bottom:0;left:0;right:0;background:var(--ink);color:#fff;padding:22px 28px;display:flex;gap:20px;align-items:center;justify-content:center;z-index:200;flex-wrap:wrap}
.accept-cookies p{font-size:.9rem;color:rgba(255,255,255,.8)}
.accept-cookies .btn{padding:11px 24px;border-color:#fff;color:#fff}
.accept-cookies .btn:hover{background:var(--accent);border-color:var(--accent)}

/* animation */
.animate-on-scroll{opacity:0;transform:translateY(26px);transition:.6s cubic-bezier(.2,.8,.2,1)}
.animate-on-scroll.is-visible{opacity:1;transform:none}

/* responsive */
@media(max-width:900px){
  nav{display:none}
  .burger{display:block}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .trust-item:nth-child(odd){border-left:none}
  .features,.pricing,.steps{grid-template-columns:1fr}
  .split,.contact-grid{grid-template-columns:1fr}
  .split-media,.contact-form{border-left:none;border-right:none;border-top:2px solid var(--line)}
  .step{border-left:none;border-top:2px solid var(--line)}
  .step:first-child{border-top:none}
  .form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
