:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%;box-sizing:border-box}*{box-sizing:border-box}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:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.home-page{padding:2rem;text-align:center}.home-page h1{color:#333;margin-bottom:1rem}.home-page p{color:#666;font-size:1.1rem}.header{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:1rem 0;position:sticky;top:0;z-index:100}.header-container{max-width:1200px;margin:0 auto;padding:0 2rem}.header-title{margin:0;color:#333;font-size:1.5rem;font-weight:600}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:inline-block;text-align:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.input-group{margin-bottom:1rem}.input-label{display:block;margin-bottom:.5rem;color:#6b7280;font-weight:600;font-size:.9rem}.required{color:#dc3545;margin-left:.25rem}.input-field{width:100%;padding:.85rem .95rem;border:1px solid #e5e7eb;border-radius:12px;font-size:1rem;background-color:#f9fafb;color:#111827;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease;box-sizing:border-box}.input-field:focus{outline:none;border-color:#2563eb;background-color:#fff;box-shadow:0 0 0 3px #2563eb1f}.input-error{border-color:#ef4444;background-color:#fff5f5}.input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}.input-error-message{display:block;color:#dc3545;font-size:.875rem;margin-top:.25rem}.sidebar{width:260px;min-height:100vh;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column;padding:1.75rem 1.5rem;gap:2rem}.sidebar-brand{display:flex;flex-direction:column;gap:.35rem}.sidebar-logo{font-size:1.2rem;font-weight:700;color:#f8fafc}.sidebar-tag{font-size:.85rem;color:#94a3b8}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.sidebar-link{text-decoration:none;color:#cbd5f5;padding:.65rem .9rem;border-radius:10px;font-weight:600;transition:background .2s ease,color .2s ease}.sidebar-link:hover{background:#1e293b;color:#f8fafc}.sidebar-link.is-active{background:#2563eb;color:#fff}.sidebar-footer{margin-top:auto}.sidebar-logout{width:100%;padding:.7rem .9rem;border:1px solid #1f2937;border-radius:10px;background:transparent;color:#e2e8f0;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease}.sidebar-logout:hover{background:#1e293b;color:#fff}.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:#f7f8fb;padding:2rem}.auth-layout{width:100%;max-width:1080px;display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:stretch}.auth-aside{background:linear-gradient(135deg,#111827,#1f2937);color:#f9fafb;border-radius:20px;padding:3rem;display:flex;flex-direction:column;justify-content:center;box-shadow:0 20px 50px #11182740}.brand-badge{background:#ffffff14;padding:.5rem 1rem;border-radius:999px;font-weight:600;font-size:.9rem;width:fit-content;letter-spacing:.3px;margin-bottom:1.5rem}.auth-title{font-size:2.25rem;line-height:1.2;margin:0 0 1rem}.auth-subtitle{color:#e5e7eb;font-size:1rem;margin:0 0 1.5rem}.auth-list{list-style:none;padding:0;margin:0;display:grid;gap:.75rem}.auth-list li{display:flex;align-items:center;gap:.5rem;color:#d1d5db}.auth-list li:before{content:"•";color:#60a5fa}.auth-card{background:#fff;border-radius:20px;padding:2.75rem;box-shadow:0 10px 40px #0f172a14}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:1.6rem;font-weight:700;color:#111827;margin:0 0 .5rem}.login-subtitle{color:#6b7280;font-size:.95rem;margin:0}.login-form{margin-bottom:1.25rem}.login-button{width:100%;margin-top:.75rem;padding:.95rem;font-size:1.05rem}.login-footer{text-align:center;padding-top:1.25rem;border-top:1px solid #eef2f7}.login-footer p{margin:0;color:#666;font-size:.9rem}@media(max-width:1024px){.auth-layout{grid-template-columns:1fr}.auth-aside{padding:2.5rem}.auth-card{padding:2.25rem}}@media(max-width:480px){.login-page{padding:1rem}.auth-aside{padding:2rem}.auth-title{font-size:1.7rem}.auth-card{padding:1.75rem}}.register-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:#f5f7fb;padding:2rem}.register-shell{width:100%;max-width:1040px;display:grid;gap:1.25rem}.register-hero{background:#fff;color:#111827;border-radius:18px;padding:1.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;border:1px solid #e5e7eb;box-shadow:0 12px 30px #0f172a0f}.brand-badge{background:#eef2ff;color:#3730a3;padding:.45rem .9rem;border-radius:999px;font-weight:700;font-size:.85rem;letter-spacing:.4px;white-space:nowrap}.register-hero-title{font-size:1.6rem;line-height:1.2;margin:0 0 .25rem}.register-hero-subtitle{color:#6b7280;font-size:.95rem;margin:0}.register-hero-tags{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.register-hero-tags span{background:#f3f4f6;color:#374151;padding:.35rem .7rem;border-radius:999px;font-size:.8rem;font-weight:600}.auth-card{background:#fff;border-radius:18px;padding:2.25rem;border:1px solid #e5e7eb;box-shadow:0 10px 30px #0f172a0f}.register-header{text-align:left;margin-bottom:1.1rem}.register-title{font-size:1.6rem;font-weight:700;color:#111827;margin:0 0 .5rem}.register-subtitle{color:#6b7280;font-size:.95rem;margin:0}.register-form{margin-bottom:1rem;display:grid;grid-template-columns:1fr 1fr;gap:.85rem 1.2rem}.register-form>*:nth-child(-n+4){grid-column:1 / -1}.register-form>.register-button,.register-form>.error-message{grid-column:1 / -1}.register-button{width:100%;margin-top:.5rem;padding:.9rem;font-size:1.05rem}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem;text-align:center;border:1px solid #fcc}.register-footer{text-align:left;padding-top:1.1rem;border-top:1px solid #eef2f7}.register-footer p{margin:0;color:#6b7280;font-size:.9rem}.link{color:#2563eb;text-decoration:none;font-weight:600;transition:color .3s ease}.link:hover{color:#1d4ed8;text-decoration:underline}@media(max-width:1024px){.register-shell{max-width:720px}.register-hero{padding:1.5rem;flex-direction:column;align-items:flex-start}.auth-card{padding:2rem}.register-form{grid-template-columns:1fr}.register-form>*{grid-column:1 / -1}}@media(max-width:480px){.register-page{padding:1rem}.register-hero{padding:1.25rem}.register-hero-title{font-size:1.4rem}.auth-card{padding:1.75rem}}.dashboard-layout{display:flex;min-height:100vh;background:#f8fafc}.dashboard-content{flex:1;padding:2.5rem}.dashboard-placeholder{background:#fff;border-radius:16px;padding:2rem;border:1px solid #e5e7eb;box-shadow:0 10px 30px #0f172a0f}.dashboard-placeholder h1{margin:0 0 .5rem;color:#111827}.dashboard-placeholder p{margin:0;color:#6b7280}@media(max-width:1024px){.dashboard-layout{flex-direction:column}.dashboard-content{padding:1.5rem}}.produtos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.produtos-header h1{margin:0 0 .25rem;color:#111827}.produtos-header p{margin:0;color:#6b7280}.produtos-button{background:#2563eb;color:#fff;border:none;padding:.7rem 1.2rem;border-radius:10px;font-weight:600;cursor:pointer}.produtos-table{background:#fff;border-radius:16px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 10px 30px #0f172a0f}.produtos-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:1rem 1.5rem;align-items:center;border-bottom:1px solid #f1f5f9;color:#0f172a}.produtos-row--clickable{cursor:pointer;transition:background .2s ease}.produtos-row--clickable:hover{background:#f8fafc}.produtos-row--clickable:focus-visible{outline:2px solid #93c5fd;outline-offset:-2px}.produtos-row--empty{grid-template-columns:1fr;text-align:center;color:#64748b}.produtos-row--header{background:#f8fafc;font-weight:600;color:#64748b;text-transform:uppercase;font-size:.8rem}.produtos-info{display:flex;align-items:center;gap:.75rem;color:#0f172a}.produtos-info img{width:48px;height:48px;border-radius:10px;object-fit:cover;border:1px solid #e5e7eb}.produtos-status{display:inline-block;padding:.25rem .7rem;border-radius:999px;font-size:.8rem;font-weight:600;text-align:center}.status-ativo{background:#dcfce7;color:#166534}.status-inativo{background:#e2e8f0;color:#475569}.status-indisponivel{background:#fee2e2;color:#991b1b}@media(max-width:1024px){.produtos-row{grid-template-columns:2fr 1fr 1fr}.produtos-row span:last-child{display:none}}@media(max-width:640px){.produtos-header{flex-direction:column;align-items:flex-start;gap:1rem}.produtos-row{grid-template-columns:1fr;gap:.5rem}.produtos-row--header{display:none}}.produtos-novo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.produtos-novo-header h1{margin:0 0 .25rem;color:#111827}.produtos-novo-header p{margin:0;color:#6b7280}.produtos-novo-back{border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;padding:.6rem 1.1rem;border-radius:10px;cursor:pointer;font-weight:600}.produtos-novo-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;padding:1.5rem;box-shadow:0 10px 30px #0f172a0f}.produtos-novo-error{background:#fee2e2;color:#991b1b;padding:.75rem 1rem;border-radius:10px;font-weight:600;margin-bottom:1rem}.produtos-novo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.25rem}.produtos-novo-field{display:flex;flex-direction:column;gap:.4rem}.produtos-novo-field label{font-weight:600;color:#0f172a}.produtos-novo-field input,.produtos-novo-field textarea,.produtos-novo-field select{border:1px solid #e2e8f0;border-radius:10px;padding:.65rem .85rem;font-size:.95rem;background:#f8fafc;color:#0f172a}.produtos-novo-field textarea{min-height:110px;resize:vertical}.produtos-novo-field--full{grid-column:1 / -1}.produtos-novo-preview{margin-top:.6rem;background:#f8fafc;border:1px dashed #cbd5f5;border-radius:12px;padding:.6rem;display:flex;justify-content:center}.produtos-novo-preview img{width:100%;max-width:320px;max-height:200px;object-fit:cover;border-radius:10px;border:1px solid #e5e7eb}.produtos-novo-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.produtos-novo-secondary{border:1px solid #e2e8f0;background:#fff;color:#0f172a;padding:.65rem 1.2rem;border-radius:10px;font-weight:600;cursor:pointer}.produtos-novo-primary{background:#2563eb;color:#fff;border:none;padding:.65rem 1.4rem;border-radius:10px;font-weight:600;cursor:pointer}@media(max-width:768px){.produtos-novo-header{flex-direction:column;align-items:flex-start;gap:1rem}.produtos-novo-grid{grid-template-columns:1fr}}.produto-detalhe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.produto-detalhe-header h1{margin:0 0 .25rem;color:#111827}.produto-detalhe-header p{margin:0;color:#6b7280}.produto-detalhe-back{border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;padding:.6rem 1.1rem;border-radius:10px;cursor:pointer;font-weight:600}.produto-detalhe-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;padding:1.5rem;box-shadow:0 10px 30px #0f172a0f}.produto-detalhe-state{color:#64748b;text-align:center;margin:0}.produto-detalhe-content{display:grid;grid-template-columns:minmax(0,280px) minmax(0,1fr);gap:1.5rem}.produto-detalhe-image{border-radius:14px;border:1px solid #e5e7eb;background:#f8fafc;padding:.75rem}.produto-detalhe-image img{width:100%;height:auto;border-radius:10px;object-fit:cover;max-height:280px}.produto-detalhe-info{display:flex;flex-direction:column;gap:1.25rem}.produto-detalhe-title{display:flex;align-items:center;justify-content:space-between;gap:1rem}.produto-detalhe-title h2{margin:0;color:#0f172a}.produto-detalhe-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.5rem}.produto-detalhe-grid span{display:block;color:#6b7280;font-size:.85rem}.produto-detalhe-grid strong{color:#0f172a;font-size:1rem}.produto-detalhe-descricao span{display:block;color:#6b7280;font-size:.85rem;margin-bottom:.35rem}.produto-detalhe-descricao p{margin:0;color:#0f172a;line-height:1.5}@media(max-width:900px){.produto-detalhe-content{grid-template-columns:1fr}}@media(max-width:640px){.produto-detalhe-header{flex-direction:column;align-items:flex-start;gap:1rem}.produto-detalhe-grid{grid-template-columns:1fr}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}
