/* Page CSS — subpage-specific layouts */

/* PAGE HERO */
.page-hero {
  padding: 80px 0 56px;
  background:
    radial-gradient(ellipse at 90% 0%, color-mix(in oklab, var(--green) 8%, transparent) 0%, transparent 55%),
    radial-gradient(ellipse at 10% 100%, color-mix(in oklab, var(--blue) 5%, transparent) 0%, transparent 55%);
  border-bottom: 1px solid var(--line);
}
.page-hero-grid {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center;
}
.page-hero-img { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3;
  box-shadow: var(--shadow-lg); border: 1px solid var(--line); }
.page-hero-img img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 880px) { .page-hero-grid { grid-template-columns: 1fr; gap: 32px; } }

/* SERVICES PAGE */
.services-page-list { display: flex; flex-direction: column; gap: 96px; }
.service-row {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center;
}
.service-row.reverse { direction: rtl; }
.service-row.reverse > * { direction: ltr; }
.service-row-img {
  position: relative; aspect-ratio: 4/3;
  border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--shadow);
}
.service-row-img img { width: 100%; height: 100%; object-fit: cover; }
.service-row-num {
  position: absolute; top: 18px; left: 18px;
  background: rgba(255,255,255,0.95); backdrop-filter: blur(10px);
  font-family: var(--font-mono); font-size: 13px; font-weight: 600;
  padding: 6px 12px; border-radius: 999px; color: var(--green);
}
.service-includes { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 0; }
.service-includes li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--ink-2); }
.service-includes .check {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--green-soft); color: var(--green);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; flex-shrink: 0; margin-top: 1px;
}
.service-price { font-family: var(--font-display); font-size: 22px; font-weight: 600; color: var(--green); letter-spacing: -0.02em; }
@media (max-width: 880px) {
  .service-row { grid-template-columns: 1fr; gap: 28px; }
  .service-row.reverse { direction: ltr; }
  .service-includes { grid-template-columns: 1fr; }
}

/* ABOUT PAGE */
.about-page-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.about-portrait { position: relative; aspect-ratio: 4/5; }
.about-portrait img {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line); box-shadow: var(--shadow-lg);
}
.about-portrait-card {
  position: absolute; bottom: 24px; left: -24px;
  display: flex; align-items: center; gap: 12px;
  background: var(--bg-elev); border: 1px solid var(--line);
  padding: 14px 18px 14px 14px; border-radius: 16px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.14);
}
.about-portrait-card img { height: 32px; width: auto; border: none; box-shadow: none; }
[data-theme="dark"] .about-portrait-card img { filter: brightness(0) invert(1); }
.about-portrait-card strong { display: block; font-size: 14px; color: var(--ink); font-weight: 600; }
.about-portrait-card span { font-size: 12px; color: var(--muted); }
@media (max-width: 880px) { .about-page-grid { grid-template-columns: 1fr; } .about-portrait-card { left: 12px; } }

.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat-big {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 32px 24px; text-align: center;
}
.stat-big strong {
  display: block; font-family: var(--font-display); font-size: 56px; font-weight: 600;
  color: var(--green); letter-spacing: -0.03em; line-height: 1; margin-bottom: 8px;
}
.stat-big span { font-size: 13px; color: var(--muted); }
@media (max-width: 880px) { .stats-grid { grid-template-columns: 1fr 1fr; } }

.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.value-card {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 36px 32px;
}
.value-num {
  font-family: var(--font-mono); font-size: 13px; color: var(--green);
  margin-bottom: 22px; letter-spacing: 0.05em;
}
.value-card h3 { margin-bottom: 12px; }
.value-card p { font-size: 15px; line-height: 1.6; }
@media (max-width: 880px) { .values-grid { grid-template-columns: 1fr; } }

/* CONTACT PAGE */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 72px; align-items: start; }
.contact-info-list { display: flex; flex-direction: column; gap: 14px; }
.contact-info {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 20px; background: var(--bg-elev);
  border: 1px solid var(--line); border-radius: var(--radius);
  transition: border-color 0.15s, transform 0.12s;
}
a.contact-info:hover { border-color: var(--green); transform: translateY(-1px); }
.contact-info-icon {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--green-soft); color: var(--green);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.contact-info strong { display: block; font-size: 14px; color: var(--ink); margin-bottom: 2px; }
.contact-info span { font-size: 14px; color: var(--muted); }
.contact-form-wrap {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--radius-xl); padding: 40px;
  box-shadow: var(--shadow-lg);
}
.contact-form { display: flex; flex-direction: column; gap: 14px; }
.contact-field { display: block; }
.contact-field span { display: block; font-size: 13px; font-weight: 500; color: var(--ink-2); margin-bottom: 6px; }
.contact-field input, .contact-field textarea {
  width: 100%; padding: 12px 14px;
  background: var(--bg); border: 1.5px solid var(--line);
  border-radius: 10px; font-size: 15px; color: var(--ink);
  font-family: inherit; outline: none; transition: border-color 0.15s, box-shadow 0.15s;
}
.contact-field textarea { resize: vertical; min-height: 110px; }
.contact-field input:focus, .contact-field textarea:focus {
  border-color: var(--green); box-shadow: 0 0 0 3px color-mix(in oklab, var(--green) 18%, transparent);
}
.contact-foot { font-size: 13px; color: var(--muted); text-align: center; margin-top: 8px; }
.contact-foot a { color: var(--green); font-weight: 500; }
.contact-success { text-align: center; padding: 40px 20px; }
.contact-success-icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--green); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 30px; margin: 0 auto 24px;
}
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; gap: 32px; } .contact-form-wrap { padding: 24px; } }

/* Premium polish: nav active link */
.nav-links a.is-active { color: var(--green); }
.nav-links a.is-active::after {
  content: ""; display: block; height: 2px; background: var(--green);
  margin-top: 4px; border-radius: 2px;
}

/* Single-purpose page wrapper (calc/seo) */
.single-tool {
  padding: 56px 0 96px;
  min-height: 60vh;
}
.single-tool-head { text-align: center; max-width: 720px; margin: 0 auto 40px; }
.single-tool-head h1 { font-size: clamp(36px, 4.6vw, 60px); margin-bottom: 18px; }
