/* ============================================================================
   Pixels LA — Homepage revamp (index.php)
   Modern, responsive, accessible. Scoped under .revamp-home so it never
   affects the shared header/footer or other pages. Brand: #0a51a1 / Montserrat.
   ============================================================================ */

.revamp-home {
  --brand: #0a51a1;
  --brand-dark: #073d78;
  --brand-100: #e9f1fb;
  --brand-200: #cfe0f5;
  --ink: #16233a;
  --muted: #5b6577;
  --line: #e6eaf0;
  --card: #ffffff;
  --page: #f4f7fb;
  --ok: #2e9b46;
  --radius: 16px;
  --radius-lg: 22px;
  --shadow-sm: 0 1px 3px rgba(16, 42, 80, .06);
  --shadow: 0 10px 28px rgba(16, 42, 80, .10);
  --shadow-lg: 0 18px 44px rgba(16, 42, 80, .18);
  --ease: cubic-bezier(.2, .7, .2, 1);

  font-family: 'Montserrat', sans-serif;
  color: var(--ink);
  background: var(--page);
}

/* ---------- Hero ---------- */
.revamp-home .hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(1200px 400px at 15% -10%, var(--brand-100), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, var(--page) 100%);
  border-bottom: 1px solid var(--line);
  padding: clamp(40px, 7vw, 84px) 0 clamp(56px, 9vw, 104px);
}
.revamp-home .hero-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 clamp(18px, 4vw, 40px);
  text-align: center;
}
.revamp-home .eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--brand);
  background: var(--brand-100);
  border: 1px solid var(--brand-200);
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 18px;
}
.revamp-home .hero h1 {
  margin: 0 auto 14px;
  max-width: 16ch;
  font-size: clamp(30px, 5.2vw, 54px);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.revamp-home .hero h1 .accent { color: var(--brand); }
.revamp-home .hero p {
  margin: 0 auto;
  max-width: 56ch;
  font-size: clamp(15px, 2vw, 18px);
  line-height: 1.6;
  color: var(--muted);
}

/* ---------- Services grid ---------- */
.revamp-home .services {
  max-width: 1180px;
  margin: clamp(-48px, -6vw, -64px) auto 0;
  padding: 0 clamp(18px, 4vw, 40px) clamp(48px, 8vw, 80px);
  position: relative;
  z-index: 2;
}
.revamp-home .svc-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(16px, 2.2vw, 26px);
  max-width: 760px;
  margin: 0 auto;
}
.revamp-home .svc-card {
  display: flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease);
}
.revamp-home .svc-card:hover,
.revamp-home .svc-card:focus-within {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--brand-200);
}
.revamp-home .svc-media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #eef2f7;
}
.revamp-home .svc-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s var(--ease);
}
.revamp-home .svc-card:hover .svc-media img { transform: scale(1.05); }
.revamp-home .svc-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .6px;
  text-transform: uppercase;
  color: var(--brand-dark);
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(4px);
  padding: 5px 11px;
  border-radius: 999px;
  box-shadow: var(--shadow-sm);
}
.revamp-home .svc-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px 20px 22px;
  flex: 1;
}
.revamp-home .svc-title {
  margin: 0;
  font-size: 19px;
  font-weight: 700;
  color: var(--ink);
}
.revamp-home .svc-desc {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--muted);
  flex: 1;
}

/* ---------- Session-code form (Proofsheet card) ---------- */
.revamp-home .code-form { display: flex; flex-direction: column; gap: 12px; margin-top: 2px; }
.revamp-home .code-form .field-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
}
.revamp-home .code-form .field-label .req { color: #ec0303; }
.revamp-home .code-input {
  width: 100%;
  height: 46px;
  padding: 0 14px;
  font-size: 15px;
  font-family: inherit;
  color: var(--ink);
  background: #fff;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  transition: border-color .18s var(--ease), box-shadow .18s var(--ease);
}
.revamp-home .code-input::placeholder { color: #9aa4b2; }
.revamp-home .code-input:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(10, 81, 161, .18);
}
.revamp-home .security-check { margin: 2px 0 0; }

/* ---------- Buttons ---------- */
.revamp-home .btn-modern {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 46px;
  padding: 0 20px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  background: var(--brand);
  border: 1px solid var(--brand);
  border-radius: 12px;
  cursor: pointer;
  text-decoration: none;
  transition: background .18s var(--ease), transform .06s var(--ease), box-shadow .18s var(--ease);
}
.revamp-home .btn-modern:hover { background: var(--brand-dark); box-shadow: 0 8px 20px rgba(10, 81, 161, .28); color: #fff; }
.revamp-home .btn-modern:active { transform: translateY(1px); }
.revamp-home .btn-modern:focus-visible { outline: 3px solid rgba(10, 81, 161, .4); outline-offset: 2px; }
.revamp-home .btn-modern.full { width: 100%; }
.revamp-home .btn-outline {
  color: var(--brand);
  background: #fff;
  border-color: var(--brand-200);
}
.revamp-home .btn-outline:hover { background: var(--brand-100); color: var(--brand-dark); }
.revamp-home .btn-modern svg { width: 17px; height: 17px; }

/* ---------- Sign-up CTA band ---------- */
.revamp-home .cta-band {
  max-width: 1180px;
  margin: 0 auto clamp(40px, 7vw, 72px);
  padding: 0 clamp(18px, 4vw, 40px);
}
.revamp-home .cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  background: linear-gradient(120deg, var(--brand) 0%, var(--brand-dark) 100%);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: clamp(22px, 4vw, 36px) clamp(22px, 4vw, 40px);
  box-shadow: var(--shadow);
}
.revamp-home .cta-inner h2 { margin: 0 0 4px; font-size: clamp(20px, 3vw, 26px); font-weight: 800; }
.revamp-home .cta-inner p { margin: 0; color: rgba(255, 255, 255, .85); font-size: 15px; }
.revamp-home .cta-inner .btn-modern {
  background: #fff; color: var(--brand); border-color: #fff; white-space: nowrap;
}
.revamp-home .cta-inner .btn-modern:hover { background: var(--brand-100); color: var(--brand-dark); }

/* ---------- Modernised modals (Bootstrap 3 markup) ---------- */
.revamp-modal .modal-content {
  border: none;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(16, 42, 80, .30);
  font-family: 'Montserrat', sans-serif;
}
.revamp-modal .modal-header {
  background: linear-gradient(120deg, var(--brand, #0a51a1), var(--brand-dark, #073d78));
  color: #fff;
  border: none;
  padding: 16px 20px;
}
.revamp-modal .modal-header .modal-title { font-weight: 700; font-size: 17px; }
.revamp-modal .modal-header .close { color: #fff; opacity: .9; text-shadow: none; font-size: 26px; }
.revamp-modal .modal-header .close:hover { opacity: 1; }
.revamp-modal .modal-body { padding: 22px 20px; color: #16233a; }
.revamp-modal .modal-body h5 { font-size: 15px; line-height: 1.6; margin: 0; font-style: normal; }
.revamp-modal .modal-body a { color: var(--brand, #0a51a1); font-weight: 600; }
.revamp-modal .modal-footer { border-top: 1px solid #eef1f5; padding: 14px 20px; }

/* ---------- Responsive ---------- */
@media (max-width: 600px) {
  .revamp-home .svc-grid { grid-template-columns: 1fr; max-width: 420px; }
  .revamp-home .cta-inner { flex-direction: column; align-items: flex-start; text-align: left; }
  .revamp-home .cta-inner .btn-modern { width: 100%; }
}

/* ---------- Accessibility: reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .revamp-home .svc-card,
  .revamp-home .svc-media img,
  .revamp-home .btn-modern,
  .revamp-home .code-input { transition: none !important; }
  .revamp-home .svc-card:hover { transform: none; }
  .revamp-home .svc-card:hover .svc-media img { transform: none; }
}

/* ============================================================================
   Auth pages — login.php / sign-up.php   (scoped under .revamp-auth)
   ============================================================================ */
.revamp-auth {
  --brand: #0a51a1;
  --brand-dark: #073d78;
  --brand-100: #e9f1fb;
  --brand-200: #cfe0f5;
  --ink: #16233a;
  --muted: #5b6577;
  --line: #e6eaf0;
  --page: #f4f7fb;
  --radius-lg: 22px;
  --shadow: 0 10px 28px rgba(16, 42, 80, .10);
  --ease: cubic-bezier(.2, .7, .2, 1);
  font-family: 'Montserrat', sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1000px 360px at 12% -8%, var(--brand-100), transparent 60%),
    var(--page);
  float: none;
}
.revamp-auth .auth-shell {
  max-width: 1000px;
  margin: 0 auto;
  padding: clamp(26px, 5vw, 60px) clamp(16px, 4vw, 40px) clamp(40px, 7vw, 72px);
}
.revamp-auth .auth-head { text-align: center; margin-bottom: 22px; }
.revamp-auth .auth-head .eyebrow {
  display: inline-block; font-size: 12px; font-weight: 600; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--brand); background: var(--brand-100);
  border: 1px solid var(--brand-200); padding: 6px 14px; border-radius: 999px; margin-bottom: 12px;
}
.revamp-auth .auth-head h1 {
  margin: 0 0 6px; font-size: clamp(24px, 3.6vw, 34px); font-weight: 800;
  letter-spacing: -0.02em; color: var(--ink);
}
.revamp-auth .auth-head p { margin: 0; color: var(--muted); font-size: 15px; }

.revamp-auth .auth-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg);
  box-shadow: var(--shadow); overflow: hidden;
}
.revamp-auth .auth-split { display: grid; grid-template-columns: 1.08fr .92fr; }
.revamp-auth .auth-main { padding: clamp(24px, 4vw, 40px); }
.revamp-auth .auth-main h2 { margin: 0 0 4px; font-size: 20px; font-weight: 700; }
.revamp-auth .auth-main .sub { margin: 0 0 20px; color: var(--muted); font-size: 14px; }

.revamp-auth .auth-aside {
  background: linear-gradient(150deg, var(--brand) 0%, var(--brand-dark) 100%);
  color: #fff; padding: clamp(24px, 4vw, 40px);
  display: flex; flex-direction: column; justify-content: center; gap: 14px;
}
.revamp-auth .auth-aside h2 { margin: 0; font-size: clamp(20px, 2.6vw, 26px); font-weight: 800; }
.revamp-auth .auth-aside p { margin: 0; color: rgba(255,255,255,.86); font-size: 14px; line-height: 1.6; }
.revamp-auth .auth-aside ul { list-style: none; padding: 0; margin: 4px 0 6px; display: flex; flex-direction: column; gap: 9px; }
.revamp-auth .auth-aside li { font-size: 14px; display: flex; gap: 9px; align-items: flex-start; color: rgba(255,255,255,.92); }
.revamp-auth .auth-aside li svg { flex: 0 0 auto; width: 18px; height: 18px; margin-top: 1px; }

/* Fields */
.revamp-auth .field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.revamp-auth .field > label,
.revamp-auth .field .form-name { font-size: 13px; font-weight: 600; color: var(--ink); margin: 0; }
.revamp-auth .field .req,
.revamp-auth .field .form-name sup { color: #ec0303; }
.revamp-auth .form-control {
  width: 100%; min-height: 46px; padding: 11px 14px; font-size: 15px; font-family: inherit;
  color: var(--ink); background: #fff; border: 1.5px solid var(--line); border-radius: 12px;
  box-shadow: none; transition: border-color .18s var(--ease), box-shadow .18s var(--ease); float: none;
}
.revamp-auth .form-control::placeholder { color: #9aa4b2; }
.revamp-auth .form-control:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(10,81,161,.18); }
.revamp-auth textarea.form-control { min-height: 78px; resize: vertical; line-height: 1.5; }
.revamp-auth .form-control[readonly] { background: #f2f5f9; color: var(--muted); cursor: not-allowed; }
/* Keep base display:none (jQuery .slideDown reveals on error); restyle as clean inline text, not a red bar. */
.revamp-auth .error_msg { background: transparent; color: #ec0303; padding: 0; font-size: 12px; font-weight: 600; margin-top: 4px; }

/* Password show/hide */
.revamp-auth .pw-wrap { position: relative; }
.revamp-auth .pw-wrap .form-control { padding-right: 46px; }
.revamp-auth .pw-toggle {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  border: none; background: transparent; color: var(--muted); cursor: pointer;
  padding: 9px; border-radius: 9px; line-height: 0;
}
.revamp-auth .pw-toggle:hover { color: var(--brand); background: var(--brand-100); }
.revamp-auth .pw-toggle:focus-visible { outline: 3px solid rgba(10,81,161,.4); outline-offset: 1px; }

/* Signup field grid */
.revamp-auth .field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 20px; }
.revamp-auth .field-grid .span-2 { grid-column: 1 / -1; }

/* Actions */
.revamp-auth .auth-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-top: 8px; }
.revamp-auth .muted-note { color: var(--muted); font-size: 12px; margin-left: 2px; }

/* Buttons (self-contained for auth scope) */
.revamp-auth .btn-modern {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 46px; padding: 0 22px; font-family: inherit; font-size: 15px; font-weight: 600; line-height: 1;
  color: #fff; background: var(--brand); border: 1px solid var(--brand); border-radius: 12px;
  cursor: pointer; text-decoration: none;
  transition: background .18s var(--ease), transform .06s var(--ease), box-shadow .18s var(--ease);
}
.revamp-auth .btn-modern:hover { background: var(--brand-dark); color: #fff; box-shadow: 0 8px 20px rgba(10,81,161,.28); }
.revamp-auth .btn-modern:active { transform: translateY(1px); }
.revamp-auth .btn-modern:focus-visible { outline: 3px solid rgba(10,81,161,.4); outline-offset: 2px; }
.revamp-auth .btn-modern.full { width: 100%; }
.revamp-auth .btn-modern svg { width: 17px; height: 17px; }
.revamp-auth .btn-ghost {
  height: 46px; padding: 0 18px; display: inline-flex; align-items: center; justify-content: center;
  font-family: inherit; font-size: 14px; font-weight: 600; border-radius: 12px; cursor: pointer;
  color: var(--muted); background: #fff; border: 1px solid var(--line); text-decoration: none;
  transition: background .16s var(--ease), color .16s var(--ease), border-color .16s var(--ease);
}
.revamp-auth .btn-ghost:hover { background: #f3f6fa; color: var(--ink); border-color: var(--brand-200); }
.revamp-auth .auth-aside .btn-modern { background: #fff; color: var(--brand); border-color: #fff; }
.revamp-auth .auth-aside .btn-modern:hover { background: var(--brand-100); color: var(--brand-dark); }

/* Responsive */
@media (max-width: 820px) {
  .revamp-auth .auth-split { grid-template-columns: 1fr; }
  .revamp-auth .auth-aside { order: -1; }
}
@media (max-width: 560px) {
  .revamp-auth .field-grid { grid-template-columns: 1fr; gap: 0; }
  .revamp-auth .auth-actions .btn-modern,
  .revamp-auth .auth-actions .btn-ghost { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
  .revamp-auth .form-control, .revamp-auth .btn-modern, .revamp-auth .btn-ghost { transition: none !important; }
}

/* ---------- Service feature list (retouching card) ---------- */
.revamp-home .svc-list {
  list-style: none;
  margin: 2px 0 4px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
  flex: 1;
}
.revamp-home .svc-list li {
  position: relative;
  padding-left: 26px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--muted);
}
.revamp-home .svc-list li::before {
  content: "";
  position: absolute;
  left: 0; top: 2px;
  width: 17px; height: 17px;
  border-radius: 50%;
  background: var(--brand-100);
  /* check mark */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' viewBox='0 0 24 24' fill='none' stroke='%230a51a1' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px 12px;
}

/* ============================================================================
   Homepage v3 — hero split (session code + visual) + retouching band
   Overrides the earlier centered hero / card grid.
   ============================================================================ */
.revamp-home .hero { padding: clamp(34px, 6vw, 72px) 0 clamp(30px, 5vw, 60px); }

.revamp-home .hero-split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
  text-align: left;
  max-width: 1180px;
}
.revamp-home .hero-copy { max-width: 520px; }
.revamp-home .hero-copy .eyebrow { margin-bottom: 14px; }
.revamp-home .hero-copy h1 {
  max-width: none; margin: 0 0 12px; text-align: left;
  font-size: clamp(30px, 4.4vw, 48px);
}
.revamp-home .hero-copy > p { margin: 0 0 22px; max-width: 46ch; text-align: left; }
.revamp-home .hero-copy .code-form { max-width: 420px; gap: 12px; }
.revamp-home .hero-copy .code-form .btn-modern { width: 100%; }

.revamp-home .hero-visual { }
.revamp-home .hero-visual img {
  width: 100%; height: auto; display: block;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
}

/* Retouching band */
.revamp-home .retouch-band {
  max-width: 1180px; margin: clamp(6px, 2vw, 20px) auto 0;
  padding: 0 clamp(18px, 4vw, 40px);
}
.revamp-home .retouch-inner {
  display: grid; grid-template-columns: 0.85fr 1.15fr;
  align-items: stretch;
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden;
}
.revamp-home .retouch-media { position: relative; min-height: 260px; background: #eef2f7; }
.revamp-home .retouch-media img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block;
}
.revamp-home .retouch-copy { padding: clamp(24px, 4vw, 44px); }
.revamp-home .retouch-copy .eyebrow { margin-bottom: 12px; }
.revamp-home .retouch-copy h2 { margin: 0 0 10px; font-size: clamp(20px, 2.8vw, 28px); font-weight: 800; color: var(--ink); }
.revamp-home .retouch-copy p { margin: 0 0 12px; font-size: 15px; line-height: 1.6; color: var(--muted); }
.revamp-home .retouch-copy .retouch-how { color: var(--ink); }
.revamp-home .retouch-copy .retouch-how a { color: var(--brand); font-weight: 600; }
.revamp-home .retouch-copy .btn-modern { margin-top: 6px; }

/* Retouch band CTA belongs to home tokens */
.revamp-home .btn-outline { color: var(--brand); background: #fff; border-color: var(--brand-200); }
.revamp-home .btn-outline:hover { background: var(--brand-100); color: var(--brand-dark); }

/* Responsive */
@media (max-width: 860px) {
  .revamp-home .hero-split { grid-template-columns: 1fr; gap: clamp(22px, 5vw, 34px); }
  .revamp-home .hero-copy { max-width: 560px; }
  .revamp-home .retouch-inner { grid-template-columns: 1fr; }
  .revamp-home .retouch-media { min-height: 200px; aspect-ratio: 16 / 9; }
  .revamp-home .retouch-media img { position: static; height: 100%; }
}
@media (max-width: 560px) {
  .revamp-home .hero-visual { display: none; }             /* keep mobile focused on the form */
  .revamp-home .hero-copy .code-form { max-width: 100%; }
}

/* ---------- Contact info panel (contact.php aside) ---------- */
.revamp-auth .contact-info { list-style: none; padding: 0; margin: 6px 0 8px; display: flex; flex-direction: column; gap: 16px; }
.revamp-auth .contact-info li { display: flex; gap: 12px; align-items: flex-start; }
.revamp-auth .contact-info .ci-ico {
  flex: 0 0 auto; width: 38px; height: 38px; border-radius: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.14); color: #fff;
}
.revamp-auth .contact-info .ci-ico svg { width: 19px; height: 19px; }
.revamp-auth .contact-info .ci-label { font-size: 12px; letter-spacing: .5px; text-transform: uppercase; color: rgba(255,255,255,.7); margin: 0 0 2px; }
.revamp-auth .contact-info .ci-val { font-size: 15px; font-weight: 600; color: #fff; margin: 0; line-height: 1.45; }
.revamp-auth .contact-info a.ci-val:hover { text-decoration: underline; }

/* Contact aside: top-align so it lines up with the form (not vertically centered) */
.revamp-auth .contact-aside { justify-content: flex-start; }

/* ============================================================================
   Content pages — about / how-it-works / location / faq / services / pricing
   Scoped under .revamp-content
   ============================================================================ */
.revamp-content {
  --brand: #0a51a1; --brand-dark: #073d78; --brand-100: #e9f1fb; --brand-200: #cfe0f5;
  --ink: #16233a; --muted: #5b6577; --line: #e6eaf0; --page: #f4f7fb;
  --radius-lg: 22px; --shadow: 0 10px 28px rgba(16,42,80,.10); --shadow-sm: 0 1px 3px rgba(16,42,80,.06);
  --ease: cubic-bezier(.2,.7,.2,1);
  font-family: 'Montserrat', sans-serif; color: var(--ink); float: none;
  background: radial-gradient(1000px 340px at 12% -8%, var(--brand-100), transparent 60%), var(--page);
}
.revamp-content .content-shell { max-width: 980px; margin: 0 auto; padding: clamp(28px,5vw,60px) clamp(16px,4vw,40px) clamp(40px,7vw,76px); }
.revamp-content .content-head { text-align: center; margin-bottom: 24px; }
.revamp-content .content-head .eyebrow {
  display: inline-block; font-size: 12px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--brand); background: var(--brand-100); border: 1px solid var(--brand-200);
  padding: 6px 14px; border-radius: 999px; margin-bottom: 12px;
}
.revamp-content .content-head h1 { margin: 0 0 8px; font-size: clamp(26px,4vw,40px); font-weight: 800; letter-spacing: -0.02em; color: var(--ink); }
.revamp-content .content-head p { margin: 0 auto; max-width: 60ch; color: var(--muted); font-size: 15px; line-height: 1.6; }

.revamp-content .content-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg);
  box-shadow: var(--shadow); padding: clamp(24px,4vw,44px);
}
.revamp-content .content-card > :first-child { margin-top: 0; }
.revamp-content .content-card > :last-child { margin-bottom: 0; }
.revamp-content .content-card p { font-size: 15px; line-height: 1.75; color: #33404f; margin: 0 0 16px; }
.revamp-content .content-card h2 { font-size: clamp(19px,2.6vw,24px); font-weight: 700; color: var(--ink); margin: 6px 0 14px; }
.revamp-content .content-card a { color: var(--brand); font-weight: 600; }
.revamp-content .content-card a:hover { color: var(--brand-dark); }
.revamp-content .content-card strong { color: var(--ink); }

/* Steps (how-it-works) */
.revamp-content .steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin: 4px 0 0; }
.revamp-content .step {
  background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 22px 20px;
  box-shadow: var(--shadow-sm); transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.revamp-content .step:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--brand-200); }
.revamp-content .step .step-num {
  width: 40px; height: 40px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center;
  background: var(--brand-100); color: var(--brand); font-weight: 800; font-size: 17px; margin-bottom: 14px;
}
.revamp-content .step h3 { margin: 0 0 8px; font-size: 16px; font-weight: 700; color: var(--ink); }
.revamp-content .step p { margin: 0; font-size: 14px; line-height: 1.6; color: var(--muted); }

/* FAQ accordion */
.revamp-content .faq .card { border: 1px solid var(--line) !important; border-radius: 14px !important; margin-bottom: 12px; overflow: hidden; box-shadow: var(--shadow-sm); background: #fff; }
.revamp-content .faq .card-header { background: #fff; padding: 0; border: none; }
.revamp-content .faq .card-header a {
  display: block; padding: 16px 46px 16px 18px; position: relative;
  font-weight: 600; font-size: 15px; color: var(--ink); text-decoration: none;
}
.revamp-content .faq .card-header a:hover { color: var(--brand); }
.revamp-content .faq .card-header a::after {
  content: "+"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  font-size: 20px; font-weight: 400; color: var(--brand);
}
.revamp-content .faq .card-header a[aria-expanded="true"]::after { content: "\2212"; }
.revamp-content .faq .card-block, .revamp-content .faq .card-body { padding: 0 18px 18px; font-size: 14px; line-height: 1.7; color: #4a5563; }

/* Responsive */
@media (max-width: 780px) { .revamp-content .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .revamp-content .steps { grid-template-columns: 1fr; } }

/* Content-page buttons + icon service cards */
.revamp-content .btn-modern {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 46px; padding: 0 22px;
  font-family: inherit; font-size: 15px; font-weight: 600; line-height: 1; color: #fff;
  background: var(--brand); border: 1px solid var(--brand); border-radius: 12px; cursor: pointer; text-decoration: none;
  transition: background .18s var(--ease), transform .06s var(--ease), box-shadow .18s var(--ease);
}
.revamp-content .btn-modern:hover { background: var(--brand-dark); color: #fff; box-shadow: 0 8px 20px rgba(10,81,161,.28); }
.revamp-content .btn-modern:active { transform: translateY(1px); }
.revamp-content .btn-modern svg { width: 17px; height: 17px; }
.revamp-content .step .step-num svg { width: 20px; height: 20px; }
.revamp-content .step .step-num { color: var(--brand); }
.revamp-content .quote-cta { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; margin-top: 8px; }
.revamp-content .price-note { font-size: 13px; color: var(--muted); }

/* ============================================================================
   Authenticated app pages (my-gallery, galleries_view, etc.) — .revamp-app
   ============================================================================ */
.revamp-app {
  --brand:#0a51a1; --brand-dark:#073d78; --brand-100:#e9f1fb; --brand-200:#cfe0f5;
  --ink:#16233a; --muted:#5b6577; --line:#e6eaf0; --page:#f4f7fb; --radius-lg:20px;
  --shadow:0 10px 28px rgba(16,42,80,.10); --shadow-sm:0 1px 3px rgba(16,42,80,.06);
  --ease:cubic-bezier(.2,.7,.2,1);
  font-family:'Montserrat',sans-serif; color:var(--ink); float:none; background:var(--page);
}
.revamp-app .app-shell { max-width:1180px; margin:0 auto; padding:clamp(24px,4vw,48px) clamp(16px,4vw,40px) clamp(40px,7vw,72px); }
.revamp-app .app-topbar { display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:16px; margin-bottom:26px; padding-bottom:20px; border-bottom:1px solid var(--line); }
.revamp-app .app-topbar h1 { margin:0; font-size:clamp(24px,3.4vw,32px); font-weight:800; letter-spacing:-.02em; }
.revamp-app .app-sub { margin:5px 0 0; color:var(--muted); font-size:14px; }
.revamp-app .app-actions { display:flex; gap:10px; flex-wrap:wrap; }
.revamp-app .btn-modern, .revamp-app .btn-ghost {
  display:inline-flex; align-items:center; justify-content:center; gap:7px; height:42px; padding:0 16px;
  font-family:inherit; font-size:14px; font-weight:600; border-radius:11px; cursor:pointer; text-decoration:none;
  transition:background .16s var(--ease), color .16s var(--ease), border-color .16s var(--ease), box-shadow .16s var(--ease);
}
.revamp-app .btn-modern { color:#fff; background:var(--brand); border:1px solid var(--brand); }
.revamp-app .btn-modern:hover { background:var(--brand-dark); color:#fff; box-shadow:0 8px 18px rgba(10,81,161,.26); }
.revamp-app .btn-ghost { color:var(--muted); background:#fff; border:1px solid var(--line); }
.revamp-app .btn-ghost:hover { color:var(--ink); border-color:var(--brand-200); background:#f3f6fa; }
.revamp-app .btn-ghost.danger:hover { color:#c0281f; border-color:#f2b8b3; background:#fdf2f1; }
.revamp-app .btn-modern svg, .revamp-app .btn-ghost svg { width:16px; height:16px; }

/* Empty state */
.revamp-app .empty-state { text-align:center; background:#fff; border:1.5px dashed var(--brand-200); border-radius:22px; padding:clamp(40px,7vw,72px) 24px; }
.revamp-app .empty-state .es-ico { width:64px; height:64px; border-radius:18px; background:var(--brand-100); color:var(--brand); display:inline-flex; align-items:center; justify-content:center; margin-bottom:16px; }
.revamp-app .empty-state .es-ico svg { width:30px; height:30px; }
.revamp-app .empty-state h2 { margin:0 0 8px; font-size:20px; font-weight:700; }
.revamp-app .empty-state p { margin:0 auto 20px; max-width:44ch; color:var(--muted); font-size:14px; line-height:1.6; }

/* Gallery cards */
.revamp-app .gallery-list { display:flex; flex-direction:column; gap:20px; }
.revamp-app .gallery-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:clamp(18px,3vw,26px); }
.revamp-app .gallery-card .gallery-name { margin:0 0 16px; font-size:18px; font-weight:700; color:var(--ink); }
.revamp-app .gallery-views { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.revamp-app .view-tile { display:flex; flex-direction:column; text-align:center; }
.revamp-app .view-tile .vlabel { font-size:12px; font-weight:600; letter-spacing:.3px; color:var(--muted); text-transform:uppercase; margin:0 0 8px; min-height:30px; display:flex; align-items:center; justify-content:center; }
.revamp-app .view-tile .thumb { display:block; border-radius:12px; overflow:hidden; border:1px solid var(--line); background:#eef2f7; aspect-ratio:1; }
.revamp-app .view-tile .thumb img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .35s var(--ease); }
.revamp-app .view-tile .thumb:hover img { transform:scale(1.05); }
.revamp-app .view-tile .vlink { margin-top:10px; display:inline-flex; align-items:center; justify-content:center; height:38px; border-radius:10px; font-size:13px; font-weight:600; color:var(--brand); background:var(--brand-100); border:1px solid var(--brand-200); text-decoration:none; transition:background .16s var(--ease); }
.revamp-app .view-tile .vlink:hover { background:var(--brand-200); color:var(--brand-dark); }

@media (max-width:820px){ .revamp-app .gallery-views { grid-template-columns:repeat(2,1fr); } }
@media (max-width:460px){ .revamp-app .gallery-views { grid-template-columns:1fr; } .revamp-app .app-topbar { align-items:flex-start; } }

/* ============================================================================
   Compat layer — gently modernizes EXISTING bootstrap markup on the gallery,
   compare, order and account pages (scoped .revamp-app). Conservative: only
   restyles buttons, headings, thumbnails, toolbar — no layout restructuring.
   ============================================================================ */
.revamp-app .about-section { background: transparent; box-shadow: none; padding: clamp(20px,4vw,36px) 0 6px; }
.revamp-app .about-heading {
  font-size: clamp(22px,3.4vw,34px) !important; font-weight: 800; letter-spacing: -.02em; color: var(--ink);
  border: none; padding: 0; line-height: 1.1;
}
.revamp-app .about-heading span { color: var(--brand); }
.revamp-app .about-content { background: transparent; }
.revamp-app .login-form-title { font-size: 14px; color: var(--muted); font-weight: 600; }

/* Buttons (bootstrap .btn) — brand-aligned, rounded, subtle motion */
.revamp-app .btn {
  border-radius: 11px !important; font-weight: 600; font-family: inherit; box-shadow: none;
  transition: background .16s var(--ease), border-color .16s var(--ease), box-shadow .16s var(--ease), transform .06s var(--ease);
}
.revamp-app .btn:active { transform: translateY(1px); }
.revamp-app .btn-primary { background: var(--brand); border-color: var(--brand); color: #fff; }
.revamp-app .btn-primary:hover, .revamp-app .btn-primary:focus { background: var(--brand-dark); border-color: var(--brand-dark); box-shadow: 0 6px 16px rgba(10,81,161,.24); }
.revamp-app .btn-success { background: #2e9b46; border-color: #2e9b46; }
.revamp-app .btn-success:hover { background: #268039; border-color: #268039; }
.revamp-app .btn-danger { background: #e23b30; border-color: #e23b30; }
.revamp-app .btn-danger:hover { background: #c62d23; border-color: #c62d23; }

/* Photo thumbnails + gallery link buttons */
.revamp-app img.img-fluid { border-radius: 12px; }
.revamp-app .view-gallery-btn { color: var(--brand); font-weight: 600; text-decoration: none; }
.revamp-app .view-gallery-btn:hover { color: var(--brand-dark); }
.revamp-app .new-gallery-btn { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.revamp-app .new-gallery-btn > li > a {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 10px;
  font-size: 13px; font-weight: 600; text-decoration: none; color: var(--brand);
  background: var(--brand-100); border: 1px solid var(--brand-200); transition: background .16s var(--ease);
}
.revamp-app .new-gallery-btn > li > a:hover { background: var(--brand-200); color: var(--brand-dark); }

/* App-scope form inputs (add_gallery, add_image, account, etc.) */
.revamp-app .form-control, .revamp-app select.form-control, .revamp-app textarea.form-control {
  min-height: 44px; padding: 10px 13px; font-size: 15px; font-family: inherit; color: var(--ink);
  background: #fff; border: 1.5px solid var(--line); border-radius: 11px; box-shadow: none;
  transition: border-color .16s var(--ease), box-shadow .16s var(--ease);
}
.revamp-app .form-control:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(10,81,161,.16); }
.revamp-app .form-name, .revamp-app label { font-weight: 600; font-size: 13px; color: var(--ink); }

/* Keep "Pixels LA" on one line */
.revamp-home .hero h1 .accent { white-space: nowrap; }

/* ============================================================================
   Gallery photo grid fix — galleries_view / favorites / photographer / compare
   Uniform portrait thumbnails so the float grid tiles evenly. CSS-only.
   ============================================================================ */
.revamp-app .user-gallery-box {
  display: flex; flex-direction: column; float: none; width: 100%;
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  box-shadow: var(--shadow-sm); padding: 12px; margin-bottom: 22px;
  transition: box-shadow .2s var(--ease), border-color .2s var(--ease);
}
.revamp-app .user-gallery-box:hover { box-shadow: var(--shadow); border-color: var(--brand-200); }
.revamp-app .user-gallery-box .view-gallery-btn {
  display: inline-block; font-size: 12px; font-weight: 600; color: var(--muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 78%; margin: 0 0 8px; vertical-align: middle;
}
.revamp-app .my-download-btn { float: right; font-size: 18px; margin: 0; color: var(--brand); line-height: 1; }
.revamp-app .my-download-btn:hover { color: var(--brand-dark); }
.revamp-app .user-gallery-box img.img-fluid {
  width: 100%; aspect-ratio: 3 / 4; object-fit: cover; object-position: top center;
  border-radius: 10px; display: block; background: #eef2f7; clear: both;
}
.revamp-app .add-listing-gallery {
  margin: 12px 0 2px; padding: 0; list-style: none;
  display: flex; align-items: center; justify-content: center; gap: 16px;
}
.revamp-app .add-listing-gallery li { margin: 0 !important; display: inline-flex; }
.revamp-app .add-listing-gallery li a { font-size: 17px !important; margin: 0 !important; padding: 0 !important; line-height: 1; }
.revamp-app .add-listing-gallery .custom-check-box { width: 17px; height: 17px; cursor: pointer; }

/* Tidy the dated gallery header clipart -> clean back link */
.revamp-app .about-content h3 a img[src*="gallery1"] { display: none; }
.revamp-app .about-content h3 a { display: inline-flex; align-items: center; gap: 6px; text-decoration: none; }
.revamp-app .about-content h3 a::before {
  content: "\2190  Back to My Galleries"; font-size: 14px; font-weight: 600; color: var(--brand);
}
.revamp-app .about-content h3 a:hover::before { color: var(--brand-dark); }
.revamp-app .heading-margin { font-size: 18px; font-weight: 700; color: var(--ink); margin: 8px 0 0; }

/* Toolbar (download/compare) spacing */
.revamp-app .download-check-box { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; margin: 8px 0 6px; }
.revamp-app .download-check-box .btn-sm { margin: 0 !important; }
.revamp-app .compare { }

/* Upload progress bar (add_image.php) */
.revamp-app .up-track{ width:100%; max-width:420px; height:16px; background:#e9ecef; border-radius:9px; overflow:hidden; margin-top:6px; }
.revamp-app .up-fill{ height:100%; width:0; background:linear-gradient(90deg,#0a51a1,#2e9b46); transition:width .15s ease; }
.revamp-app .up-pct{ margin-top:7px; font-size:13px; font-weight:600; color:#16233a; }

/* ===== Gallery per-page toolbar + pagination (revamp-app) ===== */
.rg-toolbar{ display:flex; align-items:center; justify-content:flex-end; gap:16px; flex-wrap:wrap; float:right; font-family:'Montserrat',sans-serif; }
.rg-toolbar .rg-count{ margin:0; color:#0a51a1; font-weight:600; font-size:15px; }
.rg-perpage-form{ display:flex; align-items:center; gap:8px; margin:0; }
.rg-perpage-label{ margin:0; font-size:14px; color:#555; font-weight:500; }
.rg-perpage-select{
	min-height:44px; padding:8px 36px 8px 14px; border:1px solid #d0d7e2; border-radius:10px; background:#fff;
	color:#0a51a1; font-family:inherit; font-size:14px; font-weight:600; cursor:pointer; appearance:none; -webkit-appearance:none;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230a51a1' d='M6 8 0 2l1.4-1.4L6 5.2 10.6.6 12 2z'/%3E%3C/svg%3E");
	background-repeat:no-repeat; background-position:right 14px center; transition:border-color .15s, box-shadow .15s;
}
.rg-perpage-select:hover{ border-color:#0a51a1; }
.rg-perpage-select:focus-visible{ outline:none; border-color:#0a51a1; box-shadow:0 0 0 3px rgba(10,81,161,.18); }
.pager{ margin:28px 0 8px; font-family:'Montserrat',sans-serif; clear:both; }
.pager ul{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:6px; list-style:none; margin:0; padding:0; }
.pager a,.pager span{ display:inline-flex; align-items:center; justify-content:center; min-width:44px; min-height:44px; padding:0 12px; border-radius:10px; font-size:14px; font-weight:600; text-decoration:none; color:#0a51a1; background:#fff; border:1px solid #d0d7e2; transition:background .15s,color .15s,border-color .15s,box-shadow .15s; }
.pager a:hover{ background:#eef4fb; border-color:#0a51a1; }
.pager a:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(10,81,161,.25); }
.pager .is-current{ background:#0a51a1; border-color:#0a51a1; color:#fff; cursor:default; }
.pager .is-disabled{ opacity:.45; cursor:not-allowed; background:#f5f7fa; color:#9aa4b2; }
.pager .ellipsis{ border:none; background:transparent; color:#9aa4b2; min-width:24px; cursor:default; }
@media(max-width:576px){ .rg-toolbar{ justify-content:space-between; float:none; width:100%; } .pager a,.pager span{ min-width:44px; padding:0 8px; } }

/* ===== Header layout — Bootstrap 4.6.2 compat (restore horizontal nav + social row) ===== */
.header-section nav.navbar-light{ display:flex; flex-wrap:wrap; align-items:center; width:100%; }
.header-section nav.navbar-light > .col-md-4{ display:flex; align-items:center; }
.header-section nav.navbar-light > .col-md-4:nth-child(2){ justify-content:center; }
.header-section nav.navbar-light > .col-md-4:last-child{ justify-content:flex-end; }
.header-section .navbar-nav.social-media{ flex-direction:row; align-items:center; margin:0; padding:0; }
.header-section .navbar-nav.social-media .nav-item{ padding:0 6px; list-style:none; }
@media(max-width:767px){
  .header-section nav.navbar-light{ flex-direction:column; text-align:center; gap:8px; }
  .header-section nav.navbar-light > .col-md-4{ justify-content:center; }
  .header-section .navbar-nav.social-media{ justify-content:center; }
}

/* <picture> wrappers for landing images (keep slots/layout unchanged) */
.revamp-home .hero-visual picture{ display:block; }
.revamp-home .retouch-media picture{ display:contents; }

/* ============================================================================
   Premium refinement — user dashboard (.revamp-app). Visual polish only:
   typography, whitespace, colour & depth. No structural/layout changes,
   no components moved or reordered.
   ============================================================================ */
.revamp-app{
  --muted:#616d82; --line:#e9eef5;
  --shadow:0 14px 40px rgba(16,42,80,.10); --shadow-sm:0 2px 8px rgba(16,42,80,.05);
  background:linear-gradient(180deg,#f8fbfd 0%,#eef2f8 55%);
}
.revamp-app .app-shell{ padding-top:clamp(30px,4.5vw,54px); }
.revamp-app .app-topbar{ margin-bottom:32px; padding-bottom:24px; border-bottom-color:#e7edf5; }
.revamp-app .app-topbar h1{ font-size:clamp(27px,3.7vw,35px); letter-spacing:-.03em; }
.revamp-app .app-sub{ margin-top:7px; font-size:14.5px; color:var(--muted); }
.revamp-app .app-actions .btn-modern{ box-shadow:0 6px 16px rgba(10,81,161,.18); }

.revamp-app .gallery-list{ gap:26px; }
.revamp-app .gallery-card{
  padding:clamp(22px,3vw,32px); border-radius:22px; border-color:var(--line);
  box-shadow:var(--shadow-sm); transition:box-shadow .28s var(--ease), border-color .28s var(--ease);
}
.revamp-app .gallery-card:hover{ box-shadow:var(--shadow); border-color:#dce4f0; }
.revamp-app .gallery-card .gallery-name{
  font-size:16px; font-weight:700; letter-spacing:.005em; color:var(--ink);
  margin:0 0 20px; display:inline-flex; align-items:center; gap:11px;
}
.revamp-app .gallery-card .gallery-name::before{
  content:""; width:9px; height:9px; border-radius:3px; flex:0 0 9px;
  background:linear-gradient(135deg,var(--brand),#2f80ed);
}
.revamp-app .gallery-views{ gap:20px; }
.revamp-app .view-tile .vlabel{
  font-size:10.5px; font-weight:600; letter-spacing:.75px; color:#8b95a7; margin-bottom:11px; min-height:28px;
}
.revamp-app .view-tile .thumb{
  border-radius:15px; border-color:var(--line);
  box-shadow:inset 0 0 0 1px rgba(16,42,80,.02), 0 1px 2px rgba(16,42,80,.04);
}
.revamp-app .view-tile .vlink{
  margin-top:12px; height:40px; border-radius:12px; font-size:12.5px; font-weight:600; letter-spacing:.02em;
}
.revamp-app .view-tile .vlink:hover{ box-shadow:0 4px 12px rgba(10,81,161,.14); }

@media (prefers-reduced-motion:reduce){ .revamp-app .gallery-card, .revamp-app .view-tile .thumb img, .revamp-app .view-tile .vlink{ transition:none !important; } }
