/* ============================================================
   IAC Website - Shared CSS for all mockup pages
   Includes: topbar, header, sitewide features, footer, common
   ============================================================ */
:root{
  --iac-primary:#b54608;
  --iac-primary-dark:#933905;
  --iac-ink:#1f1d1a;
  --iac-body:#4a463f;
  --iac-line:#e7e2da;
  --iac-bg:#ffffff;
  --iac-bg-soft:#faf7f2;
  --iac-bg-deep:#1c1a17;
  --shadow-sm:0 2px 10px rgba(31,29,26,.06);
  --shadow-md:0 14px 40px rgba(31,29,26,.12);
  --r:14px;
  --ease:cubic-bezier(.16,.84,.44,1);
  --maxw:1280px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:"Montserrat",system-ui,sans-serif;color:var(--iac-body);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{color:var(--iac-ink);font-weight:700;line-height:1.15;letter-spacing:-.01em}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:inherit;font-weight:600;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:.95em 1.9em;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.35s var(--ease)}
.btn--solid{background:var(--iac-primary);color:#fff}
.btn--solid:hover{background:var(--iac-primary-dark);transform:translateY(-2px);box-shadow:0 12px 26px rgba(181,70,8,.32)}
.btn--ghost{background:transparent;border-color:var(--iac-line);color:var(--iac-ink)}
.btn--ghost:hover{border-color:var(--iac-primary);color:var(--iac-primary)}
.btn--lg{padding:1.1em 2.4em;font-size:.86rem}
.btn--block{width:100%}
.btn--white{background:#fff;color:var(--iac-ink)}
.btn--white:hover{background:#fff;color:var(--iac-primary)}

/* === PAGE PREVIEW NAVIGATION (dev only) === */
.pn{background:#1a1a2e;color:#fff;padding:.55rem 1.5rem;display:flex;align-items:center;gap:.45rem;font-size:.7rem;overflow-x:auto;white-space:nowrap;border-bottom:3px solid var(--iac-primary);position:relative;z-index:200}
.pn b{color:var(--iac-primary);text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;margin-right:.4rem}
.pn a{color:#aaa;padding:.32em .8em;border-radius:999px;transition:.2s;font-weight:600}
.pn a:hover,.pn a.is-on{color:#fff;background:rgba(255,255,255,.12)}

/* === TOP BAR === */
.topbar{background:#262626;color:#cfcfcf;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.04)}
.topbar__inner{max-width:var(--maxw);margin:0 auto;padding:.5rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.topbar__contact{display:flex;gap:1.6rem;flex-wrap:wrap;align-items:center}
.topbar__contact a{display:inline-flex;align-items:center;gap:.5em;transition:.2s;color:#cfcfcf}
.topbar__contact a svg{flex:0 0 auto;opacity:.85}
.topbar__contact a:hover,.topbar__social-link:hover{color:#ed7637}
.topbar__social{display:flex;gap:.55rem;align-items:center}
.topbar__social-link{display:inline-flex;align-items:center;gap:.4em;padding:.32em .7em;border-radius:999px;background:rgba(255,255,255,.06);color:#e7e7e7;font-weight:600;font-size:.74rem;letter-spacing:.02em;transition:.2s;border:1px solid rgba(255,255,255,.04)}
.topbar__social-link:hover{background:rgba(237,118,55,.18);border-color:rgba(237,118,55,.4);color:#fff;transform:translateY(-1px)}
.topbar__social-link--google{background:#fff;color:#1f1d1a;border-color:transparent}
.topbar__social-link--google:hover{background:#fff;color:#1a73e8;box-shadow:0 6px 18px rgba(0,0,0,.22)}
.topbar__social-label{line-height:1}

/* === HEADER === */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #ececec;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.header__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:.7rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.logo{display:inline-flex;align-items:center;line-height:0}
.logo__img{height:56px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:1.55rem}
.nav>a:not(.btn),.nav__has>a{font-size:.94rem;font-weight:500;color:#3a3a3a;transition:.2s;white-space:nowrap}
.nav>a:not(.btn):hover,.nav>a.is-active,.nav__has:hover>a,.nav__has>a.is-active{color:#ed7637}
.nav__has{position:relative;display:flex;align-items:center}
.nav__has>a{display:inline-flex;align-items:center;gap:.35em;cursor:pointer}
.nav__caret{font-size:.7em;transition:transform .2s;opacity:.8}
.nav__has:hover .nav__caret{transform:rotate(180deg)}
.nav__drop{position:absolute;top:100%;right:0;left:auto;transform:translateY(8px);min-width:230px;background:#fff;border:1px solid #ececec;border-radius:6px;box-shadow:0 18px 44px rgba(31,29,26,.16);padding:.5rem 0;opacity:0;visibility:hidden;transition:.2s var(--ease);z-index:60}
.nav__has:hover .nav__drop,.nav__has:focus-within .nav__drop{opacity:1;visibility:visible;transform:translateY(0)}
.nav__drop a{display:block;padding:.55em 1.2em;font-size:.86rem;font-weight:500;color:#3a3a3a;white-space:nowrap;transition:.15s}
.nav__drop a:hover{background:#faf4ee;color:#b54608}
.nav__cta{font-size:.84rem;font-weight:600;letter-spacing:.02em;text-transform:none;padding:.85em 1.7em;border-radius:8px;color:#fff!important;margin-left:.4rem;box-shadow:0 4px 12px rgba(181,70,8,.18)}
.nav__cta:hover{color:#fff!important}
.nav__toggle{display:none;background:none;border:none;font-size:1.6rem;line-height:1;cursor:pointer;color:#2f2f2f;padding:.2rem .4rem}

/* === TRUST STRIP (sitewide #2) === */
.trust-strip{background:#fff;border-bottom:1px solid var(--iac-line);padding:.85rem 1.5rem}
.trust-strip__inner{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:1rem}
.trust-item{display:flex;align-items:center;gap:.55rem;font-size:.78rem;color:var(--iac-body)}
.trust-item .ic{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#f8efe5,#f0e4d4);display:flex;align-items:center;justify-content:center;color:var(--iac-primary);font-size:1rem;flex-shrink:0}
.trust-item b{color:var(--iac-ink);font-weight:700;font-size:.82rem;display:block;line-height:1.2}
.trust-item .stars{color:#e8a93b;letter-spacing:.04em;font-size:.78rem;display:inline-block;margin-right:.2rem}
.trust-item .sub{font-size:.68rem;color:#8a857b;display:block;line-height:1.1}

/* === COMMON: PAGE HERO (gradient) === */
.page-hero{position:relative;text-align:center;padding:5rem 1.5rem 4.5rem;background:radial-gradient(120% 90% at 50% 0%,#fbf7f1 0%,#f3ece1 55%,#ece2d2 100%);overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:auto 0 0 0;height:1px;background:linear-gradient(90deg,transparent,var(--iac-line),transparent)}
.page-hero__inner{max-width:780px;margin:0 auto;position:relative;z-index:1}
.page-hero__eyebrow{display:inline-block;font-size:.74rem;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--iac-primary);margin-bottom:1.2rem}
.page-hero h1{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(2.4rem,5.5vw,3.8rem);letter-spacing:-.015em;margin-bottom:1rem}
.page-hero p{font-size:1.02rem;color:var(--iac-body);max-width:580px;margin:0 auto 1.8rem}
.page-hero__actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* === COMMON: SECTION === */
.section{padding:4rem 1.5rem}
.section--alt{background:var(--iac-bg-soft)}
.section__wrap{max-width:var(--maxw);margin:0 auto}
.section__head{text-align:center;max-width:680px;margin:0 auto 3rem}
.section__eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--iac-primary);margin-bottom:.7rem}
.section__title{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.5rem}
.section__sub{font-size:.95rem;color:var(--iac-body)}

/* === FOOTER === */
.footer{background:var(--iac-bg-deep);color:#a59f93;font-size:.85rem}
.footer__inner{max-width:var(--maxw);margin:0 auto;padding:3.5rem 1.5rem;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:2.5rem}
.footer h4{color:#fff;font-size:.95rem;margin-bottom:1rem}
.footer a,.footer span{display:block;color:#a59f93;margin-bottom:.55rem;transition:.2s}
.footer a:hover{color:#fff}
.footer__tag{margin-top:1rem;color:#8d877b}
.footer__bar{border-top:1px solid rgba(255,255,255,.08);text-align:center;padding:1.3rem;font-size:.78rem;color:#8d877b;padding-bottom:5rem}
.footer__social{margin-top:1rem;display:flex;gap:1rem}
.footer__social a{color:#ed7637;margin:0}
.logo__img--footer{height:58px;margin-bottom:1rem}

/* === SITEWIDE #3: FLOATING QUICK QUOTE === */
.qq-btn{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--iac-primary);color:#fff;border:none;padding:1em 1.6em;border-radius:999px;font:700 .8rem "Montserrat",sans-serif;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;box-shadow:0 12px 32px rgba(181,70,8,.4);transition:.3s;display:flex;align-items:center;gap:.55em;z-index:80;animation:qq-pulse 2.5s infinite}
.qq-btn:hover{transform:translateY(-3px);box-shadow:0 16px 42px rgba(181,70,8,.55)}
@keyframes qq-pulse{0%,100%{box-shadow:0 12px 32px rgba(181,70,8,.4),0 0 0 0 rgba(181,70,8,.4)}50%{box-shadow:0 12px 32px rgba(181,70,8,.4),0 0 0 16px rgba(181,70,8,0)}}
.qq-panel{position:fixed;bottom:1.5rem;right:1.5rem;width:320px;background:#fff;border-radius:18px;box-shadow:0 30px 70px rgba(0,0,0,.3);padding:1.5rem;border:1px solid var(--iac-line);display:none;z-index:81}
.qq-panel.is-open{display:block;animation:slideUp .35s var(--ease)}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}}
.qq-panel h4{font-family:"Cormorant Garamond",serif;font-size:1.35rem;margin-bottom:.3rem}
.qq-panel p{font-size:.8rem;color:#8a857b;margin-bottom:1.1rem}
.qq-panel input,.qq-panel select{width:100%;border:1px solid var(--iac-line);border-radius:8px;padding:.65em .9em;font:400 .85rem "Montserrat";margin-bottom:.55rem;outline:none}
.qq-panel input:focus,.qq-panel select:focus{border-color:var(--iac-primary)}
.qq-panel .btn{width:100%;margin-top:.5rem;padding:.75em 1em;font-size:.78rem}
.qq-panel__close{position:absolute;top:.6rem;right:.7rem;background:none;border:none;font-size:1.3rem;cursor:pointer;color:#aaa;line-height:1}

/* === SITEWIDE #5: LIVE VISITOR COUNTER (real-time, polled from /visitors.php) === */
.live-counter{position:fixed;bottom:1.5rem;left:1.5rem;display:flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--iac-line);border-radius:999px;padding:.65rem 1rem .65rem .9rem;box-shadow:0 14px 36px rgba(0,0,0,.12);font-size:.78rem;z-index:75;animation:lvcIn .5s var(--ease)}
@keyframes lvcIn{from{opacity:0;transform:translateY(20px)}}
.live-counter__dot{width:9px;height:9px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:livePulse 1.8s infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.55)}50%{box-shadow:0 0 0 8px rgba(34,197,94,0)}}
.live-counter__text{color:var(--iac-body);line-height:1.2}
.live-counter__text b{color:var(--iac-ink);font-weight:700;font-size:.82rem}
.live-counter__text span{color:#8a857b;font-size:.78rem}
.live-counter__close{background:none;border:none;color:#bcb6aa;cursor:pointer;font-size:1.1rem;line-height:1;margin-left:.25rem;padding:0 .15rem;transition:.2s}
.live-counter__close:hover{color:#5a5550}

/* === SITEWIDE #1: MOBILE CTA BAR === */
.mobile-cta{position:fixed;bottom:0;left:0;right:0;max-width:100vw;background:#fff;border-top:1px solid var(--iac-line);box-shadow:0 -8px 24px rgba(0,0,0,.1);padding:.55rem .5rem;display:none;gap:.4rem;z-index:90;box-sizing:border-box}
.mobile-cta a{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.55em .3em;border-radius:8px;font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:.2s;text-decoration:none}
.mobile-cta a.call{background:var(--iac-primary);color:#fff}
.mobile-cta a.email,.mobile-cta a.sms{background:#fff;border:1px solid var(--iac-line);color:var(--iac-ink)}
.mobile-cta a .ic{font-size:1.1rem}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .footer__inner{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav{display:none}
  .nav.is-open{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:100%;left:0;right:0;background:#fff;padding:1rem 1.25rem 1.4rem;border-bottom:1px solid #ececec;box-shadow:0 12px 30px rgba(0,0,0,.08);gap:.15rem;text-align:center}
  .nav.is-open>a,.nav.is-open .nav__has>a{padding:.75em .5em;font-size:1.02rem;justify-content:center;text-align:center;border-radius:8px}
  .nav.is-open>a:hover,.nav.is-open .nav__has>a:hover{background:#faf4ee}
  /* Dropdown becomes inline accordion on mobile, centered */
  .nav.is-open .nav__has{position:static;flex-direction:column;align-items:stretch;width:100%}
  .nav.is-open .nav__drop{position:static;opacity:1;visibility:visible;transform:none;border:none;box-shadow:none;background:#faf7f2;border-radius:10px;padding:.3rem 0;margin:.2rem 0 .5rem;min-width:0;max-height:0;overflow:hidden;transition:max-height .25s ease,padding .25s ease,margin .25s ease}
  .nav.is-open .nav__has.is-expanded .nav__drop{max-height:600px;padding:.45rem 0}
  .nav.is-open .nav__drop a{text-align:center;padding:.55em 1em;font-size:.92rem}
  .nav.is-open .nav__caret{transition:transform .2s}
  .nav.is-open .nav__has.is-expanded .nav__caret{transform:rotate(180deg)}
  .nav.is-open .nav__cta{margin:.6rem auto 0;display:inline-flex;padding:.95em 2.2em;border-radius:10px;font-size:.86rem;width:auto;max-width:100%}
  .nav__toggle{display:block}
  .logo__img{height:40px}
  .header__inner{padding:.55rem 1rem}
  .trust-strip__inner{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}
  .trust-item{flex-shrink:0}
  .mobile-cta{display:flex}
  .qq-btn{display:none}
  .qq-panel{left:1rem;right:1rem;bottom:5rem;width:auto}
  .live-counter{left:.8rem;right:auto;bottom:5rem}
  body{padding-bottom:64px}
  /* Mobile topbar: stack contact / social rows, center, polish */
  .topbar__inner{padding:.55rem 1rem .65rem;gap:.55rem;flex-direction:column;justify-content:center;align-items:center;text-align:center}
  .topbar__contact{justify-content:center;gap:.9rem .9rem;width:100%;flex-wrap:wrap;row-gap:.25rem}
  .topbar__contact a{font-size:.74rem}
  .topbar__email span{display:inline-block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}
  .topbar__social{justify-content:center;gap:.45rem;width:100%}
  .topbar__social-link{padding:.36em .75em;font-size:.72rem}
}
@media(max-width:480px){
  .logo__img{height:34px}
  .footer__inner{grid-template-columns:1fr}
  .topbar__contact{gap:.55rem .9rem}
  .topbar__email{order:2}
  .topbar__phone{font-weight:600}
}
