/* friendboy.pro — charte navy + ambre. v1 */
:root{
  --bg:#111923; --bg2:#17212d; --panel:#1b2735; --panel2:#243448;
  --ink:#edeff0; --muted:#9bb0bd; --soft:#7d92a2;
  --accent:#feae4d; --accent2:#ffba67; --line:#2b3f58; --blue:#1e88e5;
  --ok:#4caf50; --radius:14px; --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent2)}
h1,h2,h3{line-height:1.2;margin:0 0 .5em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 18px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:#111923;
  padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:100;background:rgba(17,25,35,.92);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;height:64px}
.nav .logo img{height:38px;width:auto}
.nav ul{display:flex;align-items:center;gap:10px;list-style:none;margin:0;padding:0}
.nav a.navlink{color:var(--muted);padding:8px 12px;border-radius:8px;font-weight:600}
.nav a.navlink:hover{color:var(--ink);background:var(--panel)}
.btn{display:inline-block;border:0;cursor:pointer;font-weight:700;text-align:center;
  padding:11px 20px;border-radius:999px;background:var(--accent);color:#111923;
  transition:background .15s ease}
.btn:hover{background:var(--accent2);color:#111923}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--panel);color:var(--ink)}
.btn-sm{padding:8px 14px;font-size:14px}

/* Hero */
.hero{background:radial-gradient(120% 130% at 50% 0%,#2b3f58 0%,#111923 60%);
  padding:64px 0 52px;text-align:center;border-bottom:1px solid var(--line)}
.hero img.brand{width:360px;max-width:80%;margin:0 auto 18px}
.hero h1{font-size:clamp(26px,4vw,40px)}
.hero p.lead{color:var(--muted);max-width:620px;margin:0 auto 26px;font-size:17px}

/* Search */
.search{display:flex;justify-content:center;gap:10px;max-width:620px;margin:0 auto}
.search input{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--ink);
  padding:13px 16px;border-radius:999px;font-size:15px}
.search input::placeholder{color:var(--soft)}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--soft);padding:14px 0}
.breadcrumb a{color:var(--muted)}
.breadcrumb span{margin:0 6px;color:var(--line)}

/* Section heading */
.section{padding:34px 0}
.section h2{font-size:22px;color:var(--ink)}
.section .sub{color:var(--muted);margin:-6px 0 18px}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:transform .15s ease,border-color .15s ease}
.card:hover{transform:translateY(-3px);border-color:var(--accent)}
.card a{color:inherit;display:block}
.card .thumb{aspect-ratio:4/5;background:var(--bg2);position:relative;overflow:hidden}
.card .thumb picture{display:block;width:100%;height:100%}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.card .meta{padding:11px 13px}
.card .meta .name{font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis}
.card .meta .loc{font-size:12.5px;color:var(--muted);white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;margin-top:2px}

.card .name-row{display:block;min-width:0}
.card .name-row .name{min-width:0}
.model-age{display:block;color:var(--muted);font-size:11.5px;font-weight:500;line-height:1.35;margin-top:2px}
.card .meta .cdesc{font-size:12.5px;color:var(--soft);margin-top:7px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.city-grid .card a{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);height:100%}
.city-grid .card .thumb{aspect-ratio:auto;min-height:190px;height:100%;position:relative;overflow:hidden}
.city-grid .card .thumb img{height:100%;object-fit:cover}
.city-grid .card .meta{padding:12px 13px;min-width:0;display:flex;flex-direction:column}
.city-grid .card .meta .cdesc{-webkit-line-clamp:3}
.city-grid .badges{margin-bottom:8px}
.badge.badge-ok{background:transparent;color:#69d27a;border-color:currentColor}
.badge.badge-accent{background:transparent;color:var(--accent);border-color:currentColor}

.photo-badge{position:absolute;top:8px;left:8px;z-index:2;background:rgba(17,25,35,.72)!important;color:var(--accent);border-color:currentColor;backdrop-filter:blur(3px);margin:0}

.card .badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:7px}
.card .badge{margin:0;padding:3px 7px;font-size:10.5px;line-height:1.25;background:transparent;border-color:currentColor}

/* Profile */
.profile{display:grid;grid-template-columns:380px 1fr;gap:28px;padding:24px 0 40px}
.profile .ph{border-radius:var(--radius);overflow:hidden;
  position:sticky;top:84px}
.profile .ph img{width:100%;aspect-ratio:4/5;object-fit:cover}
.profile h1{font-size:30px}
.profile .loc{color:var(--accent);font-weight:600;margin-bottom:14px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;margin-bottom:18px}
.panel h2{font-size:17px;color:var(--accent);margin-bottom:10px}
.panel p{margin:0 0 8px;color:var(--ink)}
.kv{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.kv li{display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line);
  padding-bottom:6px;font-size:14px}
.kv li span:first-child{color:var(--muted)}
.taglist{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.taglist li{background:var(--panel2);border:1px solid var(--line);padding:5px 11px;
  border-radius:999px;font-size:13px;color:var(--ink)}
.badge{display:inline-block;background:transparent;color:var(--accent);
  border:1px solid currentColor;padding:3px 8px;border-radius:5px;font-size:11px;
  font-weight:600;margin:0 6px 6px 0;letter-spacing:.01em}
.notice{background:var(--panel2);border:1px dashed var(--line);border-radius:var(--radius);
  padding:16px 18px;color:var(--muted)}

/* Pagination */
.pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:30px 0}
.pager a,.pager span{padding:8px 13px;border-radius:8px;border:1px solid var(--line);
  color:var(--muted);font-size:14px}
.pager a:hover{border-color:var(--accent);color:var(--ink)}
.pager .cur{background:var(--accent);color:#111923;border-color:var(--accent);font-weight:700}

/* Alpha nav */
.alpha{display:flex;flex-wrap:wrap;gap:6px;padding:6px 0 18px}
.alpha a{padding:6px 11px;border:1px solid var(--line);border-radius:8px;color:var(--muted);
  font-weight:600;font-size:14px}
.alpha a:hover{border-color:var(--accent);color:var(--ink)}

/* Forms */
.form{max-width:640px;margin:0 auto}
.form .field{margin-bottom:16px}
.form label{display:block;margin-bottom:6px;color:var(--muted);font-size:14px;font-weight:600}
.form input,.form textarea,.form select{width:100%;background:var(--panel);
  border:1px solid var(--line);color:var(--ink);padding:12px 14px;border-radius:10px;font-size:15px}
.form textarea{min-height:120px;resize:vertical}
.form .check{display:flex;gap:10px;align-items:flex-start}
.form .check input{width:auto;margin-top:4px}

/* Footer */
.site-footer{background:#0d141d;border-top:1px solid var(--line);margin-top:30px;
  padding:38px 0 26px;color:var(--muted);font-size:14px}
.site-footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:26px}
.site-footer img{height:34px;margin-bottom:12px}
.site-footer h2,.site-footer .footer-title{display:block;font-size:14px;color:var(--ink);text-transform:uppercase;letter-spacing:.5px;margin:0 0 .6em;font-weight:700}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:6px 0}
.site-footer a{color:var(--muted)}
.site-footer a:hover{color:var(--accent)}
.site-footer .copy{border-top:1px solid var(--line);margin-top:24px;padding-top:16px;
  color:var(--soft);font-size:13px}
.age{display:inline-block;border:1px solid var(--line);border-radius:8px;padding:2px 8px;
  font-size:12px;color:var(--accent);font-weight:700;margin-bottom:10px}
.profile-badges{display:flex;flex-wrap:wrap;gap:7px;margin:4px 0 14px}
.profile-badges .badge{margin:0}

@media(max-width:860px){
  .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
  .city-grid .card a{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
  .city-grid .card .thumb{min-height:180px}
  .profile{grid-template-columns:1fr}
  .profile .ph{position:static;max-width:340px;margin:0 auto}
  .site-footer .cols{grid-template-columns:1fr 1fr}
  .kv{grid-template-columns:1fr}
}
@media(max-width:560px){
  .grid{grid-template-columns:1fr;gap:16px}
  .city-grid .card a{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
  .city-grid .card .thumb{min-height:170px}
  .nav .logo img{height:32px}
  .site-footer .cols{grid-template-columns:1fr}
}

/* Profile page/city CTA */
.profile-actions{display:flex;justify-content:flex-end;margin:8px 0 22px}
.post-ad-cta{box-shadow:0 8px 22px rgba(255,183,77,.22)}

/* Adult age gate */
.age-gate[hidden]{display:none!important}
.age-gate{position:fixed;inset:0;z-index:10000;background:rgba(5,8,12,.78);display:flex;align-items:center;justify-content:center;padding:18px;overflow:auto}
.age-gate-open body{overflow:hidden}
.age-gate__dialog{width:min(980px,100%);background:#111923;border:1px solid rgba(255,255,255,.16);box-shadow:0 24px 80px rgba(0,0,0,.55);border-radius:10px;overflow:hidden}
.age-gate__banner{min-height:520px;background:linear-gradient(90deg,rgba(17,25,35,.97) 0%,rgba(17,25,35,.92) 48%,rgba(17,25,35,.55) 100%),url('/images/android-icon-512x512.png') right 48px center/240px 240px no-repeat;display:flex;align-items:center}
.age-gate__content{max-width:650px;padding:38px 42px}
.age-gate__title{display:inline-block;margin:0 0 22px;padding:8px 18px;border-top:1px solid var(--accent);border-bottom:1px solid var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.08em;font-size:28px}
.age-gate__brand{font-size:24px;font-weight:800;color:#fff;margin-bottom:12px}
.age-gate__text{max-height:280px;overflow:auto;color:#d8e1ec;font-size:14px;line-height:1.65;padding-right:10px}
.age-gate__actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:22px}
.age-gate__exit{background:transparent;color:#d8e1ec;text-decoration:underline;padding-left:0;padding-right:0}
.age-gate__exit:hover{background:transparent;color:#fff}
@media(max-width:720px){.age-gate{padding:10px}.age-gate__banner{min-height:auto;background:linear-gradient(180deg,rgba(17,25,35,.98),rgba(17,25,35,.95))}.age-gate__content{padding:26px 20px}.age-gate__title{font-size:22px}.age-gate__text{max-height:50vh}.profile-actions{justify-content:stretch}.post-ad-cta{width:100%}}

/* Top locations dropdown + mobile burger */
.nav{position:relative}
.nav-menu{display:flex;align-items:center;gap:10px;list-style:none;margin:0;padding:0}
.nav-dropdown{position:relative;display:flex;align-items:center;gap:2px}
.dropdown-toggle{border:0;background:transparent;color:var(--muted);font-weight:800;cursor:pointer;padding:8px 6px;border-radius:8px;line-height:1}
.nav-dropdown:hover .dropdown-toggle,.dropdown-toggle:hover{color:var(--ink);background:var(--panel)}
.dropdown-menu{position:absolute;top:calc(100% + 10px);left:0;z-index:200;min-width:235px;padding:8px;background:#152131;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 44px rgba(0,0,0,.35);display:none;grid-template-columns:1fr;gap:2px}
.dropdown-menu a{display:block;padding:9px 11px;border-radius:8px;color:var(--muted);font-weight:600;white-space:nowrap}
.dropdown-menu a:hover{background:var(--panel);color:var(--ink)}
.dropdown-menu a.locations-all{margin-top:5px;border-top:1px solid var(--line);border-radius:0 0 8px 8px;color:var(--accent);font-weight:600}
.dropdown-menu a.locations-all:hover{background:rgba(255,122,24,.10);color:#ffb26f}
.nav-dropdown:hover .dropdown-menu,.nav-dropdown:focus-within .dropdown-menu{display:grid}
.nav-toggle{display:none;align-items:center;justify-content:center;flex-direction:column;width:42px;height:42px;border:1px solid var(--line);border-radius:10px;background:transparent;gap:5px;cursor:pointer}
.nav-toggle span{display:block;width:21px;height:2px;background:var(--ink);border-radius:2px}

@media(max-width:980px){
  .nav{height:58px}
  .nav .logo img{height:34px;max-width:190px}
  .nav-toggle{display:flex;margin-left:auto}
  .nav-menu{display:none!important;position:absolute;top:calc(100% + 9px);right:0;left:0;z-index:250;flex-direction:column;align-items:stretch;gap:4px;padding:10px;background:#111923;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px rgba(0,0,0,.45)}
  .nav.nav-open .nav-menu{display:flex!important}
  .nav-menu li{width:100%}
  .nav a.navlink,.nav-menu .btn{display:block;width:100%;box-sizing:border-box;text-align:left;padding:11px 12px;border-radius:10px}
  .nav-dropdown{display:block}
  .nav-dropdown .navlink{padding-right:40px}
  .dropdown-toggle{position:absolute;right:6px;top:5px;width:34px;height:34px}
  .dropdown-menu{position:static;min-width:0;margin:4px 0 4px 10px;padding:5px;background:#0d1622;box-shadow:none;border-radius:10px;display:none}
  .nav-dropdown.open .dropdown-menu{display:grid}
  .nav-dropdown:hover .dropdown-menu{display:none}
  .nav-dropdown.open:hover .dropdown-menu{display:grid}
  .profile-actions{display:none!important}
}

.form-alert{display:none;max-width:640px;margin:0 auto 18px;padding:13px 15px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);font-weight:600}
.form-alert.is-visible,.form-alert:target{display:block}
.form-alert-success{border-color:rgba(105,210,122,.55);color:#b8f5c1;background:rgba(105,210,122,.08)}
.form-alert-error{border-color:rgba(255,106,106,.55);color:#ffb7b7;background:rgba(255,106,106,.08)}

@supports (content-visibility:auto){.grid .card{content-visibility:auto;contain-intrinsic-size:320px 430px}.city-grid .card{contain-intrinsic-size:360px 220px}}

.contact-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.btn-telegram{background:#229ED9;color:#fff}
.btn-telegram:hover{background:#1b8fc6;color:#fff}
@media(max-width:720px){.contact-actions{display:block}.contact-actions .btn{display:block;width:100%;box-sizing:border-box;margin-top:10px}}

.btn-icon{display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn-svg{width:18px;height:18px;display:block;fill:currentColor;flex:0 0 auto}
.contact-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:0}
@media(max-width:720px){.contact-actions{display:block}.contact-actions .btn{display:flex;width:100%;box-sizing:border-box;margin-top:10px}.contact-actions .btn:first-child{margin-top:0}}
