/* ===========================================================
   Custom Cone Sleeve, location pages (states + cities)
   loads after cone-styles.css; reuses its tokens & components
   =========================================================== */

/* ---------- locations dropdown in nav ---------- */
.has-drop{position:relative;}
.has-drop > a{display:inline-flex;align-items:center;gap:6px;}
.drop-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);padding:10px;
  min-width:230px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60;
}
.has-drop:hover .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(4px);}
.drop-menu a{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--ink);font-weight:600;font-size:14px;padding:11px 14px;border-radius:9px;}
.drop-menu a:hover{background:var(--pink-blush);color:var(--pink-deep);}
.drop-menu a .ab{font-size:11px;color:var(--muted);font-weight:700;}
.drop-menu .dm-all{border-top:1px solid var(--line);margin-top:6px;padding-top:6px;color:var(--pink-deep);}

/* ---------- location hero ---------- */
.loc-hero{background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.loc-hero::before{content:"";position:absolute;inset:0;background:
  linear-gradient(105deg, var(--ink) 38%, transparent),
  var(--bg-img) center/cover;opacity:1;}
.loc-hero .img-layer{position:absolute;right:0;top:0;bottom:0;width:52%;background-size:cover;background-position:center;}
.loc-hero .img-layer::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, var(--ink), transparent 60%);}
.loc-hero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:78px 28px 84px;}
/* hero with form (no image) */
.loc-hero.has-form{--bg-img:none;}
.loc-hero.has-form::before{background:radial-gradient(120% 90% at 85% 10%, color-mix(in srgb,var(--pink) 22%,transparent), transparent 60%), var(--ink);}
.loc-hero.has-form .img-layer{display:none;}
.loc-hero.has-form .inner{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.hero-form{background:#fff;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-lg);color:var(--text);}
.hero-form .hf-top{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.hero-form .hf-top .tag{background:var(--pink);color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:30px;}
.hero-form h3{font-size:24px;color:var(--ink);}
.hero-form .sub{color:var(--muted);font-size:14px;margin:6px 0 18px;}
.hero-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.hero-form input,.hero-form select,.hero-form textarea{border:1px solid var(--line);background:#fbfcfc;border-radius:10px;padding:13px 14px;font-family:var(--sans);font-size:14px;color:var(--text);outline:none;width:100%;margin-bottom:12px;transition:border .2s,box-shadow .2s;}
.hero-form input:focus,.hero-form select:focus,.hero-form textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px color-mix(in srgb,var(--pink) 13%,transparent);background:#fff;}
.hero-form .hf-file{display:flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fbfcfc;margin-bottom:12px;cursor:pointer;}
.hero-form .hf-file input{display:none;}
.hero-form .hf-file .b{background:var(--pink);color:#fff;padding:13px 15px;font-size:13px;font-weight:700;white-space:nowrap;}
.hero-form .hf-file .n{padding:0 13px;color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hero-form button{width:100%;justify-content:center;margin-top:4px;}
.hero-form .note{text-align:center;color:var(--muted);font-size:12px;margin-top:12px;}
.loc-hero .geo-tag{display:inline-flex;align-items:center;gap:9px;background:color-mix(in srgb,var(--pink) 18%,transparent);border:1px solid color-mix(in srgb,var(--pink) 50%,transparent);color:#fff;font-weight:700;font-size:13px;letter-spacing:.06em;padding:9px 18px;border-radius:40px;margin-bottom:22px;}
.loc-hero .geo-tag i{color:var(--pink);}
.loc-hero h1{color:#fff;font-size:56px;line-height:1.04;max-width:680px;}
.loc-hero h1 .accent{color:var(--pink);}
.loc-hero .lead{color:rgba(255,255,255,.78);font-size:18px;margin-top:20px;max-width:560px;}
.loc-hero .cta-row{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
.loc-hero .h-stats{display:flex;gap:38px;margin-top:42px;flex-wrap:wrap;}
.loc-hero .h-stats .st b{font-family:var(--serif);font-size:30px;color:#fff;display:block;}
.loc-hero .h-stats .st span{color:rgba(255,255,255,.6);font-size:13px;}

/* ---------- generic section heading ---------- */
.loc-sec{padding:76px 0;}
.loc-head{max-width:640px;margin:0 auto 46px;text-align:center;}
.loc-head .eyebrow{display:inline-flex;align-items:center;gap:8px;}
.loc-head h2{font-size:38px;}
.loc-head p{color:var(--muted);margin-top:12px;}

/* ---------- city grid ---------- */
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.city-card{position:relative;display:block;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);min-height:240px;transition:transform .25s,box-shadow .25s;}
.city-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.city-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s;}
.city-card:hover .bg{transform:scale(1.06);}
.city-card .scrim{position:absolute;inset:0;background:linear-gradient(transparent 30%, rgba(14,42,54,.92));}
.city-card .meta{position:absolute;left:0;right:0;bottom:0;padding:22px;color:#fff;z-index:2;}
.city-card .meta h3{color:#fff;font-size:23px;}
.city-card .meta p{color:rgba(255,255,255,.82);font-size:13px;margin-top:6px;line-height:1.5;}
.city-card .meta .go{display:inline-flex;align-items:center;gap:7px;margin-top:12px;font-weight:700;font-size:13px;color:#fff;}
.city-card .meta .go i{transition:transform .2s;}
.city-card:hover .meta .go i{transform:translateX(4px);}
.city-card .pin{position:absolute;top:16px;left:16px;z-index:2;width:36px;height:36px;border-radius:50%;background:var(--pink);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-sm);}

/* ---------- category cards ---------- */
.cat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.cat-tile{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s;}
.cat-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.cat-tile .top{aspect-ratio:4/3;background:var(--pink-blush);position:relative;}
.cat-tile .top image-slot{width:100%;height:100%;}
.cat-tile .b{padding:18px 20px;}
.cat-tile h3{font-size:18px;}
.cat-tile p{color:var(--muted);font-size:13px;margin-top:6px;line-height:1.5;}
.cat-tile .go{display:inline-flex;align-items:center;gap:7px;margin-top:12px;color:var(--pink-deep);font-weight:700;font-size:13px;}

/* ---------- content prose ---------- */
.loc-prose{max-width:820px;margin:0 auto;}
.loc-prose h2{font-size:34px;margin-bottom:16px;}
.loc-prose h3{font-size:24px;margin:32px 0 12px;}
.loc-prose p{color:var(--muted);line-height:1.8;margin-bottom:16px;}
.loc-prose .lead-in{font-size:19px;color:var(--text);}

/* ---------- info trio ---------- */
.info-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm);}
.info-card .ic{width:54px;height:54px;border-radius:14px;background:var(--pink-soft);color:var(--pink-deep);display:grid;place-items:center;font-size:24px;margin-bottom:18px;}
.info-card h3{font-size:20px;margin-bottom:8px;}
.info-card p{color:var(--muted);font-size:14px;line-height:1.6;}

/* ---------- states hub grid ---------- */
.state-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;}
.state-card{position:relative;display:block;border-radius:var(--radius-lg);overflow:hidden;min-height:280px;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s;}
.state-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.state-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s;}
.state-card:hover .bg{transform:scale(1.05);}
.state-card .scrim{position:absolute;inset:0;background:linear-gradient(105deg, rgba(14,42,54,.92) 30%, rgba(14,42,54,.35));}
.state-card .meta{position:absolute;inset:0;padding:34px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;z-index:2;}
.state-card .abbr{position:absolute;top:26px;right:30px;font-family:var(--serif);font-weight:800;font-size:40px;color:rgba(255,255,255,.22);}
.state-card .meta .tg{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--pink);margin-bottom:8px;}
.state-card .meta h2{color:#fff;font-size:32px;}
.state-card .meta p{color:rgba(255,255,255,.82);font-size:14px;margin-top:8px;max-width:90%;line-height:1.55;}
.state-card .meta .cities-line{margin-top:14px;font-size:13px;color:rgba(255,255,255,.7);}
.state-card .meta .go{display:inline-flex;align-items:center;gap:8px;margin-top:18px;background:#fff;color:var(--ink);font-weight:700;font-size:14px;padding:11px 20px;border-radius:40px;align-self:flex-start;transition:background .2s,color .2s;}
.state-card:hover .meta .go{background:var(--pink);color:#fff;}

/* ---------- mini quote band ---------- */
.loc-quote{background:var(--cream);}
.loc-quote .grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.loc-quote h2{font-size:34px;margin-bottom:14px;}
.loc-quote p{color:var(--muted);margin-bottom:24px;}
.loc-quote .chips{display:flex;flex-wrap:wrap;gap:10px;}
.loc-quote .chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:40px;padding:10px 16px;font-size:13px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm);}
.loc-quote .chip i{color:var(--pink);}
.loc-quote .qcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow);}
.loc-quote .qcard h3{font-size:22px;margin-bottom:18px;}
.loc-quote .qcard .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.loc-quote .qcard input,.loc-quote .qcard select,.loc-quote .qcard textarea{border:1px solid var(--line);background:#fbfcfc;border-radius:10px;padding:13px 14px;font-family:var(--sans);font-size:14px;color:var(--text);outline:none;width:100%;margin-bottom:14px;transition:border .2s,box-shadow .2s;}
.loc-quote .qcard input:focus,.loc-quote .qcard select:focus,.loc-quote .qcard textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px color-mix(in srgb,var(--pink) 13%,transparent);background:#fff;}
.loc-quote .qcard button{width:100%;justify-content:center;}

/* ---------- nearby cities chips (city page) ---------- */
.nearby{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;}
.nearby a{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:40px;padding:11px 18px;font-weight:600;font-size:14px;color:var(--ink);box-shadow:var(--shadow-sm);transition:all .2s;}
.nearby a:hover{background:var(--pink);color:#fff;border-color:var(--pink);}
.nearby a i{color:var(--pink);}
.nearby a:hover i{color:#fff;}

@media(max-width:980px){
  .loc-hero::before{background:linear-gradient(120deg, var(--ink) 60%, rgba(14,42,54,.7)), var(--bg-img) center/cover;}
  .loc-hero.has-form .inner{grid-template-columns:1fr;gap:34px;}
  .loc-hero h1{font-size:40px;}
  .city-grid{grid-template-columns:repeat(2,1fr);}
  .cat-cards{grid-template-columns:repeat(2,1fr);}
  .info-trio{grid-template-columns:1fr;}
  .state-grid{grid-template-columns:1fr;}
  .loc-quote .grid{grid-template-columns:1fr;gap:32px;}
}
@media(max-width:560px){
  .city-grid,.cat-cards{grid-template-columns:1fr;}
  .loc-hero h1{font-size:32px;}
  .loc-quote .qcard .row{grid-template-columns:1fr;}
}
