/* Mini UI mock frames inside portfolio carousels */

.mock-frame {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  padding: 14% 12% 18%;
  background: linear-gradient(160deg, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.2) 100%);
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(0.45rem, 2.2vw, 0.62rem);
  line-height: 1.3;
  overflow: hidden;
}
.mock-frame::before {
  content: '';
  position: absolute;
  inset: 8% 10%;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 6px;
  pointer-events: none;
}
.mock-photo {
  position: absolute;
  right: 10%;
  top: 12%;
  width: 28%;
  max-height: 36%;
  object-fit: contain;
  opacity: 0.9;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.35));
  z-index: 2;
}
.mock-bar {
  height: 4px;
  width: 40%;
  border-radius: 2px;
  margin-bottom: 8px;
}
.mock-bar--red { background: var(--mock-accent, #ed1c24); }
.mock-title {
  font-family: var(--serif);
  font-size: clamp(0.75rem, 3.5vw, 1.05rem);
  font-weight: 500;
  margin-bottom: 6px;
}
.mock-title--light { color: #fff; }
.mock-caption-sm {
  font-size: 0.55em;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  opacity: 0.75;
  margin-top: 6px;
}
.mock-cta {
  display: inline-block;
  margin-top: 8px;
  padding: 4px 10px;
  background: var(--mock-accent, #ed9433);
  color: #1a1a1a;
  font-size: 0.55em;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  border-radius: 3px;
  align-self: flex-start;
}
.mock-cta--gold { background: #c9a227; color: #1a1410; }
.mock-split { display: flex; gap: 8px; margin-bottom: 6px; }
.mock-swatch { width: 28px; height: 28px; border-radius: 4px; }
.mock-grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; width: 70%; }
.mock-grid3 span { aspect-ratio: 4/3; background: rgba(255, 255, 255, 0.15); border-radius: 2px; }
.mock-doc {
  width: 42%;
  height: 52%;
  background: rgba(255, 255, 255, 0.12);
  border-radius: 3px;
  margin-bottom: 6px;
}
.mock-lines { display: flex; flex-direction: column; gap: 4px; width: 75%; }
.mock-lines span {
  display: block;
  height: 4px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 2px;
}
.mock-lines span:nth-child(2) { width: 85%; }
.mock-lines span:nth-child(3) { width: 60%; }
.mock-diagram-ring {
  width: 48px;
  height: 48px;
  border: 3px solid var(--mock-accent, #2dd4bf);
  border-radius: 50%;
  margin-bottom: 6px;
}
.mock-sidebar {
  position: absolute;
  left: 12%;
  top: 14%;
  bottom: 20%;
  width: 22%;
  background: rgba(0, 0, 0, 0.35);
  border-radius: 4px;
}
.mock-sidebar--gold { background: rgba(207, 147, 40, 0.25); }
.mock-main {
  margin-left: 28%;
  padding-top: 4px;
}
.mock-chip {
  display: inline-block;
  padding: 3px 8px;
  background: var(--mock-accent, #2dd4bf);
  color: #0d1f24;
  font-size: 0.55em;
  font-weight: 700;
  border-radius: 3px;
}
.mock-stat-row { display: flex; gap: 6px; margin-bottom: 8px; }
.mock-stat-row span {
  flex: 1;
  height: 22px;
  background: rgba(255, 255, 255, 0.12);
  border-radius: 3px;
}
.mock-chair-row { display: flex; gap: 6px; }
.mock-chair-row i {
  flex: 1;
  height: 28px;
  background: rgba(201, 162, 39, 0.35);
  border-radius: 4px;
  font-style: normal;
}
.mock-calendar {
  width: 80%;
  height: 45%;
  background: repeating-linear-gradient(
    0deg,
    rgba(255, 255, 255, 0.08) 0,
    rgba(255, 255, 255, 0.08) 8px,
    transparent 8px,
    transparent 16px
  );
  border-radius: 4px;
}
.mock-list { display: flex; flex-direction: column; gap: 4px; width: 80%; }
.mock-list span {
  padding: 5px 8px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
  font-size: 0.55em;
}
.mock-queue span { display: block; margin-bottom: 3px; }
.mock-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  margin-bottom: 6px;
}
.mock-meter {
  height: 6px;
  width: 70%;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 3px;
  margin-bottom: 8px;
  position: relative;
}
.mock-meter::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 65%;
  background: var(--mock-accent, #e8c242);
  border-radius: inherit;
}
.mock-cycle {
  width: 56px;
  height: 56px;
  border: 2px dashed rgba(255, 255, 255, 0.35);
  border-radius: 50%;
}
.mock-cards { display: flex; gap: 6px; }
.mock-cards span {
  flex: 1;
  padding: 10px 6px;
  background: rgba(124, 108, 240, 0.35);
  border-radius: 4px;
  font-size: 0.5em;
  text-align: center;
}
.mock-lesson .mock-progress {
  height: 4px;
  width: 100%;
  background: rgba(124, 108, 240, 0.5);
  margin-bottom: 8px;
  border-radius: 2px;
}
.mock-phone {
  width: 42%;
  margin: 0 auto;
  aspect-ratio: 9/16;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 8px;
  border: 2px solid rgba(255, 255, 255, 0.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 0.55em;
}
.mock-phone--install .mock-icon {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--mock-accent, #dfbe00);
}
.mock-check { color: #9ae6b4; font-weight: 600; }
.mock-kanban { display: flex; gap: 4px; width: 90%; }
.mock-kanban span {
  flex: 1;
  padding: 12px 4px;
  background: rgba(237, 148, 51, 0.25);
  border-radius: 3px;
  font-size: 0.5em;
  text-align: center;
}
.mock-table span {
  display: block;
  height: 6px;
  margin-bottom: 5px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 2px;
}
.mock-ticket .mock-priority {
  display: block;
  width: 24px;
  height: 4px;
  background: var(--mock-accent, #ed9433);
  margin-bottom: 6px;
}
.mock-landscape {
  width: 92%;
  aspect-ratio: 16/9;
  background: rgba(0, 0, 0, 0.35);
  border-radius: 4px;
  overflow: hidden;
}
.mock-hero-band { height: 55%; background: var(--mock-accent, #f59e0b); opacity: 0.7; }
.mock-ticker {
  padding: 6px;
  font-size: 0.55em;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.mock-portrait {
  width: 38%;
  margin: 0 auto;
  aspect-ratio: 3/4;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 6px;
}
.mock-tiles-h { height: 40%; margin: 20% 10%; background: rgba(255, 255, 255, 0.15); border-radius: 3px; }
.mock-tile-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  width: 70%;
}
.mock-tile-grid span { aspect-ratio: 1; background: rgba(255, 255, 255, 0.12); border-radius: 3px; }
.mock-billboard {
  width: 88%;
  height: 58%;
  background: #111;
  border: 3px solid var(--mock-accent, #ed1c24);
  display: flex;
  align-items: center;
  justify-content: center;
}
.mock-billboard--split { gap: 4px; padding: 4px; }
.mock-billboard--split span { flex: 1; background: rgba(255, 255, 255, 0.1); height: 100%; }
.mock-billboard-type {
  font-size: clamp(0.9rem, 4vw, 1.2rem);
  font-weight: 800;
  letter-spacing: 0.05em;
}
.mock-frame-outline {
  width: 75%;
  height: 50%;
  border: 2px dashed rgba(255, 255, 255, 0.35);
}
.mock-anpr-feed { display: flex; flex-direction: column; gap: 4px; width: 80%; }
.mock-plate {
  display: inline-block;
  padding: 4px 10px;
  background: #facc15;
  color: #0f172a;
  font-weight: 800;
  font-size: 0.65em;
  letter-spacing: 0.08em;
  border-radius: 3px;
  border: 2px solid #1e293b;
}
.mock-plate--lg { font-size: 0.85em; }
.mock-plate-card { text-align: center; }
.mock-confidence { display: block; margin-top: 4px; color: #38bdf8; font-size: 0.55em; }
.mock-camera {
  width: 75%;
  aspect-ratio: 16/10;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 4px;
  position: relative;
}
.mock-roi-box {
  position: absolute;
  left: 20%;
  top: 25%;
  width: 55%;
  height: 45%;
  border: 2px dashed #38bdf8;
}
.mock-map-line {
  height: 3px;
  width: 70%;
  background: linear-gradient(90deg, transparent, #5eead4, transparent);
  margin-bottom: 8px;
}
.mock-input {
  padding: 4px 8px;
  background: rgba(255, 255, 255, 0.12);
  border-radius: 3px;
  font-size: 0.55em;
}
.mock-bars {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  height: 40px;
  width: 70%;
}
.mock-bars span {
  flex: 1;
  background: #5eead4;
  border-radius: 2px 2px 0 0;
  min-height: 8px;
}
.mock-compare { display: flex; gap: 8px; width: 75%; }
.mock-compare span {
  flex: 1;
  padding: 10px 4px;
  text-align: center;
  background: rgba(94, 234, 212, 0.25);
  border-radius: 4px;
  font-size: 0.55em;
}
.mock-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.mock-chips span {
  padding: 3px 8px;
  background: rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  font-size: 0.5em;
}
.mock-chips .live { background: rgba(251, 191, 36, 0.35); }
.mock-code {
  font-family: ui-monospace, monospace;
  font-size: 0.5em;
  padding: 6px 8px;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 3px;
}
.mock-links span {
  display: block;
  height: 5px;
  margin-bottom: 5px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 2px;
}
.mock-week { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px; width: 85%; }
.mock-week span { aspect-ratio: 1; background: rgba(233, 213, 255, 0.25); border-radius: 2px; }
.mock-invoice {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 80%;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
}
.mock-invoice strong { color: #e9d5ff; }
.mock-leads span {
  display: block;
  padding: 5px 8px;
  margin-bottom: 4px;
  background: rgba(249, 115, 22, 0.25);
  border-radius: 3px;
  font-size: 0.55em;
}
.mock-job-card span:first-child { font-weight: 600; display: block; margin-bottom: 6px; }
.mock-pdf {
  width: 50%;
  height: 55%;
  background: #fff;
  color: #444;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  font-size: 0.5em;
}
.mock-stars { color: #ecc94b; font-size: 1rem; letter-spacing: 2px; }
.mock-quote { font-style: italic; opacity: 0.85; margin-top: 4px; max-width: 90%; }
.mock-status.ok {
  display: inline-block;
  padding: 3px 8px;
  background: rgba(72, 187, 120, 0.35);
  border-radius: 3px;
  font-size: 0.5em;
  margin-bottom: 6px;
}
.mock-cta-row { display: flex; gap: 6px; }
.mock-cta-row span {
  flex: 1;
  text-align: center;
  padding: 6px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 3px;
  font-size: 0.5em;
}
