:root{--sunculture-green:#00B140;--sunculture-green-dark:#009935;--sunculture-blue:#003366;--gray-light:#f3f4f6;--gray:#e5e7eb;--gray-dark:#6b7280;--error-red:#ef4444;--success-green:#10b981;--white:#ffffff;--black:#111827;--neutral-bg:#f9fafb;--yellow:#fbbf24;--orange:#f97316}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;line-height:1.5;color:var(--black);background-color:var(--white)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.header{background-color:var(--white);box-shadow:0 1px 3px rgba(0,0,0,.1);padding:.5rem 0}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem}.logo-section{display:flex;align-items:center}.logo{margin-right:1rem}.logo-link{display:block;max-width:120px}.logo-image{display:block;width:100%;height:auto;aspect-ratio:1024/387}.logo-section h1{font-size:1.5rem;font-weight:700;color:var(--black)}.user-section{display:flex;align-items:center;gap:1rem;color:var(--gray-dark)}.main-content{max-width:1200px;margin:0 auto;padding:3rem 1rem}.title-section{text-align:center;margin-bottom:2rem}.title-section h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:var(--black)}.title-section .subtitle{color:var(--gray-dark);font-size:1rem}.auth-section{display:flex;justify-content:center;align-items:center;min-height:60vh;transition:opacity .2s ease-in-out}.auth-card{background-color:var(--white);border-radius:.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:2rem;text-align:center;max-width:28rem;width:100%}.auth-card h2{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--black)}.auth-card p{color:var(--gray-dark);margin-bottom:2rem}.auth-card .loading-indicator{display:flex;flex-direction:column;align-items:center;padding:0}.auth-card .loading-indicator h2{margin-top:1rem;margin-bottom:.5rem}.auth-card .loading-indicator p{margin-bottom:0}.token-section{max-width:48rem;margin:0 auto}.card{background-color:var(--white);border-radius:.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:1.5rem;margin-bottom:1.5rem}.card h2,.card h3{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--black)}.card .subtitle{color:var(--gray-dark);font-size:.875rem;margin-bottom:1.5rem}.token-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;margin-bottom:.5rem;color:var(--black)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group input,.form-group select{padding:.5rem .75rem;border:1px solid var(--gray);border-radius:.375rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:0;border-color:var(--sunculture-green);box-shadow:0 0 0 3px rgba(0,177,64,.2)}.form-group input:invalid{border-color:var(--error-red)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:.2s;text-decoration:none;font-size:.875rem}.btn-primary{background-color:var(--sunculture-green);color:var(--white)}.btn-primary:hover{background-color:var(--sunculture-green-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:transparent;color:var(--gray-dark);border:1px solid var(--gray)}.btn-secondary:hover{background-color:var(--gray-light)}.btn-warning{background-color:var(--yellow);color:var(--black)}.btn-warning:hover{background-color:#f59e0b}.btn-danger{background-color:var(--error-red);color:var(--white)}.btn-danger:hover{background-color:#dc2626}.btn-generate{width:100%;padding:.75rem;font-size:1rem;margin-top:1rem}.btn-copy{padding:.5rem 1rem;font-size:.875rem}.token-result{margin-top:1.5rem;padding:1.5rem;background-color:var(--neutral-bg);border-radius:.5rem;border:1px solid var(--gray)}.token-result h3{color:var(--sunculture-green);margin-bottom:1rem}.token-display{display:flex;gap:.5rem;margin-bottom:1rem}.token-value{flex:1;padding:.75rem;border:1px solid var(--gray);border-radius:.375rem;background-color:var(--white);font-family:monospace;font-size:1.25rem;font-weight:600;text-align:center;letter-spacing:1px}.token-metadata{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem;margin-top:1rem}.token-metadata p{font-size:.875rem;color:var(--gray-dark)}.token-metadata strong{color:var(--black)}.key-actions{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.key-list{background-color:var(--neutral-bg);padding:1rem;border-radius:.375rem;margin-bottom:1rem}.key-list h4{margin-bottom:.5rem;color:var(--black)}.key-list ul{list-style:none;padding:0}.key-list li{padding:.25rem 0;font-family:monospace;color:var(--gray-dark)}.revoke-section{background-color:rgba(239,68,68,.1);padding:1rem;border-radius:.375rem;border:1px solid var(--error-red)}.revoke-section h4{color:var(--error-red);margin-bottom:.5rem}.revoke-section input{width:100%;margin-bottom:.5rem}.badge{display:inline-block;padding:.2em .6em;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:capitalize;white-space:nowrap}.badge-created{background-color:rgba(0,177,64,.12);color:var(--sunculture-green-dark)}.badge-recreated{background-color:rgba(251,191,36,.2);color:#92400e}.badge-first{background-color:rgba(0,51,102,.1);color:var(--sunculture-blue)}.key-version-cell{font-family:monospace;font-size:.8em;color:var(--gray-dark)}.audit-filters{display:grid;grid-template-columns:1fr 1fr auto;gap:1rem;margin-top:1rem;margin-bottom:1rem;padding:1rem;background-color:var(--neutral-bg);border-radius:.375rem;align-items:end}.provision-filters{grid-template-columns:1fr 1fr 1fr 1fr auto}.filter-group{display:flex;flex-direction:column}.filter-group label{font-weight:500;margin-bottom:.5rem;color:var(--black);font-size:.875rem}.filter-input,.filter-select{padding:.5rem .75rem;border:1px solid var(--gray);border-radius:.375rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.filter-input:focus,.filter-select:focus{outline:0;border-color:var(--sunculture-green);box-shadow:0 0 0 3px rgba(0,177,64,.2)}.filter-actions{display:flex;gap:.5rem;flex-wrap:wrap}.no-results{text-align:center;padding:2rem;color:var(--gray-dark);font-style:italic}.audit-table{overflow-x:auto;margin-top:1rem}.audit-table table{width:100%;border-collapse:collapse}.audit-table td,.audit-table th{padding:.5rem;text-align:left;border-bottom:1px solid var(--gray);font-size:.875rem}.audit-table th{font-weight:600;color:var(--black);background-color:var(--neutral-bg);white-space:nowrap}.audit-table td{white-space:nowrap}.audit-table .success{color:var(--success-green);font-weight:500}.audit-table .error{color:var(--error-red);font-weight:500}.audit-token-cell{display:flex;align-items:center;gap:.375rem}.audit-token-value{font-family:monospace;font-size:.875rem;letter-spacing:.05em}.audit-copy-btn{background:0 0;border:1px solid var(--gray);border-radius:3px;cursor:pointer;font-size:.8rem;padding:1px 4px;color:var(--gray-dark);line-height:1;flex-shrink:0;transition:background-color .15s,color .15s}.audit-copy-btn:hover{background-color:var(--neutral-bg);color:var(--black)}.pagination-controls{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:1rem;background-color:var(--neutral-bg);border-radius:.375rem;flex-wrap:wrap;gap:1rem}.pagination-info{color:var(--gray-dark);font-size:.875rem}.pagination-buttons{display:flex;align-items:center;gap:.5rem}.pagination-current{padding:0 .75rem;color:var(--black);font-size:.875rem;white-space:nowrap}.btn-pagination{min-width:2.5rem;height:2.5rem;padding:.5rem;background-color:var(--white);border:1px solid var(--gray);color:var(--gray-dark);font-size:1.125rem;font-weight:600;transition:.2s}.btn-pagination:hover:not(:disabled){background-color:var(--sunculture-green);border-color:var(--sunculture-green);color:var(--white)}.btn-pagination:disabled{opacity:.4;cursor:not-allowed;background-color:var(--gray-light)}.loading-indicator{display:flex;flex-direction:column;align-items:center;padding:2rem;color:var(--gray-dark)}.spinner{width:2rem;height:2rem;border:3px solid rgba(0,177,64,.2);border-top-color:var(--sunculture-green);border-radius:50%;animation:1s linear infinite spin;margin-bottom:.5rem}.spinner-small{display:inline-block;width:.875rem;height:.875rem;border:2px solid rgba(0,177,64,.2);border-top-color:var(--sunculture-green);border-radius:50%;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.input-autofilled{border-color:var(--success-green)!important;background-color:rgba(16,185,129,.05);transition:.3s}.input-autofilled:focus{box-shadow:0 0 0 3px rgba(16,185,129,.2)!important}.toast-container{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem;max-width:24rem}.toast{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-radius:.375rem;box-shadow:0 4px 6px rgba(0,0,0,.1);transition:.3s}.toast.success{background-color:var(--success-green);color:var(--white)}.toast.error{background-color:var(--error-red);color:var(--white)}.toast.info{background-color:var(--sunculture-blue);color:var(--white)}.toast-close{background:0 0;border:none;color:inherit;font-size:1.25rem;cursor:pointer;margin-left:.5rem}.footer{background-color:var(--gray-light);padding:1.5rem 0;margin-top:3rem;text-align:center}.footer p{color:var(--gray-dark);font-size:.875rem}.highlight{font-weight:600;color:var(--sunculture-green)}.text-error{color:var(--error-red)}.text-success{color:var(--success-green)}.text-muted{color:var(--gray-dark)}@media (max-width:1024px){.provision-filters{grid-template-columns:1fr 1fr auto}}@media (max-width:768px){.header-content{padding:0 1rem}.main-content{padding:2rem 1rem}.title-section h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}.key-actions,.token-display{flex-direction:column}.token-metadata{grid-template-columns:1fr}.toast-container{left:1rem;right:1rem;max-width:none}.audit-filters,.provision-filters{grid-template-columns:1fr;gap:1rem}.filter-actions{justify-content:stretch}.filter-actions .btn{flex:1}.audit-table{font-size:.75rem}.audit-table td,.audit-table th{padding:.375rem;font-size:.75rem}.pagination-controls{flex-direction:column;align-items:stretch;gap:.75rem}.pagination-info{text-align:center}.pagination-buttons{justify-content:center}.pagination-current{font-size:.75rem}.btn-pagination{min-width:2rem;height:2rem;font-size:1rem}}@media (max-width:480px){.card{padding:1rem}.auth-card{padding:1.5rem}.token-value{font-size:1rem}}