:root{--primary-color: #2563eb;--primary-dark: #1e40af;--primary-light: #3b82f6;--secondary-color: #64748b;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--bg-color: #ffffff;--text-primary: #1f2937;--text-secondary: #6b7280;--border-color: #e5e7eb;--sidebar-bg: #f8fafc;--sidebar-text: #334155;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--border-radius-sm: .375rem;--border-radius-md: .5rem;--border-radius-lg: .75rem;--border-radius-full: 9999px;--transition: all .2s ease-in-out;--font-stack: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-stack);background-color:#f9fafb;color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;min-height:100vh;width:100%}.app-layout,.layout-container{display:flex;flex-direction:column;width:100%;min-height:100vh}.layout-header{background-color:var(--bg-color);border-bottom:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-user{display:flex;gap:var(--spacing-md);align-items:center}.user-email{font-size:.9rem;color:var(--text-secondary)}.logout-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition)}.logout-btn:hover{background-color:#f3f4f6;color:var(--danger-color);border-color:var(--danger-color)}.layout-body{display:flex;flex:1;width:100%}.sidebar,.layout-sidebar{width:220px;min-width:220px;background-color:var(--sidebar-bg);border-right:1px solid var(--border-color);position:sticky;top:0;height:100vh;overflow-y:auto;padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar::-webkit-scrollbar,.layout-sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track,.layout-sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb,.layout-sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:var(--border-radius-full)}.sidebar::-webkit-scrollbar-thumb:hover,.layout-sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.main-content,.layout-main{flex:1;display:flex;flex-direction:column;min-height:calc(100vh - 60px);padding:var(--spacing-xl);overflow-y:auto;width:0}.content-area{flex:1;padding:var(--spacing-xl);overflow-y:auto}.header{background-color:var(--bg-color);border-bottom:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm)}.header-title{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;gap:var(--spacing-md);align-items:center}.sidebar-title{font-size:1.25rem;font-weight:700;color:var(--primary-color);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.nav-section{margin-bottom:var(--spacing-xl)}.nav-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm)}.nav-list{list-style:none}.nav-item{margin-bottom:var(--spacing-sm)}.nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-md);color:var(--sidebar-text);text-decoration:none;border-radius:var(--border-radius-md);transition:var(--transition);font-size:.95rem;cursor:pointer}.nav-link:hover{background-color:#e2e8f0;color:var(--primary-color)}.nav-link.active{background-color:var(--primary-color);color:#fff;font-weight:600}.nav-link svg{width:20px;height:20px;flex-shrink:0}.form-group{margin-bottom:var(--spacing-lg)}.form-group:last-child{margin-bottom:0}label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--text-primary);font-size:.95rem}label.required:after{content:" *";color:var(--danger-color)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],select,textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-family:var(--font-stack);font-size:1rem;color:var(--text-primary);background-color:var(--bg-color);transition:var(--transition)}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=date]:focus,input[type=time]:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}input[type=text]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=number]:disabled,input[type=date]:disabled,input[type=time]:disabled,select:disabled,textarea:disabled{background-color:#f3f4f6;color:var(--text-secondary);cursor:not-allowed}textarea{resize:vertical;min-height:120px}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:2.5rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M7 8l3 3 3-3' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center}.input-group{display:flex;gap:var(--spacing-md)}.input-group input{flex:1}.input-error{display:block;font-size:.875rem;color:var(--danger-color);margin-top:var(--spacing-sm)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.form-row.full{grid-template-columns:1fr}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}button{font-family:var(--font-stack);cursor:pointer;border:none;border-radius:var(--border-radius-md);font-weight:600;transition:var(--transition);display:inline-flex;align-items:center;gap:var(--spacing-sm);justify-content:center}.btn{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}.btn-lg{padding:var(--spacing-lg) var(--spacing-xl);font-size:1.125rem}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{background-color:#cbd5e1;cursor:not-allowed;box-shadow:none}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover{background-color:#475569;box-shadow:var(--shadow-md)}.btn-outline{background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-outline:hover{background-color:#2563eb1a}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover{background-color:#dc2626;box-shadow:var(--shadow-md)}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover{background-color:#059669;box-shadow:var(--shadow-md)}.btn-warning{background-color:var(--warning-color);color:#fff}.btn-warning:hover{background-color:#d97706;box-shadow:var(--shadow-md)}.btn-block{width:100%}button:disabled{opacity:.6;cursor:not-allowed}.table-container{background-color:var(--bg-color);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl)}table{width:100%;border-collapse:collapse}thead{background-color:#f3f4f6;border-bottom:2px solid var(--border-color)}th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-weight:700;color:var(--text-primary);font-size:.95rem;white-space:nowrap}td{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);font-size:.95rem}tbody tr{transition:var(--transition)}tbody tr:hover{background-color:#f9fafb}tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:var(--spacing-sm)}.table-actions button{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}.card{background-color:var(--bg-color);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.card-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.card-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:var(--spacing-sm)}.card-body{font-size:.95rem;color:var(--text-secondary);line-height:1.8}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--bg-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-in-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:var(--transition)}.modal-close:hover{background-color:#f3f4f6;color:var(--text-primary)}.modal-body{padding:var(--spacing-xl)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-xl);border-top:1px solid var(--border-color);background-color:#f9fafb}.alert{padding:var(--spacing-lg);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);animation:slideDown .3s ease-in-out}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.alert-success{background-color:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.alert-error{background-color:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-warning{background-color:#fffbeb;color:#92400e;border:1px solid #fcd34d}.alert-info{background-color:#eff6ff;color:#0c2d6b;border:1px solid #bfdbfe}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-content{flex:1;font-size:.95rem}.alert-title{font-weight:700;margin-bottom:var(--spacing-sm)}.alert-close{background:none;border:none;cursor:pointer;color:inherit;padding:0;font-size:1.25rem;line-height:1;opacity:.7;transition:var(--transition)}.alert-close:hover{opacity:1}.tree{padding:0;margin:0}.tree-node{list-style:none;margin-bottom:0;-webkit-user-select:none;user-select:none}.tree-node-item{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border-radius:var(--border-radius-sm);transition:var(--transition);font-size:.95rem;color:var(--text-primary)}.tree-node-item:hover{background-color:#f3f4f6}.tree-node-item.selected{background-color:#dbeafe;color:var(--primary-color);font-weight:600}.tree-toggle{background:none;border:none;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-right:var(--spacing-sm);color:var(--text-secondary);transition:var(--transition)}.tree-toggle:hover{color:var(--primary-color)}.tree-toggle.collapsed:before{content:"▶";font-size:.75rem}.tree-toggle.expanded:before{content:"▼";font-size:.75rem}.tree-toggle.no-children{visibility:hidden}.tree-children{margin-left:1.5rem;display:none}.tree-children.visible{display:block}.tree-icon{margin-right:var(--spacing-sm);width:18px;height:18px;flex-shrink:0}.spinner{display:inline-block;width:20px;height:20px;border:3px solid #e5e7eb;border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-lg)}.loading-text{color:var(--text-secondary);font-size:.95rem}.pagination{display:flex;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-xl)}.pagination-item{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition);font-size:.95rem;background-color:var(--bg-color);color:var(--text-primary)}.pagination-item:hover{border-color:var(--primary-color);color:var(--primary-color)}.pagination-item.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:600}.pagination-item:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-full);font-size:.8rem;font-weight:700;white-space:nowrap}.badge-primary{background-color:#dbeafe;color:#0c2d6b}.badge-success{background-color:#dcfce7;color:#15803d}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-warning{background-color:#fef08a;color:#713f12}.badge-secondary{background-color:#e2e8f0;color:#334155}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.p-4{padding:var(--spacing-xl)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-primary{color:var(--primary-color)}.text-secondary{color:var(--text-secondary)}.text-danger{color:var(--danger-color)}.text-success{color:var(--success-color)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-normal{font-weight:400}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-between{justify-content:space-between}.flex-center{justify-content:center;align-items:center}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}.gap-3{gap:var(--spacing-lg)}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.w-full{width:100%}.h-full{height:100%}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.opacity-50{opacity:.5}.opacity-75{opacity:.75}@media (max-width: 1024px){.sidebar,.layout-sidebar{width:180px;min-width:180px}.main-content,.layout-main,.content-area{padding:var(--spacing-lg)}}@media (max-width: 768px){.sidebar,.layout-sidebar{position:absolute;left:-240px;width:240px;height:100vh;z-index:999;transition:left .3s ease-in-out}.sidebar.open,.layout-sidebar.open{left:0}.main-content{margin-left:0}.layout-main,.content-area{padding:var(--spacing-lg)}.form-row{grid-template-columns:1fr}.input-group{flex-direction:column}table{font-size:.85rem}th,td{padding:var(--spacing-sm)}.table-actions{flex-direction:column}.header,.layout-header{flex-direction:column;gap:var(--spacing-md)}.header-title{font-size:1.25rem}.modal{width:95%}}@media (max-width: 480px){:root{font-size:15px}.sidebar{width:100%;left:-100%}.card{padding:var(--spacing-lg)}.btn{width:100%}.form-row{grid-template-columns:1fr}.pagination{flex-wrap:wrap}.alert{padding:var(--spacing-md)}}@page{size:A4 landscape;margin:10mm 15mm}@media print{.sidebar,.layout-sidebar,.header,.layout-header,.btn,.logout-btn,.pagination,.nav-link,.sidebar-nav{display:none!important}html,body{width:100%;margin:0;padding:0;background-color:#fff;font-size:11pt;color:#000}#root{display:block;min-height:auto}.layout-container,.app-layout{display:block;width:100%;min-height:auto}.layout-body{display:block;width:100%}.main-content,.layout-main{margin-left:0;padding:0;width:100%;min-height:auto;overflow:visible}.content-area{padding:0}.card,.table-container{box-shadow:none;border:1px solid #ccc;page-break-inside:avoid;break-inside:avoid}table{width:100%;font-size:10pt}th,td{padding:4pt 8pt;border:1px solid #ccc}thead{background-color:#f0f0f0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.page-break-before{page-break-before:always;break-before:page}.page-break-after{page-break-after:always;break-after:page}.no-print{display:none!important}}
