html,body,#root{min-height:100%;margin:0;padding:0}body{background:#f2f3f3;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Hiragino Sans,Noto Sans JP,Yu Gothic,Meiryo,sans-serif;font-size:16px;line-height:1.8;overflow:hidden}.aws-service-container-line{box-sizing:border-box;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;width:100%;margin:0 auto;padding:24px;display:grid}.aws-service-container{box-sizing:border-box;min-height:100px;color:inherit;background-color:#fff;border:2px solid #d5dbdb;border-radius:8px;justify-content:flex-start;align-items:center;gap:15px;padding:20px;text-decoration:none;transition:box-shadow .2s,transform .15s,border-color .2s;display:flex;box-shadow:0 1px 2px #0f172a0f}.aws-service-container:hover{cursor:pointer;border:2px solid #87cefa;transform:translateY(-2px);box-shadow:0 4px 12px #0f172a1f}.aws-service-container:active{transform:translateY(0);box-shadow:0 2px 6px #0f172a1a}.aws-service-container img{object-fit:contain;flex:none;width:48px;height:48px}.aws-service-container h3{color:#343434;margin:0;font-size:20px;font-weight:700;line-height:1.4}.container-disabled{opacity:.5;cursor:not-allowed;background-color:#f7f7f7}.container-disabled:hover{box-shadow:none;border-color:#d5dbdb;transform:none}.aws-service-container-disabled h3{color:#879596}.app-layout{width:100%;height:calc(100vh - 50px);display:flex}.app-main{background-color:#f9fafb;flex:1;min-width:0;transition:width .3s;overflow:auto}.guest-disabled{opacity:.5;cursor:not-allowed}@media (width<=900px){.aws-service-container-line{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (width<=600px){.aws-service-container-line{grid-template-columns:1fr}}.aws-page{box-sizing:border-box;grid-template-columns:1fr;align-items:start;gap:24px;max-width:1200px;margin:0 auto;padding:32px 24px 48px;display:grid}.aws-page-top{justify-content:space-between;align-items:center;gap:16px;margin-bottom:4px;display:flex}.aws-page-title{align-items:center;gap:12px;display:flex}.aws-page-top h2{color:#16191f;margin:0;font-size:28px;font-weight:700}.group-header{justify-content:space-between;align-items:center;display:flex}.aws-icon{object-fit:contain;width:40px;height:40px}.preview-toggle-button{white-space:nowrap;min-width:160px}.remove-group-button{background:#dc2626;border-color:#dc2626;min-width:72px;padding:10px 14px}.remove-group-button:hover{background:#b91c1c;border-color:#b91c1c}.form-section,.warning-section,.preview-section{box-sizing:border-box;background:#fff;border:1px solid #d5dbdb;border-radius:16px;width:100%;box-shadow:0 8px 24px #0f172a0f}.form-section{padding:28px 24px 24px;position:relative}.group-header-button{align-items:center;gap:12px;display:flex}.usecase-header{align-items:center;gap:8px;display:flex}.help-icon-button{cursor:pointer;width:24px;min-width:24px;height:24px;min-height:24px;box-shadow:none;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.help-icon-button:hover{background:0 0;border:none;transform:none}.help-icon{opacity:.75;width:18px;height:18px;display:block}.help-panel{background:#f8fbff;border:1px solid #dbe3f0;border-radius:10px;margin-top:8px;padding:12px 14px}.help-panel p{color:#334155;margin:0 0 10px;font-size:13px;line-height:1.7}.help-panel p:last-child{margin-bottom:0}.form-group{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.form-group:last-child{margin-bottom:0}.form-group label{color:#1f2937;font-size:14px;font-weight:700;line-height:1.5}.form-group input,.form-group select,.form-group textarea,.tag-row input{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #cbd5e1;border-radius:10px;width:100%;min-height:44px;padding:10px 12px;font-size:14px;line-height:1.5;transition:border-color .2s,box-shadow .2s,background-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.tag-row input:focus,.preview-section textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 4px #2563eb1f}.form-group input::placeholder,.tag-row input::placeholder,.preview-section textarea::placeholder{color:#94a3b8}.checkbox-group{margin-bottom:14px}.checkbox-group label{cursor:pointer;align-items:flex-start;gap:10px;font-weight:600;display:flex}.checkbox-group input[type=checkbox]{accent-color:#2563eb;width:18px;min-width:18px;height:18px;min-height:18px;box-shadow:none;margin-top:2px;padding:0}.tag-list{flex-direction:column;gap:12px;display:flex}.tag-row{grid-template-columns:minmax(140px,1fr) minmax(180px,1fr) auto;align-items:center;gap:10px;display:grid}button{color:#fff;cursor:pointer;background:#2563eb;border:1px solid #2563eb;border-radius:10px;min-height:42px;padding:10px 16px;font-size:14px;font-weight:700;line-height:1;transition:background-color .2s,border-color .2s,transform .15s,opacity .2s}button:hover{background:#1d4ed8;border-color:#1d4ed8}button:active{transform:translateY(1px)}button:disabled{opacity:.55;cursor:not-allowed}.add-tag-button{width:220px;margin:6px auto 0;display:block}.add-group-button{width:220px;margin:6px auto 30px;display:block}.tag-row button{background:#dc2626;border-color:#dc2626;min-width:72px;padding:10px 14px}.tag-row button:hover{background:#b91c1c;border-color:#b91c1c}.input-error{color:#dc2626;margin:2px 0 0;font-size:13px;font-weight:600;line-height:1.5}.label-duplicate-error{color:#d93025;margin-left:8px;font-size:.9rem;font-weight:700}.warning-section{background:#fff8e6;border-color:#f5c46b;padding:20px 24px}.warning-section h3{color:#8a4b08;margin:0 0 10px;font-size:18px;font-weight:700}.warning-section p{color:#8a4b08;margin:0 0 8px;font-size:14px;line-height:1.7}.warning-section p:last-child{margin-bottom:0}.preview-section{flex-direction:column;min-height:720px;padding:24px;display:flex}.preview-section-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.preview-section-header h3{color:#16191f;margin:0;font-size:20px;font-weight:700}.preview-section textarea{box-sizing:border-box;resize:vertical;color:#e2e8f0;white-space:pre;background:#0f172a;border:1px solid #cbd5e1;border-radius:12px;width:100%;min-height:640px;padding:18px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.7;overflow:auto}.preview-section .input-error{margin-top:12px}.aws-page.form-mode .form-section,.aws-page.form-mode .warning-section,.aws-page.preview-mode .preview-section{display:block}@media (width<=768px){.aws-page{gap:16px;padding:20px 16px 32px}.aws-page-top{flex-direction:column;align-items:stretch}.aws-page-title{align-items:center}.aws-page-top h2{font-size:24px}.preview-toggle-button{width:100%;min-width:auto}.form-section,.warning-section,.preview-section{border-radius:12px;padding:18px 16px}.tag-row{grid-template-columns:1fr}.tag-row button{width:100%}.preview-section{min-height:auto}.preview-section-header{flex-direction:column;align-items:stretch}.preview-section-header button{width:100%}.preview-section textarea{min-height:420px;padding:14px;font-size:12px}}.site-header{color:#fff;background-color:#232f3e;min-height:98px;padding:0 10px}.site-header h1{margin:0;font-size:28px}.header-title a{color:inherit;text-decoration:none}.site-header button{color:#fff;cursor:pointer;background-color:#4682b4;border:none;border-radius:4px;width:150px;height:50px;padding:8px 16px;font-size:16px;font-weight:600;transition:background-color .2s,transform .1s}.site-header button:hover{background-color:#3a6d99}.site-header button:active{background-color:#2f5c80;transform:scale(.97)}.header-components{align-items:stretch;gap:0;min-height:98px;display:flex}.header-container{border-right:1px solid #ffffff40;align-items:center;padding:0 20px;display:flex}.header-menu{flex:none;align-items:center;display:flex}.menu-icon{cursor:pointer;width:20px;height:20px}.header-title{flex:1;min-width:300px}.header-actions{flex:none;gap:12px}.header-actions img{width:25px;height:25px}.header-loginstatus{white-space:nowrap;text-overflow:ellipsis;color:#fffc;flex-direction:column;flex:none;min-width:75px;max-width:160px;font-size:14px;display:flex;overflow:hidden}.header-loginstatus-top{justify-content:center;align-items:center;width:100%;height:30px;display:flex;position:relative}.header-loginstatus-top:after{content:"";background:#ffffff40;height:1px;position:absolute;bottom:0;left:-20px;right:-20px}.header-loginstatus-bottom{white-space:nowrap;text-overflow:ellipsis;justify-content:center;align-items:center;display:flex;overflow:hidden}.header-login{border-right:none;flex:none;padding-right:0}.disabled-action{opacity:.5;cursor:not-allowed}.header-actions .save-icon:not(.disabled-action){cursor:pointer}.sidebar{background-color:#fff;flex-shrink:0;width:0;height:calc(100vh - 50px);transition:width .3s;overflow:hidden}.sidebar.open{width:200px}.sidebar.closed{width:0}.sidebar-nav{box-sizing:border-box;flex-direction:column;width:200px;height:100%;display:flex}.sidebar-item{color:#000;white-space:nowrap;border:1px solid #000;gap:10px;padding:12px 20px;text-decoration:none;display:flex}.sidebar-item img{width:25px;height:25px}.sidebar-item:hover{border:2px solid #87cefa}.save-workspace-modal-backdrop{z-index:1000;box-sizing:border-box;background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.save-workspace-modal{box-sizing:border-box;background:#fff;border-radius:12px;width:min(440px,100%);padding:24px;box-shadow:0 20px 50px #0f172a33}.save-workspace-modal h2{color:#16191f;margin:0 0 8px;font-size:1.25rem}.save-workspace-modal-hint{color:#545b64;margin:0 0 16px;font-size:14px;line-height:1.5}.save-workspace-modal-field{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.save-workspace-modal-field label{color:#232f3e;font-size:14px;font-weight:600}.save-workspace-modal-field input,.save-workspace-modal-field textarea{border:1px solid #d5dbdb;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:15px}.save-workspace-modal-field textarea{resize:vertical;min-height:72px}.save-workspace-modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.save-workspace-modal-actions button{cursor:pointer;color:#232f3e;background:#fff;border:1px solid #d5dbdb;border-radius:8px;min-width:100px;padding:10px 16px;font-size:15px}.save-workspace-modal-actions button[type=submit]{color:#fff;background:#4682b4;border-color:#4682b4}.save-workspace-modal-actions button:disabled{opacity:.6;cursor:not-allowed}
