/* ============================================
 *  PropDeals — Shared Styles
 * ============================================ */

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* VARIABLES */
:root{
  --bg:#FDFCFC;--bg-alt:#F8F7F7;--text:#201D1D;--text-muted:#656363;
  --border:#E0DEDE;--accent:#201D1D;--accent-light:#CFCECD;
  --code-bg:#F0EFEF;--card-hover:#F5F4F4;--green:#3a7a3a;--green-bg:#e8f5e8;
  --font:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
  --max-w:1200px;
}
[data-theme="dark"]{
  --bg:#111111;--bg-alt:#1a1a1a;--text:#e0e0e0;--text-muted:#999;
  --border:#2a2a2a;--accent:#e0e0e0;--accent-light:#444;
  --code-bg:#222;--card-hover:#1e1e1e;--green:#5cb85c;--green-bg:#1a2e1a;
}

/* BASE */
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s;
}
a{color:inherit;text-decoration:none}
button{font-family:var(--font);cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.anim.visible{opacity:1;transform:translateY(0)}

/* === HEADER === */
header{
  border-bottom:1px solid var(--border);padding:0 2rem;
  position:sticky;top:0;background:var(--bg);z-index:100;transition:background .3s;
}
.header-inner{
  max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;height:60px;
}
.logo{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem}
.logo-icon{display:grid;grid-template-columns:repeat(3,8px);grid-template-rows:repeat(3,8px);gap:2px}
.logo-icon span{background:var(--text-muted);transition:background .3s}
.logo-icon span:nth-child(1),.logo-icon span:nth-child(5),.logo-icon span:nth-child(9){background:var(--text)}
.logo-icon span:nth-child(3),.logo-icon span:nth-child(7){background:var(--accent-light)}
nav{display:flex;align-items:center;gap:1.5rem}
nav a{font-size:.8rem;color:var(--text-muted);transition:color .2s;letter-spacing:.02em}
nav a:hover,nav a.active{color:var(--text)}
.theme-toggle{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);font-size:.85rem;transition:all .2s;
}
.theme-toggle:hover{background:var(--bg-alt)}

/* === SECTION BASICS === */
.section{max-width:var(--max-w);margin:0 auto;padding:4rem 2rem}
.section-header{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border);
}
.section-header h2{font-size:1.1rem;font-weight:600;letter-spacing:-.02em}
.section-header span{font-size:.75rem;color:var(--text-muted)}

/* === HERO === */
.hero{max-width:var(--max-w);margin:0 auto;padding:5rem 2rem 3rem;text-align:center}
.hero h1{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:1rem}
.hero p{font-size:.9rem;color:var(--text-muted);max-width:520px;margin:0 auto 2.5rem;line-height:1.7}
.search-bar{max-width:500px;margin:0 auto 3rem;display:flex;border:1px solid var(--border);transition:border-color .2s}
.search-bar:focus-within{border-color:var(--text-muted)}
.search-bar input{
  flex:1;padding:.75rem 1rem;font-family:var(--font);font-size:.85rem;
  background:transparent;border:none;outline:none;color:var(--text);
}
.search-bar input::placeholder{color:var(--accent-light)}
.search-bar button{
  padding:.75rem 1.25rem;font-size:.8rem;color:var(--text-muted);
  border-left:1px solid var(--border);transition:all .2s;
}
.search-bar button:hover{background:var(--bg-alt);color:var(--text)}
.stats{display:flex;justify-content:center;gap:0;border:1px solid var(--border);max-width:600px;margin:0 auto}
.stat{flex:1;padding:1rem;text-align:center;font-size:.8rem;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat strong{display:block;font-size:1.1rem;font-weight:700;margin-bottom:.15rem}
.stat span{color:var(--text-muted);font-size:.75rem}

/* === DEAL CARDS === */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1px;background:var(--border)}
.card{background:var(--bg);padding:1.5rem;transition:background .2s;display:flex;flex-direction:column;gap:.75rem}
.card:hover{background:var(--card-hover)}
.card-top{display:flex;align-items:flex-start;justify-content:space-between}
.card-firm{font-size:.95rem;font-weight:600;letter-spacing:-.01em}
.card-firm a{transition:color .2s}
.card-firm a:hover{color:var(--text-muted)}
.card-discount{font-size:.85rem;font-weight:700;padding:.2rem .5rem;background:var(--green-bg);color:var(--green);white-space:nowrap}
.card-tp{font-size:.72rem;color:var(--text-muted)}
.tp-inline{display:flex;align-items:center;gap:.35rem}
.stars{color:#d4a017;letter-spacing:1px;font-size:.78rem}
.stars-na{color:var(--accent-light);font-style:italic}
.tp-count{color:var(--accent-light);font-size:.68rem}
.card-desc{font-size:.78rem;color:var(--text-muted);line-height:1.5}
.card-code{display:flex;align-items:center;gap:0;border:1px solid var(--border);margin-top:auto}
.card-code code{flex:1;padding:.5rem .75rem;font-size:.82rem;font-weight:600;background:var(--code-bg);letter-spacing:.05em;font-family:var(--font)}
.card-code code.code-hidden{color:var(--accent-light);font-weight:400;font-size:.78rem;letter-spacing:.02em;user-select:none}
.copy-btn{padding:.5rem .75rem;font-size:.72rem;color:var(--text-muted);border-left:1px solid var(--border);transition:all .15s;letter-spacing:.03em}
.copy-btn:hover{background:var(--bg-alt);color:var(--text)}
.copy-btn.copied{color:var(--green)}
.reveal-btn{font-weight:500;color:var(--text);background:var(--bg-alt)}
.reveal-btn:hover{background:var(--accent);color:var(--bg)}
.card-bottom{display:flex;align-items:center;justify-content:space-between}
.verified{display:flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--green)}
.verified::before{content:"[*]";font-weight:700}
.get-deal{font-size:.78rem;font-weight:500;color:var(--text-muted);transition:color .2s;letter-spacing:.02em;cursor:pointer;font-family:var(--font);text-decoration:none}
.get-deal:hover{color:var(--text)}
.no-results{padding:3rem;text-align:center;font-size:.85rem;color:var(--text-muted);background:var(--bg);grid-column:1/-1}

/* === FEATURES === */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border)}
.feature{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);border-right:1px solid var(--border);display:flex;align-items:flex-start;gap:.75rem;font-size:.85rem}
.feature:nth-child(3n){border-right:none}
.feature:nth-last-child(-n+3){border-bottom:none}
.feature-check{color:var(--text-muted);font-weight:700;font-size:.8rem;flex-shrink:0;margin-top:.1rem}

/* === FAQ === */
.faq-list{border:1px solid var(--border)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;text-align:left;padding:1.25rem 1.5rem;font-size:.85rem;font-weight:500;display:flex;align-items:center;justify-content:space-between;color:var(--text);transition:background .15s;letter-spacing:-.01em}
.faq-q:hover{background:var(--bg-alt)}
.faq-arrow{font-size:.7rem;color:var(--text-muted);transition:transform .25s}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 1.5rem 1.25rem;font-size:.8rem;color:var(--text-muted);line-height:1.7}

/* === NEWSLETTER === */
.newsletter{text-align:center;padding:4rem 2rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-width:var(--max-w);margin:0 auto}
.newsletter h3{font-size:1rem;font-weight:600;margin-bottom:.5rem}
.newsletter p{font-size:.8rem;color:var(--text-muted);margin-bottom:1.5rem}
.newsletter-form{display:flex;max-width:400px;margin:0 auto;border:1px solid var(--border)}
.newsletter-form input{flex:1;padding:.7rem 1rem;font-family:var(--font);font-size:.8rem;background:transparent;border:none;outline:none;color:var(--text)}
.newsletter-form button{padding:.7rem 1.25rem;font-size:.78rem;font-weight:500;border-left:1px solid var(--border);color:var(--text);transition:all .2s}
.newsletter-form button:hover{background:var(--bg-alt)}

/* === FOOTER === */
footer{max-width:var(--max-w);margin:0 auto;padding:2rem;display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}
footer a{transition:color .2s}
footer a:hover{color:var(--text)}
.footer-links{display:flex;gap:1.5rem}

/* === MODAL (Get Deal Interstitial) === */
.modal-overlay{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,.5);z-index:999;display:none;
  align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s;
}
.modal-overlay.active{display:flex;opacity:1}
.modal{
  background:var(--bg);border:1px solid var(--border);max-width:440px;width:90%;
  padding:2.5rem;text-align:center;
}
.modal h3{font-size:1rem;font-weight:600;margin-bottom:.5rem}
.modal .modal-firm{font-size:.85rem;color:var(--text-muted);margin-bottom:1.5rem}
.modal .modal-code{
  display:inline-block;padding:.6rem 1.5rem;background:var(--code-bg);
  font-size:1rem;font-weight:700;letter-spacing:.1em;margin-bottom:1rem;
  border:1px solid var(--border);
}
.modal .modal-copied{font-size:.72rem;color:var(--green);margin-bottom:1.5rem;min-height:1rem}
.modal .modal-redirect{font-size:.78rem;color:var(--text-muted);margin-bottom:1rem}
.modal .modal-redirect strong{color:var(--text)}
.modal .modal-btn{
  display:inline-block;padding:.7rem 2rem;border:1px solid var(--border);
  font-size:.8rem;font-weight:500;transition:all .2s;
}
.modal .modal-btn:hover{background:var(--bg-alt)}
.modal .modal-skip{display:block;margin-top:.75rem;font-size:.72rem;color:var(--text-muted);cursor:pointer;background:none;border:none;font-family:var(--font)}

/* === BLOG CARDS === */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1px;background:var(--border)}
.blog-card{background:var(--bg);padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;transition:background .2s}
.blog-card:hover{background:var(--card-hover)}
.blog-meta{font-size:.72rem;color:var(--text-muted);display:flex;gap:1rem}
.blog-card h3{font-size:.9rem;font-weight:600;line-height:1.4;letter-spacing:-.01em}
.blog-card h3 a{transition:color .2s}
.blog-card h3 a:hover{color:var(--text-muted)}
.blog-excerpt{font-size:.78rem;color:var(--text-muted);line-height:1.5}
.blog-read{font-size:.75rem;color:var(--text-muted);margin-top:auto;padding-top:.5rem;transition:color .2s}
.blog-read:hover{color:var(--text)}

/* === FIRM DETAIL PAGE === */
.firm-hero{max-width:var(--max-w);margin:0 auto;padding:3rem 2rem 2rem}
.firm-back{font-size:.78rem;color:var(--text-muted);margin-bottom:1.5rem;display:inline-block;transition:color .2s}
.firm-back:hover{color:var(--text)}
.firm-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem}
.firm-title-row h1{font-size:clamp(1.4rem,3vw,1.8rem);font-weight:700;letter-spacing:-.03em}
.firm-badges{display:flex;gap:.75rem;flex-wrap:wrap}
.firm-badge{padding:.3rem .6rem;font-size:.75rem;border:1px solid var(--border)}
.firm-badge.discount{background:var(--green-bg);color:var(--green);border-color:var(--green-bg)}
.firm-desc{font-size:.85rem;color:var(--text-muted);line-height:1.8;max-width:700px;margin-bottom:2rem}
.firm-cta{display:flex;gap:0;border:1px solid var(--border);max-width:500px}
.firm-cta code{flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:600;background:var(--code-bg);letter-spacing:.05em;font-family:var(--font)}
.firm-cta button{padding:.75rem 1.25rem;font-size:.8rem;border-left:1px solid var(--border);transition:all .2s;color:var(--text-muted)}
.firm-cta button:hover{background:var(--bg-alt);color:var(--text)}
.firm-details{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:0;border:1px solid var(--border)}
.firm-detail-block{padding:1.5rem;border-bottom:1px solid var(--border)}
.firm-detail-block:nth-child(odd){border-right:1px solid var(--border)}
.firm-detail-block h3{font-size:.82rem;font-weight:600;margin-bottom:.75rem}
.firm-detail-block ul{list-style:none;padding:0}
.firm-detail-block li{font-size:.8rem;color:var(--text-muted);padding:.25rem 0;display:flex;align-items:flex-start;gap:.5rem}
.firm-detail-block li::before{content:"[*]";color:var(--green);font-weight:700;font-size:.7rem;margin-top:.15rem}
.firm-info-table{width:100%;font-size:.8rem;border-collapse:collapse}
.firm-info-table td{padding:.5rem 0;border-bottom:1px solid var(--border)}
.firm-info-table td:first-child{color:var(--text-muted);width:40%}

/* === BLOG LAYOUT WITH SIDEBAR === */
.blog-layout{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 280px;gap:0;padding:0 2rem 4rem}
.blog-main{padding-right:2rem;border-right:1px solid var(--border)}
.blog-main .post-content{max-width:none;margin:0;padding:0 0 2rem}
.blog-sidebar{padding-left:2rem;position:sticky;top:80px;align-self:start;max-height:calc(100vh - 100px);overflow-y:auto}
.sidebar-section{margin-bottom:2rem}
.sidebar-section h4{font-size:.78rem;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);letter-spacing:-.01em}
.sidebar-toc{list-style:none;padding:0}
.sidebar-toc li{padding:.35rem 0}
.sidebar-toc a{font-size:.72rem;color:var(--text-muted);transition:color .2s;display:block;line-height:1.4}
.sidebar-toc a:hover{color:var(--text)}
.sidebar-toc a.active{color:var(--text);font-weight:500}
.sidebar-deal{padding:.75rem;border:1px solid var(--border);margin-bottom:.5rem;transition:background .15s}
.sidebar-deal:hover{background:var(--bg-alt)}
.sidebar-deal-firm{font-size:.75rem;font-weight:600;margin-bottom:.2rem}
.sidebar-deal-discount{font-size:.7rem;color:var(--green);font-weight:600}
.sidebar-deal-link{font-size:.68rem;color:var(--text-muted);display:block;margin-top:.35rem;transition:color .15s}
.sidebar-deal-link:hover{color:var(--text)}
.sidebar-related a{display:block;font-size:.72rem;color:var(--text-muted);padding:.4rem 0;border-bottom:1px solid var(--border);transition:color .15s;line-height:1.4}
.sidebar-related a:last-child{border-bottom:none}
.sidebar-related a:hover{color:var(--text)}

/* === BLOG POST PAGE === */
.post-hero{max-width:700px;margin:0 auto;padding:3rem 2rem 1rem}
.post-hero h1{font-size:clamp(1.3rem,3vw,1.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.3;margin-bottom:.75rem}
.post-meta{font-size:.75rem;color:var(--text-muted);margin-bottom:2rem;display:flex;gap:1rem}
.post-content{max-width:700px;margin:0 auto;padding:0 2rem 4rem}
.post-content h2{font-size:1rem;font-weight:600;margin:2rem 0 .75rem;letter-spacing:-.01em}
.post-content p{font-size:.85rem;color:var(--text-muted);line-height:1.8;margin-bottom:1rem}
.post-content ul{list-style:none;padding:0;margin-bottom:1rem;border:1px solid var(--border)}
.post-content li{padding:.75rem 1rem;font-size:.82rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:.5rem}
.post-content li:last-child{border-bottom:none}
.post-content li::before{content:"—";color:var(--text-muted)}
.post-content blockquote{border-left:2px solid var(--border);padding:.75rem 1rem;margin:1.5rem 0;font-size:.82rem;color:var(--text-muted);font-style:italic}
.post-content a{border-bottom:1px solid var(--border);transition:border-color .2s}
.post-content a:hover{border-color:var(--text)}

/* === BREADCRUMB === */
.breadcrumb{font-size:.72rem;color:var(--text-muted);margin-bottom:1.5rem}
.breadcrumb a{transition:color .2s}
.breadcrumb a:hover{color:var(--text)}
.breadcrumb span{margin:0 .35rem}

/* === RESPONSIVE === */

/* === FIRMS LISTING === */
.firms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1px;background:var(--border)}
.firm-card{background:var(--bg);padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;transition:background .2s}
.firm-card:hover{background:var(--card-hover)}
.firm-card-top{display:flex;align-items:center;justify-content:space-between}
.firm-card h3{font-size:.92rem;font-weight:600}
.firm-card h3 a{transition:color .2s}
.firm-card h3 a:hover{color:var(--text-muted)}
.firm-card-badges{display:flex;gap:.5rem;align-items:center}
.firm-card-badge{font-size:.7rem;padding:.15rem .4rem;border:1px solid var(--border)}
.firm-card-badge.cat{text-transform:uppercase;letter-spacing:.04em}
.firm-card-rating{font-size:.72rem;color:var(--text-muted)}
.firm-card-desc{font-size:.78rem;color:var(--text-muted);line-height:1.5}
.firm-card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.5rem}
.firm-card-accounts{font-size:.72rem;color:var(--text-muted)}

/* === TRUSTPILOT LINK === */
.tp-link{text-decoration:none;transition:opacity .2s}
.tp-link:hover{opacity:.7}

/* === DIRECT DEAL BADGE === */
.card-discount.direct{background:var(--code-bg);color:var(--text);border:1px solid var(--border)}

/* === HIGHLIGHT FLASH (AI deep link) === */
@keyframes highlightFlash{
  0%{background:transparent}
  20%{background:var(--green-bg)}
  100%{background:transparent}
}
.highlight-flash{animation:highlightFlash 3s ease}

/* === AI CHAT WIDGET === */
.chat-widget{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200}
.chat-toggle{
  width:48px;height:48px;border:1px solid var(--border);background:var(--bg);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  font-weight:700;color:var(--text);transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.chat-toggle:hover{background:var(--bg-alt);box-shadow:0 4px 16px rgba(0,0,0,.12)}
.chat-toggle.hidden{display:none}

.chat-panel{
  position:absolute;bottom:0;right:0;width:380px;max-height:520px;
  background:var(--bg);border:1px solid var(--border);display:none;
  flex-direction:column;box-shadow:0 4px 24px rgba(0,0,0,.1);
}
.chat-panel.open{display:flex}

.chat-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 1rem;border-bottom:1px solid var(--border);
}
.chat-title{font-size:.8rem;font-weight:600}
.chat-close{font-size:1.2rem;color:var(--text-muted);transition:color .2s;line-height:1}
.chat-close:hover{color:var(--text)}

.chat-messages{
  flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;
  max-height:360px;min-height:200px;
}
.chat-msg{max-width:92%}
.chat-msg.user{align-self:flex-end}
.chat-msg.bot{align-self:flex-start}
.chat-msg-text{
  font-size:.78rem;line-height:1.6;padding:.6rem .85rem;
  border:1px solid var(--border);
}
.chat-msg.user .chat-msg-text{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.chat-msg.bot .chat-msg-text{background:var(--bg-alt)}

/* Typing animation */
.chat-msg.typing .chat-msg-text{display:flex;gap:.25rem;padding:.8rem 1rem}
.dot{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:dotPulse .8s ease-in-out infinite}
.dot:nth-child(2){animation-delay:.15s}
.dot:nth-child(3){animation-delay:.3s}
@keyframes dotPulse{0%,80%,100%{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}

/* Chat sources */
.chat-sources{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}
.chat-source-link{
  display:flex;gap:.5rem;align-items:center;font-size:.7rem;
  padding:.35rem .6rem;border:1px solid var(--border);transition:all .15s;
  text-decoration:none;color:var(--text);cursor:pointer;
}
.chat-source-link:hover{background:var(--bg-alt)}
.chat-source-firm{font-weight:600;font-size:.68rem}
.chat-source-section{color:var(--text-muted);font-size:.65rem}

.chat-input-area{display:flex;border-top:1px solid var(--border)}
.chat-input-area input{
  flex:1;padding:.7rem 1rem;font-family:var(--font);font-size:.8rem;
  background:transparent;border:none;outline:none;color:var(--text);
}
.chat-input-area input::placeholder{color:var(--accent-light)}
.chat-input-area button{
  padding:.7rem 1rem;font-size:.75rem;font-weight:500;
  border-left:1px solid var(--border);color:var(--text-muted);transition:all .2s;
}
.chat-input-area button:hover{background:var(--bg-alt);color:var(--text)}

/* === RESPONSIVE === */
@media(max-width:768px){
  .hero{padding:3rem 1.5rem 2rem}
  .hero h1{font-size:1.5rem}
  .stats{flex-direction:column}
  .stat{border-right:none;border-bottom:1px solid var(--border)}
  .stat:last-child{border-bottom:none}
  .grid,.blog-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .feature{border-right:none !important}
  .feature:last-child{border-bottom:none}
  .section{padding:3rem 1.5rem}
  nav{gap:.75rem}
  nav a{font-size:.72rem}
  footer{flex-direction:column;gap:1rem;text-align:center}
  .header-inner{height:50px}
  .search-bar{flex-direction:column}
  .search-bar button{border-left:none;border-top:1px solid var(--border)}
  .firm-title-row{flex-direction:column;gap:.75rem}
  .firm-details{grid-template-columns:1fr}
  .firm-detail-block{border-right:none !important}
  .firm-cta{flex-direction:column}
  .firm-cta button{border-left:none;border-top:1px solid var(--border)}
  .chat-panel{width:calc(100vw - 2rem);right:-.5rem}
  .chat-widget{bottom:1rem;right:1rem}
  .blog-layout{grid-template-columns:1fr;padding:0 1.5rem 3rem}
  .blog-main{padding-right:0;border-right:none}
  .blog-sidebar{position:static;padding-left:0;border-top:1px solid var(--border);padding-top:2rem;max-height:none}
}
