:root{color:#0f172a;background:#f5f9ff;font-family:Open Sans,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}.page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 50% 10%,rgba(37,99,235,.16),transparent 30%),linear-gradient(180deg,#fff,#eef6ff)}.phone{width:min(100%,430px);min-height:720px;display:flex;flex-direction:column;justify-content:center;border:8px solid #050b18;border-radius:38px;background:#fbfdff;padding:28px 22px;box-shadow:0 26px 70px #0f172a38}.logo{display:block;width:230px;max-width:100%;height:auto;margin:0 auto 28px}.eyebrow{color:#6c4dff;font-weight:800;margin:0 0 10px}h1,h2,h3,h4,h5,h6{color:inherit;margin:0}h1{font-size:31px;line-height:1.08;margin:0 0 20px}p{color:#64748b;line-height:1.55;margin:0}.on-color{color:#fff}.on-color p,.on-color span,.on-color h1,.on-color h2,.on-color h3,.on-color small,.on-color label,.on-color button{color:inherit}.privacy{display:flex;gap:12px;align-items:flex-start;border-radius:8px;background:#f1f6ff;padding:14px;color:#2563eb}.privacy p{margin:0;color:#334155;font-size:14px}.field{display:block;margin:16px 0}textarea{width:100%;min-height:116px;padding:14px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#0f172a;font:inherit;resize:vertical}small{display:block;margin-top:-28px;padding-right:12px;color:#64748b;text-align:right}.actions{display:grid;gap:12px}button{min-height:56px;border:0;border-radius:8px;background:#2563eb;color:#fff;font:inherit;font-weight:800;cursor:pointer}button.secondary{background:#0f172a}button:disabled{opacity:.65;cursor:wait}.error{color:#dc2626;font-weight:700}.note{margin:18px 0 0;color:#46606f;font-size:13px;text-align:center}.hidden-video{height:1px;opacity:0;position:absolute;width:1px}.state-card,.success-card{border:1px solid #dbeafe;border-radius:8px;background:#fff;padding:28px 20px;text-align:center;box-shadow:0 16px 45px #2563eb1f}.success-ring{width:86px;height:86px;display:grid;place-items:center;margin:0 auto 22px;border:8px solid #dcfce7;border-radius:999px;background:#22c55e;color:#fff;font-size:42px;font-weight:900}.loader{width:42px;height:42px;display:inline-block;border:4px solid #dbeafe;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}.door-line{height:150px;margin-top:42px;border-bottom:3px solid #dbeafe;opacity:.7}@keyframes spin{to{transform:rotate(360deg)}}.panel{width:min(100%,420px);background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:44px 40px 36px;box-shadow:0 16px 45px #2563eb1a}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;font-weight:600;color:#475569}.input-wrap{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;font-size:15px;pointer-events:none;-webkit-user-select:none;user-select:none}.input-with-icon{padding-left:40px!important}.input-with-toggle{padding-right:44px!important}.input-toggle{position:absolute;right:12px;background:none;border:none;min-height:auto;padding:4px;cursor:pointer;font-size:16px;color:#94a3b8;line-height:1}.btn-primary-lg{width:100%;min-height:52px;background:#1e3a8a;border:0;border-radius:8px;color:#fff;font:inherit;font-size:16px;font-weight:700;letter-spacing:.5px;cursor:pointer;margin-top:4px}.btn-primary-lg:hover{background:#1e40af}.btn-primary-lg:disabled{opacity:.65;cursor:wait}.panel-version{text-align:center;font-size:12px;color:#94a3b8;margin:12px 0 0}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:#f8fafc}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.app-logo{width:180px;max-width:calc(100% - 160px);height:auto}.app-main{flex:1;width:min(100%,640px);margin:0 auto;padding:24px 20px 48px}.app-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.app-title{font-size:22px;font-weight:800;margin:0}.btn-nova{width:90px;height:55px;min-height:unset;background:#2563eb;border:0;border-radius:8px;color:#fff;font:inherit;font-weight:700;font-size:14px;cursor:pointer}.btn-nova:hover{background:#1d4ed8}.btn-ghost{background:none;border:none;min-height:auto;color:#2563eb;font:inherit;font-size:14px;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:6px}.btn-ghost:hover{background:#f1f5f9}.btn-danger{color:#dc2626}.center-block{display:flex;justify-content:center;padding:48px 0}.empty-state{text-align:center;padding:56px 24px;color:#64748b}.empty-icon{font-size:48px;margin-bottom:12px}.doorbell-list{display:flex;flex-direction:column;gap:10px}.doorbell-card{display:flex;align-items:center;gap:14px;width:100%;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;cursor:pointer;text-align:left;min-height:auto;font:inherit;color:inherit;transition:box-shadow .15s}.doorbell-card:hover{box-shadow:0 4px 16px #0f172a14}.doorbell-icon-wrap{font-size:28px;flex-shrink:0}.doorbell-info{flex:1;display:flex;flex-direction:column;gap:2px}.doorbell-nome{font-weight:700;font-size:16px}.doorbell-local{font-size:13px;color:#64748b}.chevron{font-size:22px;color:#94a3b8}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:grid;place-items:center;padding:24px;z-index:100}.modal{background:#fff;border-radius:16px;padding:28px;width:min(100%,420px);box-shadow:0 24px 60px #0f172a33}.modal h2{margin:0 0 20px}.modal-actions{display:flex;gap:10px;margin-top:4px}.modal-actions button{flex:1}.form{display:flex;flex-direction:column;gap:12px}.input{display:block;width:100%;height:48px;padding:0 14px;border:1px solid #cbd5e1;border-radius:8px;background:#f8fafc;font:inherit;font-size:15px;color:#0f172a;outline:none}.input:focus{border-color:#2563eb;background:#fff}.panel-title{font-size:26px;margin:0 0 6px}.panel-sub{margin:0 0 20px}.panel-switch{text-align:center;margin-top:16px;font-size:14px}.panel-switch a{color:#2563eb;font-weight:600}.panel-switch-secondary{margin-top:6px}.login-role-banner{display:flex;flex-direction:column;gap:4px;margin-bottom:20px;padding:14px 16px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff}.login-role-banner span{color:#2563eb;font-size:12px;font-weight:800;text-transform:uppercase}.login-role-banner strong{color:#0f172a;font-size:17px}.access-panel{width:min(100%,500px)}.access-links{display:grid;gap:12px;margin-top:20px}.access-card{width:100%;min-height:auto;display:flex;flex-direction:column;gap:5px;padding:18px;border:1px solid #dbeafe;border-radius:8px;background:#fff;color:#0f172a;text-align:left}.access-card:hover{border-color:#2563eb;background:#eff6ff}.access-card strong{font-size:18px}.access-card span:last-child{color:#64748b;font-size:13px;font-weight:500}.access-kicker{color:#2563eb;font-size:12px;font-weight:800;text-transform:uppercase}.detail-local{color:#64748b;margin:-8px 0 20px}.qr-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:28px;text-align:center;margin-bottom:20px}.qr-img{width:200px;height:200px;border-radius:8px}.qr-hint{font-size:13px;color:#64748b;margin:14px 0 0}.detail-actions{display:flex;gap:10px;margin-bottom:16px}.detail-actions button{flex:1}.url-box{background:#f1f5f9;border-radius:8px;padding:12px 14px;word-break:break-all}.url-box code{font-size:12px;color:#475569}.visitor-page{min-height:100vh;display:grid;place-items:center;padding:20px 16px;background:radial-gradient(circle at 50% 10%,rgba(108,77,255,.12),transparent 40%),linear-gradient(180deg,#fff,#eef2ff)}.visitor-card{width:min(100%,420px);background:#fff;border-radius:28px;padding:32px 24px 28px;box-shadow:0 8px 40px #6c4dff1f;display:flex;flex-direction:column;gap:16px}.visitor-logo{width:224px;margin:0 auto;display:block}.visitor-bell-wrap{position:relative;width:80px;height:80px;margin:8px auto 0;display:grid;place-items:center}.visitor-bell-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#eef2ff;animation:bell-pulse 2s ease-in-out infinite}.visitor-bell-icon{font-size:40px;position:relative;z-index:1}@keyframes bell-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.7}}.visitor-title{font-size:22px;font-weight:800;color:#6c4dff;text-align:center;margin:0}.visitor-subtitle{font-size:16px;color:#6c4dff;text-align:center;font-weight:600;margin:-8px 0 0}.visitor-field{display:flex;flex-direction:column;gap:4px}.visitor-textarea{width:100%;box-sizing:border-box;border:1.5px solid #e2e8f0;border-radius:12px;padding:12px 14px;font-size:14px;color:#0f172a;resize:none;font-family:inherit;transition:border-color .15s}.visitor-textarea:focus{outline:none;border-color:#6c4dff}.visitor-char-count{font-size:11px;color:#94a3b8;text-align:right}.visitor-actions{display:flex;flex-direction:column;gap:10px}.visitor-btn-primary{width:100%;height:54px;background:#6c4dff;color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .15s}.visitor-btn-primary:disabled{opacity:.6;cursor:not-allowed}.visitor-btn-primary:hover:not(:disabled){opacity:.9}.visitor-btn-secondary{width:100%;height:50px;background:#f8fafc;color:#475569;border:1.5px solid #e2e8f0;border-radius:14px;font-size:14px;font-weight:600;cursor:pointer}.visitor-btn-secondary:hover{background:#f1f5f9}.visitor-btn-outline{width:100%;height:50px;background:transparent;color:#6c4dff;border:1.5px solid #6C4DFF;border-radius:14px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.visitor-btn-outline:hover{background:#6c4dff0f}.visitor-btn-outline:disabled{opacity:.6;cursor:not-allowed}.visitor-note{font-size:12px;color:#94a3b8;text-align:center;margin:0}.visitor-privacy{font-size:13px;color:#475569;text-align:center;margin:0}.visitor-error{font-size:13px;color:#dc2626;text-align:center;background:#fef2f2;border-radius:10px;padding:10px;margin:0}.visitor-camera-wrap{position:relative;border-radius:16px;overflow:hidden;background:#000;aspect-ratio:4/3}.visitor-camera-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.visitor-camera-badge{position:absolute;top:10px;left:10px;background:#dc2626;color:#fff;font-size:11px;font-weight:800;letter-spacing:1px;padding:3px 8px;border-radius:99px;animation:blink 1.2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.visitor-status-card{text-align:center;padding:24px 16px;border-radius:20px;background:#f8fafc;display:flex;flex-direction:column;align-items:center;gap:10px}.visitor-status-card.sent{background:#eef2ff}.visitor-status-card.viewed,.visitor-status-card.ended{background:#f0fdf4}.visitor-status-icon{font-size:48px}.pulse-ring{display:inline-block;animation:bell-pulse 1s ease-in-out infinite}.visitor-status-card h2{margin:0;font-size:20px;color:#2d1b69}.visitor-status-card p{margin:0;color:#64748b;font-size:14px}.visitor-countdown{font-size:13px!important;color:#94a3b8!important;margin-top:8px!important}.visitor-state{text-align:center;padding:24px 0}.visitor-state p{color:#64748b}.error-state .visitor-icon{font-size:40px;margin-bottom:12px}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.dash-header-right{display:flex;align-items:center;gap:20px}.dash-nav-link{text-decoration:none;font-size:14px;font-weight:600;color:#0637b8}.dash-welcome{display:flex;align-items:center;justify-content:space-between;padding:28px 24px 12px}.dash-welcome-sub{font-size:13px;color:#64748b;margin:0 0 2px}.dash-welcome-title{font-size:24px;font-weight:900;color:#061746;margin:0}.dash-msg-btn{width:44px;height:44px;border-radius:50%;background:#eef4ff;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:20px;flex-shrink:0}.dash-section{padding:0 24px 28px}.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.dash-section-title{font-size:17px;font-weight:800;color:#061746;margin:0}.dash-link-all{font-size:13px;font-weight:600;color:#0637b8;text-decoration:none}.carousel-wrap{overflow:hidden}.carousel-track{display:flex;gap:12px;transition:transform .35s ease}.carousel-controls{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px}.carousel-btn{width:32px;height:32px;border-radius:50%;border:1px solid #e2e8f0;background:#fff;font-size:18px;cursor:pointer;line-height:1}.carousel-btn:disabled{opacity:.35;cursor:default}.carousel-dots{display:flex;gap:6px;align-items:center}.carousel-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1;border:none;cursor:pointer;padding:0;transition:background .2s,width .2s}.carousel-dot.active{background:#0637b8;width:20px;border-radius:4px}.offer-card{width:300px;flex-shrink:0;border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 2px 12px #0f172a14}.offer-banner{height:160px;position:relative;display:flex;align-items:flex-end}.offer-banner-text{padding:14px}.offer-banner-text h3{color:#fff;font-size:18px;font-weight:900;margin:4px 0 0}.offer-banner-text p{color:#bfdbfe;font-size:12px;margin:4px 0 0}.offer-cat{color:#93c5fd;font-size:11px;font-weight:700}.offer-badge{position:absolute;top:10px;right:10px;background:#475569;color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:99px}.offer-badge.tier2{background:#0637b8}.offer-footer{display:flex;align-items:center;gap:10px;padding:12px 14px}.offer-info{flex:1}.offer-info strong{display:block;font-size:14px;color:#061746}.offer-info span{font-size:12px;color:#64748b}.btn-offer-cta{background:#0637b8;color:#fff;font-size:13px;font-weight:700;padding:8px 14px;border-radius:10px;text-decoration:none;white-space:nowrap}.dash-empty-offers{height:120px;border:2px dashed #e2e8f0;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.dash-empty-offers span{font-size:28px}.dash-empty-offers p{color:#94a3b8;font-size:14px;margin:0}.dash-empty-doorbell{text-align:center;padding:40px 20px;border:2px dashed #e2e8f0;border-radius:16px}.dash-empty-doorbell .empty-icon{font-size:40px;display:block;margin-bottom:12px}.doorbell-grid{display:flex;flex-direction:column;gap:16px}.doorbell-qr-card{border-radius:16px;background:#fff;box-shadow:0 2px 12px #0f172a12;overflow:hidden}.doorbell-qr-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid #f1f5f9}.doorbell-qr-body{display:flex;flex-direction:column;align-items:center;padding:20px}.doorbell-qr-canvas{border-radius:12px}.doorbell-qr-url{font-size:11px;color:#94a3b8;word-break:break-all;text-align:center;max-width:280px;margin:10px 0 0}.doorbell-qr-actions{display:flex;gap:8px;padding:0 16px 16px}.btn-share{flex:1;background:#0637b8;color:#fff;border:none;border-radius:10px;height:44px;font-size:14px;font-weight:700;cursor:pointer}.btn-outline-sm{background:#fff;color:#475569;border:1px solid #e2e8f0;border-radius:10px;height:44px;padding:0 14px;font-size:13px;font-weight:600;cursor:pointer}.btn-nova-sm{background:#0637b8;color:#fff;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:700;cursor:pointer}.doorbell-status{font-size:12px;font-weight:700;color:#94a3b8;margin-left:auto}.doorbell-status.active{color:#16a34a}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f1eeb;display:grid;place-items:center;padding:24px;z-index:200;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.call-card{background:#0f172a;border:1px solid #1e40af;border-radius:20px;padding:36px 28px;width:min(100%,380px);text-align:center;box-shadow:0 0 60px #2563eb59}.call-ring-icon{font-size:64px;margin-bottom:16px;animation:ring .6s ease infinite alternate}.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.role-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;border:2px solid #e2e8f0;border-radius:12px;background:#f8fafc;cursor:pointer;min-height:unset;text-align:center;transition:border-color .15s,background .15s}.role-option:hover{border-color:#93c5fd;background:#eff6ff}.role-option.active{border-color:#2563eb;background:#eff6ff}.role-icon{font-size:28px;line-height:1}.role-label{font-size:14px;font-weight:700;color:#0f172a}.role-desc{font-size:11px;color:#64748b;line-height:1.3}@keyframes ring{0%{transform:rotate(-15deg) scale(1)}to{transform:rotate(15deg) scale(1.1)}}.call-title{font-size:26px;font-weight:800;color:#fff;margin:0 0 8px}.call-local{font-size:18px;font-weight:600;color:#93c5fd;margin:0 0 16px}.call-message{background:#1e293b;border-radius:10px;padding:12px 16px;margin-bottom:16px}.call-message p{color:#cbd5e1;font-size:15px;margin:0;font-style:italic}.call-time{color:#64748b;font-size:13px;margin:0 0 24px}.call-btn-dismiss{width:100%;min-height:52px;background:#16a34a;border:0;border-radius:10px;color:#fff;font:inherit;font-weight:700;font-size:16px;cursor:pointer}.call-btn-dismiss:hover{background:#15803d}.call-photo-wrap{width:100%;aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:#1e293b;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:16px}.call-photo{width:100%;height:100%;object-fit:cover}.call-photo-loading,.call-photo-empty{gap:8px}@media (max-width: 480px){.page{padding:0}.phone{width:100%;min-height:100vh;border:0;border-radius:0;box-shadow:none}}.login-shell{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(160deg,#7f00ff,#e100ff)}.login-hero{min-height:330px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:42px 24px 78px;background:linear-gradient(160deg,#7f00ff,#e100ff);text-align:center}.login-hero-logo{width:300px;max-width:min(78vw,340px);height:auto}.login-hero p{margin:18px 0 0;color:#ffffffd1;font-size:24px;font-weight:600;line-height:1.35}.login-card{flex:1;width:100%;max-width:720px;margin:-42px auto 0;padding:72px 42px 44px;border-radius:42px 42px 0 0;background:#f8fafc;position:relative}.login-form-panel{position:relative;overflow:hidden;isolation:isolate}.login-form-panel:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:radial-gradient(circle at 18% 10%,rgba(255,255,255,.75),transparent 24%),radial-gradient(circle at 82% 8%,rgba(225,0,255,.16),transparent 26%),#f8fafc;z-index:-2}.login-form-panel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(135deg,rgba(127,0,255,.04) .5px,transparent .5px),linear-gradient(45deg,rgba(225,0,255,.04) .5px,transparent .5px);background-size:30px 30px;opacity:.45;pointer-events:none;z-index:-1}.login-card-light{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;border-radius:inherit;pointer-events:none;z-index:0}.login-card-light span{position:absolute;display:block;background:linear-gradient(90deg,transparent,rgba(255,255,255,.9),transparent);filter:blur(1px);opacity:.68}.login-card-light span:nth-child(1){top:0;left:-55%;width:55%;height:3px;animation:loginBeamTop 3.2s ease-in-out infinite}.login-card-light span:nth-child(2){top:-55%;right:0;width:3px;height:55%;background:linear-gradient(180deg,transparent,rgba(255,255,255,.9),transparent);animation:loginBeamRight 3.2s ease-in-out infinite .8s}.login-card-light span:nth-child(3){right:-55%;bottom:0;width:55%;height:3px;animation:loginBeamBottom 3.2s ease-in-out infinite 1.6s}.login-card-light span:nth-child(4){bottom:-55%;left:0;width:3px;height:55%;background:linear-gradient(180deg,transparent,rgba(255,255,255,.9),transparent);animation:loginBeamLeft 3.2s ease-in-out infinite 2.4s}.login-form-panel>*:not(.login-card-light){position:relative;z-index:1}.login-user-icon{width:92px;height:92px;display:grid;place-items:center;margin:-18px auto 26px;border-radius:999px;background:#7f00ff14;color:#7f00ff;font-weight:900}.login-user-icon span{font-size:16px}.login-card h1{margin:0 0 10px;color:#0f172a;font-size:42px;font-weight:900;text-align:center}.login-card-sub{max-width:470px;margin:0 auto 34px;color:#64748b;font-size:22px;font-weight:500;line-height:1.35;text-align:center}.login-form{display:flex;flex-direction:column;gap:16px}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:26px;display:grid;place-items:center;color:#7f00ff;pointer-events:none}.login-input{width:100%;height:76px;padding:0 26px 0 74px;border:1px solid #dbe2ea;border-radius:18px;background:#fff;color:#0f172a;font:inherit;font-size:22px;outline:none;box-shadow:0 1px 3px #0f172a0a}.login-input::placeholder{color:#94a3b8}.login-input:focus{border-color:#e100ff;box-shadow:0 0 0 4px #e100ff1f}.login-input-password{padding-right:92px}.login-eye{position:absolute;right:22px;display:grid;place-items:center;min-height:auto;padding:8px;border:0;border-radius:8px;background:transparent;color:#94a3b8;line-height:1}.login-forgot{align-self:flex-end;min-height:auto;margin:-4px 0 12px;padding:0;background:transparent;color:#7f00ff;font-size:20px;font-weight:800}.login-submit{width:100%;height:76px;min-height:auto;display:flex;align-items:center;justify-content:center;gap:10px;border-radius:16px;background:linear-gradient(90deg,#7f00ff,#e100ff);color:#fff;font-size:24px;font-weight:900}.login-submit:hover{filter:brightness(.96)}.login-divider{display:flex;align-items:center;gap:14px;margin:20px 0;color:#94a3b8;font-size:14px;font-weight:800}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.login-social{width:100%;height:64px;min-height:auto;display:flex;align-items:center;justify-content:center;gap:12px;border:1px solid #dbe2ea;border-radius:16px;background:#ffffffc7;color:#0f172a;font-size:18px;font-weight:900;box-shadow:0 1px 3px #0f172a0a}.login-social:hover{border-color:#7f00ff47;background:#fff}.login-mode-card,.login-role-card{width:100%;min-height:76px;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;padding:16px 20px;border:1px solid #dbe2ea;border-radius:16px;background:#fff;color:#475569;box-shadow:0 1px 3px #0f172a0a}.login-mode-card span{font-size:20px;font-weight:500}.login-mode-card strong{color:#7f00ff;font-size:20px;font-weight:900}.login-role-card{min-height:96px;flex-direction:column;gap:4px;margin-top:14px;border-color:#e100ff3d;background:linear-gradient(135deg,#7f00ff14,#e100ff14)}.login-role-card span{color:#7f00ff;font-size:13px;font-weight:900;line-height:1.2;text-transform:uppercase}.login-role-card strong{color:#0f172a;font-size:22px;font-weight:900;line-height:1.2}.login-role-card small{display:block;margin-top:0;padding-right:0;color:#64748b;font-size:14px;font-weight:600;line-height:1.35;text-align:center}.login-security{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:34px}.login-security span{color:#64748b;font-size:14px;font-weight:900}.login-security p{margin:0;color:#64748b;font-size:18px}.login-version{margin:24px 0 0;color:#cbd5e1;font-size:16px;text-align:center}@media (min-width: 900px){.login-shell{min-height:100vh;flex-direction:row;align-items:stretch;justify-content:stretch;gap:0;padding:0}.login-hero{flex:0 0 48%;width:48%;min-height:100vh;justify-content:center;padding:56px;background:transparent}.login-hero-logo{width:380px;max-width:86%}.login-hero p{max-width:430px;font-size:28px}.login-card{flex:1;width:52%;max-width:none;min-height:100vh;display:grid;place-items:center;margin:0;padding:56px;border:0;border-radius:42px 0 0 42px;background:#f8fafc;box-shadow:-24px 0 70px #0f172a2e;-webkit-backdrop-filter:none;backdrop-filter:none}.login-form-panel{width:min(100%,572px);padding:38px 32px 30px;border:1px solid rgba(255,255,255,.74);border-radius:18px;background:#f8fafcf0;box-shadow:0 24px 70px #0f172a38,0 6px 18px #7f00ff29,inset 0 1px #ffffffd1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.login-card h1,.login-card-sub{text-align:center}.login-card-sub{margin-left:auto;margin-right:auto;font-size:16px}.login-user-icon{width:68px;height:68px;margin:-4px auto 18px}.login-card h1{font-size:30px}.login-input,.login-submit,.login-mode-card{height:54px;min-height:54px;border-radius:10px}.login-submit{font-size:22px}.login-input{padding-left:48px}.login-input-icon{left:16px}.login-input-password{padding-right:70px}.login-eye{right:12px}.login-forgot{font-size:14px;margin-bottom:10px}.login-social{height:52px;border-radius:10px;font-size:22px}.login-mode-card{margin-top:14px}.login-mode-card span,.login-mode-card strong{font-size:18px}.login-role-card{min-height:78px;border-radius:10px}.login-security{margin-top:22px}.login-security p{font-size:13px}.login-version{margin-top:14px;font-size:12px}}@media (max-width: 640px){.login-hero{min-height:270px;padding:34px 24px 62px}.login-hero-logo{width:238px}.login-hero p{font-size:20px}.login-card{margin-top:-34px;padding:56px 24px 32px;border-radius:32px 32px 0 0}.login-card h1{font-size:32px}.login-card-sub{font-size:18px}.login-input,.login-submit,.login-mode-card{height:64px;min-height:64px}.login-social{height:58px;font-size:16px}.login-input{font-size:18px}.login-forgot,.login-mode-card span,.login-mode-card strong{font-size:16px}.login-security p{font-size:15px}}@keyframes loginBeamTop{0%{left:-55%;opacity:.15}45%,65%{opacity:.72}to{left:100%;opacity:.15}}@keyframes loginBeamRight{0%{top:-55%;opacity:.15}45%,65%{opacity:.72}to{top:100%;opacity:.15}}@keyframes loginBeamBottom{0%{right:-55%;opacity:.15}45%,65%{opacity:.72}to{right:100%;opacity:.15}}@keyframes loginBeamLeft{0%{bottom:-55%;opacity:.15}45%,65%{opacity:.72}to{bottom:100%;opacity:.15}}.portal-root{display:flex;min-height:100vh;background:#f1f5fb}.portal-loading{display:grid;place-items:center;min-height:100vh}.portal-sidebar{width:240px;min-height:100vh;background:linear-gradient(160deg,#21005d,#5b00b8 48%,#9b00cc);display:flex;flex-direction:column;padding:0 0 24px;position:sticky;top:0;align-self:flex-start;flex-shrink:0}.portal-brand{padding:24px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;gap:6px}.portal-logo{width:130px;height:auto}.portal-role{font-size:11px;font-weight:700;color:#ffffffc7;letter-spacing:1px;text-transform:uppercase}.portal-advertiser-info{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.portal-avatar{width:40px;height:40px;border-radius:50%;background:#ffffff38;color:#fff;display:grid;place-items:center;font-weight:800;font-size:18px;flex-shrink:0}.portal-advertiser-name{font-size:14px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-advertiser-cat{font-size:11px;color:#ffffffc7;margin-top:2px}.portal-nav{padding:16px 12px;display:flex;flex-direction:column;gap:4px;flex:1}.portal-nav-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;background:transparent;color:#ffffffdb;font-size:14px;font-weight:600;cursor:pointer;min-height:unset;text-align:left;transition:background .15s}.portal-nav-item:hover{background:#ffffff29}.portal-nav-item.active{background:#ffffff3d;color:#fff}.portal-nav-icon{font-size:18px;width:24px;text-align:center}.portal-signout{margin:0 12px;color:#fff}.portal-overlay{display:none}.portal-main{flex:1;display:flex;flex-direction:column;min-width:0}.portal-topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px 32px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10}.portal-menu-btn{display:none;background:transparent;color:#061746;font-size:22px;min-height:unset;padding:4px 8px;border-radius:6px}.portal-topbar-title{flex:1;font-size:18px;font-weight:800;color:#061746}.portal-topbar-user{font-size:13px;color:#64748b}.portal-content{padding:32px;max-width:1100px;width:100%}.portal-section{display:flex;flex-direction:column;gap:24px}.portal-section-title{font-size:22px;font-weight:800;color:#061746;margin:0 0 6px}.portal-section-sub{font-size:14px;color:#64748b;margin:0;line-height:1.5}.portal-subsection-title{font-size:16px;font-weight:700;color:#334155;margin:0}.section-header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.btn-portal{padding:10px 20px;background:#2563eb;color:#fff;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;min-height:unset;white-space:nowrap}.btn-portal:hover{background:#1d4ed8}.btn-back{background:transparent;color:#2563eb;font-size:14px;font-weight:600;min-height:unset;padding:0;cursor:pointer;margin-bottom:4px}.btn-sm{padding:6px 12px;font-size:12px;font-weight:700;border-radius:8px;cursor:pointer;min-height:unset}.btn-outline{background:#f1f5f9;color:#334155}.btn-success{background:#dcfce7;color:#16a34a}.btn-warn{background:#fef3c7;color:#d97706}.btn-danger{background:#fee2e2;color:#dc2626}.empty-portal{text-align:center;padding:60px 20px;background:#fff;border-radius:16px;border:2px dashed #e2e8f0;display:flex;flex-direction:column;align-items:center;gap:12px;color:#64748b}.empty-icon{font-size:48px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;gap:6px}.stat-card.clickable{cursor:pointer;transition:transform .15s}.stat-card.clickable:hover{transform:translateY(-2px)}.stat-icon{font-size:26px}.stat-value{font-size:28px;font-weight:800;color:#061746}.stat-label{font-size:13px;color:#64748b}.quick-actions{display:flex;flex-direction:column;gap:8px}.quick-action{display:flex;align-items:center;gap:14px;padding:16px 20px;background:#fff;border-radius:12px;cursor:pointer;min-height:unset;text-align:left;color:#061746;box-shadow:0 1px 4px #0000000f}.quick-action:hover{background:#f8fafc}.qa-icon{font-size:24px;width:32px;text-align:center}.qa-text{flex:1;display:flex;flex-direction:column;gap:2px}.qa-title{font-size:15px;font-weight:700}.qa-desc{font-size:13px;color:#64748b}.qa-arrow{font-size:22px;color:#cbd5e1}.profile-card{display:flex;gap:16px;align-items:flex-start;background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 4px #0000000f}.profile-avatar{width:56px;height:56px;border-radius:14px;background:#2563eb;color:#fff;display:grid;place-items:center;font-size:24px;font-weight:800;flex-shrink:0}.profile-info{display:flex;flex-direction:column;gap:4px}.profile-nome{font-size:18px;font-weight:800;color:#061746}.profile-cat{font-size:13px;color:#2563eb;font-weight:600}.profile-detail{font-size:13px;color:#64748b}.campaign-list{display:flex;flex-direction:column;gap:12px}.campaign-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000f;display:flex;align-items:stretch}.campaign-banner{width:120px;min-height:100px;object-fit:cover;flex-shrink:0}.campaign-banner-placeholder{width:120px;background:#f1f5fb;display:grid;place-items:center;font-size:36px;flex-shrink:0}.campaign-html-banner{width:100%;min-height:176px;border-radius:18px;overflow:hidden;background:#061746;box-shadow:inset 0 0 0 1px #ffffff14}.campaign-html-banner.compact{width:180px;min-height:118px;height:118px;border-radius:0;flex-shrink:0}.campaign-html-banner.compact .cd-ai-banner{min-height:118px!important;border-radius:0!important}.campaign-html-banner.compact h3{font-size:17px!important;margin-top:8px!important}.campaign-html-banner.compact p{display:none}.campaign-html-banner.compact .cd-ai-banner>div:last-child{padding:14px!important}.banner-ai-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.banner-ai-empty{min-height:120px;display:grid;place-items:center;padding:18px;border:1px dashed #cbd5e1;border-radius:14px;color:#64748b;text-align:center;background:#f8fafc}.campaign-body{flex:1;padding:16px 20px;display:flex;flex-direction:column;gap:6px}.campaign-top{display:flex;align-items:center;gap:10px}.campaign-titulo{font-size:16px;font-weight:700;color:#061746;flex:1}.campaign-badge{font-size:11px;font-weight:700;color:#fff;padding:3px 10px;border-radius:999px}.campaign-sub{font-size:13px;color:#64748b;margin:0}.campaign-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px;flex-wrap:wrap;gap:8px}.campaign-actions{display:flex;gap:8px;flex-wrap:wrap}.plan-options{display:flex;flex-direction:column;gap:10px}.plan-option{display:flex;align-items:flex-start;gap:12px;padding:14px;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer}.plan-option.selected{border-color:#2563eb;background:#eff6ff}.plan-option input[type=radio]{margin-top:3px;flex-shrink:0}.plan-option div{display:flex;flex-direction:column;gap:3px}.plan-option strong{font-size:14px;color:#061746}.plan-option span{font-size:13px;color:#64748b}.product-list{display:flex;flex-direction:column;gap:10px}.product-card{background:#fff;border-radius:12px;display:flex;align-items:center;gap:14px;padding:12px 16px;box-shadow:0 1px 4px #0000000f}.product-img{width:64px;height:64px;border-radius:10px;object-fit:cover;flex-shrink:0}.product-img-placeholder{width:64px;height:64px;border-radius:10px;background:#f1f5fb;display:grid;place-items:center;font-size:24px;flex-shrink:0}.product-info{flex:1;display:flex;flex-direction:column;gap:3px}.product-nome{font-size:15px;font-weight:700;color:#061746}.product-desc{font-size:12px;color:#64748b}.product-preco{display:flex;align-items:center;gap:8px}.preco-de{font-size:12px;color:#94a3b8;text-decoration:line-through}.preco-atual{font-size:15px;font-weight:800;color:#2563eb}.product-estoque{font-size:12px;color:#64748b}.product-actions{display:flex;gap:6px}.filter-bar{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:6px 14px;background:#f1f5f9;color:#475569;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;min-height:unset}.filter-btn.active{background:#2563eb;color:#fff}.order-list{display:flex;flex-direction:column;gap:10px}.order-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.order-header{display:flex;align-items:center;gap:12px;padding:16px 20px;cursor:pointer;flex-wrap:wrap}.order-id{font-size:14px;font-weight:800;color:#061746;font-family:monospace}.order-status{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}.order-total{font-size:16px;font-weight:800;color:#061746;margin-left:auto}.order-date{font-size:13px;color:#64748b}.order-toggle{color:#94a3b8;font-size:14px}.order-detail{padding:12px 20px 16px;display:flex;flex-direction:column;gap:8px;border-top:1px solid #f1f5f9}.order-item{display:flex;justify-content:space-between;font-size:14px;color:#334155}.order-summary{display:flex;flex-direction:column;gap:3px;font-size:14px;color:#64748b;padding:10px 0;border-top:1px dashed #e2e8f0}.order-summary strong{color:#16a34a;font-size:15px}.order-obs{font-size:13px;color:#64748b;margin:0}.order-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.chat-list{display:flex;flex-direction:column;gap:6px}.chat-list-item{display:flex;align-items:center;gap:14px;padding:16px 20px;background:#fff;border-radius:12px;min-height:unset;text-align:left;cursor:pointer;color:#061746;box-shadow:0 1px 4px #0000000d}.chat-list-item:hover{background:#f8fafc}.chat-avatar{font-size:28px;width:40px;text-align:center}.chat-meta{flex:1;display:flex;flex-direction:column;gap:3px}.chat-campaign{font-size:15px;font-weight:700}.chat-time{font-size:12px;color:#64748b}.chat-arrow{font-size:22px;color:#cbd5e1}.chat-room{height:calc(100vh - 120px);display:flex!important;flex-direction:column;gap:0!important}.chat-room-header{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:16px 0;display:flex;flex-direction:column;gap:8px}.chat-empty{text-align:center;color:#94a3b8;padding:40px}.chat-bubble-wrap{display:flex;flex-direction:column;max-width:70%}.chat-bubble-wrap.own{align-self:flex-end;align-items:flex-end}.chat-bubble-wrap.other{align-self:flex-start;align-items:flex-start}.chat-bubble{padding:10px 16px;border-radius:18px;font-size:14px;line-height:1.5;word-break:break-word}.bubble-own{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.bubble-other{background:#fff;color:#061746;box-shadow:0 1px 4px #00000014;border-bottom-left-radius:4px}.bubble-time{font-size:11px;color:#94a3b8;margin-top:3px}.chat-input-bar{display:flex;gap:10px;padding-top:12px;border-top:1px solid #e2e8f0;flex-shrink:0}.chat-input{flex:1;padding:12px 16px;border:1px solid #e2e8f0;border-radius:12px;font:inherit;font-size:14px;outline:none;color:#061746;min-height:unset}.chat-input:focus{border-color:#2563eb}.chat-send-btn{width:46px;height:46px;border-radius:12px;background:#2563eb;color:#fff;font-size:20px;font-weight:800;cursor:pointer;min-height:unset;flex-shrink:0}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.setup-page{min-height:100vh;display:grid;place-items:center;padding:32px 24px;background:linear-gradient(135deg,#eff6ff,#f8fafc)}.setup-card{background:#fff;border-radius:20px;padding:40px;width:min(100%,560px);box-shadow:0 8px 32px #2563eb1f}.setup-logo{display:block;width:160px;margin:0 auto 24px}.setup-sub{color:#64748b;margin:-12px 0 24px}.setup-form{display:flex;flex-direction:column;gap:16px}.field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.location-capture{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border:1px solid #dbeafe;border-radius:12px;background:#eff6ff}.location-capture div{display:flex;flex-direction:column;gap:3px}.location-capture strong{color:#061746;font-size:14px}.location-capture span,.location-capture small{color:#64748b;font-size:12px}.modal-lg{width:min(100%,640px)!important}.input{padding:10px 14px;border:1px solid #cbd5e1;border-radius:8px;font:inherit;font-size:14px;color:#0f172a;background:#fff;outline:none}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}select.input{cursor:pointer}.center-block{display:grid;place-items:center;padding:60px}@media (max-width: 768px){.portal-sidebar{position:fixed;left:-260px;top:0;z-index:100;height:100vh;transition:left .25s ease;overflow-y:auto}.portal-sidebar.open{left:0}.portal-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}.portal-menu-btn{display:flex}.portal-topbar{padding:14px 16px}.portal-content{padding:20px 16px}.campaign-card{flex-direction:column}.campaign-banner,.campaign-banner-placeholder,.campaign-html-banner.compact{width:100%;height:160px}.campaign-html-banner.compact .cd-ai-banner{min-height:160px!important}.section-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.chat-room{height:calc(100vh - 80px)}}
