/* ═══════════════════════════════════════════
   HOSPITALITY IMPROVEMENTS INC — Design System
   Plaster #F4EFE6 | Ink #1F1D1A | Tiffany Blue #5BBCCB
   Sage #7C8B72 | Soft White #FBFAF7
   Type: Fraunces (display) / Inter (body)
   Brand accent: company tiffany blue (matches the Hii logo)
   Signature: tiffany rule-and-dot wayfinding divider
═══════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --plaster:#F4EFE6;
  --ink:#1F1D1A;
  --ink-soft:#3A3631;
  --brass:#5BBCCB;        /* tiffany blue — company brand color */
  --brass-dark:#0E7C8A;   /* deeper tiffany for text & links (accessible contrast) */
  --sage:#7C8B72;
  --white:#FBFAF7;
  --stone:#8A8478;
  --line:rgba(31,29,26,0.1);
  --line-soft:rgba(31,29,26,0.06);

  --font-d:'Fraunces',Georgia,serif;
  --font-b:'Inter',system-ui,sans-serif;

  --max-w:1180px;
  --r:6px;
  --r-lg:14px;
  --trans:0.22s ease;
  --shadow:0 6px 24px rgba(31,29,26,0.08);
  --shadow-lg:0 16px 48px rgba(31,29,26,0.14);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);background:var(--white);color:var(--ink-soft);line-height:1.65}
img{max-width:100%;display:block}
ul{list-style:none}
a{color:var(--brass-dark);text-decoration:none;transition:color var(--trans)}
a:hover{color:var(--ink)}
a:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:2px}

.skip-link{position:absolute;top:-100%;left:1rem;background:var(--ink);color:var(--white);padding:.5rem 1rem;z-index:9999}
.skip-link:focus{top:1rem}
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-b);font-weight:600;font-size:.92rem;padding:.75rem 1.75rem;border-radius:50px;border:1.5px solid transparent;cursor:pointer;transition:all var(--trans);text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--ink);color:var(--white);border-color:var(--ink)}
.btn-primary:hover{background:var(--brass-dark);border-color:var(--brass-dark);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(91,188,203,.35)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--white);transform:translateY(-2px)}
.btn-text{background:var(--brass-dark);color:#fff;border-color:var(--brass-dark)}
.btn-text:hover{background:var(--ink);border-color:var(--ink);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(91,188,203,.35)}
.btn-lg{padding:.9rem 2.1rem;font-size:1rem}
.btn-xl{padding:1.05rem 2.5rem;font-size:1.08rem}

/* ── SECTION HELPERS ── */
.eyebrow{font-family:var(--font-b);font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-dark);margin-bottom:.6rem;display:block}
.eyebrow.center{text-align:center}
h2.center,p.center{text-align:center}

/* ════════════════════
   BRASS DIVIDER (signature element)
════════════════════ */
.brass-divider{
  display:flex;align-items:center;justify-content:center;gap:.85rem;
  padding:2.5rem 0;
}
.brass-divider span{
  display:block;height:1px;width:120px;
  background:linear-gradient(90deg,transparent,var(--brass),transparent);
}
.brass-divider i{
  width:6px;height:6px;border-radius:50%;background:var(--brass);
  flex-shrink:0;font-style:normal;
}

/* ════════════════════
   TOP BAR
════════════════════ */
.top-bar{background:var(--ink);color:rgba(251,250,247,.85);font-size:.8rem;padding:.5rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.top-bar-cta{color:var(--brass);font-weight:600;transition:color var(--trans)}
.top-bar-cta:hover{color:var(--white)}
.top-bar-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}

/* ════════════════════
   HEADER
════════════════════ */
.site-header{position:sticky;top:0;z-index:900;background:rgba(251,250,247,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:78px;gap:1.5rem}
.logo{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:var(--ink)}
.logo-img{height:60px;width:auto;display:block}
.logo-mark{font-size:1.5rem;color:var(--brass);line-height:1}
.logo-text{line-height:1.2}
.logo-text strong{font-family:var(--font-d);font-size:1.05rem;font-weight:600;display:block;color:var(--ink)}
.logo-text span{font-size:.68rem;color:var(--stone);text-transform:uppercase;letter-spacing:.07em}

.main-nav ul{display:flex;align-items:center;gap:.1rem}
.main-nav a{font-size:.85rem;font-weight:500;color:var(--ink-soft);padding:.45rem .8rem;border-radius:var(--r);transition:all var(--trans)}
.main-nav a:hover{color:var(--ink);background:rgba(91,188,203,.12)}
.nav-cta{background:var(--ink) !important;color:var(--white) !important;border-radius:50px !important;padding:.5rem 1.25rem !important;font-weight:600 !important}
.nav-cta:hover{background:var(--brass-dark) !important;color:#fff !important}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px}

/* ════════════════════
   HERO
════════════════════ */
.hero{background:var(--plaster);padding:6rem 0 5rem;position:relative}
.hero-content{max-width:760px;margin:0 auto;text-align:center}
.hero-eyebrow{font-family:var(--font-b);font-size:.8rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-dark);margin-bottom:1.25rem}
.hero-headline{font-family:var(--font-d);font-size:clamp(2.6rem,6vw,4.6rem);font-weight:600;line-height:1.08;color:var(--ink);margin-bottom:1.5rem;letter-spacing:-0.01em}
.hero-headline em{font-style:italic;font-weight:500;color:var(--brass-dark)}
.hero-sub{font-size:clamp(1rem,1.8vw,1.15rem);color:var(--ink-soft);max-width:600px;margin:0 auto 2.5rem;line-height:1.7}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}
.hero-trust-row{display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap;font-size:.82rem;color:var(--stone);font-weight:500}
.dot{color:var(--brass)}

/* ════════════════════
   TRUST BAR
════════════════════ */
.trust-bar{padding:1rem 0 3rem}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.trust-item{display:flex;align-items:flex-start;gap:.75rem}
.trust-icon{font-size:1rem;color:var(--brass-dark);background:rgba(91,188,203,.16);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700}
.trust-item strong{font-size:.92rem;color:var(--ink);display:block;margin-bottom:.2rem}
.trust-item p{font-size:.8rem;color:var(--stone);line-height:1.5}

/* ════════════════════
   INTRO SECTION
════════════════════ */
.intro-section{padding:1rem 0 3rem}
.intro-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:4rem;align-items:start}
.intro-text h2{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:1.25rem}
.intro-text p{color:var(--ink-soft);margin-bottom:1rem;font-size:1rem}
.intro-text p:last-of-type{margin-bottom:2rem}

.intro-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat-card{background:var(--plaster);border-radius:var(--r-lg);padding:1.75rem 1.25rem;text-align:center}
.stat-num{font-family:var(--font-d);font-size:2.2rem;font-weight:600;color:var(--brass-dark);display:block;line-height:1;margin-bottom:.4rem}
.stat-label{font-size:.78rem;color:var(--stone);font-weight:500;text-transform:uppercase;letter-spacing:.04em;line-height:1.4}

/* ════════════════════
   SERVICE SECTIONS
════════════════════ */
.service-section{padding:3rem 0}
.service-section-alt{background:var(--plaster)}
.service-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.service-grid-reverse{direction:rtl}
.service-grid-reverse > *{direction:ltr}
.service-text .eyebrow{display:block}
.service-text h2{font-family:var(--font-d);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:1rem}
.service-text p{color:var(--ink-soft);font-size:1rem;margin-bottom:1.5rem}
.service-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.75rem}
.service-list li{font-size:.95rem;color:var(--ink-soft);display:flex;align-items:center;gap:.6rem}
.check{color:var(--brass);font-weight:700}
.service-image{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.service-image img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* ════════════════════
   PROCESS
════════════════════ */
.process-section{padding:1rem 0 2rem}
.process-section h2{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;color:var(--ink);margin-bottom:.75rem}
.process-sub{color:var(--stone);font-size:1rem;max-width:560px;margin:0 auto 3rem;text-align:center}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.process-step{text-align:center;padding:0 .5rem}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--ink);color:var(--brass);font-family:var(--font-d);font-size:1.3rem;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.process-step h3{font-family:var(--font-d);font-size:1.1rem;font-weight:600;color:var(--ink);margin-bottom:.5rem}
.process-step p{font-size:.85rem;color:var(--stone);line-height:1.6}

/* ════════════════════
   TESTIMONIALS
════════════════════ */
.testimonial-section{padding:1rem 0 2rem}
.testimonial-section h2{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;color:var(--ink);margin-bottom:3rem}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testimonial-card{background:var(--plaster);border-radius:var(--r-lg);padding:2rem 1.75rem;position:relative}
.testimonial-card p{font-family:var(--font-d);font-style:italic;font-size:1.02rem;color:var(--ink-soft);line-height:1.6;margin-bottom:1.25rem}
.testimonial-card cite{font-size:.82rem;font-weight:600;color:var(--brass-dark);font-style:normal}

/* ════════════════════
   AREAS
════════════════════ */
.areas-section{padding:1rem 0 2rem;text-align:center}
.areas-section h2{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;color:var(--ink);margin-bottom:1rem}
.areas-sub{color:var(--stone);font-size:1rem;max-width:560px;margin:0 auto 2.5rem}
.areas-grid{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.area-pill{background:var(--plaster);border:1px solid var(--line);color:var(--ink-soft);font-size:.88rem;font-weight:500;padding:.5rem 1.2rem;border-radius:50px;transition:all var(--trans)}
.area-pill:hover{background:var(--ink);color:var(--white);border-color:var(--ink)}

/* ════════════════════
   FAQ
════════════════════ */
.faq-section{padding:1rem 0 2rem}
.faq-section h2{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;color:var(--ink);margin-bottom:3rem}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:.65rem}
.faq-item{border:1.5px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--trans)}
.faq-item[open]{border-color:var(--brass)}
.faq-q{font-size:.97rem;font-weight:600;color:var(--ink);padding:1.15rem 1.5rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:color var(--trans)}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:'+';font-size:1.3rem;color:var(--brass);flex-shrink:0;margin-left:1rem;transition:transform var(--trans)}
details[open] .faq-q::after{transform:rotate(45deg)}
.faq-q:hover{color:var(--brass-dark)}
.faq-a{padding:0 1.5rem 1.25rem;font-size:.92rem;color:var(--ink-soft);line-height:1.7}
.faq-a a{color:var(--brass-dark);font-weight:600}

/* ════════════════════
   CONTACT
════════════════════ */
.contact-section{padding:1rem 0 4rem}
.contact-grid{display:grid;grid-template-columns:1fr auto;gap:4rem;align-items:center}
.contact-text .eyebrow{display:block}
.contact-text h2{font-family:var(--font-d);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:600;color:var(--ink);margin-bottom:1.25rem;line-height:1.2}
.contact-text p{color:var(--ink-soft);font-size:1.02rem;margin-bottom:2rem}
.contact-ctas{margin-bottom:2rem;display:flex;gap:1rem;flex-wrap:wrap}
.contact-details p{font-size:.9rem;color:var(--ink-soft);margin-bottom:.5rem}
.contact-socials{margin-top:1.5rem}
.social-btn{background:var(--plaster);color:var(--ink-soft);padding:.5rem 1.1rem;border-radius:50px;font-size:.85rem;font-weight:500;transition:all var(--trans)}
.social-btn:hover{background:var(--ink);color:var(--white)}

.contact-card{min-width:300px}
.contact-card-inner{background:var(--ink);border-radius:var(--r-lg);padding:2.75rem 2.25rem;text-align:center;box-shadow:var(--shadow-lg)}
.contact-card-inner .logo-mark{font-size:2rem;color:var(--brass);display:block;margin-bottom:1rem}
.contact-card-inner h3{font-family:var(--font-d);font-size:1.2rem;font-weight:600;color:var(--white);margin-bottom:.25rem}
.contact-card-inner > p{font-size:.8rem;color:rgba(251,250,247,.55);margin-bottom:1.5rem}
.contact-phone{display:block;font-family:var(--font-d);font-size:1.9rem;font-weight:600;color:var(--brass);margin-bottom:.25rem}
.contact-phone:hover{color:var(--white)}
.contact-card-sub{font-size:.75rem;color:rgba(251,250,247,.5);margin-bottom:1.5rem !important}
.contact-card-text{margin:0 auto;width:100%;justify-content:center}
.contact-card-divider{height:1px;background:rgba(251,250,247,.12);margin:1.25rem 0}
.contact-card-note{font-size:.78rem;color:rgba(251,250,247,.55)}

/* ════════════════════
   FOOTER
════════════════════ */
.site-footer{background:var(--ink);padding-top:3.5rem}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(251,250,247,.08)}
.footer-brand .logo-mark{font-size:1.5rem;color:var(--brass);display:block;margin-bottom:.5rem}
.footer-brand strong{font-family:var(--font-d);font-size:1.05rem;color:var(--white);display:block;margin-bottom:.35rem}
.footer-brand p{font-size:.8rem;color:rgba(251,250,247,.5);margin-bottom:.75rem}
.footer-phone{font-family:var(--font-d);font-size:1.25rem;color:var(--brass);display:block}
.footer-phone:hover{color:var(--white)}
.footer-text-link{display:inline-block;margin-top:.5rem;font-size:.85rem;font-weight:600;color:rgba(251,250,247,.75)}
.footer-text-link:hover{color:var(--brass)}
.footer-col h4{font-family:var(--font-b);font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(251,250,247,.4);margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer-col a{font-size:.85rem;color:rgba(251,250,247,.65)}
.footer-col a:hover{color:var(--brass)}
.footer-bottom{padding:1.25rem 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.footer-bottom p{font-size:.75rem;color:rgba(251,250,247,.4)}

/* ════════════════════
   REDUCED MOTION
════════════════════ */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}html{scroll-behavior:auto}}

/* ════════════════════
   RESPONSIVE
════════════════════ */
@media(max-width:1024px){
  .trust-grid{grid-template-columns:1fr 1fr}
  .intro-grid{grid-template-columns:1fr;gap:2.5rem}
  .intro-stats{max-width:420px}
  .service-grid{grid-template-columns:1fr;gap:2rem}
  .service-grid-reverse{direction:ltr}
  .service-image{order:-1}
  .process-steps{grid-template-columns:1fr 1fr}
  .testimonial-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .contact-card{max-width:380px}
}
@media(max-width:768px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;top:0;right:-100%;width:80%;max-width:300px;height:100vh;background:var(--white);box-shadow:var(--shadow-lg);padding:5rem 2rem 2rem;transition:right var(--trans);z-index:800}
  .main-nav.open{right:0}
  .main-nav ul{flex-direction:column;gap:.25rem}
  .main-nav a{padding:.75rem 1rem;font-size:1rem;display:block}
  .top-bar{flex-direction:column;gap:.4rem;text-align:center}
  .trust-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .footer-bottom-inner{flex-direction:column;text-align:center}
}
