@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Noto+Sans+JP:wght@300;400;500;700&display=swap";.header{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,var(--color-navy-900) 0%,var(--color-navy-800) 100%);border-bottom:2px solid var(--color-gold-500);box-shadow:0 2px 16px #0a16284d;z-index:var(--z-fixed, 1030)}.header-content{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 var(--spacing-xl, 2rem);max-width:1400px;margin:0 auto}.header-left-section{display:flex;align-items:center;gap:var(--spacing-sm, .5rem)}.hamburger-button{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;border:1.5px solid rgba(255,255,255,.18);border-radius:var(--border-radius-md, .5rem);color:#ffffffd9;cursor:pointer;transition:all var(--transition-fast, .15s);flex-shrink:0}.hamburger-button:hover{background:#ffffff1a;border-color:var(--color-gold-400, #CDB060);color:var(--color-gold-300, #DEC878)}.hamburger-icon{font-size:1.15rem}.header-user-section{display:flex;align-items:center;gap:var(--spacing-sm, .5rem)}.user-info{display:flex;align-items:center;gap:6px;padding:6px var(--spacing-sm, .5rem);border-radius:var(--border-radius-md, .5rem);cursor:default}.user-icon{font-size:1rem;color:var(--color-gold-400, #CDB060);flex-shrink:0}.user-name{font-size:var(--font-size-sm, .875rem);font-weight:500;color:#ffffffd9;letter-spacing:.01em;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-button{display:flex;align-items:center;gap:6px;padding:6px var(--spacing-sm, .5rem);background:#b8973a1f;border:1.5px solid rgba(184,151,58,.45);border-radius:var(--border-radius-md, .5rem);color:var(--color-gold-300, #DEC878);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s);white-space:nowrap}.admin-button:hover{background:#b8973a40;border-color:var(--color-gold-400, #CDB060);color:var(--color-gold-200, #EDD896);transform:translateY(-1px);box-shadow:0 2px 8px #b8973a33}.admin-icon{font-size:1rem;flex-shrink:0}.logout-button{display:flex;align-items:center;gap:6px;padding:6px var(--spacing-sm, .5rem);background:transparent;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--border-radius-md, .5rem);color:#ffffffbf;font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s);white-space:nowrap}.logout-button:hover{background:#c0392b26;border-color:#c0392b99;color:#e88070}.logout-icon{font-size:1rem;flex-shrink:0}.button-text{font-size:var(--font-size-sm, .875rem)}.breadcrumb-bar{background:#081120eb;border-top:1px solid rgba(255,255,255,.06);height:48px;display:flex;align-items:center;padding:0 var(--spacing-xl, 2rem);max-width:100%}.breadcrumb-nav{display:flex;align-items:center;gap:0;max-width:1400px;margin:0 auto;width:100%;overflow:hidden;white-space:nowrap}.breadcrumb-sep{color:#ffffff4d;font-size:1.3rem;padding:0 9px;-webkit-user-select:none;user-select:none;flex-shrink:0}.breadcrumb-link{color:#ffffff9e;font-size:1.05rem;font-weight:400;letter-spacing:.03em;text-decoration:none;transition:color var(--transition-fast, .15s);flex-shrink:0}.breadcrumb-link:hover{color:var(--color-gold-400, #CDB060)}.breadcrumb-current{color:var(--color-gold-300, #DEC878);font-size:1.1rem;font-weight:600;letter-spacing:.03em;flex-shrink:0;overflow:hidden;text-overflow:ellipsis}.gnav-wrapper{visibility:hidden;pointer-events:none}.gnav-wrapper--open{visibility:visible;pointer-events:auto}.gnav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:1035;opacity:0;transition:opacity .28s cubic-bezier(.4,0,.2,1);cursor:pointer}.gnav-wrapper--open .gnav-backdrop{opacity:1}.gnav-panel{position:fixed;top:0;left:0;bottom:0;width:272px;background:#111;border-right:1px solid rgba(255,255,255,.07);z-index:1040;display:flex;flex-direction:column;overflow:hidden;transform:translate(-100%);transition:transform .3s cubic-bezier(.25,.46,.45,.94);box-shadow:4px 0 24px #00000080}.gnav-wrapper--open .gnav-panel{transform:translate(0)}.gnav-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:64px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.gnav-logo{font-size:.7rem;font-weight:700;letter-spacing:.22em;color:#ffffff59;text-transform:uppercase}.gnav-close{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:#ffffff8c;cursor:pointer;transition:all var(--transition-fast, .15s);font-size:1.1rem}.gnav-close:hover{background:#ffffff14;border-color:#ffffff40;color:#fff}.gnav-body{flex:1;overflow-y:auto;padding:8px 0 24px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}.gnav-body::-webkit-scrollbar{width:4px}.gnav-body::-webkit-scrollbar-track{background:transparent}.gnav-body::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:2px}.gnav-group{border-bottom:1px solid rgba(255,255,255,.06);padding:8px 0}.gnav-group:last-child{border-bottom:none}.gnav-group-title{padding:10px 20px 4px;font-size:.65rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#b8973ab3}.gnav-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 20px;background:transparent;border:none;border-left:3px solid transparent;cursor:pointer;text-align:left;transition:all var(--transition-fast, .15s)}.gnav-item:hover{background:#ffffff0d;border-left-color:var(--color-gold-500, #B8973A)}.gnav-item--active{background:#b8973a1a;border-left-color:var(--color-gold-400, #CDB060)}.gnav-item-icon{font-size:1rem;color:#ffffff73;flex-shrink:0;display:flex;align-items:center;transition:color var(--transition-fast, .15s)}.gnav-item--active .gnav-item-icon{color:var(--color-gold-400, #CDB060)}.gnav-item:hover .gnav-item-icon{color:#ffffffbf}.gnav-item-label{font-size:.875rem;font-weight:400;color:#ffffffb3;letter-spacing:.02em;transition:color var(--transition-fast, .15s);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gnav-item--active .gnav-item-label{color:var(--color-gold-300, #DEC878);font-weight:600}.gnav-item:hover .gnav-item-label{color:#ffffffeb}@media(max-width:768px){.header-content{padding:0 var(--spacing-md, 1rem)}.button-text{display:none}.logout-button{padding:8px;border-radius:var(--border-radius-sm, .25rem)}.user-name{max-width:100px}.breadcrumb-bar{padding:0 var(--spacing-md, 1rem);height:44px}.gnav-panel{width:240px}}@media(max-width:480px){.header-content{padding:0 var(--spacing-sm, .5rem)}.user-name{display:none}.header-user-section{gap:var(--spacing-xs, .25rem)}.breadcrumb-bar{padding:0 var(--spacing-sm, .5rem);height:40px}.breadcrumb-nav{overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.breadcrumb-nav::-webkit-scrollbar{display:none}.breadcrumb-current{max-width:none;overflow:visible;text-overflow:clip}.gnav-panel{width:85vw;max-width:300px}}.dashboard{display:flex;flex-direction:column;min-height:100vh}.dashboard-main{flex:1;display:flex;flex-direction:column}.hero-section{flex:1;position:relative;background-image:url(/assets/back_ground_1-C2tgnesT.jpg);background-size:cover;background-position:center center;background-repeat:no-repeat;display:flex;flex-direction:column;min-height:calc(100vh - 136px)}.hero-overlay{flex:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#0a1628d1,#0e2040b8 60%,#0a1628cc);padding:1rem var(--spacing-xl, 2rem) .5rem}.hero-content{width:100%;max-width:1100px;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.hero-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm, .5rem)}.hero-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:2.5rem;font-weight:400;color:#fff;letter-spacing:.04em;text-shadow:0 2px 16px rgba(0,0,0,.6);position:relative;padding-bottom:var(--spacing-md, 1rem)}.hero-title:after{content:"";position:absolute;left:50%;bottom:0;transform:translate(-50%);width:48px;height:2px;background:linear-gradient(90deg,var(--color-gold-500, #B8973A),var(--color-gold-300, #DEC878));border-radius:2px}.hero-subtitle{font-family:var(--font-body, sans-serif);font-size:1rem;color:#ffffffa6;font-weight:400;letter-spacing:.08em;margin:0;text-shadow:0 1px 8px rgba(0,0,0,.5)}.hero-menu-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem var(--spacing-xl, 2rem);width:100%}.hero-menu-item{display:flex;flex-direction:column;align-items:center;gap:.6rem;background:none;border:none;padding:0;cursor:pointer;animation:iconAppear .5s cubic-bezier(.4,0,.2,1) both}.hero-menu-item:nth-child(1){animation-delay:.05s}.hero-menu-item:nth-child(2){animation-delay:.1s}.hero-menu-item:nth-child(3){animation-delay:.15s}.hero-menu-item:nth-child(4){animation-delay:.2s}.hero-menu-item:nth-child(5){animation-delay:.25s}.hero-menu-item:nth-child(6){animation-delay:.3s}.hero-menu-item:nth-child(7){animation-delay:.35s}.hero-menu-item:nth-child(8){animation-delay:.4s}.hero-menu-item:nth-child(9){animation-delay:.45s}.hero-menu-item:nth-child(10){animation-delay:.5s}@keyframes iconAppear{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.menu-icon{display:flex;align-items:center;justify-content:center;width:128px;height:128px;border-radius:50%;background:#ffffff2e;border:2.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;font-size:3rem;transition:transform .28s cubic-bezier(.4,0,.2,1),box-shadow .28s ease,border-color .28s ease,filter .28s ease;box-shadow:0 4px 20px #0000004d}.hero-menu-item:hover .menu-icon{transform:scale(1.14) translateY(-4px);box-shadow:0 8px 32px #0006,0 0 24px #ffffff40;border-color:#ffffffbf;filter:brightness(1.18)}.hero-menu-item:active .menu-icon{transform:scale(1.05);box-shadow:0 4px 16px #0000004d}.highlighted-icon{width:128px!important;height:128px!important;font-size:3rem!important;background:linear-gradient(135deg,var(--color-gold-500, #B8973A),var(--color-gold-600, #9A7720))!important;border:2.5px solid rgba(255,255,255,.5)!important;box-shadow:0 6px 24px #0006,0 0 0 4px #b8973a73,0 0 32px #b8973a66!important}.hero-menu-item--highlighted:hover .highlighted-icon{box-shadow:0 10px 40px #00000080,0 0 0 5px #b8973aa6,0 0 48px #b8973a99!important}.menu-title{font-family:var(--font-body, sans-serif);font-size:1.05rem;font-weight:700;color:#ffffffeb;letter-spacing:.04em;line-height:1.35;text-align:center;word-break:keep-all;overflow-wrap:break-word;text-shadow:0 1px 8px rgba(0,0,0,.6);transition:color .25s}.hero-menu-item:hover .menu-title{color:#fff}.hero-menu-item--highlighted .menu-title{color:var(--color-gold-300, #DEC878);font-size:.82rem;white-space:nowrap;text-shadow:0 1px 8px rgba(0,0,0,.6),0 0 16px rgba(184,151,58,.5)}.hero-menu-item--highlighted:hover .menu-title{color:#f0d070}@media(max-width:1024px){.hero-menu-grid{grid-template-columns:repeat(4,1fr);gap:var(--spacing-xl, 2rem) var(--spacing-lg, 1.5rem)}.menu-icon{width:112px;height:112px;font-size:2.6rem}.highlighted-icon{width:132px!important;height:132px!important;font-size:3rem!important}}@media(max-width:768px){.hero-overlay{padding:var(--spacing-2xl, 3rem) var(--spacing-md, 1rem);align-items:flex-start;padding-top:var(--spacing-3xl, 4rem);padding-bottom:var(--spacing-2xl, 3rem)}.hero-content{gap:var(--spacing-2xl, 3rem)}.hero-menu-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-xl, 2rem) var(--spacing-md, 1rem)}.hero-title{font-size:2rem}.menu-icon{width:92px;height:92px;font-size:2.2rem}.highlighted-icon{width:110px!important;height:110px!important;font-size:2.5rem!important}}@media(max-width:480px){.hero-overlay{padding:var(--spacing-xl, 2rem) var(--spacing-sm, .5rem);padding-bottom:var(--spacing-2xl, 3rem)}.hero-menu-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-lg, 1.5rem) var(--spacing-sm, .5rem)}.menu-icon{width:78px;height:78px;font-size:1.85rem}.highlighted-icon{width:78px!important;height:78px!important;font-size:1.85rem!important}.menu-title{font-size:.85rem;word-break:break-word}.hero-menu-item--highlighted .menu-title{white-space:normal;word-break:break-word}}@media(max-width:360px){.hero-overlay{padding:var(--spacing-xl, 2rem) 6px;padding-bottom:var(--spacing-2xl, 3rem)}.menu-icon{width:68px;height:68px;font-size:1.6rem}.highlighted-icon{width:68px!important;height:68px!important;font-size:1.6rem!important}.menu-title{font-size:.75rem;word-break:break-word}}.brand-bar{display:flex;align-items:center;height:72px;background:linear-gradient(135deg,var(--color-navy-900, #0A1628) 0%,var(--color-navy-800, #0E2040) 100%);border-bottom:2px solid var(--color-gold-500, #B8973A);flex-shrink:0}.brand-tile{flex:1;display:flex;align-items:center;justify-content:center;border-right:1px solid rgba(184,151,58,.35)}.brand-tile:last-child{border-right:none}.brand-logo{height:32px;width:auto;object-fit:contain}.brand-tile--light .brand-logo{filter:drop-shadow(0 0 6px rgba(255,255,255,.95)) drop-shadow(0 0 2px rgba(255,255,255,1))}.brand-tile--dark .brand-logo{filter:drop-shadow(0 0 6px rgba(255,255,255,.8)) drop-shadow(0 0 2px rgba(255,255,255,.8))}@media(max-width:768px){.brand-bar{height:56px}.brand-logo{height:26px}}@media(max-width:480px){.brand-bar{height:48px}.brand-logo{height:22px}}@media(max-width:360px){.brand-bar{height:42px}.brand-logo{height:18px}}@media print{.brand-bar{display:none!important}}.page-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-2xl, 1.5rem);font-weight:400;color:var(--color-navy-800, #0E2040);letter-spacing:-.01em;line-height:1.2;padding-bottom:var(--spacing-sm, .5rem);margin-bottom:var(--spacing-xl, 2rem);position:relative}.page-title:after{content:"";position:absolute;left:0;bottom:0;width:40px;height:2px;background:linear-gradient(90deg,var(--color-gold-500, #B8973A),var(--color-gold-300, #DEC878));border-radius:2px}@media(max-width:768px){.page-title{font-size:var(--font-size-xl, 1.25rem)}}@media(max-width:480px){.page-title{font-size:var(--font-size-lg, 1.125rem)}}.manuals-section{display:flex;flex-direction:column;gap:var(--spacing-2xl, 3rem)}.manuals-intro{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem);padding-bottom:var(--spacing-lg, 1.5rem);border-bottom:1px solid var(--color-cream-200, #EDE8DF);position:relative}.manuals-intro:after{content:"";position:absolute;bottom:-1px;left:0;width:48px;height:2px;background:var(--color-gold-500, #B8973A);border-radius:2px}.manuals-intro-label{font-family:var(--font-body, sans-serif);font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--color-gold-500, #B8973A)}.manuals-intro-description{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-muted, #6E7F8D);margin:0;line-height:var(--line-height-relaxed, 1.8)}.manuals-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg, 1.5rem)}.manual-department-card{position:relative;background:linear-gradient(160deg,var(--color-navy-800, #0E2040) 0%,#0A1830 100%);border-radius:var(--border-radius-lg, 1rem);overflow:hidden;cursor:pointer;padding:var(--spacing-xl, 2rem) var(--spacing-lg, 1.5rem) var(--spacing-lg, 1.5rem);display:flex;flex-direction:column;min-height:240px;animation:cardReveal .5s cubic-bezier(.4,0,.2,1) both;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;box-shadow:0 4px 24px #0a162859}.manual-department-card:nth-child(1){animation-delay:.05s}.manual-department-card:nth-child(2){animation-delay:.12s}.manual-department-card:nth-child(3){animation-delay:.19s}.manual-department-card:nth-child(4){animation-delay:.26s}@keyframes cardReveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.manual-department-card:before{content:attr(data-index);position:absolute;right:.75rem;bottom:.5rem;font-family:Georgia,Times New Roman,"Noto Serif JP",serif;font-size:7.25rem;font-weight:400;line-height:1;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;letter-spacing:0;color:#ffffff0f;pointer-events:none;-webkit-user-select:none;user-select:none}.manual-department-card:hover{transform:translateY(-6px);box-shadow:0 20px 56px #0a162880}.manual-card-accent{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--border-radius-lg, 1rem) var(--border-radius-lg, 1rem) 0 0;transition:height .3s ease}.manual-department-card:hover .manual-card-accent{height:5px}.manual-card-icon-wrapper{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:var(--border-radius-md, .5rem);font-size:1.4rem;color:#fff;flex-shrink:0;transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000004d}.manual-department-card:hover .manual-card-icon-wrapper{transform:scale(1.1)}.manual-card-body{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem);margin-top:var(--spacing-md, 1rem)}.manual-card-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-xl, 1.25rem);font-weight:400;color:#fff;margin:0;line-height:1.25;letter-spacing:.02em}.manual-card-divider{width:32px;height:2px;border-radius:1px;transition:width .35s cubic-bezier(.4,0,.2,1);flex-shrink:0}.manual-department-card:hover .manual-card-divider{width:52px}.manual-card-description{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:#ffffff7a;margin:0;line-height:1.55}.manual-card-footer{display:flex;justify-content:flex-end;align-items:center;margin-top:var(--spacing-md, 1rem)}.manual-card-arrow{font-size:.875rem;color:#ffffff4d;transition:transform .25s ease,color .25s ease}.manual-department-card:hover .manual-card-arrow{transform:translate(5px);color:#ffffffd9}@media(max-width:1024px){.manuals-card-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.manuals-card-grid{grid-template-columns:1fr}.manual-department-card{min-height:180px}.manual-department-card:before{font-size:5.75rem}}.dialog-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0a1628a6;z-index:var(--z-modal-backdrop, 1040);animation:dialogBackdropFadeIn .2s ease;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md, 1rem)}@keyframes dialogBackdropFadeIn{0%{opacity:0}to{opacity:1}}.dialog-container{position:relative;background:var(--color-white, #ffffff);border-radius:var(--border-radius-lg, 1rem);box-shadow:0 24px 64px #0a16284d;border-top:3px solid var(--color-gold-500, #B8973A);z-index:var(--z-modal, 1050);width:100%;max-width:680px;max-height:85vh;display:flex;flex-direction:column;animation:dialogSlideIn .25s cubic-bezier(.4,0,.2,1);overflow:hidden}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));border-bottom:1px solid var(--color-navy-600, #1B3A6B);flex-shrink:0}.dialog-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-lg, 1.125rem);font-weight:400;color:var(--color-white, #ffffff);margin-bottom:0;line-height:1.3}.dialog-close-button,.dialog-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:var(--border-radius-sm, .25rem);color:#ffffffbf;font-size:1.25rem;line-height:1;cursor:pointer;transition:all var(--transition-fast, .15s);flex-shrink:0}.dialog-close-button:hover,.dialog-close:hover{background:#c0392b33;border-color:#c0392b80;color:#e88070}.dialog-content,.dialog-body{padding:var(--spacing-xl, 2rem);overflow-y:auto;flex:1;background:var(--color-cream-50, #FDFBF8);color:var(--color-text-primary, #1A2433);font-size:var(--font-size-base, 1rem);line-height:var(--line-height-relaxed, 1.8)}.dialog-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm, .5rem);padding:var(--spacing-md, 1rem) var(--spacing-xl, 2rem);background:var(--color-white, #ffffff);border-top:1px solid var(--color-cream-200, #EDE8DF);flex-shrink:0}@media print{body *{visibility:hidden}.dialog-backdrop,.dialog-backdrop *{visibility:visible}.dialog-backdrop{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:none!important;padding:0!important;z-index:9999!important;display:block!important}.dialog-container{position:absolute!important;top:0!important;left:0!important;width:100%!important;max-width:100%!important;height:auto!important;max-height:none!important;border-radius:0!important;box-shadow:none!important;overflow:visible!important;border-top:none!important}.dialog-content,.dialog-body{overflow:visible!important;max-height:none!important;height:auto!important;padding:1rem 2rem!important}.dialog-close-button,.dialog-close,.dialog-footer{display:none!important}}@media(max-width:640px){.dialog-container{max-height:92vh;border-radius:var(--border-radius-md, .5rem)}.dialog-header,.dialog-content,.dialog-body,.dialog-footer{padding-left:var(--spacing-md, 1rem);padding-right:var(--spacing-md, 1rem)}}.toast-container{position:fixed;bottom:calc(var(--footer-height, 80px) + var(--spacing-md, 1rem));right:var(--spacing-lg, 1.5rem);z-index:var(--z-tooltip, 1070);display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--spacing-sm, .5rem);min-width:280px;max-width:380px;padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);border-radius:var(--border-radius-lg, 1rem);border-left:4px solid transparent;border-top:1px solid var(--color-gold-500, #B8973A);box-shadow:0 8px 32px #0a16282e,0 2px 8px #0a16281a;pointer-events:all;font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);line-height:var(--line-height-normal, 1.6);animation:toastSlideIn .3s cubic-bezier(.4,0,.2,1)}.toast.toast-exit{animation:toastSlideOut .25s cubic-bezier(.4,0,.2,1) forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.95)}}.toast-success{background:var(--color-white, #ffffff);border-left-color:var(--color-success, #2D7A4F);color:var(--color-text-primary, #1A2433)}.toast-success .toast-icon{color:var(--color-success, #2D7A4F)}.toast-error{background:var(--color-white, #ffffff);border-left-color:var(--color-error, #C0392B);color:var(--color-text-primary, #1A2433)}.toast-error .toast-icon{color:var(--color-error, #C0392B)}.toast-warning{background:var(--color-white, #ffffff);border-left-color:var(--color-gold-500, #B8973A);color:var(--color-text-primary, #1A2433)}.toast-warning .toast-icon{color:var(--color-gold-600, #9A7720)}.toast-info{background:var(--color-white, #ffffff);border-left-color:var(--color-navy-600, #1B3A6B);color:var(--color-text-primary, #1A2433)}.toast-info .toast-icon{color:var(--color-navy-600, #1B3A6B)}.toast-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}.toast-message{flex:1;color:var(--color-text-secondary, #3D4F62);font-size:var(--font-size-sm, .875rem);margin-bottom:0;word-break:break-word}.toast-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;border-radius:var(--border-radius-sm, .25rem);color:var(--color-text-muted, #6E7F8D);font-size:1rem;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast, .15s);margin-top:-2px}.toast-close:hover{background:var(--color-cream-100, #F7F4EF);color:var(--color-text-primary, #1A2433)}@media(max-width:480px){.toast-container{left:var(--spacing-md, 1rem);right:var(--spacing-md, 1rem);bottom:calc(var(--footer-height, 80px) + var(--spacing-sm, .5rem))}.toast{min-width:auto;max-width:100%}}body.request-confirmation-page .toast-container{z-index:10000}@media print{.toast-container{display:none!important}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0a1628a6;z-index:var(--z-modal-backdrop, 1040);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md, 1rem);animation:confirmOverlayFadeIn .2s ease}@keyframes confirmOverlayFadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog-container{background:var(--color-white, #ffffff);border-radius:var(--border-radius-lg, 1rem);box-shadow:0 24px 64px #0a16284d;border-top:3px solid var(--color-gold-500, #B8973A);z-index:var(--z-modal, 1050);width:100%;max-width:420px;animation:confirmDialogSlideIn .25s cubic-bezier(.4,0,.2,1);overflow:hidden}@keyframes confirmDialogSlideIn{0%{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-dialog-header{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem) var(--spacing-md, 1rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952))}.confirm-dialog-header h3{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-lg, 1.125rem);font-weight:400;color:var(--color-white, #ffffff);margin-bottom:0}.confirm-dialog-body{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);background:var(--color-cream-50, #FDFBF8)}.confirm-dialog-body p{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);line-height:var(--line-height-relaxed, 1.8);margin-bottom:0}.confirm-dialog-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm, .5rem);padding:var(--spacing-md, 1rem) var(--spacing-xl, 2rem);background:var(--color-white, #ffffff);border-top:1px solid var(--color-cream-200, #EDE8DF)}.confirm-dialog-cancel-button{padding:.5rem var(--spacing-md, 1rem);background:transparent;border:1.5px solid var(--color-cream-300, #DDD5C8);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:500;color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:all var(--transition-fast, .15s)}.confirm-dialog-cancel-button:hover{background:var(--color-cream-100, #F7F4EF);border-color:var(--color-cream-300, #DDD5C8)}.confirm-dialog-confirm-button{padding:.5rem var(--spacing-md, 1rem);background:var(--color-navy-800, #0E2040);border:1.5px solid var(--color-navy-800, #0E2040);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-white, #ffffff);cursor:pointer;transition:all var(--transition-fast, .15s)}.confirm-dialog-confirm-button:hover{background:var(--color-navy-900, #0A1628);border-color:var(--color-navy-900, #0A1628);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.confirm-dialog-confirm-button.approve{background:var(--color-success, #2D7A4F);border-color:var(--color-success, #2D7A4F)}.confirm-dialog-confirm-button.approve:hover{background:#246040;border-color:#246040}.confirm-dialog-confirm-button.reject{background:var(--color-error, #C0392B);border-color:var(--color-error, #C0392B)}.confirm-dialog-confirm-button.reject:hover{background:#a93226;border-color:#a93226}@media(max-width:480px){.confirm-dialog-container{max-width:95vw}.confirm-dialog-header,.confirm-dialog-body,.confirm-dialog-actions{padding-left:var(--spacing-md, 1rem);padding-right:var(--spacing-md, 1rem)}}@media print{.confirm-dialog-overlay{display:none!important}}.dept-manual-section{display:flex;flex-direction:column;gap:var(--spacing-xl, 2rem)}.dept-manual-header{background:linear-gradient(135deg,var(--color-navy-800, #0E2040) 0%,var(--color-navy-600, #1B3A6B) 100%);border-radius:var(--border-radius-lg, 1rem);border-bottom:3px solid var(--color-gold-500, #B8973A);box-shadow:0 4px 24px #0a162840;overflow:hidden;position:relative}.dept-manual-header:after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border:36px solid rgba(184,151,58,.08);border-radius:50%;pointer-events:none}.dept-manual-header-info{display:flex;align-items:center;gap:var(--spacing-lg, 1.5rem);padding:var(--spacing-xl, 2rem) var(--spacing-2xl, 3rem);position:relative;z-index:1}.dept-header-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--border-radius-lg, 1rem);font-size:1.8rem;color:#fff;flex-shrink:0;box-shadow:0 4px 16px #0000004d;border:1px solid rgba(255,255,255,.2)}.dept-header-text{flex:1;min-width:0}.dept-header-text h2{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-2xl, 1.5rem);font-weight:400;color:#fff;margin:0 0 var(--spacing-xs, .25rem) 0;letter-spacing:.04em}.dept-header-text p{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:#fff9;margin:0}.dept-manuals-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md, 1rem)}.dept-manual-card{position:relative;background:linear-gradient(160deg,var(--color-navy-800, #0E2040) 0%,#091526 100%);border-radius:var(--border-radius-lg, 1rem);overflow:hidden;cursor:pointer;box-shadow:0 4px 20px #0a16284d;transition:transform .28s cubic-bezier(.4,0,.2,1),box-shadow .28s ease;animation:manualCardReveal .45s cubic-bezier(.4,0,.2,1) both}.dept-manual-card:nth-child(1){animation-delay:.04s}.dept-manual-card:nth-child(2){animation-delay:.08s}.dept-manual-card:nth-child(3){animation-delay:.12s}.dept-manual-card:nth-child(4){animation-delay:.16s}.dept-manual-card:nth-child(5){animation-delay:.2s}.dept-manual-card:nth-child(6){animation-delay:.24s}@keyframes manualCardReveal{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dept-manual-card:before{content:attr(data-index);position:absolute;right:.75rem;bottom:.25rem;font-family:Georgia,Times New Roman,"Noto Serif JP",serif;font-size:5.5rem;font-weight:400;line-height:1;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;letter-spacing:0;color:#ffffff0f;pointer-events:none;-webkit-user-select:none;user-select:none}.dept-manual-card:after{content:"›";position:absolute;right:var(--spacing-lg, 1.5rem);top:50%;transform:translateY(-50%) translate(6px);font-size:1.5rem;color:#fff0;transition:opacity .25s,transform .25s,color .25s;line-height:1}.dept-manual-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #0a162880}.dept-manual-card:hover:after{color:#ffffff80;transform:translateY(-50%) translate(0)}.dept-manual-card-header{display:flex;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-lg, 1.5rem);border-left:4px solid transparent;padding-right:calc(var(--spacing-lg, 1.5rem) + 2rem)}.dept-manual-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--border-radius-md, .5rem);font-size:1.25rem;flex-shrink:0;transition:transform .25s ease}.dept-manual-card:hover .dept-manual-icon{transform:scale(1.08)}.dept-manual-title-area{flex:1;min-width:0}.dept-manual-title-area h3{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-base, 1rem);font-weight:400;color:#fff;margin:0 0 4px;line-height:1.3;letter-spacing:.02em}.dept-manual-title-area p{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:#ffffff73;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dept-no-manuals{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-4xl, 6rem) var(--spacing-xl, 2rem);text-align:center;background:var(--color-white, #ffffff);border:1px dashed var(--color-cream-300, #DDD5C8);border-radius:var(--border-radius-lg, 1rem)}.dept-no-manuals-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--border-radius-lg, 1rem);font-size:2rem;color:#fff;box-shadow:var(--shadow-md)}.dept-no-manuals h3{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-xl, 1.25rem);font-weight:400;color:var(--color-navy-700, #132952);margin:0}.dept-no-manuals p{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-muted, #6E7F8D);margin:0}.manual-dialog-content{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-lg, 1.5rem);overflow-y:auto;max-height:62vh}.manual-dialog-header{display:flex;align-items:flex-start;gap:var(--spacing-md, 1rem);padding-bottom:var(--spacing-md, 1rem);border-bottom:1px solid var(--color-cream-200, #EDE8DF)}.manual-dialog-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--border-radius-md, .5rem);font-size:1.4rem;flex-shrink:0}.manual-dialog-description{font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);color:var(--color-text-secondary, #3D4F62);line-height:var(--line-height-relaxed, 1.8);margin:0;padding-top:var(--spacing-xs, .25rem)}.manual-dialog-sections{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.manual-dialog-section{background:var(--color-cream-50, #FDFBF8);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);overflow:hidden}.manual-dialog-section h4{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;color:#fff;margin:0;padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));letter-spacing:.03em}.manual-dialog-section ul{list-style:none;padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);margin:0;display:flex;flex-direction:column;gap:1px}.manual-dialog-section li{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);padding:var(--spacing-xs, .25rem) 0 var(--spacing-xs, .25rem) var(--spacing-md, 1rem);border-bottom:1px solid var(--color-cream-100, #F7F4EF);position:relative;line-height:var(--line-height-normal, 1.6)}.manual-dialog-section li:last-child{border-bottom:none}.manual-dialog-section li:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:5px;height:5px;background:var(--color-gold-500, #B8973A);border-radius:50%}@media(max-width:768px){.dept-manual-header-info{flex-direction:column;align-items:flex-start;padding:var(--spacing-lg, 1.5rem)}.dept-header-text h2{font-size:var(--font-size-xl, 1.25rem)}.dept-manuals-grid{grid-template-columns:1fr}.dept-manual-card-header{padding:var(--spacing-md, 1rem);padding-right:calc(var(--spacing-md, 1rem) + 2rem)}.manual-dialog-content{padding:var(--spacing-md, 1rem)}.manual-dialog-header{flex-direction:column}}.content-section{display:flex;flex-direction:column;gap:var(--spacing-xl, 2rem)}.content-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg, 1.5rem);align-items:start}.content-item{background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-lg, 1rem);border-top:3px solid var(--color-navy-600, #1B3A6B);padding:var(--spacing-lg, 1.5rem);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal, .3s),transform var(--transition-normal, .3s)}.content-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.content-item h3{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-lg, 1.125rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin-bottom:var(--spacing-md, 1rem);padding-bottom:var(--spacing-sm, .5rem);border-bottom:1px solid var(--color-cream-200, #EDE8DF);position:relative}.content-item h3:after{content:"";position:absolute;left:0;bottom:-1px;width:28px;height:2px;background:var(--color-gold-500, #B8973A);border-radius:2px}.content-item ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.content-item li{display:flex;align-items:flex-start;gap:var(--spacing-sm, .5rem);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);line-height:var(--line-height-relaxed, 1.8);padding:4px 0;border-bottom:1px solid var(--color-cream-50, #FDFBF8)}.content-item li:last-child{border-bottom:none}.content-item li:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--color-gold-500, #B8973A);flex-shrink:0;margin-top:9px}@media(max-width:1024px){.content-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.content-grid{grid-template-columns:1fr}}.schedule-section{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.schedule-controls{display:flex;align-items:center;gap:var(--spacing-md, 1rem);flex-wrap:wrap}.department-selector-wrapper{flex-shrink:0}.dropdown-wrapper{position:relative;display:inline-block;min-width:200px}.dropdown-button{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm, .5rem);width:100%;padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:var(--color-white, #ffffff);border:2px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-navy-800, #0E2040);cursor:pointer;transition:border-color .2s,box-shadow .2s;box-shadow:var(--shadow-sm)}.dropdown-button:hover{border-color:var(--color-gold-500, #B8973A)}.dropdown-button-text{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:dropdownFadeIn .15s ease}.dropdown-menu button{display:block;width:100%;padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);text-align:left;background:transparent;border:none;font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);cursor:pointer;transition:background .15s}.dropdown-menu button:hover{background:var(--color-cream-100, #F7F4EF)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.calendar-header{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-lg, 1rem);box-shadow:var(--shadow-sm);flex-wrap:wrap}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-cream-100, #F7F4EF);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);color:var(--color-navy-700, #132952);cursor:pointer;transition:background .2s;flex-shrink:0;font-size:1rem}.calendar-nav-btn:hover:not(:disabled){background:var(--color-cream-200, #EDE8DF)}.calendar-nav-btn:disabled{opacity:.4;cursor:not-allowed}.calendar-title-section{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem);min-width:0}.calendar-title{font-family:var(--font-display, serif);font-size:var(--font-size-xl, 1.25rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin:0;letter-spacing:.04em}.calendar-title.clickable-title{cursor:pointer;text-decoration:underline;text-decoration-color:var(--color-gold-400, #CDB060);text-underline-offset:4px}.calendar-title.clickable-title:hover{color:var(--color-navy-600, #1B3A6B)}.department-stats-container{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.department-stats-toggle{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:2px var(--spacing-sm, .5rem);background:transparent;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D);cursor:pointer;transition:background .2s;align-self:flex-start}.department-stats-toggle:hover{background:var(--color-cream-100, #F7F4EF)}.department-stats-container>div:last-child{display:flex;gap:var(--spacing-sm, .5rem);flex-wrap:wrap}.stat-card{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:var(--color-cream-50, #FDFBF8);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);cursor:pointer;transition:box-shadow .2s,border-color .2s;min-width:100px}.stat-card:hover{border-color:var(--color-gold-400, #CDB060);box-shadow:0 2px 8px #b8973a26}.stat-card.working-days{border-left:3px solid var(--color-navy-500, #2A5B8F)}.stat-card-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-navy-100, #D4E6F4);border-radius:var(--border-radius-md, .5rem);font-size:1rem;color:var(--color-navy-700, #132952);flex-shrink:0}.stat-card-icon.holiday-icon{background:var(--color-warning-light, #FDF6E3);color:var(--color-gold-600, #9A7720)}.stat-card-icon.sales-icon{background:var(--color-success-light, #E8F5EE);color:var(--color-success, #2D7A4F)}.stat-card-icon.profit-icon{background:var(--color-error-light, #FDECEA);color:var(--color-error, #C0392B)}.stat-card-content{display:flex;flex-direction:column;gap:1px}.stat-card-label{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D)}.stat-card-value{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;color:var(--color-navy-800, #0E2040);white-space:nowrap}.stat-card-edit{color:var(--color-text-light, #A0ADB7);font-size:.9rem;flex-shrink:0}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg, 1.5rem)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-cream-200, #EDE8DF);border-top-color:var(--color-navy-500, #2A5B8F);border-radius:50%;animation:spin .8s linear infinite}.calendar-container{background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-lg, 1rem);overflow:hidden;box-shadow:var(--shadow-sm);min-width:420px}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952))}.calendar-weekday{padding:var(--spacing-md, 1rem) var(--spacing-sm, .5rem);text-align:center;font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);font-weight:700;color:#ffffffd1;letter-spacing:.04em}.calendar-scroll-outer{overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--color-cream-200, #EDE8DF);grid-auto-rows:130px}.calendar-grid>*{border-right:1px solid var(--color-cream-100, #F7F4EF);border-bottom:1px solid var(--color-cream-100, #F7F4EF);padding:var(--spacing-sm, .5rem);position:relative;background:var(--color-white, #ffffff);transition:background .15s;overflow:hidden}.calendar-grid>*:nth-child(7n){border-right:none}.calendar-grid>*.holiday{background:var(--color-cream-200, #EDE8DF);opacity:.75}.calendar-day-number{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);font-weight:700;color:var(--color-text-secondary, #3D4F62);margin-bottom:4px;line-height:1}.calendar-store-holiday{font-family:var(--font-body, sans-serif);font-size:10px;font-weight:600;color:var(--color-text-muted, #6E7F8D);background:#00000014;border-radius:2px;padding:0 3px;margin-bottom:2px;display:inline-block}.calendar-japanese-holiday{font-family:var(--font-body, sans-serif);font-size:10px;color:var(--color-error, #C0392B);background:var(--color-error-light, #FDECEA);border-radius:2px;padding:0 3px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.calendar-events{display:flex;flex-direction:column;gap:2px}.event-content{display:flex;align-items:center;gap:3px;padding:2px 4px;border-radius:3px;font-family:var(--font-body, sans-serif);font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:opacity .15s}.event-content:hover{opacity:.85}.event-time{font-size:9px;opacity:.82;flex-shrink:0}.event-attachment-icon{font-size:9px;flex-shrink:0;opacity:.9}.dialog-actions{display:flex;gap:var(--spacing-sm, .5rem);justify-content:flex-end;padding:var(--spacing-md, 1rem) var(--spacing-xl, 2rem);border-top:1px solid var(--color-cream-200, #EDE8DF);background:var(--color-cream-50, #FDFBF8)}.dialog-btn{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s,background .2s;border:none}.dialog-btn-cancel{background:transparent;border:1px solid var(--color-cream-200, #EDE8DF)!important;color:var(--color-text-secondary, #3D4F62)}.dialog-btn-cancel:hover{background:var(--color-cream-100, #F7F4EF)}.dialog-btn-save{background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));color:#fff;box-shadow:var(--shadow-sm)}.dialog-btn-save:hover{opacity:.88}.dialog-btn-save:disabled{opacity:.5;cursor:not-allowed}.dialog-btn-delete{background:var(--color-error-light, #FDECEA);color:var(--color-error, #C0392B);border:1px solid var(--color-error, #C0392B)!important}.dialog-btn-delete:hover{background:#f5c0bb}.event-form{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem);overflow-y:auto;max-height:60vh}.settings-form{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.form-input,.form-group input,.form-group select{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);background:var(--color-white, #ffffff);transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box}.form-input:focus,.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-navy-500, #2A5B8F);box-shadow:0 0 0 3px #2a5b8f1f}.form-textarea,.form-group textarea{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);background:var(--color-white, #ffffff);transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box;resize:vertical;min-height:80px}.form-textarea:focus,.form-group textarea:focus{outline:none;border-color:var(--color-navy-500, #2A5B8F);box-shadow:0 0 0 3px #2a5b8f1f}.form-readonly-value{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:var(--color-cream-50, #FDFBF8);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62)}.schedule-attachment-list{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.schedule-attachment-item{display:grid;grid-template-columns:84px 1fr auto;gap:var(--spacing-sm, .5rem);align-items:center;padding:var(--spacing-sm, .5rem);background:var(--color-cream-50, #FDFBF8);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem)}.schedule-attachment-preview-link{display:inline-flex;text-decoration:none;border-radius:6px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.schedule-attachment-preview-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0e20401f}.schedule-attachment-preview-link:focus-visible{outline:2px solid var(--color-navy-600, #1B3A6B);outline-offset:2px}.schedule-attachment-preview{width:84px;height:60px;border-radius:6px;overflow:hidden;background:var(--color-white, #ffffff);border:1px solid rgba(14,32,64,.08);display:flex;align-items:center;justify-content:center}.schedule-attachment-image{width:100%;height:100%;object-fit:cover;display:block}.schedule-attachment-video{width:100%;height:100%;object-fit:cover;display:block;background:#000}.schedule-attachment-file{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-navy-700, #132952);font-size:1.35rem;background:linear-gradient(135deg,#f7f4ef,#fff)}.schedule-attachment-file.pdf{color:var(--color-error, #C0392B)}.schedule-attachment-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.schedule-attachment-link{display:inline-flex;align-items:center;gap:4px;min-width:0;color:var(--color-navy-700, #132952);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;text-decoration:none}.schedule-attachment-link span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.schedule-attachment-link:hover{color:var(--color-navy-500, #2A5B8F)}.schedule-attachment-size{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D)}.schedule-attachment-remove{width:32px;height:32px;border:1px solid rgba(192,57,43,.35);border-radius:var(--border-radius-md, .5rem);background:var(--color-error-light, #FDECEA);color:var(--color-error, #C0392B);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.schedule-attachment-remove:hover{background:#f5c0bb}.schedule-attachment-inputs{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.schedule-attachment-input-row{display:grid;grid-template-columns:1fr 36px;gap:var(--spacing-sm, .5rem);align-items:center}.schedule-attachment-input-remove{width:36px;height:36px;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);background:var(--color-white, #ffffff);color:var(--color-error, #C0392B);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.schedule-attachment-add{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);border:1px dashed var(--color-navy-500, #2A5B8F);border-radius:var(--border-radius-md, .5rem);background:#2a5b8f0f;color:var(--color-navy-700, #132952);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:background .2s,border-color .2s}.schedule-attachment-add:hover{background:#2a5b8f1f;border-color:var(--color-navy-700, #132952)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md, 1rem)}.time-error-message{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-error, #C0392B);margin-top:-var(--spacing-sm,.5rem)}.holiday-settings-container{padding:var(--spacing-md, 1rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem);overflow-y:auto;max-height:65vh}.holiday-settings-tabs{display:flex;gap:var(--spacing-xs, .25rem);border-bottom:2px solid var(--color-cream-200, #EDE8DF);margin-bottom:var(--spacing-sm, .5rem)}.holiday-settings-tabs button{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-text-muted, #6E7F8D);cursor:pointer;transition:color .2s,border-color .2s}.holiday-settings-tabs button:hover{color:var(--color-navy-700, #132952)}.holiday-settings-tabs button.active{color:var(--color-navy-800, #0E2040);border-bottom-color:var(--color-gold-500, #B8973A)}.holiday-calendar-section{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.holiday-calendar-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm, .5rem)}.clear-monthly-holidays-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);background:var(--color-error-light, #FDECEA);color:var(--color-error, #C0392B);border:1px solid var(--color-error, #C0392B);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);cursor:pointer;transition:background .2s}.clear-monthly-holidays-btn:hover{background:#f5c0bb}.holiday-calendar-grid{background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);overflow:hidden}.holiday-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--color-navy-800, #0E2040)}.holiday-calendar-weekday{padding:4px;text-align:center;font-family:var(--font-body, sans-serif);font-size:10px;font-weight:700;color:#fffc}.holiday-calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.holiday-calendar-day{min-height:44px;padding:4px 2px;border-right:1px solid var(--color-cream-100, #F7F4EF);border-bottom:1px solid var(--color-cream-100, #F7F4EF);display:flex;flex-direction:column;align-items:center;cursor:pointer;position:relative;transition:background .15s;font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);background:var(--color-white, #ffffff)}.holiday-calendar-day:hover:not(.empty){background:var(--color-cream-100, #F7F4EF)}.holiday-calendar-day.empty{cursor:default;background:var(--color-cream-50, #FDFBF8)}.holiday-calendar-day-number{font-size:11px;font-weight:600;color:var(--color-text-secondary, #3D4F62);line-height:1}.holiday-calendar-japanese-holiday{font-size:9px;color:var(--color-error, #C0392B);background:var(--color-error-light, #FDECEA);border-radius:2px;padding:0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.holiday-calendar-label-recurring{font-size:9px;font-weight:700;color:#fff;background:var(--color-navy-600, #1B3A6B);border-radius:2px;padding:0 3px;margin-top:1px}.holiday-calendar-label-single{font-size:9px;font-weight:700;color:#fff;background:var(--color-gold-500, #B8973A);border-radius:2px;padding:0 3px;margin-top:1px}.recurring-holiday-section{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.recurring-holiday-header{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.recurring-holiday-description{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D);margin:0}.recurring-holiday-grid{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem);background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);overflow:hidden}.recurring-weekday-row{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);border-bottom:1px solid var(--color-cream-100, #F7F4EF)}.recurring-weekday-row:last-child{border-bottom:none}.recurring-weekday-label{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-navy-700, #132952);min-width:60px;flex-shrink:0}.recurring-nth-buttons{display:flex;gap:var(--spacing-xs, .25rem);flex-wrap:wrap}.recurring-nth-buttons button{padding:3px var(--spacing-sm, .5rem);background:var(--color-cream-100, #F7F4EF);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.recurring-nth-buttons button.selected,.recurring-nth-buttons button[data-selected=true]{background:var(--color-navy-700, #132952);color:#fff;border-color:var(--color-navy-700, #132952)}.recurring-nth-buttons button:hover:not(.selected){background:var(--color-cream-200, #EDE8DF)}@media(max-width:768px){.calendar-grid{grid-auto-rows:100px}.calendar-day-number{font-size:10px}.calendar-store-holiday,.calendar-japanese-holiday{display:none}.event-content{font-size:9px;padding:1px 3px}.event-time{display:none}.department-stats-container>div:last-child{flex-direction:column}.form-row{grid-template-columns:1fr}.schedule-attachment-item{grid-template-columns:72px 1fr auto}.schedule-attachment-preview{width:72px;height:54px}.recurring-weekday-row{flex-direction:column;align-items:flex-start}}.stat-card.with-sub-targets{align-items:flex-start;padding-top:.6rem;padding-bottom:.6rem}.sub-target-list{display:flex;flex-direction:column;gap:0;margin-top:5px;width:100%}.sub-target-item{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:4px 0 4px 8px;border-left:2.5px solid transparent;transition:background .15s}.sub-target-item+.sub-target-item{border-top:1px solid rgba(14,32,64,.05)}.sub-target-item:hover{background:#0e204008;border-radius:0 4px 4px 0}[data-sub=bp]{border-left-color:#4e7ec4!important}[data-sub=seibi]{border-left-color:#2bab8e!important}[data-sub=mito]{border-left-color:#d4842a!important}[data-sub=saitama]{border-left-color:#cc4d4d!important}[data-sub=cargo]{border-left-color:#7080a0!important}.sub-target-label{font-size:.68rem;color:var(--color-text-muted, #6E7F8D);letter-spacing:.01em;white-space:nowrap;flex-shrink:0}.sub-target-value{font-size:.75rem;font-weight:700;color:var(--color-navy-800, #0E2040);font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right}.sub-target-value.unset{font-weight:400;font-style:italic;color:var(--color-text-muted, #6E7F8D);font-size:.68rem}.target-dialog-period{font-size:.78rem;font-weight:600;color:var(--color-text-muted, #6E7F8D);letter-spacing:.04em;padding:0 0 12px;border-bottom:1px solid var(--color-cream-200, #EDE8DF);margin-bottom:12px}.sub-target-form-group{display:flex;flex-direction:column;gap:10px}.sub-target-form-item{display:flex;flex-direction:column;gap:6px;padding:10px 12px;border-left:3px solid transparent;border-radius:0 6px 6px 0;background:#0e204006;transition:background .2s}.sub-target-form-item:hover{background:#0e20400b}.sub-target-form-header{display:flex;align-items:center;gap:7px}.sub-target-form-accent{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;background:transparent}.sub-target-form-accent[data-sub=bp]{background:#4e7ec4}.sub-target-form-accent[data-sub=seibi]{background:#2bab8e}.sub-target-form-accent[data-sub=mito]{background:#d4842a}.sub-target-form-accent[data-sub=saitama]{background:#cc4d4d}.sub-target-form-accent[data-sub=cargo]{background:#7080a0}.sub-target-form-label{font-size:.78rem;font-weight:600;color:var(--color-navy-700, #132952);letter-spacing:.02em}.tool-section{display:flex;flex-direction:column;gap:var(--spacing-2xl, 3rem)}.tool-button-container{display:flex;align-items:center}.tool-button{display:inline-flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:.875rem var(--spacing-xl, 2rem);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);font-weight:600;letter-spacing:.02em;text-decoration:none;color:var(--color-white, #ffffff);transition:all var(--transition-fast, .15s);box-shadow:var(--shadow-md)}.tool-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.tool-button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.tool-button-navy{background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-600, #1B3A6B));border:1px solid var(--color-navy-700, #132952)}.tool-button-navy:hover{background:linear-gradient(135deg,var(--color-navy-900, #0A1628),var(--color-navy-700, #132952));color:var(--color-white, #ffffff)}.tool-button-green{background:linear-gradient(135deg,#1d6a4a,#2d7a4f);border:1px solid #1D6A4A}.tool-button-green:hover{background:linear-gradient(135deg,#155c3d,#1d6a4a);color:var(--color-white, #ffffff)}.tool-button-purple{background:linear-gradient(135deg,var(--color-gold-700, #7A5C18),var(--color-gold-500, #B8973A));border:1px solid var(--color-gold-700, #7A5C18)}.tool-button-purple:hover{background:linear-gradient(135deg,#6B5016,var(--color-gold-600, #9A7720));color:var(--color-white, #ffffff)}.tool-button-icon{font-size:1.25rem;display:flex;align-items:center;flex-shrink:0}.tool-button-text{font-size:var(--font-size-base, 1rem)}.tool-button-arrow{display:flex;align-items:center;font-size:.875rem;transition:transform var(--transition-fast, .15s)}.tool-button:hover .tool-button-arrow{transform:translate(4px)}.tool-content-row{display:flex;gap:var(--spacing-2xl, 3rem);align-items:flex-start}.tool-info-box{flex:1;min-width:0}.tool-info-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-xl, 1.25rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin-bottom:var(--spacing-md, 1rem);padding-bottom:var(--spacing-sm, .5rem);border-bottom:1px solid var(--color-cream-200, #EDE8DF);position:relative}.tool-info-title:after{content:"";position:absolute;left:0;bottom:-1px;width:32px;height:2px;background:var(--color-gold-500, #B8973A);border-radius:2px}.tool-info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.tool-info-list li{display:flex;align-items:flex-start;gap:var(--spacing-sm, .5rem);padding:var(--spacing-sm, .5rem) 0;font-size:var(--font-size-base, 1rem);color:var(--color-text-secondary, #3D4F62);line-height:var(--line-height-relaxed, 1.8);border-bottom:1px solid var(--color-cream-100, #F7F4EF)}.tool-info-list li:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--color-gold-500, #B8973A);flex-shrink:0;margin-top:10px}.tool-image-container{flex:0 0 280px;height:200px;border-radius:var(--border-radius-lg, 1rem);overflow:hidden;border:1px solid var(--color-cream-200, #EDE8DF);box-shadow:var(--shadow-md)}.tool-image{width:100%;height:100%;object-fit:cover}.tool-hero-page{position:relative;min-height:100vh;background:linear-gradient(135deg,#081727e6,#125038b8);overflow:hidden}.tool-hero-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:var(--tool-bg-image);background-position:center;background-repeat:no-repeat;background-size:contain;opacity:.18;filter:blur(1px);pointer-events:none;z-index:0}.tool-hero-page>main,.tool-hero-page>.page-main{position:relative;z-index:1}.tool-hero-page-main{display:flex;align-items:center;padding-top:calc(var(--header-height, 64px) + clamp(2rem,6vw,4.5rem));padding-bottom:calc(var(--footer-height, 80px) + clamp(2.5rem,7vw,5rem))}.tool-hero-page-container{width:100%}.tool-hero-page-container .page-eyebrow{text-align:center}.tool-hero-page-title{color:var(--color-white, #ffffff);text-align:center;text-shadow:0 10px 28px rgba(5,15,27,.35)}.tool-hero-page-title:after{left:50%;transform:translate(-50%)}.tool-hero-section{max-width:760px;margin:0 auto;padding:clamp(1.5rem,3vw,2.25rem);border:1px solid rgba(255,255,255,.22);border-radius:28px;background:linear-gradient(180deg,#ffffffe0,#f7f9fbd1);box-shadow:0 28px 60px #06131e3d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tool-hero-page .tool-button-container{justify-content:center}.tool-hero-page .tool-button{min-width:min(100%,22rem);justify-content:center;padding:1.1rem 2.75rem;border-radius:999px;font-size:1.125rem;box-shadow:0 18px 36px #0f342747}.tool-hero-page .tool-button-icon{font-size:1.35rem}.tool-hero-page .tool-button-text{font-size:1.125rem}.tool-hero-page .tool-button-arrow{font-size:1rem}.tool-hero-content{justify-content:center}.tool-hero-info-box{max-width:100%}.tool-hero-page .tool-info-title{text-align:center}.tool-hero-page .tool-info-title:after{left:50%;transform:translate(-50%)}.tool-hero-page .tool-info-list li{border-bottom-color:#3d4f621f}@media(max-width:768px){.tool-content-row{flex-direction:column;gap:var(--spacing-xl, 2rem)}.tool-image-container{flex:none;width:100%;height:180px}.tool-hero-page-main{align-items:stretch}.tool-hero-section{border-radius:22px}}@media(max-width:480px){.tool-button{padding:.75rem var(--spacing-lg, 1.5rem);font-size:var(--font-size-sm, .875rem)}.tool-image-container{height:150px}.tool-hero-page .tool-button{min-width:100%;padding:1rem 1.5rem;font-size:1rem}.tool-hero-page .tool-button-text{font-size:1rem}.tool-hero-section{padding:1.25rem 1rem}}.data-table{width:100%;background:var(--color-white, #ffffff);border-radius:var(--border-radius-lg, 1rem);border:1px solid var(--color-cream-200, #EDE8DF);box-shadow:var(--shadow-sm);overflow:hidden;font-family:var(--font-body, sans-serif)}.data-table-wrapper,.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table table{width:100%;border-collapse:collapse;min-width:500px}.data-table thead{background:linear-gradient(135deg,var(--color-navy-800, #0E2040) 0%,var(--color-navy-700, #132952) 100%)}.data-table th{padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);text-align:left;font-size:var(--font-size-xs, .75rem);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#ffffffd9;border-right:1px solid rgba(255,255,255,.08);white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}.data-table th:last-child{border-right:none}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{color:var(--color-gold-300, #DEC878);background:#ffffff0d}.data-table th .sort-icon{display:inline-flex;flex-direction:column;margin-left:var(--spacing-xs, .25rem);vertical-align:middle}.data-table tbody tr{border-bottom:1px solid var(--color-cream-200, #EDE8DF);transition:background-color var(--transition-fast, .15s)}.data-table tbody tr:nth-child(2n){background-color:var(--color-cream-50, #FDFBF8)}.data-table tbody tr:hover{background-color:var(--color-navy-100, #D4E6F4)!important}.data-table tbody tr:last-child{border-bottom:none}.data-table td{padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);vertical-align:middle;white-space:nowrap}.data-table-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);background:var(--color-cream-50, #FDFBF8);border-top:1px solid var(--color-cream-200, #EDE8DF);flex-wrap:wrap;gap:var(--spacing-sm, .5rem)}.data-table-count{font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D);letter-spacing:.02em}.data-table-pagination{display:flex;align-items:center;gap:4px}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--spacing-sm, .5rem);background:transparent;border:1.5px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);font-weight:500;color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:all var(--transition-fast, .15s)}.pagination-btn:hover:not(:disabled){background:var(--color-navy-800, #0E2040);border-color:var(--color-navy-800, #0E2040);color:var(--color-white, #ffffff)}.pagination-btn.active{background:var(--color-navy-800, #0E2040);border-color:var(--color-navy-800, #0E2040);color:var(--color-white, #ffffff)}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.data-table-empty{padding:var(--spacing-4xl, 6rem) var(--spacing-xl, 2rem);text-align:center;color:var(--color-text-muted, #6E7F8D);font-size:var(--font-size-sm, .875rem)}.data-table-loading{padding:var(--spacing-4xl, 6rem) var(--spacing-xl, 2rem);text-align:center}@media(max-width:640px){.data-table th,.data-table td{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem)}.data-table-footer{flex-direction:column;align-items:flex-start}}.request-management-section{display:flex;flex-direction:column;gap:var(--spacing-lg, 1.5rem);min-width:0}.request-header-section{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm, .5rem);flex-wrap:wrap}.create-request-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s;box-shadow:var(--shadow-sm);white-space:nowrap}.create-request-button:hover{opacity:.88}.create-request-button.expense-button{background:linear-gradient(135deg,var(--color-gold-500, #B8973A),var(--color-gold-600, #9A7720))}.request-table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:0}.request-type-badge{display:inline-flex;align-items:center;padding:2px var(--spacing-sm, .5rem);background:var(--color-navy-100, #D4E6F4);color:var(--color-navy-700, #132952);border-radius:999px;font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);font-weight:700;white-space:nowrap}.request-dialog-content{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.request-type-selector{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.request-type-dropdown{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);background:var(--color-white, #ffffff);width:100%;cursor:pointer;transition:border-color .2s,box-shadow .2s}.request-type-dropdown:focus{outline:none;border-color:var(--color-navy-500, #2A5B8F);box-shadow:0 0 0 3px #2a5b8f1f}.request-form{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.expense-dialog-content{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.budget-setting-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);background:var(--color-cream-100, #F7F4EF);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .2s}.budget-setting-button:hover{background:var(--color-cream-200, #EDE8DF)}.budget-dialog-content{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem)}.budget-setting-section{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.budget-row{display:flex;align-items:flex-end;gap:var(--spacing-sm, .5rem);padding:var(--spacing-sm, .5rem);background:var(--color-cream-50, #FDFBF8);border-radius:var(--border-radius-md, .5rem);border:1px solid var(--color-cream-200, #EDE8DF)}.budget-update-button{display:inline-flex;align-items:center;padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);background:var(--color-navy-600, #1B3A6B);color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap;flex-shrink:0}.budget-update-button:hover{opacity:.85}.budget-update-button:disabled{opacity:.5;cursor:not-allowed}.request-detail-content{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.detail-row{display:flex;align-items:flex-start;gap:var(--spacing-sm, .5rem);padding:var(--spacing-xs, .25rem) 0;border-bottom:1px solid var(--color-cream-100, #F7F4EF)}.detail-label{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-text-muted, #6E7F8D);min-width:100px;flex-shrink:0}.detail-value{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);flex:1;word-break:break-word}.detail-actions{display:flex;gap:var(--spacing-sm, .5rem);justify-content:flex-end;padding-top:var(--spacing-md, 1rem);margin-top:var(--spacing-xs, .25rem);border-top:1px solid var(--color-cream-200, #EDE8DF)}.reject-button{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:var(--color-error-light, #FDECEA);color:var(--color-error, #C0392B);border:1px solid var(--color-error, #C0392B);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:background .2s}.reject-button:hover{background:#f5c0bb}.approve-button{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:var(--color-success, #2D7A4F);color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s;box-shadow:var(--shadow-sm)}.approve-button:hover{opacity:.88}.form-actions{display:flex;gap:var(--spacing-sm, .5rem);justify-content:flex-end;padding-top:var(--spacing-md, 1rem)}.cancel-button{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:transparent;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .2s}.submit-button{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s;box-shadow:var(--shadow-sm)}.submit-button:hover{opacity:.88}.submit-button:disabled{opacity:.5;cursor:not-allowed}@media print{.request-detail-content{overflow:visible!important;max-height:none!important;padding:0!important}.detail-actions{display:none!important}.detail-row{border-bottom:1px solid #ccc!important;padding:4px 0!important;page-break-inside:avoid}.detail-label{font-weight:700!important;color:#000!important}.detail-value{color:#000!important}.attached-image-section{display:none!important}}@media(max-width:768px){.request-header-section,.budget-row{flex-direction:column;align-items:stretch}.detail-label{min-width:80px}.detail-actions,.form-actions{flex-direction:column}.reject-button,.approve-button,.cancel-button,.submit-button{width:100%}}.receipt-notice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0a122899;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:receipt-overlay-fadein .22s ease both}@keyframes receipt-overlay-fadein{0%{opacity:0}to{opacity:1}}.receipt-notice-card{background:#fff;border-radius:20px;max-width:420px;width:92%;animation:receipt-card-enter .32s cubic-bezier(.34,1.42,.64,1) both;animation-delay:.05s;overflow:hidden;box-shadow:0 2px #ffffff1f inset,0 20px 60px #0a122847,0 4px 16px #0a122824}@keyframes receipt-card-enter{0%{opacity:0;transform:translateY(-20px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}.receipt-notice-header-bar{height:6px;background:linear-gradient(90deg,#0e2040,#1a3d7a,#0e2040);background-size:200% 100%;animation:receipt-bar-shimmer 2.4s ease-in-out .3s both}@keyframes receipt-bar-shimmer{0%{background-position:200% center}to{background-position:-200% center}}.receipt-notice-body{display:flex;flex-direction:column;align-items:center;padding:36px 40px 40px;gap:0}.receipt-notice-icon-wrap{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,#e8ecf5,#d4daf0);display:flex;align-items:center;justify-content:center;margin-bottom:20px;animation:receipt-icon-pop .4s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes receipt-icon-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.receipt-notice-svg{width:48px;height:48px}.receipt-notice-label{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#6b7a99;margin:0 0 8px}.receipt-notice-title{font-size:1.35rem;font-weight:800;color:#0e2040;margin:0 0 18px;letter-spacing:-.01em;line-height:1.2}.receipt-notice-divider{width:36px;height:2px;background:linear-gradient(90deg,#0e2040,#4a6fa5);border-radius:1px;margin-bottom:18px}.receipt-notice-message{font-size:.975rem;color:#3a4560;margin:0 0 28px;line-height:1.75;text-align:center}.receipt-notice-message strong{color:#0e2040;font-weight:700;border-bottom:2px solid rgba(14,32,64,.25);padding-bottom:1px}.receipt-notice-close-button{position:relative;width:100%;padding:13px 0;border:2px solid #0E2040;border-radius:10px;background:transparent;color:#0e2040;font-size:.9rem;font-weight:700;letter-spacing:.04em;cursor:pointer;overflow:hidden;transition:color .28s ease}.receipt-notice-close-button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0e2040;transform:scaleX(0);transform-origin:left center;transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:0}.receipt-notice-close-button:hover:before{transform:scaleX(1)}.receipt-notice-btn-text{position:relative;z-index:1}.receipt-notice-close-button:hover{color:#fff}.request-confirmation-container{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0a1628,#132952,#0e2040);padding:20px 20px calc(env(safe-area-inset-bottom,0px) + 40px) 20px;z-index:9999;overflow-y:auto;-webkit-overflow-scrolling:touch}body.request-confirmation-page header.header,body.request-confirmation-page .header{display:none!important}.confirmation-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;max-width:700px;width:100%;padding:20px 30px;margin-left:auto;margin-right:auto}.confirmation-title{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;text-align:center;border-bottom:2px solid #B8973A;padding-bottom:10px}.request-details{margin-bottom:20px}.detail-row{display:flex;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #eee}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;color:#555;min-width:120px;flex-shrink:0}.detail-value{color:#333;flex:1;word-break:break-word}.request-type-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;background:#132952;color:#fff}.request-status{display:inline-block;padding:6px 16px;border-radius:16px;font-size:13px;font-weight:600}.status-approved{background-color:#d4edda;color:#155724}.status-pending{background-color:#fff3cd;color:#856404}.status-rejected{background-color:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:20px}.approve-button,.reject-button{padding:12px 32px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s;min-width:120px}.approve-button{background:#2d7a4f;color:#fff;border:none;box-shadow:0 2px 8px #2d7a4f4d}.approve-button:hover:not(:disabled){opacity:.88;transform:translateY(-2px);box-shadow:0 5px 16px #2d7a4f66}.reject-button{background:#fdecea;color:#c0392b;border:1px solid #C0392B}.reject-button:hover:not(:disabled){background:#f5c0bb;transform:translateY(-2px)}.approve-button:disabled,.reject-button:disabled{opacity:.6;cursor:not-allowed}.status-message{text-align:center;padding:15px;background:#e9ecef;border-radius:8px;color:#495057;font-weight:500;margin-top:15px;font-size:14px}.navigation-buttons{display:flex;justify-content:center;margin-top:28px}.back-to-request-button{padding:12px 32px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;color:#fff;background:linear-gradient(135deg,#1f2937,#374151);transition:all .3s ease;min-width:180px}.back-to-request-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 18px #1118274d}.back-to-request-button:disabled{opacity:.6;cursor:not-allowed}.loading,.error-message{text-align:center;padding:40px;font-size:18px;color:#fff}.error-message{background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:768px){.request-confirmation-container{padding:8px 16px calc(env(safe-area-inset-bottom,0px) + 96px) 16px;min-height:100vh}.confirmation-card{padding:16px 18px;margin-top:5px}.confirmation-title{font-size:20px;margin-bottom:15px;padding-bottom:8px}.detail-row{flex-direction:column;gap:8px}.detail-label{min-width:auto;font-size:14px}.detail-value{font-size:14px}.action-buttons{flex-direction:column;gap:12px}.approve-button,.reject-button{width:100%;min-width:auto}}@media(max-width:480px){.request-confirmation-container{padding-bottom:calc(env(safe-area-inset-bottom,0px) + 112px)}.confirmation-card{padding:20px 16px}.confirmation-title{font-size:18px}.approve-button,.reject-button,.back-to-request-button{padding:14px 20px;font-size:14px}}@media print{.attached-image-section{display:none!important}}.login-container{display:flex;min-height:100vh;margin-top:calc(-1 * var(--header-height, 64px));margin-bottom:calc(-1 * var(--footer-height, 80px));padding-top:0;padding-bottom:0}.login-brand-panel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--color-navy-900, #0A1628) 0%,var(--color-navy-700, #132952) 60%,var(--color-navy-600, #1B3A6B) 100%);padding:var(--spacing-4xl, 6rem) var(--spacing-2xl, 3rem);position:relative;overflow:hidden}.login-brand-panel:before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;border:1px solid rgba(184,151,58,.12)}.login-brand-panel:after{content:"";position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;border-radius:50%;border:1px solid rgba(184,151,58,.08)}.login-brand-content{position:relative;z-index:1;text-align:center;max-width:360px}.login-brand-divider{width:48px;height:2px;background:linear-gradient(90deg,var(--color-gold-500, #B8973A),var(--color-gold-300, #DEC878));margin:var(--spacing-lg, 1.5rem) auto;border-radius:2px}.login-brand-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-4xl, 2.25rem);font-weight:400;color:var(--color-white, #ffffff);letter-spacing:-.02em;margin-bottom:0;line-height:1.15}.login-brand-subtitle{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:300;color:#ffffff8c;letter-spacing:.12em;text-transform:uppercase;margin-bottom:0}.login-brand-tagline{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:#fff9;line-height:var(--line-height-relaxed, 1.8);margin-bottom:0}.login-form-panel{flex:0 0 480px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-cream-50, #FDFBF8);padding:var(--spacing-4xl, 6rem) var(--spacing-3xl, 4rem)}.login-box{width:100%;max-width:360px;transition:opacity var(--transition-normal, .3s)}.login-box.loading{opacity:.6;pointer-events:none}.login-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-3xl, 1.875rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin-bottom:var(--spacing-xs, .25rem);letter-spacing:-.01em}.login-title-line{width:40px;height:2px;background:linear-gradient(90deg,var(--color-gold-500, #B8973A),var(--color-gold-300, #DEC878));border-radius:2px;margin-bottom:var(--spacing-2xl, 3rem)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.form-group label{font-size:var(--font-size-xs, .75rem);font-weight:600;color:var(--color-text-muted, #6E7F8D);letter-spacing:.06em;text-transform:uppercase}.form-group input{padding:.75rem var(--spacing-md, 1rem);border:1.5px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);color:var(--color-text-primary, #1A2433);background:var(--color-white, #ffffff);transition:border-color var(--transition-fast, .15s),box-shadow var(--transition-fast, .15s);outline:none;width:100%}.form-group input:focus{border-color:var(--color-navy-500, #2A5B8F);box-shadow:0 0 0 3px #2a5b8f1f}.form-group input:disabled{background:var(--color-cream-100, #F7F4EF);color:var(--color-text-muted, #6E7F8D);cursor:not-allowed}.error-message{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:var(--color-error-light, #FDECEA);border:1px solid rgba(192,57,43,.25);border-left:3px solid var(--color-error, #C0392B);border-radius:var(--border-radius-md, .5rem);color:var(--color-error, #C0392B);font-size:var(--font-size-sm, .875rem);line-height:var(--line-height-normal, 1.6)}.login-button{margin-top:var(--spacing-sm, .5rem);padding:.875rem var(--spacing-xl, 2rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);font-weight:600;letter-spacing:.04em;color:var(--color-white, #ffffff);cursor:pointer;transition:all var(--transition-fast, .15s);width:100%}.login-button:hover:not(:disabled){background:linear-gradient(135deg,var(--color-navy-900, #0A1628),var(--color-navy-800, #0E2040));transform:translateY(-1px);box-shadow:0 6px 20px #0e204059}.login-button:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.login-button-content{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm, .5rem)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white, #ffffff);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0a162873;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:var(--z-modal-backdrop, 1040);cursor:wait;display:flex;align-items:center;justify-content:center;animation:overlayFadeIn .15s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.loading-overlay-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-xl, 2rem) var(--spacing-2xl, 3rem);background:var(--color-white, #ffffff);border-radius:var(--border-radius-xl, 1.5rem);box-shadow:0 24px 64px #0a16284d;animation:cardSlideUp .2s cubic-bezier(.4,0,.2,1)}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.loading-overlay-spinner{width:40px;height:40px;border:3px solid var(--color-cream-200, #EDE8DF);border-top-color:var(--color-navy-700, #132952);border-radius:50%;animation:spin .75s linear infinite}.loading-overlay-text{font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);font-weight:500;color:var(--color-navy-700, #132952);letter-spacing:.04em}@media(max-width:900px){.login-container{flex-direction:column}.login-brand-panel{flex:none;padding:1.5rem var(--spacing-xl, 2rem);flex-direction:row;align-items:center;justify-content:center;gap:1.25rem}.login-brand-content{display:flex;align-items:center;gap:1rem;max-width:none;text-align:left}.login-brand-divider{width:1px;height:32px;margin:0;background:linear-gradient(180deg,var(--color-gold-500, #B8973A),var(--color-gold-300, #DEC878))}.login-brand-subtitle{font-size:.7rem}.login-brand-title{font-size:1.5rem}.login-brand-tagline{display:none}.login-form-panel{flex:1;background:var(--color-cream-50, #FDFBF8);padding:var(--spacing-2xl, 3rem) var(--spacing-xl, 2rem)}}@media(max-width:480px){.login-brand-panel{padding:1rem var(--spacing-md, 1rem);gap:.75rem}.login-brand-title{font-size:1.25rem}.login-brand-subtitle{font-size:.65rem}.login-form-panel{padding:var(--spacing-xl, 2rem) var(--spacing-md, 1rem);justify-content:flex-start;padding-top:var(--spacing-2xl, 3rem)}.login-box{max-width:100%}}.not-found-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--color-cream-100, #F7F4EF);padding:var(--spacing-xl, 2rem);margin-top:calc(-1 * var(--header-height, 64px));margin-bottom:calc(-1 * var(--footer-height, 80px))}.not-found-box{max-width:500px;width:100%;text-align:center;padding:var(--spacing-4xl, 6rem) var(--spacing-2xl, 3rem);background:var(--color-white, #ffffff);border-radius:var(--border-radius-xl, 1.5rem);border:1px solid var(--color-cream-200, #EDE8DF);border-top:3px solid var(--color-gold-500, #B8973A);box-shadow:var(--shadow-xl);animation:notFoundFadeIn .5s cubic-bezier(.4,0,.2,1)}@keyframes notFoundFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.not-found-icon{font-family:var(--font-display, "DM Serif Display", serif);font-size:7rem;font-weight:400;color:transparent;-webkit-text-stroke:2px var(--color-navy-800, #0E2040);line-height:1;margin-bottom:var(--spacing-lg, 1.5rem);letter-spacing:-.05em;animation:notFoundPulse 3s ease-in-out infinite}@keyframes notFoundPulse{0%,to{opacity:1}50%{opacity:.7}}.not-found-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:var(--font-size-2xl, 1.5rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin-bottom:var(--spacing-md, 1rem)}.not-found-message{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);line-height:var(--line-height-relaxed, 1.8);margin-bottom:var(--spacing-sm, .5rem)}.not-found-path{font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D);margin-bottom:var(--spacing-2xl, 3rem)}.not-found-path code{display:inline-block;padding:2px 8px;background:var(--color-cream-100, #F7F4EF);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-sm, .25rem);font-family:Courier New,monospace;font-size:var(--font-size-xs, .75rem);color:var(--color-navy-600, #1B3A6B);word-break:break-all}.not-found-actions{display:flex;justify-content:center;gap:var(--spacing-md, 1rem)}.not-found-button{padding:.75rem var(--spacing-2xl, 3rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);font-weight:600;letter-spacing:.03em;border-radius:var(--border-radius-md, .5rem);cursor:pointer;transition:all var(--transition-fast, .15s);border:none}.not-found-button.primary{background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));color:var(--color-white, #ffffff)}.not-found-button.primary:hover{background:linear-gradient(135deg,var(--color-navy-900, #0A1628),var(--color-navy-800, #0E2040));transform:translateY(-2px);box-shadow:0 6px 20px #0e20404d}@media(max-width:480px){.not-found-box{padding:var(--spacing-2xl, 3rem) var(--spacing-xl, 2rem)}.not-found-icon{font-size:5rem}.not-found-title{font-size:var(--font-size-xl, 1.25rem)}}.organization-section{width:100%}.organization-tabs{display:flex;gap:var(--spacing-xs, .25rem);margin-bottom:var(--spacing-md, 1rem);flex-wrap:wrap;border-bottom:2px solid var(--color-cream-200, #EDE8DF);padding-bottom:0}.organization-tabs button{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-text-muted, #6E7F8D);cursor:pointer;transition:color .2s,border-color .2s;white-space:nowrap}.organization-tabs button:hover{color:var(--color-navy-600, #1B3A6B)}.organization-tabs button.active,.organization-tabs button[data-active=true]{color:var(--color-navy-800, #0E2040);border-bottom-color:var(--color-gold-500, #B8973A)}.organization-chart-container{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.chart-instruction{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-muted, #6E7F8D);text-align:center;margin:0;padding:var(--spacing-xs, .25rem) var(--spacing-md, 1rem);background:var(--color-cream-50, #FDFBF8);border-radius:var(--border-radius-md, .5rem);border:1px dashed var(--color-cream-300, #DDD5C8)}.organization-chart-image{width:100%;height:auto;border-radius:var(--border-radius-lg, 1rem);border:1px solid var(--color-cream-200, #EDE8DF);box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .2s;display:block}.organization-chart-image:hover{box-shadow:var(--shadow-md)}.members-container{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem);padding-bottom:var(--spacing-xl, 2rem)}.members-header{display:flex;align-items:center;gap:var(--spacing-md, 1rem);flex-wrap:wrap;padding-bottom:var(--spacing-md, 1rem);border-bottom:1px solid var(--color-cream-200, #EDE8DF)}.back-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:transparent;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);font-weight:600;color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap}.back-button:hover{background:var(--color-cream-100, #F7F4EF);border-color:var(--color-navy-400, #4A7BAD)}.members-title{font-family:var(--font-display, serif);font-size:var(--font-size-xl, 1.25rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin:0;flex:1}.add-member-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s;box-shadow:var(--shadow-sm);white-space:nowrap}.add-member-button:hover{opacity:.88}.department-menu-bar{display:flex;gap:var(--spacing-xs, .25rem);flex-wrap:wrap;padding:var(--spacing-sm, .5rem);background:var(--color-cream-50, #FDFBF8);border-radius:var(--border-radius-md, .5rem);border:1px solid var(--color-cream-200, #EDE8DF)}.department-menu-bar button{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background:transparent;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .15s,color .15s}.department-menu-bar button:hover,.department-menu-bar button.active{background:var(--color-navy-800, #0E2040);color:#fff;border-color:var(--color-navy-800, #0E2040)}.loading{text-align:center;padding:var(--spacing-2xl, 3rem);color:var(--color-text-muted, #6E7F8D);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem)}.members-list-container{display:flex;flex-direction:column;gap:var(--spacing-lg, 1.5rem);padding-bottom:calc(var(--footer-height, 80px) + var(--spacing-xl, 2rem))}.department-section{background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-lg, 1rem);overflow:hidden;box-shadow:var(--shadow-sm)}.department-section-title{font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);font-weight:700;color:#fff;margin:0;padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));border-bottom:2px solid var(--color-gold-500, #B8973A)}.members-list{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem);padding:var(--spacing-md, 1rem);background:var(--color-cream-50, #FDFBF8)}.member-card{position:relative;display:grid;grid-template-columns:230px 1fr;gap:var(--spacing-xl, 2rem);background:var(--color-white, #ffffff);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-lg, 1rem);box-shadow:var(--shadow-xs);padding:var(--spacing-lg, 1.5rem) var(--spacing-lg, 1.5rem) var(--spacing-lg, 1.5rem) calc(var(--spacing-lg, 1.5rem) + 4px);overflow:hidden;transition:box-shadow .25s ease,transform .25s ease}.member-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--color-gold-400, #CDB060),var(--color-gold-600, #9A7720))}.member-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.member-card.is-sortable{padding-left:calc(var(--spacing-lg, 1.5rem) + 4px + 24px)}.member-card.is-dragging{opacity:.9;box-shadow:var(--shadow-lg);cursor:grabbing}.member-card-handle{position:absolute;left:6px;top:0;bottom:0;width:26px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-light, #A0ADB7);cursor:grab;touch-action:none;transition:color .2s,background .2s;border-radius:var(--border-radius-md, .5rem)}.member-card-handle:hover{color:var(--color-navy-600, #1B3A6B);background:var(--color-cream-100, #F7F4EF)}.member-card-handle:active{cursor:grabbing}.member-card-aside{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem);min-width:0}.member-card-photo{width:100%;aspect-ratio:1 / 1;border-radius:var(--border-radius-lg, 1rem);overflow:hidden;background:linear-gradient(135deg,var(--color-cream-100, #F7F4EF),var(--color-cream-200, #EDE8DF));border:1px solid var(--color-cream-200, #EDE8DF);box-shadow:var(--shadow-xs);position:relative}.member-card-photo img{width:100%;height:100%;object-fit:cover;display:block}.member-card-photo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:inset 0 -4px 0 var(--color-gold-500, #B8973A);border-radius:var(--border-radius-lg, 1rem);pointer-events:none}.member-card-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display, serif);font-size:3rem;color:var(--color-navy-300, #7AADCF);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-600, #1B3A6B))}.member-card-identity{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem);min-width:0}.member-card-name{font-family:var(--font-display, serif);font-size:var(--font-size-2xl, 1.5rem);font-weight:400;line-height:1.2;color:var(--color-navy-800, #0E2040);margin:0;letter-spacing:-.01em;word-break:break-word}.member-card-name.is-vacant{color:var(--color-text-muted, #6E7F8D);font-style:italic}.member-card-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-xs, .25rem)}.member-card-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 11px;border-radius:999px;font-family:var(--font-body, sans-serif);font-size:.72rem;font-weight:700;letter-spacing:.03em}.member-card-badge.badge-blood{background:var(--color-gold-100, #F5EDD4);color:var(--color-gold-700, #7A5C18);border:1px solid var(--color-gold-300, #DEC878)}.member-card-badge.badge-vacant{background:var(--color-navy-100, #D4E6F4);color:var(--color-navy-700, #132952);border:1px solid var(--color-navy-300, #7AADCF)}.member-card-meta{display:flex;flex-direction:column;gap:6px;margin-top:var(--spacing-xs, .25rem)}.member-card-meta-item{display:flex;gap:8px;font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);line-height:1.4}.member-card-meta-item .meta-label{flex-shrink:0;width:4.5em;font-size:.72rem;font-weight:700;color:var(--color-text-muted, #6E7F8D);letter-spacing:.02em;padding-top:1px}.member-card-meta-item .meta-value{color:var(--color-text-secondary, #3D4F62);word-break:break-word}.member-card-main{min-width:0}.member-card-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem)}.member-fact{display:flex;flex-direction:column;gap:3px;min-width:0;padding-left:10px;border-left:2px solid var(--color-gold-300, #DEC878)}.member-fact-label{font-family:var(--font-body, sans-serif);font-size:.72rem;font-weight:700;letter-spacing:.02em;color:var(--color-navy-600, #1B3A6B);line-height:1.4}.member-fact-value{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);line-height:1.55;color:var(--color-text-primary, #1A2433);word-break:break-word}.member-card-pr{grid-column:1 / -1;position:relative;margin-top:var(--spacing-xs, .25rem);padding:var(--spacing-md, 1rem) var(--spacing-md, 1rem) var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);background:var(--color-cream-50, #FDFBF8);border-radius:var(--border-radius-md, .5rem);border-left:3px solid var(--color-gold-500, #B8973A)}.member-card-pr-label{font-family:var(--font-body, sans-serif);font-size:.7rem;font-weight:700;letter-spacing:.08em;color:var(--color-gold-700, #7A5C18);margin-bottom:5px}.member-card-pr-text{font-family:var(--font-display, serif);font-style:italic;font-size:1.05rem;line-height:1.7;color:var(--color-navy-700, #132952)}.member-card-empty{margin:0;color:var(--color-text-muted, #6E7F8D);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-style:italic}.member-card-actions{position:absolute;top:var(--spacing-md, 1rem);right:var(--spacing-md, 1rem);display:flex;gap:var(--spacing-xs, .25rem)}.icon-button{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:50%;cursor:pointer;font-size:.85rem;transition:background .2s,transform .2s}.icon-button:hover{transform:translateY(-1px)}.icon-button.edit{background:var(--color-navy-100, #D4E6F4);color:var(--color-navy-700, #132952)}.icon-button.edit:hover{background:var(--color-navy-300, #7AADCF)}.icon-button.del{background:var(--color-error-light, #FDECEA);color:var(--color-error, #C0392B)}.icon-button.del:hover{background:#f5c0bb}.no-members-in-department{padding:var(--spacing-xl, 2rem);text-align:center;color:var(--color-text-muted, #6E7F8D);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem)}.member-form{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem);overflow-y:auto;max-height:65vh}.photo-upload-container{display:flex;align-items:flex-start;gap:var(--spacing-md, 1rem)}.photo-preview{width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid var(--color-cream-200, #EDE8DF);background:var(--color-cream-100, #F7F4EF);flex-shrink:0;display:flex;align-items:center;justify-content:center}.photo-preview img{width:100%;height:100%;object-fit:cover}.default-avatar-preview{font-size:2rem;color:var(--color-text-muted, #6E7F8D)}.photo-upload-actions{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem);justify-content:center}.photo-select-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);background:var(--color-cream-100, #F7F4EF);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .2s}.photo-select-button:hover{background:var(--color-cream-200, #EDE8DF)}.photo-remove-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);background:var(--color-error-light, #FDECEA);border:1px solid transparent;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-error, #C0392B);cursor:pointer;transition:background .2s}.photo-remove-button:hover{background:#f5c0bb}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.form-group label{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:600;color:var(--color-navy-700, #132952)}.form-group input,.form-group select,.form-group textarea{padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1A2433);background:var(--color-white, #ffffff);transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-navy-500, #2A5B8F);box-shadow:0 0 0 3px #2a5b8f1f}.form-actions{display:flex;gap:var(--spacing-sm, .5rem);justify-content:flex-end;padding-top:var(--spacing-md, 1rem);border-top:1px solid var(--color-cream-200, #EDE8DF)}.cancel-button{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:transparent;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .2s,border-color .2s}.cancel-button:hover{background:var(--color-cream-100, #F7F4EF)}.save-button{padding:var(--spacing-sm, .5rem) var(--spacing-lg, 1.5rem);background:linear-gradient(135deg,var(--color-navy-800, #0E2040),var(--color-navy-700, #132952));color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s;box-shadow:var(--shadow-sm)}.save-button:hover{opacity:.88}.save-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.member-card{grid-template-columns:1fr;gap:var(--spacing-lg, 1.5rem);padding:var(--spacing-md, 1rem) var(--spacing-md, 1rem) var(--spacing-md, 1rem) calc(var(--spacing-md, 1rem) + 4px)}.member-card.is-sortable{padding-left:calc(var(--spacing-md, 1rem) + 4px + 24px)}.member-card-aside{flex-direction:row;gap:var(--spacing-md, 1rem);align-items:flex-start}.member-card-photo{width:96px;height:96px;flex-shrink:0;aspect-ratio:1 / 1}.member-card-identity{flex:1}.member-card-name{font-size:var(--font-size-xl, 1.25rem)}.member-card-facts{grid-template-columns:1fr}.members-header{flex-direction:column;align-items:flex-start}.form-actions{flex-direction:column}.cancel-button,.save-button{width:100%}}.bf-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-cream-100, #F7F4EF)}.bf-main{flex:1;padding:0 1.5rem calc(var(--footer-height, 80px) + 3rem)}.bf-container{max-width:1100px;margin:0 auto}.bf-hero{position:relative;width:100%;min-height:clamp(300px,40vh,460px);padding-top:var(--header-height, 64px);background:linear-gradient(160deg,var(--color-navy-900, #0A1628) 0%,var(--color-navy-800, #0E2040) 55%,var(--color-navy-700, #132952) 100%);overflow:hidden;display:flex;align-items:center}.bf-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(184,151,58,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(184,151,58,.07) 1px,transparent 1px);background-size:64px 64px;background-position:-1px -1px;pointer-events:none}.bf-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:var(--bf-hero-img);background-size:cover;background-position:center;opacity:.08;pointer-events:none}.bf-hero-kanji{position:absolute;right:-.05em;bottom:-.18em;font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(10rem,22vw,18rem);line-height:1;color:#ffffff0a;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:1}.bf-hero-inner{position:relative;z-index:2;padding:clamp(2rem,5vw,3.5rem) clamp(1.5rem,4vw,3rem);width:100%}.bf-hero-eyebrow{font-family:var(--font-body, sans-serif);font-size:.7rem;font-weight:500;color:var(--color-gold-400, #CDB060);letter-spacing:.22em;text-transform:uppercase;margin:0 0 .75rem}.bf-hero-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(1.75rem,4.5vw,2.75rem);font-weight:400;color:#fff;margin:0 0 1.25rem;letter-spacing:.04em;line-height:1.2}.bf-hero-rule{width:48px;height:2px;background:linear-gradient(90deg,var(--color-gold-500, #B8973A),var(--color-gold-300, #DEC878));border-radius:2px;margin-bottom:1.25rem}.bf-hero-sub{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:#ffffff9e;margin:0;line-height:var(--line-height-relaxed, 1.8)}.bf-chapters{display:flex;flex-direction:column;gap:0}.bf-chapter{border-top:1px solid var(--color-cream-200, #EDE8DF);padding:2.5rem 0 2rem;animation:bfChapterIn .5s ease both}@keyframes bfChapterIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.bf-chapter:nth-child(1){animation-delay:.05s}.bf-chapter:nth-child(2){animation-delay:.12s}.bf-chapter:nth-child(3){animation-delay:.19s}.bf-chapter:nth-child(4){animation-delay:.26s}.bf-chapter:nth-child(5){animation-delay:.33s}.bf-chapter:nth-child(6){animation-delay:.4s}.bf-chapter-head{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.25rem}.bf-chapter-num{font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(2.5rem,5vw,3.5rem);color:var(--color-cream-200, #EDE8DF);line-height:1;font-weight:400;flex-shrink:0;transition:color .25s;min-width:3.5rem;-webkit-user-select:none;user-select:none}.bf-chapter:hover .bf-chapter-num{color:var(--color-gold-400, #CDB060)}.bf-chapter-label-wrap{display:flex;align-items:center;gap:.625rem}.bf-chapter-icon{font-size:1.1rem;color:var(--color-navy-500, #2A5B8F);flex-shrink:0;transition:color .25s}.bf-chapter:hover .bf-chapter-icon{color:var(--color-gold-500, #B8973A)}.bf-chapter-label{font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(1rem,2.5vw,1.375rem);font-weight:400;color:var(--color-navy-800, #0E2040);margin:0;letter-spacing:.03em}.bf-rows{list-style:none;padding:0;margin:0;padding-left:4.75rem}.bf-row{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;border-bottom:1px solid var(--color-cream-100, #F7F4EF);cursor:pointer;border-left:2px solid transparent;margin-left:-2px;transition:background .18s,border-left-color .18s,transform .18s;border-radius:0 var(--border-radius-sm, .25rem) var(--border-radius-sm, .25rem) 0}.bf-row:hover{background:var(--color-cream-50, #FDFBF8);border-left-color:var(--color-gold-500, #B8973A);transform:translate(3px)}.bf-row:last-child{border-bottom:none}.bf-row-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--color-cream-100, #F7F4EF);border-radius:var(--border-radius-sm, .25rem);font-size:.95rem;color:var(--color-navy-600, #1B3A6B);flex-shrink:0;transition:background .18s,color .18s}.bf-row:hover .bf-row-icon{background:#b8973a1a;color:var(--color-gold-600, #9A7720)}.bf-row-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.bf-row-title{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;color:var(--color-navy-800, #0E2040);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .18s}.bf-row:hover .bf-row-title{color:var(--color-navy-600, #1B3A6B)}.bf-row-desc{font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-text-muted, #6E7F8D);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bf-row-arr{font-size:1.25rem;color:var(--color-text-light, #A0ADB7);flex-shrink:0;line-height:1;transition:color .18s,transform .18s}.bf-row:hover .bf-row-arr{color:var(--color-gold-500, #B8973A);transform:translate(4px)}.bf-detail-body{padding:var(--spacing-lg, 1.5rem) var(--spacing-xl, 2rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.bf-detail-desc{font-family:var(--font-body, sans-serif);font-size:var(--font-size-base, 1rem);color:var(--color-text-primary, #1A2433);line-height:var(--line-height-relaxed, 1.8);background:var(--color-cream-50, #FDFBF8);border-radius:var(--border-radius-md, .5rem);padding:var(--spacing-md, 1rem);border-left:3px solid var(--color-gold-500, #B8973A)}.bf-detail-list-wrap{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.bf-detail-list-title{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;color:var(--color-navy-700, #132952);margin:0 0 var(--spacing-xs, .25rem) 0}.bf-detail-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}.bf-detail-item{font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);padding:.5rem 0 .5rem 1.125rem;border-bottom:1px solid var(--color-cream-200, #EDE8DF);position:relative}.bf-detail-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:var(--color-gold-500, #B8973A)}.bf-apply-note{display:flex;align-items:flex-start;gap:.5rem;padding:.625rem var(--spacing-md, 1rem);background:var(--color-info-light, #EBF3FB);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-xs, .75rem);color:var(--color-info, #2A5B8F);line-height:var(--line-height-relaxed, 1.8)}.bf-note-icon{flex-shrink:0;margin-top:3px}.bf-dialog-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm, .5rem);padding:var(--spacing-md, 1rem) var(--spacing-xl, 2rem);border-top:1px solid var(--color-cream-200, #EDE8DF);background:var(--color-cream-50, #FDFBF8)}.bf-apply-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1.5rem;background:linear-gradient(135deg,var(--color-gold-500, #B8973A),var(--color-gold-600, #9A7720));color:#fff;border:none;border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);font-weight:700;cursor:pointer;transition:opacity .2s,box-shadow .2s;box-shadow:var(--shadow-sm)}.bf-apply-btn:hover{opacity:.9;box-shadow:var(--shadow-md)}.bf-apply-icon{font-size:.85rem}.bf-close-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);font-family:var(--font-body, sans-serif);font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #3D4F62);cursor:pointer;transition:background .2s,border-color .2s}.bf-close-btn:hover{background:var(--color-cream-100, #F7F4EF);border-color:var(--color-navy-300, #7AADCF)}@media(max-width:768px){.bf-hero{min-height:220px}.bf-rows{padding-left:3.5rem}.bf-chapter-num{font-size:2.5rem;min-width:2.5rem}.bf-dialog-footer{flex-direction:column;align-items:stretch}.bf-row-title,.bf-row-desc{white-space:normal}}@media(max-width:480px){.bf-hero{min-height:200px}.bf-hero-kanji{font-size:8rem}.bf-chapter{padding:1.75rem 0 1.25rem}.bf-chapter-head{gap:.75rem}.bf-rows{padding-left:0}.bf-row-icon{width:28px;height:28px;font-size:.8rem}.bf-row:hover{transform:none}.bf-detail-body,.bf-dialog-footer{padding:var(--spacing-md, 1rem)}}@media print{.bf-hero{background:none!important;border:1px solid #ccc;border-radius:0;min-height:auto;padding:1rem;margin-bottom:1rem}.bf-hero:before,.bf-hero:after,.bf-hero-kanji{display:none!important}.bf-hero-title,.bf-hero-sub,.bf-hero-eyebrow{color:#000!important}.bf-chapter{animation:none!important;page-break-inside:avoid}.bf-row:hover{background:none;transform:none}}.company-philosophy-page{display:flex;flex-direction:column;min-height:100vh;background-color:#fff}.company-philosophy-container{flex:1;width:100%;max-width:100%;margin:0 auto;padding:0 0 80px;background-color:#fff}.president-message-section{width:100%;display:flex;justify-content:center;background-color:#fff;padding:30px 0 0}.president-content-wrapper{position:relative;width:80%;max-width:1100px}.president-image{width:100%;aspect-ratio:1246 / 601;display:block;object-fit:cover}.president-message-box{position:absolute;top:12%;left:2%;padding:2% 3%;z-index:2;max-width:42%}.president-message-box p{color:#fff;font-size:clamp(10px,1.5vw,20px);line-height:1.65;font-weight:700;letter-spacing:.02em;margin:0;text-shadow:1px 1px 4px rgba(0,0,0,.9)}.president-info{position:absolute;bottom:0;left:0;background-color:#000000ad;border-top:2px solid rgba(255,255,255,.4);padding:clamp(14px,2.5vw,34px) clamp(22px,3.5vw,54px);z-index:2;min-width:clamp(120px,18vw,260px);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.president-name{font-size:clamp(16px,2.4vw,34px);font-weight:700;color:#fff;margin:0 0 5px;letter-spacing:.12em}.president-position{font-size:clamp(11px,1.5vw,20px);color:#ffffffbf;margin:0;letter-spacing:.08em}.president-title-box{position:absolute;top:0;right:0;background-color:#000000ad;width:clamp(40px,7.5vw,108px);height:88%;writing-mode:vertical-rl;text-orientation:upright;display:flex;align-items:center;justify-content:flex-start;padding-top:10%;z-index:2;box-sizing:border-box;border-left:2px solid rgba(255,255,255,.25);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.president-title-box span{color:#fff;font-size:clamp(13px,2.2vw,28px);font-weight:700;letter-spacing:.2em}.president-full-message-section{width:80%;max-width:1100px;margin:0 auto;padding:50px 0 60px}.president-full-message-header{display:flex;align-items:center;gap:16px;margin-bottom:40px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.president-full-message-header h2{font-size:clamp(16px,2vw,26px);font-weight:900;color:#1a1a1a;margin:0;letter-spacing:.12em}.president-full-message-body{font-size:clamp(12px,1.3vw,16px);color:#3a3a3a;line-height:2}.president-full-message-body p{margin:0 0 1.4em}.msg-opening{font-size:clamp(13px,1.5vw,19px)!important;font-weight:700!important;color:#1a1a1a!important;line-height:1.9!important;margin-bottom:2em!important}.msg-section-divider{display:flex;align-items:center;gap:12px;margin:2.2em 0 1.4em;font-size:clamp(13px,1.4vw,18px);font-weight:900;color:#1a1a1a;letter-spacing:.15em}.msg-section-divider:before,.msg-section-divider:after{content:"";flex:1;height:1px;background-color:#c8c8c8}.msg-pullquote{font-size:clamp(14px,1.8vw,22px)!important;font-weight:700!important;color:#1a1a1a!important;border-left:3px solid #1a1a1a;padding:10px 0 10px 18px!important;margin:1.6em 0 1.2em!important;line-height:1.7!important;background-color:#f7f7f5}.msg-key{font-weight:900;color:#8b0000;letter-spacing:.04em}.msg-question{color:#555!important;font-size:clamp(11px,1.2vw,15px)!important;font-style:italic!important;letter-spacing:.01em!important;margin-bottom:1em!important}.msg-closing-big{font-size:clamp(14px,1.8vw,22px)!important;font-weight:700!important;color:#1a1a1a!important;line-height:1.7!important;margin-top:2em!important;margin-bottom:.6em!important}.msg-final{font-size:clamp(15px,2vw,26px)!important;font-weight:900!important;color:#1a1a1a!important;text-align:center!important;letter-spacing:.12em!important;margin-top:2em!important;line-height:1.8!important;padding:16px 0;border-top:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0}.president-signature{margin-top:40px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:right}.president-signature p{font-size:clamp(11px,1.2vw,15px);color:#555;margin:0 0 4px;line-height:1.6}.president-signature .president-signature-name{font-size:clamp(13px,1.5vw,18px);font-weight:700;color:#1a1a1a;margin:0}.philosophy-vision-section{margin-top:2%;background-color:#fff;padding:0}.section-title-box{display:inline-block;position:relative;background-color:#000;padding:clamp(14px,2vw,30px) clamp(20px,3vw,50px);left:37%;transform:translateY(35%);z-index:2}.section-title-box h2{color:#fff;font-size:clamp(13px,1.8vw,26px);font-weight:700;margin:0;letter-spacing:.1em;white-space:nowrap}.comp-philosophy-cards{display:flex;width:100%}.comp-philosophy-card-link{flex:1;text-decoration:none;display:block;min-width:0}.comp-philosophy-card{position:relative;width:100%;aspect-ratio:3 / 4;overflow:hidden}.comp-card-image{width:100%;height:100%;display:block;object-fit:cover;transition:transform .3s ease}.comp-philosophy-card-link:hover .comp-card-image{transform:scale(1.05)}.comp-card-title-box{position:absolute;top:33%;left:50%;transform:translate(-50%);background-color:#000000b8;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);width:72%;padding:clamp(9px,1.4vw,20px) clamp(12px,1.8vw,28px);text-align:center;box-sizing:border-box;border-top:2px solid rgba(205,176,96,.7)}.comp-card-title-box h3{font-size:clamp(14px,2.2vw,28px);font-weight:800;color:#fff;margin:0;white-space:nowrap;letter-spacing:.12em}.comp-card-desc-box{position:absolute;top:53%;left:50%;transform:translate(-50%);background-color:#ffffffc7;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);width:82%;padding:clamp(8px,1.3vw,18px) clamp(12px,1.8vw,24px);text-align:left;box-sizing:border-box}.comp-card-desc-box p{font-size:clamp(11px,1.4vw,18px);font-weight:600;color:#111;line-height:1.65;margin:0}.comp-card-desc-box p:first-letter{font-size:clamp(22px,3vw,38px);font-weight:900;color:#000;line-height:.85;float:left;margin-right:3px;margin-top:2px}.action-guidelines-section{background-color:#fff;margin-top:2%}.action-guidelines-white-space-top,.action-guidelines-white-space-bottom{display:none}.action-guidelines-content{display:flex;align-items:center;justify-content:flex-start;padding:clamp(30px,5vw,70px) 0;background-color:#000;margin:0}.action-title-vertical{display:flex;flex-direction:column;gap:0;margin-left:clamp(30px,8vw,130px);flex-shrink:0}.action-title-char{font-size:clamp(28px,6vw,86px);font-weight:900;font-family:Noto Sans JP,sans-serif;color:#fff;line-height:1.02}.action-guidelines-list{margin-left:clamp(16px,3vw,50px);text-align:left}.guideline-item{font-size:clamp(11px,1.4vw,20px);color:#fff;line-height:2;margin:0;font-family:Inter,sans-serif}.highlight-bold{font-weight:400;font-size:inherit;color:#fff}@media(max-width:1024px){.president-content-wrapper,.president-full-message-section{width:88%}.section-title-box{left:30%;padding:20px 30px}.action-title-char{font-size:clamp(24px,5vw,64px)}}@media(max-width:768px){.president-content-wrapper{width:95%}.president-full-message-section{width:92%}.president-message-box{max-width:55%}.president-title-box{width:clamp(32px,7.5vw,72px);height:82%}.president-info{padding:clamp(10px,2vw,24px) clamp(16px,2.5vw,36px);min-width:clamp(100px,15vw,180px)}.section-title-box{position:relative;left:auto;transform:none;display:block;margin:0 auto -16px;text-align:center;padding:16px 22px;width:max-content;max-width:92%}.section-title-box h2{font-size:14px;white-space:nowrap}.comp-philosophy-cards{flex-direction:column}.comp-philosophy-card{aspect-ratio:16 / 7}.comp-card-title-box{width:50%;top:32%}.comp-card-desc-box{width:60%;top:52%}.action-guidelines-content{flex-direction:column;align-items:center;padding:30px 20px}.action-title-vertical{flex-direction:row;margin-left:0;margin-bottom:20px}.action-title-char{font-size:clamp(20px,7vw,48px)}.action-guidelines-list{margin-left:0;text-align:center}.guideline-item{font-size:clamp(11px,2.5vw,16px);line-height:1.9}.msg-pullquote{font-size:clamp(13px,2.5vw,18px)!important}.msg-final{font-size:clamp(13px,3vw,20px)!important}.company-philosophy-container{padding-bottom:50px}}@media(max-width:480px){.president-content-wrapper{width:100%}.president-message-box{max-width:60%;top:8%}.president-title-box{width:clamp(26px,8vw,52px);height:75%}.president-info{padding:10px 16px;min-width:90px}.president-full-message-section{width:96%;padding:24px 0 30px}.president-full-message-body{font-size:12px}.section-title-box{padding:10px 14px;margin-bottom:-12px}.section-title-box h2{font-size:12px;letter-spacing:.04em;white-space:nowrap}.comp-philosophy-card{aspect-ratio:16 / 9}.comp-card-title-box{width:60%;top:30%}.comp-card-title-box h3{font-size:clamp(11px,4vw,16px);white-space:normal}.comp-card-desc-box{width:76%;top:52%}.comp-card-desc-box p{font-size:clamp(9px,3vw,12px)}.action-title-char{font-size:clamp(18px,8vw,36px)}.guideline-item{font-size:11px;line-height:1.8}.msg-pullquote{padding:8px 0 8px 12px!important}.company-philosophy-container{padding-bottom:40px}.msg-modal-overlay{padding:0;align-items:flex-end}.msg-modal-panel{border-radius:0;max-height:95vh}.msg-modal-header{padding:20px 20px 16px}.msg-modal-president-bar{padding:10px 20px;flex-wrap:wrap;gap:6px}.msg-modal-body{padding:20px 20px 0}.msg-modal-signature-area{padding:20px 20px 32px}.president-cta-hint{font-size:11px;padding:6px 14px}}.president-content-wrapper--clickable{cursor:pointer}.president-content-wrapper--clickable:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid rgba(184,151,58,.3);pointer-events:none;z-index:6;animation:president-pulse-border 2.8s ease-in-out infinite}@keyframes president-pulse-border{0%,to{border-color:#b8973a40;box-shadow:inset 0 0 #b8973a00}50%{border-color:#b8973abf;box-shadow:inset 0 0 24px #b8973a1a}}.president-content-wrapper--clickable:hover:after{border-color:#cdb060f2;box-shadow:inset 0 0 30px #b8973a26;animation:none}.president-hover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(7,16,28,.92) 0%,rgba(7,16,28,.6) 38%,rgba(7,16,28,.15) 65%,transparent 85%);display:flex;align-items:flex-end;justify-content:center;padding-bottom:9%;padding-right:10%;opacity:0;transition:opacity .45s cubic-bezier(.4,0,.2,1);z-index:3;pointer-events:none}.president-content-wrapper--clickable:hover .president-hover-overlay{opacity:1}.president-hover-content{text-align:center;transform:translateY(12px);transition:transform .45s cubic-bezier(.4,0,.2,1)}.president-content-wrapper--clickable:hover .president-hover-content{transform:translateY(0)}.president-hover-label{font-size:clamp(8px,.9vw,11px);letter-spacing:.32em;color:#cdb060cc;margin:0 0 10px;font-weight:400;text-transform:uppercase}.president-hover-main{font-size:clamp(16px,2.6vw,36px);color:#fff;font-weight:700;letter-spacing:.14em;margin:0 0 14px;text-shadow:0 2px 12px rgba(0,0,0,.5)}.president-hover-line{width:56px;height:2px;background:linear-gradient(90deg,transparent,rgba(205,176,96,.9),transparent);margin:0 auto}.president-cta-hint{position:absolute;bottom:clamp(10px,2.2vw,24px);left:56%;transform:translate(-50%);background:#b8973aed;color:#07101c;padding:7px 18px 7px 14px;display:flex;align-items:center;gap:7px;z-index:5;white-space:nowrap;font-size:clamp(10px,1.1vw,13px);font-weight:700;letter-spacing:.07em;animation:cta-float 2.6s ease-in-out infinite;pointer-events:none;border-left:3px solid rgba(255,255,255,.5)}@keyframes cta-float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-6px)}}.president-content-wrapper--clickable:hover .president-cta-hint{opacity:0;transition:opacity .3s}.president-cta-icon{font-size:1em;opacity:.85}.president-cta-arrow{display:inline-block;animation:cta-arrow-slide 1.6s ease-in-out infinite}@keyframes cta-arrow-slide{0%,to{transform:translate(0)}50%{transform:translate(5px)}}.msg-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#040a14e6;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:flex-start;justify-content:center;padding:48px 20px 60px;overflow-y:auto;animation:msg-overlay-in .3s ease forwards}@keyframes msg-overlay-in{0%{opacity:0}to{opacity:1}}.msg-modal-panel{background:#07101c;width:100%;max-width:800px;border:1px solid rgba(184,151,58,.3);box-shadow:0 40px 100px #000000bf,0 0 0 1px #b8973a0f,inset 0 1px #ffffff0a;animation:msg-panel-in .42s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes msg-panel-in{0%{opacity:0;transform:translateY(36px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.msg-modal-gold-bar{height:3px;background:linear-gradient(90deg,transparent 0%,rgba(184,151,58,.6) 20%,#DEC878 50%,rgba(184,151,58,.6) 80%,transparent 100%)}.msg-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:28px 40px 20px;border-bottom:1px solid rgba(255,255,255,.06);animation:msg-content-in .5s .1s ease both}@keyframes msg-content-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.msg-modal-header-text{display:flex;flex-direction:column;gap:4px}.msg-modal-eyebrow{font-size:.62rem;letter-spacing:.32em;color:#cdb060b3;text-transform:uppercase}.msg-modal-title{font-size:clamp(18px,2.8vw,26px);font-weight:700;color:#fff;letter-spacing:.1em;margin:0}.msg-modal-close{display:flex;align-items:center;gap:5px;padding:7px 14px;background:transparent;border:1px solid rgba(255,255,255,.16);color:#fff9;font-size:.78rem;letter-spacing:.09em;cursor:pointer;white-space:nowrap;flex-shrink:0;font-family:var(--font-body, sans-serif);transition:all .15s}.msg-modal-close:hover{border-color:#cdb060a6;color:#cdb060f2}.msg-modal-president-bar{display:flex;align-items:center;gap:12px;padding:14px 40px;background:#b8973a14;border-bottom:1px solid rgba(184,151,58,.18);animation:msg-content-in .5s .18s ease both}.msg-modal-president-name{font-size:clamp(14px,1.8vw,20px);font-weight:700;color:#fff;letter-spacing:.12em;white-space:nowrap}.msg-modal-president-sep{color:#cdb06073;font-weight:300}.msg-modal-president-role{font-size:clamp(11px,1.2vw,14px);color:#cdb060cc;letter-spacing:.08em;white-space:nowrap}.msg-modal-president-company{font-size:clamp(10px,1.1vw,13px);color:#ffffff61;letter-spacing:.05em;margin-left:auto;white-space:nowrap}.msg-modal-body{padding:36px 40px 0;animation:msg-content-in .5s .24s ease both}.msg-modal-body .president-full-message-body{color:#e8e0d0d9}.msg-modal-body .president-full-message-body p{margin:0 0 1.5em}.msg-modal-body .msg-opening{color:#fffffff2!important;font-size:clamp(13px,1.5vw,17px)!important}.msg-modal-body .msg-pullquote{border-left:3px solid rgba(205,176,96,.85)!important;background:#b8973a14!important;color:#e8e0d0f2!important}.msg-modal-body .msg-key{color:#cdb060!important}.msg-modal-body .msg-section-divider{color:#e8e0d0e0!important}.msg-modal-body .msg-section-divider:before,.msg-modal-body .msg-section-divider:after{background-color:#ffffff1a!important}.msg-modal-body .msg-question{color:#e8e0d08c!important}.msg-modal-body .msg-closing-big{color:#e8e0d0f2!important}.msg-modal-body .msg-final{color:#fff!important;border-top:1px solid rgba(205,176,96,.3)!important;border-bottom:1px solid rgba(205,176,96,.3)!important}.msg-modal-signature-area{padding:28px 40px 44px;text-align:right;border-top:1px solid rgba(205,176,96,.22);animation:msg-content-in .5s .3s ease both}.msg-modal-signature-area p{font-size:clamp(10px,1.1vw,13px);color:#e8e0d07a;margin:0 0 4px;letter-spacing:.05em}.msg-modal-signature-area .sig-name{font-size:clamp(13px,1.4vw,17px);font-weight:700;color:#e8e0d0d9;margin:0;letter-spacing:.08em}.department-policy-page{display:flex;flex-direction:column;min-height:100vh;background-color:#fff}.department-policy-container{flex:1;width:100%;max-width:100%;margin:0 auto;padding:0;background-color:#fff}.dp-hero-section{width:100%;background-color:#000;aspect-ratio:16 / 5;overflow:hidden;display:flex;justify-content:space-between;align-items:center;position:relative;padding:40px 8%}.dp-hero-left{display:flex;flex-direction:column;align-items:flex-start}.dp-hero-boxes-container{position:relative;width:clamp(280px,35vw,450px);height:clamp(220px,28vw,360px)}.dp-hero-box{position:absolute;border:1px solid #ffffff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(12px,1.5vw,20px) clamp(20px,2.5vw,35px);background-color:transparent}.dp-hero-box-1{top:0;left:0;z-index:4}.dp-hero-box-2{top:15%;left:38%;z-index:3}.dp-hero-box-3{top:45%;left:18%;z-index:2}.dp-hero-box-4{top:58%;left:52%;z-index:1}.dp-hero-box-main{color:#fff;font-size:clamp(50px,7vw,100px);font-weight:900;line-height:1}.dp-hero-box-sub{color:#fff;font-size:clamp(25px,3vw,45px);font-weight:600;line-height:1.3}.dp-hero-tagline{color:#fff;font-size:clamp(20px,3vw,42px);font-weight:900;margin-top:clamp(15px,2vw,30px);letter-spacing:.15em}.dp-hero-title-vertical{display:flex;flex-direction:column;align-items:center}.dp-hero-title-vertical span{color:transparent;font-family:Noto Sans JP,sans-serif;font-size:clamp(40px,6vw,90px);font-weight:700;line-height:1.1;letter-spacing:.05em;-webkit-text-stroke:1px #ffffff}.dp-description-section{padding:50px 5%;background-color:#fff;max-width:1000px;margin:0 auto}.dp-description-text{font-size:clamp(14px,1.6vw,18px);color:#333;line-height:2;text-align:center}.dp-departments-section{position:relative;width:90%;max-width:1000px;margin:0 auto;padding:40px 0 60px}.dp-departments-title-box{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#000;padding:5px;z-index:10;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;min-width:140px;min-height:140px}.dp-departments-title-text{font-size:48px}.dp-departments-title{color:#fff;font-size:clamp(22px,2.8vw,32px);font-weight:700;margin:0;letter-spacing:.1em;white-space:nowrap}.dp-departments-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px}.dp-department-card{padding:40px 35px;border:1px solid #cccccc;position:relative;background-color:#fff}.dp-department-card.dp-card-left .dp-department-label-en-top,.dp-department-card.dp-card-left .dp-department-label-en-bottom,.dp-department-card.dp-card-left .dp-department-name,.dp-department-card.dp-card-left .dp-department-footer,.dp-department-card.dp-card-left .dp-department-footer-en{text-align:left;font-size:28px}.dp-department-card.dp-card-right .dp-department-label-en-top,.dp-department-card.dp-card-right .dp-department-label-en-bottom,.dp-department-card.dp-card-right .dp-department-name,.dp-department-card.dp-card-right .dp-department-footer,.dp-department-card.dp-card-right .dp-department-footer-en{text-align:right;font-size:28px}.dp-department-label-en-top{font-size:clamp(14px,1.8vw,20px);color:#ccc;letter-spacing:.1em;margin-bottom:5px;font-weight:600;text-transform:uppercase}.dp-department-name{font-size:clamp(24px,3vw,36px);font-weight:900;color:#000;margin:0 0 15px}.dp-department-name-first{font-size:clamp(36px,5vw,56px);font-weight:900}.dp-department-name-rest{font-size:clamp(24px,3vw,36px);font-weight:900}.dp-department-description{font-size:clamp(13px,1.4vw,15px);color:#333;line-height:1.8;height:80px;margin-bottom:20px}.dp-department-services{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:15px}.dp-service-item{display:block;width:70%;max-width:200px;text-align:center;background-color:#fff;padding:10px 20px;font-size:clamp(13px,1.5vw,16px);color:#333;border:1px solid #cccccc}.dp-department-label-en-bottom{font-size:clamp(14px,1.8vw,20px);color:#ccc;letter-spacing:.1em;margin-top:15px;font-weight:600;text-transform:uppercase}.dp-department-footer{margin-top:15px}.dp-department-footer-name{font-size:clamp(24px,3vw,36px);font-weight:900;color:#000;margin:0 0 5px}.dp-department-footer-name-first{font-size:clamp(36px,5vw,56px);font-weight:900}.dp-department-footer-name-rest{font-size:clamp(24px,3vw,36px);font-weight:900}.dp-department-footer-en{font-size:clamp(14px,1.8vw,20px);color:#ccc;letter-spacing:.1em;text-transform:uppercase;font-weight:600}.dp-department-card.dp-card-top .dp-department-services{margin-top:0;margin-bottom:0}.dp-department-card.dp-card-bottom{display:flex;flex-direction:column}.dp-department-card.dp-card-bottom .dp-department-services{margin-bottom:20px}.dp-strategy-section{padding:80px 5%;margin-bottom:10%;background-color:#fff}.dp-strategy-title-box{display:flex;justify-content:center;margin-bottom:50px}.dp-strategy-title{background-color:#000;color:#fff;font-size:clamp(18px,2.2vw,24px);font-weight:700;padding:25px 50px;letter-spacing:.15em;margin:0}.dp-strategy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:25px;max-width:1000px;margin:0 auto 25px}.dp-strategy-grid-bottom{display:grid;grid-template-columns:repeat(2,1fr);gap:25px;max-width:660px;margin:0 auto}.dp-strategy-card{border:1px solid #cccccc;padding:25px;background-color:#fff}.dp-strategy-number{display:flex;align-items:center;gap:12px;margin-bottom:12px}.dp-strategy-num,.dp-strategy-name{font-size:clamp(16px,1.8vw,20px);font-weight:700;color:#000}.dp-strategy-description{font-size:clamp(12px,1.3vw,14px);color:#666;line-height:1.7;margin:0}.dp-footer-logos{display:flex;justify-content:center;align-items:center;gap:50px;padding:50px 5%;border-top:1px solid #eeeeee}.dp-footer-logo{height:35px;width:auto;opacity:.8}@media(max-width:1024px){.dp-departments-section{width:95%}.dp-departments-grid{gap:30px}.dp-department-card{padding:35px 28px}.dp-departments-title-box{padding:28px 22px}.dp-strategy-grid{gap:20px}.dp-strategy-grid-bottom{gap:20px;max-width:450px}.dp-strategy-card{padding:20px}}@media(max-width:768px){.dp-hero-section{aspect-ratio:16 / 10;flex-direction:column;padding:30px;justify-content:center;align-items:center}.dp-hero-left{align-items:center}.dp-hero-boxes-container{width:250px;height:200px}.dp-hero-box{padding:8px 15px;border-width:2px}.dp-hero-box-main{font-size:40px}.dp-hero-box-sub{font-size:16px}.dp-hero-tagline{font-size:18px;margin-top:15px}.dp-hero-title-vertical{flex-direction:row;margin-top:20px}.dp-hero-title-vertical span{font-size:32px}.dp-department-card.dp-card-right .dp-department-label-en-top,.dp-department-card.dp-card-right .dp-department-label-en-bottom,.dp-department-card.dp-card-right .dp-department-name,.dp-department-card.dp-card-right .dp-department-footer,.dp-department-card.dp-card-right .dp-department-footer-en{text-align:left}.dp-departments-section{width:95%;padding:40px 0 60px}.dp-departments-grid{grid-template-columns:1fr;gap:25px}.dp-department-card{border:1px solid #cccccc!important}.dp-departments-title-box{position:relative;top:auto;left:auto;transform:none;margin:0 auto 30px;width:max-content;min-width:110px;min-height:110px;max-width:90%;padding:14px 18px}.dp-departments-title-text{font-size:20px}.dp-service-item{width:80%;max-width:220px}.dp-department-label-en-top,.dp-department-label-en-bottom,.dp-department-footer-en{font-size:16px}.dp-strategy-grid,.dp-strategy-grid-bottom{grid-template-columns:1fr;max-width:450px}.dp-footer-logos{flex-wrap:wrap;gap:25px}.dp-footer-logo{height:28px}}@media(max-width:480px){.dp-hero-section{aspect-ratio:5 / 4;padding:20px}.dp-hero-boxes-container{width:200px;height:160px}.dp-hero-box{padding:6px 10px;border-width:2px}.dp-hero-box-main{font-size:32px}.dp-hero-box-sub{font-size:14px}.dp-hero-tagline{font-size:14px;margin-top:12px}.dp-hero-title-vertical span{font-size:24px}.dp-description-section{padding:35px 4%}.dp-description-text{font-size:13px;text-align:left;line-height:1.9}.dp-departments-section{width:100%;padding:30px 3% 50px}.dp-department-card{padding:22px 18px}.dp-departments-title-box{min-width:100px;min-height:100px;padding:12px 16px}.dp-departments-title{font-size:16px}.dp-departments-title-text{font-size:18px}.dp-service-item{padding:6px 12px;font-size:12px}.dp-strategy-section{padding:50px 3% 100px}.dp-strategy-title{font-size:15px;padding:18px 30px}.dp-strategy-card{padding:18px 15px}.dp-footer-logos{gap:18px;padding:35px 3%}.dp-footer-logo{height:22px}}@media(max-width:320px){.dp-description-text{font-size:12px}.dp-department-card{padding:18px 12px}.dp-departments-title-box{padding:14px 18px}.dp-departments-title{font-size:14px}.dp-department-name{font-size:20px}.dp-department-description,.dp-service-item{font-size:11px}.dp-strategy-title{font-size:13px;padding:14px 22px}.dp-strategy-name{font-size:14px}.dp-strategy-description{font-size:11px}.dp-footer-logo{height:18px}}.corporate-philosophy-page{display:flex;flex-direction:column;min-height:100vh;background-color:#fff}.corporate-philosophy-container{flex:1;width:100%;max-width:100%;margin:0 auto;padding:0;background-color:#fff}.cp-hero-section{width:100%;background-color:#000;aspect-ratio:16 / 5;overflow:hidden;background-size:cover;background-position:center;position:relative}.cp-hero-title-group{position:absolute;left:7%;top:50%;transform:translateY(-50%);width:clamp(80px,13vw,195px);height:clamp(72px,11.7vw,175px)}.cp-hero-char-ki{position:absolute;top:0;left:0;font-size:clamp(32px,6.2vw,92px);font-family:Noto Sans JP,sans-serif;font-weight:900;color:#fff;line-height:1}.cp-hero-char-gyo{position:absolute;top:5%;left:50%;font-size:clamp(24px,4.6vw,69px);font-family:Inter,sans-serif;font-weight:700;color:#fff;line-height:1}.cp-hero-char-ri{position:absolute;top:62%;left:4%;font-size:clamp(24px,4.6vw,69px);font-family:Inter,sans-serif;font-weight:700;color:#fff;line-height:1}.cp-hero-char-nen{position:absolute;top:44%;left:44%;font-size:clamp(32px,6.2vw,92px);font-family:Noto Sans JP,sans-serif;font-weight:700;color:#fff;line-height:1}.cp-hero-text-area{position:absolute;left:29%;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:flex-start}.cp-hero-text-line{color:#fff;font-family:Noto Sans JP,Inter,sans-serif;font-size:clamp(20px,5.5vw,82px);font-weight:900;line-height:1.38;margin:0;letter-spacing:.04em;text-shadow:2px 2px 8px rgba(0,0,0,.6)}.cp-slogan-section{padding:40px 0 25px;background-color:#fff;width:80%;max-width:1100px;margin:2% 0 0 8%}.cp-slogan-box{text-align:left;margin-bottom:12px}.cp-slogan-label{display:inline-block;background-color:#1a1a1a;padding:4px 14px;margin-bottom:6px}.cp-slogan-label span{color:#fff;font-size:clamp(11px,1.3vw,18px);font-weight:700;letter-spacing:.05em}.cp-slogan-title{font-size:clamp(16px,2.8vw,40px);font-weight:700;font-family:Inter,sans-serif;display:inline-block;color:#fff;background-color:#1a1a1a;margin:0;padding:8px 3px;letter-spacing:.06em;text-align:left}.cp-slogan-description{font-size:clamp(11px,1.4vw,20px);color:#333;line-height:1.7;margin:10px 0 0;text-align:left}.cp-message-section{padding:30px 0 50px;background-color:#fff}.cp-message-content{display:flex;justify-content:center;align-items:flex-start;width:84%;max-width:1100px;margin:0 auto;position:relative;gap:20px}.cp-message-text-area{flex:1;min-width:0;position:relative}.cp-message-text{font-size:clamp(11px,1.3vw,18px);color:#333;line-height:1.7;margin:0 0 20px;white-space:pre-line}.cp-emphasis{color:#c41e3a;font-weight:700}.cp-message-image{width:100%;height:auto;display:block;margin-top:16px;aspect-ratio:914 / 407;object-fit:cover}.cp-message-vertical-text{writing-mode:vertical-rl;text-orientation:upright;display:flex;flex-direction:row;align-items:center;gap:2px;padding:0;align-self:flex-start;flex-shrink:0;margin-left:8px}.cp-message-vertical-text span{font-size:clamp(13px,1.5vw,22px);color:#000;letter-spacing:.3em;line-height:1.5;font-weight:700}.cp-vt-sep{width:1px;height:1.8em;background-color:#000;flex-shrink:0;display:block}.cp-pillars-section{margin-top:2%;background-color:#fff;padding:0}.cp-pillars-title-box{display:inline-block;position:relative;background-color:#000;text-align:center;width:clamp(160px,20vw,280px);padding:clamp(14px,2vw,30px) 0;left:50%;transform:translate(-50%) translateY(50%);z-index:2}.cp-pillars-title-box h2{color:#fff;font-size:clamp(13px,1.6vw,22px);font-weight:700;margin:0;letter-spacing:.1em}.philosophy-cards{display:flex;width:100%}.philosophy-card{position:relative;flex:1;aspect-ratio:3 / 4;overflow:hidden}.card-image{width:100%;height:100%;display:block;object-fit:cover}.card-title-box,.card-desc-box{position:absolute;left:0;right:0;text-align:center}.card-description-box{background-color:#ffffffd1;padding:clamp(8px,1.4vw,18px) clamp(10px,1.8vw,22px)}.card-description-box h3,.card-description-box p{color:#111;font-size:clamp(11px,1.5vw,21px);font-weight:600;line-height:1.6;margin:0}.card-keyword-box{background-color:transparent;padding:0}.card-keyword-box h3,.card-keyword-box p{color:#fff;font-size:clamp(52px,8vw,130px);font-weight:900;font-family:Inter,sans-serif;line-height:.9;text-shadow:2px 4px 12px rgba(0,0,0,.55);margin:0}.philosophy-card:nth-child(1) .card-description-box{top:16%}.philosophy-card:nth-child(1) .card-keyword-box{bottom:14%}.philosophy-card:nth-child(2) .card-keyword-box{top:12%}.philosophy-card:nth-child(2) .card-description-box{top:54%}.philosophy-card:nth-child(3) .card-description-box{top:16%}.philosophy-card:nth-child(3) .card-keyword-box{bottom:14%}.cp-spirit-section{margin-top:4%;margin-bottom:6%;background-color:#fff;padding:0 0 50px}.cp-spirit-title-box{display:inline-block;position:relative;background-color:#000;width:clamp(160px,20vw,280px);text-align:center;padding:clamp(14px,2vw,30px) 20px;left:50%;transform:translate(-50%) translateY(50%);z-index:2}.cp-spirit-title-box h2{color:#fff;font-size:clamp(13px,1.6vw,22px);font-weight:700;margin:0;letter-spacing:.1em}.cp-spirit-card{position:relative;width:86%;margin:0 auto;overflow:hidden}.cp-spirit-image{width:100%;height:auto;display:block}.cp-spirit-items{position:absolute;bottom:5%;left:20%;right:20%;display:flex;flex-direction:column;gap:clamp(4px,.8vw,10px);align-items:stretch}.cp-spirit-item{background-color:#ffffffeb;padding:clamp(4px,.7vw,9px) clamp(10px,1.8vw,22px);text-align:center;box-sizing:border-box}.cp-spirit-item span{font-size:clamp(9px,1.2vw,17px);color:#1a1a1a;font-weight:700;display:block;word-break:keep-all;overflow-wrap:break-word}.cp-spirit-item-last{margin-top:0}@media(max-width:1024px){.cp-slogan-section{width:86%;margin-left:7%}.cp-message-content{width:88%}}@media(max-width:768px){.cp-hero-section{aspect-ratio:4 / 3}.cp-hero-title-group{left:5%;width:clamp(60px,18vw,130px);height:clamp(54px,16vw,117px)}.cp-hero-text-area{left:36%}.cp-hero-text-line{font-size:clamp(16px,6.5vw,52px)}.cp-slogan-section{width:92%;margin-left:4%}.cp-message-content{width:92%;flex-direction:column}.cp-message-vertical-text{writing-mode:horizontal-tb;text-orientation:mixed;flex-direction:column;align-items:flex-start;gap:4px;margin-left:0;margin-top:16px;border-top:1px solid #333;padding-top:10px}.cp-vt-sep{width:1.8em;height:1px}.philosophy-cards{flex-direction:column}.philosophy-card{aspect-ratio:4 / 3}.card-keyword-box h3,.card-keyword-box p{font-size:clamp(40px,11vw,90px)}.cp-spirit-card{width:95%}.cp-spirit-items{left:15%;right:15%;bottom:4%}}@media(max-width:480px){.cp-hero-section{aspect-ratio:3 / 2;display:flex;align-items:center;padding:0 4%;position:relative}.cp-hero-title-group{position:relative;left:auto;top:auto;transform:none;width:70px;height:63px;flex-shrink:0}.cp-hero-text-area{position:relative;left:auto;top:auto;transform:none;margin-left:12px}.cp-hero-text-line{font-size:clamp(14px,6.5vw,32px);line-height:1.4}.cp-slogan-section{width:96%;margin-left:2%;padding:24px 10px 14px;box-sizing:border-box;margin-top:0}.cp-message-section{padding:20px 0 30px}.cp-message-content{width:96%}.cp-message-text{font-size:12px}.cp-pillars-section,.cp-spirit-section{margin-top:2%}.philosophy-card{aspect-ratio:16 / 9}.card-description-box h3,.card-description-box p{font-size:clamp(9px,3vw,13px)}.card-keyword-box h3,.card-keyword-box p{font-size:clamp(36px,10vw,60px)}.cp-spirit-items{left:8%;right:8%;bottom:3%}.cp-spirit-item span{font-size:clamp(8px,2.5vw,12px)}.cp-spirit-card{width:100%}}@media(max-width:320px){.cp-hero-text-line{font-size:12px}.cp-slogan-title{font-size:14px}.cp-spirit-item span{font-size:7px}}.corporate-vision-page{display:flex;flex-direction:column;min-height:100vh;background-color:#fff}.corporate-vision-container{flex:1;width:100%;max-width:100%;margin:0 auto;padding:0;background-color:#fff}.cv-hero-section{width:100%;background:linear-gradient(to right,#1a1a1a,#4a4a4a,#8a8a8a);aspect-ratio:16 / 5;overflow:hidden;position:relative}.cv-hero-content{width:100%;height:100%;position:relative;display:flex;align-items:center}.cv-hero-title-vertical{position:absolute;left:15%;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;-webkit-text-stroke:1px rgb(70,70,70);align-items:center;gap:0}.cv-hero-title-vertical span{font-size:clamp(32px,4.5vw,60px);font-weight:900;color:#000;line-height:1.1;letter-spacing:0}.cv-hero-keywords{position:absolute;left:18%;top:8%;width:50%;height:55%}.cv-hero-keyword-box{position:absolute;border:2px solid #ffffff;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:clamp(4px,.8vw,10px) clamp(8px,1.2vw,18px);padding-top:clamp(18px,2.5vw,38px)}.cv-keyword-first{font-size:clamp(36px,5vw,70px);font-weight:900;color:#fff;line-height:.8;margin-top:clamp(-25px,-3.5vw,-45px)}.cv-keyword-rest{font-size:clamp(24px,3.2vw,45px);font-weight:900;color:#fff;line-height:1}.cv-keyword-uru{left:0;top:5%}.cv-keyword-naosu{left:13%;top:30%}.cv-keyword-arau{left:15%;top:78%}.cv-keyword-hakobu{left:1%;top:55%}.cv-hero-service-text{position:absolute;left:30%;top:70%;font-size:clamp(32px,3vw,70px);font-weight:700;color:#fff;line-height:1.4}.cv-service-no{font-size:clamp(25px,3vw,36px)}.cv-hero-bottom-text{position:absolute;bottom:4%;left:18%;display:flex;flex-direction:column;align-items:flex-start;gap:0}.cv-hero-main-slogan{font-size:clamp(32px,6vw,85px);font-weight:900;color:#fff;letter-spacing:.05em;line-height:1}.cv-hero-sub-slogan{font-size:clamp(12px,1.8vw,25px);font-weight:700;color:#fff;align-self:flex-end}.cv-targets-section{padding:60px 5%;background-color:#fff;margin-top:5%}.cv-targets-layout{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:50px 80px}.cv-target-card{display:flex;align-items:flex-start;gap:10px}.cv-target-card.cv-card-customer{grid-column:1;grid-row:1}.cv-target-card.cv-card-employee{grid-column:2;grid-row:1 / 3;align-self:center}.cv-target-card.cv-card-society{grid-column:1;grid-row:2}.cv-target-label-area{display:flex;flex-direction:column;align-items:flex-start;flex-shrink:0}.cv-target-tai{font-size:clamp(28px,4vw,45px);color:#000;font-style:italic;font-weight:500;margin-bottom:0;line-height:1}.cv-target-tai.cv-tai-white{color:#fff;-webkit-text-stroke:1.5px #000000}.cv-target-label{writing-mode:vertical-rl;text-orientation:upright;font-size:clamp(56px,7vw,90px);font-weight:900;color:#000;letter-spacing:0;line-height:1}.cv-target-content{flex:1;padding-top:5px}.cv-target-mission{display:block;width:fit-content;background-color:transparent;color:#000;font-size:clamp(16px,2vw,22px);font-weight:700;padding:8px 15px;margin-bottom:8px;border:2px solid #000000}.cv-target-subtitle{display:block;width:fit-content;font-size:clamp(20px,2.5vw,28px);font-weight:900;color:#fff;background-color:#000;padding:8px 20px;margin-bottom:15px}.cv-target-subtitle-outline{display:inline-block;font-size:clamp(20px,2.5vw,28px);font-weight:900;color:#000;border:2px solid #000000;background-color:transparent;padding:6px 20px;margin-bottom:15px}.cv-target-description{font-size:clamp(13px,1.5vw,16px);color:#333;line-height:1.9;margin:0}.cv-policy-section{background-color:#fff;padding:80px 5%}.cv-policy-title-box{display:flex;justify-content:center;margin-bottom:50px}.cv-policy-title{background-color:#000;color:#fff;font-size:clamp(28px,4vw,42px);font-weight:700;padding:35px 120px;letter-spacing:.2em;margin:0}.cv-policy-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:950px;margin:0 auto}.cv-policy-card{background-color:#fff;border:1px solid #cccccc;padding:40px 30px}.cv-policy-card-title{font-size:clamp(22px,2.8vw,32px);font-weight:700;color:#000;margin:0 0 20px;text-align:center}.cv-policy-card-title-bold{font-size:clamp(28px,3.5vw,42px);font-weight:900;color:#000}.cv-policy-card-title-normal{font-size:clamp(22px,2.8vw,32px);font-weight:400;color:#fff;-webkit-text-stroke:1.5px #000000}.cv-policy-card-description{font-size:clamp(14px,1.5vw,17px);color:#333;line-height:1.9;margin:0}.cv-philosophy-section{padding:80px 5% 0;margin-bottom:15%;background-color:#fff}.cv-philosophy-title-box{display:flex;justify-content:center;margin-bottom:80px}.cv-philosophy-title{background-color:#000;color:#fff;font-size:clamp(24px,3.5vw,38px);font-weight:700;padding:30px 80px;letter-spacing:.1em;margin:0}.cv-philosophy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1000px;margin:0 auto}.cv-philosophy-card{border:1px solid #cccccc;border-radius:20px;padding:60px 25px 35px;text-align:center;position:relative;margin-top:40px}.cv-philosophy-card-title{position:absolute;top:-45px;left:50%;transform:translate(-50%);font-size:clamp(36px,5vw,60px);font-weight:900;color:#000;margin:0;text-shadow:3px 3px 0 #d0d0d0;white-space:nowrap}.cv-philosophy-card-title-first{font-size:clamp(48px,6.5vw,80px);font-weight:900}.cv-philosophy-card-title-rest{font-size:clamp(36px,5vw,60px);font-weight:900}.cv-philosophy-card-title.cv-title-black-white-stroke{color:#000;-webkit-text-stroke:2px #ffffff;text-shadow:none}.cv-philosophy-card-title.cv-title-black-white-stroke .cv-philosophy-card-title-first,.cv-philosophy-card-title.cv-title-black-white-stroke .cv-philosophy-card-title-rest{color:#000;-webkit-text-stroke:2px #ffffff}.cv-philosophy-card-title.cv-title-white-black-stroke{color:#fff;-webkit-text-stroke:2px #000000;text-shadow:none}.cv-philosophy-card-title.cv-title-white-black-stroke .cv-philosophy-card-title-first,.cv-philosophy-card-title.cv-title-white-black-stroke .cv-philosophy-card-title-rest{color:#fff;-webkit-text-stroke:2px #000000}.cv-philosophy-card-description{font-size:clamp(14px,1.5vw,16px);color:#333;line-height:2.2;margin:0;text-align:center}.cv-footer-logos{display:flex;justify-content:center;align-items:center;gap:50px;padding:50px 5%;border-top:1px solid #eeeeee}.cv-footer-logo{height:35px;width:auto;opacity:.8}@media(max-width:1024px){.cv-hero-section{aspect-ratio:16 / 6}.cv-hero-title-vertical{left:5%}.cv-hero-keywords{left:15%;width:55%}.cv-keyword-first{margin-top:-30px}.cv-targets-layout{gap:30px 50px}.cv-policy-title{padding:30px 80px}.cv-policy-grid{gap:15px}.cv-policy-card{padding:30px 25px}.cv-philosophy-title{padding:25px 60px}.cv-philosophy-grid{gap:25px}.cv-philosophy-card{padding:50px 20px 30px;margin-top:35px}.cv-philosophy-card-title{top:-40px}}@media(max-width:860px){.cv-hero-section{aspect-ratio:16 / 6}}@media(max-width:768px){.cv-hero-section{aspect-ratio:16 / 7}.cv-hero-title-vertical{left:4%}.cv-hero-title-vertical span{font-size:24px}.cv-hero-keywords{left:12%;top:8%;width:60%;height:55%}.cv-keyword-first{font-size:32px;margin-top:-22px}.cv-keyword-rest{font-size:20px}.cv-hero-service-text{font-size:16px;left:42%;top:48%}.cv-service-no{font-size:12px}.cv-hero-bottom-text{bottom:4%;left:12%}.cv-hero-main-slogan{font-size:28px}.cv-hero-sub-slogan{font-size:12px}.cv-targets-section{padding:50px 4%}.cv-targets-layout{grid-template-columns:1fr;grid-template-rows:auto;gap:50px}.cv-target-card.cv-card-customer,.cv-target-card.cv-card-employee,.cv-target-card.cv-card-society{grid-column:1;grid-row:auto}.cv-target-label{font-size:70px}.cv-policy-section{padding:60px 4%}.cv-policy-grid{grid-template-columns:1fr;gap:15px}.cv-policy-title{padding:25px 60px;font-size:28px}.cv-policy-card{padding:35px 25px}.cv-philosophy-section{padding:60px 4%}.cv-philosophy-grid{grid-template-columns:1fr;gap:60px;max-width:400px}.cv-philosophy-title{padding:22px 50px;font-size:24px}.cv-philosophy-card{padding:55px 25px 35px;margin-top:30px}.cv-philosophy-card-title{top:-35px}.cv-footer-logos{flex-wrap:wrap;gap:25px}.cv-footer-logo{height:28px}}@media(max-width:480px){.cv-hero-section{aspect-ratio:4 / 3}.cv-hero-title-vertical{left:3%;top:50%;transform:translateY(-50%)}.cv-hero-title-vertical span{font-size:18px}.cv-hero-keywords{left:12%;top:8%;width:65%;height:52%}.cv-hero-keyword-box{padding:14px 6px 3px}.cv-keyword-first{font-size:22px;margin-top:-15px}.cv-keyword-rest{font-size:14px}.cv-hero-service-text{font-size:11px;left:42%;top:48%}.cv-service-no{font-size:9px}.cv-hero-bottom-text{bottom:5%;left:10%}.cv-hero-main-slogan{font-size:22px}.cv-hero-sub-slogan{font-size:10px}.cv-targets-section{padding:40px 3%}.cv-target-label{font-size:48px}.cv-policy-section{padding:50px 3%}.cv-policy-title{font-size:18px;padding:18px 35px}.cv-policy-card{padding:18px 15px}.cv-philosophy-section{padding:50px 3%}.cv-philosophy-title{font-size:14px;padding:12px 20px}.cv-philosophy-card-title{font-size:40px}.cv-footer-logos{gap:18px;padding:35px 3%}.cv-footer-logo{height:22px}}@media(max-width:320px){.cv-hero-title-vertical span{font-size:14px}.cv-keyword-first{font-size:18px;margin-top:-12px}.cv-keyword-rest{font-size:12px}.cv-hero-service-text{font-size:9px}.cv-hero-main-slogan{font-size:16px}.cv-hero-sub-slogan{font-size:8px}.cv-target-card{padding:15px 12px}.cv-target-label{font-size:28px}.cv-target-description{font-size:11px}.cv-policy-title{font-size:14px;padding:10px 20px}.cv-policy-card{padding:15px 12px}.cv-policy-card-description{font-size:11px}.cv-philosophy-title{font-size:12px;padding:10px 15px}.cv-philosophy-card-title{font-size:32px}.cv-philosophy-card-description{font-size:11px}.cv-footer-logo{height:18px}}.wr-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-cream-100, #F7F4EF)}.wr-hero{position:relative;width:100%;min-height:clamp(280px,38vh,420px);padding-top:var(--header-height, 64px);background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden;display:flex;align-items:stretch}.wr-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0a1628ed,#132952d4);display:flex;align-items:center;width:100%}.wr-hero-kanji{position:absolute;right:5%;top:50%;transform:translateY(-50%);font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(10rem,22vw,20rem);line-height:1;color:#ffffff08;pointer-events:none;-webkit-user-select:none;user-select:none}.wr-hero-inner{position:relative;z-index:1;width:100%;max-width:900px;margin:0 auto;padding:clamp(2.5rem,5vw,4.5rem) clamp(1.5rem,4vw,3rem)}.wr-hero-inner .page-eyebrow{margin-bottom:.75rem}.wr-hero-title{font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(2.25rem,5.5vw,4rem);font-weight:400;color:#fff;margin:0 0 1.25rem;letter-spacing:.06em;line-height:1.1}.wr-hero-rule{width:40px;height:2px;background:var(--color-gold-500, #B8973A);margin-bottom:1rem}.wr-hero-sub{font-family:var(--font-body, "Plus Jakarta Sans", sans-serif);font-size:.9rem;color:#ffffffa6;margin:0;letter-spacing:.04em}.wr-main{flex:1;padding:2.5rem 1.5rem calc(var(--footer-height, 80px) + 3rem)}.wr-container{max-width:900px;margin:0 auto}.wr-dept-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-cream-200, #EDE8DF);margin-bottom:0}.wr-dept-tab{position:relative;padding:.875rem 1.75rem .875rem 0;background:none;border:none;cursor:pointer;font-family:var(--font-body, sans-serif);font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-light, #A0ADB7);transition:color .2s}.wr-dept-tab:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:2px;background:var(--color-gold-500, #B8973A);transition:width .25s cubic-bezier(.4,0,.2,1)}.wr-dept-tab.active{color:var(--color-navy-800, #0E2040)}.wr-dept-tab.active:after{width:calc(100% - 1.75rem)}.wr-dept-tab:hover{color:var(--color-navy-600, #1B3A6B)}.wr-section-label{font-family:var(--font-body, sans-serif);font-size:.68rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text-muted, #6E7F8D);margin:1.5rem 0 0;padding-bottom:1.5rem;border-bottom:1px solid var(--color-cream-200, #EDE8DF)}.wr-accordion{display:flex;flex-direction:column}.wr-chapter{border-bottom:1px solid var(--color-cream-200, #EDE8DF)}.wr-chapter-head{width:100%;display:flex;align-items:center;gap:1rem;padding:1.125rem .5rem;background:none;border:none;cursor:pointer;text-align:left;border-radius:var(--border-radius-sm, .25rem);transition:background .15s}.wr-chapter-head:hover{background:var(--color-cream-50, #FDFBF8)}.wr-chapter-num{font-family:var(--font-display, "DM Serif Display", serif);font-size:clamp(1.1rem,2.5vw,1.6rem);color:var(--color-cream-300, #DDD5C8);line-height:1;min-width:2.25rem;flex-shrink:0;transition:color .2s}.wr-chapter.open .wr-chapter-num,.wr-chapter-head:hover .wr-chapter-num{color:var(--color-gold-500, #B8973A)}.wr-chapter-icon{font-size:1rem;flex-shrink:0;display:flex;align-items:center;opacity:.85}.wr-chapter-title{font-family:var(--font-body, sans-serif);font-size:.95rem;font-weight:600;color:var(--color-navy-800, #0E2040);flex:1;letter-spacing:.01em}.wr-chapter-toggle{font-size:1.3rem;font-weight:300;color:var(--color-gold-400, #CDB060);flex-shrink:0;line-height:1;min-width:1rem;text-align:center}.wr-chapter-body{padding:0 .5rem 1.5rem 5.25rem;display:flex;flex-direction:column;gap:0;position:relative}.wr-chapter-body:before{content:"";position:absolute;left:2.75rem;top:0;bottom:1.5rem;width:1px;background:var(--color-gold-400, #CDB060);opacity:.45}.wr-rule-item{padding:.875rem 0 .875rem 1rem;border-bottom:1px solid var(--color-cream-200, #EDE8DF);transition:background .15s}.wr-rule-item:last-child{border-bottom:none}.wr-rule-item:hover{background:#fdfbf8cc}.wr-rule-label{font-family:var(--font-body, sans-serif);font-size:.78rem;font-weight:700;color:var(--color-navy-700, #132952);letter-spacing:.05em;margin:0 0 .4rem}.wr-rule-text{font-family:var(--font-body, sans-serif);font-size:.875rem;color:var(--color-text-secondary, #3D4F62);line-height:1.85;margin:0;white-space:pre-line}@media(max-width:768px){.wr-hero{min-height:240px}.wr-hero-kanji{font-size:8rem}.wr-dept-tab{font-size:.72rem;padding-right:1.25rem}.wr-chapter-body{padding-left:1rem}.wr-chapter-body:before{left:0}.wr-chapter-num{font-size:1rem;min-width:1.75rem}}@media(max-width:480px){.wr-main{padding:2rem 1rem calc(var(--footer-height, 80px) + 2rem)}.wr-chapter-head{gap:.75rem;padding:1rem .25rem}.wr-chapter-icon{display:none}.wr-chapter-body{padding-left:.75rem}.wr-rule-label{font-size:.75rem}.wr-rule-text{font-size:.825rem}}.admin-page-wrapper{display:flex;flex-direction:column;min-height:100%;flex:1;background-color:var(--color-cream-100);margin-bottom:calc(-1 * var(--footer-height, 80px))}.admin-permission-message{max-width:720px;margin:calc(var(--header-height, 64px) + 48px) auto 0;padding:24px;border:1px solid var(--color-cream-200, #EDE8DF);border-radius:var(--border-radius-md, .5rem);background:var(--color-white, #ffffff);color:var(--color-text-secondary, #3D4F62);font-weight:700;text-align:center;box-shadow:0 8px 24px #0a162814}.admin-hero{background:linear-gradient(135deg,var(--color-navy-900) 0%,var(--color-navy-800) 60%,#1A3060 100%);border-bottom:2px solid var(--color-gold-600);padding:2rem var(--spacing-xl);position:relative;overflow:hidden}.admin-hero:before{content:"";position:absolute;top:0;right:0;width:400px;height:100%;background:radial-gradient(ellipse at 100% 50%,rgba(184,151,58,.08) 0%,transparent 70%);pointer-events:none}.admin-hero-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);position:relative;z-index:1}.admin-hero-left{display:flex;align-items:center;gap:var(--spacing-md)}.admin-hero-badge{width:52px;height:52px;background:linear-gradient(135deg,var(--color-gold-600),var(--color-gold-400));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-navy-900);box-shadow:0 4px 16px #b8973a59;flex-shrink:0}.admin-hero-text{display:flex;flex-direction:column;gap:2px}.admin-hero-eyebrow{font-family:var(--font-body);font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--color-gold-400)}.admin-hero-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:400;color:var(--color-cream-50);margin:0;letter-spacing:-.01em;line-height:1.2}.admin-hero-subtitle{font-family:var(--font-body);font-size:var(--font-size-sm);color:#f5f1e88c;margin:0}.admin-main{flex:1;display:flex;max-width:1400px;margin:0 auto;width:100%;padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-2xl);gap:var(--spacing-xl);box-sizing:border-box}.admin-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-sidebar-label{font-family:var(--font-body);font-size:.65rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-xs);margin-top:var(--spacing-xs)}.admin-nav-btn{display:flex;align-items:center;gap:10px;padding:11px var(--spacing-md);background:transparent;border:1px solid transparent;border-radius:var(--border-radius-md);color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.admin-nav-btn svg{font-size:1.05rem;flex-shrink:0;opacity:.7}.admin-nav-btn:hover{background:#2a5b8f0f;color:var(--color-navy-700)}.admin-nav-btn.active{background:#b8973a1f;border:1px solid rgba(184,151,58,.4);color:var(--color-gold-700)}.admin-nav-btn.active svg{color:var(--color-gold-600);opacity:1}.admin-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-lg)}.admin-card{background:var(--color-cream-50);border-radius:var(--border-radius-lg);border:1px solid var(--color-cream-200);box-shadow:var(--shadow-md);overflow:hidden}.admin-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-cream-200);background:var(--color-white);gap:var(--spacing-md);flex-wrap:wrap}.admin-card-title-area{display:flex;flex-direction:column;gap:2px}.admin-card-title{font-family:var(--font-display);font-size:var(--font-size-xl);color:var(--color-navy-800);margin:0;font-weight:400}.admin-card-subtitle{font-family:var(--font-body);font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.admin-card-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.admin-card-body{padding:0}.admin-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:8px var(--spacing-md);background:var(--color-navy-800);color:var(--color-white);border:1.5px solid var(--color-navy-800);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.admin-btn-primary:hover{background:var(--color-navy-900);border-color:var(--color-navy-900);transform:translateY(-1px);box-shadow:var(--shadow-md)}.admin-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse;font-family:var(--font-body);font-size:var(--font-size-sm)}.admin-table thead tr{background:var(--color-cream-100);border-bottom:2px solid var(--color-cream-200)}.admin-table th{padding:12px var(--spacing-lg);text-align:left;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap}.admin-table tbody tr{border-bottom:1px solid var(--color-cream-200);transition:background var(--transition-fast)}.admin-table tbody tr.admin-table-row-clickable{cursor:pointer}.admin-table tbody tr:hover{background:#2a5b8f08}.admin-table tbody tr:last-child{border-bottom:none}.admin-table td{padding:14px var(--spacing-lg);color:var(--color-text-primary);vertical-align:middle}.admin-table .col-username{font-weight:600;color:var(--color-navy-700)}.admin-table .col-email{color:var(--color-text-secondary)}.admin-table .col-status{white-space:nowrap}.admin-table .col-groups{min-width:100px;max-width:200px;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.04em;white-space:nowrap}.status-badge.enabled{background:var(--color-success-light);color:var(--color-success);border:1px solid rgba(45,122,79,.25)}.status-badge.enabled:before{content:"";width:6px;height:6px;background:var(--color-success);border-radius:50%;flex-shrink:0}.status-badge.disabled{background:var(--color-error-light);color:var(--color-error);border:1px solid rgba(192,57,43,.2)}.status-badge.disabled:before{content:"";width:6px;height:6px;background:var(--color-error);border-radius:50%;flex-shrink:0}.row-actions{display:flex;align-items:center;gap:4px;justify-content:flex-end}.row-action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:1px solid var(--color-cream-300);border-radius:var(--border-radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem}.row-action-btn:hover{background:var(--color-cream-100);color:var(--color-navy-600);border-color:var(--color-navy-400)}.row-action-btn.danger:hover{background:var(--color-error-light);color:var(--color-error);border-color:#c0392b59}.row-action-btn.success:hover{background:var(--color-success-light);color:var(--color-success);border-color:#2d7a4f59}.admin-state-message{padding:var(--spacing-3xl) var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--font-size-base)}.admin-state-message.error{color:var(--color-error)}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1628a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop, 1040);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);animation:modalOverlayFadeIn .2s ease}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}.admin-modal{background:var(--color-white);border-radius:var(--border-radius-xl);box-shadow:0 24px 64px #0a16284d;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modalSlideUp .25s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-cream-200);position:sticky;top:0;background:var(--color-white);z-index:1;border-radius:var(--border-radius-xl) var(--border-radius-xl) 0 0}.admin-modal-title{font-family:var(--font-display);font-size:var(--font-size-xl);color:var(--color-navy-800);margin:0;font-weight:400}.admin-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--border-radius-md);color:var(--color-text-muted);cursor:pointer;font-size:1.1rem;transition:all var(--transition-fast)}.admin-modal-close:hover{background:var(--color-cream-100);color:var(--color-text-primary)}.admin-modal-body{padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-cream-200)}.admin-form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-form-label{font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);letter-spacing:.02em}.admin-form-label .required{color:var(--color-error);margin-left:3px}.admin-form-input{padding:10px var(--spacing-md);border:1.5px solid var(--color-cream-300);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;width:100%;box-sizing:border-box}.admin-form-input:focus{border-color:var(--color-navy-500);box-shadow:0 0 0 3px #2a5b8f1a}.admin-form-input:disabled{background:var(--color-cream-100);color:var(--color-text-muted);cursor:not-allowed}.admin-form-select{padding:10px var(--spacing-md);border:1.5px solid var(--color-cream-300);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;width:100%;box-sizing:border-box;cursor:pointer}.admin-form-select:focus{border-color:var(--color-navy-500);box-shadow:0 0 0 3px #2a5b8f1a}.admin-btn-cancel{padding:9px var(--spacing-lg);background:transparent;color:var(--color-text-secondary);border:1.5px solid var(--color-cream-300);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.admin-btn-cancel:hover{background:var(--color-cream-100);border-color:var(--color-cream-300)}.admin-btn-submit{padding:9px var(--spacing-lg);background:var(--color-navy-800);color:var(--color-white);border:1.5px solid var(--color-navy-800);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.admin-btn-submit:hover{background:var(--color-navy-900);border-color:var(--color-navy-900)}.admin-btn-submit:disabled{opacity:.55;cursor:not-allowed}.admin-btn-danger{padding:9px var(--spacing-lg);background:var(--color-error);color:var(--color-white);border:1.5px solid var(--color-error);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.admin-btn-danger:hover{background:#a02f23;border-color:#a02f23}.admin-confirm-message{font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text-primary);line-height:var(--line-height-relaxed);margin:0}.admin-confirm-message strong{color:var(--color-navy-700);font-weight:600}.admin-warning-text{font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--color-error);margin:var(--spacing-sm) 0 0;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-error-light);border-radius:var(--border-radius-md);border-left:3px solid var(--color-error)}.admin-detail-list{display:flex;flex-direction:column;gap:var(--spacing-sm);list-style:none;margin:0;padding:0}.admin-detail-item{display:grid;grid-template-columns:140px 1fr;gap:var(--spacing-sm);align-items:baseline;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-cream-200);font-family:var(--font-body);font-size:var(--font-size-sm)}.admin-detail-item:last-child{border-bottom:none}.admin-detail-key{font-weight:600;color:var(--color-text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}.admin-detail-value{color:var(--color-text-primary);word-break:break-all}.admin-groups-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin:0;padding:0;list-style:none}.admin-group-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--color-info-light);border:1px solid rgba(42,91,143,.25);border-radius:20px;font-family:var(--font-body);font-size:var(--font-size-xs);font-weight:500;color:var(--color-info)}.admin-group-tag-remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:#2a5b8f26;border:none;border-radius:50%;color:var(--color-info);cursor:pointer;font-size:.7rem;transition:all var(--transition-fast);padding:0}.admin-group-tag-remove:hover{background:#c0392b26;color:var(--color-error)}.admin-groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md);padding:var(--spacing-xl)}.admin-group-card{background:var(--color-white);border:1px solid var(--color-cream-200);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.admin-group-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-group-card-name{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--color-navy-700);margin:0 0 var(--spacing-xs);font-weight:400}.admin-group-card-desc{font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;line-height:var(--line-height-relaxed)}.admin-search-wrapper{position:relative;max-width:280px}.admin-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);font-size:.9rem;pointer-events:none}.admin-search-input{padding:7px 10px 7px 32px;border:1.5px solid var(--color-cream-300);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;width:100%;box-sizing:border-box}.admin-search-input:focus{border-color:var(--color-navy-500);box-shadow:0 0 0 3px #2a5b8f1a}@media(max-width:1024px){.admin-main{padding:var(--spacing-lg);gap:var(--spacing-lg)}.admin-sidebar{width:190px}}@media(max-width:1100px){.admin-table th:nth-child(3),.admin-table td:nth-child(3){display:none}}@media(max-width:768px){.admin-hero{flex-shrink:0;padding:1.5rem var(--spacing-md) 1.75rem}.admin-main{flex-direction:column;padding:var(--spacing-md)}.admin-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;gap:4px}.admin-sidebar-label{width:100%}.admin-nav-btn{flex:1;min-width:120px;justify-content:center}.admin-card-header{flex-direction:column;align-items:flex-start;padding:var(--spacing-md) var(--spacing-md)}.admin-card-actions{width:100%;flex-wrap:wrap}.admin-search-wrapper{order:-1;width:100%;flex:1 1 100%;max-width:none}.admin-hero-subtitle{display:none}}@media(max-width:540px){.admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}}:root{--color-navy-900: #0A1628;--color-navy-800: #0E2040;--color-navy-700: #132952;--color-navy-600: #1B3A6B;--color-navy-500: #2A5B8F;--color-navy-400: #4A7BAD;--color-navy-300: #7AADCF;--color-navy-100: #D4E6F4;--color-gold-700: #7A5C18;--color-gold-600: #9A7720;--color-gold-500: #B8973A;--color-gold-400: #CDB060;--color-gold-300: #DEC878;--color-gold-100: #F5EDD4;--color-cream-50: #FDFBF8;--color-cream-100: #F7F4EF;--color-cream-200: #EDE8DF;--color-cream-300: #DDD5C8;--color-text-primary: #1A2433;--color-text-secondary: #3D4F62;--color-text-muted: #6E7F8D;--color-text-light: #A0ADB7;--color-success: #2D7A4F;--color-success-light: #E8F5EE;--color-error: #C0392B;--color-error-light: #FDECEA;--color-warning: #B8973A;--color-warning-light: #FDF6E3;--color-info: #2A5B8F;--color-info-light: #EBF3FB;--color-primary: var(--color-navy-500);--color-primary-dark: var(--color-navy-700);--color-primary-light: var(--color-navy-400);--color-secondary: var(--color-gold-500);--color-white: #ffffff;--color-black: #000000;--color-gray-50: var(--color-cream-50);--color-gray-100: var(--color-cream-100);--color-gray-200: var(--color-cream-200);--color-gray-300: var(--color-cream-300);--color-gray-400: var(--color-text-light);--color-gray-500: var(--color-text-muted);--color-gray-600: var(--color-text-secondary);--color-gray-700: var(--color-text-secondary);--color-gray-800: var(--color-text-primary);--color-gray-900: var(--color-navy-900);--font-display: "DM Serif Display", "Noto Serif JP", Georgia, "Times New Roman", serif;--font-body: "Plus Jakarta Sans", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--line-height-tight: 1.25;--line-height-normal: 1.6;--line-height-relaxed: 1.8;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--border-radius-sm: .25rem;--border-radius-md: .5rem;--border-radius-lg: 1rem;--border-radius-xl: 1.5rem;--shadow-xs: 0 1px 3px rgba(10, 22, 40, .06);--shadow-sm: 0 2px 8px rgba(10, 22, 40, .08);--shadow-md: 0 4px 16px rgba(10, 22, 40, .1);--shadow-lg: 0 8px 32px rgba(10, 22, 40, .12);--shadow-xl: 0 16px 48px rgba(10, 22, 40, .16);--shadow-card: var(--shadow-md);--border-color: var(--color-cream-200);--border-color-strong: var(--color-cream-300);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--scrollbar-width: calc(100vw - 100%) ;--header-height: 64px;--footer-height: 80px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;height:100%;overflow-y:scroll;scrollbar-gutter:stable}@media(max-width:768px){html{overflow-y:auto;scrollbar-gutter:auto}}html{font-family:var(--font-body)}body{font-family:var(--font-body);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-cream-100);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;text-rendering:optimizeLegibility;padding-top:var(--header-height);padding-bottom:var(--footer-height)}body.tool-hero-body{padding-top:0;padding-bottom:0}#root{height:100%;display:flex;flex-direction:column}.App{min-height:100%;display:flex;flex-direction:column;flex:1}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:400;line-height:var(--line-height-tight);margin-bottom:var(--spacing-md);color:var(--color-navy-800);letter-spacing:-.01em}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base);font-weight:600}@media(max-width:768px){h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}}p{margin-bottom:var(--spacing-md)}a{color:var(--color-navy-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-navy-700)}.container{width:100%;margin-left:auto;margin-right:auto;padding-left:var(--spacing-md);padding-right:var(--spacing-md)}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px;padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.625rem var(--spacing-lg);border-radius:var(--border-radius-md);font-family:var(--font-body);font-weight:600;font-size:var(--font-size-sm);letter-spacing:.02em;text-decoration:none;border:1.5px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background-color:var(--color-navy-800);color:var(--color-white);border-color:var(--color-navy-800)}.btn-primary:hover{background-color:var(--color-navy-900);border-color:var(--color-navy-900);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:transparent;color:var(--color-navy-700);border-color:var(--color-navy-700)}.btn-secondary:hover{background-color:var(--color-navy-700);color:var(--color-white)}.btn-gold{background-color:var(--color-gold-500);color:var(--color-white);border-color:var(--color-gold-500)}.btn-gold:hover{background-color:var(--color-gold-600);border-color:var(--color-gold-600);transform:translateY(-1px);box-shadow:var(--shadow-md)}.section-title{font-family:var(--font-display);font-size:var(--font-size-2xl);color:var(--color-navy-800);position:relative;padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.section-title:after{content:"";position:absolute;left:0;bottom:0;width:48px;height:2px;background-color:var(--color-gold-500);border-radius:2px}.subsection-title{font-family:var(--font-body);font-size:var(--font-size-lg);font-weight:600;color:var(--color-navy-700);margin-bottom:var(--spacing-md)}.page-eyebrow{font-family:var(--font-body);font-size:.7rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--color-gold-400, #CDB060);margin:0 0 .5rem;display:block}.page-wrapper{display:flex;flex-direction:column;min-height:100%;flex:1}.page-main{flex:1;padding:var(--spacing-2xl) var(--spacing-md);overflow-x:hidden}.page-container{max-width:1100px;margin:0 auto;width:100%;min-width:0}.card{background-color:var(--color-white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);letter-spacing:.03em;text-transform:uppercase}.form-input,.form-select,.form-textarea{padding:.625rem var(--spacing-md);border:1.5px solid var(--border-color);border-radius:var(--border-radius-md);font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-navy-500);box-shadow:0 0 0 3px #2a5b8f1f}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:var(--color-cream-100);color:var(--color-text-muted);cursor:not-allowed}.scroll-reveal{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}.scroll-reveal.visible{opacity:1;transform:translateY(0)}.scroll-reveal-left{opacity:0;transform:translate(-28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}.scroll-reveal-left.visible{opacity:1;transform:translate(0)}.scroll-reveal-right{opacity:0;transform:translate(28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}.scroll-reveal-right.visible{opacity:1;transform:translate(0)}.scroll-delay-1{transition-delay:.05s}.scroll-delay-2{transition-delay:.12s}.scroll-delay-3{transition-delay:.19s}.scroll-delay-4{transition-delay:.26s}.scroll-delay-5{transition-delay:.33s}.scroll-delay-6{transition-delay:.4s}.scroll-delay-7{transition-delay:.47s}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--color-navy-500)}.text-white{color:var(--color-white)}.text-muted{color:var(--color-text-muted)}.bg-primary{background-color:var(--color-navy-800)}.bg-white{background-color:var(--color-white)}.bg-cream{background-color:var(--color-cream-100)}.hidden{display:none}@media(max-width:767px){.md\:hidden{display:none}}@media(min-width:768px){.md\:block{display:block}.md\:flex{display:flex}.md\:grid{display:grid}}@media(max-width:1023px){.lg\:hidden{display:none}}@media(min-width:1024px){.lg\:block{display:block}.lg\:flex{display:flex}.lg\:grid{display:grid}}
