/* IMIN — стили лендинга и карты артистов (site.css).
   Отдельно от card.css/themes.css витрин. Сдержанный редакционный тон. */

:root{
  --ink:#1a1815;
  --ink-soft:#5c564e;
  --paper:#f6f3ee;
  --paper-2:#fffdf9;
  --line:#ddd6ca;
  --accent:#7a1f1f;       /* приглушённый кармин */
  --accent-soft:#a64b3a;
  --radius:14px;
  --maxw:1100px;
  --font: "Georgia", "Times New Roman", serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font);font-weight:600;line-height:1.2;margin:0}

/* ---------- Шапка ---------- */
.site-head{
  border-bottom:1px solid var(--line);
  background:var(--paper-2);
  position:sticky;top:0;z-index:10;
}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-logo{flex:none;width:34px;height:34px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-mark{font-family:var(--font);font-size:24px;font-weight:700;letter-spacing:.04em}
.brand-sub{font-size:11px;color:var(--ink-soft);letter-spacing:.02em}
.site-nav{display:flex;gap:24px}
.site-nav a{font-size:14px;color:var(--ink-soft);padding:4px 0;border-bottom:2px solid transparent}
.site-nav a:hover,.site-nav a.active{color:var(--ink);border-color:var(--accent)}

/* ---------- Hero ---------- */
.hero{padding:88px 0 64px;background:
  radial-gradient(120% 80% at 80% -10%, rgba(122,31,31,.07), transparent 60%),
  var(--paper);}
.hero h1{font-size:44px;max-width:18ch}
.hero-lead{font-size:19px;color:var(--ink-soft);max-width:62ch;margin:22px 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-block;padding:13px 24px;border-radius:999px;
  font-size:15px;font-weight:500;border:1.5px solid transparent;cursor:pointer;
  transition:transform .08s ease, background .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#8d2626}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- About ---------- */
.about{padding:64px 0;border-top:1px solid var(--line)}
.about h2{font-size:30px;margin-bottom:32px}
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.about-cell h3{font-size:20px;margin-bottom:8px;color:var(--accent)}
.about-cell p{color:var(--ink-soft);font-size:15px;margin:0}

/* ---------- Rollen ---------- */
.roles{padding:64px 0;background:var(--paper-2);border-top:1px solid var(--line)}
.roles h2{font-size:30px}
.roles-lead{color:var(--ink-soft);max-width:64ch;margin:14px 0 36px;font-size:16px}
.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.role-card{
  display:flex;flex-direction:column;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px;transition:border-color .15s ease, transform .08s ease;
}
.role-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.role-icon{
  font-size:26px;width:52px;height:52px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(122,31,31,.08);color:var(--accent);margin-bottom:16px;
}
.role-card h3{font-size:21px;margin-bottom:10px}
.role-card p{color:var(--ink-soft);font-size:14.5px;margin:0 0 18px;flex:1}
.role-go{font-size:14px;color:var(--accent);font-weight:600}
.roles-note{margin-top:28px;color:var(--ink-soft);font-size:13px;font-style:italic}

/* ---------- Footer ---------- */
.site-foot{border-top:1px solid var(--line);background:var(--paper-2);padding:28px 0;margin-top:0}
.site-foot .wrap{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--ink-soft)}
.site-foot nav{display:flex;gap:18px}
.site-foot nav a:hover{color:var(--accent)}

/* ---------- Карта артистов ---------- */
.map-head{padding:48px 0 24px}
.map-head h1{font-size:34px}
.map-lead{color:var(--ink-soft);margin:10px 0 24px}
.map-search input{
  width:100%;max-width:480px;padding:13px 18px;font-size:16px;
  border:1.5px solid var(--line);border-radius:999px;background:var(--paper-2);
  outline:none;transition:border-color .15s ease;font-family:var(--sans);
}
.map-search input:focus{border-color:var(--accent)}
.map-filters{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-label{font-size:13px;color:var(--ink-soft);min-width:56px;font-weight:600}
.chip{
  padding:6px 14px;font-size:13.5px;border:1px solid var(--line);
  background:var(--paper-2);border-radius:999px;cursor:pointer;color:var(--ink-soft);
  font-family:var(--sans);transition:all .12s ease;
}
.chip:hover{border-color:var(--accent-soft);color:var(--ink)}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}

.map-grid-wrap{padding:32px 0 64px}
.map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.artist-card{
  display:flex;flex-direction:column;background:var(--paper-2);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:border-color .15s ease, transform .08s ease, box-shadow .15s ease;
}
.artist-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,24,21,.08)}
.artist-photo{height:180px;background-size:cover;background-position:center;background-color:#e8e2d6}
.artist-photo.placeholder{display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(45deg,#ece6da,#ece6da 12px,#e6dfd1 12px,#e6dfd1 24px);}
.artist-photo.placeholder span{font-size:13px;color:var(--ink-soft);font-style:italic}
.artist-body{padding:18px 18px 20px}
.artist-body h3{font-size:19px;margin-bottom:4px}
.artist-tag{font-size:14px;color:var(--ink-soft);margin:0 0 12px}
.artist-genres{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.tag{font-size:12px;padding:3px 10px;background:rgba(122,31,31,.07);color:var(--accent);border-radius:999px}
.artist-loc{font-size:12.5px;color:var(--ink-soft);margin:0}
.map-empty{color:var(--ink-soft);padding:40px 0;text-align:center;font-style:italic}

/* ---------- Адаптив ---------- */
@media(max-width:820px){
  .hero h1{font-size:34px}
  .about-grid,.roles-grid{grid-template-columns:1fr}
  .site-nav{gap:16px}
  .brand-sub{display:none}
}
