/* ============================================================
   Rivergate Crossing — Heritage direction
   ============================================================ */
:root{
  --navy:#15233F;
  --navy-deep:#0E1830;
  --brass:#C8922E;
  --cream:#F6F1E7;
  --river:#5B86AD;
  --slate:#324A78;
  --ink:#26303F;
  --paper:#FBF8F2;
  --line:rgba(21,35,63,.12);
  --wrap:1140px;
  --r:14px;
  --shadow:0 1px 2px rgba(21,35,63,.06), 0 10px 30px rgba(21,35,63,.08);
  --display:'Fraunces',Georgia,serif;
  --body:'Archivo',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}

.wrap{width:min(100% - 2.5rem, var(--wrap));margin-inline:auto}

.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--brass);color:var(--navy);
  padding:.6rem 1rem;border-radius:0 0 var(--r) 0;font-weight:700;z-index:200;
}
.skip-link:focus{left:0}

/* Shared bits ------------------------------------------------ */
.eyebrow{
  font-family:var(--body);font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.2em;color:var(--brass);margin:0 0 .9rem;
}
.eyebrow--light{color:var(--brass)}
.section__title{
  font-family:var(--display);font-weight:600;color:var(--navy);
  font-size:clamp(1.7rem,3.6vw,2.6rem);line-height:1.12;margin:0 0 1.2rem;
  letter-spacing:-.01em;
}
.section__title--light{color:var(--cream)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--body);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:.85rem 1.5rem;border-radius:999px;text-decoration:none;cursor:pointer;
  border:2px solid transparent;transition:transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
}
.btn--sm{padding:.6rem 1.1rem;font-size:.9rem}
.btn--brass{background:var(--brass);color:var(--navy)}
.btn--brass:hover{background:#b27f22}
.btn--navy{background:var(--navy);color:var(--cream)}
.btn--navy:hover{background:#1d3158}
.btn--outline{background:transparent;color:var(--cream);border-color:rgba(246,241,231,.6)}
.btn--outline:hover{background:rgba(246,241,231,.12);border-color:var(--cream)}
.btn:active{transform:translateY(1px)}

:focus-visible{outline:3px solid var(--brass);outline-offset:2px;border-radius:4px}

/* Top bar ---------------------------------------------------- */
.topbar{background:var(--navy);color:var(--cream);font-size:.82rem}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;min-height:40px;gap:1rem}
.topbar__loc{opacity:.85}
.topbar__review{color:var(--brass);text-decoration:none;font-weight:700;white-space:nowrap}
.topbar__review:hover{text-decoration:underline}

/* Nav -------------------------------------------------------- */
.nav{position:sticky;top:0;z-index:100;background:rgba(246,241,231,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;min-height:76px;gap:1rem}
.nav__logo img{height:52px;width:auto}
.nav__links{display:flex;gap:2rem}
.nav__links a{
  text-decoration:none;color:var(--navy);font-weight:600;font-size:.98rem;padding:.25rem 0;position:relative;
}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--brass);
  transform:scaleX(0);transform-origin:left;transition:transform .18s ease;
}
.nav__links a:hover::after,.nav__links a:focus-visible::after{transform:scaleX(1)}

.nav__toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  background:none;border:none;cursor:pointer;padding:0;
}
.nav__toggle span{display:block;height:2px;width:24px;background:var(--navy);margin-inline:auto;transition:.2s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__panel{border-top:1px solid var(--line);background:var(--cream)}
.nav__panel a{display:block;padding:1rem 1.25rem;text-decoration:none;color:var(--navy);font-weight:600;border-bottom:1px solid var(--line)}
.nav__panel a:last-child{border-bottom:none}

/* Hero ------------------------------------------------------- */
.hero{position:relative;min-height:clamp(560px,82vh,760px);display:flex;align-items:center;overflow:hidden}
.hero__img,.hero__img img{position:absolute;inset:0;width:100%;height:100%}
.hero__img img{object-fit:cover}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,35,63,.42),rgba(21,35,63,.62))}
.hero__wrap{position:relative;display:flex;justify-content:center;width:100%;padding:2.5rem 0}
.hero__card{
  text-align:center;color:var(--cream);max-width:660px;width:max-content;
  background:rgba(21,35,63,.30);
  -webkit-backdrop-filter:blur(12px) saturate(1.1);backdrop-filter:blur(12px) saturate(1.1);
  border:1px solid rgba(246,241,231,.28);border-radius:10px;
  padding:1.6rem clamp(2rem,5vw,3.2rem) 1.8rem;
  display:flex;flex-direction:column;align-items:center;
  box-shadow:0 24px 60px rgba(0,0,0,.34);
}
.hero__logo{width:clamp(280px,46vw,440px);height:auto;margin:0 0 1rem;filter:drop-shadow(0 6px 22px rgba(0,0,0,.35))}
.hero__tagline{
  font-family:var(--display);font-weight:500;font-style:italic;letter-spacing:.005em;
  font-size:clamp(1.25rem,2.8vw,1.85rem);line-height:1.2;margin:0 0 1.4rem;color:var(--cream);max-width:24ch;
}
.hero__buttons{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}

/* About ------------------------------------------------------ */
.about{background:var(--cream);padding:clamp(3.5rem,7vw,6rem) 0}
.about__inner{max-width:760px}
.about__body{font-size:1.12rem;color:var(--ink);margin:0 0 2rem}
.glance{
  list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;
  font-weight:600;color:var(--slate);font-size:.95rem;
}
.glance li{position:relative;padding-left:1.3rem}
.glance li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;background:var(--brass);transform:rotate(45deg)}

/* Store directory (navy marquee) ----------------------------- */
.stores{background:var(--navy);padding:clamp(3.5rem,7vw,6rem) 0;color:var(--cream)}
.stores__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:.5rem;
}
.tenant{
  display:flex;flex-direction:column;text-decoration:none;background:var(--paper);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);
  transition:transform .16s ease, box-shadow .16s ease;
}
.tenant:hover,.tenant:focus-visible{transform:translateY(-3px);box-shadow:0 14px 34px rgba(0,0,0,.28)}
.tenant__mark{
  display:flex;align-items:center;justify-content:center;min-height:108px;padding:1.4rem 1rem;
}
.tenant__cat{
  display:block;background:var(--navy-deep);color:var(--brass);text-align:center;
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;padding:.7rem .8rem;
}

/* EV charging row */
.ev{margin-top:2.6rem;padding-top:2.2rem;border-top:1px solid rgba(246,241,231,.18)}
.ev__title{
  font-family:var(--display);font-weight:600;color:var(--cream);text-align:center;
  font-size:clamp(1.25rem,2.4vw,1.6rem);margin:0 0 1.4rem;
}
.ev__grid{display:grid;grid-template-columns:repeat(2,minmax(0,256px));gap:1.1rem;justify-content:center}

/* Wordmark treatments (brand-styled text) -------------------- */
.wm{display:flex;flex-direction:column;align-items:center;text-align:center;line-height:1}
.wm b{font-weight:800;letter-spacing:.01em}
.wm i{font-style:normal;font-weight:600;margin-top:.28rem;font-size:.62em;letter-spacing:.04em}

.wm--ross{color:#0B2C7A}
.wm--ross b{font-size:2rem;letter-spacing:.06em}
.wm--ross i{color:#0B2C7A;text-transform:uppercase;letter-spacing:.22em;font-size:.55em}

.wm--ulta{color:#E54C8C}
.wm--ulta b{font-family:var(--display);font-weight:600;font-size:2rem;letter-spacing:.02em}
.wm--ulta i{color:var(--ink);text-transform:uppercase;letter-spacing:.3em;font-size:.5em}

.wm--wilson{color:#B22234}
.wm--wilson b{font-family:var(--display);font-size:1.55rem}
.wm--wilson i{color:var(--ink)}

.wm--shoe{color:#0A2540}
.wm--shoe b{font-size:1.6rem;letter-spacing:.02em}
.wm--shoe i{color:#C8102E;text-transform:uppercase;letter-spacing:.34em;font-weight:800;font-size:.66em}

.wm--realdeals{color:#6B4F3A}
.wm--realdeals b{font-family:var(--display);font-weight:600;font-size:1.9rem;text-transform:lowercase}
.wm--realdeals i{color:#6B4F3A;letter-spacing:.18em;text-transform:lowercase}

.wm--minidoka{color:#1F6F8B}
.wm--minidoka b{font-family:var(--display);font-weight:600;font-size:1.4rem}
.wm--minidoka i{color:var(--slate)}

.wm--cricket{color:#6AB42D}
.wm--cricket b{font-size:1.95rem;text-transform:lowercase;letter-spacing:-.01em}
.wm--cricket i{color:var(--ink);text-transform:lowercase;letter-spacing:.16em}

.wm--greatclips{color:#005DAA}
.wm--greatclips b{font-size:1.7rem}
.wm--greatclips i{color:var(--ink)}

.wm--panda{color:#D2232A}
.wm--panda b{font-size:1.4rem;letter-spacing:.02em}
.wm--panda i{color:var(--ink)}

.wm--jersey{color:#0B2C7A}
.wm--jersey b{font-size:1.4rem;letter-spacing:.01em}
.wm--jersey i{color:#C8102E;text-transform:uppercase;letter-spacing:.3em;font-weight:800;font-size:.7em}

.wm--dominos{color:#0B6EB5}
.wm--dominos b{font-family:var(--display);font-weight:600;font-size:1.85rem}
.wm--dominos i{color:#E31837;text-transform:uppercase;letter-spacing:.2em;font-size:.55em}

.wm--tesla{color:#CC1B22}
.wm--tesla b{font-size:1.7rem;letter-spacing:.42em;text-indent:.42em}
.wm--tesla i{color:var(--ink);text-transform:uppercase;letter-spacing:.22em;font-size:.5em}

.wm--rivian{color:#1C2B33}
.wm--rivian b{font-size:1.7rem;letter-spacing:.34em;text-indent:.34em}
.wm--rivian i{color:var(--slate);text-transform:uppercase;letter-spacing:.26em;font-size:.5em}

/* Visit ------------------------------------------------------ */
.visit{background:var(--cream);padding:clamp(3.5rem,7vw,6rem) 0}
.visit__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.visit__body{font-size:1.08rem;margin:0 0 1.8rem;max-width:46ch}
.info{margin:0;display:grid;gap:1rem}
.info__row{display:grid;grid-template-columns:170px 1fr;gap:1rem;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--line)}
.info__row:last-child{border-bottom:none;padding-bottom:0}
.info dt{font-weight:700;color:var(--navy);font-size:.95rem}
.info dd{margin:0;font-weight:600;color:var(--slate)}
.info dd a{color:var(--slate);text-decoration:none}
.info dd a:hover{text-decoration:underline}
.map{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:#dfe6ee}
.map iframe{width:100%;height:100%;border:0;display:block}

/* EV charging callout */
.charging{margin-top:1.8rem;background:var(--navy);color:var(--cream);border-radius:var(--r);padding:1.5rem 1.6rem;border-left:5px solid var(--brass)}
.charging__eyebrow{margin:0 0 .5rem;font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--brass)}
.charging__body{margin:0 0 1rem;font-size:1rem;color:rgba(246,241,231,.92)}
.charging__brands{display:flex;flex-wrap:wrap;gap:.6rem;margin:0}
.charging__brands span{font-size:.78rem;font-weight:700;letter-spacing:.04em;padding:.4rem .85rem;border:1px solid rgba(246,241,231,.4);border-radius:999px;color:var(--cream)}

/* Contact ---------------------------------------------------- */
.contact{background:var(--navy);padding:clamp(3.5rem,7vw,6rem) 0;color:var(--cream)}
.contact__inner{max-width:720px}
.contact__sub{font-size:1.08rem;color:rgba(246,241,231,.85);margin:0 0 2rem;max-width:52ch}
.form{display:grid;gap:1.1rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-weight:700;font-size:.9rem;color:var(--cream)}
.field .opt{font-weight:500;color:rgba(246,241,231,.6)}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink);background:var(--paper);
  border:2px solid transparent;border-radius:10px;padding:.75rem .9rem;width:100%;
}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass)}
.field input:invalid:not(:placeholder-shown),.field select:invalid:not(:focus){border-color:transparent}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.form__actions{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-top:.3rem}
.form__status{margin:0;font-weight:600;font-size:.95rem}
.form__status.is-ok{color:#9BD49B}
.form__status.is-err{color:#F0B6A8}

/* Footer ----------------------------------------------------- */
.footer{background:var(--navy-deep);color:rgba(246,241,231,.8);padding:2.6rem 0;text-align:center}
.footer__mark{width:48px;height:48px;margin:0 auto 1rem}
.footer__line{margin:.25rem 0;font-size:.86rem}
.footer__line--quiet{font-size:.82rem;opacity:.8}
.footer a{color:var(--brass);text-decoration:none}
.footer a:hover{text-decoration:underline}

/* Responsive ------------------------------------------------- */
@media (max-width:920px){
  .stores__grid{grid-template-columns:repeat(2,1fr)}
  .visit__grid{grid-template-columns:1fr}
  .map{aspect-ratio:16/10}
}
@media (max-width:760px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
  .topbar__loc{display:none}
  .topbar__inner{justify-content:flex-end}
}
@media (max-width:560px){
  body{font-size:16px}
  .stores__grid{grid-template-columns:1fr}
  .ev__grid{grid-template-columns:1fr;max-width:300px;margin-inline:auto}
  .form__row{grid-template-columns:1fr}
  .info__row{grid-template-columns:1fr;gap:.35rem;align-items:start}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none !important;animation:none !important}
}
