/* Sunday Rooms — компоненты обратной связи */

/* ============ МОДАЛКА «ПЕРЕДЗВОНІТЬ МЕНІ» ============ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(10,10,10,0.6);backdrop-filter:blur(4px);
  z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s;
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal-window{
  background:#FFF;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;
  position:relative;transform:translateY(20px);transition:transform .4s cubic-bezier(.65,0,.35,1);
}
.modal-overlay.open .modal-window{transform:translateY(0)}
.modal-close{
  position:absolute;top:16px;right:16px;width:36px;height:36px;
  font-size:24px;color:#888;line-height:1;cursor:pointer;
  background:transparent;border:none;transition:color .2s;
}
.modal-close:hover{color:#0A0A0A}
.modal-content{padding:48px 40px}
.modal-pre{font-size:10px;letter-spacing:4px;color:#888;text-transform:uppercase}
.modal-title{
  font-family:'Fraunces',serif;font-size:34px;font-weight:400;line-height:1.05;
  letter-spacing:-1px;margin-top:14px;color:#0A0A0A;
}
.modal-title em{font-style:italic;color:#888;font-weight:300}
.modal-sub{font-size:13px;color:#555;margin-top:14px;line-height:1.6}
.modal-form{margin-top:28px}

.form-field{display:block;margin-bottom:18px}
.form-label{
  display:block;font-size:10px;letter-spacing:1.5px;color:#888;
  font-weight:500;margin-bottom:8px;
}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:10px 0;border:none;border-bottom:0.5px solid #DDD;
  font-family:inherit;font-size:15px;color:#0A0A0A;background:transparent;
  transition:border-color .2s;outline:none;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  border-bottom-color:#0A0A0A;
}
.form-field textarea{resize:vertical;min-height:80px;padding-top:8px}

.form-submit{
  width:100%;background:#0A0A0A;color:#FFF;padding:16px;border:none;
  font-size:11px;letter-spacing:2px;font-weight:500;cursor:pointer;
  margin-top:8px;transition:background .2s;font-family:inherit;
}
.form-submit:hover{background:#333}
.form-privacy{font-size:11px;color:#888;margin-top:14px;line-height:1.5}
.form-privacy a{color:#0A0A0A;text-decoration:underline;text-underline-offset:3px}

.modal-success,.floating-success,.inline-success{
  text-align:center;padding:40px 20px;
}
.modal-success .success-icon,.floating-success .success-icon{
  width:56px;height:56px;border:1px solid #0A0A0A;border-radius:50%;
  margin:0 auto 18px;display:flex;align-items:center;justify-content:center;
  font-size:24px;color:#0A0A0A;
}
.modal-success h4,.floating-success h4{
  font-family:'Fraunces',serif;font-size:24px;font-weight:400;color:#0A0A0A;
}
.modal-success p,.floating-success p{
  font-size:13px;color:#555;margin-top:8px;
}

/* ============ FLOATING BUTTON ============ */
.floating-cta{
  position:fixed;bottom:24px;right:24px;z-index:99;
  background:#0A0A0A;color:#FFF;padding:14px 18px;
  display:flex;align-items:center;gap:8px;
  cursor:pointer;transition:all .25s;border:none;
  font-family:inherit;font-size:13px;font-weight:500;
  box-shadow:0 4px 20px rgba(0,0,0,0.2);
}
.floating-cta:hover{background:#333;transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.25)}
.floating-cta svg{width:18px;height:18px;flex-shrink:0}
.floating-cta-label{letter-spacing:0.5px}

.floating-panel{
  position:fixed;bottom:90px;right:24px;width:360px;max-width:calc(100vw - 48px);
  background:#FFF;z-index:100;border:0.5px solid #0A0A0A;
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity .3s,visibility .3s,transform .3s;
  box-shadow:0 10px 40px rgba(0,0,0,0.15);
}
.floating-panel.open{opacity:1;visibility:visible;transform:translateY(0)}

.floating-panel-head{
  padding:18px 20px;border-bottom:0.5px solid #E5E5E5;
  display:flex;justify-content:space-between;align-items:center;
}
.floating-panel-pre{font-size:9px;letter-spacing:2.5px;color:#888;font-weight:500}
.floating-panel-title{font-family:'Fraunces',serif;font-size:22px;margin-top:2px;color:#0A0A0A}
.floating-close{
  width:32px;height:32px;font-size:22px;color:#888;line-height:1;
  cursor:pointer;background:transparent;border:none;
}
.floating-close:hover{color:#0A0A0A}

.floating-panel-body{padding:20px}
.floating-intro{font-size:12px;color:#555;line-height:1.6;margin-bottom:16px}

.floating-channels{display:flex;flex-direction:column;gap:8px}
.floating-channel{
  display:flex;align-items:center;gap:12px;padding:10px 12px;
  border:0.5px solid #E5E5E5;transition:all .2s;color:#0A0A0A;
}
.floating-channel:hover{border-color:#0A0A0A;background:#FAFAFA}
.ch-icon{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  color:#FFF;font-size:13px;font-weight:500;flex-shrink:0;
}
.ch-text{display:flex;flex-direction:column;line-height:1.2}
.ch-text strong{font-size:13px;font-weight:500;color:#0A0A0A}
.ch-text small{font-size:10px;color:#888;margin-top:2px;letter-spacing:0.5px}

.floating-divider{
  display:flex;align-items:center;margin:16px 0;
  font-size:9px;color:#888;letter-spacing:2px;
}
.floating-divider::before,.floating-divider::after{
  content:'';flex:1;height:0.5px;background:#E5E5E5;
}
.floating-divider span{padding:0 12px}

.floating-form{display:flex;flex-direction:column;gap:10px}
.floating-form input{
  padding:10px 12px;border:0.5px solid #E5E5E5;
  font-family:inherit;font-size:13px;color:#0A0A0A;
  background:#FFF;transition:border-color .2s;outline:none;
}
.floating-form input:focus{border-color:#0A0A0A}
.floating-form button{
  background:#0A0A0A;color:#FFF;padding:12px;border:none;
  font-size:11px;letter-spacing:2px;font-weight:500;cursor:pointer;
  font-family:inherit;transition:background .2s;
}
.floating-form button:hover{background:#333}

/* ============ ИНЛАЙН-ФОРМА В ТЁМНОЙ ПЛАШКЕ ============ */
.inline-callback{
  background:#0A0A0A;color:#FFF;padding:64px 0;
}
.inline-callback-wrap{
  max-width:1280px;margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.inline-callback h3{
  font-family:'Fraunces',serif;font-size:38px;font-weight:400;line-height:1.05;
  letter-spacing:-1.5px;color:#FFF;
}
.inline-callback h3 em{font-style:italic;color:#888;font-weight:300}
.inline-callback .inline-intro{font-size:13px;color:#999;margin-top:12px;line-height:1.6;max-width:360px}

.inline-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.inline-form input{
  grid-column:span 2;padding:14px 16px;
  border:0.5px solid rgba(255,255,255,0.25);background:transparent;
  color:#FFF;font-family:inherit;font-size:14px;outline:none;transition:border-color .2s;
}
.inline-form input::placeholder{color:#888}
.inline-form input:focus{border-color:#FFF}
.inline-form input[name="name"],.inline-form input[name="phone"]{grid-column:span 1}
.inline-form button{
  grid-column:span 2;background:#FFF;color:#0A0A0A;padding:14px;border:none;
  font-size:11px;letter-spacing:2.5px;font-weight:500;cursor:pointer;
  font-family:inherit;transition:background .2s;
}
.inline-form button:hover{background:#E5E5E5}
.inline-success{padding:20px}
.inline-success .success-icon{
  width:48px;height:48px;border:1px solid #FFF;border-radius:50%;
  margin:0 auto 14px;display:flex;align-items:center;justify-content:center;
  font-size:20px;color:#FFF;
}
.inline-success p{font-size:14px;color:#999}

/* Кнопка callback в хедере */
.btn-callback{
  font-size:11px;letter-spacing:1.5px;color:#0A0A0A;
  border-bottom:0.5px solid #0A0A0A;padding-bottom:2px;
  transition:opacity .2s;cursor:pointer;
}
.btn-callback:hover{opacity:0.6}

/* ============ РЕСПОНСИВ ============ */
@media (max-width:768px){
  .modal-content{padding:36px 24px}
  .modal-title{font-size:28px}
  .floating-cta{bottom:16px;right:16px;padding:12px 14px}
  .floating-cta-label{display:none}
  .floating-panel{right:16px;bottom:78px;width:calc(100vw - 32px)}
  .inline-callback-wrap{grid-template-columns:1fr;gap:32px;padding:0 20px}
  .inline-callback h3{font-size:30px}
  .btn-callback{display:none}
}
