@font-face{font-family:instrument sans;src:url(/fonts/InstrumentSans.woff2)format('woff2');font-weight:400 700;font-style:normal;font-display:swap}@font-face{font-family:instrument sans;src:url(/fonts/InstrumentSans-Italic.woff2)format('woff2');font-weight:400 700;font-style:italic;font-display:swap}@font-face{font-family:figtree;src:url(/fonts/Figtree.woff2)format('woff2');font-weight:300 900;font-style:normal;font-display:swap}@font-face{font-family:figtree;src:url(/fonts/Figtree-Italic.woff2)format('woff2');font-weight:300 900;font-style:italic;font-display:swap}.theme-transition-disabled,.theme-transition-disabled *{transition:none !important}:root{--logo-casita-color:#18BCF2;--esphome-color:#00bfff;--primary-color:#00bfff;--secondary-color:#00979d;--heading-color:#222222;--text-color:#444444;--text-secondary:#666666;--background-color:#fafbfc;--surface-color:#f2f4f8;--card-bg:#ffffff;--border-color:#d8dce4;--link-accent:#007FA8;--hover-overlay:rgba(0, 0, 0, 0.05);--btn-primary-color:#00a8e0;--btn-primary-hover-color:var(--esphome-color);--btn-text-color:#fff;--btn-secondary-bg:#e8ebf0;--btn-secondary-hover-color:#dce0e6;--shadow-sm:0 1px 3px rgba(0, 0, 0, 0.04);--shadow-md:0 2px 8px rgba(0, 0, 0, 0.08);--shadow-lg:0 4px 12px rgba(0, 0, 0, 0.08);--font-body:"Instrument Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--font-heading:"Figtree", system, -apple-system, ".SFNSText-Regular", "San Francisco", "Roboto", "Segoe UI", "Helvetica Neue", "Lucida Grande", sans-serif;--font-mono:"SFMono-Regular", Consolas, "Liberation Mono", Menlo, Courier, monospace;--mobile-width-stop:1000px;--nav-height:4rem;--max-page-width:90rem;--grid-gap:1.5rem;--grid-gap-sm:0.75rem;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--icon-sm:0.875rem;--icon-md:1.5rem;--radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--transition-fast:150ms ease;--nav-transition-up:transform 0.3s ease;--nav-transition-down:transform 0.1s ease-out;--sidebar-background:var(--surface-color);--feature-card-bg:var(--card-bg);--feature-card-text:var(--text-color);--feature-card-text-secondary:rgba(0, 0, 0, 0.55);--feature-icon-color:var(--esphome-color);--getting-started-bg:var(--surface-color);--getting-started-text:var(--text-color);--nav-bg:var(--surface-color);--nav-text:var(--text-color);--dropdown-bg:var(--card-bg);--dropdown-hover-bg:var(--surface-color);--dropdown-text:var(--text-color);--footer-bg:var(--surface-color);--footer-text:var(--text-color);--component-card-bg:var(--card-bg);--component-card-text:var(--text-color);--component-card-text-bg:var(--surface-color);--blockquote-bg:var(--surface-color);--blockquote-border:var(--primary-color);--nav-version-bg:rgba(0, 127, 168, 0.1);--nav-version-bg-hover:rgba(0, 127, 168, 0.2);--nav-version-text:var(--link-accent);--alert-caution:#ff0000;--alert-important:var(--text-color);--alert-note:#5dade2;--alert-tip:#7cb342;--alert-warning:#b8860b}[data-theme=dark]{--primary-color:#1f2937;--esphome-color:#00bfff;--heading-color:#f0f0f3;--text-color:#d0d0d6;--text-secondary:#9898a0;--background-color:#13161a;--surface-color:#1e2228;--card-bg:#1e2228;--border-color:#2d333c;--link-accent:#3db8dc;--hover-overlay:rgba(255, 255, 255, 0.1);--btn-secondary-bg:#282d35;--btn-secondary-hover-color:#323840;--shadow-sm:0 1px 3px rgba(0, 0, 0, 0.2);--shadow-md:0 2px 8px rgba(0, 0, 0, 0.3);--shadow-lg:0 4px 12px rgba(0, 0, 0, 0.4);--sidebar-background:#1a1e24;--feature-card-text-secondary:rgba(212, 212, 216, 0.65);--nav-bg:#1a1e24;--dropdown-bg:#252a32;--dropdown-hover-bg:#2d333c;--footer-bg:#1a1e24;--component-card-text-bg:#1a1e24;--logo-text-color:var(--text-color);--blockquote-bg:#1a1e24;--blockquote-border:var(--text-color);--nav-version-bg:rgba(61, 184, 220, 0.12);--nav-version-bg-hover:rgba(61, 184, 220, 0.2)}[data-theme=dark] .nav-version{border-color:rgba(255,255,255,.1)}.dark-only{display:none}[data-theme=dark] .dark-only{display:block}[data-theme=dark] .light-only{display:none}*{box-sizing:border-box;margin:0;padding:0}html{height:100%;margin:0;overscroll-behavior:none}html,body{scroll-padding-top:calc(var(--nav-height) + 1rem)}body{min-height:100vh;margin:0;font-family:var(--font-body);line-height:1.6;color:var(--text-color);background-color:var(--background-color);overscroll-behavior:none;display:flex;flex-direction:column}.body{visibility:initial}a{color:var(--link-accent);text-decoration:none}a:hover{text-decoration:underline}strong{font-weight:600}em,i,figcaption{font-style:italic}h1,h2,h3,h4,h5,h6,.footer-heading,.getting-started-heading,.feature-text{font-family:var(--font-heading);font-weight:600;margin:1em 0 .5em;color:var(--heading-color)}h1{font-size:2rem;line-height:1.5}h2{font-size:1.5rem;line-height:1.5}h3{font-size:1.25rem;line-height:1.5}h4{font-size:1rem;line-height:1.5}h5{font-size:.875rem;line-height:1.5;text-transform:uppercase;letter-spacing:.05em}h6{font-size:.75rem;line-height:1.5;text-transform:uppercase;letter-spacing:.05em}p{margin-top:.5em;margin-bottom:.5em}.getting-started-grid{margin-top:1.5em}ul,ol{margin:0 0 1em 1.5em}code{font-family:var(--font-mono);background-color:var(--sidebar-background);border-radius:var(--radius-sm);font-size:.9em;color:var(--text-color)}[data-theme=dark] code{color:var(--heading-color)}pre{background-color:var(--sidebar-background);padding:1em;border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow-x:auto;margin-bottom:1em}pre code{background-color:transparent;padding:0}img{max-width:100%;max-height:50rem;height:auto;width:auto}.h-100{height:100%}.w-100{width:100%}img{margin-left:auto;margin-right:auto}img.align-left,figure.align-left,.figure.align-left,object.align-left{clear:left;float:left;margin-right:1em}img.align-right,figure.align-right,.figure.align-right,object.align-right{clear:right;float:right;margin-left:1em}.copy-link{background:0 0;border:none;cursor:pointer;padding:.2em;margin-left:0;opacity:.4;transform-origin:center;transition:opacity var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.copy-link:hover{opacity:1}.copy-link-icon,.copy-link-check{width:1em;height:1em}.copy-link-check{display:none}.copy-link.copied .copy-link-icon{display:none}.copy-link.copied .copy-link-check{display:inline}.branch-overlay{pointer-events:none;display:block;font-size:4em;color:#ff808080;z-index:99999;position:fixed;bottom:0;right:6rem}.external-link{background:0 0;border:none;cursor:pointer;vertical-align:middle;padding-bottom:.1em;margin-left:.2em;width:1em;height:1em}.sidebar-content{background-color:var(--sidebar-background);padding:var(--space-lg)var(--space-lg)0;border-radius:var(--radius-lg)}.sidebar-content.scroll-trap{top:var(--nav-height);max-height:calc(100vh - var(--nav-height));position:sticky;overflow-y:auto;overflow-x:hidden;overscroll-behavior:none;transition:top .3s ease,max-height .3s ease;& h3 { margin-top: 0; }}.nav-container.nav-hidden~main .sidebar-content.scroll-trap{top:0;max-height:100vh}.sidebar-logo{margin-bottom:1.5em}.sidebar-logo img{height:1.875rem}.sidebar-search{margin-bottom:1.5em}.sidebar-search input{width:100%;padding:.5em;border:1px solid var(--border-color);border-radius:var(--radius-lg)}.sidebar-nav h3{margin-top:0;margin-bottom:.5em;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.sidebar-nav ul,.sidebar-nav ol{list-style:none;margin:0 0 .5em;& ul { list-style: none; margin-bottom: 0; margin-left: 0.75em; } & ol { list-style: none; margin-bottom: 0; margin-left: 0.75em; }}.sidebar-nav li{margin-bottom:.5em;& li { margin-bottom: 0; }}.sidebar-nav a{display:block;padding:0;color:var(--link-accent)}.sidebar-nav a.active{font-weight:700;color:var(--primary-color)}.toc-separator{overflow-wrap:break-word}.sidebar-contact{border-top:1px solid var(--border-color);padding-top:1.5em}.sidebar-social{list-style:none;margin:0}.sidebar-social li{margin-bottom:.5em}.sidebar-social a{display:flex;align-items:center}.sidebar-social i{margin-right:.5em}.page-toc{list-style-type:none;padding-left:0;margin-bottom:var(--space-lg);font-size:1rem;line-height:1.5}.page-toc ul{list-style-type:none;padding-left:0;margin-top:.125rem;margin-left:.75rem;border-left:1px solid var(--border-color)}.page-toc>li{margin-bottom:.125rem}.page-toc li li{margin-bottom:0}.toc-level-1>a{font-weight:500}.toc-level-2>a,.toc-level-3>a,.toc-level-4>a,.toc-level-5>a,.toc-level-6>a{font-weight:400;color:var(--text-secondary)}.page-toc a{color:var(--text-color);display:block;text-decoration:none;padding:.25rem 0 .25rem .75rem;transition:color var(--transition-fast)}.page-toc>li>a{border-left:2px solid transparent;margin-left:-2px;transition:color var(--transition-fast),border-color var(--transition-fast)}.page-toc ul a{margin-left:-1px;border-left:2px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast)}.page-toc a:hover{color:var(--link-accent);border-left-color:var(--border-color);text-decoration:none}.page-toc a.active{color:var(--link-accent);border-left-color:var(--link-accent);font-weight:500}.nav-container{background-color:var(--background-color);box-shadow:none;position:fixed;top:0;width:100%;z-index:1000;transition:var(--nav-transition-down);border-bottom:1px solid var(--border-color)}.nav-container.nav-scrolling-up{transition:var(--nav-transition-up)}.nav-container.nav-hidden{transform:translateY(-100%)}.sticky-nav{max-width:var(--max-page-width);display:flex;justify-content:space-between;align-items:center;padding:0 2em 0 3em;margin:0 auto;color:var(--text-color);border:none;height:var(--nav-height);box-sizing:border-box}.sticky-nav .dropbtn svg{height:1.1em;width:1.1em;margin-right:.5em;& path { fill: var(--text-color); }}.nav-logo{display:flex;align-items:center;gap:.5em}.nav-logo a{display:flex;align-items:center}.nav-logo img,.nav-logo svg{height:var(--icon-md);max-width:9rem;padding:0;width:fit-content}.nav-version{font-size:.7em;font-weight:500;color:var(--nav-version-text);background:var(--nav-version-bg);padding:.25em .6em;border-radius:var(--radius-lg);white-space:nowrap;margin-left:.35em;letter-spacing:.02em;border:1px solid rgba(0,0,0,8%);text-decoration:none;transition:background-color var(--transition-fast)}.nav-version:hover{background:var(--nav-version-bg-hover);text-decoration:none}.nav-links{display:flex;align-items:center}.nav-links a{font-family:var(--font-body)}.hamburger-button{display:none;background:0 0;border:none;cursor:pointer;z-index:1001;padding:.5rem;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.hamburger-button:hover{background-color:var(--hover-overlay)}.hamburger-button svg{width:var(--icon-md);height:var(--icon-md)}.hamburger-button svg path{fill:var(--nav-text)}.hamburger-button .menu-icon{display:block}.hamburger-button .close-icon{display:none}.hamburger-button[aria-expanded=true] .menu-icon{display:none}.hamburger-button[aria-expanded=true] .close-icon{display:block}.toc-button{background:0 0;border:none;cursor:pointer;padding:.5rem;color:var(--nav-text);display:none;border-radius:var(--radius-md);transition:background-color var(--transition-fast);line-height:0}.toc-button svg{width:var(--icon-md);height:var(--icon-md);display:block;fill:var(--nav-text)}.toc-button:hover{background-color:var(--hover-overlay)}.dropdown{position:relative;margin-right:1em}.dropbtn{background-color:transparent;color:var(--nav-text);border:none;cursor:pointer;padding:.5em .75em;font-size:1em;text-decoration:none;font-weight:400;font-family:var(--font-body)}.dropbtn:hover{text-decoration:underline;color:var(--link-accent)}.dropbtn:has(.theme-toggle){padding:.5em}.dropdown-content{display:none;position:absolute;background-color:var(--dropdown-bg);min-width:12.5rem;box-shadow:var(--shadow-md);z-index:1;border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.dropdown-content a{color:var(--text-color);padding:.625em 1em;display:block;transition:background-color 150ms ease,color 150ms ease}.dropdown-content a:hover{background-color:var(--dropdown-hover-bg);color:var(--heading-color)}.nav-search{margin-left:1.25rem;position:relative}#nav-search-container{position:relative;display:inline-flex;align-items:center;height:2.125rem;padding:0 .75rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);background-color:var(--background-color);width:11rem;transition:width 200ms ease,border-color 150ms ease,box-shadow 150ms ease}#nav-search-container .search-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:.5rem;pointer-events:none;line-height:0}#nav-search-container .search-icon svg{width:var(--icon-sm);height:var(--icon-sm);fill:var(--text-secondary);display:block}.nav-search .pagefind-ui__form{margin:0;flex:1;display:flex;align-items:center}.nav-search .pagefind-ui__search-input{height:auto;padding:0;border:none;border-radius:0;font-size:.875rem;width:100%;background-color:transparent;color:var(--text-color);flex:1;line-height:1.5;vertical-align:middle}.nav-search .pagefind-ui__search-input::placeholder{color:var(--text-secondary)}.nav-search .pagefind-ui__search-input::selection{background-color:var(--link-accent);color:var(--btn-text-color)}#nav-search-container:has(.pagefind-ui__search-input:focus){width:15rem;border-color:var(--link-accent);box-shadow:0 0 0 3px rgba(0,127,168,.1)}.nav-search .pagefind-ui__search-input:focus{outline:none}#nav-search-results ul,.nav-search .pagefind-ui__drawer ul{list-style:none;padding:0;margin:0}.pagefind-modular-list-result{overflow-wrap:anywhere;border:none !important;border-bottom:1px solid var(--border-color) !important;padding:.75em 0}.pagefind-modular-list-result:last-child{border-bottom:none}.pagefind-modular-list-result:first-child{padding-top:0}.search-clear-button{position:absolute;right:.625rem;top:.5rem;background:0 0;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:50%;color:var(--text-color);opacity:.5;font-size:.75rem;transition:background-color var(--transition-fast),opacity var(--transition-fast);z-index:10}.search-clear-button:hover{background-color:var(--hover-overlay);opacity:1}.nav-search .pagefind-ui__search-clear{width:2.25rem;height:2.25rem;background-position:50%;background-repeat:no-repeat;background-size:var(--icon-sm)}.nav-search .pagefind-ui__drawer{position:absolute;top:var(--nav-height);right:0;width:25rem;max-height:80vh;overflow-y:auto;overscroll-behavior:none;background:var(--sidebar-background);color:var(--text-color);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:1002;padding:var(--space-md)}#nav-search-results{display:none;position:absolute;top:var(--nav-height);right:0;width:25rem;max-height:80vh;overflow-y:auto;overscroll-behavior:none;background:var(--sidebar-background);color:var(--text-color);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:1002;padding:var(--space-md)}.theme-toggle{margin:0;background:0 0;border:none;color:var(--text-color);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:background-color var(--transition-fast),color var(--transition-fast);display:grid;place-items:center;width:2.25rem;height:2.25rem;aspect-ratio:1}.theme-toggle:hover{color:var(--link-accent);background:var(--hover-overlay)}.theme-toggle .sun-icon,.theme-toggle .moon-icon{display:none}.theme-toggle svg{height:var(--icon-md);width:auto;fill:currentColor;margin:0 !important;display:block}[data-theme=dark] .moon-icon,[data-theme=light] .sun-icon{display:contents}[data-theme=dark]{.dark-invert img { filter: invert(1); } img.dark-invert { filter: invert(1.0); } svg.dark-invert { filter: invert(1.0); } .sticky-nav { color: var(--text-color); } .nav-links a, .dropbtn { color: var(--text-color); } .nav-links a:hover, .dropbtn:hover { color: var(--esphome-color); } .toc-button { color: var(--text-color); } .content { background: var(--background-color); color: var(--text-color); overflow: auto; } body { background-color: var(--background-color); } main { background-color: var(--background-color); } .dropdown-content { background: var(--dropdown-bg); box-shadow: var(--shadow-md); } .dropdown-content a { color: var(--text-color); } .dropdown-content a:hover { background: var(--dropdown-hover-bg); color: var(--heading-color); } .footer, .footer-content { background: var(--footer-bg); color: var(--footer-text); } footer { background-color: var(--footer-bg); } .footer a, .footer-content a { color: var(--link-accent); } .footer-column .footer-heading { color: var(--footer-text); } .footer-column svg path { fill: var(--link-accent); } .footer a:hover, .footer-content a:hover { color: var(--link-accent); } .note, .tip, .warning, .caution, .important { color: var(--text-color); border-color: var(--secondary-color); } .overlay { background: rgba(20,20,20,0.7); } #nav-search-results, .nav-search .pagefind-ui__drawer { background: var(--dropdown-bg); color: var(--text-color); } #nav-search-container { background-color: var(--surface-color); border-color: var(--border-color); } #nav-search-container:has(.pagefind-ui__search-input:focus) { border-color: var(--esphome-color); background-color: var(--dropdown-bg); } .nav-search .pagefind-ui__search-input { background-color: transparent; color: var(--text-color); } .nav-search .pagefind-ui__search-input:focus { outline: none; } .nav-search .pagefind-ui__search-input::placeholder { color: var(--text-secondary); } .nav-search .pagefind-ui__search-input::selection { background-color: var(--esphome-color); color: var(--btn-text-color); } #nav-search-container .search-icon svg { fill: var(--text-color); } .feature-icon { color: var(--feature-icon-color) !important; } .feature-card h2, .feature-card h3 { color: var(--feature-card-text) !important; } .feature-card p { color: var(--feature-card-text-secondary) !important; } .feature-card a:hover { color: var(--link-accent) !important; } .getting-started-block { background: var(--getting-started-bg) !important; color: var(--getting-started-text) !important; border-color: var(--border-color); } .feature-card { border: 1px solid var(--border-color); background: var(--feature-card-bg); color: var(--feature-card-text); } .btn-secondary { color: var(--text-color); }}.getting-started-heading{font-weight:600;font-size:1.25em;margin:0 0 .75em;line-height:1.4;color:var(--feature-card-text)}.feature-card .getting-started-heading+p{margin:0 0 1em;flex:1}.page-container{display:flex;flex-direction:column;min-height:100vh;width:100%}main{max-width:var(--max-page-width);width:100%;margin:0 auto;padding-left:2em;padding-right:2em;margin-top:var(--nav-height);flex:1;background-color:var(--background-color);display:flex;flex-direction:column}main.homepage{padding-bottom:2em}.content-container{display:flex;gap:var(--grid-gap);overflow:visible;flex:1;min-width:0}.sidebar{width:18.75rem;flex-shrink:0;background-color:var(--sidebar-background);color:var(--text-color);border-color:var(--border-color);border-right:1px solid var(--border-color);overflow:visible;position:relative}.sidebar::before{content:'';position:absolute;top:0;bottom:0;right:100%;width:50vw;background-color:var(--sidebar-background);pointer-events:none}.sidebar-fixed{position:relative;z-index:1;overflow:visible}.sidebar-resource{position:sticky;bottom:0;background-color:var(--sidebar-background);padding-top:1em;padding-bottom:1.5em;margin-top:1.5em}.sidebar-resource hr{margin-bottom:1em;border-color:var(--border-color);background:0 0;border-style:solid;border-width:1px 0 0}.sidebar-resource svg,.sidebar-resource img{height:.8em;width:.8em;margin-right:.5em;& path { fill: var(--link-accent); }}.content{flex-grow:1;min-width:0;margin-top:2em;margin-bottom:2em}.content-container .content{margin-top:var(--space-lg)}.content-container .content>:first-child{margin-top:0}.content svg{max-width:37.5rem}.hero-container{display:flex;align-items:center;margin-top:var(--space-xl)}.hero-content{flex:1}.hero-content h1{margin-top:0;margin-bottom:.75rem;text-wrap:balance}.hero-content p{margin-bottom:var(--space-xl)}.hero-img{flex:1;text-align:center;max-width:50rem}.casita{fill:var(--logo-casita-color,#18BCF2)}.hero-img img{max-width:100%}.cta-buttons{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:.75rem}.cta-buttons a{white-space:nowrap}.btn{padding:.7rem 1.4rem;border-radius:1.5rem;font-weight:600;font-size:.9375rem;line-height:1.25;cursor:pointer;transition:background-color var(--transition-fast),box-shadow var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:.5em;border:none;text-decoration:none}a.btn,a.btn:hover{text-decoration:none}.btn-primary{background-color:var(--btn-primary-color);color:var(--btn-text-color)}.btn-primary:hover{background-color:var(--esphome-color)}a.btn-primary,a.btn-primary:hover{color:var(--btn-text-color)}.btn-secondary{background-color:var(--surface-color);border:1px solid var(--border-color);color:var(--text-color)}.btn-secondary:hover{background-color:var(--btn-secondary-hover-color)}a.btn-secondary,a.btn-secondary:hover{color:var(--text-color)}.home-section{margin-bottom:3em}summary::marker{font-size:1.5em}summary h4.shown{margin-left:1em;display:inline}blockquote{border-left:.25em solid var(--blockquote-border);border:1px solid var(--border-color);border-left-width:.25em;border-radius:var(--radius-lg);padding:.5em 1em;margin:1em 0;background-color:var(--blockquote-bg)}blockquote.alert-caution{border-left-color:var(--alert-caution)}blockquote.alert-caution p.alert-heading{color:var(--alert-caution)}blockquote.alert-important{border-left-color:var(--alert-important)}blockquote.alert-important p.alert-heading{color:var(--alert-important)}blockquote.alert-note{border-left-color:var(--alert-note)}blockquote.alert-note p.alert-heading{color:var(--alert-note)}blockquote.alert-tip{border-left-color:var(--alert-tip)}blockquote.alert-tip p.alert-heading{color:var(--alert-tip)}blockquote.alert-warning{border-left-color:var(--alert-warning)}blockquote.alert-warning p.alert-heading{color:var(--alert-warning)}.alert p.alert-heading{font-weight:600;margin:.5em 0;display:flex;align-items:center;gap:.5em}.alert-icon{display:flex;align-items:center;flex-shrink:0}.alert-icon svg{height:1.2em;width:1.2em;fill:currentColor;display:block}.option{padding-top:.2em;padding-left:1em;padding-right:1em;padding-bottom:1em}.option-title{display:block;padding-bottom:1em}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(15.5rem,1fr));gap:var(--grid-gap);margin-bottom:var(--space-md);margin-top:var(--space-xl)}.feature-card{background:var(--feature-card-bg);color:var(--feature-card-text);border:1px solid var(--border-color);padding:1.5em;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:flex-start}.feature-icon{font-size:2em;color:var(--primary-color);margin-bottom:.75em;flex-shrink:0}.feature-icon svg{height:1.5em;width:1.5em;& path { fill: var(--esphome-color); }}.feature-text{font-weight:600;font-size:1.25em;margin:0 0 .75em;line-height:1.4;color:var(--feature-card-text)}.feature-card p{margin:0 0 1em;flex:1;color:var(--feature-card-text-secondary)}.getting-started-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(18.75rem,1fr));gap:var(--grid-gap)}.getting-started-card{padding:1.5em;border-radius:var(--radius-lg);background:var(--getting-started-bg) !important;color:var(--getting-started-text) !important;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.getting-started-card h3{margin-top:0}.getting-started-card .btn{margin-top:auto;width:100%}.getting-started-card .btn-secondary,.feature-card .btn-secondary{background-color:var(--background-color)}.getting-started-card .btn-secondary:hover,.feature-card .btn-secondary:hover{background-color:var(--surface-color)}footer{position:relative;z-index:1;background-color:var(--footer-bg);color:var(--footer-text);border-top:1px solid var(--border-color)}.footer-content{padding:3rem 2rem 2rem;max-width:var(--max-page-width);margin:0 auto;display:flex;flex-wrap:wrap;gap:2rem;position:relative;align-items:flex-start}.footer-links{display:flex;flex-flow:row wrap;gap:2rem;justify-content:center;margin-left:auto;margin-right:auto}.footer-logo{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;flex-grow:2}.footer-logo a.footer-logo{display:flex;flex-direction:column;gap:.75rem}.footer-logo img{max-width:12.5rem;height:auto}.footer-logo span{color:var(--footer-text);margin-bottom:.5rem}.footer-content a{color:var(--link-accent);text-decoration:none;font-size:1rem;line-height:1.5rem}.footer-content a:hover{text-decoration:underline}.footer-column{padding-top:0;margin-top:0}.footer-column .footer-heading{margin-top:0 !important;margin-bottom:.5rem;font-size:.875rem;font-weight:700;text-transform:uppercase;color:var(--footer-text);letter-spacing:.025em}.footer-column ul{list-style:none;margin:0;padding:0}.footer-column li{padding-bottom:.5rem;line-height:1.5rem}.footer-column svg{height:1em;width:1em;margin-right:.5em;vertical-align:-.125em;& path { fill: var(--link-accent); }}.footer-bottom{max-width:var(--max-page-width);margin:var(--space-xl)auto 0;padding-top:var(--space-md);border-top:1px solid var(--border-color);text-align:center;color:var(--footer-text)}.push-right{margin-left:auto}.component-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));grid-auto-rows:5rem;gap:var(--space-sm);margin-bottom:var(--space-xl)}.cta-buttons{display:flex;flex-flow:row wrap;justify-content:flex-start;gap:var(--grid-gap-sm)}.cta-buttons .btn{flex:none}.component-card{background-color:var(--surface-color);border-radius:var(--radius-lg);padding:0;text-align:center;overflow-wrap:break-word;display:block;width:100%;height:100%;font-family:var(--font-heading);font-weight:500;color:var(--component-card-text);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:transform 150ms ease,box-shadow 150ms ease,border-color 150ms ease;overflow:hidden}.component-card a{width:100%;height:100%;display:flex;flex-direction:row;align-items:center;position:relative;padding:0}.component-text{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;text-align:left;padding:.5rem .75rem .5rem 0;flex:1}.component-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--link-accent)}.component-icon{flex:0 0 4rem;width:4rem;height:4rem;display:flex;align-items:center;justify-content:center;padding:0;margin:.5rem}.component-icon figure{margin:0;padding:0}.component-icon img{width:auto;height:auto;min-width:3rem;min-height:3rem;max-width:3rem;max-height:3rem;object-fit:contain;display:block}.component-name{font-weight:600;font-size:1rem;line-height:1.3;padding:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex-shrink:0}.component-caption{font-family:var(--font-body);font-size:.8125rem;font-weight:400;line-height:1.3;margin-top:.25rem;padding:0;color:var(--text-secondary);overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;flex-shrink:1}.component-card h2,.component-card h3,.component-card p,.component-card a{color:var(--component-card-text) !important;text-decoration:none}.component-card a:hover{color:var(--component-card-text) !important;text-decoration:none}figure{margin-bottom:1em;margin-left:auto;margin-right:auto}figure img{max-height:31.25rem;object-fit:contain;width:auto;border-radius:var(--radius-lg)}figcaption{margin-top:.75em;font-size:.9em;color:var(--text-secondary);font-style:italic;line-height:1.4;max-width:80%;margin-left:auto;margin-right:auto}.center{display:block;margin-left:auto;margin-right:auto}.overlay{position:fixed;top:var(--nav-height);left:0;right:0;bottom:0;background:rgba(0,0,0,.3);display:none;z-index:998}.overlay.show{display:block}@media(min-width:1001px){.overlay.show,.sidebar-mobile{display:none}.dropdown:hover .dropdown-content{display:block}}@media(max-width:700px){.desktop-only{display:none}.dropdown-content{position:relative;width:100%;top:0;right:0}.nav-links.active{overflow-y:auto;overscroll-behavior:none}.cta-buttons{flex-direction:column}.cta-buttons .btn{width:100%;text-align:center}.component-grid{grid-template-columns:1fr}}.theme-picker-mobile{display:none}@media(max-width:1000px){.sidebar-fixed{display:none}.sticky-nav{padding:.5em 1em}.theme-toggle{margin-right:0}.hamburger-button{display:block}.hamburger-button .menu-icon,.hamburger-button .close-icon{width:var(--icon-md);height:var(--icon-md);line-height:0}.hamburger-button .close-icon{display:none}.hamburger-button[aria-expanded=true] .menu-icon{display:none}.hamburger-button[aria-expanded=true] .close-icon{display:block}.nav-search{margin-left:auto;margin-right:.625rem;position:relative}.nav-links{position:absolute;top:100%;left:0;right:0;background-color:var(--background-color);flex-direction:column;align-items:stretch;padding:.5rem;box-shadow:var(--shadow-lg);display:flex;gap:0;scrollbar-width:none;-ms-overflow-style:none;clip-path:inset(0 0 100% 0);pointer-events:none;transition:clip-path .2s ease;z-index:10000}.nav-links.active{clip-path:inset(0 0 -20px 0);pointer-events:auto}.nav-links .nav-link{display:block;padding:.625rem .75rem;border-radius:var(--radius-md);color:var(--text-color);font-weight:500;font-size:.9375rem;transition:background-color var(--transition-fast)}.nav-links .nav-link:hover{background-color:var(--dropdown-hover-bg);text-decoration:none}.nav-links>.theme-toggle-desktop{display:none}.theme-picker-mobile{order:100;display:flex;align-items:center;justify-content:space-between;margin-top:.5rem;padding:.75rem;border-top:1px solid var(--border-color)}.theme-picker-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.theme-picker-options{display:flex;gap:0;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.125rem}.theme-option{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:0 0;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.theme-option svg{width:var(--icon-sm);height:var(--icon-sm);fill:currentColor}.theme-option:hover{color:var(--text-color)}.theme-option.active{background-color:var(--background-color);color:var(--text-color);box-shadow:var(--shadow-sm)}.dropdown{position:relative;margin-right:0;margin-bottom:0;width:100%}.dropbtn{width:100%;position:relative;text-align:left;padding:.625rem .75rem;border-radius:var(--radius-md);font-weight:500;font-size:.9375rem;color:var(--text-color);transition:background-color var(--transition-fast)}.dropbtn:hover{background-color:var(--dropdown-hover-bg)}.dropdown-content{position:static;box-shadow:none;background:0 0;border:none;margin-top:0;padding:0 0 .25rem .75rem}.dropdown-content a{display:block;padding:.5rem .75rem;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem}.dropdown-content a:hover{background-color:var(--dropdown-hover-bg);color:var(--text-color);text-decoration:none}.nav-links .nav-search{order:-1;margin:0 0 .5rem;padding:0 0 .5rem;border-bottom:1px solid var(--border-color)}.nav-links .nav-search #nav-search-container{width:100%}.nav-links .nav-search .search-icon{left:.625rem}.nav-links .nav-search .search-icon svg{width:var(--space-md);height:var(--space-md)}.content-container{flex-direction:column}.toc-button{display:block}.sidebar-content{position:static}.hero-container{flex-direction:column;text-align:center}.hero-content{margin-bottom:2em}.cta-buttons{justify-content:center}.footer-content{flex-direction:column;padding:2rem 1.5rem;gap:1.5rem}.footer-logo{order:-1}.footer-links{flex-direction:column;align-items:flex-start;gap:1.5rem;margin-left:0}.footer-column{width:100%}.sidebar{position:fixed;top:var(--nav-height);left:-100%;width:85%;max-width:20rem;height:calc(100% - var(--nav-height));background-color:var(--background-color);transition:left .2s ease;padding:0;overflow-y:auto;overscroll-behavior:none;box-shadow:var(--shadow-md);z-index:999}.sidebar .sidebar-content{padding:1rem;background-color:transparent}.sidebar .sidebar-resource{position:static;padding-top:.5rem;padding-bottom:0;margin-top:.5rem;background-color:transparent}.sidebar.open{left:0}}details{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:0;margin:var(--space-md)0}@supports(interpolate-size:allow-keywords){details{interpolate-size:allow-keywords}}details summary{padding:.625rem 1rem;cursor:pointer;font-weight:500;font-size:.9375rem;color:var(--text-color);list-style:none;display:flex;align-items:center;gap:.5rem;transition:color 150ms ease}details summary:hover{color:var(--heading-color)}details summary::before{content:"";width:.4rem;height:.4rem;border-right:1.5px solid;border-bottom:1.5px solid;transform:rotate(-45deg);transition:transform 150ms ease;opacity:.7}details[open] summary::before{transform:rotate(45deg)}details summary::-webkit-details-marker{display:none}details>ul{padding:0 1rem 1rem 2rem;margin:0}details>ul li{padding:.25rem 0}@supports selector(::details-content){details::details-content{block-size:0;transition:content-visibility,block-size;transition-duration:.3s;transition-behavior:allow-discrete;overflow:hidden}details[open]::details-content{block-size:auto}@media(prefers-reduced-motion){details::details-content{transition-duration:.8s}}}.code-block{position:relative;clear:both}.copy-button{position:absolute;top:.75rem;right:.75rem;padding:.375rem;background:var(--feature-card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-color);transition:background-color var(--transition-fast),border-color var(--transition-fast);z-index:1}.copy-button:hover{background-color:var(--btn-secondary-hover-color);border-color:var(--btn-primary-color)}.copy-button:active{transform:scale(.95)}.copy-button svg{width:var(--icon-sm);height:var(--icon-sm)}.copy-button .copy-check{display:none}.copy-button.copied .copy-icon{display:none}.copy-button.copied .copy-check{display:block}.build-info{position:absolute;text-align:left;top:.5rem;left:.5rem}.build-info-button{background-color:rgba(255,255,255,.1);color:#fff;border:none;padding:.5rem .75rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;transition:background-color var(--transition-fast)}.build-info-button:hover{background-color:rgba(255,255,255,.2)}.build-info-button:active{transform:scale(.98)}.build-info-popup{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,.5)}.build-info-content{background-color:var(--background-color);color:var(--text-color);margin:15% auto;padding:1.25rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);width:80%;max-width:31.25rem;position:relative;display:flex;flex-flow:column;align-items:center}.build-info-close{color:var(--text-color);position:absolute;right:.625rem;top:0;font-size:1.75rem;font-weight:700;cursor:pointer}.build-info-close:hover{color:var(--primary-color)}.build-info-content h4{margin-top:0;color:var(--text-color)}.build-info-content p{margin:.625rem 0}.build-info-content a{color:var(--link-accent)}@media(max-width:768px){.build-info-content{width:90%;margin:30% auto}}.build-info-grid{display:grid;grid-template-columns:1fr 2fr;gap:.625rem;margin-top:1rem}.build-info-label{text-align:right;font-weight:700;padding-right:.625rem}.build-info-value{text-align:left}.header-print,.footer-logo-print{display:none}@media print{.nav-container,footer,.sidebar,.copy-button{display:none}[aria-hidden=true]{display:none}.footer-logo-print{display:block}.header-print{display:block;margin-left:auto;margin-right:auto;width:12.5rem}}