/* hoi.vg — Brand-Layer über Bootstrap 5. Marke „Hoi" = „Hallo Vinschgau".
   Fixe Design-Logik für alle Seiten: Tokens, Komponenten, Parallax, Animationen. */

@font-face{font-family:"Inter";src:url("/assets/fonts/inter-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Inter";src:url("/assets/fonts/inter-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Inter";src:url("/assets/fonts/inter-700.woff2") format("woff2");font-weight:700;font-display:swap}

:root{
  --ink:#3e3a37; --paper:#fff; --bg:#fafafa; --peach:#f9d6ba; --peach-soft:#fdeee0;
  --accent:#e8472b; --accent2:#ff7a59; --mute:#6b7280;
  --line:rgba(62,58,55,.12); --radius:18px; --shadow:0 18px 50px rgba(62,58,55,.10);
  --ease:cubic-bezier(.16,.84,.44,1); --nav-h:66px;
  --bs-body-font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --bs-body-color:#3e3a37; --bs-body-bg:#fff;
}
body{font-family:var(--bs-body-font-family);color:var(--ink);font-size:clamp(15px,.92vw,16.5px);line-height:1.66;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{font-weight:700;letter-spacing:-.02em;line-height:1.1}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%}
.text-muted-2{color:var(--mute)!important}
.skip{position:absolute;top:8px;left:8px;z-index:1000;background:var(--ink);color:#fff;padding:.5rem 1rem;border-radius:8px}

/* ---- Buttons ---- */
.btn{font-weight:700;border-radius:999px;border:1.5px solid transparent;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s,color .2s;padding:.7em 1.4em}
.btn:hover{transform:translateY(-2px)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 10px 24px rgba(232,71,43,.28)}
.btn-accent:hover{background:#d83d22;color:#fff}
.btn-ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn-lg{padding:.85em 1.7em;font-size:1.05rem}

/* ---- Header / Navbar ---- */
.site-header{position:sticky;top:0;z-index:1030;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
body.scrolled .site-header{border-color:var(--line);box-shadow:0 6px 20px rgba(62,58,55,.05)}
.navbar{min-height:var(--nav-h)}
.brand{font-weight:700;font-size:1.2rem;letter-spacing:-.03em;color:var(--ink)}
.brand .dot{color:var(--accent)}
.nav-link{font-weight:600;color:var(--ink);opacity:.8;padding:.4rem .85rem!important;border-radius:999px}
.nav-link:hover,.nav-link.active{opacity:1;color:var(--accent)}
.navbar-toggler:focus{box-shadow:none}

/* ---- Sections ---- */
.section{padding:clamp(3.5rem,8vw,6.5rem) 0}
.section-soft{background:var(--bg)}
.kicker{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:700;color:var(--accent);display:inline-block}
.lead{color:var(--mute);font-size:clamp(1.05rem,2.2vw,1.25rem)}
.section-head{max-width:60ch;margin-bottom:2.6rem}
.section-head h2{font-size:clamp(1.7rem,4.2vw,2.6rem);margin:.5rem 0 .7rem}

/* ---- Hero (home) ---- */
.hero{position:relative;overflow:hidden;text-align:center;padding:clamp(2rem,6vw,4rem) 0 clamp(3.5rem,8vw,6rem);
  background:radial-gradient(1100px 620px at 50% -10%,var(--peach-soft),var(--paper) 64%)}
.hero .eyebrow{display:inline-block;font-size:.8rem;font-weight:700;color:var(--ink);background:var(--peach);padding:.4em 1em;border-radius:999px;margin-bottom:1.4rem}
.hero h1{font-size:clamp(2.3rem,6.5vw,4.4rem);margin:.2rem auto .9rem;max-width:16ch}
.hero h1 .accent{color:var(--accent)}
.hero .lead{margin:0 auto 2rem;max-width:60ch}
.hero-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* ---- Page hero (Unterseiten) ---- */
.page-hero{padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(1.5rem,4vw,2.5rem);background:radial-gradient(900px 420px at 20% -20%,var(--peach-soft),var(--paper) 70%)}
.page-hero h1{font-size:clamp(2rem,5vw,3.4rem);max-width:18ch;margin:.4rem 0 .8rem}
.page-hero .lead{max-width:62ch}
.crumb{font-size:.85rem;color:var(--mute)}
.crumb a:hover{color:var(--accent)}

/* ---- Animiertes Logo ---- */
.logo-stage{width:min(440px,84vw);margin:0 auto 1.4rem;filter:drop-shadow(0 16px 34px rgba(62,58,55,.12))}
.logo-bubble{transform-origin:122px 63px;animation:bubblePop .9s var(--ease) both}
.logo-text{opacity:0;animation:fadeUp .7s var(--ease) .45s both}
#logo-rays{transform-box:fill-box;transform-origin:center;animation:spin 22s linear infinite}
#logo-rays line{animation:twinkle 2.4s ease-in-out infinite}
.logo-sun{transform-box:fill-box;transform-origin:center;animation:sunPop .6s var(--ease) .7s both,sunPulse 3s ease-in-out 1.3s infinite}
@keyframes bubblePop{0%{opacity:0;transform:scale(.82) translateY(10px)}60%{opacity:1}100%{opacity:1;transform:scale(1) translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes twinkle{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes sunPop{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
@keyframes sunPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.14)}}

/* ---- Cards / Leistungen ---- */
.card-hoi{height:100%;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s}
.card-hoi:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.card-hoi .ic{color:var(--accent);margin-bottom:.9rem}
.card-hoi h3{font-size:1.2rem;margin:.2rem 0 .15rem}
.card-hoi .sub{font-weight:700;font-size:.95rem;margin-bottom:.5rem}
.card-hoi p{color:var(--mute);font-size:.95rem;margin:0}
.card-link{display:inline-flex;align-items:center;gap:.3em;color:var(--accent);font-weight:700;font-size:.9rem;margin-top:.9rem}
.card-link .ic{margin:0;color:inherit}
.card-link:hover{color:#d83d22}

/* ---- Trust band ---- */
.band{background:var(--bg);border-radius:var(--radius);padding:clamp(2rem,5vw,3rem)}
.trust .ic{color:var(--accent);margin-bottom:.6rem}
.trust h3{font-size:1.1rem;margin-bottom:.35rem}
.trust p{color:var(--mute);font-size:.95rem;margin:0}

/* ---- Feature list (Unterseiten) ---- */
.feat{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:1rem}
.feat .ic{flex:none;color:var(--accent);margin-top:2px}
.feat h3{font-size:1.05rem;margin:0 0 .1rem}
.feat p{color:var(--mute);font-size:.95rem;margin:0}

/* ---- Steps ---- */
.step{position:relative;padding-left:0}
.step .num{display:inline-flex;width:2.2rem;height:2.2rem;align-items:center;justify-content:center;border-radius:999px;background:var(--peach);color:var(--ink);font-weight:700;margin-bottom:.7rem}
.step h3{font-size:1.1rem;margin-bottom:.2rem}
.step p{color:var(--mute);font-size:.95rem;margin:0}

/* ---- Contact strip ---- */
.section-contact{padding:clamp(2.5rem,6vw,4rem) 0}
.contact{background:var(--ink);color:#fff;border-radius:var(--radius);text-align:center;padding:clamp(2.5rem,6vw,4rem) clamp(1.2rem,5vw,3rem)}
.contact h2{font-size:clamp(1.8rem,4.5vw,2.8rem);margin-bottom:.7rem}
.contact p{color:rgba(255,255,255,.78);max-width:48ch;margin:0 auto 1.8rem}
.contact .btn-accent{box-shadow:0 10px 30px rgba(232,71,43,.4)}

/* ---- FAQ ---- */
.faq details{border:1px solid var(--line);border-radius:14px;padding:1rem 1.2rem;margin-bottom:.7rem;background:var(--paper)}
.faq summary{font-weight:700;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq details[open] summary{color:var(--accent)}
.faq p{color:var(--mute);margin:.7rem 0 0}

/* ---- Footer ---- */
.site-footer{padding:3rem 0 2rem;border-top:1px solid var(--line)}
.foot-h{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--mute);margin-bottom:.8rem}
.foot-list{list-style:none;padding:0;margin:0}
.foot-list li{margin-bottom:.4rem}
.foot-list a{color:var(--ink);opacity:.85;font-size:.92rem}
.foot-list a:hover{color:var(--accent);opacity:1}
.foot-legal{margin-top:2rem;padding-top:1.2rem;border-top:1px solid var(--line);color:var(--mute);font-size:.85rem}

/* ---- Prose (Impressum/Datenschutz) ---- */
.prose{max-width:70ch}
.prose h2{font-size:1.4rem;margin:2rem 0 .6rem}
.prose p,.prose li{color:var(--ink)}
.prose a{color:var(--accent)}

/* ---- Consent banner ---- */
.consent{position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:520px;margin:0 auto;z-index:1050;
  background:var(--ink);color:#fff;border-radius:14px;padding:1rem 1.2rem;box-shadow:0 18px 50px rgba(0,0,0,.3)}
.consent p{font-size:.9rem;margin:0 0 .8rem}
.consent-actions{display:flex;gap:.6rem;justify-content:flex-end}
.consent .btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}

/* ---- Parallax + Reveal ---- */
.parallax{will-change:transform}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.no-js .reveal{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .logo-bubble,.logo-text,.logo-sun,#logo-rays,#logo-rays line{animation:none;opacity:1;transform:none}
  .parallax{transform:none!important}
}
