
:root{
  --bg:#0b0b0e; --panel:#121216; --line:#22232a;
  --text:#f1efe9; --muted:#b8b6b0; --gold: #fcf602;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{text-decoration:none;color:var(--text)}
header{position:sticky;top:0;z-index:10;background:rgba(11,11,14,.85);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line)}
.head{max-width:1100px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px}
nav a{margin-left:18px;font-weight:700}
nav a:hover{color:var(--gold)}
.lang a{margin-left:10px;color:var(--muted);font-weight:700}
.lang a.active{color:var(--gold)}

/* HERO with video */
.hero{position:relative;min-height:52vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero .bgvideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero::after{content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(80% 80% at 50% 25%, rgba(201,166,70,.10), transparent 60%),
             linear-gradient(180deg, rgba(0,0,0,.30), rgba(0,0,0,.70));}
.hero .inner{max-width:1100px;text-align:center;padding:80px 20px}
h1{font-family:'Playfair Display', Georgia, serif;font-weight:900;margin:0 0 10px 0;font-size:46px}
p.lead{color:var(--muted)}

.section{border-bottom:1px solid var(--line)}
.wrap{max-width:1000px;margin:0 auto;padding:50px 20px}
h2{font-family:'Playfair Display', Georgia, serif;font-weight:900;margin:0 0 10px 0;font-size:28px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.badge{display:inline-block;border:1px solid var(--gold);color:var(--gold);padding:2px 8px;border-radius:999px;font-size:12px;margin-left:8px}
form label{display:block;font-weight:700;margin:14px 0 8px}
input,select,textarea{width:100%;background:#0f0f13;border:1px solid var(--line);color:var(--text);
  border-radius:10px;padding:12px}
.button{display:inline-block;background:var(--gold);color:#111;border:none;border-radius:10px;padding:12px 18px;font-weight:800;cursor:pointer}
.button.ghost{background:transparent;border:1px solid var(--gold);color:var(--gold)}
footer{border-top:1px solid var(--line);color:var(--muted)}
footer .wrap{padding:26px 20px}
@media (max-width:900px){.cards{grid-template-columns:1fr} nav{display:none}}


/* === HERO with background video and dark overlay === */
.hero{
  position: relative;
  min-height: clamp(420px, 70vh, 760px);
  display: grid;
  align-items: center;
  
  overflow: hidden;
}
.hero .hero-video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-height: none; /* we control height via container */
  filter: grayscale(0); /* keep color then overlay dims */
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.42); /* slight grey/dim */
  pointer-events:none;
  z-index:1;
}
.hero .inner{
  position: relative;
  z-index: 2;
  max-width: 1100px;
  width: 100%;
  padding: 60px 20px;
  margin: 0 auto;
}
.hero h1{ 
  font-family:'Playfair Display', Georgia, serif;
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.05;
  margin: 0 0 10px 0;
}
.hero .lead{ 
  color: var(--muted);
  font-size: clamp(16px, 1.8vw, 20px);
}
.hero .button{ margin-right:10px }
@media (max-width: 700px){
  .hero{ min-height: 60vh }
  .hero .inner{ padding: 40px 16px }
}


.hero .button{margin:10px 8px 0 8px;}
.explain{max-width:800px;margin:0 auto 20px auto;text-align:center;line-height:1.5;}


form .button, form button[type=submit]{margin-top:20px;display:inline-block}


/* extra spacing for submit button inside forms */
section .wrap form .button, form .button { margin-top: 18px; display:inline-block; }
section .wrap form .field, form .field { margin-bottom: 14px; }
input[type="file"]{ background:#0f0f13; border:1px solid var(--line); color:var(--text); border-radius:10px; padding:10px; }
.small-note{ color: var(--muted); font-size: 13px; margin-top: 6px; display:block; }


.cards .card{transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease; cursor:default;}
.cards .card:hover{ background: var(--gold); color:#111; border-color: var(--gold); transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.25); cursor:pointer;}

.form-row{display:flex;gap:20px;flex-wrap:wrap}.form-col{flex:1;min-width:220px}
