
:root{
  --blue:#1e4f86;
  --blue-dark:#143a63;
  --text:#1b1f24;
  --muted:#6b7280;
  --bg:#f3f5f7;
  --card:#ffffff;
  --line:#e6e9ee;
  --shadow:0 10px 25px rgba(16,24,40,.08);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--bg);}
a{color:inherit}
.container{width:min(1100px,92%);margin:0 auto}
.narrow{width:min(700px,92%)}
.center{text-align:center}
.muted{color:var(--muted)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0;}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-img{height:42px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-mark{font-weight:800;letter-spacing:.4px;color:var(--blue)}
.brand-sub{font-weight:400;color:#5b6472}
.nav a{text-decoration:none;font-size:12px;letter-spacing:.6px;color:#2b313a;margin-left:16px;padding:8px 2px;border-bottom:2px solid transparent;}
.nav a:hover,.nav a.active{color:var(--blue);border-bottom-color:var(--blue)}

/* Hero */
.hero{position:relative;height:470px;display:flex;align-items:center;color:#fff;overflow:hidden;background:#0f1720;}
.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg, rgba(0,0,0,.65), rgba(0,0,0,.35)),url("../img/hero.jpg");background-size:cover;background-position:center;filter:saturate(1.05);transform:scale(1.02);}
.hero-inner{position:relative;text-align:center}
.hero h1{margin:0 0 14px;font-size:38px;letter-spacing:.2px}
.hero p{margin:0 auto 22px;max-width:760px;color:rgba(255,255,255,.9);line-height:1.6;font-size:14px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 22px;border-radius:4px;font-weight:700;letter-spacing:.4px;text-decoration:none;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.22)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-ghost-dark{background:#fff;color:var(--blue);border-color:#cfd6df}
.btn-ghost-dark:hover{background:#f7fafc}
.btn-block{width:100%}
.btn-mini{height:30px;padding:0 10px;font-size:12px;border-radius:6px;border:1px solid #cfd6df;background:#fff}
.btn-mini:hover{border-color:var(--blue);color:var(--blue)}
.btn-mini.danger{border-color:#fecaca;color:#991b1b}
.btn-mini.danger:hover{border-color:#f87171}

/* Sections */
.section{margin-top:22px}
.section-white{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.section .container{padding:56px 0}
.section-title{text-align:center;color:#0e2d52;margin:0 0 34px;font-size:26px}

/* About */
.about{max-width:900px;margin:0 auto}
.about-block{padding:8px 0 18px}
.about-block h3{margin:0 0 10px;font-size:14px;color:#0f2540;border-bottom:1px solid var(--line);padding-bottom:10px}
.about-block p{margin:0;color:#4b5563;line-height:1.7;font-size:13px}
.value-icons{display:flex;gap:46px;justify-content:center;flex-wrap:wrap;padding-top:10px}
.value-icon{display:flex;flex-direction:column;align-items:center;gap:10px}
.value-badge{width:48px;height:48px;border-radius:50%;border:2px solid var(--blue);display:grid;place-items:center}
.value-badge img{width:22px;height:22px;display:block}
.value-label{font-size:12px;color:#111827}

/* Cards */
.cards{display:grid;gap:18px}
.cards-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:22px 18px;text-align:center;box-shadow:none}
.card-icon{width:54px;height:54px;border:2px solid var(--blue);border-radius:50%;margin:0 auto 14px;display:grid;place-items:center}
.card-icon img{width:26px;height:26px;display:block}
.card h3{margin:0 0 8px;font-size:14px;color:#0f2540}
.card p{margin:0;font-size:12px;color:var(--muted);line-height:1.55}
.card-link{text-decoration:none;transition:transform .08s ease}
.card-link:hover{transform:translateY(-2px)}
.card-cta{margin-top:12px;font-size:12px;color:var(--blue);font-weight:700}

/* Values row */
.values{margin-top:34px;padding-top:24px;border-top:1px solid var(--line)}
.values-title{text-align:center;margin:0 0 14px;color:#0e2d52}
.values-row{display:flex;gap:28px;justify-content:center;flex-wrap:wrap}
.value-item{color:#111827;font-size:13px}
.check{color:var(--blue);font-weight:900;margin-right:8px}

/* Panel header (Work/Contact) */
.panel-hero{position:relative;background:#0f1720;color:#fff;padding:64px 0;margin-top:22px;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}
.panel-hero-bg{position:absolute;inset:0;background:linear-gradient(90deg, rgba(0,0,0,.7), rgba(0,0,0,.4)),url("../img/hero.jpg");background-size:cover;background-position:center}
.panel-hero-inner{position:relative;text-align:center}
.panel-hero-inner h2{margin:0 0 10px;font-size:30px}
.panel-hero-inner p{margin:0 auto;max-width:680px;color:rgba(255,255,255,.9);font-size:13px;line-height:1.6}

/* Form */
.form{display:grid;gap:14px}
label span{display:block;font-size:12px;color:#374151;margin-bottom:6px}
input,textarea{width:100%;padding:12px 12px;border:1px solid #cfd6df;border-radius:4px;outline:none;font-size:13px}
input:focus,textarea:focus{border-color:var(--blue)}
textarea{min-height:120px;resize:vertical}

/* Alerts */
.alert{border-radius:6px;padding:12px 14px;margin-bottom:16px;font-size:13px}
.alert.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}
.alert.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}

/* Contact card */
.contact-card{border:1px solid var(--line);border-radius:8px;padding:26px 22px;background:#fff;box-shadow:var(--shadow)}
.contact-card h3{margin:0 0 18px;color:#0e2d52;text-align:center}
.contact-row{display:flex;gap:14px;align-items:center;padding:12px 0}
.contact-icon{width:42px;height:42px;border-radius:10px;background:#f3f7ff;display:grid;place-items:center;border:1px solid #dbe7ff}
.contact-icon svg{width:22px;height:22px;fill:var(--blue)}
.contact-label{font-size:12px;color:#6b7280;margin-bottom:2px}
.contact-link{font-weight:700;color:#0f2540;text-decoration:none}
.contact-link:hover{color:var(--blue)}
.divider{height:1px;background:var(--line);margin:14px 0}
.contact-foot{font-size:11px;color:#6b7280;text-align:center}

/* Service page */
.service-head{text-align:center;margin-bottom:18px}
.service-icon{width:70px;height:70px;border-radius:50%;border:2px solid var(--blue);display:grid;place-items:center;margin:0 auto 14px}
.service-icon img{width:32px;height:32px}
.service-sub{color:var(--muted);margin:0 auto;max-width:680px;line-height:1.6;font-size:13px}
.service-body h3{margin:18px 0 8px;color:#0f2540}
.bullets{margin:0 0 10px;padding-left:18px;color:#374151;line-height:1.8}
.service-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;justify-content:center}

/* Artists grid */
.artist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}
.artist-card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.artist-photo{height:190px;background:#0f1720;display:flex;align-items:center;justify-content:center}
.artist-photo img{width:100%;height:100%;object-fit:cover;display:block}
.artist-placeholder{width:64px;height:64px;border-radius:16px;background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;font-weight:900;font-size:22px;border:1px solid rgba(255,255,255,.2)}
.artist-info{padding:14px 14px 16px}
.artist-name{font-weight:800;color:#0f2540}
.artist-genre{color:var(--blue);font-size:12px;margin-top:4px;font-weight:700}
.artist-bio{color:#4b5563;font-size:12px;line-height:1.6;margin-top:8px}
.artist-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.artist-links a{font-size:12px;color:var(--blue);font-weight:700;text-decoration:none}
.artist-links a:hover{text-decoration:underline}

/* Admin */
.admin-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-split{display:grid;grid-template-columns:1fr 1.2fr;gap:18px;margin-top:14px}
.admin-panel{border:1px solid var(--line);border-radius:10px;padding:16px;background:#fff;box-shadow:var(--shadow)}
.admin-panel h3{margin:0 0 12px;color:#0f2540}
.table{border:1px solid var(--line);border-radius:10px;overflow:hidden}
.table .row{display:grid;grid-template-columns:2fr 1fr 1.2fr;gap:10px;padding:10px 12px;border-top:1px solid var(--line);align-items:center}
.table .row.head{background:#f7fafc;border-top:none;font-size:12px;color:#6b7280;font-weight:700}
.row-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}

/* Auth */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:26px;background:var(--bg)}
.auth-card{width:min(420px,92%);border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:var(--shadow);padding:18px 18px 16px}
.auth-card h2{margin:0 0 6px;color:#0f2540}
.auth-foot{margin-top:12px;text-align:center}
.auth-foot a{color:var(--blue);text-decoration:none;font-weight:700}
.auth-foot a:hover{text-decoration:underline}

/* Footer */
.site-footer{margin-top:26px;background:#0f2540;color:#fff}
.footer-inner{padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;font-size:12px}
.footer-note{opacity:.85}

/* Responsive */
.br-md{display:none}
@media (max-width: 980px){
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .artist-grid{grid-template-columns:repeat(2,1fr)}
  .admin-split{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .br-md{display:block}
  .nav a{margin-left:10px}
  .hero{height:520px}
  .hero h1{font-size:30px}
  .cards-4{grid-template-columns:1fr}
  .artist-grid{grid-template-columns:1fr}
}


/* ===== PRO ADMIN UI ===== */

.admin-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  background: #0f2540;
  color: #fff;
  padding: 20px;
}

.admin-sidebar h2 {
  font-size: 16px;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

.admin-sidebar a {
  display: block;
  padding: 10px 12px;
  border-radius: 6px;
  text-decoration: none;
  color: #fff;
  margin-bottom: 6px;
  font-size: 13px;
}

.admin-sidebar a:hover {
  background: rgba(255,255,255,0.1);
}

.admin-content {
  padding: 30px;
  background: #f4f6f9;
}

.admin-card-pro {
  background: #fff;
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
  margin-bottom: 20px;
}

.admin-card-pro h3 {
  margin-top: 0;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
}

.admin-table th,
.admin-table td {
  padding: 12px;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
  font-size: 13px;
}

.admin-table th {
  background: #f9fafb;
  font-weight: 700;
  color: #374151;
}

.badge {
  display: inline-block;
  padding: 4px 8px;
  font-size: 11px;
  border-radius: 999px;
  background: #e0f2fe;
  color: #0369a1;
  font-weight: 600;
}

@media (max-width: 900px) {
  .admin-layout {
    grid-template-columns: 1fr;
  }
  .admin-sidebar {
    display: none;
  }
}


/* ===== FINTECH HOME ENHANCEMENTS ===== */
:root{
  --accent:#2b6de8;
  --accent2:#00b3a4;
  --ink:#0b1220;
}
body{color:var(--ink);}
.site-header{backdrop-filter:saturate(140%) blur(6px);}
.site-main{padding-bottom:10px;}

/* Hero v2 */
.hero{height:520px;}
.hero-bg{
  background:
    radial-gradient(800px 420px at 15% 35%, rgba(43,109,232,.35), transparent 60%),
    radial-gradient(700px 420px at 85% 30%, rgba(0,179,164,.28), transparent 60%),
    linear-gradient(100deg, rgba(0,0,0,.72), rgba(0,0,0,.38)),
    url("../img/hero.jpg");
}
.hero-inner{max-width:920px;margin:0 auto;}
.hero h1{font-size:44px; line-height:1.08; letter-spacing:-.3px;}
.hero p{font-size:15px;}
.hero-actions .btn{height:46px;border-radius:10px;}
.btn-primary{background:linear-gradient(135deg, var(--accent), #1e4f86);}
.btn-primary:hover{filter:brightness(.95);}
.btn-ghost{border-radius:10px;}
.btn-ghost:hover{border-color:rgba(255,255,255,.35);}

/* Trust bar */
.trustbar{
  margin-top:-26px;
  position:relative;
  z-index:2;
}
.trustbar .wrap{
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:14px;
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.trustbar .label{
  font-weight:800;
  color:#0e2d52;
  font-size:13px;
  letter-spacing:.2px;
}
.trustbar .items{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  color:#4b5563;
  font-size:12px;
}
.pill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:#f7fafc;
  border:1px solid #e5e7eb;
}
.pill b{color:#111827;}

/* Section backgrounds */
.section-white{border-radius:16px;}
.section .container{padding:60px 0;}
.section-title{font-size:28px; letter-spacing:-.2px;}

.cards-4 .card{
  border-radius:14px;
  padding:22px 18px 20px;
}
.card-link:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(16,24,40,.10);
}
.card-icon{border-radius:18px; border-width:1px; background:#f3f7ff;}
.card-cta{color:var(--accent);}

/* Feature split */
.feature-split{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:22px;
  align-items:start;
  margin-top:14px;
}
.feature-box{
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:18px;
}
.feature-box h3{margin:0 0 10px;color:#0f2540}
.feature-box p{margin:0;color:#4b5563;line-height:1.7;font-size:13px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.kpi{
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:14px 14px 12px;
  background:linear-gradient(180deg,#ffffff,#f8fafc);
}
.kpi .num{font-size:22px;font-weight:900;color:#0e2d52}
.kpi .txt{font-size:12px;color:#6b7280;margin-top:4px}

/* Work/contact panels */
.panel-hero{border-radius:16px;}
.panel-hero-bg{
  background:
    radial-gradient(700px 360px at 20% 35%, rgba(43,109,232,.30), transparent 60%),
    radial-gradient(700px 360px at 85% 30%, rgba(0,179,164,.22), transparent 60%),
    linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.46)),
    url("../img/hero.jpg");
}
.form input, .form textarea{border-radius:10px;padding:12px 14px;}
.contact-card{border-radius:16px;}

/* Responsive tweaks */
@media (max-width: 980px){
  .hero h1{font-size:36px}
  .feature-split{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 640px){
  .hero h1{font-size:32px}
  .kpis{grid-template-columns:1fr}
}


/* Clickable artist cards */
.artist-card-link{display:block;text-decoration:none;color:inherit;transition:transform .08s ease, box-shadow .12s ease}
.artist-card-link:hover{transform:translateY(-2px); box-shadow:0 14px 30px rgba(16,24,40,.12)}
.artist-card-link:focus{outline:2px solid rgba(43,109,232,.35); outline-offset:2px}

/* Artist detail page */
.artist-detail{display:grid;grid-template-columns: 420px 1fr; gap:22px; align-items:start}
.artist-detail-media{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#0f1720;box-shadow:var(--shadow)}
.artist-detail-media img{width:100%;height:100%;display:block;object-fit:cover;min-height:420px}
.artist-detail-placeholder{min-height:420px;display:grid;place-items:center;color:#fff;font-weight:900;font-size:42px}
.artist-detail-body{border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow);padding:18px}
.artist-detail-name{margin:0;color:#0f2540;letter-spacing:-.2px}
.artist-detail-genre{margin-top:6px;color:var(--accent);font-weight:800;font-size:12px}
.artist-meta{margin-top:12px;border-top:1px solid var(--line);padding-top:12px;display:grid;gap:8px;color:#374151;font-size:13px}
.artist-meta span{color:#6b7280;font-weight:700;margin-right:8px}
.artist-detail-bio{margin-top:12px;color:#4b5563;line-height:1.75;font-size:13px}
.artist-detail-h3{margin:16px 0 8px;color:#0f2540}
.artist-detail-p{margin:0;color:#4b5563;line-height:1.75;font-size:13px}
.artist-detail-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.artist-detail-links a{font-size:12px;color:var(--accent);font-weight:800;text-decoration:none}
.artist-detail-links a:hover{text-decoration:underline}

@media (max-width: 980px){
  .artist-detail{grid-template-columns:1fr}
  .artist-detail-media img, .artist-detail-placeholder{min-height:300px}
}

.artists-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:20px;
}

.artist-card{
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  text-decoration:none;
  color:#111;
  box-shadow:0 10px 25px rgba(0,0,0,0.08);
  transition:all .2s ease;
}

.artist-card:hover{
  transform:translateY(-4px);
}

.artist-photo{
  width:100%;
  height:220px;
  overflow:hidden;
}

.artist-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.artist-meta{
  padding:14px;
  text-align:center;
}

.artist-name{
  font-weight:700;
  font-size:16px;
}

.artist-genre{
  font-size:13px;
  opacity:.7;
}

@media (max-width:900px){
  .artists-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:500px){
  .artists-grid{
    grid-template-columns:1fr;
  }
}

/* ===== FIX SERVICES LAYOUT (copy/paste) ===== */

/* Services grid: propre, centré, responsive */
.services-grid{
  display:grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 28px !important;
  align-items:start;
  justify-items:center;
  margin-top: 26px;
}

/* Card */
.service-card{
  width:100%;
  max-width: 210px;
  text-align:center;
  text-decoration:none;
  color: inherit;
  padding: 10px 8px;
}

/* Icon wrapper */
.service-card .svc-ico{
  width: 76px !important;
  height: 76px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin: 0 auto 12px auto !important;
}

/* XL icons must NOT explode */
.service-card .svc-ico.xl{
  width: 92px !important;
  height: 92px !important;
}

/* Icon image */
.service-card .svc-ico img{
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  display:block;
}

/* Titles / subtitle */
.service-card h3{
  margin: 0 0 6px 0;
  font-size: 15px;
  letter-spacing: .06em;
  font-weight: 900;
  text-decoration: none !important;
}
.service-card .svc-sub{
  font-size: 13px;
  opacity: .75;
  text-decoration: none !important;
}

/* Responsive */
@media (max-width: 1100px){
  .services-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .services-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px !important; }
  .service-card{ max-width: 240px; }
}
@media (max-width: 420px){
  .services-grid{ grid-template-columns: 1fr; }
  .service-card{ max-width: 320px; }
}

/* Platforms row (en bas) : centré + wrap propre */
.platforms-row{
  display:flex !important;
  flex-wrap:wrap !important;
  gap: 18px !important;
  align-items:center !important;
  justify-content:center !important;
}
.platforms-row img{
  height: 22px !important;
  width:auto !important;
  opacity: .95;
}

/* ===== END FIX ===== */

/* ===== FIX MOBILE MENU CLICKABLE ===== */
@media (max-width: 900px){

  /* menu au-dessus de tout */
  #primary-nav{
    position: fixed;
    top: 70px;           /* ajuste si ton header a une autre hauteur */
    left: 16px;
    right: 16px;
    z-index: 99999 !important;
    pointer-events: auto !important;
  }

  /* liens cliquables */
  #primary-nav a{
    pointer-events: auto !important;
  }

  /* bouton hamburger au-dessus */
  .nav-toggle{
    position: relative;
    z-index: 100000 !important;
  }

  /* si tu as un overlay, il doit être en dessous du menu */
  .nav-overlay{
    z-index: 99990 !important;
  }
}
/* ===== END FIX ===== */

/* FIX FEATURED ARTISTS MOBILE */

@media (max-width:600px){

  .artists-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
  }

  .artist-card{
    width:100%;
  }

}

/* ===== FEATURED ARTISTS (no conflicts) ===== */

.fa-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:20px;
  margin-top:20px;
}

.fa-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none;
  color:#111;
  box-shadow:0 10px 25px rgba(0,0,0,0.08);
  transition:transform .2s ease, box-shadow .2s ease;
}

.fa-card:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 30px rgba(16,24,40,.12);
}

.fa-photo{
  height:220px;
  background:#0f1720;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.fa-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.fa-placeholder{
  width:64px;height:64px;border-radius:16px;
  background:rgba(255,255,255,.1);
  color:#fff;display:grid;place-items:center;
  font-weight:900;font-size:22px;
  border:1px solid rgba(255,255,255,.2);
}

.fa-meta{padding:14px;text-align:center;}
.fa-name{font-weight:800;color:#0f2540;font-size:15px;}
.fa-genre{margin-top:4px;font-size:12px;color:var(--blue);font-weight:700;opacity:.9;}

@media (max-width:900px){
  .fa-grid{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .fa-photo{height:180px;}
}
@media (max-width:520px){
  .fa-grid{grid-template-columns:repeat(2, minmax(0, 1fr)); gap:16px;}
  .fa-photo{height:160px;}
}