/*
Theme Name: Queen Escorts Theme
Theme URI: https://queenescorts.vip
Author: Queen Escorts
Description: Custom agency theme (no external plugins required).
Version: 1.0.0
Text Domain: queenescorts-theme
*/

:root{
  --bg:#ececec;
  --text:#111111;
  --muted:#7a7a7a;
  --accent:#c92135;
  --dark:#050505;
  --light:#ffffff;
  --max:1180px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Georgia,"Times New Roman",serif}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{margin:0 0 1rem 1.1rem}
.container{max-width:var(--max);margin:0 auto;padding:0 16px}

/* Header / Hero */
.site-header{position:relative}
.qe-hero{position:relative;min-height:620px;overflow:hidden;background:#000}
.qe-hero__media{width:100%;height:620px;object-fit:cover;opacity:.95}
.qe-hero__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.25),rgba(0,0,0,.15))}
.qe-brand{
  position:absolute;left:50%;top:56px;transform:translateX(-50%);
  text-align:center;color:#fff;z-index:2
}
.qe-brand__title{margin:0;font-size:58px;letter-spacing:.28em;font-weight:500}
.qe-brand__subtitle{margin:10px 0 0;font-size:12px;letter-spacing:.45em;text-transform:lowercase}
.qe-brand__mark{margin:22px auto 0;width:54px;height:54px;border:3px solid var(--accent);border-radius:50%}

/* Tabs */
.qe-tabs{display:flex;justify-content:center;gap:26px;padding:20px 16px;color:var(--accent);text-transform:uppercase;letter-spacing:.23em;font-size:11px}
.qe-tabs a{opacity:.75}
.qe-tabs a.is-active,.qe-tabs a:hover{opacity:1}

/* Grid */
.qe-section{padding:30px 0}
.qe-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.qe-card{background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.qe-card__img{width:100%;height:320px;object-fit:cover;background:#ddd}
.qe-card__body{padding:10px 12px}
.qe-card__title{margin:0;font-size:20px;color:#8a0f1d}
.qe-card__meta{margin:6px 0 0;color:#6a6a6a;font-size:13px}

/* Content block */
.qe-copy h2{margin:8px 0 8px;font-size:56px;line-height:1.02;color:var(--accent);font-weight:500}
.qe-copy h3{margin:12px 0 8px;font-size:48px;line-height:1.05;color:var(--accent);font-weight:500}
.qe-copy p{margin:0 0 10px;color:#9a9a9a;font-size:30px;line-height:1.35}
.qe-copy .small{font-size:32px;color:#b4b4b4}

/* Footer */
.qe-footer-top{background:#000;color:#fff;margin-top:24px}
.qe-footer-top .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 16px}
.qe-footer-brand{font-size:36px;color:var(--accent)}
.qe-footer-nav{display:flex;gap:24px;font-size:12px;letter-spacing:.08em}
.qe-footer-phone{font-size:32px;color:#ff2d45}
.qe-footer-bottom{padding:42px 16px 58px;text-align:center;color:#c6c6c6}
.qe-footer-bottom .ad-wrap{max-width:560px;margin:16px auto}
.qe-footer-bottom .copyright{margin-top:14px;font-size:14px;color:#d1a9a9}

/* Single model */
.qe-single{padding:34px 0}
.qe-single__wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
.qe-pill{display:inline-block;padding:4px 10px;border:1px solid #ddd;border-radius:20px;font-size:12px;margin-right:6px}

/* Utilities */
.btn{display:inline-block;background:#111;color:#fff;padding:10px 14px;border-radius:3px}
.btn--accent{background:var(--accent)}
.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.4rem}
.text-muted{color:#8a8a8a}

/* Responsive */
@media (max-width:1100px){
  .qe-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .qe-card__img{height:280px}
}
@media (max-width:820px){
  .qe-brand__title{font-size:38px}
  .qe-hero,.qe-hero__media{min-height:470px;height:470px}
  .qe-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .qe-copy h2,.qe-copy h3{font-size:40px}
  .qe-copy p,.qe-copy .small{font-size:22px}
  .qe-single__wrap{grid-template-columns:1fr}
}
@media (max-width:520px){
  .qe-grid{grid-template-columns:1fr}
  .qe-tabs{gap:14px;letter-spacing:.12em}
  .qe-footer-top .container{flex-direction:column;align-items:flex-start}
}