/* ===== Bento Grid Q&A theme redesign ===== */
:root {
  --color-primary:   #6c5ce7;  /* Bento purple: primary actions, active UI, focus */
  --color-header:    #111827;  /* deep ink: header, footer, strong text */
  --color-link:      #4f46e5;  /* readable bento links */
  --color-text:      #182033;  /* main text */
  --color-bg:        #f7f3ea;  /* warm bento canvas */
  --color-accent:    #ff7a59;  /* warm CTA accent */
  --color-offer-btn: #ff7a59;  /* offer CTA coral */
  --color-nick:      #0f9f6e;  /* usernames / people */
  --color-answers:   #0f9f6e;  /* answers / positive counters */

  --color-surface:   rgba(255,255,255,.92);
  --color-surface-2: rgba(255,255,255,.72);
  --color-surface-3: #fbf7ef;
  --color-border:    rgba(24,32,51,.10);
  --color-muted:     #697086;
  --color-success:   #0f9f6e;
  --color-warning:   #f5a524;
  --color-error:     #e5484d;

  --metro-cyan:      #5dd6ff;
  --metro-green:     #7bd88f;
  --metro-purple:    #a78bfa;
  --metro-red:       #ff8b8b;
  --metro-yellow:    #ffe08a;

  --glass-line:      rgba(255,255,255,.65);
  --glass-line-soft: rgba(255,255,255,.48);
  --glass-shadow:    0 18px 48px rgba(24,32,51,.12);
  --glass-shadow-sm: 0 10px 28px rgba(24,32,51,.08);
  --glass-inset:     none;
  --shadow-sm:       var(--glass-shadow-sm);
  --shadow-md:       var(--glass-shadow);
  --radius-sm:       14px;
  --radius-md:       22px;
  --radius-lg:       30px;
  --blur-glass:      none;
}

/* ===== Reset & Base ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { touch-action: manipulation; min-height: 100%; }
body {
  min-height: 100vh;
  overflow-x: hidden;
  font-family: "Segoe UI", -apple-system, BlinkMacSystemFont, Arial, sans-serif;
  background:
    linear-gradient(90deg, rgba(0,120,212,.035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,120,212,.035) 1px, transparent 1px),
    var(--color-bg);
  background-size: 72px 72px, 72px 72px, auto;
  color: var(--color-text);
  line-height: 1.58;
  font-size: 15px;
  -webkit-tap-highlight-color: transparent;
}
body::before,
body::after { display: none; }
a { color: var(--color-link); text-decoration: none; transition: color .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease, transform .12s ease, opacity .12s ease; }
a:hover { color: var(--color-primary); text-decoration: none; }
ul { list-style: none; }
button, input, textarea, select { font: inherit; }
::selection { background: rgba(0,120,212,.22); color: #111; }

/* ===== Layout ===== */
.container { max-width: 1080px; margin: 0 auto; padding: 0 20px; }
.layout { display: grid; grid-template-columns: minmax(0,1fr) 272px; gap: 24px; padding: 28px 0; align-items: start; }
.main-col, .side-col, .layout > aside { min-width: 0; }

.metro-card,
.question-item,
.cat-list li,
.feed-item,
.question-card,
.answer-card,
.ask-block,
.similar-item,
.profile-tile,

.metro-card,
.question-item,
.cat-list li,
.feed-item,
.question-card,
.answer-card,
.ask-block,
.similar-item,
.profile-tile,

@media (max-width: 700px) {
  .container { padding: 0 14px; }
  .layout { grid-template-columns: 1fr; gap: 18px; padding: 20px 0; }
}

/* ===== Header ===== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  overflow: hidden;
  background: var(--color-header);
  padding: 0;
  border-bottom: 4px solid var(--color-primary);
  box-shadow: 0 4px 18px rgba(0,0,0,.18);
}
.site-header::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent 0 58%, rgba(0,120,212,.28) 58% 72%, transparent 72%),
    linear-gradient(135deg, rgba(255,255,255,.06), transparent 44%);
}
.site-header::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  width: 180px;
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  opacity: .22;
  clip-path: polygon(26% 0, 100% 0, 100% 100%, 0 100%);
}
.site-header .container { position: relative; z-index: 1; min-height: 72px; }
.logo {
  color: #fff;
  font-size: 1.28rem;
  font-weight: 700;
  letter-spacing: .2px;
  text-transform: none;
}
.logo:hover { color: #fff; opacity: .92; }
.logo-img img {
  width: 160px;
  height: 50px;
  object-fit: contain;
  object-position: left center;
  display: block;
  filter: none;
}
@media (max-width: 500px) {
  .site-header .container { min-height: 58px; }
  .logo-img img { width: 110px; height: 36px; }
}

/* ===== Titles ===== */
.section-title, .answers-title, .similar-title {
  position: relative;
  font-size: .92rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-header);
  margin-bottom: 12px;
  padding: 10px 12px;
  background: var(--color-surface);
  border-left: 5px solid var(--color-primary);
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}
.section-title::before, .answers-title::before, .similar-title::before { display: none; }
.page-title {
  font-size: 1.72rem;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--color-header);
  line-height: 1.22;
  letter-spacing: -.02em;
}
.breadcrumb { font-size: .86rem; color: var(--color-muted); margin-bottom: 18px; }
.breadcrumb a { color: var(--color-link); font-weight: 600; }

/* ===== Question list as Bento tiles ===== */
.question-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}
.question-item {
  position: relative;
  overflow: hidden;
  min-height: 138px;
  padding: 16px 16px 14px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  border-left: 6px solid var(--color-primary);
  transition: box-shadow .14s ease, transform .14s ease, border-color .14s ease, background .14s ease;
}
.question-item:nth-child(4n+2) { border-left-color: var(--metro-green); }
.question-item:nth-child(4n+3) { border-left-color: var(--metro-purple); }
.question-item:nth-child(4n+4) { border-left-color: var(--color-offer-btn); }
.question-item::before {
  content: '';
  position: absolute;
  right: -32px;
  bottom: -32px;
  width: 98px;
  height: 98px;
  background: var(--color-primary);
  opacity: .08;
}
.question-item::after {
  content: '';
  position: absolute;
  right: 16px;
  top: 16px;
  width: 20px;
  height: 20px;
  border: 4px solid rgba(0,120,212,.12);
}
.question-item:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--color-primary); background: #fff; }
.qi-avatar { flex-shrink: 0; position: relative; z-index: 1; }
.qi-avatar img { width: 42px; height: 42px; border-radius: 2px; object-fit: cover; display: block; border: 1px solid var(--color-border); box-shadow: none; }
.qi-avatar-ph, .avatar-placeholder, .q-author-ph, .feed-avatar-ph {
  background: var(--color-primary);
  border: 1px solid var(--color-primary);
  color: #fff;
  box-shadow: none;
}
.qi-avatar-ph { width: 42px; height: 42px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.08rem; }
.qi-body { flex: 1; min-width: 0; position: relative; z-index: 1; }
.question-link { font-size: 1rem; font-weight: 700; color: var(--color-header); display: block; margin-bottom: 9px; line-height: 1.38; padding-right: 20px; }
.question-link:hover { color: var(--color-primary); }
.question-meta { display: flex; align-items: center; gap: 7px; font-size: .77rem; color: var(--color-muted); flex-wrap: wrap; }
.qi-nick { color: var(--color-nick); font-weight: 700; }
.qi-time { color: var(--color-muted); }
.cat-tag {
  background: var(--color-surface-2);
  color: var(--color-link);
  border: 1px solid var(--color-border);
  border-radius: 2px;
  padding: 2px 7px;
  font-size: .74rem;
  font-weight: 700;
}
.cat-tag:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.ans-badge { color: var(--color-answers); font-weight: 700; }

/* ===== Sidebar tiles ===== */
.sidebar { min-width: 0; }
.cat-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.cat-list li {
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 12px 12px 12px 14px;
  border-left: 5px solid var(--color-primary);
  transition: transform .14s ease, box-shadow .14s ease, background .14s ease;
}
.cat-list li:nth-child(3n+2) { border-left-color: var(--metro-green); }
.cat-list li:nth-child(3n+3) { border-left-color: var(--metro-purple); }
.cat-list li:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); background: #fff; }
.cat-list li a { color: var(--color-header); font-weight: 700; }
.cat-list li a:hover { color: var(--color-primary); }
.cat-count {
  background: var(--color-primary);
  color: #fff;
  border-radius: 2px;
  padding: 4px 9px;
  font-size: .76rem;
  font-weight: 700;
  min-width: 28px;
  text-align: center;
  display: inline-block;
}

/* ===== Question page ===== */
.question-text { font-size: 1.28rem; font-weight: 700; color: var(--color-header); margin: 0; line-height: 1.48; }
.question-card {
  position: relative;
  overflow: hidden;
  padding: 26px 28px;
  margin-bottom: 26px;
  border-top: 6px solid var(--color-primary);
}
.question-card::before {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  width: 96px;
  height: 96px;
  background: linear-gradient(135deg, rgba(0,120,212,.12), rgba(0,164,239,.08));
  clip-path: polygon(100% 0, 100% 100%, 0 0);
}
.question-card::after { display: none; }
.question-card > * { position: relative; z-index: 1; }
.question-info { margin-top: 12px; font-size: .83rem; color: var(--color-muted); display: flex; gap: 14px; flex-wrap: wrap; }
.answer-list { display: flex; flex-direction: column; gap: 12px; }
.answer-card {
  position: relative;
  overflow: hidden;
  padding: 18px 18px;
  display: flex;
  gap: 15px;
  border-left: 5px solid var(--color-answers);
  transition: box-shadow .14s ease, transform .14s ease, background .14s ease;
}
.answer-card::before { display: none; }
.answer-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); background: #fff; }
.avatar { width: 44px; height: 44px; border-radius: 2px; object-fit: cover; flex-shrink: 0; background: #fff; border: 1px solid var(--color-border); box-shadow: none; }
.avatar-placeholder { width: 44px; height: 44px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.05rem; flex-shrink: 0; }
.answer-body { flex: 1; min-width: 0; position: relative; z-index: 1; }
.answer-author { font-weight: 700; color: var(--color-nick); font-size: .92rem; }
.answer-date { font-size: .78rem; color: var(--color-muted); margin-left: 10px; }
.answer-text { margin-top: 8px; color: var(--color-text); line-height: 1.68; }
.answer-text a { color: var(--color-link); font-weight: 600; }
.answer-text a:hover { color: var(--color-primary); }

/* ===== Question author ===== */
.q-author { display: inline-flex; align-items: center; gap: 5px; font-size: .82rem; font-weight: 600; color: var(--color-nick); }
.q-author-av { width: 20px; height: 20px; border-radius: 2px; object-fit: cover; flex-shrink: 0; border: 1px solid var(--color-border); }
.q-author-ph { width: 20px; height: 20px; border-radius: 2px; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-size: .68rem; flex-shrink: 0; }

/* ===== Answer feed ===== */
.answer-feed { display: flex; flex-direction: column; gap: 9px; }
.feed-item { border-left: 5px solid var(--metro-cyan); padding: 12px 12px; }
.feed-item:hover { box-shadow: var(--shadow-md); background: #fff; }
.feed-header { display: flex; align-items: center; gap: 7px; margin-bottom: 6px; }
.feed-avatar { width: 26px; height: 26px; border-radius: 2px; object-fit: cover; flex-shrink: 0; border: 1px solid var(--color-border); }
.feed-avatar-ph { width: 26px; height: 26px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .74rem; }
.feed-nick { font-weight: 700; font-size: .82rem; color: var(--color-nick); }
.feed-time { font-size: .73rem; color: var(--color-muted); margin-left: auto; }
.feed-question { display: block; font-size: .78rem; color: var(--color-header); margin-bottom: 4px; line-height: 1.4; font-weight: 700; }
.feed-question:hover { color: var(--color-primary); }
.feed-text { font-size: .8rem; color: #323130; line-height: 1.5; margin: 0; }
.empty { color: var(--color-muted); font-style: italic; padding: 20px 0; }

/* ===== Forms and buttons ===== */
.metro-card { position: relative; overflow: hidden; padding: 24px; border-top: 5px solid var(--color-primary); }
.metro-card::before { display: none; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-weight: 700; margin-bottom: 5px; font-size: .88rem; color: var(--color-header); }
.form-group input[type=text],
.form-group input[type=email],
.form-group input[type=password],
.form-group input[type=number],
.form-group textarea,
.form-group select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  font-size: .9rem;
  background: #fff;
  color: var(--color-text);
  box-shadow: none;
  transition: border .12s ease, box-shadow .12s ease, background .12s ease;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus,
#qa-modal-uname:focus, #qa-ask-field:focus {
  outline: 2px solid rgba(0,120,212,.25);
  outline-offset: 0;
  border-color: var(--color-primary) !important;
  background: #fff;
}
.form-group textarea { resize: vertical; min-height: 100px; }
.btn { display: inline-block; padding: 10px 18px; border: none; border-radius: 2px; cursor: pointer; font-size: .9rem; font-weight: 700; transition: opacity .12s ease, transform .12s ease, box-shadow .12s ease; }
.btn:hover { opacity: .94; transform: translateY(-1px); }
.btn-primary,
.btn-danger,
.offer-btn,
.qa-offer-btn { box-shadow: var(--shadow-sm); }
.btn-primary { background: var(--color-primary); color: #fff; }
.btn-danger { background: var(--color-error); color: #fff; }
.btn-sm { padding: 6px 12px; font-size: .8rem; }

/* ===== Ask block ===== */
.ask-block {
  padding: 16px 18px;
  margin-bottom: 20px;
  cursor: pointer;
  border-left: 6px solid var(--color-primary);
  transition: box-shadow .14s ease, transform .14s ease, background .14s ease;
}
.ask-block:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); background: #fff; }
.ask-line1, .ask-line2 { color: #605e5c; font-size: .95rem; margin-bottom: 4px; }
.ask-cta { color: var(--color-primary); font-size: .9rem; font-weight: 700; letter-spacing: .04em; margin: 0; text-transform: uppercase; }
#qa-ask-field {
  background: #fff !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 2px 2px 0 0 !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ===== Pagination ===== */
.pagination { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; padding: 24px 0 8px; }
.page-link, .page-current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: 2px;
  font-size: .88rem;
  font-weight: 700;
}
.page-link { background: #fff; color: var(--color-header); border: 1px solid var(--color-border); box-shadow: var(--shadow-sm); }
.page-link:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); transform: translateY(-1px); }
.page-current { background: var(--color-primary); color: #fff; cursor: default; box-shadow: var(--shadow-sm); }
.page-arrow { font-size: 1rem; font-weight: 700; min-width: 36px; }
.page-disabled { color: #a19f9d; cursor: default; box-shadow: none; opacity: .7; }
.page-gap { display: inline-flex; align-items: center; justify-content: center; min-width: 24px; height: 36px; font-size: .88rem; color: #a19f9d; }

/* ===== Footer ===== */
.site-footer {
  position: relative;
  overflow: hidden;
  background: var(--color-header);
  color: #fff;
  padding: 24px 0;
  margin-top: 38px;
  font-size: .88rem;
  border-top: 4px solid var(--color-primary);
  box-shadow: 0 -4px 18px rgba(0,0,0,.12);
}
.site-footer::before { content:''; position:absolute; left:0; top:0; bottom:0; width:220px; background:linear-gradient(90deg, rgba(0,120,212,.28), transparent); pointer-events:none; }
.site-footer .container { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.footer-links { display: flex; align-items: center; gap: 10px; }
.footer-links a, .footer-nav-link { color: #fff; transition: color .12s; font-size: .85rem; text-decoration: none; font-weight: 600; }
.footer-links a:hover, .footer-nav-link:hover { color: var(--metro-cyan); text-decoration: none; }
.footer-sep { color: rgba(255,255,255,.55); }
.footer-copy { color: rgba(255,255,255,.85); }

/* ===== Static / contact ===== */
.static-content { color: var(--color-text); line-height: 1.72; font-size: .95rem; }
.static-content p { margin-bottom: 14px; }
.static-content h2 { font-size: 1.16rem; font-weight: 700; margin: 20px 0 8px; color: var(--color-header); }
.static-content h3 { font-size: 1rem; font-weight: 700; margin: 16px 0 6px; color: var(--color-header); }
.static-content ul, .static-content ol { margin: 10px 0 14px 22px; padding: 0; }
.static-content ul { list-style: disc; }
.static-content ol { list-style: decimal; }
.static-content li { margin-bottom: 6px; }
.static-content a { color: var(--color-link); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.static-content strong, .static-content b { font-weight: 700; }
.alert { padding: 11px 14px; border-radius: 2px; margin-bottom: 16px; font-size: .9rem; font-weight: 600; border: 1px solid var(--color-border); }
.alert-success { background: #dff6dd; color: #0b5a0b; border-color: rgba(16,124,16,.28); }
.alert-error { background: #fde7e9; color: #a4262c; border-color: rgba(209,52,56,.28); }

/* ===== Offers widget ===== */
.offers-widget, .qa-offers {
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 26px;
  border-top: 5px solid var(--color-offer-btn);
}
.offer-row, .qa-offer-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  background: #fff;
}
.offer-row:nth-child(even), .qa-offer-row:nth-child(even) { background: var(--color-surface-2); }
.offer-row:last-child, .qa-offer-row:last-child { border-bottom: none; }
.offer-logo-wrap, .qa-offer-logo-wrap {
  flex-shrink: 0;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  padding: 6px;
  display: flex;
  width: 150px;
  min-width: 150px;
  height: 60px;
  align-items: center;
  justify-content: center;
  background: #fff;
  box-shadow: none;
  box-sizing: border-box;
  text-decoration: none;
  overflow: hidden;
}
.offer-logo, .qa-offer-logo { width: auto; max-width: 138px; height: auto; max-height: 48px; object-fit: contain; display: block; }
.offer-logo-ph { font-size: .8rem; color: var(--color-muted); font-weight: 700; }
.offer-stars, .qa-offer-stars { flex-shrink: 0; display: flex; gap: 3px; width: 170px; align-items: center; justify-content: center; color: var(--color-warning); }
.star { font-size: 1.3rem; }
.star.full, .star.half { color: var(--color-warning); }
.star.half { opacity: .78; }
.star.empty { color: #c8c6c4; }
.offer-text, .qa-offer-text { flex: 1; font-size: .9rem; color: #323130; text-align: center; line-height: 1.4; font-weight: 600; min-width: 0; }
.offer-btn, .qa-offer-btn {
  flex-shrink: 0;
  background: var(--color-offer-btn);
  color: #fff;
  font-weight: 700;
  font-size: .88rem;
  letter-spacing: .06em;
  padding: 10px 22px;
  border-radius: 2px;
  border: 1px solid var(--color-offer-btn);
  text-decoration: none;
  white-space: nowrap;
  transition: opacity .12s ease, transform .12s ease, box-shadow .12s ease;
  display: inline-block;
}
.offer-btn:hover, .qa-offer-btn:hover { opacity: .96; transform: translateY(-1px); text-decoration: none; color: #fff; box-shadow: var(--shadow-md); }
@media (max-width: 600px) {
  .offer-row, .qa-offer-row { flex-wrap: wrap; gap: 12px; justify-content: center; padding: 14px 12px; }
  .offer-text, .qa-offer-text { text-align: center; width: 100%; flex-basis: 100%; order: 4; font-size: .85rem; }
  .offer-logo-wrap, .qa-offer-logo-wrap { width: 150px !important; min-width: 150px !important; height: 60px !important; padding: 6px !important; flex-shrink: 0 !important; box-sizing: border-box !important; }
  .offer-logo, .qa-offer-logo { max-width: 138px !important; max-height: 48px !important; object-fit: contain !important; }
  .offer-stars, .qa-offer-stars { min-width: 0; width: 100%; flex-basis: 100%; order: 2; justify-content: center; padding-left: 0; }
  .offer-btn, .qa-offer-btn { order: 3; width: 100%; max-width: 280px; text-align: center; padding: 12px 22px; box-sizing: border-box; }
}

/* ===== Similar questions ===== */
.similar-questions { margin-top: 32px; }
.similar-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.similar-item { padding: 13px 15px; display: flex; align-items: center; justify-content: space-between; gap: 12px; border-left: 5px solid var(--metro-purple); }
.similar-item:hover { box-shadow: var(--shadow-md); background: #fff; }
.similar-link { font-size: 1rem; font-weight: 700; color: var(--color-header); flex: 1; }
.similar-link:hover { color: var(--color-primary); }
.similar-meta { font-size: .78rem; color: var(--color-muted); white-space: nowrap; flex-shrink: 0; }

/* ===== Profile ===== */
.profile-header { display: flex; align-items: center; gap: 18px; margin-bottom: 22px; }
.profile-avatar { width: 80px; height: 80px; border-radius: 2px; object-fit: cover; flex-shrink: 0; border: 1px solid var(--color-border); box-shadow: var(--shadow-sm); }
.profile-avatar-ph { width: 80px; height: 80px; border-radius: 2px; background: var(--color-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 2rem; font-weight: 700; flex-shrink: 0; box-shadow: var(--shadow-sm); }
.profile-stats { display: flex; gap: 20px; font-size: .9rem; color: var(--color-muted); flex-wrap: wrap; }
.profile-stats b { color: var(--color-header); }
.profile-activity { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.profile-tile { position: relative; overflow: hidden; padding: 14px 16px; border-left: 5px solid var(--color-primary); }
.profile-tile-answer { border-left-color: var(--color-answers); }
.profile-tile::before { display: none; }
.profile-tile:hover { box-shadow: var(--shadow-md); background: #fff; }
.profile-meta { font-size: .78rem; color: var(--color-muted); margin-top: 4px; }
.profile-excerpt { font-size: .86rem; color: var(--color-text); margin-top: 6px; line-height: 1.6; }

/* ===== Ratings and votes ===== */
.star-rating { display: flex; gap: 4px; align-items: center; }
.star-rating .star { font-size: 1.4rem; cursor: pointer; color: #c8c6c4; transition: color .12s, transform .12s; line-height: 1; }
.star-rating .star:hover, .star-rating .star.active, .star-rating .star.voted { color: var(--color-warning); }
.star-rating .star:hover { transform: scale(1.06); }
.star-rating .star.voted { cursor: default; }
.answer-votes { display: inline-flex; align-items: center; gap: 4px; margin-top: 8px; }
.vote-btn { background: none; border: none; cursor: pointer; padding: 0 2px; font-size: 1rem; line-height: 1; transition: transform .1s, color .12s; }
.vote-up { color: var(--color-success); }
.vote-up:hover, .vote-up.voted { color: #0b5a0b; transform: scale(1.16); }
.vote-up.voted, .vote-down.voted { cursor: default; }
.vote-down { color: var(--color-error); }
.vote-down:hover, .vote-down.voted { color: #a4262c; transform: scale(1.16); }
.vote-count { font-size: .78rem; color: var(--color-muted); min-width: 10px; font-weight: 700; }
.user-stat { background: var(--color-surface-2); border: 1px solid var(--color-border); border-radius: 2px; padding: 2px 7px; }

/* ===== Inline-style hard overrides for Bento consistency ===== */
#qa-modal > div {
  background: #fff !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 2px !important;
  box-shadow: var(--shadow-md) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
#qa-modal button,
.site-header button,
#qa-ask-field + div button,
form button[type="submit"] {
  border-radius: 2px !important;
  box-shadow: var(--shadow-sm) !important;
}
#qa-ask-field + div {
  border-color: var(--color-border) !important;
  border-radius: 0 0 2px 2px !important;
  background: #fff !important;
  box-shadow: var(--shadow-sm) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.site-header [style*="border-radius:20px"] {
  border-radius: 2px !important;
  background: rgba(255,255,255,.12) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.site-footer [style*="border-radius:22px"] {
  border-radius: 2px !important;
  background: rgba(255,255,255,.08) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

@media (max-width: 600px) {
  body { font-size: 14px; background-size: 54px 54px, 54px 54px, auto; }
  .question-list { grid-template-columns: 1fr; }
  .question-card { padding: 22px 18px; }
  .question-item, .answer-card { padding: 13px 14px; }
  .answer-card { gap: 12px; }
  .profile-header { align-items: flex-start; }
  .site-header { position: relative; }
  .section-title, .answers-title, .similar-title { padding: 9px 10px; }
}


/* ===== Bento Grid final overrides ===== */
:root {
  --bento-peach: #ffe6d6;
  --bento-mint: #dff8ee;
  --bento-lilac: #ebe4ff;
  --bento-sky: #dff4ff;
  --bento-lemon: #fff4c7;
  --bento-rose: #ffe2ea;
  --bento-ink: #182033;
  --bento-card-shadow: 0 20px 55px rgba(24,32,51,.11);
  --bento-card-shadow-hover: 0 28px 70px rgba(24,32,51,.16);
}

body {
  background:
    radial-gradient(circle at 8% 8%, rgba(108,92,231,.16), transparent 28%),
    radial-gradient(circle at 86% 12%, rgba(255,122,89,.15), transparent 30%),
    radial-gradient(circle at 22% 86%, rgba(15,159,110,.13), transparent 34%),
    linear-gradient(135deg, #fbf7ef 0%, #f6f2ff 44%, #edf8f7 100%) !important;
  background-attachment: fixed;
  color: var(--color-text);
}

.container { max-width: 1160px; }
.layout {
  grid-template-columns: minmax(0,1fr) 306px;
  gap: 28px;
  padding: 32px 0;
}

.metro-card,
.question-item,
.cat-list li,
.feed-item,
.question-card,
.answer-card,
.ask-block,
.similar-item,
.profile-tile,

.metro-card,
.question-item,
.cat-list li,
.feed-item,
.question-card,
.answer-card,
.ask-block,
.similar-item,
.profile-tile,

.metro-card:hover,
.question-item:hover,
.cat-list li:hover,
.feed-item:hover,
.answer-card:hover,
.ask-block:hover,
.similar-item:hover,
.profile-tile:hover,
.offer-row:hover,
.qa-offer-row:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--bento-card-shadow-hover) !important;
}

.site-header {
  position: sticky;
  background:
    radial-gradient(circle at 14% 50%, rgba(108,92,231,.42), transparent 28%),
    radial-gradient(circle at 76% 26%, rgba(255,122,89,.32), transparent 26%),
    linear-gradient(135deg, #111827 0%, #20284a 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 16px 38px rgba(17,24,39,.25) !important;
}
.site-header::before {
  background:
    linear-gradient(135deg, rgba(255,255,255,.10), transparent 42%),
    radial-gradient(circle at 40% 110%, rgba(125,211,252,.20), transparent 30%) !important;
}
.site-header::after {
  width: 310px !important;
  opacity: .26 !important;
  background: linear-gradient(135deg, var(--bento-lilac), var(--bento-peach)) !important;
  border-radius: 999px 0 0 999px;
  clip-path: none !important;
  transform: translateX(96px);
}
.site-header .container { min-height: 76px; }
.logo { font-weight: 900; letter-spacing: -.02em; }
.logo-img img { border-radius: 18px; }
.site-header [style*="border-radius:2px"],
.site-header [style*="border-radius:20px"] {
  border-radius: 999px !important;
  background: rgba(255,255,255,.13) !important;
  border-color: rgba(255,255,255,.24) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10) !important;
}
.site-header button,
#qa-modal button,
#qa-ask-field + div button,
form button[type="submit"],
.btn,
.btn-primary,
.offer-btn,
.qa-offer-btn {
  border-radius: 999px !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 14px 32px rgba(108,92,231,.25) !important;
}
.site-header button:hover,
#qa-modal button:hover,
#qa-ask-field + div button:hover,
form button[type="submit"]:hover,
.btn:hover,
.offer-btn:hover,
.qa-offer-btn:hover {
  opacity: 1 !important;
  transform: translateY(-2px) !important;
}

.section-title,
.answers-title,
.similar-title,
.page-title {
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  color: var(--bento-ink) !important;
}
.section-title,
.answers-title,
.similar-title {
  padding: 0 !important;
  letter-spacing: .11em;
}
.page-title { font-size: clamp(1.55rem, 3vw, 2.3rem) !important; font-weight: 900 !important; }
.breadcrumb { color: var(--color-muted); }

.question-list {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-auto-flow: dense;
  gap: 16px !important;
}
.question-item {
  grid-column: span 3;
  min-height: 172px !important;
  padding: 20px !important;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px !important;
  border-left: 0 !important;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease !important;
}
.question-item:nth-child(6n+1) { grid-column: span 4; min-height: 218px !important; background: linear-gradient(135deg, rgba(235,228,255,.92), rgba(255,255,255,.82)) !important; }
.question-item:nth-child(6n+2) { grid-column: span 2; background: linear-gradient(135deg, rgba(223,248,238,.92), rgba(255,255,255,.82)) !important; }
.question-item:nth-child(6n+3) { grid-column: span 2; background: linear-gradient(135deg, rgba(255,230,214,.92), rgba(255,255,255,.82)) !important; }
.question-item:nth-child(6n+4) { grid-column: span 4; background: linear-gradient(135deg, rgba(223,244,255,.92), rgba(255,255,255,.82)) !important; }
.question-item:nth-child(6n+5) { grid-column: span 3; background: linear-gradient(135deg, rgba(255,244,199,.94), rgba(255,255,255,.82)) !important; }
.question-item:nth-child(6n+6) { grid-column: span 3; background: linear-gradient(135deg, rgba(255,226,234,.92), rgba(255,255,255,.82)) !important; }
.question-item::before {
  right: -52px !important;
  bottom: -52px !important;
  width: 160px !important;
  height: 160px !important;
  border-radius: 50%;
  background: rgba(255,255,255,.55) !important;
  opacity: 1 !important;
}
.question-item::after {
  right: 18px !important;
  top: 18px !important;
  width: 44px !important;
  height: 44px !important;
  border: 1px solid rgba(255,255,255,.62) !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.28);
}
.qi-avatar img,
.qi-avatar-ph,
.avatar,
.avatar-placeholder,
.q-author-av,
.q-author-ph,
.feed-avatar,
.feed-avatar-ph,
.profile-avatar,
.profile-avatar-ph {
  border-radius: 18px !important;
}
.qi-avatar-ph,
.avatar-placeholder,
.q-author-ph,
.feed-avatar-ph,
.profile-avatar-ph {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)) !important;
  border: 0 !important;
}
.question-link {
  font-size: clamp(1.02rem, 1.8vw, 1.22rem) !important;
  font-weight: 900 !important;
  letter-spacing: -.02em;
  color: var(--bento-ink) !important;
}
.question-link:hover { color: var(--color-primary) !important; }
.question-meta { margin-top: auto; }
.cat-tag,
.user-stat,
.cat-count,
.status-badge {
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.62) !important;
  background: rgba(255,255,255,.54) !important;
  color: var(--color-link) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.34);
}
.cat-count { color: var(--bento-ink) !important; font-weight: 900; }
.ans-badge { color: var(--color-answers) !important; font-weight: 900; }

.ask-block {
  border-left: 0 !important;
  padding: 22px 24px !important;
  background: linear-gradient(135deg, rgba(235,228,255,.94), rgba(223,244,255,.86)) !important;
}
.ask-cta { color: var(--color-primary) !important; font-weight: 900 !important; }
#qa-ask-field {
  border-radius: 26px 26px 0 0 !important;
  background: rgba(255,255,255,.82) !important;
}
#qa-ask-field + div {
  border-radius: 0 0 26px 26px !important;
  background: rgba(255,255,255,.72) !important;
}

.sidebar {
  display: grid;
  gap: 18px;
}
.cat-list { gap: 12px !important; }
.cat-list li,
.feed-item {
  min-height: 78px;
  border-left: 0 !important;
  padding: 16px !important;
}
.cat-list li:nth-child(6n+1), .feed-item:nth-child(6n+1) { background: linear-gradient(135deg, rgba(223,248,238,.92), rgba(255,255,255,.82)) !important; }
.cat-list li:nth-child(6n+2), .feed-item:nth-child(6n+2) { background: linear-gradient(135deg, rgba(255,230,214,.92), rgba(255,255,255,.82)) !important; }
.cat-list li:nth-child(6n+3), .feed-item:nth-child(6n+3) { background: linear-gradient(135deg, rgba(235,228,255,.92), rgba(255,255,255,.82)) !important; }
.cat-list li:nth-child(6n+4), .feed-item:nth-child(6n+4) { background: linear-gradient(135deg, rgba(223,244,255,.92), rgba(255,255,255,.82)) !important; }

.question-card {
  padding: 30px !important;
  border-top: 0 !important;
  background: linear-gradient(135deg, rgba(235,228,255,.92), rgba(255,255,255,.84)) !important;
}
.question-card::before {
  width: 180px !important;
  height: 180px !important;
  right: -70px !important;
  top: -70px !important;
  border-radius: 50%;
  clip-path: none !important;
  background: rgba(255,255,255,.45) !important;
}
.question-text { font-size: clamp(1.25rem, 2.3vw, 1.75rem) !important; font-weight: 900 !important; }
.answer-list { gap: 16px !important; }
.answer-card {
  border-left: 0 !important;
  padding: 20px !important;
  background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(223,248,238,.82)) !important;
}
.answer-card:nth-child(3n+2) { background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(223,244,255,.84)) !important; }
.answer-card:nth-child(3n+3) { background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(255,230,214,.82)) !important; }
.answer-author,
.qi-nick,
.feed-nick { color: var(--color-nick) !important; font-weight: 900 !important; }

.offer-row,
.qa-offer-row {
  border-bottom: 1px solid rgba(24,32,51,.08) !important;
  background: rgba(255,255,255,.58) !important;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.offer-row:nth-child(even),
.qa-offer-row:nth-child(even) { background: rgba(255,246,235,.66) !important; }
.offer-logo-wrap,
.qa-offer-logo-wrap {
  border-radius: 20px !important;
  background: rgba(255,255,255,.68) !important;
  border: 1px solid rgba(255,255,255,.72) !important;
}
.offers-widget,
.qa-offers { border-top: 0 !important; background: linear-gradient(135deg, rgba(255,230,214,.82), rgba(255,255,255,.78)) !important; }
.offer-btn,
.qa-offer-btn { background: linear-gradient(135deg, var(--color-offer-btn), #ff9f68) !important; box-shadow: 0 14px 32px rgba(255,122,89,.24) !important; }

.similar-list,
.profile-activity {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px !important;
}
.similar-item,
.profile-tile,
.metro-card,
.similar-item:nth-child(4n+1), .profile-tile:nth-child(4n+1), .metro-card { background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(235,228,255,.80)) !important; }
.similar-item:nth-child(4n+2), .profile-tile:nth-child(4n+2) { background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(223,248,238,.82)) !important; }
.similar-item:nth-child(4n+3), .profile-tile:nth-child(4n+3) { background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(255,230,214,.82)) !important; }
.similar-item:nth-child(4n+4), .profile-tile:nth-child(4n+4) { background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(223,244,255,.82)) !important; }

.form-group input[type=text],
.form-group input[type=email],
.form-group input[type=password],
.form-group input[type=number],
.form-group textarea,
.form-group select,
#qa-modal-uname,
textarea,
input[type=text],
input[type=email] {
  border-radius: 18px !important;
  border: 1px solid rgba(24,32,51,.12) !important;
  background: rgba(255,255,255,.76) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.64) !important;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus,
#qa-modal-uname:focus,
#qa-ask-field:focus,
textarea:focus,
input[type=text]:focus,
input[type=email]:focus {
  outline: 4px solid rgba(108,92,231,.14) !important;
  border-color: rgba(108,92,231,.58) !important;
}
.alert { border-radius: 22px !important; }
.alert-success, .status-published { background: rgba(223,248,238,.86) !important; color: #08744f !important; }
.alert-error { background: rgba(255,226,234,.90) !important; color: #b4232a !important; }
.status-pending { background: rgba(255,244,199,.92) !important; color: #8a5d00 !important; }

.pagination { gap: 9px !important; }
.page-link,
.page-current {
  border-radius: 16px !important;
  border: 1px solid rgba(255,255,255,.68) !important;
  background: rgba(255,255,255,.72) !important;
  box-shadow: var(--glass-shadow-sm) !important;
}
.page-link:hover,
.page-current {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)) !important;
  color: #fff !important;
}

.site-footer {
  background:
    radial-gradient(circle at 16% 0%, rgba(108,92,231,.28), transparent 30%),
    radial-gradient(circle at 88% 100%, rgba(255,122,89,.24), transparent 32%),
    linear-gradient(135deg, #111827 0%, #20284a 100%) !important;
  border-top: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 30px 30px 0 0;
}
.site-footer [style*="border-radius:2px"],
.site-footer [style*="border-radius:22px"] {
  border-radius: 999px !important;
  background: rgba(255,255,255,.11) !important;
  border-color: rgba(255,255,255,.22) !important;
}
.footer-links a:hover, .footer-nav-link:hover { color: #ffe6d6 !important; }


@media (max-width: 900px) {
  .question-list { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .question-item,
  .question-item:nth-child(n) { grid-column: span 1; min-height: 166px !important; }
  .layout { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  body { background-attachment: scroll; }
  .question-list { grid-template-columns: 1fr !important; }
  .question-item,
  .question-item:nth-child(n) { grid-column: span 1; min-height: auto !important; }
  .site-header { position: relative; }
  .site-header .container { min-height: 62px; }
  .logo-img img { width: 110px !important; height: 36px !important; border-radius: 13px; }
  .question-card { padding: 22px !important; }
  .answer-card { flex-direction: row; gap: 12px !important; }
  .similar-list,
  .profile-activity { grid-template-columns: 1fr; }
  .site-footer { border-radius: 24px 24px 0 0; }
}
