@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600&family=Lora:wght@500;600&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px);background:#fffc;border-bottom:1px solid #e5e7eb99;transition:box-shadow .3s,background .3s;position:fixed;top:0;left:0;right:0;box-shadow:0 1px 8px #0000000f}.navbar.scrolled{background:#fffffff2;box-shadow:0 2px 20px #0000001a}.navbar-inner{align-items:center;gap:0;max-width:1280px;height:64px;margin:0 auto;padding:0 24px;display:flex}.navbar-logo{cursor:pointer;flex-shrink:0;align-items:center;gap:10px;margin-right:24px;text-decoration:none;display:flex}.navbar-logo-img{object-fit:contain;border-radius:8px;width:36px;height:36px}.navbar-logo-text-wrap{flex-direction:column;line-height:1.1;display:flex}.navbar-logo-main{background:linear-gradient(135deg,#1d9e75,#378add);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:800}.navbar-logo-sub{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.navbar-links{flex:1;justify-content:center;align-items:center;gap:2px;display:flex}.nav-link{color:#6b7280;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;padding:7px 11px;font-size:13.5px;font-weight:500;transition:all .2s;position:relative}.nav-link:hover{color:#1d9e75;background:#1d9e7514}.nav-link.active{color:#1d9e75;font-weight:600}.nav-link.active:after{content:"";background:#1d9e75;border-radius:2px;width:20px;height:2px;position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}.navbar-right{flex-shrink:0;align-items:center;gap:8px;margin-left:24px;display:flex}.notif-wrapper{position:relative}.nav-bell{cursor:pointer;background:#1d9e7514;border:none;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;transition:background .2s;display:flex;position:relative}.nav-bell:hover{background:#1d9e7529}.notif-badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 3px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.nav-logout{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#1d9e75,#16a34a);border:none;border-radius:10px;padding:8px 18px;font-size:13.5px;font-weight:600;transition:opacity .2s,transform .1s}.nav-logout:hover{opacity:.9;transform:translateY(-1px)}.hamburger{cursor:pointer;color:#374151;background:0 0;border:none;border-radius:8px;margin-left:8px;padding:6px 8px;font-size:20px;display:none}.hamburger:hover{background:#f3f4f6}@media (width<=960px){.hamburger{align-items:center;display:flex}.navbar-links{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffffa;border-bottom:1px solid #e5e7eb;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:2px;padding:8px 16px 16px;display:none;position:absolute;top:64px;left:0;right:0;box-shadow:0 8px 24px #00000014}.navbar-links.open{display:flex}.nav-link{text-align:left;width:100%;padding:11px 16px;font-size:14px}.nav-link.active:after{display:none}.navbar-right{margin-left:auto}}.notif-dropdown{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:1000;background:#fffffffa;border:1px solid #e5e7eb;border-radius:16px;width:320px;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;box-shadow:0 8px 32px #0000001f}.notif-dropdown-header{color:#111827;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:14px 16px;font-size:14px;font-weight:600;display:flex}.notif-lihat-semua{color:#1d9e75;cursor:pointer;background:0 0;border:none;font-size:12px;font-weight:500}.notif-lihat-semua:hover{text-decoration:underline}.notif-dropdown-item{border-bottom:1px solid #f3f4f6;gap:10px;padding:12px 16px;transition:background .15s;display:flex}.notif-dropdown-item:last-child{border-bottom:none}.notif-dropdown-item.unread{background:#f0fdf4}.notif-dropdown-item:hover{background:#f9fafb}.notif-dropdown-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.notif-dropdown-content{flex:1}.notif-dropdown-msg{color:#374151;margin-bottom:4px;font-size:12px;line-height:1.4}.notif-dropdown-time{color:#9ca3af;font-size:11px}.notif-empty{text-align:center;color:#9ca3af;padding:24px;font-size:14px}body{padding-top:64px}.landing h1,.landing h2,.landing h3{font-family:Playfair Display,Georgia,serif}.scroll-animate{opacity:0;will-change:opacity, transform;backface-visibility:hidden;transition:opacity .55s,transform .55s;transform:translateY(24px)}.scroll-animate.scroll-visible{opacity:1;transform:translateY(0)}.landing{background:var(--white);width:100%;min-height:100vh;position:relative;overflow-x:hidden}.landing-nav{z-index:1000;will-change:transform;background:0 0;border-bottom:1px solid #0000;grid-template-columns:1fr auto 1fr;align-items:center;width:100%;height:62px;padding:0 32px;transition:background .35s,border-color .35s,box-shadow .35s,transform .4s cubic-bezier(.4,0,.2,1);display:grid;position:fixed;top:0;left:0;right:0}.landing-nav.nav-scrolled{-webkit-backdrop-filter:blur(20px)saturate(160%);background:#05140fb8;border-bottom-color:#ffffff14;box-shadow:0 1px 32px #00000040}.landing-nav.nav-hidden{transform:translateY(-100%)}.landing-nav-left{justify-content:flex-start;align-items:center;display:flex}.nav-logo-img{object-fit:contain;filter:drop-shadow(0 0 6px #1d9e7580);width:34px;height:34px;transition:filter .2s}.nav-logo-img:hover{filter:drop-shadow(0 0 10px #1d9e75d9)}.landing-nav-center{justify-content:center;align-items:center;display:flex}.nav-title{color:#ffffffe6;letter-spacing:.01em;white-space:nowrap;font-family:Playfair Display,Georgia,serif;font-size:15px;font-weight:400}.nav-title strong{color:#fff;font-weight:700}.landing-nav-right{justify-content:flex-end;align-items:center;display:flex}.landing-nav-btn{background:var(--teal);color:#fff;cursor:pointer;font-size:13.5px;font-weight:600;font-family:var(--font);border:none;border-radius:999px;align-items:center;gap:7px;padding:8px 22px;transition:background .18s,transform .15s,box-shadow .18s;display:inline-flex;box-shadow:0 2px 12px #1d9e7559}.landing-nav-btn:hover{background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 4px 20px #1d9e7580}.landing-nav-btn:active{transform:translateY(0)}.nav-btn-dot{background:#fffc;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite nav-dot-pulse}@keyframes nav-dot-pulse{0%,to{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.landing-hero{align-items:flex-end;width:100%;min-height:100vh;margin-top:0;padding-top:0;display:flex;position:relative;overflow:hidden}.hero-bg-photo{z-index:0;position:absolute;inset:-1px 0 0}.hero-bg-img{object-fit:cover;object-position:center;opacity:0;pointer-events:none;width:100%;height:100%;transition:opacity .35s;position:absolute;inset:0}.hero-bg-img.hero-slide-active{opacity:1}.hero-bg-img.hero-slide-in{animation:.38s forwards hero-slide-in}.hero-bg-img.hero-slide-out-left{animation:.32s forwards hero-slide-out-left}.hero-bg-img.hero-slide-out-right{animation:.32s forwards hero-slide-out-right}.hero-bg-img.hero-slide-hidden{opacity:0}@keyframes hero-slide-in{0%{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}@keyframes hero-slide-out-left{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-48px)}}@keyframes hero-slide-out-right{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(48px)}}.hero-arrow{z-index:10;-webkit-backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#ffffff14;border:1.5px solid #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;transition:background .18s,border-color .18s,transform .18s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.hero-arrow:hover{background:#1d9e7573;border-color:#1d9e75b3;transform:translateY(-50%)scale(1.08)}.hero-arrow-left{left:24px}.hero-arrow-right{right:24px}.hero-slide-dots{z-index:10;align-items:center;gap:8px;display:flex;position:absolute;bottom:56px;left:50%;transform:translate(-50%)}.hero-slide-dot{cursor:pointer;background:#fff6;border:none;border-radius:50%;width:7px;height:7px;padding:0;transition:background .2s,width .25s}.hero-slide-dot.active{background:var(--teal);border-radius:4px;width:22px}.hero-bg-placeholder{background:radial-gradient(70% 60% at 70% 40%,#1d9e752e 0%,#0000 60%),linear-gradient(160deg,#0d1f1a 0%,#1a2e28 40%,#0a1510 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.hero-bg-placeholder-inner{color:#ffffff59;font-size:13px;font-family:var(--font);text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.hero-bg-placeholder-inner .hint{color:#fff3;font-size:11px}.hero-bg-placeholder-inner code{background:#ffffff14;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:10px}.hero-overlay{z-index:1;background:linear-gradient(90deg,#05140fc7 0%,#05140f73 55%,#05140f26 100%),linear-gradient(#0000 45%,#05140f8c 100%);position:absolute;inset:0}.landing-hero-content{z-index:2;max-width:680px;padding:0 80px 100px;position:relative}.landing-badge{color:#5dcaa5;letter-spacing:.03em;background:#1d9e7540;border:1px solid #1d9e754d;border-radius:20px;margin-bottom:20px;padding:5px 14px;font-size:12px;font-weight:500;display:inline-block}.landing-hero-content h1{color:#fff;text-shadow:0 2px 20px #0000004d;margin-bottom:20px;font-size:clamp(36px,5vw,62px);font-weight:700;line-height:1.12}.landing-hero-content h1 em{color:#5dcaa5;font-style:italic}.landing-hero-content p{color:#ffffffb8;max-width:500px;margin-bottom:36px;font-size:16px;line-height:1.7}.landing-hero-btns{flex-wrap:wrap;gap:12px;display:flex}.btn-primary{background:var(--teal);color:#fff;cursor:pointer;font-size:15px;font-family:var(--font);border:none;border-radius:8px;padding:13px 26px;font-weight:500;transition:background .15s,transform .1s,box-shadow .15s;box-shadow:0 4px 14px #1d9e7559}.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 6px 20px #1d9e7566}.btn-secondary{color:#ffffffd9;cursor:pointer;font-size:15px;font-family:var(--font);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff40;border-radius:8px;padding:12px 24px;font-weight:500;transition:background .15s,border-color .15s,transform .1s}.btn-secondary:hover{background:#ffffff2e;border-color:#fff6;transform:translateY(-1px)}.hero-sensor-card{z-index:3;-webkit-backdrop-filter:blur(24px);background:#ffffff1a;border:1px solid #ffffff40;border-radius:20px;min-width:260px;padding:20px 24px 16px;position:absolute;bottom:100px;right:80px;box-shadow:0 8px 40px #00000059,inset 0 1px #ffffff26}.hero-sensor-card .hero-card-header span{color:#fffc}.hero-sensor-card .metric-num{color:#fff}.hero-sensor-card .metric-lbl{color:#ffffff8c}.hero-sensor-card .metric-bar{background:#ffffff1f}.hero-sensor-card .hero-uptime{color:#ffffff80;border-top:1px solid #ffffff1a;padding-top:8px}.hero-sensor-card .hero-card-live{color:#4ade80;background:#1d9e754d;border:1px solid #1d9e7566}.hero-card-header{color:var(--gray-600);align-items:center;gap:8px;margin-bottom:16px;font-size:13px;display:flex}.hero-card-live{letter-spacing:.08em;color:var(--teal);background:var(--teal-light);border:1px solid #1d9e7533;border-radius:4px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:700}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot.green{background:var(--teal);animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 0 3px #1d9e7533}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 3px #1d9e7533}50%{box-shadow:0 0 0 6px #1d9e7512}}.hero-metrics{align-items:stretch;gap:0;margin-bottom:14px;display:flex}.metric-item{flex:1;padding:0 4px}.metric-divider{background:#1d9e751f;flex-shrink:0;width:1px;margin:0 14px}.metric-num{color:var(--gray-800);margin-bottom:4px;font-family:Playfair Display,Georgia,serif;font-size:26px;font-weight:700;line-height:1}.metric-lbl{color:var(--gray-400);margin-bottom:7px;font-size:11px}.metric-bar{background:#1d9e751a;border-radius:2px;width:100%;height:3px;overflow:hidden}.metric-bar-fill{border-radius:2px;height:100%}.hero-uptime{color:var(--teal);align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.uptime-dot{background:var(--teal);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:1.8s ease-in-out infinite pulse-dot;display:inline-block}.uptime-label{color:var(--gray-400);font-weight:400}.hero-scroll-hint{z-index:3;color:#fff6;letter-spacing:.1em;text-transform:uppercase;flex-direction:column;align-items:center;gap:4px;font-size:10px;transition:opacity .1s linear;animation:2s ease-in-out infinite bounce;display:flex;position:absolute;bottom:36px;left:50%;transform:translate(-50%)}.scroll-arrow{font-size:14px}@keyframes bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(5px)}}.section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:10px;font-size:11px;font-weight:600}.landing-features{text-align:center;background:#f9fafb;border-top:1px solid #1d9e7514;width:100%;padding:88px 80px}.landing-features h2{color:var(--gray-800);margin-bottom:12px;font-size:30px;font-weight:700}.features-sub{color:var(--gray-600);max-width:500px;margin-bottom:52px;margin-left:auto;margin-right:auto;font-size:15px;line-height:1.65}.features-grid{grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto;display:grid}.feature-card{background:var(--white);text-align:left;border:1.5px solid #1d9e751a;border-radius:14px;padding:32px 26px;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 2px 10px #0000000a}.feature-card:hover{border-color:#1d9e7547;transform:translateY(-5px);box-shadow:0 12px 32px #1d9e751f}.feature-icon-wrap{background:#1d9e7514;border:1px solid #1d9e7526;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:18px;display:flex}.feature-card h3{color:var(--gray-800);margin-bottom:10px;font-size:16px;font-weight:700}.feature-card p{color:var(--gray-600);font-size:14px;line-height:1.65}.feature-badge{color:var(--teal);background:var(--teal-light);border-radius:6px;margin-top:14px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.landing-dashboard{background:var(--white);border-top:1px solid #0000000f;grid-template-columns:1fr 1.3fr;align-items:center;gap:72px;width:100%;padding:96px 80px;display:grid}.dashboard-left h2{color:var(--gray-800);margin-bottom:16px;font-size:34px;font-weight:700;line-height:1.2}.dashboard-left h2 em{color:var(--teal);font-style:italic}.dashboard-left p{color:var(--gray-600);margin-bottom:24px;font-size:15px;line-height:1.7}.dashboard-checklist{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.dashboard-checklist li{color:var(--gray-700);align-items:center;gap:10px;font-size:14px;display:flex}.check-icon{width:20px;height:20px;color:var(--teal);background:#1d9e751a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.dashboard-mockup{background:var(--white);border:1px solid #00000014;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #00000014,0 0 0 1px #0000000a}.mockup-header{background:#f8f9fa;border-bottom:1px solid #0000000f;align-items:center;gap:10px;padding:12px 16px;display:flex}.mockup-dots{gap:5px;display:flex}.mockup-dots span{border-radius:50%;width:10px;height:10px;display:block}.mockup-dots span:first-child{background:#ff5f57}.mockup-dots span:nth-child(2){background:#ffbd2e}.mockup-dots span:nth-child(3){background:#28c840}.mockup-title{color:#888;text-align:center;flex:1;font-size:12px;font-weight:500}.mockup-live{color:var(--teal);align-items:center;gap:5px;font-size:11px;font-weight:600;display:flex}.chart-block{padding:16px 20px 0}.chart-label-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.chart-val{font-family:Playfair Display,Georgia,serif;font-size:14px;font-weight:700}.chart-val.current{color:var(--teal)}.chart-val.warning{color:#f59e0b}.chart-area{position:relative}.chart-svg{width:100%;height:auto;display:block}.chart-x-labels{justify-content:space-between;padding:4px 0 0;display:flex}.chart-x-labels span{color:#bbb;font-size:9px}.mockup-status-row{flex-wrap:wrap;gap:8px;padding:14px 20px 16px;display:flex}.status-pill{border-radius:6px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.status-pill.green{color:var(--teal);background:#1d9e751a}.status-pill.amber{color:#d97706;background:#f59e0b1a}.status-pill.tg{color:#2563eb;background:#2563eb14}.landing-proof{border-top:1px solid #0000000f;grid-template-columns:1.1fr .9fr;width:100%;min-height:560px;padding:0;display:grid}.proof-photo-wrap{min-height:560px;position:relative;overflow:hidden}.proof-photo{object-fit:cover;width:100%;height:100%;display:block}.proof-photo-placeholder{background:radial-gradient(70% 50% at 50% 60%,#1d9e7538 0%,#0000 65%),linear-gradient(160deg,#0d2318 0%,#1a3828 50%,#0a1f12 100%);justify-content:center;align-items:center;width:100%;height:100%;min-height:560px;display:flex}.proof-placeholder-inner{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.proof-placeholder-text{color:#fff6;font-size:14px;font-weight:500}.proof-placeholder-hint{color:#fff3;font-size:11px}.proof-placeholder-hint code{background:#ffffff12;border-radius:4px;padding:2px 6px;font-family:monospace}.proof-photo-overlay{pointer-events:none;background:linear-gradient(90deg,#0000 60%,#ffffff14 100%);position:absolute;inset:0}.proof-stat-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;border:1px solid #ffffff4d;border-radius:12px;align-items:center;gap:10px;min-width:170px;padding:12px 16px;display:flex;position:absolute;box-shadow:0 8px 32px #00000026}.proof-stat-1{bottom:80px;left:24px}.proof-stat-2{bottom:28px;left:210px}.proof-stat-3{top:30%;left:5%}.proof-stat-4{top:30%;right:5%}.proof-stat-5{bottom:12%;right:5%}.proof-stat-icon{font-size:22px}.proof-stat-num{color:var(--gray-800);margin-bottom:2px;font-size:13px;font-weight:700;line-height:1}.proof-stat-lbl{color:var(--gray-500);font-size:11px}.proof-content{background:#f9fafb;flex-direction:column;justify-content:center;padding:80px 64px;display:flex}.proof-content h2{color:var(--gray-800);margin-bottom:16px;font-size:34px;font-weight:700;line-height:1.2}.proof-content h2 em{color:var(--teal);font-style:italic}.proof-content p{color:var(--gray-600);max-width:380px;margin-bottom:28px;font-size:15px;line-height:1.7}.proof-metrics{gap:32px;margin-bottom:32px;display:flex}.proof-metric{flex-direction:column;gap:4px;display:flex}.proof-metric-num{color:var(--teal);font-family:Playfair Display,Georgia,serif;font-size:22px;font-weight:700}.proof-metric-lbl{color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.landing-cta{color:#fff;text-align:center;background:radial-gradient(60% 80% at 15%,#157a5ab3 0%,#0000 65%),radial-gradient(50% 60% at 85% 30%,#1d9e7580 0%,#0000 60%),linear-gradient(145deg,#1d9e75 0%,#0f6e56 60%,#085041 100%);width:100%;padding:0;position:relative;overflow:hidden}.cta-wave-top{width:100%;line-height:0;display:block}.cta-wave-top svg{width:100%;height:70px;display:block}.cta-wave-bottom{width:100%;line-height:0;display:block}.cta-wave-bottom svg{width:100%;height:70px;display:block}.cta-bg-deco{pointer-events:none;position:absolute;inset:0;overflow:hidden}.cta-orb{border-radius:50%;position:absolute}.cta-orb-1{background:#ffffff0d;border:1px solid #ffffff1a;width:380px;height:380px;top:-120px;right:-60px}.cta-orb-2{background:#ffffff0a;border:1px solid #ffffff14;width:220px;height:220px;bottom:20px;left:8%}.cta-orb-3{background:#ffffff08;width:120px;height:120px;top:30%;left:40%}.cta-content{z-index:1;max-width:700px;margin:0 auto;padding:56px 80px 64px;position:relative}.cta-icon-wrap{background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:24px;display:inline-flex}.landing-cta h2{margin-bottom:14px;font-size:32px;font-weight:700}.landing-cta p{opacity:.88;margin-bottom:36px;font-size:16px;line-height:1.65}.cta-actions{margin-bottom:40px}.btn-cta{color:var(--teal);cursor:pointer;font-size:16px;font-family:var(--font);background:#fff;border:none;border-radius:10px;padding:14px 36px;font-weight:600;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px #00000026}.btn-cta:hover{transform:translateY(-3px);box-shadow:0 8px 32px #0003}.cta-stats{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff26;border-radius:14px;justify-content:center;align-items:center;gap:0;padding:16px 24px;display:flex}.cta-stat{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.cta-stat-num{color:#fff;font-family:Playfair Display,Georgia,serif;font-size:18px;font-weight:700}.cta-stat-lbl{color:#ffffffa6;text-transform:uppercase;letter-spacing:.06em;font-size:11px}.cta-stat-divider{background:#fff3;flex-shrink:0;width:1px;height:36px;margin:0 8px}.landing-footer{background:var(--gray-800);width:100%;color:var(--gray-400);justify-content:space-between;align-items:center;padding:32px 80px;font-size:13px;display:flex}.landing-footer strong{color:#fff;margin-bottom:4px;font-size:14px;display:block}@media (width<=1024px){.landing-dashboard{grid-template-columns:1fr;gap:40px;padding:72px 48px}.landing-proof{grid-template-columns:1fr}.proof-photo-wrap,.proof-photo-placeholder{min-height:400px}}@media (width<=900px){.landing-hero-content{padding:0 32px 80px}.hero-sensor-card{bottom:80px;right:24px}.hero-arrow-left{left:12px}.hero-arrow-right{right:12px}.landing-features{padding:64px 32px}.features-grid{grid-template-columns:1fr}.cta-content{padding:48px 32px 56px}.landing-footer{padding:24px 32px}.proof-content{padding:48px 32px}}@media (width<=600px){.landing-nav{height:56px;padding:0 16px}.nav-title{font-size:13px}.landing-nav-btn{padding:7px 16px;font-size:12.5px}.landing-hero-content{padding:0 20px 80px}.landing-hero-content h1{font-size:32px}.hero-sensor-card{display:none}.hero-arrow{width:36px;height:36px}.hero-arrow-left{left:8px}.hero-arrow-right{right:8px}.landing-features,.cta-content{padding:56px 20px}.landing-footer{text-align:center;flex-direction:column;gap:12px;padding:24px 20px}.cta-stats{flex-direction:column;gap:12px}.cta-stat-divider{width:40px;height:1px;margin:0}.proof-stat-2{display:none}.landing-dashboard{padding:56px 20px}.proof-content{padding:40px 20px}}[class*=scroll-animate-]{opacity:0;transition:opacity .6s,transform .6s cubic-bezier(.22,1,.36,1)}.scroll-animate-slide-left{transform:translate(-60px)}.scroll-animate-slide-right{transform:translate(60px)}.scroll-animate-fade-down{transform:translateY(-40px)}.scroll-animate-zoom{transform:scale(.92)}.scroll-animate-flip{transform:perspective(600px)rotateY(25deg)}.scroll-animate-slide-left.scroll-visible,.scroll-animate-slide-right.scroll-visible,.scroll-animate-fade-down.scroll-visible,.scroll-animate-zoom.scroll-visible,.scroll-animate-flip.scroll-visible{opacity:1;transform:none}.scroll-animate-delay-1{transition-delay:.1s}.scroll-animate-delay-2{transition-delay:.22s}.scroll-animate-delay-3{transition-delay:.34s}.lm-overlay{z-index:999;background:#0f172ab3;justify-content:center;align-items:center;padding:16px;animation:.25s both lm-bg-fade;display:flex;position:fixed;inset:0}@keyframes lm-bg-fade{0%{opacity:0}to{opacity:1}}.lm-card{background:#fff;border-radius:16px;width:100%;max-width:380px;padding:36px 32px;animation:.45s cubic-bezier(.22,1,.36,1) both cardFadeIn;position:relative;box-shadow:0 8px 32px #0000001f,0 1px 4px #0000000d}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(24px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.lm-close{cursor:pointer;color:#9caba6;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px;transition:background .15s,color .15s;position:absolute;top:16px;right:16px}.lm-close:hover{color:#3a6050;background:#f0f4f2}.lm-fish-wrap{justify-content:center;align-items:center;width:110px;height:110px;margin:0 auto 18px;animation:.55s cubic-bezier(.22,1,.36,1) .1s both fishDrop;display:flex}@keyframes fishDrop{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}.lm-fish-img{object-fit:contain;filter:drop-shadow(0 3px 8px #14643c2e);width:110px;height:110px;animation:3.5s ease-in-out infinite lm-sway}@keyframes lm-sway{0%,to{transform:rotate(-2deg)translate(0)}50%{transform:rotate(2deg)translate(3px)}}.lm-title{color:#1e3a2f;text-align:center;margin-bottom:22px;font-family:Lora,serif;font-size:15.5px;font-weight:600;line-height:1.45;animation:.5s .2s both fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.lm-error{color:#b84040;background:#fef3f2;border:1px solid #fdc0b8;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;animation:.2s both fadeUp;display:flex}.lm-field{margin-bottom:16px}.lm-label{letter-spacing:.05em;color:#5a7a6a;margin-bottom:6px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:600;display:block}.lm-input{color:#1e3a2f;-webkit-appearance:none;background:#fafcfb;border:1px solid #d4e2db;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;transition:border .2s,box-shadow .2s,background .2s}.lm-input::placeholder{color:#b0c8bc}.lm-input:focus{background:#fff;border-color:#3a9a6e;box-shadow:0 0 0 3px #3a9a6e1f}.lm-pass-wrap{position:relative}.lm-pass-wrap .lm-input{padding-right:44px}.lm-pass-toggle{cursor:pointer;color:#94b4a4;background:0 0;border:none;padding:3px;font-size:16px;transition:color .15s;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.lm-pass-toggle:hover{color:#3a9a6e}.lm-btn-wrap{margin-top:8px;position:relative}.lm-btn-wrap:after{content:"";pointer-events:none;border:2px solid #2dab7261;border-radius:12px;animation:2.2s ease-out infinite pulseRing;position:absolute;inset:-3px}@keyframes pulseRing{0%{opacity:.75;transform:scale(1)}70%{opacity:0;transform:scale(1.04)}to{opacity:0;transform:scale(1.04)}}.lm-btn{letter-spacing:.02em;color:#fff;cursor:pointer;background:linear-gradient(110deg,#1e8a5a,#2dab72,#1a7a4e) 0%/200% 100%;border:none;border-radius:9px;width:100%;padding:13px;font-family:Plus Jakarta Sans,sans-serif;font-size:14.5px;font-weight:600;transition:background-position .4s,transform .15s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 4px 16px #2d8c5e4d}.lm-btn:before{content:"";pointer-events:none;background:linear-gradient(120deg,#0000,#ffffff38,#0000);width:50%;height:100%;animation:2.4s ease-in-out infinite shimmer;position:absolute;top:0;left:-75%}@keyframes shimmer{0%{left:-75%}60%{left:125%}to{left:125%}}.lm-btn:hover:not(:disabled){background-position:100%;transform:translateY(-2px);box-shadow:0 8px 24px #2d8c5e61}.lm-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #2d8c5e38}.lm-btn:disabled{opacity:.65;cursor:not-allowed}.lm-hint{text-align:center;color:#94b4a4;margin-top:16px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px}.lm-hint a{color:#2d8c5e;text-decoration:none}.lm-hint a:hover{text-decoration:underline}.dashboard{min-height:calc(100vh - 60px);padding:24px}.dashboard-inner{flex-direction:column;gap:20px;max-width:1280px;margin:0 auto;display:flex}.status-bar{border-radius:10px;justify-content:space-between;align-items:center;padding:14px 20px;font-size:13px;display:flex}.status-bar.normal{background:var(--teal-light)}.status-bar.peringatan{background:var(--amber-light)}.status-bar.bahaya{background:var(--red-light)}.status-bar.offline{background:#fef2f2;border:1px solid #fecaca}.status-badge-main.offline{color:#fff;background:#ef4444}.metric-card.border-offline{border-top-color:#d1d5db}.metric-status.offline{color:#9ca3af}.status-bar-left{align-items:center;gap:16px;display:flex}.status-bar-right{color:var(--gray-600);font-size:12px}.status-info{color:var(--teal);font-size:13px}.status-badge-main{border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600}.status-badge-main.normal{background:var(--teal);color:#fff}.status-badge-main.peringatan{background:var(--amber);color:#fff}.status-badge-main.bahaya{background:var(--red);color:#fff}.metrics-grid{grid-template-columns:repeat(5,1fr);gap:16px;display:grid}@media (width<=1200px){.metrics-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}.metric-card{background:var(--white);border:1px solid var(--gray-200);border-top-width:3px;border-radius:12px;padding:20px}.metric-card.border-normal{border-top-color:var(--teal)}.metric-card.border-peringatan{border-top-color:var(--amber)}.metric-card.border-bahaya{border-top-color:var(--red)}.metric-label{color:var(--gray-400);margin-bottom:6px;font-size:12px}.metric-value{color:var(--gray-800);font-size:32px;font-weight:700;line-height:1.1}.metric-unit{color:var(--gray-600);font-size:16px;font-weight:400}.metric-status{margin-top:6px;font-size:12px}.metric-status.normal{color:var(--teal)}.metric-status.peringatan{color:var(--amber)}.metric-status.bahaya{color:var(--red)}.charts-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.chart-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px}.chart-detail{color:var(--teal);cursor:pointer;font-size:12px}.chart-warn{color:var(--red)}.chart-svg{width:100%;height:110px}.bottom-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.history-card,.notif-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px}.section-title{color:var(--gray-800);margin-bottom:14px;font-size:13px;font-weight:600}.notif-item{border-bottom:1px solid var(--gray-100);gap:12px;padding:10px 0;display:flex}.notif-item:last-of-type{border-bottom:none}.notif-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.notif-dot.normal{background:var(--teal)}.notif-dot.peringatan{background:var(--amber)}.notif-dot.bahaya{background:var(--red)}.notif-msg{color:var(--gray-800);font-size:13px;line-height:1.5}.notif-meta{color:var(--gray-400);margin-top:2px;font-size:11px}.lihat-semua{border:1px solid var(--gray-200);width:100%;color:var(--gray-600);cursor:pointer;font-size:13px;font-family:var(--font);background:0 0;border-radius:8px;margin-top:12px;padding:8px}@media (width<=768px){.metrics-grid{grid-template-columns:1fr 1fr}.charts-row,.bottom-row{grid-template-columns:1fr}}.charts-row-three{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;display:grid}@media (width<=1024px){.charts-row-three{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.charts-row-three{grid-template-columns:1fr}}.history-page{min-height:calc(100vh - 60px);padding:24px}.history-inner{flex-direction:column;gap:20px;max-width:1280px;margin:0 auto;display:flex}.export-btn{border:1px solid var(--gray-200);color:var(--gray-600);cursor:pointer;font-size:13px;font-family:var(--font);background:0 0;border-radius:8px;padding:8px 16px}.filter-bar{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:16px;padding:16px 20px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:var(--gray-600);letter-spacing:.05em;font-size:11px;font-weight:600}.filter-group input,.filter-group select{border:1px solid var(--gray-200);font-size:14px;font-family:var(--font);border-radius:8px;outline:none;padding:8px 12px}.filter-group input:focus,.filter-group select:focus{border-color:var(--teal)}.btn-tampilkan{background:var(--teal);color:#fff;cursor:pointer;font-size:14px;font-family:var(--font);border:none;border-radius:8px;padding:9px 20px;font-weight:500}.table-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;background:var(--gray-50);color:var(--gray-600);border-bottom:1px solid var(--gray-200);padding:12px 16px;font-size:12px;font-weight:600}.data-table td{color:var(--gray-800);border-bottom:1px solid var(--gray-100);padding:12px 16px}.td-ket{color:var(--gray-600);max-width:200px;font-size:12px}.row-peringatan{background:#fffbeb}.row-bahaya{background:#fef2f2}.badge{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.badge.normal{background:var(--teal-light);color:var(--teal)}.badge.peringatan{background:var(--amber-light);color:#92400e}.badge.bahaya{background:var(--red-light);color:var(--red)}.pagination{border-top:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.pagi-info{color:var(--gray-400);font-size:12px}.pagi-btns{gap:4px;display:flex}.pagi-btns button{border:1px solid var(--gray-200);cursor:pointer;font-size:13px;font-family:var(--font);color:var(--gray-600);background:0 0;border-radius:6px;padding:5px 12px}.pagi-btns button:hover:not(:disabled){background:var(--gray-100)}.pagi-btns button.active{background:var(--teal);color:#fff;border-color:var(--teal)}.pagi-btns button:disabled{opacity:.4;cursor:not-allowed}.temp-page{min-height:calc(100vh - 60px);padding:24px}.temp-inner{flex-direction:column;gap:20px;max-width:1280px;margin:0 auto;display:flex}.page-header{justify-content:space-between;align-items:center;display:flex}.page-header h1{color:var(--gray-800);font-size:28px;font-weight:700}.sensor-status{color:var(--gray-600);align-items:center;gap:8px;font-size:13px;display:flex}.sensor-dot{border-radius:50%;width:8px;height:8px}.sensor-time{color:var(--gray-400);margin-left:8px}.temp-main-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;grid-template-columns:1fr 2fr;align-items:center;gap:40px;padding:32px;display:grid}.temp-big{text-align:center}.temp-value{color:var(--gray-800);font-size:72px;font-weight:700;line-height:1}.temp-deg{color:var(--gray-600);font-size:32px;font-weight:400}.temp-label{color:var(--gray-400);margin:8px 0;font-size:13px}.temp-range{color:var(--gray-600);margin-top:8px;font-size:12px}.status-pill{border-radius:20px;margin:4px 0;padding:4px 16px;font-size:13px;font-weight:600;display:inline-block}.status-pill.normal{background:var(--teal-light);color:var(--teal)}.status-pill.peringatan{background:var(--amber-light);color:#92400e}.status-pill.bahaya{background:var(--red-light);color:var(--red)}.sensor-dot.online{background:#1d9e75}.temp-stats{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.stat-item{background:var(--gray-50);text-align:center;border-radius:10px;padding:16px}.stat-val{color:var(--gray-800);font-size:24px;font-weight:700}.stat-lbl{color:var(--gray-400);margin-top:4px;font-size:12px}.chart-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.legend-item.teal{color:var(--teal)}.legend-item.gray{color:var(--gray-400)}.row-warn{background:var(--amber-light)}.sensor-dot.offline{background:#9ca3af}.legend-item.gray2{color:#ef4444}.turb-page{min-height:calc(100vh - 60px);padding:24px}.turb-inner{flex-direction:column;gap:20px;max-width:1280px;margin:0 auto;display:flex}.page-sub{color:var(--gray-400);margin-top:4px;font-size:13px}.sensor-online{font-size:12px;font-weight:500}.sensor-online.ok{color:var(--teal)}.sensor-online.danger{color:var(--red)}.turb-grid{grid-template-columns:280px 1fr;gap:16px;display:grid}.turb-main-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;flex-direction:column;gap:8px;padding:24px;display:flex}.turb-label{color:var(--gray-400);font-size:12px}.turb-value{color:var(--gray-800);font-size:56px;font-weight:700;line-height:1}.turb-unit{color:var(--gray-600);font-size:20px;font-weight:400}.turb-range{color:var(--gray-600);font-size:12px}.turb-stats-col{flex-direction:column;gap:10px;margin-top:12px;display:flex}.stat-row{justify-content:space-between;align-items:center;display:flex}.chart-card-full{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px}.legend-item.blue{color:#378add}.log-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px}.unduh-btn{border:1px solid var(--gray-200);color:var(--gray-600);cursor:pointer;font-size:13px;font-family:var(--font);background:0 0;border-radius:8px;padding:6px 14px}.history-table th{text-align:left;color:var(--gray-400);border-bottom:1px solid var(--gray-200);padding:6px 8px;font-size:12px;font-weight:500}.row-danger{background:var(--red-light)}.aksi-btn{cursor:pointer;background:0 0;border:none;font-size:16px}.tds-page{background:#f9fafb;min-height:100vh;padding:24px 16px}.tds-inner{flex-direction:column;gap:20px;max-width:1100px;margin:0 auto;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.page-header h1{color:#111827;margin:0 0 4px;font-size:24px;font-weight:700}.page-sub{color:#6b7280;margin:0;font-size:13px}.sensor-online{border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500}.sensor-online.ok{color:#16a34a;background:#dcfce7}.sensor-online.danger{color:#dc2626;background:#fef2f2}.tds-grid{grid-template-columns:280px 1fr;gap:20px;display:grid}@media (width<=768px){.tds-grid{grid-template-columns:1fr}}.tds-main-card{background:#fff;border-radius:16px;flex-direction:column;gap:12px;padding:28px 24px;display:flex;box-shadow:0 1px 4px #00000012}.tds-label{color:#6b7280;font-size:13px;font-weight:500}.tds-value{color:#111827;font-size:52px;font-weight:800;line-height:1}.tds-unit{color:#6b7280;font-size:20px;font-weight:500}.tds-range{color:#9ca3af;font-size:12px}.tds-progress-wrap{margin:4px 0}.tds-progress-labels{color:#9ca3af;justify-content:space-between;margin-bottom:4px;font-size:10px;display:flex}.tds-progress-bar{background:#f3f4f6;border-radius:99px;height:10px;position:relative;overflow:visible}.tds-progress-fill{border-radius:99px;height:100%;transition:width .5s}.tds-progress-fill.normal{background:#1d9e75}.tds-progress-fill.peringatan{background:#f59e0b}.tds-progress-fill.bahaya{background:#ef4444}.status-pill.offline{color:#dc2626;background:#fee2e2}.tds-progress-fill.offline{background:#d1d5db}.tds-progress-limit{background:#ef4444;border-radius:2px;width:2px;height:18px;position:absolute;top:-4px}.tds-stats-col{flex-direction:column;gap:10px;margin-top:4px;display:flex}.stat-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.stat-lbl-sm{color:#6b7280;font-size:13px}.stat-val-sm{color:#111827;font-size:13px;font-weight:600}.chart-card-full{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 1px 4px #00000012}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:16px;display:flex}.chart-title{color:#111827;font-size:15px;font-weight:600}.chart-legend{gap:16px;font-size:12px;display:flex}.legend-item.purple{color:#8b5cf6}.legend-item.red{color:#ef4444}.chart-svg-full{width:100%;height:auto}.tds-info-card{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 1px 4px #00000012}.tds-info-title{color:#111827;margin-bottom:16px;font-size:15px;font-weight:600}.tds-info-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=768px){.tds-info-grid{grid-template-columns:repeat(2,1fr)}}.tds-info-item{border:1px solid #e5e7eb;border-radius:12px;padding:14px}.tds-info-item.normal{background:#f0fdf4;border-color:#bbf7d0}.tds-info-item.peringatan{background:#fffbeb;border-color:#fde68a}.tds-info-item.bahaya{background:#fef2f2;border-color:#fecaca}.tds-info-range{color:#111827;margin-bottom:4px;font-size:14px;font-weight:700}.tds-info-label{margin-bottom:4px;font-size:12px;font-weight:600}.tds-info-item.normal .tds-info-label{color:#16a34a}.tds-info-item.peringatan .tds-info-label{color:#d97706}.tds-info-item.bahaya .tds-info-label{color:#dc2626}.tds-info-desc{color:#6b7280;font-size:11px;line-height:1.4}.log-card{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 1px 4px #00000012}.log-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.unduh-btn{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .2s}.unduh-btn:hover{background:#e5e7eb}.history-table{border-collapse:collapse;width:100%;font-size:13px}.history-table th{text-align:left;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-weight:600}.history-table td{color:#374151;border-bottom:1px solid #f3f4f6;padding:10px 12px}.history-table tr:last-child td{border-bottom:none}.history-table tr.row-warn{background:#fffbeb}.status-pill{border-radius:99px;padding:4px 14px;font-size:13px;font-weight:600;display:inline-block}.status-pill.normal{color:#16a34a;background:#dcfce7}.status-pill.peringatan{color:#ca8a04;background:#fef9c3}.status-pill.bahaya{color:#dc2626;background:#fee2e2}.badge{border-radius:99px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.badge.normal{color:#16a34a;background:#dcfce7}.badge.peringatan{color:#ca8a04;background:#fef9c3}.badge.bahaya{color:#dc2626;background:#fee2e2}.tds-info-range-wrap{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.tds-edit-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:14px;transition:opacity .2s}.tds-edit-btn:hover{opacity:1}.tds-edit-form{flex-direction:column;gap:6px;display:flex}.tds-edit-input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;outline:none;width:100%;padding:6px 8px;font-size:12px}.tds-edit-input:focus{border-color:#8b5cf6}.tds-edit-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;width:100%;padding:6px 8px;font-size:12px}.tds-edit-actions{gap:6px;margin-top:2px;display:flex}.tds-btn-save{color:#fff;cursor:pointer;background:#8b5cf6;border:none;border-radius:6px;flex:1;padding:6px;font-size:12px;font-weight:600}.tds-btn-save:hover{background:#7c3aed}.tds-btn-cancel{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:6px;flex:1;padding:6px;font-size:12px}.tds-btn-cancel:hover{background:#e5e7eb}.settings-page{min-height:calc(100vh - 60px);padding:24px}.settings-inner{flex-direction:column;gap:20px;max-width:1280px;margin:0 auto;display:flex}.settings-inner h1{color:var(--gray-800);font-size:28px;font-weight:700}.page-sub{color:var(--gray-400);max-width:600px;margin-top:4px;font-size:13px}.settings-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.settings-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;flex-direction:column;gap:16px;padding:28px;display:flex}.settings-card-header{align-items:center;gap:10px;margin-bottom:4px;display:flex}.settings-icon{font-size:20px}.settings-card-header h2{color:var(--gray-800);font-size:17px;font-weight:600}.alert-success{background:var(--teal-light);color:var(--teal);border:1px solid #a7f3d0;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:500}.alert-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:13px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:var(--gray-600);letter-spacing:.04em;font-size:11px;font-weight:600}.form-hint{color:var(--gray-400);margin-top:2px;font-size:11px}.input-unit{border:1px solid var(--gray-200);border-radius:8px;align-items:center;display:flex;overflow:hidden}.input-unit input{font-size:14px;font-family:var(--font);border:none;outline:none;flex:1;padding:9px 12px}.input-unit span{background:var(--gray-100);color:var(--gray-600);border-left:1px solid var(--gray-200);padding:9px 12px;font-size:13px}.input-full{border:1px solid var(--gray-200);width:100%;font-size:14px;font-family:var(--font);border-radius:8px;outline:none;padding:9px 12px}.input-full:focus{border-color:var(--teal)}.btn-save{background:var(--teal);color:#fff;cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font);border:none;border-radius:8px;align-self:flex-start;margin-top:4px;padding:11px 20px}.btn-save:hover{background:var(--teal-dark)}.toggle-row{background:var(--gray-50);border-radius:10px;justify-content:space-between;align-items:center;padding:14px;display:flex}.toggle-label{color:var(--gray-800);font-size:14px;font-weight:500}.toggle-sub{color:var(--gray-400);margin-top:2px;font-size:12px}.toggle-btn{cursor:pointer;border:none;border-radius:13px;flex-shrink:0;width:48px;height:26px;transition:background .2s;position:relative}.toggle-btn.on{background:var(--teal)}.toggle-btn.off{background:var(--gray-200)}.toggle-thumb{background:#fff;border-radius:50%;width:20px;height:20px;transition:left .2s;position:absolute;top:3px}.toggle-btn.on .toggle-thumb{left:25px}.toggle-btn.off .toggle-thumb{left:3px}.btn-test{border:1px solid var(--teal);color:var(--teal);cursor:pointer;font-size:14px;font-family:var(--font);background:0 0;border-radius:8px;padding:10px 20px;font-weight:500}.btn-test:hover{background:var(--teal-light)}.settings-img-placeholder{background:linear-gradient(135deg,#0f6e56,#1d9e75);border-radius:10px;height:140px;margin-top:auto;position:relative;overflow:hidden}.img-overlay{background:#00000040;align-items:flex-end;padding:16px;display:flex;position:absolute;inset:0}.img-overlay span{color:#fff;font-size:16px;font-weight:600}@media (width<=768px){.settings-grid,.form-row{grid-template-columns:1fr}}.modal-btn-ok:hover{background:#178a63;transform:translateY(-1px)}.modal-btn-ok:active{transform:translateY(0)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalPopIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes strokeDraw{to{stroke-dashoffset:0}}.modal-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-box{text-align:center;background:#fff;border-radius:20px;width:320px;padding:40px 32px;animation:.3s slideUp;box-shadow:0 20px 60px #0003}.modal-icon-wrap{width:72px;height:72px;margin:0 auto 20px}.modal-checkmark{width:72px;height:72px}.modal-checkmark-circle{stroke:#1d9e75;stroke-width:2px;stroke-dasharray:166;stroke-dashoffset:166px;animation:.6s cubic-bezier(.65,0,.45,1) forwards strokeCircle}.modal-checkmark-check{stroke:#1d9e75;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48px;animation:.4s cubic-bezier(.65,0,.45,1) .5s forwards strokeCheck}.modal-title{color:#111827;margin:0 0 8px;font-size:22px;font-weight:700}.modal-desc{color:#6b7280;margin:0 0 24px;font-size:14px}.modal-btn-ok{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1d9e75,#16a34a);border:none;border-radius:12px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:opacity .2s,transform .1s}.modal-btn-ok:hover{opacity:.9;transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes strokeCircle{to{stroke-dashoffset:0}}@keyframes strokeCheck{to{stroke-dashoffset:0}}*{box-sizing:border-box;margin:0;padding:0}:root{--teal:#1d9e75;--teal-dark:#157a5a;--teal-light:#e8f5f0;--amber:#f59e0b;--amber-light:#fef3c7;--red:#ef4444;--red-light:#fee2e2;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-400:#9ca3af;--gray-600:#4b5563;--gray-800:#1f2937;--white:#fff;--font:"Segoe UI", system-ui, sans-serif}body{font-family:var(--font);background:var(--gray-50);color:var(--gray-800)}.app{min-height:100vh}
