:root {
--ink: #1B1D21;
--ink-soft: #4A4D53;
--shell: #EFF0EC;
--paper: #FFFFFF;
--line: #DBDCD6;
--amber: #F2A93B; --coral: #E8623D; --cyan: #3FC6C3; --violet: #8B7CF6; --teal: #4FA98A; --neutral-tag: #6B6E76; --blue: #0183B7; --font-display: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;
--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
--font-mono: "IBM Plex Mono", "SF Mono", Consolas, monospace;
--radius: 10px;
--max-width: 1180px;
--transition: 180ms ease;
}
@media (prefers-reduced-motion: reduce) {
:root { --transition: 0ms; }
* { animation: none !important; }
} * { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
margin: 0;
background: var(--shell);
color: var(--ink);
font-family: var(--font-body);
font-size: 17px;
line-height: 1.6;
-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; height: auto; }
a { color: var(--ink); text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4 {
font-family: var(--font-display);
line-height: 1.15;
margin: 0 0 0.5em;
letter-spacing: -0.01em;
}
p { margin: 0 0 1.1em; }
:focus-visible {
outline: 2px solid var(--ink);
outline-offset: 3px;
}
.container {
max-width: var(--max-width);
margin: 0 auto;
padding: 0 24px;
}
.skip-link {
position: absolute;
left: -9999px;
top: 0;
background: var(--ink);
color: var(--paper);
padding: 10px 16px;
z-index: 100;
}
.skip-link:focus { left: 12px; top: 12px; } .status-dot {
display: inline-block;
width: 8px;
height: 8px;
border-radius: 50%;
margin-right: 7px;
flex-shrink: 0;
box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 18%, transparent);
}
.tag-lighting   { color: var(--amber); }
.tag-heating    { color: var(--coral); }
.tag-security, .tag-cameras { color: var(--cyan); }
.tag-homeassistant { color: var(--violet); }
.tag-smarthome  { color: var(--teal); }
.tag-default, .tag-reviews, .tag-articles { color: var(--neutral-tag); }
.category-pill {
display: inline-flex;
align-items: center;
font-family: var(--font-mono);
font-size: 12px;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--ink-soft);
} .site-header {
background: var(--ink);
color: var(--shell);
}
.site-header .container {
display: flex;
align-items: center;
justify-content: space-between;
gap: 24px;
padding-top: 18px;
padding-bottom: 18px;
}
.site-branding img { height: 34px; }
.site-branding a { display: flex; align-items: center; gap: 10px; }
.site-title {
font-family: var(--font-display);
font-size: 19px;
color: var(--shell);
font-weight: 600;
transition: color var(--transition);
}
.site-branding a:hover .site-title { color: var(--blue); }
.primary-nav ul { display: flex; gap: 28px; align-items: center; }
.primary-nav a {
color: var(--shell);
opacity: 0.82;
font-size: 15px;
transition: opacity var(--transition), color var(--transition);
}
.primary-nav a:hover, .primary-nav a:focus-visible { opacity: 1; color: #6FD3F2; }
.header-actions {
display: flex;
align-items: center;
gap: 18px;
}
.youtube-chip {
display: inline-flex;
align-items: center;
gap: 8px;
font-family: var(--font-mono);
font-size: 12px;
text-transform: uppercase;
letter-spacing: 0.05em;
color: #fff;
background: var(--blue);
padding: 8px 14px;
border-radius: 999px;
transition: transform var(--transition), background var(--transition);
}
.youtube-chip:hover { transform: translateY(-1px); background: #016E9B; }
.menu-toggle {
display: none;
background: none;
border: 1px solid rgba(255,255,255,0.3);
color: var(--shell);
border-radius: 6px;
padding: 8px 10px;
}
@media (max-width: 780px) {
.primary-nav { display: none; }
.menu-toggle { display: inline-flex; }
.primary-nav.is-open {
display: block;
position: absolute;
top: 68px;
left: 0;
right: 0;
background: var(--ink);
padding: 16px 24px 24px;
}
.primary-nav.is-open ul { flex-direction: column; gap: 16px; }
} .hero {
padding: 56px 0 40px;
border-bottom: 1px solid var(--line);
}
.hero .container {
display: flex;
align-items: flex-end;
justify-content: space-between;
gap: 32px;
flex-wrap: wrap;
}
.hero-eyebrow {
font-family: var(--font-mono);
font-size: 12px;
text-transform: uppercase;
letter-spacing: 0.08em;
color: var(--ink-soft);
margin-bottom: 10px;
display: block;
}
.hero h1 {
font-size: clamp(28px, 4vw, 44px);
max-width: 640px;
}
.hero-sub {
color: var(--ink-soft);
max-width: 460px;
font-size: 16px;
margin: 0;
} .section-heading {
display: flex;
align-items: baseline;
justify-content: space-between;
margin: 48px 0 22px;
}
.section-heading h2 { font-size: 22px; margin: 0; }
.section-heading a {
font-family: var(--font-mono);
font-size: 13px;
color: var(--ink-soft);
text-transform: uppercase;
letter-spacing: 0.04em;
}
.featured-card {
display: grid;
grid-template-columns: 1.1fr 1fr;
gap: 32px;
background: var(--paper);
border-radius: var(--radius);
overflow: hidden;
border: 1px solid var(--line);
margin-bottom: 32px;
}
.featured-card .thumb { aspect-ratio: 16/9; overflow: hidden; }
.featured-card .thumb img {
width: 100%; height: 100%; object-fit: cover;
transition: transform var(--transition);
}
.featured-card:hover .thumb img { transform: scale(1.03); }
.featured-card .body { padding: 32px 32px 32px 0; display: flex; flex-direction: column; justify-content: center; }
.featured-card h3 { font-size: 26px; transition: color var(--transition); }
.featured-card:hover h3 { color: var(--blue); }
.featured-card .excerpt { color: var(--ink-soft); font-size: 15.5px; }
.card-meta {
display: flex;
align-items: center;
gap: 14px;
margin-bottom: 12px;
font-family: var(--font-mono);
font-size: 12px;
color: var(--ink-soft);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.post-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 26px;
}
.post-card {
background: var(--paper);
border: 1px solid var(--line);
border-radius: var(--radius);
overflow: hidden;
display: flex;
flex-direction: column;
transition: transform var(--transition), box-shadow var(--transition);
}
.post-card:hover {
transform: translateY(-3px);
box-shadow: 0 10px 24px rgba(0,0,0,0.06);
}
.post-card .thumb { aspect-ratio: 16/9; overflow: hidden; }
.post-card .thumb img { width: 100%; height: 100%; object-fit: cover; }
.post-card .body { padding: 18px 20px 22px; flex: 1; display: flex; flex-direction: column; }
.post-card h3 { font-size: 17px; margin-bottom: 8px; transition: color var(--transition); }
.post-card:hover h3 { color: var(--blue); }
.post-card .excerpt { color: var(--ink-soft); font-size: 14.5px; flex: 1; }
@media (max-width: 900px) {
.featured-card { grid-template-columns: 1fr; }
.featured-card .body { padding: 0 24px 28px; }
.post-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
.post-grid { grid-template-columns: 1fr; }
}
.pagination {
display: flex;
justify-content: center;
gap: 10px;
margin: 44px 0 20px;
font-family: var(--font-mono);
font-size: 13px;
}
.pagination a, .pagination span {
padding: 8px 14px;
border: 1px solid var(--line);
border-radius: 6px;
color: var(--ink);
transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.pagination a:hover, .pagination a:focus-visible {
background: var(--blue);
color: #fff;
border-color: var(--blue);
}
.pagination .current { background: var(--ink); color: var(--shell); border-color: var(--ink); } .single-header { padding: 44px 0 0; }
.single-header .category-pill { margin-bottom: 14px; }
.single-header h1 {
font-size: clamp(26px, 3.4vw, 40px);
max-width: 760px;
}
.single-meta {
display: flex;
gap: 18px;
font-family: var(--font-mono);
font-size: 13px;
color: var(--ink-soft);
margin: 16px 0 28px;
}
.single-thumb {
border-radius: var(--radius);
overflow: hidden;
margin-bottom: 32px;
aspect-ratio: 16/9;
}
.single-thumb img { width: 100%; height: 100%; object-fit: cover; }
.entry-content {
max-width: 700px;
font-size: 17px;
}
.entry-content h2 { font-size: 24px; margin-top: 1.6em; }
.entry-content h3 { font-size: 19px; margin-top: 1.4em; }
.entry-content a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--blue); text-decoration-thickness: 2px; }
.entry-content ul, .entry-content ol { padding-left: 1.3em; margin-bottom: 1.1em; }
.entry-content img { border-radius: var(--radius); margin: 1.4em 0; }
.author-box {
max-width: 700px;
display: flex;
gap: 16px;
align-items: flex-start;
background: var(--paper);
border: 1px solid var(--line);
border-radius: var(--radius);
padding: 22px;
margin: 44px 0;
}
.author-box img { width: 52px; height: 52px; border-radius: 50%; }
.author-box h4 { font-size: 15px; margin-bottom: 4px; }
.author-box p { font-size: 14.5px; color: var(--ink-soft); margin: 0; } .comments-area {
max-width: 700px;
margin: 48px 0 20px;
}
.comments-title {
font-size: 20px;
margin-bottom: 20px;
}
.comment-list {
list-style: none;
margin: 0 0 36px;
padding: 0;
}
.comment-list .comment,
.comment-list .pingback {
background: var(--paper);
border: 1px solid var(--line);
border-radius: var(--radius);
padding: 18px 20px;
margin-bottom: 14px;
}
.comment-list .children {
list-style: none;
margin: 14px 0 0 28px;
padding: 0;
}
.comment-author {
display: flex;
align-items: center;
gap: 10px;
margin-bottom: 8px;
}
.comment-author .avatar {
border-radius: 50%;
width: 36px;
height: 36px;
}
.comment-author .fn {
font-style: normal;
font-weight: 600;
font-size: 14.5px;
}
.comment-metadata {
font-family: var(--font-mono);
font-size: 12px;
color: var(--ink-soft);
text-transform: uppercase;
letter-spacing: 0.04em;
}
.comment-metadata a { color: var(--ink-soft); }
.comment-content p { font-size: 15px; margin-bottom: 0.7em; }
.comment-content p:last-child { margin-bottom: 0; }
.reply {
margin-top: 10px;
}
.comment-reply-link {
font-family: var(--font-mono);
font-size: 12px;
text-transform: uppercase;
letter-spacing: 0.04em;
color: var(--blue);
border: 1px solid var(--blue);
border-radius: 999px;
padding: 5px 12px;
display: inline-block;
transition: background var(--transition), color var(--transition);
}
.comment-reply-link:hover {
background: var(--blue);
color: #fff;
}
.no-comments {
color: var(--ink-soft);
font-size: 14.5px;
} #respond, .comment-respond {
background: var(--paper);
border: 1px solid var(--line);
border-radius: var(--radius);
padding: 28px;
}
.comment-reply-title {
font-size: 18px;
margin-bottom: 4px;
}
.comment-notes {
font-size: 13.5px;
color: var(--ink-soft);
margin-bottom: 20px;
}
.comment-form p { margin-bottom: 16px; }
.comment-form label {
display: block;
font-family: var(--font-mono);
font-size: 12px;
text-transform: uppercase;
letter-spacing: 0.05em;
color: var(--ink-soft);
margin-bottom: 6px;
}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
width: 100%;
font-family: var(--font-body);
font-size: 15px;
color: var(--ink);
background: var(--shell);
border: 1px solid var(--line);
border-radius: 8px;
padding: 12px 14px;
transition: border-color var(--transition), box-shadow var(--transition);
}
.comment-form textarea { resize: vertical; }
.comment-form input:focus-visible,
.comment-form textarea:focus-visible {
outline: none;
border-color: var(--blue);
box-shadow: 0 0 0 3px color-mix(in srgb, var(--blue) 18%, transparent);
}
.comment-form-cookies-consent {
display: flex;
align-items: flex-start;
gap: 8px;
font-size: 13.5px;
color: var(--ink-soft);
}
.comment-form-cookies-consent label { margin: 0; text-transform: none; font-family: var(--font-body); letter-spacing: normal; }
.form-submit { margin-bottom: 0; }
.form-submit input[type="submit"] {
font-family: var(--font-mono);
font-size: 13px;
text-transform: uppercase;
letter-spacing: 0.05em;
color: #fff;
background: var(--blue);
border: none;
border-radius: 999px;
padding: 12px 24px;
cursor: pointer;
transition: background var(--transition), transform var(--transition);
}
.form-submit input[type="submit"]:hover {
background: #016E9B;
transform: translateY(-1px);
}
@media (max-width: 600px) {
#respond, .comment-respond { padding: 20px; }
.comment-list .children { margin-left: 14px; }
}
.archive-header {
padding: 44px 0 8px;
}
.archive-header h1 { font-size: 28px; } .site-footer {
background: var(--ink);
color: var(--shell);
margin-top: 64px;
padding: 48px 0 28px;
}
.footer-grid {
display: grid;
grid-template-columns: 1.3fr 1fr 1fr;
gap: 32px;
padding-bottom: 32px;
border-bottom: 1px solid rgba(255,255,255,0.12);
}
.footer-grid h5 {
font-family: var(--font-mono);
font-size: 12px;
text-transform: uppercase;
letter-spacing: 0.06em;
color: rgba(239,240,236,0.55);
margin-bottom: 14px;
}
.footer-grid a {
color: var(--shell);
opacity: 0.85;
display: block;
margin-bottom: 10px;
font-size: 14.5px;
}
.footer-grid a:hover { opacity: 1; }
.category-legend { display: flex; flex-wrap: wrap; gap: 12px 18px; }
.category-legend span { display: flex; align-items: center; font-size: 13px; opacity: 0.85; }
.footer-disclaimer {
font-size: 13px;
color: rgba(239,240,236,0.6);
max-width: 640px;
margin: 20px 0 0;
}
.footer-bottom {
display: flex;
justify-content: space-between;
margin-top: 20px;
font-size: 13px;
color: rgba(239,240,236,0.55);
flex-wrap: wrap;
gap: 10px;
}
@media (max-width: 780px) {
.footer-grid { grid-template-columns: 1fr; }
}