:root{
  --purple:#5C3566;
  --purple-deep:#300B3B;
  --orange:#ED8721;

  --bg:#ffffff;
  --bg-soft:#fbfafc;
  --text:#15131a;
  --muted:#6b6573;

  --line:#ece8f0;
  --card:#ffffff;

  --shadow-sm: 0 8px 22px rgba(0,0,0,.08);
  --shadow: 0 14px 40px rgba(0,0,0,.12);

  --r:18px;
  --r2:22px;

  --max:1120px;

  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit}
img{max-width:100%; display:block}

.container{max-width:var(--max); margin:0 auto; padding:0 18px;}
.narrow{max-width:820px;}
.center{text-align:center}
.muted{color:var(--muted)}
.lead{font-size:1.05rem; line-height:1.7; color:#2b2731}

.main{min-height:60vh}

/* =========================
   TOPBAR
========================= */
.topbar{
  position:sticky; top:0; z-index:20;
  background:rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:12px 0;
}
.brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none;
}
.brand-logo{height:34px; width:auto}
.nav{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.nav-link{
  text-decoration:none;
  padding:10px 12px;
  border-radius:14px;
  color:#2c2432;
  font-weight:650;
}
.nav-link:hover{background:#f4f1f6}
.nav-link.active{background:rgba(92,53,102,.10)}
.lang{
  padding:9px 10px;
  border-radius:14px;
  text-decoration:none;
  border:1px solid var(--line);
  background:#fff;
}
.lang:hover{background:#f7f4f8}

/* =========================
   FLASH
========================= */
.flash{
  max-width:var(--max);
  margin:14px auto 0;
  padding:12px 18px;
  border-radius:14px;
  border:1px solid var(--line);
}
.flash-ok{background:#eefaf1}
.flash-warn{background:#fff8e8}
.flash-error{background:#ffeef0}

/* =========================
   HERO (Premium + Compact)
========================= */
.hero{
  position:relative;
  padding:74px 0 62px;
  color:#fff;

  background:
    radial-gradient(900px 450px at 70% 20%, rgba(237,135,33,.30), transparent 60%),
    radial-gradient(900px 500px at 10% 10%, rgba(255,255,255,.10), transparent 62%),
    linear-gradient(120deg, rgba(48,11,59,.95), rgba(92,53,102,.78));
}
.hero:after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-1px;
  height:18px;
  background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,1));
}
.hero-inner{display:flex; justify-content:flex-start;}

.hero-wrap{
  display:flex;
  flex-direction:column;
  gap:14px;
  max-width:760px; /* high-end focus */
}

.hero-card{
  border-radius:var(--r2);
  padding:26px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  box-shadow: 0 20px 80px rgba(0,0,0,.26);
  backdrop-filter: blur(8px);
}

.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:13px;
  color:rgba(255,255,255,.90);
}
.kicker-dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 5px rgba(237,135,33,.22);
}

.hero-card h1{
  margin:14px 0 10px;
  font-size:44px;
  line-height:1.04;
  letter-spacing:-.6px;
  color:#fff;
}
.hero-sub{
  margin:0 0 14px;
  font-size:18px;
  line-height:1.65;
  color:rgba(255,255,255,.92);
  max-width:62ch;
}

/* USP list in hero */
.points{
  display:grid;
  grid-template-columns:1fr; /* compact */
  gap:10px;
  margin:0 0 14px;
  padding:0;
  list-style:none;
}
.points li{
  position:relative;
  padding-left:22px;
  color:rgba(255,255,255,.92);
}
.points li:before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--orange);
  font-weight:900;
}

.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:12px}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 18px;
  border-radius:16px;
  text-decoration:none;
  font-weight:900;
  border:1px solid rgba(0,0,0,.08);
  transition: transform .14s ease, filter .14s ease, box-shadow .14s ease, background .14s ease;
  user-select:none;
}
.btn:active{transform: translateY(1px)}
.btn-primary{
  background:var(--orange);
  color:#2b1605;
  box-shadow: 0 16px 30px rgba(237,135,33,.24);
}
.btn-primary:hover{filter:brightness(1.03)}
.btn-ghost{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.20);
  box-shadow:none;
}
.btn-ghost:hover{background:rgba(255,255,255,.12)}

.link-soft{
  color:rgba(255,255,255,.92);
  text-decoration:none;
  font-weight:900;
  padding:10px 6px;
  border-radius:12px;
}
.link-soft:hover{background:rgba(255,255,255,.08)}

/* Trust strip under hero card */
.trust-strip{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding-left:6px;
}
.chip{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.92);
  font-size:13px;
}

/* =========================
   SECTIONS
========================= */
.section{padding:62px 0}
.section.alt{
  background:var(--bg-soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-title{
  margin:0;
  font-size:34px;
  letter-spacing:-.4px;
  color:#2c2432;
}
.section-subtitle{
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.6;
}

/* =========================
   TILES (Services)
========================= */
.tiles{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top:22px;
}
.tile{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r2);
  padding:22px 22px 20px;
  box-shadow: var(--shadow-sm);
  text-align:left;
  outline:none;
  position:relative;
  overflow:hidden;
  min-height:178px;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.tile:before{
  content:"";
  position:absolute;
  inset:-40px -40px auto auto;
  width:160px;
  height:160px;
  border-radius:50%;
  background: radial-gradient(circle at 30% 30%, rgba(92,53,102,.18), rgba(237,135,33,.10), transparent 62%);
  pointer-events:none;
}
.tile:hover, .tile:focus{
  transform: translateY(-4px);
  border-color: rgba(92,53,102,.22);
  box-shadow: var(--shadow);
}
.tile-top{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.tile-icon{
  width:52px; height:52px;
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(92,53,102,.10);
  border:1px solid rgba(92,53,102,.16);
  font-size:24px;
}
.tile-title{
  margin:0;
  font-size:20px;
  font-weight:950;
  letter-spacing:-.2px;
  color:#2c2432;
}
.tile-desc{
  margin:10px 0 0;
  color:#3a3541;
  line-height:1.55;

  opacity:0;
  transform: translateY(6px);
  transition: .18s ease;
}
.tile:hover .tile-desc,
.tile:focus .tile-desc{
  opacity:1;
  transform: translateY(0);
}
.tile-foot{
  margin-top:14px;
  display:flex;
  gap:10px;
  align-items:center;
  color:var(--muted);
  font-size:13px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:#f6f3f7;
  border:1px solid var(--line);
}


/* =========================
   CARDS (Qualities)
========================= */
.cards3{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top:18px;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r2);
  padding:22px;
  box-shadow: var(--shadow-sm);
}
.card h3{
  margin:0 0 8px;
  color:#2c2432;
  font-size:18px;
  letter-spacing:-.2px;
}
.card p{margin:0; color:#3b3642; line-height:1.62}

/* =========================
   PRICING
========================= */
.price-card{
  margin-top:18px;
  border-radius:var(--r2);
  border:1px solid var(--line);
  box-shadow: var(--shadow-sm);
  overflow:hidden;
  background:#fff;
}
.price-head{
  padding:18px 18px 14px;
  background:linear-gradient(120deg, rgba(48,11,59,.95), rgba(92,53,102,.85));
  color:#fff;
  font-weight:950;
  font-size:20px;
}
.price-body{padding:16px 18px 18px}
.price-row{
  padding:12px 0;
  border-top:1px solid var(--line);
  color:#2f2a36;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.price-row:first-child{border-top:none}
.price-note{
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.6;
  font-size:14px;
}
.price-cta{margin-top:14px}

/* =========================
   FORM
========================= */
.form{margin-top:18px; display:grid; gap:14px;}
label{display:grid; gap:8px; font-size:14px; color:#2f2a36}
input, textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px 12px;
  font:inherit;
  outline:none;
  background:#fff;
}
input:focus, textarea:focus{
  border-color:rgba(92,53,102,.45);
  box-shadow:0 0 0 4px rgba(92,53,102,.12);
}
.grid2{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px}
.hp{display:none !important;}
.small{font-size:13px}

/* =========================
   CONTACT premium layout
========================= */
.contact-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap:18px;
  align-items:start;
}
.contact-card,
.contact-form-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius: var(--r2);
  box-shadow: var(--shadow-sm);
  padding:22px;
}
.contact-card-title{
  margin:0 0 10px;
  font-size:18px;
  letter-spacing:-.2px;
}
.contact-steps{
  margin:0;
  padding:0 0 0 18px;
  display:grid;
  gap:12px;
  line-height:1.55;
}
.contact-mini{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.form-foot{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  margin-top:4px;
}

/* =========================
   ABOUT (Premium 2-col)
========================= */
.about-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  align-items:start;
}
.about-card{
  margin-top:16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius: var(--r2);
  box-shadow: var(--shadow-sm);
  padding:22px;
}
.about-highlights{
  margin-top:16px;
  display:grid;
  gap:12px;
}
.hl{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:#fff;
}
.hl-ico{
  width:42px; height:42px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(92,53,102,.10);
  border:1px solid rgba(92,53,102,.16);
  font-size:18px;
}

/* Trust card */
.trust-card{
  background: linear-gradient(180deg, #ffffff, #fbfafc);
  border:1px solid var(--line);
  border-radius: var(--r2);
  box-shadow: var(--shadow-sm);
  overflow:hidden;
}
.trust-head{
  padding:22px;
  background:
    radial-gradient(520px 220px at 20% 10%, rgba(92,53,102,.14), transparent 60%),
    radial-gradient(520px 220px at 90% 0%, rgba(237,135,33,.14), transparent 60%),
    #fff;
  border-bottom:1px solid var(--line);
}
.trust-badge{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(237,135,33,.16);
  border:1px solid rgba(237,135,33,.22);
  font-size:13px;
  font-weight:950;
  color:#4a2a0b;
}
.trust-title{
  margin:12px 0 0;
  font-size:18px;
  letter-spacing:-.2px;
}
.trust-list{
  padding:18px 22px 8px;
  display:grid;
  gap:14px;
}
.trust-item{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.trust-icon{
  width:22px; height:22px;
  border-radius:7px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(92,53,102,.10);
  border:1px solid rgba(92,53,102,.16);
  color:#2c2432;
  font-weight:900;
  flex:0 0 auto;
  margin-top:2px;
}
.trust-foot{
  padding:16px 22px 22px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* About: area + FAQ */
.split-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
}
.split-actions{display:flex; gap:10px; flex-wrap:wrap}

.area-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
}
.area-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius: var(--r2);
  box-shadow: var(--shadow-sm);
  padding:22px;
}
.area-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.area-city{
  margin:0;
  font-size:18px;
  letter-spacing:-.2px;
}
.area-icon{
  width:44px; height:44px;
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(92,53,102,.10);
  border:1px solid rgba(92,53,102,.16);
}
.area-lines{
  display:grid;
  gap:6px;
  color:#2f2a36;
}
.area-lines a{color:inherit}

.faq{
  margin-top:18px;
  display:grid;
  gap:12px;
}
.faq-item{
  border:1px solid var(--line);
  border-radius: var(--r2);
  background:#fff;
  box-shadow: var(--shadow-sm);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:16px 18px;
  font-weight:950;
  color:#2c2432;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:after{
  content:"+";
  width:28px; height:28px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background:#f6f3f7;
  border:1px solid var(--line);
  font-weight:950;
}
.faq-item[open] summary:after{content:"–"}
.faq-body{
  padding:0 18px 16px;
  color:#3b3642;
  line-height:1.65;
}
.faq-cta{
  margin-top:10px;
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}

/* =========================
   FOOTER
========================= */
.footer{
  margin-top:50px;
  background:linear-gradient(0deg, rgba(237,135,33,1), rgba(237,135,33,1));
  color:#1f140a;
  padding:38px 0;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:22px;
}
.footer h3{margin:0 0 10px}
.footer a{color:#1f140a}
.cols{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:18px; margin-top:14px}
.meta{display:grid; gap:8px; align-content:start}
.brand-mark{margin-top:10px; font-weight:950; letter-spacing:.6px}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px){
  .hero-card h1{font-size:40px}
  .tiles{grid-template-columns:repeat(2, minmax(0,1fr))}
  .about-grid{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .cards3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cols{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .split-head{align-items:flex-start; flex-direction:column}
  .area-grid{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .hero{padding:60px 0 52px}
  .hero-card h1{font-size:34px}
  .tiles{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
}
