/* verbrauchertipp.com — content + tools */

:root { --vt-accent: #1d6fa5; --vt-accent-soft: #e3f0fa; }

.vt-hero-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1rem; margin: 1.5rem 0; }
.vt-cat-card { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1.4rem; text-decoration: none; color: inherit;
  transition: box-shadow .15s, border-color .15s; display: block; }
.vt-cat-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,.08); border-color: var(--vt-accent); text-decoration: none; }
.vt-cat-card-icon { font-size: 2rem; margin-bottom: .3rem; }
.vt-cat-card h3 { margin: 0 0 .2rem; color: var(--vt-accent); font-size: 1.05rem; }
.vt-cat-card p  { color: #555; font-size: .85rem; margin: 0; line-height: 1.45; }
.vt-cat-card .ct { color: #888; font-size: .8rem; margin-top: .3rem; }

.vt-articles { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem; margin: 1rem 0; }
.vt-art-card { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1.15rem 1.3rem; text-decoration: none; color: inherit;
  transition: box-shadow .15s, border-color .15s; }
.vt-art-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,.08); border-color: var(--vt-accent); }
.vt-art-card .cat { color: #888; font-size: .75rem; text-transform: uppercase; letter-spacing: .04em; }
.vt-art-card h3 { margin: .3rem 0 .35rem; color: var(--vt-accent); font-size: 1.05rem; line-height: 1.3; }
.vt-art-card p { color: #555; font-size: .9rem; margin: 0; line-height: 1.5; }

.vt-article { max-width: 760px; margin: 0 auto; }
.vt-article-cat { color: var(--vt-accent); font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; margin-bottom: .3rem; }
.vt-article h1 { margin: .2rem 0 1rem; font-size: 1.9rem; line-height: 1.25; }
.vt-article .meta { color: #999; font-size: .85rem; margin-bottom: 2rem; }
.vt-article h2 { margin: 2rem 0 .8rem; font-size: 1.3rem; color: var(--vt-accent); }
.vt-article p, .vt-article li { line-height: 1.65; color: #333; }
.vt-article p { margin: .8rem 0; }
.vt-article ul, .vt-article ol { padding-left: 1.5em; }
.vt-article li { margin: .35rem 0; }
.vt-article-related { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1.2rem 1.4rem; margin-top: 2rem; }

.vt-disclaimer { background: #fff3cd; border: 1px solid #ffe69c; color: #5a4500;
  border-radius: 8px; padding: .9rem 1.1rem; font-size: .9rem; margin: 1rem 0; }
.vt-legal-note { background: #f0f4f7; border-left: 4px solid var(--vt-accent); color: #333;
  padding: .9rem 1.1rem; font-size: .9rem; margin: 1.5rem 0; border-radius: 4px; }

/* Tool styles */
.vt-tool { background: linear-gradient(135deg, var(--vt-accent-soft), #fff); border: 2px solid var(--vt-accent);
  border-radius: 12px; padding: 1.5rem; margin: 0 0 2rem; }
.vt-tool h2 { margin-top: 0; color: var(--vt-accent); }
.vt-form { display: grid; gap: .8rem; }
.vt-form label { display: flex; flex-direction: column; gap: .25rem; color: #555; font-size: .9rem; }
.vt-form input, .vt-form select, .vt-form textarea { padding: .65rem .8rem; border: 2px solid var(--border);
  border-radius: 6px; font-size: 1rem; font-family: inherit; }
.vt-form textarea { min-height: 4em; font-family: inherit; }
.vt-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
@media (max-width: 600px) { .vt-form .row2 { grid-template-columns: 1fr; } }
.vt-form button { padding: .7rem 1.5rem; background: var(--vt-accent); color: #fff; border: none;
  border-radius: 6px; font-size: 1rem; cursor: pointer; font-weight: 600; }
.vt-form button:hover { filter: brightness(.95); }

.vt-output { background: #fff; border: 2px solid var(--vt-accent); border-radius: 8px;
  padding: 1.2rem; margin-top: 1.2rem; white-space: pre-wrap; font-family: monospace;
  font-size: .9rem; line-height: 1.5; }

/* Test sources table */
.vt-sources { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: .9rem; }
.vt-sources th { background: var(--vt-accent); color: #fff; text-align: left; padding: .55rem .8rem; }
.vt-sources td { padding: .6rem .8rem; border-bottom: 1px solid var(--border); vertical-align: top; }
.vt-sources tr:hover { background: #f8fafc; }
.vt-sources .flag { font-size: 1.2rem; margin-right: .4rem; }
.vt-source-free { color: #2e9e4d; font-weight: 600; }
.vt-source-paid { color: #b07b00; }
.vt-source-mixed { color: #1d6fa5; }
.vt-filter-row { display: flex; gap: .8rem; align-items: center; margin: 1rem 0; flex-wrap: wrap; }
.vt-filter-row input, .vt-filter-row select { padding: .55rem .8rem; border: 1px solid var(--border);
  border-radius: 6px; font-size: .9rem; }
.vt-filter-row input { flex: 1; min-width: 200px; }

/* Garantie tracker list */
.vt-tracker-list { list-style: none; padding: 0; margin: 1.2rem 0 0; }
.vt-tracker-item { background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 1rem 1.2rem; margin-bottom: .6rem; display: grid;
  grid-template-columns: 1fr auto; gap: .5rem; align-items: center; }
.vt-tracker-item .name { font-weight: 600; color: var(--vt-accent); }
.vt-tracker-item .dates { color: #666; font-size: .85rem; }
.vt-tracker-item .left { font-family: monospace; font-size: 1rem; color: #333; }
.vt-tracker-item.expired .left { color: #d4504e; }
.vt-tracker-item.soon    .left { color: #b07b00; font-weight: 700; }
.vt-tracker-item button { background: transparent; border: 1px solid var(--border); color: #666;
  border-radius: 4px; padding: .3rem .6rem; cursor: pointer; font-size: .8rem; }
.vt-empty { color: #888; font-style: italic; padding: 1rem; text-align: center; }
