/* =========================================================
   APP: visa_photo
   Scope STRICT:
   - body.visa-photo
   - .app-main.visa-photo
========================================================= */
/* ===== Layout safety: centre l'app (scope strict) ===== */
/* Safety layout – centre l'app */
body.visa-photo .app-main.visa-photo .app-container{
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
  }
  
body.visa-photo .app-main.visa-photo .app-container {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
  }
  
  body.visa-photo .app-main.visa-photo .vp-home {
    width: 100%;
  }
  
body.visa-photo .app-main.visa-photo {
    --vp-border: var(--border, rgba(255,255,255,0.10));
    --vp-muted: var(--muted, rgba(255,255,255,0.70));
    --vp-accent: var(--primary, #4f8cff);
    --vp-radius: 16px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-home {
    color: rgba(255,255,255,0.92);
  }
  
  /* HERO */
  body.visa-photo .app-main.visa-photo .vp-hero {
    padding: clamp(20px, 3.5vw, 36px);
    border: 1px solid var(--vp-border);
    background: linear-gradient(180deg, rgba(79,140,255,0.10), rgba(255,255,255,0.02));
    border-radius: var(--vp-radius);
    overflow: hidden;
  }
  
  body.visa-photo .app-main.visa-photo .vp-hero__grid {
    display: grid;
    gap: 18px;
    grid-template-columns: 1.1fr 0.9fr;
    align-items: start;
  }
  
  body.visa-photo .app-main.visa-photo .vp-kicker {
    display: inline-flex;
    gap: 10px;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    color: var(--vp-muted);
    font-size: 0.92rem;
  }
  
  body.visa-photo .app-main.visa-photo .vp-kicker__dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--vp-accent);
    box-shadow: 0 0 0 4px rgba(79,140,255,0.18);
  }
  
  body.visa-photo .app-main.visa-photo .vp-title {
    margin: 12px 0 10px;
    font-weight: 760;
    letter-spacing: -0.02em;
    line-height: 1.08;
    font-size: clamp(1.6rem, 2.6vw, 2.35rem);
  }
  
  body.visa-photo .app-main.visa-photo .vp-accent {
    color: var(--vp-accent);
  }
  
  body.visa-photo .app-main.visa-photo .vp-lead {
    margin: 0 0 16px;
    color: var(--vp-muted);
    line-height: 1.65;
    max-width: 72ch;
  }
  
  body.visa-photo .app-main.visa-photo .vp-cta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin: 14px 0 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-proof {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
    color: var(--vp-muted);
    max-width: 72ch;
  }
  
  body.visa-photo .app-main.visa-photo .vp-proof__item {
    padding-left: 18px;
    position: relative;
  }
  
  body.visa-photo .app-main.visa-photo .vp-proof__item::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--vp-accent);
  }
  
  body.visa-photo .app-main.visa-photo .vp-note {
    margin: 10px 0 0;
    color: var(--vp-muted);
    font-size: 0.95rem;
  }
  
  /* PANEL */
  body.visa-photo .app-main.visa-photo .vp-panel {
    border: 1px solid var(--vp-border);
    background: rgba(0,0,0,0.16);
    border-radius: var(--vp-radius);
    padding: 16px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-panel__title {
    margin: 0 0 12px;
    font-size: 1.05rem;
    letter-spacing: -0.01em;
  }
  
  body.visa-photo .app-main.visa-photo .vp-examples {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-example {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: 14px;
    overflow: hidden;
  }
  
  body.visa-photo .app-main.visa-photo .vp-example img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    display: block;
  }
  
  body.visa-photo .app-main.visa-photo .vp-example figcaption {
    padding: 10px 10px 12px;
    color: var(--vp-muted);
    font-size: 0.95rem;
  }
  
  body.visa-photo .app-main.visa-photo .vp-panel__mini {
    margin-top: 12px;
    border-top: 1px solid var(--vp-border);
    padding-top: 12px;
    display: grid;
    gap: 8px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-mini__title {
    font-weight: 720;
  }
  
  body.visa-photo .app-main.visa-photo .vp-mini__text {
    margin: 0;
    color: var(--vp-muted);
    line-height: 1.55;
  }
  
  body.visa-photo .app-main.visa-photo .vp-panel__btn {
    width: 100%;
  }
  
  /* SECTIONS */
  body.visa-photo .app-main.visa-photo .vp-section {
    margin-top: 18px;
    padding: clamp(16px, 2.4vw, 22px);
    border: 1px solid var(--vp-border);
    border-radius: var(--vp-radius);
    background: rgba(255,255,255,0.02);
  }
  
  body.visa-photo .app-main.visa-photo .vp-section--soft {
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(79,140,255,0.06));
  }
  
  body.visa-photo .app-main.visa-photo .vp-section--seo {
    background: rgba(0,0,0,0.14);
  }
  
  body.visa-photo .app-main.visa-photo .vp-section__head {
    max-width: 90ch;
  }
  
  body.visa-photo .app-main.visa-photo .vp-h2 {
    margin: 0 0 8px;
    font-size: clamp(1.18rem, 1.7vw, 1.45rem);
    letter-spacing: -0.015em;
  }
  
  body.visa-photo .app-main.visa-photo .vp-sub {
    margin: 0;
    color: var(--vp-muted);
    line-height: 1.6;
  }
  
  /* BADGES */
  body.visa-photo .app-main.visa-photo .vp-badges {
    margin-top: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-badge {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: 999px;
    padding: 8px 12px;
    color: var(--vp-muted);
  }
  
  body.visa-photo .app-main.visa-photo .vp-divider {
    margin: 16px 0;
    height: 1px;
    background: var(--vp-border);
  }
  
  /* UPLOAD */
  body.visa-photo .app-main.visa-photo .vp-upload__title {
    margin: 0 0 6px;
    font-size: 1.15rem;
    letter-spacing: -0.01em;
  }
  
  body.visa-photo .app-main.visa-photo .vp-upload__sub {
    margin: 0 0 14px;
    color: var(--vp-muted);
    line-height: 1.6;
    max-width: 75ch;
  }
  
  body.visa-photo .app-main.visa-photo .vp-form {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: var(--vp-radius);
    padding: 14px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-field {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-label {
    font-weight: 700;
    color: rgba(255,255,255,0.92);
  }
  
  body.visa-photo .app-main.visa-photo .vp-hint {
    margin: 0;
    color: var(--vp-muted);
    font-size: 0.95rem;
    line-height: 1.5;
  }
  
  body.visa-photo .app-main.visa-photo .vp-submit {
    width: 100%;
    margin-top: 6px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-legal {
    margin: 10px 0 0;
    color: var(--vp-muted);
    font-size: 0.92rem;
    text-align: center;
  }
  
  /* SPEC CARDS */
  body.visa-photo .app-main.visa-photo .vp-cards {
    margin-top: 14px;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  
  body.visa-photo .app-main.visa-photo .vp-card {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: var(--vp-radius);
    padding: 14px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-card__t {
    margin: 0 0 6px;
    font-size: 1.02rem;
  }
  
  body.visa-photo .app-main.visa-photo .vp-card__m {
    color: rgba(255,255,255,0.86);
    font-weight: 650;
    margin-bottom: 8px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-card__d {
    margin: 0;
    color: var(--vp-muted);
    line-height: 1.6;
  }
  
  /* STEPS */
  body.visa-photo .app-main.visa-photo .vp-steps {
    margin: 14px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-step {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: 14px;
    padding: 12px;
    color: var(--vp-muted);
  }
  
  body.visa-photo .app-main.visa-photo .vp-bottom-cta {
    margin-top: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }
  
  /* FAQ */
  body.visa-photo .app-main.visa-photo .vp-faq {
    margin-top: 14px;
    display: grid;
    gap: 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-faq__item {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: var(--vp-radius);
    padding: 10px 12px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-faq__q {
    cursor: pointer;
    font-weight: 720;
    color: rgba(255,255,255,0.92);
    list-style: none;
  }
  
  body.visa-photo .app-main.visa-photo .vp-faq__q::-webkit-details-marker {
    display: none;
  }
  
  body.visa-photo .app-main.visa-photo .vp-faq__a {
    margin-top: 8px;
    color: var(--vp-muted);
    line-height: 1.6;
  }
  
  /* SEO text */
  body.visa-photo .app-main.visa-photo .vp-seo {
    margin-top: 12px;
    max-width: 95ch;
    color: var(--vp-muted);
    line-height: 1.75;
  }
  
  body.visa-photo .app-main.visa-photo .vp-seo strong {
    color: rgba(255,255,255,0.92);
  }
  
  /* Responsive */
  @media (max-width: 980px) {
    body.visa-photo .app-main.visa-photo .vp-hero__grid {
      grid-template-columns: 1fr;
    }
  
    body.visa-photo .app-main.visa-photo .vp-cards {
      grid-template-columns: 1fr;
    }
  
    body.visa-photo .app-main.visa-photo .vp-examples {
      grid-template-columns: 1fr;
    }
  }
/* =========================================================
   RESULT (visa_photo)
========================================================= */

body.visa-photo .app-main.visa-photo .vp-result {
    color: rgba(255,255,255,0.92);
  }
  
  /* compat : si tes templates utilisent encore .btn */
  body.visa-photo .app-main.visa-photo .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 12px;
    border: 1px solid var(--vp-border);
    text-decoration: none;
    color: rgba(255,255,255,0.92);
    background: rgba(255,255,255,0.03);
    font-weight: 650;
  }
  body.visa-photo .app-main.visa-photo .btn-primary {
    background: rgba(79,140,255,0.22);
    border-color: rgba(79,140,255,0.30);
  }
  body.visa-photo .app-main.visa-photo .btn-outline,
  body.visa-photo .app-main.visa-photo .btn--ghost {
    background: rgba(255,255,255,0.03);
  }
  
  body.visa-photo .app-main.visa-photo .vp-rhead {
    margin-top: 4px;
    padding: 18px;
    border: 1px solid var(--vp-border);
    border-radius: var(--vp-radius);
    background: rgba(255,255,255,0.02);
  }
  
  body.visa-photo .app-main.visa-photo .vp-rtitle {
    margin: 0 0 8px;
    font-size: clamp(1.35rem, 2vw, 1.7rem);
    letter-spacing: -0.015em;
  }
  
  body.visa-photo .app-main.visa-photo .vp-rsub {
    margin: 0;
    color: var(--vp-muted);
    line-height: 1.6;
    max-width: 85ch;
  }
  
  body.visa-photo .app-main.visa-photo .vp-rmeta {
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-pill {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: 999px;
    padding: 6px 10px;
    color: var(--vp-muted);
    font-size: 0.92rem;
  }
  
  body.visa-photo .app-main.visa-photo .vp-preview {
    margin-top: 16px;
    padding: 18px;
    border: 1px solid var(--vp-border);
    border-radius: var(--vp-radius);
    background: rgba(255,255,255,0.02);
  }
  
  body.visa-photo .app-main.visa-photo .vp-compare {
    display: grid;
    grid-template-columns: 1fr 40px 1fr;
    gap: 12px;
    align-items: center;
  }
  
  body.visa-photo .app-main.visa-photo .vp-arrow {
    text-align: center;
    color: rgba(255,255,255,0.75);
    font-size: 1.4rem;
  }
  
  body.visa-photo .app-main.visa-photo .vp-card2 {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: var(--vp-radius);
    padding: 12px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-card2__t {
    font-weight: 720;
    margin-bottom: 10px;
    color: rgba(255,255,255,0.92);
  }
  
  body.visa-photo .app-main.visa-photo .vp-img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.10);
    display: block;
  }
  
  body.visa-photo .app-main.visa-photo .vp-processed {
    position: relative;
  }
  
  body.visa-photo .app-main.visa-photo .vp-watermark {
    position: absolute;
    inset: auto 12px 12px auto;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.18);
    background: rgba(0,0,0,0.35);
    color: rgba(255,255,255,0.92);
    font-weight: 800;
    letter-spacing: 0.08em;
    font-size: 0.78rem;
  }
  
  body.visa-photo .app-main.visa-photo .vp-check {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    color: var(--vp-muted);
    display: grid;
    gap: 6px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-check li {
    padding-left: 18px;
    position: relative;
  }
  
  body.visa-photo .app-main.visa-photo .vp-check li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--vp-accent);
  }
  
  /* CTA Panel */
  body.visa-photo .app-main.visa-photo .vp-cta-panel {
    margin-top: 16px;
    padding: 18px;
    border: 1px solid var(--vp-border);
    border-radius: var(--vp-radius);
    background: linear-gradient(180deg, rgba(79,140,255,0.08), rgba(255,255,255,0.02));
    display: grid;
    gap: 12px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-cta-panel__title {
    margin: 0 0 6px;
    font-size: 1.1rem;
    letter-spacing: -0.01em;
  }
  
  body.visa-photo .app-main.visa-photo .vp-cta-panel__sub {
    margin: 0;
    color: var(--vp-muted);
    line-height: 1.6;
    max-width: 85ch;
  }
  
  body.visa-photo .app-main.visa-photo .vp-cta-panel__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-action {
    white-space: nowrap;
  }
  
  body.visa-photo .app-main.visa-photo .c-btn.c-btn--ghost {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
  }
  
  body.visa-photo .app-main.visa-photo .vp-cta-panel__note {
    margin: 6px 0 0;
    color: var(--vp-muted);
    font-size: 0.95rem;
    width: 100%;
  }
  
  /* Specs grid */
  body.visa-photo .app-main.visa-photo .vp-specgrid {
    margin-top: 14px;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  
  body.visa-photo .app-main.visa-photo .vp-spec {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: var(--vp-radius);
    padding: 14px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-spec__k {
    color: var(--vp-muted);
    font-size: 0.92rem;
    margin-bottom: 6px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-spec__v {
    font-weight: 720;
    color: rgba(255,255,255,0.92);
  }
  
  /* Share */
  body.visa-photo .app-main.visa-photo .vp-share {
    border: 1px solid var(--vp-border);
    background: rgba(255,255,255,0.03);
    border-radius: var(--vp-radius);
    padding: 14px;
    display: grid;
    gap: 10px;
  }
  
  body.visa-photo .app-main.visa-photo .vp-share__text {
    margin: 0;
    color: var(--vp-muted);
    line-height: 1.6;
  }
  
  @media (max-width: 980px) {
    body.visa-photo .app-main.visa-photo .vp-compare {
      grid-template-columns: 1fr;
    }
  
    body.visa-photo .app-main.visa-photo .vp-arrow {
      display: none;
    }
  
    body.visa-photo .app-main.visa-photo .vp-specgrid {
      grid-template-columns: 1fr;
    }
  
    body.visa-photo .app-main.visa-photo .vp-img {
      height: 220px;
    }
  }
    