/* ===========================
   public.css — Public pages (GG:CHAT)
   Used by: landing.html, pricing_public.html,
            login_public.html, register_public.html,
            faq_public.html, forgot_password.html,
            reset_password.html
   =========================== */

/* --- Shared base reset and variables --- */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#244fa2;
  --brand-hover:#1d3e82;
  --brand-light:#eef3ff;
  --fg:#0f172a;
  --fg-secondary:#475569;
  --bg:#f8fafc;
  --surface:#ffffff;
  --border:#e2e8f0;
  --radius:12px;
  --radius-sm:8px;
}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);color:var(--fg);line-height:1.6;-webkit-font-smoothing:antialiased
}
.container{max-width:1100px;margin:0 auto;padding:0 24px}

/* --- Shared nav (landing, pricing_public, login_public, register_public, faq_public) --- */
nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;max-width:1100px;margin:0 auto;
  position:sticky;top:0;z-index:50;
  background:rgba(248,250,252,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
}
.nav-logo{font-weight:700;font-size:1.1rem;display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--fg)}
.nav-logo img{height:24px;width:auto}
.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{display:inline-flex;text-decoration:none;font-size:.875rem;font-weight:500;padding:8px 16px;border-radius:var(--radius-sm);transition:all .15s;color:var(--fg-secondary)}
.nav-links a:hover{background:var(--border);color:var(--fg)}
.nav-links a.btn-primary{background:var(--brand);color:#fff}
.nav-links a.btn-primary:hover{background:var(--brand-hover)}

/* --- Shared footer --- */
footer{text-align:center;padding:24px 0 32px;border-top:1px solid var(--border);font-size:.8rem;color:var(--fg-secondary)}

/* --- Shared mobile nav --- */
.nav-mobile-right{display:none;align-items:center;gap:6px}
.nav-mobile-login,.nav-mobile-support{text-decoration:none;font-size:.875rem;font-weight:600;padding:8px 12px;border-radius:var(--radius-sm);transition:all .15s}
.nav-mobile-login{color:var(--brand);background:var(--brand-light)}
.nav-mobile-login:hover{background:var(--brand)}
.nav-mobile-support{font-size:1.15rem;padding:8px 10px;color:var(--fg-secondary)}
.nav-mobile-support:hover{background:var(--border);color:var(--fg)}
.nav-hamburger{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);color:var(--fg);display:none;align-items:center;justify-content:center;line-height:1}
.nav-hamburger:hover{background:var(--border)}
.nav-mobile-menu{display:flex;position:fixed;top:68px;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);padding:12px 24px 16px;flex-direction:column;gap:6px;z-index:49;box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-8px);opacity:0;visibility:hidden;transition:all .2s;pointer-events:none}
.nav-mobile-menu.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
.nav-mobile-menu a{text-decoration:none;font-size:.875rem;font-weight:500;padding:10px 16px;border-radius:var(--radius-sm);color:var(--fg-secondary);display:flex;align-items:center;gap:8px}
.nav-mobile-menu a:hover{background:var(--border);color:var(--fg)}
.nav-mobile-menu a.btn-primary{background:var(--brand);color:#fff;justify-content:center;margin-top:4px}
.nav-mobile-menu a.btn-primary:hover{background:var(--brand-hover)}

/* --- Shared animations --- */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.anim-fade{animation:fadeUp .5s ease-out both}
.anim-d1{animation-delay:.05s}
.anim-d2{animation-delay:.1s}
.anim-d3{animation-delay:.15s}
.anim-d4{animation-delay:.2s}
.anim-d5{animation-delay:.25s}
.anim-d6{animation-delay:.3s}

/* --- Shared responsive --- */
@media(max-width:640px){
  .nav-links{display:none}
  .nav-mobile-right{display:flex}
  .nav-hamburger{display:flex}
}

/* ======= LANDING PAGE (landing.html) ======= */
.hero{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;
  padding:72px 0 48px;position:relative;overflow:hidden;text-align:left
}
.hero::before{
  content:'';position:absolute;top:-50%;left:50%;width:800px;height:800px;
  background:radial-gradient(circle,rgba(36,79,162,.06) 0%,transparent 70%);
  transform:translate(-50%,0);pointer-events:none
}
.hero h1{
  font-size:clamp(2rem,5vw,3.2rem);font-weight:700;line-height:1.15;
  background:linear-gradient(135deg,var(--fg) 0%,var(--brand) 100%);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px
}
.hero h1 .star {
  color: #22C55E;
  -webkit-text-fill-color: #22C55E;
  font-size: 0.6em;
  vertical-align: super;
  margin-left: 0.2em;
}
.hero-content{display:flex;flex-direction:column;gap:16px}
.hero-content p{
  font-size:clamp(1rem,2vw,1.15rem);color:var(--fg-secondary);max-width:500px;margin:0
}
.hero-btns{display:flex;gap:12px;justify-content:flex-start;flex-wrap:wrap;margin-top:24px}
.hero-btns a{
  display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius-sm);
  font-size:.95rem;font-weight:600;text-decoration:none;transition:all .15s
}
.hero-btns .primary{background:var(--brand);color:#fff}
.hero-btns .primary:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(36,79,162,.3)}
.hero-btns .secondary{background:var(--surface);color:var(--fg);border:1px solid var(--border)}
.hero-btns .secondary:hover{background:var(--border)}
.hero-btns .consultation{background:var(--surface);color:var(--brand);border:1px solid var(--brand)}
.hero-btns .consultation:hover{background:var(--brand-light)}
.hero-visual{display:flex;justify-content:flex-end;align-items:center}
.preview{
  width:100%;max-width:420px;position:relative
}
.preview-window{
  background:var(--surface);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.06),0 1px 4px rgba(0,0,0,.04);
  border:1px solid var(--border);
}
.preview-header{
  background:var(--brand);color:#fff;padding:14px 16px;display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:600
}
.preview-header .h-dots{display:flex;gap:3px;margin-left:auto}
.preview-header .h-dots span{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.4)}
.preview-body{position:relative;height:180px;overflow:hidden}
.p-msg{max-width:75%;padding:10px 14px;border-radius:14px;font-size:.875rem;line-height:1.4}
.p-msg.in{background:#f1f5f9;align-self:flex-start;border-bottom-left-radius:4px}
.p-msg.out{background:var(--brand);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.p-msg.bot{background:#f1f5f9;align-self:flex-start;border-bottom-left-radius:4px}
.p-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}
.p-input input{flex:1;border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:.85rem;outline:none;background:#fff}
.p-input input:focus{border-color:var(--brand);box-shadow:0 0 0 2px rgba(36,79,162,.1)}
.p-input button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:.85rem;cursor:pointer;font-weight:600}
.features{
  padding:80px 0;
  position:relative
}
.features::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,var(--bg) 0%,rgba(36,79,162,.03) 50%,var(--bg) 100%);
  pointer-events:none
}
.features h2{
  text-align:center;font-size:clamp(1.3rem,3vw,1.8rem);font-weight:700;
  margin-bottom:8px;position:relative
}
.features .subtitle{
  text-align:center;color:var(--fg-secondary);font-size:.95rem;
  margin-bottom:44px;position:relative
}
.grid-3{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;position:relative
}
.grid-3 .card{
  background:var(--surface);border-radius:var(--radius);padding:28px 24px;
  border:1px solid var(--border);transition:all .3s cubic-bezier(.25,.46,.45,.94);
  position:relative;overflow:hidden
}
.grid-3 .card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--brand);opacity:0;transition:opacity .3s
}
.grid-3 .card:hover{
  border-color:transparent;transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(15,23,42,.08),0 2px 8px rgba(15,23,42,.04)
}
.grid-3 .card:hover::before{opacity:1}
.grid-3 .card .icon{
  width:48px;height:48px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:16px;transition:transform .3s,box-shadow .3s
}
.grid-3 .card:hover .icon{
  transform:scale(1.08);box-shadow:0 4px 16px rgba(36,79,162,.15)
}
.grid-3 .card h3{font-size:1.05rem;font-weight:650;margin-bottom:8px;color:var(--fg)}
.grid-3 .card p{
  font-size:.875rem;color:var(--fg-secondary);line-height:1.6;margin:0
}
.icon-ai{background:#eef3ff;color:var(--brand)}
.icon-tg{background:#e0f2fe;color:#0284c7}
.icon-chat{background:#f0fdf4;color:#16a34a}
.icon-kb{background:#fef3c7;color:#d97706}
.icon-custom{background:#f5f3ff;color:#7c3aed}
.icon-leads{background:#fce7f3;color:#db2777}
.cta{
  text-align:center;padding:48px 0 64px;
  position:relative;overflow:hidden
}
.cta::before{
  content:'';position:absolute;bottom:-50%;left:50%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(36,79,162,.05) 0%,transparent 70%);
  transform:translate(-50%,0);pointer-events:none
}
.cta h2{font-size:1.5rem;font-weight:700;margin-bottom:12px}
.cta p{color:var(--fg-secondary);margin-bottom:24px}
.cta a{
  display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--radius-sm);
  background:var(--brand);color:#fff;font-size:1rem;font-weight:600;text-decoration:none;transition:all .15s
}
.cta a:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 4px 16px rgba(36,79,162,.3)}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:1}}
.typing span{animation:blink 1.2s infinite;font-size:.7rem}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}

/* --- Preview cycling dialogs --- */
.dc{position:absolute;left:16px;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;pointer-events:none;animation:showCycle 18s infinite}
.dc[data-cycle="1"]{animation-delay:0s}
.dc[data-cycle="2"]{animation-delay:6s}
.dc[data-cycle="3"]{animation-delay:12s}
@keyframes showCycle{
  0%,2%{opacity:0}
  4%,31%{opacity:1}
  33%,100%{opacity:0}
}
@keyframes msgCycle{
  0%{opacity:0;transform:translateY(8px)}
  2.2%{opacity:1;transform:translateY(0)}
  17.2%{opacity:1;transform:translateY(0)}
  19.4%{opacity:0;transform:translateY(0)}
  100%{opacity:0;transform:translateY(0)}
}
.p-msg.cy{opacity:0;animation:msgCycle 18s infinite}
@media(max-width:768px){
  .hero{grid-template-columns:1fr;gap:32px;padding:48px 0 32px;text-align:center}
  .hero-content{align-items:center}
  .hero-content p{max-width:100%}
  .hero-btns{justify-content:center}
  .hero-visual{justify-content:center}
  .preview{max-width:380px}
}
@media(max-width:640px){
  .hero{padding:40px 0 24px}
  .features{padding:40px 0}
}

/* ======= PRICING PUBLIC (pricing_public.html) ======= */
.pricing{padding:48px 0 32px;position:relative;overflow:hidden}
.pricing::before{
  content:'';position:absolute;top:-50%;left:50%;width:800px;height:800px;
  background:radial-gradient(circle,rgba(36,79,162,.05) 0%,transparent 70%);
  transform:translate(-50%,0);pointer-events:none
}
.pricing h1{text-align:center;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;margin-bottom:8px}
.pricing .subtitle{text-align:center;color:var(--fg-secondary);margin-bottom:36px;font-size:1rem}
.enterprise{
  text-align:center;padding:40px 0 64px;position:relative;overflow:hidden
}
.enterprise::before{
  content:'';position:absolute;bottom:-50%;left:50%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(36,79,162,.05) 0%,transparent 70%);
  transform:translate(-50%,0);pointer-events:none
}
.enterprise h2{font-size:1.4rem;font-weight:700;margin-bottom:8px}
.enterprise p{color:var(--fg-secondary);margin-bottom:20px;max-width:500px;margin-left:auto;margin-right:auto}
.enterprise a{
  display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--radius-sm);
  background:var(--brand);color:#fff;font-size:1rem;font-weight:600;text-decoration:none;transition:all .15s
}
.enterprise a:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 4px 16px rgba(36,79,162,.3)}
@media(max-width:640px){
  .pricing{padding:32px 0 16px}
}

/* ======= PRICING CARDS (shared with pricing_public.html) ======= */
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; align-items: stretch; }
.p-card {
  background: var(--surface); border-radius: 12px; overflow: hidden;
  border: 1px solid var(--border); transition: all .2s; display: flex; flex-direction: column;
  position: relative;
}
.p-card:hover { box-shadow: 0 4px 20px rgba(0, 0, 0, .06); }
.p-card.popular { border-color: #22c55e; border-width: 2px; }
.p-card .popular-badge {
  position: absolute; top: 12px; right: 12px;
  background: #22c55e; color: #fff; font-size: .7rem; font-weight: 700;
  padding: 4px 10px; border-radius: 12px; text-transform: uppercase; letter-spacing: .5px;
}
.p-card-head { padding: 28px 24px 0; text-align: center; }
.p-card-head .emoji { font-size: 2rem; margin-bottom: 4px; }
.p-card-head .name { font-size: .85rem; font-weight: 600; color: var(--fg-secondary); text-transform: uppercase; letter-spacing: 1px; }
.p-card-head .price { font-size: 2.5rem; font-weight: 700; margin: 12px 0 4px; }
.p-card-head .price small { font-size: .875rem; font-weight: 400; color: var(--fg-secondary); }
.p-card-head .period { font-size: .8rem; color: var(--fg-secondary); margin-bottom: 16px; }
.p-card-head .desc { font-size: .875rem; color: var(--fg-secondary); margin-bottom: 20px; }
.p-card-body { padding: 0 24px 24px; flex: 1; }
.p-card-body ul { list-style: none; padding: 0; margin: 0; }
.p-card-body li { display: flex; align-items: flex-start; gap: 8px; padding: 5px 0; font-size: .85rem; }
.p-card-body li .icon { flex-shrink: 0; width: 18px; text-align: center; font-size: .75rem; }
.p-card-body li .icon.ok { color: #22c55e; }
.p-card-body li .icon.no { color: #94a3b8; }
.p-card-body li .label { color: var(--fg-secondary); }
.p-card-foot { padding: 0 24px 24px; margin-top: auto; }
.p-card-foot .primary {
  display: block; text-align: center; padding: 12px; border-radius: 8px;
  font-size: .9rem; font-weight: 600; text-decoration: none; transition: all .15s;
  background: var(--brand); color: #fff;
}
.p-card-foot .primary:hover { background: var(--brand-hover); }
.pricing .subtitle{text-align:center;color:var(--fg-secondary);margin-bottom:36px;font-size:1rem}

/* ======= AUTH PAGES (login_public, register_public, forgot_password, reset_password) ======= */
.page-wrap{display:flex;flex-direction:column;min-height:100vh}
.auth-section{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px}
.auth-card{
  background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);
  padding:40px 32px;width:100%;max-width:400px;text-align:center;
  box-shadow:0 4px 24px rgba(0,0,0,.04)
}
.auth-card .logo{font-size:1.8rem;font-weight:800;color:var(--brand);margin-bottom:4px}
.auth-card h1{font-size:1.2rem;font-weight:600;margin-bottom:4px}
.auth-card .subtitle{color:var(--fg-secondary);font-size:.9rem;margin-bottom:24px}
.auth-card .field{text-align:left;margin-bottom:16px}
.auth-card .field label{display:block;font-size:.85rem;font-weight:500;margin-bottom:4px;color:var(--fg)}
.auth-card .field input{
  width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;
  font-size:.9rem;outline:none;transition:border-color .15s;background:#fff
}
.auth-card .field input:focus{border-color:var(--brand);box-shadow:0 0 0 2px rgba(36,79,162,.1)}
.auth-card .field input::placeholder{color:#94a3b8}
.auth-card .error{
  background:#fef2f2;border:1px solid #fecaca;color:#dc2626;
  padding:10px 14px;border-radius:8px;font-size:.85rem;margin-bottom:16px
}
.auth-card .success{
  background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;
  padding:10px 14px;border-radius:8px;font-size:.85rem;margin-bottom:16px
}
.auth-card .btn{
  display:block;width:100%;padding:12px;border:none;border-radius:8px;
  font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none
}
.auth-card .btn-primary{background:var(--brand);color:#fff}
.auth-card .btn-primary:hover{background:var(--brand-hover)}
.auth-card .link{color:var(--fg-secondary);font-size:.85rem;margin-top:16px}
.auth-card .link a{color:var(--brand);text-decoration:none;font-weight:500}
.auth-card .link a:hover{text-decoration:underline}
footer{margin-top:auto}
@media(max-width:640px){
  .auth-section{padding:24px 16px}
  .auth-card{padding:28px 20px}
}

/* ======= FAQ PUBLIC (faq_public.html) ======= */
.faq-section{padding:48px 0;position:relative;overflow:hidden}
.faq-section::before{
  content:'';position:absolute;top:-50%;left:50%;width:800px;height:800px;
  background:radial-gradient(circle,rgba(36,79,162,.05) 0%,transparent 70%);
  transform:translate(-50%,0);pointer-events:none
}
.faq-section h1{text-align:center;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;margin-bottom:8px}
.faq-section .subtitle{text-align:center;color:var(--fg-secondary);margin-bottom:36px;font-size:1rem}
.faq-section .card{
  background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);
  margin-bottom:16px;overflow:hidden
}
.faq-section .card-header{
  padding:20px 24px 16px;border-bottom:1px solid var(--border);
  background:transparent
}
.faq-section .card-header h3.card-title{
  font-size:1.05rem;font-weight:600;color:var(--fg);margin:0
}
.faq-section .card-body{padding:16px 24px 24px;font-size:.9rem;color:var(--fg)}
.faq-section .card-body .text-secondary{color:var(--fg-secondary)!important}
.faq-section .card-body code.badge{
  background:#e2e8f0!important;color:#0f172a!important;
  font-size:.8rem;padding:2px 8px;border-radius:4px;font-family:monospace
}
.faq-section .card-body ul, .faq-section .card-body ol{padding-left:20px}
.faq-section .card-body li{margin-bottom:4px;line-height:1.5}
.faq-section .card-body strong{font-weight:600}
.faq-section .card-body .btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .15s;cursor:pointer}
.faq-section .card-body .btn-primary{background:var(--brand);color:#fff;border:none}
.faq-section .card-body .btn-primary:hover{background:var(--brand-hover)}
.faq-section .card-body .btn-sm{padding:6px 14px;font-size:.8rem}
.faq-section .card-body .avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.faq-section .card-body .avatar-lg{width:44px;height:44px;font-size:1.1rem}
.faq-section .card-body .form-control{
  width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;
  font-size:.85rem;font-family:monospace;background:#0f172a!important;color:#22c55e!important;
  resize:none;outline:none;cursor:pointer
}
.faq-section .card-body .form-label{font-size:.8rem;color:var(--fg-secondary);margin-bottom:6px;display:block}
.faq-section .card-body .alert{
  padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:8px;font-size:.85rem
}
.faq-section .card-body .alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.faq-section .card-body .bg-dark{background:#0f172a!important;color:#22c55e!important}
.faq-section .card-body .font-monospace{font-family:monospace!important}
.faq-section .card-body .text-success{color:#22c55e!important}
.faq-section .card-body .text-white{color:#fff!important}
.faq-section .card-body .bg-secondary{background:#94a3b8!important}
.faq-section .card-body .bg-light{background:#f1f5f9!important}
.faq-section .card-body .bg-primary{background:var(--brand)!important}
.faq-section .card-body .text-primary{color:var(--brand)!important}
.faq-section .accordion-item{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden}
.faq-section .accordion-item:not(:first-of-type){border-top:1px solid var(--border)}
.faq-section .accordion-header{margin:0}
.faq-section .accordion-button{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;background:var(--surface);border:none;cursor:pointer;
  font-size:.9rem;font-weight:500;color:var(--fg);text-align:left;
  transition:all .15s
}
.faq-section .accordion-button:hover{background:#f8fafc}
.faq-section .accordion-button::after{
  content:'▼';font-size:.7rem;color:var(--fg-secondary);transition:transform .2s;margin-left:8px
}
.faq-section .accordion-button.collapsed::after{transform:rotate(-90deg)}
.faq-section .accordion-collapse{display:none}
.faq-section .accordion-collapse.show{display:block}
.faq-section .accordion-body{padding:0 16px 14px;font-size:.85rem;color:var(--fg-secondary)}
.faq-section .accordion-body ul{padding-left:18px}
.faq-section .accordion-body li{margin-bottom:4px}
.faq-section .step{display:flex;gap:12px;margin-bottom:20px}
.faq-section .step:last-child{margin-bottom:0}
.faq-section .step-num{
  width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-weight:700;font-size:1.1rem
}
@media(max-width:640px){
  .faq-section{padding:32px 0}
}

/* ======= UTILITY CLASSES for inline-style replacement ======= */
.sr-only {
  position: absolute;
  left: -9999px;
  top: -9999px;
  height: 0;
  opacity: 0;
  overflow: hidden;
  width: 1px;
}
.min-vh-80 { min-height: 80vh; }

/* --- Site footer --- */
.site-footer {
  text-align: center;
  padding: 24px 24px 32px;
  border-top: 1px solid var(--tblr-border-color, #e2e8f0);
  font-size: .8rem;
  color: var(--tblr-secondary, #475569);
  line-height: 1.6;
}
.site-footer a {
  color: var(--tblr-primary, #244fa2);
  text-decoration: none;
}
.site-footer a:hover {
  text-decoration: underline;
}

/* --- Cookie banner --- */
.cookie-banner {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  z-index: 99999;
  width: calc(100% - 32px);
  max-width: 720px;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 20px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.08);
  display: flex;
  align-items: center;
  gap: 12px;
  opacity: 0;
  transition: opacity 0.35s ease, transform 0.35s ease;
  pointer-events: none;
}
.cookie-banner--show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.cookie-banner__text {
  flex: 1;
  font-size: 0.8rem;
  color: var(--fg-secondary);
  margin: 0;
  line-height: 1.5;
}
.cookie-banner__text a {
  color: var(--brand);
  text-decoration: none;
  font-weight: 500;
}
.cookie-banner__text a:hover {
  text-decoration: underline;
}
.cookie-banner__btn {
  flex-shrink: 0;
  padding: 6px 20px;
  border: none;
  border-radius: 8px;
  background: var(--brand);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}
.cookie-banner__btn:hover {
  background: var(--brand-hover);
}
@media (max-width: 640px) {
  .cookie-banner {
    bottom: 12px;
    padding: 12px 16px;
    flex-direction: column;
    gap: 10px;
    border-radius: 10px;
  }
  .cookie-banner__btn {
    width: 100%;
    text-align: center;
  }
}\n