/* =====================================================================
   pages/contact.css — contact-page-only rules.
   Adds: contact-grid, form-shell, fld stack, contact-info-list,
   plus a contact-specific .nl override (slightly different padding/radius/gradient).
   Base .page-hero, .nl, .nl-form all live in common.css.
   ===================================================================== */

/* Two-column grid: form on the left, channels on the right */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:start}

/* Form shell + fields */
.form-shell{background:#fff;border:1px solid var(--sp-line);border-radius:18px;padding:36px;box-shadow:var(--sp-shadow)}
.form-title{font-size:22px;font-weight:800;color:var(--sp-secondary-d);margin-bottom:6px;letter-spacing:0}
.form-sub{font-size:14px;color:var(--sp-muted);margin-bottom:22px}
.fld{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.fld label{font-size:13px;font-weight:700;color:var(--sp-secondary-d);display:flex;align-items:center;gap:6px}
.fld label .req,.req{color:var(--sp-red);font-weight:700}
.fld input[type=text],.fld input[type=email],.fld input[type=tel],.fld select,.fld textarea{
  width:100%;padding:12px 16px;border-radius:10px;
  border:1.5px solid var(--sp-line);background:#fff;
  font-size:14px;color:var(--sp-text);
  transition:.2s;font-family:inherit;
}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--sp-primary);box-shadow:0 0 0 3px rgba(1,128,129,.15)}
.fld textarea{resize:vertical;min-height:120px;line-height:1.6}
.fld.row{flex-direction:row;align-items:flex-start;gap:10px}
.fld.row input[type=checkbox]{flex-shrink:0;width:18px;height:18px;margin-top:2px;accent-color:var(--sp-primary)}
.fld.row label{font-weight:500;font-size:13.5px;line-height:1.55}
.fld-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fld-grid .fld{margin-bottom:0}
.fld-group{padding:18px;border:1px dashed var(--sp-line);border-radius:12px;background:#fafbfb;margin-bottom:18px}
.fld-group h4{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1.4px;color:var(--sp-primary);margin-bottom:14px}
.form-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:22px;padding-top:22px;border-top:1px solid var(--sp-line)}
.req-note{font-size:12.5px;color:var(--sp-muted)}
.inline-link{color:var(--sp-primary);font-weight:700}

/* Contact channel list */
.channels-title{font-size:20px;font-weight:800;color:var(--sp-secondary-d);margin-bottom:4px;letter-spacing:0}
.channels-sub{font-size:14px;color:var(--sp-muted)}
.contact-info-list{display:flex;flex-direction:column;gap:12px;margin-top:22px;list-style:none;padding:0}
.contact-info-list li{display:flex;gap:14px;align-items:flex-start;padding:14px 18px;background:#fff;border:1px solid var(--sp-line);border-radius:12px;font-size:14px;line-height:1.5}
.contact-info-list .icn{
  width:40px;height:40px;border-radius:10px;
  background:rgba(1,128,129,.1);color:var(--sp-primary);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.contact-info-list strong{display:block;color:var(--sp-secondary-d);margin-bottom:2px;font-size:13px;text-transform:uppercase;letter-spacing:1px;font-weight:800}
.contact-info-list a{color:var(--sp-primary);font-weight:600}

/* Contact-page newsletter override (deeper padding/radius + custom gradient) */
.nl{
  padding:40px;border-radius:24px;
  background:linear-gradient(135deg,var(--sp-secondary-d),var(--sp-secondary));
}
.nl::before{
  content:'';position:absolute;top:-80px;right:-80px;width:280px;height:280px;
  background:radial-gradient(circle,var(--sp-peach),transparent 70%);
  opacity:.2;
}
.nl > *{position:relative}
.nl-tag{background:rgba(238,176,146,.18);color:var(--sp-peach)}

.form-shell .pirt-contact-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px 20px;
}

.form-shell .pirt-contact-form > .form-item,
.form-shell .pirt-contact-form > .field--type-string,
.form-shell .pirt-contact-form > .field--type-list-string,
.form-shell .pirt-contact-form > .field--type-text-long,
.form-shell .pirt-contact-form > .field--type-list-integer,
.form-shell .pirt-contact-form > .field--type-boolean{
  margin:0;
}

.form-shell .pirt-contact-form label,
.form-shell .pirt-contact-form legend{
  color:var(--sp-secondary-d);
  font-size:13px;
  font-weight:800;
  line-height:1.35;
}

.form-shell .pirt-contact-form .form-required::after{
  color:var(--sp-red);
}

.form-shell .pirt-contact-form input[type="text"],
.form-shell .pirt-contact-form input[type="email"],
.form-shell .pirt-contact-form select,
.form-shell .pirt-contact-form textarea{
  width:100%;
  border:1.5px solid var(--sp-line);
  border-radius:10px;
  background:#fff;
  color:var(--sp-text);
  font-family:inherit;
  font-size:14px;
  line-height:1.4;
}

.form-shell .pirt-contact-form input[type="text"],
.form-shell .pirt-contact-form input[type="email"],
.form-shell .pirt-contact-form select{
  min-height:52px;
  padding:12px 16px;
}

.form-shell .pirt-contact-form textarea{
  min-height:150px;
  padding:14px 16px;
  resize:vertical;
}

.form-shell .pirt-contact-form input:focus,
.form-shell .pirt-contact-form select:focus,
.form-shell .pirt-contact-form textarea:focus{
  outline:none;
  border-color:var(--sp-primary);
  box-shadow:0 0 0 3px rgba(1,128,129,.15);
}

.form-shell .pirt-contact-form .js-form-item-message-0-value,
.form-shell .pirt-contact-form .field--name-message,
.form-shell .pirt-contact-form .fld-group,
.form-shell .pirt-contact-form .field--name-field-consent,
.form-shell .pirt-contact-form .contact-required-note,
.form-shell .pirt-contact-form .form-actions{
  grid-column:1 / -1;
}

.form-shell .pirt-contact-form .field--name-message{order:20}
.form-shell .pirt-contact-form .fld-group{order:30}
.form-shell .pirt-contact-form .field--name-field-consent{order:40}
.form-shell .pirt-contact-form .contact-required-note{order:50}
.form-shell .pirt-contact-form .form-actions{order:60}
.form-shell .pirt-contact-form .url-textfield{order:70}

.form-shell .pirt-contact-form .fld-group{
  display:block;
  padding:18px 22px;
  border:1px dashed #bfe5ed;
  border-radius:14px;
  background:#f8fbfb;
}

.form-shell .pirt-contact-form .fld-group h4{
  margin:0 0 14px;
  color:var(--sp-primary);
  font-size:13px;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
}

.form-shell .pirt-contact-form .fld-group fieldset{
  margin:0;
  min-inline-size:0;
  padding:0;
  border:0;
  background:transparent;
}

.form-shell .pirt-contact-form .fld-group legend{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
}

.form-shell .pirt-contact-form .fld-group .fieldset-wrapper,
.form-shell .pirt-contact-form .fld-group .form-checkboxes{
  margin:0;
  padding:0;
}

.form-shell .pirt-contact-form .fld-group .form-checkboxes{
  display:flex;
  flex-direction:column;
  gap:13px;
}

.form-shell .pirt-contact-form .form-type-checkbox,
.form-shell .pirt-contact-form .form-type--checkbox{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin:0;
}

.form-shell .pirt-contact-form input[type="checkbox"]{
  flex:0 0 auto;
  width:20px;
  height:20px;
  margin:1px 0 0;
  accent-color:var(--sp-primary);
}

.form-shell .pirt-contact-form .form-type-checkbox label,
.form-shell .pirt-contact-form .form-type--checkbox label,
.form-shell .pirt-contact-form label.option{
  margin:0;
  font-size:14px;
  font-weight:750;
  line-height:1.45;
}

.form-shell .pirt-contact-form .field--name-field-consent{
  padding-top:4px;
}

.form-shell .pirt-contact-form .contact-required-note{
  margin-top:4px;
  padding-top:18px;
  border-top:1px solid var(--sp-line);
  color:var(--sp-muted);
  font-size:13px;
}

.form-shell .pirt-contact-form .form-actions{
  display:flex;
  justify-content:flex-end;
  margin:0;
}

.form-shell .pirt-contact-form .form-actions .button,
.form-shell .pirt-contact-form .form-actions input[type="submit"]{
  min-height:52px;
  padding:0 28px;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,var(--sp-primary),var(--sp-blue,#0077b6));
  color:#fff;
  font-weight:900;
  box-shadow:0 12px 26px rgba(1,128,129,.22);
}

@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .fld-grid{grid-template-columns:1fr}
  .form-shell .pirt-contact-form{grid-template-columns:1fr}
  .nl{grid-template-columns:1fr;padding:28px}
}
