/* /public/assets/css/pages/partners.css */
/* Partners page styles (scoped). Route: /partners (e.g. /ru/partners). */

.page--partners .main{ padding-top:0; }

/* ------------------------------------------------------------ */
/* HERO                                                         */
/* ------------------------------------------------------------ */

.page--partners .partners-hero{
  position:relative;
  overflow:hidden;
  padding:74px 0 44px;
  background:
    radial-gradient(820px 520px at 50% 12%, rgba(154,184,255,.10), transparent 62%),
    radial-gradient(1100px 760px at 50% 120%, rgba(0,0,0,.46), transparent 62%);
}

.page--partners .partners-hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: radial-gradient(rgba(231,236,246,.10) 1px, transparent 1px);
  background-size:14px 14px;
  opacity:.28;
  -webkit-mask-image: radial-gradient(circle at 50% 28%, #000 0%, transparent 70%);
          mask-image: radial-gradient(circle at 50% 28%, #000 0%, transparent 70%);
}

.page--partners .partners-hero::after{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,10,18,.92) 0%, rgba(7,10,18,.00) 220px),
    radial-gradient(1200px 780px at 50% 44%, transparent 0%, rgba(0,0,0,.22) 56%, rgba(0,0,0,.55) 100%);
  opacity:.95;
  transform:translateZ(0);
}

.page--partners .partners-hero .container{ position:relative; z-index:2; }
.page--partners .partners-hero .hero__inner{
  max-width:920px;
  margin:0 auto;
  text-align:center;
}

.page--partners .partners-hero .lead{
  margin:10px auto 0;
  max-width:70ch;
  color:rgba(231,236,246,.82);
  line-height:1.62;
  text-wrap:balance;
}

/* ------------------------------------------------------------ */
/* SECTION                                                       */
/* ------------------------------------------------------------ */

.page--partners .partners-section{ padding:42px 0 64px; }

.page--partners .partners-block{
  max-width:980px;
  margin:0 auto;
}

/* ------------------------------------------------------------ */
/* CARDS                                                        */
/* ------------------------------------------------------------ */

.page--partners .partners-cards{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
}

.page--partners .partners-card{
  border-radius:18px;
  border:1px solid rgba(231,236,246,.10);
  background:rgba(16,20,30,.54);
  box-shadow: 0 10px 26px rgba(0,0,0,.34);
  padding:16px 16px 15px;
  min-height:92px;
}

.page--partners .partners-card__title{
  font-weight:900;
  letter-spacing:-.012em;
  font-size:14px;
  margin-bottom:6px;
}

.page--partners .partners-card__desc{
  color:rgba(231,236,246,.70);
  font-size:13px;
  line-height:1.55;
}

/* ------------------------------------------------------------ */
/* PANEL + STEPS                                                 */
/* ------------------------------------------------------------ */

.page--partners .partners-panel{
  border-radius:22px;
  border:1px solid rgba(231,236,246,.12);
  background:rgba(16,20,30,.46);
  box-shadow: 0 18px 40px rgba(0,0,0,.38);
  overflow:hidden;
}

/* head already padded; keep it */
.page--partners .partners-panel__head{
  padding:16px 18px 12px;
  border-bottom:1px solid rgba(231,236,246,.10);
}

/* ✅ IMPORTANT: add inner padding for everything inside panel except head */
.page--partners .partners-panel > :not(.partners-panel__head){
  padding-left:18px;
  padding-right:18px;
}

/* For forms/alerts inside panel: add vertical padding */
.page--partners .partners-panel .partners-alert,
.page--partners .partners-panel .partners-form{
  padding-top:14px;
  padding-bottom:16px;
}

/* Steps */
.page--partners .partners-steps{
  display:grid;
  padding-top:8px;     /* breathing */
  padding-bottom:8px;  /* breathing */
}

.page--partners .partners-step{
  display:grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap:14px;
  align-items:center;
  padding:12px 0;
  border-top:1px solid rgba(231,236,246,.08);
}

.page--partners .partners-step:first-child{ border-top:0; }

.page--partners .partners-step__n{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;

  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(231,236,246,.78);

  border:1px solid rgba(231,236,246,.12);
  background:rgba(231,236,246,.04);
  border-radius:999px;
  padding:7px 12px;
  width:max-content;
}

.page--partners .partners-step__t{
  font-size:14px;
  line-height:1.55;
  color:rgba(231,236,246,.82);
}

/* OK state */
.page--partners .partners-panel--ok{
  border-color:rgba(120,255,170,.22);
  background:rgba(120,255,170,.06);
}

/* ------------------------------------------------------------ */
/* FORM                                                          */
/* ------------------------------------------------------------ */

/* One nice card-like rhythm (no edge sticking) */
.page--partners .partners-form{ margin:0; }

/* Make form fields align nicely and not “flat” */
.page--partners .partners-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

/* Full-width fields */
.page--partners #p_source,
.page--partners #p_msg{
  min-height:120px;
}

/* Make textarea rows take full width */
.page--partners .field:has(#p_source),
.page--partners .field:has(#p_msg){
  grid-column: 1 / -1;
}

/* If :has not supported, fallback by ids */
@supports not selector(:has(*)){
  .page--partners .field{ grid-column:auto; }
  .page--partners .field--wide{ grid-column: 1 / -1; }
}

/* Labels + hints */
.page--partners .field{ margin:0; }
.page--partners .label{
  display:block;
  margin:0 0 6px 0;
  font-weight:800;
  font-size:13px;
  color:rgba(231,236,246,.86);
}
.page--partners .hint{
  margin-top:6px;
  font-size:12.5px;
  color:rgba(231,236,246,.62);
  line-height:1.45;
}

/* Controls */
.page--partners .input,
.page--partners .textarea{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(231,236,246,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015)),
    rgba(7,10,18,.52);
  color:rgba(231,236,246,.92);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 10px 22px rgba(0,0,0,.22);
  outline:none;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.page--partners .input{
  height:44px;
  padding:0 14px;
  font-size:14px;
}

.page--partners .textarea{
  min-height:120px;
  padding:12px 14px;
  font-size:14px;
  line-height:1.55;
  resize:none; /* ✅ убираем “кривые” ресайз-хэндлы */
}

.page--partners .input::placeholder,
.page--partners .textarea::placeholder{
  color:rgba(231,236,246,.40);
}

.page--partners .input:focus,
.page--partners .textarea:focus{
  border-color:rgba(60,207,208,.58);
  box-shadow:
    0 0 0 3px rgba(60,207,208,.10),
    inset 0 1px 0 rgba(255,255,255,.04),
    0 12px 26px rgba(0,0,0,.28);
  transform: translateY(-1px);
}

/* Buttons row */
.page--partners .partners-actions{
  grid-column: 1 / -1;
  display:flex;
  gap:10px;
  margin-top:2px;
  flex-wrap:wrap;
}

/* Errors */
.page--partners .partners-alert{
  margin:0;
  border-radius:18px;
  border:1px solid rgba(255,120,120,.22);
  background:rgba(255,120,120,.08);
  color:rgba(231,236,246,.90);
  line-height:1.5;
}

/* Honeypot hidden */
.page--partners .partners-hp{
  position:absolute !important;
  left:-99999px !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* ------------------------------------------------------------ */
/* RESPONSIVE                                                    */
/* ------------------------------------------------------------ */

@media (max-width:980px){
  .page--partners .partners-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .page--partners .partners-step{
    grid-template-columns: 120px minmax(0, 1fr);
  }
  .page--partners .partners-form{
    grid-template-columns: 1fr;
  }
  .page--partners .partners-actions{
    margin-top:4px;
  }
}

@media (max-width:560px){
  .page--partners .partners-hero{ padding:66px 0 38px; }
  .page--partners .partners-cards{
    grid-template-columns: 1fr;
  }
  .page--partners .partners-step{
    grid-template-columns: 1fr;
    gap:10px;
    align-items:start;
  }
  .page--partners .partners-step__n{
    justify-content:center;
  }
  .page--partners .partners-actions .btn{
    width:100%;
  }
}
