/* COUNSELOR — black & gold premium */
:root{
  --bg:#0b0b0d;
  --panel:#101015;
  --text:#f2f2f2;
  --muted:rgba(242,242,242,.82);
  --gold:#d8b35a;
  --line:rgba(216,179,90,.35);
  --shadow: 0 18px 50px rgba(0,0,0,.55);
  --radius: 18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-size:17px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  background:var(--bg);
  color:var(--text);
}
.bg{
  position:fixed; inset:0;
  background:
    radial-gradient(900px 520px at 50% -10%, rgba(216,179,90,.16), transparent 60%),
    radial-gradient(900px 520px at 10% 10%, rgba(216,179,90,.07), transparent 62%),
    radial-gradient(700px 520px at 90% 30%, rgba(216,179,90,.05), transparent 65%);
  pointer-events:none;
  z-index:-1;
}
a{color:inherit}
.wrap{max-width:1080px; margin:0 auto; padding:18px}
.top{
  position:sticky; top:0; z-index:10;
  backdrop-filter: blur(10px);
  background: rgba(11,11,13,.62);
  border-bottom:1px solid rgba(216,179,90,.18);
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px;
}
.brand{display:flex; gap:12px; align-items:center; text-decoration:none}
.logo{
  width:44px; height:44px; border-radius:50%;
  border:2px solid var(--gold);
  display:grid; place-items:center;
  box-shadow: 0 10px 30px rgba(216,179,90,.18);
}
.logo span{font-weight:900; font-size:22px; letter-spacing:.5px; color:var(--gold)}
.brand-name{font-weight:900; letter-spacing:3px}
.brand-sub{font-size:13px; color:var(--muted); margin-top:2px}
.actions{display:flex; gap:10px; align-items:center; flex-wrap:wrap; row-gap:10px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 14px; border-radius:999px;
  border:1px solid rgba(216,179,90,.35);
  background: linear-gradient(180deg, rgba(216,179,90,.22), rgba(216,179,90,.10));
  color: var(--text);
  text-decoration:none; font-weight:800; letter-spacing:.3px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.btn:hover{border-color: rgba(216,179,90,.60)}
.btn-outline{background: transparent}
.btn-sm{padding:8px 12px; font-size:13px}
.hero{
  margin-top:18px;
  background: linear-gradient(180deg, rgba(216,179,90,.10), rgba(16,16,21,.70));
  border:1px solid rgba(216,179,90,.22);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 26px 18px;
}
h1{margin:0 0 10px; font-size: clamp(26px, 4vw, 44px); letter-spacing:.3px}
.lead{margin:0 0 18px; color:var(--muted); font-size:17px; line-height:1.6}
.lead strong{color:var(--text)}
.grid{display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:12px; margin-top:14px}
.card{
  text-decoration:none; color:inherit;
  background: rgba(255,255,255,.035);
  border:1px solid rgba(216,179,90,.20);
  border-radius:16px; padding:14px;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.card:hover{transform: translateY(-2px); border-color: rgba(216,179,90,.45); background: rgba(16,16,21,.92)}
.icon{font-size:22px; margin-bottom:8px}
.title{font-weight:900; letter-spacing:.2px; margin-bottom:6px}
.desc{color:var(--muted); font-size:14px; line-height:1.45}
.section{
  margin-top:16px; padding:18px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(216,179,90,.18);
  border-radius: var(--radius);
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
}
.section-head h2{margin:0; letter-spacing:.4px}
.section-head p{margin:8px 0 0; color: var(--muted)}
.list{margin:14px 0 0; padding-left:18px; color:var(--muted); line-height:1.7}
.list li{margin:6px 0}
.list li::marker{color:var(--gold)}
.breadcrumb{margin-top:10px; color:rgba(242,242,242,.6); font-size:13px}
.breadcrumb a{color:rgba(242,242,242,.9); text-decoration:none; border-bottom:1px dashed rgba(216,179,90,.35)}
.breadcrumb a:hover{border-bottom-color: rgba(216,179,90,.8)}
.split{display:grid; grid-template-columns: 1.1fr .9fr; gap:14px; align-items:start}
.contact-box{
  border:1px solid rgba(216,179,90,.20);
  border-radius:16px; padding:14px;
  background: rgba(255,255,255,.025);
}
.kv{display:flex; gap:10px; justify-content:space-between; padding:10px 0; border-bottom:1px solid rgba(216,179,90,.12)}
.kv:last-child{border-bottom:0}
.k{color: var(--muted)}
.v a{color: var(--text); text-decoration:none; border-bottom:1px dashed rgba(216,179,90,.40)}
.v a:hover{border-bottom-color: rgba(216,179,90,.80)}
.note{margin-top:10px; color:var(--muted); font-size:13px}
.qr{display:flex; flex-direction:column; align-items:center; gap:10px}
.qr-box{
  width:210px; max-width:100%;
  border-radius:16px; border:1px solid rgba(216,179,90,.25);
  background:#fff; padding:12px;
}
.qr-box img{display:block; width:100%; height:auto}
.qr-caption{color:var(--muted); font-size:13px; text-align:center}
.form{display:grid; gap:10px; margin-top:10px}
.input, .textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(216,179,90,.25);
  background: rgba(255,255,255,.025);
  color: var(--text);
  outline:none;
}
.textarea{min-height:110px; resize:vertical}
.input:focus, .textarea:focus{border-color: rgba(216,179,90,.65)}
.small{color:var(--muted); font-size:12px; line-height:1.5}
.footer{margin:18px 0 50px; text-align:center; color:rgba(242,242,242,.55); font-size:12px}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(216,179,90,.22);
  background: rgba(216,179,90,.06);
  color: rgba(242,242,242,.85);
  font-size:12px;
}
/* Floating contact buttons */
.fab{
  position:fixed;
  right:16px;
  bottom:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:999;
}
.fab a{
  width:54px; height:54px;
  border-radius:18px;
  display:grid; place-items:center;
  text-decoration:none;
  border:1px solid rgba(216,179,90,.35);
  background: rgba(11,11,13,.72);
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
}
.fab a:hover{border-color: rgba(216,179,90,.70)}
.fab span{font-size:22px}
@media (max-width: 980px){
  .grid{grid-template-columns: repeat(2, minmax(0,1fr))}
  .split{grid-template-columns: 1fr}
}

/* Buttons */
.btn-primary{
  background: linear-gradient(180deg, rgba(216,179,90,.34), rgba(216,179,90,.14));
  border-color: rgba(216,179,90,.65);
}
.btn-primary:hover{border-color: rgba(216,179,90,.95)}
.btn-outline{
  background: transparent;
  border-color: rgba(216,179,90,.35);
}

@media (max-width: 720px){
  .top{align-items:flex-start}
  .actions{
    width: 100%;
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:10px;
    margin-top: 10px;
  }
  .actions .btn{
    width:100%;
    justify-content:center;
  }
  .brand-sub{max-width: 220px}
}


@media (max-width: 720px){
  .actions{
    width:100% !important;
    display:grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap:10px !important;
    margin-top:10px !important;
  }
  .actions .btn{
    width:100% !important;
  }
}



@media (max-width: 860px){
  .top{
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .brand{
    width: 100%;
  }
  .actions{
    width:100%;
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap:10px;
  }
  .actions .btn{
    width:100%;
    justify-content:center;
    padding:12px 14px;
    font-size:14px;
  }
  /* last button (Сохранить контакт) на всю ширину */
  .actions .btn:last-child{
    grid-column: 1 / -1;
  }
}



@media (max-width: 520px){
  .wrap{padding:14px}
  .hero{padding:18px 14px}
  .lead{font-size:15px}
  .grid{grid-template-columns: 1fr 1fr; gap:10px}
  .card{padding:12px}
  .desc{font-size:12.5px}
}



/* Mobile bottom bar */
.bbar{
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 1000;
  display: none;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.bbtn{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  padding: 10px 8px;
  border-radius: 16px;
  text-decoration:none;
  border: 1px solid rgba(216,179,90,.35);
  background: rgba(11,11,13,.65);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
}
.bbtn span{font-size:20px}
.bbtn small{font-size:11px; color: rgba(242,242,242,.85)}
@media (max-width: 720px){
  .bbar{display:grid;}
  .fab{display:none;}
  body{padding-bottom: 90px;} /* space for bottom bar */
}



/* iOS Safari fixes */
html{height: -webkit-fill-available;}
body{
  -webkit-text-size-adjust: 100%;
}

/* Prevent iOS zoom on input focus */
.input, .textarea{
  font-size: 16px;
}

/* On mobile: avoid sticky jump when keyboard opens */
@media (max-width: 720px){
  .top{position: relative;}
  .bbar{transform: translateZ(0);}
}

/* Hide fixed bars while typing (keyboard open) */
body.keyboard .bbar{display:none !important;}
body.keyboard .fab{display:none !important;}

/* Micro animations */
.btn, .card, .input, .textarea{
  transition: transform .12s ease, border-color .12s ease, background .12s ease, box-shadow .12s ease;
}
.btn:active{transform: translateY(1px)}
.input:focus, .textarea:focus{
  box-shadow: 0 0 0 4px rgba(216,179,90,.10);
}
.card:hover{
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}

/* FAQ */
.faq{margin-top:14px; display:grid; gap:10px}
.faq details{
  border:1px solid rgba(216,179,90,.18);
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  padding: 10px 12px;
}
.faq summary{
  cursor:pointer;
  font-weight:800;
  list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq .a{color: rgba(242,242,242,.85); margin-top:8px; line-height:1.65; font-size:14px}

/* Map */
.map{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(216,179,90,.18);
  background: rgba(255,255,255,.02);
}
.map iframe{display:block;}

/* Packages grid */
@media (max-width: 980px){
  #packages .grid{grid-template-columns: 1fr !important;}
}

/* Packages (cards as buttons) */
.pkg-grid{grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px}
.pkg{cursor:pointer; text-align:left; border:1px solid rgba(216,179,90,.18)}
.pkg .price{font-size:28px;font-weight:900;margin-top:12px}
.pkg.popular{
  border:1px solid rgba(216,179,90,.55);
  box-shadow: 0 18px 55px rgba(216,179,90,.10), 0 24px 70px rgba(0,0,0,.35);
}
.pop-badge{
  display:inline-block;
  margin-bottom:10px;
  background: rgba(216,179,90,.18);
  border: 1px solid rgba(216,179,90,.55);
}

/* Modal */
body.modal-open{overflow:hidden}
.modal{position:fixed; inset:0; display:none; z-index:50;}
.modal.show{display:block}
.modal-bg{position:absolute; inset:0; background: rgba(0,0,0,.65); backdrop-filter: blur(6px);}
.modal-card{
  position:relative;
  max-width: 560px;
  margin: 10vh auto;
  background: rgba(15,15,18,.96);
  border:1px solid rgba(216,179,90,.25);
  border-radius: 18px;
  padding: 14px 14px 16px;
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
@media (max-width: 980px){
  .pkg-grid{grid-template-columns: 1fr;}
  .modal-card{margin: 8vh 14px;}
}

/* Package modal text */
.pkg-contents{font-size:16.5px; line-height:1.45}
@media (max-width: 980px){
  .pkg-contents{font-size:17px}
}

/* Ensure modal contents is readable on top of .small */
.small.pkg-contents{font-size:18px !important; line-height:1.5 !important;}
@media (max-width: 980px){
  .small.pkg-contents{font-size:18.5px !important;}
}

/* footer policies */
.footer a{opacity:.9}
.footer a:hover{text-decoration:underline}

/* law menu */
.tiles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px}
@media (max-width:520px){.tiles{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}}
.tile{background:rgba(18,18,22,.72);border:1px solid rgba(216,179,90,.22);border-radius:24px;padding:16px;min-height:128px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 24px 70px rgba(0,0,0,.28);text-decoration:none;color:inherit}
.tile:hover{border-color:rgba(216,179,90,.38)}
.tile .emoji{font-size:28px;opacity:.95}
.tile h3{margin:10px 0 0;font-size:20px;line-height:1.15}
.tile .muted{opacity:.78;font-size:13px;margin-top:6px}
.list-links{display:grid;gap:10px;margin-top:14px}
.list-links a{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 14px;border-radius:18px;background:rgba(18,18,22,.55);border:1px solid rgba(216,179,90,.18);text-decoration:none;color:inherit}
.list-links a:hover{border-color:rgba(216,179,90,.32)}
.list-links .name{font-weight:750}
