:root{
  --bg:#f5f7fb;
  --card:#ffffff;
  --text:#0b1220;
  --muted:#5b667a;
  --line:rgba(15, 23, 42, 0.12);
  --shadow:0 10px 25px rgba(15,23,42,0.08);
  --accent:#009fe3; /* Knauf-like blue */
  --accent2:#0b4aa2;
  --radius:18px;
  --radius2:14px;
  --maxw:1080px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  background: radial-gradient(1200px 500px at 15% -10%, rgba(0,159,227,0.12), transparent 60%),
              radial-gradient(900px 420px at 85% -15%, rgba(11,74,162,0.10), transparent 55%),
              var(--bg);
  color:var(--text);
}

a{color:inherit}

.app{
  min-height:100%;
  display:flex;
  flex-direction:column;
}

.topbar{
  position:sticky;
  top:0;
  z-index:20;
  background: rgba(245,247,251,0.85);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}


.statusBar{
  padding:8px 16px;
  border-bottom:1px solid var(--line);
  background: rgba(245,247,251,0.85);
  backdrop-filter: blur(10px);
  color:var(--muted);
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.brand{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.logo{
  font-weight:900;
  letter-spacing:0.16em;
  font-size:14px;
  color:var(--accent2);
}
.subtitle{
  font-size:12px;
  color:var(--muted);
}

.status{
  margin-top:8px;
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.tabs{
  display:flex;
  gap:8px;
  padding:10px 16px 14px 16px;
  overflow:auto;
  border-bottom:1px solid var(--line);
  background: rgba(245,247,251,0.85);
  backdrop-filter: blur(10px);
}
.tabs::-webkit-scrollbar{height:6px}
.tabs::-webkit-scrollbar-thumb{background:rgba(15,23,42,0.18);border-radius:999px}

.tab{
  border:1px solid var(--line);
  background:var(--card);
  color:var(--text);
  padding:10px 12px;
  border-radius:999px;
  font-size:13px;
  cursor:pointer;
  box-shadow:0 2px 10px rgba(15,23,42,0.04);
  display:flex;
  position:relative;
  align-items:center;
  gap:8px;
  flex:0 0 auto;
}
.tab:hover{border-color:rgba(0,159,227,0.35)}
.tab.active{
  border-color:rgba(0,159,227,0.55);
  box-shadow:0 6px 18px rgba(0,159,227,0.16);
}

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:rgba(0,159,227,0.16);
  color:var(--accent2);
  font-weight:700;
  font-size:12px;
}

.content{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:18px 16px 28px 16px;
  flex:1 1 auto;
}

.view.hidden{display:none}

.hero{
  border:1px solid rgba(0,159,227,0.18);
  background: linear-gradient(135deg, rgba(0,159,227,0.10), rgba(11,74,162,0.06));
  border-radius:var(--radius);
  padding:18px 16px;
  box-shadow:var(--shadow);
  margin-bottom:14px;
}
.heroTitle{
  font-size:18px;
  font-weight:900;
  letter-spacing:-0.02em;
}
.heroText{
  margin-top:6px;
  font-size:13px;
  color:var(--muted);
  line-height:1.35;
}

.toolbar{
  display:flex;
  gap:10px;
  align-items:center;
  margin:12px 0 12px 0;
  flex-wrap:wrap;
}

input, select{
  width:100%;
  border:1px solid var(--line);
  background:var(--card);
  color:var(--text);
  border-radius:12px;
  padding:12px 12px;
  font-size:14px;
  outline:none;
}
input:focus, select:focus{
  border-color:rgba(0,159,227,0.55);
  box-shadow:0 0 0 4px rgba(0,159,227,0.12);
}

#search{flex:1 1 320px}
#categorySelect{flex:0 0 260px}

.chips{
  display:flex;
  gap:8px;
  overflow:auto;
  padding-bottom:6px;
  margin-bottom:10px;
}
.chip{
  flex:0 0 auto;
  border:1px solid var(--line);
  background:var(--card);
  color:var(--text);
  padding:8px 10px;
  border-radius:999px;
  font-size:13px;
  cursor:pointer;
}
.chip.active{
  border-color:rgba(0,159,227,0.55);
  background:rgba(0,159,227,0.08);
}

.grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}
@media (max-width: 980px){
  .grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width: 560px){
  .grid{grid-template-columns:1fr}
  #categorySelect{flex:1 1 100%}
}

.card{
  border:1px solid var(--line);
  background:var(--card);
  border-radius:var(--radius);
  padding:14px;
  box-shadow:var(--shadow);
}

.pcard{
  display:flex;
  flex-direction:column;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--card);
  overflow:hidden;
  box-shadow:0 6px 18px rgba(15,23,42,0.06);
}
.pimg{
  width:100%;
  aspect-ratio: 16 / 10;
  background:linear-gradient(135deg, rgba(0,159,227,0.08), rgba(11,74,162,0.05));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.pimg img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.pbody{padding:12px}
.ptitle{
  font-size:14px;
  font-weight:800;
  line-height:1.25;
}
.pdesc{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
  line-height:1.3;
  height:46px;
  overflow:hidden;
}
.pprice{
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.price{
  font-weight:900;
  font-size:14px;
}
.btn{
  border:1px solid rgba(0,159,227,0.35);
  background:rgba(0,159,227,0.10);
  color:var(--accent2);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
}
.btn:hover{background:rgba(0,159,227,0.14)}

.cardTitle{
  font-weight:900;
  font-size:15px;
  margin-bottom:8px;
}
.cardHint{
  font-size:12px;
  color:var(--muted);
  line-height:1.35;
  margin-bottom:10px;
}
.muted{color:var(--muted)}
.tiny{font-size:12px}

.list{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:10px 0;
}
.itemRow{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  padding:10px 10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(245,247,251,0.65);
}
.itemMain{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.itemName{
  font-weight:800;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:58vw;
}
.itemMeta{
  font-size:12px;
  color:var(--muted);
}
.qtyBox{
  display:flex;
  gap:8px;
  align-items:center;
}
.qtyBtn{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid var(--line);
  background:var(--card);
  cursor:pointer;
  font-weight:900;
}
.qtyNum{
  min-width:28px;
  text-align:center;
  font-weight:900;
}
.delBtn{
  border:1px solid rgba(239,68,68,0.35);
  background:rgba(239,68,68,0.10);
  color:#991b1b;
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
  font-weight:900;
}

.rowBetween{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:10px;
}
.total{
  font-weight:900;
  font-size:16px;
}

.primary, .secondary{
  width:100%;
  border-radius:14px;
  padding:12px 14px;
  cursor:pointer;
  font-weight:900;
  font-size:14px;
  border:1px solid transparent;
}
.primary{
  background:linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff;
  box-shadow:0 10px 24px rgba(0,159,227,0.25);
}
.primary:hover{filter:brightness(1.02)}
.secondary{
  background:rgba(0,159,227,0.10);
  border-color:rgba(0,159,227,0.30);
  color:var(--accent2);
}
.secondary:hover{background:rgba(0,159,227,0.14)}

.formGrid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:10px;
}
@media (max-width: 740px){
  .formGrid{grid-template-columns:1fr}
}
.field{display:flex; flex-direction:column; gap:6px}
.fieldFull{grid-column:1 / -1}
.label{font-size:12px; color:var(--muted); font-weight:800}

.result{
  margin-top:10px;
  padding:12px;
  border:1px dashed rgba(0,159,227,0.40);
  border-radius:14px;
  background:rgba(0,159,227,0.06);
  font-weight:900;
}

.profile{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:13px;
}

.links{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(245,247,251,0.75);
  text-decoration:none;
  font-weight:900;
  color:var(--accent2);
}

.footer{
  border-top:1px solid var(--line);
  padding:14px 16px;
  background:rgba(245,247,251,0.85);
  backdrop-filter: blur(10px);
}


.topRight{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:flex-end;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(0,159,227,0.25);
  background:rgba(0,159,227,0.10);
  color:var(--accent2);
  font-weight:700;
  font-size:12px;
  white-space:nowrap;
}
.hidden{display:none !important;}

.promos{margin-top:12px;}
.promoGrid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
  margin-top:10px;
}
@media (max-width: 980px){
  .promoGrid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width: 560px){
  .promoGrid{grid-template-columns:1fr}
}
.promoCard{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:12px 12px;
  background:linear-gradient(180deg, rgba(0,159,227,0.08), rgba(255,255,255,0.85));
}
.promoTitle{font-weight:900; font-size:15px; margin:0 0 6px 0;}
.promoText{color:var(--muted); font-size:13px; margin:0 0 10px 0; line-height:1.35;}
.promoMeta{display:flex; align-items:center; justify-content:space-between; gap:10px;}
.promoBadge{
  display:inline-flex; align-items:center; justify-content:center;
  padding:6px 10px; border-radius:999px;
  background:rgba(11,74,162,0.12);
  color:var(--accent2);
  font-weight:900;
  font-size:12px;
}
.promoLink{font-weight:800; font-size:12px; color:var(--accent2); text-decoration:none;}
.promoLink:hover{text-decoration:underline;}

.tab .ico{display:none;}
.tab .txt{display:inline;}
@media (max-width: 720px){
  .tabs{
    position:fixed;
    left:0; right:0; bottom:0;
    z-index:50;
    border-bottom:none;
    border-top:1px solid var(--line);
    padding:8px 10px;
    justify-content:space-between;
    overflow:visible;
    background:rgba(255,255,255,0.92);
  }
  .tab{
    flex:1 1 0;
    justify-content:center;
    border-radius:14px;
    padding:10px 6px;
    flex-direction:column;
    gap:4px;
    font-size:11px;
    text-align:center;
  }
  .tab .ico{display:block; font-size:18px; line-height:18px;}
  .tab .txt{display:block;}
  .badge{
    position:absolute;
    top:6px;
    right:10px;
  }
  .container{padding-bottom:90px;}
  .status{font-size:12px; max-width:55vw; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
}


/* Catalog pagination */
.moreRow{
  display:flex;
  align-items:center;
  gap:12px;
  margin:14px 0 24px;
}
.moreRow .muted{font-size:12px;}

/* Product cards */
.pcard{
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  box-shadow: var(--shadow-sm);
  transition: transform .15s ease, box-shadow .15s ease;
}
.pcard:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.pimg{
  aspect-ratio: 4 / 3;
  background: #f3f4f6;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pimg img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.pbody{
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.ptitle{
  font-weight:700;
  font-size:14px;
  line-height:1.25;
}
.pdesc{
  color: var(--muted);
  font-size:12px;
  line-height:1.35;
  min-height: 32px;
}
.pprice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:auto;
}
.price{
  font-weight:800;
}

/* Modal */
.modal.hidden{display:none;}
.modal{
  position:fixed;
  inset:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px;
}
.modalOverlay{
  position:absolute;
  inset:0;
  background: rgba(2,6,23,.55);
  backdrop-filter: blur(2px);
}
.modalBody{
  position:relative;
  width:min(980px, 100%);
  max-height: 92vh;
  overflow:hidden;
  border-radius: 18px;
  background: var(--bg);
  border:1px solid var(--border);
  box-shadow: var(--shadow-lg);
  display:flex;
  flex-direction:column;
}
.modalHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.7));
}
.modalTitle{
  font-weight:900;
}
.modalContent{
  padding:14px;
  overflow:auto;
}
.pmTop{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
}
.pmGallery{display:flex; flex-direction:column; gap:10px;}
.pmMainImg{
  width:100%;
  aspect-ratio: 4/3;
  border-radius: 14px;
  border:1px solid var(--border);
  background:#f3f4f6;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pmMainImg img{width:100%; height:100%; object-fit:cover;}
.pmThumbs{display:flex; gap:8px; flex-wrap:wrap;}
.pmThumb{
  width:72px; height:54px;
  border-radius:10px;
  border:1px solid var(--border);
  overflow:hidden;
  background:#f3f4f6;
  cursor:pointer;
}
.pmThumb img{width:100%; height:100%; object-fit:cover;}
.pmThumb.active{outline:2px solid var(--accent);}
.pmInfo{
  border:1px solid var(--border);
  border-radius: 14px;
  padding:12px;
  background: var(--card-bg);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.pmPrice{
  font-size:18px;
  font-weight:900;
}
.pmActions{display:flex; gap:10px; flex-wrap:wrap;}
.pmMeta{display:flex; flex-direction:column; gap:6px; font-size:12px;}
.pmMetaRow a{color: var(--accent); text-decoration:none;}
.pmMetaRow a:hover{text-decoration:underline;}

.pmBlock{
  margin-top:14px;
  border:1px solid var(--border);
  border-radius: 14px;
  padding:12px;
  background: var(--card-bg);
}
.pmBlockTitle{font-weight:900; margin-bottom:8px;}
.pmText{font-size:13px; line-height:1.5; white-space:pre-wrap;}
.pmSpecs table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}
.pmSpecs th, .pmSpecs td{
  padding:8px 10px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}
.pmSpecs th{color:var(--muted); font-weight:700; text-align:left; width:42%;}
.pmSpecs .groupRow td{
  padding-top:14px;
  font-weight:900;
  color: var(--text);
}
.pmDocs a{color: var(--accent); text-decoration:none;}
.pmDocs a:hover{text-decoration:underline;}
.pmDocs .docItem{display:flex; gap:10px; align-items:baseline; padding:6px 0; border-bottom:1px dashed var(--border);}
.pmDocs .docMeta{color: var(--muted); font-size:12px;}

@media (max-width: 900px){
  .pmTop{grid-template-columns:1fr;}
  .pmThumb{width:64px; height:48px;}
  .modalBody{max-height: 96vh;}
}


.noScroll{overflow:hidden;}

.pactions{display:flex; gap:8px; align-items:center; justify-content:flex-end; flex-wrap:wrap;}
.btnSmallGhost{padding:8px 10px; border-radius: 12px; border:1px solid var(--border); background: transparent; font-weight:800; cursor:pointer;}
.btnSmallGhost:hover{border-color: rgba(249,115,22,.6);}


.segmented{
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px;
  border:1px solid var(--line);
  border-radius:var(--radius2);
  background:rgba(255,255,255,0.6);
}
.segmented.small{padding:4px; gap:6px;}
.seg{
  flex:1 1 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  font-weight:900;
  color:var(--text);
  cursor:pointer;
  user-select:none;
}
.segmented.small .seg{padding:8px 8px; font-size:12px;}
.seg.active{
  background:linear-gradient(180deg, rgba(0,159,227,0.18), rgba(0,159,227,0.10));
  border-color:rgba(0,159,227,0.35);
  color:var(--accent2);
}
.checkRow{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:10px;
  color:var(--muted);
  font-weight:700;
}
.checkRow input{width:18px; height:18px;}


/* Burger + drawer */
.burger{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.9);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  padding:0 12px;
  cursor:pointer;
}
.burger span{
  display:block;
  height:2px;
  border-radius:999px;
  background:var(--text);
  opacity:0.85;
}
.drawerOverlay{
  position:fixed;
  inset:0;
  background:rgba(15, 23, 42, 0.40);
  z-index:80;
}
.drawer{
  position:fixed;
  top:0;
  bottom:0;
  left:0;
  width:min(360px, 88vw);
  background:#fff;
  border-right:1px solid var(--line);
  z-index:90;
  display:flex;
  flex-direction:column;
  transform:translateX(-110%);
  transition:transform 180ms ease;
}
.drawer.show{transform:translateX(0);}
.drawerHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 14px;
  border-bottom:1px solid var(--line);
}
.drawerBrand .logo{
  font-weight:1000;
  letter-spacing:1px;
  color:var(--accent2);
}
.drawerBrand .subtitle{
  font-size:12px;
  color:var(--muted);
  margin-top:2px;
}
.drawerNav{
  padding:10px 10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow:auto;
}
.ditem{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  background:rgba(255,255,255,0.9);
  cursor:pointer;
  font-weight:800;
}
.ditem .ico{width:24px; text-align:center;}
.ditem.link{text-decoration:none; color:var(--text);}
.dmeta{
  min-width:26px;
  text-align:center;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(11,74,162,0.10);
  color:var(--accent2);
  font-weight:1000;
  font-size:12px;
}
.dsep{
  height:1px;
  background:var(--line);
  margin:8px 2px;
}
.drawerFoot{
  padding:12px 14px 16px 14px;
  border-top:1px solid var(--line);
}

/* Tools subtabs */
.subtabs{
  display:flex;
  gap:8px;
  margin-bottom:12px;
}
.subtab{
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  background:rgba(255,255,255,0.9);
  cursor:pointer;
  font-weight:900;
}
.subtab.active{
  border-color:rgba(0,159,227,0.35);
  background:rgba(0,159,227,0.12);
  color:var(--accent2);
}

/* Recently viewed row */
.recentRow{
  display:flex;
  gap:10px;
  overflow:auto;
  padding:6px 2px;
}
.rchip{
  min-width:180px;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px;
  background:rgba(255,255,255,0.9);
  cursor:pointer;
}
.rchipTitle{font-weight:900; font-size:13px; margin-bottom:6px;}
.rchipMeta{display:flex; align-items:center; justify-content:space-between; gap:8px; font-size:12px; color:var(--muted);}

/* Product card extra buttons */
.pcard{position:relative;}
.pbadges{
  position:absolute;
  top:10px;
  right:10px;
  display:flex;
  gap:8px;
  z-index:5;
}
.pmini{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.92);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pmini.active{
  border-color:rgba(0,159,227,0.35);
  background:rgba(0,159,227,0.12);
}

/* Compare table */
.compareWrap{
  overflow:auto;
}
.ctable{
  border-collapse:separate;
  border-spacing:0;
  width:max(760px, 100%);
  font-size:13px;
}
.ctable th, .ctable td{
  border:1px solid var(--line);
  padding:10px;
  vertical-align:top;
  background:#fff;
}
.ctable th{
  position:sticky;
  top:0;
  z-index:2;
  background:rgba(248,250,252,0.98);
}
.ctitle{font-weight:1000;}
.csmall{font-size:12px; color:var(--muted);}
.cbtnRow{display:flex; gap:8px; flex-wrap:wrap; margin-top:8px;}
.cbtn{border:1px solid var(--line); border-radius:12px; padding:8px 10px; background:#fff; cursor:pointer; font-weight:900;}

/* Toasts */
.toastWrap{
  position:fixed;
  left:50%;
  bottom:92px;
  transform:translateX(-50%);
  z-index:120;
  display:flex;
  flex-direction:column;
  gap:10px;
  pointer-events:none;
}
.toast{
  pointer-events:none;
  min-width:min(520px, 92vw);
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.96);
  padding:10px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-shadow:0 10px 24px rgba(15,23,42,0.12);
}
.toast strong{font-weight:1000;}
.toast .muted{font-size:12px;}

.iconBtn.active{border-color:rgba(0,159,227,0.35); background:rgba(0,159,227,0.12);}


/* helpers: help view and small blocks */
.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media (max-width:820px){.grid2{grid-template-columns:1fr}}
.infoRow{border:1px solid var(--border);background:var(--card);border-radius:14px;padding:12px}
.infoRow .muted{margin-bottom:4px}
.olist{margin:0;padding-left:18px}
.olist li{margin:8px 0;color:var(--text)}
.miniCard{border:1px solid var(--border);background:linear-gradient(180deg,var(--card),#fff);border-radius:16px;padding:12px}
.miniTitle{font-weight:800;margin-bottom:6px}
.miniText{color:var(--muted);font-size:13px;line-height:1.35}
.link{color:var(--accent);text-decoration:none;font-weight:700}
.link:hover{text-decoration:underline}
