@import"https://fonts.googleapis.com/css2?family=Jaro:opsz@6..72:wght@400&display=swap";@import"https://fonts.googleapis.com/css2?family=Jaro:opsz@6..72&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#000;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{width:100%;overflow-x:hidden}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:block;width:100%;min-width:320px;min-height:100vh;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#000;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media (max-width: 768px){body{min-width:280px}h1{font-size:2.5em}button{padding:.5em 1em;font-size:.9em}}@media (max-width: 480px){body{min-width:250px}h1{font-size:2em}button{padding:.4em .8em;font-size:.8em}}html,body{width:100%;min-height:100vh;height:auto;margin:0;padding:0}.app{display:flex;flex-direction:column;position:relative;min-height:100vh;height:auto;background-color:#fff;z-index:1}.app:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url(/assets/weather-background-DMStwolN.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.2;z-index:-1}#container{display:flex;width:100%;height:auto}.header-header{width:100%;display:flex;flex-direction:row;align-items:center;justify-content:space-between;min-height:80px;margin-bottom:40px;overflow-x:hidden}.header-left{display:flex;align-items:center}.header-logo{width:80px;height:80px}.header-title{color:#1e90ff;font-weight:600;font-size:1rem;margin-left:.25rem}.header-center{display:flex;gap:25%;justify-content:center;flex:1}.header-link{color:#111;font-weight:700;font-size:1.2rem;text-decoration:none;border-radius:8px;padding:.7rem 2rem;margin:0 .5rem;transition:background .2s,color .2s}.header-link:hover{background:#fff;color:#000}.header-right{display:flex;align-items:center;padding-right:2rem}@media (max-width: 900px){.header-center{gap:1.5rem}.header-header{padding:0 .5rem}.header-logo{width:100px;height:100px}}@media (max-width: 768px){.header-header{flex-direction:column;gap:1rem;padding:1rem .5rem}.header-center{gap:1rem;order:2}.header-left{order:1}.header-right{order:3;padding-right:0}.header-link{font-size:1rem;padding:.5rem 1rem}}@media (max-width: 480px){.header-header{padding:.5rem}.header-center{gap:.5rem}.header-link{font-size:.9rem;padding:.4rem .8rem;margin:0 .2rem}.header-logo{width:80px;height:80px}.header-title{font-size:.8rem}}.navbar{height:auto;width:100%;display:flex;align-items:center;justify-content:center;padding-top:2rem;padding:2}.profile-box{height:60px;max-width:75%;padding:0 1rem;border:1px solid #444;border-radius:12px;display:flex;flex-direction:row;align-items:center;gap:.75rem;margin-bottom:2rem}.avatar{min-width:35px;min-height:35px;background-color:#3f51b5;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.profile-info{display:flex;flex-direction:column;max-width:100%;color:#fff}.email{font-size:12px;color:#ccc;text-decoration:underline}.nav-list{list-style:none;padding:0;width:100%;display:flex;flex-direction:row;justify-content:center;gap:5rem}.nav-item{border-radius:8px}.nav-link{display:flex;align-items:center;padding:12px;background-color:#111;border-radius:8px;gap:10px;color:#ccc;text-decoration:none;transition:background-color .2s ease}.nav-link:hover{background-color:#171717}.nav-item.active .nav-link{background-color:#1d1d1d}.icon{color:#ccc;min-width:20px}.header-link.active,.header-link:hover{background:#fff;color:#000}.logout-button{background:#ff7875;color:#000;border:none;cursor:pointer}.logout-button:hover{background:#ff7875;color:#000}.weather-page{padding:2rem;min-height:100vh;box-sizing:border-box}@media (max-width: 1024px){.weather-page{padding:1.5rem}}@media (max-width: 768px){.weather-page{padding:1rem}}@media (max-width: 480px){.weather-page{padding:.5rem}}@media (max-width: 768px){.large-screen-container{height:35vh!important;min-height:250px!important}.text.weather{font-size:80px!important}.room{font-size:20px!important;padding:15px!important}.room-btn{font-size:16px!important;padding:8px 16px!important}}@media (max-width: 480px){.text.weather{font-size:60px!important}.room{font-size:16px!important;padding:10px!important}.room-btn{font-size:14px!important;padding:6px 12px!important}}.status-circle{display:inline-block;border-radius:50%;border:1.5px solid #e0e0e0;box-shadow:3px 3px 8px #2c3e502e;box-sizing:content-box;flex-shrink:0}.status-circle.success{background:#b2f2bb}.status-circle.warning{background:#ffe0a3}.status-circle.danger{background:#f2b2b2}.status-circle-row{display:flex;align-items:center;gap:.75rem}.row-statistics{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;column-gap:2rem;row-gap:1rem;background:#fff0;border-radius:12px;padding:.5rem 0;width:100%;min-height:90px;box-sizing:border-box}.row-left{display:flex;flex-direction:column;gap:2.2rem;min-width:180px;flex:1 1 240px}.row-separator{width:2px;height:100px;background:linear-gradient(to bottom,#fff6f6,#888);margin:0 2rem;border-radius:8px;align-self:center;box-shadow:0 0 6px #b4b4b440;opacity:.9}.row-center{display:flex;flex-direction:column;gap:2rem;min-width:320px;flex:2 1 360px}.row-center-row{display:flex;gap:clamp(.8rem,3.5vw,3.5rem);align-items:center;width:100%;justify-content:center;padding:0 .5rem}.row-right{display:flex;flex-direction:column;gap:2rem;align-items:flex-start;flex:1 1 260px;min-width:200px;max-width:360px}.row-text{font-size:1.1rem;color:#222;font-weight:400;width:100%;text-align:right;word-break:break-word}@media (max-width: 1100px){.row-statistics{flex-direction:column;align-items:stretch;gap:1rem}.row-separator{display:none}.row-center{align-items:center}.row-left{gap:1.2rem}.row-center-row{justify-content:center}}@media (max-width: 700px){.row-statistics{flex-direction:column;align-items:stretch;padding:.5rem;min-height:auto;gap:1.5rem}.row-left{min-width:120px;gap:1.2rem}.row-separator{width:80%;height:2px;background:linear-gradient(to right,#fff6f6,#888);margin:2rem auto;border-radius:8px;box-shadow:0 0 6px #b4b4b440;opacity:.9}.row-center{min-width:180px;gap:1.2rem}.row-center-row{gap:clamp(.7rem,3vw,1.5rem);padding:0 .5rem}.row-right{align-items:flex-start;margin-left:0;min-width:120px;max-width:250px}.row-text{font-size:.95rem;text-align:left}}.modal-message{color:#000;font-size:1.1rem;margin-bottom:1rem;font-weight:500}.modal-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:#fff;border-radius:8px;padding:2rem;min-width:300px;box-shadow:0 2px 16px #0003;text-align:center}.modal-button{margin-top:1.5rem;padding:.5rem 1.5rem;border-radius:4px;border:none;background:#007bff;color:#fff;font-weight:700;cursor:pointer}.large-screen-container{position:relative;display:flex;align-items:center;justify-content:center;height:45vh;min-height:350px;width:100%;flex-shrink:0;margin:20px 0}.large-screen-container,.large-screen-container *{font-family:Jaro,serif;font-weight:400}.screen{position:relative;display:flex;align-items:center;justify-content:center;padding:5px;margin:auto;height:100%;width:70%;background-color:#bffdcab3;border:1px solid #139e24;border-radius:20px;cursor:default;z-index:1}.screen.alarm{cursor:pointer}.screen.on{background-color:#bffdcab3!important;border:1px solid #139e24}.screen.off{background-color:#e4414db3!important;border:1px solid #e4414d}.screen.weather{background-color:#bffdcab3!important;border:1px solid #139e24}.room{position:absolute;top:0;left:0;padding:30px;font-size:32px;background:none;border:none;z-index:2;pointer-events:auto}.room:focus{outline:none;box-shadow:none;border:none;background:none}.text{font-size:250px}.text.alarm{font-size:100px!important}.text.weather{font-size:clamp(72px,9vw,150px)!important}.room-column{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:16px;z-index:2;padding-right:30px}.room-btn{border:none;background-color:initial;color:#000;border:1px solid #000;border-radius:8px;padding:12px 24px;font-size:24px;cursor:pointer;transition:all .2s ease}.room-btn:hover:not(.disabled){background-color:#000;color:#fff}.room-btn.selected{background-color:#000;color:#fff}.room-btn.disabled{opacity:.5;cursor:not-allowed;background-color:#ccc;color:#666;border-color:#999}.room-btn.disabled:hover{background-color:#ccc;color:#666;border-color:#999}@media (max-width: 800px){.large-screen-container{flex-direction:column;align-items:center;justify-content:center;height:auto;min-height:350px}.room-column{position:static;transform:none;flex-direction:row;gap:12px;padding:20px 0;order:2}.text.alarm{font-size:50px!important}.text.weather{font-size:80px!important}.screen{width:90%}.alarm-history-item{font-size:15px!important;border-left:1px solid #000;padding-left:10px}.alarm-history-container{gap:10px}}@media (max-width: 600px){.large-screen-container{height:auto;min-height:300px;margin:10px 0}.screen{width:95%}.text.weather{font-size:60px!important}.room{font-size:18px;padding:20px}.room-column{gap:8px;padding:15px 0}.room-btn{font-size:18px;padding:8px 16px}}@media (max-width: 300px){.text.alarm{font-size:30px!important}}.container-wrapper{display:flex;flex-direction:column;flex:1;overflow:hidden;gap:16px;height:100%}.room-selector{padding:16px;background-color:#ffffffe6;border-radius:8px;margin:16px;flex-shrink:0}.room-selector h3{margin:0 0 16px;color:#333;font-size:18px}.room-list{display:flex;gap:12px;flex-wrap:wrap}.room-button{padding:10px 20px;border:2px solid #139e24;background-color:#fff;color:#139e24;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.room-button:hover{background-color:#139e24;color:#fff}.room-button.selected{background-color:#139e24;color:#fff;box-shadow:0 2px 8px #139e244d}.selected-room-info{padding:16px;text-align:center;flex-shrink:0}.selected-room-info h2{margin:0;color:#333;font-size:24px;font-weight:600}.alarm-history-container{margin:24px;height:200px;max-height:200px;background-color:#bffdcab3;border:1px solid #139e24;overflow-y:auto;color:#000;display:flex;font-size:20px;gap:3px;flex-direction:column;padding:16px;width:-webkit-fill-available;flex-shrink:0}.alarm-history-container.on{background-color:#bffdcab3!important;border:1px solid #139e24}.alarm-history-container.off{background-color:#e4414db3!important;border:1px solid #e4414d}.alarm-history-empty{text-align:center;color:#666;font-style:italic;padding:20px}.container-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;width:100%;padding:2rem 1rem}.login-container{margin:0 auto;background:#fffc;padding:40px;border-radius:12px;display:flex;flex-direction:column;align-items:center;width:100%;max-width:520px}.login-container h2{margin-bottom:20px;color:#333}.login-container input{width:100%;padding:10px;margin-bottom:15px;border:1px solid #ccc;border-radius:8px;font-size:16px}.login-container button{border:none;background-color:#c8f5d6;color:#139e24;border-radius:8px;cursor:pointer;font-size:16px;width:100%}.login-container button:hover{background-color:#b5f5c9}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;padding:10px;color:red;font-size:14px;margin-bottom:10px;width:100%}@media (max-width: 480px){.login-container{padding:24px}}.backoffice-container{padding:2rem;max-width:1200px;margin:0 auto;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.backoffice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.backoffice-header h1{color:#333;margin:0;font-size:2rem;font-weight:600}.create-user-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.create-user-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.users-table-container{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;overflow:hidden}.users-table{width:100%;border-collapse:collapse;font-size:.95rem}.users-table thead{background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.users-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.users-table td{padding:1rem;border-bottom:1px solid #f0f0f0;vertical-align:middle;color:#000}.users-table tbody tr:hover{background-color:#f8f9fa;transition:background-color .2s ease}.role-badge{padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:capitalize}.role-admin{background-color:#ff6b6b;color:#fff}.role-moderator{background-color:#4ecdc4;color:#fff}.role-user{background-color:#45b7d1;color:#fff}.action-buttons{display:flex;gap:8px}.edit-btn,.delete-btn,.assign-btn{padding:8px 16px;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.edit-btn{background-color:#ffa726;color:#fff}.edit-btn:hover{background-color:#ff9800;transform:translateY(-1px)}.edit-btn:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.delete-btn{background-color:#ef5350;color:#fff}.delete-btn:hover{background-color:#e53935;transform:translateY(-1px)}.delete-btn:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.assign-btn{background-color:#4caf50;color:#fff}.assign-btn:hover{background-color:#45a049;transform:translateY(-1px)}.assign-btn:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal{background:#fff;border-radius:12px;padding:2rem;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal h2{margin:0 0 1.5rem;color:#333;font-size:1.5rem;font-weight:600}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.form-group input,.form-group select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:2rem}.modal-actions button{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.modal-actions button:first-child{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-actions button:last-child{background-color:#f5f5f5;color:#666;border:1px solid #ddd}.modal-actions button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}@media (max-width: 768px){.backoffice-container{padding:1rem}.backoffice-header{flex-direction:column;gap:1rem;text-align:center}.backoffice-header h1{font-size:1.5rem}.users-table-container{overflow:visible;border-radius:8px}.users-table{width:100%;font-size:.85rem}.users-table th:first-child,.users-table td:first-child{display:none}.users-table th,.users-table td{padding:.75rem .5rem;color:#000;word-wrap:break-word;max-width:120px}.action-buttons{flex-direction:column;gap:4px;min-width:120px}.edit-btn,.delete-btn,.assign-btn{padding:6px 12px;font-size:.8rem;width:100%}.modal{width:95%;padding:1.5rem}}@media (max-width: 480px){.backoffice-container{padding:.5rem}.backoffice-header h1{font-size:1.25rem}.create-user-btn{padding:10px 20px;font-size:.9rem}.users-table{font-size:.8rem}.users-table th,.users-table td{padding:.5rem .25rem;max-width:100px}.action-buttons{min-width:100px}.edit-btn,.delete-btn,.assign-btn{padding:4px 8px;font-size:.75rem}}@media (min-width: 769px) and (max-width: 1024px){.backoffice-container{padding:1.5rem}.users-table{font-size:.9rem}.users-table th,.users-table td{padding:.875rem .75rem}.action-buttons{gap:6px}.edit-btn,.delete-btn,.assign-btn{padding:7px 14px;font-size:.9rem}}.users-table-container::-webkit-scrollbar{height:8px}.users-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.users-table-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.users-table-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;background:#fff5f5;border:1px solid #fed7d7;border-radius:12px;margin:2rem 0}.error-message{color:#e53e3e;font-weight:500;margin-bottom:1rem}.error-container button{background:#e53e3e;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.error-container button:hover{background:#c53030}.rooms-selection{margin-bottom:1.5rem}.rooms-selection h3{margin:0 0 1rem;color:#333;font-size:1.1rem;font-weight:500}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;max-height:300px;overflow-y:auto;padding:1rem;border:1px solid #e0e0e0;border-radius:8px;background-color:#f9f9f9}.room-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fff;border-radius:6px;border:1px solid #e0e0e0;transition:all .2s ease}.room-checkbox:hover{background-color:#f0f0f0;border-color:#667eea}.room-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.room-checkbox label{font-weight:500;color:#333;cursor:pointer;flex:1;margin:0}@media (max-width: 768px){.rooms-grid{grid-template-columns:1fr;max-height:250px}.assign-btn{padding:6px 12px;font-size:.8rem}.modal{width:95%;max-width:none;margin:1rem;padding:1.5rem;max-height:90vh;overflow-y:auto}.modal h2{font-size:1.3rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{font-size:.9rem;margin-bottom:.4rem}.form-group input,.form-group select{padding:10px;font-size:.9rem}.modal-actions{margin-top:1.5rem;gap:8px}.modal-actions button{padding:10px 20px;font-size:.9rem;flex:1}}@media (max-width: 480px){.modal{width:98%;margin:.5rem;padding:1rem;max-height:95vh}.modal h2{font-size:1.2rem;margin-bottom:.8rem}.form-group{margin-bottom:.8rem}.form-group label{font-size:.85rem}.form-group input,.form-group select{padding:8px;font-size:.85rem}.modal-actions{margin-top:1.2rem;gap:6px}.modal-actions button{padding:8px 16px;font-size:.85rem}.rooms-selection h3{font-size:1rem;margin-bottom:.8rem}.rooms-grid{max-height:200px;padding:.8rem;gap:.8rem}.room-checkbox{padding:.4rem}.room-checkbox input[type=checkbox]{width:16px;height:16px}.room-checkbox label{font-size:.85rem}}.portfolio-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:relative;z-index:1;width:100%;overflow-x:hidden}.hero-section{display:flex;align-items:center;justify-content:space-between;padding:80px 5%;min-height:80vh;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:relative;z-index:2;transform:translateZ(0);will-change:transform}.hero-content{flex:1;max-width:600px;position:relative;z-index:3}.hero-title{font-size:4rem;font-weight:700;margin-bottom:20px;color:#fff;position:relative;z-index:4}.hero-subtitle{font-size:1.5rem;margin-bottom:40px;opacity:.9;line-height:1.6;position:relative;z-index:4}.hero-buttons{display:flex;gap:20px;flex-wrap:wrap;position:relative;z-index:4}.btn-primary,.btn-secondary{padding:15px 30px;border:none;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;position:relative;z-index:5}.btn-primary{background:linear-gradient(45deg,#ff6b6b,#ee5a24);color:#fff;box-shadow:0 4px 15px #ff6b6b66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b99}.btn-secondary{background:transparent;color:#fff;border:2px solid white}.btn-secondary:hover{background:#fff;color:#667eea;transform:translateY(-2px)}.hero-image{width:700px}.smart-room-preview{position:relative;width:400px;height:300px;background:#ffffff1a;border-radius:20px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transform:translateZ(0);will-change:transform}.room-element{position:absolute;width:60px;height:60px;border-radius:50%;background:linear-gradient(45deg,#ff6b6b,#ee5a24);animation:pulse 2s infinite;transform:translateZ(0);will-change:transform}.room-element.sensor{top:20px;left:20px;background:linear-gradient(45deg,#4ecdc4,#44a08d)}.room-element.alarm{top:20px;right:20px;background:linear-gradient(45deg,#ff6b6b,#ee5a24)}.room-element.weather{bottom:20px;left:20px;background:linear-gradient(45deg,#74b9ff,#0984e3)}.room-element.office{bottom:20px;right:20px;background:linear-gradient(45deg,#a29bfe,#6c5ce7)}@keyframes pulse{0%{transform:scale(1) translateZ(0)}50%{transform:scale(1.1) translateZ(0)}to{transform:scale(1) translateZ(0)}}.features-section{padding:100px 5%;background:#ffffff0d;position:relative;z-index:2;transform:translateZ(0);will-change:transform}.section-title{text-align:center;font-size:3rem;margin-bottom:60px;font-weight:700;position:relative;z-index:3}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px;max-width:1200px;margin:0 auto;position:relative;z-index:3}.feature-card{background:#ffffff1a;padding:40px 30px;border-radius:20px;text-align:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:transform .3s ease;position:relative;z-index:4;transform:translateZ(0);will-change:transform}.feature-card:hover{transform:translateY(-10px) translateZ(0)}.feature-icon{font-size:3rem;margin-bottom:20px;position:relative;z-index:5}.feature-card h3{font-size:1.5rem;margin-bottom:15px;font-weight:600;position:relative;z-index:5}.feature-card p{line-height:1.6;opacity:.9;position:relative;z-index:5}.how-it-works-section{padding:100px 5%;position:relative;z-index:2;transform:translateZ(0);will-change:transform}.steps-container{max-width:1000px;margin:0 auto;position:relative;z-index:3}.step{display:flex;align-items:center;margin-bottom:60px;gap:30px;position:relative;z-index:4}.step:nth-child(2n){flex-direction:row-reverse}.step-number{width:80px;height:80px;background:linear-gradient(45deg,#ff6b6b,#ee5a24);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0;position:relative;z-index:5;transform:translateZ(0);will-change:transform}.step-content{flex:1;position:relative;z-index:5}.step-content h3{font-size:1.8rem;margin-bottom:15px;font-weight:600;position:relative;z-index:6}.step-content p{font-size:1.1rem;line-height:1.6;opacity:.9;position:relative;z-index:6}.tech-section{padding:100px 5%;background:#ffffff0d;position:relative;z-index:2;transform:translateZ(0);will-change:transform}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;max-width:1000px;margin:0 auto;position:relative;z-index:3}.tech-card{background:#ffffff1a;padding:30px;border-radius:15px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);position:relative;z-index:4;transform:translateZ(0);will-change:transform}.tech-card h4{font-size:1.5rem;margin-bottom:20px;font-weight:600;text-align:center;position:relative;z-index:5}.tech-card ul{list-style:none;padding:0;position:relative;z-index:5}.tech-card li{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1);text-align:center;position:relative;z-index:6}.tech-card li:last-child{border-bottom:none}.cta-section{padding:100px 5%;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;z-index:2;transform:translateZ(0);will-change:transform}.cta-content{position:relative;z-index:3}.cta-content h2{font-size:3rem;margin-bottom:20px;font-weight:700;position:relative;z-index:4}.cta-content p{font-size:1.3rem;margin-bottom:40px;opacity:.9;position:relative;z-index:4}@media (max-width: 768px){.hero-section{flex-direction:column;text-align:center;padding:60px 5%}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.2rem}.hero-buttons{justify-content:center}.hero-image{width:60vw;max-width:380px;height:auto}.smart-room-preview{width:300px;height:200px;margin-top:40px}.section-title{font-size:2rem}.step{flex-direction:column;text-align:center}.step:nth-child(2n){flex-direction:column}.cta-content h2{font-size:2rem}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero-image{width:70vw;max-width:260px;height:auto}.features-grid,.tech-grid{grid-template-columns:1fr}}*{box-sizing:border-box}.portfolio-container *{backface-visibility:hidden;-webkit-backface-visibility:hidden}@supports (backdrop-filter: blur(10px)){.hero-section,.smart-room-preview,.feature-card,.tech-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}}@supports not (backdrop-filter: blur(10px)){.hero-section,.smart-room-preview,.feature-card,.tech-card{background:#ffffff26}}.pnf-container{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);overflow:hidden;width:100%}.pnf-background{position:absolute;top:0;right:0;bottom:0;left:0;background:url(/assets/weather-background-DMStwolN.jpg) center/cover no-repeat;opacity:.12}.pnf-content{position:relative;z-index:1;text-align:center;padding:2rem;max-width:520px;width:90%}.pnf-logo{width:64px;height:64px;object-fit:contain;margin-bottom:1rem}.pnf-title{font-size:5rem;margin:0;line-height:1;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.pnf-subtitle{color:#333;margin:.5rem 0 1.5rem}.pnf-actions{display:flex;gap:12px;justify-content:center}.pnf-button{padding:12px 20px;border-radius:10px;border:1px solid #ddd;color:#333;background:#fff;text-decoration:none;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.pnf-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.pnf-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}@media (max-width: 480px){.pnf-title{font-size:3.5rem}.pnf-actions{flex-direction:column}.pnf-button{width:100%;text-align:center}}
